@onecx/angular-accelerator 5.23.5 → 5.23.6

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.
@@ -65,15 +65,25 @@ export class DataSortBase {
65
65
  if (!clientSideSorting || sortColumn === '') {
66
66
  return [items, filters, sortColumn, sortDirection, translations];
67
67
  }
68
- let translatedColValues = Object.fromEntries(items.map((i) => [
69
- ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),
70
- ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),
71
- ]));
72
- if (columns.find((h) => h.id === sortColumn)?.columnType === ColumnType.TRANSLATION_KEY) {
73
- translatedColValues = translations[sortColumn];
68
+ const column = columns.find((h) => h.id === sortColumn);
69
+ let colValues;
70
+ if (column?.columnType === ColumnType.DATE || column?.columnType === ColumnType.RELATIVE_DATE) {
71
+ colValues = Object.fromEntries(items.map((i) => [
72
+ ObjectUtils.resolveFieldData(i, sortColumn),
73
+ ObjectUtils.resolveFieldData(i, sortColumn),
74
+ ]));
75
+ }
76
+ else {
77
+ colValues = Object.fromEntries(items.map((i) => [
78
+ ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),
79
+ ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),
80
+ ]));
81
+ }
82
+ if (column?.columnType === ColumnType.TRANSLATION_KEY) {
83
+ colValues = translations[sortColumn];
74
84
  }
75
85
  return [
76
- [...items].sort(this.createCompareFunction(translatedColValues, sortColumn, sortDirection)),
86
+ [...items].sort(this.createCompareFunction(colValues, sortColumn, sortDirection)),
77
87
  filters,
78
88
  sortColumn,
79
89
  sortDirection,
@@ -121,4 +131,4 @@ export class DataSortBase {
121
131
  };
122
132
  }
123
133
  }
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-sort-base.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/data-sort-base/data-sort-base.ts"],"names":[],"mappings":"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","sourcesContent":["import { TranslateService } from '@ngx-translate/core'\nimport { Observable, map, of } from 'rxjs'\nimport { flattenObject } from '../../functions/flatten-object'\nimport { ColumnType } from '../../model/column-type.model'\nimport { DataSortDirection } from '../../model/data-sort-direction'\nimport { DataTableColumn } from '../../model/data-table-column.model'\nimport { ListGridData } from '../../components/data-list-grid/data-list-grid.component'\nimport { Row } from '../../components/data-table/data-table.component'\nimport { ObjectUtils } from '../../utils/objectutils'\nimport { Filter, FilterType } from '../../model/filter.model'\n\ntype RowListGridData = ListGridData | Row\n\nexport class DataSortBase {\n  constructor(\n    protected locale: string,\n    protected translateService: TranslateService\n  ) {}\n\n  translateItems(\n    [items, filters, sortColumn, sortDirection]: [RowListGridData[], Filter[], string, DataSortDirection],\n    columns: DataTableColumn[],\n    clientSideFiltering: boolean,\n    clientSideSorting: boolean\n  ): Observable<[RowListGridData[], Filter[], string, DataSortDirection, Record<string, Record<string, string>>]> {\n    if (clientSideFiltering || clientSideSorting) {\n      let translationKeys: string[] = []\n      const translatedColumns = columns.filter((c) => c.columnType === ColumnType.TRANSLATION_KEY)\n      translatedColumns.forEach((c) => {\n        translationKeys = [\n          ...translationKeys,\n          ...items.map((i) => ObjectUtils.resolveFieldData(i, c.id)?.toString()).filter((v) => !!v),\n        ]\n      })\n      if (translationKeys.length) {\n        return this.translateService.get(translationKeys).pipe(\n          map((translatedValues: Record<string, string>) => {\n            const translations: Record<string, Record<string, string>> = {}\n            translatedColumns.forEach((c) => {\n              translations[c.id] = Object.fromEntries(\n                items.map((i) => [\n                  ObjectUtils.resolveFieldData(i, c.id)?.toString() || '',\n                  translatedValues[ObjectUtils.resolveFieldData(i, c.id)?.toString()],\n                ])\n              )\n            })\n            return [items, filters, sortColumn, sortDirection, translations]\n          })\n        )\n      }\n    }\n    return of([items, filters, sortColumn, sortDirection, {}])\n  }\n\n  filterItems(\n    [items, filters, sortColumn, sortDirection, translations]: [\n      RowListGridData[],\n      Filter[],\n      string,\n      DataSortDirection,\n      Record<string, Record<string, string>>,\n    ],\n    clientSideFiltering: boolean\n  ): [RowListGridData[], Filter[], string, DataSortDirection, Record<string, Record<string, string>>] {\n    if (!clientSideFiltering) {\n      return [items, filters, sortColumn, sortDirection, translations]\n    }\n    return [\n      items.filter((item) =>\n        filters\n          .map((filter) => filter.columnId)\n          .filter((value, index, self) => self.indexOf(value) === index && value != null)\n          .every((filterColumnId) =>\n            filters\n              .filter((filter) => filter.columnId === filterColumnId)\n              .some((filter) => {\n                const value = (\n                  translations[filter.columnId]?.[ObjectUtils.resolveFieldData(item, filter.columnId)?.toString()] ||\n                  ObjectUtils.resolveFieldData(item, filter.columnId)\n                )?.toString()\n                switch (filter.filterType) {\n                  case undefined:\n                  case FilterType.EQUAL:\n                    return value === String(filter.value)\n                  case FilterType.TRUTHY: {\n                    return filter.value ? !!value : !value\n                  }\n                }\n              })\n          )\n      ),\n      filters,\n      sortColumn,\n      sortDirection,\n      translations,\n    ]\n  }\n\n  sortItems(\n    [items, filters, sortColumn, sortDirection, translations]: [\n      RowListGridData[],\n      Filter[],\n      string,\n      DataSortDirection,\n      Record<string, Record<string, string>>,\n    ],\n    columns: DataTableColumn[],\n    clientSideSorting: boolean\n  ): [RowListGridData[], Filter[], string, DataSortDirection, Record<string, Record<string, string>>] {\n    if (!clientSideSorting || sortColumn === '') {\n      return [items, filters, sortColumn, sortDirection, translations]\n    }\n    let translatedColValues: Record<string, string> = Object.fromEntries(\n      items.map((i) => [\n        ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),\n        ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),\n      ])\n    )\n    if (columns.find((h) => h.id === sortColumn)?.columnType === ColumnType.TRANSLATION_KEY) {\n      translatedColValues = translations[sortColumn]\n    }\n    return [\n      [...items].sort(this.createCompareFunction(translatedColValues, sortColumn, sortDirection)),\n      filters,\n      sortColumn,\n      sortDirection,\n      translations,\n    ]\n  }\n\n  flattenItems(items: RowListGridData[]) {\n    return items.map((i) => flattenObject(i))\n  }\n\n  createCompareFunction(\n    translatedColValues: Record<string, string>,\n    sortColumn: string,\n    sortDirection: DataSortDirection\n  ): (a: Record<string, any>, b: Record<string, any>) => number {\n    let direction = 0\n    if (sortDirection === DataSortDirection.ASCENDING) {\n      direction = 1\n    } else if (sortDirection === DataSortDirection.DESCENDING) {\n      direction = -1\n    }\n    return (data1, data2) => {\n      if (direction === 0) {\n        return 0\n      }\n      let result\n      const value1 = translatedColValues[ObjectUtils.resolveFieldData(data1, sortColumn)]\n      const value2 = translatedColValues[ObjectUtils.resolveFieldData(data2, sortColumn)]\n\n      if (value1 == null && value2 != null) result = -1\n      else if (value1 != null && value2 == null) result = 1\n      else if (value1 == null && value2 == null) result = 0\n      else if (typeof value1 === 'string' && typeof value2 === 'string')\n        result = value1.localeCompare(value2, [this.locale, 'en', 'de'], { numeric: true })\n      else {\n        if (value1 < value2) {\n          result = -1\n        } else if (value1 > value2) {\n          result = 1\n        } else {\n          result = 0\n        }\n      }\n      return direction * result\n    }\n  }\n}\n"]}
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-sort-base.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/data-sort-base/data-sort-base.ts"],"names":[],"mappings":"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","sourcesContent":["import { TranslateService } from '@ngx-translate/core'\nimport { Observable, map, of } from 'rxjs'\nimport { flattenObject } from '../../functions/flatten-object'\nimport { ColumnType } from '../../model/column-type.model'\nimport { DataSortDirection } from '../../model/data-sort-direction'\nimport { DataTableColumn } from '../../model/data-table-column.model'\nimport { ListGridData } from '../../components/data-list-grid/data-list-grid.component'\nimport { Row } from '../../components/data-table/data-table.component'\nimport { ObjectUtils } from '../../utils/objectutils'\nimport { Filter, FilterType } from '../../model/filter.model'\n\ntype RowListGridData = ListGridData | Row\n\nexport class DataSortBase {\n  constructor(\n    protected locale: string,\n    protected translateService: TranslateService\n  ) {}\n\n  translateItems(\n    [items, filters, sortColumn, sortDirection]: [RowListGridData[], Filter[], string, DataSortDirection],\n    columns: DataTableColumn[],\n    clientSideFiltering: boolean,\n    clientSideSorting: boolean\n  ): Observable<[RowListGridData[], Filter[], string, DataSortDirection, Record<string, Record<string, string>>]> {\n    if (clientSideFiltering || clientSideSorting) {\n      let translationKeys: string[] = []\n      const translatedColumns = columns.filter((c) => c.columnType === ColumnType.TRANSLATION_KEY)\n      translatedColumns.forEach((c) => {\n        translationKeys = [\n          ...translationKeys,\n          ...items.map((i) => ObjectUtils.resolveFieldData(i, c.id)?.toString()).filter((v) => !!v),\n        ]\n      })\n      if (translationKeys.length) {\n        return this.translateService.get(translationKeys).pipe(\n          map((translatedValues: Record<string, string>) => {\n            const translations: Record<string, Record<string, string>> = {}\n            translatedColumns.forEach((c) => {\n              translations[c.id] = Object.fromEntries(\n                items.map((i) => [\n                  ObjectUtils.resolveFieldData(i, c.id)?.toString() || '',\n                  translatedValues[ObjectUtils.resolveFieldData(i, c.id)?.toString()],\n                ])\n              )\n            })\n            return [items, filters, sortColumn, sortDirection, translations]\n          })\n        )\n      }\n    }\n    return of([items, filters, sortColumn, sortDirection, {}])\n  }\n\n  filterItems(\n    [items, filters, sortColumn, sortDirection, translations]: [\n      RowListGridData[],\n      Filter[],\n      string,\n      DataSortDirection,\n      Record<string, Record<string, string>>,\n    ],\n    clientSideFiltering: boolean\n  ): [RowListGridData[], Filter[], string, DataSortDirection, Record<string, Record<string, string>>] {\n    if (!clientSideFiltering) {\n      return [items, filters, sortColumn, sortDirection, translations]\n    }\n    return [\n      items.filter((item) =>\n        filters\n          .map((filter) => filter.columnId)\n          .filter((value, index, self) => self.indexOf(value) === index && value != null)\n          .every((filterColumnId) =>\n            filters\n              .filter((filter) => filter.columnId === filterColumnId)\n              .some((filter) => {\n                const value = (\n                  translations[filter.columnId]?.[ObjectUtils.resolveFieldData(item, filter.columnId)?.toString()] ||\n                  ObjectUtils.resolveFieldData(item, filter.columnId)\n                )?.toString()\n                switch (filter.filterType) {\n                  case undefined:\n                  case FilterType.EQUAL:\n                    return value === String(filter.value)\n                  case FilterType.TRUTHY: {\n                    return filter.value ? !!value : !value\n                  }\n                }\n              })\n          )\n      ),\n      filters,\n      sortColumn,\n      sortDirection,\n      translations,\n    ]\n  }\n\n  sortItems(\n    [items, filters, sortColumn, sortDirection, translations]: [\n      RowListGridData[],\n      Filter[],\n      string,\n      DataSortDirection,\n      Record<string, Record<string, string>>,\n    ],\n    columns: DataTableColumn[],\n    clientSideSorting: boolean\n  ): [RowListGridData[], Filter[], string, DataSortDirection, Record<string, Record<string, string>>] {\n    if (!clientSideSorting || sortColumn === '') {\n      return [items, filters, sortColumn, sortDirection, translations]\n    }\n    const column = columns.find((h) => h.id === sortColumn)\n    let colValues: Record<string, string>\n    if (column?.columnType === ColumnType.DATE || column?.columnType === ColumnType.RELATIVE_DATE) {\n      colValues = Object.fromEntries(\n        items.map((i) => [\n          ObjectUtils.resolveFieldData(i, sortColumn) as Date,\n          ObjectUtils.resolveFieldData(i, sortColumn) as Date,\n        ])\n      )\n    } else {\n      colValues = Object.fromEntries(\n        items.map((i) => [\n          ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),\n          ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),\n        ])\n      )\n    }\n    if (column?.columnType === ColumnType.TRANSLATION_KEY) {\n      colValues = translations[sortColumn]\n    }\n    return [\n      [...items].sort(this.createCompareFunction(colValues, sortColumn, sortDirection)),\n      filters,\n      sortColumn,\n      sortDirection,\n      translations,\n    ]\n  }\n\n  flattenItems(items: RowListGridData[]) {\n    return items.map((i) => flattenObject(i))\n  }\n\n  createCompareFunction(\n    translatedColValues: Record<string, string>,\n    sortColumn: string,\n    sortDirection: DataSortDirection\n  ): (a: Record<string, any>, b: Record<string, any>) => number {\n    let direction = 0\n    if (sortDirection === DataSortDirection.ASCENDING) {\n      direction = 1\n    } else if (sortDirection === DataSortDirection.DESCENDING) {\n      direction = -1\n    }\n    return (data1, data2) => {\n      if (direction === 0) {\n        return 0\n      }\n      let result\n      const value1 = translatedColValues[ObjectUtils.resolveFieldData(data1, sortColumn)]\n      const value2 = translatedColValues[ObjectUtils.resolveFieldData(data2, sortColumn)]\n\n      if (value1 == null && value2 != null) result = -1\n      else if (value1 != null && value2 == null) result = 1\n      else if (value1 == null && value2 == null) result = 0\n      else if (typeof value1 === 'string' && typeof value2 === 'string')\n        result = value1.localeCompare(value2, [this.locale, 'en', 'de'], { numeric: true })\n      else {\n        if (value1 < value2) {\n          result = -1\n        } else if (value1 > value2) {\n          result = 1\n        } else {\n          result = 0\n        }\n      }\n      return direction * result\n    }\n  }\n}\n"]}
@@ -124,6 +124,9 @@ export class FilterViewComponent {
124
124
  .slice()
125
125
  .sort((a, b) => columnIds.indexOf(a.valueColumnId) - columnIds.indexOf(b.valueColumnId));
126
126
  }));
