@onecx/angular-accelerator 5.23.5 → 5.23.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/data-sort-base/data-sort-base.mjs +18 -8
- package/esm2022/lib/components/filter-view/filter-view.component.mjs +4 -1
- package/esm2022/lib/components/interactive-data-view/interactive-data-view.component.mjs +8 -2
- package/esm2022/lib/directives/if-permission.directive.mjs +15 -15
- package/fesm2022/onecx-angular-accelerator.mjs +41 -22
- package/fesm2022/onecx-angular-accelerator.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -278,13 +278,19 @@ export class InteractiveDataViewComponent {
|
|
|
278
278
|
activeColumnGroupKey: this.selectedGroupKey,
|
|
279
279
|
}));
|
|
280
280
|
}
|
|
281
|
+
let filterViewComponentState$ = this.filterViewComponentState$;
|
|
282
|
+
if (this.disableFilterView) {
|
|
283
|
+
filterViewComponentState$ = filterViewComponentState$.pipe(startWith({
|
|
284
|
+
filters: this.filters,
|
|
285
|
+
}));
|
|
286
|
+
}
|
|
281
287
|
combineLatest([
|
|
282
288
|
columnGroupSelectionComponentState$.pipe(timestamp()),
|
|
283
289
|
customGroupColumnSelectorComponentState$.pipe(timestamp()),
|
|
284
290
|
this.dataLayoutComponentState$.pipe(timestamp()),
|
|
285
291
|
dataListGridSortingComponentState$.pipe(timestamp()),
|
|
286
292
|
this.dataViewComponentState$.pipe(timestamp()),
|
|
287
|
-
|
|
293
|
+
filterViewComponentState$.pipe(timestamp()),
|
|
288
294
|
])
|
|
289
295
|
.pipe(map((componentStates) => {
|
|
290
296
|
return orderAndMergeValuesByTimestamp(componentStates);
|
|
@@ -712,4 +718,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
712
718
|
}], data: [{
|
|
713
719
|
type: Input
|
|
714
720
|
}] } });
|
|
715
|
-
//# 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    combineLatest([\n      columnGroupSelectionComponentState$.pipe(timestamp()),\n      customGroupColumnSelectorComponentState$.pipe(timestamp()),\n      this.dataLayoutComponentState$.pipe(timestamp()),\n      dataListGridSortingComponentState$.pipe(timestamp()),\n      this.dataViewComponentState$.pipe(timestamp()),\n      this.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 | 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"]}
|
|
@@ -37,24 +37,24 @@ export class IfPermissionDirective {
|
|
|
37
37
|
this.permissionChecker = hasPermissionChecker ?? userService;
|
|
38
38
|
}
|
|
39
39
|
ngOnInit() {
|
|
40
|
-
if (this.permission
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
40
|
+
if ((this.permission &&
|
|
41
|
+
this.negate === this.hasPermission(Array.isArray(this.permission) ? this.permission : [this.permission])) ||
|
|
42
|
+
!this.permission) {
|
|
43
|
+
if (this.ocxIfPermissionElseTemplate) {
|
|
44
|
+
this.viewContainer.createEmbeddedView(this.ocxIfPermissionElseTemplate);
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
if (this.onMissingPermission === 'disable') {
|
|
48
|
+
this.renderer.setAttribute(this.el.nativeElement, 'disabled', 'disabled');
|
|
44
49
|
}
|
|
45
50
|
else {
|
|
46
|
-
|
|
47
|
-
this.renderer.setAttribute(this.el.nativeElement, 'disabled', 'disabled');
|
|
48
|
-
}
|
|
49
|
-
else {
|
|
50
|
-
this.viewContainer.clear();
|
|
51
|
-
}
|
|
51
|
+
this.viewContainer.clear();
|
|
52
52
|
}
|
|
53
53
|
}
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
if (this.templateRef) {
|
|
57
|
+
this.viewContainer.createEmbeddedView(this.templateRef);
|
|
58
58
|
}
|
|
59
59
|
}
|
|
60
60
|
}
|
|
@@ -100,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
100
100
|
}], ocxIfNotPermissionElseTemplate: [{
|
|
101
101
|
type: Input
|
|
102
102
|
}] } });
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"if-permission.directive.js","sourceRoot":"","sources":["../../../../../../libs/angular-accelerator/src/lib/directives/if-permission.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  Inject,\n  InjectionToken,\n  Input,\n  OnInit,\n  Optional,\n  Renderer2,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core'\nimport { UserService } from '@onecx/angular-integration-interface'\n\nexport interface HasPermissionChecker {\n  hasPermission(permissionKey: string): boolean\n}\n\n/**\n * This checker always returns true, basically disabling the permission system on the UI side\n */\nexport class AlwaysGrantPermissionChecker implements HasPermissionChecker {\n  hasPermission(_permissionKey: string): boolean {\n    return true\n  }\n}\n\nexport const HAS_PERMISSION_CHECKER = new InjectionToken<HasPermissionChecker>('hasPermission')\n\n@Directive({ selector: '[ocxIfPermission], [ocxIfNotPermission]' })\nexport class IfPermissionDirective implements OnInit {\n  @Input('ocxIfPermission') permission: string | string[] | undefined\n  @Input('ocxIfNotPermission') set notPermission(value: string | string[] | undefined) {\n    this.permission = value\n    this.negate = true\n  }\n\n  @Input() onMissingPermission: 'hide' | 'disable' = 'hide'\n\n  @Input() ocxIfPermissionPermissions: string[] | undefined\n  @Input()\n  set ocxIfNotPermissionPermissions(value: string[] | undefined) {\n    this.ocxIfPermissionPermissions = value\n  }\n\n  @Input()\n  ocxIfPermissionElseTemplate: TemplateRef<any> | undefined\n  @Input()\n  set ocxIfNotPermissionElseTemplate(value: TemplateRef<any> | undefined) {\n    this.ocxIfPermissionElseTemplate = value\n  }\n\n  private permissionChecker: HasPermissionChecker | undefined\n  negate = false\n\n  constructor(\n    private renderer: Renderer2,\n    private el: ElementRef,\n    private viewContainer: ViewContainerRef,\n    @Optional()\n    @Inject(HAS_PERMISSION_CHECKER)\n    private hasPermissionChecker?: HasPermissionChecker,\n    @Optional() private templateRef?: TemplateRef<any>,\n    @Optional() private userService?: UserService\n  ) {\n    if (!(hasPermissionChecker || userService)) {\n      throw 'IfPermission requires UserService or HasPermissionChecker to be provided!'\n    }\n\n    this.permissionChecker = hasPermissionChecker ?? userService\n  }\n\n  ngOnInit() {\n    if (\n      (this.permission &&\n        this.negate === this.hasPermission(Array.isArray(this.permission) ? this.permission : [this.permission])) ||\n      !this.permission\n    ) {\n      if (this.ocxIfPermissionElseTemplate) {\n        this.viewContainer.createEmbeddedView(this.ocxIfPermissionElseTemplate)\n      } else {\n        if (this.onMissingPermission === 'disable') {\n          this.renderer.setAttribute(this.el.nativeElement, 'disabled', 'disabled')\n        } else {\n          this.viewContainer.clear()\n        }\n      }\n    } else {\n      if (this.templateRef) {\n        this.viewContainer.createEmbeddedView(this.templateRef)\n      }\n    }\n  }\n\n  hasPermission(permission: string[]) {\n    if (this.ocxIfPermissionPermissions) {\n      const result = permission.every((p) => this.ocxIfPermissionPermissions?.includes(p))\n      if (!result) {\n        console.log('👮‍♀️ No permission in overwrites for: `', permission)\n      }\n      return result\n    }\n    return permission.every((p) => this.permissionChecker?.hasPermission(p))\n  }\n}\n"]}
|
|
@@ -95,24 +95,24 @@ class IfPermissionDirective {
|
|
|
95
95
|
this.permissionChecker = hasPermissionChecker ?? userService;
|
|
96
96
|
}
|
|
97
97
|
ngOnInit() {
|
|
98
|
-
if (this.permission
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
98
|
+
if ((this.permission &&
|
|
99
|
+
this.negate === this.hasPermission(Array.isArray(this.permission) ? this.permission : [this.permission])) ||
|
|
100
|
+
!this.permission) {
|
|
101
|
+
if (this.ocxIfPermissionElseTemplate) {
|
|
102
|
+
this.viewContainer.createEmbeddedView(this.ocxIfPermissionElseTemplate);
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
if (this.onMissingPermission === 'disable') {
|
|
106
|
+
this.renderer.setAttribute(this.el.nativeElement, 'disabled', 'disabled');
|
|
102
107
|
}
|
|
103
108
|
else {
|
|
104
|
-
|
|
105
|
-
this.renderer.setAttribute(this.el.nativeElement, 'disabled', 'disabled');
|
|
106
|
-
}
|
|
107
|
-
else {
|
|
108
|
-
this.viewContainer.clear();
|
|
109
|
-
}
|
|
109
|
+
this.viewContainer.clear();
|
|
110
110
|
}
|
|
111
111
|
}
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
if (this.templateRef) {
|
|
115
|
+
this.viewContainer.createEmbeddedView(this.templateRef);
|
|
116
116
|
}
|
|
117
117
|
}
|
|
118
118
|
}
|
|
@@ -1357,15 +1357,25 @@ class DataSortBase {
|
|
|
1357
1357
|
if (!clientSideSorting || sortColumn === '') {
|
|
1358
1358
|
return [items, filters, sortColumn, sortDirection, translations];
|
|
1359
1359
|
}
|
|
1360
|
-
|
|
1361
|
-
|
|
1362
|
-
|
|
1363
|
-
|
|
1364
|
-
|
|
1365
|
-
|
|
1360
|
+
const column = columns.find((h) => h.id === sortColumn);
|
|
1361
|
+
let colValues;
|
|
1362
|
+
if (column?.columnType === ColumnType.DATE || column?.columnType === ColumnType.RELATIVE_DATE) {
|
|
1363
|
+
colValues = Object.fromEntries(items.map((i) => [
|
|
1364
|
+
ObjectUtils.resolveFieldData(i, sortColumn),
|
|
1365
|
+
ObjectUtils.resolveFieldData(i, sortColumn),
|
|
1366
|
+
]));
|
|
1367
|
+
}
|
|
1368
|
+
else {
|
|
1369
|
+
colValues = Object.fromEntries(items.map((i) => [
|
|
1370
|
+
ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),
|
|
1371
|
+
ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),
|
|
1372
|
+
]));
|
|
1373
|
+
}
|
|
1374
|
+
if (column?.columnType === ColumnType.TRANSLATION_KEY) {
|
|
1375
|
+
colValues = translations[sortColumn];
|
|
1366
1376
|
}
|
|
1367
1377
|
return [
|
|
1368
|
-
[...items].sort(this.createCompareFunction(
|
|
1378
|
+
[...items].sort(this.createCompareFunction(colValues, sortColumn, sortDirection)),
|
|
1369
1379
|
filters,
|
|
1370
1380
|
sortColumn,
|
|
1371
1381
|
sortDirection,
|
|
@@ -3906,6 +3916,9 @@ class FilterViewComponent {
|
|
|
3906
3916
|
.slice()
|
|
3907
3917
|
.sort((a, b) => columnIds.indexOf(a.valueColumnId) - columnIds.indexOf(b.valueColumnId));
|
|
3908
3918
|
}));
|
|
3919
|
+
this.componentStateChanged.emit({
|
|
3920
|
+
filters: this.filters,
|
|
3921
|
+
});
|
|
3909
3922
|
}
|
|
3910
3923
|
get _fitlerViewNoSelection() {
|
|
3911
3924
|
return this.fitlerViewNoSelection;
|
|
@@ -4408,13 +4421,19 @@ class InteractiveDataViewComponent {
|
|
|
4408
4421
|
activeColumnGroupKey: this.selectedGroupKey,
|
|
4409
4422
|
}));
|
|
4410
4423
|
}
|
|
4424
|
+
let filterViewComponentState$ = this.filterViewComponentState$;
|
|
4425
|
+
if (this.disableFilterView) {
|
|
4426
|
+
filterViewComponentState$ = filterViewComponentState$.pipe(startWith({
|
|
4427
|
+
filters: this.filters,
|
|
4428
|
+
}));
|
|
4429
|
+
}
|
|
4411
4430
|
combineLatest([
|
|
4412
4431
|
columnGroupSelectionComponentState$.pipe(timestamp()),
|
|
4413
4432
|
customGroupColumnSelectorComponentState$.pipe(timestamp()),
|
|
4414
4433
|
this.dataLayoutComponentState$.pipe(timestamp()),
|
|
4415
4434
|
dataListGridSortingComponentState$.pipe(timestamp()),
|
|
4416
4435
|
this.dataViewComponentState$.pipe(timestamp()),
|
|
4417
|
-
|
|
4436
|
+
filterViewComponentState$.pipe(timestamp()),
|
|
4418
4437
|
])
|
|
4419
4438
|
.pipe(map((componentStates) => {
|
|
4420
4439
|
return orderAndMergeValuesByTimestamp(componentStates);
|