@onecx/angular-accelerator 5.23.5 → 5.24.0

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.
@@ -667,4 +667,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
667
667
  type: ContentChildren,
668
668
  args: [PrimeTemplate]
669
669
  }] } });
670
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-view.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/data-view/data-view.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/data-view/data-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  DoCheck,\n  EventEmitter,\n  Injector,\n  Input,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { DataListGridComponent, DataListGridComponentState, ListGridData } from '../data-list-grid/data-list-grid.component'\nimport { Row, Sort, DataTableComponent, DataTableComponentState } from '../data-table/data-table.component'\nimport { DataTableColumn } from '../../model/data-table-column.model'\nimport { DataSortDirection } from '../../model/data-sort-direction'\nimport { DataAction } from '../../model/data-action'\nimport { BehaviorSubject, ReplaySubject, timestamp, combineLatest, map, Observable, startWith } from 'rxjs'\nimport { orderAndMergeValuesByTimestamp } from '../../utils/rxjs-utils'\nimport { PrimeTemplate } from 'primeng/api'\nimport { Filter } from '../../model/filter.model'\n\nexport type RowListGridData = ListGridData & Row\n\nexport type DataViewComponentState = DataListGridComponentState & DataTableComponentState\n\n@Component({\n  selector: 'ocx-data-view',\n  templateUrl: './data-view.component.html',\n  styleUrls: ['./data-view.component.css'],\n  providers: [{ provide: 'DataViewComponent', useExisting: DataViewComponent }],\n})\nexport class DataViewComponent implements DoCheck, OnInit, AfterContentInit {\n  _dataListGridComponent: DataListGridComponent | undefined\n  @ViewChild(DataListGridComponent) set listGrid(ref: DataListGridComponent | undefined) {\n    this._dataListGridComponent = ref\n    this.registerEventListenerForListGrid()\n  }\n  get listGrid(): DataListGridComponent | undefined {\n    return this._dataListGridComponent\n  }\n\n  _dataTableComponent: DataTableComponent | undefined\n  @ViewChild(DataTableComponent) set dataTable(ref: DataTableComponent | undefined) {\n    this._dataTableComponent = ref\n    this.registerEventListenerForDataTable()\n  }\n  get dataTable(): DataTableComponent | undefined {\n    return this._dataTableComponent\n  }\n\n  dataTableComponentState$ = new ReplaySubject<DataTableComponentState>(1)\n  dataListGridComponentState$ = new ReplaySubject<DataListGridComponentState>(1)\n\n  @Input() deletePermission: string | undefined\n  @Input() editPermission: string | undefined\n  @Input() viewPermission: string | undefined\n  @Input() deleteActionVisibleField: string | undefined\n  @Input() deleteActionEnabledField: string | undefined\n  @Input() viewActionVisibleField: string | undefined\n  @Input() viewActionEnabledField: string | undefined\n  @Input() editActionVisibleField: string | undefined\n  @Input() editActionEnabledField: string | undefined\n  @Input() tableSelectionEnabledField: string | undefined\n  @Input() tableAllowSelectAll = true\n  @Input() data: RowListGridData[] = []\n  @Input() name = 'Data table'\n  @Input() titleLineId: string | undefined\n  @Input() subtitleLineIds: string[] = []\n  @Input() layout: any = ['grid', 'list', 'table']\n  @Input() columns: DataTableColumn[] = []\n  @Input() emptyResultsMessage: string | undefined\n  @Input() clientSideSorting = true\n  @Input() clientSideFiltering = true\n  @Input() fallbackImage = 'placeholder.png'\n  @Input() filters: Filter[] = []\n  @Input() sortField: any = ''\n  @Input() sortDirection: DataSortDirection = DataSortDirection.NONE\n  @Input() listGridPaginator = true\n  @Input() tablePaginator = true\n  @Input() page = 0\n  @Input() totalRecordsOnServer: number | undefined\n  @Input() currentPageShowingKey = 'OCX_DATA_TABLE.SHOWING'\n  @Input() currentPageShowingWithTotalOnServerKey = 'OCX_DATA_TABLE.SHOWING_WITH_TOTAL_ON_SERVER'\n  @Input() selectedRows: Row[] = []\n  @Input() frozenActionColumn = false\n  @Input() actionColumnPosition: 'left' | 'right' = 'right'\n\n  @Input()\n  get paginator(): boolean {\n    return this.listGridPaginator && this.tablePaginator\n  }\n  set paginator(value: boolean) {\n    this.listGridPaginator = value\n    this.tablePaginator = value\n  }\n\n  @Input() sortStates: DataSortDirection[] = [DataSortDirection.ASCENDING, DataSortDirection.DESCENDING]\n  @Input() pageSizes: number[] = [10, 25, 50]\n  @Input() pageSize: number | undefined\n\n  @Input() stringTableCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('stringTableCell') stringTableCellChildTemplate: TemplateRef<any> | undefined\n  get _stringTableCell(): TemplateRef<any> | undefined {\n    return this.stringTableCellTemplate || this.stringTableCellChildTemplate\n  }\n\n  @Input() numberTableCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('numberTableCell') numberTableCellChildTemplate: TemplateRef<any> | undefined\n  get _numberTableCell(): TemplateRef<any> | undefined {\n    return this.numberTableCellTemplate || this.numberTableCellChildTemplate\n  }\n  /**\n   * @deprecated Will be removed and instead to change the template of a specific column\n   * use the new approach instead by following the naming convention column id + IdTableCell\n   * e.g. for a column with the id 'status' in DataTable use pTemplate=\"statusIdTableCell\"\n   */\n  @Input() customTableCellTemplate: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be removed and instead to change the template of a specific column\n   * use the new approach instead by following the naming convention column id + IdTableCell\n   * e.g. for a column with the id 'status' in DataTable use pTemplate=\"statusIdTableCell\"\n   */\n  @ContentChild('customTableCell') customTableCellChildTemplate: TemplateRef<any> | undefined\n  get _customTableCell(): TemplateRef<any> | undefined {\n    return this.customTableCellTemplate || this.customTableCellChildTemplate\n  }\n\n  @Input() dateTableCellTemplate: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be replaced by dateTableCellTemplate\n   */\n  @Input()\n  get tableDateCellTemplate(): TemplateRef<any> | undefined {\n    return this.dateTableCellTemplate\n  }\n  set tableDateCellTemplate(value: TemplateRef<any> | undefined) {\n    this.dateTableCellTemplate = value\n  }\n  /**\n   * @deprecated Will be replaced by dateTableCellChildTemplate\n   */\n  @ContentChild('tableDateCell') tableDateCellChildTemplate: TemplateRef<any> | undefined\n  @ContentChild('dateTableCell') dateTableCellChildTemplate: TemplateRef<any> | undefined\n  get _dateTableCell(): TemplateRef<any> | undefined {\n    return this.dateTableCellTemplate || this.dateTableCellChildTemplate || this.tableDateCellChildTemplate\n  }\n\n  @Input() tableCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('tableCell') tableCellChildTemplate: TemplateRef<any> | undefined\n  get _tableCell(): TemplateRef<any> | undefined {\n    return this.tableCellTemplate || this.tableCellChildTemplate\n  }\n\n  @Input() translationKeyTableCellTemplate: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be replaced by translationKeyTableCellTemplate\n   */\n  @Input()\n  get tableTranslationKeyCellTemplate(): TemplateRef<any> | undefined {\n    return this.translationKeyTableCellTemplate\n  }\n  set tableTranslationKeyCellTemplate(value: TemplateRef<any> | undefined) {\n    this.translationKeyTableCellTemplate = value\n  }\n  /**\n   * @deprecated Will be replaced by translationKeyTableCellChildTemplate\n   */\n  @ContentChild('tableTranslationKeyCell') tableTranslationKeyCellChildTemplate: TemplateRef<any> | undefined\n  @ContentChild('translationKeyTableCell') translationKeyTableCellChildTemplate: TemplateRef<any> | undefined\n  get _translationKeyTableCell(): TemplateRef<any> | undefined {\n    return (\n      this.translationKeyTableCellTemplate ||\n      this.translationKeyTableCellChildTemplate ||\n      this.tableTranslationKeyCellChildTemplate\n    )\n  }\n\n  @Input() gridItemSubtitleLinesTemplate: TemplateRef<any> | undefined\n  @ContentChild('gridItemSubtitleLines') gridItemSubtitleLinesChildTemplate: TemplateRef<any> | undefined\n  get _gridItemSubtitleLines(): TemplateRef<any> | undefined {\n    return this.gridItemSubtitleLinesTemplate || this.gridItemSubtitleLinesChildTemplate\n  }\n\n  @Input() listItemSubtitleLinesTemplate: TemplateRef<any> | undefined\n  @ContentChild('listItemSubtitleLines') listItemSubtitleLinesChildTemplate: TemplateRef<any> | undefined\n  get _listItemSubtitleLines(): TemplateRef<any> | undefined {\n    return this.listItemSubtitleLinesTemplate || this.listItemSubtitleLinesChildTemplate\n  }\n  @Input() gridItemTemplate: TemplateRef<any> | undefined\n  @ContentChild('gridItem') gridItemChildTemplate: TemplateRef<any> | undefined\n  get _gridItem(): TemplateRef<any> | undefined {\n    return this.gridItemTemplate || this.gridItemChildTemplate\n  }\n\n  @Input() listItemTemplate: TemplateRef<any> | undefined\n  @ContentChild('listItem') listItemChildTemplate: TemplateRef<any> | undefined\n  get _listItem(): TemplateRef<any> | undefined {\n    return this.listItemTemplate || this.listItemChildTemplate\n  }\n\n  @Input() relativeDateTableCellTemplate: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be replaced by relativeDateTableCellTemplate\n   */\n  @Input()\n  get tableRelativeDateCellTemplate(): TemplateRef<any> | undefined {\n    return this.relativeDateTableCellTemplate\n  }\n  set tableRelativeDateCellTemplate(value: TemplateRef<any> | undefined) {\n    this.relativeDateTableCellTemplate = value\n  }\n  /**\n   * @deprecated Will be replace by relativeDateTableCellChildTemplate\n   */\n  @ContentChild('tableRelativeDateCell') tableRelativeDateCellChildTemplate: TemplateRef<any> | undefined\n  @ContentChild('relativeDateTableCell') relativeDateTableCellChildTemplate: TemplateRef<any> | undefined\n  get _relativeDateTableCell(): TemplateRef<any> | undefined {\n    return (\n      this.relativeDateTableCellTemplate ||\n      this.relativeDateTableCellChildTemplate ||\n      this.tableRelativeDateCellChildTemplate\n    )\n  }\n\n  @Input() listValueTemplate: TemplateRef<any> | undefined\n  @ContentChild('listValue') listValueChildTemplate: TemplateRef<any> | undefined\n  get _listValue(): TemplateRef<any> | undefined {\n    return this.listValueTemplate || this.listValueChildTemplate\n  }\n  @Input() translationKeyListValueTemplate: TemplateRef<any> | undefined\n  @ContentChild('translationKeyListValue') translationKeyListValueChildTemplate: TemplateRef<any> | undefined\n  get _translationKeyListValue(): TemplateRef<any> | undefined {\n    return this.translationKeyListValueTemplate || this.translationKeyListValueChildTemplate\n  }\n  @Input() numberListValueTemplate: TemplateRef<any> | undefined\n  @ContentChild('numberListValue') numberListValueChildTemplate: TemplateRef<any> | undefined\n  get _numberListValue(): TemplateRef<any> | undefined {\n    return this.numberListValueTemplate || this.numberListValueChildTemplate\n  }\n  @Input() relativeDateListValueTemplate: TemplateRef<any> | undefined\n  @ContentChild('relativeDateListValue') relativeDateListValueChildTemplate: TemplateRef<any> | undefined\n  get _relativeDateListValue(): TemplateRef<any> | undefined {\n    return this.relativeDateListValueTemplate || this.relativeDateListValueChildTemplate\n  }\n  /**\n   * @deprecated Will be removed and instead to change the template of a specific column\n   * use the new approach instead by following the naming convention column id + IdListValue\n   * e.g. for a column with the id 'status' in DataListGrid use pTemplate=\"statusIdListValue\"\n   */\n  @Input() customListValueTemplate: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be removed and instead to change the template of a specific column\n   * use the new approach instead by following the naming convention column id + IdListValue\n   * e.g. for a column with the id 'status' DataListGrid use pTemplate=\"statusIdListValue\"\n   */\n  @ContentChild('customListValue') customListValueChildTemplate: TemplateRef<any> | undefined\n  get _customListValue(): TemplateRef<any> | undefined {\n    return this.customListValueTemplate || this.customListValueChildTemplate\n  }\n  @Input() stringListValueTemplate: TemplateRef<any> | undefined\n  @ContentChild('stringListValue') stringListValueChildTemplate: TemplateRef<any> | undefined\n  get _stringListValue(): TemplateRef<any> | undefined {\n    return this.stringListValueTemplate || this.stringListValueChildTemplate\n  }\n  @Input() dateListValueTemplate: TemplateRef<any> | undefined\n  @ContentChild('dateListValue') dateListValueChildTemplate: TemplateRef<any> | undefined\n  get _dateListValue(): TemplateRef<any> | undefined {\n    return this.dateListValueTemplate || this.dateListValueChildTemplate\n  }\n  @Input() tableFilterCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('tableFilterCell') tableFilterCellChildTemplate: TemplateRef<any> | undefined\n  get _tableFilterCell(): TemplateRef<any> | undefined {\n    return this.tableFilterCellTemplate || this.tableFilterCellChildTemplate\n  }\n  @Input() dateTableFilterCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('dateFilterCell') dateTableFilterCellChildTemplate: TemplateRef<any> | undefined\n  get _dateTableFilterCell(): TemplateRef<any> | undefined {\n    return this.dateTableFilterCellTemplate || this.dateTableFilterCellChildTemplate\n  }\n  @Input() relativeDateTableFilterCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('relativeDateTableFilterCell') relativeDateTableFilterCellChildTemplate: TemplateRef<any> | undefined\n  get _relativeDateTableFilterCell(): TemplateRef<any> | undefined {\n    return this.relativeDateTableFilterCellTemplate || this.relativeDateTableFilterCellChildTemplate\n  }\n  @Input() translationKeyTableFilterCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('translationKeyTableFilterCell') translationKeyTableFilterCellChildTemplate:\n    | TemplateRef<any>\n    | undefined\n  get _translationKeyTableFilterCell(): TemplateRef<any> | undefined {\n    return this.translationKeyTableFilterCellTemplate || this.translationKeyTableFilterCellChildTemplate\n  }\n  @Input() stringTableFilterCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('stringTableFilterCell') stringTableFilterCellChildTemplate: TemplateRef<any> | undefined\n  get _stringTableFilterCell(): TemplateRef<any> | undefined {\n    return this.stringTableFilterCellTemplate || this.stringTableFilterCellChildTemplate\n  }\n  @Input() numberTableFilterCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('numberTableFilterCell') numberTableFilterCellChildTemplate: TemplateRef<any> | undefined\n  get _numberTableFilterCell(): TemplateRef<any> | undefined {\n    return this.numberTableFilterCellTemplate || this.numberTableFilterCellChildTemplate\n  }\n  /**\n   * @deprecated Will be removed and instead to change the template of a specific column filter\n   * use the new approach instead by following the naming convention column id + IdTableFilterCell\n   * e.g. for a column with the id 'status' in DataTable use pTemplate=\"statusIdTableFilterCell\"\n   */\n  @Input() customTableFilterCellTemplate: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be removed and instead to change the template of a specific column filter\n   * use the new approach instead by following the naming convention column id + IdTableFilterCell\n   * e.g. for a column with the id 'status' in DataTable use pTemplate=\"statusIdTableFilterCell\"\n   */\n  @ContentChild('customTableFilterCell') customTableFilterCellChildTemplate: TemplateRef<any> | undefined\n  get _customTableFilterCell(): TemplateRef<any> | undefined {\n    return this.customTableFilterCellTemplate || this.customTableFilterCellChildTemplate\n  }\n\n  @Input() additionalActions: DataAction[] = []\n\n  @Output() filtered = new EventEmitter<Filter[]>()\n  @Output() sorted = new EventEmitter<Sort>()\n  @Output() deleteItem = new EventEmitter<RowListGridData>()\n  @Output() viewItem = new EventEmitter<RowListGridData>()\n  @Output() editItem = new EventEmitter<RowListGridData>()\n  @Output() selectionChanged = new EventEmitter<Row[]>()\n  @Output() pageChanged = new EventEmitter<number>()\n  @Output() pageSizeChanged = new EventEmitter<number>()\n  @Output() componentStateChanged = new EventEmitter<DataViewComponentState>()\n  isDeleteItemObserved: boolean | undefined\n  isViewItemObserved: boolean | undefined\n  IsEditItemObserved: boolean | undefined\n  firstColumnId: string | undefined\n\n  parentTemplates$: BehaviorSubject<QueryList<PrimeTemplate> | null | undefined> = new BehaviorSubject<\n    QueryList<PrimeTemplate> | null | undefined\n  >(undefined)\n  @Input()\n  set parentTemplates(value: QueryList<PrimeTemplate> | null | undefined) {\n    this.parentTemplates$.next(value)\n  }\n\n  templates$: BehaviorSubject<QueryList<PrimeTemplate> | undefined> = new BehaviorSubject<\n    QueryList<PrimeTemplate> | undefined\n  >(undefined)\n  @ContentChildren(PrimeTemplate)\n  set templates(value: QueryList<PrimeTemplate> | undefined) {\n    this.templates$.next(value)\n  }\n\n  templatesForChildren$: Observable<QueryList<PrimeTemplate> | undefined> = combineLatest([\n    this.templates$,\n    this.parentTemplates$,\n  ]).pipe(\n    map(([t, pt]) => {\n      const ql = new QueryList<PrimeTemplate>()\n      ql.reset([...(t?.toArray() ?? []), ...(pt?.toArray() ?? [])])\n      return ql\n    })\n  )\n\n  get viewItemObserved(): boolean {\n    return this.injector.get('InteractiveDataViewComponent', null)?.viewItem.observed || this.viewItem.observed\n  }\n  get editItemObserved(): boolean {\n    return this.injector.get('InteractiveDataViewComponent', null)?.editItem.observed || this.editItem.observed\n  }\n  get deleteItemObserved(): boolean {\n    return this.injector.get('InteractiveDataViewComponent', null)?.deleteItem.observed || this.deleteItem.observed\n  }\n  get selectionChangedObserved(): boolean {\n    return (\n      this.injector.get('InteractiveDataViewComponent', null)?.selectionChanged.observed ||\n      this.selectionChanged.observed\n    )\n  }\n\n  constructor(private injector: Injector) {}\n\n  ngOnInit(): void {\n    this.firstColumnId = this.columns[0]?.id\n\n    let dataTableComponentState$: Observable<DataTableComponentState | Record<string, never>> = this.dataTableComponentState$\n    let dataListGridComponentState$: Observable<DataListGridComponentState | Record<string, never>> = this.dataListGridComponentState$\n    if (this.layout === 'table') {\n      dataListGridComponentState$ = dataListGridComponentState$.pipe(startWith({}))\n    } else {\n      dataTableComponentState$ = dataTableComponentState$.pipe(startWith({}))\n    }\n\n    combineLatest([\n      dataTableComponentState$.pipe(timestamp()),\n      dataListGridComponentState$.pipe(timestamp()),\n    ])\n      .pipe(\n        map((componentStates) => {\n          return orderAndMergeValuesByTimestamp(componentStates)\n        })\n      )\n      .subscribe((val) => {this.componentStateChanged.emit(val)})\n  }\n\n  ngAfterContentInit() {\n    this.templates$.value?.forEach((item) => {\n      switch (item.getType()) {\n        case 'stringTableCell':\n          this.stringTableCellChildTemplate = item.template\n          break\n        case 'numberTableCell':\n          this.numberTableCellChildTemplate = item.template\n          break\n        case 'customTableCell':\n          this.customTableCellChildTemplate = item.template\n          break\n        case 'tableDateCell':\n          this.tableDateCellChildTemplate = item.template\n          break\n        case 'dateTableCell':\n          this.dateTableCellChildTemplate = item.template\n          break\n        case 'tableCell':\n          this.tableCellChildTemplate = item.template\n          break\n        case 'tableTranslationKeyCell':\n          this.tableTranslationKeyCellChildTemplate = item.template\n          break\n        case 'translationKeyTableCell':\n          this.translationKeyTableCellChildTemplate = item.template\n          break\n        case 'gridItemSubtitleLines':\n          this.gridItemSubtitleLinesChildTemplate = item.template\n          break\n        case 'listItemSubtitleLines':\n          this.listItemSubtitleLinesChildTemplate = item.template\n          break\n        case 'gridItem':\n          this.gridItemChildTemplate = item.template\n          break\n        case 'listItem':\n          this.listItemChildTemplate = item.template\n          break\n        case 'tableRelativeDateCell':\n          this.tableRelativeDateCellChildTemplate = item.template\n          break\n        case 'relativeDateTableCell':\n          this.relativeDateTableCellChildTemplate = item.template\n          break\n        case 'listValue':\n          this.listValueChildTemplate = item.template\n          break\n        case 'translationKeyListValue':\n          this.translationKeyListValueChildTemplate = item.template\n          break\n        case 'numberListValue':\n          this.numberListValueChildTemplate = item.template\n          break\n        case 'relativeDateListValue':\n          this.relativeDateListValueChildTemplate = item.template\n          break\n        case 'customListValue':\n          this.customListValueChildTemplate = item.template\n          break\n        case 'stringListValue':\n          this.stringListValueChildTemplate = item.template\n          break\n        case 'dateListValue':\n          this.dateListValueChildTemplate = item.template\n          break\n        case 'tableFilterCell':\n          this.tableFilterCellChildTemplate = item.template\n          break\n        case 'dateTableFilterCell':\n          this.dateTableFilterCellChildTemplate = item.template\n          break\n        case 'relativeDateTableFilterCell':\n          this.relativeDateTableFilterCellChildTemplate = item.template\n          break\n        case 'translationKeyTableFilterCell':\n          this.translationKeyTableFilterCellChildTemplate = item.template\n          break\n        case 'stringTableFilterCell':\n          this.stringTableFilterCellChildTemplate = item.template\n          break\n        case 'numberTableFilterCell':\n          this.numberTableFilterCellChildTemplate = item.template\n          break\n        case 'customTableFilterCell':\n          this.customTableFilterCellChildTemplate = item.template\n          break\n      }\n    })\n  }\n\n  ngDoCheck(): void {\n    this.registerEventListenerForDataTable()\n    this.registerEventListenerForListGrid()\n  }\n\n  registerEventListenerForListGrid() {\n    if (this.layout !== 'table') {\n      if (this.deleteItem.observed) {\n        this.isDeleteItemObserved = true\n        if (!this._dataListGridComponent?.deleteItem.observed) {\n          this._dataListGridComponent?.deleteItem.subscribe((event) => {\n            this.deletingElement(event)\n          })\n        }\n      }\n      if (this.viewItem.observed) {\n        this.isViewItemObserved = true\n        if (!this._dataListGridComponent?.viewItem.observed) {\n          this._dataListGridComponent?.viewItem.subscribe((event) => {\n            this.viewingElement(event)\n          })\n        }\n      }\n      if (this.editItem.observed) {\n        this.IsEditItemObserved = true\n        if (!this._dataListGridComponent?.editItem.observed) {\n          this._dataListGridComponent?.editItem.subscribe((event) => {\n            this.editingElement(event)\n          })\n        }\n      }\n    }\n  }\n\n  registerEventListenerForDataTable() {\n    if (this.layout === 'table') {\n      if (this.deleteItem.observed) {\n        this.isDeleteItemObserved = true\n        if (!this._dataTableComponent?.deleteTableRow.observed) {\n          this._dataTableComponent?.deleteTableRow.subscribe((event) => {\n            this.deletingElement(event)\n          })\n        }\n      }\n      if (this.viewItem.observed) {\n        this.isViewItemObserved = true\n        if (!this._dataTableComponent?.viewTableRow.observed) {\n          this._dataTableComponent?.viewTableRow.subscribe((event) => {\n            this.viewingElement(event)\n          })\n        }\n      }\n      if (this.editItem.observed) {\n        this.IsEditItemObserved = true\n        if (!this._dataTableComponent?.editTableRow.observed) {\n          this._dataTableComponent?.editTableRow.subscribe((event) => {\n            this.editingElement(event)\n          })\n        }\n      }\n      if (this.selectionChangedObserved) {\n        if (!this._dataTableComponent?.selectionChanged.observed) {\n          this._dataTableComponent?.selectionChanged.subscribe((event) => {\n            this.onRowSelectionChange(event)\n          })\n        }\n      }\n    }\n  }\n\n  filtering(event: any) {\n    this.filters = event\n    this.filtered.emit(event)\n  }\n\n  sorting(event: any) {\n    this.sortDirection = event.sortDirection\n    this.sortField = event.sortColumn\n    this.sorted.emit(event)\n  }\n\n  deletingElement(event: any) {\n    if (this.isDeleteItemObserved) {\n      this.deleteItem.emit(event)\n    }\n  }\n\n  viewingElement(event: any) {\n    if (this.isViewItemObserved) {\n      this.viewItem.emit(event)\n    }\n  }\n  editingElement(event: any) {\n    if (this.IsEditItemObserved) {\n      this.editItem.emit(event)\n    }\n  }\n\n  onRowSelectionChange(event: Row[]) {\n    if (this.selectionChangedObserved) {\n      this.selectionChanged.emit(event)\n    }\n  }\n\n  onPageChange(event: number) {\n    this.page = event\n    this.pageChanged.emit(event)\n  }\n\n  onPageSizeChange(event: number) {\n    this.pageSize = event\n    this.pageSizeChanged.emit(event)\n  }\n}\n","<div *ngIf=\"layout !== 'table'\">\n  <ocx-data-list-grid\n    #ocxdatalistgrid\n    [name]=\"name\"\n    [data]=\"data\"\n    [columns]=\"columns\"\n    [filters]=\"filters\"\n    [sortDirection]=\"sortDirection\"\n    [sortField]=\"sortField\"\n    [sortStates]=\"sortStates\"\n    [clientSideFiltering]=\"clientSideFiltering\"\n    [clientSideSorting]=\"clientSideSorting\"\n    [titleLineId]=\"titleLineId\"\n    [subtitleLineIds]=\"subtitleLineIds\"\n    [clientSideSorting]=\"true\"\n    [pageSizes]=\"pageSizes\"\n    [pageSize]=\"pageSize\"\n    [paginator]=\"listGridPaginator\"\n    [page]=\"page\"\n    (pageChanged)=\"onPageChange($event)\"\n    (pageSizeChanged)=\"onPageSizeChange($event)\"\n    (componentStateChanged)=\"dataListGridComponentState$.next($event)\"\n    [emptyResultsMessage]=\"emptyResultsMessage\"\n    [layout]=\"layout\"\n    [deletePermission]=\"deletePermission\"\n    [editPermission]=\"editPermission\"\n    [viewPermission]=\"viewPermission\"\n    [deleteActionEnabledField]=\"deleteActionEnabledField\"\n    [deleteActionVisibleField]=\"deleteActionVisibleField\"\n    [editActionEnabledField]=\"editActionEnabledField\"\n    [editActionVisibleField]=\"editActionVisibleField\"\n    [viewActionEnabledField]=\"viewActionEnabledField\"\n    [viewActionVisibleField]=\"viewActionVisibleField\"\n    [additionalActions]=\"additionalActions\"\n    [gridItemSubtitleLinesTemplate]=\"_gridItemSubtitleLines ? gridItemSubtitleLines : undefined\"\n    [listItemSubtitleLinesTemplate]=\"_listItemSubtitleLines ? listItemSubtitleLines : undefined\"\n    [listItemTemplate]=\"_listItem ? listItem : undefined\"\n    [listValueTemplate]=\"_listValue ? listValue : undefined\"\n    [translationKeyListValueTemplate]=\"_translationKeyListValue ? translationKeyListValue : undefined\"\n    [numberListValueTemplate]=\"_numberListValue ? numberListValue : undefined\"\n    [relativeDateListValueTemplate]=\"_relativeDateListValue ? relativeDateListValue : undefined\"\n    [customListValueTemplate]=\"_customListValue ? customListValue : undefined\"\n    [stringListValueTemplate]=\"_stringListValue ? stringListValue : undefined\"\n    [dateListValueTemplate]=\"_dateListValue ? dateListValue : undefined\"\n    [gridItemTemplate]=\"_gridItem ? gridItem  : undefined\"\n    [totalRecordsOnServer]=\"totalRecordsOnServer\"\n    [parentTemplates]=\"templatesForChildren$ | async\"\n  >\n  </ocx-data-list-grid>\n  <ng-template #listItemSubtitleLines let-item>\n    <ng-container\n      *ngIf=\"_listItemSubtitleLines\"\n      [ngTemplateOutlet]=\"_listItemSubtitleLines\"\n      [ngTemplateOutletContext]=\"{$implicit:item}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #gridItemSubtitleLines let-item>\n    <ng-container\n      *ngIf=\"_gridItemSubtitleLines\"\n      [ngTemplateOutlet]=\"_gridItemSubtitleLines\"\n      [ngTemplateOutletContext]=\"{$implicit:item}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #gridItem let-item>\n    <ng-container *ngIf=\"_gridItem\" [ngTemplateOutlet]=\"_gridItem\" [ngTemplateOutletContext]=\"{$implicit:item}\">\n    </ng-container\n  ></ng-template>\n  <ng-template #listItem let-item>\n    <ng-container *ngIf=\"_listItem\" [ngTemplateOutlet]=\"_listItem\" [ngTemplateOutletContext]=\"{$implicit:item}\">\n    </ng-container\n  ></ng-template>\n  <ng-template #listValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_listValue\"\n      [ngTemplateOutlet]=\"_listValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #translationKeyListValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_translationKeyListValue\"\n      [ngTemplateOutlet]=\"_translationKeyListValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #numberListValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_numberListValue\"\n      [ngTemplateOutlet]=\"_numberListValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #relativeDateListValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_relativeDateListValue\"\n      [ngTemplateOutlet]=\"_relativeDateListValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #customListValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_customListValue\"\n      [ngTemplateOutlet]=\"_customListValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #stringListValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_stringListValue\"\n      [ngTemplateOutlet]=\"_stringListValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #dateListValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_dateListValue\"\n      [ngTemplateOutlet]=\"_dateListValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n</div>\n\n<div *ngIf=\"layout === 'table'\">\n  <ocx-data-table\n    #ocxdatatable\n    [rows]=\"data\"\n    [columns]=\"columns\"\n    [filters]=\"filters\"\n    [sortDirection]=\"sortDirection\"\n    [sortColumn]=\"sortField\"\n    [sortStates]=\"sortStates\"\n    [clientSideFiltering]=\"clientSideFiltering\"\n    [clientSideSorting]=\"clientSideSorting\"\n    [pageSizes]=\"pageSizes\"\n    [pageSize]=\"pageSize\"\n    [paginator]=\"tablePaginator\"\n    [page]=\"page\"\n    (pageChanged)=\"onPageChange($event)\"\n    (pageSizeChanged)=\"onPageSizeChange($event)\"\n    (componentStateChanged)=\"dataTableComponentState$.next($event)\"\n    [selectedRows]=\"selectedRows\"\n    [frozenActionColumn]=\"frozenActionColumn\"\n    [actionColumnPosition]=\"actionColumnPosition\"\n    [emptyResultsMessage]=\"emptyResultsMessage\"\n    [name]=\"name\"\n    [deletePermission]=\"deletePermission\"\n    [editPermission]=\"editPermission\"\n    [viewPermission]=\"viewPermission\"\n    [deleteActionEnabledField]=\"deleteActionEnabledField\"\n    [deleteActionVisibleField]=\"deleteActionVisibleField\"\n    [editActionEnabledField]=\"editActionEnabledField\"\n    [editActionVisibleField]=\"editActionVisibleField\"\n    [viewActionEnabledField]=\"viewActionEnabledField\"\n    [viewActionVisibleField]=\"viewActionVisibleField\"\n    [additionalActions]=\"additionalActions\"\n    [stringCellTemplate]=\"_stringTableCell ? stringCell : undefined\"\n    [numberCellTemplate]=\"_numberTableCell ? numberCell : undefined\"\n    [customCellTemplate]=\"_customTableCell ? customCell : undefined\"\n    [dateCellTemplate]=\"_dateTableCell ? dateCell : undefined\"\n    [relativeDateCellTemplate]=\"_relativeDateTableCell ? relativeDateCell : undefined\"\n    [cellTemplate]=\"_tableCell ? cell : undefined\"\n    [translationKeyCellTemplate]=\"_translationKeyTableCell ? translationKeyCell : undefined\"\n    [filterCellTemplate]=\"_tableFilterCell ? filterCell : undefined\"\n    [dateFilterCellTemplate]=\"_dateTableFilterCell ? dateFilterCell : undefined\"\n    [customFilterCellTemplate]=\"_customTableFilterCell ? customFilterCell : undefined\"\n    [numberFilterCellTemplate]=\"_numberTableFilterCell ? numberFilterCell : undefined\"\n    [stringFilterCellTemplate]=\"_stringTableFilterCell ? stringFilterCell : undefined\"\n    [relativeDateFilterCellTemplate]=\"_relativeDateTableFilterCell ? relativeDateFilterCell : undefined\"\n    [translationKeyFilterCellTemplate]=\"_translationKeyTableFilterCell ? translationKeyFilterCell : undefined\"\n    (sorted)=\"sorting($event)\"\n    (filtered)=\"filtering($event)\"\n    [totalRecordsOnServer]=\"totalRecordsOnServer\"\n    [currentPageShowingKey]=\"currentPageShowingKey\"\n    [currentPageShowingWithTotalOnServerKey]=\"currentPageShowingWithTotalOnServerKey\"\n    [parentTemplates]=\"templatesForChildren$ | async\"\n    [allowSelectAll]=\"tableAllowSelectAll\"\n    [selectionEnabledField]=\"tableSelectionEnabledField\"\n  >\n  </ocx-data-table>\n  <ng-template #stringCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_stringTableCell\"\n      [ngTemplateOutlet]=\"_stringTableCell\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #numberCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_numberTableCell\"\n      [ngTemplateOutlet]=\"_numberTableCell\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #customCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_customTableCell\"\n      [ngTemplateOutlet]=\"_customTableCell\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #dateCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_dateTableCell\"\n      [ngTemplateOutlet]=\"_dateTableCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #relativeDateCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_relativeDateTableCell\"\n      [ngTemplateOutlet]=\"_relativeDateTableCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #cell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_tableCell\"\n      [ngTemplateOutlet]=\"_tableCell\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #translationKeyCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_translationKeyTableCell\"\n      [ngTemplateOutlet]=\"_translationKeyTableCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #stringFilterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_stringTableFilterCell\"\n      [ngTemplateOutlet]=\"_stringTableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #filterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_tableFilterCell\"\n      [ngTemplateOutlet]=\"_tableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container>\n  </ng-template>\n  <ng-template #dateFilterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_dateTableFilterCell\"\n      [ngTemplateOutlet]=\"_dateTableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container>\n  </ng-template>\n  <ng-template #customFilterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_customTableFilterCell\"\n      [ngTemplateOutlet]=\"_customTableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container>\n  </ng-template>\n  <ng-template #numberFilterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_numberTableFilterCell\"\n      [ngTemplateOutlet]=\"_numberTableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container>\n  </ng-template>\n  <ng-template #relativeDateFilterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_relativeDateTableFilterCell\"\n      [ngTemplateOutlet]=\"_relativeDateTableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container>\n  </ng-template>\n  <ng-template #translationKeyFilterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_translationKeyTableFilterCell\"\n      [ngTemplateOutlet]=\"_translationKeyTableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container>\n  </ng-template>\n</div>\n"]}
670
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-view.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/data-view/data-view.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/data-view/data-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  DoCheck,\n  EventEmitter,\n  Injector,\n  Input,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { DataListGridComponent, DataListGridComponentState, ListGridData } from '../data-list-grid/data-list-grid.component'\nimport { Row, Sort, DataTableComponent, DataTableComponentState } from '../data-table/data-table.component'\nimport { DataTableColumn } from '../../model/data-table-column.model'\nimport { DataSortDirection } from '../../model/data-sort-direction'\nimport { DataAction } from '../../model/data-action'\nimport { BehaviorSubject, ReplaySubject, timestamp, combineLatest, map, Observable, startWith } from 'rxjs'\nimport { orderAndMergeValuesByTimestamp } from '../../utils/rxjs-utils'\nimport { PrimeTemplate } from 'primeng/api'\nimport { Filter } from '../../model/filter.model'\n\nexport type RowListGridData = ListGridData & Row\n\nexport type DataViewComponentState = DataListGridComponentState & DataTableComponentState\n\n@Component({\n  selector: 'ocx-data-view',\n  templateUrl: './data-view.component.html',\n  styleUrls: ['./data-view.component.css'],\n  providers: [{ provide: 'DataViewComponent', useExisting: DataViewComponent }],\n})\nexport class DataViewComponent implements DoCheck, OnInit, AfterContentInit {\n  _dataListGridComponent: DataListGridComponent | undefined\n  @ViewChild(DataListGridComponent) set listGrid(ref: DataListGridComponent | undefined) {\n    this._dataListGridComponent = ref\n    this.registerEventListenerForListGrid()\n  }\n  get listGrid(): DataListGridComponent | undefined {\n    return this._dataListGridComponent\n  }\n\n  _dataTableComponent: DataTableComponent | undefined\n  @ViewChild(DataTableComponent) set dataTable(ref: DataTableComponent | undefined) {\n    this._dataTableComponent = ref\n    this.registerEventListenerForDataTable()\n  }\n  get dataTable(): DataTableComponent | undefined {\n    return this._dataTableComponent\n  }\n\n  dataTableComponentState$ = new ReplaySubject<DataTableComponentState>(1)\n  dataListGridComponentState$ = new ReplaySubject<DataListGridComponentState>(1)\n\n  @Input() deletePermission: string | string[] | undefined\n  @Input() editPermission: string | string[] | undefined\n  @Input() viewPermission: string | string[] | undefined\n  @Input() deleteActionVisibleField: string | undefined\n  @Input() deleteActionEnabledField: string | undefined\n  @Input() viewActionVisibleField: string | undefined\n  @Input() viewActionEnabledField: string | undefined\n  @Input() editActionVisibleField: string | undefined\n  @Input() editActionEnabledField: string | undefined\n  @Input() tableSelectionEnabledField: string | undefined\n  @Input() tableAllowSelectAll = true\n  @Input() data: RowListGridData[] = []\n  @Input() name = 'Data table'\n  @Input() titleLineId: string | undefined\n  @Input() subtitleLineIds: string[] = []\n  @Input() layout: any = ['grid', 'list', 'table']\n  @Input() columns: DataTableColumn[] = []\n  @Input() emptyResultsMessage: string | undefined\n  @Input() clientSideSorting = true\n  @Input() clientSideFiltering = true\n  @Input() fallbackImage = 'placeholder.png'\n  @Input() filters: Filter[] = []\n  @Input() sortField: any = ''\n  @Input() sortDirection: DataSortDirection = DataSortDirection.NONE\n  @Input() listGridPaginator = true\n  @Input() tablePaginator = true\n  @Input() page = 0\n  @Input() totalRecordsOnServer: number | undefined\n  @Input() currentPageShowingKey = 'OCX_DATA_TABLE.SHOWING'\n  @Input() currentPageShowingWithTotalOnServerKey = 'OCX_DATA_TABLE.SHOWING_WITH_TOTAL_ON_SERVER'\n  @Input() selectedRows: Row[] = []\n  @Input() frozenActionColumn = false\n  @Input() actionColumnPosition: 'left' | 'right' = 'right'\n\n  @Input()\n  get paginator(): boolean {\n    return this.listGridPaginator && this.tablePaginator\n  }\n  set paginator(value: boolean) {\n    this.listGridPaginator = value\n    this.tablePaginator = value\n  }\n\n  @Input() sortStates: DataSortDirection[] = [DataSortDirection.ASCENDING, DataSortDirection.DESCENDING]\n  @Input() pageSizes: number[] = [10, 25, 50]\n  @Input() pageSize: number | undefined\n\n  @Input() stringTableCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('stringTableCell') stringTableCellChildTemplate: TemplateRef<any> | undefined\n  get _stringTableCell(): TemplateRef<any> | undefined {\n    return this.stringTableCellTemplate || this.stringTableCellChildTemplate\n  }\n\n  @Input() numberTableCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('numberTableCell') numberTableCellChildTemplate: TemplateRef<any> | undefined\n  get _numberTableCell(): TemplateRef<any> | undefined {\n    return this.numberTableCellTemplate || this.numberTableCellChildTemplate\n  }\n  /**\n   * @deprecated Will be removed and instead to change the template of a specific column\n   * use the new approach instead by following the naming convention column id + IdTableCell\n   * e.g. for a column with the id 'status' in DataTable use pTemplate=\"statusIdTableCell\"\n   */\n  @Input() customTableCellTemplate: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be removed and instead to change the template of a specific column\n   * use the new approach instead by following the naming convention column id + IdTableCell\n   * e.g. for a column with the id 'status' in DataTable use pTemplate=\"statusIdTableCell\"\n   */\n  @ContentChild('customTableCell') customTableCellChildTemplate: TemplateRef<any> | undefined\n  get _customTableCell(): TemplateRef<any> | undefined {\n    return this.customTableCellTemplate || this.customTableCellChildTemplate\n  }\n\n  @Input() dateTableCellTemplate: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be replaced by dateTableCellTemplate\n   */\n  @Input()\n  get tableDateCellTemplate(): TemplateRef<any> | undefined {\n    return this.dateTableCellTemplate\n  }\n  set tableDateCellTemplate(value: TemplateRef<any> | undefined) {\n    this.dateTableCellTemplate = value\n  }\n  /**\n   * @deprecated Will be replaced by dateTableCellChildTemplate\n   */\n  @ContentChild('tableDateCell') tableDateCellChildTemplate: TemplateRef<any> | undefined\n  @ContentChild('dateTableCell') dateTableCellChildTemplate: TemplateRef<any> | undefined\n  get _dateTableCell(): TemplateRef<any> | undefined {\n    return this.dateTableCellTemplate || this.dateTableCellChildTemplate || this.tableDateCellChildTemplate\n  }\n\n  @Input() tableCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('tableCell') tableCellChildTemplate: TemplateRef<any> | undefined\n  get _tableCell(): TemplateRef<any> | undefined {\n    return this.tableCellTemplate || this.tableCellChildTemplate\n  }\n\n  @Input() translationKeyTableCellTemplate: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be replaced by translationKeyTableCellTemplate\n   */\n  @Input()\n  get tableTranslationKeyCellTemplate(): TemplateRef<any> | undefined {\n    return this.translationKeyTableCellTemplate\n  }\n  set tableTranslationKeyCellTemplate(value: TemplateRef<any> | undefined) {\n    this.translationKeyTableCellTemplate = value\n  }\n  /**\n   * @deprecated Will be replaced by translationKeyTableCellChildTemplate\n   */\n  @ContentChild('tableTranslationKeyCell') tableTranslationKeyCellChildTemplate: TemplateRef<any> | undefined\n  @ContentChild('translationKeyTableCell') translationKeyTableCellChildTemplate: TemplateRef<any> | undefined\n  get _translationKeyTableCell(): TemplateRef<any> | undefined {\n    return (\n      this.translationKeyTableCellTemplate ||\n      this.translationKeyTableCellChildTemplate ||\n      this.tableTranslationKeyCellChildTemplate\n    )\n  }\n\n  @Input() gridItemSubtitleLinesTemplate: TemplateRef<any> | undefined\n  @ContentChild('gridItemSubtitleLines') gridItemSubtitleLinesChildTemplate: TemplateRef<any> | undefined\n  get _gridItemSubtitleLines(): TemplateRef<any> | undefined {\n    return this.gridItemSubtitleLinesTemplate || this.gridItemSubtitleLinesChildTemplate\n  }\n\n  @Input() listItemSubtitleLinesTemplate: TemplateRef<any> | undefined\n  @ContentChild('listItemSubtitleLines') listItemSubtitleLinesChildTemplate: TemplateRef<any> | undefined\n  get _listItemSubtitleLines(): TemplateRef<any> | undefined {\n    return this.listItemSubtitleLinesTemplate || this.listItemSubtitleLinesChildTemplate\n  }\n  @Input() gridItemTemplate: TemplateRef<any> | undefined\n  @ContentChild('gridItem') gridItemChildTemplate: TemplateRef<any> | undefined\n  get _gridItem(): TemplateRef<any> | undefined {\n    return this.gridItemTemplate || this.gridItemChildTemplate\n  }\n\n  @Input() listItemTemplate: TemplateRef<any> | undefined\n  @ContentChild('listItem') listItemChildTemplate: TemplateRef<any> | undefined\n  get _listItem(): TemplateRef<any> | undefined {\n    return this.listItemTemplate || this.listItemChildTemplate\n  }\n\n  @Input() relativeDateTableCellTemplate: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be replaced by relativeDateTableCellTemplate\n   */\n  @Input()\n  get tableRelativeDateCellTemplate(): TemplateRef<any> | undefined {\n    return this.relativeDateTableCellTemplate\n  }\n  set tableRelativeDateCellTemplate(value: TemplateRef<any> | undefined) {\n    this.relativeDateTableCellTemplate = value\n  }\n  /**\n   * @deprecated Will be replace by relativeDateTableCellChildTemplate\n   */\n  @ContentChild('tableRelativeDateCell') tableRelativeDateCellChildTemplate: TemplateRef<any> | undefined\n  @ContentChild('relativeDateTableCell') relativeDateTableCellChildTemplate: TemplateRef<any> | undefined\n  get _relativeDateTableCell(): TemplateRef<any> | undefined {\n    return (\n      this.relativeDateTableCellTemplate ||\n      this.relativeDateTableCellChildTemplate ||\n      this.tableRelativeDateCellChildTemplate\n    )\n  }\n\n  @Input() listValueTemplate: TemplateRef<any> | undefined\n  @ContentChild('listValue') listValueChildTemplate: TemplateRef<any> | undefined\n  get _listValue(): TemplateRef<any> | undefined {\n    return this.listValueTemplate || this.listValueChildTemplate\n  }\n  @Input() translationKeyListValueTemplate: TemplateRef<any> | undefined\n  @ContentChild('translationKeyListValue') translationKeyListValueChildTemplate: TemplateRef<any> | undefined\n  get _translationKeyListValue(): TemplateRef<any> | undefined {\n    return this.translationKeyListValueTemplate || this.translationKeyListValueChildTemplate\n  }\n  @Input() numberListValueTemplate: TemplateRef<any> | undefined\n  @ContentChild('numberListValue') numberListValueChildTemplate: TemplateRef<any> | undefined\n  get _numberListValue(): TemplateRef<any> | undefined {\n    return this.numberListValueTemplate || this.numberListValueChildTemplate\n  }\n  @Input() relativeDateListValueTemplate: TemplateRef<any> | undefined\n  @ContentChild('relativeDateListValue') relativeDateListValueChildTemplate: TemplateRef<any> | undefined\n  get _relativeDateListValue(): TemplateRef<any> | undefined {\n    return this.relativeDateListValueTemplate || this.relativeDateListValueChildTemplate\n  }\n  /**\n   * @deprecated Will be removed and instead to change the template of a specific column\n   * use the new approach instead by following the naming convention column id + IdListValue\n   * e.g. for a column with the id 'status' in DataListGrid use pTemplate=\"statusIdListValue\"\n   */\n  @Input() customListValueTemplate: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be removed and instead to change the template of a specific column\n   * use the new approach instead by following the naming convention column id + IdListValue\n   * e.g. for a column with the id 'status' DataListGrid use pTemplate=\"statusIdListValue\"\n   */\n  @ContentChild('customListValue') customListValueChildTemplate: TemplateRef<any> | undefined\n  get _customListValue(): TemplateRef<any> | undefined {\n    return this.customListValueTemplate || this.customListValueChildTemplate\n  }\n  @Input() stringListValueTemplate: TemplateRef<any> | undefined\n  @ContentChild('stringListValue') stringListValueChildTemplate: TemplateRef<any> | undefined\n  get _stringListValue(): TemplateRef<any> | undefined {\n    return this.stringListValueTemplate || this.stringListValueChildTemplate\n  }\n  @Input() dateListValueTemplate: TemplateRef<any> | undefined\n  @ContentChild('dateListValue') dateListValueChildTemplate: TemplateRef<any> | undefined\n  get _dateListValue(): TemplateRef<any> | undefined {\n    return this.dateListValueTemplate || this.dateListValueChildTemplate\n  }\n  @Input() tableFilterCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('tableFilterCell') tableFilterCellChildTemplate: TemplateRef<any> | undefined\n  get _tableFilterCell(): TemplateRef<any> | undefined {\n    return this.tableFilterCellTemplate || this.tableFilterCellChildTemplate\n  }\n  @Input() dateTableFilterCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('dateFilterCell') dateTableFilterCellChildTemplate: TemplateRef<any> | undefined\n  get _dateTableFilterCell(): TemplateRef<any> | undefined {\n    return this.dateTableFilterCellTemplate || this.dateTableFilterCellChildTemplate\n  }\n  @Input() relativeDateTableFilterCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('relativeDateTableFilterCell') relativeDateTableFilterCellChildTemplate: TemplateRef<any> | undefined\n  get _relativeDateTableFilterCell(): TemplateRef<any> | undefined {\n    return this.relativeDateTableFilterCellTemplate || this.relativeDateTableFilterCellChildTemplate\n  }\n  @Input() translationKeyTableFilterCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('translationKeyTableFilterCell') translationKeyTableFilterCellChildTemplate:\n    | TemplateRef<any>\n    | undefined\n  get _translationKeyTableFilterCell(): TemplateRef<any> | undefined {\n    return this.translationKeyTableFilterCellTemplate || this.translationKeyTableFilterCellChildTemplate\n  }\n  @Input() stringTableFilterCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('stringTableFilterCell') stringTableFilterCellChildTemplate: TemplateRef<any> | undefined\n  get _stringTableFilterCell(): TemplateRef<any> | undefined {\n    return this.stringTableFilterCellTemplate || this.stringTableFilterCellChildTemplate\n  }\n  @Input() numberTableFilterCellTemplate: TemplateRef<any> | undefined\n  @ContentChild('numberTableFilterCell') numberTableFilterCellChildTemplate: TemplateRef<any> | undefined\n  get _numberTableFilterCell(): TemplateRef<any> | undefined {\n    return this.numberTableFilterCellTemplate || this.numberTableFilterCellChildTemplate\n  }\n  /**\n   * @deprecated Will be removed and instead to change the template of a specific column filter\n   * use the new approach instead by following the naming convention column id + IdTableFilterCell\n   * e.g. for a column with the id 'status' in DataTable use pTemplate=\"statusIdTableFilterCell\"\n   */\n  @Input() customTableFilterCellTemplate: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be removed and instead to change the template of a specific column filter\n   * use the new approach instead by following the naming convention column id + IdTableFilterCell\n   * e.g. for a column with the id 'status' in DataTable use pTemplate=\"statusIdTableFilterCell\"\n   */\n  @ContentChild('customTableFilterCell') customTableFilterCellChildTemplate: TemplateRef<any> | undefined\n  get _customTableFilterCell(): TemplateRef<any> | undefined {\n    return this.customTableFilterCellTemplate || this.customTableFilterCellChildTemplate\n  }\n\n  @Input() additionalActions: DataAction[] = []\n\n  @Output() filtered = new EventEmitter<Filter[]>()\n  @Output() sorted = new EventEmitter<Sort>()\n  @Output() deleteItem = new EventEmitter<RowListGridData>()\n  @Output() viewItem = new EventEmitter<RowListGridData>()\n  @Output() editItem = new EventEmitter<RowListGridData>()\n  @Output() selectionChanged = new EventEmitter<Row[]>()\n  @Output() pageChanged = new EventEmitter<number>()\n  @Output() pageSizeChanged = new EventEmitter<number>()\n  @Output() componentStateChanged = new EventEmitter<DataViewComponentState>()\n  isDeleteItemObserved: boolean | undefined\n  isViewItemObserved: boolean | undefined\n  IsEditItemObserved: boolean | undefined\n  firstColumnId: string | undefined\n\n  parentTemplates$: BehaviorSubject<QueryList<PrimeTemplate> | null | undefined> = new BehaviorSubject<\n    QueryList<PrimeTemplate> | null | undefined\n  >(undefined)\n  @Input()\n  set parentTemplates(value: QueryList<PrimeTemplate> | null | undefined) {\n    this.parentTemplates$.next(value)\n  }\n\n  templates$: BehaviorSubject<QueryList<PrimeTemplate> | undefined> = new BehaviorSubject<\n    QueryList<PrimeTemplate> | undefined\n  >(undefined)\n  @ContentChildren(PrimeTemplate)\n  set templates(value: QueryList<PrimeTemplate> | undefined) {\n    this.templates$.next(value)\n  }\n\n  templatesForChildren$: Observable<QueryList<PrimeTemplate> | undefined> = combineLatest([\n    this.templates$,\n    this.parentTemplates$,\n  ]).pipe(\n    map(([t, pt]) => {\n      const ql = new QueryList<PrimeTemplate>()\n      ql.reset([...(t?.toArray() ?? []), ...(pt?.toArray() ?? [])])\n      return ql\n    })\n  )\n\n  get viewItemObserved(): boolean {\n    return this.injector.get('InteractiveDataViewComponent', null)?.viewItem.observed || this.viewItem.observed\n  }\n  get editItemObserved(): boolean {\n    return this.injector.get('InteractiveDataViewComponent', null)?.editItem.observed || this.editItem.observed\n  }\n  get deleteItemObserved(): boolean {\n    return this.injector.get('InteractiveDataViewComponent', null)?.deleteItem.observed || this.deleteItem.observed\n  }\n  get selectionChangedObserved(): boolean {\n    return (\n      this.injector.get('InteractiveDataViewComponent', null)?.selectionChanged.observed ||\n      this.selectionChanged.observed\n    )\n  }\n\n  constructor(private injector: Injector) {}\n\n  ngOnInit(): void {\n    this.firstColumnId = this.columns[0]?.id\n\n    let dataTableComponentState$: Observable<DataTableComponentState | Record<string, never>> = this.dataTableComponentState$\n    let dataListGridComponentState$: Observable<DataListGridComponentState | Record<string, never>> = this.dataListGridComponentState$\n    if (this.layout === 'table') {\n      dataListGridComponentState$ = dataListGridComponentState$.pipe(startWith({}))\n    } else {\n      dataTableComponentState$ = dataTableComponentState$.pipe(startWith({}))\n    }\n\n    combineLatest([\n      dataTableComponentState$.pipe(timestamp()),\n      dataListGridComponentState$.pipe(timestamp()),\n    ])\n      .pipe(\n        map((componentStates) => {\n          return orderAndMergeValuesByTimestamp(componentStates)\n        })\n      )\n      .subscribe((val) => {this.componentStateChanged.emit(val)})\n  }\n\n  ngAfterContentInit() {\n    this.templates$.value?.forEach((item) => {\n      switch (item.getType()) {\n        case 'stringTableCell':\n          this.stringTableCellChildTemplate = item.template\n          break\n        case 'numberTableCell':\n          this.numberTableCellChildTemplate = item.template\n          break\n        case 'customTableCell':\n          this.customTableCellChildTemplate = item.template\n          break\n        case 'tableDateCell':\n          this.tableDateCellChildTemplate = item.template\n          break\n        case 'dateTableCell':\n          this.dateTableCellChildTemplate = item.template\n          break\n        case 'tableCell':\n          this.tableCellChildTemplate = item.template\n          break\n        case 'tableTranslationKeyCell':\n          this.tableTranslationKeyCellChildTemplate = item.template\n          break\n        case 'translationKeyTableCell':\n          this.translationKeyTableCellChildTemplate = item.template\n          break\n        case 'gridItemSubtitleLines':\n          this.gridItemSubtitleLinesChildTemplate = item.template\n          break\n        case 'listItemSubtitleLines':\n          this.listItemSubtitleLinesChildTemplate = item.template\n          break\n        case 'gridItem':\n          this.gridItemChildTemplate = item.template\n          break\n        case 'listItem':\n          this.listItemChildTemplate = item.template\n          break\n        case 'tableRelativeDateCell':\n          this.tableRelativeDateCellChildTemplate = item.template\n          break\n        case 'relativeDateTableCell':\n          this.relativeDateTableCellChildTemplate = item.template\n          break\n        case 'listValue':\n          this.listValueChildTemplate = item.template\n          break\n        case 'translationKeyListValue':\n          this.translationKeyListValueChildTemplate = item.template\n          break\n        case 'numberListValue':\n          this.numberListValueChildTemplate = item.template\n          break\n        case 'relativeDateListValue':\n          this.relativeDateListValueChildTemplate = item.template\n          break\n        case 'customListValue':\n          this.customListValueChildTemplate = item.template\n          break\n        case 'stringListValue':\n          this.stringListValueChildTemplate = item.template\n          break\n        case 'dateListValue':\n          this.dateListValueChildTemplate = item.template\n          break\n        case 'tableFilterCell':\n          this.tableFilterCellChildTemplate = item.template\n          break\n        case 'dateTableFilterCell':\n          this.dateTableFilterCellChildTemplate = item.template\n          break\n        case 'relativeDateTableFilterCell':\n          this.relativeDateTableFilterCellChildTemplate = item.template\n          break\n        case 'translationKeyTableFilterCell':\n          this.translationKeyTableFilterCellChildTemplate = item.template\n          break\n        case 'stringTableFilterCell':\n          this.stringTableFilterCellChildTemplate = item.template\n          break\n        case 'numberTableFilterCell':\n          this.numberTableFilterCellChildTemplate = item.template\n          break\n        case 'customTableFilterCell':\n          this.customTableFilterCellChildTemplate = item.template\n          break\n      }\n    })\n  }\n\n  ngDoCheck(): void {\n    this.registerEventListenerForDataTable()\n    this.registerEventListenerForListGrid()\n  }\n\n  registerEventListenerForListGrid() {\n    if (this.layout !== 'table') {\n      if (this.deleteItem.observed) {\n        this.isDeleteItemObserved = true\n        if (!this._dataListGridComponent?.deleteItem.observed) {\n          this._dataListGridComponent?.deleteItem.subscribe((event) => {\n            this.deletingElement(event)\n          })\n        }\n      }\n      if (this.viewItem.observed) {\n        this.isViewItemObserved = true\n        if (!this._dataListGridComponent?.viewItem.observed) {\n          this._dataListGridComponent?.viewItem.subscribe((event) => {\n            this.viewingElement(event)\n          })\n        }\n      }\n      if (this.editItem.observed) {\n        this.IsEditItemObserved = true\n        if (!this._dataListGridComponent?.editItem.observed) {\n          this._dataListGridComponent?.editItem.subscribe((event) => {\n            this.editingElement(event)\n          })\n        }\n      }\n    }\n  }\n\n  registerEventListenerForDataTable() {\n    if (this.layout === 'table') {\n      if (this.deleteItem.observed) {\n        this.isDeleteItemObserved = true\n        if (!this._dataTableComponent?.deleteTableRow.observed) {\n          this._dataTableComponent?.deleteTableRow.subscribe((event) => {\n            this.deletingElement(event)\n          })\n        }\n      }\n      if (this.viewItem.observed) {\n        this.isViewItemObserved = true\n        if (!this._dataTableComponent?.viewTableRow.observed) {\n          this._dataTableComponent?.viewTableRow.subscribe((event) => {\n            this.viewingElement(event)\n          })\n        }\n      }\n      if (this.editItem.observed) {\n        this.IsEditItemObserved = true\n        if (!this._dataTableComponent?.editTableRow.observed) {\n          this._dataTableComponent?.editTableRow.subscribe((event) => {\n            this.editingElement(event)\n          })\n        }\n      }\n      if (this.selectionChangedObserved) {\n        if (!this._dataTableComponent?.selectionChanged.observed) {\n          this._dataTableComponent?.selectionChanged.subscribe((event) => {\n            this.onRowSelectionChange(event)\n          })\n        }\n      }\n    }\n  }\n\n  filtering(event: any) {\n    this.filters = event\n    this.filtered.emit(event)\n  }\n\n  sorting(event: any) {\n    this.sortDirection = event.sortDirection\n    this.sortField = event.sortColumn\n    this.sorted.emit(event)\n  }\n\n  deletingElement(event: any) {\n    if (this.isDeleteItemObserved) {\n      this.deleteItem.emit(event)\n    }\n  }\n\n  viewingElement(event: any) {\n    if (this.isViewItemObserved) {\n      this.viewItem.emit(event)\n    }\n  }\n  editingElement(event: any) {\n    if (this.IsEditItemObserved) {\n      this.editItem.emit(event)\n    }\n  }\n\n  onRowSelectionChange(event: Row[]) {\n    if (this.selectionChangedObserved) {\n      this.selectionChanged.emit(event)\n    }\n  }\n\n  onPageChange(event: number) {\n    this.page = event\n    this.pageChanged.emit(event)\n  }\n\n  onPageSizeChange(event: number) {\n    this.pageSize = event\n    this.pageSizeChanged.emit(event)\n  }\n}\n","<div *ngIf=\"layout !== 'table'\">\n  <ocx-data-list-grid\n    #ocxdatalistgrid\n    [name]=\"name\"\n    [data]=\"data\"\n    [columns]=\"columns\"\n    [filters]=\"filters\"\n    [sortDirection]=\"sortDirection\"\n    [sortField]=\"sortField\"\n    [sortStates]=\"sortStates\"\n    [clientSideFiltering]=\"clientSideFiltering\"\n    [clientSideSorting]=\"clientSideSorting\"\n    [titleLineId]=\"titleLineId\"\n    [subtitleLineIds]=\"subtitleLineIds\"\n    [clientSideSorting]=\"true\"\n    [pageSizes]=\"pageSizes\"\n    [pageSize]=\"pageSize\"\n    [paginator]=\"listGridPaginator\"\n    [page]=\"page\"\n    (pageChanged)=\"onPageChange($event)\"\n    (pageSizeChanged)=\"onPageSizeChange($event)\"\n    (componentStateChanged)=\"dataListGridComponentState$.next($event)\"\n    [emptyResultsMessage]=\"emptyResultsMessage\"\n    [layout]=\"layout\"\n    [deletePermission]=\"deletePermission\"\n    [editPermission]=\"editPermission\"\n    [viewPermission]=\"viewPermission\"\n    [deleteActionEnabledField]=\"deleteActionEnabledField\"\n    [deleteActionVisibleField]=\"deleteActionVisibleField\"\n    [editActionEnabledField]=\"editActionEnabledField\"\n    [editActionVisibleField]=\"editActionVisibleField\"\n    [viewActionEnabledField]=\"viewActionEnabledField\"\n    [viewActionVisibleField]=\"viewActionVisibleField\"\n    [additionalActions]=\"additionalActions\"\n    [gridItemSubtitleLinesTemplate]=\"_gridItemSubtitleLines ? gridItemSubtitleLines : undefined\"\n    [listItemSubtitleLinesTemplate]=\"_listItemSubtitleLines ? listItemSubtitleLines : undefined\"\n    [listItemTemplate]=\"_listItem ? listItem : undefined\"\n    [listValueTemplate]=\"_listValue ? listValue : undefined\"\n    [translationKeyListValueTemplate]=\"_translationKeyListValue ? translationKeyListValue : undefined\"\n    [numberListValueTemplate]=\"_numberListValue ? numberListValue : undefined\"\n    [relativeDateListValueTemplate]=\"_relativeDateListValue ? relativeDateListValue : undefined\"\n    [customListValueTemplate]=\"_customListValue ? customListValue : undefined\"\n    [stringListValueTemplate]=\"_stringListValue ? stringListValue : undefined\"\n    [dateListValueTemplate]=\"_dateListValue ? dateListValue : undefined\"\n    [gridItemTemplate]=\"_gridItem ? gridItem  : undefined\"\n    [totalRecordsOnServer]=\"totalRecordsOnServer\"\n    [parentTemplates]=\"templatesForChildren$ | async\"\n  >\n  </ocx-data-list-grid>\n  <ng-template #listItemSubtitleLines let-item>\n    <ng-container\n      *ngIf=\"_listItemSubtitleLines\"\n      [ngTemplateOutlet]=\"_listItemSubtitleLines\"\n      [ngTemplateOutletContext]=\"{$implicit:item}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #gridItemSubtitleLines let-item>\n    <ng-container\n      *ngIf=\"_gridItemSubtitleLines\"\n      [ngTemplateOutlet]=\"_gridItemSubtitleLines\"\n      [ngTemplateOutletContext]=\"{$implicit:item}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #gridItem let-item>\n    <ng-container *ngIf=\"_gridItem\" [ngTemplateOutlet]=\"_gridItem\" [ngTemplateOutletContext]=\"{$implicit:item}\">\n    </ng-container\n  ></ng-template>\n  <ng-template #listItem let-item>\n    <ng-container *ngIf=\"_listItem\" [ngTemplateOutlet]=\"_listItem\" [ngTemplateOutletContext]=\"{$implicit:item}\">\n    </ng-container\n  ></ng-template>\n  <ng-template #listValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_listValue\"\n      [ngTemplateOutlet]=\"_listValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #translationKeyListValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_translationKeyListValue\"\n      [ngTemplateOutlet]=\"_translationKeyListValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #numberListValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_numberListValue\"\n      [ngTemplateOutlet]=\"_numberListValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #relativeDateListValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_relativeDateListValue\"\n      [ngTemplateOutlet]=\"_relativeDateListValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #customListValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_customListValue\"\n      [ngTemplateOutlet]=\"_customListValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #stringListValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_stringListValue\"\n      [ngTemplateOutlet]=\"_stringListValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #dateListValue let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_dateListValue\"\n      [ngTemplateOutlet]=\"_dateListValue\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n</div>\n\n<div *ngIf=\"layout === 'table'\">\n  <ocx-data-table\n    #ocxdatatable\n    [rows]=\"data\"\n    [columns]=\"columns\"\n    [filters]=\"filters\"\n    [sortDirection]=\"sortDirection\"\n    [sortColumn]=\"sortField\"\n    [sortStates]=\"sortStates\"\n    [clientSideFiltering]=\"clientSideFiltering\"\n    [clientSideSorting]=\"clientSideSorting\"\n    [pageSizes]=\"pageSizes\"\n    [pageSize]=\"pageSize\"\n    [paginator]=\"tablePaginator\"\n    [page]=\"page\"\n    (pageChanged)=\"onPageChange($event)\"\n    (pageSizeChanged)=\"onPageSizeChange($event)\"\n    (componentStateChanged)=\"dataTableComponentState$.next($event)\"\n    [selectedRows]=\"selectedRows\"\n    [frozenActionColumn]=\"frozenActionColumn\"\n    [actionColumnPosition]=\"actionColumnPosition\"\n    [emptyResultsMessage]=\"emptyResultsMessage\"\n    [name]=\"name\"\n    [deletePermission]=\"deletePermission\"\n    [editPermission]=\"editPermission\"\n    [viewPermission]=\"viewPermission\"\n    [deleteActionEnabledField]=\"deleteActionEnabledField\"\n    [deleteActionVisibleField]=\"deleteActionVisibleField\"\n    [editActionEnabledField]=\"editActionEnabledField\"\n    [editActionVisibleField]=\"editActionVisibleField\"\n    [viewActionEnabledField]=\"viewActionEnabledField\"\n    [viewActionVisibleField]=\"viewActionVisibleField\"\n    [additionalActions]=\"additionalActions\"\n    [stringCellTemplate]=\"_stringTableCell ? stringCell : undefined\"\n    [numberCellTemplate]=\"_numberTableCell ? numberCell : undefined\"\n    [customCellTemplate]=\"_customTableCell ? customCell : undefined\"\n    [dateCellTemplate]=\"_dateTableCell ? dateCell : undefined\"\n    [relativeDateCellTemplate]=\"_relativeDateTableCell ? relativeDateCell : undefined\"\n    [cellTemplate]=\"_tableCell ? cell : undefined\"\n    [translationKeyCellTemplate]=\"_translationKeyTableCell ? translationKeyCell : undefined\"\n    [filterCellTemplate]=\"_tableFilterCell ? filterCell : undefined\"\n    [dateFilterCellTemplate]=\"_dateTableFilterCell ? dateFilterCell : undefined\"\n    [customFilterCellTemplate]=\"_customTableFilterCell ? customFilterCell : undefined\"\n    [numberFilterCellTemplate]=\"_numberTableFilterCell ? numberFilterCell : undefined\"\n    [stringFilterCellTemplate]=\"_stringTableFilterCell ? stringFilterCell : undefined\"\n    [relativeDateFilterCellTemplate]=\"_relativeDateTableFilterCell ? relativeDateFilterCell : undefined\"\n    [translationKeyFilterCellTemplate]=\"_translationKeyTableFilterCell ? translationKeyFilterCell : undefined\"\n    (sorted)=\"sorting($event)\"\n    (filtered)=\"filtering($event)\"\n    [totalRecordsOnServer]=\"totalRecordsOnServer\"\n    [currentPageShowingKey]=\"currentPageShowingKey\"\n    [currentPageShowingWithTotalOnServerKey]=\"currentPageShowingWithTotalOnServerKey\"\n    [parentTemplates]=\"templatesForChildren$ | async\"\n    [allowSelectAll]=\"tableAllowSelectAll\"\n    [selectionEnabledField]=\"tableSelectionEnabledField\"\n  >\n  </ocx-data-table>\n  <ng-template #stringCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_stringTableCell\"\n      [ngTemplateOutlet]=\"_stringTableCell\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #numberCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_numberTableCell\"\n      [ngTemplateOutlet]=\"_numberTableCell\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #customCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_customTableCell\"\n      [ngTemplateOutlet]=\"_customTableCell\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #dateCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_dateTableCell\"\n      [ngTemplateOutlet]=\"_dateTableCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #relativeDateCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_relativeDateTableCell\"\n      [ngTemplateOutlet]=\"_relativeDateTableCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #cell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_tableCell\"\n      [ngTemplateOutlet]=\"_tableCell\"\n      [ngTemplateOutletContext]=\"{rowObject: rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #translationKeyCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_translationKeyTableCell\"\n      [ngTemplateOutlet]=\"_translationKeyTableCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #stringFilterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_stringTableFilterCell\"\n      [ngTemplateOutlet]=\"_stringTableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container\n  ></ng-template>\n  <ng-template #filterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_tableFilterCell\"\n      [ngTemplateOutlet]=\"_tableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container>\n  </ng-template>\n  <ng-template #dateFilterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_dateTableFilterCell\"\n      [ngTemplateOutlet]=\"_dateTableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container>\n  </ng-template>\n  <ng-template #customFilterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_customTableFilterCell\"\n      [ngTemplateOutlet]=\"_customTableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container>\n  </ng-template>\n  <ng-template #numberFilterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_numberTableFilterCell\"\n      [ngTemplateOutlet]=\"_numberTableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container>\n  </ng-template>\n  <ng-template #relativeDateFilterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_relativeDateTableFilterCell\"\n      [ngTemplateOutlet]=\"_relativeDateTableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container>\n  </ng-template>\n  <ng-template #translationKeyFilterCell let-rowObject=\"rowObject\" let-column=\"column\">\n    <ng-container\n      *ngIf=\"_translationKeyTableFilterCell\"\n      [ngTemplateOutlet]=\"_translationKeyTableFilterCell\"\n      [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n    >\n    </ng-container>\n  </ng-template>\n</div>\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":"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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    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"]}