merge_requests_helper.rb 3.9 KB
Newer Older
D
Dmitriy Zaporozhets 已提交
1
module MergeRequestsHelper
2
  def new_mr_path_from_push_event(event)
3
    target_project = event.project.default_merge_request_target
4
    project_new_merge_request_path(
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
      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

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

28
  def ci_build_details_path(merge_request)
29
    build_url = merge_request.source_project.ci_service.build_page(merge_request.diff_head_sha, merge_request.source_branch)
30 31
    return nil unless build_url

32 33 34 35 36 37 38
    parsed_url = URI.parse(build_url)

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

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

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

49
  def mr_change_branches_path(merge_request)
50 51
    project_new_merge_request_path(
      @project,
52
      merge_request: {
53 54 55
        source_project_id: merge_request.source_project_id,
        target_project_id: merge_request.target_project_id,
        source_branch: merge_request.source_branch,
56
        target_branch: merge_request.target_branch
57 58
      },
      change_branches: true
59 60
    )
  end
61

62 63 64 65 66 67 68 69 70 71 72 73
  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
74

75
  def target_projects(project)
76 77
    MergeRequestTargetProjectFinder.new(current_user: current_user, source_project: project)
      .execute
78 79
  end

80
  def merge_request_button_visibility(merge_request, closed)
81
    return 'hidden' if merge_request.closed? == closed || (merge_request.merged? == closed && !merge_request.closed?) || merge_request.closed_without_fork?
82
  end
83

84
  def merge_request_version_path(project, merge_request, merge_request_diff, start_sha = nil)
85
    diffs_project_merge_request_path(project, merge_request, diff_id: merge_request_diff.id, start_sha: start_sha)
86
  end
87 88 89 90

  def version_index(merge_request_diff)
    @merge_request_diffs.size - @merge_request_diffs.index(merge_request_diff)
  end
91 92 93 94

  def different_base?(version1, version2)
    version1 && version2 && version1.base_commit_sha != version2.base_commit_sha
  end
S
Sean McGivern 已提交
95 96 97

  def merge_params(merge_request)
    {
J
James Lopez 已提交
98
      merge_when_pipeline_succeeds: true,
S
Sean McGivern 已提交
99 100 101 102 103
      should_remove_source_branch: true,
      sha: merge_request.diff_head_sha
    }.merge(merge_params_ee(merge_request))
  end

104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127
  def tab_link_for(tab, options={}, &block)
    data_attrs = {
      action: tab.to_s,
      target: "##{tab.to_s}",
      toggle: options.fetch(:force_link, false) ? '' : 'tab'
    }

    url = case tab
    when :show
      data_attrs.merge!(target: '#notes')
      project_merge_request_path(@project, @merge_request)
    when :commits
      commits_project_merge_request_path(@project, @merge_request)
    when :pipelines
      pipelines_project_merge_request_path(@project, @merge_request)
    when :diffs
      diffs_project_merge_request_path(@project, @merge_request)
    else
      raise "Cannot create tab #{tab}."
    end

    link_to(url, data: data_attrs, &block)
  end

S
Sean McGivern 已提交
128 129 130
  def merge_params_ee(merge_request)
    {}
  end
D
Dmitriy Zaporozhets 已提交
131
end