@one-paragon/angular-utilities 1.2.11 → 1.2.13
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/action-state/ngrx.d.ts +1 -1
- package/esm2022/table-builder/classes/TableBuilderDataSource.mjs +18 -27
- package/esm2022/table-builder/classes/table-builder.mjs +2 -2
- package/esm2022/table-builder/classes/table-store.mjs +9 -13
- package/esm2022/table-builder/components/column-builder/column-helpers.mjs +1 -3
- package/esm2022/table-builder/components/gen-col-displayer/gen-col-displayer.component.mjs +11 -17
- package/esm2022/table-builder/components/generic-table/generic-table.component.mjs +21 -20
- package/esm2022/table-builder/components/generic-table/paginator.component.mjs +58 -56
- package/esm2022/table-builder/components/table-container/table-container.mjs +55 -51
- package/esm2022/table-builder/components/table-container/virtual-scroll-container.mjs +57 -34
- package/esm2022/table-builder/directives/tb-filter.directive.mjs +10 -19
- package/esm2022/table-builder/services/export-to-csv.service.mjs +6 -16
- package/fesm2022/one-paragon-angular-utilities.mjs +239 -242
- package/fesm2022/one-paragon-angular-utilities.mjs.map +1 -1
- package/package.json +1 -1
- package/table-builder/classes/TableBuilderDataSource.d.ts +4 -4
- package/table-builder/classes/table-store.d.ts +5 -3
- package/table-builder/components/gen-col-displayer/gen-col-displayer.component.d.ts +5 -3
- package/table-builder/components/generic-table/generic-table.component.d.ts +3 -1
- package/table-builder/components/generic-table/paginator.component.d.ts +20 -19
- package/table-builder/components/table-container/table-container-imports.d.ts +2 -2
- package/table-builder/components/table-container/table-container.d.ts +10 -11
- package/table-builder/components/table-container/virtual-scroll-container.d.ts +15 -2
- package/table-builder/directives/table-wrapper.directive.d.ts +1 -1
- package/table-builder/directives/tb-filter.directive.d.ts +2 -3
- package/table-builder/services/export-to-csv.service.d.ts +1 -6
|
@@ -1,43 +1,60 @@
|
|
|
1
|
-
import { Component, ChangeDetectionStrategy,
|
|
1
|
+
import { Component, ChangeDetectionStrategy, computed, inject, viewChild, input, effect, untracked } from '@angular/core';
|
|
2
2
|
import { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';
|
|
3
|
-
import {
|
|
4
|
-
import { delay, distinctUntilChanged, distinctUntilKeyChanged, map } from 'rxjs/operators';
|
|
3
|
+
import { switchMap } from 'rxjs/operators';
|
|
5
4
|
import { TableStore } from '../../classes/table-store';
|
|
6
|
-
import {
|
|
5
|
+
import { NgClass } from '@angular/common';
|
|
7
6
|
import { MatButtonModule } from '@angular/material/button';
|
|
8
7
|
import { DataStore } from '../../classes/data-store';
|
|
8
|
+
import { toObservable, toSignal } from '@angular/core/rxjs-interop';
|
|
9
|
+
import { notNull } from '../../../rxjs';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
import * as i1 from "@angular/material/paginator";
|
|
11
12
|
import * as i2 from "@angular/material/button";
|
|
12
13
|
export class PaginatorComponent {
|
|
13
14
|
state = inject(TableStore);
|
|
14
15
|
data = inject(DataStore);
|
|
15
|
-
paginator;
|
|
16
|
-
|
|
17
|
-
$
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
16
|
+
$paginator = viewChild(MatPaginator);
|
|
17
|
+
$tableElRef = input.required({ alias: 'tableElRef' });
|
|
18
|
+
$dataLength = this.data.selectSignal(d => d.dataLen);
|
|
19
|
+
pageEvent$ = toObservable(this.$paginator).pipe(notNull(), switchMap(p => p.page));
|
|
20
|
+
$pageEvent = toSignal(this.pageEvent$);
|
|
21
|
+
$pageIndexChangeEvent = computed(() => this.$pageEvent()?.pageIndex);
|
|
22
|
+
$pageSizeChangeEvent = computed(() => this.$pageEvent()?.pageSize);
|
|
23
|
+
$currentPageData = computed(() => {
|
|
24
|
+
const pageEvent = this.$pageEvent();
|
|
25
|
+
if (!pageEvent)
|
|
26
|
+
return;
|
|
27
|
+
const pageDetails = mapPaginationEventToCurrentPageDetails(pageEvent);
|
|
28
|
+
const dataLength = this.$dataLength();
|
|
29
|
+
return ({ ...pageDetails, total: dataLength });
|
|
30
|
+
});
|
|
31
|
+
onPageIndexEffect = effect(() => {
|
|
32
|
+
const index = this.$pageIndexChangeEvent();
|
|
33
|
+
untracked(() => this.state.updateState({ currentPage: index }));
|
|
34
|
+
});
|
|
35
|
+
onPageSizeEffect = effect(() => {
|
|
36
|
+
const size = this.$pageSizeChangeEvent();
|
|
37
|
+
if (!size)
|
|
38
|
+
return;
|
|
39
|
+
untracked(() => this.state.setPageSize(size));
|
|
40
|
+
});
|
|
41
|
+
onMetaPageSizeEffect = effect(() => {
|
|
42
|
+
const paginator = this.$paginator();
|
|
43
|
+
if (!paginator)
|
|
44
|
+
return;
|
|
45
|
+
const metaPageSize = this.state.$pageSize();
|
|
46
|
+
untracked(() => paginator._changePageSize(metaPageSize));
|
|
47
|
+
});
|
|
48
|
+
onDataLengthEffect = effect(() => {
|
|
49
|
+
const paginator = this.$paginator();
|
|
50
|
+
const dataLength = this.$dataLength();
|
|
51
|
+
untracked(() => {
|
|
52
|
+
if (paginator) {
|
|
53
|
+
paginator.length = dataLength;
|
|
54
|
+
}
|
|
25
55
|
});
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
}
|
|
29
|
-
ngAfterViewInit() {
|
|
30
|
-
this.currentPageData$ = merge(this.paginator.page.pipe(map(mapPaginationEventToCurrentPageDetails)), this.data$.pipe(distinctUntilKeyChanged("length"), delayToAllowForProperUpdate, map(updateCurrentPageDetailsOnDataLengthChange(this.paginator))));
|
|
31
|
-
}
|
|
32
|
-
paginatorChange() {
|
|
33
|
-
if (!this.ourPageEvent) {
|
|
34
|
-
setTimeout(() => this.tableElRef?.nativeElement?.scrollIntoView(), 0);
|
|
35
|
-
}
|
|
36
|
-
else {
|
|
37
|
-
this.ourPageEvent = false;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
ourPageEvent = false;
|
|
56
|
+
});
|
|
57
|
+
$collapseFooter = computed(() => this.state.selectSignal(state => state.persistedTableSettings.collapseFooter)() || this.$showAll());
|
|
41
58
|
$showAllOption = this.state.selectSignal(s => s.notPersistedTableSettings?.includeAllInPaginatorOptions);
|
|
42
59
|
$showAll = this.state.selectSignal(s => s.showAll);
|
|
43
60
|
updatePaginator = this.state.updater(state => ({ ...state, showAll: !state.showAll }));
|
|
@@ -45,54 +62,39 @@ export class PaginatorComponent {
|
|
|
45
62
|
this.updatePaginator();
|
|
46
63
|
}
|
|
47
64
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: PaginatorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
48
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: PaginatorComponent, isStandalone: true, selector: "tb-paginator", inputs: {
|
|
65
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: PaginatorComponent, isStandalone: true, selector: "tb-paginator", inputs: { $tableElRef: { classPropertyName: "$tableElRef", publicName: "tableElRef", isSignal: true, isRequired: true, transformFunction: null } }, viewQueries: [{ propertyName: "$paginator", first: true, predicate: MatPaginator, descendants: true, isSignal: true }], ngImport: i0, template: `
|
|
49
66
|
<div class="paginator-row">
|
|
50
|
-
@if(currentPageData
|
|
67
|
+
@if($currentPageData(); as pageData){
|
|
51
68
|
<div [class]="{ 'hide' : ! $collapseFooter(), 'page-amounts':true}">
|
|
52
|
-
@if(!$showAll()){{{pageData.currentStart}} - {{pageData.currentEnd}} of }{{pageData.total}}
|
|
69
|
+
@if(!$showAll()){ {{pageData.currentStart}} - {{pageData.currentEnd}} of }{{pageData.total}}
|
|
53
70
|
</div>
|
|
54
71
|
}
|
|
55
|
-
<mat-paginator [pageSizeOptions]="[5, 10, 20, 50, 100, 500]" showFirstLastButtons
|
|
72
|
+
<mat-paginator [pageSizeOptions]="[5, 10, 20, 50, 100, 500]" showFirstLastButtons
|
|
56
73
|
[class]="{ 'hide' : $collapseFooter() }">
|
|
57
74
|
</mat-paginator>
|
|
58
75
|
@if ($showAllOption()) {<button mat-button (click)="updatePaginator()"><span [style.text-decoration]="$showAll() ? 'line-through' : ''" >All</span></button>}
|
|
59
76
|
</div>
|
|
60
|
-
`, isInline: true, styles: [":host{--mat-paginator-container-size: initial}.select-column{min-width:var(--tb-min-select-column-width, 42px)}.index-column{min-width:var(--tb-min-index-column-width, 42px)}.mat-mdc-row:nth-child(odd){background-color:var(--tb-odd-row-background-color, #cdeefe)}.page-amounts{color:#0000008a;font-family:Roboto,Helvetica Neue,sans-serif;font-size:12px;margin-right:.2rem}: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:var(--tb-cell-padding, 0 0 0 .2rem);line-height:var(--tb-cell-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}\n", ".collapse-icon{font-size:16px;height:16px;color:#3f51b5;align-self:flex-start}.collapse-icon:hover{cursor:pointer}.hide{display:none}.paginator-row{display:flex;align-items:center}\n"], dependencies: [{ kind: "
|
|
77
|
+
`, isInline: true, styles: [":host{--mat-paginator-container-size: initial}.select-column{min-width:var(--tb-min-select-column-width, 42px)}.index-column{min-width:var(--tb-min-index-column-width, 42px)}.mat-mdc-row:nth-child(odd){background-color:var(--tb-odd-row-background-color, #cdeefe)}.page-amounts{color:#0000008a;font-family:Roboto,Helvetica Neue,sans-serif;font-size:12px;margin-right:.2rem}: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:var(--tb-cell-padding, 0 0 0 .2rem);line-height:var(--tb-cell-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}mat-table{overflow-x:auto}\n", ".collapse-icon{font-size:16px;height:16px;color:#3f51b5;align-self:flex-start}.collapse-icon:hover{cursor:pointer}.hide{display:none}.paginator-row{display:flex;align-items:center}\n"], dependencies: [{ kind: "ngmodule", type: MatPaginatorModule }, { kind: "component", type: i1.MatPaginator, selector: "mat-paginator", inputs: ["color", "pageIndex", "length", "pageSize", "pageSizeOptions", "hidePageSize", "showFirstLastButtons", "selectConfig", "disabled"], outputs: ["page"], exportAs: ["matPaginator"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
61
78
|
}
|
|
62
79
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: PaginatorComponent, decorators: [{
|
|
63
80
|
type: Component,
|
|
64
|
-
args: [{ selector: 'tb-paginator', standalone: true, imports: [
|
|
81
|
+
args: [{ selector: 'tb-paginator', standalone: true, imports: [MatPaginatorModule, NgClass, MatButtonModule], template: `
|
|
65
82
|
<div class="paginator-row">
|
|
66
|
-
@if(currentPageData
|
|
83
|
+
@if($currentPageData(); as pageData){
|
|
67
84
|
<div [class]="{ 'hide' : ! $collapseFooter(), 'page-amounts':true}">
|
|
68
|
-
@if(!$showAll()){{{pageData.currentStart}} - {{pageData.currentEnd}} of }{{pageData.total}}
|
|
85
|
+
@if(!$showAll()){ {{pageData.currentStart}} - {{pageData.currentEnd}} of }{{pageData.total}}
|
|
69
86
|
</div>
|
|
70
87
|
}
|
|
71
|
-
<mat-paginator [pageSizeOptions]="[5, 10, 20, 50, 100, 500]" showFirstLastButtons
|
|
88
|
+
<mat-paginator [pageSizeOptions]="[5, 10, 20, 50, 100, 500]" showFirstLastButtons
|
|
72
89
|
[class]="{ 'hide' : $collapseFooter() }">
|
|
73
90
|
</mat-paginator>
|
|
74
91
|
@if ($showAllOption()) {<button mat-button (click)="updatePaginator()"><span [style.text-decoration]="$showAll() ? 'line-through' : ''" >All</span></button>}
|
|
75
92
|
</div>
|
|
76
|
-
`, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{--mat-paginator-container-size: initial}.select-column{min-width:var(--tb-min-select-column-width, 42px)}.index-column{min-width:var(--tb-min-index-column-width, 42px)}.mat-mdc-row:nth-child(odd){background-color:var(--tb-odd-row-background-color, #cdeefe)}.page-amounts{color:#0000008a;font-family:Roboto,Helvetica Neue,sans-serif;font-size:12px;margin-right:.2rem}: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:var(--tb-cell-padding, 0 0 0 .2rem);line-height:var(--tb-cell-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}\n", ".collapse-icon{font-size:16px;height:16px;color:#3f51b5;align-self:flex-start}.collapse-icon:hover{cursor:pointer}.hide{display:none}.paginator-row{display:flex;align-items:center}\n"] }]
|
|
77
|
-
}]
|
|
78
|
-
type: ViewChild,
|
|
79
|
-
args: [MatPaginator, { static: true }]
|
|
80
|
-
}], data$: [{
|
|
81
|
-
type: Input
|
|
82
|
-
}], tableElRef: [{
|
|
83
|
-
type: Input,
|
|
84
|
-
args: [{ required: true }]
|
|
85
|
-
}] } });
|
|
93
|
+
`, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{--mat-paginator-container-size: initial}.select-column{min-width:var(--tb-min-select-column-width, 42px)}.index-column{min-width:var(--tb-min-index-column-width, 42px)}.mat-mdc-row:nth-child(odd){background-color:var(--tb-odd-row-background-color, #cdeefe)}.page-amounts{color:#0000008a;font-family:Roboto,Helvetica Neue,sans-serif;font-size:12px;margin-right:.2rem}: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:var(--tb-cell-padding, 0 0 0 .2rem);line-height:var(--tb-cell-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}mat-table{overflow-x:auto}\n", ".collapse-icon{font-size:16px;height:16px;color:#3f51b5;align-self:flex-start}.collapse-icon:hover{cursor:pointer}.hide{display:none}.paginator-row{display:flex;align-items:center}\n"] }]
|
|
94
|
+
}] });
|
|
86
95
|
const mapPaginationEventToCurrentPageDetails = (pageData) => ({
|
|
87
96
|
currentStart: (pageData.pageIndex * pageData.pageSize) + 1,
|
|
88
97
|
currentEnd: Math.min(pageData.length, ((pageData.pageIndex + 1) * pageData.pageSize)),
|
|
89
98
|
total: pageData.length
|
|
90
99
|
});
|
|
91
|
-
const updateCurrentPageDetailsOnDataLengthChange = (paginator) => () => ({ currentStart: (paginator.pageIndex * paginator.pageSize) + 1,
|
|
92
|
-
currentEnd: Math.min(paginator.length, ((paginator.pageIndex + 1) * paginator.pageSize)),
|
|
93
|
-
total: paginator.length });
|
|
94
|
-
const delayToAllowForProperUpdate = delay(0, asyncScheduler);
|
|
95
|
-
const metaDataPageSizeChange = (state) => state.state$.pipe(map(state => state.userDefined.pageSize || state.pageSize), distinctUntilChanged());
|
|
96
|
-
const setPaginatorPageSize = (paginator) => (pageSize) => paginator._changePageSize(pageSize);
|
|
97
|
-
const onPaginatorPageSizeChange = (paginator) => paginator.page.pipe(map(e => e.pageSize), distinctUntilChanged());
|
|
98
|
-
//# 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 { Component, ChangeDetectionStrategy, ViewChild, Input, AfterViewInit, OnInit, ElementRef, computed, inject } from '@angular/core';\r\nimport { MatPaginator, MatPaginatorModule, PageEvent } from '@angular/material/paginator';\r\nimport { asyncScheduler, merge, Observable } from 'rxjs';\r\nimport { delay, distinctUntilChanged, distinctUntilKeyChanged, map } from 'rxjs/operators';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { AsyncPipe, NgClass } from '@angular/common';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { DataStore } from '../../classes/data-store';\r\n\r\n@Component({\r\n  selector: 'tb-paginator',\r\n  standalone: true,\r\n  imports: [AsyncPipe, MatPaginatorModule, NgClass, MatButtonModule],\r\n  template: `\r\n  <div class=\"paginator-row\">\r\n    @if(currentPageData$ | async; as pageData){\r\n      <div [class]=\"{ 'hide' : ! $collapseFooter(), 'page-amounts':true}\">\r\n        @if(!$showAll()){{{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      [class]=\"{ 'hide' : $collapseFooter() }\">\r\n    </mat-paginator>\r\n    @if ($showAllOption()) {<button mat-button (click)=\"updatePaginator()\"><span [style.text-decoration]=\"$showAll() ? 'line-through' : ''\" >All</span></button>}\r\n  </div>\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  private state = inject(TableStore);\r\n  private data = inject(DataStore);\r\n  @ViewChild(MatPaginator, { static: true }) paginator!: MatPaginator;\r\n  currentPageData$!: Observable<CurrentPageDetails>;\r\n  $collapseFooter = computed(() => this.state.selectSignal(state => state.persistedTableSettings.collapseFooter)() || this.$showAll());\r\n  @Input() data$!: Observable<any[]>;\r\n  @Input({ required: true }) tableElRef! : ElementRef\r\n  ngOnInit(){\r\n    this.ourPageEvent = true;\r\n    this.state.on(metaDataPageSizeChange(this.state), setPaginatorPageSize(this.paginator));\r\n    this.state.on(this.paginator.page, (pageEvent) => {\r\n      this.state.updateState({currentPage: pageEvent.pageIndex} );\r\n    });\r\n    this.state.setPageSize(onPaginatorPageSizeChange(this.paginator))\r\n\r\n    this.state.on( this.data.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.tableElRef?.nativeElement?.scrollIntoView(), 0);\r\n    } else {\r\n      this.ourPageEvent = false;\r\n    }\r\n  }\r\n  ourPageEvent = false;\r\n\r\n  $showAllOption = this.state.selectSignal(s => s.notPersistedTableSettings?.includeAllInPaginatorOptions);\r\n  $showAll = this.state.selectSignal(s => s.showAll);\r\n  updatePaginator = this.state.updater(state => ({ ...state, showAll: !state.showAll }));\r\n  showAll(){\r\n    this.updatePaginator();\r\n  }\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), distinctUntilChanged());\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 ), distinctUntilChanged());"]}
|
|
100
|
+
//# 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 { Component, ChangeDetectionStrategy, ElementRef, computed, inject, viewChild, input, effect, untracked } from '@angular/core';\r\nimport { MatPaginator, MatPaginatorModule, PageEvent } from '@angular/material/paginator';\r\nimport { switchMap } from 'rxjs/operators';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { NgClass } from '@angular/common';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { DataStore } from '../../classes/data-store';\r\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\r\nimport { notNull } from '../../../rxjs';\r\n\r\n@Component({\r\n  selector: 'tb-paginator',\r\n  standalone: true,\r\n  imports: [MatPaginatorModule, NgClass, MatButtonModule],\r\n  template: `\r\n  <div class=\"paginator-row\">\r\n    @if($currentPageData(); as pageData){\r\n      <div [class]=\"{ 'hide' : ! $collapseFooter(), 'page-amounts':true}\">\r\n        @if(!$showAll()){ {{pageData.currentStart}} - {{pageData.currentEnd}} of }{{pageData.total}}\r\n      </div>\r\n    }\r\n    <mat-paginator [pageSizeOptions]=\"[5, 10, 20, 50, 100, 500]\" showFirstLastButtons\r\n      [class]=\"{ 'hide' : $collapseFooter() }\">\r\n    </mat-paginator>\r\n    @if ($showAllOption()) {<button mat-button (click)=\"updatePaginator()\"><span [style.text-decoration]=\"$showAll() ? 'line-through' : ''\" >All</span></button>}\r\n  </div>\r\n  `,\r\n  styleUrls: ['./generic-table.component.scss','../../styles/collapser.styles.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class PaginatorComponent {\r\n  private state = inject(TableStore);\r\n  private data = inject(DataStore);\r\n  $paginator = viewChild(MatPaginator);\r\n  $tableElRef = input.required<ElementRef<HTMLDivElement>>({alias: 'tableElRef'});\r\n\r\n  $dataLength = this.data.selectSignal(d => d.dataLen);\r\n  pageEvent$ = toObservable(this.$paginator).pipe(notNull(), switchMap(p => p.page));\r\n  $pageEvent = toSignal(this.pageEvent$);\r\n  $pageIndexChangeEvent = computed(() => this.$pageEvent()?.pageIndex);\r\n  $pageSizeChangeEvent = computed(() => this.$pageEvent()?.pageSize);\r\n  $currentPageData = computed(() => {\r\n    const pageEvent = this.$pageEvent();\r\n    if(!pageEvent) return;\r\n    const pageDetails = mapPaginationEventToCurrentPageDetails(pageEvent);\r\n    const dataLength = this.$dataLength();\r\n    return ({...pageDetails, total: dataLength})\r\n  })\r\n\r\n  onPageIndexEffect = effect(() => {\r\n    const index = this.$pageIndexChangeEvent();\r\n    untracked(() => this.state.updateState({currentPage: index}))\r\n  });\r\n  onPageSizeEffect = effect(() => {\r\n    const size = this.$pageSizeChangeEvent();\r\n    if(!size) return;\r\n    untracked(() => this.state.setPageSize(size));\r\n  });\r\n  onMetaPageSizeEffect = effect(() => {\r\n    const paginator = this.$paginator();\r\n    if(!paginator) return;\r\n    const metaPageSize = this.state.$pageSize();\r\n    untracked(() => paginator._changePageSize(metaPageSize));\r\n  });\r\n  onDataLengthEffect = effect(() => {\r\n    const paginator = this.$paginator();\r\n    const dataLength = this.$dataLength();\r\n    untracked(() => {\r\n      if(paginator){\r\n        paginator.length = dataLength;\r\n      }\r\n    })\r\n  });\r\n  $collapseFooter = computed(() => this.state.selectSignal(state => state.persistedTableSettings.collapseFooter)() || this.$showAll());\r\n  $showAllOption = this.state.selectSignal(s => s.notPersistedTableSettings?.includeAllInPaginatorOptions);\r\n  $showAll = this.state.selectSignal(s => s.showAll);\r\n  updatePaginator = this.state.updater(state => ({ ...state, showAll: !state.showAll }));\r\n  showAll(){\r\n    this.updatePaginator();\r\n  }\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\n\r\ninterface CurrentPageDetails {\r\n  currentStart:number,\r\n  currentEnd:number,\r\n  total:number\r\n}"]}
|