2024-10-31 22:45:26 +07:00
|
|
|
package views
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/paging"
|
|
|
|
)
|
|
|
|
|
|
|
|
var availablePages = []int{5, 10, 20, 50, 100}
|
|
|
|
|
|
|
|
templ DtRowPerPage(url, hxTarget string, rowsPerPage int, q interface{}) {
|
|
|
|
<div class="max-w-sm space-y-3">
|
|
|
|
<select
|
|
|
|
name="limit"
|
|
|
|
id="dt_limit"
|
|
|
|
class="py-2 px-3 pe-9 block bg-neutral-900 border-neutral-700 rounded-lg text-sm focus:border-orange-400 focus:ring-orange-400"
|
|
|
|
hx-get={ fmt.Sprintf("%s?%s", url, paging.EncodedQuery(q, []string{"limit"})) }
|
|
|
|
hx-trigger="change"
|
|
|
|
hx-push-url="true"
|
|
|
|
hx-target={ hxTarget }
|
|
|
|
hx-swap="outerHTML"
|
|
|
|
>
|
|
|
|
<option disabled>CHOOSE</option>
|
|
|
|
for _, page := range availablePages {
|
|
|
|
<option
|
|
|
|
value={ fmt.Sprintf("%d", page) }
|
|
|
|
selected?={ page == rowsPerPage }
|
|
|
|
>{ fmt.Sprintf("%d", page) }</option>
|
|
|
|
}
|
|
|
|
</select>
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
|
2024-11-03 20:57:56 +07:00
|
|
|
// Sort TH table
|
|
|
|
//
|
|
|
|
// URL: Where the URL to get the results is
|
|
|
|
// HxTarget: Where the results will be displayed
|
|
|
|
// Title: The title of the column
|
|
|
|
// ExpectedSort: The expected sort, used to determine the sort direction indicator
|
|
|
|
// SortBy: The current sort by
|
|
|
|
// SortDir: The current sort direction
|
|
|
|
// Q: The current query
|
|
|
|
templ DtThSort(url, hxTarget, title, expectedSort, sortBy, sortDir string, q interface{}) {
|
|
|
|
if expectedSort == sortBy && sortDir== "asc" {
|
|
|
|
<th
|
|
|
|
scope="col"
|
|
|
|
class="cursor-pointer"
|
|
|
|
hx-push-url="true"
|
|
|
|
hx-target={ hxTarget }
|
|
|
|
hx-swap="outerHTML"
|
|
|
|
hx-get={ fmt.Sprintf("%s?sort_by=%s&sort_direction=desc&%s", url, expectedSort, paging.EncodedQuery(q, []string{"sort_by", "sort_direction"})) }
|
|
|
|
>{ title } ▾</th>
|
|
|
|
} else if expectedSort == sortBy && sortDir== "desc" {
|
|
|
|
<th
|
|
|
|
scope="col"
|
|
|
|
class="cursor-pointer"
|
|
|
|
hx-push-url="true"
|
|
|
|
hx-target={ hxTarget }
|
|
|
|
hx-swap="outerHTML"
|
|
|
|
hx-get={ string(templ.URL(fmt.Sprintf("%s?sort_by=%s&sort_direction=asc&%s", url, expectedSort, paging.EncodedQuery(q, []string{"sort_by", "sort_direction"})))) }
|
|
|
|
>{ title } ▴</th>
|
|
|
|
} else {
|
|
|
|
<th
|
|
|
|
scope="col"
|
|
|
|
class="cursor-pointer"
|
|
|
|
hx-push-url="true"
|
|
|
|
hx-target={ hxTarget }
|
|
|
|
hx-swap="outerHTML"
|
|
|
|
hx-get={ string(templ.URL(fmt.Sprintf("%s?sort_by=%s&sort_direction=desc&%s", url, expectedSort, paging.EncodedQuery(q, []string{"sort_by", "sort_direction"})))) }
|
|
|
|
>{ title } ▴▾</th>
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-10-31 22:45:26 +07:00
|
|
|
templ DtRowCount(currentPage, rowsPerPage, totalRows int) {
|
|
|
|
<div>
|
|
|
|
<p class="text-sm">
|
|
|
|
if totalRows <= 0 {
|
|
|
|
No entries found
|
|
|
|
} else {
|
|
|
|
<b>{ fmt.Sprintf("%d", (rowsPerPage * currentPage) - rowsPerPage + 1) }</b>
|
|
|
|
if rowsPerPage * currentPage > totalRows {
|
|
|
|
- <b>{ fmt.Sprintf("%d", totalRows) }</b>
|
|
|
|
} else {
|
|
|
|
- <b>{ fmt.Sprintf("%d", rowsPerPage * currentPage) }</b>
|
|
|
|
}
|
|
|
|
<b>/ { fmt.Sprintf("%d", totalRows) }</b>
|
|
|
|
}
|
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
|
|
|
|
templ DtPagination(url, hxTarget string, q interface{}, p paging.Pagination) {
|
|
|
|
<div>
|
|
|
|
<nav class="pagination inline-flex gap-x-2">
|
|
|
|
for _, page := range p.Pages {
|
|
|
|
if page == -1 {
|
|
|
|
<button class="cursor-not-allowed" disabled>...</button>
|
|
|
|
} else if page == p.CurrentPage {
|
|
|
|
<button class="active" disabled>{ fmt.Sprintf("%d", page) }</button>
|
|
|
|
} else {
|
|
|
|
<button
|
|
|
|
hx-get={ fmt.Sprintf("%s?%s&page=%d", url, paging.EncodedQuery(q, []string{"page"}), page) }
|
|
|
|
hx-push-url="true"
|
|
|
|
hx-target={ hxTarget }
|
|
|
|
hx-swap="outerHTML"
|
|
|
|
>{ fmt.Sprintf("%d", page) }</button>
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</nav>
|
|
|
|
</div>
|
|
|
|
}
|