56 lines
2.7 KiB
HTML
56 lines
2.7 KiB
HTML
|
{{ $pag := $.Paginator }}
|
|||
|
{{ if gt $pag.TotalPages 1 }}
|
|||
|
{{ $.Scratch.Set "dot_rendered" false }}
|
|||
|
|
|||
|
<nav class="flex items-center justify-center px-4 sm:px-0">
|
|||
|
<div class="flex flex-1 w-0">
|
|||
|
<div class="mx-auto border-t-2 border-indigo-300">
|
|||
|
<!-- Don't show on 1st and 2nd page -->
|
|||
|
{{ if and (ne $pag.PageNumber 1) (ne $pag.PageNumber 2) }}
|
|||
|
<a href="{{ $pag.First.URL }}" rel="first"
|
|||
|
class="inline-flex items-center px-4 pt-4 text-lg font-black text-indigo-600 dark:text-indigo-400">«
|
|||
|
First</a>
|
|||
|
{{ end }}
|
|||
|
|
|||
|
{{ if $pag.HasPrev }}
|
|||
|
<a href="{{ $pag.Prev.URL }}" rel="prev"
|
|||
|
class="inline-flex items-center px-4 pt-4 text-lg font-black text-indigo-600 dark:text-indigo-400">‹
|
|||
|
Prev</a>
|
|||
|
{{ end }}
|
|||
|
|
|||
|
{{ range $pag.Pagers }}
|
|||
|
{{ if eq . $pag }}
|
|||
|
<!-- Current Page -->
|
|||
|
<a class="font-black page-item active"><a href="{{ .URL }}"
|
|||
|
class="inline-flex items-center px-4 pt-4 text-lg font-medium text-indigo-600 dark:text-indigo-400">{{ .PageNumber }}</a>
|
|||
|
</a>
|
|||
|
{{ else if and (ge .PageNumber (sub $pag.PageNumber 2)) (le .PageNumber (add $pag.PageNumber 2)) }}
|
|||
|
{{ $.Scratch.Set "dot_rendered" false }}
|
|||
|
<!-- Render prev 2 page and next 2 pages -->
|
|||
|
<a class="page-item"><a href="{{ .URL }}"
|
|||
|
class="inline-flex items-center px-4 pt-4 text-lg font-medium text-indigo-600 dark:text-indigo-400">{{ .PageNumber }}</a>
|
|||
|
</a>
|
|||
|
{{ else if eq ($.Scratch.Get "dot_rendered") false }}
|
|||
|
<!-- render skip pages -->
|
|||
|
{{ $.Scratch.Set "dot_rendered" true }}
|
|||
|
<a class="page-item disabled"><a
|
|||
|
class="inline-flex items-center px-4 pt-4 text-lg font-medium text-indigo-600 dark:text-indigo-400">...</a>
|
|||
|
</a>
|
|||
|
{{ end }}
|
|||
|
{{ end }}
|
|||
|
|
|||
|
{{ if $pag.HasNext }}
|
|||
|
<a class="page-item"><a href="{{ $pag.Next.URL }}" rel="next"
|
|||
|
class="inline-flex items-center px-4 pt-4 text-lg font-black text-indigo-600 dark:text-indigo-400">Next
|
|||
|
›</a></a>
|
|||
|
{{ end }}
|
|||
|
|
|||
|
<!-- Don't show on last and 2nd last page -->
|
|||
|
{{ if and (ne $pag.PageNumber $pag.TotalPages) ((ne $pag.PageNumber (sub $pag.TotalPages 1))) }}
|
|||
|
<a class="page-item"><a href="{{ $pag.Last.URL }}" rel="last"
|
|||
|
class="inline-flex items-center px-4 pt-4 text-lg font-black text-indigo-600 dark:text-indigo-400">Last
|
|||
|
»</a></a>
|
|||
|
{{ end }}
|
|||
|
</div>
|
|||
|
</nav>
|
|||
|
{{ end }}
|