import * as debug from 'debug' import { LazyLoadEvent, SortMeta } from 'primeng/api' import { Subject } from 'rxjs' import { ActivatedRoute, Router } from '@angular/router' import { peertubeLocalStorage } from '@root-helpers/peertube-web-storage' import { RouteFilter } from '../routing' import { RestPagination } from './rest-pagination' const logger = debug('peertube:tables:RestTable') export abstract class RestTable extends RouteFilter { abstract totalRecords: number abstract sort: SortMeta abstract pagination: RestPagination search: string rowsPerPageOptions = [ 10, 20, 50, 100 ] rowsPerPage = this.rowsPerPageOptions[0] expandedRows = {} protected searchStream: Subject protected route: ActivatedRoute protected router: Router abstract getIdentifier (): string initialize () { this.loadSort() this.initSearch() } loadSort () { const result = peertubeLocalStorage.getItem(this.getSortLocalStorageKey()) if (result) { try { this.sort = JSON.parse(result) } catch (err) { console.error('Cannot load sort of local storage key ' + this.getSortLocalStorageKey(), err) } } } loadLazy (event: LazyLoadEvent) { logger('Load lazy %o.', event) this.sort = { order: event.sortOrder, field: event.sortField } this.pagination = { start: event.first, count: this.rowsPerPage } this.loadData() this.saveSort() } saveSort () { peertubeLocalStorage.setItem(this.getSortLocalStorageKey(), JSON.stringify(this.sort)) } onPage (event: { first: number, rows: number }) { logger('On page %o.', event) if (this.rowsPerPage !== event.rows) { this.rowsPerPage = event.rows this.pagination = { start: event.first, count: this.rowsPerPage } this.loadData() } this.expandedRows = {} } protected abstract loadData (): void private getSortLocalStorageKey () { return 'rest-table-sort-' + this.getIdentifier() } }