merge_requests_helper.rb 2.9 KB
Newer Older
D
Dmitriy Zaporozhets 已提交
1
module MergeRequestsHelper
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
  def new_mr_path_from_push_event(event)
    target_project = event.project.forked_from_project || event.project
    new_namespace_project_merge_request_path(
      event.project.namespace,
      event.project,
      new_mr_from_push_event(event, target_project)
    )
  end

  def new_mr_from_push_event(event, target_project)
    {
      merge_request: {
        source_project_id: event.project.id,
        target_project_id: target_project.id,
        source_branch: event.branch_name,
        target_branch: target_project.repository.root_ref
      }
    }
  end

22
  def mr_css_classes(mr)
D
Dmitriy Zaporozhets 已提交
23
    classes = "merge-request"
A
Andrew8xx8 已提交
24
    classes << " closed" if mr.closed?
D
Dmitriy Zaporozhets 已提交
25 26 27
    classes << " merged" if mr.merged?
    classes
  end
D
Dmitriy Zaporozhets 已提交
28

29
  def ci_build_details_path(merge_request)
30 31 32 33 34 35 36 37
    build_url = merge_request.source_project.ci_service.build_page(merge_request.last_commit.sha, merge_request.source_branch)
    parsed_url = URI.parse(build_url)

    unless parsed_url.userinfo.blank?
      parsed_url.userinfo = ''
    end

    parsed_url.to_s
D
Dmitriy Zaporozhets 已提交
38
  end
39 40 41

  def merge_path_description(merge_request, separator)
    if merge_request.for_fork?
42
      "Project:Branches: #{@merge_request.source_project_path}:#{@merge_request.source_branch} #{separator} #{@merge_request.target_project.path_with_namespace}:#{@merge_request.target_branch}"
43 44 45 46
    else
      "Branches: #{@merge_request.source_branch} #{separator} #{@merge_request.target_branch}"
    end
  end
47 48

  def issues_sentence(issues)
49 50 51 52 53
    # Sorting based on the `#123` or `group/project#123` reference will sort
    # local issues first.
    issues.map do |issue|
      issue.to_reference(@project)
    end.sort.to_sentence
54
  end
55 56 57 58 59 60 61 62

  def mr_change_branches_path(merge_request)
    new_namespace_project_merge_request_path(
      @project.namespace, @project,
      merge_request: {
        source_project_id: @merge_request.source_project_id,
        target_project_id: @merge_request.target_project_id,
        source_branch: @merge_request.source_branch,
63 64 65
        target_branch: @merge_request.target_branch,
      },
      change_branches: true
66 67
    )
  end
68 69

  def source_branch_with_namespace(merge_request)
D
Douwe Maan 已提交
70 71
    branch = link_to(merge_request.source_branch, namespace_project_commits_path(merge_request.source_project.namespace, merge_request.source_project, merge_request.source_branch))

72 73 74
    if merge_request.for_fork?
      namespace = link_to(merge_request.source_project_namespace,
        project_path(merge_request.source_project))
D
Douwe Maan 已提交
75
      namespace + ":" + branch
76
    else
D
Douwe Maan 已提交
77
      branch
78 79
    end
  end
80 81 82 83 84 85 86 87 88 89 90 91 92

  def format_mr_branch_names(merge_request)
    source_path = merge_request.source_project_path
    target_path = merge_request.target_project_path
    source_branch = merge_request.source_branch
    target_branch = merge_request.target_branch

    if source_path == target_path
      [source_branch, target_branch]
    else
      ["#{source_path}:#{source_branch}", "#{target_path}:#{target_branch}"]
    end
  end
D
Dmitriy Zaporozhets 已提交
93
end