127
+ this.componentStateChanged.emit({
128
+ filters: this.filters,
129
+ });
127
130
  }
128
131
  get _fitlerViewNoSelection() {
129
132
  return this.fitlerViewNoSelection;
@@ -257,4 +260,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
257
260
  }], templates: [{
258
261
  type: Input
259
262
  }] } });
260
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-view.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/filter-view/filter-view.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/filter-view/filter-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core'\nimport { Filter, FilterType } from '../../model/filter.model'\nimport { DataTableColumn } from '../../model/data-table-column.model'\nimport { BehaviorSubject, Observable, combineLatest, debounceTime, map } from 'rxjs'\nimport { ColumnType } from '../../model/column-type.model'\nimport { PrimeTemplate } from 'primeng/api'\nimport { findTemplate } from '../../utils/template.utils'\nimport { ObjectUtils } from '../../utils/objectutils'\nimport { limit } from '../../utils/filter.utils'\nimport { OverlayPanel } from 'primeng/overlaypanel'\nimport { Row } from '../data-table/data-table.component'\nimport { Button } from 'primeng/button'\n\nexport type FilterViewDisplayMode = 'chips' | 'button'\nexport type FilterViewRowDisplayData = {\n  id: string\n  column: string\n  value: unknown\n}\nexport type FilterViewRowDetailData = FilterViewRowDisplayData & {\n  valueColumnId: string\n}\n\nexport interface FilterViewComponentState {\n  filters?: Filter[]\n}\n\n@Component({\n  selector: 'ocx-filter-view',\n  templateUrl: './filter-view.component.html',\n  styleUrls: ['./filter-view.component.scss'],\n})\nexport class FilterViewComponent implements OnInit {\n  ColumnType = ColumnType\n  FilterType = FilterType\n  filters$ = new BehaviorSubject<Filter[]>([])\n  @Input()\n  get filters(): Filter[] {\n    return this.filters$.getValue()\n  }\n  set filters(value: Filter[]) {\n    this.filters$.next(value)\n  }\n  columns$ = new BehaviorSubject<DataTableColumn[]>([])\n  @Input()\n  get columns(): DataTableColumn[] {\n    return this.columns$.getValue()\n  }\n  set columns(value: DataTableColumn[]) {\n    this.columns$.next(value)\n    const chipObs = value.map((c) => this.getTemplate(c, this.chipTemplateNames, this.chipTemplates, this.chipIdSuffix))\n    this.chipTemplates$ = combineLatest(chipObs).pipe(\n      map((values) => Object.fromEntries(value.map((c, i) => [c.id, values[i]])))\n    )\n\n    const tableTemplateColumns = value.concat(this.columnFilterTableColumns)\n    this.tableTemplates$ = combineLatest(\n      tableTemplateColumns.map((c) =>\n        this.getTemplate(c, this.tableTemplateNames, this.tableTemplates, this.tableIdSuffix)\n      )\n    ).pipe(map((values) => Object.fromEntries(tableTemplateColumns.map((c, i) => [c.id, values[i]]))))\n  }\n\n  columnFilterDataRows$: Observable<FilterViewRowDisplayData[]> | undefined\n\n  @Input() displayMode: FilterViewDisplayMode = 'button'\n  @Input() selectDisplayedChips: (filters: Filter[], columns: DataTableColumn[]) => Filter[] = (filters) =>\n    limit(filters, 3, { reverse: true })\n  @Input() chipStyleClass = ''\n  @Input() tableStyle: { [klass: string]: any } = { 'max-height': '50vh' }\n  @Input() panelStyle: { [klass: string]: any } = { 'max-width': '90%' }\n\n  @Output() filtered: EventEmitter<Filter[]> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<FilterViewComponentState> = new EventEmitter()\n\n  columnFilterTableColumns: DataTableColumn[] = [\n    {\n      id: 'column',\n      columnType: ColumnType.TRANSLATION_KEY,\n      nameKey: 'OCX_FILTER_VIEW.TABLE.COLUMN_NAME',\n    },\n    { id: 'value', columnType: ColumnType.STRING, nameKey: 'OCX_FILTER_VIEW.TABLE.VALUE' },\n    {\n      id: 'actions',\n      columnType: ColumnType.STRING,\n      nameKey: 'OCX_FILTER_VIEW.TABLE.ACTIONS',\n    },\n  ]\n\n  ngOnInit(): void {\n    this.columnFilterDataRows$ = combineLatest([this.filters$, this.columns$]).pipe(\n      map(([filters, columns]) => {\n        const columnIds = columns.map((c) => c.id)\n        return filters\n          .map((f) => {\n            const filterColumn = this.getColumnForFilter(f, columns)\n            if (!filterColumn) return undefined\n            return {\n              id: `${f.columnId}-${f.value}`,\n              column: filterColumn.nameKey,\n              value: f.value,\n              valueColumnId: filterColumn.id,\n            } satisfies FilterViewRowDetailData\n          })\n          .filter((v): v is FilterViewRowDetailData => v !== undefined)\n          .slice()\n          .sort((a, b) => columnIds.indexOf(a.valueColumnId) - columnIds.indexOf(b.valueColumnId))\n      })\n    )\n  }\n\n  @ViewChild(OverlayPanel) panel!: OverlayPanel\n  @ViewChild('manageButton') manageButton!: Button\n  trigger: HTMLElement | undefined\n\n  fitlerViewNoSelection: TemplateRef<any> | undefined\n  get _fitlerViewNoSelection(): TemplateRef<any> | undefined {\n    return this.fitlerViewNoSelection\n  }\n\n  filterViewChipContent: TemplateRef<any> | undefined\n  get _filterViewChipContent(): TemplateRef<any> | undefined {\n    return this.filterViewChipContent\n  }\n\n  filterViewShowMoreChip: TemplateRef<any> | undefined\n  get _filterViewShowMoreChip(): TemplateRef<any> | undefined {\n    return this.filterViewShowMoreChip\n  }\n\n  defaultTemplates$: BehaviorSubject<QueryList<PrimeTemplate> | undefined> = new BehaviorSubject<\n    QueryList<PrimeTemplate> | undefined\n  >(undefined)\n  @ViewChildren(PrimeTemplate)\n  set defaultTemplates(value: QueryList<PrimeTemplate> | undefined) {\n    this.defaultTemplates$.next(value)\n  }\n\n  parentTemplates$: BehaviorSubject<QueryList<PrimeTemplate> | null | undefined> = new BehaviorSubject<\n    QueryList<PrimeTemplate> | null | undefined\n  >(undefined)\n  @Input()\n  set templates(value: QueryList<PrimeTemplate> | null | undefined) {\n    this.parentTemplates$.next(value)\n    value?.forEach((item) => {\n      switch (item.getType()) {\n        case 'fitlerViewNoSelection':\n          this.fitlerViewNoSelection = item.template\n          break\n        case 'filterViewChipContent':\n          this.filterViewChipContent = item.template\n          break\n        case 'filterViewShowMoreChip':\n          this.filterViewShowMoreChip = item.template\n          break\n      }\n    })\n  }\n\n  chipTemplates$: Observable<Record<string, TemplateRef<any> | null>> | undefined\n  tableTemplates$: Observable<Record<string, TemplateRef<any> | null>> | undefined\n\n  chipIdSuffix: Array<string> = ['IdFilterChip', 'IdTableFilterCell', 'IdTableCell']\n  chipTemplateNames: Record<ColumnType, Array<string>> = {\n    [ColumnType.DATE]: ['dateFilterChipValue', 'dateTableFilterCell', 'dateTableCell', 'defaultDateValue'],\n    [ColumnType.NUMBER]: ['numberFilterChipValue', 'numberTableFilterCell', 'numberTableCell', 'defaultNumberValue'],\n    [ColumnType.RELATIVE_DATE]: [\n      'relativeDateFilterChipValue',\n      'relativeDateTableFilterCell',\n      'relativeDateTableCell',\n      'defaultRelativeDateValue',\n    ],\n    [ColumnType.TRANSLATION_KEY]: [\n      'translationKeyFilterChipValue',\n      'translationKeyTableFilterCell',\n      'translationKeyTableCell',\n      'defaultTranslationKeyValue',\n    ],\n    [ColumnType.CUSTOM]: ['customFilterChipValue', 'customTableFilterCell', 'customTableCell', 'defaultCustomValue'],\n    [ColumnType.STRING]: ['stringFilterChipValue', 'stringTableFilterCell', 'stringTableCell', 'defaultStringValue'],\n  }\n  chipTemplates: Record<string, Observable<TemplateRef<any> | null>> = {}\n\n  tableIdSuffix: Array<string> = ['IdFilterViewCell', 'IdTableFilterCell', 'IdTableCell']\n  tableTemplateNames: Record<ColumnType, Array<string>> = {\n    [ColumnType.DATE]: ['dateFilterViewCell', 'dateTableFilterCell', 'dateTableCell', 'defaultDateValue'],\n    [ColumnType.NUMBER]: ['numberFilterViewCell', 'numberTableFilterCell', 'numberTableCell', 'defaultNumberValue'],\n    [ColumnType.RELATIVE_DATE]: [\n      'relativeDateFilterViewCell',\n      'relativeDateTableFilterCell',\n      'relativeDateTableCell',\n      'defaultRelativeDateValue',\n    ],\n    [ColumnType.TRANSLATION_KEY]: [\n      'translationKey',\n      'translationKeyTableFilterCell',\n      'translationKeyTableCell',\n      'defaultTranslationKeyValue',\n    ],\n    [ColumnType.CUSTOM]: ['customFilterViewCell', 'customTableFilterCell', 'customTableCell', 'defaultCustomValue'],\n    [ColumnType.STRING]: ['stringFilterViewCell', 'stringTableFilterCell', 'stringTableCell', 'defaultStringValue'],\n  }\n  tableTemplates: Record<string, Observable<TemplateRef<any> | null>> = {}\n\n  getTemplate(\n    column: DataTableColumn,\n    templateNames: Record<ColumnType, Array<string>>,\n    templates: Record<string, Observable<TemplateRef<any> | null>>,\n    idSuffix: Array<string>\n  ): Observable<TemplateRef<any> | null> {\n    if (!templates[column.id]) {\n      templates[column.id] = combineLatest([this.defaultTemplates$, this.parentTemplates$]).pipe(\n        map(([dt, t]) => {\n          const templates = [...(dt ?? []), ...(t ?? [])]\n          const columnTemplate = findTemplate(\n            templates,\n            idSuffix.map((suffix) => column.id + suffix)\n          )?.template\n          if (columnTemplate) {\n            return columnTemplate\n          }\n          return findTemplate(templates, templateNames[column.columnType])?.template ?? null\n        }),\n        debounceTime(50)\n      )\n    }\n    return templates[column.id]\n  }\n\n  onResetFilersClick() {\n    this.filters = []\n    this.filtered.emit([])\n    this.componentStateChanged.emit({\n      filters: [],\n    })\n  }\n\n  onChipRemove(filter: Filter) {\n    const filters = this.filters.filter((f) => f.value !== filter.value)\n    this.filters = filters\n    this.filtered.emit(filters)\n    this.componentStateChanged.emit({\n      filters: filters,\n    })\n  }\n\n  onFilterDelete(row: Row) {\n    const filters = this.filters.filter((f) => !(f.columnId === row['valueColumnId'] && f.value === row['value']))\n    this.filters = filters\n    this.filtered.emit(filters)\n    this.componentStateChanged.emit({\n      filters: filters,\n    })\n  }\n\n  focusTrigger() {\n    if (this.trigger?.id === 'ocxFilterViewShowMore') {\n      this.trigger?.focus()\n    } else {\n      this.manageButton.focus()\n    }\n  }\n\n  showPanel(event: any) {\n    this.trigger = event.srcElement\n    this.panel.toggle(event)\n  }\n\n  getColumnForFilter(filter: Filter, columns: DataTableColumn[]) {\n    return columns.find((c) => c.id === filter.columnId)\n  }\n\n  getColumn(colId: string, columns: DataTableColumn[]) {\n    return columns.find((c) => c.id === colId)\n  }\n\n  resolveFieldData(object: any, key: any) {\n    return ObjectUtils.resolveFieldData(object, key)\n  }\n\n  getRowObjectFromFiterData(filter: Filter) {\n    return {\n      [filter.columnId]: filter.value,\n    }\n  }\n\n  getRowForValueColumn(row: Row): Row {\n    return {\n      id: row.id,\n      [row['valueColumnId'] as string]: row['value'],\n    }\n  }\n}\n","<ng-container *ngIf=\"columns$ | async as columns\">\n  <div *ngIf=\"filters$ | async as filters\" class=\"flex flex-wrap align-items-center gap-2\">\n    <ng-container *ngIf=\"displayMode === 'chips'; else noChipsContent\">\n      <ng-container *ocxIfBreakpoint=\"'desktop'; elseTemplate: noChipsContent\">\n        <ng-container *ngIf=\"selectDisplayedChips(filters, columns) as selectedFilters\">\n          <p-button\n            #chipFilterResetButton\n            id=\"ocxFilterViewReset\"\n            (onClick)=\"onResetFilersClick()\"\n            icon=\"pi pi-eraser\"\n            pTooltip=\"{{ 'OCX_FILTER_VIEW.RESET_FILTERS_BUTTON.DETAIL' | translate }}\"\n            tooltipPosition=\"top\"\n            tooltipEvent=\"hover\"\n            [ariaLabel]=\"'OCX_FILTER_VIEW.RESET_FILTERS_BUTTON.ARIA_LABEL' | translate\"\n          ></p-button>\n          <ng-container *ngIf=\"filters.length <= 0\">\n            <ng-container\n              *ngIf=\"_fitlerViewNoSelection; else defaultNoFilters\"\n              [ngTemplateOutlet]=\"_fitlerViewNoSelection\"\n            >\n            </ng-container>\n            <ng-template #defaultNoFilters>\n              <span id=\"ocxFilterViewNoFilters\">{{ 'OCX_FILTER_VIEW.NO_FILTERS' | translate }}</span>\n            </ng-template>\n          </ng-container>\n          <ng-container *ngIf=\"(chipTemplates$ | async) ?? {} as templates\">\n            <ng-container *ngFor=\"let filter of selectedFilters\">\n              <ng-container *ngIf=\"getColumnForFilter(filter, columns) as column\">\n                <p-chip [removable]=\"true\" (onRemove)=\"onChipRemove(filter)\" [styleClass]=\"chipStyleClass\">\n                  <ng-container\n                    *ngIf=\"_filterViewChipContent; else chipContentTemplate\"\n                    [ngTemplateOutlet]=\"_filterViewChipContent\"\n                    [ngTemplateOutletContext]=\"{\n                filter: filter,\n                column: column,\n                filterValueTemplates: templates,\n                truthyTemplate: truthyTemplate,\n                filterValueTemplate: chipTemplate\n              }\"\n                  >\n                  </ng-container>\n                  <ng-template #chipContentTemplate>\n                    <span\n                      *ngIf=\"columns$ | async as columns\"\n                      style=\"white-space: nowrap\"\n                      class=\"p-chip-text flex flex-nowrap\"\n                      >{{column?.nameKey ?? '' | translate }}:<ng-container\n                        *ngIf=\"filter.filterType === FilterType.EQUAL || !filter.filterType\"\n                        [ngTemplateOutlet]=\"chipTemplate\"\n                        [ngTemplateOutletContext]=\"{\n                        templates: templates,\n                        filter: filter,\n                        column: column\n                      }\"\n                      ></ng-container>\n                      <ng-container *ngIf=\"filter.filterType === FilterType.TRUTHY\">\n                        <ng-container\n                          [ngTemplateOutlet]=\"truthyTemplate\"\n                          [ngTemplateOutletContext]=\"{\n                      value: filter.value\n                    }\"\n                        ></ng-container>\n                      </ng-container>\n                    </span>\n                  </ng-template>\n                </p-chip>\n              </ng-container>\n            </ng-container>\n            <ng-container *ngIf=\"selectedFilters.length < filters.length\">\n              <p-chip\n                #showMoreChip\n                id=\"ocxFilterViewShowMore\"\n                tabindex=\"0\"\n                role=\"button\"\n                (click)=\"showPanel($event)\"\n                class=\"cursor-pointer filter-view-focusable\"\n                (keydown.enter)=\"showPanel($event)\"\n                (keydown.space)=\"showPanel($event)\"\n              >\n                <ng-container\n                  *ngIf=\"_filterViewShowMoreChip; else showMoreChipTemplate\"\n                  [ngTemplateOutlet]=\"_filterViewShowMoreChip\"\n                  [ngTemplateOutletContext]=\"{\n            $implicit: filters.length - selectedFilters.length\n          }\"\n                >\n                </ng-container>\n                <ng-template #showMoreChipTemplate>\n                  <span class=\"p-chip-text flex flex-nowrap\"> +{{filters.length - selectedFilters.length}} </span>\n                </ng-template>\n                <ng-container [ngTemplateOutlet]=\"filterTablePanel\"></ng-container>\n              </p-chip>\n            </ng-container>\n          </ng-container>\n        </ng-container>\n      </ng-container>\n    </ng-container>\n    <ng-template #noChipsContent>\n      <p-button\n        #manageButton\n        id=\"ocxFilterViewManage\"\n        (onClick)=\"showPanel($event)\"\n        icon=\"pi pi-sliders-h\"\n        label=\"{{ 'OCX_FILTER_VIEW.MANAGE_FILTERS_BUTTON.LABEL' | translate }}\"\n        pTooltip=\"{{ 'OCX_FILTER_VIEW.MANAGE_FILTERS_BUTTON.DETAIL' | translate }}\"\n        tooltipPosition=\"top\"\n        tooltipEvent=\"hover\"\n        [badge]=\"filters.length.toString()\"\n        [ariaLabel]=\"'OCX_FILTER_VIEW.MANAGE_FILTERS_BUTTON.ARIA_LABEL' | translate\"\n      ></p-button>\n      <ng-container [ngTemplateOutlet]=\"filterTablePanel\"></ng-container>\n    </ng-template>\n\n    <ng-template #filterTablePanel>\n      <p-overlayPanel *ngIf=\"tableTemplates$ | async as templates\" #op [style]=\"panelStyle\" (onHide)=\"focusTrigger()\">\n        <ng-template pTemplate=\"content\">\n          <div pFocusTrap>\n            <div class=\"flex justify-content-between align-items-center mb-2\">\n              <span class=\"text-2xl font-medium\">{{'OCX_FILTER_VIEW.PANEL_TITLE' | translate}}</span>\n              <div>\n                <p-button\n                  pAutoFocus\n                  [autofocus]=\"true\"\n                  id=\"ocxFilterViewOverlayReset\"\n                  (onClick)=\"onResetFilersClick()\"\n                  icon=\"pi pi-eraser\"\n                  pTooltip=\"{{ 'OCX_FILTER_VIEW.RESET_FILTERS_BUTTON.DETAIL' | translate }}\"\n                  tooltipPosition=\"top\"\n                  tooltipEvent=\"hover\"\n                  [ariaLabel]=\"'OCX_FILTER_VIEW.RESET_FILTERS_BUTTON.ARIA_LABEL' | translate\"\n                ></p-button>\n              </div>\n            </div>\n            <ocx-data-table\n              id=\"ocxFilterViewDataTable\"\n              [rows]=\"(columnFilterDataRows$ | async) ?? []\"\n              [columns]=\"columnFilterTableColumns\"\n              [emptyResultsMessage]=\"'OCX_FILTER_VIEW.NO_FILTERS' | translate\"\n              [paginator]=\"false\"\n              [tableStyle]=\"tableStyle\"\n            >\n              <ng-template pTemplate=\"columnIdCell\" let-rowObject=\"rowObject\" let-column=\"column\">\n                <ng-container\n                  [ngTemplateOutlet]=\"templates[column.id]\"\n                  [ngTemplateOutletContext]=\"{\n            rowObject: rowObject,\n            column: column,\n          }\"\n                >\n                </ng-container>\n              </ng-template>\n              <ng-template pTemplate=\"valueIdCell\" let-rowObject=\"rowObject\" let-column=\"column\">\n                <ng-container *ngIf=\"getColumn(rowObject['valueColumnId'], columns) as valueColumn\">\n                  <ng-container\n                    *ngIf=\"!valueColumn.filterType || valueColumn.filterType === FilterType.EQUAL\"\n                    [ngTemplateOutlet]=\"templates[valueColumn.id]\"\n                    [ngTemplateOutletContext]=\"{\n              rowObject: getRowForValueColumn(rowObject),\n              column: valueColumn\n            }\"\n                  >\n                  </ng-container>\n                  <ng-container\n                    *ngIf=\"valueColumn.filterType === FilterType.TRUTHY\"\n                    [ngTemplateOutlet]=\"truthyTemplate\"\n                    [ngTemplateOutletContext]=\"{\n        value: resolveFieldData(rowObject, column.id)\n      }\"\n                  >\n                  </ng-container>\n                </ng-container>\n              </ng-template>\n              <ng-template pTemplate=\"actionsIdCell\" let-rowObject=\"rowObject\" let-column=\"column\">\n                <div>\n                  <button\n                    pButton\n                    class=\"p-button-rounded p-button-danger p-button-text\"\n                    title=\"{{ 'OCX_FILTER_VIEW.TABLE.REMOVE_FILTER_TITLE' | translate }}\"\n                    [attr.aria-label]=\"'OCX_FILTER_VIEW.TABLE.REMOVE_FILTER_ARIA_LABEL' | translate\"\n                    icon=\"pi pi-trash\"\n                    (click)=\"onFilterDelete(rowObject)\"\n                  ></button>\n                </div>\n              </ng-template>\n            </ocx-data-table>\n          </div>\n        </ng-template>\n      </p-overlayPanel>\n    </ng-template>\n  </div>\n</ng-container>\n\n<ng-template #chipTemplate let-templates=\"templates\" let-filter=\"filter\" let-column=\"column\">\n  <ng-container\n    *ngIf=\"templates[column.id] as template\"\n    [ngTemplateOutlet]=\"template\"\n    [ngTemplateOutletContext]=\"{\n            rowObject: getRowObjectFromFiterData(filter),\n            column: column\n          }\"\n  >\n  </ng-container>\n</ng-template>\n\n<ng-template #truthyTemplate let-value=\"value\">\n  <ng-container *ngIf=\"value\"> {{'OCX_FILTER_VIEW.FILTER_YES' | translate}} </ng-container>\n  <ng-container *ngIf=\"!value\"> {{'OCX_FILTER_VIEW.FILTER_NO' | translate}} </ng-container>\n</ng-template>\n\n<ng-template pTemplate=\"defaultStringValue\" let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container> {{ resolveFieldData(rowObject, column.id)}} </ng-container>\n</ng-template>\n\n<ng-template pTemplate=\"defaultNumberValue\" let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container> {{ resolveFieldData(rowObject, column.id) | number }} </ng-container>\n</ng-template>\n\n<ng-template pTemplate=\"defaultCustomValue\" let-rowObject=\"rowObject\" let-column=\"column\"> </ng-template>\n\n<ng-template pTemplate=\"defaultDateValue\" let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container> {{ resolveFieldData(rowObject, column.id) | date: column.dateFormat ?? 'medium' }} </ng-container>\n</ng-template>\n\n<ng-template pTemplate=\"defaultRelativeDateValue\" let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container>\n    {{ 'OCX_DATA_TABLE.EDITED' | translate }} {{ resolveFieldData(rowObject, column.id) | timeago }}\n  </ng-container>\n</ng-template>\n\n<ng-template pTemplate=\"defaultTranslationKeyValue\" let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container> {{ resolveFieldData(rowObject, column.id) | translate }}</ng-container>\n</ng-template>\n"]}
263
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-view.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/filter-view/filter-view.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/filter-view/filter-view.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,EAGN,SAAS,EACT,YAAY,GACb,MAAM,eAAe,CAAA;AACtB,OAAO,EAAU,UAAU,EAAE,MAAM,0BAA0B,CAAA;AAE7D,OAAO,EAAE,eAAe,EAAc,aAAa,EAAE,YAAY,EAAE,GAAG,EAAE,MAAM,MAAM,CAAA;AACpF,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAA;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AACrD,OAAO,EAAE,KAAK,EAAE,MAAM,0BAA0B,CAAA;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AAEnD,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;;;;;;;;;;;;;AAqBvC,MAAM,OAAO,mBAAmB;IALhC;QAME,eAAU,GAAG,UAAU,CAAA;QACvB,eAAU,GAAG,UAAU,CAAA;QACvB,aAAQ,GAAG,IAAI,eAAe,CAAW,EAAE,CAAC,CAAA;QAQ5C,aAAQ,GAAG,IAAI,eAAe,CAAoB,EAAE,CAAC,CAAA;QAsB5C,gBAAW,GAA0B,QAAQ,CAAA;QAC7C,yBAAoB,GAAgE,CAAC,OAAO,EAAE,EAAE,CACvG,KAAK,CAAC,OAAO,EAAE,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QAC7B,mBAAc,GAAG,EAAE,CAAA;QACnB,eAAU,GAA6B,EAAE,YAAY,EAAE,MAAM,EAAE,CAAA;QAC/D,eAAU,GAA6B,EAAE,WAAW,EAAE,KAAK,EAAE,CAAA;QAE5D,aAAQ,GAA2B,IAAI,YAAY,EAAE,CAAA;QACrD,0BAAqB,GAA2C,IAAI,YAAY,EAAE,CAAA;QAE5F,6BAAwB,GAAsB;YAC5C;gBACE,EAAE,EAAE,QAAQ;gBACZ,UAAU,EAAE,UAAU,CAAC,eAAe;gBACtC,OAAO,EAAE,mCAAmC;aAC7C;YACD,EAAE,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,CAAC,MAAM,EAAE,OAAO,EAAE,6BAA6B,EAAE;YACtF;gBACE,EAAE,EAAE,SAAS;gBACb,UAAU,EAAE,UAAU,CAAC,MAAM;gBAC7B,OAAO,EAAE,+BAA+B;aACzC;SACF,CAAA;QA8CD,sBAAiB,GAA0D,IAAI,eAAe,CAE5F,SAAS,CAAC,CAAA;QAMZ,qBAAgB,GAAiE,IAAI,eAAe,CAElG,SAAS,CAAC,CAAA;QAsBZ,iBAAY,GAAkB,CAAC,cAAc,EAAE,mBAAmB,EAAE,aAAa,CAAC,CAAA;QAClF,sBAAiB,GAAsC;YACrD,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,qBAAqB,EAAE,qBAAqB,EAAE,eAAe,EAAE,kBAAkB,CAAC;YACtG,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,uBAAuB,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,oBAAoB,CAAC;YAChH,CAAC,UAAU,CAAC,aAAa,CAAC,EAAE;gBAC1B,6BAA6B;gBAC7B,6BAA6B;gBAC7B,uBAAuB;gBACvB,0BAA0B;aAC3B;YACD,CAAC,UAAU,CAAC,eAAe,CAAC,EAAE;gBAC5B,+BAA+B;gBAC/B,+BAA+B;gBAC/B,yBAAyB;gBACzB,4BAA4B;aAC7B;YACD,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,uBAAuB,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,oBAAoB,CAAC;YAChH,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,uBAAuB,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,oBAAoB,CAAC;SACjH,CAAA;QACD,kBAAa,GAAwD,EAAE,CAAA;QAEvE,kBAAa,GAAkB,CAAC,kBAAkB,EAAE,mBAAmB,EAAE,aAAa,CAAC,CAAA;QACvF,uBAAkB,GAAsC;YACtD,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,oBAAoB,EAAE,qBAAqB,EAAE,eAAe,EAAE,kBAAkB,CAAC;YACrG,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,sBAAsB,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,oBAAoB,CAAC;YAC/G,CAAC,UAAU,CAAC,aAAa,CAAC,EAAE;gBAC1B,4BAA4B;gBAC5B,6BAA6B;gBAC7B,uBAAuB;gBACvB,0BAA0B;aAC3B;YACD,CAAC,UAAU,CAAC,eAAe,CAAC,EAAE;gBAC5B,gBAAgB;gBAChB,+BAA+B;gBAC/B,yBAAyB;gBACzB,4BAA4B;aAC7B;YACD,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,sBAAsB,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,oBAAoB,CAAC;YAC/G,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,sBAAsB,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,oBAAoB,CAAC;SAChH,CAAA;QACD,mBAAc,GAAwD,EAAE,CAAA;KA0FzE;IAnQC,IACI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAA;IACjC,CAAC;IACD,IAAI,OAAO,CAAC,KAAe;QACzB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAC3B,CAAC;IAED,IACI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAA;IACjC,CAAC;IACD,IAAI,OAAO,CAAC,KAAwB;QAClC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACzB,MAAM,OAAO,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,EAAE,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAA;QACpH,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC,IAAI,CAC/C,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAC5E,CAAA;QAED,MAAM,oBAAoB,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAA;QACxE,IAAI,CAAC,eAAe,GAAG,aAAa,CAClC,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAC7B,IAAI,CAAC,WAAW,CAAC,CAAC,EAAE,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,aAAa,CAAC,CACtF,CACF,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IACpG,CAAC;IA4BD,QAAQ;QACN,IAAI,CAAC,qBAAqB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAC7E,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,EAAE;YACzB,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;YAC1C,OAAO,OAAO;iBACX,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBACT,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC,EAAE,OAAO,CAAC,CAAA;gBACxD,IAAI,CAAC,YAAY;oBAAE,OAAO,SAAS,CAAA;gBACnC,OAAO;oBACL,EAAE,EAAE,GAAG,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,KAAK,EAAE;oBAC9B,MAAM,EAAE,YAAY,CAAC,OAAO;oBAC5B,KAAK,EAAE,CAAC,CAAC,KAAK;oBACd,aAAa,EAAE,YAAY,CAAC,EAAE;iBACG,CAAA;YACrC,CAAC,CAAC;iBACD,MAAM,CAAC,CAAC,CAAC,EAAgC,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC;iBAC5D,KAAK,EAAE;iBACP,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,GAAG,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAA;QAC5F,CAAC,CAAC,CACH,CAAA;QACD,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;YAC9B,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC,CAAA;IACJ,CAAC;IAOD,IAAI,sBAAsB;QACxB,OAAO,IAAI,CAAC,qBAAqB,CAAA;IACnC,CAAC;IAGD,IAAI,sBAAsB;QACxB,OAAO,IAAI,CAAC,qBAAqB,CAAA;IACnC,CAAC;IAGD,IAAI,uBAAuB;QACzB,OAAO,IAAI,CAAC,sBAAsB,CAAA;IACpC,CAAC;IAKD,IACI,gBAAgB,CAAC,KAA2C;QAC9D,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IACpC,CAAC;IAKD,IACI,SAAS,CAAC,KAAkD;QAC9D,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACjC,KAAK,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACtB,QAAQ,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;gBACvB,KAAK,uBAAuB;oBAC1B,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,QAAQ,CAAA;oBAC1C,MAAK;gBACP,KAAK,uBAAuB;oBAC1B,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,QAAQ,CAAA;oBAC1C,MAAK;gBACP,KAAK,wBAAwB;oBAC3B,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,QAAQ,CAAA;oBAC3C,MAAK;YACT,CAAC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IA+CD,WAAW,CACT,MAAuB,EACvB,aAAgD,EAChD,SAA8D,EAC9D,QAAuB;QAEvB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC;YAC1B,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CACxF,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE;gBACd,MAAM,SAAS,GAAG,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAA;gBAC/C,MAAM,cAAc,GAAG,YAAY,CACjC,SAAS,EACT,QAAQ,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,GAAG,MAAM,CAAC,CAC7C,EAAE,QAAQ,CAAA;gBACX,IAAI,cAAc,EAAE,CAAC;oBACnB,OAAO,cAAc,CAAA;gBACvB,CAAC;gBACD,OAAO,YAAY,CAAC,SAAS,EAAE,aAAa,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,EAAE,QAAQ,IAAI,IAAI,CAAA;YACpF,CAAC,CAAC,EACF,YAAY,CAAC,EAAE,CAAC,CACjB,CAAA;QACH,CAAC;QACD,OAAO,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;IAC7B,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAA;QACjB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QACtB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;YAC9B,OAAO,EAAE,EAAE;SACZ,CAAC,CAAA;IACJ,CAAC;IAED,YAAY,CAAC,MAAc;QACzB,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,MAAM,CAAC,KAAK,CAAC,CAAA;QACpE,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAC3B,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;YAC9B,OAAO,EAAE,OAAO;SACjB,CAAC,CAAA;IACJ,CAAC;IAED,cAAc,CAAC,GAAQ;QACrB,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,KAAK,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,KAAK,KAAK,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAC9G,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAC3B,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;YAC9B,OAAO,EAAE,OAAO;SACjB,CAAC,CAAA;IACJ,CAAC;IAED,YAAY;QACV,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,KAAK,uBAAuB,EAAE,CAAC;YACjD,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,CAAA;QACvB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAA;QAC3B,CAAC;IACH,CAAC;IAED,SAAS,CAAC,KAAU;QAClB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,UAAU,CAAA;QAC/B,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;IAC1B,CAAC;IAED,kBAAkB,CAAC,MAAc,EAAE,OAA0B;QAC3D,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAA;IACtD,CAAC;IAED,SAAS,CAAC,KAAa,EAAE,OAA0B;QACjD,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,CAAA;IAC5C,CAAC;IAED,gBAAgB,CAAC,MAAW,EAAE,GAAQ;QACpC,OAAO,WAAW,CAAC,gBAAgB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAClD,CAAC;IAED,yBAAyB,CAAC,MAAc;QACtC,OAAO;YACL,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,KAAK;SAChC,CAAA;IACH,CAAC;IAED,oBAAoB,CAAC,GAAQ;QAC3B,OAAO;YACL,EAAE,EAAE,GAAG,CAAC,EAAE;YACV,CAAC,GAAG,CAAC,eAAe,CAAW,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC;SAC/C,CAAA;IACH,CAAC;8GAtQU,mBAAmB;kGAAnB,mBAAmB,6ZAkFnB,YAAY,qKAsBT,aAAa,gDClJ7B,8rVAwOA;;2FD9La,mBAAmB;kBAL/B,SAAS;+BACE,iBAAiB;8BASvB,OAAO;sBADV,KAAK;gBASF,OAAO;sBADV,KAAK;gBAqBG,WAAW;sBAAnB,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBAEG,cAAc;sBAAtB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAEI,QAAQ;sBAAjB,MAAM;gBACG,qBAAqB;sBAA9B,MAAM;gBAyCkB,KAAK;sBAA7B,SAAS;uBAAC,YAAY;gBACI,YAAY;sBAAtC,SAAS;uBAAC,cAAc;gBAsBrB,gBAAgB;sBADnB,YAAY;uBAAC,aAAa;gBASvB,SAAS;sBADZ,KAAK","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core'\nimport { Filter, FilterType } from '../../model/filter.model'\nimport { DataTableColumn } from '../../model/data-table-column.model'\nimport { BehaviorSubject, Observable, combineLatest, debounceTime, map } from 'rxjs'\nimport { ColumnType } from '../../model/column-type.model'\nimport { PrimeTemplate } from 'primeng/api'\nimport { findTemplate } from '../../utils/template.utils'\nimport { ObjectUtils } from '../../utils/objectutils'\nimport { limit } from '../../utils/filter.utils'\nimport { OverlayPanel } from 'primeng/overlaypanel'\nimport { Row } from '../data-table/data-table.component'\nimport { Button } from 'primeng/button'\n\nexport type FilterViewDisplayMode = 'chips' | 'button'\nexport type FilterViewRowDisplayData = {\n  id: string\n  column: string\n  value: unknown\n}\nexport type FilterViewRowDetailData = FilterViewRowDisplayData & {\n  valueColumnId: string\n}\n\nexport interface FilterViewComponentState {\n  filters?: Filter[]\n}\n\n@Component({\n  selector: 'ocx-filter-view',\n  templateUrl: './filter-view.component.html',\n  styleUrls: ['./filter-view.component.scss'],\n})\nexport class FilterViewComponent implements OnInit {\n  ColumnType = ColumnType\n  FilterType = FilterType\n  filters$ = new BehaviorSubject<Filter[]>([])\n  @Input()\n  get filters(): Filter[] {\n    return this.filters$.getValue()\n  }\n  set filters(value: Filter[]) {\n    this.filters$.next(value)\n  }\n  columns$ = new BehaviorSubject<DataTableColumn[]>([])\n  @Input()\n  get columns(): DataTableColumn[] {\n    return this.columns$.getValue()\n  }\n  set columns(value: DataTableColumn[]) {\n    this.columns$.next(value)\n    const chipObs = value.map((c) => this.getTemplate(c, this.chipTemplateNames, this.chipTemplates, this.chipIdSuffix))\n    this.chipTemplates$ = combineLatest(chipObs).pipe(\n      map((values) => Object.fromEntries(value.map((c, i) => [c.id, values[i]])))\n    )\n\n    const tableTemplateColumns = value.concat(this.columnFilterTableColumns)\n    this.tableTemplates$ = combineLatest(\n      tableTemplateColumns.map((c) =>\n        this.getTemplate(c, this.tableTemplateNames, this.tableTemplates, this.tableIdSuffix)\n      )\n    ).pipe(map((values) => Object.fromEntries(tableTemplateColumns.map((c, i) => [c.id, values[i]]))))\n  }\n\n  columnFilterDataRows$: Observable<FilterViewRowDisplayData[]> | undefined\n\n  @Input() displayMode: FilterViewDisplayMode = 'button'\n  @Input() selectDisplayedChips: (filters: Filter[], columns: DataTableColumn[]) => Filter[] = (filters) =>\n    limit(filters, 3, { reverse: true })\n  @Input() chipStyleClass = ''\n  @Input() tableStyle: { [klass: string]: any } = { 'max-height': '50vh' }\n  @Input() panelStyle: { [klass: string]: any } = { 'max-width': '90%' }\n\n  @Output() filtered: EventEmitter<Filter[]> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<FilterViewComponentState> = new EventEmitter()\n\n  columnFilterTableColumns: DataTableColumn[] = [\n    {\n      id: 'column',\n      columnType: ColumnType.TRANSLATION_KEY,\n      nameKey: 'OCX_FILTER_VIEW.TABLE.COLUMN_NAME',\n    },\n    { id: 'value', columnType: ColumnType.STRING, nameKey: 'OCX_FILTER_VIEW.TABLE.VALUE' },\n    {\n      id: 'actions',\n      columnType: ColumnType.STRING,\n      nameKey: 'OCX_FILTER_VIEW.TABLE.ACTIONS',\n    },\n  ]\n\n  ngOnInit(): void {\n    this.columnFilterDataRows$ = combineLatest([this.filters$, this.columns$]).pipe(\n      map(([filters, columns]) => {\n        const columnIds = columns.map((c) => c.id)\n        return filters\n          .map((f) => {\n            const filterColumn = this.getColumnForFilter(f, columns)\n            if (!filterColumn) return undefined\n            return {\n              id: `${f.columnId}-${f.value}`,\n              column: filterColumn.nameKey,\n              value: f.value,\n              valueColumnId: filterColumn.id,\n            } satisfies FilterViewRowDetailData\n          })\n          .filter((v): v is FilterViewRowDetailData => v !== undefined)\n          .slice()\n          .sort((a, b) => columnIds.indexOf(a.valueColumnId) - columnIds.indexOf(b.valueColumnId))\n      })\n    )\n    this.componentStateChanged.emit({\n      filters: this.filters,\n    })\n  }\n\n  @ViewChild(OverlayPanel) panel!: OverlayPanel\n  @ViewChild('manageButton') manageButton!: Button\n  trigger: HTMLElement | undefined\n\n  fitlerViewNoSelection: TemplateRef<any> | undefined\n  get _fitlerViewNoSelection(): TemplateRef<any> | undefined {\n    return this.fitlerViewNoSelection\n  }\n\n  filterViewChipContent: TemplateRef<any> | undefined\n  get _filterViewChipContent(): TemplateRef<any> | undefined {\n    return this.filterViewChipContent\n  }\n\n  filterViewShowMoreChip: TemplateRef<any> | undefined\n  get _filterViewShowMoreChip(): TemplateRef<any> | undefined {\n    return this.filterViewShowMoreChip\n  }\n\n  defaultTemplates$: BehaviorSubject<QueryList<PrimeTemplate> | undefined> = new BehaviorSubject<\n    QueryList<PrimeTemplate> | undefined\n  >(undefined)\n  @ViewChildren(PrimeTemplate)\n  set defaultTemplates(value: QueryList<PrimeTemplate> | undefined) {\n    this.defaultTemplates$.next(value)\n  }\n\n  parentTemplates$: BehaviorSubject<QueryList<PrimeTemplate> | null | undefined> = new BehaviorSubject<\n    QueryList<PrimeTemplate> | null | undefined\n  >(undefined)\n  @Input()\n  set templates(value: QueryList<PrimeTemplate> | null | undefined) {\n    this.parentTemplates$.next(value)\n    value?.forEach((item) => {\n      switch (item.getType()) {\n        case 'fitlerViewNoSelection':\n          this.fitlerViewNoSelection = item.template\n          break\n        case 'filterViewChipContent':\n          this.filterViewChipContent = item.template\n          break\n        case 'filterViewShowMoreChip':\n          this.filterViewShowMoreChip = item.template\n          break\n      }\n    })\n  }\n\n  chipTemplates$: Observable<Record<string, TemplateRef<any> | null>> | undefined\n  tableTemplates$: Observable<Record<string, TemplateRef<any> | null>> | undefined\n\n  chipIdSuffix: Array<string> = ['IdFilterChip', 'IdTableFilterCell', 'IdTableCell']\n  chipTemplateNames: Record<ColumnType, Array<string>> = {\n    [ColumnType.DATE]: ['dateFilterChipValue', 'dateTableFilterCell', 'dateTableCell', 'defaultDateValue'],\n    [ColumnType.NUMBER]: ['numberFilterChipValue', 'numberTableFilterCell', 'numberTableCell', 'defaultNumberValue'],\n    [ColumnType.RELATIVE_DATE]: [\n      'relativeDateFilterChipValue',\n      'relativeDateTableFilterCell',\n      'relativeDateTableCell',\n      'defaultRelativeDateValue',\n    ],\n    [ColumnType.TRANSLATION_KEY]: [\n      'translationKeyFilterChipValue',\n      'translationKeyTableFilterCell',\n      'translationKeyTableCell',\n      'defaultTranslationKeyValue',\n    ],\n    [ColumnType.CUSTOM]: ['customFilterChipValue', 'customTableFilterCell', 'customTableCell', 'defaultCustomValue'],\n    [ColumnType.STRING]: ['stringFilterChipValue', 'stringTableFilterCell', 'stringTableCell', 'defaultStringValue'],\n  }\n  chipTemplates: Record<string, Observable<TemplateRef<any> | null>> = {}\n\n  tableIdSuffix: Array<string> = ['IdFilterViewCell', 'IdTableFilterCell', 'IdTableCell']\n  tableTemplateNames: Record<ColumnType, Array<string>> = {\n    [ColumnType.DATE]: ['dateFilterViewCell', 'dateTableFilterCell', 'dateTableCell', 'defaultDateValue'],\n    [ColumnType.NUMBER]: ['numberFilterViewCell', 'numberTableFilterCell', 'numberTableCell', 'defaultNumberValue'],\n    [ColumnType.RELATIVE_DATE]: [\n      'relativeDateFilterViewCell',\n      'relativeDateTableFilterCell',\n      'relativeDateTableCell',\n      'defaultRelativeDateValue',\n    ],\n    [ColumnType.TRANSLATION_KEY]: [\n      'translationKey',\n      'translationKeyTableFilterCell',\n      'translationKeyTableCell',\n      'defaultTranslationKeyValue',\n    ],\n    [ColumnType.CUSTOM]: ['customFilterViewCell', 'customTableFilterCell', 'customTableCell', 'defaultCustomValue'],\n    [ColumnType.STRING]: ['stringFilterViewCell', 'stringTableFilterCell', 'stringTableCell', 'defaultStringValue'],\n  }\n  tableTemplates: Record<string, Observable<TemplateRef<any> | null>> = {}\n\n  getTemplate(\n    column: DataTableColumn,\n    templateNames: Record<ColumnType, Array<string>>,\n    templates: Record<string, Observable<TemplateRef<any> | null>>,\n    idSuffix: Array<string>\n  ): Observable<TemplateRef<any> | null> {\n    if (!templates[column.id]) {\n      templates[column.id] = combineLatest([this.defaultTemplates$, this.parentTemplates$]).pipe(\n        map(([dt, t]) => {\n          const templates = [...(dt ?? []), ...(t ?? [])]\n          const columnTemplate = findTemplate(\n            templates,\n            idSuffix.map((suffix) => column.id + suffix)\n          )?.template\n          if (columnTemplate) {\n            return columnTemplate\n          }\n          return findTemplate(templates, templateNames[column.columnType])?.template ?? null\n        }),\n        debounceTime(50)\n      )\n    }\n    return templates[column.id]\n  }\n\n  onResetFilersClick() {\n    this.filters = []\n    this.filtered.emit([])\n    this.componentStateChanged.emit({\n      filters: [],\n    })\n  }\n\n  onChipRemove(filter: Filter) {\n    const filters = this.filters.filter((f) => f.value !== filter.value)\n    this.filters = filters\n    this.filtered.emit(filters)\n    this.componentStateChanged.emit({\n      filters: filters,\n    })\n  }\n\n  onFilterDelete(row: Row) {\n    const filters = this.filters.filter((f) => !(f.columnId === row['valueColumnId'] && f.value === row['value']))\n    this.filters = filters\n    this.filtered.emit(filters)\n    this.componentStateChanged.emit({\n      filters: filters,\n    })\n  }\n\n  focusTrigger() {\n    if (this.trigger?.id === 'ocxFilterViewShowMore') {\n      this.trigger?.focus()\n    } else {\n      this.manageButton.focus()\n    }\n  }\n\n  showPanel(event: any) {\n    this.trigger = event.srcElement\n    this.panel.toggle(event)\n  }\n\n  getColumnForFilter(filter: Filter, columns: DataTableColumn[]) {\n    return columns.find((c) => c.id === filter.columnId)\n  }\n\n  getColumn(colId: string, columns: DataTableColumn[]) {\n    return columns.find((c) => c.id === colId)\n  }\n\n  resolveFieldData(object: any, key: any) {\n    return ObjectUtils.resolveFieldData(object, key)\n  }\n\n  getRowObjectFromFiterData(filter: Filter) {\n    return {\n      [filter.columnId]: filter.value,\n    }\n  }\n\n  getRowForValueColumn(row: Row): Row {\n    return {\n      id: row.id,\n      [row['valueColumnId'] as string]: row['value'],\n    }\n  }\n}\n","<ng-container *ngIf=\"columns$ | async as columns\">\n  <div *ngIf=\"filters$ | async as filters\" class=\"flex flex-wrap align-items-center gap-2\">\n    <ng-container *ngIf=\"displayMode === 'chips'; else noChipsContent\">\n      <ng-container *ocxIfBreakpoint=\"'desktop'; elseTemplate: noChipsContent\">\n        <ng-container *ngIf=\"selectDisplayedChips(filters, columns) as selectedFilters\">\n          <p-button\n            #chipFilterResetButton\n            id=\"ocxFilterViewReset\"\n            (onClick)=\"onResetFilersClick()\"\n            icon=\"pi pi-eraser\"\n            pTooltip=\"{{ 'OCX_FILTER_VIEW.RESET_FILTERS_BUTTON.DETAIL' | translate }}\"\n            tooltipPosition=\"top\"\n            tooltipEvent=\"hover\"\n            [ariaLabel]=\"'OCX_FILTER_VIEW.RESET_FILTERS_BUTTON.ARIA_LABEL' | translate\"\n          ></p-button>\n          <ng-container *ngIf=\"filters.length <= 0\">\n            <ng-container\n              *ngIf=\"_fitlerViewNoSelection; else defaultNoFilters\"\n              [ngTemplateOutlet]=\"_fitlerViewNoSelection\"\n            >\n            </ng-container>\n            <ng-template #defaultNoFilters>\n              <span id=\"ocxFilterViewNoFilters\">{{ 'OCX_FILTER_VIEW.NO_FILTERS' | translate }}</span>\n            </ng-template>\n          </ng-container>\n          <ng-container *ngIf=\"(chipTemplates$ | async) ?? {} as templates\">\n            <ng-container *ngFor=\"let filter of selectedFilters\">\n              <ng-container *ngIf=\"getColumnForFilter(filter, columns) as column\">\n                <p-chip [removable]=\"true\" (onRemove)=\"onChipRemove(filter)\" [styleClass]=\"chipStyleClass\">\n                  <ng-container\n                    *ngIf=\"_filterViewChipContent; else chipContentTemplate\"\n                    [ngTemplateOutlet]=\"_filterViewChipContent\"\n                    [ngTemplateOutletContext]=\"{\n                filter: filter,\n                column: column,\n                filterValueTemplates: templates,\n                truthyTemplate: truthyTemplate,\n                filterValueTemplate: chipTemplate\n              }\"\n                  >\n                  </ng-container>\n                  <ng-template #chipContentTemplate>\n                    <span\n                      *ngIf=\"columns$ | async as columns\"\n                      style=\"white-space: nowrap\"\n                      class=\"p-chip-text flex flex-nowrap\"\n                      >{{column?.nameKey ?? '' | translate }}:<ng-container\n                        *ngIf=\"filter.filterType === FilterType.EQUAL || !filter.filterType\"\n                        [ngTemplateOutlet]=\"chipTemplate\"\n                        [ngTemplateOutletContext]=\"{\n                        templates: templates,\n                        filter: filter,\n                        column: column\n                      }\"\n                      ></ng-container>\n                      <ng-container *ngIf=\"filter.filterType === FilterType.TRUTHY\">\n                        <ng-container\n                          [ngTemplateOutlet]=\"truthyTemplate\"\n                          [ngTemplateOutletContext]=\"{\n                      value: filter.value\n                    }\"\n                        ></ng-container>\n                      </ng-container>\n                    </span>\n                  </ng-template>\n                </p-chip>\n              </ng-container>\n            </ng-container>\n            <ng-container *ngIf=\"selectedFilters.length < filters.length\">\n              <p-chip\n                #showMoreChip\n                id=\"ocxFilterViewShowMore\"\n                tabindex=\"0\"\n                role=\"button\"\n                (click)=\"showPanel($event)\"\n                class=\"cursor-pointer filter-view-focusable\"\n                (keydown.enter)=\"showPanel($event)\"\n                (keydown.space)=\"showPanel($event)\"\n              >\n                <ng-container\n                  *ngIf=\"_filterViewShowMoreChip; else showMoreChipTemplate\"\n                  [ngTemplateOutlet]=\"_filterViewShowMoreChip\"\n                  [ngTemplateOutletContext]=\"{\n            $implicit: filters.length - selectedFilters.length\n          }\"\n                >\n                </ng-container>\n                <ng-template #showMoreChipTemplate>\n                  <span class=\"p-chip-text flex flex-nowrap\"> +{{filters.length - selectedFilters.length}} </span>\n                </ng-template>\n                <ng-container [ngTemplateOutlet]=\"filterTablePanel\"></ng-container>\n              </p-chip>\n            </ng-container>\n          </ng-container>\n        </ng-container>\n      </ng-container>\n    </ng-container>\n    <ng-template #noChipsContent>\n      <p-button\n        #manageButton\n        id=\"ocxFilterViewManage\"\n        (onClick)=\"showPanel($event)\"\n        icon=\"pi pi-sliders-h\"\n        label=\"{{ 'OCX_FILTER_VIEW.MANAGE_FILTERS_BUTTON.LABEL' | translate }}\"\n        pTooltip=\"{{ 'OCX_FILTER_VIEW.MANAGE_FILTERS_BUTTON.DETAIL' | translate }}\"\n        tooltipPosition=\"top\"\n        tooltipEvent=\"hover\"\n        [badge]=\"filters.length.toString()\"\n        [ariaLabel]=\"'OCX_FILTER_VIEW.MANAGE_FILTERS_BUTTON.ARIA_LABEL' | translate\"\n      ></p-button>\n      <ng-container [ngTemplateOutlet]=\"filterTablePanel\"></ng-container>\n    </ng-template>\n\n    <ng-template #filterTablePanel>\n      <p-overlayPanel *ngIf=\"tableTemplates$ | async as templates\" #op [style]=\"panelStyle\" (onHide)=\"focusTrigger()\">\n        <ng-template pTemplate=\"content\">\n          <div pFocusTrap>\n            <div class=\"flex justify-content-between align-items-center mb-2\">\n              <span class=\"text-2xl font-medium\">{{'OCX_FILTER_VIEW.PANEL_TITLE' | translate}}</span>\n              <div>\n                <p-button\n                  pAutoFocus\n                  [autofocus]=\"true\"\n                  id=\"ocxFilterViewOverlayReset\"\n                  (onClick)=\"onResetFilersClick()\"\n                  icon=\"pi pi-eraser\"\n                  pTooltip=\"{{ 'OCX_FILTER_VIEW.RESET_FILTERS_BUTTON.DETAIL' | translate }}\"\n                  tooltipPosition=\"top\"\n                  tooltipEvent=\"hover\"\n                  [ariaLabel]=\"'OCX_FILTER_VIEW.RESET_FILTERS_BUTTON.ARIA_LABEL' | translate\"\n                ></p-button>\n              </div>\n            </div>\n            <ocx-data-table\n              id=\"ocxFilterViewDataTable\"\n              [rows]=\"(columnFilterDataRows$ | async) ?? []\"\n              [columns]=\"columnFilterTableColumns\"\n              [emptyResultsMessage]=\"'OCX_FILTER_VIEW.NO_FILTERS' | translate\"\n              [paginator]=\"false\"\n              [tableStyle]=\"tableStyle\"\n            >\n              <ng-template pTemplate=\"columnIdCell\" let-rowObject=\"rowObject\" let-column=\"column\">\n                <ng-container\n                  [ngTemplateOutlet]=\"templates[column.id]\"\n                  [ngTemplateOutletContext]=\"{\n            rowObject: rowObject,\n            column: column,\n          }\"\n                >\n                </ng-container>\n              </ng-template>\n              <ng-template pTemplate=\"valueIdCell\" let-rowObject=\"rowObject\" let-column=\"column\">\n                <ng-container *ngIf=\"getColumn(rowObject['valueColumnId'], columns) as valueColumn\">\n                  <ng-container\n                    *ngIf=\"!valueColumn.filterType || valueColumn.filterType === FilterType.EQUAL\"\n                    [ngTemplateOutlet]=\"templates[valueColumn.id]\"\n                    [ngTemplateOutletContext]=\"{\n              rowObject: getRowForValueColumn(rowObject),\n              column: valueColumn\n            }\"\n                  >\n                  </ng-container>\n                  <ng-container\n                    *ngIf=\"valueColumn.filterType === FilterType.TRUTHY\"\n                    [ngTemplateOutlet]=\"truthyTemplate\"\n                    [ngTemplateOutletContext]=\"{\n        value: resolveFieldData(rowObject, column.id)\n      }\"\n                  >\n                  </ng-container>\n                </ng-container>\n              </ng-template>\n              <ng-template pTemplate=\"actionsIdCell\" let-rowObject=\"rowObject\" let-column=\"column\">\n                <div>\n                  <button\n                    pButton\n                    class=\"p-button-rounded p-button-danger p-button-text\"\n                    title=\"{{ 'OCX_FILTER_VIEW.TABLE.REMOVE_FILTER_TITLE' | translate }}\"\n                    [attr.aria-label]=\"'OCX_FILTER_VIEW.TABLE.REMOVE_FILTER_ARIA_LABEL' | translate\"\n                    icon=\"pi pi-trash\"\n                    (click)=\"onFilterDelete(rowObject)\"\n                  ></button>\n                </div>\n              </ng-template>\n            </ocx-data-table>\n          </div>\n        </ng-template>\n      </p-overlayPanel>\n    </ng-template>\n  </div>\n</ng-container>\n\n<ng-template #chipTemplate let-templates=\"templates\" let-filter=\"filter\" let-column=\"column\">\n  <ng-container\n    *ngIf=\"templates[column.id] as template\"\n    [ngTemplateOutlet]=\"template\"\n    [ngTemplateOutletContext]=\"{\n            rowObject: getRowObjectFromFiterData(filter),\n            column: column\n          }\"\n  >\n  </ng-container>\n</ng-template>\n\n<ng-template #truthyTemplate let-value=\"value\">\n  <ng-container *ngIf=\"value\"> {{'OCX_FILTER_VIEW.FILTER_YES' | translate}} </ng-container>\n  <ng-container *ngIf=\"!value\"> {{'OCX_FILTER_VIEW.FILTER_NO' | translate}} </ng-container>\n</ng-template>\n\n<ng-template pTemplate=\"defaultStringValue\" let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container> {{ resolveFieldData(rowObject, column.id)}} </ng-container>\n</ng-template>\n\n<ng-template pTemplate=\"defaultNumberValue\" let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container> {{ resolveFieldData(rowObject, column.id) | number }} </ng-container>\n</ng-template>\n\n<ng-template pTemplate=\"defaultCustomValue\" let-rowObject=\"rowObject\" let-column=\"column\"> </ng-template>\n\n<ng-template pTemplate=\"defaultDateValue\" let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container> {{ resolveFieldData(rowObject, column.id) | date: column.dateFormat ?? 'medium' }} </ng-container>\n</ng-template>\n\n<ng-template pTemplate=\"defaultRelativeDateValue\" let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container>\n    {{ 'OCX_DATA_TABLE.EDITED' | translate }} {{ resolveFieldData(rowObject, column.id) | timeago }}\n  </ng-container>\n</ng-template>\n\n<ng-template pTemplate=\"defaultTranslationKeyValue\" let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container> {{ resolveFieldData(rowObject, column.id) | translate }}</ng-container>\n</ng-template>\n"]}