ontimize-web-ngx 15.8.1 → 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.
@@ -93,19 +93,47 @@ export class OTableVisibleColumnsDialogComponent {
93
93
  const newGroupColumns = columnGroupingToRemove.length > 0 ?
94
94
  this.table.groupedColumnsArray.filter(col => !columnGroupingToRemove.includes(col)) :
95
95
  undefined;
96
+ const columnsOrder = this.getColumnsOrder();
96
97
  this.dialogRef.close({
97
- visibleColArray: this.getVisibleColumns(),
98
- columnsOrder: this.getColumnsOrder(),
98
+ visibleColArray: this.getVisibleColumns().sort((a, b) => columnsOrder.indexOf(a) - columnsOrder.indexOf(b)),
99
+ columnsOrder: columnsOrder,
99
100
  sortColumns: newSortColumns,
100
101
  columnValueFiltersToRemove: this.getColumnValueFiltersToRemove(),
101
102
  groupColumns: newGroupColumns
102
103
  });
103
104
  }
104
105
  getVisibleColumns() {
105
- return this.columns.filter(col => col.visible).map(col => col.attr);
106
+ const nonHidableColumns = Util.parseArray(this.table.nonHidableColumns, true);
107
+ const visibleFromDialog = this.columns
108
+ .filter(col => col.visible)
109
+ .map(col => col.attr);
110
+ const allVisibleAttrs = new Set([...visibleFromDialog, ...nonHidableColumns]);
111
+ return this.table.oTableOptions.columns
112
+ .filter(oCol => allVisibleAttrs.has(oCol.attr))
113
+ .map(oCol => oCol.attr);
106
114
  }
107
115
  getColumnsOrder() {
108
- return this.columns.map(col => col.attr);
116
+ const originalOrder = this.table.oTableOptions.columns.map(col => col.attr);
117
+ const dialogColumnsOrder = this.columns.map(col => col.attr);
118
+ const columnsNotInDialog = originalOrder.filter(attr => !dialogColumnsOrder.includes(attr));
119
+ const newOrder = [];
120
+ for (const dialogAttr of dialogColumnsOrder) {
121
+ const dialogOriginalPos = originalOrder.indexOf(dialogAttr);
122
+ for (const notInDialogAttr of columnsNotInDialog) {
123
+ const notInDialogOriginalPos = originalOrder.indexOf(notInDialogAttr);
124
+ if (notInDialogOriginalPos < dialogOriginalPos &&
125
+ !newOrder.includes(notInDialogAttr)) {
126
+ newOrder.push(notInDialogAttr);
127
+ }
128
+ }
129
+ newOrder.push(dialogAttr);
130
+ }
131
+ for (const notInDialogAttr of columnsNotInDialog) {
132
+ if (!newOrder.includes(notInDialogAttr)) {
133
+ newOrder.push(notInDialogAttr);
134
+ }
135
+ }
136
+ return newOrder;
109
137
  }
