@onecx/angular-accelerator 5.38.0 → 6.0.0-rc.11

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.
Files changed (126) hide show
  1. package/assets/i18n/de.json +3 -3
  2. package/assets/i18n/en.json +3 -3
  3. package/assets/styles.scss +0 -4
  4. package/fesm2022/onecx-angular-accelerator-testing.mjs +90 -28
  5. package/fesm2022/onecx-angular-accelerator-testing.mjs.map +1 -1
  6. package/fesm2022/onecx-angular-accelerator.mjs +941 -510
  7. package/fesm2022/onecx-angular-accelerator.mjs.map +1 -1
  8. package/index.d.ts +8 -0
  9. package/lib/angular-accelerator-primeng.module.d.ts +6 -4
  10. package/lib/angular-accelerator.module.d.ts +26 -20
  11. package/lib/components/content/content.component.d.ts +13 -0
  12. package/lib/components/content-container/content-container.component.d.ts +19 -0
  13. package/lib/components/custom-group-column-selector/custom-group-column-selector.component.d.ts +0 -2
  14. package/lib/components/data-list-grid/data-list-grid.component.d.ts +10 -20
  15. package/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.d.ts +2 -2
  16. package/lib/components/data-table/data-table.component.d.ts +12 -20
  17. package/lib/components/data-view/data-view.component.d.ts +10 -8
  18. package/lib/components/diagram/diagram.component.d.ts +0 -2
  19. package/lib/components/filter-view/filter-view.component.d.ts +3 -3
  20. package/lib/components/group-by-count-diagram/group-by-count-diagram.component.d.ts +0 -2
  21. package/lib/components/interactive-data-view/interactive-data-view.component.d.ts +10 -6
  22. package/lib/components/lifecycle/lifecycle.component.d.ts +12 -0
  23. package/lib/components/page-header/page-header.component.d.ts +1 -4
  24. package/lib/components/search-header/search-header.component.d.ts +3 -4
  25. package/lib/directives/advanced.directive.d.ts +5 -6
  26. package/lib/directives/content-container.directive.d.ts +23 -0
  27. package/lib/directives/content.directive.d.ts +21 -0
  28. package/lib/directives/if-breakpoint.directive.d.ts +3 -4
  29. package/lib/directives/if-permission.directive.d.ts +7 -9
  30. package/lib/directives/src.directive.d.ts +2 -3
  31. package/lib/directives/template.directive.d.ts +9 -0
  32. package/lib/directives/tooltipOnOverflow.directive.d.ts +2 -3
  33. package/lib/model/filter.model.d.ts +16 -4
  34. package/lib/pipes/dynamic.pipe.d.ts +2 -2
  35. package/lib/pipes/ocxtimeago.pipe.d.ts +3 -3
  36. package/lib/services/breadcrumb.service.d.ts +2 -4
  37. package/lib/services/translation-connection.service.d.ts +10 -0
  38. package/lib/utils/criteria.utils.d.ts +3 -3
  39. package/lib/utils/data-operation-strategy.d.ts +20 -0
  40. package/lib/utils/dateutils.d.ts +0 -1
  41. package/lib/utils/provide-connection-service.d.ts +6 -0
  42. package/migrations.json +26 -0
  43. package/package.json +22 -20
  44. package/testing/column-group-selection.harness.d.ts +2 -2
  45. package/testing/content-container.harness.d.ts +7 -0
  46. package/testing/content.harness.d.ts +10 -0
  47. package/testing/data-layout-selection.harness.d.ts +7 -6
  48. package/testing/index.d.ts +3 -0
  49. package/testing/interactive-data-view.harness.d.ts +5 -3
  50. package/testing/lifecycle.harness.d.ts +6 -0
  51. package/esm2022/index.mjs +0 -63
  52. package/esm2022/lib/angular-accelerator-primeng.module.mjs +0 -146
  53. package/esm2022/lib/angular-accelerator.module.mjs +0 -209
  54. package/esm2022/lib/components/column-group-selection/column-group-selection.component.mjs +0 -90
  55. package/esm2022/lib/components/custom-group-column-selector/custom-group-column-selector.component.mjs +0 -184
  56. package/esm2022/lib/components/data-layout-selection/data-layout-selection.component.mjs +0 -73
  57. package/esm2022/lib/components/data-list-grid/data-list-grid.component.mjs +0 -615
  58. package/esm2022/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.mjs +0 -107
  59. package/esm2022/lib/components/data-loading-error/data-loading-error.component.mjs +0 -28
  60. package/esm2022/lib/components/data-sort-base/data-sort-base.mjs +0 -134
  61. package/esm2022/lib/components/data-table/data-table.component.mjs +0 -840
  62. package/esm2022/lib/components/data-view/data-view.component.mjs +0 -672
  63. package/esm2022/lib/components/diagram/diagram.component.mjs +0 -183
  64. package/esm2022/lib/components/filter-view/filter-view.component.mjs +0 -263
  65. package/esm2022/lib/components/group-by-count-diagram/group-by-count-diagram.component.mjs +0 -133
  66. package/esm2022/lib/components/interactive-data-view/interactive-data-view.component.mjs +0 -724
  67. package/esm2022/lib/components/page-header/page-header.component.mjs +0 -238
  68. package/esm2022/lib/components/search-header/search-header.component.mjs +0 -199
  69. package/esm2022/lib/directives/advanced.directive.mjs +0 -36
  70. package/esm2022/lib/directives/if-breakpoint.directive.mjs +0 -47
  71. package/esm2022/lib/directives/if-permission.directive.mjs +0 -95
  72. package/esm2022/lib/directives/src.directive.mjs +0 -65
  73. package/esm2022/lib/directives/tooltipOnOverflow.directive.mjs +0 -48
  74. package/esm2022/lib/functions/at-least-one-field-filled-validator.mjs +0 -7
  75. package/esm2022/lib/functions/flatten-object.mjs +0 -20
  76. package/esm2022/lib/injection-tokens/has-permission-checker.mjs +0 -10
  77. package/esm2022/lib/model/breadcrumb-menu-item.model.mjs +0 -2
  78. package/esm2022/lib/model/column-type.model.mjs +0 -16
  79. package/esm2022/lib/model/data-action.mjs +0 -2
  80. package/esm2022/lib/model/data-column-name-id.model.mjs +0 -2
  81. package/esm2022/lib/model/data-sort-direction.mjs +0 -2
  82. package/esm2022/lib/model/data-table-column.model.mjs +0 -2
  83. package/esm2022/lib/model/diagram-column.mjs +0 -2
  84. package/esm2022/lib/model/diagram-data.mjs +0 -2
  85. package/esm2022/lib/model/diagram-type.mjs +0 -2
  86. package/esm2022/lib/model/filter.model.mjs +0 -6
  87. package/esm2022/lib/pipes/dynamic.pipe.mjs +0 -58
  88. package/esm2022/lib/pipes/ocxtimeago.pipe.mjs +0 -107
  89. package/esm2022/lib/services/breadcrumb.service.mjs +0 -128
  90. package/esm2022/lib/services/translation-cache.service.mjs +0 -44
  91. package/esm2022/lib/utils/async-translate-loader.utils.mjs +0 -15
  92. package/esm2022/lib/utils/caching-translate-loader.utils.mjs +0 -18
  93. package/esm2022/lib/utils/colorutils.mjs +0 -19
  94. package/esm2022/lib/utils/create-remote-component-and-mfe-translate-loader.utils.mjs +0 -12
  95. package/esm2022/lib/utils/create-remote-component-translate-loader.utils.mjs +0 -25
  96. package/esm2022/lib/utils/create-translate-loader.utils.mjs +0 -30
  97. package/esm2022/lib/utils/criteria.utils.mjs +0 -28
  98. package/esm2022/lib/utils/dateutils.mjs +0 -38
  99. package/esm2022/lib/utils/dynamic-locale-id.mjs +0 -21
  100. package/esm2022/lib/utils/enum-to-dropdown-options.utils.mjs +0 -8
  101. package/esm2022/lib/utils/filter.utils.mjs +0 -6
  102. package/esm2022/lib/utils/objectutils.mjs +0 -30
  103. package/esm2022/lib/utils/primeicon.utils.mjs +0 -2
  104. package/esm2022/lib/utils/rxjs-utils.mjs +0 -13
  105. package/esm2022/lib/utils/string-and-array-helper-functions.utils.mjs +0 -22
  106. package/esm2022/lib/utils/template.utils.mjs +0 -11
  107. package/esm2022/lib/utils/translate.combined.loader.mjs +0 -42
  108. package/esm2022/onecx-angular-accelerator.mjs +0 -5
  109. package/esm2022/testing/column-group-selection.harness.mjs +0 -10
  110. package/esm2022/testing/custom-group-column-selector.harness.mjs +0 -31
  111. package/esm2022/testing/data-layout-selection.harness.mjs +0 -32
  112. package/esm2022/testing/data-list-grid.harness.mjs +0 -51
  113. package/esm2022/testing/data-table.harness.mjs +0 -69
  114. package/esm2022/testing/data-view.harness.mjs +0 -12
  115. package/esm2022/testing/default-grid-item.harness.mjs +0 -24
  116. package/esm2022/testing/default-list-item.harness.mjs +0 -26
  117. package/esm2022/testing/diagram.harness.mjs +0 -22
  118. package/esm2022/testing/filter-view.harness.mjs +0 -18
  119. package/esm2022/testing/group-by-count-diagram.harness.mjs +0 -10
  120. package/esm2022/testing/index.mjs +0 -23
  121. package/esm2022/testing/interactive-data-view.harness.mjs +0 -21
  122. package/esm2022/testing/more-actions-menu-button.harness.mjs +0 -35
  123. package/esm2022/testing/onecx-angular-accelerator-testing.mjs +0 -5
  124. package/esm2022/testing/page-header.harness.mjs +0 -81
  125. package/esm2022/testing/search-header.harness.mjs +0 -36
  126. package/esm2022/testing/slot.harness.mjs +0 -5
