Commit 22b1af59 authored by Phil Hughes's avatar Phil Hughes

Merge branch 'ee-44386-better-ux-for-long-name-branches' into 'master'

EE port of UX re-design branch items with flexbox

See merge request gitlab-org/gitlab-ee!5021
parents 2686c97d c56f7d12
.content-list > .branch-item,
.branch-title {
display: flex;
align-items: center;
}
.branch-info {
flex: auto;
min-width: 0;
overflow: hidden;
}
.divergence-graph { .divergence-graph {
padding: 12px 12px 0 0; padding: 0 6px;
float: right;
.graph-side { .graph-side {
position: relative; position: relative;
...@@ -53,3 +64,9 @@ ...@@ -53,3 +64,9 @@
background-color: $divergence-graph-separator-bg; background-color: $divergence-graph-separator-bg;
} }
} }
.divergence-graph,
.branch-item .controls {
flex: 0 0 auto;
white-space: nowrap;
}
...@@ -5,87 +5,87 @@ ...@@ -5,87 +5,87 @@
- number_commits_behind = diverging_commit_counts[:behind] - number_commits_behind = diverging_commit_counts[:behind]
- number_commits_ahead = diverging_commit_counts[:ahead] - number_commits_ahead = diverging_commit_counts[:ahead]
- merge_project = can?(current_user, :create_merge_request, @project) ? @project : (current_user && current_user.fork_of(@project)) - merge_project = can?(current_user, :create_merge_request, @project) ? @project : (current_user && current_user.fork_of(@project))
%li{ class: "js-branch-#{branch.name}" } %li{ class: "branch-item js-branch-#{branch.name}" }
%div .branch-info
= link_to project_tree_path(@project, branch.name), class: 'item-title str-truncated ref-name' do .branch-title
= sprite_icon('fork', size: 12) = link_to project_tree_path(@project, branch.name), class: 'item-title str-truncated-100 ref-name' do
= branch.name = sprite_icon('fork', size: 12)
  = branch.name
- if branch.name == @repository.root_ref  
%span.label.label-primary default - if branch.name == @repository.root_ref
- elsif merged %span.label.label-primary default
%span.label.label-info.has-tooltip{ title: s_('Branches|Merged into %{default_branch}') % { default_branch: @repository.root_ref } } - elsif merged
= s_('Branches|merged') %span.label.label-info.has-tooltip{ title: s_('Branches|Merged into %{default_branch}') % { default_branch: @repository.root_ref } }
= s_('Branches|merged')
- if protected_branch?(@project, branch) - if protected_branch?(@project, branch)
%span.label.label-success %span.label.label-success
= s_('Branches|protected') = s_('Branches|protected')
- if @project.mirror_ever_updated_successfully? && @repository.diverged_from_upstream?(branch.name) - if @project.mirror_ever_updated_successfully? && @repository.diverged_from_upstream?(branch.name)
%span.label.label-danger.has-tooltip{ data: { html: "true", title: branch_diverged_tooltip_message } } %span.label.label-danger.has-tooltip{ data: { html: "true", title: branch_diverged_tooltip_message } }
= icon('exclamation-triangle') = icon('exclamation-triangle')
= s_('Branches|diverged from upstream') = s_('Branches|diverged from upstream')
.controls.hidden-xs< .block-truncated
- if merge_project && create_mr_button?(@repository.root_ref, branch.name) - if commit
= link_to create_mr_path(@repository.root_ref, branch.name), class: 'btn btn-default' do = render 'projects/branches/commit', commit: commit, project: @project
= _('Merge request') - else
= s_('Branches|Cant find HEAD commit for this branch')
- if branch.name != @repository.root_ref - if branch.name != @repository.root_ref
= link_to project_compare_index_path(@project, from: @repository.root_ref, to: branch.name), .divergence-graph{ title: s_('%{number_commits_behind} commits behind %{default_branch}, %{number_commits_ahead} commits ahead') % { number_commits_behind: diverging_count_label(number_commits_behind),
class: "btn btn-default #{'prepend-left-10' unless merge_project}", default_branch: @repository.root_ref,
method: :post, number_commits_ahead: diverging_count_label(number_commits_ahead) } }
title: s_('Branches|Compare') do .graph-side
= s_('Branches|Compare') .bar.bar-behind{ style: "width: #{number_commits_behind * bar_graph_width_factor}%" }
%span.count.count-behind= diverging_count_label(number_commits_behind)
.graph-separator
.graph-side
.bar.bar-ahead{ style: "width: #{number_commits_ahead * bar_graph_width_factor}%" }
%span.count.count-ahead= diverging_count_label(number_commits_ahead)
= render 'projects/buttons/download', project: @project, ref: branch.name, pipeline: @refs_pipelines[branch.name] .controls.hidden-xs<
- if merge_project && create_mr_button?(@repository.root_ref, branch.name)
- if can?(current_user, :push_code, @project) = link_to create_mr_path(@repository.root_ref, branch.name), class: 'btn btn-default' do
- if branch.name == @project.repository.root_ref = _('Merge request')
%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, :delete_protected_branch, @project)
%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,
title: s_('Branches|Only a project master or owner can delete a protected branch') }
= icon("trash-o")
- else
= link_to project_branch_path(@project, branch.name),
class: "btn btn-remove remove-row js-ajax-loading-spinner has-tooltip",
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")
- if branch.name != @repository.root_ref - if branch.name != @repository.root_ref
.divergence-graph{ title: s_('%{number_commits_behind} commits behind %{default_branch}, %{number_commits_ahead} commits ahead') % { number_commits_behind: diverging_count_label(number_commits_behind), = link_to project_compare_index_path(@project, from: @repository.root_ref, to: branch.name),
default_branch: @repository.root_ref, class: "btn btn-default #{'prepend-left-10' unless merge_project}",
number_commits_ahead: diverging_count_label(number_commits_ahead) } } method: :post,
.graph-side title: s_('Branches|Compare') do
.bar.bar-behind{ style: "width: #{number_commits_behind * bar_graph_width_factor}%" } = s_('Branches|Compare')
%span.count.count-behind= diverging_count_label(number_commits_behind)
.graph-separator
.graph-side
.bar.bar-ahead{ style: "width: #{number_commits_ahead * bar_graph_width_factor}%" }
%span.count.count-ahead= diverging_count_label(number_commits_ahead)
= render 'projects/buttons/download', project: @project, ref: branch.name, pipeline: @refs_pipelines[branch.name]
- if commit - if can?(current_user, :push_code, @project)
= render 'projects/branches/commit', commit: commit, project: @project - if branch.name == @project.repository.root_ref
- else %button{ class: "btn btn-remove remove-row js-ajax-loading-spinner has-tooltip disabled",
%p disabled: true,
= s_('Branches|Cant find HEAD commit for this branch') title: s_('Branches|The default branch cannot be deleted') }
= icon("trash-o")
- elsif protected_branch?(@project, branch)
- if can?(current_user, :delete_protected_branch, @project)
%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,
title: s_('Branches|Only a project master or owner can delete a protected branch') }
= icon("trash-o")
- else
= link_to project_branch_path(@project, branch.name),
class: "btn btn-remove remove-row js-ajax-loading-spinner has-tooltip",
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")
---
title: UX re-design branch items with flexbox
merge_request: 17832
author: Takuya Noguchi
type: fixed
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment