@enigmatry/entry-components 15.2.0 → 16.0.0-preview
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/common/directives/auto-disable-button.directive.d.ts +1 -1
- package/dialog/dialogs/entry-dialog.component.d.ts +1 -1
- package/{esm2020 → esm2022}/button/entry-button.directive.mjs +4 -4
- package/{esm2020 → esm2022}/button/entry-button.module.mjs +7 -7
- package/{esm2020 → esm2022}/common/common.module.mjs +7 -7
- package/{esm2020 → esm2022}/common/date-time/entry-date-time-adapter.mjs +4 -4
- package/{esm2020 → esm2022}/common/directives/auto-disable-button.directive.mjs +4 -4
- package/{esm2020 → esm2022}/common/directives/scroll-to-invalid-control.directive.mjs +4 -4
- package/{esm2020 → esm2022}/common/event-plugins/debounce.plugin.mjs +4 -4
- package/{esm2020 → esm2022}/common/event-plugins/throttle.plugin.mjs +4 -4
- package/{esm2020 → esm2022}/common/interceptors/accept-language.interceptor.mjs +4 -4
- package/{esm2020 → esm2022}/dialog/dialogs/alert/entry-alert-dialog.component.mjs +4 -4
- package/{esm2020 → esm2022}/dialog/dialogs/confirm/entry-confirm-dialog.component.mjs +4 -4
- package/{esm2020 → esm2022}/dialog/dialogs/entry-dialog.component.mjs +4 -4
- package/{esm2020 → esm2022}/dialog/dialogs/error/entry-error-dialog.component.mjs +4 -4
- package/{esm2020 → esm2022}/dialog/entry-dialog.module.mjs +19 -19
- package/esm2022/dialog/entry-dialog.service.mjs +86 -0
- package/esm2022/file-input/entry-file-input.component.mjs +201 -0
- package/{esm2020 → esm2022}/file-input/entry-file-input.module.mjs +13 -13
- package/{esm2020 → esm2022}/modules/entry-components.module.mjs +21 -21
- package/{esm2020 → esm2022}/permissions/permission.directive.mjs +4 -4
- package/{esm2020 → esm2022}/permissions/permission.module.mjs +7 -7
- package/{esm2020 → esm2022}/permissions/permission.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/search-filter/autocomplete/autocomplete-search-filter.component.mjs +4 -4
- package/esm2022/search-filter/date/date-search-filter.component.mjs +19 -0
- package/{esm2020 → esm2022}/search-filter/date-time/date-time-search-filter.component.mjs +7 -7
- package/{esm2020 → esm2022}/search-filter/entry-search-filter.component.mjs +4 -4
- package/{esm2020 → esm2022}/search-filter/entry-search-filter.module.mjs +28 -28
- package/{esm2020 → esm2022}/search-filter/select/select-search-filter.component.mjs +4 -4
- package/{esm2020 → esm2022}/search-filter/text/text-search-filter.component.mjs +4 -4
- package/{esm2020 → esm2022}/spinner/entry-spinner/spinner.component.mjs +10 -10
- package/{esm2020 → esm2022}/spinner/spinner-overlay-container.mjs +4 -4
- package/{esm2020 → esm2022}/spinner/spinner.module.mjs +9 -9
- package/{esm2020 → esm2022}/table/components/entry-cell/entry-cell.component.mjs +4 -4
- package/{esm2020 → esm2022}/table/components/entry-cell-context-menu/entry-cell-context-menu.component.mjs +4 -4
- package/{esm2020 → esm2022}/table/components/entry-cell-formatted-value/entry-cell-formatted-value.component.mjs +4 -4
- package/esm2022/table/components/entry-table/entry-table.component.mjs +248 -0
- package/{esm2020 → esm2022}/table/entry-table.module.mjs +33 -33
- package/{esm2020 → esm2022}/table/interfaces/entry-table-config.mjs +1 -2
- package/{esm2020 → esm2022}/validation/entry-display-control-validation.directive.mjs +4 -4
- package/{esm2020 → esm2022}/validation/entry-form-errors.component.mjs +6 -6
- package/{esm2020 → esm2022}/validation/entry-validation.module.mjs +13 -13
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-button.mjs +9 -9
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-button.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-common.mjs +24 -24
- package/{fesm2015 → fesm2022}/enigmatry-entry-components-common.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-dialog.mjs +33 -33
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-dialog.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-file-input.mjs +21 -17
- package/fesm2022/enigmatry-entry-components-file-input.mjs.map +1 -0
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-permissions.mjs +12 -12
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-permissions.mjs.map +1 -1
- package/fesm2022/enigmatry-entry-components-search-filter.mjs +387 -0
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-search-filter.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-spinner.mjs +20 -20
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-spinner.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-table.mjs +44 -45
- package/fesm2022/enigmatry-entry-components-table.mjs.map +1 -0
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-validation.mjs +20 -20
- package/{fesm2020 → fesm2022}/enigmatry-entry-components-validation.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/enigmatry-entry-components.mjs +20 -20
- package/{fesm2020 → fesm2022}/enigmatry-entry-components.mjs.map +1 -1
- package/file-input/entry-file-input.component.d.ts +1 -1
- package/package.json +39 -63
- package/permissions/permission.directive.d.ts +1 -1
- package/search-filter/autocomplete/autocomplete-search-filter.component.d.ts +1 -1
- package/search-filter/date/date-search-filter.component.d.ts +1 -1
- package/search-filter/date-time/date-time-search-filter.component.d.ts +1 -1
- package/search-filter/entry-search-filter.component.d.ts +1 -1
- package/search-filter/select/select-search-filter.component.d.ts +1 -1
- package/search-filter/text/text-search-filter.component.d.ts +1 -1
- package/spinner/entry-spinner/spinner.component.d.ts +1 -1
- package/table/components/entry-cell/entry-cell.component.d.ts +1 -1
- package/table/components/entry-cell-context-menu/entry-cell-context-menu.component.d.ts +1 -1
- package/table/components/entry-cell-formatted-value/entry-cell-formatted-value.component.d.ts +1 -1
- package/table/components/entry-table/entry-table.component.d.ts +1 -1
- package/validation/entry-display-control-validation.directive.d.ts +1 -1
- package/validation/entry-form-errors.component.d.ts +1 -1
- package/esm2020/dialog/entry-dialog.service.mjs +0 -86
- package/esm2020/file-input/entry-file-input.component.mjs +0 -197
- package/esm2020/search-filter/date/date-search-filter.component.mjs +0 -19
- package/esm2020/table/components/entry-table/entry-table.component.mjs +0 -248
- package/fesm2015/enigmatry-entry-components-button.mjs +0 -114
- package/fesm2015/enigmatry-entry-components-button.mjs.map +0 -1
- package/fesm2015/enigmatry-entry-components-common.mjs +0 -405
- package/fesm2015/enigmatry-entry-components-dialog.mjs +0 -333
- package/fesm2015/enigmatry-entry-components-dialog.mjs.map +0 -1
- package/fesm2015/enigmatry-entry-components-file-input.mjs +0 -237
- package/fesm2015/enigmatry-entry-components-file-input.mjs.map +0 -1
- package/fesm2015/enigmatry-entry-components-permissions.mjs +0 -98
- package/fesm2015/enigmatry-entry-components-permissions.mjs.map +0 -1
- package/fesm2015/enigmatry-entry-components-search-filter.mjs +0 -394
- package/fesm2015/enigmatry-entry-components-search-filter.mjs.map +0 -1
- package/fesm2015/enigmatry-entry-components-spinner.mjs +0 -156
- package/fesm2015/enigmatry-entry-components-spinner.mjs.map +0 -1
- package/fesm2015/enigmatry-entry-components-table.mjs +0 -462
- package/fesm2015/enigmatry-entry-components-table.mjs.map +0 -1
- package/fesm2015/enigmatry-entry-components-validation.mjs +0 -219
- package/fesm2015/enigmatry-entry-components-validation.mjs.map +0 -1
- package/fesm2015/enigmatry-entry-components.mjs +0 -87
- package/fesm2015/enigmatry-entry-components.mjs.map +0 -1
- package/fesm2020/enigmatry-entry-components-common.mjs.map +0 -1
- package/fesm2020/enigmatry-entry-components-file-input.mjs.map +0 -1
- package/fesm2020/enigmatry-entry-components-search-filter.mjs +0 -387
- package/fesm2020/enigmatry-entry-components-table.mjs.map +0 -1
- /package/{esm2020 → esm2022}/button/enigmatry-entry-components-button.mjs +0 -0
- /package/{esm2020 → esm2022}/button/entry-button-config.mjs +0 -0
- /package/{esm2020 → esm2022}/button/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/common/constants.mjs +0 -0
- /package/{esm2020 → esm2022}/common/date-time/entry-date-time.mjs +0 -0
- /package/{esm2020 → esm2022}/common/date-time/index.mjs +0 -0
- /package/{esm2020 → esm2022}/common/directives/index.mjs +0 -0
- /package/{esm2020 → esm2022}/common/enigmatry-entry-components-common.mjs +0 -0
- /package/{esm2020 → esm2022}/common/event-plugins/abstract.plugin.mjs +0 -0
- /package/{esm2020 → esm2022}/common/event-plugins/index.mjs +0 -0
- /package/{esm2020 → esm2022}/common/interceptors/index.mjs +0 -0
- /package/{esm2020 → esm2022}/common/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/common/utils/index.mjs +0 -0
- /package/{esm2020 → esm2022}/common/utils/provide-config.mjs +0 -0
- /package/{esm2020 → esm2022}/dialog/dialogs/alert/entry-alert-dialog-data.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/dialog/dialogs/confirm/entry-confirm-dialog-data.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/dialog/dialogs/error/entry-error-dialog-data.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/dialog/enigmatry-entry-components-dialog.mjs +0 -0
- /package/{esm2020 → esm2022}/dialog/entry-dialog-buttons-alignment.type.mjs +0 -0
- /package/{esm2020 → esm2022}/dialog/entry-dialog-config.model.mjs +0 -0
- /package/{esm2020 → esm2022}/dialog/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/enigmatry-entry-components.mjs +0 -0
- /package/{esm2020 → esm2022}/file-input/enigmatry-entry-components-file-input.mjs +0 -0
- /package/{esm2020 → esm2022}/file-input/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/permissions/enigmatry-entry-components-permissions.mjs +0 -0
- /package/{esm2020 → esm2022}/permissions/permission-type.mjs +0 -0
- /package/{esm2020 → esm2022}/permissions/permission.guard.mjs +0 -0
- /package/{esm2020 → esm2022}/permissions/permission.service.mjs +0 -0
- /package/{esm2020 → esm2022}/permissions/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/search-filter/autocomplete/autocomplete-search-filter.model.mjs +0 -0
- /package/{esm2020 → esm2022}/search-filter/control-type.mjs +0 -0
- /package/{esm2020 → esm2022}/search-filter/date/date-search-filter.model.mjs +0 -0
- /package/{esm2020 → esm2022}/search-filter/date-time/date-time-search-filter.model.mjs +0 -0
- /package/{esm2020 → esm2022}/search-filter/enigmatry-entry-components-search-filter.mjs +0 -0
- /package/{esm2020 → esm2022}/search-filter/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/search-filter/search-filter-base.model.mjs +0 -0
- /package/{esm2020 → esm2022}/search-filter/search-filter-config.model.mjs +0 -0
- /package/{esm2020 → esm2022}/search-filter/search-filter-params.type.mjs +0 -0
- /package/{esm2020 → esm2022}/search-filter/select/select-search-filter.model.mjs +0 -0
- /package/{esm2020 → esm2022}/search-filter/select-option.model.mjs +0 -0
- /package/{esm2020 → esm2022}/search-filter/text/text-search-filter.model.mjs +0 -0
- /package/{esm2020 → esm2022}/spinner/enigmatry-entry-components-spinner.mjs +0 -0
- /package/{esm2020 → esm2022}/spinner/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/table/components/index.mjs +0 -0
- /package/{esm2020 → esm2022}/table/enigmatry-entry-components-table.mjs +0 -0
- /package/{esm2020 → esm2022}/table/interfaces/cell-template.mjs +0 -0
- /package/{esm2020 → esm2022}/table/interfaces/column-def.mjs +0 -0
- /package/{esm2020 → esm2022}/table/interfaces/column-sort-prop.mjs +0 -0
- /package/{esm2020 → esm2022}/table/interfaces/column-type-parameter.mjs +0 -0
- /package/{esm2020 → esm2022}/table/interfaces/column-type.mjs +0 -0
- /package/{esm2020 → esm2022}/table/interfaces/context-menu-item.mjs +0 -0
- /package/{esm2020 → esm2022}/table/interfaces/index.mjs +0 -0
- /package/{esm2020 → esm2022}/table/interfaces/paged-query.mjs +0 -0
- /package/{esm2020 → esm2022}/table/interfaces/pagination.mjs +0 -0
- /package/{esm2020 → esm2022}/table/interfaces/row-class-formatter.mjs +0 -0
- /package/{esm2020 → esm2022}/table/interfaces/row-context-menu-formatter.mjs +0 -0
- /package/{esm2020 → esm2022}/table/interfaces/row-selection-formatter.mjs +0 -0
- /package/{esm2020 → esm2022}/table/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/validation/enigmatry-entry-components-validation.mjs +0 -0
- /package/{esm2020 → esm2022}/validation/entry-validation-config.model.mjs +0 -0
- /package/{esm2020 → esm2022}/validation/entry-validation.mjs +0 -0
- /package/{esm2020 → esm2022}/validation/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/validation/validation-problem-details.interface.mjs +0 -0
|
@@ -15,10 +15,10 @@ export class EntryCellContextMenuComponent {
|
|
|
15
15
|
? this.rowMenuFormatter.items(this.rowData)
|
|
16
16
|
: this.items;
|
|
17
17
|
}
|
|
18
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryCellContextMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
19
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EntryCellContextMenuComponent, selector: "entry-cell-context-menu", inputs: { items: "items", rowMenuFormatter: "rowMenuFormatter", rowData: "rowData" }, outputs: { selected: "selected" }, ngImport: i0, template: "<button mat-icon-button [matMenuTriggerFor]=\"menu\" (click)=\"$event.stopPropagation()\">\n <mat-icon>more_vert</mat-icon>\n</button>\n<mat-menu #menu=\"matMenu\" class=\"entry-table-menu\">\n <button *ngFor=\"let item of menuItems\" mat-menu-item [disabled]=\"item.disabled\" (click)=\"selected.emit(item.id)\"\n class=\"context-menu-item\">\n <mat-icon *ngIf=\"item.icon\">{{item.icon}}</mat-icon>\n <span>{{item.name}}</span>\n </button>\n</mat-menu>", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i3.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
18
20
|
}
|
|
19
|
-
|
|
20
|
-
EntryCellContextMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: EntryCellContextMenuComponent, selector: "entry-cell-context-menu", inputs: { items: "items", rowMenuFormatter: "rowMenuFormatter", rowData: "rowData" }, outputs: { selected: "selected" }, ngImport: i0, template: "<button mat-icon-button [matMenuTriggerFor]=\"menu\" (click)=\"$event.stopPropagation()\">\n <mat-icon>more_vert</mat-icon>\n</button>\n<mat-menu #menu=\"matMenu\" class=\"entry-table-menu\">\n <button *ngFor=\"let item of menuItems\" mat-menu-item [disabled]=\"item.disabled\" (click)=\"selected.emit(item.id)\"\n class=\"context-menu-item\">\n <mat-icon *ngIf=\"item.icon\">{{item.icon}}</mat-icon>\n <span>{{item.name}}</span>\n </button>\n</mat-menu>", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i3.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
21
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EntryCellContextMenuComponent, decorators: [{
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryCellContextMenuComponent, decorators: [{
|
|
22
22
|
type: Component,
|
|
23
23
|
args: [{ selector: 'entry-cell-context-menu', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button mat-icon-button [matMenuTriggerFor]=\"menu\" (click)=\"$event.stopPropagation()\">\n <mat-icon>more_vert</mat-icon>\n</button>\n<mat-menu #menu=\"matMenu\" class=\"entry-table-menu\">\n <button *ngFor=\"let item of menuItems\" mat-menu-item [disabled]=\"item.disabled\" (click)=\"selected.emit(item.id)\"\n class=\"context-menu-item\">\n <mat-icon *ngIf=\"item.icon\">{{item.icon}}</mat-icon>\n <span>{{item.name}}</span>\n </button>\n</mat-menu>" }]
|
|
24
24
|
}], propDecorators: { items: [{
|
|
@@ -30,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
30
30
|
}], selected: [{
|
|
31
31
|
type: Output
|
|
32
32
|
}] } });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cnktY2VsbC1jb250ZXh0LW1lbnUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL3RhYmxlL2NvbXBvbmVudHMvZW50cnktY2VsbC1jb250ZXh0LW1lbnUvZW50cnktY2VsbC1jb250ZXh0LW1lbnUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL3RhYmxlL2NvbXBvbmVudHMvZW50cnktY2VsbC1jb250ZXh0LW1lbnUvZW50cnktY2VsbC1jb250ZXh0LW1lbnUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBU3hHLE1BQU0sT0FBTyw2QkFBNkI7SUFMMUM7UUFPVyxVQUFLLEdBQXNCLEVBQUUsQ0FBQztRQUc3QixhQUFRLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUVoRCxjQUFTLEdBQXNCLEVBQUUsQ0FBQztLQU9uQztJQUxDLFFBQVE7UUFDTixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxLQUFLO1lBQzNDLENBQUMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7WUFDM0MsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDakIsQ0FBQzsrR0FiVSw2QkFBNkI7bUdBQTdCLDZCQUE2Qix3TENUMUMsc2VBU1c7OzRGREFFLDZCQUE2QjtrQkFMekMsU0FBUzsrQkFDRSx5QkFBeUIsbUJBRWxCLHVCQUF1QixDQUFDLE1BQU07OEJBSXRDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxnQkFBZ0I7c0JBQXhCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNJLFFBQVE7c0JBQWpCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUm93Q29udGV4dE1lbnVGb3JtYXR0ZXIgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL3Jvdy1jb250ZXh0LW1lbnUtZm9ybWF0dGVyJztcbmltcG9ydCB7IENvbnRleHRNZW51SXRlbSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvY29udGV4dC1tZW51LWl0ZW0nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdlbnRyeS1jZWxsLWNvbnRleHQtbWVudScsXG4gIHRlbXBsYXRlVXJsOiAnLi9lbnRyeS1jZWxsLWNvbnRleHQtbWVudS5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEVudHJ5Q2VsbENvbnRleHRNZW51Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBASW5wdXQoKSBpdGVtczogQ29udGV4dE1lbnVJdGVtW10gPSBbXTtcbiAgQElucHV0KCkgcm93TWVudUZvcm1hdHRlcjogUm93Q29udGV4dE1lbnVGb3JtYXR0ZXI7XG4gIEBJbnB1dCgpIHJvd0RhdGE6IGFueTtcbiAgQE91dHB1dCgpIHNlbGVjdGVkID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgbWVudUl0ZW1zOiBDb250ZXh0TWVudUl0ZW1bXSA9IFtdO1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMubWVudUl0ZW1zID0gdGhpcy5yb3dNZW51Rm9ybWF0dGVyPy5pdGVtc1xuICAgICAgPyB0aGlzLnJvd01lbnVGb3JtYXR0ZXIuaXRlbXModGhpcy5yb3dEYXRhKVxuICAgICAgOiB0aGlzLml0ZW1zO1xuICB9XG59XG4iLCI8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiBbbWF0TWVudVRyaWdnZXJGb3JdPVwibWVudVwiIChjbGljayk9XCIkZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcIj5cbiAgICA8bWF0LWljb24+bW9yZV92ZXJ0PC9tYXQtaWNvbj5cbjwvYnV0dG9uPlxuPG1hdC1tZW51ICNtZW51PVwibWF0TWVudVwiIGNsYXNzPVwiZW50cnktdGFibGUtbWVudVwiPlxuICAgIDxidXR0b24gKm5nRm9yPVwibGV0IGl0ZW0gb2YgbWVudUl0ZW1zXCIgbWF0LW1lbnUtaXRlbSBbZGlzYWJsZWRdPVwiaXRlbS5kaXNhYmxlZFwiIChjbGljayk9XCJzZWxlY3RlZC5lbWl0KGl0ZW0uaWQpXCJcbiAgICAgICAgY2xhc3M9XCJjb250ZXh0LW1lbnUtaXRlbVwiPlxuICAgICAgICA8bWF0LWljb24gKm5nSWY9XCJpdGVtLmljb25cIj57e2l0ZW0uaWNvbn19PC9tYXQtaWNvbj5cbiAgICAgICAgPHNwYW4+e3tpdGVtLm5hbWV9fTwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbjwvbWF0LW1lbnU+Il19
|
|
@@ -6,10 +6,10 @@ export class EntryCellFormattedValueComponent {
|
|
|
6
6
|
constructor(defaultPercentageMultiplier) {
|
|
7
7
|
this.defaultPercentageMultiplier = defaultPercentageMultiplier;
|
|
8
8
|
}
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryCellFormattedValueComponent, deps: [{ token: DEFAULT_PERCENTAGE_MULTIPLIER }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
10
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EntryCellFormattedValueComponent, selector: "entry-cell-formatted-value", inputs: { value: "value", type: "type", typeParameter: "typeParameter" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"type\">\n <!-- Boolean -->\n <ng-container *ngSwitchCase=\"'boolean'\">\n {{value ? '\\u2713' : ''}}\n </ng-container>\n <!-- Number -->\n <ng-container *ngSwitchCase=\"'number'\">\n {{value | number: typeParameter?.digitsInfo : typeParameter?.locale}}\n </ng-container>\n <!-- Currency -->\n <ng-container *ngSwitchCase=\"'currency'\">\n {{value | currency: typeParameter?.currencyCode : typeParameter?.display : typeParameter?.digitsInfo : typeParameter?.locale}}\n </ng-container>\n <!-- Percent -->\n <ng-container *ngSwitchCase=\"'percent'\">\n {{+value * (typeParameter?.multiplier ?? defaultPercentageMultiplier) | percent: typeParameter?.digitsInfo : typeParameter?.locale}}\n </ng-container>\n <!-- Date -->\n <ng-container *ngSwitchCase=\"'date'\">\n {{value | date: typeParameter?.format : typeParameter?.timezone : typeParameter?.locale}}\n </ng-container>\n <!-- Link -->\n <ng-container *ngSwitchCase=\"'link'\">\n <a [href]=\"value\" target=\"_blank\">{{value}}</a>\n </ng-container>\n <!-- Default -->\n <ng-container *ngSwitchDefault>\n {{value}}\n </ng-container>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "pipe", type: i1.DecimalPipe, name: "number" }, { kind: "pipe", type: i1.PercentPipe, name: "percent" }, { kind: "pipe", type: i1.CurrencyPipe, name: "currency" }, { kind: "pipe", type: i1.DatePipe, name: "date" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
9
11
|
}
|
|
10
|
-
|
|
11
|
-
EntryCellFormattedValueComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: EntryCellFormattedValueComponent, selector: "entry-cell-formatted-value", inputs: { value: "value", type: "type", typeParameter: "typeParameter" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"type\">\n <!-- Boolean -->\n <ng-container *ngSwitchCase=\"'boolean'\">\n {{value ? '\\u2713' : ''}}\n </ng-container>\n <!-- Number -->\n <ng-container *ngSwitchCase=\"'number'\">\n {{value | number: typeParameter?.digitsInfo : typeParameter?.locale}}\n </ng-container>\n <!-- Currency -->\n <ng-container *ngSwitchCase=\"'currency'\">\n {{value | currency: typeParameter?.currencyCode : typeParameter?.display : typeParameter?.digitsInfo : typeParameter?.locale}}\n </ng-container>\n <!-- Percent -->\n <ng-container *ngSwitchCase=\"'percent'\">\n {{+value * (typeParameter?.multiplier ?? defaultPercentageMultiplier) | percent: typeParameter?.digitsInfo : typeParameter?.locale}}\n </ng-container>\n <!-- Date -->\n <ng-container *ngSwitchCase=\"'date'\">\n {{value | date: typeParameter?.format : typeParameter?.timezone : typeParameter?.locale}}\n </ng-container>\n <!-- Link -->\n <ng-container *ngSwitchCase=\"'link'\">\n <a [href]=\"value\" target=\"_blank\">{{value}}</a>\n </ng-container>\n <!-- Default -->\n <ng-container *ngSwitchDefault>\n {{value}}\n </ng-container>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "pipe", type: i1.DecimalPipe, name: "number" }, { kind: "pipe", type: i1.PercentPipe, name: "percent" }, { kind: "pipe", type: i1.CurrencyPipe, name: "currency" }, { kind: "pipe", type: i1.DatePipe, name: "date" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
12
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EntryCellFormattedValueComponent, decorators: [{
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryCellFormattedValueComponent, decorators: [{
|
|
13
13
|
type: Component,
|
|
14
14
|
args: [{ selector: 'entry-cell-formatted-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container [ngSwitch]=\"type\">\n <!-- Boolean -->\n <ng-container *ngSwitchCase=\"'boolean'\">\n {{value ? '\\u2713' : ''}}\n </ng-container>\n <!-- Number -->\n <ng-container *ngSwitchCase=\"'number'\">\n {{value | number: typeParameter?.digitsInfo : typeParameter?.locale}}\n </ng-container>\n <!-- Currency -->\n <ng-container *ngSwitchCase=\"'currency'\">\n {{value | currency: typeParameter?.currencyCode : typeParameter?.display : typeParameter?.digitsInfo : typeParameter?.locale}}\n </ng-container>\n <!-- Percent -->\n <ng-container *ngSwitchCase=\"'percent'\">\n {{+value * (typeParameter?.multiplier ?? defaultPercentageMultiplier) | percent: typeParameter?.digitsInfo : typeParameter?.locale}}\n </ng-container>\n <!-- Date -->\n <ng-container *ngSwitchCase=\"'date'\">\n {{value | date: typeParameter?.format : typeParameter?.timezone : typeParameter?.locale}}\n </ng-container>\n <!-- Link -->\n <ng-container *ngSwitchCase=\"'link'\">\n <a [href]=\"value\" target=\"_blank\">{{value}}</a>\n </ng-container>\n <!-- Default -->\n <ng-container *ngSwitchDefault>\n {{value}}\n </ng-container>\n</ng-container>\n" }]
|
|
15
15
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
@@ -22,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
22
22
|
}], typeParameter: [{
|
|
23
23
|
type: Input
|
|
24
24
|
}] } });
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cnktY2VsbC1mb3JtYXR0ZWQtdmFsdWUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL3RhYmxlL2NvbXBvbmVudHMvZW50cnktY2VsbC1mb3JtYXR0ZWQtdmFsdWUvZW50cnktY2VsbC1mb3JtYXR0ZWQtdmFsdWUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL3RhYmxlL2NvbXBvbmVudHMvZW50cnktY2VsbC1mb3JtYXR0ZWQtdmFsdWUvZW50cnktY2VsbC1mb3JtYXR0ZWQtdmFsdWUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xGLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOzs7QUFPcEYsTUFBTSxPQUFPLGdDQUFnQztJQU0zQyxZQUNnRCwyQkFBbUM7UUFBbkMsZ0NBQTJCLEdBQTNCLDJCQUEyQixDQUFRO0lBQ25GLENBQUM7K0dBUlUsZ0NBQWdDLGtCQU9qQyw2QkFBNkI7bUdBUDVCLGdDQUFnQyw0SUNSN0MsbXBDQThCQTs7NEZEdEJhLGdDQUFnQztrQkFMNUMsU0FBUzsrQkFDRSw0QkFBNEIsbUJBRXJCLHVCQUF1QixDQUFDLE1BQU07OzBCQVM1QyxNQUFNOzJCQUFDLDZCQUE2Qjs0Q0FMOUIsS0FBSztzQkFBYixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5qZWN0LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgREVGQVVMVF9QRVJDRU5UQUdFX01VTFRJUExJRVIgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL2VudHJ5LXRhYmxlLWNvbmZpZyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VudHJ5LWNlbGwtZm9ybWF0dGVkLXZhbHVlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2VudHJ5LWNlbGwtZm9ybWF0dGVkLXZhbHVlLmNvbXBvbmVudC5odG1sJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRW50cnlDZWxsRm9ybWF0dGVkVmFsdWVDb21wb25lbnQge1xuXG4gIEBJbnB1dCgpIHZhbHVlOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIEBJbnB1dCgpIHR5cGU6IHN0cmluZztcbiAgQElucHV0KCkgdHlwZVBhcmFtZXRlcjogYW55IHwgdW5kZWZpbmVkO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoREVGQVVMVF9QRVJDRU5UQUdFX01VTFRJUExJRVIpIHB1YmxpYyBkZWZhdWx0UGVyY2VudGFnZU11bHRpcGxpZXI6IG51bWJlcikge1xuICB9XG59XG4iLCI8bmctY29udGFpbmVyIFtuZ1N3aXRjaF09XCJ0eXBlXCI+XG4gIDwhLS0gQm9vbGVhbiAtLT5cbiAgPG5nLWNvbnRhaW5lciAqbmdTd2l0Y2hDYXNlPVwiJ2Jvb2xlYW4nXCI+XG4gICAge3t2YWx1ZSA/ICdcXHUyNzEzJyA6ICcnfX1cbiAgPC9uZy1jb250YWluZXI+XG4gIDwhLS0gTnVtYmVyIC0tPlxuICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCInbnVtYmVyJ1wiPlxuICAgIHt7dmFsdWUgfCBudW1iZXI6IHR5cGVQYXJhbWV0ZXI/LmRpZ2l0c0luZm8gOiB0eXBlUGFyYW1ldGVyPy5sb2NhbGV9fVxuICA8L25nLWNvbnRhaW5lcj5cbiAgPCEtLSBDdXJyZW5jeSAtLT5cbiAgPG5nLWNvbnRhaW5lciAqbmdTd2l0Y2hDYXNlPVwiJ2N1cnJlbmN5J1wiPlxuICAgIHt7dmFsdWUgfCBjdXJyZW5jeTogdHlwZVBhcmFtZXRlcj8uY3VycmVuY3lDb2RlIDogdHlwZVBhcmFtZXRlcj8uZGlzcGxheSA6IHR5cGVQYXJhbWV0ZXI/LmRpZ2l0c0luZm8gOiB0eXBlUGFyYW1ldGVyPy5sb2NhbGV9fVxuICA8L25nLWNvbnRhaW5lcj5cbiAgPCEtLSBQZXJjZW50IC0tPlxuICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCIncGVyY2VudCdcIj5cbiAgICB7eyt2YWx1ZSAqICh0eXBlUGFyYW1ldGVyPy5tdWx0aXBsaWVyID8/IGRlZmF1bHRQZXJjZW50YWdlTXVsdGlwbGllcikgfCBwZXJjZW50OiB0eXBlUGFyYW1ldGVyPy5kaWdpdHNJbmZvIDogdHlwZVBhcmFtZXRlcj8ubG9jYWxlfX1cbiAgPC9uZy1jb250YWluZXI+XG4gIDwhLS0gRGF0ZSAtLT5cbiAgPG5nLWNvbnRhaW5lciAqbmdTd2l0Y2hDYXNlPVwiJ2RhdGUnXCI+XG4gICAge3t2YWx1ZSB8IGRhdGU6IHR5cGVQYXJhbWV0ZXI/LmZvcm1hdCA6IHR5cGVQYXJhbWV0ZXI/LnRpbWV6b25lIDogdHlwZVBhcmFtZXRlcj8ubG9jYWxlfX1cbiAgPC9uZy1jb250YWluZXI+XG4gIDwhLS0gTGluayAtLT5cbiAgPG5nLWNvbnRhaW5lciAqbmdTd2l0Y2hDYXNlPVwiJ2xpbmsnXCI+XG4gICAgPGEgW2hyZWZdPVwidmFsdWVcIiB0YXJnZXQ9XCJfYmxhbmtcIj57e3ZhbHVlfX08L2E+XG4gIDwvbmctY29udGFpbmVyPlxuICA8IS0tIERlZmF1bHQgLS0+XG4gIDxuZy1jb250YWluZXIgKm5nU3dpdGNoRGVmYXVsdD5cbiAgICB7e3ZhbHVlfX1cbiAgPC9uZy1jb250YWluZXI+XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==
|
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/member-ordering */
|
|
2
|
+
import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy, TemplateRef, HostBinding, Inject, } from '@angular/core';
|
|
3
|
+
import { SelectionModel } from '@angular/cdk/collections';
|
|
4
|
+
import { MatTableDataSource } from '@angular/material/table';
|
|
5
|
+
import { ENTRY_TABLE_CONFIG } from '../../interfaces';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
import * as i2 from "@angular/material/table";
|
|
9
|
+
import * as i3 from "@angular/material/sort";
|
|
10
|
+
import * as i4 from "@angular/material/paginator";
|
|
11
|
+
import * as i5 from "@angular/material/checkbox";
|
|
12
|
+
import * as i6 from "@angular/material/radio";
|
|
13
|
+
import * as i7 from "../entry-cell/entry-cell.component";
|
|
14
|
+
import * as i8 from "../entry-cell-context-menu/entry-cell-context-menu.component";
|
|
15
|
+
import * as i9 from "../../interfaces";
|
|
16
|
+
export class EntryTableComponent {
|
|
17
|
+
get hasNoResult() {
|
|
18
|
+
return (!this.data || this._data.length === 0) && !this.loading;
|
|
19
|
+
}
|
|
20
|
+
constructor(_config, _elementRef, _changeDetectorRef) {
|
|
21
|
+
this._config = _config;
|
|
22
|
+
this._elementRef = _elementRef;
|
|
23
|
+
this._changeDetectorRef = _changeDetectorRef;
|
|
24
|
+
this.className = 'entry-table';
|
|
25
|
+
this.dataSource = new MatTableDataSource([]);
|
|
26
|
+
this.columns = [];
|
|
27
|
+
// Data
|
|
28
|
+
this._data = [];
|
|
29
|
+
this.data = [];
|
|
30
|
+
this.total = 0;
|
|
31
|
+
this.loading = false;
|
|
32
|
+
this.pageDisabled = false;
|
|
33
|
+
this.pageIndex = 0;
|
|
34
|
+
this.pageChange = new EventEmitter();
|
|
35
|
+
this.sortDisableClear = false;
|
|
36
|
+
this.sortDisabled = false;
|
|
37
|
+
this.sortStart = 'asc';
|
|
38
|
+
this.sortChange = new EventEmitter();
|
|
39
|
+
// Row
|
|
40
|
+
this.rowHover = false;
|
|
41
|
+
this.rowStriped = false;
|
|
42
|
+
this.rowFocusVisible = false;
|
|
43
|
+
this.rowClick = new EventEmitter();
|
|
44
|
+
// Row selection
|
|
45
|
+
this.multiSelectable = true;
|
|
46
|
+
this.rowSelection = new SelectionModel(true, []);
|
|
47
|
+
this.rowSelected = [];
|
|
48
|
+
this.rowSelectable = false;
|
|
49
|
+
this.showSelectAllCheckbox = true;
|
|
50
|
+
this.rowSelectionFormatter = {};
|
|
51
|
+
this.rowSelectionChange = new EventEmitter();
|
|
52
|
+
// Context menu
|
|
53
|
+
this.showContextMenu = false;
|
|
54
|
+
this.contextMenuItems = [];
|
|
55
|
+
this.contextMenuItemSelected = new EventEmitter();
|
|
56
|
+
this.selectionColumn = 'selection-column';
|
|
57
|
+
this.contextMenuColumn = 'context-menu-column';
|
|
58
|
+
}
|
|
59
|
+
detectChanges() {
|
|
60
|
+
this._changeDetectorRef.detectChanges();
|
|
61
|
+
}
|
|
62
|
+
isTemplateRef(obj) {
|
|
63
|
+
return obj instanceof TemplateRef;
|
|
64
|
+
}
|
|
65
|
+
getRowClassList(rowData, index) {
|
|
66
|
+
const classList = {
|
|
67
|
+
selected: this.rowSelection.isSelected(rowData),
|
|
68
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
69
|
+
'mat-row-odd': index % 2,
|
|
70
|
+
};
|
|
71
|
+
if (this.rowClassFormatter) {
|
|
72
|
+
for (const key of Object.keys(this.rowClassFormatter)) {
|
|
73
|
+
classList[key] = this.rowClassFormatter[key](rowData);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return classList;
|
|
77
|
+
}
|
|
78
|
+
getColumnClassList(colDef) {
|
|
79
|
+
const customClasses = colDef.class ?? '';
|
|
80
|
+
const columnType = colDef.type ?? '';
|
|
81
|
+
const columnField = `cell-${this.convertToKebabCase(colDef.field)}`;
|
|
82
|
+
return `${customClasses} ${columnType} ${columnField}`;
|
|
83
|
+
}
|
|
84
|
+
ngOnChanges(changes) {
|
|
85
|
+
this.showPaginator = this.showPaginator ?? this._config.showPaginator;
|
|
86
|
+
this.showFirstLastButtons = this.showFirstLastButtons ?? this._config.showFirstLastButtons;
|
|
87
|
+
this.pageSizeOptions = this.pageSizeOptions ?? this._config.pageSizeOptions;
|
|
88
|
+
this.hidePageSize = this.hidePageSize ?? this._config.hidePageSize;
|
|
89
|
+
this.noResultText = this.noResultText ?? this._config.noResultsText;
|
|
90
|
+
this.displayedColumns = this.columns.filter(item => !item.hide).map(item => item.field);
|
|
91
|
+
if (this.rowSelectable && !this.displayedColumns.includes(this.selectionColumn)) {
|
|
92
|
+
this.displayedColumns.unshift(this.selectionColumn);
|
|
93
|
+
}
|
|
94
|
+
if (this.showContextMenu && !this.displayedColumns.includes(this.contextMenuColumn)) {
|
|
95
|
+
this.displayedColumns.push(this.contextMenuColumn);
|
|
96
|
+
}
|
|
97
|
+
if (this.rowSelectable) {
|
|
98
|
+
this.rowSelection = new SelectionModel(this.multiSelectable, this.rowSelected);
|
|
99
|
+
}
|
|
100
|
+
if (!this.data) {
|
|
101
|
+
this.data = [];
|
|
102
|
+
}
|
|
103
|
+
if (Array.isArray(this.data)) {
|
|
104
|
+
this._data = this.data;
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
this._page = this.data;
|
|
108
|
+
this._data = this._page.items ?? [];
|
|
109
|
+
this.total = this._page.totalCount ?? 0;
|
|
110
|
+
this.pageSize = this._page.pageSize ?? this.pageSize ?? this._config.pageSize;
|
|
111
|
+
this.pageIndex = this._page.pageNumber ? this._page.pageNumber - 1 : this.pageIndex;
|
|
112
|
+
}
|
|
113
|
+
if (this.dataSource) {
|
|
114
|
+
this.dataSource.disconnect();
|
|
115
|
+
}
|
|
116
|
+
this.dataSource = new MatTableDataSource(this._data);
|
|
117
|
+
if (changes.data) {
|
|
118
|
+
this.scrollToTop();
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
getIndex(index, dataIndex) {
|
|
122
|
+
return typeof index === 'undefined' ? dataIndex : index;
|
|
123
|
+
}
|
|
124
|
+
isAllSelected() {
|
|
125
|
+
const numSelected = this.rowSelection.selected.length;
|
|
126
|
+
const numRows = this.dataSource.data.filter(row => !this.rowSelectionFormatter.disabled?.(row)).length;
|
|
127
|
+
return numSelected === numRows;
|
|
128
|
+
}
|
|
129
|
+
toggleSelectAllCheckbox() {
|
|
130
|
+
if (this.isAllSelected()) {
|
|
131
|
+
this.rowSelection.clear();
|
|
132
|
+
this.rowSelectionChange.emit(this.rowSelection.selected);
|
|
133
|
+
return;
|
|
134
|
+
}
|
|
135
|
+
this.dataSource.data.forEach(row => {
|
|
136
|
+
if (!this.rowSelectionFormatter.disabled?.(row)) {
|
|
137
|
+
this.rowSelection.select(row);
|
|
138
|
+
}
|
|
139
|
+
});
|
|
140
|
+
this.rowSelectionChange.emit(this.rowSelection.selected);
|
|
141
|
+
}
|
|
142
|
+
toggleRowSelection(row) {
|
|
143
|
+
this.rowSelection.toggle(row);
|
|
144
|
+
this.rowSelectionChange.emit(this.rowSelection.selected);
|
|
145
|
+
}
|
|
146
|
+
handlePage(e) {
|
|
147
|
+
this.pageChange.emit(e);
|
|
148
|
+
}
|
|
149
|
+
scrollToTop() {
|
|
150
|
+
this._elementRef.nativeElement.scrollTop = 0;
|
|
151
|
+
}
|
|
152
|
+
convertToKebabCase(value) {
|
|
153
|
+
return value?.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase();
|
|
154
|
+
}
|
|
155
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryTableComponent, deps: [{ token: ENTRY_TABLE_CONFIG }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
156
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EntryTableComponent, selector: "entry-table", inputs: { displayedColumns: "displayedColumns", columns: "columns", data: "data", total: "total", loading: "loading", showPaginator: "showPaginator", pageDisabled: "pageDisabled", showFirstLastButtons: "showFirstLastButtons", pageIndex: "pageIndex", pageSize: "pageSize", pageSizeOptions: "pageSizeOptions", hidePageSize: "hidePageSize", paginationTemplate: "paginationTemplate", sortActive: "sortActive", sortDirection: "sortDirection", sortDisableClear: "sortDisableClear", sortDisabled: "sortDisabled", sortStart: "sortStart", rowHover: "rowHover", rowStriped: "rowStriped", rowFocusVisible: "rowFocusVisible", multiSelectable: "multiSelectable", rowSelected: "rowSelected", rowSelectable: "rowSelectable", showSelectAllCheckbox: "showSelectAllCheckbox", rowSelectionFormatter: "rowSelectionFormatter", rowClassFormatter: "rowClassFormatter", showContextMenu: "showContextMenu", contextMenuItems: "contextMenuItems", contextMenuTemplate: "contextMenuTemplate", rowContextMenuFormatter: "rowContextMenuFormatter", noResultText: "noResultText", noResultTemplate: "noResultTemplate", headerTemplate: "headerTemplate", cellTemplate: "cellTemplate" }, outputs: { pageChange: "pageChange", sortChange: "sortChange", rowClick: "rowClick", rowSelectionChange: "rowSelectionChange", contextMenuItemSelected: "contextMenuItemSelected" }, host: { properties: { "class": "this.className" } }, usesOnChanges: true, ngImport: i0, template: "<!-- Table content -->\n<table mat-table \n [ngClass]=\"{'mat-table-hover': rowHover, 'mat-table-striped': rowStriped, 'mat-table-with-data': !hasNoResult }\"\n [dataSource]=\"dataSource\"\n matSort\n [matSortActive]=\"sortActive\"\n [matSortDirection]=\"sortDirection\"\n [matSortDisableClear]=\"sortDisableClear\"\n [matSortDisabled]=\"sortDisabled\"\n [matSortStart]=\"sortStart\"\n (matSortChange)=\"sortChange.emit($event)\">\n\n <!-- Selection column -->\n <ng-container *ngIf=\"rowSelectable\" [matColumnDef]=\"selectionColumn\">\n <th mat-header-cell *matHeaderCellDef class=\"selection-cell\">\n <mat-checkbox *ngIf=\"multiSelectable && showSelectAllCheckbox\"\n [checked]=\"rowSelection.hasValue() && isAllSelected()\"\n [indeterminate]=\"rowSelection.hasValue() && !isAllSelected()\"\n (change)=\"$event ? toggleSelectAllCheckbox() : null\">\n </mat-checkbox>\n </th>\n <td mat-cell *matCellDef=\"let row; let index = index; let dataIndex = dataIndex;\"\n class=\"selection-cell\"\n (click)=\"$event.stopPropagation()\">\n <mat-checkbox\n *ngIf=\"multiSelectable && !(rowSelectionFormatter.hideCheckbox && rowSelectionFormatter.hideCheckbox!(row))\"\n [disabled]=\"rowSelectionFormatter.disabled && rowSelectionFormatter.disabled!(row)\"\n [checked]=\"rowSelection.isSelected(row)\"\n (change)=\"$event ? toggleRowSelection(row) : null\">\n </mat-checkbox>\n <mat-radio-button\n *ngIf=\"!multiSelectable && !(rowSelectionFormatter.hideCheckbox && rowSelectionFormatter.hideCheckbox!(row))\"\n [disabled]=\"rowSelectionFormatter.disabled && rowSelectionFormatter.disabled!(row)\"\n [checked]=\"rowSelection.isSelected(row)\"\n [value]=\"rowSelection.isSelected(row)\"\n (change)=\"$event ? toggleRowSelection(row) : null\">\n </mat-radio-button>\n </td>\n </ng-container>\n\n <!-- Context menu column -->\n <ng-container *ngIf=\"showContextMenu\" [matColumnDef]=\"contextMenuColumn\">\n <th mat-header-cell *matHeaderCellDef class=\"action-cell\"></th>\n <td mat-cell *matCellDef=\"let row; let index = index; let dataIndex = dataIndex;\"\n class=\"action-cell\">\n <ng-template [ngIf]=\"isTemplateRef(contextMenuTemplate)\" [ngIfElse]=\"contextMenuTpl\">\n <ng-template [ngTemplateOutlet]=\"contextMenuTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, rowData: row }\">\n </ng-template>\n </ng-template>\n <ng-template #contextMenuTpl>\n <entry-cell-context-menu\n [items]=\"contextMenuItems\"\n [rowData]=\"row\"\n [rowMenuFormatter]=\"rowContextMenuFormatter\"\n (selected)=\"contextMenuItemSelected.emit({itemId: $event, rowData: row})\"\n ></entry-cell-context-menu>\n </ng-template>\n </td>\n </ng-container>\n\n <ng-container *ngFor=\"let col of columns;\">\n <ng-container [matColumnDef]=\"col.field\"\n [sticky]=\"col.pinned==='left'\" [stickyEnd]=\"col.pinned==='right'\">\n <th mat-header-cell *matHeaderCellDef\n [class]=\"getColumnClassList(col)\"\n [ngClass]=\"{'mat-table-sticky-left': col.pinned === 'left', 'mat-table-sticky-right': col.pinned === 'right'}\"\n [ngStyle]=\"{'width': col.width, 'min-width': col.width}\">\n <ng-template [ngIf]=\"isTemplateRef(headerTemplate)\" [ngIfElse]=\"headerTpl\">\n <ng-template [ngTemplateOutlet]=\"headerTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: col, colDef: col }\">\n </ng-template>\n </ng-template>\n <ng-template #headerTpl>\n <ng-template [ngIf]=\"headerTemplate && isTemplateRef(headerTemplate[col.field])\"\n [ngIfElse]=\"defaultHeaderTpl\">\n <ng-template [ngTemplateOutlet]=\"headerTemplate[col.field]\"\n [ngTemplateOutletContext]=\"{ $implicit: col, colDef: col }\">\n </ng-template>\n </ng-template>\n </ng-template>\n <ng-template #defaultHeaderTpl>\n <div [mat-sort-header]=\"col.sortProp?.id || col.field\"\n [disabled]=\"!col.sortable\"\n [disableClear]=\"col.sortProp?.disableClear\">\n <span>{{col.header}}</span>\n </div>\n </ng-template>\n </th>\n\n <td mat-cell *matCellDef=\"let row; let index = index; let dataIndex = dataIndex;\"\n [class]=\"getColumnClassList(col)\"\n [ngClass]=\"{'mat-table-sticky-left': col.pinned === 'left', 'mat-table-sticky-right': col.pinned === 'right'}\"\n [ngStyle]=\"{'width': col.width, 'min-width': col.width}\">\n <ng-template [ngIf]=\"isTemplateRef(cellTemplate)\" [ngIfElse]=\"cellTpl\">\n <ng-template [ngTemplateOutlet]=\"cellTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, rowData: row, index: getIndex(index, dataIndex), colDef: col }\">\n </ng-template>\n </ng-template>\n <ng-template #cellTpl>\n <ng-template [ngIf]=\"cellTemplate && isTemplateRef(cellTemplate[col.field])\"\n [ngIfElse]=\"colDefCellTpl\">\n <ng-template [ngTemplateOutlet]=\"cellTemplate[col.field]\"\n [ngTemplateOutletContext]=\"{ $implicit: row, rowData: row, index: getIndex(index, dataIndex), colDef: col }\">\n </ng-template>\n </ng-template>\n </ng-template>\n <ng-template #colDefCellTpl>\n <ng-template [ngIf]=\"col.cellTemplate\" [ngIfElse]=\"defaultCellTpl\"\n [ngTemplateOutlet]=\"col.cellTemplate ?? null\"\n [ngTemplateOutletContext]=\"{ $implicit: row, rowData: row, index: getIndex(index, dataIndex), colDef: col }\">\n </ng-template>\n </ng-template>\n <ng-template #defaultCellTpl>\n <entry-cell [rowData]=\"row\" [colDef]=\"col\"></entry-cell>\n </ng-template>\n </td>\n </ng-container>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns; sticky: true\"></tr>\n <tr mat-row\n *matRowDef=\"let row; let index = index; let dataIndex = dataIndex; columns: displayedColumns;\"\n [ngClass]=\"getRowClassList(row, getIndex(index, dataIndex))\"\n [attr.tabindex]=\"rowFocusVisible ? 0 : -1\"\n (click)=\"rowClick.emit(row)\"\n (keyup.enter)=\"rowClick.emit(row)\">\n </tr>\n</table>\n\n<!-- No results -->\n<div class=\"no-results mat-body-2\" *ngIf=\"hasNoResult\">\n <ng-template [ngIf]=\"isTemplateRef(noResultTemplate)\" [ngIfElse]=\"defaultNoResultTpl\">\n <ng-template [ngTemplateOutlet]=\"noResultTemplate\"></ng-template>\n </ng-template>\n <ng-template #defaultNoResultTpl>{{noResultText}}</ng-template>\n</div>\n\n<!-- Pagination -->\n<ng-template [ngIf]=\"isTemplateRef(paginationTemplate)\" [ngIfElse]=\"defaultPaginationTemplate\">\n <ng-template [ngTemplateOutlet]=\"paginationTemplate\"></ng-template>\n</ng-template>\n<ng-template #defaultPaginationTemplate>\n <mat-paginator class=\"pagination\" *ngIf=\"showPaginator\"\n [showFirstLastButtons]=\"showFirstLastButtons\"\n [length]=\"total\"\n [pageIndex]=\"pageIndex\"\n [pageSize]=\"pageSize\"\n [pageSizeOptions]=\"pageSizeOptions\"\n [hidePageSize]=\"hidePageSize\"\n (page)=\"handlePage($event)\"\n [disabled]=\"pageDisabled\">\n </mat-paginator>\n</ng-template>", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i2.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i2.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i2.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i2.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i2.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i2.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i2.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i3.MatSort, selector: "[matSort]", inputs: ["matSortDisabled", "matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { kind: "component", type: i3.MatSortHeader, selector: "[mat-sort-header]", inputs: ["disabled", "mat-sort-header", "arrowPosition", "start", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { kind: "component", type: i4.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "component", type: i5.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i6.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }, { kind: "component", type: i7.EntryCellComponent, selector: "entry-cell", inputs: ["rowData", "colDef"] }, { kind: "component", type: i8.EntryCellContextMenuComponent, selector: "entry-cell-context-menu", inputs: ["items", "rowMenuFormatter", "rowData"], outputs: ["selected"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
157
|
+
}
|
|
158
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryTableComponent, decorators: [{
|
|
159
|
+
type: Component,
|
|
160
|
+
args: [{ selector: 'entry-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- Table content -->\n<table mat-table \n [ngClass]=\"{'mat-table-hover': rowHover, 'mat-table-striped': rowStriped, 'mat-table-with-data': !hasNoResult }\"\n [dataSource]=\"dataSource\"\n matSort\n [matSortActive]=\"sortActive\"\n [matSortDirection]=\"sortDirection\"\n [matSortDisableClear]=\"sortDisableClear\"\n [matSortDisabled]=\"sortDisabled\"\n [matSortStart]=\"sortStart\"\n (matSortChange)=\"sortChange.emit($event)\">\n\n <!-- Selection column -->\n <ng-container *ngIf=\"rowSelectable\" [matColumnDef]=\"selectionColumn\">\n <th mat-header-cell *matHeaderCellDef class=\"selection-cell\">\n <mat-checkbox *ngIf=\"multiSelectable && showSelectAllCheckbox\"\n [checked]=\"rowSelection.hasValue() && isAllSelected()\"\n [indeterminate]=\"rowSelection.hasValue() && !isAllSelected()\"\n (change)=\"$event ? toggleSelectAllCheckbox() : null\">\n </mat-checkbox>\n </th>\n <td mat-cell *matCellDef=\"let row; let index = index; let dataIndex = dataIndex;\"\n class=\"selection-cell\"\n (click)=\"$event.stopPropagation()\">\n <mat-checkbox\n *ngIf=\"multiSelectable && !(rowSelectionFormatter.hideCheckbox && rowSelectionFormatter.hideCheckbox!(row))\"\n [disabled]=\"rowSelectionFormatter.disabled && rowSelectionFormatter.disabled!(row)\"\n [checked]=\"rowSelection.isSelected(row)\"\n (change)=\"$event ? toggleRowSelection(row) : null\">\n </mat-checkbox>\n <mat-radio-button\n *ngIf=\"!multiSelectable && !(rowSelectionFormatter.hideCheckbox && rowSelectionFormatter.hideCheckbox!(row))\"\n [disabled]=\"rowSelectionFormatter.disabled && rowSelectionFormatter.disabled!(row)\"\n [checked]=\"rowSelection.isSelected(row)\"\n [value]=\"rowSelection.isSelected(row)\"\n (change)=\"$event ? toggleRowSelection(row) : null\">\n </mat-radio-button>\n </td>\n </ng-container>\n\n <!-- Context menu column -->\n <ng-container *ngIf=\"showContextMenu\" [matColumnDef]=\"contextMenuColumn\">\n <th mat-header-cell *matHeaderCellDef class=\"action-cell\"></th>\n <td mat-cell *matCellDef=\"let row; let index = index; let dataIndex = dataIndex;\"\n class=\"action-cell\">\n <ng-template [ngIf]=\"isTemplateRef(contextMenuTemplate)\" [ngIfElse]=\"contextMenuTpl\">\n <ng-template [ngTemplateOutlet]=\"contextMenuTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, rowData: row }\">\n </ng-template>\n </ng-template>\n <ng-template #contextMenuTpl>\n <entry-cell-context-menu\n [items]=\"contextMenuItems\"\n [rowData]=\"row\"\n [rowMenuFormatter]=\"rowContextMenuFormatter\"\n (selected)=\"contextMenuItemSelected.emit({itemId: $event, rowData: row})\"\n ></entry-cell-context-menu>\n </ng-template>\n </td>\n </ng-container>\n\n <ng-container *ngFor=\"let col of columns;\">\n <ng-container [matColumnDef]=\"col.field\"\n [sticky]=\"col.pinned==='left'\" [stickyEnd]=\"col.pinned==='right'\">\n <th mat-header-cell *matHeaderCellDef\n [class]=\"getColumnClassList(col)\"\n [ngClass]=\"{'mat-table-sticky-left': col.pinned === 'left', 'mat-table-sticky-right': col.pinned === 'right'}\"\n [ngStyle]=\"{'width': col.width, 'min-width': col.width}\">\n <ng-template [ngIf]=\"isTemplateRef(headerTemplate)\" [ngIfElse]=\"headerTpl\">\n <ng-template [ngTemplateOutlet]=\"headerTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: col, colDef: col }\">\n </ng-template>\n </ng-template>\n <ng-template #headerTpl>\n <ng-template [ngIf]=\"headerTemplate && isTemplateRef(headerTemplate[col.field])\"\n [ngIfElse]=\"defaultHeaderTpl\">\n <ng-template [ngTemplateOutlet]=\"headerTemplate[col.field]\"\n [ngTemplateOutletContext]=\"{ $implicit: col, colDef: col }\">\n </ng-template>\n </ng-template>\n </ng-template>\n <ng-template #defaultHeaderTpl>\n <div [mat-sort-header]=\"col.sortProp?.id || col.field\"\n [disabled]=\"!col.sortable\"\n [disableClear]=\"col.sortProp?.disableClear\">\n <span>{{col.header}}</span>\n </div>\n </ng-template>\n </th>\n\n <td mat-cell *matCellDef=\"let row; let index = index; let dataIndex = dataIndex;\"\n [class]=\"getColumnClassList(col)\"\n [ngClass]=\"{'mat-table-sticky-left': col.pinned === 'left', 'mat-table-sticky-right': col.pinned === 'right'}\"\n [ngStyle]=\"{'width': col.width, 'min-width': col.width}\">\n <ng-template [ngIf]=\"isTemplateRef(cellTemplate)\" [ngIfElse]=\"cellTpl\">\n <ng-template [ngTemplateOutlet]=\"cellTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, rowData: row, index: getIndex(index, dataIndex), colDef: col }\">\n </ng-template>\n </ng-template>\n <ng-template #cellTpl>\n <ng-template [ngIf]=\"cellTemplate && isTemplateRef(cellTemplate[col.field])\"\n [ngIfElse]=\"colDefCellTpl\">\n <ng-template [ngTemplateOutlet]=\"cellTemplate[col.field]\"\n [ngTemplateOutletContext]=\"{ $implicit: row, rowData: row, index: getIndex(index, dataIndex), colDef: col }\">\n </ng-template>\n </ng-template>\n </ng-template>\n <ng-template #colDefCellTpl>\n <ng-template [ngIf]=\"col.cellTemplate\" [ngIfElse]=\"defaultCellTpl\"\n [ngTemplateOutlet]=\"col.cellTemplate ?? null\"\n [ngTemplateOutletContext]=\"{ $implicit: row, rowData: row, index: getIndex(index, dataIndex), colDef: col }\">\n </ng-template>\n </ng-template>\n <ng-template #defaultCellTpl>\n <entry-cell [rowData]=\"row\" [colDef]=\"col\"></entry-cell>\n </ng-template>\n </td>\n </ng-container>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns; sticky: true\"></tr>\n <tr mat-row\n *matRowDef=\"let row; let index = index; let dataIndex = dataIndex; columns: displayedColumns;\"\n [ngClass]=\"getRowClassList(row, getIndex(index, dataIndex))\"\n [attr.tabindex]=\"rowFocusVisible ? 0 : -1\"\n (click)=\"rowClick.emit(row)\"\n (keyup.enter)=\"rowClick.emit(row)\">\n </tr>\n</table>\n\n<!-- No results -->\n<div class=\"no-results mat-body-2\" *ngIf=\"hasNoResult\">\n <ng-template [ngIf]=\"isTemplateRef(noResultTemplate)\" [ngIfElse]=\"defaultNoResultTpl\">\n <ng-template [ngTemplateOutlet]=\"noResultTemplate\"></ng-template>\n </ng-template>\n <ng-template #defaultNoResultTpl>{{noResultText}}</ng-template>\n</div>\n\n<!-- Pagination -->\n<ng-template [ngIf]=\"isTemplateRef(paginationTemplate)\" [ngIfElse]=\"defaultPaginationTemplate\">\n <ng-template [ngTemplateOutlet]=\"paginationTemplate\"></ng-template>\n</ng-template>\n<ng-template #defaultPaginationTemplate>\n <mat-paginator class=\"pagination\" *ngIf=\"showPaginator\"\n [showFirstLastButtons]=\"showFirstLastButtons\"\n [length]=\"total\"\n [pageIndex]=\"pageIndex\"\n [pageSize]=\"pageSize\"\n [pageSizeOptions]=\"pageSizeOptions\"\n [hidePageSize]=\"hidePageSize\"\n (page)=\"handlePage($event)\"\n [disabled]=\"pageDisabled\">\n </mat-paginator>\n</ng-template>" }]
|
|
161
|
+
}], ctorParameters: function () { return [{ type: i9.EntryTableConfig, decorators: [{
|
|
162
|
+
type: Inject,
|
|
163
|
+
args: [ENTRY_TABLE_CONFIG]
|
|
164
|
+
}] }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { className: [{
|
|
165
|
+
type: HostBinding,
|
|
166
|
+
args: ['class']
|
|
167
|
+
}], displayedColumns: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], columns: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], data: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], total: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}], loading: [{
|
|
176
|
+
type: Input
|
|
177
|
+
}], showPaginator: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], pageDisabled: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], showFirstLastButtons: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], pageIndex: [{
|
|
184
|
+
type: Input
|
|
185
|
+
}], pageSize: [{
|
|
186
|
+
type: Input
|
|
187
|
+
}], pageSizeOptions: [{
|
|
188
|
+
type: Input
|
|
189
|
+
}], hidePageSize: [{
|
|
190
|
+
type: Input
|
|
191
|
+
}], pageChange: [{
|
|
192
|
+
type: Output
|
|
193
|
+
}], paginationTemplate: [{
|
|
194
|
+
type: Input
|
|
195
|
+
}], sortActive: [{
|
|
196
|
+
type: Input
|
|
197
|
+
}], sortDirection: [{
|
|
198
|
+
type: Input
|
|
199
|
+
}], sortDisableClear: [{
|
|
200
|
+
type: Input
|
|
201
|
+
}], sortDisabled: [{
|
|
202
|
+
type: Input
|
|
203
|
+
}], sortStart: [{
|
|
204
|
+
type: Input
|
|
205
|
+
}], sortChange: [{
|
|
206
|
+
type: Output
|
|
207
|
+
}], rowHover: [{
|
|
208
|
+
type: Input
|
|
209
|
+
}], rowStriped: [{
|
|
210
|
+
type: Input
|
|
211
|
+
}], rowFocusVisible: [{
|
|
212
|
+
type: Input
|
|
213
|
+
}], rowClick: [{
|
|
214
|
+
type: Output
|
|
215
|
+
}], multiSelectable: [{
|
|
216
|
+
type: Input
|
|
217
|
+
}], rowSelected: [{
|
|
218
|
+
type: Input
|
|
219
|
+
}], rowSelectable: [{
|
|
220
|
+
type: Input
|
|
221
|
+
}], showSelectAllCheckbox: [{
|
|
222
|
+
type: Input
|
|
223
|
+
}], rowSelectionFormatter: [{
|
|
224
|
+
type: Input
|
|
225
|
+
}], rowClassFormatter: [{
|
|
226
|
+
type: Input
|
|
227
|
+
}], rowSelectionChange: [{
|
|
228
|
+
type: Output
|
|
229
|
+
}], showContextMenu: [{
|
|
230
|
+
type: Input
|
|
231
|
+
}], contextMenuItems: [{
|
|
232
|
+
type: Input
|
|
233
|
+
}], contextMenuTemplate: [{
|
|
234
|
+
type: Input
|
|
235
|
+
}], rowContextMenuFormatter: [{
|
|
236
|
+
type: Input
|
|
237
|
+
}], contextMenuItemSelected: [{
|
|
238
|
+
type: Output
|
|
239
|
+
}], noResultText: [{
|
|
240
|
+
type: Input
|
|
241
|
+
}], noResultTemplate: [{
|
|
242
|
+
type: Input
|
|
243
|
+
}], headerTemplate: [{
|
|
244
|
+
type: Input
|
|
245
|
+
}], cellTemplate: [{
|
|
246
|
+
type: Input
|
|
247
|
+
}] } });
|
|
248
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entry-table.component.js","sourceRoot":"","sources":["../../../../../../../libs/entry-components/table/components/entry-table/entry-table.component.ts","../../../../../../../libs/entry-components/table/components/entry-table/entry-table.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/member-ordering */\n\nimport {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ChangeDetectionStrategy,\n  OnChanges,\n  TemplateRef,\n  ChangeDetectorRef,\n  ElementRef,\n  SimpleChanges,\n  HostBinding,\n  Inject,\n} from '@angular/core';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { PageEvent } from '@angular/material/paginator';\nimport { Sort, SortDirection } from '@angular/material/sort';\n\nimport {\n  ColumnDef, PagedData, RowSelectionFormatter, RowClassFormatter,\n  ContextMenuItem, RowContextMenuFormatter, CellTemplate, ENTRY_TABLE_CONFIG, EntryTableConfig\n} from '../../interfaces';\n\n@Component({\n  selector: 'entry-table',\n  templateUrl: './entry-table.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class EntryTableComponent<T> implements OnChanges {\n  @HostBinding('class') className = 'entry-table';\n\n  dataSource = new MatTableDataSource<T>([]);\n\n  @Input() displayedColumns: string[];\n  @Input() columns: ColumnDef[] = [];\n\n  // Data\n\n  private _data: T[] = [];\n  private _page: PagedData<T>;\n  @Input() data: T[] | PagedData<T> | null | undefined = [];\n  @Input() total = 0;\n  @Input() loading = false;\n\n  // Pagination\n\n  @Input() showPaginator: boolean;\n  @Input() pageDisabled = false;\n  @Input() showFirstLastButtons: boolean;\n  @Input() pageIndex = 0;\n  @Input() pageSize: number;\n  @Input() pageSizeOptions: number[];\n  @Input() hidePageSize: boolean;\n  @Output() pageChange = new EventEmitter<PageEvent>();\n\n  @Input() paginationTemplate: TemplateRef<any>;\n\n  // Sort\n\n  @Input() sortActive: string;\n  @Input() sortDirection: SortDirection;\n  @Input() sortDisableClear = false;\n  @Input() sortDisabled = false;\n  @Input() sortStart: 'asc' | 'desc' = 'asc';\n  @Output() sortChange = new EventEmitter<Sort>();\n\n  // Row\n\n  @Input() rowHover = false;\n  @Input() rowStriped = false;\n  @Input() rowFocusVisible = false;\n  @Output() rowClick = new EventEmitter<T>();\n\n  // Row selection\n\n  @Input() multiSelectable = true;\n  rowSelection: SelectionModel<T> = new SelectionModel<T>(true, []);\n\n  @Input() rowSelected: T[] = [];\n  @Input() rowSelectable = false;\n  @Input() showSelectAllCheckbox = true;\n  @Input() rowSelectionFormatter: RowSelectionFormatter = {};\n  @Input() rowClassFormatter: RowClassFormatter;\n  @Output() rowSelectionChange = new EventEmitter<T[]>();\n\n  // Context menu\n\n  @Input() showContextMenu = false;\n  @Input() contextMenuItems: ContextMenuItem[] = [];\n  @Input() contextMenuTemplate: TemplateRef<any> | null;\n  @Input() rowContextMenuFormatter: RowContextMenuFormatter;\n  @Output() contextMenuItemSelected = new EventEmitter<{ itemId: string; rowData: T }>();\n\n  // No Result\n\n  @Input() noResultText: string;\n  @Input() noResultTemplate: TemplateRef<any> | null;\n\n  readonly selectionColumn = 'selection-column';\n  readonly contextMenuColumn = 'context-menu-column';\n\n  get hasNoResult() {\n    return (!this.data || this._data.length === 0) && !this.loading;\n  }\n\n  @Input() headerTemplate: TemplateRef<any> | CellTemplate | any;\n\n  @Input() cellTemplate: TemplateRef<any> | CellTemplate | any;\n\n  constructor(\n    @Inject(ENTRY_TABLE_CONFIG) private _config: EntryTableConfig,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _changeDetectorRef: ChangeDetectorRef) { }\n\n  detectChanges() {\n    this._changeDetectorRef.detectChanges();\n  }\n\n  isTemplateRef(obj: any) {\n    return obj instanceof TemplateRef;\n  }\n\n  getRowClassList(rowData: T, index: number) {\n    const classList = {\n      selected: this.rowSelection.isSelected(rowData),\n      // eslint-disable-next-line @typescript-eslint/naming-convention\n      'mat-row-odd': index % 2,\n    };\n    if (this.rowClassFormatter) {\n      for (const key of Object.keys(this.rowClassFormatter)) {\n        classList[key] = this.rowClassFormatter[key](rowData);\n      }\n    }\n    return classList;\n  }\n\n  getColumnClassList(colDef: ColumnDef): string {\n    const customClasses = colDef.class ?? '';\n    const columnType = colDef.type ?? '';\n    const columnField = `cell-${this.convertToKebabCase(colDef.field)}`;\n\n    return `${customClasses} ${columnType} ${columnField}`;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    this.showPaginator = this.showPaginator ?? this._config.showPaginator;\n    this.showFirstLastButtons = this.showFirstLastButtons ?? this._config.showFirstLastButtons;\n    this.pageSizeOptions = this.pageSizeOptions ?? this._config.pageSizeOptions;\n    this.hidePageSize = this.hidePageSize ?? this._config.hidePageSize;\n    this.noResultText = this.noResultText ?? this._config.noResultsText;\n\n    this.displayedColumns = this.columns.filter(item => !item.hide).map(item => item.field);\n\n    if (this.rowSelectable && !this.displayedColumns.includes(this.selectionColumn)) {\n      this.displayedColumns.unshift(this.selectionColumn);\n    }\n\n    if (this.showContextMenu && !this.displayedColumns.includes(this.contextMenuColumn)) {\n      this.displayedColumns.push(this.contextMenuColumn);\n    }\n\n    if (this.rowSelectable) {\n      this.rowSelection = new SelectionModel<T>(this.multiSelectable, this.rowSelected);\n    }\n\n    if (!this.data) {\n      this.data = [];\n    }\n\n    if (Array.isArray(this.data)) {\n      this._data = this.data as T[];\n    } else {\n      this._page = this.data as PagedData<T>;\n      this._data = this._page.items ?? [];\n      this.total = this._page.totalCount ?? 0;\n      this.pageSize = this._page.pageSize ?? this.pageSize ?? this._config.pageSize;\n      this.pageIndex = this._page.pageNumber ? this._page.pageNumber - 1 : this.pageIndex;\n    }\n\n    if (this.dataSource) {\n      this.dataSource.disconnect();\n    }\n\n    this.dataSource = new MatTableDataSource(this._data);\n\n    if (changes.data) {\n      this.scrollToTop();\n    }\n  }\n\n  getIndex(index: number, dataIndex: number) {\n    return typeof index === 'undefined' ? dataIndex : index;\n  }\n\n  isAllSelected() {\n    const numSelected = this.rowSelection.selected.length;\n    const numRows = this.dataSource.data.filter(row => !this.rowSelectionFormatter.disabled?.(row)).length;\n    return numSelected === numRows;\n  }\n\n  toggleSelectAllCheckbox(): void {\n    if (this.isAllSelected()) {\n      this.rowSelection.clear();\n      this.rowSelectionChange.emit(this.rowSelection.selected);\n      return;\n    }\n    this.dataSource.data.forEach(row => {\n      if (!this.rowSelectionFormatter.disabled?.(row)) {\n        this.rowSelection.select(row);\n      }\n    });\n    this.rowSelectionChange.emit(this.rowSelection.selected);\n  }\n\n  toggleRowSelection(row: any) {\n    this.rowSelection.toggle(row);\n    this.rowSelectionChange.emit(this.rowSelection.selected);\n  }\n\n  handlePage(e: PageEvent) {\n    this.pageChange.emit(e);\n  }\n\n  scrollToTop(): void {\n    this._elementRef.nativeElement.scrollTop = 0;\n  }\n\n  private convertToKebabCase(value: string): string {\n    return value?.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase();\n  }\n}\n","<!-- Table content -->\n<table mat-table \n        [ngClass]=\"{'mat-table-hover': rowHover, 'mat-table-striped': rowStriped, 'mat-table-with-data': !hasNoResult }\"\n        [dataSource]=\"dataSource\"\n        matSort\n        [matSortActive]=\"sortActive\"\n        [matSortDirection]=\"sortDirection\"\n        [matSortDisableClear]=\"sortDisableClear\"\n        [matSortDisabled]=\"sortDisabled\"\n        [matSortStart]=\"sortStart\"\n        (matSortChange)=\"sortChange.emit($event)\">\n\n  <!-- Selection column -->\n  <ng-container *ngIf=\"rowSelectable\" [matColumnDef]=\"selectionColumn\">\n    <th mat-header-cell *matHeaderCellDef class=\"selection-cell\">\n      <mat-checkbox *ngIf=\"multiSelectable && showSelectAllCheckbox\"\n                    [checked]=\"rowSelection.hasValue() && isAllSelected()\"\n                    [indeterminate]=\"rowSelection.hasValue() && !isAllSelected()\"\n                    (change)=\"$event ? toggleSelectAllCheckbox() : null\">\n      </mat-checkbox>\n    </th>\n    <td mat-cell *matCellDef=\"let row; let index = index; let dataIndex = dataIndex;\"\n        class=\"selection-cell\"\n        (click)=\"$event.stopPropagation()\">\n      <mat-checkbox\n        *ngIf=\"multiSelectable && !(rowSelectionFormatter.hideCheckbox && rowSelectionFormatter.hideCheckbox!(row))\"\n        [disabled]=\"rowSelectionFormatter.disabled && rowSelectionFormatter.disabled!(row)\"\n        [checked]=\"rowSelection.isSelected(row)\"\n        (change)=\"$event ? toggleRowSelection(row) : null\">\n      </mat-checkbox>\n      <mat-radio-button\n        *ngIf=\"!multiSelectable && !(rowSelectionFormatter.hideCheckbox && rowSelectionFormatter.hideCheckbox!(row))\"\n        [disabled]=\"rowSelectionFormatter.disabled && rowSelectionFormatter.disabled!(row)\"\n        [checked]=\"rowSelection.isSelected(row)\"\n        [value]=\"rowSelection.isSelected(row)\"\n        (change)=\"$event ? toggleRowSelection(row) : null\">\n      </mat-radio-button>\n    </td>\n  </ng-container>\n\n  <!-- Context menu column -->\n  <ng-container *ngIf=\"showContextMenu\" [matColumnDef]=\"contextMenuColumn\">\n    <th mat-header-cell *matHeaderCellDef class=\"action-cell\"></th>\n    <td mat-cell *matCellDef=\"let row; let index = index; let dataIndex = dataIndex;\"\n        class=\"action-cell\">\n        <ng-template [ngIf]=\"isTemplateRef(contextMenuTemplate)\" [ngIfElse]=\"contextMenuTpl\">\n          <ng-template [ngTemplateOutlet]=\"contextMenuTemplate\"\n                        [ngTemplateOutletContext]=\"{ $implicit: row, rowData: row }\">\n          </ng-template>\n        </ng-template>\n        <ng-template #contextMenuTpl>\n          <entry-cell-context-menu\n            [items]=\"contextMenuItems\"\n            [rowData]=\"row\"\n            [rowMenuFormatter]=\"rowContextMenuFormatter\"\n            (selected)=\"contextMenuItemSelected.emit({itemId: $event, rowData: row})\"\n          ></entry-cell-context-menu>\n        </ng-template>\n    </td>\n  </ng-container>\n\n  <ng-container *ngFor=\"let col of columns;\">\n    <ng-container [matColumnDef]=\"col.field\"\n                  [sticky]=\"col.pinned==='left'\" [stickyEnd]=\"col.pinned==='right'\">\n      <th mat-header-cell *matHeaderCellDef\n          [class]=\"getColumnClassList(col)\"\n          [ngClass]=\"{'mat-table-sticky-left': col.pinned === 'left', 'mat-table-sticky-right': col.pinned === 'right'}\"\n          [ngStyle]=\"{'width': col.width, 'min-width': col.width}\">\n          <ng-template [ngIf]=\"isTemplateRef(headerTemplate)\" [ngIfElse]=\"headerTpl\">\n            <ng-template [ngTemplateOutlet]=\"headerTemplate\"\n                          [ngTemplateOutletContext]=\"{ $implicit: col, colDef: col }\">\n            </ng-template>\n          </ng-template>\n          <ng-template #headerTpl>\n            <ng-template [ngIf]=\"headerTemplate && isTemplateRef(headerTemplate[col.field])\"\n                          [ngIfElse]=\"defaultHeaderTpl\">\n              <ng-template [ngTemplateOutlet]=\"headerTemplate[col.field]\"\n                            [ngTemplateOutletContext]=\"{ $implicit: col, colDef: col }\">\n              </ng-template>\n            </ng-template>\n          </ng-template>\n          <ng-template #defaultHeaderTpl>\n            <div [mat-sort-header]=\"col.sortProp?.id || col.field\"\n                  [disabled]=\"!col.sortable\"\n                  [disableClear]=\"col.sortProp?.disableClear\">\n              <span>{{col.header}}</span>\n            </div>\n          </ng-template>\n      </th>\n\n      <td mat-cell *matCellDef=\"let row; let index = index; let dataIndex = dataIndex;\"\n          [class]=\"getColumnClassList(col)\"\n          [ngClass]=\"{'mat-table-sticky-left': col.pinned === 'left', 'mat-table-sticky-right': col.pinned === 'right'}\"\n          [ngStyle]=\"{'width': col.width, 'min-width': col.width}\">\n        <ng-template [ngIf]=\"isTemplateRef(cellTemplate)\" [ngIfElse]=\"cellTpl\">\n          <ng-template [ngTemplateOutlet]=\"cellTemplate\"\n                        [ngTemplateOutletContext]=\"{ $implicit: row, rowData: row, index: getIndex(index, dataIndex), colDef: col }\">\n          </ng-template>\n        </ng-template>\n        <ng-template #cellTpl>\n          <ng-template [ngIf]=\"cellTemplate && isTemplateRef(cellTemplate[col.field])\"\n                        [ngIfElse]=\"colDefCellTpl\">\n            <ng-template [ngTemplateOutlet]=\"cellTemplate[col.field]\"\n                          [ngTemplateOutletContext]=\"{ $implicit: row, rowData: row, index: getIndex(index, dataIndex), colDef: col }\">\n            </ng-template>\n          </ng-template>\n        </ng-template>\n        <ng-template #colDefCellTpl>\n          <ng-template [ngIf]=\"col.cellTemplate\" [ngIfElse]=\"defaultCellTpl\"\n                        [ngTemplateOutlet]=\"col.cellTemplate ?? null\"\n                        [ngTemplateOutletContext]=\"{ $implicit: row, rowData: row, index: getIndex(index, dataIndex), colDef: col }\">\n          </ng-template>\n        </ng-template>\n        <ng-template #defaultCellTpl>\n          <entry-cell [rowData]=\"row\" [colDef]=\"col\"></entry-cell>\n        </ng-template>\n      </td>\n    </ng-container>\n  </ng-container>\n\n  <tr mat-header-row *matHeaderRowDef=\"displayedColumns; sticky: true\"></tr>\n  <tr mat-row\n      *matRowDef=\"let row; let index = index; let dataIndex = dataIndex; columns: displayedColumns;\"\n      [ngClass]=\"getRowClassList(row, getIndex(index, dataIndex))\"\n      [attr.tabindex]=\"rowFocusVisible ? 0 : -1\"\n      (click)=\"rowClick.emit(row)\"\n      (keyup.enter)=\"rowClick.emit(row)\">\n  </tr>\n</table>\n\n<!-- No results -->\n<div class=\"no-results mat-body-2\" *ngIf=\"hasNoResult\">\n  <ng-template [ngIf]=\"isTemplateRef(noResultTemplate)\" [ngIfElse]=\"defaultNoResultTpl\">\n    <ng-template [ngTemplateOutlet]=\"noResultTemplate\"></ng-template>\n  </ng-template>\n  <ng-template #defaultNoResultTpl>{{noResultText}}</ng-template>\n</div>\n\n<!-- Pagination -->\n<ng-template [ngIf]=\"isTemplateRef(paginationTemplate)\" [ngIfElse]=\"defaultPaginationTemplate\">\n  <ng-template [ngTemplateOutlet]=\"paginationTemplate\"></ng-template>\n</ng-template>\n<ng-template #defaultPaginationTemplate>\n  <mat-paginator class=\"pagination\" *ngIf=\"showPaginator\"\n                  [showFirstLastButtons]=\"showFirstLastButtons\"\n                  [length]=\"total\"\n                  [pageIndex]=\"pageIndex\"\n                  [pageSize]=\"pageSize\"\n                  [pageSizeOptions]=\"pageSizeOptions\"\n                  [hidePageSize]=\"hidePageSize\"\n                  (page)=\"handlePage($event)\"\n                  [disabled]=\"pageDisabled\">\n  </mat-paginator>\n</ng-template>"]}
|
|
@@ -16,39 +16,39 @@ import { EntryCellFormattedValueComponent } from './components/entry-cell-format
|
|
|
16
16
|
import { DEFAULT_PERCENTAGE_MULTIPLIER } from './interfaces';
|
|
17
17
|
import * as i0 from "@angular/core";
|
|
18
18
|
export class EntryTableModule {
|
|
19
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryTableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
20
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: EntryTableModule, declarations: [EntryTableComponent,
|
|
21
|
+
EntryCellComponent,
|
|
22
|
+
EntryCellContextMenuComponent,
|
|
23
|
+
EntryCellFormattedValueComponent], imports: [CommonModule,
|
|
24
|
+
FormsModule,
|
|
25
|
+
MatTableModule,
|
|
26
|
+
MatSortModule,
|
|
27
|
+
MatPaginatorModule,
|
|
28
|
+
MatCheckboxModule,
|
|
29
|
+
MatIconModule,
|
|
30
|
+
MatMenuModule,
|
|
31
|
+
MatRadioModule,
|
|
32
|
+
CommonModule,
|
|
33
|
+
MatButtonModule], exports: [EntryTableComponent,
|
|
34
|
+
EntryCellComponent,
|
|
35
|
+
EntryCellContextMenuComponent,
|
|
36
|
+
EntryCellFormattedValueComponent] }); }
|
|
37
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryTableModule, providers: [
|
|
38
|
+
{ provide: DEFAULT_PERCENTAGE_MULTIPLIER, useValue: 1 }
|
|
39
|
+
], imports: [CommonModule,
|
|
40
|
+
FormsModule,
|
|
41
|
+
MatTableModule,
|
|
42
|
+
MatSortModule,
|
|
43
|
+
MatPaginatorModule,
|
|
44
|
+
MatCheckboxModule,
|
|
45
|
+
MatIconModule,
|
|
46
|
+
MatMenuModule,
|
|
47
|
+
MatRadioModule,
|
|
48
|
+
CommonModule,
|
|
49
|
+
MatButtonModule] }); }
|
|
19
50
|
}
|
|
20
|
-
|
|
21
|
-
EntryTableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: EntryTableModule, declarations: [EntryTableComponent,
|
|
22
|
-
EntryCellComponent,
|
|
23
|
-
EntryCellContextMenuComponent,
|
|
24
|
-
EntryCellFormattedValueComponent], imports: [CommonModule,
|
|
25
|
-
FormsModule,
|
|
26
|
-
MatTableModule,
|
|
27
|
-
MatSortModule,
|
|
28
|
-
MatPaginatorModule,
|
|
29
|
-
MatCheckboxModule,
|
|
30
|
-
MatIconModule,
|
|
31
|
-
MatMenuModule,
|
|
32
|
-
MatRadioModule,
|
|
33
|
-
CommonModule,
|
|
34
|
-
MatButtonModule], exports: [EntryTableComponent,
|
|
35
|
-
EntryCellComponent,
|
|
36
|
-
EntryCellContextMenuComponent,
|
|
37
|
-
EntryCellFormattedValueComponent] });
|
|
38
|
-
EntryTableModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EntryTableModule, providers: [
|
|
39
|
-
{ provide: DEFAULT_PERCENTAGE_MULTIPLIER, useValue: 1 }
|
|
40
|
-
], imports: [CommonModule,
|
|
41
|
-
FormsModule,
|
|
42
|
-
MatTableModule,
|
|
43
|
-
MatSortModule,
|
|
44
|
-
MatPaginatorModule,
|
|
45
|
-
MatCheckboxModule,
|
|
46
|
-
MatIconModule,
|
|
47
|
-
MatMenuModule,
|
|
48
|
-
MatRadioModule,
|
|
49
|
-
CommonModule,
|
|
50
|
-
MatButtonModule] });
|
|
51
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EntryTableModule, decorators: [{
|
|
51
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryTableModule, decorators: [{
|
|
52
52
|
type: NgModule,
|
|
53
53
|
args: [{
|
|
54
54
|
imports: [
|
|
@@ -81,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
81
81
|
]
|
|
82
82
|
}]
|
|
83
83
|
}] });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cnktdGFibGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL3RhYmxlL2VudHJ5LXRhYmxlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUNqRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFFekQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDckYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOENBQThDLENBQUM7QUFDbEYsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sd0VBQXdFLENBQUM7QUFDdkgsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0sOEVBQThFLENBQUM7QUFDaEksT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sY0FBYyxDQUFDOztBQWdDN0QsTUFBTSxPQUFPLGdCQUFnQjsrR0FBaEIsZ0JBQWdCO2dIQUFoQixnQkFBZ0IsaUJBZnpCLG1CQUFtQjtZQUNuQixrQkFBa0I7WUFDbEIsNkJBQTZCO1lBQzdCLGdDQUFnQyxhQWhCaEMsWUFBWTtZQUNaLFdBQVc7WUFDWCxjQUFjO1lBQ2QsYUFBYTtZQUNiLGtCQUFrQjtZQUNsQixpQkFBaUI7WUFDakIsYUFBYTtZQUNiLGFBQWE7WUFDYixjQUFjO1lBQ2QsWUFBWTtZQUNaLGVBQWUsYUFTZixtQkFBbUI7WUFDbkIsa0JBQWtCO1lBQ2xCLDZCQUE2QjtZQUM3QixnQ0FBZ0M7Z0hBTXZCLGdCQUFnQixhQUpoQjtZQUNULEVBQUUsT0FBTyxFQUFFLDZCQUE2QixFQUFFLFFBQVEsRUFBRSxDQUFDLEVBQUU7U0FDeEQsWUExQkMsWUFBWTtZQUNaLFdBQVc7WUFDWCxjQUFjO1lBQ2QsYUFBYTtZQUNiLGtCQUFrQjtZQUNsQixpQkFBaUI7WUFDakIsYUFBYTtZQUNiLGFBQWE7WUFDYixjQUFjO1lBQ2QsWUFBWTtZQUNaLGVBQWU7OzRGQWtCTixnQkFBZ0I7a0JBOUI1QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsY0FBYzt3QkFDZCxhQUFhO3dCQUNiLGtCQUFrQjt3QkFDbEIsaUJBQWlCO3dCQUNqQixhQUFhO3dCQUNiLGFBQWE7d0JBQ2IsY0FBYzt3QkFDZCxZQUFZO3dCQUNaLGVBQWU7cUJBQ2hCO29CQUNELFlBQVksRUFBRTt3QkFDWixtQkFBbUI7d0JBQ25CLGtCQUFrQjt3QkFDbEIsNkJBQTZCO3dCQUM3QixnQ0FBZ0M7cUJBQ2pDO29CQUNELE9BQU8sRUFBRTt3QkFDUCxtQkFBbUI7d0JBQ25CLGtCQUFrQjt3QkFDbEIsNkJBQTZCO3dCQUM3QixnQ0FBZ0M7cUJBQ2pDO29CQUNELFNBQVMsRUFBRTt3QkFDVCxFQUFFLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxRQUFRLEVBQUUsQ0FBQyxFQUFFO3FCQUN4RDtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRUYWJsZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3RhYmxlJztcbmltcG9ydCB7IE1hdFNvcnRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zb3J0JztcbmltcG9ydCB7IE1hdFBhZ2luYXRvck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3BhZ2luYXRvcic7XG5pbXBvcnQgeyBNYXRDaGVja2JveE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NoZWNrYm94JztcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IE1hdE1lbnVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9tZW51JztcbmltcG9ydCB7IE1hdFJhZGlvTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcmFkaW8nO1xuaW1wb3J0IHtNYXRCdXR0b25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5cbmltcG9ydCB7IEVudHJ5VGFibGVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZW50cnktdGFibGUvZW50cnktdGFibGUuY29tcG9uZW50JztcbmltcG9ydCB7IEVudHJ5Q2VsbENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9lbnRyeS1jZWxsL2VudHJ5LWNlbGwuY29tcG9uZW50JztcbmltcG9ydCB7IEVudHJ5Q2VsbENvbnRleHRNZW51Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2VudHJ5LWNlbGwtY29udGV4dC1tZW51L2VudHJ5LWNlbGwtY29udGV4dC1tZW51LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBFbnRyeUNlbGxGb3JtYXR0ZWRWYWx1ZUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9lbnRyeS1jZWxsLWZvcm1hdHRlZC12YWx1ZS9lbnRyeS1jZWxsLWZvcm1hdHRlZC12YWx1ZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgREVGQVVMVF9QRVJDRU5UQUdFX01VTFRJUExJRVIgfSBmcm9tICcuL2ludGVyZmFjZXMnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIE1hdFRhYmxlTW9kdWxlLFxuICAgIE1hdFNvcnRNb2R1bGUsXG4gICAgTWF0UGFnaW5hdG9yTW9kdWxlLFxuICAgIE1hdENoZWNrYm94TW9kdWxlLFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgTWF0TWVudU1vZHVsZSxcbiAgICBNYXRSYWRpb01vZHVsZSxcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgTWF0QnV0dG9uTW9kdWxlXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEVudHJ5VGFibGVDb21wb25lbnQsXG4gICAgRW50cnlDZWxsQ29tcG9uZW50LFxuICAgIEVudHJ5Q2VsbENvbnRleHRNZW51Q29tcG9uZW50LFxuICAgIEVudHJ5Q2VsbEZvcm1hdHRlZFZhbHVlQ29tcG9uZW50XG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBFbnRyeVRhYmxlQ29tcG9uZW50LFxuICAgIEVudHJ5Q2VsbENvbXBvbmVudCxcbiAgICBFbnRyeUNlbGxDb250ZXh0TWVudUNvbXBvbmVudCxcbiAgICBFbnRyeUNlbGxGb3JtYXR0ZWRWYWx1ZUNvbXBvbmVudFxuICBdLFxuICBwcm92aWRlcnM6IFtcbiAgICB7IHByb3ZpZGU6IERFRkFVTFRfUEVSQ0VOVEFHRV9NVUxUSVBMSUVSLCB1c2VWYWx1ZTogMSB9XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgRW50cnlUYWJsZU1vZHVsZSB7IH1cbiJdfQ==
|
|
@@ -9,10 +9,9 @@ export class EntryTableConfig {
|
|
|
9
9
|
this.noResultsText = 'No results found';
|
|
10
10
|
}
|
|
11
11
|
}
|
|
12
|
-
;
|
|
13
12
|
export const ENTRY_TABLE_CONFIG = new InjectionToken('ENTRY_TABLE_CONFIG', {
|
|
14
13
|
providedIn: 'root',
|
|
15
14
|
factory: () => new EntryTableConfig()
|
|
16
15
|
});
|
|
17
16
|
export const DEFAULT_PERCENTAGE_MULTIPLIER = new InjectionToken('');
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cnktdGFibGUtY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL3RhYmxlL2ludGVyZmFjZXMvZW50cnktdGFibGUtY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFL0MsTUFBTSxPQUFPLGdCQUFnQjtJQUE3QjtRQUNTLGtCQUFhLEdBQUcsSUFBSSxDQUFDO1FBQ3JCLHlCQUFvQixHQUFHLEtBQUssQ0FBQztRQUM3QixhQUFRLEdBQUcsRUFBRSxDQUFDO1FBQ2Qsb0JBQWUsR0FBRyxDQUFDLEVBQUUsRUFBRSxFQUFFLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDaEMsaUJBQVksR0FBRyxLQUFLLENBQUM7UUFDckIsa0JBQWEsR0FBRyxrQkFBa0IsQ0FBQztJQUM1QyxDQUFDO0NBQUE7QUFFRCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLGNBQWMsQ0FDbEQsb0JBQW9CLEVBQ3BCO0lBQ0UsVUFBVSxFQUFFLE1BQU07SUFDbEIsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLElBQUksZ0JBQWdCLEVBQUU7Q0FDdEMsQ0FBQyxDQUFDO0FBR0wsTUFBTSxDQUFDLE1BQU0sNkJBQTZCLEdBQTJCLElBQUksY0FBYyxDQUFTLEVBQUUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGNsYXNzIEVudHJ5VGFibGVDb25maWcge1xuICBwdWJsaWMgc2hvd1BhZ2luYXRvciA9IHRydWU7XG4gIHB1YmxpYyBzaG93Rmlyc3RMYXN0QnV0dG9ucyA9IGZhbHNlO1xuICBwdWJsaWMgcGFnZVNpemUgPSAyMDtcbiAgcHVibGljIHBhZ2VTaXplT3B0aW9ucyA9IFsyMCwgNTAsIDEwMF07XG4gIHB1YmxpYyBoaWRlUGFnZVNpemUgPSBmYWxzZTtcbiAgcHVibGljIG5vUmVzdWx0c1RleHQgPSAnTm8gcmVzdWx0cyBmb3VuZCc7XG59XG5cbmV4cG9ydCBjb25zdCBFTlRSWV9UQUJMRV9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW48RW50cnlUYWJsZUNvbmZpZz4oXG4gICdFTlRSWV9UQUJMRV9DT05GSUcnLFxuICB7XG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxuICAgIGZhY3Rvcnk6ICgpID0+IG5ldyBFbnRyeVRhYmxlQ29uZmlnKClcbiAgfSk7XG5cblxuZXhwb3J0IGNvbnN0IERFRkFVTFRfUEVSQ0VOVEFHRV9NVUxUSVBMSUVSOiBJbmplY3Rpb25Ub2tlbjxudW1iZXI+ID0gbmV3IEluamVjdGlvblRva2VuPG51bWJlcj4oJycpO1xuIl19
|
|
@@ -46,10 +46,10 @@ export class EntryDisplayControlValidationDirective {
|
|
|
46
46
|
const serverErrorsString = serverErrors instanceof Array ? serverErrors.join(', ') : '';
|
|
47
47
|
return [errorsString, serverErrorsString].filter(x => x !== '').join(', ');
|
|
48
48
|
}
|
|
49
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryDisplayControlValidationDirective, deps: [{ token: ENTRY_VALIDATION_CONFIG }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
50
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: EntryDisplayControlValidationDirective, selector: "[entryDisplayControlValidation]", inputs: { control: "control" }, ngImport: i0 }); }
|
|
49
51
|
}
|
|
50
|
-
|
|
51
|
-
EntryDisplayControlValidationDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: EntryDisplayControlValidationDirective, selector: "[entryDisplayControlValidation]", inputs: { control: "control" }, ngImport: i0 });
|
|
52
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EntryDisplayControlValidationDirective, decorators: [{
|
|
52
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryDisplayControlValidationDirective, decorators: [{
|
|
53
53
|
type: Directive,
|
|
54
54
|
args: [{
|
|
55
55
|
selector: '[entryDisplayControlValidation]'
|
|
@@ -60,4 +60,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
60
60
|
}] }, { type: i0.ElementRef }]; }, propDecorators: { control: [{
|
|
61
61
|
type: Input
|
|
62
62
|
}] } });
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cnktZGlzcGxheS1jb250cm9sLXZhbGlkYXRpb24uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL3ZhbGlkYXRpb24vZW50cnktZGlzcGxheS1jb250cm9sLXZhbGlkYXRpb24uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsTUFBTSxFQUFFLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDeEYsT0FBTyxFQUFFLHVCQUF1QixFQUF5QixNQUFNLGlDQUFpQyxDQUFDO0FBR2pHLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDOzs7QUFFMUQ7Ozs7Ozs7OztHQVNHO0FBSUgsTUFBTSxPQUFPLHNDQUFzQztJQU1qRCxZQUNvRCxPQUE4QixFQUMvRCxRQUFvQjtRQURhLFlBQU8sR0FBUCxPQUFPLENBQXVCO1FBQy9ELGFBQVEsR0FBUixRQUFRLENBQVk7SUFBRyxDQUFDO0lBRTNDLFFBQVE7UUFDTixJQUFJLENBQUMsb0JBQW9CLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhO2FBQ25ELFNBQVMsQ0FBQyxDQUFDLGFBQWdDLEVBQUUsRUFBRTtZQUM5QyxJQUFJLGFBQWEsS0FBSyxTQUFTLEVBQUU7Z0JBQy9CLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMseUJBQXlCLEVBQUUsQ0FBQzthQUMxRTtRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLElBQUksQ0FBQyxvQkFBb0IsRUFBRTtZQUM3QixJQUFJLENBQUMsb0JBQW9CLENBQUMsV0FBVyxFQUFFLENBQUM7U0FDekM7SUFDSCxDQUFDO0lBRU8seUJBQXlCO1FBQy9CLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRTtZQUN4QixPQUFPLEVBQUUsQ0FBQztTQUNYO1FBQ0QsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxrQkFBa0I7YUFDakQsR0FBRyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUM7WUFDbkUsQ0FBQyxDQUFDLE9BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsS0FBSyxRQUFRO2dCQUM5QyxDQUFDLENBQUMsaUJBQWlCLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztZQUN2RSxDQUFDLENBQUMsRUFBRSxDQUNMO2FBQ0EsTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQzthQUNqQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFZCxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1FBQy9ELE1BQU0sa0JBQWtCLEdBQUcsWUFBWSxZQUFZLEtBQUssQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBRXhGLE9BQU8sQ0FBQyxZQUFZLEVBQUUsa0JBQWtCLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzdFLENBQUM7K0dBMUNVLHNDQUFzQyxrQkFPdkMsdUJBQXVCO21HQVB0QixzQ0FBc0M7OzRGQUF0QyxzQ0FBc0M7a0JBSGxELFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlDQUFpQztpQkFDNUM7OzBCQVFJLE1BQU07MkJBQUMsdUJBQXVCO3FFQUx4QixPQUFPO3NCQUFmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEluamVjdCwgSW5wdXQsIE9uRGVzdHJveSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBFTlRSWV9WQUxJREFUSU9OX0NPTkZJRywgRW50cnlWYWxpZGF0aW9uQ29uZmlnIH0gZnJvbSAnLi9lbnRyeS12YWxpZGF0aW9uLWNvbmZpZy5tb2RlbCc7XG5pbXBvcnQgeyBBYnN0cmFjdENvbnRyb2wsIEZvcm1Db250cm9sU3RhdHVzIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBGT1JNX0ZJRUxEX0VSUk9SX0tFWSB9IGZyb20gJy4vZW50cnktdmFsaWRhdGlvbic7XG5cbi8qKlxuICogQSBkaXJlY3RpdmUgdGhhdCBkaXNwbGF5cyBjb25maWd1cmVkIHZhbGlkYXRpb24gbWVzc2FnZXMgb3Igc2VydmVyIHNpZGUgdmFsaWRhdGlvbnMgZm9yIGdpdmVuIGZvcm0gY29udHJvbC5cbiAqIFRoZSBtZXNzYWdlcyBhcmUgc2VwYXJhdGVkIHdpdGggY29tYSgsKSBhbmQgZGlzcGxheWVkIGFzIF9pbm5lckhUTUxfIHZhbHVlIG9mIGhvc3QgY29tcG9uZW50LlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGBodG1sXG4gKiA8ZGl2IGVudHJ5RGlzcGxheUNvbnRyb2xWYWxpZGF0aW9uIFtjb250cm9sXT1cIm15Rm9ybS5jb250cm9scy5maXJzdE5hbWVcIj5cbiAqIDwvZGl2XG4gKiBgYGBcbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2VudHJ5RGlzcGxheUNvbnRyb2xWYWxpZGF0aW9uXSdcbn0pXG5leHBvcnQgY2xhc3MgRW50cnlEaXNwbGF5Q29udHJvbFZhbGlkYXRpb25EaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIC8qKiBGb3JtIGNvbnRyb2wgZm9yIHdoaWNoIHRoZSB2YWxpZGF0aW9uIG1lc3NhZ2VzIGFyZSBkaXNwbGF5ZWQgZm9yLiAqL1xuICBASW5wdXQoKSBjb250cm9sOiBBYnN0cmFjdENvbnRyb2w7XG5cbiAgcHJpdmF0ZSBfY29udHJvbFN1YnNjcmlwdGlvbjogU3Vic2NyaXB0aW9uIHwgdW5kZWZpbmVkO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoRU5UUllfVkFMSURBVElPTl9DT05GSUcpIHByaXZhdGUgcmVhZG9ubHkgX2NvbmZpZzogRW50cnlWYWxpZGF0aW9uQ29uZmlnLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgX2VsZW1lbnQ6IEVsZW1lbnRSZWYpIHt9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5fY29udHJvbFN1YnNjcmlwdGlvbiA9IHRoaXMuY29udHJvbC5zdGF0dXNDaGFuZ2VzXG4gICAgICAuc3Vic2NyaWJlKChjb250cm9sU3RhdHVzOiBGb3JtQ29udHJvbFN0YXR1cykgPT4ge1xuICAgICAgICBpZiAoY29udHJvbFN0YXR1cyA9PT0gJ0lOVkFMSUQnKSB7XG4gICAgICAgICAgdGhpcy5fZWxlbWVudC5uYXRpdmVFbGVtZW50LmlubmVyVGV4dCA9IHRoaXMuZXh0cmFjdFZhbGlkYXRpb25NZXNzYWdlcygpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLl9jb250cm9sU3Vic2NyaXB0aW9uKSB7XG4gICAgICB0aGlzLl9jb250cm9sU3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBleHRyYWN0VmFsaWRhdGlvbk1lc3NhZ2VzKCk6IHN0cmluZyB7XG4gICAgaWYgKCF0aGlzLmNvbnRyb2wuZXJyb3JzKSB7XG4gICAgICByZXR1cm4gJyc7XG4gICAgfVxuICAgIGNvbnN0IGVycm9yc1N0cmluZyA9IHRoaXMuX2NvbmZpZy52YWxpZGF0aW9uTWVzc2FnZXNcbiAgICAgIC5tYXAodmFsaWRhdGlvbk1lc3NhZ2UgPT4gdGhpcy5jb250cm9sLmVycm9yc1t2YWxpZGF0aW9uTWVzc2FnZS5uYW1lXVxuICAgICAgICA/IHR5cGVvZih2YWxpZGF0aW9uTWVzc2FnZS5tZXNzYWdlKSA9PT0gJ3N0cmluZydcbiAgICAgICAgICA/IHZhbGlkYXRpb25NZXNzYWdlLm1lc3NhZ2UgOiB2YWxpZGF0aW9uTWVzc2FnZS5tZXNzYWdlKHRoaXMuY29udHJvbClcbiAgICAgICAgOiAnJ1xuICAgICAgKVxuICAgICAgLmZpbHRlcihtZXNzYWdlID0+IG1lc3NhZ2UgIT09ICcnKVxuICAgICAgLmpvaW4oJywgJyk7XG5cbiAgICBjb25zdCBzZXJ2ZXJFcnJvcnMgPSB0aGlzLmNvbnRyb2wuZXJyb3JzW0ZPUk1fRklFTERfRVJST1JfS0VZXTtcbiAgICBjb25zdCBzZXJ2ZXJFcnJvcnNTdHJpbmcgPSBzZXJ2ZXJFcnJvcnMgaW5zdGFuY2VvZiBBcnJheSA/IHNlcnZlckVycm9ycy5qb2luKCcsICcpIDogJyc7XG5cbiAgICByZXR1cm4gW2Vycm9yc1N0cmluZywgc2VydmVyRXJyb3JzU3RyaW5nXS5maWx0ZXIoeCA9PiB4ICE9PSAnJykuam9pbignLCAnKTtcbiAgfVxufVxuIl19
|