BigW Consortium Gitlab

_branch.html.haml 2.73 KB
Newer Older
1
- commit = @repository.commit(branch.dereferenced_target)
2
- bar_graph_width_factor = @max_commits > 0 ? 100.0/@max_commits : 0
3
- diverging_commit_counts = @repository.diverging_commit_counts(branch)
4 5
- number_commits_behind = diverging_commit_counts[:behind]
- number_commits_ahead = diverging_commit_counts[:ahead]
6
- merge_project = can?(current_user, :create_merge_request, @project) ? @project : (current_user && current_user.fork_of(@project))
7
%li(class="js-branch-#{branch.name}")
8
  %div
9 10
    = link_to namespace_project_tree_path(@project.namespace, @project, branch.name), class: 'item-title str-truncated' do
      = branch.name
11 12 13 14
     
    - if branch.name == @repository.root_ref
      %span.label.label-primary default
    - elsif @repository.merged_to_root_ref? branch.name
15
      %span.label.label-info.has-tooltip(title="Merged into #{@repository.root_ref}")
16
        merged
17

18 19 20 21
    - if @project.protected_branch? branch.name
      %span.label.label-success
        %i.fa.fa-lock
        protected
22
    .controls.hidden-xs
23
      - if merge_project && create_mr_button?(@repository.root_ref, branch.name)
24
        = link_to create_mr_path(@repository.root_ref, branch.name), class: 'btn btn-default' do
25 26
          Merge Request

27
      - if branch.name != @repository.root_ref
28
        = 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
29
          Compare
30

31
      = render 'projects/buttons/download', project: @project, ref: branch.name
32

33
      - if can?(current_user, :push_code, @project)
34 35 36 37 38 39
        = link_to namespace_project_branch_path(@project.namespace, @project, branch.name),
          class: "btn btn-remove remove-row #{can_remove_branch?(@project, branch.name) ? '' : 'disabled'}",
          method: :delete,
          data: { confirm: "Deleting the '#{branch.name}' branch cannot be undone. Are you sure?" },
          remote: true,
          "aria-label" => "Delete branch" do
40
          = icon("trash-o")
41

42
    - if branch.name != @repository.root_ref
43
      .divergence-graph{ title: "#{number_commits_ahead} commits ahead, #{number_commits_behind} commits behind #{@repository.root_ref}" }
44
        .graph-side
45
          .bar.bar-behind{ style: "width: #{number_commits_behind * bar_graph_width_factor}%" }
46 47 48
          %span.count.count-behind= number_commits_behind
        .graph-separator
        .graph-side
49
          .bar.bar-ahead{ style: "width: #{number_commits_ahead * bar_graph_width_factor}%" }
50 51 52
          %span.count.count-ahead= number_commits_ahead


53
  - if commit
54
    = render 'projects/branches/commit', commit: commit, project: @project
55 56 57
  - else
    %p
      Cant find HEAD commit for this branch