ontimize-web-ngx 15.8.0 → 15.8.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (21) hide show
  1. package/esm2020/lib/components/input/date-range-legacy/o-daterange-picker.component.mjs +2 -2
  2. package/esm2020/lib/components/input/radio/o-radio.component.mjs +4 -3
  3. package/esm2020/lib/components/o-form-data-component.class.mjs +2 -2
  4. package/esm2020/lib/components/table/extensions/default-o-table.datasource.mjs +4 -2
  5. package/esm2020/lib/components/table/extensions/dialog/visible-columns/o-table-visible-columns-dialog.component.mjs +33 -5
  6. package/esm2020/lib/components/table/extensions/header/table-header/o-table-header.component.mjs +6 -4
  7. package/esm2020/lib/components/table/extensions/header/table-header-column-filter-icon/o-table-header-column-filter-icon.component.mjs +30 -24
  8. package/esm2020/lib/components/table/extensions/header/table-header-select-all/o-table-header-select-all.component.mjs +2 -2
  9. package/esm2020/lib/components/table/extensions/o-table-strategy.service.mjs +9 -2
  10. package/esm2020/lib/components/table/o-table.component.mjs +59 -41
  11. package/fesm2015/ontimize-web-ngx.mjs +146 -80
  12. package/fesm2015/ontimize-web-ngx.mjs.map +1 -1
  13. package/fesm2020/ontimize-web-ngx.mjs +141 -77
  14. package/fesm2020/ontimize-web-ngx.mjs.map +1 -1
  15. package/lib/components/input/radio/o-radio.component.d.ts +1 -0
  16. package/lib/components/table/extensions/header/table-header/o-table-header.component.d.ts +3 -1
  17. package/lib/components/table/extensions/header/table-header-column-filter-icon/o-table-header-column-filter-icon.component.d.ts +9 -4
  18. package/lib/components/table/extensions/header/table-header-select-all/o-table-header-select-all.component.d.ts +1 -1
  19. package/lib/components/table/extensions/o-table-strategy.service.d.ts +2 -0
  20. package/lib/components/table/o-table.component.d.ts +14 -7
  21. package/package.json +1 -1
@@ -10,7 +10,8 @@ import * as i5 from "../table-header-column-filter-icon/o-table-header-column-fi
10
10
  import * as i6 from "../../../../../pipes/o-translate.pipe";
11
11
  import * as i7 from "../../../o-table-base.class";
12
12
  export const DEFAULT_INPUTS_O_TABLE_HEADER = [
13
- 'column'
13
+ 'column',
14
+ 'columnFilters: column-filters'
14
15
  ];
15
16
  export class OTableHeaderComponent {
16
17
  set columnFilterIcon(value) {
@@ -18,6 +19,7 @@ export class OTableHeaderComponent {
18
19
  }
19
20
  constructor(table) {
20
21
  this.table = table;
22
+ this.columnFilters = [];
21
23
  this.resizable = this.table.resizable;
22
24
  }
23
25
  isModeColumnFilterable(column) {
@@ -33,14 +35,14 @@ export class OTableHeaderComponent {
33
35
  }
34
36
  }
35
37
  OTableHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OTableHeaderComponent, deps: [{ token: forwardRef(() => OTableBase) }], target: i0.ɵɵFactoryTarget.Component });
36
- OTableHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: OTableHeaderComponent, selector: "o-table-header", inputs: { column: "column" }, host: { listeners: { "mouseenter": "setFilterIconHintVisible(true)", "mouseleave": "setFilterIconHintVisible(false)" }, properties: { "class.o-table-header": "true" } }, viewQueries: [{ propertyName: "columnFilterIcon", first: true, predicate: ["columnFilterIcon"], descendants: true }, { propertyName: "matSortHeader", first: true, predicate: OMatSortHeader, descendants: true }], ngImport: i0, template: "<o-table-header-column-filter-icon #columnFilterIcon *ngIf=\"isModeColumnFilterable(column)\" [column]=\"column\">\n</o-table-header-column-filter-icon>\n\n<ng-container *ngIf=\"column.orderable\">\n <span o-mat-sort-header>{{ column.title | oTranslate }}</span>\n</ng-container>\n<ng-container *ngIf=\"!column.orderable\">\n <span class=\"header-title-container\" fxFlex>{{ column.title | oTranslate }}</span>\n</ng-container>\n\n<o-table-column-resizer *ngIf=\"resizable\" [column]=\"column\"></o-table-column-resizer>\n", styles: [".o-table-header{display:flex;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.o-table-header span[o-mat-sort-header]{flex:1;min-width:0}.o-table-header span[o-mat-sort-header]:not(:has(+ .o-table-column-resizer)){padding-right:6px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "component", type: i3.OMatSortHeader, selector: "[o-mat-sort-header]", inputs: ["disabled"], exportAs: ["oMatSortHeader"] }, { kind: "component", type: i4.OTableColumnResizerComponent, selector: "o-table-column-resizer", inputs: ["column"] }, { kind: "component", type: i5.OTableHeaderColumnFilterIconComponent, selector: "o-table-header-column-filter-icon", inputs: ["column"] }, { kind: "pipe", type: i6.OTranslatePipe, name: "oTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
38
+ OTableHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: OTableHeaderComponent, selector: "o-table-header", inputs: { column: "column", columnFilters: ["column-filters", "columnFilters"] }, host: { listeners: { "mouseenter": "setFilterIconHintVisible(true)", "mouseleave": "setFilterIconHintVisible(false)" }, properties: { "class.o-table-header": "true" } }, viewQueries: [{ propertyName: "columnFilterIcon", first: true, predicate: ["columnFilterIcon"], descendants: true }, { propertyName: "matSortHeader", first: true, predicate: OMatSortHeader, descendants: true }], ngImport: i0, template: "<o-table-header-column-filter-icon #columnFilterIcon *ngIf=\"isModeColumnFilterable(column)\" [column]=\"column\" [column-filters]=\"columnFilters\">\n</o-table-header-column-filter-icon>\n\n<ng-container *ngIf=\"column.orderable\">\n <span o-mat-sort-header>{{ column.title | oTranslate }}</span>\n</ng-container>\n<ng-container *ngIf=\"!column.orderable\">\n <span class=\"header-title-container\" fxFlex>{{ column.title | oTranslate }}</span>\n</ng-container>\n\n<o-table-column-resizer *ngIf=\"resizable\" [column]=\"column\"></o-table-column-resizer>\n", styles: [".o-table-header{display:flex;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.o-table-header span[o-mat-sort-header]{flex:1;min-width:0}.o-table-header span[o-mat-sort-header]:not(:has(+ .o-table-column-resizer)){padding-right:6px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "component", type: i3.OMatSortHeader, selector: "[o-mat-sort-header]", inputs: ["disabled"], exportAs: ["oMatSortHeader"] }, { kind: "component", type: i4.OTableColumnResizerComponent, selector: "o-table-column-resizer", inputs: ["column"] }, { kind: "component", type: i5.OTableHeaderColumnFilterIconComponent, selector: "o-table-header-column-filter-icon", inputs: ["column", "column-filters"] }, { kind: "pipe", type: i6.OTranslatePipe, name: "oTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
37
39
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OTableHeaderComponent, decorators: [{
38
40
  type: Component,
39
41
  args: [{ selector: 'o-table-header', inputs: DEFAULT_INPUTS_O_TABLE_HEADER, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: {
40
42
  '[class.o-table-header]': 'true',
41
43
  '(mouseenter)': 'setFilterIconHintVisible(true)',
42
44
  '(mouseleave)': 'setFilterIconHintVisible(false)'
43
- }, template: "<o-table-header-column-filter-icon #columnFilterIcon *ngIf=\"isModeColumnFilterable(column)\" [column]=\"column\">\n</o-table-header-column-filter-icon>\n\n<ng-container *ngIf=\"column.orderable\">\n <span o-mat-sort-header>{{ column.title | oTranslate }}</span>\n</ng-container>\n<ng-container *ngIf=\"!column.orderable\">\n <span class=\"header-title-container\" fxFlex>{{ column.title | oTranslate }}</span>\n</ng-container>\n\n<o-table-column-resizer *ngIf=\"resizable\" [column]=\"column\"></o-table-column-resizer>\n", styles: [".o-table-header{display:flex;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.o-table-header span[o-mat-sort-header]{flex:1;min-width:0}.o-table-header span[o-mat-sort-header]:not(:has(+ .o-table-column-resizer)){padding-right:6px}\n"] }]
45
+ }, template: "<o-table-header-column-filter-icon #columnFilterIcon *ngIf=\"isModeColumnFilterable(column)\" [column]=\"column\" [column-filters]=\"columnFilters\">\n</o-table-header-column-filter-icon>\n\n<ng-container *ngIf=\"column.orderable\">\n <span o-mat-sort-header>{{ column.title | oTranslate }}</span>\n</ng-container>\n<ng-container *ngIf=\"!column.orderable\">\n <span class=\"header-title-container\" fxFlex>{{ column.title | oTranslate }}</span>\n</ng-container>\n\n<o-table-column-resizer *ngIf=\"resizable\" [column]=\"column\"></o-table-column-resizer>\n", styles: [".o-table-header{display:flex;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.o-table-header span[o-mat-sort-header]{flex:1;min-width:0}.o-table-header span[o-mat-sort-header]:not(:has(+ .o-table-column-resizer)){padding-right:6px}\n"] }]
44
46
  }], ctorParameters: function () { return [{ type: i7.OTableBase, decorators: [{
45
47
  type: Inject,
46
48
  args: [forwardRef(() => OTableBase)]
@@ -51,4 +53,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
51
53
  type: ViewChild,
52
54
  args: [OMatSortHeader]
53
55
  }] } });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiby10YWJsZS1oZWFkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb250aW1pemUtd2ViLW5neC9zcmMvbGliL2NvbXBvbmVudHMvdGFibGUvZXh0ZW5zaW9ucy9oZWFkZXIvdGFibGUtaGVhZGVyL28tdGFibGUtaGVhZGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29udGltaXplLXdlYi1uZ3gvc3JjL2xpYi9jb21wb25lbnRzL3RhYmxlL2V4dGVuc2lvbnMvaGVhZGVyL3RhYmxlLWhlYWRlci9vLXRhYmxlLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXJILE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7Ozs7OztBQUc5RCxNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBRztJQUMzQyxRQUFRO0NBQ1QsQ0FBQTtBQWNELE1BQU0sT0FBTyxxQkFBcUI7SUFNaEMsSUFBbUMsZ0JBQWdCLENBQUMsS0FBNEM7UUFDOUYsSUFBSSxDQUFDLGlCQUFpQixHQUFHLEtBQUssQ0FBQztJQUNqQyxDQUFDO0lBSUQsWUFDa0QsS0FBaUI7UUFBakIsVUFBSyxHQUFMLEtBQUssQ0FBWTtRQUVqRSxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDO0lBQ3hDLENBQUM7SUFHRCxzQkFBc0IsQ0FBQyxNQUFlO1FBQ3BDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxxQkFBcUIsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFFRCx3QkFBd0IsQ0FBQyxPQUFnQjtRQUN2QyxJQUFJLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtZQUMxQixJQUFJLENBQUMsaUJBQWlCLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1NBQzVEO0lBQ0gsQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLENBQUMsS0FBSyxDQUFDLG9CQUFvQixDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3hDLENBQUM7O21IQS9CVSxxQkFBcUIsa0JBYXRCLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxVQUFVLENBQUM7dUdBYjNCLHFCQUFxQixvWkFVckIsY0FBYyxnRENoQzNCLDhnQkFXQTs0RkRXYSxxQkFBcUI7a0JBYmpDLFNBQVM7K0JBQ0UsZ0JBQWdCLFVBQ2xCLDZCQUE2QixpQkFHdEIsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSxRQUN6Qzt3QkFDSix3QkFBd0IsRUFBRSxNQUFNO3dCQUNoQyxjQUFjLEVBQUUsZ0NBQWdDO3dCQUNoRCxjQUFjLEVBQUUsaUNBQWlDO3FCQUNsRDs7MEJBZUUsTUFBTTsyQkFBQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsVUFBVSxDQUFDOzRDQVBILGdCQUFnQjtzQkFBbEQsU0FBUzt1QkFBQyxrQkFBa0I7Z0JBSUYsYUFBYTtzQkFBdkMsU0FBUzt1QkFBQyxjQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgZm9yd2FyZFJlZiwgSW5qZWN0LCBWaWV3Q2hpbGQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB0eXBlIHsgT0NvbHVtbiB9IGZyb20gXCIuLi8uLi8uLi9jb2x1bW4vby1jb2x1bW4uY2xhc3NcIjtcbmltcG9ydCB7IE9UYWJsZUJhc2UgfSBmcm9tIFwiLi4vLi4vLi4vby10YWJsZS1iYXNlLmNsYXNzXCI7XG5pbXBvcnQgeyBPTWF0U29ydEhlYWRlciB9IGZyb20gXCIuLi8uLi9zb3J0L28tbWF0LXNvcnQtaGVhZGVyXCI7XG5pbXBvcnQgdHlwZSB7IE9UYWJsZUhlYWRlckNvbHVtbkZpbHRlckljb25Db21wb25lbnQgfSBmcm9tIFwiLi4vdGFibGUtaGVhZGVyLWNvbHVtbi1maWx0ZXItaWNvbi9vLXRhYmxlLWhlYWRlci1jb2x1bW4tZmlsdGVyLWljb24uY29tcG9uZW50XCI7XG5cbmV4cG9ydCBjb25zdCBERUZBVUxUX0lOUFVUU19PX1RBQkxFX0hFQURFUiA9IFtcbiAgJ2NvbHVtbidcbl1cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ28tdGFibGUtaGVhZGVyJyxcbiAgaW5wdXRzOiBERUZBVUxUX0lOUFVUU19PX1RBQkxFX0hFQURFUixcbiAgdGVtcGxhdGVVcmw6ICcuL28tdGFibGUtaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vby10YWJsZS1oZWFkZXIuY29tcG9uZW50LnNjc3MnXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGhvc3Q6IHtcbiAgICAnW2NsYXNzLm8tdGFibGUtaGVhZGVyXSc6ICd0cnVlJyxcbiAgICAnKG1vdXNlZW50ZXIpJzogJ3NldEZpbHRlckljb25IaW50VmlzaWJsZSh0cnVlKScsXG4gICAgJyhtb3VzZWxlYXZlKSc6ICdzZXRGaWx0ZXJJY29uSGludFZpc2libGUoZmFsc2UpJ1xuICB9XG59KVxuZXhwb3J0IGNsYXNzIE9UYWJsZUhlYWRlckNvbXBvbmVudCB7XG5cbiAgcHVibGljIGNvbHVtbjogT0NvbHVtbjtcbiAgcHVibGljIHJlc2l6YWJsZTogYm9vbGVhbjtcbiAgcHJvdGVjdGVkIF9jb2x1bW5GaWx0ZXJJY29uOiBPVGFibGVIZWFkZXJDb2x1bW5GaWx0ZXJJY29uQ29tcG9uZW50O1xuXG4gIEBWaWV3Q2hpbGQoJ2NvbHVtbkZpbHRlckljb24nKSBzZXQgY29sdW1uRmlsdGVySWNvbih2YWx1ZTogT1RhYmxlSGVhZGVyQ29sdW1uRmlsdGVySWNvbkNvbXBvbmVudCkge1xuICAgIHRoaXMuX2NvbHVtbkZpbHRlckljb24gPSB2YWx1ZTtcbiAgfVxuXG4gIEBWaWV3Q2hpbGQoT01hdFNvcnRIZWFkZXIpIG1hdFNvcnRIZWFkZXI6IE9NYXRTb3J0SGVhZGVyO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoZm9yd2FyZFJlZigoKSA9PiBPVGFibGVCYXNlKSkgcHJvdGVjdGVkIHRhYmxlOiBPVGFibGVCYXNlXG4gICkge1xuICAgIHRoaXMucmVzaXphYmxlID0gdGhpcy50YWJsZS5yZXNpemFibGU7XG4gIH1cblxuXG4gIGlzTW9kZUNvbHVtbkZpbHRlcmFibGUoY29sdW1uOiBPQ29sdW1uKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMudGFibGUuaXNDb2x1bW5GaWx0ZXJzQWN0aXZlICYmIHRoaXMudGFibGUuaXNDb2x1bW5GaWx0ZXJhYmxlKGNvbHVtbik7XG4gIH1cblxuICBzZXRGaWx0ZXJJY29uSGludFZpc2libGUodmlzaWJsZTogYm9vbGVhbikge1xuICAgIGlmICh0aGlzLl9jb2x1bW5GaWx0ZXJJY29uKSB7XG4gICAgICB0aGlzLl9jb2x1bW5GaWx0ZXJJY29uLmZpbHRlckljb25IaW50VmlzaWJsZS5uZXh0KHZpc2libGUpO1xuICAgIH1cbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLnRhYmxlLnJlZ2lzdGVyVGFibGVIZWFkZXJzKHRoaXMpO1xuICB9XG5cbn1cbiIsIjxvLXRhYmxlLWhlYWRlci1jb2x1bW4tZmlsdGVyLWljb24gI2NvbHVtbkZpbHRlckljb24gKm5nSWY9XCJpc01vZGVDb2x1bW5GaWx0ZXJhYmxlKGNvbHVtbilcIiBbY29sdW1uXT1cImNvbHVtblwiPlxuPC9vLXRhYmxlLWhlYWRlci1jb2x1bW4tZmlsdGVyLWljb24+XG5cbjxuZy1jb250YWluZXIgKm5nSWY9XCJjb2x1bW4ub3JkZXJhYmxlXCI+XG4gIDxzcGFuIG8tbWF0LXNvcnQtaGVhZGVyPnt7IGNvbHVtbi50aXRsZSB8IG9UcmFuc2xhdGUgfX08L3NwYW4+XG48L25nLWNvbnRhaW5lcj5cbjxuZy1jb250YWluZXIgKm5nSWY9XCIhY29sdW1uLm9yZGVyYWJsZVwiPlxuICA8c3BhbiBjbGFzcz1cImhlYWRlci10aXRsZS1jb250YWluZXJcIiBmeEZsZXg+e3sgY29sdW1uLnRpdGxlIHwgb1RyYW5zbGF0ZSB9fTwvc3Bhbj5cbjwvbmctY29udGFpbmVyPlxuXG48by10YWJsZS1jb2x1bW4tcmVzaXplciAqbmdJZj1cInJlc2l6YWJsZVwiIFtjb2x1bW5dPVwiY29sdW1uXCI+PC9vLXRhYmxlLWNvbHVtbi1yZXNpemVyPlxuIl19
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiby10YWJsZS1oZWFkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb250aW1pemUtd2ViLW5neC9zcmMvbGliL2NvbXBvbmVudHMvdGFibGUvZXh0ZW5zaW9ucy9oZWFkZXIvdGFibGUtaGVhZGVyL28tdGFibGUtaGVhZGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29udGltaXplLXdlYi1uZ3gvc3JjL2xpYi9jb21wb25lbnRzL3RhYmxlL2V4dGVuc2lvbnMvaGVhZGVyL3RhYmxlLWhlYWRlci9vLXRhYmxlLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXJILE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7Ozs7OztBQUk5RCxNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBRztJQUMzQyxRQUFRO0lBRVIsK0JBQStCO0NBQ2hDLENBQUE7QUFjRCxNQUFNLE9BQU8scUJBQXFCO0lBU2hDLElBQW1DLGdCQUFnQixDQUFDLEtBQTRDO1FBQzlGLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxLQUFLLENBQUM7SUFDakMsQ0FBQztJQUlELFlBQ2tELEtBQWlCO1FBQWpCLFVBQUssR0FBTCxLQUFLLENBQVk7UUFaNUQsa0JBQWEsR0FBeUIsRUFBRSxDQUFDO1FBYzlDLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUM7SUFDeEMsQ0FBQztJQUdELHNCQUFzQixDQUFDLE1BQWU7UUFDcEMsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLHFCQUFxQixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsa0JBQWtCLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDbkYsQ0FBQztJQUVELHdCQUF3QixDQUFDLE9BQWdCO1FBQ3ZDLElBQUksSUFBSSxDQUFDLGlCQUFpQixFQUFFO1lBQzFCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxxQkFBcUIsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7U0FDNUQ7SUFDSCxDQUFDO0lBRUQsZUFBZTtRQUNiLElBQUksQ0FBQyxLQUFLLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEMsQ0FBQzs7bUhBbENVLHFCQUFxQixrQkFnQnRCLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxVQUFVLENBQUM7dUdBaEIzQixxQkFBcUIsd2NBYXJCLGNBQWMsZ0RDdEMzQixpakJBV0E7NEZEY2EscUJBQXFCO2tCQWJqQyxTQUFTOytCQUNFLGdCQUFnQixVQUNsQiw2QkFBNkIsaUJBR3RCLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0sUUFDekM7d0JBQ0osd0JBQXdCLEVBQUUsTUFBTTt3QkFDaEMsY0FBYyxFQUFFLGdDQUFnQzt3QkFDaEQsY0FBYyxFQUFFLGlDQUFpQztxQkFDbEQ7OzBCQWtCRSxNQUFNOzJCQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxVQUFVLENBQUM7NENBUEgsZ0JBQWdCO3NCQUFsRCxTQUFTO3VCQUFDLGtCQUFrQjtnQkFJRixhQUFhO3NCQUF2QyxTQUFTO3VCQUFDLGNBQWMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBmb3J3YXJkUmVmLCBJbmplY3QsIFZpZXdDaGlsZCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHR5cGUgeyBPQ29sdW1uIH0gZnJvbSBcIi4uLy4uLy4uL2NvbHVtbi9vLWNvbHVtbi5jbGFzc1wiO1xuaW1wb3J0IHsgT1RhYmxlQmFzZSB9IGZyb20gXCIuLi8uLi8uLi9vLXRhYmxlLWJhc2UuY2xhc3NcIjtcbmltcG9ydCB7IE9NYXRTb3J0SGVhZGVyIH0gZnJvbSBcIi4uLy4uL3NvcnQvby1tYXQtc29ydC1oZWFkZXJcIjtcbmltcG9ydCB0eXBlIHsgT1RhYmxlSGVhZGVyQ29sdW1uRmlsdGVySWNvbkNvbXBvbmVudCB9IGZyb20gXCIuLi90YWJsZS1oZWFkZXItY29sdW1uLWZpbHRlci1pY29uL28tdGFibGUtaGVhZGVyLWNvbHVtbi1maWx0ZXItaWNvbi5jb21wb25lbnRcIjtcbmltcG9ydCB7IE9Db2x1bW5WYWx1ZUZpbHRlciB9IGZyb20gXCIuLi8uLi8uLi8uLi8uLi90eXBlcy90YWJsZS9vLWNvbHVtbi12YWx1ZS1maWx0ZXIudHlwZVwiO1xuXG5leHBvcnQgY29uc3QgREVGQVVMVF9JTlBVVFNfT19UQUJMRV9IRUFERVIgPSBbXG4gICdjb2x1bW4nLFxuICAvLyBjb2x1bW5GaWx0ZXJzOiBBY3RpdmUgZmlsdGVycyBhcHBsaWVkIHRvIHRhYmxlIGNvbHVtbnNcbiAgJ2NvbHVtbkZpbHRlcnM6IGNvbHVtbi1maWx0ZXJzJ1xuXVxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnby10YWJsZS1oZWFkZXInLFxuICBpbnB1dHM6IERFRkFVTFRfSU5QVVRTX09fVEFCTEVfSEVBREVSLFxuICB0ZW1wbGF0ZVVybDogJy4vby10YWJsZS1oZWFkZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9vLXRhYmxlLWhlYWRlci5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaG9zdDoge1xuICAgICdbY2xhc3Muby10YWJsZS1oZWFkZXJdJzogJ3RydWUnLFxuICAgICcobW91c2VlbnRlciknOiAnc2V0RmlsdGVySWNvbkhpbnRWaXNpYmxlKHRydWUpJyxcbiAgICAnKG1vdXNlbGVhdmUpJzogJ3NldEZpbHRlckljb25IaW50VmlzaWJsZShmYWxzZSknXG4gIH1cbn0pXG5leHBvcnQgY2xhc3MgT1RhYmxlSGVhZGVyQ29tcG9uZW50IHtcblxuICBwdWJsaWMgY29sdW1uOiBPQ29sdW1uO1xuXG4gIHB1YmxpYyBjb2x1bW5GaWx0ZXJzOiBPQ29sdW1uVmFsdWVGaWx0ZXJbXSA9IFtdO1xuXG4gIHB1YmxpYyByZXNpemFibGU6IGJvb2xlYW47XG4gIHByb3RlY3RlZCBfY29sdW1uRmlsdGVySWNvbjogT1RhYmxlSGVhZGVyQ29sdW1uRmlsdGVySWNvbkNvbXBvbmVudDtcblxuICBAVmlld0NoaWxkKCdjb2x1bW5GaWx0ZXJJY29uJykgc2V0IGNvbHVtbkZpbHRlckljb24odmFsdWU6IE9UYWJsZUhlYWRlckNvbHVtbkZpbHRlckljb25Db21wb25lbnQpIHtcbiAgICB0aGlzLl9jb2x1bW5GaWx0ZXJJY29uID0gdmFsdWU7XG4gIH1cblxuICBAVmlld0NoaWxkKE9NYXRTb3J0SGVhZGVyKSBtYXRTb3J0SGVhZGVyOiBPTWF0U29ydEhlYWRlcjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBASW5qZWN0KGZvcndhcmRSZWYoKCkgPT4gT1RhYmxlQmFzZSkpIHByb3RlY3RlZCB0YWJsZTogT1RhYmxlQmFzZVxuICApIHtcbiAgICB0aGlzLnJlc2l6YWJsZSA9IHRoaXMudGFibGUucmVzaXphYmxlO1xuICB9XG5cblxuICBpc01vZGVDb2x1bW5GaWx0ZXJhYmxlKGNvbHVtbjogT0NvbHVtbik6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLnRhYmxlLmlzQ29sdW1uRmlsdGVyc0FjdGl2ZSAmJiB0aGlzLnRhYmxlLmlzQ29sdW1uRmlsdGVyYWJsZShjb2x1bW4pO1xuICB9XG5cbiAgc2V0RmlsdGVySWNvbkhpbnRWaXNpYmxlKHZpc2libGU6IGJvb2xlYW4pIHtcbiAgICBpZiAodGhpcy5fY29sdW1uRmlsdGVySWNvbikge1xuICAgICAgdGhpcy5fY29sdW1uRmlsdGVySWNvbi5maWx0ZXJJY29uSGludFZpc2libGUubmV4dCh2aXNpYmxlKTtcbiAgICB9XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgdGhpcy50YWJsZS5yZWdpc3RlclRhYmxlSGVhZGVycyh0aGlzKTtcbiAgfVxuXG59XG4iLCI8by10YWJsZS1oZWFkZXItY29sdW1uLWZpbHRlci1pY29uICNjb2x1bW5GaWx0ZXJJY29uICpuZ0lmPVwiaXNNb2RlQ29sdW1uRmlsdGVyYWJsZShjb2x1bW4pXCIgW2NvbHVtbl09XCJjb2x1bW5cIiBbY29sdW1uLWZpbHRlcnNdPVwiY29sdW1uRmlsdGVyc1wiPlxuPC9vLXRhYmxlLWhlYWRlci1jb2x1bW4tZmlsdGVyLWljb24+XG5cbjxuZy1jb250YWluZXIgKm5nSWY9XCJjb2x1bW4ub3JkZXJhYmxlXCI+XG4gIDxzcGFuIG8tbWF0LXNvcnQtaGVhZGVyPnt7IGNvbHVtbi50aXRsZSB8IG9UcmFuc2xhdGUgfX08L3NwYW4+XG48L25nLWNvbnRhaW5lcj5cbjxuZy1jb250YWluZXIgKm5nSWY9XCIhY29sdW1uLm9yZGVyYWJsZVwiPlxuICA8c3BhbiBjbGFzcz1cImhlYWRlci10aXRsZS1jb250YWluZXJcIiBmeEZsZXg+e3sgY29sdW1uLnRpdGxlIHwgb1RyYW5zbGF0ZSB9fTwvc3Bhbj5cbjwvbmctY29udGFpbmVyPlxuXG48by10YWJsZS1jb2x1bW4tcmVzaXplciAqbmdJZj1cInJlc2l6YWJsZVwiIFtjb2x1bW5dPVwiY29sdW1uXCI+PC9vLXRhYmxlLWNvbHVtbi1yZXNpemVyPlxuIl19
@@ -1,5 +1,5 @@
1
1
  import { animate, state, style, transition, trigger } from '@angular/animations';
