2017-09-10 17:25:29 +05:30
|
|
|
- @content_class = "limit-container-width" unless fluid_layout
|
2018-03-17 18:26:18 +05:30
|
|
|
- add_to_breadcrumbs "Merge Requests", project_merge_requests_path(@project)
|
|
|
|
- breadcrumb_title @merge_request.to_reference
|
2017-09-10 17:25:29 +05:30
|
|
|
- page_title "#{@merge_request.title} (#{@merge_request.to_reference})", "Merge Requests"
|
|
|
|
- page_description @merge_request.description
|
|
|
|
- page_card_attributes @merge_request.card_attributes
|
|
|
|
- content_for :page_specific_javascripts do
|
|
|
|
= webpack_bundle_tag('common_vue')
|
|
|
|
= webpack_bundle_tag('diff_notes')
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
.merge-request{ data: { mr_action: j(params[:tab].presence || 'show'), url: merge_request_path(@merge_request, format: :json), project_path: project_path(@merge_request.project) } }
|
2017-09-10 17:25:29 +05:30
|
|
|
= render "projects/merge_requests/mr_title"
|
|
|
|
|
|
|
|
.merge-request-details.issuable-details{ data: { id: @merge_request.project.id } }
|
|
|
|
= render "projects/merge_requests/mr_box"
|
|
|
|
|
|
|
|
- if @merge_request.source_branch_exists?
|
|
|
|
= render "projects/merge_requests/how_to_merge"
|
|
|
|
|
|
|
|
-# haml-lint:disable InlineJavaScript
|
|
|
|
:javascript
|
|
|
|
window.gl = window.gl || {};
|
2018-03-17 18:26:18 +05:30
|
|
|
window.gl.mrWidgetData = #{serialize_issuable(@merge_request, serializer: 'widget')}
|
2017-09-10 17:25:29 +05:30
|
|
|
|
|
|
|
#js-vue-mr-widget.mr-widget
|
|
|
|
|
|
|
|
- content_for :page_specific_javascripts do
|
|
|
|
= webpack_bundle_tag 'vue_merge_request_widget'
|
|
|
|
|
|
|
|
.content-block.content-block-small.emoji-list-container
|
|
|
|
= render 'award_emoji/awards_block', awardable: @merge_request, inline: true
|
|
|
|
|
|
|
|
.merge-request-tabs-holder{ class: ("js-tabs-affix" unless ENV['RAILS_ENV'] == 'test') }
|
|
|
|
.merge-request-tabs-container
|
|
|
|
.scrolling-tabs-container.inner-page-scroll-tabs.is-smaller
|
|
|
|
.fade-left= icon('angle-left')
|
|
|
|
.fade-right= icon('angle-right')
|
|
|
|
.nav-links.scrolling-tabs
|
|
|
|
%ul.merge-request-tabs
|
|
|
|
%li.notes-tab
|
2018-03-17 18:26:18 +05:30
|
|
|
= tab_link_for @merge_request, :show, force_link: @commit.present? do
|
2017-09-10 17:25:29 +05:30
|
|
|
Discussion
|
|
|
|
%span.badge= @merge_request.related_notes.user.count
|
|
|
|
- if @merge_request.source_project
|
|
|
|
%li.commits-tab
|
2018-03-17 18:26:18 +05:30
|
|
|
= tab_link_for @merge_request, :commits do
|
2017-09-10 17:25:29 +05:30
|
|
|
Commits
|
|
|
|
%span.badge= @commits_count
|
|
|
|
- if @pipelines.any?
|
|
|
|
%li.pipelines-tab
|
2018-03-17 18:26:18 +05:30
|
|
|
= tab_link_for @merge_request, :pipelines do
|
2017-09-10 17:25:29 +05:30
|
|
|
Pipelines
|
|
|
|
%span.badge.js-pipelines-mr-count= @pipelines.size
|
|
|
|
%li.diffs-tab
|
2018-03-17 18:26:18 +05:30
|
|
|
= tab_link_for @merge_request, :diffs do
|
2017-09-10 17:25:29 +05:30
|
|
|
Changes
|
|
|
|
%span.badge= @merge_request.diff_size
|
|
|
|
#resolve-count-app.line-resolve-all-container.prepend-top-10{ "v-cloak" => true }
|
|
|
|
%resolve-count{ "inline-template" => true, ":logged-out" => "#{current_user.nil?}" }
|
|
|
|
%div
|
|
|
|
.line-resolve-all{ "v-show" => "discussionCount > 0",
|
|
|
|
":class" => "{ 'has-next-btn': !loggedOut && resolvedDiscussionCount !== discussionCount }" }
|
|
|
|
%span.line-resolve-btn.is-disabled{ type: "button",
|
|
|
|
":class" => "{ 'is-active': resolvedDiscussionCount === discussionCount }" }
|
2018-03-17 18:26:18 +05:30
|
|
|
%template{ 'v-if' => 'resolvedDiscussionCount === discussionCount' }
|
|
|
|
= render 'shared/icons/icon_status_success_solid.svg'
|
|
|
|
%template{ 'v-else' => '' }
|
|
|
|
= render 'shared/icons/icon_resolve_discussion.svg'
|
2017-09-10 17:25:29 +05:30
|
|
|
%span.line-resolve-text
|
|
|
|
{{ resolvedDiscussionCount }}/{{ discussionCount }} {{ resolvedCountText }} resolved
|
|
|
|
= render "discussions/new_issue_for_all_discussions", merge_request: @merge_request
|
|
|
|
= render "discussions/jump_to_next"
|
|
|
|
|
|
|
|
.tab-content#diff-notes-app
|
|
|
|
#notes.notes.tab-pane.voting_notes
|
|
|
|
.row
|
|
|
|
%section.col-md-12
|
|
|
|
.issuable-discussion
|
|
|
|
= render "projects/merge_requests/discussion"
|
|
|
|
|
|
|
|
#commits.commits.tab-pane
|
|
|
|
-# This tab is always loaded via AJAX
|
|
|
|
#pipelines.pipelines.tab-pane
|
|
|
|
- if @pipelines.any?
|
|
|
|
= render 'projects/commit/pipelines_list', disable_initialization: true, endpoint: pipelines_project_merge_request_path(@project, @merge_request)
|
2018-03-17 18:26:18 +05:30
|
|
|
#diffs.diffs.tab-pane{ data: { "is-locked" => @merge_request.discussion_locked? } }
|
2017-09-10 17:25:29 +05:30
|
|
|
-# This tab is always loaded via AJAX
|
|
|
|
|
|
|
|
.mr-loading-status
|
|
|
|
= spinner
|
|
|
|
|
|
|
|
= render 'shared/issuable/sidebar', issuable: @merge_request
|
|
|
|
- if @merge_request.can_be_reverted?(current_user)
|
|
|
|
= render "projects/commit/change", type: 'revert', commit: @merge_request.merge_commit, title: @merge_request.title
|
|
|
|
- if @merge_request.can_be_cherry_picked?
|
|
|
|
= render "projects/commit/change", type: 'cherry-pick', commit: @merge_request.merge_commit, title: @merge_request.title
|