mirror of
https://github.com/hrfee/jfa-go.git
synced 2025-01-22 00:00:10 +00:00
accounts: add indicator of sorted column at top of list
When clicking on a column to sort by it, a button with "Sorting By: <column>" appears. Clicking it will reset the sort, which defaults for ascending username.
This commit is contained in:
parent
f13c0d78a8
commit
bc4015ac50
@ -584,6 +584,7 @@
|
||||
<div class="row">
|
||||
<span class="text-3xl font-bold mr-2 col">{{ .strings.accounts }}</span>
|
||||
<input type="search" class="col sm field ~neutral @low input search ml-2 mr-2" id="accounts-search" placeholder="{{ .strings.search }}">
|
||||
<button type="button" class="button ~neutral @low center ml-2 mr-2 hidden"><span id="accounts-sort-by-field"></span> <span class="ml-2">×</span></button>
|
||||
</div>
|
||||
<div class="row">
|
||||
<span class="col sm button ~neutral @low center mb-2" id="accounts-add-user">{{ .quantityStrings.addUser.Singular }}</span>
|
||||
@ -615,22 +616,22 @@
|
||||
<thead>
|
||||
<tr>
|
||||
<th><input type="checkbox" value="" id="accounts-select-all"></th>
|
||||
<th class="table-inline my-2 accounts-header-username">{{ .strings.username }}</th>
|
||||
<th class="table-inline my-2 grid gap-4 place-items-stretch accounts-header-username">{{ .strings.username }}</th>
|
||||
{{ if .jellyfinLogin }}
|
||||
<th class="text-center-i accounts-header-access-jfa">{{ .strings.accessJFA }}</th>
|
||||
<th class="text-center-i grid gap-4 place-items-stretch accounts-header-access-jfa">{{ .strings.accessJFA }}</th>
|
||||
{{ end }}
|
||||
<th class="accounts-header-email">{{ .strings.emailAddress }}</th>
|
||||
<th class="grid gap-4 place-items-stretch accounts-header-email">{{ .strings.emailAddress }}</th>
|
||||
{{ if .telegramEnabled }}
|
||||
<th class="text-center-i accounts-header-telegram">Telegram</th>
|
||||
<th class="text-center-i grid gap-4 place-items-stretch accounts-header-telegram">Telegram</th>
|
||||
{{ end }}
|
||||
{{ if .matrixEnabled }}
|
||||
<th class="text-center-i accounts-header-matrix">Matrix</th>
|
||||
<th class="text-center-i grid gap-4 place-items-stretch accounts-header-matrix">Matrix</th>
|
||||
{{ end }}
|
||||
{{ if .discordEnabled }}
|
||||
<th class="text-center-i accounts-header-discord">Discord</th>
|
||||
<th class="text-center-i grid gap-4 place-items-stretch accounts-header-discord">Discord</th>
|
||||
{{ end }}
|
||||
<th class="accounts-header-expiry">{{ .strings.expiry }}</th>
|
||||
<th class="accounts-header-last-active">{{ .strings.lastActiveTime }}</th>
|
||||
<th class="grid gap-4 place-items-stretch accounts-header-expiry">{{ .strings.expiry }}</th>
|
||||
<th class="grid gap-4 place-items-stretch accounts-header-last-active">{{ .strings.lastActiveTime }}</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody id="accounts-list"></tbody>
|
||||
|
@ -114,7 +114,8 @@
|
||||
"deleteTemplate": "Delete template",
|
||||
"templateEnterName": "Enter a name to save this template.",
|
||||
"accessJFA": "Access jfa-go",
|
||||
"accessJFASettings": "Cannot be changed as either \"Admin Only\" or \"Allow All\" has been set in Settings > General."
|
||||
"accessJFASettings": "Cannot be changed as either \"Admin Only\" or \"Allow All\" has been set in Settings > General.",
|
||||
"sortingBy": "Sorting By"
|
||||
},
|
||||
"notifications": {
|
||||
"changedEmailAddress": "Changed email address of {n}.",
|
||||
|
@ -752,6 +752,7 @@ export class accountsList {
|
||||
private _columns: { [className: string]: Column } = {};
|
||||
private _activeSortColumn: string;
|
||||
|
||||
private _sortingByButton = document.getElementById("accounts-sort-by-field") as HTMLButtonElement;
|
||||
|
||||
// Whether the "Extend expiry" is extending or setting an expiry.
|
||||
private _settingExpiry = false;
|
||||
@ -1538,9 +1539,22 @@ export class accountsList {
|
||||
}
|
||||
}
|
||||
|
||||
// Start off sorting by Name
|
||||
const defaultSort = () => {
|
||||
this._activeSortColumn = document.getElementsByClassName("accounts-header-" + headerNames[0])[0].className;
|
||||
document.dispatchEvent(new CustomEvent("header-click", { detail: this._activeSortColumn }));
|
||||
this._columns[this._activeSortColumn].ascending = true;
|
||||
this._columns[this._activeSortColumn].hideIcon();
|
||||
this._sortingByButton.parentElement.classList.add("hidden");
|
||||
};
|
||||
|
||||
this._sortingByButton.parentElement.addEventListener("click", defaultSort);
|
||||
|
||||
document.addEventListener("header-click", (event: CustomEvent) => {
|
||||
this._ordering = this._columns[event.detail].sort(this._users);
|
||||
this._activeSortColumn = event.detail;
|
||||
this._sortingByButton.innerHTML = this._columns[event.detail].buttonContent;
|
||||
this._sortingByButton.parentElement.classList.remove("hidden");
|
||||
// console.log("ordering by", event.detail, ": ", this._ordering);
|
||||
if (!(this._inSearch)) {
|
||||
this.setVisibility(this._ordering, true);
|
||||
@ -1549,9 +1563,7 @@ export class accountsList {
|
||||
}
|
||||
});
|
||||
|
||||
// Start off sorting by Name
|
||||
this._activeSortColumn = document.getElementsByClassName("accounts-header-" + headerNames[0])[0].className;
|
||||
document.dispatchEvent(new CustomEvent("header-click", { detail: this._activeSortColumn }));
|
||||
defaultSort();
|
||||
}
|
||||
|
||||
reload = () => {
|
||||
@ -1615,12 +1627,14 @@ class Column {
|
||||
console.log("wasn't active keeping direction as", this._ascending ? "ascending" : "descending");
|
||||
}
|
||||
this._active = true;
|
||||
this._header.setAttribute("aria-sort", this._headerContent);
|
||||
this.updateHeader();
|
||||
document.dispatchEvent(new CustomEvent("header-click", { detail: this._header.className }));
|
||||
});
|
||||
document.addEventListener("header-click", (event: CustomEvent) => {
|
||||
if (event.detail != this._header.className) {
|
||||
this._active = false;
|
||||
this._header.removeAttribute("aria-sort");
|
||||
this.hideIcon();
|
||||
}
|
||||
});
|
||||
@ -1632,11 +1646,24 @@ class Column {
|
||||
|
||||
updateHeader = () => {
|
||||
this._header.innerHTML = `
|
||||
${this._headerContent}
|
||||
<i class="ri-arrow-${this._ascending? "up" : "down"}-s-line ml-2"></i>
|
||||
<span class="">${this._headerContent}</span>
|
||||
<i class="ri-arrow-${this._ascending? "up" : "down"}-s-line" aria-hidden="true"></i>
|
||||
`;
|
||||
}
|
||||
|
||||
// Returns the inner HTML to show in the "Sorting By" button.
|
||||
get buttonContent() {
|
||||
return `<span class="font-bold">` + window.lang.strings("sortingBy") + ": " + `</span>` + this._headerContent;
|
||||
}
|
||||
|
||||
get ascending() { return this._ascending; }
|
||||
set ascending(v: boolean) {
|
||||
this._ascending = v;
|
||||
if (!this._active) return;
|
||||
this.updateHeader();
|
||||
this._header.setAttribute("aria-sort", this._headerContent);
|
||||
document.dispatchEvent(new CustomEvent("header-click", { detail: this._header.className }));
|
||||
}
|
||||
|
||||
// Sorts the user list. previouslyActive is whether this column was previously sorted by, indicating that the direction should change.
|
||||
sort = (users: { [id: string]: user }): string[] => {
|
||||
|
Loading…
Reference in New Issue
Block a user