Sha256: b1b1142c18c7ca1354b64532b355bed6f424e1adf1105ef38b1b1228240d7c3a
Contents?: true
Size: 1.5 KB
Versions: 2
Compression:
Stored size: 1.5 KB
Contents
# See Pagy::Backend API documentation: https://ddnexus.github.io/pagy/docs/api/backend # frozen_string_literal: true class Pagy # Define a few generic methods to paginate a collection out of the box, # or any collection by overriding pagy_get_items and/or pagy_get_vars in your controller # See also the extras if you need specialized methods to paginate Arrays or other collections module Backend private # Return Pagy object and paginated items/results def pagy(collection, vars = {}) pagy = Pagy.new(pagy_get_vars(collection, vars)) [pagy, pagy_get_items(collection, pagy)] end # Sub-method called only by #pagy: here for easy customization of variables by overriding # You may need to override the count call for non AR collections def pagy_get_vars(collection, vars) pagy_set_items_from_params(vars) if defined?(ItemsExtra) vars[:count] ||= (count = collection.count(*vars[:count_args])).is_a?(Hash) ? count.size : count vars[:page] ||= pagy_get_page(vars) vars end # Get the page integer from the params # Overridable by the jsonapi extra def pagy_get_page(vars) (params[vars[:page_param] || DEFAULT[:page_param]] || 1).to_i end # Sub-method called only by #pagy: here for easy customization of record-extraction by overriding # You may need to override this method for collections without offset|limit def pagy_get_items(collection, pagy) collection.offset(pagy.offset).limit(pagy.items) end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
pagy-7.0.1 | lib/pagy/backend.rb |
pagy-7.0.0 | lib/pagy/backend.rb |