debian-mirror-gitlab/app/helpers/merge_requests_helper.rb

162 lines
5 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2014-09-02 18:07:02 +05:30
module MergeRequestsHelper
def new_mr_path_from_push_event(event)
2017-08-17 22:00:37 +05:30
target_project = event.project.default_merge_request_target
2017-09-10 17:25:29 +05:30
project_new_merge_request_path(
2014-09-02 18:07:02 +05:30
event.project,
new_mr_from_push_event(event, target_project)
)
end
def new_mr_from_push_event(event, target_project)
2015-04-26 12:48:37 +05:30
{
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
}
2014-09-02 18:07:02 +05:30
}
end
2015-04-26 12:48:37 +05:30
def mr_css_classes(mr)
2018-12-05 23:21:45 +05:30
classes = ["merge-request"]
classes << "closed" if mr.closed?
classes << "merged" if mr.merged?
classes.join(' ')
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
def ci_build_details_path(merge_request)
2016-08-24 12:49:21 +05:30
build_url = merge_request.source_project.ci_service.build_page(merge_request.diff_head_sha, merge_request.source_branch)
2019-07-07 11:18:12 +05:30
return unless build_url
2015-12-23 02:04:40 +05:30
parsed_url = URI.parse(build_url)
unless parsed_url.userinfo.blank?
parsed_url.userinfo = ''
end
parsed_url.to_s
2014-09-02 18:07:02 +05:30
end
def merge_path_description(merge_request, separator)
if merge_request.for_fork?
2017-09-10 17:25:29 +05:30
"Project:Branches: #{@merge_request.source_project_path}:#{@merge_request.source_branch} #{separator} #{@merge_request.target_project.full_path}:#{@merge_request.target_branch}"
2014-09-02 18:07:02 +05:30
else
"Branches: #{@merge_request.source_branch} #{separator} #{@merge_request.target_branch}"
end
end
2015-09-11 14:41:01 +05:30
def mr_change_branches_path(merge_request)
2017-09-10 17:25:29 +05:30
project_new_merge_request_path(
@project,
2015-09-11 14:41:01 +05:30
merge_request: {
2017-08-17 22:00:37 +05:30
source_project_id: merge_request.source_project_id,
target_project_id: merge_request.target_project_id,
source_branch: merge_request.source_branch,
2017-09-10 17:25:29 +05:30
target_branch: merge_request.target_branch
2015-12-23 02:04:40 +05:30
},
change_branches: true
2015-09-11 14:41:01 +05:30
)
end
2015-10-24 18:46:33 +05:30
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
2016-08-24 12:49:21 +05:30
2017-08-17 22:00:37 +05:30
def target_projects(project)
2018-03-17 18:26:18 +05:30
MergeRequestTargetProjectFinder.new(current_user: current_user, source_project: project)
.execute
2017-08-17 22:00:37 +05:30
end
2016-08-24 12:49:21 +05:30
def merge_request_button_visibility(merge_request, closed)
2018-12-05 23:21:45 +05:30
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?
2016-09-29 09:46:39 +05:30
end
def merge_request_version_path(project, merge_request, merge_request_diff, start_sha = nil)
2017-09-10 17:25:29 +05:30
diffs_project_merge_request_path(project, merge_request, diff_id: merge_request_diff.id, start_sha: start_sha)
2016-09-29 09:46:39 +05:30
end
def version_index(merge_request_diff)
2019-07-07 11:18:12 +05:30
return if @merge_request_diffs.empty?
2018-11-08 19:23:39 +05:30
2016-09-29 09:46:39 +05:30
@merge_request_diffs.size - @merge_request_diffs.index(merge_request_diff)
2016-08-24 12:49:21 +05:30
end
2016-11-03 12:29:30 +05:30
def different_base?(version1, version2)
version1 && version2 && version1.base_commit_sha != version2.base_commit_sha
end
2017-08-17 22:00:37 +05:30
def merge_params(merge_request)
{
2019-09-04 21:01:54 +05:30
auto_merge_strategy: AutoMergeService::STRATEGY_MERGE_WHEN_PIPELINE_SUCCEEDS,
2017-08-17 22:00:37 +05:30
should_remove_source_branch: true,
2018-11-08 19:23:39 +05:30
sha: merge_request.diff_head_sha,
squash: merge_request.squash
}
2017-08-17 22:00:37 +05:30
end
2018-03-17 18:26:18 +05:30
def tab_link_for(merge_request, tab, options = {}, &block)
data_attrs = {
action: tab.to_s,
target: "##{tab}",
2018-11-08 19:23:39 +05:30
toggle: options.fetch(:force_link, false) ? '' : 'tabvue'
2018-03-17 18:26:18 +05:30
}
url = case tab
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)
end
2018-11-08 19:23:39 +05:30
def allow_collaboration_unavailable_reason(merge_request)
return if merge_request.can_allow_collaboration?(current_user)
2018-03-27 19:54:05 +05:30
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
2018-05-09 12:01:36 +05:30
def merge_request_source_project_for_project(project = @project)
unless can?(current_user, :create_merge_request_in, project)
2019-07-07 11:18:12 +05:30
return
2018-05-09 12:01:36 +05:30
end
if can?(current_user, :create_merge_request_from, project)
project
else
current_user.fork_of(project)
end
end
2014-09-02 18:07:02 +05:30
end