@onecx/angular-accelerator 5.19.2 → 5.19.4

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.
@@ -37,9 +37,10 @@ export class ColumnGroupSelectionComponent {
37
37
  .concat([selectedGroupKey])
38
38
  .filter((value) => !!value)
39
39
  .filter((value, index, self) => self.indexOf(value) === index && value != null)));
40
+ const activeColumns = this.columns.filter((c) => c.predefinedGroupKeys?.includes(this.selectedGroupKey$.getValue() ?? this.defaultGroupKey));
40
41
  this.componentStateChanged.emit({
41
42
  activeColumnGroupKey: this.selectedGroupKey,
42
- displayedColumns: this.columns,
43
+ displayedColumns: activeColumns,
43
44
  });
44
45
  }
45
46
  changeGroupSelection(event) {
@@ -50,7 +51,7 @@ export class ColumnGroupSelectionComponent {
50
51
  this.groupSelectionChanged.emit({ activeColumns, groupKey: event.value });
51
52
  this.componentStateChanged.emit({
52
53
  activeColumnGroupKey: event.value,
53
- displayedColumns: activeColumns
54
+ displayedColumns: activeColumns,
54
55
  });
55
56
  }
56
57
  clearGroupSelection() {
@@ -61,7 +62,7 @@ export class ColumnGroupSelectionComponent {
61
62
  this.groupSelectionChanged.emit({ activeColumns, groupKey: this.defaultGroupKey });
62
63
  this.componentStateChanged.emit({
63
64
  activeColumnGroupKey: this.defaultGroupKey,
64
- displayedColumns: activeColumns
65
+ displayedColumns: activeColumns,
65
66
  });
66
67
  }
67
68
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ColumnGroupSelectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
@@ -85,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
85
86
  }], componentStateChanged: [{
86
87
  type: Output
87
88
  }] } });
