@one-paragon/angular-utilities 0.3.9 → 0.3.10--beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/table-builder/classes/TableBuilderDataSource.mjs +50 -0
- package/esm2022/table-builder/classes/TableState.mjs +11 -1
- package/esm2022/table-builder/components/generic-table/generic-table.component.mjs +32 -36
- package/esm2022/table-builder/components/generic-table/paginator.component.mjs +17 -16
- package/esm2022/table-builder/components/scroll-strategy.mjs +63 -0
- package/esm2022/table-builder/components/table-container/table-container-imports.mjs +5 -2
- package/esm2022/table-builder/components/table-container/table-container.mjs +101 -39
- package/esm2022/table-builder/components/table-container/tableProps.mjs +9 -0
- package/esm2022/table-builder/components/table-container/virtual-scroll-container.mjs +101 -0
- package/esm2022/table-builder/components/table-context.mjs +2 -0
- package/fesm2022/one-paragon-angular-utilities.mjs +433 -151
- package/fesm2022/one-paragon-angular-utilities.mjs.map +1 -1
- package/package.json +1 -1
- package/table-builder/classes/TableBuilderDataSource.d.ts +13 -0
- package/table-builder/classes/TableState.d.ts +5 -0
- package/table-builder/components/generic-table/generic-table.component.d.ts +11 -14
- package/table-builder/components/generic-table/paginator.component.d.ts +5 -6
- package/table-builder/components/scroll-strategy.d.ts +23 -0
- package/table-builder/components/table-container/table-container-imports.d.ts +3 -1
- package/table-builder/components/table-container/table-container.d.ts +18 -7
- package/table-builder/components/table-container/tableProps.d.ts +11 -0
- package/table-builder/components/table-container/virtual-scroll-container.d.ts +17 -0
- package/table-builder/components/table-context.d.ts +10 -0
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { MatTableDataSource } from '@angular/material/table';
|
|
2
|
+
import { combineLatest, map } from 'rxjs';
|
|
3
|
+
export class TableBuilderDataSource extends MatTableDataSource {
|
|
4
|
+
constructor(dataSrc, state, context) {
|
|
5
|
+
super([]);
|
|
6
|
+
this.dataSrc = dataSrc;
|
|
7
|
+
this.state = state;
|
|
8
|
+
this.context = context;
|
|
9
|
+
}
|
|
10
|
+
connect() {
|
|
11
|
+
if (!this.subscription) {
|
|
12
|
+
let dataSource$ = this.dataSrc;
|
|
13
|
+
if (this.context.tableProps.usePaginator) {
|
|
14
|
+
const currentPage$ = this.state.select(s => s.currentPage);
|
|
15
|
+
const pageSize$ = this.state.select(s => s.pageSize);
|
|
16
|
+
dataSource$ = combineLatest([
|
|
17
|
+
currentPage$,
|
|
18
|
+
pageSize$,
|
|
19
|
+
dataSource$
|
|
20
|
+
]).pipe(map(([currentPage, pageSize, d]) => {
|
|
21
|
+
const start = currentPage * pageSize;
|
|
22
|
+
return d.slice(start, start + pageSize);
|
|
23
|
+
}));
|
|
24
|
+
}
|
|
25
|
+
if (this.context.tableProps.useVirtualScroll) {
|
|
26
|
+
const start$ = this.state.select(s => s.virtualStart);
|
|
27
|
+
const end$ = this.state.select(s => s.virtualEnd);
|
|
28
|
+
dataSource$ = combineLatest([
|
|
29
|
+
start$,
|
|
30
|
+
end$,
|
|
31
|
+
dataSource$
|
|
32
|
+
]).pipe(map(([start, end, data]) => {
|
|
33
|
+
return data.slice(start, end);
|
|
34
|
+
}));
|
|
35
|
+
}
|
|
36
|
+
this.subscription = dataSource$.subscribe((data) => {
|
|
37
|
+
this.data = data;
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
return super.connect();
|
|
41
|
+
}
|
|
42
|
+
disconnect() {
|
|
43
|
+
if (this.subscription) {
|
|
44
|
+
this.subscription.unsubscribe();
|
|
45
|
+
this.subscription = undefined;
|
|
46
|
+
}
|
|
47
|
+
super.disconnect();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGFibGVCdWlsZGVyRGF0YVNvdXJjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL2NsYXNzZXMvVGFibGVCdWlsZGVyRGF0YVNvdXJjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM3RCxPQUFPLEVBQTRCLGFBQWEsRUFBRSxHQUFHLEVBQWtCLE1BQU0sTUFBTSxDQUFDO0FBSXBGLE1BQU0sT0FBTyxzQkFBMEIsU0FBUSxrQkFBcUI7SUFHbEUsWUFDUyxPQUF3QixFQUN2QixLQUFpQixFQUNqQixPQUFxQjtRQUU3QixLQUFLLENBQUMsRUFBRSxDQUFDLENBQUM7UUFKSCxZQUFPLEdBQVAsT0FBTyxDQUFpQjtRQUN2QixVQUFLLEdBQUwsS0FBSyxDQUFZO1FBQ2pCLFlBQU8sR0FBUCxPQUFPLENBQWM7SUFHL0IsQ0FBQztJQUVELE9BQU87UUFDTCxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRTtZQUN0QixJQUFJLFdBQVcsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDO1lBRS9CLElBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsWUFBWSxFQUFFO2dCQUN2QyxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBRSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxXQUFXLENBQUMsQ0FBQztnQkFDNUQsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFFLENBQUM7Z0JBQ3ZELFdBQVcsR0FBRyxhQUFhLENBQUM7b0JBQzFCLFlBQVk7b0JBQ1osU0FBUztvQkFDVCxXQUFXO2lCQUNaLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUMsUUFBUSxFQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7b0JBQ3ZDLE1BQU0sS0FBSyxHQUFHLFdBQVcsR0FBRyxRQUFRLENBQUM7b0JBQ3JDLE9BQU8sQ0FBQyxDQUFDLEtBQUssQ0FBQyxLQUFLLEVBQUUsS0FBSyxHQUFHLFFBQVEsQ0FBRSxDQUFDO2dCQUMzQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQ0w7WUFFRCxJQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLGdCQUFnQixFQUFFO2dCQUMzQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBRSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxZQUFZLENBQUMsQ0FBQztnQkFDdkQsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUM7Z0JBQ25ELFdBQVcsR0FBRyxhQUFhLENBQUM7b0JBQzFCLE1BQU07b0JBQ04sSUFBSTtvQkFDSixXQUFXO2lCQUNaLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFFLENBQUMsQ0FBQyxLQUFLLEVBQUMsR0FBRyxFQUFDLElBQUksQ0FBQyxFQUFFLEVBQUU7b0JBQ2hDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLEVBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQy9CLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDTDtZQUVELElBQUksQ0FBQyxZQUFZLEdBQUcsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFO2dCQUNqRCxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztZQUNuQixDQUFDLENBQUMsQ0FBQztTQUNKO1FBQ0QsT0FBTyxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUNELFVBQVU7UUFDUixJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDckIsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUNoQyxJQUFJLENBQUMsWUFBWSxHQUFHLFNBQVMsQ0FBQztTQUMvQjtRQUNELEtBQUssQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNyQixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNYXRUYWJsZURhdGFTb3VyY2UgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90YWJsZSc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUsIFN1YnNjcmlwdGlvbiwgY29tYmluZUxhdGVzdCwgbWFwLCBzdGFydFdpdGgsIHRhcCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBUYWJsZVN0b3JlIH0gZnJvbSAnLi90YWJsZS1zdG9yZSc7XHJcbmltcG9ydCB7IFRhYmxlQ29udGV4dCB9IGZyb20gJy4uL2NvbXBvbmVudHMvdGFibGUtY29udGV4dCc7XHJcblxyXG5leHBvcnQgY2xhc3MgVGFibGVCdWlsZGVyRGF0YVNvdXJjZTxUPiBleHRlbmRzIE1hdFRhYmxlRGF0YVNvdXJjZTxUPiB7XHJcbiAgc3Vic2NyaXB0aW9uPzogU3Vic2NyaXB0aW9uO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHB1YmxpYyBkYXRhU3JjOiBPYnNlcnZhYmxlPFRbXT4sXHJcbiAgICBwcml2YXRlIHN0YXRlOiBUYWJsZVN0b3JlLFxyXG4gICAgcHJpdmF0ZSBjb250ZXh0OiBUYWJsZUNvbnRleHRcclxuICApIHtcclxuICAgIHN1cGVyKFtdKTtcclxuICB9XHJcblxyXG4gIGNvbm5lY3QoKSB7XHJcbiAgICBpZiAoIXRoaXMuc3Vic2NyaXB0aW9uKSB7XHJcbiAgICAgIGxldCBkYXRhU291cmNlJCA9IHRoaXMuZGF0YVNyYztcclxuXHJcbiAgICAgIGlmKHRoaXMuY29udGV4dC50YWJsZVByb3BzLnVzZVBhZ2luYXRvcikge1xyXG4gICAgICAgIGNvbnN0IGN1cnJlbnRQYWdlJCA9IHRoaXMuc3RhdGUuc2VsZWN0KCBzID0+IHMuY3VycmVudFBhZ2UpO1xyXG4gICAgICAgIGNvbnN0IHBhZ2VTaXplJCA9IHRoaXMuc3RhdGUuc2VsZWN0KCBzID0+IHMucGFnZVNpemUgKTtcclxuICAgICAgICBkYXRhU291cmNlJCA9IGNvbWJpbmVMYXRlc3QoW1xyXG4gICAgICAgICAgY3VycmVudFBhZ2UkLFxyXG4gICAgICAgICAgcGFnZVNpemUkLFxyXG4gICAgICAgICAgZGF0YVNvdXJjZSRcclxuICAgICAgICBdKS5waXBlKG1hcCgoW2N1cnJlbnRQYWdlLHBhZ2VTaXplLGRdKSA9PiB7XHJcbiAgICAgICAgICBjb25zdCBzdGFydCA9IGN1cnJlbnRQYWdlICogcGFnZVNpemU7XHJcbiAgICAgICAgICByZXR1cm4gZC5zbGljZShzdGFydCwgc3RhcnQgKyBwYWdlU2l6ZSApO1xyXG4gICAgICAgIH0pKTtcclxuICAgICAgfVxyXG5cclxuICAgICAgaWYodGhpcy5jb250ZXh0LnRhYmxlUHJvcHMudXNlVmlydHVhbFNjcm9sbCkge1xyXG4gICAgICAgIGNvbnN0IHN0YXJ0JCA9IHRoaXMuc3RhdGUuc2VsZWN0KCBzID0+IHMudmlydHVhbFN0YXJ0KTtcclxuICAgICAgICBjb25zdCBlbmQkID0gdGhpcy5zdGF0ZS5zZWxlY3QoIHMgPT4gcy52aXJ0dWFsRW5kKTtcclxuICAgICAgICBkYXRhU291cmNlJCA9IGNvbWJpbmVMYXRlc3QoW1xyXG4gICAgICAgICAgc3RhcnQkLFxyXG4gICAgICAgICAgZW5kJCxcclxuICAgICAgICAgIGRhdGFTb3VyY2UkXHJcbiAgICAgICAgXSkucGlwZShtYXAoIChbc3RhcnQsZW5kLGRhdGFdKSA9PiB7XHJcbiAgICAgICAgICByZXR1cm4gZGF0YS5zbGljZShzdGFydCxlbmQpO1xyXG4gICAgICAgIH0pKTtcclxuICAgICAgfVxyXG5cclxuICAgICAgdGhpcy5zdWJzY3JpcHRpb24gPSBkYXRhU291cmNlJC5zdWJzY3JpYmUoKGRhdGEpID0+IHtcclxuICAgICAgICB0aGlzLmRhdGEgPSBkYXRhO1xyXG4gICAgICB9KTtcclxuICAgIH1cclxuICAgIHJldHVybiBzdXBlci5jb25uZWN0KCk7XHJcbiAgfVxyXG4gIGRpc2Nvbm5lY3QoKSB7XHJcbiAgICBpZiAodGhpcy5zdWJzY3JpcHRpb24pIHtcclxuICAgICAgdGhpcy5zdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcclxuICAgICAgdGhpcy5zdWJzY3JpcHRpb24gPSB1bmRlZmluZWQ7XHJcbiAgICB9XHJcbiAgICBzdXBlci5kaXNjb25uZWN0KCk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -6,6 +6,11 @@ class KeysToDelete {
|
|
|
6
6
|
this.notPersistedTableSettings = null;
|
|
7
7
|
this.linkMaps = null;
|
|
8
8
|
this.pageSize = null;
|
|
9
|
+
this.currentPage = null;
|
|
10
|
+
this.virtualScrollOffset = null;
|
|
11
|
+
this.dataLen = null;
|
|
12
|
+
this.virtualStart = null;
|
|
13
|
+
this.virtualEnd = null;
|
|
9
14
|
}
|
|
10
15
|
}
|
|
11
16
|
export const keysToDelete = Object.keys(new KeysToDelete());
|
|
@@ -28,5 +33,10 @@ export const defaultTableState = {
|
|
|
28
33
|
pageSize: 10,
|
|
29
34
|
linkMaps: {},
|
|
30
35
|
groupBy: [],
|
|
36
|
+
currentPage: 0,
|
|
37
|
+
virtualScrollOffset: 0,
|
|
38
|
+
dataLen: 0,
|
|
39
|
+
virtualStart: 0,
|
|
40
|
+
virtualEnd: 20,
|
|
31
41
|
};
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGFibGVTdGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL2NsYXNzZXMvVGFibGVTdGF0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQXVDckcsTUFBTSxZQUFZO0lBQWxCO1FBQ0Usd0JBQW1CLEdBQUcsSUFBSSxDQUFDO1FBQzNCLGFBQVEsR0FBRyxJQUFJLENBQUM7UUFDaEIsOEJBQXlCLEdBQUcsSUFBSSxDQUFDO1FBQ2pDLGFBQVEsR0FBRyxJQUFJLENBQUM7UUFDaEIsYUFBUSxHQUFHLElBQUksQ0FBQztRQUNoQixnQkFBVyxHQUFHLElBQUksQ0FBQztRQUNuQix3QkFBbUIsR0FBRyxJQUFJLENBQUM7UUFDM0IsWUFBTyxHQUFHLElBQUksQ0FBQztRQUNmLGlCQUFZLEdBQUcsSUFBSSxDQUFDO1FBQ3BCLGVBQVUsR0FBRyxJQUFJLENBQUM7SUFDcEIsQ0FBQztDQUFBO0FBQ0QsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxZQUFZLEVBQUUsQ0FBQyxDQUFDO0FBRTVELE1BQU0sQ0FBTixJQUFZLG1CQUtYO0FBTEQsV0FBWSxtQkFBbUI7SUFDN0IsbUVBQU8sQ0FBQTtJQUNQLGlGQUFjLENBQUE7SUFDZCxtRkFBZSxDQUFBO0lBQ2YsK0RBQUssQ0FBQTtBQUNQLENBQUMsRUFMVyxtQkFBbUIsS0FBbkIsbUJBQW1CLFFBSzlCO0FBRUQsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQWU7SUFDM0MsbUJBQW1CLEVBQUUsbUJBQW1CLENBQUMsT0FBTztJQUNoRCxRQUFRLEVBQUUsRUFBRTtJQUNaLE9BQU8sRUFBRSxFQUFFO0lBQ1gsVUFBVSxFQUFFLEVBQUU7SUFDZCxNQUFNLEVBQUUsRUFBRTtJQUNWLFdBQVcsRUFBQyxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFDO0lBQy9DLHNCQUFzQixFQUFHLElBQUksc0JBQXNCLEVBQUU7SUFDckQseUJBQXlCLEVBQUcsSUFBSSx5QkFBeUIsRUFBRTtJQUMzRCxRQUFRLEVBQUUsRUFBRTtJQUNaLFFBQVEsRUFBQyxFQUFFO0lBQ1gsT0FBTyxFQUFFLEVBQUU7SUFDWCxXQUFXLEVBQUUsQ0FBQztJQUNkLG1CQUFtQixFQUFFLENBQUM7SUFDdEIsT0FBTyxFQUFFLENBQUM7SUFDVixZQUFZLEVBQUUsQ0FBQztJQUNmLFVBQVUsRUFBRSxFQUFFO0NBQ2YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEN1c3RvbUZpbHRlciwgRmlsdGVySW5mbyB9IGZyb20gJy4vZmlsdGVyLWluZm8nO1xyXG5pbXBvcnQgeyBEaWN0aW9uYXJ5IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9kaWN0aW9uYXJ5JztcclxuaW1wb3J0IHsgU29ydCB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NvcnQnO1xyXG5pbXBvcnQgeyBNZXRhRGF0YSwgVGFyZ2V0IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9yZXBvcnQtZGVmJztcclxuaW1wb3J0IHsgTm90UGVyc2lzdGVkVGFibGVTZXR0aW5ncywgUGVyc2lzdGVkVGFibGVTZXR0aW5ncyB9IGZyb20gJy4vdGFibGUtYnVpbGRlci1nZW5lcmFsLXNldHRpbmdzJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgR3JvdXAge1xyXG4gIGdyb3VwTmFtZT86IHN0cmluZztcclxuICBwYXJlbnRHcm91cE5hbWU/OiBzdHJpbmc7XHJcbiAgaXNFeHBhbmRlZD86IGJvb2xlYW47XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgR3JvdXBlZERhdGEge1xyXG4gIGtleTogc3RyaW5nLFxyXG4gIGV4cGFuZGVkSGVhZGVyczogc3RyaW5nW11cclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBQZXJzaXN0ZWRUYWJsZVN0YXRlIHtcclxuICBoaWRkZW5LZXlzPzogc3RyaW5nIFtdO1xyXG4gIGZpbHRlcnM6IERpY3Rpb25hcnk8RmlsdGVySW5mbyB8IEN1c3RvbUZpbHRlcj47XHJcbiAgc29ydGVkIDogU29ydCBbXTtcclxuICB1c2VyRGVmaW5lZCA6IHsgb3JkZXI6RGljdGlvbmFyeTxudW1iZXI+LCB3aWR0aHM6RGljdGlvbmFyeTxudW1iZXI+LCB0YWJsZTp7IHdpZHRoPzpudW1iZXIgfSwgcGFnZVNpemU/OiBudW1iZXIgfTtcclxuICBwZXJzaXN0ZWRUYWJsZVNldHRpbmdzIDogUGVyc2lzdGVkVGFibGVTZXR0aW5ncztcclxuICBncm91cEJ5OiBHcm91cGVkRGF0YVtdO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlU3RhdGUgZXh0ZW5kcyBSZXF1aXJlZDxQZXJzaXN0ZWRUYWJsZVN0YXRlPiB7XHJcbiAgaW5pdGlhbGl6YXRpb25TdGF0ZTogSW5pdGlhbGl6YXRpb25TdGF0ZTtcclxuICBtZXRhRGF0YTogRGljdGlvbmFyeTxNZXRhRGF0YT47XHJcbiAgbm90UGVyc2lzdGVkVGFibGVTZXR0aW5ncyA6IE5vdFBlcnNpc3RlZFRhYmxlU2V0dGluZ3M7XHJcbiAgcGFnZVNpemU6IG51bWJlcjtcclxuICBjdXJyZW50UGFnZTogbnVtYmVyO1xyXG4gIHZpcnR1YWxTY3JvbGxPZmZzZXQ6IG51bWJlcjtcclxuICB2aXJ0dWFsU3RhcnQ6IG51bWJlcjtcclxuICB2aXJ0dWFsRW5kOiBudW1iZXI7XHJcbiAgZGF0YUxlbjogbnVtYmVyO1xyXG4gIGxpbmtNYXBzOntba2V5OnN0cmluZ106e1xyXG4gICAgbGluazogKHQ6YW55KT0+c3RyaW5nLFxyXG4gICAgdXNlUm91dGVyTGluazogYm9vbGVhbixcclxuICAgIHRhcmdldDogVGFyZ2V0XHJcbiAgfX07XHJcbn1cclxudHlwZSBSZXF1aXJlTnVsbDxUPiA9IHsgW0sgaW4ga2V5b2YgVF06IG51bGwgfTtcclxuY2xhc3MgS2V5c1RvRGVsZXRlIGltcGxlbWVudHMgIFJlcXVpcmVOdWxsPE9taXQ8VGFibGVTdGF0ZSwga2V5b2YgUGVyc2lzdGVkVGFibGVTdGF0ZT4+IHtcclxuICBpbml0aWFsaXphdGlvblN0YXRlID0gbnVsbDtcclxuICBtZXRhRGF0YSA9IG51bGw7XHJcbiAgbm90UGVyc2lzdGVkVGFibGVTZXR0aW5ncyA9IG51bGw7XHJcbiAgbGlua01hcHMgPSBudWxsO1xyXG4gIHBhZ2VTaXplID0gbnVsbDtcclxuICBjdXJyZW50UGFnZSA9IG51bGw7XHJcbiAgdmlydHVhbFNjcm9sbE9mZnNldCA9IG51bGw7XHJcbiAgZGF0YUxlbiA9IG51bGw7XHJcbiAgdmlydHVhbFN0YXJ0ID0gbnVsbDtcclxuICB2aXJ0dWFsRW5kID0gbnVsbDtcclxufVxyXG5leHBvcnQgY29uc3Qga2V5c1RvRGVsZXRlID0gT2JqZWN0LmtleXMobmV3IEtleXNUb0RlbGV0ZSgpKTtcclxuXHJcbmV4cG9ydCBlbnVtIEluaXRpYWxpemF0aW9uU3RhdGUge1xyXG4gIENyZWF0ZWQsXHJcbiAgTWV0YURhdGFMb2FkZWQsXHJcbiAgTG9hZGVkRnJvbVN0b3JlLFxyXG4gIFJlYWR5LFxyXG59XHJcblxyXG5leHBvcnQgY29uc3QgZGVmYXVsdFRhYmxlU3RhdGU6IFRhYmxlU3RhdGUgPSB7XHJcbiAgaW5pdGlhbGl6YXRpb25TdGF0ZTogSW5pdGlhbGl6YXRpb25TdGF0ZS5DcmVhdGVkLFxyXG4gIG1ldGFEYXRhOiB7fSxcclxuICBmaWx0ZXJzOiB7fSxcclxuICBoaWRkZW5LZXlzOiBbXSxcclxuICBzb3J0ZWQ6IFtdLFxyXG4gIHVzZXJEZWZpbmVkOnsgb3JkZXI6IHt9LCB3aWR0aHM6IHt9LCB0YWJsZToge319LFxyXG4gIHBlcnNpc3RlZFRhYmxlU2V0dGluZ3MgOiBuZXcgUGVyc2lzdGVkVGFibGVTZXR0aW5ncygpLFxyXG4gIG5vdFBlcnNpc3RlZFRhYmxlU2V0dGluZ3MgOiBuZXcgTm90UGVyc2lzdGVkVGFibGVTZXR0aW5ncygpLFxyXG4gIHBhZ2VTaXplOiAxMCxcclxuICBsaW5rTWFwczp7fSxcclxuICBncm91cEJ5OiBbXSxcclxuICBjdXJyZW50UGFnZTogMCxcclxuICB2aXJ0dWFsU2Nyb2xsT2Zmc2V0OiAwLFxyXG4gIGRhdGFMZW46IDAsXHJcbiAgdmlydHVhbFN0YXJ0OiAwLFxyXG4gIHZpcnR1YWxFbmQ6IDIwLFxyXG59O1xyXG4iXX0=
|
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
import { Component, ViewChild, Input, ChangeDetectionStrategy, Output, ElementRef, Injector, } from '@angular/core';
|
|
1
|
+
import { Component, ViewChild, Input, ChangeDetectionStrategy, Output, ElementRef, Injector, Inject, } from '@angular/core';
|
|
2
2
|
import { MatTable, MatTableModule } from '@angular/material/table';
|
|
3
3
|
import { combineLatest } from 'rxjs';
|
|
4
4
|
import { SelectionModel } from '@angular/cdk/collections';
|
|
5
|
-
import {
|
|
5
|
+
import { map, distinctUntilChanged } from 'rxjs/operators';
|
|
6
6
|
import { ColumnBuilderComponent } from '../column-builder/column-builder.component';
|
|
7
7
|
import { FieldType } from '../../interfaces/report-def';
|
|
8
8
|
import { previousAndCurrent } from '../../../rxjs/rxjs-operators';
|
|
9
9
|
import { CdkDropList, DragDropModule } from '@angular/cdk/drag-drop';
|
|
10
|
-
import { PaginatorComponent } from './paginator.component';
|
|
11
10
|
import { FunctionPipe } from '../../../utilities';
|
|
12
11
|
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
13
12
|
import { MatButtonModule } from '@angular/material/button';
|
|
@@ -15,7 +14,6 @@ import { MatIconModule } from '@angular/material/icon';
|
|
|
15
14
|
import { AsyncPipe, NgTemplateOutlet } from '@angular/common';
|
|
16
15
|
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
17
16
|
import { LetDirective } from '@ngrx/component';
|
|
18
|
-
import { MatTableObservableDataSource } from '../../classes/MatTableObservableDataSource';
|
|
19
17
|
import { initIndexSymbol } from '../table-container/table-container.helpers/sort-state.helpers';
|
|
20
18
|
import * as i0 from "@angular/core";
|
|
21
19
|
import * as i1 from "@angular/material/sort";
|
|
@@ -26,7 +24,6 @@ import * as i5 from "@angular/cdk/drag-drop";
|
|
|
26
24
|
import * as i6 from "@angular/material/checkbox";
|
|
27
25
|
import * as i7 from "@angular/material/button";
|
|
28
26
|
import * as i8 from "@angular/material/icon";
|
|
29
|
-
import * as i9 from "@angular/material/tooltip";
|
|
30
27
|
export class GenericTableComponent {
|
|
31
28
|
drop(event) {
|
|
32
29
|
this.state.setUserDefinedOrder({ newOrder: event.currentIndex, oldOrder: event.previousIndex });
|
|
@@ -36,18 +33,20 @@ export class GenericTableComponent {
|
|
|
36
33
|
this.trackByFunction = (index, item) => item[trackBy];
|
|
37
34
|
}
|
|
38
35
|
}
|
|
39
|
-
|
|
36
|
+
set tableElRef(val) {
|
|
37
|
+
this.context.tableElRef = val;
|
|
38
|
+
}
|
|
39
|
+
constructor(sort, state, viewContainer, transformCreator, injector, context) {
|
|
40
40
|
this.sort = sort;
|
|
41
41
|
this.state = state;
|
|
42
42
|
this.viewContainer = viewContainer;
|
|
43
43
|
this.transformCreator = transformCreator;
|
|
44
|
-
this.
|
|
45
|
-
this.selectionColumn = false;
|
|
46
|
-
this.isSticky = false;
|
|
44
|
+
this.context = context;
|
|
47
45
|
this.keys = [];
|
|
48
46
|
this.rowDefArr = [];
|
|
49
47
|
this.columns = [];
|
|
50
48
|
this.myColumns = {};
|
|
49
|
+
this.offsetIndex = 0;
|
|
51
50
|
this.defaultTrackBy = (index, item) => item[initIndexSymbol];
|
|
52
51
|
this.trackByFunction = this.defaultTrackBy;
|
|
53
52
|
this.initializeRowDefs = (defs) => {
|
|
@@ -76,7 +75,6 @@ export class GenericTableComponent {
|
|
|
76
75
|
return (previousUserDefinedWidth ?? 0) >= 0 && currentUserDefinedWidth == null;
|
|
77
76
|
}
|
|
78
77
|
}));
|
|
79
|
-
this.collapseFooter$ = this.state.state$.pipe(map(state => state.persistedTableSettings.collapseFooter));
|
|
80
78
|
this.getTransform = (key, val) => {
|
|
81
79
|
if (val == undefined || val === 'null')
|
|
82
80
|
return '';
|
|
@@ -87,6 +85,7 @@ export class GenericTableComponent {
|
|
|
87
85
|
return val;
|
|
88
86
|
}
|
|
89
87
|
};
|
|
88
|
+
this.props = context.tableProps;
|
|
90
89
|
this.injector = Injector.create({
|
|
91
90
|
providers: [
|
|
92
91
|
{ provide: MatTable, useFactory: () => this.table },
|
|
@@ -94,6 +93,7 @@ export class GenericTableComponent {
|
|
|
94
93
|
],
|
|
95
94
|
parent: injector
|
|
96
95
|
});
|
|
96
|
+
this.offset$ = this.state.select(s => s.virtualScrollOffset);
|
|
97
97
|
}
|
|
98
98
|
ngOnChanges(changes) {
|
|
99
99
|
if (changes.rows && this.rows && this.myColumns.length) {
|
|
@@ -101,13 +101,12 @@ export class GenericTableComponent {
|
|
|
101
101
|
}
|
|
102
102
|
}
|
|
103
103
|
ngOnInit() {
|
|
104
|
-
if (this.selectionColumn) {
|
|
104
|
+
if (this.props.selectionColumn) {
|
|
105
105
|
this.columns.push('select');
|
|
106
106
|
}
|
|
107
|
-
if (this.indexColumn) {
|
|
107
|
+
if (this.props.indexColumn) {
|
|
108
108
|
this.columns.push('index');
|
|
109
109
|
}
|
|
110
|
-
this.createDataSource();
|
|
111
110
|
this.state.on(this.columnInfos, columns => {
|
|
112
111
|
columns.forEach(ci => this.addMetaData(ci));
|
|
113
112
|
});
|
|
@@ -122,12 +121,17 @@ export class GenericTableComponent {
|
|
|
122
121
|
this.state.metaDataArray$.pipe(map(metaData => metaData.some(md => !!md.additional?.footer)), distinctUntilChanged()),
|
|
123
122
|
this.columnInfos.pipe(map(columnInfos => columnInfos.some(ci => !!ci.customCell?.columnDef?.footerCell)), distinctUntilChanged()),
|
|
124
123
|
]).pipe(map(([hasData, hasFooterDef, hasCustomFooter]) => {
|
|
125
|
-
const hasSelectionColumn = this.selectionColumn;
|
|
124
|
+
const hasSelectionColumn = this.props.selectionColumn;
|
|
126
125
|
return hasCustomFooter || (hasData && (hasFooterDef || hasSelectionColumn)) ? 'regular-footer' : hasData ? 'no-footer' : 'small-footer';
|
|
127
126
|
}));
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
127
|
+
if (this.context.tableProps.usePaginator || this.context.tableProps.useVirtualScroll) {
|
|
128
|
+
this.state.on(this.state.state$, (state) => {
|
|
129
|
+
this.offsetIndex = state.virtualStart;
|
|
130
|
+
if (this.context.tableProps.usePaginator) {
|
|
131
|
+
this.offsetIndex += (state.pageSize * state.currentPage);
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
}
|
|
131
135
|
}
|
|
132
136
|
isGroupHeader(_, row) {
|
|
133
137
|
return row.isGroupHeader;
|
|
@@ -153,44 +157,39 @@ export class GenericTableComponent {
|
|
|
153
157
|
}
|
|
154
158
|
isAllSelected() {
|
|
155
159
|
const numSelected = this.selection.selected.length;
|
|
156
|
-
const numRows = this.dataSource
|
|
160
|
+
const numRows = this.context.dataSource?.data.length;
|
|
157
161
|
return numSelected === numRows;
|
|
158
162
|
}
|
|
159
163
|
/** Selects all rows if they are not all selected; otherwise clear selection. */
|
|
160
164
|
masterToggle() {
|
|
161
165
|
this.isAllSelected() ?
|
|
162
166
|
this.selection.clear() :
|
|
163
|
-
this.selection.select(...this.dataSource.data);
|
|
167
|
+
this.selection.select(...this.context.dataSource.data);
|
|
164
168
|
}
|
|
165
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: GenericTableComponent, deps: [{ token: i1.MatSort }, { token: i2.TableStore }, { token: i0.ViewContainerRef }, { token: i3.TransformCreator }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
166
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.3", type: GenericTableComponent, isStandalone: true, selector: "tb-generic-table", inputs: { trackBy: "trackBy", displayData$: "displayData$", data$: "data$",
|
|
169
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: GenericTableComponent, deps: [{ token: i1.MatSort }, { token: i2.TableStore }, { token: i0.ViewContainerRef }, { token: i3.TransformCreator }, { token: i0.Injector }, { token: "TABLE_CONTEXT" }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
170
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.3", type: GenericTableComponent, isStandalone: true, selector: "tb-generic-table", inputs: { trackBy: "trackBy", displayData$: "displayData$", data$: "data$", rows: "rows", columnBuilders: "columnBuilders", columnInfos: "columnInfos" }, outputs: { selection$: "selection$" }, viewQueries: [{ propertyName: "table", first: true, predicate: MatTable, descendants: true, static: true }, { propertyName: "dropList", first: true, predicate: CdkDropList, descendants: true, static: true }, { propertyName: "tableElRef", first: true, predicate: ["table"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<mat-table\r\n cdkDropList\r\n cdkDropListLockAxis='x'\r\n cdkDropListOrientation=\"horizontal\"\r\n (cdkDropListDropped)=\"drop($event)\"\r\n class=\"table-drag-list\"\r\n [class]=\"(showFooterRow$ | async)\"\r\n #table\r\n [dataSource]=\"context.dataSource!\"\r\n [trackBy]=\"trackByFunction\"\r\n [style]=\"tableWidth | async\"\r\n>\r\n\r\n <!-- select column -->\r\n <ng-container matColumnDef=\"select\">\r\n\r\n <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\">\r\n <mat-checkbox (change)=\"$event ? masterToggle() : null\"\r\n [checked]=\"!!(masterToggleChecked$ | async)\"\r\n [indeterminate]=\"masterToggleIndeterminate$ | async\">\r\n </mat-checkbox>\r\n </mat-header-cell>\r\n\r\n <mat-cell *matCellDef=\"let row\">\r\n <mat-checkbox\r\n (click)=\"$event.stopPropagation()\"\r\n (change)=\"$event ? selection.toggle(row) : null\"\r\n [checked]=\"selection.isSelected(row)\"/>\r\n </mat-cell>\r\n\r\n <mat-footer-cell *matFooterCellDef>\r\n {{ selection.selected.length }}\r\n </mat-footer-cell>\r\n </ng-container>\r\n\r\n <!-- index column -->\r\n <ng-container matColumnDef=\"index\">\r\n <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\" >#</mat-header-cell>\r\n <mat-cell *matCellDef=\"let i = index;\">\r\n {{ 1 + i + offsetIndex}}\r\n </mat-cell>\r\n <mat-footer-cell *matFooterCellDef></mat-footer-cell>\r\n </ng-container>\r\n\r\n <!-- Grouping -->\r\n <ng-container matColumnDef=\"groupHeader\">\r\n <mat-cell *matCellDef=\"let row\">\r\n <div [style.paddingLeft]=\"row.padding + 'px !important'\" *ngrxLet=\"(state.getIsExpanded | func : row.key : row.groupName ) as expanded\">\r\n <button mat-icon-button (click)=\"setExpanded(row.key, row.groupName, !expanded);\">\r\n @if(!expanded){\r\n <mat-icon>chevron_right</mat-icon>\r\n } @else {\r\n <mat-icon>expand_more</mat-icon>\r\n }\r\n </button>\r\n {{getTransform | func : row.key : row.groupHeaderDisplay}} ({{row.length}})\r\n </div>\r\n <div style=\"flex-grow: 1\">\r\n <ng-container *ngTemplateOutlet=\"props.groupHeaderTemplate!; context: { element: row }\"></ng-container>\r\n </div>\r\n </mat-cell>\r\n </ng-container>\r\n\r\n @if(showHeader$ | async){\r\n <mat-header-row *matHeaderRowDef=\"keys; sticky: props.isSticky\" [style.top.px]=\"((offset$ | async)! * -1)\" />\r\n }\r\n <mat-row *matRowDef=\"let row; columns: keys; let i = index\" />\r\n <mat-row *matRowDef=\"let row; columns: ['groupHeader']; when: isGroupHeader\" style=\"background-color: white;\" />\r\n <mat-footer-row *matFooterRowDef=\"(showFooterRow$ | async) === 'regular-footer' ? keys : []; sticky: props.stickyFooter \" [style.bottom.px]=\"props.stickyFooter ? (offset$ | async) : undefined\" />\r\n\r\n</mat-table>\r\n", styles: [".mat-mdc-row:nth-child(odd){background-color:#cdeefe}.page-amounts{color:#0000008a;font-family:Roboto,Helvetica Neue,sans-serif;font-size:12px;margin-right:.2rem}:host::ng-deep .mat-mdc-paginator-container{min-height:initial!important}.group-header{display:flex}:host::ng-deep .table-drag-list.cdk-drop-list-dragging .drag-header:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}:host::ng-deep .mdc-data-table__cell,:host::ng-deep .mdc-data-table__header-cell{padding:0 0 0 .2rem;line-height:normal}::ng-deep .op-date-time-input{line-height:3rem;font-size:.9rem;font-family:Roboto,Helvetica Neue,sans-serif;padding-left:.2rem;width:12rem}.small-footer mat-footer-row{min-height:1rem;height:1rem}.no-footer mat-footer-row{display:none}\n"], dependencies: [{ kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i4.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i4.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i4.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i4.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i4.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i4.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i4.MatFooterCellDef, selector: "[matFooterCellDef]" }, { kind: "directive", type: i4.MatFooterRowDef, selector: "[matFooterRowDef]", inputs: ["matFooterRowDef", "matFooterRowDefSticky"] }, { kind: "directive", type: i4.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i4.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "directive", type: i4.MatFooterCell, selector: "mat-footer-cell, td[mat-footer-cell]" }, { kind: "component", type: i4.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i4.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i4.MatFooterRow, selector: "mat-footer-row, tr[mat-footer-row]", exportAs: ["matFooterRow"] }, { kind: "ngmodule", type: DragDropModule }, { kind: "directive", type: i5.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i6.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i7.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: LetDirective, selector: "[ngrxLet]", inputs: ["ngrxLet", "ngrxLetSuspenseTpl"] }, { kind: "pipe", type: FunctionPipe, name: "func" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
167
171
|
}
|
|
168
172
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: GenericTableComponent, decorators: [{
|
|
169
173
|
type: Component,
|
|
170
174
|
args: [{ selector: 'tb-generic-table', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
171
175
|
MatTableModule, DragDropModule, MatCheckboxModule, MatButtonModule, MatIconModule, NgTemplateOutlet,
|
|
172
|
-
|
|
173
|
-
], template: "<mat-table\r\n cdkDropList\r\n cdkDropListLockAxis='x'\r\n cdkDropListOrientation=\"horizontal\"\r\n (cdkDropListDropped)=\"drop($event)\"\r\n class=\"table-drag-list\"\r\n [class]=\"(showFooterRow$ | async)\"\r\n #table\r\n [dataSource]=\"dataSource
|
|
174
|
-
}], ctorParameters: () => [{ type: i1.MatSort }, { type: i2.TableStore }, { type: i0.ViewContainerRef }, { type: i3.TransformCreator }, { type: i0.Injector }
|
|
176
|
+
MatTooltipModule, AsyncPipe, LetDirective, FunctionPipe,
|
|
177
|
+
], template: "<mat-table\r\n cdkDropList\r\n cdkDropListLockAxis='x'\r\n cdkDropListOrientation=\"horizontal\"\r\n (cdkDropListDropped)=\"drop($event)\"\r\n class=\"table-drag-list\"\r\n [class]=\"(showFooterRow$ | async)\"\r\n #table\r\n [dataSource]=\"context.dataSource!\"\r\n [trackBy]=\"trackByFunction\"\r\n [style]=\"tableWidth | async\"\r\n>\r\n\r\n <!-- select column -->\r\n <ng-container matColumnDef=\"select\">\r\n\r\n <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\">\r\n <mat-checkbox (change)=\"$event ? masterToggle() : null\"\r\n [checked]=\"!!(masterToggleChecked$ | async)\"\r\n [indeterminate]=\"masterToggleIndeterminate$ | async\">\r\n </mat-checkbox>\r\n </mat-header-cell>\r\n\r\n <mat-cell *matCellDef=\"let row\">\r\n <mat-checkbox\r\n (click)=\"$event.stopPropagation()\"\r\n (change)=\"$event ? selection.toggle(row) : null\"\r\n [checked]=\"selection.isSelected(row)\"/>\r\n </mat-cell>\r\n\r\n <mat-footer-cell *matFooterCellDef>\r\n {{ selection.selected.length }}\r\n </mat-footer-cell>\r\n </ng-container>\r\n\r\n <!-- index column -->\r\n <ng-container matColumnDef=\"index\">\r\n <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\" >#</mat-header-cell>\r\n <mat-cell *matCellDef=\"let i = index;\">\r\n {{ 1 + i + offsetIndex}}\r\n </mat-cell>\r\n <mat-footer-cell *matFooterCellDef></mat-footer-cell>\r\n </ng-container>\r\n\r\n <!-- Grouping -->\r\n <ng-container matColumnDef=\"groupHeader\">\r\n <mat-cell *matCellDef=\"let row\">\r\n <div [style.paddingLeft]=\"row.padding + 'px !important'\" *ngrxLet=\"(state.getIsExpanded | func : row.key : row.groupName ) as expanded\">\r\n <button mat-icon-button (click)=\"setExpanded(row.key, row.groupName, !expanded);\">\r\n @if(!expanded){\r\n <mat-icon>chevron_right</mat-icon>\r\n } @else {\r\n <mat-icon>expand_more</mat-icon>\r\n }\r\n </button>\r\n {{getTransform | func : row.key : row.groupHeaderDisplay}} ({{row.length}})\r\n </div>\r\n <div style=\"flex-grow: 1\">\r\n <ng-container *ngTemplateOutlet=\"props.groupHeaderTemplate!; context: { element: row }\"></ng-container>\r\n </div>\r\n </mat-cell>\r\n </ng-container>\r\n\r\n @if(showHeader$ | async){\r\n <mat-header-row *matHeaderRowDef=\"keys; sticky: props.isSticky\" [style.top.px]=\"((offset$ | async)! * -1)\" />\r\n }\r\n <mat-row *matRowDef=\"let row; columns: keys; let i = index\" />\r\n <mat-row *matRowDef=\"let row; columns: ['groupHeader']; when: isGroupHeader\" style=\"background-color: white;\" />\r\n <mat-footer-row *matFooterRowDef=\"(showFooterRow$ | async) === 'regular-footer' ? keys : []; sticky: props.stickyFooter \" [style.bottom.px]=\"props.stickyFooter ? (offset$ | async) : undefined\" />\r\n\r\n</mat-table>\r\n", styles: [".mat-mdc-row:nth-child(odd){background-color:#cdeefe}.page-amounts{color:#0000008a;font-family:Roboto,Helvetica Neue,sans-serif;font-size:12px;margin-right:.2rem}:host::ng-deep .mat-mdc-paginator-container{min-height:initial!important}.group-header{display:flex}:host::ng-deep .table-drag-list.cdk-drop-list-dragging .drag-header:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}:host::ng-deep .mdc-data-table__cell,:host::ng-deep .mdc-data-table__header-cell{padding:0 0 0 .2rem;line-height:normal}::ng-deep .op-date-time-input{line-height:3rem;font-size:.9rem;font-family:Roboto,Helvetica Neue,sans-serif;padding-left:.2rem;width:12rem}.small-footer mat-footer-row{min-height:1rem;height:1rem}.no-footer mat-footer-row{display:none}\n"] }]
|
|
178
|
+
}], ctorParameters: () => [{ type: i1.MatSort }, { type: i2.TableStore }, { type: i0.ViewContainerRef }, { type: i3.TransformCreator }, { type: i0.Injector }, { type: undefined, decorators: [{
|
|
179
|
+
type: Inject,
|
|
180
|
+
args: ["TABLE_CONTEXT"]
|
|
181
|
+
}] }], propDecorators: { trackBy: [{
|
|
175
182
|
type: Input
|
|
176
183
|
}], displayData$: [{
|
|
177
184
|
type: Input
|
|
178
185
|
}], data$: [{
|
|
179
186
|
type: Input
|
|
180
|
-
}], indexColumn: [{
|
|
181
|
-
type: Input
|
|
182
|
-
}], selectionColumn: [{
|
|
183
|
-
type: Input
|
|
184
187
|
}], rows: [{
|
|
185
188
|
type: Input
|
|
186
|
-
}], isSticky: [{
|
|
187
|
-
type: Input
|
|
188
189
|
}], columnBuilders: [{
|
|
189
190
|
type: Input
|
|
190
191
|
}], columnInfos: [{
|
|
191
192
|
type: Input
|
|
192
|
-
}], groupHeaderTemplate: [{
|
|
193
|
-
type: Input
|
|
194
193
|
}], table: [{
|
|
195
194
|
type: ViewChild,
|
|
196
195
|
args: [MatTable, { static: true }]
|
|
@@ -200,10 +199,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImpor
|
|
|
200
199
|
}], tableElRef: [{
|
|
201
200
|
type: ViewChild,
|
|
202
201
|
args: ['table', { read: ElementRef }]
|
|
203
|
-
}], paginatorComponent: [{
|
|
204
|
-
type: ViewChild,
|
|
205
|
-
args: [PaginatorComponent]
|
|
206
202
|
}], selection$: [{
|
|
207
203
|
type: Output
|
|
208
204
|
}] } });
|
|
209
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-table.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  Input,\r\n  ChangeDetectionStrategy,\r\n  Output,\r\n  SimpleChanges,\r\n  OnInit,\r\n  QueryList,\r\n  ViewContainerRef,\r\n  ElementRef,\r\n  Injector,\r\n  TemplateRef,\r\n} from '@angular/core';\r\nimport { MatSort } from '@angular/material/sort';\r\nimport { MatRowDef, MatTable, MatTableModule } from '@angular/material/table';\r\nimport { Observable, combineLatest } from 'rxjs';\r\nimport { SelectionModel } from '@angular/cdk/collections';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { tap, map, distinctUntilChanged } from 'rxjs/operators';\r\nimport { ColumnBuilderComponent } from '../column-builder/column-builder.component';\r\nimport { Dictionary } from '../../interfaces/dictionary';\r\nimport { FieldType } from '../../interfaces/report-def';\r\nimport { previousAndCurrent } from '../../../rxjs/rxjs-operators';\r\nimport { ColumnInfo } from '../../interfaces/ColumnInfo';\r\nimport { CdkDragDrop, CdkDropList, DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { PaginatorComponent } from './paginator.component';\r\nimport { FunctionPipe } from '../../../utilities';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { AsyncPipe, NgTemplateOutlet } from '@angular/common';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { LetDirective } from '@ngrx/component';\r\nimport { TransformCreator } from '../../services/transform-creator';\r\nimport { MatTableObservableDataSource } from '../../classes/MatTableObservableDataSource';\r\nimport { initIndexSymbol } from '../table-container/table-container.helpers/sort-state.helpers';\r\n\r\n@Component({\r\n  selector: 'tb-generic-table',\r\n  templateUrl: './generic-table.component.html',\r\n  styleUrls: ['./generic-table.component.scss','../../styles/collapser.styles.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    MatTableModule, DragDropModule, MatCheckboxModule, MatButtonModule, MatIconModule, NgTemplateOutlet,\r\n    PaginatorComponent, MatTooltipModule, AsyncPipe, LetDirective, FunctionPipe\r\n  ]\r\n})\r\nexport class GenericTableComponent implements OnInit {\r\n\r\n\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    this.state.setUserDefinedOrder({newOrder:event.currentIndex,oldOrder:event.previousIndex})\r\n  }\r\n  @Input() set trackBy(trackBy: string){\r\n    if(trackBy){\r\n      this.trackByFunction = (index:number, item: any) => item[trackBy];\r\n    }\r\n  }\r\n\r\n  @Input() displayData$!: Observable<any[]>;\r\n  @Input() data$!: Observable<any[]>;\r\n  @Input() indexColumn = false;\r\n  @Input() selectionColumn = false;\r\n  @Input() rows!: QueryList<MatRowDef<any>>;\r\n  @Input() isSticky = false;\r\n  @Input() columnBuilders!: ColumnBuilderComponent[];\r\n  @Input() columnInfos!: Observable<ColumnInfo[]>;\r\n  @Input() groupHeaderTemplate!: TemplateRef<any>;\r\n\r\n\r\n  @ViewChild(MatTable, { static: true }) table!: MatTable<any>;\r\n  @ViewChild(CdkDropList, { static: true }) dropList!: CdkDropList;\r\n  @ViewChild('table', {read: ElementRef}) tableElRef!: ElementRef;\r\n  @ViewChild(PaginatorComponent) paginatorComponent!: PaginatorComponent;\r\n  currentColumns!: string[];\r\n  dataSource!: MatTableObservableDataSource<any>;\r\n  keys: string [] = [];\r\n  injector: Injector;\r\n  rowDefArr :MatRowDef<any>[]= [];\r\n  columns:string [] = [];\r\n  myColumns: Dictionary<ColumnBuilderComponent> = {};\r\n  showHeader$!: Observable<boolean>;\r\n\r\n  constructor(\r\n    private sort: MatSort,\r\n    public state: TableStore,\r\n    private viewContainer: ViewContainerRef,\r\n    private transformCreator: TransformCreator,\r\n    injector: Injector,\r\n    ) {\r\n\r\n    this.injector = Injector.create({\r\n      providers: [\r\n        {provide: MatTable, useFactory: ()=> this.table },\r\n        {provide: CdkDropList, useFactory: ()=> this.dropList },\r\n      ],\r\n      parent: injector\r\n    });\r\n  }\r\n\r\n  defaultTrackBy = (index:number, item: any) => item[initIndexSymbol];\r\n  trackByFunction = this.defaultTrackBy;\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.rows && this.rows && this.myColumns.length) {\r\n      this.initializeRowDefs([...this.rows]);\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.selectionColumn) {\r\n      this.columns.push('select');\r\n    }\r\n\r\n    if (this.indexColumn) {\r\n     this.columns.push('index');\r\n    }\r\n\r\n    this.createDataSource();\r\n\r\n    this.state.on(this.columnInfos, columns => {\r\n      columns.forEach(ci => this.addMetaData(ci))\r\n    });\r\n\r\n    this.initializeRowDefs([...this.rows]);\r\n\r\n    this.state.on(this.state.displayedColumns$, keys => {\r\n      this.keys = [...this.columns, ...keys];\r\n      this.rowDefArr?.forEach(row => row.columns = this.keys)\r\n    });\r\n\r\n    this.showHeader$ = this.state.tableSettings$.pipe(map(settings => !(settings.hideColumnHeader)));\r\n\r\n    this.showFooterRow$ = combineLatest([\r\n      this.displayData$.pipe(map(d => !!d.length), distinctUntilChanged()),\r\n      this.state.metaDataArray$.pipe(map(metaData => metaData.some(md => !!md.additional?.footer)), distinctUntilChanged()),\r\n      this.columnInfos.pipe(map(columnInfos => columnInfos.some(ci => !!ci.customCell?.columnDef?.footerCell)), distinctUntilChanged()),\r\n    ]).pipe(map(([hasData, hasFooterDef, hasCustomFooter]) => {\r\n      const hasSelectionColumn = this.selectionColumn;\r\n      return hasCustomFooter || (hasData && (hasFooterDef || hasSelectionColumn)) ? 'regular-footer' : hasData ? 'no-footer' : 'small-footer';\r\n    }));\r\n  }\r\n\r\n  createDataSource() {\r\n    this.dataSource = new MatTableObservableDataSource(\r\n      this.displayData$.pipe(tap((d) => this.selection.clear() ))\r\n    );\r\n  }\r\n\r\n  isGroupHeader(_: number, row: { isGroupHeader: boolean }) {\r\n    return row.isGroupHeader;\r\n  }\r\n\r\n  setExpanded(key: string, groupKey: string, isExpanded: boolean): void {\r\n    this.state.updateExpandedGroups({ key , isExpanded, groupKey });\r\n  }\r\n\r\n  addMetaData(column: ColumnInfo) {\r\n    const columnBuilder = this.myColumns[column.metaData.key];\r\n    if(columnBuilder) {\r\n      columnBuilder.metaData = column.metaData;\r\n    } else {\r\n      const component = this.viewContainer.createComponent(ColumnBuilderComponent, {\r\n        index: 0,\r\n        injector: this.injector\r\n      });\r\n      component.instance.customCell = column.customCell;\r\n      component.instance.metaData = column.metaData;\r\n      component.instance.data$ = this.data$;\r\n      this.myColumns[column.metaData.key] = component.instance;\r\n    }\r\n  }\r\n\r\n  initializeRowDefs = (defs:MatRowDef<any>[])=>{\r\n    this.rowDefArr.forEach(r=>this.table.removeRowDef(r));\r\n    this.rowDefArr = defs;\r\n    defs.forEach(r => {\r\n      r.columns = this.columns.concat(Object.values(this.myColumns).filter(c => c.metaData.fieldType !== FieldType.Hidden).map(c => c.metaData.key));\r\n      if (this.table) {\r\n        this.table.addRowDef(r);\r\n      }\r\n    });\r\n  }\r\n\r\n  selection : SelectionModel<any> = new SelectionModel<any>(true, []);\r\n  @Output() selection$: Observable<any> = this.selection.changed;\r\n  masterToggleChecked$ = this.selection$.pipe(map(()=>this.selection.hasValue() && this.isAllSelected()));\r\n  masterToggleIndeterminate$ = this.selection$.pipe(map(()=>this.selection.hasValue() && !this.isAllSelected()));\r\n\r\n  isAllSelected() {\r\n    const numSelected = this.selection.selected.length;\r\n    const numRows = this.dataSource.data.length;\r\n    return numSelected === numRows;\r\n  }\r\n\r\n  /** Selects all rows if they are not all selected; otherwise clear selection. */\r\n  masterToggle() {\r\n    this.isAllSelected() ?\r\n      this.selection.clear() :\r\n      this.selection.select(...this.dataSource.data);\r\n  }\r\n\r\n  tableWidth = this.state.getUserDefinedTableSize$.pipe(\r\n    previousAndCurrent<number | undefined>(0),\r\n    map(([previousUserDefinedWidth, currentUserDefinedWidth]) => {\r\n      if( currentUserDefinedWidth){\r\n        return ({width:`${currentUserDefinedWidth}px`});\r\n      } if( wasReset() ){\r\n        return ({width:'initial'});\r\n      }\r\n      return ({});\r\n\r\n      function wasReset(){\r\n        return (previousUserDefinedWidth ?? 0) >=0 && currentUserDefinedWidth == null;\r\n      }\r\n    })\r\n  );\r\n  \r\n  showFooterRow$!: Observable<'regular-footer' | 'no-footer' | 'small-footer'>;\r\n  collapseFooter$ = this.state.state$.pipe(map(state => state.persistedTableSettings.collapseFooter));\r\n  getTransform = (key: string, val: string) => {\r\n    if(val == undefined || val === 'null') return '';\r\n    try {\r\n      return this.transformCreator.createTransformer(this.myColumns[key].metaData, true)({ [key]: val});\r\n    } catch (error) {\r\n      return val;\r\n    }\r\n  }\r\n}\r\n","<mat-table\r\n  cdkDropList\r\n  cdkDropListLockAxis='x'\r\n  cdkDropListOrientation=\"horizontal\"\r\n  (cdkDropListDropped)=\"drop($event)\"\r\n  class=\"table-drag-list\"\r\n  [class]=\"(showFooterRow$ | async)\"\r\n  #table\r\n  [dataSource]=\"dataSource\"\r\n  [trackBy]=\"trackByFunction\"\r\n  [style]=\"tableWidth | async\"\r\n>\r\n\r\n  <!-- select column -->\r\n  <ng-container matColumnDef=\"select\">\r\n\r\n    <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\">\r\n      <mat-checkbox (change)=\"$event ? masterToggle() : null\"\r\n                    [checked]=\"!!(masterToggleChecked$ | async)\"\r\n                    [indeterminate]=\"masterToggleIndeterminate$ | async\">\r\n      </mat-checkbox>\r\n    </mat-header-cell>\r\n\r\n    <mat-cell *matCellDef=\"let row\">\r\n      <mat-checkbox\r\n      (click)=\"$event.stopPropagation()\"\r\n      (change)=\"$event ? selection.toggle(row) : null\"\r\n      [checked]=\"selection.isSelected(row)\"/>\r\n    </mat-cell>\r\n\r\n    <mat-footer-cell *matFooterCellDef>\r\n      {{ selection.selected.length }}\r\n    </mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- index column -->\r\n  <ng-container matColumnDef=\"index\">\r\n      <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\" >#</mat-header-cell>\r\n      <mat-cell *matCellDef=\"let i = index;\"> {{ (tbPaginator.paginator.pageIndex * tbPaginator.paginator.pageSize) +  i + 1 }} </mat-cell>\r\n      <mat-footer-cell *matFooterCellDef></mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- Grouping -->\r\n  <ng-container matColumnDef=\"groupHeader\">\r\n    <mat-cell *matCellDef=\"let row\">\r\n      <div [style.paddingLeft]=\"row.padding + 'px !important'\" *ngrxLet=\"(state.getIsExpanded | func : row.key : row.groupName ) as expanded\">\r\n        <button mat-icon-button (click)=\"setExpanded(row.key, row.groupName, !expanded);\">\r\n          @if(!expanded){\r\n            <mat-icon>chevron_right</mat-icon>\r\n          } @else {\r\n            <mat-icon>expand_more</mat-icon> \r\n          }\r\n        </button>\r\n        {{getTransform | func : row.key :  row.groupHeaderDisplay}} ({{row.length}})\r\n      </div>\r\n      <div style=\"flex-grow: 1\">\r\n        <ng-container *ngTemplateOutlet=\"groupHeaderTemplate; context: { element: row }\"></ng-container>\r\n      </div>\r\n    </mat-cell>\r\n  </ng-container>\r\n\r\n  @if(showHeader$ | async){\r\n    <mat-header-row *matHeaderRowDef=\"keys; sticky: isSticky\" />\r\n  }\r\n  <mat-row *matRowDef=\"let row; columns: keys; let i = index\" />\r\n  <mat-row *matRowDef=\"let row; columns: ['groupHeader']; when: isGroupHeader\" style=\"background-color: white;\" />\r\n  <mat-footer-row *matFooterRowDef=\"(showFooterRow$ | async) === 'regular-footer' ? keys : []\" />\r\n\r\n</mat-table>\r\n\r\n<div class=\"flx-row-end sticky\">\r\n  <tb-paginator #tbPaginator\r\n    [dataSource]=\"dataSource\"\r\n    [tableElRef]=\"tableElRef\"\r\n    [data$]=\"data$\" />\r\n\r\n  <mat-icon [matTooltip]=\"(collapseFooter$ | async) ? 'expand' : 'collapse'\" class=\"collapse-icon footer\" (click)=\"state.toggleCollapseFooter()\">\r\n    {{(collapseFooter$ | async) ? 'expand_more' : 'expand_less'}}\r\n  </mat-icon>\r\n</div>\r\n"]}
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-table.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  Input,\r\n  ChangeDetectionStrategy,\r\n  Output,\r\n  SimpleChanges,\r\n  OnInit,\r\n  QueryList,\r\n  ViewContainerRef,\r\n  ElementRef,\r\n  Injector,\r\n  Inject,\r\n} from '@angular/core';\r\nimport { MatSort } from '@angular/material/sort';\r\nimport { MatRowDef, MatTable, MatTableModule } from '@angular/material/table';\r\nimport { Observable, combineLatest } from 'rxjs';\r\nimport { SelectionModel } from '@angular/cdk/collections';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { tap, map, distinctUntilChanged } from 'rxjs/operators';\r\nimport { ColumnBuilderComponent } from '../column-builder/column-builder.component';\r\nimport { Dictionary } from '../../interfaces/dictionary';\r\nimport { FieldType } from '../../interfaces/report-def';\r\nimport { previousAndCurrent } from '../../../rxjs/rxjs-operators';\r\nimport { ColumnInfo } from '../../interfaces/ColumnInfo';\r\nimport { CdkDragDrop, CdkDropList, DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { PaginatorComponent } from './paginator.component';\r\nimport { FunctionPipe } from '../../../utilities';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { AsyncPipe, NgTemplateOutlet } from '@angular/common';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { LetDirective } from '@ngrx/component';\r\nimport { TransformCreator } from '../../services/transform-creator';\r\nimport { initIndexSymbol } from '../table-container/table-container.helpers/sort-state.helpers';\r\nimport { tableProps } from '../table-container/tableProps';\r\nimport { TableContext } from '../table-context';\r\n\r\n@Component({\r\n  selector: 'tb-generic-table',\r\n  templateUrl: './generic-table.component.html',\r\n  styleUrls: ['./generic-table.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    MatTableModule, DragDropModule, MatCheckboxModule, MatButtonModule, MatIconModule, NgTemplateOutlet,\r\n    MatTooltipModule, AsyncPipe, LetDirective, FunctionPipe,\r\n  ],\r\n})\r\nexport class GenericTableComponent implements OnInit {\r\n\r\n  props!: tableProps;\r\n\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    this.state.setUserDefinedOrder({newOrder:event.currentIndex,oldOrder:event.previousIndex})\r\n  }\r\n  @Input() set trackBy(trackBy: string){\r\n    if(trackBy){\r\n      this.trackByFunction = (index:number, item: any) => item[trackBy];\r\n    }\r\n  }\r\n  @Input() displayData$!: Observable<any[]>;\r\n  @Input() data$!: Observable<any[]>;\r\n  @Input() rows!: QueryList<MatRowDef<any>>;\r\n  @Input() columnBuilders!: ColumnBuilderComponent[];\r\n  @Input() columnInfos!: Observable<ColumnInfo[]>;\r\n\r\n\r\n  @ViewChild(MatTable, { static: true }) table!: MatTable<any>;\r\n  @ViewChild(CdkDropList, { static: true }) dropList!: CdkDropList;\r\n  @ViewChild('table', {read: ElementRef}) set tableElRef(val: ElementRef) {\r\n    this.context.tableElRef = val;\r\n  }\r\n\r\n  currentColumns!: string[];\r\n  keys: string [] = [];\r\n  injector: Injector;\r\n  rowDefArr :MatRowDef<any>[] = [];\r\n  columns:string [] = [];\r\n  myColumns: Dictionary<ColumnBuilderComponent> = {};\r\n  showHeader$!: Observable<boolean>;\r\n  offset$! : Observable<number>;\r\n  offsetIndex = 0;\r\n  dataView!: Observable<any[]>;\r\n\r\n  constructor(\r\n    private sort: MatSort,\r\n    public state: TableStore,\r\n    private viewContainer: ViewContainerRef,\r\n    private transformCreator: TransformCreator,\r\n    injector: Injector,\r\n    @Inject(\"TABLE_CONTEXT\") public context: TableContext<any>,\r\n    ) {\r\n    this.props = context.tableProps;\r\n    this.injector = Injector.create({\r\n      providers: [\r\n        {provide: MatTable, useFactory: ()=> this.table },\r\n        {provide: CdkDropList, useFactory: ()=> this.dropList },\r\n      ],\r\n      parent: injector\r\n    });\r\n\r\n    this.offset$ = this.state.select( s => s.virtualScrollOffset );\r\n  }\r\n\r\n  defaultTrackBy = (index:number, item: any) => item[initIndexSymbol];\r\n  trackByFunction = this.defaultTrackBy;\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.rows && this.rows && this.myColumns.length) {\r\n      this.initializeRowDefs([...this.rows]);\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.props.selectionColumn) {\r\n      this.columns.push('select');\r\n    }\r\n\r\n    if (this.props.indexColumn) {\r\n     this.columns.push('index');\r\n    }\r\n\r\n    this.state.on(this.columnInfos, columns => {\r\n      columns.forEach(ci => this.addMetaData(ci))\r\n    });\r\n\r\n    this.initializeRowDefs([...this.rows]);\r\n\r\n    this.state.on(this.state.displayedColumns$, keys => {\r\n      this.keys = [...this.columns, ...keys];\r\n      this.rowDefArr?.forEach(row => row.columns = this.keys)\r\n    });\r\n\r\n    this.showHeader$ = this.state.tableSettings$.pipe(map(settings => !(settings.hideColumnHeader)));\r\n\r\n    this.showFooterRow$ = combineLatest([\r\n      this.displayData$.pipe(map(d => !!d.length), distinctUntilChanged()),\r\n      this.state.metaDataArray$.pipe(map(metaData => metaData.some(md => !!md.additional?.footer)), distinctUntilChanged()),\r\n      this.columnInfos.pipe(map(columnInfos => columnInfos.some(ci => !!ci.customCell?.columnDef?.footerCell)), distinctUntilChanged()),\r\n    ]).pipe(map(([hasData, hasFooterDef, hasCustomFooter]) => {\r\n      const hasSelectionColumn = this.props.selectionColumn;\r\n      return hasCustomFooter || (hasData && (hasFooterDef || hasSelectionColumn)) ? 'regular-footer' : hasData ? 'no-footer' : 'small-footer';\r\n    }));\r\n\r\n    if(this.context.tableProps.usePaginator || this.context.tableProps.useVirtualScroll) {\r\n      this.state.on(this.state.state$, (state) => {\r\n        this.offsetIndex = state.virtualStart;\r\n        if(this.context.tableProps.usePaginator) {\r\n          this.offsetIndex += (state.pageSize * state.currentPage);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  isGroupHeader(_: number, row: { isGroupHeader: boolean }) {\r\n    return row.isGroupHeader;\r\n  }\r\n\r\n  setExpanded(key: string, groupKey: string, isExpanded: boolean): void {\r\n    this.state.updateExpandedGroups({ key , isExpanded, groupKey });\r\n  }\r\n\r\n  addMetaData(column: ColumnInfo) {\r\n    const columnBuilder = this.myColumns[column.metaData.key];\r\n    if(columnBuilder) {\r\n      columnBuilder.metaData = column.metaData;\r\n    } else {\r\n      const component = this.viewContainer.createComponent(ColumnBuilderComponent, {\r\n        index: 0,\r\n        injector: this.injector\r\n      });\r\n      component.instance.customCell = column.customCell;\r\n      component.instance.metaData = column.metaData;\r\n      component.instance.data$ = this.data$;\r\n      this.myColumns[column.metaData.key] = component.instance;\r\n    }\r\n  }\r\n\r\n  initializeRowDefs = (defs:MatRowDef<any>[])=>{\r\n    this.rowDefArr.forEach(r=>this.table.removeRowDef(r));\r\n    this.rowDefArr = defs;\r\n    defs.forEach(r => {\r\n      r.columns = this.columns.concat(Object.values(this.myColumns).filter(c => c.metaData.fieldType !== FieldType.Hidden).map(c => c.metaData.key));\r\n      if (this.table) {\r\n        this.table.addRowDef(r);\r\n      }\r\n    });\r\n  }\r\n\r\n  selection : SelectionModel<any> = new SelectionModel<any>(true, []);\r\n  @Output() selection$: Observable<any> = this.selection.changed;\r\n  masterToggleChecked$ = this.selection$.pipe(map(()=>this.selection.hasValue() && this.isAllSelected()));\r\n  masterToggleIndeterminate$ = this.selection$.pipe(map(()=>this.selection.hasValue() && !this.isAllSelected()));\r\n\r\n  isAllSelected() {\r\n    const numSelected = this.selection.selected.length;\r\n    const numRows = this.context.dataSource?.data.length;\r\n    return numSelected === numRows;\r\n  }\r\n\r\n  /** Selects all rows if they are not all selected; otherwise clear selection. */\r\n  masterToggle() {\r\n    this.isAllSelected() ?\r\n      this.selection.clear() :\r\n      this.selection.select(...this.context.dataSource!.data);\r\n  }\r\n\r\n  tableWidth = this.state.getUserDefinedTableSize$.pipe(\r\n    previousAndCurrent<number | undefined>(0),\r\n    map(([previousUserDefinedWidth, currentUserDefinedWidth]) => {\r\n      if( currentUserDefinedWidth){\r\n        return ({width:`${currentUserDefinedWidth}px`});\r\n      } if( wasReset() ){\r\n        return ({width:'initial'});\r\n      }\r\n      return ({});\r\n\r\n      function wasReset(){\r\n        return (previousUserDefinedWidth ?? 0) >=0 && currentUserDefinedWidth == null;\r\n      }\r\n    })\r\n  );\r\n\r\n  showFooterRow$!: Observable<'regular-footer' | 'no-footer' | 'small-footer'>;\r\n  getTransform = (key: string, val: string) => {\r\n    if(val == undefined || val === 'null') return '';\r\n    try {\r\n      return this.transformCreator.createTransformer(this.myColumns[key].metaData, true)({ [key]: val});\r\n    } catch (error) {\r\n      return val;\r\n    }\r\n  }\r\n}\r\n","<mat-table\r\n  cdkDropList\r\n  cdkDropListLockAxis='x'\r\n  cdkDropListOrientation=\"horizontal\"\r\n  (cdkDropListDropped)=\"drop($event)\"\r\n  class=\"table-drag-list\"\r\n  [class]=\"(showFooterRow$ | async)\"\r\n  #table\r\n  [dataSource]=\"context.dataSource!\"\r\n  [trackBy]=\"trackByFunction\"\r\n  [style]=\"tableWidth | async\"\r\n>\r\n\r\n  <!-- select column -->\r\n  <ng-container matColumnDef=\"select\">\r\n\r\n    <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\">\r\n      <mat-checkbox (change)=\"$event ? masterToggle() : null\"\r\n                    [checked]=\"!!(masterToggleChecked$ | async)\"\r\n                    [indeterminate]=\"masterToggleIndeterminate$ | async\">\r\n      </mat-checkbox>\r\n    </mat-header-cell>\r\n\r\n    <mat-cell *matCellDef=\"let row\">\r\n      <mat-checkbox\r\n      (click)=\"$event.stopPropagation()\"\r\n      (change)=\"$event ? selection.toggle(row) : null\"\r\n      [checked]=\"selection.isSelected(row)\"/>\r\n    </mat-cell>\r\n\r\n    <mat-footer-cell *matFooterCellDef>\r\n      {{ selection.selected.length }}\r\n    </mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- index column -->\r\n  <ng-container matColumnDef=\"index\">\r\n      <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\" >#</mat-header-cell>\r\n      <mat-cell *matCellDef=\"let i = index;\">\r\n         {{ 1 + i + offsetIndex}}\r\n      </mat-cell>\r\n      <mat-footer-cell *matFooterCellDef></mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- Grouping -->\r\n  <ng-container matColumnDef=\"groupHeader\">\r\n    <mat-cell *matCellDef=\"let row\">\r\n      <div [style.paddingLeft]=\"row.padding + 'px !important'\" *ngrxLet=\"(state.getIsExpanded | func : row.key : row.groupName ) as expanded\">\r\n        <button mat-icon-button (click)=\"setExpanded(row.key, row.groupName, !expanded);\">\r\n          @if(!expanded){\r\n            <mat-icon>chevron_right</mat-icon>\r\n          } @else {\r\n            <mat-icon>expand_more</mat-icon>\r\n          }\r\n        </button>\r\n        {{getTransform | func : row.key :  row.groupHeaderDisplay}} ({{row.length}})\r\n      </div>\r\n      <div style=\"flex-grow: 1\">\r\n        <ng-container *ngTemplateOutlet=\"props.groupHeaderTemplate!; context: { element: row }\"></ng-container>\r\n      </div>\r\n    </mat-cell>\r\n  </ng-container>\r\n\r\n  @if(showHeader$ | async){\r\n    <mat-header-row *matHeaderRowDef=\"keys; sticky: props.isSticky\" [style.top.px]=\"((offset$ | async)! * -1)\"  />\r\n  }\r\n  <mat-row *matRowDef=\"let row; columns: keys; let i = index\" />\r\n  <mat-row *matRowDef=\"let row; columns: ['groupHeader']; when: isGroupHeader\" style=\"background-color: white;\" />\r\n  <mat-footer-row *matFooterRowDef=\"(showFooterRow$ | async) === 'regular-footer' ? keys : []; sticky: props.stickyFooter \"  [style.bottom.px]=\"props.stickyFooter ? (offset$ | async) : undefined\"  />\r\n\r\n</mat-table>\r\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, ChangeDetectionStrategy, ViewChild, Input, } from '@angular/core';
|
|
1
|
+
import { Component, ChangeDetectionStrategy, ViewChild, Input, Inject, } from '@angular/core';
|
|
2
2
|
import { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';
|
|
3
3
|
import { asyncScheduler, merge } from 'rxjs';
|
|
4
4
|
import { delay, distinct, distinctUntilKeyChanged, map } from 'rxjs/operators';
|
|
@@ -7,30 +7,33 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
import * as i1 from "../../classes/table-store";
|
|
8
8
|
import * as i2 from "@angular/material/paginator";
|
|
9
9
|
export class PaginatorComponent {
|
|
10
|
-
constructor(state) {
|
|
10
|
+
constructor(state, context) {
|
|
11
11
|
this.state = state;
|
|
12
|
+
this.context = context;
|
|
12
13
|
this.ourPageEvent = false;
|
|
13
14
|
}
|
|
14
15
|
ngOnInit() {
|
|
15
|
-
this.dataSource.paginator = this.paginator;
|
|
16
16
|
this.ourPageEvent = true;
|
|
17
17
|
this.state.on(metaDataPageSizeChange(this.state), setPaginatorPageSize(this.paginator));
|
|
18
|
-
this.state.setPageSize(onPaginatorPageSizeChange(this.paginator));
|
|
19
18
|
this.collapseFooter$ = this.state.state$.pipe(map(state => state.persistedTableSettings.collapseFooter));
|
|
19
|
+
this.state.on(this.paginator.page, (pageEvent) => {
|
|
20
|
+
this.state.updateState({ currentPage: pageEvent.pageIndex, pageSize: pageEvent.pageSize });
|
|
21
|
+
});
|
|
22
|
+
this.state.on(this.state.select(s => s.dataLen), (len) => this.paginator.length = len);
|
|
20
23
|
}
|
|
21
24
|
ngAfterViewInit() {
|
|
22
25
|
this.currentPageData$ = merge(this.paginator.page.pipe(map(mapPaginationEventToCurrentPageDetails)), this.data$.pipe(distinctUntilKeyChanged("length"), delayToAllowForProperUpdate, map(updateCurrentPageDetailsOnDataLengthChange(this.paginator))));
|
|
23
26
|
}
|
|
24
27
|
paginatorChange() {
|
|
25
28
|
if (!this.ourPageEvent) {
|
|
26
|
-
setTimeout(() => this.tableElRef?.nativeElement?.scrollIntoView(), 0);
|
|
29
|
+
setTimeout(() => this.context.tableElRef?.nativeElement?.scrollIntoView(), 0);
|
|
27
30
|
}
|
|
28
31
|
else {
|
|
29
32
|
this.ourPageEvent = false;
|
|
30
33
|
}
|
|
31
34
|
}
|
|
32
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: PaginatorComponent, deps: [{ token: i1.TableStore }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
33
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.3", type: PaginatorComponent, isStandalone: true, selector: "tb-paginator", inputs: {
|
|
35
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: PaginatorComponent, deps: [{ token: i1.TableStore }, { token: "TABLE_CONTEXT" }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
36
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.3", type: PaginatorComponent, isStandalone: true, selector: "tb-paginator", inputs: { data$: "data$" }, viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true, static: true }], ngImport: i0, template: `
|
|
34
37
|
@if(currentPageData$ | async; as pageData){
|
|
35
38
|
<div [ngClass]="{'hide' : !(collapseFooter$ | async), 'page-amounts':true}">
|
|
36
39
|
{{pageData.currentStart}} - {{pageData.currentEnd}} of {{pageData.total}}
|
|
@@ -39,7 +42,7 @@ export class PaginatorComponent {
|
|
|
39
42
|
<mat-paginator [pageSizeOptions]="[5, 10, 20, 50, 100, 500]" showFirstLastButtons (page)="paginatorChange()"
|
|
40
43
|
[ngClass]="{'hide' : (collapseFooter$ | async)}">
|
|
41
44
|
</mat-paginator>
|
|
42
|
-
`, isInline: true, styles: [".mat-mdc-row:nth-child(odd){background-color:#cdeefe}.
|
|
45
|
+
`, isInline: true, styles: [".mat-mdc-row:nth-child(odd){background-color:#cdeefe}.page-amounts{color:#0000008a;font-family:Roboto,Helvetica Neue,sans-serif;font-size:12px;margin-right:.2rem}:host::ng-deep .mat-mdc-paginator-container{min-height:initial!important}.group-header{display:flex}:host::ng-deep .table-drag-list.cdk-drop-list-dragging .drag-header:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}:host::ng-deep .mdc-data-table__cell,:host::ng-deep .mdc-data-table__header-cell{padding:0 0 0 .2rem;line-height:normal}::ng-deep .op-date-time-input{line-height:3rem;font-size:.9rem;font-family:Roboto,Helvetica Neue,sans-serif;padding-left:.2rem;width:12rem}.small-footer mat-footer-row{min-height:1rem;height:1rem}.no-footer mat-footer-row{display:none}\n", ".collapse-icon{font-size:16px;height:16px;color:#3f51b5;align-self:flex-start}.collapse-icon:hover{cursor:pointer}.hide{display:none}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatPaginatorModule }, { kind: "component", type: i2.MatPaginator, selector: "mat-paginator", inputs: ["disabled", "color", "pageIndex", "length", "pageSize", "pageSizeOptions", "hidePageSize", "showFirstLastButtons", "selectConfig"], outputs: ["page"], exportAs: ["matPaginator"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
43
46
|
}
|
|
44
47
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: PaginatorComponent, decorators: [{
|
|
45
48
|
type: Component,
|
|
@@ -52,12 +55,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImpor
|
|
|
52
55
|
<mat-paginator [pageSizeOptions]="[5, 10, 20, 50, 100, 500]" showFirstLastButtons (page)="paginatorChange()"
|
|
53
56
|
[ngClass]="{'hide' : (collapseFooter$ | async)}">
|
|
54
57
|
</mat-paginator>
|
|
55
|
-
`, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".mat-mdc-row:nth-child(odd){background-color:#cdeefe}.
|
|
56
|
-
}], ctorParameters: () => [{ type: i1.TableStore }
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
}], paginator: [{
|
|
58
|
+
`, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".mat-mdc-row:nth-child(odd){background-color:#cdeefe}.page-amounts{color:#0000008a;font-family:Roboto,Helvetica Neue,sans-serif;font-size:12px;margin-right:.2rem}:host::ng-deep .mat-mdc-paginator-container{min-height:initial!important}.group-header{display:flex}:host::ng-deep .table-drag-list.cdk-drop-list-dragging .drag-header:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}:host::ng-deep .mdc-data-table__cell,:host::ng-deep .mdc-data-table__header-cell{padding:0 0 0 .2rem;line-height:normal}::ng-deep .op-date-time-input{line-height:3rem;font-size:.9rem;font-family:Roboto,Helvetica Neue,sans-serif;padding-left:.2rem;width:12rem}.small-footer mat-footer-row{min-height:1rem;height:1rem}.no-footer mat-footer-row{display:none}\n", ".collapse-icon{font-size:16px;height:16px;color:#3f51b5;align-self:flex-start}.collapse-icon:hover{cursor:pointer}.hide{display:none}\n"] }]
|
|
59
|
+
}], ctorParameters: () => [{ type: i1.TableStore }, { type: undefined, decorators: [{
|
|
60
|
+
type: Inject,
|
|
61
|
+
args: ["TABLE_CONTEXT"]
|
|
62
|
+
}] }], propDecorators: { paginator: [{
|
|
61
63
|
type: ViewChild,
|
|
62
64
|
args: [MatPaginator, { static: true }]
|
|
63
65
|
}], data$: [{
|
|
@@ -74,5 +76,4 @@ const updateCurrentPageDetailsOnDataLengthChange = (paginator) => () => ({ curre
|
|
|
74
76
|
const delayToAllowForProperUpdate = delay(0, asyncScheduler);
|
|
75
77
|
const metaDataPageSizeChange = (state) => state.state$.pipe(map(state => state.userDefined.pageSize || state.pageSize), distinct());
|
|
76
78
|
const setPaginatorPageSize = (paginator) => (pageSize) => paginator._changePageSize(pageSize);
|
|
77
|
-
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/paginator.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ChangeDetectionStrategy,\r\n  ViewChild,\r\n  Input,\r\n  ElementRef,\r\n  AfterViewInit,\r\n  OnInit,\r\n} from '@angular/core';\r\nimport { MatPaginator, MatPaginatorModule, PageEvent } from '@angular/material/paginator';\r\nimport { asyncScheduler, merge, Observable } from 'rxjs';\r\nimport { delay, distinct, distinctUntilKeyChanged, map, tap } from 'rxjs/operators';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { AsyncPipe, NgClass } from '@angular/common';\r\nimport { MatTableObservableDataSource } from '../../classes/MatTableObservableDataSource';\r\n@Component({\r\n  selector: 'tb-paginator',\r\n  standalone: true,\r\n  imports: [AsyncPipe, MatPaginatorModule, NgClass],\r\n  template: `\r\n  @if(currentPageData$ | async; as pageData){\r\n    <div [ngClass]=\"{'hide' : !(collapseFooter$ | async), 'page-amounts':true}\">\r\n      {{pageData.currentStart}} - {{pageData.currentEnd}} of {{pageData.total}}\r\n    </div>\r\n  }\r\n  <mat-paginator [pageSizeOptions]=\"[5, 10, 20, 50, 100, 500]\" showFirstLastButtons (page)=\"paginatorChange()\"\r\n    [ngClass]=\"{'hide' : (collapseFooter$ | async)}\">\r\n  </mat-paginator>\r\n  `,\r\n  styleUrls: ['./generic-table.component.scss','../../styles/collapser.styles.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class PaginatorComponent implements OnInit, AfterViewInit{\r\n  @Input() dataSource! : MatTableObservableDataSource<any>;\r\n  @Input() tableElRef! : ElementRef\r\n  @ViewChild(MatPaginator, { static: true }) paginator!: MatPaginator;\r\n  currentPageData$!: Observable<CurrentPageDetails>;\r\n  collapseFooter$!:Observable<boolean>;\r\n  @Input() data$!: Observable<any[]>;\r\n\r\n  constructor(private state : TableStore){}\r\n  ngOnInit(){\r\n    this.dataSource.paginator = this.paginator;\r\n    this.ourPageEvent = true;\r\n    this.state.on(metaDataPageSizeChange(this.state), setPaginatorPageSize(this.paginator));\r\n    this.state.setPageSize(onPaginatorPageSizeChange(this.paginator));\r\n    this.collapseFooter$ = this.state.state$.pipe(map(state => state.persistedTableSettings.collapseFooter));\r\n\r\n  }\r\n  ngAfterViewInit(){\r\n    this.currentPageData$ = merge(\r\n      this.paginator.page.pipe(map(mapPaginationEventToCurrentPageDetails)),\r\n      this.data$.pipe(\r\n        distinctUntilKeyChanged(\"length\"),\r\n        delayToAllowForProperUpdate,\r\n        map(updateCurrentPageDetailsOnDataLengthChange(this.paginator)))\r\n    );\r\n  }\r\n\r\n  paginatorChange() : void {\r\n    if(!this.ourPageEvent){\r\n      setTimeout(() => this.tableElRef?.nativeElement?.scrollIntoView(), 0);\r\n    } else {\r\n      this.ourPageEvent = false;\r\n    }\r\n  }\r\n  ourPageEvent = false;\r\n}\r\n\r\nconst mapPaginationEventToCurrentPageDetails = (pageData: PageEvent):CurrentPageDetails => ({\r\n  currentStart : (pageData.pageIndex * pageData.pageSize) + 1,\r\n  currentEnd : Math.min(pageData.length , ((pageData.pageIndex + 1) * pageData.pageSize)),\r\n  total : pageData.length\r\n});\r\n\r\nconst updateCurrentPageDetailsOnDataLengthChange = (paginator:MatPaginator) => () => ({currentStart:(paginator.pageIndex * paginator.pageSize) + 1,\r\n  currentEnd: Math.min(paginator.length , ((paginator.pageIndex + 1) * paginator.pageSize)),\r\n  total:paginator.length})\r\n\r\nconst delayToAllowForProperUpdate = delay<any[]>(0,asyncScheduler);\r\n\r\ninterface CurrentPageDetails {\r\n  currentStart:number,\r\n  currentEnd:number,\r\n  total:number\r\n}\r\n\r\nconst metaDataPageSizeChange = (state:TableStore) => state.state$.pipe(map(state => state.userDefined.pageSize || state.pageSize), distinct());\r\n\r\nconst setPaginatorPageSize = (paginator:MatPaginator) => (pageSize: number) =>\r\n  paginator._changePageSize(pageSize);\r\n\r\nconst onPaginatorPageSizeChange = (paginator: MatPaginator) => paginator.page.pipe(map( e => e.pageSize ), distinct());\r\n"]}
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/paginator.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ChangeDetectionStrategy,\r\n  ViewChild,\r\n  Input,\r\n  AfterViewInit,\r\n  OnInit,\r\n  Inject,\r\n} from '@angular/core';\r\nimport { MatPaginator, MatPaginatorModule, PageEvent } from '@angular/material/paginator';\r\nimport { asyncScheduler, merge, Observable } from 'rxjs';\r\nimport { delay, distinct, distinctUntilKeyChanged, map, tap } from 'rxjs/operators';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { AsyncPipe, NgClass } from '@angular/common';\r\nimport { TableContext } from '../table-context';\r\n@Component({\r\n  selector: 'tb-paginator',\r\n  standalone: true,\r\n  imports: [AsyncPipe, MatPaginatorModule, NgClass],\r\n  template: `\r\n  @if(currentPageData$ | async; as pageData){\r\n    <div [ngClass]=\"{'hide' : !(collapseFooter$ | async), 'page-amounts':true}\">\r\n      {{pageData.currentStart}} - {{pageData.currentEnd}} of {{pageData.total}}\r\n    </div>\r\n  }\r\n  <mat-paginator [pageSizeOptions]=\"[5, 10, 20, 50, 100, 500]\" showFirstLastButtons (page)=\"paginatorChange()\"\r\n    [ngClass]=\"{'hide' : (collapseFooter$ | async)}\">\r\n  </mat-paginator>\r\n  `,\r\n  styleUrls: ['./generic-table.component.scss','../../styles/collapser.styles.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class PaginatorComponent implements OnInit, AfterViewInit{\r\n  @ViewChild(MatPaginator, { static: true }) paginator!: MatPaginator;\r\n  currentPageData$!: Observable<CurrentPageDetails>;\r\n  collapseFooter$!:Observable<boolean>;\r\n  @Input() data$!: Observable<any[]>;\r\n\r\n  constructor(private state : TableStore, @Inject(\"TABLE_CONTEXT\") private context: TableContext){}\r\n  ngOnInit(){\r\n    this.ourPageEvent = true;\r\n    this.state.on(metaDataPageSizeChange(this.state), setPaginatorPageSize(this.paginator));\r\n    this.collapseFooter$ = this.state.state$.pipe(map(state => state.persistedTableSettings.collapseFooter));\r\n    this.state.on(this.paginator.page, (pageEvent) => {\r\n      this.state.updateState({currentPage: pageEvent.pageIndex, pageSize: pageEvent.pageSize} )\r\n    });\r\n\r\n    this.state.on( this.state.select( s => s.dataLen), (len) => this.paginator.length = len);\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.currentPageData$ = merge(\r\n      this.paginator.page.pipe(map(mapPaginationEventToCurrentPageDetails)),\r\n      this.data$.pipe(\r\n        distinctUntilKeyChanged(\"length\"),\r\n        delayToAllowForProperUpdate,\r\n        map(updateCurrentPageDetailsOnDataLengthChange(this.paginator)))\r\n    );\r\n  }\r\n\r\n  paginatorChange() : void {\r\n    if(!this.ourPageEvent){\r\n      setTimeout(() => this.context.tableElRef?.nativeElement?.scrollIntoView(), 0);\r\n    } else {\r\n      this.ourPageEvent = false;\r\n    }\r\n  }\r\n  ourPageEvent = false;\r\n}\r\n\r\nconst mapPaginationEventToCurrentPageDetails = (pageData: PageEvent):CurrentPageDetails => ({\r\n  currentStart : (pageData.pageIndex * pageData.pageSize) + 1,\r\n  currentEnd : Math.min(pageData.length , ((pageData.pageIndex + 1) * pageData.pageSize)),\r\n  total : pageData.length\r\n});\r\n\r\nconst updateCurrentPageDetailsOnDataLengthChange = (paginator:MatPaginator) => () => ({currentStart:(paginator.pageIndex * paginator.pageSize) + 1,\r\n  currentEnd: Math.min(paginator.length , ((paginator.pageIndex + 1) * paginator.pageSize)),\r\n  total:paginator.length})\r\n\r\nconst delayToAllowForProperUpdate = delay<any[]>(0,asyncScheduler);\r\n\r\ninterface CurrentPageDetails {\r\n  currentStart:number,\r\n  currentEnd:number,\r\n  total:number\r\n}\r\n\r\nconst metaDataPageSizeChange = (state:TableStore) => state.state$.pipe(map(state => state.userDefined.pageSize || state.pageSize), distinct());\r\n\r\nconst setPaginatorPageSize = (paginator:MatPaginator) => (pageSize: number) =>\r\n  paginator._changePageSize(pageSize);\r\n"]}
|