summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2013-12-26 11:16:30 +0200
committerDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2013-12-26 11:16:30 +0200
commit6a0c0f3f3fc114a8b02e2d3f44539cf36534061c (patch)
tree8a79fe917adee3d018a147fb6aa80050d95c6287
parent8310b4589d0216cf7bb12eeee97785c3372690d9 (diff)
downloadgitlab-ce-6a0c0f3f3fc114a8b02e2d3f44539cf36534061c.tar.gz
Add sorting to public projects page
Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
-rw-r--r--app/assets/stylesheets/gitlab_bootstrap/forms.scss4
-rw-r--r--app/contexts/issues/list_context.rb3
-rw-r--r--app/controllers/public/projects_controller.rb9
-rw-r--r--app/views/public/projects/index.html.haml43
4 files changed, 44 insertions, 15 deletions
diff --git a/app/assets/stylesheets/gitlab_bootstrap/forms.scss b/app/assets/stylesheets/gitlab_bootstrap/forms.scss
index 1a310a75c31..39dd1f6c747 100644
--- a/app/assets/stylesheets/gitlab_bootstrap/forms.scss
+++ b/app/assets/stylesheets/gitlab_bootstrap/forms.scss
@@ -21,6 +21,10 @@ form {
text-align: left;
}
}
+
+ &.form-tiny {
+ margin: 0;
+ }
}
input.input-xpadding,
diff --git a/app/contexts/issues/list_context.rb b/app/contexts/issues/list_context.rb
index fd27356d1cd..b256fd4c732 100644
--- a/app/contexts/issues/list_context.rb
+++ b/app/contexts/issues/list_context.rb
@@ -29,7 +29,7 @@ module Issues
if params[:milestone_id].present?
@issues = @issues.where(milestone_id: (params[:milestone_id] == '0' ? nil : params[:milestone_id]))
end
-
+
# Sort by :sort param
@issues = sort(@issues, params[:sort])
@@ -49,6 +49,5 @@ module Issues
else issues
end
end
-
end
end
diff --git a/app/controllers/public/projects_controller.rb b/app/controllers/public/projects_controller.rb
index 8d66250d7b6..34425db72ab 100644
--- a/app/controllers/public/projects_controller.rb
+++ b/app/controllers/public/projects_controller.rb
@@ -8,6 +8,13 @@ class Public::ProjectsController < ApplicationController
def index
@projects = Project.public_or_internal_only(current_user)
@projects = @projects.search(params[:search]) if params[:search].present?
- @projects = @projects.includes(:namespace).order("namespaces.path, projects.name ASC").page(params[:page]).per(20)
+ @projects = case params[:sort]
+ when 'newest' then @projects.order('created_at DESC')
+ when 'oldest' then @projects.order('created_at ASC')
+ when 'recently_updated' then @projects.order('updated_at DESC')
+ when 'last_updated' then @projects.order('updated_at ASC')
+ else @projects.order("namespaces.path, projects.name ASC")
+ end
+ @projects = @projects.includes(:namespace).page(params[:page]).per(20)
end
end
diff --git a/app/views/public/projects/index.html.haml b/app/views/public/projects/index.html.haml
index b88169add3c..193d5c089a0 100644
--- a/app/views/public/projects/index.html.haml
+++ b/app/views/public/projects/index.html.haml
@@ -1,16 +1,35 @@
-.row
- .span6
- %h3.page-title
- Projects (#{@projects.total_count})
- .light
- You can browse public projects in read-only mode until signed in.
+%h3.page-title
+ Projects (#{@projects.total_count})
+.light
+ You can browse public projects in read-only mode until signed in.
+%hr
+.clearfix
+ .pull-left
+ = form_tag public_projects_path, method: :get, class: 'form-inline form-tiny' do |f|
+ .search-holder
+ = search_field_tag :search, params[:search], placeholder: "Filter by name", class: "span4 search-text-input", id: "projects_search"
+ = submit_tag 'Search', class: "btn btn-primary wide"
+
+ .pull-right
+ .dropdown.inline
+ %a.dropdown-toggle.btn{href: '#', "data-toggle" => "dropdown"}
+ %span.light sort:
+ - if @sort.present?
+ = @sort
+ - else
+ Newest
+ %b.caret
+ %ul.dropdown-menu
+ %li
+ = link_to public_projects_path(sort: 'newest') do
+ Newest
+ = link_to public_projects_path(sort: 'oldest') do
+ Oldest
+ = link_to public_projects_path(sort: 'recently_updated') do
+ Recently updated
+ = link_to public_projects_path(sort: 'last_updated') do
+ Last updated
- .span6
- .pull-right
- = form_tag public_projects_path, method: :get, class: 'form-inline' do |f|
- .search-holder
- = search_field_tag :search, params[:search], placeholder: "Filter by name", class: "span3 search-text-input", id: "projects_search"
- = submit_tag 'Search', class: "btn btn-primary wide"
%hr
.public-projects
%ul.bordered-list.top-list