import { html, LitElement, property, TemplateResult } from "lit-element"; import { until } from "lit-html/directives/until.js"; import { PBResponse } from "../../api/client"; import { COMMON_STYLES } from "../../common/styles"; export abstract class Table extends LitElement { abstract apiEndpoint(page: number): Promise>; abstract columns(): Array; abstract row(item: T): Array; @property() data?: PBResponse; @property() page: number = 1; static get styles() { return [COMMON_STYLES]; } public fetch() { this.apiEndpoint(this.page).then((r) => { this.data = r; this.page = r.pagination.current; }); } private renderLoading(): TemplateResult { return html`

Loading

`; } private renderRows(): TemplateResult[] | undefined { if (!this.data) { return; } return this.data.results.map((item) => { const fullRow = [``].concat( this.row(item).map((col) => { return `${col}`; }) ); fullRow.push(``); return html(fullRow); }); } renderTable() { if (!this.data) { this.fetch(); } return html`
${this.columns().map( (col) => html`` )} ${this.data ? this.renderRows() : this.renderLoading()}
${col}
`; } render() { return this.renderTable(); } }