pagy 4.1.0 → 4.5.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/config/pagy.rb +30 -24
- data/lib/javascripts/pagy.js +104 -93
- data/lib/locales/utils/i18n.rb +0 -1
- data/lib/locales/utils/loader.rb +7 -5
- data/lib/locales/utils/p11n.rb +24 -20
- data/lib/pagy.rb +50 -26
- data/lib/pagy/backend.rb +5 -3
- data/lib/pagy/console.rb +21 -0
- data/lib/pagy/countless.rb +12 -9
- data/lib/pagy/deprecation.rb +27 -0
- data/lib/pagy/exceptions.rb +7 -5
- data/lib/pagy/extras/arel.rb +4 -3
- data/lib/pagy/extras/array.rb +4 -3
- data/lib/pagy/extras/bootstrap.rb +62 -30
- data/lib/pagy/extras/bulma.rb +61 -38
- data/lib/pagy/extras/countless.rb +7 -5
- data/lib/pagy/extras/elasticsearch_rails.rb +8 -6
- data/lib/pagy/extras/foundation.rb +62 -32
- data/lib/pagy/extras/headers.rb +13 -9
- data/lib/pagy/extras/i18n.rb +7 -4
- data/lib/pagy/extras/items.rb +21 -26
- data/lib/pagy/extras/materialize.rb +59 -35
- data/lib/pagy/extras/metadata.rb +27 -21
- data/lib/pagy/extras/navs.rb +45 -20
- data/lib/pagy/extras/overflow.rb +12 -13
- data/lib/pagy/extras/searchkick.rb +9 -7
- data/lib/pagy/extras/semantic.rb +56 -30
- data/lib/pagy/extras/shared.rb +12 -11
- data/lib/pagy/extras/standalone.rb +58 -0
- data/lib/pagy/extras/support.rb +20 -11
- data/lib/pagy/extras/trim.rb +14 -9
- data/lib/pagy/extras/uikit.rb +65 -35
- data/lib/pagy/frontend.rb +62 -30
- metadata +6 -5
- data/lib/locales/README.md +0 -35
- data/pagy.gemspec +0 -16
data/lib/pagy/extras/navs.rb
CHANGED
@@ -1,5 +1,4 @@
|
|
1
1
|
# See the Pagy documentation: https://ddnexus.github.io/pagy/extras/navs
|
2
|
-
# encoding: utf-8
|
3
2
|
# frozen_string_literal: true
|
4
3
|
|
5
4
|
require 'pagy/extras/shared'
|
@@ -8,31 +7,57 @@ class Pagy
|
|
8
7
|
module Frontend
|
9
8
|
|
10
9
|
# Javascript pagination: it returns a nav and a JSON tag used by the Pagy.nav javascript
|
11
|
-
def pagy_nav_js(pagy,
|
12
|
-
|
13
|
-
|
14
|
-
|
10
|
+
def pagy_nav_js(pagy, deprecated_id=nil, pagy_id: nil, link_extra: '', steps: nil)
|
11
|
+
pagy_id = Pagy.deprecated_arg(:id, deprecated_id, :pagy_id, pagy_id) if deprecated_id
|
12
|
+
p_id = %( id="#{pagy_id}") if pagy_id
|
13
|
+
link = pagy_link_proc(pagy, link_extra: link_extra)
|
14
|
+
tags = { 'before' => pagy_nav_prev_html(pagy, link),
|
15
15
|
'link' => %(<span class="page">#{link.call(PAGE_PLACEHOLDER)}</span> ),
|
16
16
|
'active' => %(<span class="page active">#{pagy.page}</span> ),
|
17
|
-
'gap' => %(<span class="page gap">#{pagy_t
|
18
|
-
'after' =>
|
19
|
-
|
20
|
-
%(<nav
|
17
|
+
'gap' => %(<span class="page gap">#{pagy_t 'pagy.nav.gap'}</span> ),
|
18
|
+
'after' => pagy_nav_next_html(pagy, link) }
|
19
|
+
|
20
|
+
html = %(<nav#{p_id} class="pagy-njs pagy-nav-js pagination" role="navigation" aria-label="pager"></nav>)
|
21
|
+
html << pagy_json_tag(pagy, :nav, tags, pagy.sequels(steps))
|
21
22
|
end
|
22
23
|
|
23
24
|
# Javascript combo pagination: it returns a nav and a JSON tag used by the Pagy.combo_nav javascript
|
24
|
-
def pagy_combo_nav_js(pagy,
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
input
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
25
|
+
def pagy_combo_nav_js(pagy, deprecated_id=nil, pagy_id: nil, link_extra: '')
|
26
|
+
pagy_id = Pagy.deprecated_arg(:id, deprecated_id, :pagy_id, pagy_id) if deprecated_id
|
27
|
+
p_id = %( id="#{pagy_id}") if pagy_id
|
28
|
+
link = pagy_link_proc(pagy, link_extra: link_extra)
|
29
|
+
p_page = pagy.page
|
30
|
+
p_pages = pagy.pages
|
31
|
+
input = %(<input type="number" min="1" max="#{p_pages}" value="#{p_page}" style="padding: 0; text-align: center; width: #{p_pages.to_s.length+1}rem;">)
|
32
|
+
|
33
|
+
%(<nav#{p_id} class="pagy-combo-nav-js pagination" role="navigation" aria-label="pager">#{
|
34
|
+
pagy_nav_prev_html pagy, link
|
35
|
+
}<span class="pagy-combo-input" style="margin: 0 0.6rem;">#{
|
36
|
+
pagy_t 'pagy.combo_nav_js', page_input: input, count: p_page, pages: p_pages
|
37
|
+
}</span> #{
|
38
|
+
pagy_nav_next_html pagy, link
|
39
|
+
}</nav>#{
|
40
|
+
pagy_json_tag pagy, :combo_nav, p_page, pagy_marked_link(link)
|
41
|
+
})
|
35
42
|
end
|
36
43
|
|
44
|
+
private
|
45
|
+
|
46
|
+
def pagy_nav_prev_html(pagy, link)
|
47
|
+
if (p_prev = pagy.prev)
|
48
|
+
%(<span class="page prev">#{link.call p_prev, pagy_t('pagy.nav.prev'), 'aria-label="previous"'}</span> )
|
49
|
+
else
|
50
|
+
%(<span class="page prev disabled">#{pagy_t 'pagy.nav.prev'}</span> )
|
51
|
+
end
|
52
|
+
end
|
53
|
+
|
54
|
+
def pagy_nav_next_html(pagy, link)
|
55
|
+
if (p_next = pagy.next)
|
56
|
+
%(<span class="page next">#{link.call p_next, pagy_t('pagy.nav.next'), 'aria-label="next"'}</span>)
|
57
|
+
else
|
58
|
+
%(<span class="page next disabled">#{pagy_t 'pagy.nav.next'}</span>)
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
37
62
|
end
|
38
63
|
end
|
data/lib/pagy/extras/overflow.rb
CHANGED
@@ -1,10 +1,9 @@
|
|
1
1
|
# See the Pagy documentation: https://ddnexus.github.io/pagy/extras/overflow
|
2
|
-
# encoding: utf-8
|
3
2
|
# frozen_string_literal: true
|
4
3
|
|
5
4
|
class Pagy
|
6
5
|
|
7
|
-
module
|
6
|
+
module UseOverflowExtra
|
8
7
|
VARS[:overflow] = :empty_page
|
9
8
|
|
10
9
|
def overflow? = @overflow
|
@@ -19,12 +18,12 @@ class Pagy
|
|
19
18
|
raise # same as without the extra
|
20
19
|
when :last_page
|
21
20
|
initial_page = @vars[:page] # save the very initial page (even after re-run)
|
22
|
-
initialize
|
21
|
+
initialize vars.merge!(page: @last) # re-run with the last page
|
23
22
|
@vars[:page] = initial_page # restore the inital page
|
24
23
|
when :empty_page
|
25
24
|
@offset = @items = @from = @to = 0 # vars relative to the actual page
|
26
25
|
@prev = @last # prev relative to the actual page
|
27
|
-
extend
|
26
|
+
extend Series # special series for :empty_page
|
28
27
|
else
|
29
28
|
raise VariableError.new(self), "expected :overflow variable in [:last_page, :empty_page, :exception]; got #{@vars[:overflow].inspect}"
|
30
29
|
end
|
@@ -34,33 +33,33 @@ class Pagy
|
|
34
33
|
def series(size=@vars[:size])
|
35
34
|
@page = @last # series for last page
|
36
35
|
super(size).tap do |s| # call original series
|
37
|
-
|
38
|
-
|
36
|
+
s[s.index(@page.to_s)] = @page # string to integer (i.e. no current page)
|
37
|
+
@page = @vars[:page] # restore the actual page
|
39
38
|
end
|
40
39
|
end
|
41
40
|
end
|
42
41
|
|
43
42
|
end
|
44
|
-
prepend
|
43
|
+
prepend UseOverflowExtra
|
45
44
|
|
46
45
|
|
47
46
|
# support for Pagy::Countless
|
48
47
|
if defined?(Pagy::Countless)
|
49
48
|
class Countless
|
50
49
|
|
51
|
-
module
|
50
|
+
module UseOverflowExtra
|
52
51
|
|
53
52
|
def finalize(items)
|
54
53
|
@overflow = false
|
55
54
|
super
|
56
55
|
rescue OverflowError
|
57
|
-
@overflow = true
|
56
|
+
@overflow = true # add the overflow flag
|
58
57
|
case @vars[:overflow]
|
59
58
|
when :exception
|
60
|
-
raise
|
59
|
+
raise # same as without the extra
|
61
60
|
when :empty_page
|
62
|
-
@offset = @items = @from = @to = 0
|
63
|
-
@vars[:size] = []
|
61
|
+
@offset = @items = @from = @to = 0 # vars relative to the actual page
|
62
|
+
@vars[:size] = [] # no page in the series
|
64
63
|
self
|
65
64
|
else
|
66
65
|
raise VariableError.new(self), "expected :overflow variable in [:empty_page, :exception]; got #{@vars[:overflow].inspect}"
|
@@ -68,7 +67,7 @@ class Pagy
|
|
68
67
|
end
|
69
68
|
|
70
69
|
end
|
71
|
-
prepend
|
70
|
+
prepend UseOverflowExtra
|
72
71
|
|
73
72
|
end
|
74
73
|
end
|
@@ -1,5 +1,4 @@
|
|
1
1
|
# See the Pagy documentation: https://ddnexus.github.io/pagy/extras/searchkick
|
2
|
-
# encoding: utf-8
|
3
2
|
# frozen_string_literal: true
|
4
3
|
|
5
4
|
class Pagy
|
@@ -10,7 +9,7 @@ class Pagy
|
|
10
9
|
# returns an array used to delay the call of #search
|
11
10
|
# after the pagination variables are merged to the options
|
12
11
|
# it also pushes to the same array an eventually called method
|
13
|
-
def pagy_searchkick(term =
|
12
|
+
def pagy_searchkick(term = '*', **options, &block)
|
14
13
|
[self, term, options, block].tap do |args|
|
15
14
|
args.define_singleton_method(:method_missing){|*a| args += a}
|
16
15
|
end
|
@@ -27,7 +26,8 @@ class Pagy
|
|
27
26
|
end
|
28
27
|
|
29
28
|
# Add specialized backend methods to paginate Searchkick::Results
|
30
|
-
module Backend
|
29
|
+
module Backend
|
30
|
+
private
|
31
31
|
|
32
32
|
# Return Pagy object and results
|
33
33
|
def pagy_searchkick(pagy_search_args, vars={})
|
@@ -37,17 +37,19 @@ class Pagy
|
|
37
37
|
options[:page] = vars[:page]
|
38
38
|
results = model.search(term, **options, &block)
|
39
39
|
vars[:count] = results.total_count
|
40
|
+
|
40
41
|
pagy = Pagy.new(vars)
|
41
42
|
# with :last_page overflow we need to re-run the method in order to get the hits
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
43
|
+
return pagy_searchkick(pagy_search_args, vars.merge(page: pagy.page)) \
|
44
|
+
if defined?(Pagy::UseOverflowExtra) && pagy.overflow? && pagy.vars[:overflow] == :last_page
|
45
|
+
|
46
|
+
[ pagy, called.empty? ? results : results.send(*called) ]
|
46
47
|
end
|
47
48
|
|
48
49
|
# Sub-method called only by #pagy_searchkick: here for easy customization of variables by overriding
|
49
50
|
# the _collection argument is not available when the method is called
|
50
51
|
def pagy_searchkick_get_vars(_collection, vars)
|
52
|
+
pagy_set_items_from_params(vars) if defined?(UseItemsExtra)
|
51
53
|
vars[:items] ||= VARS[:items]
|
52
54
|
vars[:page] ||= (params[ vars[:page_param] || VARS[:page_param] ] || 1).to_i
|
53
55
|
vars
|
data/lib/pagy/extras/semantic.rb
CHANGED
@@ -1,5 +1,4 @@
|
|
1
1
|
# See the Pagy documentation: https://ddnexus.github.io/pagy/extras/semantic
|
2
|
-
# encoding: utf-8
|
3
2
|
# frozen_string_literal: true
|
4
3
|
|
5
4
|
require 'pagy/extras/shared'
|
@@ -8,48 +7,75 @@ class Pagy
|
|
8
7
|
module Frontend
|
9
8
|
|
10
9
|
# Pagination for semantic: it returns the html with the series of links to the pages
|
11
|
-
def pagy_semantic_nav(pagy)
|
12
|
-
|
10
|
+
def pagy_semantic_nav(pagy, pagy_id: nil, link_extra: '')
|
11
|
+
p_id = %( id="#{pagy_id}") if pagy_id
|
12
|
+
link = pagy_link_proc(pagy, link_extra: %(class="item" #{link_extra}"))
|
13
13
|
|
14
|
-
html = (
|
15
|
-
|
14
|
+
html = +%(<div#{p_id} class="pagy-semantic-nav ui pagination menu" aria-label="pager">)
|
15
|
+
html << pagy_semantic_prev_html(pagy, link)
|
16
16
|
pagy.series.each do |item| # series example: [1, :gap, 7, 8, "9", 10, 11, :gap, 36]
|
17
|
-
html <<
|
18
|
-
|
19
|
-
|
17
|
+
html << case item
|
18
|
+
when Integer then link.call item # page link
|
19
|
+
when String then %(<a class="item active">#{item}</a>) # current page
|
20
|
+
when :gap then %(<div class="disabled item">#{pagy_t 'pagy.nav.gap'}</div>) # page gap
|
20
21
|
end
|
21
22
|
end
|
22
|
-
html << (
|
23
|
-
|
24
|
-
%(<div class="pagy-semantic-nav ui pagination menu" aria-label="pager">#{html}</div>)
|
23
|
+
html << pagy_semantic_next_html(pagy, link)
|
24
|
+
html << %(</div>)
|
25
25
|
end
|
26
26
|
|
27
27
|
# Javascript pagination for semantic: it returns a nav and a JSON tag used by the Pagy.nav javascript
|
28
|
-
def pagy_semantic_nav_js(pagy,
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
28
|
+
def pagy_semantic_nav_js(pagy, deprecated_id=nil, pagy_id: nil, link_extra: '', steps: nil)
|
29
|
+
pagy_id = Pagy.deprecated_arg(:id, deprecated_id, :pagy_id, pagy_id) if deprecated_id
|
30
|
+
p_id = %( id="#{pagy_id}") if pagy_id
|
31
|
+
link = pagy_link_proc(pagy, link_extra: %(class="item" #{link_extra}))
|
32
|
+
tags = { 'before' => pagy_semantic_prev_html(pagy, link),
|
33
|
+
'link' => link.call(PAGE_PLACEHOLDER),
|
33
34
|
'active' => %(<a class="item active">#{pagy.page}</a>),
|
34
35
|
'gap' => %(<div class="disabled item">#{pagy_t('pagy.nav.gap')}</div>),
|
35
|
-
'after' => (
|
36
|
-
|
37
|
-
%(<div
|
36
|
+
'after' => pagy_semantic_next_html(pagy, link) }
|
37
|
+
|
38
|
+
html = %(<div#{p_id} class="pagy-njs pagy-semantic-nav-js ui pagination menu" role="navigation" aria-label="pager"></div>)
|
39
|
+
html << pagy_json_tag(pagy, :nav, tags, pagy.sequels(steps))
|
38
40
|
end
|
39
41
|
|
40
42
|
# Combo pagination for semantic: it returns a nav and a JSON tag used by the Pagy.combo_nav javascript
|
41
|
-
def pagy_semantic_combo_nav_js(pagy,
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
input
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
43
|
+
def pagy_semantic_combo_nav_js(pagy, deprecated_id=nil, pagy_id: nil, link_extra: '')
|
44
|
+
pagy_id = Pagy.deprecated_arg(:id, deprecated_id, :pagy_id, pagy_id) if deprecated_id
|
45
|
+
p_id = %( id="#{pagy_id}") if pagy_id
|
46
|
+
link = pagy_link_proc(pagy, link_extra: %(class="item" #{link_extra}))
|
47
|
+
p_page = pagy.page
|
48
|
+
p_pages = pagy.pages
|
49
|
+
input = %(<input type="number" min="1" max="#{p_pages}" value="#{p_page}" style="padding: 0; text-align: center; width: #{p_pages.to_s.length+1}rem; margin: 0 0.3rem">)
|
50
|
+
|
51
|
+
%(<div#{p_id} class="pagy-semantic-combo-nav-js ui compact menu" role="navigation" aria-label="pager">#{
|
52
|
+
pagy_semantic_prev_html pagy, link
|
53
|
+
}<div class="pagy-combo-input item">#{
|
54
|
+
pagy_t 'pagy.combo_nav_js', page_input: input, count: p_page, pages: p_pages
|
55
|
+
}</div> #{
|
56
|
+
pagy_semantic_next_html pagy, link
|
57
|
+
}</div>#{
|
58
|
+
pagy_json_tag pagy, :combo_nav, p_page, pagy_marked_link(link)
|
59
|
+
})
|
52
60
|
end
|
53
61
|
|
62
|
+
private
|
63
|
+
|
64
|
+
def pagy_semantic_prev_html(pagy, link)
|
65
|
+
if (p_prev = pagy.prev)
|
66
|
+
link.call p_prev, '<i class="left small chevron icon"></i>', 'aria-label="previous"'
|
67
|
+
else
|
68
|
+
+%(<div class="item disabled"><i class="left small chevron icon"></i></div>)
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
def pagy_semantic_next_html(pagy, link)
|
73
|
+
if (p_next = pagy.next)
|
74
|
+
link.call p_next, '<i class="right small chevron icon"></i>', 'aria-label="next"'
|
75
|
+
else
|
76
|
+
+%(<div class="item disabled"><i class="right small chevron icon"></i></div>)
|
77
|
+
end
|
78
|
+
end
|
79
|
+
|
54
80
|
end
|
55
81
|
end
|
data/lib/pagy/extras/shared.rb
CHANGED
@@ -1,4 +1,3 @@
|
|
1
|
-
# encoding: utf-8
|
2
1
|
# frozen_string_literal: true
|
3
2
|
|
4
3
|
require 'digest'
|
@@ -17,10 +16,13 @@ class Pagy
|
|
17
16
|
# "350" => [1, 2, :gap, 17, 18, 19, "20", 21, 22, 23, :gap, 49, 50],
|
18
17
|
# "550" => [1, 2, 3, :gap, 16, 17, 18, 19, "20", 21, 22, 23, 24, :gap, 48, 49, 50] }
|
19
18
|
# Notice: if :steps is false it will use the single {0 => @vars[:size]} size
|
20
|
-
def sequels
|
21
|
-
steps
|
22
|
-
|
23
|
-
|
19
|
+
def sequels(steps=nil)
|
20
|
+
steps ||= @vars[:steps] || {0 => @vars[:size]}
|
21
|
+
raise VariableError.new(self), "expected :steps to define the 0 width; got #{steps.inspect}" \
|
22
|
+
unless steps.key?(0)
|
23
|
+
{}.tap do |sequels|
|
24
|
+
steps.each {|width, size| sequels[width.to_s] = series(size)}
|
25
|
+
end
|
24
26
|
end
|
25
27
|
|
26
28
|
module Frontend
|
@@ -28,23 +30,22 @@ class Pagy
|
|
28
30
|
if defined?(Oj)
|
29
31
|
# it returns a script tag with the JSON-serialized args generated with the faster oj gem
|
30
32
|
def pagy_json_tag(pagy, *args)
|
31
|
-
args <<
|
33
|
+
args << pagy.vars[:page_param] if pagy.vars[:enable_trim_extra]
|
32
34
|
%(<script type="application/json" class="pagy-json">#{Oj.dump(args, mode: :strict)}</script>)
|
33
35
|
end
|
34
36
|
else
|
35
37
|
require 'json'
|
36
38
|
# it returns a script tag with the JSON-serialized args generated with the slower to_json
|
37
39
|
def pagy_json_tag(pagy, *args)
|
38
|
-
args <<
|
40
|
+
args << pagy.vars[:page_param] if pagy.vars[:enable_trim_extra]
|
39
41
|
%(<script type="application/json" class="pagy-json">#{args.to_json}</script>)
|
40
42
|
end
|
41
43
|
end
|
42
44
|
|
43
|
-
# it returns the SHA1 (fastest on modern ruby) string used as default `id` attribute by all the `*_js` tags
|
44
|
-
def pagy_id = "pagy-#{Digest::SHA1.hexdigest(caller(2..2)[0].split(':in')[0])}"
|
45
|
-
|
46
45
|
# it returns the marked link to used by pagy.js
|
47
|
-
def pagy_marked_link(link)
|
46
|
+
def pagy_marked_link(link)
|
47
|
+
link.call PAGE_PLACEHOLDER, '', 'style="display: none;"'
|
48
|
+
end
|
48
49
|
|
49
50
|
end
|
50
51
|
|
@@ -0,0 +1,58 @@
|
|
1
|
+
# See the Pagy documentation: https://ddnexus.github.io/pagy/extras/standalone
|
2
|
+
# frozen_string_literal: true
|
3
|
+
|
4
|
+
require 'uri'
|
5
|
+
class Pagy
|
6
|
+
|
7
|
+
# extracted from Rack::Utils and reformatted for rubocop
|
8
|
+
module QueryUtils
|
9
|
+
module_function
|
10
|
+
def escape(str)
|
11
|
+
URI.encode_www_form_component(str)
|
12
|
+
end
|
13
|
+
def build_nested_query(value, prefix = nil)
|
14
|
+
case value
|
15
|
+
when Array
|
16
|
+
value.map { |v| build_nested_query(v, "#{prefix}[]") }.join('&')
|
17
|
+
when Hash
|
18
|
+
value.map { |k, v| build_nested_query(v, prefix ? "#{prefix}[#{escape(k)}]" : escape(k)) }.delete_if(&:empty?).join('&')
|
19
|
+
when nil
|
20
|
+
prefix
|
21
|
+
else
|
22
|
+
raise ArgumentError, 'value must be a Hash' if prefix.nil?
|
23
|
+
"#{prefix}=#{escape(value)}"
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
module UseStandaloneExtra
|
29
|
+
# without any :url var it works exactly as the regular #pagy_url_for;
|
30
|
+
# with a defined :url variable it does not use rack/request
|
31
|
+
def pagy_url_for(pagy, page, deprecated_url=nil, absolute: nil)
|
32
|
+
absolute = Pagy.deprecated_arg(:url, deprecated_url, :absolute, absolute) if deprecated_url
|
33
|
+
pagy, page = Pagy.deprecated_order(pagy, page) if page.is_a?(Pagy)
|
34
|
+
p_vars = pagy.vars
|
35
|
+
if p_vars[:url]
|
36
|
+
url_string = p_vars[:url]
|
37
|
+
params = {}
|
38
|
+
else
|
39
|
+
url_string = "#{request.base_url if absolute}#{request.path}"
|
40
|
+
params = request.GET
|
41
|
+
end
|
42
|
+
params = params.merge(p_vars[:params])
|
43
|
+
params[p_vars[:page_param].to_s] = page
|
44
|
+
params[p_vars[:items_param].to_s] = p_vars[:items] if defined?(UseItemsExtra)
|
45
|
+
query_string = "?#{QueryUtils.build_nested_query(pagy_get_params(params))}" unless params.empty?
|
46
|
+
"#{url_string}#{query_string}#{p_vars[:fragment]}"
|
47
|
+
end
|
48
|
+
end
|
49
|
+
Helpers.prepend UseStandaloneExtra
|
50
|
+
|
51
|
+
# defines a dummy #params method if not already defined in the including module
|
52
|
+
module Backend
|
53
|
+
def self.included(controller)
|
54
|
+
controller.define_method(:params){{}} unless controller.method_defined?(:params)
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
end
|
data/lib/pagy/extras/support.rb
CHANGED
@@ -1,5 +1,4 @@
|
|
1
1
|
# See the Pagy documentation: https://ddnexus.github.io/pagy/extras/support
|
2
|
-
# encoding: utf-8
|
3
2
|
# frozen_string_literal: true
|
4
3
|
|
5
4
|
class Pagy
|
@@ -7,29 +6,39 @@ class Pagy
|
|
7
6
|
module Frontend
|
8
7
|
|
9
8
|
def pagy_prev_url(pagy)
|
10
|
-
pagy_url_for(pagy
|
9
|
+
pagy_url_for(pagy, pagy.prev) if pagy.prev
|
11
10
|
end
|
12
11
|
|
13
12
|
def pagy_next_url(pagy)
|
14
|
-
pagy_url_for(pagy
|
13
|
+
pagy_url_for(pagy, pagy.next) if pagy.next
|
15
14
|
end
|
16
15
|
|
17
|
-
def pagy_prev_link(pagy,
|
18
|
-
|
19
|
-
|
16
|
+
def pagy_prev_link(pagy, deprecated_text=nil, deprecated_link_extra=nil, text: pagy_t('pagy.nav.prev'), link_extra: '')
|
17
|
+
text = Pagy.deprecated_arg(:text, deprecated_text, :text, text) if deprecated_text
|
18
|
+
link_extra = Pagy.deprecated_arg(:link_extra, deprecated_link_extra, :link_extra, link_extra) if deprecated_link_extra
|
19
|
+
if pagy.prev
|
20
|
+
%(<span class="page prev"><a href="#{pagy_url_for(pagy, pagy.prev)}" rel="prev" aria-label="previous" #{pagy.vars[:link_extra]} #{link_extra}>#{text}</a></span>)
|
21
|
+
else
|
22
|
+
%(<span class="page prev disabled">#{text}</span>)
|
23
|
+
end
|
20
24
|
end
|
21
25
|
|
22
|
-
def pagy_next_link(pagy,
|
23
|
-
|
24
|
-
|
26
|
+
def pagy_next_link(pagy, deprecated_text=nil, deprecated_link_extra=nil, text: pagy_t('pagy.nav.next'), link_extra: '')
|
27
|
+
text = Pagy.deprecated_arg(:text, deprecated_text, :text, text) if deprecated_text
|
28
|
+
link_extra = Pagy.deprecated_arg(:link_extra, deprecated_link_extra, :link_extra, link_extra) if deprecated_link_extra
|
29
|
+
if pagy.next
|
30
|
+
%(<span class="page next"><a href="#{pagy_url_for(pagy, pagy.next)}" rel="next" aria-label="next" #{pagy.vars[:link_extra]} #{link_extra}>#{text}</a></span>)
|
31
|
+
else
|
32
|
+
%(<span class="page next disabled">#{text}</span>)
|
33
|
+
end
|
25
34
|
end
|
26
35
|
|
27
36
|
def pagy_prev_link_tag(pagy)
|
28
|
-
%(<link href="#{pagy_url_for(pagy
|
37
|
+
%(<link href="#{pagy_url_for(pagy, pagy.prev)}" rel="prev"/>) if pagy.prev
|
29
38
|
end
|
30
39
|
|
31
40
|
def pagy_next_link_tag(pagy)
|
32
|
-
%(<link href="#{pagy_url_for(pagy
|
41
|
+
%(<link href="#{pagy_url_for(pagy, pagy.next)}" rel="next"/>) if pagy.next
|
33
42
|
end
|
34
43
|
|
35
44
|
end
|