# See the Pagy documentation: https://ddnexus.github.io/pagy/extras/uikit
# frozen_string_literal: true
require 'pagy/extras/shared'
class Pagy
module UikitExtra
# Pagination for uikit: it returns the html with the series of links to the pages
def pagy_uikit_nav(pagy, pagy_id: nil, link_extra: '')
p_id = %( id="#{pagy_id}") if pagy_id
link = pagy_link_proc(pagy, link_extra: link_extra)
html = +%(
#{pagy_uikit_prev_html pagy, link})
pagy.series.each do |item|
html << case item
when Integer then %(
#{link.call item}
)
when String then %(
#{item}
)
when :gap then %(
#{pagy_t 'pagy.nav.gap'}
)
end
end
html << pagy_uikit_next_html(pagy, link)
html << %(
)
end
# Javascript pagination for uikit: it returns a nav and a JSON tag used by the Pagy.nav javascript
def pagy_uikit_nav_js(pagy, pagy_id: nil, link_extra: '', steps: nil)
p_id = %( id="#{pagy_id}") if pagy_id
link = pagy_link_proc(pagy, link_extra: link_extra)
tags = { 'before' => pagy_uikit_prev_html(pagy, link),
'link' => %(
)
end
# Javascript combo pagination for uikit: it returns a nav and a JSON tag used by the Pagy.combo_nav javascript
def pagy_uikit_combo_nav_js(pagy, pagy_id: nil, link_extra: '')
p_id = %( id="#{pagy_id}") if pagy_id
link = pagy_link_proc(pagy, link_extra: link_extra)
p_page = pagy.page
p_pages = pagy.pages
input = %()
%(