Module: Pagy::UrlHelpers

Overview

Provide the helpers to handle the url in frontend and backend

Instance Method Summary collapse

Instance Method Details

#pagy_set_query_params(page, vars, params) ⇒ Object

Add the page and items params Overridable by the jsonapi extra



22
23
24
25
# File 'lib/pagy/url_helpers.rb', line 22

def pagy_set_query_params(page, vars, params)
  params[vars[:page_param].to_s]  = page
  params[vars[:items_param].to_s] = vars[:items] if vars[:items_extra]
end

#pagy_url_for(pagy, page, absolute: false, **_) ⇒ Object

Return the URL for the page, relying on the params method and Rack by default. It supports all Rack-based frameworks (Sinatra, Padrino, Rails, …). For non-rack environments you can use the standalone extra



9
10
11
12
13
14
15
16
17
18
# File 'lib/pagy/url_helpers.rb', line 9

def pagy_url_for(pagy, page, absolute: false, **_)
  vars         = pagy.vars
  request_path = vars[:request_path].to_s.empty? ? request.path : vars[:request_path]
  pagy_params  = pagy.params.is_a?(Hash) ? pagy.params.transform_keys(&:to_s) : {}
  params       = request.GET.merge(pagy_params)
  pagy_set_query_params(page, vars, params)
  params       = pagy.params.call(params) if pagy.params.is_a?(Proc)
  query_string = "?#{Rack::Utils.build_nested_query(params)}"
  "#{request.base_url if absolute}#{request_path}#{query_string}#{vars[:fragment]}"
end