gitlab-org--gitlab-foss/app/views/projects/branches/_branch.html.haml

75 lines
3.6 KiB
Text
Raw Normal View History

2017-10-27 11:55:08 -04:00
- merged = local_assigns.fetch(:merged, false)
- commit = @repository.commit(branch.dereferenced_target)
2018-04-06 12:27:12 -04:00
- merge_project = merge_request_source_project_for_project(@project)
%li{ class: "branch-item js-branch-item js-branch-#{branch.name}", data: { name: branch.name } }
2018-03-18 08:34:35 -04:00
.branch-info
.branch-title
= sprite_icon('fork', size: 12)
= link_to project_tree_path(@project, branch.name), class: 'item-title str-truncated-100 ref-name prepend-left-8 qa-branch-name' do
2018-03-18 08:34:35 -04:00
= branch.name
- if branch.name == @repository.root_ref
%span.badge.badge-primary.prepend-left-5 default
2018-03-18 08:34:35 -04:00
- elsif merged
%span.badge.badge-info.has-tooltip.prepend-left-5{ title: s_('Branches|Merged into %{default_branch}') % { default_branch: @repository.root_ref } }
2018-03-18 08:34:35 -04:00
= s_('Branches|merged')
2015-08-09 14:31:50 -04:00
2018-03-18 08:34:35 -04:00
- if protected_branch?(@project, branch)
%span.badge.badge-success.prepend-left-5
2018-03-18 08:34:35 -04:00
= s_('Branches|protected')
2019-06-11 16:12:11 -04:00
= render_if_exists 'projects/branches/diverged_from_upstream', branch: branch
2018-03-18 08:34:35 -04:00
.block-truncated
- if commit
= render 'projects/branches/commit', commit: commit, project: @project
- else
= s_('Branches|Cant find HEAD commit for this branch')
2013-09-12 14:39:27 -04:00
2018-03-18 08:34:35 -04:00
- if branch.name != @repository.root_ref
.js-branch-divergence-graph
.controls.d-none.d-md-block<
2018-03-18 08:34:35 -04:00
- if merge_project && create_mr_button?(@repository.root_ref, branch.name)
2018-05-10 15:22:56 -04:00
= link_to create_mr_path(@repository.root_ref, branch.name), class: 'btn btn-default' do
2018-03-18 08:34:35 -04:00
= _('Merge request')
- if branch.name != @repository.root_ref
= link_to project_compare_index_path(@project, from: @repository.root_ref, to: branch.name),
class: "btn btn-default js-onboarding-compare-branches #{'prepend-left-10' unless merge_project}",
method: :post,
2018-03-18 08:34:35 -04:00
title: s_('Branches|Compare') do
= s_('Branches|Compare')
2018-03-18 08:34:35 -04:00
= render 'projects/buttons/download', project: @project, ref: branch.name, pipeline: @refs_pipelines[branch.name]
2018-03-18 08:34:35 -04:00
- if can?(current_user, :push_code, @project)
- if branch.name == @project.repository.root_ref
%button{ class: "btn btn-remove remove-row js-ajax-loading-spinner has-tooltip disabled",
disabled: true,
title: s_('Branches|The default branch cannot be deleted') }
= icon("trash-o")
- elsif protected_branch?(@project, branch)
- if can?(current_user, :push_to_delete_protected_branch, @project)
2018-03-18 08:34:35 -04:00
%button{ class: "btn btn-remove remove-row js-ajax-loading-spinner has-tooltip",
title: s_('Branches|Delete protected branch'),
data: { toggle: "modal",
target: "#modal-delete-branch",
delete_path: project_branch_path(@project, branch.name),
branch_name: branch.name,
is_merged: ("true" if merged) } }
= icon("trash-o")
- else
%button{ class: "btn btn-remove remove-row js-ajax-loading-spinner has-tooltip disabled",
disabled: true,
2018-06-03 21:25:38 -04:00
title: s_('Branches|Only a project maintainer or owner can delete a protected branch') }
2018-03-18 08:34:35 -04:00
= icon("trash-o")
- else
= link_to project_branch_path(@project, branch.name),
class: "btn btn-remove remove-row qa-remove-btn js-ajax-loading-spinner has-tooltip",
2018-03-18 08:34:35 -04:00
title: s_('Branches|Delete branch'),
method: :delete,
data: { confirm: s_("Branches|Deleting the '%{branch_name}' branch cannot be undone. Are you sure?") % { branch_name: branch.name } },
remote: true,
'aria-label' => s_('Branches|Delete branch') do
= icon("trash-o")