2
- import { ChangeDetectionStrategy, Component, forwardRef, Inject, ViewEncapsulation } from '@angular/core';
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, Inject, ViewEncapsulation } from '@angular/core';
3
3
  import { AnimationDurations } from '@angular/material/core';
4
4
  import { BehaviorSubject, Subscription } from 'rxjs';
5
5
  import { Util } from '../../../../../util/util';
@@ -16,22 +16,29 @@ import * as i5 from "@angular/flex-layout/extended";
16
16
  import * as i6 from "@angular/material/icon";
17
17
  import * as i7 from "../../../o-table-base.class";
18
18
  export const DEFAULT_INPUTS_O_TABLE_COLUMN_FILTER_ICON = [
19
- 'column'
19
+ 'column',
20
+ 'columnFilters: column-filters'
20
21
  ];
21
22
  export class OTableHeaderColumnFilterIconComponent {
22
- constructor(table, dialog, dialogService, translateService) {
23
+ set columnFilters(filters) {
24
+ this._columnFilters = filters?.filter(value => value.values) || [];
25
+ this.updateStateColumnFilter();
26
+ }
27
+ get columnFilters() {
28
+ return this._columnFilters;
29
+ }
30
+ constructor(table, dialog, dialogService, translateService, cd) {
23
31
  this.table = table;
24
32
  this.dialog = dialog;
25
33
  this.dialogService = dialogService;
26
34
  this.translateService = translateService;
35
+ this.cd = cd;
36
+ this._columnFilters = [];
27
37
  this.isColumnFilterActive = new BehaviorSubject(false);
28
38
  this.filterIconHintVisible = new BehaviorSubject(false);
29
39
  this.indicatorNumber = new BehaviorSubject('');
30
40
  this.subscription = new Subscription();
31
41
  this.filterIconStateView = new BehaviorSubject('INACTIVE');
32
- this.subscription.add(this.table.onFilterByColumnChange.subscribe(() => {
33
- this.updateStateColumnFilter();
34
- }));
35
42
  this.subscription.add(this.filterIconHintVisible.subscribe((value) => {
36
43
  this.setFilterIconHintVisible(value);
37
44
  }));
@@ -40,13 +47,17 @@ export class OTableHeaderColumnFilterIconComponent {
40
47
  this.updateStateColumnFilter();
41
48
  }
42
49
  updateStateColumnFilter() {
50
+ this.updateFilterIndicatorNumber();
51
+ const isActive = Util.isDefined(this.getColumnValueFilterByAttr()?.values);
52
+ this.isColumnFilterActive.next(isActive);
53
+ this.filterIconStateView.next(isActive ? 'ACTIVE' : 'INACTIVE');
54
+ this.cd.markForCheck();
55
+ }
56
+ updateFilterIndicatorNumber() {
43
57
  this.indicatorNumber.next(this.getFilterIndicatorNumbered());
44
- this.isColumnFilterActive.next(Util.isDefined(this.getColumnValueFilterByAttr()));
45
- this.filterIconStateView.next(this.isColumnFilterActive.getValue() ? 'ACTIVE' : 'INACTIVE');
46
58
  }
47
59
  getColumnValueFilterByAttr() {
48
- const columnValueFilters = this.table.dataSource.getColumnValueFilters();
49
- return columnValueFilters.find(item => item.attr === this.column.attr);
60
+ return this._columnFilters?.find(item => item.attr === this.column.attr);
50
61
  }
51
62
  openColumnFilterDialog(event) {
52
63
  const filterByColumnComponent = this.table.oTableColumnsFilterComponent?.getFilterColumnByAttr(this.column.attr);
@@ -58,16 +69,11 @@ export class OTableHeaderColumnFilterIconComponent {
58
69
  }
59
70
  }
60
71
  getFilterIndicatorNumbered() {
61
- let result = '';
62
- const columnValueFilters = this.table.dataSource.getColumnValueFilters();
63
- if (columnValueFilters.length < 2) {
64
- return result;
65
- }
66
- const index = columnValueFilters.findIndex(x => x.attr === this.column.attr);
67
- if (index > -1) {
68
- result += index + 1;
69
- }
70
- return result;
72
+ const filters = this._columnFilters ?? [];
73
+ const index = filters.length > 1
74
+ ? filters.findIndex(f => f.attr === this.column.attr)
75
+ : -1;
76
+ return index >= 0 ? `${index + 1}` : '';
71
77
  }
72
78
  setFilterIconHintVisible(visible) {
73
79
  if (this.filterIconStateView.getValue() === 'ACTIVE') {
@@ -79,8 +85,8 @@ export class OTableHeaderColumnFilterIconComponent {
79
85
  this.subscription.unsubscribe();
80
86
  }
81
87
  }
82
- OTableHeaderColumnFilterIconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OTableHeaderColumnFilterIconComponent, deps: [{ token: forwardRef(() => OTableBase) }, { token: i1.MatDialog }, { token: i2.DialogService }, { token: i3.OTranslateService }], target: i0.ɵɵFactoryTarget.Component });
83
- OTableHeaderColumnFilterIconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: OTableHeaderColumnFilterIconComponent, selector: "o-table-header-column-filter-icon", inputs: { column: "column" }, host: { properties: { "class.o-table-column-filter-icon": "true" } }, ngImport: i0, template: "<mat-icon class=\"column-filter-icon\" [ngClass]=\"{'column-filter-icon-active':isColumnFilterActive | async}\"\n (click)=\"openColumnFilterDialog($event)\" [@iconState]=\"filterIconStateView | async\">\n filter_alt\n</mat-icon>\n<span class=\"o-table-header-indicator-numbered\">\n {{ indicatorNumber | async }}\n</span>", styles: [".o-table .o-table-container .mat-mdc-table .mat-mdc-header-cell:has(.o-table-column-filter-icon){padding-left:0}.o-table .o-table-container .mat-mdc-table .mat-mdc-header-cell .o-table-column-filter-icon{position:relative;display:flex;margin-right:6px}.o-table .o-table-container .mat-mdc-table .mat-mdc-header-cell .o-table-column-filter-icon .mat-icon{align-self:center}.o-table .o-table-container .mat-mdc-table .mat-mdc-header-cell .o-table-column-filter-icon .o-table-header-indicator-numbered{right:-5px;bottom:-6px}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], animations: [
88
+ OTableHeaderColumnFilterIconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OTableHeaderColumnFilterIconComponent, deps: [{ token: forwardRef(() => OTableBase) }, { token: i1.MatDialog }, { token: i2.DialogService }, { token: i3.OTranslateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
89
+ OTableHeaderColumnFilterIconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: OTableHeaderColumnFilterIconComponent, selector: "o-table-header-column-filter-icon", inputs: { column: "column", columnFilters: ["column-filters", "columnFilters"] }, host: { properties: { "class.o-table-column-filter-icon": "true" } }, ngImport: i0, template: "<mat-icon class=\"column-filter-icon\" [ngClass]=\"{'column-filter-icon-active':isColumnFilterActive | async}\"\n (click)=\"openColumnFilterDialog($event)\" [@iconState]=\"filterIconStateView | async\">\n filter_alt\n</mat-icon>\n<span class=\"o-table-header-indicator-numbered\">\n {{ indicatorNumber | async }}\n</span>", styles: [".o-table .o-table-container .mat-mdc-table .mat-mdc-header-cell:has(.o-table-column-filter-icon){padding-left:0}.o-table .o-table-container .mat-mdc-table .mat-mdc-header-cell .o-table-column-filter-icon{position:relative;display:flex;margin-right:6px}.o-table .o-table-container .mat-mdc-table .mat-mdc-header-cell .o-table-column-filter-icon .mat-icon{align-self:center}.o-table .o-table-container .mat-mdc-table .mat-mdc-header-cell .o-table-column-filter-icon .o-table-header-indicator-numbered{right:-5px;bottom:-6px}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], animations: [
84
90
  trigger('iconState', [
85
91
  state('ACTIVE, HINT', style({ opacity: 1 })),
86
92
  state('INACTIVE', style({ opacity: 0 })),
@@ -101,5 +107,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
101
107
  }], ctorParameters: function () { return [{ type: i7.OTableBase, decorators: [{
102
108
  type: Inject,
103
109
  args: [forwardRef(() => OTableBase)]
104
- }] }, { type: i1.MatDialog }, { type: i2.DialogService }, { type: i3.OTranslateService }]; } });
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-table-header-column-filter-icon.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/header/table-header-column-filter-icon/o-table-header-column-filter-icon.component.ts","../../../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/header/table-header-column-filter-icon/o-table-header-column-filter-icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport { ChangeDetectionStrategy, Component, forwardRef, Inject, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\nimport { AnimationDurations } from '@angular/material/core';\nimport { BehaviorSubject, Subscription } from 'rxjs';\n\nimport { OColumnValueFilter } from '../../../../../types/table/o-column-value-filter.type';\nimport { Util } from '../../../../../util/util';\nimport type { OColumn } from '../../../column';\nimport { OTableBase } from '../../../o-table-base.class';\nimport { MatDialog } from '@angular/material/dialog';\nimport { DialogService } from '../../../../../services/dialog.service';\nimport { OTranslateService } from '../../../../../services/translate/o-translate.service';\n\nexport const DEFAULT_INPUTS_O_TABLE_COLUMN_FILTER_ICON = [\n  'column'\n]\nexport declare type STATEVIEW = 'HINT' | 'ACTIVE' | 'INACTIVE'\n@Component({\n  selector: 'o-table-header-column-filter-icon',\n  inputs: DEFAULT_INPUTS_O_TABLE_COLUMN_FILTER_ICON,\n  templateUrl: './o-table-header-column-filter-icon.component.html',\n  styleUrls: ['./o-table-header-column-filter-icon.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    '[class.o-table-column-filter-icon]': 'true'\n  },\n  animations: [\n    trigger('iconState', [\n      state('ACTIVE, HINT', style({ opacity: 1 })),\n      state('INACTIVE', style({ opacity: 0 })),\n      transition('* <=> HINT', animate(AnimationDurations.ENTERING))\n    ]),\n\n  ]\n})\nexport class OTableHeaderColumnFilterIconComponent implements OnInit, OnDestroy {\n\n  public column: OColumn;\n  public isColumnFilterActive: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  public filterIconHintVisible: BehaviorSubject<boolean> = new BehaviorSubject(false)\n  public indicatorNumber: BehaviorSubject<string> = new BehaviorSubject('');\n  private subscription = new Subscription();\n  public filterIconStateView: BehaviorSubject<STATEVIEW> = new BehaviorSubject<STATEVIEW>('INACTIVE');\n\n\n  constructor(\n    @Inject(forwardRef(() => OTableBase)) public table: OTableBase,\n    protected dialog: MatDialog,\n    protected dialogService: DialogService,\n    protected translateService: OTranslateService\n  ) {\n    this.subscription.add(this.table.onFilterByColumnChange.subscribe(() => {\n      this.updateStateColumnFilter();\n    }));\n\n    this.subscription.add(this.filterIconHintVisible.subscribe((value) => {\n\n      this.setFilterIconHintVisible(value);\n    }));\n  }\n\n  ngOnInit(): void {\n    this.updateStateColumnFilter();\n  }\n\n  public updateStateColumnFilter() {\n    this.indicatorNumber.next(this.getFilterIndicatorNumbered());\n\n    this.isColumnFilterActive.next(Util.isDefined(this.getColumnValueFilterByAttr()));\n    this.filterIconStateView.next(this.isColumnFilterActive.getValue() ? 'ACTIVE' : 'INACTIVE');\n  }\n\n  protected getColumnValueFilterByAttr(): OColumnValueFilter {\n    const columnValueFilters = this.table.dataSource.getColumnValueFilters();\n    return columnValueFilters.find(item => item.attr === this.column.attr);\n  }\n\n  public openColumnFilterDialog(event) {\n    const filterByColumnComponent = this.table.oTableColumnsFilterComponent?.getFilterColumnByAttr(this.column.attr)\n    if (filterByColumnComponent?.filterLocked) {\n      this.dialogService.alert(this.translateService.get('TABLE.FILTER_LOCKED'), this.translateService.get(filterByColumnComponent.filterLockedMessage));\n    } else {\n      this.table.openColumnFilterDialog(this.column, event);\n    }\n  }\n\n  public getFilterIndicatorNumbered(): string {\n    let result = '';\n\n    const columnValueFilters = this.table.dataSource.getColumnValueFilters();\n    if (columnValueFilters.length < 2) {\n      return result;\n    }\n\n    const index = columnValueFilters.findIndex(x => x.attr === this.column.attr);\n    if (index > -1) {\n      result += index + 1;\n    }\n\n    return result;\n  }\n\n  /**\n   * Sets the \"hint\" state such that the icon will be semi-transparently displayed as a hint to the\n   * user showing what the active filter by column will become. If set to false, the icon will fade away.\n   */\n  setFilterIconHintVisible(visible: boolean) {\n    // No-op if the sort header is ACTIVE - should not make the hint visible.\n    if (this.filterIconStateView.getValue() === 'ACTIVE') { return; }\n    this.filterIconStateView.next(visible ? 'HINT' : 'INACTIVE');\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n}\n","<mat-icon class=\"column-filter-icon\" [ngClass]=\"{'column-filter-icon-active':isColumnFilterActive | async}\"\n  (click)=\"openColumnFilterDialog($event)\" [@iconState]=\"filterIconStateView | async\">\n  filter_alt\n</mat-icon>\n<span class=\"o-table-header-indicator-numbered\">\n  {{ indicatorNumber | async }}\n</span>"]}
110
+ }] }, { type: i1.MatDialog }, { type: i2.DialogService }, { type: i3.OTranslateService }, { type: i0.ChangeDetectorRef }]; } });
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-table-header-column-filter-icon.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/header/table-header-column-filter-icon/o-table-header-column-filter-icon.component.ts","../../../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/header/table-header-column-filter-icon/o-table-header-column-filter-icon.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACjF,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAqB,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAChJ,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AAGrD,OAAO,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAC;AAEhD,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,uDAAuD,CAAC;;;;;;;;;AAE1F,MAAM,CAAC,MAAM,yCAAyC,GAAG;IACvD,QAAQ;IAER,+BAA+B;CAChC,CAAC;AAsBF,MAAM,OAAO,qCAAqC;IAQhD,IAAI,aAAa,CAAC,OAA6B;QAC7C,IAAI,CAAC,cAAc,GAAG,OAAO,EAAE,MAAM,CAAC,KAAK,CAAA,EAAE,CAAA,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACjE,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IACD,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAUD,YAC+C,KAAiB,EACpD,MAAiB,EACjB,aAA4B,EAC5B,gBAAmC,EACnC,EAAqB;QAJc,UAAK,GAAL,KAAK,CAAY;QACpD,WAAM,GAAN,MAAM,CAAW;QACjB,kBAAa,GAAb,aAAa,CAAe;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAmB;QACnC,OAAE,GAAF,EAAE,CAAmB;QAbzB,mBAAc,GAAyB,EAAE,CAAC;QAE3C,yBAAoB,GAA6B,IAAI,eAAe,CAAC,KAAK,CAAC,CAAC;QAC5E,0BAAqB,GAA6B,IAAI,eAAe,CAAC,KAAK,CAAC,CAAC;QAC7E,oBAAe,GAA4B,IAAI,eAAe,CAAC,EAAE,CAAC,CAAC;QAClE,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QACnC,wBAAmB,GAA+B,IAAI,eAAe,CAAY,UAAU,CAAC,CAAC;QASlG,IAAI,CAAC,YAAY,CAAC,GAAG,CACnB,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YAC7C,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC,CAAC;QACvC,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAKM,uBAAuB;QAC5B,IAAI,CAAC,2BAA2B,EAAE,CAAC;QAEnC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,0BAA0B,EAAE,EAAE,MAAM,CAAC,CAAC;QAC3E,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACzC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;QAChE,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;IACzB,CAAC;IAKO,2BAA2B;QACjC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,0BAA0B,EAAE,CAAC,CAAC;IAC/D,CAAC;IAKS,0BAA0B;QAClC,OAAO,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC3E,CAAC;IAGM,sBAAsB,CAAC,KAAY;QACxC,MAAM,uBAAuB,GAAG,IAAI,CAAC,KAAK,CAAC,4BAA4B,EAAE,qBAAqB,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAEjH,IAAI,uBAAuB,EAAE,YAAY,EAAE;YACzC,IAAI,CAAC,aAAa,CAAC,KAAK,CACtB,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,qBAAqB,CAAC,EAChD,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,uBAAuB,CAAC,mBAAmB,CAAC,CACvE,CAAC;SACH;aAAM;YACL,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;SACvD;IACH,CAAC;IAKM,0BAA0B;QAC/B,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,IAAI,EAAE,CAAC;QAC1C,MAAM,KAAK,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC;YAC9B,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;YACrD,CAAC,CAAC,CAAC,CAAC,CAAC;QAEP,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IAC1C,CAAC;IAMD,wBAAwB,CAAC,OAAgB;QAEvC,IAAI,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,KAAK,QAAQ,EAAE;YACpD,OAAO;SACR;QACD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;IAC/D,CAAC;IAED,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;IAClC,CAAC;;mIA5GU,qCAAqC,kBAyBtC,UAAU,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC;uHAzB3B,qCAAqC,iOCvClD,sUAMO,m2CDyBO;QACV,OAAO,CAAC,WAAW,EAAE;YACnB,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;YAC5C,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;YACxC,UAAU,CAAC,YAAY,EAAE,OAAO,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;SAC/D,CAAC;KACH;4FAEU,qCAAqC;kBAlBjD,SAAS;+BACE,mCAAmC,UACrC,yCAAyC,iBAGlC,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,QACzC;wBACJ,oCAAoC,EAAE,MAAM;qBAC7C,cACW;wBACV,OAAO,CAAC,WAAW,EAAE;4BACnB,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;4BAC5C,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;4BACxC,UAAU,CAAC,YAAY,EAAE,OAAO,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;yBAC/D,CAAC;qBACH;;0BA2BE,MAAM;2BAAC,UAAU,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, Inject, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\nimport { AnimationDurations } from '@angular/material/core';\nimport { BehaviorSubject, Subscription } from 'rxjs';\n\nimport { OColumnValueFilter } from '../../../../../types/table/o-column-value-filter.type';\nimport { Util } from '../../../../../util/util';\nimport type { OColumn } from '../../../column';\nimport { OTableBase } from '../../../o-table-base.class';\nimport { MatDialog } from '@angular/material/dialog';\nimport { DialogService } from '../../../../../services/dialog.service';\nimport { OTranslateService } from '../../../../../services/translate/o-translate.service';\n\nexport const DEFAULT_INPUTS_O_TABLE_COLUMN_FILTER_ICON = [\n  'column',\n  // columnFilters: Active filters applied to table columns\n  'columnFilters: column-filters'\n];\n\nexport declare type STATEVIEW = 'HINT' | 'ACTIVE' | 'INACTIVE';\n\n@Component({\n  selector: 'o-table-header-column-filter-icon',\n  inputs: DEFAULT_INPUTS_O_TABLE_COLUMN_FILTER_ICON,\n  templateUrl: './o-table-header-column-filter-icon.component.html',\n  styleUrls: ['./o-table-header-column-filter-icon.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    '[class.o-table-column-filter-icon]': 'true'\n  },\n  animations: [\n    trigger('iconState', [\n      state('ACTIVE, HINT', style({ opacity: 1 })),\n      state('INACTIVE', style({ opacity: 0 })),\n      transition('* <=> HINT', animate(AnimationDurations.ENTERING))\n    ]),\n  ]\n})\nexport class OTableHeaderColumnFilterIconComponent implements OnInit, OnDestroy {\n\n  public column: OColumn;\n\n  /**\n   * Array of active column filters from the table\n   * Updated by parent component when filters change\n   */\n  set columnFilters(filters: OColumnValueFilter[]) {\n    this._columnFilters = filters?.filter(value=>value.values) || [];\n    this.updateStateColumnFilter();\n  }\n  get columnFilters(): OColumnValueFilter[] {\n    return this._columnFilters;\n  }\n\n  private _columnFilters: OColumnValueFilter[] = [];\n\n  public isColumnFilterActive: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  public filterIconHintVisible: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  public indicatorNumber: BehaviorSubject<string> = new BehaviorSubject('');\n  private subscription = new Subscription();\n  public filterIconStateView: BehaviorSubject<STATEVIEW> = new BehaviorSubject<STATEVIEW>('INACTIVE');\n\n  constructor(\n    @Inject(forwardRef(() => OTableBase)) public table: OTableBase,\n    protected dialog: MatDialog,\n    protected dialogService: DialogService,\n    protected translateService: OTranslateService,\n    protected cd: ChangeDetectorRef\n  ) {\n    this.subscription.add(\n      this.filterIconHintVisible.subscribe((value) => {\n        this.setFilterIconHintVisible(value);\n      })\n    );\n  }\n\n  ngOnInit(): void {\n    this.updateStateColumnFilter();\n  }\n\n  /**\n   * Update state colum filter\n   */\n  public updateStateColumnFilter(): void {\n    this.updateFilterIndicatorNumber();\n\n    const isActive = Util.isDefined(this.getColumnValueFilterByAttr()?.values);\n    this.isColumnFilterActive.next(isActive);\n    this.filterIconStateView.next(isActive ? 'ACTIVE' : 'INACTIVE');\n    this.cd.markForCheck();\n  }\n\n  /**\n   * Update only indicator number about filter icon\n   */\n  private updateFilterIndicatorNumber(): void {\n    this.indicatorNumber.next(this.getFilterIndicatorNumbered());\n  }\n\n  /**\n   * Get the filter for this column from the array of filters\n   */\n  protected getColumnValueFilterByAttr(): OColumnValueFilter {\n    return this._columnFilters?.find(item => item.attr === this.column.attr);\n  }\n\n\n  public openColumnFilterDialog(event: Event): void {\n    const filterByColumnComponent = this.table.oTableColumnsFilterComponent?.getFilterColumnByAttr(this.column.attr);\n\n    if (filterByColumnComponent?.filterLocked) {\n      this.dialogService.alert(\n        this.translateService.get('TABLE.FILTER_LOCKED'),\n        this.translateService.get(filterByColumnComponent.filterLockedMessage)\n      );\n    } else {\n      this.table.openColumnFilterDialog(this.column, event);\n    }\n  }\n\n  /**\n   * Gets the filter indicator number (position in the active filters list)\n   */\n  public getFilterIndicatorNumbered(): string {\n    const filters = this._columnFilters ?? [];\n    const index = filters.length > 1\n      ? filters.findIndex(f => f.attr === this.column.attr)\n      : -1;\n\n    return index >= 0 ? `${index + 1}` : '';\n  }\n\n  /**\n   * Sets the \"hint\" state such that the icon will be semi-transparently displayed as a hint to the\n   * user showing what the active filter by column will become. If set to false, the icon will fade away.\n   */\n  setFilterIconHintVisible(visible: boolean): void {\n    // No-op if the filter is ACTIVE - should not make the hint visible.\n    if (this.filterIconStateView.getValue() === 'ACTIVE') {\n      return;\n    }\n    this.filterIconStateView.next(visible ? 'HINT' : 'INACTIVE');\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n}","<mat-icon class=\"column-filter-icon\" [ngClass]=\"{'column-filter-icon-active':isColumnFilterActive | async}\"\n  (click)=\"openColumnFilterDialog($event)\" [@iconState]=\"filterIconStateView | async\">\n  filter_alt\n</mat-icon>\n<span class=\"o-table-header-indicator-numbered\">\n  {{ indicatorNumber | async }}\n</span>"]}
@@ -36,7 +36,7 @@ export class OTableHeaderSelectAllComponent extends OTableHeaderComponent {
36
36
  }
37
37
  }
38
38
  OTableHeaderSelectAllComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OTableHeaderSelectAllComponent, deps: [{ token: forwardRef(() => OTableBase) }], target: i0.ɵɵFactoryTarget.Component });