88
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-group-selection.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/column-group-selection/column-group-selection.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/column-group-selection/column-group-selection.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core'\nimport { BehaviorSubject, combineLatest, map, Observable } from 'rxjs'\nimport { DataTableColumn } from '../../model/data-table-column.model'\n\nexport type GroupSelectionChangedEvent = { activeColumns: DataTableColumn[]; groupKey: string }\nexport interface ColumnGroupSelectionComponentState {\n  activeColumnGroupKey?: string\n  displayedColumns?: DataTableColumn[]\n}\n@Component({\n  templateUrl: './column-group-selection.component.html',\n  selector: 'ocx-column-group-selection',\n  styleUrls: ['./column-group-selection.component.scss'],\n})\nexport class ColumnGroupSelectionComponent implements OnInit {\n  selectedGroupKey$ = new BehaviorSubject<string>('')\n  @Input()\n  get selectedGroupKey(): string {\n    return this.selectedGroupKey$.getValue()\n  }\n  set selectedGroupKey(value: string) {\n    this.selectedGroupKey$.next(value)\n  }\n\n  columns$ = new BehaviorSubject<DataTableColumn[]>([])\n  @Input()\n  get columns(): DataTableColumn[] {\n    return this.columns$.getValue()\n  }\n  set columns(value: DataTableColumn[]) {\n    this.columns$.next(value)\n  }\n  @Input() placeholderKey = ''\n  @Input() defaultGroupKey = ''\n  @Input() customGroupKey = ''\n\n  @Output() groupSelectionChanged: EventEmitter<GroupSelectionChangedEvent> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<ColumnGroupSelectionComponentState> = new EventEmitter()\n\n  allGroupKeys$: Observable<string[]> | undefined\n\n  ngOnInit() {\n    this.allGroupKeys$ = combineLatest([this.columns$, this.selectedGroupKey$]).pipe(\n      map(([columns, selectedGroupKey]) =>\n        columns\n          .map((keys) => keys.predefinedGroupKeys || [])\n          .flat()\n          .concat([this.defaultGroupKey])\n          .concat([selectedGroupKey])\n          .filter((value) => !!value)\n          .filter((value, index, self) => self.indexOf(value) === index && value != null)\n      )\n    )\n    this.componentStateChanged.emit({\n      activeColumnGroupKey: this.selectedGroupKey,\n      displayedColumns: this.columns,\n    })\n  }\n\n  changeGroupSelection(event: { value: string }) {\n    if (event.value === this.customGroupKey) {\n      return\n    }\n    const activeColumns = this.columns.filter((c) => c.predefinedGroupKeys?.includes(event.value))\n    this.groupSelectionChanged.emit({ activeColumns, groupKey: event.value })\n    this.componentStateChanged.emit({\n      activeColumnGroupKey: event.value,\n      displayedColumns: activeColumns\n    })\n  }\n\n  clearGroupSelection() {\n    let activeColumns = this.columns\n    if (this.defaultGroupKey) {\n      activeColumns = this.columns.filter((column) => column.predefinedGroupKeys?.includes(this.defaultGroupKey))\n    }\n    this.groupSelectionChanged.emit({ activeColumns, groupKey: this.defaultGroupKey })\n    this.componentStateChanged.emit({\n      activeColumnGroupKey: this.defaultGroupKey,\n      displayedColumns: activeColumns\n    })\n  }\n}\n","<p-floatLabel>\n  <p-dropdown\n    inputId=\"columnGroupSelectionDropdown\"\n    *ngIf=\"(allGroupKeys$ | async)?.length\"\n    (onClear)=\"clearGroupSelection()\"\n    (onChange)=\"changeGroupSelection($event)\"\n    [options]=\"(allGroupKeys$ | async) || []\"\n    [placeholder]=\"placeholderKey | translate\"\n    [showClear]=\"selectedGroupKey !== defaultGroupKey\"\n    [(ngModel)]=\"selectedGroupKey\"\n    [ariaLabel]=\"'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABEL' | translate\"\n  >\n    <ng-template let-item pTemplate=\"item\"> {{ item ? (item | translate) : ''}} </ng-template>\n    <ng-template let-item pTemplate=\"selectedItem\"> {{ item ? (item | translate) : ''}} </ng-template>\n  </p-dropdown>\n  <label *ngIf=\"(allGroupKeys$ | async)?.length\" for=\"columnGroupSelectionDropdown\"\n    >{{ (\"OCX_CUSTOM_GROUP_COLUMN_SELECTOR.DROPDOWN_LABEL\" | translate) }}</label\n  >\n</p-floatLabel>\n"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-group-selection.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/column-group-selection/column-group-selection.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/column-group-selection/column-group-selection.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core'\nimport { BehaviorSubject, combineLatest, map, Observable } from 'rxjs'\nimport { DataTableColumn } from '../../model/data-table-column.model'\n\nexport type GroupSelectionChangedEvent = { activeColumns: DataTableColumn[]; groupKey: string }\nexport interface ColumnGroupSelectionComponentState {\n  activeColumnGroupKey?: string\n  displayedColumns?: DataTableColumn[]\n}\n@Component({\n  templateUrl: './column-group-selection.component.html',\n  selector: 'ocx-column-group-selection',\n  styleUrls: ['./column-group-selection.component.scss'],\n})\nexport class ColumnGroupSelectionComponent implements OnInit {\n  selectedGroupKey$ = new BehaviorSubject<string>('')\n  @Input()\n  get selectedGroupKey(): string {\n    return this.selectedGroupKey$.getValue()\n  }\n  set selectedGroupKey(value: string) {\n    this.selectedGroupKey$.next(value)\n  }\n\n  columns$ = new BehaviorSubject<DataTableColumn[]>([])\n  @Input()\n  get columns(): DataTableColumn[] {\n    return this.columns$.getValue()\n  }\n  set columns(value: DataTableColumn[]) {\n    this.columns$.next(value)\n  }\n  @Input() placeholderKey = ''\n  @Input() defaultGroupKey = ''\n  @Input() customGroupKey = ''\n\n  @Output() groupSelectionChanged: EventEmitter<GroupSelectionChangedEvent> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<ColumnGroupSelectionComponentState> = new EventEmitter()\n\n  allGroupKeys$: Observable<string[]> | undefined\n\n  ngOnInit() {\n    this.allGroupKeys$ = combineLatest([this.columns$, this.selectedGroupKey$]).pipe(\n      map(([columns, selectedGroupKey]) =>\n        columns\n          .map((keys) => keys.predefinedGroupKeys || [])\n          .flat()\n          .concat([this.defaultGroupKey])\n          .concat([selectedGroupKey])\n          .filter((value) => !!value)\n          .filter((value, index, self) => self.indexOf(value) === index && value != null)\n      )\n    )\n    const activeColumns = this.columns.filter((c) =>\n      c.predefinedGroupKeys?.includes(this.selectedGroupKey$.getValue() ?? this.defaultGroupKey)\n    )\n    this.componentStateChanged.emit({\n      activeColumnGroupKey: this.selectedGroupKey,\n      displayedColumns: activeColumns,\n    })\n  }\n\n  changeGroupSelection(event: { value: string }) {\n    if (event.value === this.customGroupKey) {\n      return\n    }\n    const activeColumns = this.columns.filter((c) => c.predefinedGroupKeys?.includes(event.value))\n    this.groupSelectionChanged.emit({ activeColumns, groupKey: event.value })\n    this.componentStateChanged.emit({\n      activeColumnGroupKey: event.value,\n      displayedColumns: activeColumns,\n    })\n  }\n\n  clearGroupSelection() {\n    let activeColumns = this.columns\n    if (this.defaultGroupKey) {\n      activeColumns = this.columns.filter((column) => column.predefinedGroupKeys?.includes(this.defaultGroupKey))\n    }\n    this.groupSelectionChanged.emit({ activeColumns, groupKey: this.defaultGroupKey })\n    this.componentStateChanged.emit({\n      activeColumnGroupKey: this.defaultGroupKey,\n      displayedColumns: activeColumns,\n    })\n  }\n}\n","<p-floatLabel>\n  <p-dropdown\n    inputId=\"columnGroupSelectionDropdown\"\n    *ngIf=\"(allGroupKeys$ | async)?.length\"\n    (onClear)=\"clearGroupSelection()\"\n    (onChange)=\"changeGroupSelection($event)\"\n    [options]=\"(allGroupKeys$ | async) || []\"\n    [placeholder]=\"placeholderKey | translate\"\n    [showClear]=\"selectedGroupKey !== defaultGroupKey\"\n    [(ngModel)]=\"selectedGroupKey\"\n    [ariaLabel]=\"'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABEL' | translate\"\n  >\n    <ng-template let-item pTemplate=\"item\"> {{ item ? (item | translate) : ''}} </ng-template>\n    <ng-template let-item pTemplate=\"selectedItem\"> {{ item ? (item | translate) : ''}} </ng-template>\n  </p-dropdown>\n  <label *ngIf=\"(allGroupKeys$ | async)?.length\" for=\"columnGroupSelectionDropdown\"\n    >{{ (\"OCX_CUSTOM_GROUP_COLUMN_SELECTOR.DROPDOWN_LABEL\" | translate) }}</label\n  >\n</p-floatLabel>\n"]}
@@ -10,10 +10,23 @@ import * as i6 from "primeng/picklist";
10
10
  import * as i7 from "primeng/selectbutton";
11
11
  import * as i8 from "@angular/forms";
