Module: Pagy::UikitExtra

Included in:
Frontend
Defined in:
lib/pagy/extras/uikit.rb

Instance Method Summary collapse

Instance Method Details

#pagy_uikit_combo_nav_js(pagy, pagy_id: nil, link_extra: '') ⇒ Object

Javascript combo pagination for uikit: it returns a nav and a JSON tag used by the Pagy.combo_nav javascript



40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
# File 'lib/pagy/extras/uikit.rb', line 40

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   = %(<input type="number" min="1" max="#{p_pages}" value="#{
                p_page}" style="text-align: center; width: #{p_pages.to_s.length + 1}rem;">)

  %(<ul#{p_id} class="pagy-uikit-combo-nav-js uk-button-group uk-pagination uk-flex-center" #{
      pagy_json_attr pagy, :combo_nav, p_page, pagy_marked_link(link)
    }>#{
      pagy_uikit_prev_html pagy, link
    }<li>#{
      pagy_t 'pagy.combo_nav_js', page_input: input, count: p_page, pages: p_pages
    }</li>#{
      pagy_uikit_next_html pagy, link
    }</ul>)
end

#pagy_uikit_nav(pagy, pagy_id: nil, link_extra: '') ⇒ Object

Pagination for uikit: it returns the html with the series of links to the pages



9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# File 'lib/pagy/extras/uikit.rb', line 9

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 = +%(<ul#{p_id} class="pagy-uikit-nav uk-pagination uk-flex-center">#{pagy_uikit_prev_html pagy, link})
  pagy.series.each do |item|
    html << case item
            when Integer then %(<li>#{link.call item}</li>)
            when String  then %(<li class="uk-active"><span>#{item}</span></li>)
            when :gap    then %(<li class="uk-disabled"><span>#{pagy_t 'pagy.nav.gap'}</span></li>)
            end
  end
  html << pagy_uikit_next_html(pagy, link)
  html << %(</ul>)
end

#pagy_uikit_nav_js(pagy, pagy_id: nil, link_extra: '', steps: nil) ⇒ Object

Javascript pagination for uikit: it returns a nav and a JSON tag used by the Pagy.nav javascript



26
27
28
29
30
31
32
33
34
35
36
37
# File 'lib/pagy/extras/uikit.rb', line 26

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'   => %(<li>#{link.call(PAGE_PLACEHOLDER)}</li>),
           'active' => %(<li class="uk-active"><span>#{PAGE_PLACEHOLDER}</span></li>),
           'gap'    => %(<li class="uk-disabled"><span>#{pagy_t 'pagy.nav.gap'}</span></li>),
           'after'  => pagy_uikit_next_html(pagy, link) }

  %(<ul#{p_id} class="pagy-njs pagy-uikit-nav-js uk-pagination uk-flex-center" #{
    pagy_json_attr(pagy, :nav, tags, pagy.sequels(steps))}></ul>)
end