2016-09-26 23:07:31 -04:00
|
|
|
- commit = @repository.commit(branch.dereferenced_target)
|
2015-07-20 21:34:19 -04:00
|
|
|
- bar_graph_width_factor = @max_commits > 0 ? 100.0/@max_commits : 0
|
2016-01-15 05:10:55 -05:00
|
|
|
- diverging_commit_counts = @repository.diverging_commit_counts(branch)
|
2015-11-11 17:29:29 -05:00
|
|
|
- number_commits_behind = diverging_commit_counts[:behind]
|
|
|
|
- number_commits_ahead = diverging_commit_counts[:ahead]
|
2016-09-02 09:33:24 -04:00
|
|
|
- merge_project = can?(current_user, :create_merge_request, @project) ? @project : (current_user && current_user.fork_of(@project))
|
2016-12-22 07:22:05 -05:00
|
|
|
%li{ class: "js-branch-#{branch.name}" }
|
2015-09-07 05:44:00 -04:00
|
|
|
%div
|
2016-08-05 15:51:29 -04:00
|
|
|
= link_to namespace_project_tree_path(@project.namespace, @project, branch.name), class: 'item-title str-truncated' do
|
|
|
|
= branch.name
|
2015-12-02 08:58:27 -05:00
|
|
|
|
|
|
|
- if branch.name == @repository.root_ref
|
|
|
|
%span.label.label-primary default
|
|
|
|
- elsif @repository.merged_to_root_ref? branch.name
|
2016-12-22 07:22:05 -05:00
|
|
|
%span.label.label-info.has-tooltip{ title: "Merged into #{@repository.root_ref}" }
|
2015-12-02 08:58:27 -05:00
|
|
|
merged
|
2015-08-09 14:31:50 -04:00
|
|
|
|
2015-12-02 08:58:27 -05:00
|
|
|
- if @project.protected_branch? branch.name
|
|
|
|
%span.label.label-success
|
|
|
|
protected
|
2017-01-19 14:20:01 -05:00
|
|
|
.controls.hidden-xs<
|
2016-09-02 09:33:24 -04:00
|
|
|
- if merge_project && create_mr_button?(@repository.root_ref, branch.name)
|
2016-06-17 05:37:27 -04:00
|
|
|
= link_to create_mr_path(@repository.root_ref, branch.name), class: 'btn btn-default' do
|
2015-05-09 16:55:19 -04:00
|
|
|
Merge Request
|
|
|
|
|
2014-02-15 16:46:02 -05:00
|
|
|
- if branch.name != @repository.root_ref
|
2016-09-02 09:33:24 -04:00
|
|
|
= link_to namespace_project_compare_index_path(@project.namespace, @project, from: @repository.root_ref, to: branch.name), class: "btn btn-default #{'prepend-left-10' unless merge_project}", method: :post, title: "Compare" do
|
2014-02-15 16:46:02 -05:00
|
|
|
Compare
|
2013-09-12 14:39:27 -04:00
|
|
|
|
2017-03-13 12:00:07 -04:00
|
|
|
= render 'projects/buttons/download', project: @project, ref: branch.name, pipeline: @refs_pipelines[branch.name]
|
2016-07-17 20:04:45 -04:00
|
|
|
|
2016-09-20 16:44:07 -04:00
|
|
|
- if can?(current_user, :push_code, @project)
|
2016-10-18 04:19:18 -04:00
|
|
|
= link_to namespace_project_branch_path(@project.namespace, @project, branch.name),
|
2016-10-09 10:17:14 -04:00
|
|
|
class: "btn btn-remove remove-row js-ajax-loading-spinner #{can_remove_branch?(@project, branch.name) ? '' : 'disabled'}",
|
2016-10-18 04:19:18 -04:00
|
|
|
method: :delete,
|
|
|
|
data: { confirm: "Deleting the '#{branch.name}' branch cannot be undone. Are you sure?" },
|
|
|
|
remote: true,
|
|
|
|
"aria-label" => "Delete branch" do
|
2015-05-09 16:55:19 -04:00
|
|
|
= icon("trash-o")
|
2013-07-16 15:19:07 -04:00
|
|
|
|
2015-07-20 21:34:19 -04:00
|
|
|
- if branch.name != @repository.root_ref
|
2015-11-11 17:29:29 -05:00
|
|
|
.divergence-graph{ title: "#{number_commits_ahead} commits ahead, #{number_commits_behind} commits behind #{@repository.root_ref}" }
|
2015-07-20 21:34:19 -04:00
|
|
|
.graph-side
|
2015-11-11 17:29:29 -05:00
|
|
|
.bar.bar-behind{ style: "width: #{number_commits_behind * bar_graph_width_factor}%" }
|
2015-07-20 21:34:19 -04:00
|
|
|
%span.count.count-behind= number_commits_behind
|
|
|
|
.graph-separator
|
|
|
|
.graph-side
|
2015-11-11 17:29:29 -05:00
|
|
|
.bar.bar-ahead{ style: "width: #{number_commits_ahead * bar_graph_width_factor}%" }
|
2015-07-20 21:34:19 -04:00
|
|
|
%span.count.count-ahead= number_commits_ahead
|
|
|
|
|
|
|
|
|
2014-02-03 11:13:24 -05:00
|
|
|
- if commit
|
2015-09-07 05:44:00 -04:00
|
|
|
= render 'projects/branches/commit', commit: commit, project: @project
|
2014-02-03 11:13:24 -05:00
|
|
|
- else
|
|
|
|
%p
|
|
|
|
Cant find HEAD commit for this branch
|