39
- OTableHeaderSelectAllComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: OTableHeaderSelectAllComponent, selector: "o-table-header-select-all", inputs: { column: "column" }, host: { properties: { "class.o-table-header-select-all": "true" } }, usesInheritance: true, ngImport: i0, template: "<mat-checkbox (click)=\"$event.stopPropagation()\" (change)=\"table.masterToggle($event)\" [checked]=\"isAllSelected | async\" [indeterminate]=\"isIndeterminate | async\">\n <ng-container *ngIf=\"table.tableColumnSelectAllContentChild?.title\">\n {{table.tableColumnSelectAllContentChild?.title | oTranslate}}\n </ng-container>\n</mat-checkbox>\n\n<o-table-column-resizer *ngIf=\"resizable && table.tableColumnSelectAllContentChild?.title\" [column]=\"column\"></o-table-column-resizer>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i3.OTableColumnResizerComponent, selector: "o-table-column-resizer", inputs: ["column"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.OTranslatePipe, name: "oTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
39
+ OTableHeaderSelectAllComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: OTableHeaderSelectAllComponent, selector: "o-table-header-select-all", inputs: { column: "column", columnFilters: ["column-filters", "columnFilters"] }, host: { properties: { "class.o-table-header-select-all": "true" } }, usesInheritance: true, ngImport: i0, template: "<mat-checkbox (click)=\"$event.stopPropagation()\" (change)=\"table.masterToggle($event)\" [checked]=\"isAllSelected | async\" [indeterminate]=\"isIndeterminate | async\">\n <ng-container *ngIf=\"table.tableColumnSelectAllContentChild?.title\">\n {{table.tableColumnSelectAllContentChild?.title | oTranslate}}\n </ng-container>\n</mat-checkbox>\n\n<o-table-column-resizer *ngIf=\"resizable && table.tableColumnSelectAllContentChild?.title\" [column]=\"column\"></o-table-column-resizer>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i3.OTableColumnResizerComponent, selector: "o-table-column-resizer", inputs: ["column"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.OTranslatePipe, name: "oTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
40
40
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OTableHeaderSelectAllComponent, decorators: [{
41
41
  type: Component,
42
42
  args: [{ selector: 'o-table-header-select-all', inputs: DEFAULT_INPUTS_O_TABLE_HEADER, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: {
@@ -46,4 +46,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
46
46
  type: Inject,
47
47
  args: [forwardRef(() => OTableBase)]
48
48
  }] }]; } });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiby10YWJsZS1oZWFkZXItc2VsZWN0LWFsbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vbnRpbWl6ZS13ZWItbmd4L3NyYy9saWIvY29tcG9uZW50cy90YWJsZS9leHRlbnNpb25zL2hlYWRlci90YWJsZS1oZWFkZXItc2VsZWN0LWFsbC9vLXRhYmxlLWhlYWRlci1zZWxlY3QtYWxsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29udGltaXplLXdlYi1uZ3gvc3JjL2xpYi9jb21wb25lbnRzL3RhYmxlL2V4dGVuc2lvbnMvaGVhZGVyL3RhYmxlLWhlYWRlci1zZWxlY3QtYWxsL28tdGFibGUtaGVhZGVyLXNlbGVjdC1hbGwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQix1QkFBdUIsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6SCxPQUFPLEVBQUUsNkJBQTZCLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUNoSCxPQUFPLEVBQUUsZUFBZSxFQUFFLEtBQUssRUFBZ0IsTUFBTSxNQUFNLENBQUM7QUFFNUQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDZCQUE2QixDQUFDOzs7Ozs7O0FBWXpELE1BQU0sT0FBTyw4QkFBK0IsU0FBUSxxQkFBcUI7SUFRdkUsWUFDK0MsS0FBaUI7UUFFOUQsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRmdDLFVBQUssR0FBTCxLQUFLLENBQVk7UUFMekQsa0JBQWEsR0FBRyxJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNwRCxvQkFBZSxHQUFHLElBQUksZUFBZSxDQUFVLEtBQUssQ0FBQyxDQUFDO0lBTzdELENBQUM7SUFFTSxlQUFlO1FBQ3BCLE1BQU0sV0FBVyxHQUFVO1lBQ3pCLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLE9BQU87U0FDN0IsQ0FBQztRQUVGLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLEVBQUU7WUFDM0IsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUNoRDtRQUNELElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxFQUFFLENBQUMsQ0FBQztRQUNwRCxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDLENBQUM7UUFFeEQsSUFBSSxDQUFDLDJCQUEyQixHQUFHLEtBQUssQ0FBQyxHQUFHLFdBQVcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUNyRSxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUM7WUFDcEQsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQyxDQUFDO1FBQzFELENBQUMsQ0FBQyxDQUFBO0lBRUosQ0FBQztJQUNELFdBQVc7UUFHVCxJQUFJLElBQUksQ0FBQywyQkFBMkIsRUFBRTtZQUNwQyxJQUFJLENBQUMsMkJBQTJCLENBQUMsV0FBVyxFQUFFLENBQUM7U0FDaEQ7SUFDSCxDQUFDOzs0SEFyQ1UsOEJBQThCLGtCQVMvQixVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsVUFBVSxDQUFDO2dIQVQzQiw4QkFBOEIsMkxDaEIzQywrZUFPQTs0RkRTYSw4QkFBOEI7a0JBVjFDLFNBQVM7K0JBQ0UsMkJBQTJCLFVBQzdCLDZCQUE2QixpQkFFdEIsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSxRQUN6Qzt3QkFDSixtQ0FBbUMsRUFBRSxNQUFNO3FCQUM1Qzs7MEJBV0UsTUFBTTsyQkFBQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgZm9yd2FyZFJlZiwgSW5qZWN0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBERUZBVUxUX0lOUFVUU19PX1RBQkxFX0hFQURFUiwgT1RhYmxlSGVhZGVyQ29tcG9uZW50IH0gZnJvbSBcIi4uL3RhYmxlLWhlYWRlci9vLXRhYmxlLWhlYWRlci5jb21wb25lbnRcIjtcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgbWVyZ2UsIFN1YnNjcmlwdGlvbiB9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQgdHlwZSB7IE9Db2x1bW4gfSBmcm9tIFwiLi4vLi4vLi4vY29sdW1uL28tY29sdW1uLmNsYXNzXCI7XG5pbXBvcnQgeyBPVGFibGVCYXNlIH0gZnJvbSBcIi4uLy4uLy4uL28tdGFibGUtYmFzZS5jbGFzc1wiO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdvLXRhYmxlLWhlYWRlci1zZWxlY3QtYWxsJyxcbiAgaW5wdXRzOiBERUZBVUxUX0lOUFVUU19PX1RBQkxFX0hFQURFUixcbiAgdGVtcGxhdGVVcmw6ICcuL28tdGFibGUtaGVhZGVyLXNlbGVjdC1hbGwuY29tcG9uZW50Lmh0bWwnLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaG9zdDoge1xuICAgICdbY2xhc3Muby10YWJsZS1oZWFkZXItc2VsZWN0LWFsbF0nOiAndHJ1ZSdcbiAgfVxufSlcbmV4cG9ydCBjbGFzcyBPVGFibGVIZWFkZXJTZWxlY3RBbGxDb21wb25lbnQgZXh0ZW5kcyBPVGFibGVIZWFkZXJDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcblxuICBwdWJsaWMgY29sdW1uOiBPQ29sdW1uO1xuICBwdWJsaWMgcmVzaXphYmxlOiBib29sZWFuO1xuICBwdWJsaWMgaXNBbGxTZWxlY3RlZCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpO1xuICBwdWJsaWMgaXNJbmRldGVybWluYXRlID0gbmV3IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPihmYWxzZSk7XG4gIHB1YmxpYyBzZWxlY3Rpb25DaGFuZ2VTdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBASW5qZWN0KGZvcndhcmRSZWYoKCkgPT4gT1RhYmxlQmFzZSkpIHB1YmxpYyB0YWJsZTogT1RhYmxlQmFzZVxuICApIHtcbiAgICBzdXBlcih0YWJsZSk7XG4gIH1cblxuICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIGNvbnN0IGRhdGFDaGFuZ2VzOiBhbnlbXSA9IFtcbiAgICAgIHRoaXMudGFibGUuc2VsZWN0aW9uLmNoYW5nZWRcbiAgICBdO1xuXG4gICAgaWYgKHRoaXMudGFibGUubWF0cGFnaW5hdG9yKSB7XG4gICAgICBkYXRhQ2hhbmdlcy5wdXNoKHRoaXMudGFibGUubWF0cGFnaW5hdG9yLnBhZ2UpO1xuICAgIH1cbiAgICB0aGlzLmlzQWxsU2VsZWN0ZWQubmV4dCh0aGlzLnRhYmxlLmlzQWxsU2VsZWN0ZWQoKSk7XG4gICAgdGhpcy5pc0luZGV0ZXJtaW5hdGUubmV4dCh0aGlzLnRhYmxlLmlzSW5kZXRlcm1pbmF0ZSgpKTtcblxuICAgIHRoaXMuc2VsZWN0aW9uQ2hhbmdlU3Vic2NyaXB0aW9uID0gbWVyZ2UoLi4uZGF0YUNoYW5nZXMpLnN1YnNjcmliZSh4ID0+IHtcbiAgICAgIHRoaXMuaXNBbGxTZWxlY3RlZC5uZXh0KHRoaXMudGFibGUuaXNBbGxTZWxlY3RlZCgpKTtcbiAgICAgIHRoaXMuaXNJbmRldGVybWluYXRlLm5leHQodGhpcy50YWJsZS5pc0luZGV0ZXJtaW5hdGUoKSk7XG4gICAgfSlcblxuICB9XG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIC8vQ2FsbGVkIG9uY2UsIGJlZm9yZSB0aGUgaW5zdGFuY2UgaXMgZGVzdHJveWVkLlxuICAgIC8vQWRkICdpbXBsZW1lbnRzIE9uRGVzdHJveScgdG8gdGhlIGNsYXNzLlxuICAgIGlmICh0aGlzLnNlbGVjdGlvbkNoYW5nZVN1YnNjcmlwdGlvbikge1xuICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2VTdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcbiAgICB9XG4gIH1cblxufSIsIjxtYXQtY2hlY2tib3ggKGNsaWNrKT1cIiRldmVudC5zdG9wUHJvcGFnYXRpb24oKVwiIChjaGFuZ2UpPVwidGFibGUubWFzdGVyVG9nZ2xlKCRldmVudClcIiBbY2hlY2tlZF09XCJpc0FsbFNlbGVjdGVkIHwgYXN5bmNcIiBbaW5kZXRlcm1pbmF0ZV09XCJpc0luZGV0ZXJtaW5hdGUgfCBhc3luY1wiPlxuICA8bmctY29udGFpbmVyICpuZ0lmPVwidGFibGUudGFibGVDb2x1bW5TZWxlY3RBbGxDb250ZW50Q2hpbGQ/LnRpdGxlXCI+XG4gICAge3t0YWJsZS50YWJsZUNvbHVtblNlbGVjdEFsbENvbnRlbnRDaGlsZD8udGl0bGUgfCBvVHJhbnNsYXRlfX1cbiAgPC9uZy1jb250YWluZXI+XG48L21hdC1jaGVja2JveD5cblxuPG8tdGFibGUtY29sdW1uLXJlc2l6ZXIgKm5nSWY9XCJyZXNpemFibGUgJiYgdGFibGUudGFibGVDb2x1bW5TZWxlY3RBbGxDb250ZW50Q2hpbGQ/LnRpdGxlXCIgW2NvbHVtbl09XCJjb2x1bW5cIj48L28tdGFibGUtY29sdW1uLXJlc2l6ZXI+XG4iXX0=
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiby10YWJsZS1oZWFkZXItc2VsZWN0LWFsbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vbnRpbWl6ZS13ZWItbmd4L3NyYy9saWIvY29tcG9uZW50cy90YWJsZS9leHRlbnNpb25zL2hlYWRlci90YWJsZS1oZWFkZXItc2VsZWN0LWFsbC9vLXRhYmxlLWhlYWRlci1zZWxlY3QtYWxsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29udGltaXplLXdlYi1uZ3gvc3JjL2xpYi9jb21wb25lbnRzL3RhYmxlL2V4dGVuc2lvbnMvaGVhZGVyL3RhYmxlLWhlYWRlci1zZWxlY3QtYWxsL28tdGFibGUtaGVhZGVyLXNlbGVjdC1hbGwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQix1QkFBdUIsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6SCxPQUFPLEVBQUUsNkJBQTZCLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUNoSCxPQUFPLEVBQUUsZUFBZSxFQUFFLEtBQUssRUFBZ0IsTUFBTSxNQUFNLENBQUM7QUFFNUQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDZCQUE2QixDQUFDOzs7Ozs7O0FBWXpELE1BQU0sT0FBTyw4QkFBK0IsU0FBUSxxQkFBcUI7SUFRdkUsWUFDK0MsS0FBaUI7UUFFOUQsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRmdDLFVBQUssR0FBTCxLQUFLLENBQVk7UUFMekQsa0JBQWEsR0FBRyxJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNwRCxvQkFBZSxHQUFHLElBQUksZUFBZSxDQUFVLEtBQUssQ0FBQyxDQUFDO0lBTzdELENBQUM7SUFFTSxlQUFlO1FBQ3BCLE1BQU0sV0FBVyxHQUFVO1lBQ3pCLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLE9BQU87U0FDN0IsQ0FBQztRQUVGLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLEVBQUU7WUFDM0IsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUNoRDtRQUNELElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxFQUFFLENBQUMsQ0FBQztRQUNwRCxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDLENBQUM7UUFFeEQsSUFBSSxDQUFDLDJCQUEyQixHQUFHLEtBQUssQ0FBQyxHQUFHLFdBQVcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUNyRSxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUM7WUFDcEQsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQyxDQUFDO1FBQzFELENBQUMsQ0FBQyxDQUFBO0lBRUosQ0FBQztJQUNELFdBQVc7UUFHVCxJQUFJLElBQUksQ0FBQywyQkFBMkIsRUFBRTtZQUNwQyxJQUFJLENBQUMsMkJBQTJCLENBQUMsV0FBVyxFQUFFLENBQUM7U0FDaEQ7SUFDSCxDQUFDOzs0SEFyQ1UsOEJBQThCLGtCQVMvQixVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsVUFBVSxDQUFDO2dIQVQzQiw4QkFBOEIsK09DaEIzQywrZUFPQTs0RkRTYSw4QkFBOEI7a0JBVjFDLFNBQVM7K0JBQ0UsMkJBQTJCLFVBQzdCLDZCQUE2QixpQkFFdEIsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSxRQUN6Qzt3QkFDSixtQ0FBbUMsRUFBRSxNQUFNO3FCQUM1Qzs7MEJBV0UsTUFBTTsyQkFBQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgZm9yd2FyZFJlZiwgSW5qZWN0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBERUZBVUxUX0lOUFVUU19PX1RBQkxFX0hFQURFUiwgT1RhYmxlSGVhZGVyQ29tcG9uZW50IH0gZnJvbSBcIi4uL3RhYmxlLWhlYWRlci9vLXRhYmxlLWhlYWRlci5jb21wb25lbnRcIjtcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgbWVyZ2UsIFN1YnNjcmlwdGlvbiB9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQgdHlwZSB7IE9Db2x1bW4gfSBmcm9tIFwiLi4vLi4vLi4vY29sdW1uL28tY29sdW1uLmNsYXNzXCI7XG5pbXBvcnQgeyBPVGFibGVCYXNlIH0gZnJvbSBcIi4uLy4uLy4uL28tdGFibGUtYmFzZS5jbGFzc1wiO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdvLXRhYmxlLWhlYWRlci1zZWxlY3QtYWxsJyxcbiAgaW5wdXRzOiBERUZBVUxUX0lOUFVUU19PX1RBQkxFX0hFQURFUixcbiAgdGVtcGxhdGVVcmw6ICcuL28tdGFibGUtaGVhZGVyLXNlbGVjdC1hbGwuY29tcG9uZW50Lmh0bWwnLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaG9zdDoge1xuICAgICdbY2xhc3Muby10YWJsZS1oZWFkZXItc2VsZWN0LWFsbF0nOiAndHJ1ZSdcbiAgfVxufSlcbmV4cG9ydCBjbGFzcyBPVGFibGVIZWFkZXJTZWxlY3RBbGxDb21wb25lbnQgZXh0ZW5kcyBPVGFibGVIZWFkZXJDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcblxuICBwdWJsaWMgY29sdW1uOiBPQ29sdW1uO1xuICBwdWJsaWMgcmVzaXphYmxlOiBib29sZWFuO1xuICBwdWJsaWMgaXNBbGxTZWxlY3RlZCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpO1xuICBwdWJsaWMgaXNJbmRldGVybWluYXRlID0gbmV3IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPihmYWxzZSk7XG4gIHB1YmxpYyBzZWxlY3Rpb25DaGFuZ2VTdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBASW5qZWN0KGZvcndhcmRSZWYoKCkgPT4gT1RhYmxlQmFzZSkpIHB1YmxpYyB0YWJsZTogT1RhYmxlQmFzZVxuICApIHtcbiAgICBzdXBlcih0YWJsZSk7XG4gIH1cblxuICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIGNvbnN0IGRhdGFDaGFuZ2VzOiBhbnlbXSA9IFtcbiAgICAgIHRoaXMudGFibGUuc2VsZWN0aW9uLmNoYW5nZWRcbiAgICBdO1xuXG4gICAgaWYgKHRoaXMudGFibGUubWF0cGFnaW5hdG9yKSB7XG4gICAgICBkYXRhQ2hhbmdlcy5wdXNoKHRoaXMudGFibGUubWF0cGFnaW5hdG9yLnBhZ2UpO1xuICAgIH1cbiAgICB0aGlzLmlzQWxsU2VsZWN0ZWQubmV4dCh0aGlzLnRhYmxlLmlzQWxsU2VsZWN0ZWQoKSk7XG4gICAgdGhpcy5pc0luZGV0ZXJtaW5hdGUubmV4dCh0aGlzLnRhYmxlLmlzSW5kZXRlcm1pbmF0ZSgpKTtcblxuICAgIHRoaXMuc2VsZWN0aW9uQ2hhbmdlU3Vic2NyaXB0aW9uID0gbWVyZ2UoLi4uZGF0YUNoYW5nZXMpLnN1YnNjcmliZSh4ID0+IHtcbiAgICAgIHRoaXMuaXNBbGxTZWxlY3RlZC5uZXh0KHRoaXMudGFibGUuaXNBbGxTZWxlY3RlZCgpKTtcbiAgICAgIHRoaXMuaXNJbmRldGVybWluYXRlLm5leHQodGhpcy50YWJsZS5pc0luZGV0ZXJtaW5hdGUoKSk7XG4gICAgfSlcblxuICB9XG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIC8vQ2FsbGVkIG9uY2UsIGJlZm9yZSB0aGUgaW5zdGFuY2UgaXMgZGVzdHJveWVkLlxuICAgIC8vQWRkICdpbXBsZW1lbnRzIE9uRGVzdHJveScgdG8gdGhlIGNsYXNzLlxuICAgIGlmICh0aGlzLnNlbGVjdGlvbkNoYW5nZVN1YnNjcmlwdGlvbikge1xuICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2VTdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcbiAgICB9XG4gIH1cblxufSIsIjxtYXQtY2hlY2tib3ggKGNsaWNrKT1cIiRldmVudC5zdG9wUHJvcGFnYXRpb24oKVwiIChjaGFuZ2UpPVwidGFibGUubWFzdGVyVG9nZ2xlKCRldmVudClcIiBbY2hlY2tlZF09XCJpc0FsbFNlbGVjdGVkIHwgYXN5bmNcIiBbaW5kZXRlcm1pbmF0ZV09XCJpc0luZGV0ZXJtaW5hdGUgfCBhc3luY1wiPlxuICA8bmctY29udGFpbmVyICpuZ0lmPVwidGFibGUudGFibGVDb2x1bW5TZWxlY3RBbGxDb250ZW50Q2hpbGQ/LnRpdGxlXCI+XG4gICAge3t0YWJsZS50YWJsZUNvbHVtblNlbGVjdEFsbENvbnRlbnRDaGlsZD8udGl0bGUgfCBvVHJhbnNsYXRlfX1cbiAgPC9uZy1jb250YWluZXI+XG48L21hdC1jaGVja2JveD5cblxuPG8tdGFibGUtY29sdW1uLXJlc2l6ZXIgKm5nSWY9XCJyZXNpemFibGUgJiYgdGFibGUudGFibGVDb2x1bW5TZWxlY3RBbGxDb250ZW50Q2hpbGQ/LnRpdGxlXCIgW2NvbHVtbl09XCJjb2x1bW5cIj48L28tdGFibGUtY29sdW1uLXJlc2l6ZXI+XG4iXX0=
@@ -9,6 +9,7 @@ export class OTableVirtualScrollStrategy {
9
9
  this.stickyChange = new Subject();
10
10
  this.bufferMultiplier = 1;
11
11
  this.lastRenderedRange = { start: 0, end: 0 };
12
+ this.savedScrollPosition = 0;
12
13
  this._dataLength = 0;
13
14
  }
