@onecx/angular-accelerator 5.7.0 → 5.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/column-group-selection/column-group-selection.component.mjs +17 -2
- package/esm2022/lib/components/custom-group-column-selector/custom-group-column-selector.component.mjs +30 -4
- package/esm2022/lib/components/data-layout-selection/data-layout-selection.component.mjs +11 -2
- package/esm2022/lib/components/data-list-grid/data-list-grid.component.mjs +26 -3
- package/esm2022/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.mjs +17 -3
- package/esm2022/lib/components/data-table/data-table.component.mjs +223 -40
- package/esm2022/lib/components/data-view/data-view.component.mjs +110 -4
- package/esm2022/lib/components/diagram/diagram.component.mjs +8 -2
- package/esm2022/lib/components/group-by-count-diagram/group-by-count-diagram.component.mjs +8 -2
- package/esm2022/lib/components/interactive-data-view/interactive-data-view.component.mjs +139 -9
- package/esm2022/lib/components/search-header/search-header.component.mjs +11 -2
- package/esm2022/lib/utils/rxjs-utils.mjs +13 -0
- package/fesm2022/onecx-angular-accelerator.mjs +598 -60
- package/fesm2022/onecx-angular-accelerator.mjs.map +1 -1
- package/lib/components/column-group-selection/column-group-selection.component.d.ts +6 -1
- package/lib/components/custom-group-column-selector/custom-group-column-selector.component.d.ts +13 -3
- package/lib/components/data-layout-selection/data-layout-selection.component.d.ts +5 -1
- package/lib/components/data-list-grid/data-list-grid.component.d.ts +16 -9
- package/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.d.ts +12 -2
- package/lib/components/data-table/data-table.component.d.ts +63 -2
- package/lib/components/data-view/data-view.component.d.ts +41 -4
- package/lib/components/diagram/diagram.component.d.ts +5 -1
- package/lib/components/group-by-count-diagram/group-by-count-diagram.component.d.ts +5 -1
- package/lib/components/interactive-data-view/interactive-data-view.component.d.ts +46 -7
- package/lib/components/search-header/search-header.component.d.ts +6 -1
- package/lib/utils/rxjs-utils.d.ts +3 -0
- package/package.json +2 -1
|
@@ -14,6 +14,7 @@ export class DataListGridSortingComponent {
|
|
|
14
14
|
this._sortField$ = new BehaviorSubject('');
|
|
15
15
|
this.sortChange = new EventEmitter();
|
|
16
16
|
this.sortDirectionChange = new EventEmitter();
|
|
17
|
+
this.componentStateChanged = new EventEmitter();
|
|
17
18
|
this.columnsChange = new EventEmitter();
|
|
18
19
|
this.dropdownOptions = [];
|
|
19
20
|
}
|
|
@@ -32,19 +33,30 @@ export class DataListGridSortingComponent {
|
|
|
32
33
|
ngOnInit() {
|
|
33
34
|
this.columns.forEach((element) => this.dropdownOptions.push({ columnId: element.id, columnName: element.nameKey }));
|
|
34
35
|
this.selectedSortingOption = this.dropdownOptions.find((e) => e.columnId === this?.sortField);
|
|
36
|
+
this.emitComponentStateChange();
|
|
35
37
|
}
|
|
36
38
|
selectSorting(event) {
|
|
37
|
-
this._sortField$.next(event.value);
|
|
39
|
+
this._sortField$.next(event.value.columnId);
|
|
38
40
|
this.sortChange.emit(event.value.columnId);
|
|
41
|
+
this.emitComponentStateChange();
|
|
39
42
|
}
|
|
40
43
|
sortDirectionChanged() {
|
|
41
44
|
const newSortDirection = this.nextSortDirection();
|
|
42
45
|
this._sortDirection$.next(newSortDirection);
|
|
43
46
|
this.sortDirectionChange.emit(newSortDirection);
|
|
47
|
+
this.emitComponentStateChange();
|
|
44
48
|
}
|
|
45
49
|
nextSortDirection() {
|
|
46
50
|
return this.sortStates[(this.sortStates.indexOf(this.sortDirection) + 1) % this.sortStates.length];
|
|
47
51
|
}
|
|
52
|
+
emitComponentStateChange() {
|
|
53
|
+
this.componentStateChanged.emit({
|
|
54
|
+
sorting: {
|
|
55
|
+
sortColumn: this.sortField,
|
|
56
|
+
sortDirection: this.sortDirection
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}
|
|
48
60
|
sortIcon() {
|
|
49
61
|
switch (this.sortDirection) {
|
|
50
62
|
case "ASCENDING" /* DataSortDirection.ASCENDING */:
|
|
@@ -69,7 +81,7 @@ export class DataListGridSortingComponent {
|
|
|
69
81
|
}
|
|
70
82
|
}
|
|
71
83
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: DataListGridSortingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
72
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: DataListGridSortingComponent, selector: "ocx-data-list-grid-sorting", inputs: { columns: "columns", sortStates: "sortStates", sortDirection: "sortDirection", sortField: "sortField" }, outputs: { sortChange: "sortChange", sortDirectionChange: "sortDirectionChange", columnsChange: "columnsChange" }, ngImport: i0, template: "<div class=\"flex align-items-center gap-2\">\n <p-dropdown\n id=\"dataListGridSortingDropdown\"\n [(ngModel)]=\"selectedSortingOption\"\n class=\"sort-dropdown\"\n [options]=\"dropdownOptions\"\n [placeholder]=\"('OCX_LIST_GRID_SORT.DROPDOWN.PLACEHOLDER' | translate)\"\n (onChange)=\"selectSorting($event)\"\n [title]=\"('OCX_LIST_GRID_SORT.DROPDOWN.TITLE' | translate)\"\n >\n <ng-template let-item pTemplate=\"item\"> {{ item?.columnName ? (item.columnName | translate) : ''}} </ng-template>\n <ng-template let-item pTemplate=\"selectedItem\">\n {{ item?.columnName ? (item.columnName | translate) : ''}}\n </ng-template></p-dropdown\n >\n <p-button\n id=\"dataListGridSortingButton\"\n icon=\"pi {{sortIcon()}}\"\n styleClass=\"p-button-outlined\"\n (onClick)=\"sortDirectionChanged()\"\n [title]=\"(sortIconTitle() | translate)\"\n [attr.aria-label]=\"('OCX_LIST_GRID_SORT.SORTING_BUTTON_ARIA_LABEL' | translate:{direction: (sortDirectionToTitle(nextSortDirection())) | translate})\"\n ></p-button>\n</div>\n", styles: [".pi{border-radius:var(--border-radius);border-width:thin;background:none;cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i2.Dropdown, selector: "p-dropdown", inputs: ["id", "scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "loadingIcon", "filterPlaceholder", "filterLocale", "variant", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "checkmark", "dropdownIcon", "loading", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "component", type: i3.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }] }); }
|
|
84
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: DataListGridSortingComponent, selector: "ocx-data-list-grid-sorting", inputs: { columns: "columns", sortStates: "sortStates", sortDirection: "sortDirection", sortField: "sortField" }, outputs: { sortChange: "sortChange", sortDirectionChange: "sortDirectionChange", componentStateChanged: "componentStateChanged", columnsChange: "columnsChange" }, ngImport: i0, template: "<div class=\"flex align-items-center gap-2\">\n <p-dropdown\n id=\"dataListGridSortingDropdown\"\n [(ngModel)]=\"selectedSortingOption\"\n class=\"sort-dropdown\"\n [options]=\"dropdownOptions\"\n [placeholder]=\"('OCX_LIST_GRID_SORT.DROPDOWN.PLACEHOLDER' | translate)\"\n (onChange)=\"selectSorting($event)\"\n [title]=\"('OCX_LIST_GRID_SORT.DROPDOWN.TITLE' | translate)\"\n >\n <ng-template let-item pTemplate=\"item\"> {{ item?.columnName ? (item.columnName | translate) : ''}} </ng-template>\n <ng-template let-item pTemplate=\"selectedItem\">\n {{ item?.columnName ? (item.columnName | translate) : ''}}\n </ng-template></p-dropdown\n >\n <p-button\n id=\"dataListGridSortingButton\"\n icon=\"pi {{sortIcon()}}\"\n styleClass=\"p-button-outlined\"\n (onClick)=\"sortDirectionChanged()\"\n [title]=\"(sortIconTitle() | translate)\"\n [attr.aria-label]=\"('OCX_LIST_GRID_SORT.SORTING_BUTTON_ARIA_LABEL' | translate:{direction: (sortDirectionToTitle(nextSortDirection())) | translate})\"\n ></p-button>\n</div>\n", styles: [".pi{border-radius:var(--border-radius);border-width:thin;background:none;cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i2.Dropdown, selector: "p-dropdown", inputs: ["id", "scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "loadingIcon", "filterPlaceholder", "filterLocale", "variant", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "checkmark", "dropdownIcon", "loading", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "component", type: i3.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }] }); }
|
|
73
85
|
}
|
|
74
86
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: DataListGridSortingComponent, decorators: [{
|
|
75
87
|
type: Component,
|
|
@@ -86,7 +98,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
86
98
|
type: Output
|
|
87
99
|
}], sortDirectionChange: [{
|
|
88
100
|
type: Output
|
|
101
|
+
}], componentStateChanged: [{
|
|
102
|
+
type: Output
|
|
89
103
|
}], columnsChange: [{
|
|
90
104
|
type: Output
|
|
91
105
|
}] } });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-list-grid-sorting.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core'\nimport { BehaviorSubject } from 'rxjs'\nimport { DataSortDirection } from '../../model/data-sort-direction'\nimport { DataColumnNameId } from '../../model/data-column-name-id.model'\nimport { DataTableColumn } from '../../model/data-table-column.model'\n\n@Component({\n  selector: 'ocx-data-list-grid-sorting',\n  templateUrl: './data-list-grid-sorting.component.html',\n  styleUrls: ['./data-list-grid-sorting.component.scss'],\n})\nexport class DataListGridSortingComponent implements OnInit {\n  @Input() columns: DataTableColumn[] = []\n  @Input() sortStates: DataSortDirection[] = [DataSortDirection.ASCENDING, DataSortDirection.DESCENDING]\n  _sortDirection$ = new BehaviorSubject<DataSortDirection>(DataSortDirection.NONE)\n  @Input()\n  get sortDirection(): DataSortDirection {\n    return this._sortDirection$.getValue()\n  }\n  set sortDirection(value: DataSortDirection) {\n    this._sortDirection$.next(value)\n  }\n  _sortField$ = new BehaviorSubject<string>('')\n  @Input()\n  get sortField(): string {\n    return this?._sortField$.getValue()\n  }\n  set sortField(value: string) {\n    this._sortField$.next(value)\n  }\n\n  @Output() sortChange: EventEmitter<string> = new EventEmitter()\n  @Output() sortDirectionChange: EventEmitter<DataSortDirection> = new EventEmitter()\n  @Output() columnsChange: EventEmitter<string[]> = new EventEmitter()\n  selectedSortingOption: DataColumnNameId | undefined\n  dropdownOptions: DataColumnNameId[] = []\n\n  ngOnInit(): void {\n    this.columns.forEach((element) => this.dropdownOptions.push({ columnId: element.id, columnName: element.nameKey }))\n    this.selectedSortingOption = this.dropdownOptions.find((e) => e.columnId === this?.sortField)\n  }\n\n  selectSorting(event: any): void {\n    this._sortField$.next(event.value)\n    this.sortChange.emit(event.value.columnId)\n  }\n  sortDirectionChanged(): void {\n    const newSortDirection = this.nextSortDirection()\n    this._sortDirection$.next(newSortDirection)\n    this.sortDirectionChange.emit(newSortDirection)\n  }\n\n  nextSortDirection() {\n    return this.sortStates[(this.sortStates.indexOf(this.sortDirection) + 1) % this.sortStates.length]\n  }\n\n  sortIcon() {\n    switch (this.sortDirection) {\n      case DataSortDirection.ASCENDING:\n        return 'pi-sort-amount-up'\n      case DataSortDirection.DESCENDING:\n        return 'pi-sort-amount-down'\n      default:\n        return 'pi-sort-alt'\n    }\n  }\n\n  sortIconTitle() {\n    return this.sortDirectionToTitle(this.sortDirection)\n  }\n\n  sortDirectionToTitle(sortDirection: DataSortDirection) {\n    switch (sortDirection) {\n      case DataSortDirection.ASCENDING:\n        return 'OCX_LIST_GRID_SORT.TOGGLE_BUTTON.ASCENDING_TITLE'\n      case DataSortDirection.DESCENDING:\n        return 'OCX_LIST_GRID_SORT.TOGGLE_BUTTON.DESCENDING_TITLE'\n      default:\n        return 'OCX_LIST_GRID_SORT.TOGGLE_BUTTON.DEFAULT_TITLE'\n    }\n  }\n}\n","<div class=\"flex align-items-center gap-2\">\n  <p-dropdown\n    id=\"dataListGridSortingDropdown\"\n    [(ngModel)]=\"selectedSortingOption\"\n    class=\"sort-dropdown\"\n    [options]=\"dropdownOptions\"\n    [placeholder]=\"('OCX_LIST_GRID_SORT.DROPDOWN.PLACEHOLDER' | translate)\"\n    (onChange)=\"selectSorting($event)\"\n    [title]=\"('OCX_LIST_GRID_SORT.DROPDOWN.TITLE' | translate)\"\n  >\n    <ng-template let-item pTemplate=\"item\"> {{ item?.columnName ? (item.columnName | translate) : ''}} </ng-template>\n    <ng-template let-item pTemplate=\"selectedItem\">\n      {{ item?.columnName ? (item.columnName | translate) : ''}}\n    </ng-template></p-dropdown\n  >\n  <p-button\n    id=\"dataListGridSortingButton\"\n    icon=\"pi {{sortIcon()}}\"\n    styleClass=\"p-button-outlined\"\n    (onClick)=\"sortDirectionChanged()\"\n    [title]=\"(sortIconTitle() | translate)\"\n    [attr.aria-label]=\"('OCX_LIST_GRID_SORT.SORTING_BUTTON_ARIA_LABEL' | translate:{direction: (sortDirectionToTitle(nextSortDirection())) | translate})\"\n  ></p-button>\n</div>\n"]}
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-list-grid-sorting.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core'\nimport { BehaviorSubject } from 'rxjs'\nimport { DataSortDirection } from '../../model/data-sort-direction'\nimport { DataColumnNameId } from '../../model/data-column-name-id.model'\nimport { DataTableColumn } from '../../model/data-table-column.model'\nimport { DropdownChangeEvent } from 'primeng/dropdown'\n\nexport type ListGridSort = { sortColumn: string; sortDirection: DataSortDirection }\nexport interface DataListGridSortingComponentState {\n  sorting?: ListGridSort\n}\n\n@Component({\n  selector: 'ocx-data-list-grid-sorting',\n  templateUrl: './data-list-grid-sorting.component.html',\n  styleUrls: ['./data-list-grid-sorting.component.scss'],\n})\nexport class DataListGridSortingComponent implements OnInit {\n  @Input() columns: DataTableColumn[] = []\n  @Input() sortStates: DataSortDirection[] = [DataSortDirection.ASCENDING, DataSortDirection.DESCENDING]\n  _sortDirection$ = new BehaviorSubject<DataSortDirection>(DataSortDirection.NONE)\n  @Input()\n  get sortDirection(): DataSortDirection {\n    return this._sortDirection$.getValue()\n  }\n  set sortDirection(value: DataSortDirection) {\n    this._sortDirection$.next(value)\n  }\n  _sortField$ = new BehaviorSubject<string>('')\n  @Input()\n  get sortField(): string {\n    return this?._sortField$.getValue()\n  }\n  set sortField(value: string) {\n    this._sortField$.next(value)\n  }\n\n  @Output() sortChange: EventEmitter<string> = new EventEmitter()\n  @Output() sortDirectionChange: EventEmitter<DataSortDirection> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<DataListGridSortingComponentState> = new EventEmitter()\n  @Output() columnsChange: EventEmitter<string[]> = new EventEmitter()\n  selectedSortingOption: DataColumnNameId | undefined\n  dropdownOptions: DataColumnNameId[] = []\n\n  ngOnInit(): void {\n    this.columns.forEach((element) => this.dropdownOptions.push({ columnId: element.id, columnName: element.nameKey }))\n    this.selectedSortingOption = this.dropdownOptions.find((e) => e.columnId === this?.sortField)\n    this.emitComponentStateChange()\n  }\n\n  selectSorting(event: DropdownChangeEvent): void {\n    this._sortField$.next(event.value.columnId)\n    this.sortChange.emit(event.value.columnId)\n    this.emitComponentStateChange()\n  }\n  sortDirectionChanged(): void {\n    const newSortDirection = this.nextSortDirection()\n    this._sortDirection$.next(newSortDirection)\n    this.sortDirectionChange.emit(newSortDirection)\n    this.emitComponentStateChange()\n  }\n\n  nextSortDirection() {\n    return this.sortStates[(this.sortStates.indexOf(this.sortDirection) + 1) % this.sortStates.length]\n  }\n\n  emitComponentStateChange() {\n    this.componentStateChanged.emit({\n      sorting: {\n        sortColumn: this.sortField,\n        sortDirection: this.sortDirection\n      }\n    })\n  }\n\n  sortIcon() {\n    switch (this.sortDirection) {\n      case DataSortDirection.ASCENDING:\n        return 'pi-sort-amount-up'\n      case DataSortDirection.DESCENDING:\n        return 'pi-sort-amount-down'\n      default:\n        return 'pi-sort-alt'\n    }\n  }\n\n  sortIconTitle() {\n    return this.sortDirectionToTitle(this.sortDirection)\n  }\n\n  sortDirectionToTitle(sortDirection: DataSortDirection) {\n    switch (sortDirection) {\n      case DataSortDirection.ASCENDING:\n        return 'OCX_LIST_GRID_SORT.TOGGLE_BUTTON.ASCENDING_TITLE'\n      case DataSortDirection.DESCENDING:\n        return 'OCX_LIST_GRID_SORT.TOGGLE_BUTTON.DESCENDING_TITLE'\n      default:\n        return 'OCX_LIST_GRID_SORT.TOGGLE_BUTTON.DEFAULT_TITLE'\n    }\n  }\n}\n","<div class=\"flex align-items-center gap-2\">\n  <p-dropdown\n    id=\"dataListGridSortingDropdown\"\n    [(ngModel)]=\"selectedSortingOption\"\n    class=\"sort-dropdown\"\n    [options]=\"dropdownOptions\"\n    [placeholder]=\"('OCX_LIST_GRID_SORT.DROPDOWN.PLACEHOLDER' | translate)\"\n    (onChange)=\"selectSorting($event)\"\n    [title]=\"('OCX_LIST_GRID_SORT.DROPDOWN.TITLE' | translate)\"\n  >\n    <ng-template let-item pTemplate=\"item\"> {{ item?.columnName ? (item.columnName | translate) : ''}} </ng-template>\n    <ng-template let-item pTemplate=\"selectedItem\">\n      {{ item?.columnName ? (item.columnName | translate) : ''}}\n    </ng-template></p-dropdown\n  >\n  <p-button\n    id=\"dataListGridSortingButton\"\n    icon=\"pi {{sortIcon()}}\"\n    styleClass=\"p-button-outlined\"\n    (onClick)=\"sortDirectionChanged()\"\n    [title]=\"(sortIconTitle() | translate)\"\n    [attr.aria-label]=\"('OCX_LIST_GRID_SORT.SORTING_BUTTON_ARIA_LABEL' | translate:{direction: (sortDirectionToTitle(nextSortDirection())) | translate})\"\n  ></p-button>\n</div>\n"]}
|