12
12
  export class CustomGroupColumnSelectorComponent {
13
+ get displayedColumns() {
14
+ return this._displayedColumns;
15
+ }
16
+ set displayedColumns(value) {
17
+ this._displayedColumns = value;
18
+ this.componentStateChanged.emit({
19
+ actionColumnConfig: {
20
+ frozen: this.frozenActionColumn,
21
+ position: this.actionColumnPosition,
22
+ },
23
+ displayedColumns: this._displayedColumns,
24
+ });
25
+ }
13
26
  constructor(translate) {
14
27
  this.translate = translate;
15
28
  this.columns = [];
16
- this.displayedColumns = [];
29
+ this._displayedColumns = [];
17
30
  this.dialogTitle = '';
18
31
  this.dialogTitleKey = '';
19
32
  this.openButtonTitle = '';
@@ -87,11 +100,6 @@ export class CustomGroupColumnSelectorComponent {
87
100
  this.columnSelectionChanged.emit({ activeColumns: [...this.displayedColumnsModel] });
88
101
  this.componentStateChanged.emit({
89
102
  displayedColumns: [...this.displayedColumnsModel],
90
- actionColumnConfig: {
91
- frozen: this.frozenActionColumnModel,
92
- position: this.actionColumnPositionModel,
93
- },
94
- activeColumnGroupKey: undefined,
95
103
  });
96
104
  }
97
105
  if (this.frozenActionColumn != this.frozenActionColumnModel ||
@@ -169,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
169
177
  }], componentStateChanged: [{
170
178
  type: Output
171
179
  }] } });