14
15
  get dataLength() {
@@ -16,7 +17,10 @@ export class OTableVirtualScrollStrategy {
16
17
  }
17
18
  set dataLength(value) {
18
19
  this._dataLength = value;
19
- this.onDataLengthChanged();
20
+ if (this.savedScrollPosition === 0) {
21
+ this.onDataLengthChanged();
22
+ }
23
+ this.savedScrollPosition = 0;
20
24
  }
21
25
  attach(viewport) {
22
26
  this.viewport = viewport;
@@ -38,6 +42,9 @@ export class OTableVirtualScrollStrategy {
38
42
  onContentScrolled() {
39
43
  this.updateContent();
40
44
  }
45
+ setSavedScrollPosition(value) {
46
+ this.savedScrollPosition = value;
47
+ }
41
48
  setConfig(rowHeight, headerHeight, footerHeight) {
42
49
  if (this.rowHeight === rowHeight
43
50
  && this.headerHeight === headerHeight
@@ -89,4 +96,4 @@ OTableVirtualScrollStrategy.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "1
89
96
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OTableVirtualScrollStrategy, decorators: [{
90
97
  type: Injectable
91
98
  }] });
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-table-strategy.service.js","sourceRoot":"","sources":["../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/o-table-strategy.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkVirtualScrollViewport, VirtualScrollStrategy } from \"@angular/cdk/scrolling\";\nimport { Injectable } from \"@angular/core\";\nimport { Observable, Subject } from \"rxjs\";\nimport { distinctUntilChanged } from \"rxjs/operators\";\n\n@Injectable()\nexport class OTableVirtualScrollStrategy implements VirtualScrollStrategy {\n  private viewport: CdkVirtualScrollViewport;\n\n  private rowHeight!: number;\n  private headerHeight!: number;\n  private footerHeight!: number;\n  private readonly indexChange = new Subject<number>();\n  public scrolledIndexChange: Observable<number> = this.indexChange.pipe(distinctUntilChanged());\n  public readonly stickyChange = new Subject<number>();\n  private readonly bufferMultiplier: number = 1;\n  private lastRenderedRange = { start: 0, end: 0 };\n\n  get dataLength(): number {\n    return this._dataLength;\n  }\n\n  set dataLength(value: number) {\n    this._dataLength = value;\n    this.onDataLengthChanged();\n  }\n\n  private _dataLength = 0;\n\n  public attach(viewport: CdkVirtualScrollViewport): void {\n    this.viewport = viewport;\n    this.onDataLengthChanged();\n    this.updateContent();\n  }\n\n  public detach(): void {\n    //no-op\n  }\n\n  public destroy(): void {\n    this.indexChange.complete();\n    this.stickyChange.complete();\n  }\n\n  public onContentRendered(): void {\n    // no-op\n  }\n\n  public onRenderedOffsetChanged(): void {\n    // no-op\n  }\n\n  public scrollToIndex(index: number, behavior?: ScrollBehavior): void {\n    // no-op\n  }\n\n  public onContentScrolled(): void {\n    this.updateContent();\n  }\n\n  public setConfig(rowHeight: number, headerHeight: number, footerHeight: number) {\n\n    if (\n      this.rowHeight === rowHeight\n      && this.headerHeight === headerHeight\n      && this.footerHeight === footerHeight\n    ) {\n      return;\n    }\n    this.rowHeight = rowHeight;\n    this.headerHeight = headerHeight;\n    this.footerHeight = footerHeight;\n    //if change heights, then update content size\n    this.onDataLengthChanged();\n  }\n\n  public onDataLengthChanged(): void {\n    if (this.viewport) {\n      this.viewport.setTotalContentSize(this.dataLength * this.rowHeight + this.headerHeight + this.footerHeight);\n      this.viewport.scrollToOffset(0);//set scroll up\n      this.updateContent();\n    }\n  }\n\n  private updateContent() {\n    if (!this.viewport || !this.rowHeight || this.dataLength === 0) {\n      return;\n    }\n    const scrollOffset = this.viewport.measureScrollOffset();\n    const itemsDisplayed = Math.ceil(this.viewport.getViewportSize() / this.rowHeight);\n    const renderedOffset = this.viewport.getOffsetToRenderedContentStart();\n    const start = renderedOffset / this.rowHeight;\n    const bufferItems = Math.ceil(itemsDisplayed * this.bufferMultiplier);\n    const bufferOffset = renderedOffset + bufferItems * this.rowHeight;\n\n    const relativeScrollOffset = scrollOffset - bufferOffset;// How far the scroll offset is from the lower buffer, which is usually where items start being displayed\n    const rowsScrolled = relativeScrollOffset / this.rowHeight;\n\n    const displayed = scrollOffset / this.rowHeight;\n    this.indexChange.next(displayed);\n\n    const rowsToMove = Math.sign(rowsScrolled) * Math.floor(Math.abs(rowsScrolled));\n    const adjustedRenderedOffset = Math.max(0, renderedOffset + rowsToMove * this.rowHeight);\n    this.viewport.setRenderedContentOffset(adjustedRenderedOffset);\n\n    const adjustedStart = Math.max(0, start + rowsToMove);\n    const adjustedEnd = adjustedStart + itemsDisplayed + bufferItems;\n\n    if (\n      this.lastRenderedRange.start === adjustedStart &&\n      this.lastRenderedRange.end === adjustedEnd\n    ) {\n      return;// No change in rendered range\n    }\n    this.lastRenderedRange = { start: adjustedStart, end: adjustedEnd };\n\n    this.viewport.setRenderedRange({ start: adjustedStart, end: adjustedEnd });\n    this.stickyChange.next(adjustedRenderedOffset);\n  }\n}"]}
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-table-strategy.service.js","sourceRoot":"","sources":["../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/o-table-strategy.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkVirtualScrollViewport, VirtualScrollStrategy } from \"@angular/cdk/scrolling\";\nimport { Injectable } from \"@angular/core\";\nimport { Observable, Subject } from \"rxjs\";\nimport { distinctUntilChanged } from \"rxjs/operators\";\n\n@Injectable()\nexport class OTableVirtualScrollStrategy implements VirtualScrollStrategy {\n  private viewport: CdkVirtualScrollViewport;\n\n  private rowHeight!: number;\n  private headerHeight!: number;\n  private footerHeight!: number;\n  private readonly indexChange = new Subject<number>();\n  public scrolledIndexChange: Observable<number> = this.indexChange.pipe(distinctUntilChanged());\n  public readonly stickyChange = new Subject<number>();\n  private readonly bufferMultiplier: number = 1;\n  private lastRenderedRange = { start: 0, end: 0 };\n  private savedScrollPosition = 0;\n\n  get dataLength(): number {\n    return this._dataLength;\n  }\n\n  set dataLength(value: number) {\n    this._dataLength = value;\n    if (this.savedScrollPosition === 0) {\n      this.onDataLengthChanged();\n    }\n    this.savedScrollPosition = 0;\n  }\n\n  private _dataLength = 0;\n\n  public attach(viewport: CdkVirtualScrollViewport): void {\n    this.viewport = viewport;\n    this.onDataLengthChanged();\n    this.updateContent();\n  }\n\n  public detach(): void {\n    //no-op\n  }\n\n  public destroy(): void {\n    this.indexChange.complete();\n    this.stickyChange.complete();\n  }\n\n  public onContentRendered(): void {\n    // no-op\n  }\n\n  public onRenderedOffsetChanged(): void {\n    // no-op\n  }\n\n  public scrollToIndex(index: number, behavior?: ScrollBehavior): void {\n    // no-op\n  }\n\n  public onContentScrolled(): void {\n    this.updateContent();\n  }\n\n  /**\n   * Sets the saved scroll position for the table.\n   * @param value - The scroll position value to be saved\n   */\n  public setSavedScrollPosition(value: number) {\n    this.savedScrollPosition = value;\n  }\n\n  public setConfig(rowHeight: number, headerHeight: number, footerHeight: number) {\n\n    if (\n      this.rowHeight === rowHeight\n      && this.headerHeight === headerHeight\n      && this.footerHeight === footerHeight\n    ) {\n      return;\n    }\n    this.rowHeight = rowHeight;\n    this.headerHeight = headerHeight;\n    this.footerHeight = footerHeight;\n    //if change heights, then update content size\n    this.onDataLengthChanged();\n  }\n\n  public onDataLengthChanged(): void {\n    if (this.viewport) {\n      this.viewport.setTotalContentSize(this.dataLength * this.rowHeight + this.headerHeight + this.footerHeight);\n      this.viewport.scrollToOffset(0);//set scroll up\n      this.updateContent();\n    }\n  }\n\n  private updateContent() {\n    if (!this.viewport || !this.rowHeight || this.dataLength === 0) {\n      return;\n    }\n    const scrollOffset = this.viewport.measureScrollOffset();\n    const itemsDisplayed = Math.ceil(this.viewport.getViewportSize() / this.rowHeight);\n    const renderedOffset = this.viewport.getOffsetToRenderedContentStart();\n    const start = renderedOffset / this.rowHeight;\n    const bufferItems = Math.ceil(itemsDisplayed * this.bufferMultiplier);\n    const bufferOffset = renderedOffset + bufferItems * this.rowHeight;\n\n    const relativeScrollOffset = scrollOffset - bufferOffset;// How far the scroll offset is from the lower buffer, which is usually where items start being displayed\n    const rowsScrolled = relativeScrollOffset / this.rowHeight;\n\n    const displayed = scrollOffset / this.rowHeight;\n    this.indexChange.next(displayed);\n\n    const rowsToMove = Math.sign(rowsScrolled) * Math.floor(Math.abs(rowsScrolled));\n    const adjustedRenderedOffset = Math.max(0, renderedOffset + rowsToMove * this.rowHeight);\n    this.viewport.setRenderedContentOffset(adjustedRenderedOffset);\n\n    const adjustedStart = Math.max(0, start + rowsToMove);\n    const adjustedEnd = adjustedStart + itemsDisplayed + bufferItems;\n\n    if (\n      this.lastRenderedRange.start === adjustedStart &&\n      this.lastRenderedRange.end === adjustedEnd\n    ) {\n      return;// No change in rendered range\n    }\n    this.lastRenderedRange = { start: adjustedStart, end: adjustedEnd };\n\n    this.viewport.setRenderedRange({ start: adjustedStart, end: adjustedEnd });\n    this.stickyChange.next(adjustedRenderedOffset);\n  }\n}"]}