Commit a667c713128b3dd8dece604e4aae3519ab7e57ed
1 parent
d8247012
Exists in
master
and in
4 other branches
repo branches and tags
Showing
7 changed files
with
62 additions
and
5 deletions
Show diff stats
app/assets/stylesheets/projects.css.scss
@@ -598,6 +598,7 @@ h4.middle-panel { | @@ -598,6 +598,7 @@ h4.middle-panel { | ||
598 | } | 598 | } |
599 | } | 599 | } |
600 | } | 600 | } |
601 | +.merge-tabs.repository .tab span{ background: url("images.png") no-repeat -38px -77px; } | ||
601 | .activities-tab span { background: url("images.png") no-repeat -161px -1px; } | 602 | .activities-tab span { background: url("images.png") no-repeat -161px -1px; } |
602 | .stat-tab span, | 603 | .stat-tab span, |
603 | .team-tab span, | 604 | .team-tab span, |
app/controllers/repositories_controller.rb
@@ -11,4 +11,12 @@ class RepositoriesController < ApplicationController | @@ -11,4 +11,12 @@ class RepositoriesController < ApplicationController | ||
11 | def show | 11 | def show |
12 | @activities = @project.fresh_commits(20) | 12 | @activities = @project.fresh_commits(20) |
13 | end | 13 | end |
14 | + | ||
15 | + def branches | ||
16 | + @branches = @project.repo.heads.sort_by(&:name) | ||
17 | + end | ||
18 | + | ||
19 | + def tags | ||
20 | + @tags = @project.repo.tags.sort_by(&:name).reverse | ||
21 | + end | ||
14 | end | 22 | end |
app/views/repositories/_head.html.haml
@@ -2,16 +2,16 @@ | @@ -2,16 +2,16 @@ | ||
2 | = link_to project_repository_path(@project), :class => "activities-tab tab #{'active' if current_page?(project_repository_path(@project)) }" do | 2 | = link_to project_repository_path(@project), :class => "activities-tab tab #{'active' if current_page?(project_repository_path(@project)) }" do |
3 | %span | 3 | %span |
4 | Activities | 4 | Activities |
5 | - = link_to "#", :class => "tab" do | 5 | + = link_to branches_project_repository_path(@project), :class => "tab #{'active' if current_page?(branches_project_repository_path(@project)) }" do |
6 | %span | 6 | %span |
7 | Branches | 7 | Branches |
8 | - = link_to "#", :class => "tab" do | 8 | + = link_to tags_project_repository_path(@project), :class => "tab #{'active' if current_page?(tags_project_repository_path(@project)) }" do |
9 | %span | 9 | %span |
10 | Tags | 10 | Tags |
11 | - = link_to "#", :class => "tab" do | 11 | + -#= link_to "#", :class => "tab" do |
12 | %span | 12 | %span |
13 | Hooks | 13 | Hooks |
14 | - = link_to "#", :class => "tab" do | 14 | + -#= link_to "#", :class => "tab" do |
15 | %span | 15 | %span |
16 | Deploy Keys | 16 | Deploy Keys |
17 | 17 |
@@ -0,0 +1,10 @@ | @@ -0,0 +1,10 @@ | ||
1 | += render "head" | ||
2 | +- unless @branches.empty? | ||
3 | + %div.update-data.ui-box.ui-box-small | ||
4 | + .data | ||
5 | + - @branches.each do |branch| | ||
6 | + %a.update-item{:href => project_commits_path(@project, :ref => branch.name)} | ||
7 | + %span.update-title{:style => "margin-bottom:0px;"} | ||
8 | + = branch.name | ||
9 | +- else | ||
10 | + %h3 No brances |
@@ -0,0 +1,10 @@ | @@ -0,0 +1,10 @@ | ||
1 | += render "head" | ||
2 | +- unless @tags.empty? | ||
3 | + %div.update-data.ui-box.ui-box-small | ||
4 | + .data | ||
5 | + - @tags.each do |tag| | ||
6 | + %a.update-item{:href => project_commits_path(@project, :ref => tag.name)} | ||
7 | + %span.update-title{:style => "margin-bottom:0px;"} | ||
8 | + = tag.name | ||
9 | +- else | ||
10 | + %h3 No tags |
config/routes.rb
@@ -46,7 +46,12 @@ Gitlab::Application.routes.draw do | @@ -46,7 +46,12 @@ Gitlab::Application.routes.draw do | ||
46 | get "files" | 46 | get "files" |
47 | end | 47 | end |
48 | 48 | ||
49 | - resource :repository | 49 | + resource :repository do |
50 | + member do | ||
51 | + get "branches" | ||
52 | + get "tags" | ||
53 | + end | ||
54 | + end | ||
50 | 55 | ||
51 | resources :refs, :only => [], :path => "/" do | 56 | resources :refs, :only => [], :path => "/" do |
52 | collection do | 57 | collection do |
spec/requests/repositories_spec.rb
@@ -31,5 +31,28 @@ describe "Repository" do | @@ -31,5 +31,28 @@ describe "Repository" do | ||
31 | page.all(:css, ".project-update").size.should == 20 | 31 | page.all(:css, ".project-update").size.should == 20 |
32 | end | 32 | end |
33 | end | 33 | end |
34 | + | ||
35 | + describe "GET /:project_name/repository/branches" do | ||
36 | + before do | ||
37 | + visit branches_project_repository_path(@project) | ||
38 | + end | ||
39 | + | ||
40 | + it "should have link to repo activities" do | ||
41 | + page.should have_content("Branches") | ||
42 | + page.should have_content("master") | ||
43 | + end | ||
44 | + end | ||
45 | + | ||
46 | + # TODO: Add new repo to seeds with tags list | ||
47 | + describe "GET /:project_name/repository/tags" do | ||
48 | + before do | ||
49 | + visit tags_project_repository_path(@project) | ||
50 | + end | ||
51 | + | ||
52 | + it "should have link to repo activities" do | ||
53 | + page.should have_content("Tags") | ||
54 | + page.should have_content("No tags") | ||
55 | + end | ||
56 | + end | ||
34 | end | 57 | end |
35 | 58 |