@onecx/angular-accelerator 4.11.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/README.md +7 -0
- package/assets/i18n/de.json +130 -0
- package/assets/i18n/en.json +130 -0
- package/assets/images/placeholder.png +0 -0
- package/assets/styles.scss +8 -0
- package/esm2020/index.mjs +49 -0
- package/esm2020/lib/angular-accelerator-primeng.module.mjs +83 -0
- package/esm2020/lib/angular-accelerator.module.mjs +209 -0
- package/esm2020/lib/components/column-group-selection/column-group-selection.component.mjs +72 -0
- package/esm2020/lib/components/custom-group-column-selector/custom-group-column-selector.component.mjs +108 -0
- package/esm2020/lib/components/data-layout-selection/data-layout-selection.component.mjs +45 -0
- package/esm2020/lib/components/data-list-grid/data-list-grid.component.mjs +358 -0
- package/esm2020/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.mjs +92 -0
- package/esm2020/lib/components/data-sort-base/data-sort-base.mjs +110 -0
- package/esm2020/lib/components/data-table/data-table.component.mjs +350 -0
- package/esm2020/lib/components/data-view/data-view.component.mjs +355 -0
- package/esm2020/lib/components/diagram/diagram.component.mjs +136 -0
- package/esm2020/lib/components/group-by-count-diagram/group-by-count-diagram.component.mjs +109 -0
- package/esm2020/lib/components/interactive-data-view/interactive-data-view.component.mjs +342 -0
- package/esm2020/lib/components/page-header/page-header.component.mjs +189 -0
- package/esm2020/lib/components/search-config/search-config.component.mjs +34 -0
- package/esm2020/lib/components/search-header/search-header.component.mjs +136 -0
- package/esm2020/lib/directives/if-breakpoint.directive.mjs +39 -0
- package/esm2020/lib/directives/if-permission.directive.mjs +53 -0
- package/esm2020/lib/functions/flatten-object.mjs +20 -0
- package/esm2020/lib/model/breadcrumb-menu-item.model.mjs +2 -0
- package/esm2020/lib/model/column-type.model.mjs +9 -0
- package/esm2020/lib/model/data-action.mjs +2 -0
- package/esm2020/lib/model/data-column-name-id.model.mjs +2 -0
- package/esm2020/lib/model/data-sort-direction.mjs +2 -0
- package/esm2020/lib/model/data-table-column.model.mjs +2 -0
- package/esm2020/lib/model/diagram-column.mjs +2 -0
- package/esm2020/lib/model/diagram-data.mjs +2 -0
- package/esm2020/lib/model/diagram-type.mjs +2 -0
- package/esm2020/lib/model/search-config-info.mjs +2 -0
- package/esm2020/lib/pipes/dynamic.pipe.mjs +58 -0
- package/esm2020/lib/pipes/ocxtimeago.pipe.mjs +15 -0
- package/esm2020/lib/services/breadcrumb.service.mjs +79 -0
- package/esm2020/lib/services/translation-cache.service.mjs +54 -0
- package/esm2020/lib/utils/async-translate-loader.utils.mjs +12 -0
- package/esm2020/lib/utils/caching-translate-loader.utils.mjs +15 -0
- package/esm2020/lib/utils/colorutils.mjs +19 -0
- package/esm2020/lib/utils/create-translate-loader.utils.mjs +23 -0
- package/esm2020/lib/utils/dateutils.mjs +32 -0
- package/esm2020/lib/utils/objectutils.mjs +30 -0
- package/esm2020/lib/utils/ocxtimeagointl.utils.mjs +34 -0
- package/esm2020/lib/utils/primeicon.utils.mjs +2 -0
- package/esm2020/lib/utils/translate.combined.loader.mjs +36 -0
- package/esm2020/onecx-angular-accelerator.mjs +5 -0
- package/esm2020/testing/column-group-selection.harness.mjs +10 -0
- package/esm2020/testing/custom-group-column-selector.harness.mjs +31 -0
- package/esm2020/testing/data-layout-selection.harness.mjs +33 -0
- package/esm2020/testing/data-list-grid.harness.mjs +47 -0
- package/esm2020/testing/data-table.harness.mjs +57 -0
- package/esm2020/testing/data-view.harness.mjs +12 -0
- package/esm2020/testing/default-grid-item.harness.mjs +24 -0
- package/esm2020/testing/default-list-item.harness.mjs +24 -0
- package/esm2020/testing/diagram.harness.mjs +22 -0
- package/esm2020/testing/index.mjs +17 -0
- package/esm2020/testing/interactive-data-view.harness.mjs +19 -0
- package/esm2020/testing/more-actions-menu-button.harness.mjs +35 -0
- package/esm2020/testing/onecx-angular-accelerator-testing.mjs +5 -0
- package/esm2020/testing/page-header.harness.mjs +36 -0
- package/esm2020/testing/search-config.harness.mjs +10 -0
- package/fesm2015/onecx-angular-accelerator-testing.mjs +430 -0
- package/fesm2015/onecx-angular-accelerator-testing.mjs.map +1 -0
- package/fesm2015/onecx-angular-accelerator.mjs +3118 -0
- package/fesm2015/onecx-angular-accelerator.mjs.map +1 -0
- package/fesm2020/onecx-angular-accelerator-testing.mjs +338 -0
- package/fesm2020/onecx-angular-accelerator-testing.mjs.map +1 -0
- package/fesm2020/onecx-angular-accelerator.mjs +3085 -0
- package/fesm2020/onecx-angular-accelerator.mjs.map +1 -0
- package/index.d.ts +38 -0
- package/lib/angular-accelerator-primeng.module.d.ts +16 -0
- package/lib/angular-accelerator.module.d.ts +32 -0
- package/lib/components/column-group-selection/column-group-selection.component.d.ts +28 -0
- package/lib/components/custom-group-column-selector/custom-group-column-selector.component.d.ts +45 -0
- package/lib/components/data-layout-selection/data-layout-selection.component.d.ts +25 -0
- package/lib/components/data-list-grid/data-list-grid.component.d.ts +120 -0
- package/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.d.ts +30 -0
- package/lib/components/data-sort-base/data-sort-base.d.ts +32 -0
- package/lib/components/data-table/data-table.component.d.ts +124 -0
- package/lib/components/data-view/data-view.component.d.ts +112 -0
- package/lib/components/diagram/diagram.component.d.ts +43 -0
- package/lib/components/group-by-count-diagram/group-by-count-diagram.component.d.ts +39 -0
- package/lib/components/interactive-data-view/interactive-data-view.component.d.ts +108 -0
- package/lib/components/page-header/page-header.component.d.ts +90 -0
- package/lib/components/search-config/search-config.component.d.ts +16 -0
- package/lib/components/search-header/search-header.component.d.ts +46 -0
- package/lib/directives/if-breakpoint.directive.d.ts +12 -0
- package/lib/directives/if-permission.directive.d.ts +18 -0
- package/lib/functions/flatten-object.d.ts +14 -0
- package/lib/model/breadcrumb-menu-item.model.d.ts +60 -0
- package/lib/model/column-type.model.d.ts +7 -0
- package/lib/model/data-action.d.ts +9 -0
- package/lib/model/data-column-name-id.model.d.ts +4 -0
- package/lib/model/data-sort-direction.d.ts +5 -0
- package/lib/model/data-table-column.model.d.ts +9 -0
- package/lib/model/diagram-column.d.ts +5 -0
- package/lib/model/diagram-data.d.ts +4 -0
- package/lib/model/diagram-type.d.ts +5 -0
- package/lib/model/search-config-info.d.ts +4 -0
- package/lib/pipes/dynamic.pipe.d.ts +13 -0
- package/lib/pipes/ocxtimeago.pipe.d.ts +6 -0
- package/lib/services/breadcrumb.service.d.ts +20 -0
- package/lib/services/translation-cache.service.d.ts +12 -0
- package/lib/utils/async-translate-loader.utils.d.ts +9 -0
- package/lib/utils/caching-translate-loader.utils.d.ts +13 -0
- package/lib/utils/colorutils.d.ts +12 -0
- package/lib/utils/create-translate-loader.utils.d.ts +5 -0
- package/lib/utils/dateutils.d.ts +9 -0
- package/lib/utils/objectutils.d.ts +4 -0
- package/lib/utils/ocxtimeagointl.utils.d.ts +9 -0
- package/lib/utils/primeicon.utils.d.ts +5 -0
- package/lib/utils/translate.combined.loader.d.ts +9 -0
- package/package.json +55 -0
- package/testing/column-group-selection.harness.d.ts +6 -0
- package/testing/custom-group-column-selector.harness.d.ts +14 -0
- package/testing/data-layout-selection.harness.d.ts +11 -0
- package/testing/data-list-grid.harness.d.ts +15 -0
- package/testing/data-table.harness.d.ts +17 -0
- package/testing/data-view.harness.d.ts +8 -0
- package/testing/default-grid-item.harness.d.ts +11 -0
- package/testing/default-list-item.harness.d.ts +12 -0
- package/testing/diagram.harness.d.ts +10 -0
- package/testing/index.d.ts +16 -0
- package/testing/interactive-data-view.harness.d.ts +15 -0
- package/testing/more-actions-menu-button.harness.d.ts +10 -0
- package/testing/page-header.harness.d.ts +13 -0
- package/testing/search-config.harness.d.ts +6 -0
|
@@ -0,0 +1,110 @@
|
|
|
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
|
+
export class DataSortBase {
|
|
6
|
+
constructor(locale, translateService) {
|
|
7
|
+
this.locale = locale;
|
|
8
|
+
this.translateService = translateService;
|
|
9
|
+
}
|
|
10
|
+
translateItems([items, filters, sortColumn, sortDirection], columns, clientSideFiltering, clientSideSorting) {
|
|
11
|
+
if (clientSideFiltering || clientSideSorting) {
|
|
12
|
+
let translationKeys = [];
|
|
13
|
+
const translatedColumns = columns.filter((c) => c.columnType === ColumnType.TRANSLATION_KEY);
|
|
14
|
+
translatedColumns.forEach((c) => {
|
|
15
|
+
translationKeys = [...translationKeys, ...items.map((i) => ObjectUtils.resolveFieldData(i, c.id)?.toString())];
|
|
16
|
+
});
|
|
17
|
+
if (translationKeys.length) {
|
|
18
|
+
return this.translateService.get(translationKeys).pipe(map((translatedValues) => {
|
|
19
|
+
const translations = {};
|
|
20
|
+
translatedColumns.forEach((c) => {
|
|
21
|
+
translations[c.id] = Object.fromEntries(items.map((i) => [
|
|
22
|
+
ObjectUtils.resolveFieldData(i, c.id)?.toString() || '',
|
|
23
|
+
translatedValues[ObjectUtils.resolveFieldData(i, c.id)?.toString()],
|
|
24
|
+
]));
|
|
25
|
+
});
|
|
26
|
+
return [items, filters, sortColumn, sortDirection, translations];
|
|
27
|
+
}));
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
return of([items, filters, sortColumn, sortDirection, {}]);
|
|
31
|
+
}
|
|
32
|
+
filterItems([items, filters, sortColumn, sortDirection, translations], clientSideFiltering) {
|
|
33
|
+
if (!clientSideFiltering) {
|
|
34
|
+
return [items, filters, sortColumn, sortDirection, translations];
|
|
35
|
+
}
|
|
36
|
+
return [
|
|
37
|
+
items.filter((item) => filters
|
|
38
|
+
.map((filter) => filter.columnId)
|
|
39
|
+
.filter((value, index, self) => self.indexOf(value) === index && value != null)
|
|
40
|
+
.every((filterColumnId) => filters
|
|
41
|
+
.filter((filter) => filter.columnId === filterColumnId)
|
|
42
|
+
.some((filter) => (translations[filter.columnId]?.[ObjectUtils.resolveFieldData(item, filter.columnId).toString()] ||
|
|
43
|
+
ObjectUtils.resolveFieldData(item, filter.columnId)).toString() === filter.value.toString()))),
|
|
44
|
+
filters,
|
|
45
|
+
sortColumn,
|
|
46
|
+
sortDirection,
|
|
47
|
+
translations,
|
|
48
|
+
];
|
|
49
|
+
}
|
|
50
|
+
sortItems([items, filters, sortColumn, sortDirection, translations], columns, clientSideSorting) {
|
|
51
|
+
if (!clientSideSorting || sortColumn === '') {
|
|
52
|
+
return [items, filters, sortColumn, sortDirection, translations];
|
|
53
|
+
}
|
|
54
|
+
let translatedColValues = Object.fromEntries(items.map((i) => [
|
|
55
|
+
ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),
|
|
56
|
+
ObjectUtils.resolveFieldData(i, sortColumn)?.toString(),
|
|
57
|
+
]));
|
|
58
|
+
if (columns.find((h) => h.id === sortColumn)?.columnType === ColumnType.TRANSLATION_KEY) {
|
|
59
|
+
translatedColValues = translations[sortColumn];
|
|
60
|
+
}
|
|
61
|
+
return [
|
|
62
|
+
[...items].sort(this.createCompareFunction(translatedColValues, sortColumn, sortDirection)),
|
|
63
|
+
filters,
|
|
64
|
+
sortColumn,
|
|
65
|
+
sortDirection,
|
|
66
|
+
translations,
|
|
67
|
+
];
|
|
68
|
+
}
|
|
69
|
+
flattenItems(items) {
|
|
70
|
+
return items.map((i) => flattenObject(i));
|
|
71
|
+
}
|
|
72
|
+
createCompareFunction(translatedColValues, sortColumn, sortDirection) {
|
|
73
|
+
let direction = 0;
|
|
74
|
+
if (sortDirection === "ASCENDING" /* DataSortDirection.ASCENDING */) {
|
|
75
|
+
direction = 1;
|
|
76
|
+
}
|
|
77
|
+
else if (sortDirection === "DESCENDING" /* DataSortDirection.DESCENDING */) {
|
|
78
|
+
direction = -1;
|
|
79
|
+
}
|
|
80
|
+
return (data1, data2) => {
|
|
81
|
+
if (direction === 0) {
|
|
82
|
+
return 0;
|
|
83
|
+
}
|
|
84
|
+
let result;
|
|
85
|
+
const value1 = translatedColValues[ObjectUtils.resolveFieldData(data1, sortColumn)];
|
|
86
|
+
const value2 = translatedColValues[ObjectUtils.resolveFieldData(data2, sortColumn)];
|
|
87
|
+
if (value1 == null && value2 != null)
|
|
88
|
+
result = -1;
|
|
89
|
+
else if (value1 != null && value2 == null)
|
|
90
|
+
result = 1;
|
|
91
|
+
else if (value1 == null && value2 == null)
|
|
92
|
+
result = 0;
|
|
93
|
+
else if (typeof value1 === 'string' && typeof value2 === 'string')
|
|
94
|
+
result = value1.localeCompare(value2, [this.locale, 'en', 'de'], { numeric: true });
|
|
95
|
+
else {
|
|
96
|
+
if (value1 < value2) {
|
|
97
|
+
result = -1;
|
|
98
|
+
}
|
|
99
|
+
else if (value1 > value2) {
|
|
100
|
+
result = 1;
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
result = 0;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
return direction * result;
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
//# 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, Filter } from '../../components/data-table/data-table.component'\nimport { ObjectUtils } from '../../utils/objectutils'\n\ntype RowListGridData = ListGridData | Row\n\nexport class DataSortBase {\n  constructor(protected locale: string, protected translateService: TranslateService) {}\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 = [...translationKeys, ...items.map((i) => ObjectUtils.resolveFieldData(i, c.id)?.toString())]\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(\n                (filter) =>\n                  (\n                    translations[filter.columnId]?.[ObjectUtils.resolveFieldData(item, filter.columnId).toString()] ||\n                    ObjectUtils.resolveFieldData(item, filter.columnId)\n                  ).toString() === filter.value.toString()\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"]}
|