110
138
  getColumnValueFiltersToRemove() {
111
139
  return this.columns.filter(col => col.deleteValueFilter).map(col => col.attr);
@@ -128,4 +156,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
128
156
  type: Inject,
129
157
  args: [MAT_DIALOG_DATA]
130
158
  }] }]; } });
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-table-visible-columns-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/dialog/visible-columns/o-table-visible-columns-dialog.component.ts","../../../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/dialog/visible-columns/o-table-visible-columns-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Inject,\n  Injector,\n  Type,\n  ViewEncapsulation\n} from '@angular/core';\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\n\nimport { DialogService } from '../../../../../services/dialog.service';\nimport { OTranslateService } from '../../../../../services/translate/o-translate.service';\nimport { Codes } from '../../../../../util/codes';\nimport { Util } from '../../../../../util/util';\nimport type { OColumn } from '../../../column/o-column.class';\nimport { OTableBase } from '../../../o-table-base.class';\n\nexport type ColumnVisibilityConfiguration = {\n  attr: string;\n  title: string;\n  visible: boolean;\n  deleteValueFilter?: boolean;\n  deleteSortColummn?: boolean;\n  deleteGrupingColumn?: boolean;\n};\n\n@Component({\n  selector: 'o-table-visible-columns-dialog',\n  templateUrl: 'o-table-visible-columns-dialog.component.html',\n  styleUrls: ['o-table-visible-columns-dialog.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    '[class.o-table-visible-columns-dialog]': 'true'\n  }\n})\nexport class OTableVisibleColumnsDialogComponent {\n\n  columns: ColumnVisibilityConfiguration[] = [];\n  rowHeight: string = Codes.DEFAULT_ROW_HEIGHT;\n  protected dialogService: DialogService;\n  protected cd: ChangeDetectorRef;\n  protected translateService: OTranslateService;\n  protected activeColumnValueFilters: string[] = [];\n  protected activeSortColumns: string[] = [];\n  protected activeGroupByColumns: string[] = [];\n  protected table: OTableBase;\n  constructor(\n    protected injector: Injector,\n    public dialogRef: MatDialogRef<OTableVisibleColumnsDialogComponent>,\n    @Inject(MAT_DIALOG_DATA) data: any\n  ) {\n    this.dialogService = this.injector.get<DialogService>(DialogService as Type<DialogService>);\n    this.cd = this.injector.get<ChangeDetectorRef>(ChangeDetectorRef as Type<ChangeDetectorRef>);\n    this.translateService = this.injector.get<OTranslateService>(OTranslateService as Type<OTranslateService>);\n\n    if (Util.isDefined(data.table)) {\n      this.table = data.table;\n\n      const visibleColumns = Util.parseArray(this.table.visibleColumns, true);\n      const nonHidableColumns = Util.parseArray(this.table.nonHidableColumns, true);\n\n      this.table.oTableOptions.columns.filter(oCol => (visibleColumns.indexOf(oCol.attr) !== -1 || oCol.definition !== undefined) &&\n        nonHidableColumns.indexOf(oCol.attr) === -1\n      ).forEach((oCol: OColumn) => {\n        this.columns.push({\n          attr: oCol.attr,\n          title: oCol.title,\n          visible: oCol.visible\n        });\n      });\n\n      this.rowHeight = this.table.rowHeight;\n      this.activeColumnValueFilters = this.table.dataSource.getColumnValueFilters().map(colValueFilter => colValueFilter.attr);\n      this.activeSortColumns = this.table.sortColArray.map(col => col.columnName);\n      this.activeGroupByColumns = this.table.groupedColumnsArray;\n    }\n  }\n\n  onClickColumn(col: ColumnVisibilityConfiguration): void {\n    const activeColFilter = this.activeColumnValueFilters.includes(col.attr);\n    const activeSorting = this.activeSortColumns.includes(col.attr);\n    const activeGrouping = this.activeGroupByColumns.includes(col.attr);\n    if (col.visible && (activeColFilter || activeSorting || activeGrouping)) {\n      const warnArgs = [];\n      if (activeColFilter) {\n        warnArgs.push(this.translateService.get('TABLE.VISIBLE_COLUMNS_DIALOG.VALUE_FILTER_WARN'));\n      }\n      if (activeSorting) {\n        warnArgs.push(this.translateService.get('TABLE.VISIBLE_COLUMNS_DIALOG.SORT_WARN'));\n      }\n      if (activeGrouping) {\n        warnArgs.push(this.translateService.get('TABLE.VISIBLE_COLUMNS_DIALOG.GROUPING_WARN'));\n      }\n      const dialogText = this.translateService.get('TABLE.VISIBLE_COLUMNS_DIALOG.HIDE_COLUMN_WARNING', warnArgs);\n      this.dialogService.confirm('CONFIRM', dialogText).then(res => {\n        if (res) {\n          col.deleteValueFilter = activeColFilter;\n          col.deleteSortColummn = activeSorting;\n          col.deleteGrupingColumn = activeGrouping;\n          col.visible = !col.visible;\n          this.cd.detectChanges();\n        }\n      });\n    } else {\n      col.visible = !col.visible;\n      if (col.visible) {\n        col.deleteValueFilter = false;\n        col.deleteSortColummn = false;\n        col.deleteGrupingColumn = false;\n      }\n    }\n  }\n\n  drop(event: CdkDragDrop<string[]>) {\n    moveItemInArray(this.columns, event.previousIndex, event.currentIndex);\n  }\n\n  closeDialog() {\n    const columnSortingToRemove = this.getColumnSortingToRemove();\n    const newSortColumns = columnSortingToRemove.length > 0 ?\n      this.table.sortColArray.filter(col => !columnSortingToRemove.includes(col.columnName)) :\n      undefined;\n\n    const columnGroupingToRemove = this.getColumnGroupingToRemove();\n    const newGroupColumns = columnGroupingToRemove.length > 0 ?\n      this.table.groupedColumnsArray.filter(col => !columnGroupingToRemove.includes(col)) :\n      undefined;\n\n    this.dialogRef.close({\n      visibleColArray: this.getVisibleColumns(),\n      columnsOrder: this.getColumnsOrder(),\n      sortColumns: newSortColumns,\n      columnValueFiltersToRemove: this.getColumnValueFiltersToRemove(),\n      groupColumns: newGroupColumns\n    });\n  }\n\n  private getVisibleColumns(): string[] {\n    return this.columns.filter(col => col.visible).map(col => col.attr);\n  }\n\n  private getColumnsOrder(): string[] {\n    return this.columns.map(col => col.attr);\n  }\n\n  private getColumnValueFiltersToRemove(): string[] {\n    return this.columns.filter(col => col.deleteValueFilter).map(col => col.attr);\n  }\n\n  private getColumnSortingToRemove(): string[] {\n    return this.columns.filter(col => col.deleteSortColummn).map(col => col.attr);\n  }\n\n  private getColumnGroupingToRemove(): string[] {\n    return this.columns.filter(col => col.deleteGrupingColumn).map(col => col.attr);\n  }\n}\n","<span mat-dialog-title>{{ 'TABLE.BUTTONS.COLVIS' | oTranslate }}</span>\n\n\n<mat-dialog-content>\n  <div mat-subheader>{{'TABLE.VISIBLE_COLUMNS.DESCRIPTION' | oTranslate}}</div>\n\n  <div [ngClass]=\"rowHeight\">\n    <mat-list cdkDropList (cdkDropListDropped)=\"drop($event)\">\n      <mat-list-item *ngFor=\"let column of columns\" cdkDrag (click)=\"onClickColumn(column)\" [ngClass]=\"{'column-hidden':!column.visible}\"\n        class=\"o-drag-list-item-box\">\n        <div fxLayout=\"row\" fxFlex fxLayoutAlign=\"stretch center\">\n          <mat-icon matListItemIcon svgIcon=\"ontimize:drag_handle\"></mat-icon>\n          <span matListItemLine fxFlex>{{ (column.title || column.attr) | oTranslate }}</span>\n          <mat-icon *ngIf=\"column.visible\" svgIcon=\"ontimize:visibility\" color=\"primary\"></mat-icon>\n          <mat-icon *ngIf=\"!column.visible\" svgIcon=\"ontimize:visibility_off\"></mat-icon>\n        </div>\n        <mat-divider></mat-divider>\n      </mat-list-item>\n    </mat-list>\n  </div>\n</mat-dialog-content>\n\n<mat-dialog-actions fxLayoutAlign=\"end center\">\n  <button type=\"button\" mat-stroked-button [mat-dialog-close]=\"null\" class=\"o-button-default cancel\" cancel>{{ 'CANCEL' | oTranslate }}</button>\n  <button type=\"button\" mat-stroked-button (click)=\"closeDialog()\" class=\"o-button-primary\">{{ 'ACCEPT' | oTranslate }}</button>\n</mat-dialog-actions>\n"]}
159
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-table-visible-columns-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/dialog/visible-columns/o-table-visible-columns-dialog.component.ts","../../../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/dialog/visible-columns/o-table-visible-columns-dialog.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAe,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACtE,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,MAAM,EACN,QAAQ,EAER,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAEzE,OAAO,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,uDAAuD,CAAC;AAC1F,OAAO,EAAE,KAAK,EAAE,MAAM,2BAA2B,CAAC;AAClD,OAAO,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAC;;;;;;;;;;;;AAuBhD,MAAM,OAAO,mCAAmC;IAY9C,YACY,QAAkB,EACrB,SAA4D,EAC1C,IAAS;QAFxB,aAAQ,GAAR,QAAQ,CAAU;QACrB,cAAS,GAAT,SAAS,CAAmD;QAZrE,YAAO,GAAoC,EAAE,CAAC;QAC9C,cAAS,GAAW,KAAK,CAAC,kBAAkB,CAAC;QAInC,6BAAwB,GAAa,EAAE,CAAC;QACxC,sBAAiB,GAAa,EAAE,CAAC;QACjC,yBAAoB,GAAa,EAAE,CAAC;QAQ5C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAgB,aAAoC,CAAC,CAAC;QAC5F,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAoB,iBAA4C,CAAC,CAAC;QAC7F,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAoB,iBAA4C,CAAC,CAAC;QAE3G,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAC9B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;YAExB,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;YACxE,MAAM,iBAAiB,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAAE,IAAI,CAAC,CAAC;YAG9E,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,CAAC;gBACzH,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAC5C,CAAC,OAAO,CAAC,CAAC,IAAa,EAAE,EAAE;gBAC1B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;oBAChB,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,OAAO,EAAE,IAAI,CAAC,OAAO;iBACtB,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;YACtC,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,qBAAqB,EAAE,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YACzH,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;YAC5E,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC;SAC5D;IACH,CAAC;IAED,aAAa,CAAC,GAAkC;QAC9C,MAAM,eAAe,GAAG,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACzE,MAAM,aAAa,GAAG,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAChE,MAAM,cAAc,GAAG,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAEpE,IAAI,GAAG,CAAC,OAAO,IAAI,CAAC,eAAe,IAAI,aAAa,IAAI,cAAc,CAAC,EAAE;YACvE,MAAM,QAAQ,GAAG,EAAE,CAAC;YACpB,IAAI,eAAe,EAAE;gBACnB,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,gDAAgD,CAAC,CAAC,CAAC;aAC5F;YACD,IAAI,aAAa,EAAE;gBACjB,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,wCAAwC,CAAC,CAAC,CAAC;aACpF;YACD,IAAI,cAAc,EAAE;gBAClB,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,4CAA4C,CAAC,CAAC,CAAC;aACxF;YACD,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,kDAAkD,EAAE,QAAQ,CAAC,CAAC;YAC3G,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;gBAC3D,IAAI,GAAG,EAAE;oBACP,GAAG,CAAC,iBAAiB,GAAG,eAAe,CAAC;oBACxC,GAAG,CAAC,iBAAiB,GAAG,aAAa,CAAC;oBACtC,GAAG,CAAC,mBAAmB,GAAG,cAAc,CAAC;oBACzC,GAAG,CAAC,OAAO,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC;oBAC3B,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;iBACzB;YACH,CAAC,CAAC,CAAC;SACJ;aAAM;YACL,GAAG,CAAC,OAAO,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC;YAC3B,IAAI,GAAG,CAAC,OAAO,EAAE;gBACf,GAAG,CAAC,iBAAiB,GAAG,KAAK,CAAC;gBAC9B,GAAG,CAAC,iBAAiB,GAAG,KAAK,CAAC;gBAC9B,GAAG,CAAC,mBAAmB,GAAG,KAAK,CAAC;aACjC;SACF;IACH,CAAC;IAED,IAAI,CAAC,KAA4B;QAC/B,eAAe,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;IACzE,CAAC;IAED,WAAW;QAET,MAAM,qBAAqB,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC9D,MAAM,cAAc,GAAG,qBAAqB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YACvD,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,qBAAqB,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACxF,SAAS,CAAC;QAEZ,MAAM,sBAAsB,GAAG,IAAI,CAAC,yBAAyB,EAAE,CAAC;QAChE,MAAM,eAAe,GAAG,sBAAsB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YACzD,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,sBAAsB,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACrF,SAAS,CAAC;QAEZ,MAAM,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAE5C,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;YACnB,eAAe,EAAE,IAAI,CAAC,iBAAiB,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC3G,YAAY,EAAE,YAAY;YAC1B,WAAW,EAAE,cAAc;YAC3B,0BAA0B,EAAE,IAAI,CAAC,6BAA6B,EAAE;YAChE,YAAY,EAAE,eAAe;SAC9B,CAAC,CAAC;IACL,CAAC;IAMO,iBAAiB;QACvB,MAAM,iBAAiB,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAAE,IAAI,CAAC,CAAC;QAG9E,MAAM,iBAAiB,GAAG,IAAI,CAAC,OAAO;aACnC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC;aAC1B,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAGxB,MAAM,eAAe,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,iBAAiB,EAAE,GAAG,iBAAiB,CAAC,CAAC,CAAC;QAG9E,OAAO,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO;aACpC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAC9C,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAMO,eAAe;QACrB,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAG5E,MAAM,kBAAkB,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAG7D,MAAM,kBAAkB,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CACrD,CAAC,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,CACnC,CAAC;QAGF,MAAM,QAAQ,GAAa,EAAE,CAAC;QAE9B,KAAK,MAAM,UAAU,IAAI,kBAAkB,EAAE;YAI3C,MAAM,iBAAiB,GAAG,aAAa,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;YAE5D,KAAK,MAAM,eAAe,IAAI,kBAAkB,EAAE;gBAChD,MAAM,sBAAsB,GAAG,aAAa,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;gBAGtE,IACE,sBAAsB,GAAG,iBAAiB;oBAC1C,CAAC,QAAQ,CAAC,QAAQ,CAAC,eAAe,CAAC,EACnC;oBACA,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;iBAChC;aACF;YAGD,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SAC3B;QAGD,KAAK,MAAM,eAAe,IAAI,kBAAkB,EAAE;YAChD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAE;gBACvC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;aAChC;SACF;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEO,6BAA6B;QACnC,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAChF,CAAC;IAEO,wBAAwB;QAC9B,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAChF,CAAC;IAEO,yBAAyB;QAC/B,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAClF,CAAC;;iIA7LU,mCAAmC,sEAepC,eAAe;qHAfd,mCAAmC,gJCtChD,q4CA0BA;4FDYa,mCAAmC;kBAV/C,SAAS;+BACE,gCAAgC,iBAG3B,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,QACzC;wBACJ,wCAAwC,EAAE,MAAM;qBACjD;;0BAiBE,MAAM;2BAAC,eAAe","sourcesContent":["import { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Inject,\n  Injector,\n  Type,\n  ViewEncapsulation\n} from '@angular/core';\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\n\nimport { DialogService } from '../../../../../services/dialog.service';\nimport { OTranslateService } from '../../../../../services/translate/o-translate.service';\nimport { Codes } from '../../../../../util/codes';\nimport { Util } from '../../../../../util/util';\nimport type { OColumn } from '../../../column/o-column.class';\nimport { OTableBase } from '../../../o-table-base.class';\n\nexport type ColumnVisibilityConfiguration = {\n  attr: string;\n  title: string;\n  visible: boolean;\n  deleteValueFilter?: boolean;\n  deleteSortColummn?: boolean;\n  deleteGrupingColumn?: boolean;\n};\n\n@Component({\n  selector: 'o-table-visible-columns-dialog',\n  templateUrl: 'o-table-visible-columns-dialog.component.html',\n  styleUrls: ['o-table-visible-columns-dialog.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    '[class.o-table-visible-columns-dialog]': 'true'\n  }\n})\nexport class OTableVisibleColumnsDialogComponent {\n\n  columns: ColumnVisibilityConfiguration[] = [];\n  rowHeight: string = Codes.DEFAULT_ROW_HEIGHT;\n  protected dialogService: DialogService;\n  protected cd: ChangeDetectorRef;\n  protected translateService: OTranslateService;\n  protected activeColumnValueFilters: string[] = [];\n  protected activeSortColumns: string[] = [];\n  protected activeGroupByColumns: string[] = [];\n  protected table: OTableBase;\n\n  constructor(\n    protected injector: Injector,\n    public dialogRef: MatDialogRef<OTableVisibleColumnsDialogComponent>,\n    @Inject(MAT_DIALOG_DATA) data: any\n  ) {\n    this.dialogService = this.injector.get<DialogService>(DialogService as Type<DialogService>);\n    this.cd = this.injector.get<ChangeDetectorRef>(ChangeDetectorRef as Type<ChangeDetectorRef>);\n    this.translateService = this.injector.get<OTranslateService>(OTranslateService as Type<OTranslateService>);\n\n    if (Util.isDefined(data.table)) {\n      this.table = data.table;\n\n      const visibleColumns = Util.parseArray(this.table.visibleColumns, true);\n      const nonHidableColumns = Util.parseArray(this.table.nonHidableColumns, true);\n\n      //if it has no definition and is not in visible columns, it is not shown\n      this.table.oTableOptions.columns.filter(oCol => (visibleColumns.indexOf(oCol.attr) !== -1 || oCol.definition !== undefined) &&\n        nonHidableColumns.indexOf(oCol.attr) === -1\n      ).forEach((oCol: OColumn) => {\n        this.columns.push({\n          attr: oCol.attr,\n          title: oCol.title,\n          visible: oCol.visible\n        });\n      });\n\n      this.rowHeight = this.table.rowHeight;\n      this.activeColumnValueFilters = this.table.dataSource.getColumnValueFilters().map(colValueFilter => colValueFilter.attr);\n      this.activeSortColumns = this.table.sortColArray.map(col => col.columnName);\n      this.activeGroupByColumns = this.table.groupedColumnsArray;\n    }\n  }\n\n  onClickColumn(col: ColumnVisibilityConfiguration): void {\n    const activeColFilter = this.activeColumnValueFilters.includes(col.attr);\n    const activeSorting = this.activeSortColumns.includes(col.attr);\n    const activeGrouping = this.activeGroupByColumns.includes(col.attr);\n\n    if (col.visible && (activeColFilter || activeSorting || activeGrouping)) {\n      const warnArgs = [];\n      if (activeColFilter) {\n        warnArgs.push(this.translateService.get('TABLE.VISIBLE_COLUMNS_DIALOG.VALUE_FILTER_WARN'));\n      }\n      if (activeSorting) {\n        warnArgs.push(this.translateService.get('TABLE.VISIBLE_COLUMNS_DIALOG.SORT_WARN'));\n      }\n      if (activeGrouping) {\n        warnArgs.push(this.translateService.get('TABLE.VISIBLE_COLUMNS_DIALOG.GROUPING_WARN'));\n      }\n      const dialogText = this.translateService.get('TABLE.VISIBLE_COLUMNS_DIALOG.HIDE_COLUMN_WARNING', warnArgs);\n      this.dialogService.confirm('CONFIRM', dialogText).then(res => {\n        if (res) {\n          col.deleteValueFilter = activeColFilter;\n          col.deleteSortColummn = activeSorting;\n          col.deleteGrupingColumn = activeGrouping;\n          col.visible = !col.visible;\n          this.cd.detectChanges();\n        }\n      });\n    } else {\n      col.visible = !col.visible;\n      if (col.visible) {\n        col.deleteValueFilter = false;\n        col.deleteSortColummn = false;\n        col.deleteGrupingColumn = false;\n      }\n    }\n  }\n\n  drop(event: CdkDragDrop<string[]>) {\n    moveItemInArray(this.columns, event.previousIndex, event.currentIndex);\n  }\n\n  closeDialog() {\n\n    const columnSortingToRemove = this.getColumnSortingToRemove();\n    const newSortColumns = columnSortingToRemove.length > 0 ?\n      this.table.sortColArray.filter(col => !columnSortingToRemove.includes(col.columnName)) :\n      undefined;\n\n    const columnGroupingToRemove = this.getColumnGroupingToRemove();\n    const newGroupColumns = columnGroupingToRemove.length > 0 ?\n      this.table.groupedColumnsArray.filter(col => !columnGroupingToRemove.includes(col)) :\n      undefined;\n\n    const columnsOrder = this.getColumnsOrder();\n\n    this.dialogRef.close({\n      visibleColArray: this.getVisibleColumns().sort((a, b) => columnsOrder.indexOf(a) - columnsOrder.indexOf(b)),\n      columnsOrder: columnsOrder,\n      sortColumns: newSortColumns,\n      columnValueFiltersToRemove: this.getColumnValueFiltersToRemove(),\n      groupColumns: newGroupColumns\n    });\n  }\n\n  /**\n   * Returns the visible columns, including non-hidable ones,\n   * preserving the order defined in oTableOptions.columns.\n   */\n  private getVisibleColumns(): string[] {\n    const nonHidableColumns = Util.parseArray(this.table.nonHidableColumns, true);\n\n    // Visible columns selected in the dialog\n    const visibleFromDialog = this.columns\n      .filter(col => col.visible)\n      .map(col => col.attr);\n\n    // Merge: visible columns from the dialog + non-hidable (always visible)\n    const allVisibleAttrs = new Set([...visibleFromDialog, ...nonHidableColumns]);\n\n    // Sort according to the updated order in oTableOptions.columns\n    return this.table.oTableOptions.columns\n      .filter(oCol => allVisibleAttrs.has(oCol.attr))\n      .map(oCol => oCol.attr);\n  }\n\n  /**\n   * Returns the final columns order, preserving the order defined in the dialog\n   * and keeping non-hidable and hidden columns in their original positions.\n   */\n  private getColumnsOrder(): string[] {\n    const originalOrder = this.table.oTableOptions.columns.map(col => col.attr);\n\n    // Columns from the dialog in their new order\n    const dialogColumnsOrder = this.columns.map(col => col.attr);\n\n    // Columns not present in the dialog (non-hidable + hidden ones)\n    const columnsNotInDialog = originalOrder.filter(attr =>\n      !dialogColumnsOrder.includes(attr)\n    );\n\n    // Build the new order\n    const newOrder: string[] = [];\n\n    for (const dialogAttr of dialogColumnsOrder) {\n      // Before adding this dialog column,\n      // add the columns (non-hidable or hidden) that were placed before it\n      // in the original order\n      const dialogOriginalPos = originalOrder.indexOf(dialogAttr);\n\n      for (const notInDialogAttr of columnsNotInDialog) {\n        const notInDialogOriginalPos = originalOrder.indexOf(notInDialogAttr);\n\n        // If it was before and has not been added yet\n        if (\n          notInDialogOriginalPos < dialogOriginalPos &&\n          !newOrder.includes(notInDialogAttr)\n        ) {\n          newOrder.push(notInDialogAttr);\n        }\n      }\n\n      // Add the dialog column\n      newOrder.push(dialogAttr);\n    }\n\n    // Add remaining columns that were placed after all dialog columns\n    for (const notInDialogAttr of columnsNotInDialog) {\n      if (!newOrder.includes(notInDialogAttr)) {\n        newOrder.push(notInDialogAttr);\n      }\n    }\n\n    return newOrder;\n  }\n\n  private getColumnValueFiltersToRemove(): string[] {\n    return this.columns.filter(col => col.deleteValueFilter).map(col => col.attr);\n  }\n\n  private getColumnSortingToRemove(): string[] {\n    return this.columns.filter(col => col.deleteSortColummn).map(col => col.attr);\n  }\n\n  private getColumnGroupingToRemove(): string[] {\n    return this.columns.filter(col => col.deleteGrupingColumn).map(col => col.attr);\n  }\n}","<span mat-dialog-title>{{ 'TABLE.BUTTONS.COLVIS' | oTranslate }}</span>\n\n\n<mat-dialog-content>\n  <div mat-subheader>{{'TABLE.VISIBLE_COLUMNS.DESCRIPTION' | oTranslate}}</div>\n\n  <div [ngClass]=\"rowHeight\">\n    <mat-list cdkDropList (cdkDropListDropped)=\"drop($event)\">\n      <mat-list-item *ngFor=\"let column of columns\" cdkDrag (click)=\"onClickColumn(column)\" [ngClass]=\"{'column-hidden':!column.visible}\"\n        class=\"o-drag-list-item-box\">\n        <div fxLayout=\"row\" fxFlex fxLayoutAlign=\"stretch center\">\n          <mat-icon matListItemIcon svgIcon=\"ontimize:drag_handle\"></mat-icon>\n          <span matListItemLine fxFlex>{{ (column.title || column.attr) | oTranslate }}</span>\n          <mat-icon *ngIf=\"column.visible\" svgIcon=\"ontimize:visibility\" color=\"primary\"></mat-icon>\n          <mat-icon *ngIf=\"!column.visible\" svgIcon=\"ontimize:visibility_off\"></mat-icon>\n        </div>\n        <mat-divider></mat-divider>\n      </mat-list-item>\n    </mat-list>\n  </div>\n</mat-dialog-content>\n\n<mat-dialog-actions fxLayoutAlign=\"end center\">\n  <button type=\"button\" mat-stroked-button [mat-dialog-close]=\"null\" class=\"o-button-default cancel\" cancel>{{ 'CANCEL' | oTranslate }}</button>\n  <button type=\"button\" mat-stroked-button (click)=\"closeDialog()\" class=\"o-button-primary\">{{ 'ACCEPT' | oTranslate }}</button>\n</mat-dialog-actions>\n"]}
@@ -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":"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","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=