@onecx/angular-accelerator 5.23.6 → 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.
- package/esm2022/lib/components/data-list-grid/data-list-grid.component.mjs +3 -3
- package/esm2022/lib/components/data-table/data-table.component.mjs +3 -3
- package/esm2022/lib/components/data-view/data-view.component.mjs +1 -1
- package/esm2022/lib/components/interactive-data-view/interactive-data-view.component.mjs +1 -1
- package/esm2022/lib/components/search-header/search-header.component.mjs +19 -14
- package/esm2022/lib/model/data-action.mjs +1 -1
- package/fesm2022/onecx-angular-accelerator.mjs +13 -10
- package/fesm2022/onecx-angular-accelerator.mjs.map +1 -1
- package/lib/components/data-list-grid/data-list-grid.component.d.ts +3 -3
- package/lib/components/data-table/data-table.component.d.ts +3 -3
- package/lib/components/data-view/data-view.component.d.ts +3 -3
- package/lib/components/interactive-data-view/interactive-data-view.component.d.ts +4 -4
- package/lib/components/search-header/search-header.component.d.ts +4 -2
- package/lib/model/data-action.d.ts +1 -1
- package/package.json +1 -1
|
@@ -718,4 +718,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
718
718
|
}], data: [{
|
|
719
719
|
type: Input
|
|
720
720
|
}] } });
|
|
721
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interactive-data-view.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport {\n  BehaviorSubject,\n  Observable,\n  ReplaySubject,\n  combineLatest,\n  distinctUntilChanged,\n  map,\n  startWith,\n  timestamp,\n  withLatestFrom,\n} from 'rxjs'\nimport { DataAction } from '../../model/data-action'\nimport { DataSortDirection } from '../../model/data-sort-direction'\nimport { DataTableColumn } from '../../model/data-table-column.model'\nimport { orderAndMergeValuesByTimestamp } from '../../utils/rxjs-utils'\nimport {\n  ColumnGroupSelectionComponentState,\n  GroupSelectionChangedEvent,\n} from '../column-group-selection/column-group-selection.component'\nimport { PrimeTemplate } from 'primeng/api'\nimport {\n  ActionColumnChangedEvent,\n  ColumnSelectionChangedEvent,\n  CustomGroupColumnSelectorComponentState,\n} from '../custom-group-column-selector/custom-group-column-selector.component'\nimport { SlotService } from '@onecx/angular-remote-components'\nimport { DataLayoutSelectionComponentState } from '../data-layout-selection/data-layout-selection.component'\nimport { DataListGridSortingComponentState } from '../data-list-grid-sorting/data-list-grid-sorting.component'\nimport { Row, Sort } from '../data-table/data-table.component'\nimport { DataViewComponent, DataViewComponentState, RowListGridData } from '../data-view/data-view.component'\nimport { Filter } from '../../model/filter.model'\nimport { limit } from '../../utils/filter.utils'\nimport { FilterViewComponentState, FilterViewDisplayMode } from '../filter-view/filter-view.component'\n\nexport type InteractiveDataViewComponentState = ColumnGroupSelectionComponentState &\n  CustomGroupColumnSelectorComponentState &\n  DataLayoutSelectionComponentState &\n  DataListGridSortingComponentState &\n  DataViewComponentState &\n  FilterViewComponentState\n\nexport interface ColumnGroupData {\n  activeColumns: DataTableColumn[]\n  groupKey: string\n}\n@Component({\n  selector: 'ocx-interactive-data-view',\n  templateUrl: './interactive-data-view.component.html',\n  styleUrls: ['./interactive-data-view.component.css'],\n  providers: [{ provide: 'InteractiveDataViewComponent', useExisting: InteractiveDataViewComponent }],\n})\nexport class InteractiveDataViewComponent implements OnInit, AfterContentInit {\n  _dataViewComponent: DataViewComponent | undefined\n  @ViewChild(DataViewComponent) set dataView(ref: DataViewComponent | undefined) {\n    this._dataViewComponent = ref\n    this.registerEventListenerForDataView()\n  }\n  get dataView(): DataViewComponent | undefined {\n    return this._dataViewComponent\n  }\n\n  columnGroupSelectionComponentState$ = new ReplaySubject<ColumnGroupSelectionComponentState>(1)\n  customGroupColumnSelectorComponentState$ = new ReplaySubject<CustomGroupColumnSelectorComponentState>(1)\n  dataLayoutComponentState$ = new ReplaySubject<DataLayoutSelectionComponentState>(1)\n  dataListGridSortingComponentState$ = new ReplaySubject<DataListGridSortingComponentState>(1)\n  dataViewComponentState$ = new ReplaySubject<DataViewComponentState>(1)\n  filterViewComponentState$ = new ReplaySubject<FilterViewComponentState>(1)\n\n  @Input() searchConfigPermission: string | undefined\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() name = 'Data'\n  @Input() titleLineId: string | undefined\n  @Input() subtitleLineIds: string[] = []\n  @Input() supportedViewLayouts: ('grid' | 'list' | 'table')[] = ['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() sortDirection: DataSortDirection = DataSortDirection.NONE\n  @Input() sortField: any = ''\n  @Input() sortStates: DataSortDirection[] = [\n    DataSortDirection.ASCENDING,\n    DataSortDirection.DESCENDING,\n    DataSortDirection.NONE,\n  ]\n  @Input() pageSizes: number[] = [10, 25, 50]\n  @Input() pageSize: number | undefined\n  @Input() totalRecordsOnServer: number | undefined\n  @Input() layout: 'grid' | 'list' | 'table' = 'table'\n  @Input() defaultGroupKey = ''\n  @Input() customGroupKey = 'OCX_INTERACTIVE_DATA_VIEW.CUSTOM_GROUP'\n  @Input() groupSelectionNoGroupSelectedKey = 'OCX_INTERACTIVE_DATA_VIEW.NO_GROUP_SELECTED'\n  @Input() currentPageShowingKey = 'OCX_DATA_TABLE.SHOWING'\n  @Input() currentPageShowingWithTotalOnServerKey = 'OCX_DATA_TABLE.SHOWING_WITH_TOTAL_ON_SERVER'\n  @Input() additionalActions: DataAction[] = []\n  @Input() listGridPaginator = true\n  @Input() tablePaginator = true\n  @Input() disableFilterView = true\n  @Input() filterViewDisplayMode: FilterViewDisplayMode = 'button'\n  @Input() filterViewChipStyleClass = ''\n  @Input() filterViewTableStyle: { [klass: string]: any } = { 'max-height': '50vh' }\n  @Input() filterViewPanelStyle: { [klass: string]: any } = { 'max-width': '90%' }\n  @Input() selectDisplayedChips: (filters: Filter[], columns: DataTableColumn[]) => Filter[] = (filters) =>\n    limit(filters, 3, { reverse: true })\n  @Input() page = 0\n  @Input() selectedRows: Row[] = []\n  displayedColumnKeys$ = new BehaviorSubject<string[]>([])\n  displayedColumns$: Observable<DataTableColumn[]> | undefined\n  @Input()\n  get displayedColumnKeys(): string[] {\n    return this.displayedColumnKeys$.getValue()\n  }\n  set displayedColumnKeys(value: string[]) {\n    this.displayedColumnKeys$.next(value)\n  }\n  /**\n   * @deprecated Use `displayedColumnKeys` and pass in column ids instead of `DataTableColumn` objects\n   */\n  @Input()\n  get displayedColumns(): DataTableColumn[] {\n    return (\n      (this.displayedColumnKeys\n        .map((d) => this.columns.find((c) => c.id === d))\n        .filter((d) => d) as DataTableColumn[]) ?? []\n    )\n  }\n  set displayedColumns(value: DataTableColumn[]) {\n    this.displayedColumnKeys$.next(value.map((d) => d.id))\n  }\n  @Input() frozenActionColumn = false\n  @Input() actionColumnPosition: 'left' | 'right' = 'right'\n  @ContentChild('tableCell') tableCell: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be replaced by dateTableCell\n   */\n  @ContentChild('tableDateCell') tableDateCell: TemplateRef<any> | undefined\n  @ContentChild('dateTableCell') dateTableCell: TemplateRef<any> | undefined\n\n  /**\n   * @deprecated Will be replaced by relativeDateTableCell\n   */\n  @ContentChild('tableRelativeDateCell') tableRelativeDateCell: TemplateRef<any> | undefined\n  @ContentChild('relativeDateTableCell') relativeDateTableCell: TemplateRef<any> | undefined\n\n  /**\n   * @deprecated Will be replaced by translationKeyTableCell\n   */\n  @ContentChild('tableTranslationKeyCell') tableTranslationKeyCell: TemplateRef<any> | undefined\n  @ContentChild('translationKeyTableCell') translationKeyTableCell: TemplateRef<any> | undefined\n\n  @ContentChild('gridItemSubtitleLines') gridItemSubtitleLines: TemplateRef<any> | undefined\n  @ContentChild('listItemSubtitleLines') listItemSubtitleLines: TemplateRef<any> | undefined\n  @ContentChild('stringTableCell') stringTableCell: TemplateRef<any> | undefined\n  @ContentChild('numberTableCell') numberTableCell: 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') customTableCell: TemplateRef<any> | undefined\n  @ContentChild('gridItem') gridItem: TemplateRef<any> | undefined\n  @ContentChild('listItem') listItem: TemplateRef<any> | undefined\n  @ContentChild('topCenter') topCenter: TemplateRef<any> | undefined\n  @ContentChild('listValue') listValue: TemplateRef<any> | undefined\n  @ContentChild('translationKeyListValue') translationKeyListValue: TemplateRef<any> | undefined\n  @ContentChild('numberListValue') numberListValue: TemplateRef<any> | undefined\n  @ContentChild('relativeDateListValue') relativeDateListValue: 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') customListValue: TemplateRef<any> | undefined\n  @ContentChild('stringListValue') stringListValue: TemplateRef<any> | undefined\n  @ContentChild('dateListValue') dateListValue: TemplateRef<any> | undefined\n  @ContentChild('tableFilterCell') tableFilterCell: TemplateRef<any> | undefined\n  @ContentChild('dateTableFilterCell') dateTableFilterCell: TemplateRef<any> | undefined\n  @ContentChild('relativeDateTableFilterCell') relativeDateTableFilterCell: TemplateRef<any> | undefined\n  @ContentChild('translationKeyTableFilterCell') translationKeyTableFilterCell: TemplateRef<any> | undefined\n  @ContentChild('stringTableFilterCell') stringTableFilterCell: TemplateRef<any> | undefined\n  @ContentChild('numberTableFilterCell') numberTableFilterCell: 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') customTableFilterCell: TemplateRef<any> | undefined\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  @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() dataViewLayoutChange = new EventEmitter<'grid' | 'list' | 'table'>()\n  // TODO: Remove following line once displayedColumns (deprecated) has been removed\n  @Output() displayedColumnsChange = new EventEmitter<DataTableColumn[]>()\n  @Output() displayedColumnKeysChange = new EventEmitter<string[]>()\n  @Output() selectionChanged: EventEmitter<Row[]> = new EventEmitter()\n\n  @Output() pageChanged: EventEmitter<number> = new EventEmitter()\n  @Output() pageSizeChanged = new EventEmitter<number>()\n\n  @Output() componentStateChanged = new EventEmitter<InteractiveDataViewComponentState>()\n\n  selectedGroupKey$ = new BehaviorSubject<string | undefined>('')\n  get selectedGroupKey(): string | undefined {\n    return this.selectedGroupKey$.getValue()\n  }\n  set selectedGroupKey(value: string | undefined) {\n    this.selectedGroupKey$.next(value)\n  }\n  isDeleteItemObserved: boolean | undefined\n  isViewItemObserved: boolean | undefined\n  isEditItemObserved: boolean | undefined\n  firstColumnId: string | undefined\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  get _gridItemSubtitleLines(): TemplateRef<any> | undefined {\n    return this.gridItemSubtitleLines\n  }\n  get _listItemSubtitleLines(): TemplateRef<any> | undefined {\n    return this.listItemSubtitleLines\n  }\n  get _tableCell(): TemplateRef<any> | undefined {\n    return this.tableCell\n  }\n  get _stringTableCell(): TemplateRef<any> | undefined {\n    return this.stringTableCell\n  }\n  get _numberTableCell(): TemplateRef<any> | undefined {\n    return this.numberTableCell\n  }\n  get _customTableCell(): TemplateRef<any> | undefined {\n    return this.customTableCell\n  }\n  get _tableDateCell(): TemplateRef<any> | undefined {\n    return this.dateTableCell ?? this.tableDateCell\n  }\n  get _dateTableCell(): TemplateRef<any> | undefined {\n    return this.dateTableCell\n  }\n  get _tableRelativeDateCell(): TemplateRef<any> | undefined {\n    return this.relativeDateTableCell ?? this.tableRelativeDateCell\n  }\n  get _relativeDateTableCell(): TemplateRef<any> | undefined {\n    return this.relativeDateTableCell\n  }\n  get _tableTranslationKeyCell(): TemplateRef<any> | undefined {\n    return this.translationKeyTableCell ?? this.tableTranslationKeyCell\n  }\n  get _translationKeyTableCell(): TemplateRef<any> | undefined {\n    return this.translationKeyTableCell\n  }\n  get _gridItem(): TemplateRef<any> | undefined {\n    return this.gridItem\n  }\n  get _listItem(): TemplateRef<any> | undefined {\n    return this.listItem\n  }\n  get _listValue(): TemplateRef<any> | undefined {\n    return this.listValue\n  }\n  get _translationKeyListValue(): TemplateRef<any> | undefined {\n    return this.translationKeyListValue\n  }\n  get _numberListValue(): TemplateRef<any> | undefined {\n    return this.numberListValue\n  }\n  get _relativeDateListValue(): TemplateRef<any> | undefined {\n    return this.relativeDateListValue\n  }\n  get _customListValue(): TemplateRef<any> | undefined {\n    return this.customListValue\n  }\n  get _stringListValue(): TemplateRef<any> | undefined {\n    return this.stringListValue\n  }\n  get _dateListValue(): TemplateRef<any> | undefined {\n    return this.dateListValue\n  }\n  get _tableFilterCell(): TemplateRef<any> | undefined {\n    return this.tableFilterCell\n  }\n  get _dateTableFilterCell(): TemplateRef<any> | undefined {\n    return this.dateTableFilterCell\n  }\n  get _relativeDateTableFilterCell(): TemplateRef<any> | undefined {\n    return this.relativeDateTableFilterCell\n  }\n  get _translationKeyTableFilterCell(): TemplateRef<any> | undefined {\n    return this.translationKeyTableFilterCell\n  }\n  get _stringTableFilterCell(): TemplateRef<any> | undefined {\n    return this.stringTableFilterCell\n  }\n  get _numberTableFilterCell(): TemplateRef<any> | undefined {\n    return this.numberTableFilterCell\n  }\n  get _customTableFilterCell(): TemplateRef<any> | undefined {\n    return this.customTableFilterCell\n  }\n\n  _data: RowListGridData[] = []\n  @Input()\n  get data(): RowListGridData[] {\n    return this._data\n  }\n  set data(value: RowListGridData[]) {\n    this._data = value\n  }\n\n  columnGroupSlotName = 'onecx-column-group-selection'\n  isColumnGroupSelectionComponentDefined$: Observable<boolean>\n  groupSelectionChangedSlotEmitter = new EventEmitter<ColumnGroupData | undefined>()\n\n  constructor(private slotService: SlotService) {\n    this.isColumnGroupSelectionComponentDefined$ = this.slotService\n      .isSomeComponentDefinedForSlot(this.columnGroupSlotName)\n      .pipe(startWith(true))\n\n    this.groupSelectionChangedSlotEmitter.subscribe((event: ColumnGroupData | undefined) => {\n      if (event === undefined) {\n        event = {\n          activeColumns: this.displayedColumns,\n          groupKey: this.selectedGroupKey ?? this.defaultGroupKey,\n        }\n      }\n      this.displayedColumnKeys$.next(event.activeColumns.map((col) => col.id))\n      this.selectedGroupKey$.next(event.groupKey)\n      this.displayedColumnsChange.emit(this.displayedColumns)\n      this.displayedColumnKeysChange.emit(this.displayedColumnKeys)\n      this.columnGroupSelectionComponentState$.next({\n        activeColumnGroupKey: event.groupKey,\n        displayedColumns: event.activeColumns,\n      })\n    })\n\n    this.dataViewLayoutChange\n      .pipe(withLatestFrom(this.isColumnGroupSelectionComponentDefined$))\n      .subscribe(([_, columnGroupComponentDefined]) => {\n        if (columnGroupComponentDefined) {\n          if (\n            !(\n              this.columns.find((c) => c.nameKey === this.selectedGroupKey) ||\n              this.selectedGroupKey === this.customGroupKey\n            )\n          ) {\n            this.selectedGroupKey$.next(undefined)\n          }\n        }\n      })\n  }\n\n  ngOnInit(): void {\n    this.selectedGroupKey = this.defaultGroupKey\n    if (!this.displayedColumns || this.displayedColumns.length === 0) {\n      this.displayedColumnKeys = this.columns.map((column) => column.id)\n    }\n    if (this.defaultGroupKey && this.defaultGroupKey !== this.customGroupKey) {\n      this.displayedColumnKeys = this.columns\n        .filter((column) => column.predefinedGroupKeys?.includes(this.defaultGroupKey))\n        .map((column) => column.id)\n    }\n    this.displayedColumns$ = this.displayedColumnKeys$.pipe(\n      distinctUntilChanged((prev, curr) => prev.length === curr.length && prev.every((v) => curr.includes(v))),\n      map(\n        (columnKeys) =>\n          (columnKeys.map((key) => this.columns.find((col) => col.id === key)).filter((d) => d) as DataTableColumn[]) ??\n          []\n      )\n    )\n    this.displayedColumnsChange.emit(this.displayedColumns)\n    this.displayedColumnKeysChange.emit(this.displayedColumnKeys)\n    if (!this.groupSelectionNoGroupSelectedKey) {\n      this.groupSelectionNoGroupSelectedKey = 'OCX_INTERACTIVE_DATA_VIEW.NO_GROUP_SELECTED'\n    }\n    this.firstColumnId = this.columns[0]?.id\n\n    let dataListGridSortingComponentState$: Observable<DataListGridSortingComponentState | Record<string, never>> =\n      this.dataListGridSortingComponentState$\n    let columnGroupSelectionComponentState$: Observable<ColumnGroupSelectionComponentState | Record<string, never>> =\n      this.columnGroupSelectionComponentState$\n    let customGroupColumnSelectorComponentState$: Observable<\n      CustomGroupColumnSelectorComponentState | Record<string, never>\n    > = this.customGroupColumnSelectorComponentState$\n\n    if (this.layout === 'table') {\n      dataListGridSortingComponentState$ = dataListGridSortingComponentState$.pipe(startWith({}))\n    } else {\n      columnGroupSelectionComponentState$ = columnGroupSelectionComponentState$.pipe(\n        startWith({\n          activeColumnGroupKey: this.selectedGroupKey,\n          displayedColumns: this.displayedColumns,\n        })\n      )\n      customGroupColumnSelectorComponentState$ = customGroupColumnSelectorComponentState$.pipe(\n        startWith({\n          actionColumnConfig: {\n            frozen: this.frozenActionColumn,\n            position: this.actionColumnPosition,\n          },\n          displayedColumns: this.displayedColumns,\n          activeColumnGroupKey: this.selectedGroupKey,\n        })\n      )\n    }\n\n    let filterViewComponentState$: Observable<FilterViewComponentState | Record<string, never>> =\n      this.filterViewComponentState$\n    if (this.disableFilterView) {\n      filterViewComponentState$ = filterViewComponentState$.pipe(\n        startWith({\n          filters: this.filters,\n        })\n      )\n    }\n\n    combineLatest([\n      columnGroupSelectionComponentState$.pipe(timestamp()),\n      customGroupColumnSelectorComponentState$.pipe(timestamp()),\n      this.dataLayoutComponentState$.pipe(timestamp()),\n      dataListGridSortingComponentState$.pipe(timestamp()),\n      this.dataViewComponentState$.pipe(timestamp()),\n      filterViewComponentState$.pipe(timestamp()),\n    ])\n      .pipe(\n        map((componentStates) => {\n          return orderAndMergeValuesByTimestamp(componentStates)\n        })\n      )\n      .subscribe((val) => {\n        this.componentStateChanged.emit(val)\n      })\n  }\n\n  ngAfterContentInit() {\n    this.templates$.value?.forEach((item) => {\n      switch (item.getType()) {\n        case 'tableCell':\n          this.tableCell = item.template\n          break\n        case 'tableDateCell':\n          this.tableDateCell = item.template\n          break\n        case 'dateTableCell':\n          this.dateTableCell = item.template\n          break\n        case 'tableRelativeDateCell':\n          this.tableRelativeDateCell = item.template\n          break\n        case 'relativeDateTableCell':\n          this.relativeDateTableCell = item.template\n          break\n        case 'tableTranslationKeyCell':\n          this.tableTranslationKeyCell = item.template\n          break\n        case 'translationKeyTableCell':\n          this.translationKeyTableCell = item.template\n          break\n        case 'gridItemSubtitleLines':\n          this.gridItemSubtitleLines = item.template\n          break\n        case 'listItemSubtitleLines':\n          this.listItemSubtitleLines = item.template\n          break\n        case 'stringTableCell':\n          this.stringTableCell = item.template\n          break\n        case 'numberTableCell':\n          this.numberTableCell = item.template\n          break\n        case 'customTableCell':\n          this.customTableCell = item.template\n          break\n        case 'gridItem':\n          this.gridItem = item.template\n          break\n        case 'listItem':\n          this.listItem = item.template\n          break\n        case 'topCenter':\n          this.topCenter = item.template\n          break\n        case 'listValue':\n          this.listValue = item.template\n          break\n        case 'translationKeyListValue':\n          this.translationKeyListValue = item.template\n          break\n        case 'numberListValue':\n          this.numberListValue = item.template\n          break\n        case 'relativeDateListValue':\n          this.relativeDateListValue = item.template\n          break\n        case 'customListValue':\n          this.customListValue = item.template\n          break\n        case 'stringListValue':\n          this.stringListValue = item.template\n          break\n        case 'dateListValue':\n          this.dateListValue = item.template\n          break\n        case 'tableFilterCell':\n          this.tableFilterCell = item.template\n          break\n        case 'dateTableFilterCell':\n          this.dateTableFilterCell = item.template\n          break\n        case 'relativeDateTableFilterCell':\n          this.relativeDateTableFilterCell = item.template\n          break\n        case 'translationKeyTableFilterCell':\n          this.translationKeyTableFilterCell = item.template\n          break\n        case 'stringTableFilterCell':\n          this.stringTableFilterCell = item.template\n          break\n        case 'numberTableFilterCell':\n          this.numberTableFilterCell = item.template\n          break\n        case 'customTableFilterCell':\n          this.customTableFilterCell = item.template\n          break\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  onDeleteElement(element: RowListGridData) {\n    if (this.isDeleteItemObserved) {\n      this.deleteItem.emit(element)\n    }\n  }\n\n  onViewElement(element: RowListGridData) {\n    if (this.isViewItemObserved) {\n      this.viewItem.emit(element)\n    }\n  }\n\n  onEditElement(element: RowListGridData) {\n    if (this.isEditItemObserved) {\n      this.editItem.emit(element)\n    }\n  }\n\n  onDataViewLayoutChange(layout: 'grid' | 'list' | 'table') {\n    this.layout = layout\n    this.dataViewLayoutChange.emit(layout)\n  }\n\n  onSortChange($event: any) {\n    this.sortField = $event\n    this.sorted.emit({ sortColumn: this.sortField, sortDirection: this.sortDirection })\n  }\n\n  onSortDirectionChange($event: any) {\n    this.sortDirection = $event\n    this.sorted.emit({ sortColumn: this.sortField, sortDirection: this.sortDirection })\n  }\n\n  onColumnGroupSelectionChange(event: GroupSelectionChangedEvent) {\n    this.displayedColumnKeys = event.activeColumns.map((col) => col.id)\n    this.selectedGroupKey = event.groupKey\n    // TODO: Remove following line once displayedColumns (deprecated) has been removed\n    this.displayedColumnsChange.emit(this.displayedColumns)\n    this.displayedColumnKeysChange.emit(this.displayedColumnKeys)\n  }\n\n  registerEventListenerForDataView() {\n    if (this.deleteItem.observed) {\n      this.isDeleteItemObserved = true\n      if (!this._dataViewComponent?.deleteItem.observed) {\n        this._dataViewComponent?.deleteItem.subscribe((event) => {\n          this.onDeleteElement(event)\n        })\n      }\n    }\n    if (this.viewItem.observed) {\n      this.isViewItemObserved = true\n      if (!this._dataViewComponent?.viewItem.observed) {\n        this._dataViewComponent?.viewItem.subscribe((event) => {\n          this.onViewElement(event)\n        })\n      }\n    }\n    if (this.editItem.observed) {\n      this.isEditItemObserved = true\n      if (!this._dataViewComponent?.editItem.observed) {\n        this._dataViewComponent?.editItem.subscribe((event) => {\n          this.onEditElement(event)\n        })\n      }\n    }\n    if (this.selectionChanged.observed) {\n      if (!this._dataViewComponent?.selectionChanged.observed) {\n        this._dataViewComponent?.selectionChanged.subscribe((event) => {\n          this.onRowSelectionChange(event)\n        })\n      }\n    }\n  }\n\n  onColumnSelectionChange(event: ColumnSelectionChangedEvent) {\n    this.displayedColumnKeys = event.activeColumns.map((col) => col.id)\n    this.selectedGroupKey = this.customGroupKey\n    // TODO: Remove following line once displayedColumns (deprecated) has been removed\n    this.displayedColumnsChange.emit(this.displayedColumns)\n    this.displayedColumnKeysChange.emit(this.displayedColumnKeys)\n  }\n\n  onActionColumnConfigChange(event: ActionColumnChangedEvent) {\n    this.frozenActionColumn = event.frozenActionColumn\n    this.actionColumnPosition = event.actionColumnPosition\n  }\n\n  onRowSelectionChange(event: Row[]) {\n    if (this.selectionChanged.observed) {\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 class=\"p-3 border-bottom-1 surface-border\">\n  <div class=\"flex flex-wrap justify-content-between align-items-center py-1 gap-2\">\n    <div class=\"flex flex-wrap justify-content-start align-items-center gap-2\">\n      <ocx-data-layout-selection\n        [supportedViewLayouts]=\"supportedViewLayouts\"\n        [layout]=\"layout\"\n        (dataViewLayoutChange)=\"onDataViewLayoutChange($event)\"\n        (componentStateChanged)=\"dataLayoutComponentState$.next($event)\"\n      ></ocx-data-layout-selection>\n      <ocx-filter-view\n        *ngIf=\"!disableFilterView\"\n        [filters]=\"filters\"\n        [columns]=\"columns\"\n        [templates]=\"templates$ | async\"\n        [displayMode]=\"filterViewDisplayMode\"\n        [selectDisplayedChips]=\"selectDisplayedChips\"\n        [chipStyleClass]=\"filterViewChipStyleClass\"\n        [tableStyle]=\"filterViewTableStyle\"\n        (filtered)=\"filtering($event)\"\n        (componentStateChanged)=\"filterViewComponentState$.next($event)\"\n      ></ocx-filter-view>\n    </div>\n\n    <div *ngIf=\"topCenter\">\n      <ng-container [ngTemplateOutlet]=\"topCenter\"> </ng-container>\n    </div>\n\n    <div *ngIf=\"layout !== 'table'\" class=\"flex align-items-center gap-2\">\n      <ocx-data-list-grid-sorting\n        [sortDirection]=\"sortDirection\"\n        [sortField]=\"sortField\"\n        [columns]=\"(displayedColumns$ | async) ?? []\"\n        [sortStates]=\"sortStates\"\n        (sortChange)=\"onSortChange($event)\"\n        (sortDirectionChange)=\"onSortDirectionChange($event)\"\n        (componentStateChanged)=\"dataListGridSortingComponentState$.next($event)\"\n      ></ocx-data-list-grid-sorting>\n    </div>\n\n    <div\n      [ngStyle]=\"layout !== 'table' ? {\n      'position': 'absolute'\n    } : {}\"\n      class=\"flex flex-wrap justify-content-between align-items-center gap-2\"\n    >\n      <ng-container *ngIf=\"isColumnGroupSelectionComponentDefined$ | async; else defaultColumnGroupSelectionComponent\">\n        <ng-container *ngIf=\"displayedColumnKeys$ | async as displayedColumnKeys\">\n          <ocx-slot\n            [ngStyle]=\"layout !== 'table' ? {'display' : 'none'}  : {}\"\n            *ocxIfPermission=\"searchConfigPermission; elseTemplate: defaultColumnGroupSelectionComponent\"\n            name=\"{{columnGroupSlotName}}\"\n            [inputs]=\"{ placeholderKey: groupSelectionNoGroupSelectedKey, defaultGroupKey: defaultGroupKey, customGroupKey: customGroupKey, columns: columns, selectedGroupKey: selectedGroupKey, layout: layout, displayedColumnsIds: displayedColumnKeys }\"\n            [outputs]=\"{ groupSelectionChanged: groupSelectionChangedSlotEmitter }\"\n          >\n            <ng-template #skeleton>\n              <div class=\"flex\">\n                <p-skeleton width=\"18rem\" height=\"3rem\"></p-skeleton>\n              </div>\n            </ng-template>\n          </ocx-slot>\n        </ng-container>\n      </ng-container>\n\n      <ocx-custom-group-column-selector\n        *ngIf=\"layout === 'table'\"\n        [columns]=\"columns\"\n        [displayedColumns]=\"(displayedColumns$ | async) ?? []\"\n        [customGroupKey]=\"customGroupKey\"\n        (columnSelectionChanged)=\"onColumnSelectionChange($event)\"\n        [frozenActionColumn]=\"frozenActionColumn\"\n        [actionColumnPosition]=\"actionColumnPosition\"\n        (actionColumnConfigChanged)=\"onActionColumnConfigChange($event)\"\n        (componentStateChanged)=\"customGroupColumnSelectorComponentState$.next($event)\"\n      ></ocx-custom-group-column-selector>\n    </div>\n  </div>\n</div>\n<div class=\"p-3\">\n  <ocx-data-view\n    [columns]=\"(displayedColumns$ | async) ?? []\"\n    [sortStates]=\"sortStates\"\n    [sortField]=\"sortField\"\n    [filters]=\"filters\"\n    [data]=\"data\"\n    [sortDirection]=\"sortDirection\"\n    [titleLineId]=\"titleLineId\"\n    [subtitleLineIds]=\"subtitleLineIds\"\n    [clientSideSorting]=\"clientSideSorting\"\n    [clientSideFiltering]=\"clientSideFiltering\"\n    [pageSizes]=\"pageSizes\"\n    [pageSize]=\"pageSize\"\n    [emptyResultsMessage]=\"emptyResultsMessage\"\n    [layout]=\"layout\"\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    [listGridPaginator]=\"listGridPaginator\"\n    [tablePaginator]=\"tablePaginator\"\n    [page]=\"page\"\n    (pageChanged)=\"onPageChange($event)\"\n    (pageSizeChanged)=\"onPageSizeChange($event)\"\n    [selectedRows]=\"selectedRows\"\n    [frozenActionColumn]=\"frozenActionColumn\"\n    [actionColumnPosition]=\"actionColumnPosition\"\n    [stringTableCellTemplate]=\"_stringTableCell ? stringTableCell : undefined\"\n    [numberTableCellTemplate]=\"_numberTableCell ? numberTableCell : undefined\"\n    [customTableCellTemplate]=\"_customTableCell ? customTableCell : undefined\"\n    [dateTableCellTemplate]=\"_dateTableCell ? dateTableCell : _tableDateCell ? tableDateCell : undefined\"\n    [relativeDateTableCellTemplate]=\"_relativeDateTableCell ? relativeDateTableCell : _tableRelativeDateCell ? tableRelativeDateCell : undefined\"\n    [tableCellTemplate]=\"_tableCell ? tableCell : undefined\"\n    [translationKeyTableCellTemplate]=\"_translationKeyTableCell ? translationKeyTableCell : _tableTranslationKeyCell ? tableTranslationKeyCell : undefined\"\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    [tableFilterCellTemplate]=\"_tableFilterCell ? tableFilterCell : undefined\"\n    [dateTableFilterCellTemplate]=\"_dateTableFilterCell ? dateTableFilterCell : undefined\"\n    [customTableFilterCellTemplate]=\"_customTableFilterCell ? customTableFilterCell : undefined\"\n    [numberTableFilterCellTemplate]=\"_numberTableFilterCell ? numberTableFilterCell : undefined\"\n    [stringTableFilterCellTemplate]=\"_stringTableFilterCell ? stringTableFilterCell : undefined\"\n    [relativeDateTableFilterCellTemplate]=\"_relativeDateTableFilterCell ? relativeDateTableFilterCell : undefined\"\n    [translationKeyTableFilterCellTemplate]=\"_translationKeyTableFilterCell ? translationKeyTableFilterCell : undefined\"\n    (sorted)=\"sorting($event)\"\n    (filtered)=\"filtering($event)\"\n    [totalRecordsOnServer]=\"totalRecordsOnServer\"\n    [currentPageShowingKey]=\"currentPageShowingKey\"\n    [currentPageShowingWithTotalOnServerKey]=\"currentPageShowingWithTotalOnServerKey\"\n    (componentStateChanged)=\"dataViewComponentState$.next($event)\"\n    [parentTemplates]=\"templates$ | async\"\n    [tableAllowSelectAll]=\"tableAllowSelectAll\"\n    [tableSelectionEnabledField]=\"tableSelectionEnabledField\"\n  >\n  </ocx-data-view>\n</div>\n\n<ng-template #defaultColumnGroupSelectionComponent>\n  <ocx-column-group-selection\n    *ngIf=\"layout === 'table'\"\n    [selectedGroupKey]=\"selectedGroupKey ?? defaultGroupKey\"\n    [columns]=\"columns\"\n    [defaultGroupKey]=\"defaultGroupKey !== customGroupKey ? defaultGroupKey : ''\"\n    [customGroupKey]=\"customGroupKey\"\n    [placeholderKey]=\"groupSelectionNoGroupSelectedKey\"\n    (groupSelectionChanged)=\"onColumnGroupSelectionChange($event)\"\n    (componentStateChanged)=\"columnGroupSelectionComponentState$.next($event)\"\n  ></ocx-column-group-selection>\n</ng-template>\n\n<ng-template #stringTableCell 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 #tableDateCell let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container\n    *ngIf=\"_tableDateCell\"\n    [ngTemplateOutlet]=\"_tableDateCell\"\n    [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n  >\n  </ng-container\n></ng-template>\n<ng-template #dateTableCell 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 #tableRelativeDateCell let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container\n    *ngIf=\"_tableRelativeDateCell\"\n    [ngTemplateOutlet]=\"_tableRelativeDateCell\"\n    [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n  >\n  </ng-container\n></ng-template>\n<ng-template #relativeDateTableCell 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 #tableCell 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 #tableTranslationKeyCell let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container\n    *ngIf=\"_tableTranslationKeyCell\"\n    [ngTemplateOutlet]=\"_tableTranslationKeyCell\"\n    [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n  >\n  </ng-container\n></ng-template>\n<ng-template #translationKeyTableCell 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 #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 #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 #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\n<ng-template #stringTableFilterCell 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 #numberTableFilterCell 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 #customTableFilterCell 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 #dateTableFilterCell 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 #relativeDateTableFilterCell 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 #translationKeyTableFilterCell 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"]}
|
|
721
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interactive-data-view.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport {\n  BehaviorSubject,\n  Observable,\n  ReplaySubject,\n  combineLatest,\n  distinctUntilChanged,\n  map,\n  startWith,\n  timestamp,\n  withLatestFrom,\n} from 'rxjs'\nimport { DataAction } from '../../model/data-action'\nimport { DataSortDirection } from '../../model/data-sort-direction'\nimport { DataTableColumn } from '../../model/data-table-column.model'\nimport { orderAndMergeValuesByTimestamp } from '../../utils/rxjs-utils'\nimport {\n  ColumnGroupSelectionComponentState,\n  GroupSelectionChangedEvent,\n} from '../column-group-selection/column-group-selection.component'\nimport { PrimeTemplate } from 'primeng/api'\nimport {\n  ActionColumnChangedEvent,\n  ColumnSelectionChangedEvent,\n  CustomGroupColumnSelectorComponentState,\n} from '../custom-group-column-selector/custom-group-column-selector.component'\nimport { SlotService } from '@onecx/angular-remote-components'\nimport { DataLayoutSelectionComponentState } from '../data-layout-selection/data-layout-selection.component'\nimport { DataListGridSortingComponentState } from '../data-list-grid-sorting/data-list-grid-sorting.component'\nimport { Row, Sort } from '../data-table/data-table.component'\nimport { DataViewComponent, DataViewComponentState, RowListGridData } from '../data-view/data-view.component'\nimport { Filter } from '../../model/filter.model'\nimport { limit } from '../../utils/filter.utils'\nimport { FilterViewComponentState, FilterViewDisplayMode } from '../filter-view/filter-view.component'\n\nexport type InteractiveDataViewComponentState = ColumnGroupSelectionComponentState &\n  CustomGroupColumnSelectorComponentState &\n  DataLayoutSelectionComponentState &\n  DataListGridSortingComponentState &\n  DataViewComponentState &\n  FilterViewComponentState\n\nexport interface ColumnGroupData {\n  activeColumns: DataTableColumn[]\n  groupKey: string\n}\n@Component({\n  selector: 'ocx-interactive-data-view',\n  templateUrl: './interactive-data-view.component.html',\n  styleUrls: ['./interactive-data-view.component.css'],\n  providers: [{ provide: 'InteractiveDataViewComponent', useExisting: InteractiveDataViewComponent }],\n})\nexport class InteractiveDataViewComponent implements OnInit, AfterContentInit {\n  _dataViewComponent: DataViewComponent | undefined\n  @ViewChild(DataViewComponent) set dataView(ref: DataViewComponent | undefined) {\n    this._dataViewComponent = ref\n    this.registerEventListenerForDataView()\n  }\n  get dataView(): DataViewComponent | undefined {\n    return this._dataViewComponent\n  }\n\n  columnGroupSelectionComponentState$ = new ReplaySubject<ColumnGroupSelectionComponentState>(1)\n  customGroupColumnSelectorComponentState$ = new ReplaySubject<CustomGroupColumnSelectorComponentState>(1)\n  dataLayoutComponentState$ = new ReplaySubject<DataLayoutSelectionComponentState>(1)\n  dataListGridSortingComponentState$ = new ReplaySubject<DataListGridSortingComponentState>(1)\n  dataViewComponentState$ = new ReplaySubject<DataViewComponentState>(1)\n  filterViewComponentState$ = new ReplaySubject<FilterViewComponentState>(1)\n\n  @Input() searchConfigPermission: string | string[] | undefined\n  @Input() deletePermission: string | 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() name = 'Data'\n  @Input() titleLineId: string | undefined\n  @Input() subtitleLineIds: string[] = []\n  @Input() supportedViewLayouts: ('grid' | 'list' | 'table')[] = ['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() sortDirection: DataSortDirection = DataSortDirection.NONE\n  @Input() sortField: any = ''\n  @Input() sortStates: DataSortDirection[] = [\n    DataSortDirection.ASCENDING,\n    DataSortDirection.DESCENDING,\n    DataSortDirection.NONE,\n  ]\n  @Input() pageSizes: number[] = [10, 25, 50]\n  @Input() pageSize: number | undefined\n  @Input() totalRecordsOnServer: number | undefined\n  @Input() layout: 'grid' | 'list' | 'table' = 'table'\n  @Input() defaultGroupKey = ''\n  @Input() customGroupKey = 'OCX_INTERACTIVE_DATA_VIEW.CUSTOM_GROUP'\n  @Input() groupSelectionNoGroupSelectedKey = 'OCX_INTERACTIVE_DATA_VIEW.NO_GROUP_SELECTED'\n  @Input() currentPageShowingKey = 'OCX_DATA_TABLE.SHOWING'\n  @Input() currentPageShowingWithTotalOnServerKey = 'OCX_DATA_TABLE.SHOWING_WITH_TOTAL_ON_SERVER'\n  @Input() additionalActions: DataAction[] = []\n  @Input() listGridPaginator = true\n  @Input() tablePaginator = true\n  @Input() disableFilterView = true\n  @Input() filterViewDisplayMode: FilterViewDisplayMode = 'button'\n  @Input() filterViewChipStyleClass = ''\n  @Input() filterViewTableStyle: { [klass: string]: any } = { 'max-height': '50vh' }\n  @Input() filterViewPanelStyle: { [klass: string]: any } = { 'max-width': '90%' }\n  @Input() selectDisplayedChips: (filters: Filter[], columns: DataTableColumn[]) => Filter[] = (filters) =>\n    limit(filters, 3, { reverse: true })\n  @Input() page = 0\n  @Input() selectedRows: Row[] = []\n  displayedColumnKeys$ = new BehaviorSubject<string[]>([])\n  displayedColumns$: Observable<DataTableColumn[]> | undefined\n  @Input()\n  get displayedColumnKeys(): string[] {\n    return this.displayedColumnKeys$.getValue()\n  }\n  set displayedColumnKeys(value: string[]) {\n    this.displayedColumnKeys$.next(value)\n  }\n  /**\n   * @deprecated Use `displayedColumnKeys` and pass in column ids instead of `DataTableColumn` objects\n   */\n  @Input()\n  get displayedColumns(): DataTableColumn[] {\n    return (\n      (this.displayedColumnKeys\n        .map((d) => this.columns.find((c) => c.id === d))\n        .filter((d) => d) as DataTableColumn[]) ?? []\n    )\n  }\n  set displayedColumns(value: DataTableColumn[]) {\n    this.displayedColumnKeys$.next(value.map((d) => d.id))\n  }\n  @Input() frozenActionColumn = false\n  @Input() actionColumnPosition: 'left' | 'right' = 'right'\n  @ContentChild('tableCell') tableCell: TemplateRef<any> | undefined\n  /**\n   * @deprecated Will be replaced by dateTableCell\n   */\n  @ContentChild('tableDateCell') tableDateCell: TemplateRef<any> | undefined\n  @ContentChild('dateTableCell') dateTableCell: TemplateRef<any> | undefined\n\n  /**\n   * @deprecated Will be replaced by relativeDateTableCell\n   */\n  @ContentChild('tableRelativeDateCell') tableRelativeDateCell: TemplateRef<any> | undefined\n  @ContentChild('relativeDateTableCell') relativeDateTableCell: TemplateRef<any> | undefined\n\n  /**\n   * @deprecated Will be replaced by translationKeyTableCell\n   */\n  @ContentChild('tableTranslationKeyCell') tableTranslationKeyCell: TemplateRef<any> | undefined\n  @ContentChild('translationKeyTableCell') translationKeyTableCell: TemplateRef<any> | undefined\n\n  @ContentChild('gridItemSubtitleLines') gridItemSubtitleLines: TemplateRef<any> | undefined\n  @ContentChild('listItemSubtitleLines') listItemSubtitleLines: TemplateRef<any> | undefined\n  @ContentChild('stringTableCell') stringTableCell: TemplateRef<any> | undefined\n  @ContentChild('numberTableCell') numberTableCell: 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') customTableCell: TemplateRef<any> | undefined\n  @ContentChild('gridItem') gridItem: TemplateRef<any> | undefined\n  @ContentChild('listItem') listItem: TemplateRef<any> | undefined\n  @ContentChild('topCenter') topCenter: TemplateRef<any> | undefined\n  @ContentChild('listValue') listValue: TemplateRef<any> | undefined\n  @ContentChild('translationKeyListValue') translationKeyListValue: TemplateRef<any> | undefined\n  @ContentChild('numberListValue') numberListValue: TemplateRef<any> | undefined\n  @ContentChild('relativeDateListValue') relativeDateListValue: 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') customListValue: TemplateRef<any> | undefined\n  @ContentChild('stringListValue') stringListValue: TemplateRef<any> | undefined\n  @ContentChild('dateListValue') dateListValue: TemplateRef<any> | undefined\n  @ContentChild('tableFilterCell') tableFilterCell: TemplateRef<any> | undefined\n  @ContentChild('dateTableFilterCell') dateTableFilterCell: TemplateRef<any> | undefined\n  @ContentChild('relativeDateTableFilterCell') relativeDateTableFilterCell: TemplateRef<any> | undefined\n  @ContentChild('translationKeyTableFilterCell') translationKeyTableFilterCell: TemplateRef<any> | undefined\n  @ContentChild('stringTableFilterCell') stringTableFilterCell: TemplateRef<any> | undefined\n  @ContentChild('numberTableFilterCell') numberTableFilterCell: 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') customTableFilterCell: TemplateRef<any> | undefined\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  @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() dataViewLayoutChange = new EventEmitter<'grid' | 'list' | 'table'>()\n  // TODO: Remove following line once displayedColumns (deprecated) has been removed\n  @Output() displayedColumnsChange = new EventEmitter<DataTableColumn[]>()\n  @Output() displayedColumnKeysChange = new EventEmitter<string[]>()\n  @Output() selectionChanged: EventEmitter<Row[]> = new EventEmitter()\n\n  @Output() pageChanged: EventEmitter<number> = new EventEmitter()\n  @Output() pageSizeChanged = new EventEmitter<number>()\n\n  @Output() componentStateChanged = new EventEmitter<InteractiveDataViewComponentState>()\n\n  selectedGroupKey$ = new BehaviorSubject<string | undefined>('')\n  get selectedGroupKey(): string | undefined {\n    return this.selectedGroupKey$.getValue()\n  }\n  set selectedGroupKey(value: string | undefined) {\n    this.selectedGroupKey$.next(value)\n  }\n  isDeleteItemObserved: boolean | undefined\n  isViewItemObserved: boolean | undefined\n  isEditItemObserved: boolean | undefined\n  firstColumnId: string | undefined\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  get _gridItemSubtitleLines(): TemplateRef<any> | undefined {\n    return this.gridItemSubtitleLines\n  }\n  get _listItemSubtitleLines(): TemplateRef<any> | undefined {\n    return this.listItemSubtitleLines\n  }\n  get _tableCell(): TemplateRef<any> | undefined {\n    return this.tableCell\n  }\n  get _stringTableCell(): TemplateRef<any> | undefined {\n    return this.stringTableCell\n  }\n  get _numberTableCell(): TemplateRef<any> | undefined {\n    return this.numberTableCell\n  }\n  get _customTableCell(): TemplateRef<any> | undefined {\n    return this.customTableCell\n  }\n  get _tableDateCell(): TemplateRef<any> | undefined {\n    return this.dateTableCell ?? this.tableDateCell\n  }\n  get _dateTableCell(): TemplateRef<any> | undefined {\n    return this.dateTableCell\n  }\n  get _tableRelativeDateCell(): TemplateRef<any> | undefined {\n    return this.relativeDateTableCell ?? this.tableRelativeDateCell\n  }\n  get _relativeDateTableCell(): TemplateRef<any> | undefined {\n    return this.relativeDateTableCell\n  }\n  get _tableTranslationKeyCell(): TemplateRef<any> | undefined {\n    return this.translationKeyTableCell ?? this.tableTranslationKeyCell\n  }\n  get _translationKeyTableCell(): TemplateRef<any> | undefined {\n    return this.translationKeyTableCell\n  }\n  get _gridItem(): TemplateRef<any> | undefined {\n    return this.gridItem\n  }\n  get _listItem(): TemplateRef<any> | undefined {\n    return this.listItem\n  }\n  get _listValue(): TemplateRef<any> | undefined {\n    return this.listValue\n  }\n  get _translationKeyListValue(): TemplateRef<any> | undefined {\n    return this.translationKeyListValue\n  }\n  get _numberListValue(): TemplateRef<any> | undefined {\n    return this.numberListValue\n  }\n  get _relativeDateListValue(): TemplateRef<any> | undefined {\n    return this.relativeDateListValue\n  }\n  get _customListValue(): TemplateRef<any> | undefined {\n    return this.customListValue\n  }\n  get _stringListValue(): TemplateRef<any> | undefined {\n    return this.stringListValue\n  }\n  get _dateListValue(): TemplateRef<any> | undefined {\n    return this.dateListValue\n  }\n  get _tableFilterCell(): TemplateRef<any> | undefined {\n    return this.tableFilterCell\n  }\n  get _dateTableFilterCell(): TemplateRef<any> | undefined {\n    return this.dateTableFilterCell\n  }\n  get _relativeDateTableFilterCell(): TemplateRef<any> | undefined {\n    return this.relativeDateTableFilterCell\n  }\n  get _translationKeyTableFilterCell(): TemplateRef<any> | undefined {\n    return this.translationKeyTableFilterCell\n  }\n  get _stringTableFilterCell(): TemplateRef<any> | undefined {\n    return this.stringTableFilterCell\n  }\n  get _numberTableFilterCell(): TemplateRef<any> | undefined {\n    return this.numberTableFilterCell\n  }\n  get _customTableFilterCell(): TemplateRef<any> | undefined {\n    return this.customTableFilterCell\n  }\n\n  _data: RowListGridData[] = []\n  @Input()\n  get data(): RowListGridData[] {\n    return this._data\n  }\n  set data(value: RowListGridData[]) {\n    this._data = value\n  }\n\n  columnGroupSlotName = 'onecx-column-group-selection'\n  isColumnGroupSelectionComponentDefined$: Observable<boolean>\n  groupSelectionChangedSlotEmitter = new EventEmitter<ColumnGroupData | undefined>()\n\n  constructor(private slotService: SlotService) {\n    this.isColumnGroupSelectionComponentDefined$ = this.slotService\n      .isSomeComponentDefinedForSlot(this.columnGroupSlotName)\n      .pipe(startWith(true))\n\n    this.groupSelectionChangedSlotEmitter.subscribe((event: ColumnGroupData | undefined) => {\n      if (event === undefined) {\n        event = {\n          activeColumns: this.displayedColumns,\n          groupKey: this.selectedGroupKey ?? this.defaultGroupKey,\n        }\n      }\n      this.displayedColumnKeys$.next(event.activeColumns.map((col) => col.id))\n      this.selectedGroupKey$.next(event.groupKey)\n      this.displayedColumnsChange.emit(this.displayedColumns)\n      this.displayedColumnKeysChange.emit(this.displayedColumnKeys)\n      this.columnGroupSelectionComponentState$.next({\n        activeColumnGroupKey: event.groupKey,\n        displayedColumns: event.activeColumns,\n      })\n    })\n\n    this.dataViewLayoutChange\n      .pipe(withLatestFrom(this.isColumnGroupSelectionComponentDefined$))\n      .subscribe(([_, columnGroupComponentDefined]) => {\n        if (columnGroupComponentDefined) {\n          if (\n            !(\n              this.columns.find((c) => c.nameKey === this.selectedGroupKey) ||\n              this.selectedGroupKey === this.customGroupKey\n            )\n          ) {\n            this.selectedGroupKey$.next(undefined)\n          }\n        }\n      })\n  }\n\n  ngOnInit(): void {\n    this.selectedGroupKey = this.defaultGroupKey\n    if (!this.displayedColumns || this.displayedColumns.length === 0) {\n      this.displayedColumnKeys = this.columns.map((column) => column.id)\n    }\n    if (this.defaultGroupKey && this.defaultGroupKey !== this.customGroupKey) {\n      this.displayedColumnKeys = this.columns\n        .filter((column) => column.predefinedGroupKeys?.includes(this.defaultGroupKey))\n        .map((column) => column.id)\n    }\n    this.displayedColumns$ = this.displayedColumnKeys$.pipe(\n      distinctUntilChanged((prev, curr) => prev.length === curr.length && prev.every((v) => curr.includes(v))),\n      map(\n        (columnKeys) =>\n          (columnKeys.map((key) => this.columns.find((col) => col.id === key)).filter((d) => d) as DataTableColumn[]) ??\n          []\n      )\n    )\n    this.displayedColumnsChange.emit(this.displayedColumns)\n    this.displayedColumnKeysChange.emit(this.displayedColumnKeys)\n    if (!this.groupSelectionNoGroupSelectedKey) {\n      this.groupSelectionNoGroupSelectedKey = 'OCX_INTERACTIVE_DATA_VIEW.NO_GROUP_SELECTED'\n    }\n    this.firstColumnId = this.columns[0]?.id\n\n    let dataListGridSortingComponentState$: Observable<DataListGridSortingComponentState | Record<string, never>> =\n      this.dataListGridSortingComponentState$\n    let columnGroupSelectionComponentState$: Observable<ColumnGroupSelectionComponentState | Record<string, never>> =\n      this.columnGroupSelectionComponentState$\n    let customGroupColumnSelectorComponentState$: Observable<\n      CustomGroupColumnSelectorComponentState | Record<string, never>\n    > = this.customGroupColumnSelectorComponentState$\n\n    if (this.layout === 'table') {\n      dataListGridSortingComponentState$ = dataListGridSortingComponentState$.pipe(startWith({}))\n    } else {\n      columnGroupSelectionComponentState$ = columnGroupSelectionComponentState$.pipe(\n        startWith({\n          activeColumnGroupKey: this.selectedGroupKey,\n          displayedColumns: this.displayedColumns,\n        })\n      )\n      customGroupColumnSelectorComponentState$ = customGroupColumnSelectorComponentState$.pipe(\n        startWith({\n          actionColumnConfig: {\n            frozen: this.frozenActionColumn,\n            position: this.actionColumnPosition,\n          },\n          displayedColumns: this.displayedColumns,\n          activeColumnGroupKey: this.selectedGroupKey,\n        })\n      )\n    }\n\n    let filterViewComponentState$: Observable<FilterViewComponentState | Record<string, never>> =\n      this.filterViewComponentState$\n    if (this.disableFilterView) {\n      filterViewComponentState$ = filterViewComponentState$.pipe(\n        startWith({\n          filters: this.filters,\n        })\n      )\n    }\n\n    combineLatest([\n      columnGroupSelectionComponentState$.pipe(timestamp()),\n      customGroupColumnSelectorComponentState$.pipe(timestamp()),\n      this.dataLayoutComponentState$.pipe(timestamp()),\n      dataListGridSortingComponentState$.pipe(timestamp()),\n      this.dataViewComponentState$.pipe(timestamp()),\n      filterViewComponentState$.pipe(timestamp()),\n    ])\n      .pipe(\n        map((componentStates) => {\n          return orderAndMergeValuesByTimestamp(componentStates)\n        })\n      )\n      .subscribe((val) => {\n        this.componentStateChanged.emit(val)\n      })\n  }\n\n  ngAfterContentInit() {\n    this.templates$.value?.forEach((item) => {\n      switch (item.getType()) {\n        case 'tableCell':\n          this.tableCell = item.template\n          break\n        case 'tableDateCell':\n          this.tableDateCell = item.template\n          break\n        case 'dateTableCell':\n          this.dateTableCell = item.template\n          break\n        case 'tableRelativeDateCell':\n          this.tableRelativeDateCell = item.template\n          break\n        case 'relativeDateTableCell':\n          this.relativeDateTableCell = item.template\n          break\n        case 'tableTranslationKeyCell':\n          this.tableTranslationKeyCell = item.template\n          break\n        case 'translationKeyTableCell':\n          this.translationKeyTableCell = item.template\n          break\n        case 'gridItemSubtitleLines':\n          this.gridItemSubtitleLines = item.template\n          break\n        case 'listItemSubtitleLines':\n          this.listItemSubtitleLines = item.template\n          break\n        case 'stringTableCell':\n          this.stringTableCell = item.template\n          break\n        case 'numberTableCell':\n          this.numberTableCell = item.template\n          break\n        case 'customTableCell':\n          this.customTableCell = item.template\n          break\n        case 'gridItem':\n          this.gridItem = item.template\n          break\n        case 'listItem':\n          this.listItem = item.template\n          break\n        case 'topCenter':\n          this.topCenter = item.template\n          break\n        case 'listValue':\n          this.listValue = item.template\n          break\n        case 'translationKeyListValue':\n          this.translationKeyListValue = item.template\n          break\n        case 'numberListValue':\n          this.numberListValue = item.template\n          break\n        case 'relativeDateListValue':\n          this.relativeDateListValue = item.template\n          break\n        case 'customListValue':\n          this.customListValue = item.template\n          break\n        case 'stringListValue':\n          this.stringListValue = item.template\n          break\n        case 'dateListValue':\n          this.dateListValue = item.template\n          break\n        case 'tableFilterCell':\n          this.tableFilterCell = item.template\n          break\n        case 'dateTableFilterCell':\n          this.dateTableFilterCell = item.template\n          break\n        case 'relativeDateTableFilterCell':\n          this.relativeDateTableFilterCell = item.template\n          break\n        case 'translationKeyTableFilterCell':\n          this.translationKeyTableFilterCell = item.template\n          break\n        case 'stringTableFilterCell':\n          this.stringTableFilterCell = item.template\n          break\n        case 'numberTableFilterCell':\n          this.numberTableFilterCell = item.template\n          break\n        case 'customTableFilterCell':\n          this.customTableFilterCell = item.template\n          break\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  onDeleteElement(element: RowListGridData) {\n    if (this.isDeleteItemObserved) {\n      this.deleteItem.emit(element)\n    }\n  }\n\n  onViewElement(element: RowListGridData) {\n    if (this.isViewItemObserved) {\n      this.viewItem.emit(element)\n    }\n  }\n\n  onEditElement(element: RowListGridData) {\n    if (this.isEditItemObserved) {\n      this.editItem.emit(element)\n    }\n  }\n\n  onDataViewLayoutChange(layout: 'grid' | 'list' | 'table') {\n    this.layout = layout\n    this.dataViewLayoutChange.emit(layout)\n  }\n\n  onSortChange($event: any) {\n    this.sortField = $event\n    this.sorted.emit({ sortColumn: this.sortField, sortDirection: this.sortDirection })\n  }\n\n  onSortDirectionChange($event: any) {\n    this.sortDirection = $event\n    this.sorted.emit({ sortColumn: this.sortField, sortDirection: this.sortDirection })\n  }\n\n  onColumnGroupSelectionChange(event: GroupSelectionChangedEvent) {\n    this.displayedColumnKeys = event.activeColumns.map((col) => col.id)\n    this.selectedGroupKey = event.groupKey\n    // TODO: Remove following line once displayedColumns (deprecated) has been removed\n    this.displayedColumnsChange.emit(this.displayedColumns)\n    this.displayedColumnKeysChange.emit(this.displayedColumnKeys)\n  }\n\n  registerEventListenerForDataView() {\n    if (this.deleteItem.observed) {\n      this.isDeleteItemObserved = true\n      if (!this._dataViewComponent?.deleteItem.observed) {\n        this._dataViewComponent?.deleteItem.subscribe((event) => {\n          this.onDeleteElement(event)\n        })\n      }\n    }\n    if (this.viewItem.observed) {\n      this.isViewItemObserved = true\n      if (!this._dataViewComponent?.viewItem.observed) {\n        this._dataViewComponent?.viewItem.subscribe((event) => {\n          this.onViewElement(event)\n        })\n      }\n    }\n    if (this.editItem.observed) {\n      this.isEditItemObserved = true\n      if (!this._dataViewComponent?.editItem.observed) {\n        this._dataViewComponent?.editItem.subscribe((event) => {\n          this.onEditElement(event)\n        })\n      }\n    }\n    if (this.selectionChanged.observed) {\n      if (!this._dataViewComponent?.selectionChanged.observed) {\n        this._dataViewComponent?.selectionChanged.subscribe((event) => {\n          this.onRowSelectionChange(event)\n        })\n      }\n    }\n  }\n\n  onColumnSelectionChange(event: ColumnSelectionChangedEvent) {\n    this.displayedColumnKeys = event.activeColumns.map((col) => col.id)\n    this.selectedGroupKey = this.customGroupKey\n    // TODO: Remove following line once displayedColumns (deprecated) has been removed\n    this.displayedColumnsChange.emit(this.displayedColumns)\n    this.displayedColumnKeysChange.emit(this.displayedColumnKeys)\n  }\n\n  onActionColumnConfigChange(event: ActionColumnChangedEvent) {\n    this.frozenActionColumn = event.frozenActionColumn\n    this.actionColumnPosition = event.actionColumnPosition\n  }\n\n  onRowSelectionChange(event: Row[]) {\n    if (this.selectionChanged.observed) {\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 class=\"p-3 border-bottom-1 surface-border\">\n  <div class=\"flex flex-wrap justify-content-between align-items-center py-1 gap-2\">\n    <div class=\"flex flex-wrap justify-content-start align-items-center gap-2\">\n      <ocx-data-layout-selection\n        [supportedViewLayouts]=\"supportedViewLayouts\"\n        [layout]=\"layout\"\n        (dataViewLayoutChange)=\"onDataViewLayoutChange($event)\"\n        (componentStateChanged)=\"dataLayoutComponentState$.next($event)\"\n      ></ocx-data-layout-selection>\n      <ocx-filter-view\n        *ngIf=\"!disableFilterView\"\n        [filters]=\"filters\"\n        [columns]=\"columns\"\n        [templates]=\"templates$ | async\"\n        [displayMode]=\"filterViewDisplayMode\"\n        [selectDisplayedChips]=\"selectDisplayedChips\"\n        [chipStyleClass]=\"filterViewChipStyleClass\"\n        [tableStyle]=\"filterViewTableStyle\"\n        (filtered)=\"filtering($event)\"\n        (componentStateChanged)=\"filterViewComponentState$.next($event)\"\n      ></ocx-filter-view>\n    </div>\n\n    <div *ngIf=\"topCenter\">\n      <ng-container [ngTemplateOutlet]=\"topCenter\"> </ng-container>\n    </div>\n\n    <div *ngIf=\"layout !== 'table'\" class=\"flex align-items-center gap-2\">\n      <ocx-data-list-grid-sorting\n        [sortDirection]=\"sortDirection\"\n        [sortField]=\"sortField\"\n        [columns]=\"(displayedColumns$ | async) ?? []\"\n        [sortStates]=\"sortStates\"\n        (sortChange)=\"onSortChange($event)\"\n        (sortDirectionChange)=\"onSortDirectionChange($event)\"\n        (componentStateChanged)=\"dataListGridSortingComponentState$.next($event)\"\n      ></ocx-data-list-grid-sorting>\n    </div>\n\n    <div\n      [ngStyle]=\"layout !== 'table' ? {\n      'position': 'absolute'\n    } : {}\"\n      class=\"flex flex-wrap justify-content-between align-items-center gap-2\"\n    >\n      <ng-container *ngIf=\"isColumnGroupSelectionComponentDefined$ | async; else defaultColumnGroupSelectionComponent\">\n        <ng-container *ngIf=\"displayedColumnKeys$ | async as displayedColumnKeys\">\n          <ocx-slot\n            [ngStyle]=\"layout !== 'table' ? {'display' : 'none'}  : {}\"\n            *ocxIfPermission=\"searchConfigPermission; elseTemplate: defaultColumnGroupSelectionComponent\"\n            name=\"{{columnGroupSlotName}}\"\n            [inputs]=\"{ placeholderKey: groupSelectionNoGroupSelectedKey, defaultGroupKey: defaultGroupKey, customGroupKey: customGroupKey, columns: columns, selectedGroupKey: selectedGroupKey, layout: layout, displayedColumnsIds: displayedColumnKeys }\"\n            [outputs]=\"{ groupSelectionChanged: groupSelectionChangedSlotEmitter }\"\n          >\n            <ng-template #skeleton>\n              <div class=\"flex\">\n                <p-skeleton width=\"18rem\" height=\"3rem\"></p-skeleton>\n              </div>\n            </ng-template>\n          </ocx-slot>\n        </ng-container>\n      </ng-container>\n\n      <ocx-custom-group-column-selector\n        *ngIf=\"layout === 'table'\"\n        [columns]=\"columns\"\n        [displayedColumns]=\"(displayedColumns$ | async) ?? []\"\n        [customGroupKey]=\"customGroupKey\"\n        (columnSelectionChanged)=\"onColumnSelectionChange($event)\"\n        [frozenActionColumn]=\"frozenActionColumn\"\n        [actionColumnPosition]=\"actionColumnPosition\"\n        (actionColumnConfigChanged)=\"onActionColumnConfigChange($event)\"\n        (componentStateChanged)=\"customGroupColumnSelectorComponentState$.next($event)\"\n      ></ocx-custom-group-column-selector>\n    </div>\n  </div>\n</div>\n<div class=\"p-3\">\n  <ocx-data-view\n    [columns]=\"(displayedColumns$ | async) ?? []\"\n    [sortStates]=\"sortStates\"\n    [sortField]=\"sortField\"\n    [filters]=\"filters\"\n    [data]=\"data\"\n    [sortDirection]=\"sortDirection\"\n    [titleLineId]=\"titleLineId\"\n    [subtitleLineIds]=\"subtitleLineIds\"\n    [clientSideSorting]=\"clientSideSorting\"\n    [clientSideFiltering]=\"clientSideFiltering\"\n    [pageSizes]=\"pageSizes\"\n    [pageSize]=\"pageSize\"\n    [emptyResultsMessage]=\"emptyResultsMessage\"\n    [layout]=\"layout\"\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    [listGridPaginator]=\"listGridPaginator\"\n    [tablePaginator]=\"tablePaginator\"\n    [page]=\"page\"\n    (pageChanged)=\"onPageChange($event)\"\n    (pageSizeChanged)=\"onPageSizeChange($event)\"\n    [selectedRows]=\"selectedRows\"\n    [frozenActionColumn]=\"frozenActionColumn\"\n    [actionColumnPosition]=\"actionColumnPosition\"\n    [stringTableCellTemplate]=\"_stringTableCell ? stringTableCell : undefined\"\n    [numberTableCellTemplate]=\"_numberTableCell ? numberTableCell : undefined\"\n    [customTableCellTemplate]=\"_customTableCell ? customTableCell : undefined\"\n    [dateTableCellTemplate]=\"_dateTableCell ? dateTableCell : _tableDateCell ? tableDateCell : undefined\"\n    [relativeDateTableCellTemplate]=\"_relativeDateTableCell ? relativeDateTableCell : _tableRelativeDateCell ? tableRelativeDateCell : undefined\"\n    [tableCellTemplate]=\"_tableCell ? tableCell : undefined\"\n    [translationKeyTableCellTemplate]=\"_translationKeyTableCell ? translationKeyTableCell : _tableTranslationKeyCell ? tableTranslationKeyCell : undefined\"\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    [tableFilterCellTemplate]=\"_tableFilterCell ? tableFilterCell : undefined\"\n    [dateTableFilterCellTemplate]=\"_dateTableFilterCell ? dateTableFilterCell : undefined\"\n    [customTableFilterCellTemplate]=\"_customTableFilterCell ? customTableFilterCell : undefined\"\n    [numberTableFilterCellTemplate]=\"_numberTableFilterCell ? numberTableFilterCell : undefined\"\n    [stringTableFilterCellTemplate]=\"_stringTableFilterCell ? stringTableFilterCell : undefined\"\n    [relativeDateTableFilterCellTemplate]=\"_relativeDateTableFilterCell ? relativeDateTableFilterCell : undefined\"\n    [translationKeyTableFilterCellTemplate]=\"_translationKeyTableFilterCell ? translationKeyTableFilterCell : undefined\"\n    (sorted)=\"sorting($event)\"\n    (filtered)=\"filtering($event)\"\n    [totalRecordsOnServer]=\"totalRecordsOnServer\"\n    [currentPageShowingKey]=\"currentPageShowingKey\"\n    [currentPageShowingWithTotalOnServerKey]=\"currentPageShowingWithTotalOnServerKey\"\n    (componentStateChanged)=\"dataViewComponentState$.next($event)\"\n    [parentTemplates]=\"templates$ | async\"\n    [tableAllowSelectAll]=\"tableAllowSelectAll\"\n    [tableSelectionEnabledField]=\"tableSelectionEnabledField\"\n  >\n  </ocx-data-view>\n</div>\n\n<ng-template #defaultColumnGroupSelectionComponent>\n  <ocx-column-group-selection\n    *ngIf=\"layout === 'table'\"\n    [selectedGroupKey]=\"selectedGroupKey ?? defaultGroupKey\"\n    [columns]=\"columns\"\n    [defaultGroupKey]=\"defaultGroupKey !== customGroupKey ? defaultGroupKey : ''\"\n    [customGroupKey]=\"customGroupKey\"\n    [placeholderKey]=\"groupSelectionNoGroupSelectedKey\"\n    (groupSelectionChanged)=\"onColumnGroupSelectionChange($event)\"\n    (componentStateChanged)=\"columnGroupSelectionComponentState$.next($event)\"\n  ></ocx-column-group-selection>\n</ng-template>\n\n<ng-template #stringTableCell 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 #tableDateCell let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container\n    *ngIf=\"_tableDateCell\"\n    [ngTemplateOutlet]=\"_tableDateCell\"\n    [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n  >\n  </ng-container\n></ng-template>\n<ng-template #dateTableCell 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 #tableRelativeDateCell let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container\n    *ngIf=\"_tableRelativeDateCell\"\n    [ngTemplateOutlet]=\"_tableRelativeDateCell\"\n    [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n  >\n  </ng-container\n></ng-template>\n<ng-template #relativeDateTableCell 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 #tableCell 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 #tableTranslationKeyCell let-rowObject=\"rowObject\" let-column=\"column\">\n  <ng-container\n    *ngIf=\"_tableTranslationKeyCell\"\n    [ngTemplateOutlet]=\"_tableTranslationKeyCell\"\n    [ngTemplateOutletContext]=\"{rowObject:rowObject, column:column}\"\n  >\n  </ng-container\n></ng-template>\n<ng-template #translationKeyTableCell 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 #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 #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 #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\n<ng-template #stringTableFilterCell 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 #numberTableFilterCell 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 #customTableFilterCell 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 #dateTableFilterCell 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 #relativeDateTableFilterCell 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 #translationKeyTableFilterCell 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"]}
|
|
@@ -2,15 +2,17 @@ import { Component, ContentChild, ContentChildren, EventEmitter, Input, Output,
|
|
|
2
2
|
import { FormControlName, FormGroupDirective } from '@angular/forms';
|
|
3
3
|
import { combineLatest, debounceTime, map, of, startWith } from 'rxjs';
|
|
4
4
|
import { getLocation } from '@onecx/accelerator';
|
|
5
|
+
import { CONFIG_KEY, ConfigurationService } from '@onecx/angular-integration-interface';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@angular
|
|
7
|
-
import * as i2 from "
|
|
8
|
-
import * as i3 from "primeng/
|
|
9
|
-
import * as i4 from "primeng/
|
|
10
|
-
import * as i5 from "
|
|
11
|
-
import * as i6 from "
|
|
12
|
-
import * as i7 from "
|
|
13
|
-
import * as i8 from "
|
|
7
|
+
import * as i1 from "@onecx/angular-integration-interface";
|
|
8
|
+
import * as i2 from "@angular/common";
|
|
9
|
+
import * as i3 from "primeng/tooltip";
|
|
10
|
+
import * as i4 from "primeng/button";
|
|
11
|
+
import * as i5 from "primeng/skeleton";
|
|
12
|
+
import * as i6 from "@onecx/angular-remote-components";
|
|
13
|
+
import * as i7 from "../page-header/page-header.component";
|
|
14
|
+
import * as i8 from "../../directives/if-permission.directive";
|
|
15
|
+
import * as i9 from "@ngx-translate/core";
|
|
14
16
|
/**
|
|
15
17
|
* To trigger the search when Enter key is pressed inside a search parameter field,
|
|
16
18
|
* an EventListener for keyup enter event is added for HTML elements which have an input.
|
|
@@ -57,7 +59,7 @@ export class SearchHeaderComponent {
|
|
|
57
59
|
get searchConfigChangeObserved() {
|
|
58
60
|
return this.selectedSearchConfigChanged.observed;
|
|
59
61
|
}
|
|
60
|
-
constructor() {
|
|
62
|
+
constructor(configurationService) {
|
|
61
63
|
this.header = '';
|
|
62
64
|
this._viewMode = 'basic';
|
|
63
65
|
this.manualBreadcrumbs = false;
|
|
@@ -77,6 +79,7 @@ export class SearchHeaderComponent {
|
|
|
77
79
|
show: 'always',
|
|
78
80
|
};
|
|
79
81
|
this.headerActions = [];
|
|
82
|
+
this.searchButtonsReversed = false;
|
|
80
83
|
this.fieldValues$ = of({});
|
|
81
84
|
this.searchConfigChangedSlotEmitter = new EventEmitter();
|
|
82
85
|
this.searchConfigChangedSlotEmitter.subscribe((config) => {
|
|
@@ -85,6 +88,8 @@ export class SearchHeaderComponent {
|
|
|
85
88
|
});
|
|
86
89
|
this.selectedSearchConfigChanged.emit(config);
|
|
87
90
|
});
|
|
91
|
+
this.searchButtonsReversed =
|
|
92
|
+
configurationService.getProperty(CONFIG_KEY.ONECX_PORTAL_SEARCH_BUTTONS_REVERSED) === 'true';
|
|
88
93
|
}
|
|
89
94
|
ngAfterContentInit() {
|
|
90
95
|
if (this.formGroup) {
|
|
@@ -139,13 +144,13 @@ export class SearchHeaderComponent {
|
|
|
139
144
|
isVisible(control) {
|
|
140
145
|
return this.visibleFormControls.some((formControl) => formControl.name !== null && String(formControl.name) === control);
|
|
141
146
|
}
|
|
142
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: SearchHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
143
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: SearchHeaderComponent, selector: "ocx-search-header", inputs: { header: "header", headline: "headline", subheader: "subheader", viewMode: "viewMode", manualBreadcrumbs: "manualBreadcrumbs", actions: "actions", searchConfigPermission: "searchConfigPermission", searchButtonDisabled: "searchButtonDisabled", resetButtonDisabled: "resetButtonDisabled", pageName: "pageName" }, outputs: { searched: "searched", resetted: "resetted", selectedSearchConfigChanged: "selectedSearchConfigChanged", viewModeChanged: "viewModeChanged", componentStateChanged: "componentStateChanged" }, providers: [], queries: [{ propertyName: "additionalToolbarContent", first: true, predicate: ["additionalToolbarContent"], descendants: true }, { propertyName: "additionalToolbarContentLeft", first: true, predicate: ["additionalToolbarContentLeft"], descendants: true }, { propertyName: "formGroup", first: true, predicate: FormGroupDirective, descendants: true }, { propertyName: "visibleFormControls", predicate: FormControlName, descendants: true }], viewQueries: [{ propertyName: "searchParameterFields", first: true, predicate: ["searchParameterFields"], descendants: true }], ngImport: i0, template: "<ocx-page-header\n [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n [subheader]=\"subheader\"\n [manualBreadcrumbs]=\"manualBreadcrumbs\"\n [actions]=\"headerActions\"\n>\n <ng-template #additionalToolbarContentLeft>\n <ng-container *ngIf=\"searchConfigChangeObserved && pageName\">\n <ocx-slot\n *ocxIfPermission=\"searchConfigPermission\"\n name=\"onecx-search-config\"\n [inputs]=\"{ pageName: pageName, currentFieldValues: fieldValues$ | async, viewMode: viewMode }\"\n [outputs]=\"{ searchConfigSelected: searchConfigChangedSlotEmitter }\"\n >\n <ng-template #skeleton>\n <div class=\"flex\">\n <p-skeleton width=\"18rem\" height=\"3rem\"></p-skeleton>\n </div>\n </ng-template>\n </ocx-slot>\n </ng-container>\n <ng-container\n *ngIf=\"_additionalToolbarContentLeft\"\n [ngTemplateOutlet]=\"_additionalToolbarContentLeft\"\n ></ng-container>\n </ng-template>\n <ng-template #additionalToolbarContent>\n <ng-container *ngIf=\"_additionalToolbarContent\" [ngTemplateOutlet]=\"_additionalToolbarContent\"></ng-container>\n </ng-template>\n <div class=\"flex row-gap-3 column-gap-6 flex-wrap align-items-center\">\n <div>\n <div #searchParameterFields>\n <ng-content></ng-content>\n </div>\n </div>\n <div class=\"flex flex-wrap gap-2\">\n <p-button\n id=\"resetButton\"\n *ngIf=\"resetted.observed\"\n (onClick)=\"onResetClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-eraser\"\n pTooltip=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"resetButtonDisabled\"\n [ariaLabel]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.ARIA_LABEL' | translate\"\n >\n </p-button>\n\n <p-button\n id=\"searchButton\"\n (onClick)=\"onSearchClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-search\"\n pTooltip=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"searchButtonDisabled || formGroup?.invalid\"\n [ariaLabel]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.ARIA_LABEL' | translate\"\n >\n </p-button>\n </div>\n </div>\n</ocx-page-header>\n", dependencies: [{ kind: "directive", type:
|
|
147
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: SearchHeaderComponent, deps: [{ token: i1.ConfigurationService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
148
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: SearchHeaderComponent, selector: "ocx-search-header", inputs: { header: "header", headline: "headline", subheader: "subheader", viewMode: "viewMode", manualBreadcrumbs: "manualBreadcrumbs", actions: "actions", searchConfigPermission: "searchConfigPermission", searchButtonDisabled: "searchButtonDisabled", resetButtonDisabled: "resetButtonDisabled", pageName: "pageName" }, outputs: { searched: "searched", resetted: "resetted", selectedSearchConfigChanged: "selectedSearchConfigChanged", viewModeChanged: "viewModeChanged", componentStateChanged: "componentStateChanged" }, providers: [], queries: [{ propertyName: "additionalToolbarContent", first: true, predicate: ["additionalToolbarContent"], descendants: true }, { propertyName: "additionalToolbarContentLeft", first: true, predicate: ["additionalToolbarContentLeft"], descendants: true }, { propertyName: "formGroup", first: true, predicate: FormGroupDirective, descendants: true }, { propertyName: "visibleFormControls", predicate: FormControlName, descendants: true }], viewQueries: [{ propertyName: "searchParameterFields", first: true, predicate: ["searchParameterFields"], descendants: true }], ngImport: i0, template: "<ocx-page-header\n [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n [subheader]=\"subheader\"\n [manualBreadcrumbs]=\"manualBreadcrumbs\"\n [actions]=\"headerActions\"\n>\n <ng-template #additionalToolbarContentLeft>\n <ng-container *ngIf=\"searchConfigChangeObserved && pageName\">\n <ocx-slot\n *ocxIfPermission=\"searchConfigPermission\"\n name=\"onecx-search-config\"\n [inputs]=\"{ pageName: pageName, currentFieldValues: fieldValues$ | async, viewMode: viewMode }\"\n [outputs]=\"{ searchConfigSelected: searchConfigChangedSlotEmitter }\"\n >\n <ng-template #skeleton>\n <div class=\"flex\">\n <p-skeleton width=\"18rem\" height=\"3rem\"></p-skeleton>\n </div>\n </ng-template>\n </ocx-slot>\n </ng-container>\n <ng-container\n *ngIf=\"_additionalToolbarContentLeft\"\n [ngTemplateOutlet]=\"_additionalToolbarContentLeft\"\n ></ng-container>\n </ng-template>\n <ng-template #additionalToolbarContent>\n <ng-container *ngIf=\"_additionalToolbarContent\" [ngTemplateOutlet]=\"_additionalToolbarContent\"></ng-container>\n </ng-template>\n <div class=\"flex row-gap-3 column-gap-6 flex-wrap align-items-center\">\n <div>\n <div #searchParameterFields>\n <ng-content></ng-content>\n </div>\n </div>\n <div class=\"flex flex-wrap gap-2\" [ngClass]=\"searchButtonsReversed ? 'flex-row-reverse' : 'flex-row'\">\n <p-button\n id=\"resetButton\"\n *ngIf=\"resetted.observed\"\n (onClick)=\"onResetClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-eraser\"\n pTooltip=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"resetButtonDisabled\"\n [ariaLabel]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.ARIA_LABEL' | translate\"\n >\n </p-button>\n\n <p-button\n id=\"searchButton\"\n (onClick)=\"onSearchClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-search\"\n pTooltip=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"searchButtonDisabled || formGroup?.invalid\"\n [ariaLabel]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.ARIA_LABEL' | translate\"\n >\n </p-button>\n </div>\n </div>\n</ocx-page-header>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i4.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: i5.Skeleton, selector: "p-skeleton", inputs: ["styleClass", "style", "shape", "animation", "borderRadius", "size", "width", "height"] }, { kind: "component", type: i6.SlotComponent, selector: "ocx-slot[name]", inputs: ["name", "inputs", "outputs"] }, { kind: "component", type: i7.PageHeaderComponent, selector: "ocx-page-header", inputs: ["header", "loading", "figureBackground", "showFigure", "figureImage", "disableDefaultActions", "subheader", "actions", "objectDetails", "showBreadcrumbs", "manualBreadcrumbs", "enableGridView", "gridLayoutDesktopColumns"], outputs: ["save"] }, { kind: "directive", type: i8.IfPermissionDirective, selector: "[ocxIfPermission], [ocxIfNotPermission]", inputs: ["ocxIfPermission", "ocxIfNotPermission", "onMissingPermission", "ocxIfPermissionPermissions", "ocxIfNotPermissionPermissions", "ocxIfPermissionElseTemplate", "ocxIfNotPermissionElseTemplate"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }] }); }
|
|
144
149
|
}
|
|
145
150
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: SearchHeaderComponent, decorators: [{
|
|
146
151
|
type: Component,
|
|
147
|
-
args: [{ selector: 'ocx-search-header', providers: [], template: "<ocx-page-header\n [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n [subheader]=\"subheader\"\n [manualBreadcrumbs]=\"manualBreadcrumbs\"\n [actions]=\"headerActions\"\n>\n <ng-template #additionalToolbarContentLeft>\n <ng-container *ngIf=\"searchConfigChangeObserved && pageName\">\n <ocx-slot\n *ocxIfPermission=\"searchConfigPermission\"\n name=\"onecx-search-config\"\n [inputs]=\"{ pageName: pageName, currentFieldValues: fieldValues$ | async, viewMode: viewMode }\"\n [outputs]=\"{ searchConfigSelected: searchConfigChangedSlotEmitter }\"\n >\n <ng-template #skeleton>\n <div class=\"flex\">\n <p-skeleton width=\"18rem\" height=\"3rem\"></p-skeleton>\n </div>\n </ng-template>\n </ocx-slot>\n </ng-container>\n <ng-container\n *ngIf=\"_additionalToolbarContentLeft\"\n [ngTemplateOutlet]=\"_additionalToolbarContentLeft\"\n ></ng-container>\n </ng-template>\n <ng-template #additionalToolbarContent>\n <ng-container *ngIf=\"_additionalToolbarContent\" [ngTemplateOutlet]=\"_additionalToolbarContent\"></ng-container>\n </ng-template>\n <div class=\"flex row-gap-3 column-gap-6 flex-wrap align-items-center\">\n <div>\n <div #searchParameterFields>\n <ng-content></ng-content>\n </div>\n </div>\n <div class=\"flex flex-wrap gap-2\">\n <p-button\n id=\"resetButton\"\n *ngIf=\"resetted.observed\"\n (onClick)=\"onResetClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-eraser\"\n pTooltip=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"resetButtonDisabled\"\n [ariaLabel]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.ARIA_LABEL' | translate\"\n >\n </p-button>\n\n <p-button\n id=\"searchButton\"\n (onClick)=\"onSearchClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-search\"\n pTooltip=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"searchButtonDisabled || formGroup?.invalid\"\n [ariaLabel]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.ARIA_LABEL' | translate\"\n >\n </p-button>\n </div>\n </div>\n</ocx-page-header>\n" }]
|
|
148
|
-
}], ctorParameters: () => [], propDecorators: { header: [{
|
|
152
|
+
args: [{ selector: 'ocx-search-header', providers: [], template: "<ocx-page-header\n [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n [subheader]=\"subheader\"\n [manualBreadcrumbs]=\"manualBreadcrumbs\"\n [actions]=\"headerActions\"\n>\n <ng-template #additionalToolbarContentLeft>\n <ng-container *ngIf=\"searchConfigChangeObserved && pageName\">\n <ocx-slot\n *ocxIfPermission=\"searchConfigPermission\"\n name=\"onecx-search-config\"\n [inputs]=\"{ pageName: pageName, currentFieldValues: fieldValues$ | async, viewMode: viewMode }\"\n [outputs]=\"{ searchConfigSelected: searchConfigChangedSlotEmitter }\"\n >\n <ng-template #skeleton>\n <div class=\"flex\">\n <p-skeleton width=\"18rem\" height=\"3rem\"></p-skeleton>\n </div>\n </ng-template>\n </ocx-slot>\n </ng-container>\n <ng-container\n *ngIf=\"_additionalToolbarContentLeft\"\n [ngTemplateOutlet]=\"_additionalToolbarContentLeft\"\n ></ng-container>\n </ng-template>\n <ng-template #additionalToolbarContent>\n <ng-container *ngIf=\"_additionalToolbarContent\" [ngTemplateOutlet]=\"_additionalToolbarContent\"></ng-container>\n </ng-template>\n <div class=\"flex row-gap-3 column-gap-6 flex-wrap align-items-center\">\n <div>\n <div #searchParameterFields>\n <ng-content></ng-content>\n </div>\n </div>\n <div class=\"flex flex-wrap gap-2\" [ngClass]=\"searchButtonsReversed ? 'flex-row-reverse' : 'flex-row'\">\n <p-button\n id=\"resetButton\"\n *ngIf=\"resetted.observed\"\n (onClick)=\"onResetClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-eraser\"\n pTooltip=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"resetButtonDisabled\"\n [ariaLabel]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.ARIA_LABEL' | translate\"\n >\n </p-button>\n\n <p-button\n id=\"searchButton\"\n (onClick)=\"onSearchClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-search\"\n pTooltip=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"searchButtonDisabled || formGroup?.invalid\"\n [ariaLabel]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.ARIA_LABEL' | translate\"\n >\n </p-button>\n </div>\n </div>\n</ocx-page-header>\n" }]
|
|
153
|
+
}], ctorParameters: () => [{ type: i1.ConfigurationService }], propDecorators: { header: [{
|
|
149
154
|
type: Input
|
|
150
155
|
}], headline: [{
|
|
151
156
|
type: Input
|
|
@@ -191,4 +196,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
191
196
|
type: ViewChild,
|
|
192
197
|
args: ['searchParameterFields']
|
|
193
198
|
}] } });
|
|
194
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-header.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/search-header/search-header.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/search-header/search-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { Action } from '../page-header/page-header.component'\nimport { FormControlName, FormGroup, FormGroupDirective } from '@angular/forms'\nimport { Observable, combineLatest, debounceTime, map, of, startWith } from 'rxjs'\nimport { getLocation } from '@onecx/accelerator'\n\nexport interface SearchHeaderComponentState {\n  activeViewMode?: 'basic' | 'advanced'\n  selectedSearchConfig?: string | null\n}\n\nexport interface SearchConfigData {\n  name: string | undefined\n  fieldValues: { [key: string]: string }\n  displayedColumnsIds: string[]\n  viewMode: 'basic' | 'advanced'\n}\n\n/**\n * To trigger the search when Enter key is pressed inside a search parameter field,\n * an EventListener for keyup enter event is added for HTML elements which have an input.\n * Please add the EventListener yourself manually, if you want to have that functionality for some other elements\n * which do not have an input element.\n */\n@Component({\n  selector: 'ocx-search-header',\n  templateUrl: './search-header.component.html',\n  providers: [],\n})\nexport class SearchHeaderComponent implements AfterContentInit, AfterViewInit {\n  @Input() header = ''\n\n  /**\n   * @deprecated Will be replaced by header\n   */\n  @Input()\n  get headline(): string {\n    return this.header\n  }\n  set headline(value: string) {\n    this.header = value\n  }\n  @Input() subheader: string | undefined\n  _viewMode: 'basic' | 'advanced' = 'basic'\n  @Input()\n  get viewMode(): 'basic' | 'advanced' {\n    return this._viewMode\n  }\n  set viewMode(viewMode: 'basic' | 'advanced') {\n    if (this.viewMode !== viewMode) {\n      this._viewMode = viewMode\n      this.viewModeChanged?.emit(this.viewMode)\n      this.componentStateChanged.emit({\n        activeViewMode: this.viewMode,\n      })\n      this.updateHeaderActions()\n      setTimeout(() => this.addKeyUpEventListener())\n    }\n  }\n  @Input() manualBreadcrumbs = false\n  _actions: Action[] = []\n  @Input()\n  get actions() {\n    return this._actions\n  }\n  set actions(value) {\n    this._actions = value\n    this.updateHeaderActions()\n  }\n  @Input() searchConfigPermission: string | undefined\n  @Input() searchButtonDisabled = false\n  @Input() resetButtonDisabled = false\n  @Input() pageName: string | undefined = getLocation().applicationPath\n\n  @Output() searched: EventEmitter<any> = new EventEmitter()\n  @Output() resetted: EventEmitter<any> = new EventEmitter()\n  @Output() selectedSearchConfigChanged: EventEmitter<SearchConfigData | undefined> = new EventEmitter()\n  @Output() viewModeChanged: EventEmitter<'basic' | 'advanced'> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<SearchHeaderComponentState> = new EventEmitter()\n  @ContentChild('additionalToolbarContent')\n  additionalToolbarContent: TemplateRef<any> | undefined\n\n  get _additionalToolbarContent(): TemplateRef<any> | undefined {\n    return this.additionalToolbarContent\n  }\n  @ContentChild('additionalToolbarContentLeft')\n  additionalToolbarContentLeft: TemplateRef<any> | undefined\n\n  get _additionalToolbarContentLeft(): TemplateRef<any> | undefined {\n    return this.additionalToolbarContentLeft\n  }\n\n  get searchConfigChangeObserved(): boolean {\n    return this.selectedSearchConfigChanged.observed\n  }\n\n  @ContentChild(FormGroupDirective) formGroup: FormGroup | undefined\n  @ContentChildren(FormControlName, { descendants: true }) visibleFormControls!: QueryList<FormControlName>\n\n  @ViewChild('searchParameterFields') searchParameterFields: ElementRef | undefined\n\n  hasAdvanced = false\n\n  simpleAdvancedAction: Action = {\n    id: 'simpleAdvancedButton',\n    actionCallback: () => this.toggleViewMode(),\n    show: 'always',\n  }\n  headerActions: Action[] = []\n\n  fieldValues$: Observable<{ [key: string]: unknown }> | undefined = of({})\n  searchConfigChangedSlotEmitter: EventEmitter<SearchConfigData | undefined> = new EventEmitter()\n\n  constructor() {\n    this.searchConfigChangedSlotEmitter.subscribe((config) => {\n      this.componentStateChanged.emit({\n        selectedSearchConfig: config?.name ?? null,\n      })\n      this.selectedSearchConfigChanged.emit(config)\n    })\n  }\n\n  ngAfterContentInit(): void {\n    if (this.formGroup) {\n      this.fieldValues$ = combineLatest([\n        this.formGroup.valueChanges.pipe(startWith({})),\n        this.visibleFormControls.changes.pipe(startWith(null)),\n      ]).pipe(\n        debounceTime(100),\n        map(([values, _]) =>\n          Object.entries(values ?? {}).reduce(\n            (acc, [key, value]) => ({\n              ...acc,\n              [key]: this.isVisible(key) ? value || undefined : undefined,\n            }),\n            {}\n          )\n        )\n      )\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.addKeyUpEventListener()\n  }\n\n  toggleViewMode() {\n    this.viewMode = this.viewMode === 'basic' ? 'advanced' : 'basic'\n  }\n\n  onResetClicked() {\n    this.resetted.emit()\n  }\n\n  onSearchClicked() {\n    this.searched.emit()\n  }\n\n  updateHeaderActions() {\n    const headerActions: Action[] = []\n    if (this.hasAdvanced) {\n      this.simpleAdvancedAction.labelKey = this.viewMode === 'basic'\n      ? 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.ADVANCED.TEXT'\n      : 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.SIMPLE.TEXT',\n      this.simpleAdvancedAction.titleKey = this.viewMode === 'basic'\n      ? 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.ADVANCED.DETAIL'\n      : 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.SIMPLE.DETAIL',\n      \n      headerActions.push(this.simpleAdvancedAction)\n    }\n    this.headerActions = headerActions.concat(this.actions)\n  }\n\n  addKeyUpEventListener() {\n    const inputElements = this.searchParameterFields?.nativeElement.querySelectorAll('input')\n    inputElements.forEach((inputElement: any) => {\n      if (!inputElement.listenerAdded) {\n        inputElement.addEventListener('keyup', (event: any) => this.onSearchKeyup(event))\n        inputElement.listenerAdded = true\n      }\n    })\n  }\n\n  onSearchKeyup(event: any) {\n    if (event.code === 'Enter') {\n      this.onSearchClicked()\n    }\n  }\n\n  private isVisible(control: string) {\n    return this.visibleFormControls.some(\n      (formControl) => formControl.name !== null && String(formControl.name) === control\n    )\n  }\n}\n","<ocx-page-header\n  [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n  [subheader]=\"subheader\"\n  [manualBreadcrumbs]=\"manualBreadcrumbs\"\n  [actions]=\"headerActions\"\n>\n  <ng-template #additionalToolbarContentLeft>\n    <ng-container *ngIf=\"searchConfigChangeObserved && pageName\">\n      <ocx-slot\n        *ocxIfPermission=\"searchConfigPermission\"\n        name=\"onecx-search-config\"\n        [inputs]=\"{ pageName: pageName, currentFieldValues: fieldValues$ | async, viewMode: viewMode }\"\n        [outputs]=\"{ searchConfigSelected: searchConfigChangedSlotEmitter }\"\n      >\n        <ng-template #skeleton>\n          <div class=\"flex\">\n            <p-skeleton width=\"18rem\" height=\"3rem\"></p-skeleton>\n          </div>\n        </ng-template>\n      </ocx-slot>\n    </ng-container>\n    <ng-container\n      *ngIf=\"_additionalToolbarContentLeft\"\n      [ngTemplateOutlet]=\"_additionalToolbarContentLeft\"\n    ></ng-container>\n  </ng-template>\n  <ng-template #additionalToolbarContent>\n    <ng-container *ngIf=\"_additionalToolbarContent\" [ngTemplateOutlet]=\"_additionalToolbarContent\"></ng-container>\n  </ng-template>\n  <div class=\"flex row-gap-3 column-gap-6 flex-wrap align-items-center\">\n    <div>\n      <div #searchParameterFields>\n        <ng-content></ng-content>\n      </div>\n    </div>\n    <div class=\"flex flex-wrap gap-2\">\n      <p-button\n        id=\"resetButton\"\n        *ngIf=\"resetted.observed\"\n        (onClick)=\"onResetClicked()\"\n        label=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.TEXT' | translate }}\"\n        icon=\"pi pi-eraser\"\n        pTooltip=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n        tooltipPosition=\"top\"\n        tooltipEvent=\"hover\"\n        [disabled]=\"resetButtonDisabled\"\n        [ariaLabel]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.ARIA_LABEL' | translate\"\n      >\n      </p-button>\n\n      <p-button\n        id=\"searchButton\"\n        (onClick)=\"onSearchClicked()\"\n        label=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.TEXT' | translate }}\"\n        icon=\"pi pi-search\"\n        pTooltip=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n        tooltipPosition=\"top\"\n        tooltipEvent=\"hover\"\n        [disabled]=\"searchButtonDisabled || formGroup?.invalid\"\n        [ariaLabel]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.ARIA_LABEL' | translate\"\n      >\n      </p-button>\n    </div>\n  </div>\n</ocx-page-header>\n"]}
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-header.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/search-header/search-header.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/search-header/search-header.component.html"],"names":[],"mappings":"AAAA,OAAO,EAGL,SAAS,EACT,YAAY,EACZ,eAAe,EAEf,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,EAET,SAAS,GACV,MAAM,eAAe,CAAA;AAEtB,OAAO,EAAE,eAAe,EAAa,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AAC/E,OAAO,EAAc,aAAa,EAAE,YAAY,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,MAAM,CAAA;AAClF,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAA;AAChD,OAAO,EAAE,UAAU,EAAE,oBAAoB,EAAE,MAAM,sCAAsC,CAAA;;;;;;;;;;;AAcvF;;;;;GAKG;AAMH,MAAM,OAAO,qBAAqB;IAGhC;;OAEG;IACH,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,MAAM,CAAA;IACpB,CAAC;IACD,IAAI,QAAQ,CAAC,KAAa;QACxB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAA;IACrB,CAAC;IAGD,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAA;IACvB,CAAC;IACD,IAAI,QAAQ,CAAC,QAA8B;QACzC,IAAI,IAAI,CAAC,QAAQ,KAAK,QAAQ,EAAE,CAAC;YAC/B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAA;YACzB,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;YACzC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;gBAC9B,cAAc,EAAE,IAAI,CAAC,QAAQ;aAC9B,CAAC,CAAA;YACF,IAAI,CAAC,mBAAmB,EAAE,CAAA;YAC1B,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAA;QAChD,CAAC;IACH,CAAC;IAGD,IACI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAA;IACtB,CAAC;IACD,IAAI,OAAO,CAAC,KAAK;QACf,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAA;QACrB,IAAI,CAAC,mBAAmB,EAAE,CAAA;IAC5B,CAAC;IAcD,IAAI,yBAAyB;QAC3B,OAAO,IAAI,CAAC,wBAAwB,CAAA;IACtC,CAAC;IAID,IAAI,6BAA6B;QAC/B,OAAO,IAAI,CAAC,4BAA4B,CAAA;IAC1C,CAAC;IAED,IAAI,0BAA0B;QAC5B,OAAO,IAAI,CAAC,2BAA2B,CAAC,QAAQ,CAAA;IAClD,CAAC;IAmBD,YAAY,oBAA0C;QAnF7C,WAAM,GAAG,EAAE,CAAA;QAapB,cAAS,GAAyB,OAAO,CAAA;QAgBhC,sBAAiB,GAAG,KAAK,CAAA;QAClC,aAAQ,GAAa,EAAE,CAAA;QAUd,yBAAoB,GAAG,KAAK,CAAA;QAC5B,wBAAmB,GAAG,KAAK,CAAA;QAC3B,aAAQ,GAAuB,WAAW,EAAE,CAAC,eAAe,CAAA;QAE3D,aAAQ,GAAsB,IAAI,YAAY,EAAE,CAAA;QAChD,aAAQ,GAAsB,IAAI,YAAY,EAAE,CAAA;QAChD,gCAA2B,GAA+C,IAAI,YAAY,EAAE,CAAA;QAC5F,oBAAe,GAAuC,IAAI,YAAY,EAAE,CAAA;QACxE,0BAAqB,GAA6C,IAAI,YAAY,EAAE,CAAA;QAuB9F,gBAAW,GAAG,KAAK,CAAA;QAEnB,yBAAoB,GAAW;YAC7B,EAAE,EAAE,sBAAsB;YAC1B,cAAc,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE;YAC3C,IAAI,EAAE,QAAQ;SACf,CAAA;QACD,kBAAa,GAAa,EAAE,CAAA;QAC5B,0BAAqB,GAAG,KAAK,CAAA;QAC7B,iBAAY,GAAuD,EAAE,CAAC,EAAE,CAAC,CAAA;QACzE,mCAA8B,GAA+C,IAAI,YAAY,EAAE,CAAA;QAG7F,IAAI,CAAC,8BAA8B,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACvD,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;gBAC9B,oBAAoB,EAAE,MAAM,EAAE,IAAI,IAAI,IAAI;aAC3C,CAAC,CAAA;YACF,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QAC/C,CAAC,CAAC,CAAA;QACF,IAAI,CAAC,qBAAqB;YACxB,oBAAoB,CAAC,WAAW,CAAC,UAAU,CAAC,oCAAoC,CAAC,KAAK,MAAM,CAAA;IAChG,CAAC;IAED,kBAAkB;QAChB,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,YAAY,GAAG,aAAa,CAAC;gBAChC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;gBAC/C,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;aACvD,CAAC,CAAC,IAAI,CACL,YAAY,CAAC,GAAG,CAAC,EACjB,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,EAAE,CAClB,MAAM,CAAC,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,MAAM,CACjC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;gBACtB,GAAG,GAAG;gBACN,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,SAAS,CAAC,CAAC,CAAC,SAAS;aAC5D,CAAC,EACF,EAAE,CACH,CACF,CACF,CAAA;QACH,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,qBAAqB,EAAE,CAAA;IAC9B,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAA;IAClE,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAA;IACtB,CAAC;IAED,eAAe;QACb,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAA;IACtB,CAAC;IAED,mBAAmB;QACjB,MAAM,aAAa,GAAa,EAAE,CAAA;QAClC,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,IAAI,CAAC,oBAAoB,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,KAAK,OAAO;gBAC9D,CAAC,CAAC,+CAA+C;gBACjD,CAAC,CAAC,6CAA6C;gBAC/C,IAAI,CAAC,oBAAoB,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,KAAK,OAAO;oBAC9D,CAAC,CAAC,iDAAiD;oBACnD,CAAC,CAAC,+CAA+C;gBAEjD,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAA;QAC/C,CAAC;QACD,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;IACzD,CAAC;IAED,qBAAqB;QACnB,MAAM,aAAa,GAAG,IAAI,CAAC,qBAAqB,EAAE,aAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAA;QACzF,aAAa,CAAC,OAAO,CAAC,CAAC,YAAiB,EAAE,EAAE;YAC1C,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC;gBAChC,YAAY,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,KAAU,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAA;gBACjF,YAAY,CAAC,aAAa,GAAG,IAAI,CAAA;YACnC,CAAC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;YAC3B,IAAI,CAAC,eAAe,EAAE,CAAA;QACxB,CAAC;IACH,CAAC;IAEO,SAAS,CAAC,OAAe;QAC/B,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAClC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,IAAI,KAAK,IAAI,IAAI,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,OAAO,CACnF,CAAA;IACH,CAAC;8GAtKU,qBAAqB;kGAArB,qBAAqB,qjBAFrB,EAAE,uTAqEC,kBAAkB,yEACf,eAAe,gLC/GlC,mgFAiEA;;2FDtBa,qBAAqB;kBALjC,SAAS;+BACE,mBAAmB,aAElB,EAAE;yFAGJ,MAAM;sBAAd,KAAK;gBAMF,QAAQ;sBADX,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBAGF,QAAQ;sBADX,KAAK;gBAeG,iBAAiB;sBAAzB,KAAK;gBAGF,OAAO;sBADV,KAAK;gBAQG,sBAAsB;sBAA9B,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAEI,QAAQ;sBAAjB,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,2BAA2B;sBAApC,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACG,qBAAqB;sBAA9B,MAAM;gBAEP,wBAAwB;sBADvB,YAAY;uBAAC,0BAA0B;gBAOxC,4BAA4B;sBAD3B,YAAY;uBAAC,8BAA8B;gBAWV,SAAS;sBAA1C,YAAY;uBAAC,kBAAkB;gBACyB,mBAAmB;sBAA3E,eAAe;uBAAC,eAAe,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAEnB,qBAAqB;sBAAxD,SAAS;uBAAC,uBAAuB","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { Action } from '../page-header/page-header.component'\nimport { FormControlName, FormGroup, FormGroupDirective } from '@angular/forms'\nimport { Observable, combineLatest, debounceTime, map, of, startWith } from 'rxjs'\nimport { getLocation } from '@onecx/accelerator'\nimport { CONFIG_KEY, ConfigurationService } from '@onecx/angular-integration-interface'\n\nexport interface SearchHeaderComponentState {\n  activeViewMode?: 'basic' | 'advanced'\n  selectedSearchConfig?: string | null\n}\n\nexport interface SearchConfigData {\n  name: string | undefined\n  fieldValues: { [key: string]: string }\n  displayedColumnsIds: string[]\n  viewMode: 'basic' | 'advanced'\n}\n\n/**\n * To trigger the search when Enter key is pressed inside a search parameter field,\n * an EventListener for keyup enter event is added for HTML elements which have an input.\n * Please add the EventListener yourself manually, if you want to have that functionality for some other elements\n * which do not have an input element.\n */\n@Component({\n  selector: 'ocx-search-header',\n  templateUrl: './search-header.component.html',\n  providers: [],\n})\nexport class SearchHeaderComponent implements AfterContentInit, AfterViewInit {\n  @Input() header = ''\n\n  /**\n   * @deprecated Will be replaced by header\n   */\n  @Input()\n  get headline(): string {\n    return this.header\n  }\n  set headline(value: string) {\n    this.header = value\n  }\n  @Input() subheader: string | undefined\n  _viewMode: 'basic' | 'advanced' = 'basic'\n  @Input()\n  get viewMode(): 'basic' | 'advanced' {\n    return this._viewMode\n  }\n  set viewMode(viewMode: 'basic' | 'advanced') {\n    if (this.viewMode !== viewMode) {\n      this._viewMode = viewMode\n      this.viewModeChanged?.emit(this.viewMode)\n      this.componentStateChanged.emit({\n        activeViewMode: this.viewMode,\n      })\n      this.updateHeaderActions()\n      setTimeout(() => this.addKeyUpEventListener())\n    }\n  }\n  @Input() manualBreadcrumbs = false\n  _actions: Action[] = []\n  @Input()\n  get actions() {\n    return this._actions\n  }\n  set actions(value) {\n    this._actions = value\n    this.updateHeaderActions()\n  }\n  @Input() searchConfigPermission: string | string[] | undefined\n  @Input() searchButtonDisabled = false\n  @Input() resetButtonDisabled = false\n  @Input() pageName: string | undefined = getLocation().applicationPath\n\n  @Output() searched: EventEmitter<any> = new EventEmitter()\n  @Output() resetted: EventEmitter<any> = new EventEmitter()\n  @Output() selectedSearchConfigChanged: EventEmitter<SearchConfigData | undefined> = new EventEmitter()\n  @Output() viewModeChanged: EventEmitter<'basic' | 'advanced'> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<SearchHeaderComponentState> = new EventEmitter()\n  @ContentChild('additionalToolbarContent')\n  additionalToolbarContent: TemplateRef<any> | undefined\n\n  get _additionalToolbarContent(): TemplateRef<any> | undefined {\n    return this.additionalToolbarContent\n  }\n  @ContentChild('additionalToolbarContentLeft')\n  additionalToolbarContentLeft: TemplateRef<any> | undefined\n\n  get _additionalToolbarContentLeft(): TemplateRef<any> | undefined {\n    return this.additionalToolbarContentLeft\n  }\n\n  get searchConfigChangeObserved(): boolean {\n    return this.selectedSearchConfigChanged.observed\n  }\n\n  @ContentChild(FormGroupDirective) formGroup: FormGroup | undefined\n  @ContentChildren(FormControlName, { descendants: true }) visibleFormControls!: QueryList<FormControlName>\n\n  @ViewChild('searchParameterFields') searchParameterFields: ElementRef | undefined\n\n  hasAdvanced = false\n\n  simpleAdvancedAction: Action = {\n    id: 'simpleAdvancedButton',\n    actionCallback: () => this.toggleViewMode(),\n    show: 'always',\n  }\n  headerActions: Action[] = []\n  searchButtonsReversed = false\n  fieldValues$: Observable<{ [key: string]: unknown }> | undefined = of({})\n  searchConfigChangedSlotEmitter: EventEmitter<SearchConfigData | undefined> = new EventEmitter()\n\n  constructor(configurationService: ConfigurationService) {\n    this.searchConfigChangedSlotEmitter.subscribe((config) => {\n      this.componentStateChanged.emit({\n        selectedSearchConfig: config?.name ?? null,\n      })\n      this.selectedSearchConfigChanged.emit(config)\n    })\n    this.searchButtonsReversed =\n      configurationService.getProperty(CONFIG_KEY.ONECX_PORTAL_SEARCH_BUTTONS_REVERSED) === 'true'\n  }\n\n  ngAfterContentInit(): void {\n    if (this.formGroup) {\n      this.fieldValues$ = combineLatest([\n        this.formGroup.valueChanges.pipe(startWith({})),\n        this.visibleFormControls.changes.pipe(startWith(null)),\n      ]).pipe(\n        debounceTime(100),\n        map(([values, _]) =>\n          Object.entries(values ?? {}).reduce(\n            (acc, [key, value]) => ({\n              ...acc,\n              [key]: this.isVisible(key) ? value || undefined : undefined,\n            }),\n            {}\n          )\n        )\n      )\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.addKeyUpEventListener()\n  }\n\n  toggleViewMode() {\n    this.viewMode = this.viewMode === 'basic' ? 'advanced' : 'basic'\n  }\n\n  onResetClicked() {\n    this.resetted.emit()\n  }\n\n  onSearchClicked() {\n    this.searched.emit()\n  }\n\n  updateHeaderActions() {\n    const headerActions: Action[] = []\n    if (this.hasAdvanced) {\n      this.simpleAdvancedAction.labelKey = this.viewMode === 'basic'\n      ? 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.ADVANCED.TEXT'\n      : 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.SIMPLE.TEXT',\n      this.simpleAdvancedAction.titleKey = this.viewMode === 'basic'\n      ? 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.ADVANCED.DETAIL'\n      : 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.SIMPLE.DETAIL',\n      \n      headerActions.push(this.simpleAdvancedAction)\n    }\n    this.headerActions = headerActions.concat(this.actions)\n  }\n\n  addKeyUpEventListener() {\n    const inputElements = this.searchParameterFields?.nativeElement.querySelectorAll('input')\n    inputElements.forEach((inputElement: any) => {\n      if (!inputElement.listenerAdded) {\n        inputElement.addEventListener('keyup', (event: any) => this.onSearchKeyup(event))\n        inputElement.listenerAdded = true\n      }\n    })\n  }\n\n  onSearchKeyup(event: any) {\n    if (event.code === 'Enter') {\n      this.onSearchClicked()\n    }\n  }\n\n  private isVisible(control: string) {\n    return this.visibleFormControls.some(\n      (formControl) => formControl.name !== null && String(formControl.name) === control\n    )\n  }\n}\n","<ocx-page-header\n  [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n  [subheader]=\"subheader\"\n  [manualBreadcrumbs]=\"manualBreadcrumbs\"\n  [actions]=\"headerActions\"\n>\n  <ng-template #additionalToolbarContentLeft>\n    <ng-container *ngIf=\"searchConfigChangeObserved && pageName\">\n      <ocx-slot\n        *ocxIfPermission=\"searchConfigPermission\"\n        name=\"onecx-search-config\"\n        [inputs]=\"{ pageName: pageName, currentFieldValues: fieldValues$ | async, viewMode: viewMode }\"\n        [outputs]=\"{ searchConfigSelected: searchConfigChangedSlotEmitter }\"\n      >\n        <ng-template #skeleton>\n          <div class=\"flex\">\n            <p-skeleton width=\"18rem\" height=\"3rem\"></p-skeleton>\n          </div>\n        </ng-template>\n      </ocx-slot>\n    </ng-container>\n    <ng-container\n      *ngIf=\"_additionalToolbarContentLeft\"\n      [ngTemplateOutlet]=\"_additionalToolbarContentLeft\"\n    ></ng-container>\n  </ng-template>\n  <ng-template #additionalToolbarContent>\n    <ng-container *ngIf=\"_additionalToolbarContent\" [ngTemplateOutlet]=\"_additionalToolbarContent\"></ng-container>\n  </ng-template>\n  <div class=\"flex row-gap-3 column-gap-6 flex-wrap align-items-center\">\n    <div>\n      <div #searchParameterFields>\n        <ng-content></ng-content>\n      </div>\n    </div>\n    <div class=\"flex flex-wrap gap-2\" [ngClass]=\"searchButtonsReversed ? 'flex-row-reverse' : 'flex-row'\">\n      <p-button\n        id=\"resetButton\"\n        *ngIf=\"resetted.observed\"\n        (onClick)=\"onResetClicked()\"\n        label=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.TEXT' | translate }}\"\n        icon=\"pi pi-eraser\"\n        pTooltip=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n        tooltipPosition=\"top\"\n        tooltipEvent=\"hover\"\n        [disabled]=\"resetButtonDisabled\"\n        [ariaLabel]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.ARIA_LABEL' | translate\"\n      >\n      </p-button>\n\n      <p-button\n        id=\"searchButton\"\n        (onClick)=\"onSearchClicked()\"\n        label=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.TEXT' | translate }}\"\n        icon=\"pi pi-search\"\n        pTooltip=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n        tooltipPosition=\"top\"\n        tooltipEvent=\"hover\"\n        [disabled]=\"searchButtonDisabled || formGroup?.invalid\"\n        [ariaLabel]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.ARIA_LABEL' | translate\"\n      >\n      </p-button>\n    </div>\n  </div>\n</ocx-page-header>\n"]}
|