@@ -1,107 +0,0 @@
1
- import { Component, EventEmitter, Input, Output } from '@angular/core';
2
- import { BehaviorSubject } from 'rxjs';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "primeng/tooltip";
5
- import * as i2 from "primeng/api";
6
- import * as i3 from "primeng/dropdown";
7
- import * as i4 from "primeng/button";
8
- import * as i5 from "@angular/forms";
9
- import * as i6 from "@ngx-translate/core";
10
- export class DataListGridSortingComponent {
11
- constructor() {
12
- this.columns = [];
13
- this.sortStates = ["ASCENDING" /* DataSortDirection.ASCENDING */, "DESCENDING" /* DataSortDirection.DESCENDING */];
14
- this._sortDirection$ = new BehaviorSubject("NONE" /* DataSortDirection.NONE */);
15
- this._sortField$ = new BehaviorSubject('');
16
- this.sortChange = new EventEmitter();
17
- this.sortDirectionChange = new EventEmitter();
18
- this.componentStateChanged = new EventEmitter();
19
- this.columnsChange = new EventEmitter();
20
- this.dropdownOptions = [];
21
- }
22
- get sortDirection() {
23
- return this._sortDirection$.getValue();
24
- }
25
- set sortDirection(value) {
26
- this._sortDirection$.next(value);
27
- }
28
- get sortField() {
29
- return this?._sortField$.getValue();
30
- }
31
- set sortField(value) {
32
- this._sortField$.next(value);
33
- }
34
- ngOnInit() {
35
- this.columns.forEach((element) => this.dropdownOptions.push({ columnId: element.id, columnName: element.nameKey }));
36
- this.selectedSortingOption = this.dropdownOptions.find((e) => e.columnId === this?.sortField);
37
- this.emitComponentStateChange();
38
- }
39
- selectSorting(event) {
40
- this._sortField$.next(event.value.columnId);
41
- this.sortChange.emit(event.value.columnId);
42
- this.emitComponentStateChange();
43
- }
44
- sortDirectionChanged() {
45
- const newSortDirection = this.nextSortDirection();
46
- this._sortDirection$.next(newSortDirection);
47
- this.sortDirectionChange.emit(newSortDirection);
48
- this.emitComponentStateChange();
49
- }
50
- nextSortDirection() {
51
- return this.sortStates[(this.sortStates.indexOf(this.sortDirection) + 1) % this.sortStates.length];
52
- }
53
- emitComponentStateChange() {
54
- this.componentStateChanged.emit({
55
- sorting: {
56
- sortColumn: this.sortField,
57
- sortDirection: this.sortDirection,
58
- },
59
- });
60
- }
61
- sortIcon() {
62
- switch (this.sortDirection) {
63
- case "ASCENDING" /* DataSortDirection.ASCENDING */:
64
- return 'pi-sort-amount-up';
65
- case "DESCENDING" /* DataSortDirection.DESCENDING */:
66
- return 'pi-sort-amount-down';
67
- default:
68
- return 'pi-sort-alt';
69
- }
70
- }
71
- sortIconTitle() {
72
- return this.sortDirectionToTitle(this.sortDirection);
73
- }
74
- sortDirectionToTitle(sortDirection) {
75
- switch (sortDirection) {
76
- case "ASCENDING" /* DataSortDirection.ASCENDING */:
77
- return 'OCX_LIST_GRID_SORT.TOGGLE_BUTTON.ASCENDING_TOOLTIP';
78
- case "DESCENDING" /* DataSortDirection.DESCENDING */:
79
- return 'OCX_LIST_GRID_SORT.TOGGLE_BUTTON.DESCENDING_TOOLTIP';
80
- default:
81
- return 'OCX_LIST_GRID_SORT.TOGGLE_BUTTON.DEFAULT_TOOLTIP';
82
- }
83
- }
84
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataListGridSortingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
85
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", 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 [ariaLabel]=\"('OCX_LIST_GRID_SORT.DROPDOWN.ARIA_LABEL' | 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 type=\"button\"\n icon=\"pi {{sortIcon()}}\"\n styleClass=\"p-button-outlined\"\n (onClick)=\"sortDirectionChanged()\"\n [pTooltip]=\"(sortIconTitle() | translate)\"\n tooltipPosition=\"top\"\n [ariaLabel]=\"('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.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i3.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", "autoShowPanelOnPrintableCharacterKeyDown", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "component", type: i4.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }] }); }
86
- }
87
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataListGridSortingComponent, decorators: [{
88
- type: Component,
89
- args: [{ selector: 'ocx-data-list-grid-sorting', 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 [ariaLabel]=\"('OCX_LIST_GRID_SORT.DROPDOWN.ARIA_LABEL' | 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 type=\"button\"\n icon=\"pi {{sortIcon()}}\"\n styleClass=\"p-button-outlined\"\n (onClick)=\"sortDirectionChanged()\"\n [pTooltip]=\"(sortIconTitle() | translate)\"\n tooltipPosition=\"top\"\n [ariaLabel]=\"('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"] }]
90
- }], propDecorators: { columns: [{
91
- type: Input
92
- }], sortStates: [{
93
- type: Input
94
- }], sortDirection: [{
95
- type: Input
96
- }], sortField: [{
97
- type: Input
98
- }], sortChange: [{
99
- type: Output
100
- }], sortDirectionChange: [{
101
- type: Output
102
- }], componentStateChanged: [{
103
- type: Output
104
- }], columnsChange: [{
105
- type: Output
106
- }] } });
107
- //# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAA;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAA;;;;;;;;AAgBtC,MAAM,OAAO,4BAA4B;IALzC;QAMW,YAAO,GAAsB,EAAE,CAAA;QAC/B,eAAU,GAAwB,gGAA2D,CAAA;QACtG,oBAAe,GAAG,IAAI,eAAe,qCAA2C,CAAA;QAQhF,gBAAW,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAA;QASnC,eAAU,GAAyB,IAAI,YAAY,EAAE,CAAA;QACrD,wBAAmB,GAAoC,IAAI,YAAY,EAAE,CAAA;QACzE,0BAAqB,GAAoD,IAAI,YAAY,EAAE,CAAA;QAC3F,kBAAa,GAA2B,IAAI,YAAY,EAAE,CAAA;QAEpE,oBAAe,GAAuB,EAAE,CAAA;KA0DzC;IA/EC,IACI,aAAa;QACf,OAAO,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAA;IACxC,CAAC;IACD,IAAI,aAAa,CAAC,KAAwB;QACxC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAClC,CAAC;IAED,IACI,SAAS;QACX,OAAO,IAAI,EAAE,WAAW,CAAC,QAAQ,EAAE,CAAA;IACrC,CAAC;IACD,IAAI,SAAS,CAAC,KAAa;QACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAC9B,CAAC;IASD,QAAQ;QACN,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,OAAO,CAAC,EAAE,EAAE,UAAU,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,CAAA;QACnH,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,IAAI,EAAE,SAAS,CAAC,CAAA;QAC7F,IAAI,CAAC,wBAAwB,EAAE,CAAA;IACjC,CAAC;IAED,aAAa,CAAC,KAA0B;QACtC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QAC3C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QAC1C,IAAI,CAAC,wBAAwB,EAAE,CAAA;IACjC,CAAC;IACD,oBAAoB;QAClB,MAAM,gBAAgB,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAA;QACjD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;QAC3C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;QAC/C,IAAI,CAAC,wBAAwB,EAAE,CAAA;IACjC,CAAC;IAED,iBAAiB;QACf,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;IACpG,CAAC;IAED,wBAAwB;QACtB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;YAC9B,OAAO,EAAE;gBACP,UAAU,EAAE,IAAI,CAAC,SAAS;gBAC1B,aAAa,EAAE,IAAI,CAAC,aAAa;aAClC;SACF,CAAC,CAAA;IACJ,CAAC;IAED,QAAQ;QACN,QAAQ,IAAI,CAAC,aAAa,EAAE,CAAC;YAC3B;gBACE,OAAO,mBAAmB,CAAA;YAC5B;gBACE,OAAO,qBAAqB,CAAA;YAC9B;gBACE,OAAO,aAAa,CAAA;QACxB,CAAC;IACH,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA;IACtD,CAAC;IAED,oBAAoB,CAAC,aAAgC;QACnD,QAAQ,aAAa,EAAE,CAAC;YACtB;gBACE,OAAO,oDAAoD,CAAA;YAC7D;gBACE,OAAO,qDAAqD,CAAA;YAC9D;gBACE,OAAO,kDAAkD,CAAA;QAC7D,CAAC;IACH,CAAC;+GAlFU,4BAA4B;mGAA5B,4BAA4B,uVCjBzC,0mCA0BA;;4FDTa,4BAA4B;kBALxC,SAAS;+BACE,4BAA4B;8BAK7B,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAGF,aAAa;sBADhB,KAAK;gBASF,SAAS;sBADZ,KAAK;gBAQI,UAAU;sBAAnB,MAAM;gBACG,mBAAmB;sBAA5B,MAAM;gBACG,qBAAqB;sBAA9B,MAAM;gBACG,aAAa;sBAAtB,MAAM","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_TOOLTIP'\n      case DataSortDirection.DESCENDING:\n        return 'OCX_LIST_GRID_SORT.TOGGLE_BUTTON.DESCENDING_TOOLTIP'\n      default:\n        return 'OCX_LIST_GRID_SORT.TOGGLE_BUTTON.DEFAULT_TOOLTIP'\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    [ariaLabel]=\"('OCX_LIST_GRID_SORT.DROPDOWN.ARIA_LABEL' | 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    type=\"button\"\n    icon=\"pi {{sortIcon()}}\"\n    styleClass=\"p-button-outlined\"\n    (onClick)=\"sortDirectionChanged()\"\n    [pTooltip]=\"(sortIconTitle() | translate)\"\n    tooltipPosition=\"top\"\n    [ariaLabel]=\"('OCX_LIST_GRID_SORT.SORTING_BUTTON_ARIA_LABEL' | translate:{direction: (sortDirectionToTitle(nextSortDirection())) | translate})\"\n  ></p-button>\n</div>\n"]}
@@ -1,28 +0,0 @@
1
- import { Component } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@ngx-translate/core";
4
- /**
5
- * Show this data not found page component if the main entity of a page could not be loaded.
6
- */
7
- export class DataLoadingErrorComponent {
8
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataLoadingErrorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
9
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DataLoadingErrorComponent, selector: "ocx-data-loading-error", ngImport: i0, template: `<div class="p-4">
10
- <h1>{{ 'OCX_DATA_LOADING_ERROR.TITLE' | translate }}</h1>
11
- <div style="white-space: pre-line">
12
- {{ 'OCX_DATA_LOADING_ERROR.MESSAGE' | translate }}
13
- </div>
14
- </div> `, isInline: true, dependencies: [{ kind: "pipe", type: i1.TranslatePipe, name: "translate" }] }); }
15
- }
16
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataLoadingErrorComponent, decorators: [{
17
- type: Component,
18
- args: [{
19
- selector: 'ocx-data-loading-error',
20
- template: `<div class="p-4">
21
- <h1>{{ 'OCX_DATA_LOADING_ERROR.TITLE' | translate }}</h1>
22
- <div style="white-space: pre-line">
23
- {{ 'OCX_DATA_LOADING_ERROR.MESSAGE' | translate }}
24
- </div>
25
- </div> `,
26
- }]
27
- }] });
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1sb2FkaW5nLWVycm9yLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci1hY2NlbGVyYXRvci9zcmMvbGliL2NvbXBvbmVudHMvZGF0YS1sb2FkaW5nLWVycm9yL2RhdGEtbG9hZGluZy1lcnJvci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQTs7O0FBRXpDOztHQUVHO0FBVUgsTUFBTSxPQUFPLHlCQUF5QjsrR0FBekIseUJBQXlCO21HQUF6Qix5QkFBeUIsOERBUDFCOzs7OztVQUtGOzs0RkFFRyx5QkFBeUI7a0JBVHJDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHdCQUF3QjtvQkFDbEMsUUFBUSxFQUFFOzs7OztVQUtGO2lCQUNUIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcblxuLyoqXG4gKiBTaG93IHRoaXMgZGF0YSBub3QgZm91bmQgcGFnZSBjb21wb25lbnQgaWYgdGhlIG1haW4gZW50aXR5IG9mIGEgcGFnZSBjb3VsZCBub3QgYmUgbG9hZGVkLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdvY3gtZGF0YS1sb2FkaW5nLWVycm9yJyxcbiAgdGVtcGxhdGU6IGA8ZGl2IGNsYXNzPVwicC00XCI+XG4gICAgPGgxPnt7ICdPQ1hfREFUQV9MT0FESU5HX0VSUk9SLlRJVExFJyB8IHRyYW5zbGF0ZSB9fTwvaDE+XG4gICAgPGRpdiBzdHlsZT1cIndoaXRlLXNwYWNlOiBwcmUtbGluZVwiPlxuICAgICAge3sgJ09DWF9EQVRBX0xPQURJTkdfRVJST1IuTUVTU0FHRScgfCB0cmFuc2xhdGUgfX1cbiAgICA8L2Rpdj5cbiAgPC9kaXY+IGAsXG59KVxuZXhwb3J0IGNsYXNzIERhdGFMb2FkaW5nRXJyb3JDb21wb25lbnQge31cbiJdfQ==
@@ -1,134 +0,0 @@
1
- import { map, of } from 'rxjs';
2
- import { flattenObject } from '../../functions/flatten-object';
3
- import { ColumnType } from '../../model/column-type.model';
4
- import { ObjectUtils } from '../../utils/objectutils';
5
- import { FilterType } from '../../model/filter.model';
6
- export class DataSortBase {
7
- constructor(locale, translateService) {
8
- this.locale = locale;
9
- this.translateService = translateService;
10
- }
11
- translateItems([items, filters, sortColumn, sortDirection], columns, clientSideFiltering, clientSideSorting) {
12
- if (clientSideFiltering || clientSideSorting) {
13
- let translationKeys = [];
14
- const translatedColumns = columns.filter((c) => c.columnType === ColumnType.TRANSLATION_KEY);
15
- translatedColumns.forEach((c) => {
16
- translationKeys = [
17
- ...translationKeys,
18
- ...items.map((i) => ObjectUtils.resolveFieldData(i, c.id)?.toString()).filter((v) => !!v),
19
- ];
20
- });
21
- if (translationKeys.length) {
22
- return this.translateService.get(translationKeys).pipe(map((translatedValues) => {
23
- const translations = {};
24
- translatedColumns.forEach((c) => {
25
- translations[c.id] = Object.fromEntries(items.map((i) => [
26
- ObjectUtils.resolveFieldData(i, c.id)?.toString() || '',
27
- translatedValues[ObjectUtils.resolveFieldData(i, c.id)?.toString()],
28
- ]));
29
- });
30
- return [items, filters, sortColumn, sortDirection, translations];
31
- }));
32
- }
33
- }
34
- return of([items, filters, sortColumn, sortDirection, {}]);
35
- }
36
- filterItems([items, filters, sortColumn, sortDirection, translations], clientSideFiltering) {
37
- if (!clientSideFiltering) {
38
- return [items, filters, sortColumn, sortDirection, translations];
39
- }
40
- return [
41
- items.filter((item) => filters
42
- .map((filter) => filter.columnId)
43
- .filter((value, index, self) => self.indexOf(value) === index && value != null)
44
- .every((filterColumnId) => filters
45
- .filter((filter) => filter.columnId === filterColumnId)
46
- .some((filter) => {
47
- const value = (translations[filter.columnId]?.[ObjectUtils.resolveFieldData(item, filter.columnId)?.toString()] ||
48
- ObjectUtils.resolveFieldData(item, filter.columnId))?.toString();
49
- switch (filter.filterType) {
50
- case undefined:
51
- case FilterType.EQUAL:
52
- return value === String(filter.value);
53
- case FilterType.TRUTHY: {
54
- return filter.value ? !!value : !value;
55
- }
56
- }
57
- }))),
58
- filters,
59
- sortColumn,
60
- sortDirection,
61
- translations,
62
- ];
63
- }
64
- sortItems([items, filters, sortColumn, sortDirection, translations], columns, clientSideSorting) {
65
- if (!clientSideSorting || sortColumn === '') {
66
- return [items, filters, sortColumn, sortDirection, translations];
67
- }
68
- const column = columns.find((h) => h.id === sortColumn);
69
- let colValues;
70
- if (column?.columnType === ColumnType.DATE || column?.columnType === ColumnType.RELATIVE_DATE) {
71
- colValues = Object.fromEntries(items.map((i) => [
72
- ObjectUtils.resolveFieldData(i, sortColumn),
73
- ObjectUtils.resolveFieldData(i, sortColumn),
74
- ]));
75
- }
76
- else {
77
- colValues = Object.fromEntries(items.map((i) => [
78
- ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),
79
- ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),
80
- ]));
81
- }
82
- if (column?.columnType === ColumnType.TRANSLATION_KEY) {
83
- colValues = translations[sortColumn];
84
- }
85
- return [
86
- [...items].sort(this.createCompareFunction(colValues, sortColumn, sortDirection)),
87
- filters,
88
- sortColumn,
89
- sortDirection,
90
- translations,
91
- ];
92
- }
93
- flattenItems(items) {
94
- return items.map((i) => flattenObject(i));
95
- }
96
- createCompareFunction(translatedColValues, sortColumn, sortDirection) {
97
- let direction = 0;
98
- if (sortDirection === "ASCENDING" /* DataSortDirection.ASCENDING */) {
99
- direction = 1;
100
- }
101
- else if (sortDirection === "DESCENDING" /* DataSortDirection.DESCENDING */) {
102
- direction = -1;
103
- }
104
- return (data1, data2) => {
105
- if (direction === 0) {
106
- return 0;
107
- }
108
- let result;
109
- const value1 = translatedColValues[ObjectUtils.resolveFieldData(data1, sortColumn)];
110
- const value2 = translatedColValues[ObjectUtils.resolveFieldData(data2, sortColumn)];
111
- if (value1 == null && value2 != null)
112
- result = -1;
113
- else if (value1 != null && value2 == null)
114
- result = 1;
115
- else if (value1 == null && value2 == null)
116
- result = 0;
117
- else if (typeof value1 === 'string' && typeof value2 === 'string')
118
- result = value1.localeCompare(value2, [this.locale, 'en', 'de'], { numeric: true });
119
- else {
120
- if (value1 < value2) {
121
- result = -1;
122
- }
123
- else if (value1 > value2) {
124
- result = 1;
125
- }
126
- else {
127
- result = 0;
128
- }
129
- }
130
- return direction * result;
131
- };
132
- }
133
- }
134
- //# 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    const column = columns.find((h) => h.id === sortColumn)\n    let colValues: Record<string, string>\n    if (column?.columnType === ColumnType.DATE || column?.columnType === ColumnType.RELATIVE_DATE) {\n      colValues = Object.fromEntries(\n        items.map((i) => [\n          ObjectUtils.resolveFieldData(i, sortColumn) as Date,\n          ObjectUtils.resolveFieldData(i, sortColumn) as Date,\n        ])\n      )\n    } else {\n      colValues = Object.fromEntries(\n        items.map((i) => [\n          ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),\n          ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),\n        ])\n      )\n    }\n    if (column?.columnType === ColumnType.TRANSLATION_KEY) {\n      colValues = translations[sortColumn]\n    }\n    return [\n      [...items].sort(this.createCompareFunction(colValues, 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"]}