Module: Merb::PaginationHelper
- Defined in:
- lib/merb-pagination/pagination_helper.rb
Instance Method Summary collapse
-
#paginate(current_page, page_count, options = {}) ⇒ Object
Given a page count and the current page, we generate a set of pagination links.
-
#paginate_with_route(current_page, page_count, route_name, params_for_route = {}, options = {}) ⇒ Object
paginate + some route parameters to generate more complex routes that let me avoid loathsome querystrings ;).
Instance Method Details
#paginate(current_page, page_count, options = {}) ⇒ Object
Given a page count and the current page, we generate a set of pagination links.
-
We use an inner and outer window into a list of links. For a set of
20 pages with the current page being 10: outer_window:
1 2 ..... 19 20
inner_window
5 6 7 8 9 10 11 12 13 14
This is totally adjustable, or can be turned off by giving the :inner_window setting a value of nil.
-
Options
- :class => <em>css_class</em
-
The CSS class to be given to the paginator div. Defaults to ‘paginated’
- :prev_label => text_for_previous_link
-
Defaults to ‘« Previous ’
- :next_labe => text_for_next_link
-
Defaults to ‘ Next »’
- :left_cut_label => text_for_cut
-
Used when the page numbers need to be cut off to prevent the set of pagination links from being too long. Defaults to ‘←’
- :right_cut_label => text_for_cut
-
Same as :left_cut_label but for the right side of numbers. Defaults to ‘→’
- :outer_window => number_of_pages
-
Sets the number of pages to include in the outer ‘window’ Defaults to 2
- :inner_window => number_of_pages
-
Sets the number of pags to include in the inner ‘window’ Defaults to 10
:default_css => use_paginator_provided_css
Use the default CSS provided by the paginator. If you want to do
your own custom styling of the paginator from scratch, set this to
false.
Defaults to true
:page_param => name_of_page_paramiter
Sets the name of the paramiter the paginator uses to return what
page is being requested.
Defaults to 'page'
:url => url_for_links
Provides the base url to use in the page navigation links.
Defaults to ''
126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 |
# File 'lib/merb-pagination/pagination_helper.rb', line 126 def paginate(current_page, page_count, = {}) .reverse_merge!({ :class => 'paginated', :prev_label => '« Previous ', :next_label => ' Next »', :left_cut_label => '←', :right_cut_label => '→', :outer_window => 2, :inner_window => 10, :default_css => true, :page_param => 'page', :url => '' }) url = .delete :url url << (url.include?('?') ? '&' : '?') << [:page_param] pages = { :all => (1 .. page_count).to_a, :left => [], :center => [], :right => [] } # Only worry about using our 'windows' if the page count is less then # our windows combined. if [:inner_window].nil? or (([:outer_window] *2) + [:inner_window] + 2) >= page_count pages[:center] = pages[:all] else pages[:left] = pages[:all][0, [:outer_window]] pages[:right] = pages[:all][page_count - [:outer_window], [:outer_window]] pages[:center] = case current_page # allow the inner 'window' to shift to right when close to the left edge # Ex: 1 2 [3] 4 5 6 7 8 9 ... 20 when -infinity .. ([:inner_window] / 2) +3 pages[:all][[:outer_window], [:inner_window]] + [[:right_cut_label]] # allow the inner 'window' to shift left when close to the right edge # Ex: 1 2 ... 12 13 14 15 16 [17] 18 19 20 when (page_count - ([:inner_window] / 2.0).ceil) -1 .. infinity [[:left_cut_label]] + pages[:all][page_count - [:inner_window] - [:outer_window], [:inner_window]] # Display the unshifed window # ex: 1 2 ... 5 6 7 [8] 9 10 11 ... 19 20 else [[:left_cut_label]] + pages[:all][current_page - ([:inner_window] / 2) -1, [:inner_window]] + [[:right_cut_label]] end end Builder::XmlMarkup.new.div(:class => [:class]) do |b| b.style {|s| s << %Q{ div.#{[:class]} ul, div.#{[:class]} ul li { display: inline; padding: 2px; } } } if [:default_css] b << (current_page <= 1 ? [:prev_label] : %Q{<a href="#{url}=#{current_page -1}">#{[:prev_label]}</a>}) b.ul do [pages[:left], pages[:center], pages[:right]].each do |p| p.each do |page_number| case page_number when String b.li(:class=>'more_marker') {|li| li << page_number} when current_page b.li(page_number, :class=>'current_page') else b.li { b.a(page_number, :href=>"#{url}=#{page_number}") } end end end end b << (current_page >= page_count ? [:next_label] : %Q{<a href="#{url}=#{current_page +1}">#{[:next_label]}</a>}) end end |
#paginate_with_route(current_page, page_count, route_name, params_for_route = {}, options = {}) ⇒ Object
paginate + some route parameters to generate more complex routes that let me avoid loathsome querystrings ;)
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 |
# File 'lib/merb-pagination/pagination_helper.rb', line 6 def paginate_with_route(current_page, page_count, route_name, params_for_route = {}, = {}) .reverse_merge!({ :class => 'paginated', :prev_label => '« Previous ', :next_label => ' Next »', :left_cut_label => '←', :right_cut_label => '→', :outer_window => 2, :inner_window => 10, :default_css => true, :page_param => 'page' }) pages = { :all => (1 .. page_count).to_a, :left => [], :center => [], :right => [] } # Only worry about using our 'windows' if the page count is less then # our windows combined. if [:inner_window].nil? or (([:outer_window] *2) + [:inner_window] + 2) >= page_count pages[:center] = pages[:all] else pages[:left] = pages[:all][0, [:outer_window]] pages[:right] = pages[:all][page_count - [:outer_window], [:outer_window]] pages[:center] = case current_page # allow the inner 'window' to shift to right when close to the left edge # Ex: 1 2 [3] 4 5 6 7 8 9 ... 20 when -infinity .. ([:inner_window] / 2) +3 pages[:all][[:outer_window], [:inner_window]] + [[:right_cut_label]] # allow the inner 'window' to shift left when close to the right edge # Ex: 1 2 ... 12 13 14 15 16 [17] 18 19 20 when (page_count - ([:inner_window] / 2.0).ceil) -1 .. infinity [[:left_cut_label]] + pages[:all][page_count - [:inner_window] - [:outer_window], [:inner_window]] # Display the unshifed window # ex: 1 2 ... 5 6 7 [8] 9 10 11 ... 19 20 else [[:left_cut_label]] + pages[:all][current_page - ([:inner_window] / 2) -1, [:inner_window]] + [[:right_cut_label]] end end Builder::XmlMarkup.new.div(:class => [:class]) do |b| b.style {|s| s << %Q{ div.#{[:class]} ul, div.#{[:class]} ul li { display: inline; padding: 2px; } } } if [:default_css] b << (current_page <= 1 ? [:prev_label] : link_to([:prev_label],url(route_name, params_for_route.merge(:page => current_page - 1))) ) b.ul do [pages[:left], pages[:center], pages[:right]].each do |p| p.each do |page_number| case page_number when String b.li(:class=>'more_marker') {|li| li << page_number} when current_page b.li(page_number, :class=>'current_page') else b.li { b.a(page_number, :href=> url(route_name, params_for_route.merge(:page => page_number)) ) } end end end end b << (current_page >= page_count ? [:next_label] : link_to([:next_label],url(route_name, params_for_route.merge(:page => current_page + 1))) ) end end |