merge_requests_helper.rb 4.96 KB
Newer Older
1 2
# frozen_string_literal: true

Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
3
module MergeRequestsHelper
4
  def new_mr_path_from_push_event(event)
5
    target_project = event.project.default_merge_request_target
6
    project_new_merge_request_path(
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
      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

23
  def mr_css_classes(mr)
24 25 26 27
    classes = ["merge-request"]
    classes << "closed" if mr.closed?
    classes << "merged" if mr.merged?
    classes.join(' ')
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
28
  end
29

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

34 35 36 37 38 39 40
    parsed_url = URI.parse(build_url)

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

    parsed_url.to_s
41
  end
42 43 44

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

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

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

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

82
  def merge_request_button_visibility(merge_request, closed)
83 84 85 86 87
    return 'hidden' if merge_request_button_hidden?(merge_request, closed)
  end

  def merge_request_button_hidden?(merge_request, closed)
    merge_request.closed? == closed || (merge_request.merged? == closed && !merge_request.closed?) || merge_request.closed_without_fork?
88
  end
89

90
  def merge_request_version_path(project, merge_request, merge_request_diff, start_sha = nil)
91
    diffs_project_merge_request_path(project, merge_request, diff_id: merge_request_diff.id, start_sha: start_sha)
92
  end
93 94

  def version_index(merge_request_diff)
Felipe Artur's avatar
Felipe Artur committed
95 96
    return nil if @merge_request_diffs.empty?

97 98
    @merge_request_diffs.size - @merge_request_diffs.index(merge_request_diff)
  end
99 100 101 102

  def different_base?(version1, version2)
    version1 && version2 && version1.base_commit_sha != version2.base_commit_sha
  end
103 104 105

  def merge_params(merge_request)
    {
106
      merge_when_pipeline_succeeds: true,
107
      should_remove_source_branch: true,
108 109 110
      sha: merge_request.diff_head_sha,
      squash: merge_request.squash
    }
111 112
  end

113
  def tab_link_for(merge_request, tab, options = {}, &block)
114 115
    data_attrs = {
      action: tab.to_s,
116
      target: "##{tab}",
117
      toggle: options.fetch(:force_link, false) ? '' : 'tabvue'
118 119 120
    }

    url = case tab
121 122 123 124 125 126 127 128 129 130 131 132 133 134
          when :show
            data_attrs[:target] = '#notes'
            method(:project_merge_request_path)
          when :commits
            method(:commits_project_merge_request_path)
          when :pipelines
            method(:pipelines_project_merge_request_path)
          when :diffs
            method(:diffs_project_merge_request_path)
          else
            raise "Cannot create tab #{tab}."
          end

    link_to(url[merge_request.project, merge_request], data: data_attrs, &block)
135 136
  end

137 138
  def allow_collaboration_unavailable_reason(merge_request)
    return if merge_request.can_allow_collaboration?(current_user)
139 140 141 142 143 144 145 146 147 148 149

    minimum_visibility = [merge_request.target_project.visibility_level,
                          merge_request.source_project.visibility_level].min

    if minimum_visibility < Gitlab::VisibilityLevel::INTERNAL
      _('Not available for private projects')
    elsif ProtectedBranch.protected?(merge_request.source_project, merge_request.source_branch)
      _('Not available for protected branches')
    end
  end

150 151 152 153 154 155 156 157 158 159 160
  def merge_request_source_project_for_project(project = @project)
    unless can?(current_user, :create_merge_request_in, project)
      return nil
    end

    if can?(current_user, :create_merge_request_from, project)
      project
    else
      current_user.fork_of(project)
    end
  end
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
161
end