172
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-group-column-selector.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/custom-group-column-selector/custom-group-column-selector.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/custom-group-column-selector/custom-group-column-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\nimport { DataTableColumn } from '../../model/data-table-column.model'\n\nexport type ColumnSelectionChangedEvent = { activeColumns: DataTableColumn[] }\nexport type ActionColumnChangedEvent = {\n  frozenActionColumn: boolean\n  actionColumnPosition: 'left' | 'right'\n}\n\nexport interface CustomGroupColumnSelectorComponentState {\n  actionColumnConfig?: {\n    frozen: boolean\n    position: 'left' | 'right'\n  }\n  displayedColumns?: DataTableColumn[]\n  activeColumnGroupKey?: string\n}\n\n@Component({\n  selector: 'ocx-custom-group-column-selector',\n  templateUrl: './custom-group-column-selector.component.html',\n  styleUrls: ['./custom-group-column-selector.component.scss'],\n})\nexport class CustomGroupColumnSelectorComponent implements OnInit {\n  @Input() columns: DataTableColumn[] = []\n  @Input() displayedColumns: DataTableColumn[] = []\n  @Input() dialogTitle = ''\n  @Input() dialogTitleKey = ''\n  @Input() openButtonTitle = ''\n  @Input() openButtonTitleKey = ''\n  @Input() openButtonAriaLabel = ''\n  @Input() openButtonAriaLabelKey = ''\n  @Input() saveButtonLabel = ''\n  @Input() saveButtonLabelKey = ''\n  @Input() saveButtonAriaLabel = ''\n  @Input() saveButtonAriaLabelKey = ''\n  @Input() cancelButtonLabel = ''\n  @Input() cancelButtonLabelKey = ''\n  @Input() cancelButtonAriaLabel = ''\n  @Input() cancelButtonAriaLabelKey = ''\n  @Input() activeColumnsLabel = ''\n  @Input() activeColumnsLabelKey = ''\n  @Input() inactiveColumnsLabel = ''\n  @Input() inactiveColumnsLabelKey = ''\n  @Input() frozenActionColumn = false\n  @Input() actionColumnPosition: 'left' | 'right' = 'right'\n\n  @Output() columnSelectionChanged: EventEmitter<ColumnSelectionChangedEvent> = new EventEmitter()\n  @Output() actionColumnConfigChanged: EventEmitter<ActionColumnChangedEvent> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<CustomGroupColumnSelectorComponentState> = new EventEmitter()\n\n  hiddenColumnsModel: DataTableColumn[] = []\n  displayedColumnsModel: DataTableColumn[] = []\n  frozenActionColumnModel = false\n  actionColumnPositionModel: 'left' | 'right' = 'right'\n  visible = false\n  alignmentOptions = [\n    {\n      label: 'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.LEFT',\n      value: 'left',\n    },\n    {\n      label: 'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.RIGHT',\n      value: 'right',\n    },\n  ]\n\n  frozenOptions = [\n    {\n      label: 'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.YES',\n      value: true,\n    },\n    {\n      label: 'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.NO',\n      value: false,\n    },\n  ]\n\n  constructor(private translate: TranslateService) {}\n\n  ngOnInit(): void {\n    this.componentStateChanged.emit({\n      actionColumnConfig: {\n        frozen: this.frozenActionColumn,\n        position: this.actionColumnPosition,\n      },\n      displayedColumns: this.displayedColumns,\n    })\n  }\n\n  onOpenCustomGroupColumnSelectionDialogClick() {\n    this.displayedColumnsModel = [...this.displayedColumns]\n    this.hiddenColumnsModel = this.columns.filter(\n      (column) => !this.displayedColumnsModel.map((c) => c.id).includes(column.id)\n    )\n    this.frozenActionColumnModel = this.frozenActionColumn\n    this.actionColumnPositionModel = this.actionColumnPosition\n    this.visible = true\n  }\n\n  onSaveClick() {\n    this.visible = false\n    const colIdsBefore = this.displayedColumns.map((column) => column.id)\n    const colIdsAfter = this.displayedColumnsModel.map((column) => column.id)\n\n    if (!colIdsAfter.every((colId, i) => colId === colIdsBefore[i]) || colIdsAfter.length != colIdsBefore.length) {\n      this.columnSelectionChanged.emit({ activeColumns: [...this.displayedColumnsModel] })\n      this.componentStateChanged.emit({\n        displayedColumns: [...this.displayedColumnsModel],\n        actionColumnConfig: {\n          frozen: this.frozenActionColumnModel,\n          position: this.actionColumnPositionModel,\n        },\n        activeColumnGroupKey: undefined,\n      })\n    }\n\n    if (\n      this.frozenActionColumn != this.frozenActionColumnModel ||\n      this.actionColumnPosition != this.actionColumnPositionModel\n    ) {\n      this.actionColumnConfigChanged.emit({\n        frozenActionColumn: this.frozenActionColumnModel,\n        actionColumnPosition: this.actionColumnPositionModel,\n      })\n      this.componentStateChanged.emit({\n        displayedColumns: [...this.displayedColumnsModel],\n        actionColumnConfig: {\n          frozen: this.frozenActionColumnModel,\n          position: this.actionColumnPositionModel,\n        },\n      })\n    }\n  }\n\n  onCancelClick() {\n    this.visible = false\n  }\n}\n","<p-button\n  id=\"customGroupColumnSelectorButton\"\n  type=\"button\"\n  (onClick)=\"onOpenCustomGroupColumnSelectionDialogClick()\"\n  [pTooltip]=\"openButtonTitle || (openButtonTitleKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.OPEN_BUTTON_DETAIL' | translate)\"\n  tooltipPosition=\"top\"\n  icon=\"pi pi-cog\"\n  styleClass=\"p-button\"\n  [ariaLabel]=\"(openButtonAriaLabelKey ? (openButtonAriaLabelKey | translate) : openButtonAriaLabel) || openButtonTitle || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.OPEN_BUTTON_DETAIL' | translate)\"\n  [attr.aria-controls]=\"visible ? 'customGroupColumnSelectorDialog' : null\"\n  [attr.aria-expanded]=\"visible ? true : false\"\n></p-button>\n\n<p-dialog\n  #dialog\n  id=\"customGroupColumnSelectorDialog\"\n  [(visible)]=\"visible\"\n  [style]=\"{ width: '70%' }\"\n  [modal]=\"true\"\n  [closeAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.CLOSE' | translate)\"\n>\n  <ng-template pTemplate=\"header\">\n    <span [id]=\"dialog.ariaLabelledBy\" class=\"text-xl font-bold\"\n      >{{ dialogTitle || (dialogTitleKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.DIALOG_TITLE' | translate)\n      }}</span\n    >\n  </ng-template>\n\n  <p-pickList\n    [source]=\"displayedColumnsModel\"\n    [target]=\"hiddenColumnsModel\"\n    [sourceHeader]=\"activeColumnsLabel || (activeColumnsLabelKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ACTIVE_COLUMNS_LABEL' | translate)\"\n    [targetHeader]=\"inactiveColumnsLabel || (inactiveColumnsLabelKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.INACTIVE_COLUMNS_LABEL' | translate)\"\n    [dragdrop]=\"true\"\n    [responsive]=\"false\"\n    [sourceStyle]=\"{ height: '300px' }\"\n    [targetStyle]=\"{ height: '300px' }\"\n    [upButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.UP' | translate)\"\n    [topButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.TOP' | translate)\"\n    [downButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.DOWN' | translate)\"\n    [bottomButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.BOTTOM' | translate)\"\n    [rightButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.RIGHT' | translate)\"\n    [allRightButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.ALL_RIGHT' | translate)\"\n    [leftButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.LEFT' | translate)\"\n    [allLeftButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.ALL_LEFT' | translate)\"\n  >\n    <ng-template let-item pTemplate=\"item\">\n      <div>{{ item.nameKey | translate }}</div>\n    </ng-template>\n  </p-pickList>\n\n  <div class=\"pt-4\">\n    <p class=\"text-xl font-bold\">{{'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.TITLE' | translate}}</p>\n    <div class=\"flex gap-6 px-3\">\n      <div>\n        <p class=\"mb-1\">{{'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.FREEZE' | translate}}</p>\n        <p-selectButton\n          [options]=\"frozenOptions\"\n          [(ngModel)]=\"frozenActionColumnModel\"\n          optionLabel=\"label\"\n          optionValue=\"value\"\n          id=\"frozenActionColumn\"\n          name=\"frozen-action-column-select-button\"\n        >\n          <ng-template let-option pTemplate>\n            <label id=\"{{option.label}}\">{{option.label | translate}}</label>\n          </ng-template>\n        </p-selectButton>\n      </div>\n      <div>\n        <p class=\"mb-1\">{{'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.POSITION' | translate}}</p>\n        <p-selectButton\n          [options]=\"alignmentOptions\"\n          [(ngModel)]=\"actionColumnPositionModel\"\n          optionLabel=\"label\"\n          optionValue=\"value\"\n          id=\"actionColumnPosition\"\n          class=\"mt-2\"\n          name=\"action-column-position-select-button\"\n        >\n          <ng-template let-option pTemplate>\n            <label id=\"{{option.label}}\">{{option.label | translate}}</label>\n          </ng-template>\n        </p-selectButton>\n      </div>\n    </div>\n  </div>\n\n  <ng-template pTemplate=\"footer\">\n    <p-button\n      id=\"cancelButton\"\n      (onClick)=\"onCancelClick()\"\n      [label]=\"cancelButtonLabel || (cancelButtonLabelKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CANCEL_BUTTON_LABEL' | translate)\"\n      styleClass=\"p-button\"\n      [ariaLabel]=\"cancelButtonLabel || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CANCEL_BUTTON_ARIA_LABEL' | translate)\"\n    ></p-button>\n    <p-button\n      id=\"saveButton\"\n      (onClick)=\"onSaveClick()\"\n      [label]=\"saveButtonLabel || (saveButtonLabelKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.SAVE_BUTTON_LABEL' | translate)\"\n      [ariaLabel]=\"saveButtonAriaLabelKey || (saveButtonAriaLabelKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.SAVE_BUTTON_ARIA_LABEL' | translate)\"\n    ></p-button>\n  </ng-template>\n</p-dialog>\n"]}
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-group-column-selector.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/custom-group-column-selector/custom-group-column-selector.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/custom-group-column-selector/custom-group-column-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\nimport { DataTableColumn } from '../../model/data-table-column.model'\n\nexport type ColumnSelectionChangedEvent = { activeColumns: DataTableColumn[] }\nexport type ActionColumnChangedEvent = {\n  frozenActionColumn: boolean\n  actionColumnPosition: 'left' | 'right'\n}\n\nexport interface CustomGroupColumnSelectorComponentState {\n  actionColumnConfig?: {\n    frozen: boolean\n    position: 'left' | 'right'\n  }\n  displayedColumns?: DataTableColumn[]\n  activeColumnGroupKey?: string\n}\n\n@Component({\n  selector: 'ocx-custom-group-column-selector',\n  templateUrl: './custom-group-column-selector.component.html',\n  styleUrls: ['./custom-group-column-selector.component.scss'],\n})\nexport class CustomGroupColumnSelectorComponent implements OnInit {\n  @Input() columns: DataTableColumn[] = []\n  private _displayedColumns: DataTableColumn[] = []\n  @Input()\n  get displayedColumns() {\n    return this._displayedColumns\n  }\n  set displayedColumns(value: DataTableColumn[]) {\n    this._displayedColumns = value\n    this.componentStateChanged.emit({\n      actionColumnConfig: {\n        frozen: this.frozenActionColumn,\n        position: this.actionColumnPosition,\n      },\n      displayedColumns: this._displayedColumns,\n    })\n  }\n  @Input() dialogTitle = ''\n  @Input() dialogTitleKey = ''\n  @Input() openButtonTitle = ''\n  @Input() openButtonTitleKey = ''\n  @Input() openButtonAriaLabel = ''\n  @Input() openButtonAriaLabelKey = ''\n  @Input() saveButtonLabel = ''\n  @Input() saveButtonLabelKey = ''\n  @Input() saveButtonAriaLabel = ''\n  @Input() saveButtonAriaLabelKey = ''\n  @Input() cancelButtonLabel = ''\n  @Input() cancelButtonLabelKey = ''\n  @Input() cancelButtonAriaLabel = ''\n  @Input() cancelButtonAriaLabelKey = ''\n  @Input() activeColumnsLabel = ''\n  @Input() activeColumnsLabelKey = ''\n  @Input() inactiveColumnsLabel = ''\n  @Input() inactiveColumnsLabelKey = ''\n  @Input() frozenActionColumn = false\n  @Input() actionColumnPosition: 'left' | 'right' = 'right'\n\n  @Output() columnSelectionChanged: EventEmitter<ColumnSelectionChangedEvent> = new EventEmitter()\n  @Output() actionColumnConfigChanged: EventEmitter<ActionColumnChangedEvent> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<CustomGroupColumnSelectorComponentState> = new EventEmitter()\n\n  hiddenColumnsModel: DataTableColumn[] = []\n  displayedColumnsModel: DataTableColumn[] = []\n  frozenActionColumnModel = false\n  actionColumnPositionModel: 'left' | 'right' = 'right'\n  visible = false\n  alignmentOptions = [\n    {\n      label: 'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.LEFT',\n      value: 'left',\n    },\n    {\n      label: 'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.RIGHT',\n      value: 'right',\n    },\n  ]\n\n  frozenOptions = [\n    {\n      label: 'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.YES',\n      value: true,\n    },\n    {\n      label: 'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.NO',\n      value: false,\n    },\n  ]\n\n  constructor(private translate: TranslateService) {}\n\n  ngOnInit(): void {\n    this.componentStateChanged.emit({\n      actionColumnConfig: {\n        frozen: this.frozenActionColumn,\n        position: this.actionColumnPosition,\n      },\n      displayedColumns: this.displayedColumns,\n    })\n  }\n\n  onOpenCustomGroupColumnSelectionDialogClick() {\n    this.displayedColumnsModel = [...this.displayedColumns]\n    this.hiddenColumnsModel = this.columns.filter(\n      (column) => !this.displayedColumnsModel.map((c) => c.id).includes(column.id)\n    )\n    this.frozenActionColumnModel = this.frozenActionColumn\n    this.actionColumnPositionModel = this.actionColumnPosition\n    this.visible = true\n  }\n\n  onSaveClick() {\n    this.visible = false\n    const colIdsBefore = this.displayedColumns.map((column) => column.id)\n    const colIdsAfter = this.displayedColumnsModel.map((column) => column.id)\n\n    if (!colIdsAfter.every((colId, i) => colId === colIdsBefore[i]) || colIdsAfter.length != colIdsBefore.length) {\n      this.columnSelectionChanged.emit({ activeColumns: [...this.displayedColumnsModel] })\n      this.componentStateChanged.emit({\n        displayedColumns: [...this.displayedColumnsModel],\n      })\n    }\n\n    if (\n      this.frozenActionColumn != this.frozenActionColumnModel ||\n      this.actionColumnPosition != this.actionColumnPositionModel\n    ) {\n      this.actionColumnConfigChanged.emit({\n        frozenActionColumn: this.frozenActionColumnModel,\n        actionColumnPosition: this.actionColumnPositionModel,\n      })\n      this.componentStateChanged.emit({\n        displayedColumns: [...this.displayedColumnsModel],\n        actionColumnConfig: {\n          frozen: this.frozenActionColumnModel,\n          position: this.actionColumnPositionModel,\n        },\n      })\n    }\n  }\n\n  onCancelClick() {\n    this.visible = false\n  }\n}\n","<p-button\n  id=\"customGroupColumnSelectorButton\"\n  type=\"button\"\n  (onClick)=\"onOpenCustomGroupColumnSelectionDialogClick()\"\n  [pTooltip]=\"openButtonTitle || (openButtonTitleKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.OPEN_BUTTON_DETAIL' | translate)\"\n  tooltipPosition=\"top\"\n  icon=\"pi pi-cog\"\n  styleClass=\"p-button\"\n  [ariaLabel]=\"(openButtonAriaLabelKey ? (openButtonAriaLabelKey | translate) : openButtonAriaLabel) || openButtonTitle || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.OPEN_BUTTON_DETAIL' | translate)\"\n  [attr.aria-controls]=\"visible ? 'customGroupColumnSelectorDialog' : null\"\n  [attr.aria-expanded]=\"visible ? true : false\"\n></p-button>\n\n<p-dialog\n  #dialog\n  id=\"customGroupColumnSelectorDialog\"\n  [(visible)]=\"visible\"\n  [style]=\"{ width: '70%' }\"\n  [modal]=\"true\"\n  [closeAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.CLOSE' | translate)\"\n>\n  <ng-template pTemplate=\"header\">\n    <span [id]=\"dialog.ariaLabelledBy\" class=\"text-xl font-bold\"\n      >{{ dialogTitle || (dialogTitleKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.DIALOG_TITLE' | translate)\n      }}</span\n    >\n  </ng-template>\n\n  <p-pickList\n    [source]=\"displayedColumnsModel\"\n    [target]=\"hiddenColumnsModel\"\n    [sourceHeader]=\"activeColumnsLabel || (activeColumnsLabelKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ACTIVE_COLUMNS_LABEL' | translate)\"\n    [targetHeader]=\"inactiveColumnsLabel || (inactiveColumnsLabelKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.INACTIVE_COLUMNS_LABEL' | translate)\"\n    [dragdrop]=\"true\"\n    [responsive]=\"false\"\n    [sourceStyle]=\"{ height: '300px' }\"\n    [targetStyle]=\"{ height: '300px' }\"\n    [upButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.UP' | translate)\"\n    [topButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.TOP' | translate)\"\n    [downButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.DOWN' | translate)\"\n    [bottomButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.BOTTOM' | translate)\"\n    [rightButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.RIGHT' | translate)\"\n    [allRightButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.ALL_RIGHT' | translate)\"\n    [leftButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.LEFT' | translate)\"\n    [allLeftButtonAriaLabel]=\"('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.ARIA_LABELS.ALL_LEFT' | translate)\"\n  >\n    <ng-template let-item pTemplate=\"item\">\n      <div>{{ item.nameKey | translate }}</div>\n    </ng-template>\n  </p-pickList>\n\n  <div class=\"pt-4\">\n    <p class=\"text-xl font-bold\">{{'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.TITLE' | translate}}</p>\n    <div class=\"flex gap-6 px-3\">\n      <div>\n        <p class=\"mb-1\">{{'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.FREEZE' | translate}}</p>\n        <p-selectButton\n          [options]=\"frozenOptions\"\n          [(ngModel)]=\"frozenActionColumnModel\"\n          optionLabel=\"label\"\n          optionValue=\"value\"\n          id=\"frozenActionColumn\"\n          name=\"frozen-action-column-select-button\"\n        >\n          <ng-template let-option pTemplate>\n            <label id=\"{{option.label}}\">{{option.label | translate}}</label>\n          </ng-template>\n        </p-selectButton>\n      </div>\n      <div>\n        <p class=\"mb-1\">{{'OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CONFIGURE_ACTION_COLUMN.POSITION' | translate}}</p>\n        <p-selectButton\n          [options]=\"alignmentOptions\"\n          [(ngModel)]=\"actionColumnPositionModel\"\n          optionLabel=\"label\"\n          optionValue=\"value\"\n          id=\"actionColumnPosition\"\n          class=\"mt-2\"\n          name=\"action-column-position-select-button\"\n        >\n          <ng-template let-option pTemplate>\n            <label id=\"{{option.label}}\">{{option.label | translate}}</label>\n          </ng-template>\n        </p-selectButton>\n      </div>\n    </div>\n  </div>\n\n  <ng-template pTemplate=\"footer\">\n    <p-button\n      id=\"cancelButton\"\n      (onClick)=\"onCancelClick()\"\n      [label]=\"cancelButtonLabel || (cancelButtonLabelKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CANCEL_BUTTON_LABEL' | translate)\"\n      styleClass=\"p-button\"\n      [ariaLabel]=\"cancelButtonLabel || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.CANCEL_BUTTON_ARIA_LABEL' | translate)\"\n    ></p-button>\n    <p-button\n      id=\"saveButton\"\n      (onClick)=\"onSaveClick()\"\n      [label]=\"saveButtonLabel || (saveButtonLabelKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.SAVE_BUTTON_LABEL' | translate)\"\n      [ariaLabel]=\"saveButtonAriaLabelKey || (saveButtonAriaLabelKey | translate) || ('OCX_CUSTOM_GROUP_COLUMN_SELECTOR.SAVE_BUTTON_ARIA_LABEL' | translate)\"\n    ></p-button>\n  </ng-template>\n</p-dialog>\n"]}
@@ -49,7 +49,7 @@ export class DataSortBase {
49
49
  switch (filter.filterType) {
50
50
  case undefined:
51
51
  case FilterType.EQUAL:
52
- return value === filter.value;
52
+ return value === String(filter.value);
53
53
  case FilterType.TRUTHY: {
54
54
  return filter.value ? !!value : !value;
55
55
  }
@@ -121,4 +121,4 @@ export class DataSortBase {
121
121
  };
122
122
  }
123
123
  }
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-sort-base.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/data-sort-base/data-sort-base.ts"],"names":[],"mappings":"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","sourcesContent":["import { TranslateService } from '@ngx-translate/core'\nimport { Observable, map, of } from 'rxjs'\nimport { flattenObject } from '../../functions/flatten-object'\nimport { ColumnType } from '../../model/column-type.model'\nimport { DataSortDirection } from '../../model/data-sort-direction'\nimport { DataTableColumn } from '../../model/data-table-column.model'\nimport { ListGridData } from '../../components/data-list-grid/data-list-grid.component'\nimport { Row } from '../../components/data-table/data-table.component'\nimport { ObjectUtils } from '../../utils/objectutils'\nimport { Filter, FilterType } from '../../model/filter.model'\n\ntype RowListGridData = ListGridData | Row\n\nexport class DataSortBase {\n  constructor(\n    protected locale: string,\n    protected translateService: TranslateService\n  ) {}\n\n  translateItems(\n    [items, filters, sortColumn, sortDirection]: [RowListGridData[], Filter[], string, DataSortDirection],\n    columns: DataTableColumn[],\n    clientSideFiltering: boolean,\n    clientSideSorting: boolean\n  ): Observable<[RowListGridData[], Filter[], string, DataSortDirection, Record<string, Record<string, string>>]> {\n    if (clientSideFiltering || clientSideSorting) {\n      let translationKeys: string[] = []\n      const translatedColumns = columns.filter((c) => c.columnType === ColumnType.TRANSLATION_KEY)\n      translatedColumns.forEach((c) => {\n        translationKeys = [\n          ...translationKeys,\n          ...items.map((i) => ObjectUtils.resolveFieldData(i, c.id)?.toString()).filter((v) => !!v),\n        ]\n      })\n      if (translationKeys.length) {\n        return this.translateService.get(translationKeys).pipe(\n          map((translatedValues: Record<string, string>) => {\n            const translations: Record<string, Record<string, string>> = {}\n            translatedColumns.forEach((c) => {\n              translations[c.id] = Object.fromEntries(\n                items.map((i) => [\n                  ObjectUtils.resolveFieldData(i, c.id)?.toString() || '',\n                  translatedValues[ObjectUtils.resolveFieldData(i, c.id)?.toString()],\n                ])\n              )\n            })\n            return [items, filters, sortColumn, sortDirection, translations]\n          })\n        )\n      }\n    }\n    return of([items, filters, sortColumn, sortDirection, {}])\n  }\n\n  filterItems(\n    [items, filters, sortColumn, sortDirection, translations]: [\n      RowListGridData[],\n      Filter[],\n      string,\n      DataSortDirection,\n      Record<string, Record<string, string>>,\n    ],\n    clientSideFiltering: boolean\n  ): [RowListGridData[], Filter[], string, DataSortDirection, Record<string, Record<string, string>>] {\n    if (!clientSideFiltering) {\n      return [items, filters, sortColumn, sortDirection, translations]\n    }\n    return [\n      items.filter((item) =>\n        filters\n          .map((filter) => filter.columnId)\n          .filter((value, index, self) => self.indexOf(value) === index && value != null)\n          .every((filterColumnId) =>\n            filters\n              .filter((filter) => filter.columnId === filterColumnId)\n              .some((filter) => {\n                const value = (\n                  translations[filter.columnId]?.[ObjectUtils.resolveFieldData(item, filter.columnId)?.toString()] ||\n                  ObjectUtils.resolveFieldData(item, filter.columnId)\n                )?.toString()\n                switch (filter.filterType) {\n                  case undefined:\n                  case FilterType.EQUAL:\n                    return value === filter.value\n                  case FilterType.TRUTHY: {\n                    return filter.value ? !!value : !value\n                  }\n                }\n              })\n          )\n      ),\n      filters,\n      sortColumn,\n      sortDirection,\n      translations,\n    ]\n  }\n\n  sortItems(\n    [items, filters, sortColumn, sortDirection, translations]: [\n      RowListGridData[],\n      Filter[],\n      string,\n      DataSortDirection,\n      Record<string, Record<string, string>>,\n    ],\n    columns: DataTableColumn[],\n    clientSideSorting: boolean\n  ): [RowListGridData[], Filter[], string, DataSortDirection, Record<string, Record<string, string>>] {\n    if (!clientSideSorting || sortColumn === '') {\n      return [items, filters, sortColumn, sortDirection, translations]\n    }\n    let translatedColValues: Record<string, string> = Object.fromEntries(\n      items.map((i) => [\n        ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),\n        ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),\n      ])\n    )\n    if (columns.find((h) => h.id === sortColumn)?.columnType === ColumnType.TRANSLATION_KEY) {\n      translatedColValues = translations[sortColumn]\n    }\n    return [\n      [...items].sort(this.createCompareFunction(translatedColValues, sortColumn, sortDirection)),\n      filters,\n      sortColumn,\n      sortDirection,\n      translations,\n    ]\n  }\n\n  flattenItems(items: RowListGridData[]) {\n    return items.map((i) => flattenObject(i))\n  }\n\n  createCompareFunction(\n    translatedColValues: Record<string, string>,\n    sortColumn: string,\n    sortDirection: DataSortDirection\n  ): (a: Record<string, any>, b: Record<string, any>) => number {\n    let direction = 0\n    if (sortDirection === DataSortDirection.ASCENDING) {\n      direction = 1\n    } else if (sortDirection === DataSortDirection.DESCENDING) {\n      direction = -1\n    }\n    return (data1, data2) => {\n      if (direction === 0) {\n        return 0\n      }\n      let result\n      const value1 = translatedColValues[ObjectUtils.resolveFieldData(data1, sortColumn)]\n      const value2 = translatedColValues[ObjectUtils.resolveFieldData(data2, sortColumn)]\n\n      if (value1 == null && value2 != null) result = -1\n      else if (value1 != null && value2 == null) result = 1\n      else if (value1 == null && value2 == null) result = 0\n      else if (typeof value1 === 'string' && typeof value2 === 'string')\n        result = value1.localeCompare(value2, [this.locale, 'en', 'de'], { numeric: true })\n      else {\n        if (value1 < value2) {\n          result = -1\n        } else if (value1 > value2) {\n          result = 1\n        } else {\n          result = 0\n        }\n      }\n      return direction * result\n    }\n  }\n}\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-sort-base.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/data-sort-base/data-sort-base.ts"],"names":[],"mappings":"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","sourcesContent":["import { TranslateService } from '@ngx-translate/core'\nimport { Observable, map, of } from 'rxjs'\nimport { flattenObject } from '../../functions/flatten-object'\nimport { ColumnType } from '../../model/column-type.model'\nimport { DataSortDirection } from '../../model/data-sort-direction'\nimport { DataTableColumn } from '../../model/data-table-column.model'\nimport { ListGridData } from '../../components/data-list-grid/data-list-grid.component'\nimport { Row } from '../../components/data-table/data-table.component'\nimport { ObjectUtils } from '../../utils/objectutils'\nimport { Filter, FilterType } from '../../model/filter.model'\n\ntype RowListGridData = ListGridData | Row\n\nexport class DataSortBase {\n  constructor(\n    protected locale: string,\n    protected translateService: TranslateService\n  ) {}\n\n  translateItems(\n    [items, filters, sortColumn, sortDirection]: [RowListGridData[], Filter[], string, DataSortDirection],\n    columns: DataTableColumn[],\n    clientSideFiltering: boolean,\n    clientSideSorting: boolean\n  ): Observable<[RowListGridData[], Filter[], string, DataSortDirection, Record<string, Record<string, string>>]> {\n    if (clientSideFiltering || clientSideSorting) {\n      let translationKeys: string[] = []\n      const translatedColumns = columns.filter((c) => c.columnType === ColumnType.TRANSLATION_KEY)\n      translatedColumns.forEach((c) => {\n        translationKeys = [\n          ...translationKeys,\n          ...items.map((i) => ObjectUtils.resolveFieldData(i, c.id)?.toString()).filter((v) => !!v),\n        ]\n      })\n      if (translationKeys.length) {\n        return this.translateService.get(translationKeys).pipe(\n          map((translatedValues: Record<string, string>) => {\n            const translations: Record<string, Record<string, string>> = {}\n            translatedColumns.forEach((c) => {\n              translations[c.id] = Object.fromEntries(\n                items.map((i) => [\n                  ObjectUtils.resolveFieldData(i, c.id)?.toString() || '',\n                  translatedValues[ObjectUtils.resolveFieldData(i, c.id)?.toString()],\n                ])\n              )\n            })\n            return [items, filters, sortColumn, sortDirection, translations]\n          })\n        )\n      }\n    }\n    return of([items, filters, sortColumn, sortDirection, {}])\n  }\n\n  filterItems(\n    [items, filters, sortColumn, sortDirection, translations]: [\n      RowListGridData[],\n      Filter[],\n      string,\n      DataSortDirection,\n      Record<string, Record<string, string>>,\n    ],\n    clientSideFiltering: boolean\n  ): [RowListGridData[], Filter[], string, DataSortDirection, Record<string, Record<string, string>>] {\n    if (!clientSideFiltering) {\n      return [items, filters, sortColumn, sortDirection, translations]\n    }\n    return [\n      items.filter((item) =>\n        filters\n          .map((filter) => filter.columnId)\n          .filter((value, index, self) => self.indexOf(value) === index && value != null)\n          .every((filterColumnId) =>\n            filters\n              .filter((filter) => filter.columnId === filterColumnId)\n              .some((filter) => {\n                const value = (\n                  translations[filter.columnId]?.[ObjectUtils.resolveFieldData(item, filter.columnId)?.toString()] ||\n                  ObjectUtils.resolveFieldData(item, filter.columnId)\n                )?.toString()\n                switch (filter.filterType) {\n                  case undefined:\n                  case FilterType.EQUAL:\n                    return value === String(filter.value)\n                  case FilterType.TRUTHY: {\n                    return filter.value ? !!value : !value\n                  }\n                }\n              })\n          )\n      ),\n      filters,\n      sortColumn,\n      sortDirection,\n      translations,\n    ]\n  }\n\n  sortItems(\n    [items, filters, sortColumn, sortDirection, translations]: [\n      RowListGridData[],\n      Filter[],\n      string,\n      DataSortDirection,\n      Record<string, Record<string, string>>,\n    ],\n    columns: DataTableColumn[],\n    clientSideSorting: boolean\n  ): [RowListGridData[], Filter[], string, DataSortDirection, Record<string, Record<string, string>>] {\n    if (!clientSideSorting || sortColumn === '') {\n      return [items, filters, sortColumn, sortDirection, translations]\n    }\n    let translatedColValues: Record<string, string> = Object.fromEntries(\n      items.map((i) => [\n        ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),\n        ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),\n      ])\n    )\n    if (columns.find((h) => h.id === sortColumn)?.columnType === ColumnType.TRANSLATION_KEY) {\n      translatedColValues = translations[sortColumn]\n    }\n    return [\n      [...items].sort(this.createCompareFunction(translatedColValues, sortColumn, sortDirection)),\n      filters,\n      sortColumn,\n      sortDirection,\n      translations,\n    ]\n  }\n\n  flattenItems(items: RowListGridData[]) {\n    return items.map((i) => flattenObject(i))\n  }\n\n  createCompareFunction(\n    translatedColValues: Record<string, string>,\n    sortColumn: string,\n    sortDirection: DataSortDirection\n  ): (a: Record<string, any>, b: Record<string, any>) => number {\n    let direction = 0\n    if (sortDirection === DataSortDirection.ASCENDING) {\n      direction = 1\n    } else if (sortDirection === DataSortDirection.DESCENDING) {\n      direction = -1\n    }\n    return (data1, data2) => {\n      if (direction === 0) {\n        return 0\n      }\n      let result\n      const value1 = translatedColValues[ObjectUtils.resolveFieldData(data1, sortColumn)]\n      const value2 = translatedColValues[ObjectUtils.resolveFieldData(data2, sortColumn)]\n\n      if (value1 == null && value2 != null) result = -1\n      else if (value1 != null && value2 == null) result = 1\n      else if (value1 == null && value2 == null) result = 0\n      else if (typeof value1 === 'string' && typeof value2 === 'string')\n        result = value1.localeCompare(value2, [this.locale, 'en', 'de'], { numeric: true })\n      else {\n        if (value1 < value2) {\n          result = -1\n        } else if (value1 > value2) {\n          result = 1\n        } else {\n          result = 0\n        }\n      }\n      return direction * result\n    }\n  }\n}\n"]}