Replace will_paginate with kaminari. Fixed foodcoop/users page.
This commit is contained in:
parent
1708df3f6c
commit
ab81ef09d5
17 changed files with 162 additions and 64 deletions
3
Gemfile
3
Gemfile
|
@ -21,11 +21,10 @@ gem 'mysql2'
|
||||||
gem "fastercsv"
|
gem "fastercsv"
|
||||||
gem 'prawn'
|
gem 'prawn'
|
||||||
gem 'haml-rails'
|
gem 'haml-rails'
|
||||||
gem "will_paginate", "~> 3.0.pre2"
|
gem 'kaminari'
|
||||||
gem 'client_side_validations'
|
gem 'client_side_validations'
|
||||||
gem 'simple_form'
|
gem 'simple_form'
|
||||||
gem 'rails3_acts_as_paranoid', "~>0.1.4"
|
gem 'rails3_acts_as_paranoid', "~>0.1.4"
|
||||||
gem 'meta_search'
|
|
||||||
gem 'inherited_resources'
|
gem 'inherited_resources'
|
||||||
gem 'localize_input', :git => "git://github.com/bennibu/localize_input.git"
|
gem 'localize_input', :git => "git://github.com/bennibu/localize_input.git"
|
||||||
gem 'wikicloth'
|
gem 'wikicloth'
|
||||||
|
|
14
Gemfile.lock
14
Gemfile.lock
|
@ -77,6 +77,9 @@ GEM
|
||||||
railties (>= 3.1.0, < 5.0)
|
railties (>= 3.1.0, < 5.0)
|
||||||
thor (~> 0.14)
|
thor (~> 0.14)
|
||||||
json (1.7.5)
|
json (1.7.5)
|
||||||
|
kaminari (0.14.1)
|
||||||
|
actionpack (>= 3.0.0)
|
||||||
|
activesupport (>= 3.0.0)
|
||||||
less (2.2.2)
|
less (2.2.2)
|
||||||
commonjs (~> 0.2.6)
|
commonjs (~> 0.2.6)
|
||||||
less-rails (2.2.3)
|
less-rails (2.2.3)
|
||||||
|
@ -87,11 +90,6 @@ GEM
|
||||||
i18n (>= 0.4.0)
|
i18n (>= 0.4.0)
|
||||||
mime-types (~> 1.16)
|
mime-types (~> 1.16)
|
||||||
treetop (~> 1.4.8)
|
treetop (~> 1.4.8)
|
||||||
meta_search (1.1.3)
|
|
||||||
actionpack (~> 3.1)
|
|
||||||
activerecord (~> 3.1)
|
|
||||||
activesupport (~> 3.1)
|
|
||||||
polyamorous (~> 0.5.0)
|
|
||||||
mime-types (1.19)
|
mime-types (1.19)
|
||||||
multi_json (1.3.6)
|
multi_json (1.3.6)
|
||||||
mysql2 (0.3.11)
|
mysql2 (0.3.11)
|
||||||
|
@ -99,8 +97,6 @@ GEM
|
||||||
Ascii85 (~> 1.0.0)
|
Ascii85 (~> 1.0.0)
|
||||||
hashery (~> 2.0)
|
hashery (~> 2.0)
|
||||||
ruby-rc4
|
ruby-rc4
|
||||||
polyamorous (0.5.0)
|
|
||||||
activerecord (~> 3.0)
|
|
||||||
polyglot (0.3.3)
|
polyglot (0.3.3)
|
||||||
prawn (0.12.0)
|
prawn (0.12.0)
|
||||||
pdf-reader (>= 0.9.0)
|
pdf-reader (>= 0.9.0)
|
||||||
|
@ -171,7 +167,6 @@ GEM
|
||||||
wikicloth (0.8.0)
|
wikicloth (0.8.0)
|
||||||
builder
|
builder
|
||||||
expression_parser
|
expression_parser
|
||||||
will_paginate (3.0.3)
|
|
||||||
|
|
||||||
PLATFORMS
|
PLATFORMS
|
||||||
ruby
|
ruby
|
||||||
|
@ -186,8 +181,8 @@ DEPENDENCIES
|
||||||
haml-rails
|
haml-rails
|
||||||
inherited_resources
|
inherited_resources
|
||||||
jquery-rails
|
jquery-rails
|
||||||
|
kaminari
|
||||||
localize_input!
|
localize_input!
|
||||||
meta_search
|
|
||||||
mysql2
|
mysql2
|
||||||
prawn
|
prawn
|
||||||
rails (= 3.2.8)
|
rails (= 3.2.8)
|
||||||
|
@ -200,4 +195,3 @@ DEPENDENCIES
|
||||||
twitter-bootstrap-rails
|
twitter-bootstrap-rails
|
||||||
uglifier (>= 1.0.3)
|
uglifier (>= 1.0.3)
|
||||||
wikicloth
|
wikicloth
|
||||||
will_paginate (~> 3.0.pre2)
|
|
||||||
|
|
|
@ -4,11 +4,16 @@ class Foodcoop::UsersController < ApplicationController
|
||||||
@users = User.order('nick ASC')
|
@users = User.order('nick ASC')
|
||||||
|
|
||||||
# if somebody uses the search field:
|
# if somebody uses the search field:
|
||||||
unless params[:query].blank?
|
unless params[:user_name].blank?
|
||||||
@users = @users.where(({:first_name.matches => "%#{params[:query]}%"}) | ({:last_name.matches => "%#{params[:query]}%"}) | ({:nick.matches => "%#{params[:query]}%"}))
|
@users = @users.where("first_name LIKE :user_name OR last_name LIKE :user_name OR nick LIKE :user_name",
|
||||||
|
user_name: "%#{params[:user_name]}%")
|
||||||
end
|
end
|
||||||
|
|
||||||
@users = @users.paginate(:page => params[:page], :per_page => @per_page)
|
if params[:ordergroup_name]
|
||||||
|
@users = @users.joins(:groups).where("groups.type = 'Ordergroup' AND groups.name LIKE ?", "%#{params[:ordergroup_name]}%")
|
||||||
|
end
|
||||||
|
|
||||||
|
@users = @users.page(params[:page]).per(@per_page).order('users.nick ASC')
|
||||||
|
|
||||||
respond_to do |format|
|
respond_to do |format|
|
||||||
format.html # index.html.haml
|
format.html # index.html.haml
|
||||||
|
|
|
@ -20,18 +20,11 @@ module ApplicationHelper
|
||||||
end
|
end
|
||||||
|
|
||||||
# Creates ajax-controlled-links for pagination
|
# Creates ajax-controlled-links for pagination
|
||||||
# see also the plugin "will_paginate"
|
|
||||||
def pagination_links_remote(collection, options = {})
|
def pagination_links_remote(collection, options = {})
|
||||||
per_page = options[:per_page] || @per_page
|
per_page = options[:per_page] || @per_page
|
||||||
params = options[:params] || {}
|
params = options[:params] || {}
|
||||||
|
|
||||||
# Translations
|
|
||||||
previous_label = '« ' + "Vorherige"
|
|
||||||
next_label = "Nächste" + ' »'
|
|
||||||
# Merge other url-options for will_paginate
|
|
||||||
params = params.merge({:per_page => per_page})
|
params = params.merge({:per_page => per_page})
|
||||||
will_paginate collection, :params => params, 'data-remote' => true,
|
paginate collection, :params => params, :remote => true
|
||||||
:previous_label => previous_label, :next_label => next_label
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Link-collection for per_page-options when using the pagination-plugin
|
# Link-collection for per_page-options when using the pagination-plugin
|
||||||
|
@ -42,9 +35,15 @@ module ApplicationHelper
|
||||||
|
|
||||||
links = per_page_options.map do |per_page|
|
links = per_page_options.map do |per_page|
|
||||||
params.merge!({:per_page => per_page})
|
params.merge!({:per_page => per_page})
|
||||||
per_page == current ? per_page : link_to(per_page, params, :remote => true)
|
link_class = 'btn'
|
||||||
|
link_class << ' disabled' if per_page == current
|
||||||
|
link_to(per_page, params, :remote => true, class: link_class)
|
||||||
end
|
end
|
||||||
"Pro Seite: #{links.join(" ")}".html_safe
|
|
||||||
|
content_tag :div, class: 'btn-group pull-right' do
|
||||||
|
links.join.html_safe
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def sort_td_class_helper(param)
|
def sort_td_class_helper(param)
|
||||||
|
|
|
@ -9,4 +9,12 @@ module MessagesHelper
|
||||||
end
|
end
|
||||||
"<b>#{link_to(h(subject), message)}</b> <span style='color:grey'>#{h(body)}</span>".html_safe
|
"<b>#{link_to(h(subject), message)}</b> <span style='color:grey'>#{h(body)}</span>".html_safe
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def link_to_new_message(options = {})
|
||||||
|
messages_params = options[:message_params] || nil
|
||||||
|
link_text = content_tag :id, nil, class: 'icon-envelope'
|
||||||
|
link_text << " #{options[:text]}" if options[:text].present?
|
||||||
|
link_to(link_text.html_safe, new_message_path(message: messages_params), class: 'btn',
|
||||||
|
title: 'Nachricht verschicken')
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,13 +1,8 @@
|
||||||
- unless params[:sort_by_ordergroups]
|
- unless params[:sort_by_ordergroups]
|
||||||
%p
|
- if User.count > 20
|
||||||
%table{:style => "width:100%"}
|
= items_per_page
|
||||||
%tr
|
= pagination_links_remote @users
|
||||||
%td
|
%table.table.table-striped
|
||||||
= pagination_links_remote @users, :update => :users
|
|
||||||
%td{:style => "text-align:right"}
|
|
||||||
- if @users.size > 20
|
|
||||||
= items_per_page :update => :users
|
|
||||||
%table.list
|
|
||||||
%thead
|
%thead
|
||||||
%tr
|
%tr
|
||||||
%th Benutzername
|
%th Benutzername
|
||||||
|
@ -17,13 +12,13 @@
|
||||||
%th Bestellgruppe
|
%th Bestellgruppe
|
||||||
%th Arbeitsgruppe(n)
|
%th Arbeitsgruppe(n)
|
||||||
%tbody
|
%tbody
|
||||||
- users = params[:sort_by_ordergroups] ? @users.sort { |a,b| a.ordergroup.name <=> b.ordergroup.name } : @users
|
- for user in @users
|
||||||
- for user in users
|
%tr
|
||||||
%tr{:class => cycle('even','odd', :name => 'users')}
|
%td= user.nick
|
||||||
%td= link_to user.nick, new_message_path(:message => {:mail_to => user.id}), :title => 'Send user an email'
|
%td= user.name if @current_user.role_admin? || user.settings["profile.nameIsPublic"] == '1'
|
||||||
%td=h user.name if @current_user.role_admin? || user.settings["profile.nameIsPublic"] == '1'
|
%td= user.email if @current_user.role_admin? || user.settings["profile.emailIsPublic"] == '1'
|
||||||
%td=h user.email if @current_user.role_admin? || user.settings["profile.emailIsPublic"] == '1'
|
%td= user.phone if @current_user.role_admin? || user.settings["profile.phoneIsPublic"] == '1'
|
||||||
%td=h user.phone if @current_user.role_admin? || user.settings["profile.phoneIsPublic"] == '1'
|
%td= user.ordergroup_name
|
||||||
%td=h user.ordergroup_name
|
%td= user.workgroups.collect(&:name).join(', ')
|
||||||
%td=h user.workgroups.collect(&:name).join(', ')
|
%td= link_to_new_message(message_params: {mail_to: user.id})
|
||||||
|
|
||||||
|
|
|
@ -1,24 +1,23 @@
|
||||||
%h1 Mitglieder der Foodcoop
|
- title "Mitglieder"
|
||||||
|
|
||||||
|
%section
|
||||||
%p
|
%p
|
||||||
%i
|
|
||||||
Hier kannst Du den Mitgliedern Deiner Foodcoop eine Nachricht schreiben.
|
Hier kannst Du den Mitgliedern Deiner Foodcoop eine Nachricht schreiben.
|
||||||
%br/
|
%br/
|
||||||
Damit Deine Kontaktdaten einzusehen sind, musst Du sie unter
|
Damit Deine Kontaktdaten einzusehen sind, musst Du sie unter
|
||||||
= link_to "Einstellungen", my_profile_path
|
= link_to "Einstellungen", my_profile_path
|
||||||
freigeben.
|
freigeben.
|
||||||
|
|
||||||
.left_column{:style => "width:100%"}
|
.well
|
||||||
.box_title
|
= form_tag foodcoop_users_path, :method => :get, :remote => true,
|
||||||
%h2 Übersicht
|
'data-submit-onchange' => true, class: 'form-search' do
|
||||||
.column_content
|
|
||||||
- unless params[:sort_by_ordergroups]
|
= text_field_tag :user_name, params[:user_name], class: 'input-medium search-query',
|
||||||
#user_filter{:style => "float:left; margin-right:2em;"}
|
placeholder: 'Name ...'
|
||||||
= form_tag foodcoop_users_path, :method => :get, :style=>"display:inline;", :id => 'user_search',
|
= text_field_tag :ordergroup_name, params[:ordergroup_name], class: 'input-medium search-query',
|
||||||
:remote => true, 'data-submit-onchange' => true do
|
placeholder: 'Bestelllgruppe ...'
|
||||||
%label{:for => 'article_name'} Suche nach Name:
|
%button.btn
|
||||||
= text_field_tag :query, params[:query], :size => 10
|
%i.icon-search
|
||||||
|
|
||||||
Nach Bestellgruppen sortieren:
|
|
||||||
= check_box_tag :sort_by_ordergroups, 1, params[:sort_by_ordergroups]
|
|
||||||
#users
|
#users
|
||||||
= render :partial => "users"
|
= render :partial => "users"
|
12
app/views/kaminari/_first_page.html.haml
Normal file
12
app/views/kaminari/_first_page.html.haml
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
-#
|
||||||
|
Link to the "First" page
|
||||||
|
- available local variables
|
||||||
|
url: url to the first page
|
||||||
|
current_page: a page object for the currently displayed page
|
||||||
|
num_pages: total number of pages
|
||||||
|
per_page: number of items to fetch per page
|
||||||
|
remote: data-remote
|
||||||
|
|
||||||
|
- unless current_page.first?
|
||||||
|
%li{:class => "first"}
|
||||||
|
= link_to_unless current_page.first?, raw(t 'views.pagination.first'), url, :remote => remote
|
11
app/views/kaminari/_gap.html.haml
Normal file
11
app/views/kaminari/_gap.html.haml
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
-#
|
||||||
|
Non-link tag that stands for skipped pages...
|
||||||
|
- available local variables
|
||||||
|
current_page: a page object for the currently displayed page
|
||||||
|
num_pages: total number of pages
|
||||||
|
per_page: number of items to fetch per page
|
||||||
|
remote: data-remote
|
||||||
|
|
||||||
|
%li{:class => "page gap disabled"}
|
||||||
|
%a{:href => "#", :onclick => "return false;"}
|
||||||
|
= raw(t 'views.pagination.truncate')
|
13
app/views/kaminari/_last_page.html.haml
Normal file
13
app/views/kaminari/_last_page.html.haml
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
-#
|
||||||
|
Link to the "Last" page
|
||||||
|
- available local variables
|
||||||
|
url: url to the last page
|
||||||
|
current_page: a page object for the currently displayed page
|
||||||
|
num_pages: total number of pages
|
||||||
|
per_page: number of items to fetch per page
|
||||||
|
remote: data-remote
|
||||||
|
|
||||||
|
- unless current_page.last?
|
||||||
|
%li{:class=>"last next"}
|
||||||
|
-# "next" class present for border styling in twitter bootstrap %>
|
||||||
|
= link_to_unless current_page.last?, raw(t 'views.pagination.last'), url, {:remote => remote}
|
12
app/views/kaminari/_next_page.html.haml
Normal file
12
app/views/kaminari/_next_page.html.haml
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
-#
|
||||||
|
Link to the "Next" page
|
||||||
|
- available local variables
|
||||||
|
url: url to the next page
|
||||||
|
current_page: a page object for the currently displayed page
|
||||||
|
num_pages: total number of pages
|
||||||
|
per_page: number of items to fetch per page
|
||||||
|
remote: data-remote
|
||||||
|
|
||||||
|
- unless current_page.last?
|
||||||
|
%li{:class=>"next_page"}
|
||||||
|
= link_to_unless current_page.last?, raw(t 'views.pagination.next'), url, :rel => 'next', :remote => remote
|
11
app/views/kaminari/_page.html.haml
Normal file
11
app/views/kaminari/_page.html.haml
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
-#
|
||||||
|
Link showing page number
|
||||||
|
- available local variables
|
||||||
|
page: a page object for "this" page
|
||||||
|
url: url to this page
|
||||||
|
current_page: a page object for the currently displayed page
|
||||||
|
num_pages: total number of pages
|
||||||
|
per_page: number of items to fetch per page
|
||||||
|
remote: data-remote
|
||||||
|
%li{:class=>"page #{' active' if page.current? }"}
|
||||||
|
= link_to page, url, opts = {:remote => remote, :rel => page.next? ? 'next' : page.prev? ? 'prev' : nil}
|
21
app/views/kaminari/_paginator.html.haml
Normal file
21
app/views/kaminari/_paginator.html.haml
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
-#
|
||||||
|
The container tag
|
||||||
|
- available local variables
|
||||||
|
current_page: a page object for the currently displayed page
|
||||||
|
num_pages: total number of pages
|
||||||
|
per_page: number of items to fetch per page
|
||||||
|
remote: data-remote
|
||||||
|
paginator: the paginator that renders the pagination tags inside
|
||||||
|
|
||||||
|
= paginator.render do
|
||||||
|
%nav.pagination
|
||||||
|
%ul
|
||||||
|
= first_page_tag unless current_page.first?
|
||||||
|
= prev_page_tag unless current_page.first?
|
||||||
|
- each_page do |page|
|
||||||
|
- if page.left_outer? || page.right_outer? || page.inside_window?
|
||||||
|
= page_tag page
|
||||||
|
- elsif !page.was_truncated?
|
||||||
|
= gap_tag
|
||||||
|
= next_page_tag unless current_page.last?
|
||||||
|
= last_page_tag unless current_page.last?
|
12
app/views/kaminari/_prev_page.html.haml
Normal file
12
app/views/kaminari/_prev_page.html.haml
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
-#
|
||||||
|
Link to the "Previous" page
|
||||||
|
- available local variables
|
||||||
|
url: url to the previous page
|
||||||
|
current_page: a page object for the currently displayed page
|
||||||
|
num_pages: total number of pages
|
||||||
|
per_page: number of items to fetch per page
|
||||||
|
remote: data-remote
|
||||||
|
|
||||||
|
- unless current_page.first?
|
||||||
|
%li{:class=>"prev"}
|
||||||
|
= link_to_unless current_page.first?, raw(t 'views.pagination.previous'), url, :rel => 'prev', :remote => remote
|
|
@ -10,6 +10,13 @@ de:
|
||||||
not_enough_apples:
|
not_enough_apples:
|
||||||
Um zu Bestellen brauchst Du mindestends %{stop_ordering_under} Äpfel.
|
Um zu Bestellen brauchst Du mindestends %{stop_ordering_under} Äpfel.
|
||||||
Momentan hat Deine Bestellgruppe aber nur %{apples} Äpfel.
|
Momentan hat Deine Bestellgruppe aber nur %{apples} Äpfel.
|
||||||
|
views:
|
||||||
|
pagination:
|
||||||
|
first: "«"
|
||||||
|
last: "»"
|
||||||
|
previous: "‹"
|
||||||
|
next: "›"
|
||||||
|
truncate: "..."
|
||||||
date:
|
date:
|
||||||
abbr_day_names:
|
abbr_day_names:
|
||||||
- So
|
- So
|
||||||
|
|
|
@ -38,9 +38,9 @@ SimpleNavigation::Configuration.run do |navigation|
|
||||||
end
|
end
|
||||||
|
|
||||||
primary.item :admin, 'Administration', '#', if: Proc.new { current_user.role_admin? } do |subnav|
|
primary.item :admin, 'Administration', '#', if: Proc.new { current_user.role_admin? } do |subnav|
|
||||||
subnav.item :users, 'Benutzerinnen', admin_users_path
|
subnav.item :users, 'Benutzerinnen', admin_users_path, id: nil
|
||||||
subnav.item :ordergroups, 'Bestellgruppen', admin_ordergroups_path
|
subnav.item :ordergroups, 'Bestellgruppen', admin_ordergroups_path, id: nil
|
||||||
subnav.item :workgroups, 'Arbeitsgruppen', admin_workgroups_path
|
subnav.item :workgroups, 'Arbeitsgruppen', admin_workgroups_path, id: nil
|
||||||
end
|
end
|
||||||
|
|
||||||
primary.item :divider, '', '#', class: 'divider'
|
primary.item :divider, '', '#', class: 'divider'
|
||||||
|
|
Loading…
Reference in a new issue