# frozen_string_literal: true module MergeRequestsHelper include Gitlab::Utils::StrongMemoize def new_mr_path_from_push_event(event) target_project = event.project.default_merge_request_target project_new_merge_request_path( 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 def mr_css_classes(mr) classes = ["merge-request"] classes << "closed" if mr.closed? classes << "merged" if mr.merged? classes.join(' ') end def merge_path_description(merge_request, separator) if merge_request.for_fork? "Project:Branches: #{@merge_request.source_project_path}:#{@merge_request.source_branch} #{separator} #{@merge_request.target_project.full_path}:#{@merge_request.target_branch}" else "Branches: #{@merge_request.source_branch} #{separator} #{@merge_request.target_branch}" end end def mr_change_branches_path(merge_request) project_new_merge_request_path( @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, target_branch: merge_request.target_branch }, change_branches: true ) end 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 def target_projects(project) MergeRequestTargetProjectFinder.new(current_user: current_user, source_project: project) .execute(include_routes: true) end def merge_request_button_visibility(merge_request, closed) 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_or_merged_without_fork? end def merge_request_version_path(project, merge_request, merge_request_diff, start_sha = nil) diffs_project_merge_request_path(project, merge_request, diff_id: merge_request_diff.id, start_sha: start_sha) end def merge_params(merge_request) { auto_merge_strategy: AutoMergeService::STRATEGY_MERGE_WHEN_PIPELINE_SUCCEEDS, should_remove_source_branch: true, sha: merge_request.diff_head_sha, squash: merge_request.squash_on_merge? } end def tab_link_for(merge_request, tab, options = {}, &block) data_attrs = { action: tab.to_s, target: "##{tab}", toggle: options.fetch(:force_link, false) ? '' : 'tabvue' } 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 def allow_collaboration_unavailable_reason(merge_request) return if merge_request.can_allow_collaboration?(current_user) 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 def merge_request_source_project_for_project(project = @project) unless can?(current_user, :create_merge_request_in, project) return end if can?(current_user, :create_merge_request_from, project) project else current_user.fork_of(project) end end def toggle_draft_merge_request_path(issuable) wip_event = issuable.work_in_progress? ? 'unwip' : 'wip' issuable_path(issuable, { merge_request: { wip_event: wip_event } }) end def user_merge_requests_counts @user_merge_requests_counts ||= begin assigned_count = assigned_issuables_count(:merge_requests) review_requested_count = review_requested_merge_requests_count total_count = assigned_count + review_requested_count counts = { assigned: assigned_count, review_requested: review_requested_count, total: total_count } if Feature.enabled?(:mr_attention_requests, default_enabled: :yaml) attention_requested_count = attention_requested_merge_requests_count counts[:attention_requested_count] = attention_requested_count counts[:total] = attention_requested_count end counts end end def reviewers_label(merge_request, include_value: true) reviewers = merge_request.reviewers if include_value sanitized_list = sanitize_name(reviewers.map(&:name).to_sentence) ns_('NotificationEmail|Reviewer: %{users}', 'NotificationEmail|Reviewers: %{users}', reviewers.count) % { users: sanitized_list } else ns_('NotificationEmail|Reviewer', 'NotificationEmail|Reviewers', reviewers.count) end end def diffs_tab_pane_data(project, merge_request, params) { "is-locked": merge_request.discussion_locked?, endpoint: diffs_project_merge_request_path(project, merge_request, 'json', params), endpoint_metadata: @endpoint_metadata_url, endpoint_batch: diffs_batch_project_json_merge_request_path(project, merge_request, 'json', params), endpoint_coverage: @coverage_path, help_page_path: help_page_path('user/discussions/index.md', anchor: 'suggest-changes'), current_user_data: @current_user_data, update_current_user_path: @update_current_user_path, project_path: project_path(merge_request.project), changes_empty_state_illustration: image_path('illustrations/merge_request_changes_empty.svg'), is_fluid_layout: fluid_layout.to_s, dismiss_endpoint: callouts_path, show_suggest_popover: show_suggest_popover?.to_s, show_whitespace_default: @show_whitespace_default.to_s, file_by_file_default: @file_by_file_default.to_s, default_suggestion_commit_message: default_suggestion_commit_message, source_project_default_url: @merge_request.source_project && default_url_to_repo(@merge_request.source_project), source_project_full_path: @merge_request.source_project&.full_path, is_forked: @project.forked?.to_s } end def award_emoji_merge_request_api_path(merge_request) if Feature.enabled?(:improved_emoji_picker, merge_request.project, default_enabled: :yaml) api_v4_projects_merge_requests_award_emoji_path(id: merge_request.project.id, merge_request_iid: merge_request.iid) end end private def review_requested_merge_requests_count current_user.review_requested_open_merge_requests_count end def attention_requested_merge_requests_count current_user.attention_requested_open_merge_requests_count end def default_suggestion_commit_message @project.suggestion_commit_message.presence || Gitlab::Suggestions::CommitMessage::DEFAULT_SUGGESTION_COMMIT_MESSAGE end end MergeRequestsHelper.prepend_mod_with('MergeRequestsHelper')