|
2 | 2 | # frozen_string_literal: true
|
3 | 3 |
|
4 | 4 | require 'pathname'
|
5 |
| -require_relative 'pagy/autoloading' |
| 5 | +require_relative 'pagy/autoload' |
6 | 6 |
|
7 | 7 | # Top superclass: it should define only what's common to all the subclasses
|
8 | 8 | class Pagy
|
| 9 | + autoload :Backend, 'pagy/backend' |
| 10 | + autoload :Frontend, 'pagy/frontend' |
| 11 | + autoload :I18n, 'pagy/i18n' |
| 12 | + autoload :UISupport, 'pagy/ui_support' |
| 13 | + autoload :Offset, 'pagy/offset' |
| 14 | + autoload :Keyset, 'pagy/keyset' |
| 15 | + autoload :ElasticsearchRails, 'pagy/mixins/elasticsearch_rails' |
| 16 | + autoload :Meilisearch, 'pagy/mixins/meilisearch' |
| 17 | + autoload :Searchkick, 'pagy/mixins/searchkick' |
| 18 | + |
9 | 19 | VERSION = '9.3.3'
|
10 | 20 | PAGE_TOKEN = 'P '
|
11 | 21 | LABEL_TOKEN = 'L'
|
@@ -41,66 +51,8 @@ def assign_vars(vars)
|
41 | 51 | cclass = cclass.superclass
|
42 | 52 | default = cclass::DEFAULT.merge(default)
|
43 | 53 | end
|
44 |
| - @vars = { **default, **vars.delete_if { |k, v| default.key?(k) && (v.nil? || v == '') } } |
45 |
| - end |
46 |
| - |
47 |
| - # Shared with KeysetForUI |
48 |
| - module SharedUIMethods |
49 |
| - attr_reader :in, :last, :prev |
50 |
| - alias pages last |
51 |
| - |
52 |
| - # Label for the current page. Allow the customization of the output (overridden by the calendar extra) |
53 |
| - def label = @page.to_s |
54 |
| - |
55 |
| - # Label for any page. Allow the customization of the output (overridden by the calendar extra) |
56 |
| - def label_for(page) = page.to_s |
57 |
| - |
58 |
| - # Return the array of page numbers and :gap e.g. [1, :gap, 8, "9", 10, :gap, 36] |
59 |
| - def series(size: @vars[:size], **_) |
60 |
| - raise VariableError.new(self, :size, 'to be an Integer >= 0', size) \ |
61 |
| - unless size.is_a?(Integer) && size >= 0 |
62 |
| - return [] if size.zero? |
63 |
| - |
64 |
| - [].tap do |series| |
65 |
| - if size >= @last |
66 |
| - series.push(*1..@last) |
67 |
| - else |
68 |
| - left = ((size - 1) / 2.0).floor # left half might be 1 page shorter for even size |
69 |
| - start = if @page <= left # beginning pages |
70 |
| - 1 |
71 |
| - elsif @page > (@last - size + left) # end pages |
72 |
| - @last - size + 1 |
73 |
| - else |
74 |
| - # intermediate pages |
75 |
| - @page - left |
76 |
| - end |
77 |
| - series.push(*start...start + size) |
78 |
| - # Set first and last pages plus gaps when needed, respecting the size |
79 |
| - if vars[:ends] && size >= 7 |
80 |
| - series[0] = 1 |
81 |
| - series[1] = :gap unless series[1] == 2 |
82 |
| - series[-2] = :gap unless series[-2] == @last - 1 |
83 |
| - series[-1] = @last |
84 |
| - end |
85 |
| - end |
86 |
| - series[series.index(@page)] = @page.to_s unless @overflow # overflow has no current page |
87 |
| - end |
88 |
| - end |
89 |
| - |
90 |
| - # `Pagy` instance method used by the `pagy*_nav_js` helpers. |
91 |
| - # Return the reverse sorted array of widths, series, and labels generated from the :steps hash |
92 |
| - # Notice: if :steps is false it will use the single {0 => @vars[:size]} size |
93 |
| - def sequels(steps: @vars[:steps] || { 0 => @vars[:size] }, **_) |
94 |
| - raise VariableError.new(self, :steps, 'to define the 0 width', steps) unless steps.key?(0) |
95 |
| - |
96 |
| - widths, series = steps.sort.reverse.map { |width, size| [width, series(size:)] }.transpose |
97 |
| - [widths, series, label_sequels(series)] |
98 |
| - end |
99 |
| - |
100 |
| - # Support for the Calendar API |
101 |
| - def label_sequels(*); end |
| 54 | + @vars = { **default, **vars.delete_if { |k, v| default.key?(k) && (v.nil? || v == '') } } |
102 | 55 | end
|
103 |
| - include Autoloading |
104 | 56 | end
|
105 | 57 |
|
106 | 58 | require_relative 'pagy/exceptions'
|
0 commit comments