mirror of
https://github.com/hrfee/jfa-go.git
synced 2024-11-15 23:00:10 +00:00
activity: refresh, load more buttons, ui adjustments
This commit is contained in:
parent
2d83718f81
commit
47ce8a9ec4
@ -735,13 +735,14 @@
|
|||||||
<button class="button ~neutral @low ml-2" id="activity-sort-direction">{{ .strings.sortDirection }}</button>
|
<button class="button ~neutral @low ml-2" id="activity-sort-direction">{{ .strings.sortDirection }}</button>
|
||||||
<input type="search" class="field ~neutral @low input search ml-2 mr-2" id="activity-search" placeholder="{{ .strings.search }}">
|
<input type="search" class="field ~neutral @low input search ml-2 mr-2" id="activity-search" placeholder="{{ .strings.search }}">
|
||||||
<span class="button ~neutral @low center ml-[-2.64rem] rounded-s-none activity-search-clear" aria-label="{{ .strings.clearSearch }}" text="{{ .strings.clearSearch }}"><i class="ri-close-line"></i></span>
|
<span class="button ~neutral @low center ml-[-2.64rem] rounded-s-none activity-search-clear" aria-label="{{ .strings.clearSearch }}" text="{{ .strings.clearSearch }}"><i class="ri-close-line"></i></span>
|
||||||
|
<button class="button ~info @low ml-2" id="activity-refresh" aria-label="{{ .strings.refresh }}" disabled><i class="ri-refresh-line"></i></button>
|
||||||
</div>
|
</div>
|
||||||
<div class="supra py-1 sm hidden" id="activity-search-options-header">{{ .strings.searchOptions }}</div>
|
<div class="supra py-1 sm hidden" id="activity-search-options-header">{{ .strings.searchOptions }}</div>
|
||||||
<div class="row -mx-2 mb-2">
|
<div class="row -mx-2 mb-2">
|
||||||
<button type="button" class="button ~neutral @low center mx-2 hidden"><span id="activity-sort-by-field"></span> <i class="ri-close-line ml-2 text-2xl"></i></button>
|
<button type="button" class="button ~neutral @low center mx-2 hidden"><span id="activity-sort-by-field"></span> <i class="ri-close-line ml-2 text-2xl"></i></button>
|
||||||
<span id="activity-filter-area"></span>
|
<span id="activity-filter-area"></span>
|
||||||
</div>
|
</div>
|
||||||
<div class="card @low dark:~d_neutral col">
|
<div class="my-2">
|
||||||
<div id="activity-card-list"></div>
|
<div id="activity-card-list"></div>
|
||||||
<div id="activity-loader"></div>
|
<div id="activity-loader"></div>
|
||||||
<div class="unfocused h-[100%] my-3" id="activity-not-found">
|
<div class="unfocused h-[100%] my-3" id="activity-not-found">
|
||||||
@ -752,6 +753,9 @@
|
|||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="flex justify-center">
|
||||||
|
<button class="button my-2 ~neutral @low" id="activity-load-more">{{ .strings.loadMore }}</button>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -167,7 +167,9 @@
|
|||||||
"passwordChangeFilter": "Password Changed",
|
"passwordChangeFilter": "Password Changed",
|
||||||
"passwordResetFilter": "Password Reset",
|
"passwordResetFilter": "Password Reset",
|
||||||
"inviteCreatedFilter": "Invite Created",
|
"inviteCreatedFilter": "Invite Created",
|
||||||
"inviteDeletedFilter": "Invite Deleted/Expired"
|
"inviteDeletedFilter": "Invite Deleted/Expired",
|
||||||
|
"loadMore": "Load More",
|
||||||
|
"noMoreResults": "No more results."
|
||||||
},
|
},
|
||||||
"notifications": {
|
"notifications": {
|
||||||
"changedEmailAddress": "Changed email address of {n}.",
|
"changedEmailAddress": "Changed email address of {n}.",
|
||||||
|
@ -317,6 +317,8 @@ export class activityList {
|
|||||||
private _searchBox = document.getElementById("activity-search") as HTMLInputElement;
|
private _searchBox = document.getElementById("activity-search") as HTMLInputElement;
|
||||||
private _sortDirection = document.getElementById("activity-sort-direction") as HTMLButtonElement;
|
private _sortDirection = document.getElementById("activity-sort-direction") as HTMLButtonElement;
|
||||||
private _loader = document.getElementById("activity-loader");
|
private _loader = document.getElementById("activity-loader");
|
||||||
|
private _loadMoreButton = document.getElementById("activity-load-more") as HTMLButtonElement;
|
||||||
|
private _refreshButton = document.getElementById("activity-refresh") as HTMLButtonElement;
|
||||||
private _search: Search;
|
private _search: Search;
|
||||||
private _ascending: boolean;
|
private _ascending: boolean;
|
||||||
private _hasLoaded: boolean;
|
private _hasLoaded: boolean;
|
||||||
@ -351,6 +353,7 @@ export class activityList {
|
|||||||
"page": 0,
|
"page": 0,
|
||||||
"ascending": this.ascending
|
"ascending": this.ascending
|
||||||
}
|
}
|
||||||
|
|
||||||
_post("/activity", send, (req: XMLHttpRequest) => {
|
_post("/activity", send, (req: XMLHttpRequest) => {
|
||||||
if (req.readyState != 4) return;
|
if (req.readyState != 4) return;
|
||||||
if (req.status != 200) {
|
if (req.status != 200) {
|
||||||
@ -359,6 +362,9 @@ export class activityList {
|
|||||||
}
|
}
|
||||||
|
|
||||||
this._hasLoaded = true;
|
this._hasLoaded = true;
|
||||||
|
// Allow refreshes every 15s
|
||||||
|
this._refreshButton.disabled = true;
|
||||||
|
setTimeout(() => this._refreshButton.disabled = false, 15000);
|
||||||
|
|
||||||
let resp = req.response as ActivitiesDTO;
|
let resp = req.response as ActivitiesDTO;
|
||||||
// FIXME: Don't destroy everything each reload!
|
// FIXME: Don't destroy everything each reload!
|
||||||
@ -383,6 +389,8 @@ export class activityList {
|
|||||||
|
|
||||||
loadMore = () => {
|
loadMore = () => {
|
||||||
this._lastLoad = Date.now();
|
this._lastLoad = Date.now();
|
||||||
|
this._loadMoreButton.disabled = true;
|
||||||
|
const timeout = setTimeout(() => this._loadMoreButton.disabled = false, 1000);
|
||||||
this._page += 1;
|
this._page += 1;
|
||||||
|
|
||||||
let send = {
|
let send = {
|
||||||
@ -405,6 +413,11 @@ export class activityList {
|
|||||||
let resp = req.response as ActivitiesDTO;
|
let resp = req.response as ActivitiesDTO;
|
||||||
|
|
||||||
this._lastPage = resp.last_page;
|
this._lastPage = resp.last_page;
|
||||||
|
if (this._lastPage) {
|
||||||
|
clearTimeout(timeout);
|
||||||
|
this._loadMoreButton.disabled = true;
|
||||||
|
this._loadMoreButton.textContent = window.lang.strings("noMoreResults");
|
||||||
|
}
|
||||||
|
|
||||||
for (let act of resp.activities) {
|
for (let act of resp.activities) {
|
||||||
this._activities[act.id] = new Activity(act);
|
this._activities[act.id] = new Activity(act);
|
||||||
@ -590,6 +603,9 @@ export class activityList {
|
|||||||
this.ascending = false;
|
this.ascending = false;
|
||||||
this._sortDirection.addEventListener("click", () => this.ascending = !this.ascending);
|
this._sortDirection.addEventListener("click", () => this.ascending = !this.ascending);
|
||||||
|
|
||||||
|
this._loadMoreButton.onclick = this.loadMore;
|
||||||
|
this._refreshButton.onclick = this.reload;
|
||||||
|
|
||||||
window.onscroll = this.detectScroll;
|
window.onscroll = this.detectScroll;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user