@onecx/angular-accelerator 5.37.0 → 6.0.0-rc.10

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 (128) hide show
  1. package/assets/i18n/de.json +3 -3
  2. package/assets/i18n/en.json +3 -3
  3. package/assets/i18n/primeng/de.json +1 -1
  4. package/assets/i18n/primeng/en.json +1 -1
  5. package/assets/styles.scss +0 -4
  6. package/fesm2022/onecx-angular-accelerator-testing.mjs +90 -28
  7. package/fesm2022/onecx-angular-accelerator-testing.mjs.map +1 -1
  8. package/fesm2022/onecx-angular-accelerator.mjs +777 -398
  9. package/fesm2022/onecx-angular-accelerator.mjs.map +1 -1
  10. package/index.d.ts +8 -0
  11. package/lib/angular-accelerator-primeng.module.d.ts +6 -4
  12. package/lib/angular-accelerator.module.d.ts +26 -20
  13. package/lib/components/content/content.component.d.ts +13 -0
  14. package/lib/components/content-container/content-container.component.d.ts +19 -0
  15. package/lib/components/custom-group-column-selector/custom-group-column-selector.component.d.ts +0 -2
  16. package/lib/components/data-list-grid/data-list-grid.component.d.ts +9 -19
  17. package/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.d.ts +2 -2
  18. package/lib/components/data-table/data-table.component.d.ts +8 -18
  19. package/lib/components/data-view/data-view.component.d.ts +10 -8
  20. package/lib/components/diagram/diagram.component.d.ts +0 -2
  21. package/lib/components/filter-view/filter-view.component.d.ts +2 -2
  22. package/lib/components/group-by-count-diagram/group-by-count-diagram.component.d.ts +0 -2
  23. package/lib/components/interactive-data-view/interactive-data-view.component.d.ts +10 -6
  24. package/lib/components/lifecycle/lifecycle.component.d.ts +12 -0
  25. package/lib/components/page-header/page-header.component.d.ts +1 -4
  26. package/lib/components/search-header/search-header.component.d.ts +3 -4
  27. package/lib/directives/advanced.directive.d.ts +5 -6
  28. package/lib/directives/content-container.directive.d.ts +23 -0
  29. package/lib/directives/content.directive.d.ts +21 -0
  30. package/lib/directives/if-breakpoint.directive.d.ts +3 -4
  31. package/lib/directives/if-permission.directive.d.ts +6 -8
  32. package/lib/directives/src.directive.d.ts +2 -3
  33. package/lib/directives/template.directive.d.ts +9 -0
  34. package/lib/directives/tooltipOnOverflow.directive.d.ts +2 -3
  35. package/lib/model/filter.model.d.ts +16 -4
  36. package/lib/pipes/dynamic.pipe.d.ts +2 -2
  37. package/lib/pipes/ocxtimeago.pipe.d.ts +3 -3
  38. package/lib/services/breadcrumb.service.d.ts +2 -4
  39. package/lib/services/translation-connection.service.d.ts +10 -0
  40. package/lib/utils/criteria.utils.d.ts +3 -3
  41. package/lib/utils/data-operation-strategy.d.ts +20 -0
  42. package/lib/utils/dateutils.d.ts +0 -1
  43. package/lib/utils/provide-connection-service.d.ts +6 -0
  44. package/migrations.json +26 -0
  45. package/package.json +21 -20
  46. package/testing/column-group-selection.harness.d.ts +2 -2
  47. package/testing/content-container.harness.d.ts +7 -0
  48. package/testing/content.harness.d.ts +10 -0
  49. package/testing/data-layout-selection.harness.d.ts +7 -6
  50. package/testing/index.d.ts +3 -0
  51. package/testing/interactive-data-view.harness.d.ts +5 -3
  52. package/testing/lifecycle.harness.d.ts +6 -0
  53. package/esm2022/index.mjs +0 -63
  54. package/esm2022/lib/angular-accelerator-primeng.module.mjs +0 -146
  55. package/esm2022/lib/angular-accelerator.module.mjs +0 -209
  56. package/esm2022/lib/components/column-group-selection/column-group-selection.component.mjs +0 -90
  57. package/esm2022/lib/components/custom-group-column-selector/custom-group-column-selector.component.mjs +0 -184
  58. package/esm2022/lib/components/data-layout-selection/data-layout-selection.component.mjs +0 -73
  59. package/esm2022/lib/components/data-list-grid/data-list-grid.component.mjs +0 -615
  60. package/esm2022/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.mjs +0 -107
  61. package/esm2022/lib/components/data-loading-error/data-loading-error.component.mjs +0 -28
  62. package/esm2022/lib/components/data-sort-base/data-sort-base.mjs +0 -134
  63. package/esm2022/lib/components/data-table/data-table.component.mjs +0 -840
  64. package/esm2022/lib/components/data-view/data-view.component.mjs +0 -672
  65. package/esm2022/lib/components/diagram/diagram.component.mjs +0 -183
  66. package/esm2022/lib/components/filter-view/filter-view.component.mjs +0 -263
  67. package/esm2022/lib/components/group-by-count-diagram/group-by-count-diagram.component.mjs +0 -133
  68. package/esm2022/lib/components/interactive-data-view/interactive-data-view.component.mjs +0 -724
  69. package/esm2022/lib/components/page-header/page-header.component.mjs +0 -238
  70. package/esm2022/lib/components/search-header/search-header.component.mjs +0 -199
  71. package/esm2022/lib/directives/advanced.directive.mjs +0 -36
  72. package/esm2022/lib/directives/if-breakpoint.directive.mjs +0 -47
  73. package/esm2022/lib/directives/if-permission.directive.mjs +0 -95
  74. package/esm2022/lib/directives/src.directive.mjs +0 -65
  75. package/esm2022/lib/directives/tooltipOnOverflow.directive.mjs +0 -48
  76. package/esm2022/lib/functions/at-least-one-field-filled-validator.mjs +0 -7
  77. package/esm2022/lib/functions/flatten-object.mjs +0 -20
  78. package/esm2022/lib/injection-tokens/has-permission-checker.mjs +0 -10
  79. package/esm2022/lib/model/breadcrumb-menu-item.model.mjs +0 -2
  80. package/esm2022/lib/model/column-type.model.mjs +0 -16
  81. package/esm2022/lib/model/data-action.mjs +0 -2
  82. package/esm2022/lib/model/data-column-name-id.model.mjs +0 -2
  83. package/esm2022/lib/model/data-sort-direction.mjs +0 -2
  84. package/esm2022/lib/model/data-table-column.model.mjs +0 -2
  85. package/esm2022/lib/model/diagram-column.mjs +0 -2
  86. package/esm2022/lib/model/diagram-data.mjs +0 -2
  87. package/esm2022/lib/model/diagram-type.mjs +0 -2
  88. package/esm2022/lib/model/filter.model.mjs +0 -6
  89. package/esm2022/lib/pipes/dynamic.pipe.mjs +0 -58
  90. package/esm2022/lib/pipes/ocxtimeago.pipe.mjs +0 -107
  91. package/esm2022/lib/services/breadcrumb.service.mjs +0 -128
  92. package/esm2022/lib/services/translation-cache.service.mjs +0 -44
  93. package/esm2022/lib/utils/async-translate-loader.utils.mjs +0 -15
  94. package/esm2022/lib/utils/caching-translate-loader.utils.mjs +0 -18
  95. package/esm2022/lib/utils/colorutils.mjs +0 -19
  96. package/esm2022/lib/utils/create-remote-component-and-mfe-translate-loader.utils.mjs +0 -12
  97. package/esm2022/lib/utils/create-remote-component-translate-loader.utils.mjs +0 -25
  98. package/esm2022/lib/utils/create-translate-loader.utils.mjs +0 -30
  99. package/esm2022/lib/utils/criteria.utils.mjs +0 -28
  100. package/esm2022/lib/utils/dateutils.mjs +0 -38
  101. package/esm2022/lib/utils/dynamic-locale-id.mjs +0 -21
  102. package/esm2022/lib/utils/enum-to-dropdown-options.utils.mjs +0 -8
  103. package/esm2022/lib/utils/filter.utils.mjs +0 -6
  104. package/esm2022/lib/utils/objectutils.mjs +0 -30
  105. package/esm2022/lib/utils/primeicon.utils.mjs +0 -2
  106. package/esm2022/lib/utils/rxjs-utils.mjs +0 -13
  107. package/esm2022/lib/utils/string-and-array-helper-functions.utils.mjs +0 -22
  108. package/esm2022/lib/utils/template.utils.mjs +0 -11
  109. package/esm2022/lib/utils/translate.combined.loader.mjs +0 -42
  110. package/esm2022/onecx-angular-accelerator.mjs +0 -5
  111. package/esm2022/testing/column-group-selection.harness.mjs +0 -10
  112. package/esm2022/testing/custom-group-column-selector.harness.mjs +0 -31
  113. package/esm2022/testing/data-layout-selection.harness.mjs +0 -32
  114. package/esm2022/testing/data-list-grid.harness.mjs +0 -51
  115. package/esm2022/testing/data-table.harness.mjs +0 -69
  116. package/esm2022/testing/data-view.harness.mjs +0 -12
  117. package/esm2022/testing/default-grid-item.harness.mjs +0 -24
  118. package/esm2022/testing/default-list-item.harness.mjs +0 -26
  119. package/esm2022/testing/diagram.harness.mjs +0 -22
  120. package/esm2022/testing/filter-view.harness.mjs +0 -18
  121. package/esm2022/testing/group-by-count-diagram.harness.mjs +0 -10
  122. package/esm2022/testing/index.mjs +0 -23
  123. package/esm2022/testing/interactive-data-view.harness.mjs +0 -21
  124. package/esm2022/testing/more-actions-menu-button.harness.mjs +0 -35
  125. package/esm2022/testing/onecx-angular-accelerator-testing.mjs +0 -5
  126. package/esm2022/testing/page-header.harness.mjs +0 -81
  127. package/esm2022/testing/search-header.harness.mjs +0 -36
  128. package/esm2022/testing/slot.harness.mjs +0 -5
@@ -1,183 +0,0 @@
1
- import { Component, EventEmitter, Input, Output } from '@angular/core';
2
- import { TranslateService } from '@ngx-translate/core';
3
- import * as d3 from 'd3-scale-chromatic';
4
- import { PrimeIcons } from 'primeng/api';
5
- import { ColorUtils } from '../../utils/colorutils';
6
- import * as i0 from "@angular/core";
7
- import * as i1 from "@ngx-translate/core";
8
- import * as i2 from "@angular/common";
9
- import * as i3 from "primeng/tooltip";
10
- import * as i4 from "primeng/api";
11
- import * as i5 from "primeng/selectbutton";
12
- import * as i6 from "primeng/chart";
13
- import * as i7 from "primeng/message";
14
- import * as i8 from "@angular/forms";
15
- const allDiagramTypes = [
16
- {
17
- id: 'diagram-pie',
18
- icon: PrimeIcons.CHART_PIE,
19
- layout: "PIE" /* DiagramType.PIE */,
20
- tooltipKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.PIE',
21
- labelKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.PIE',
22
- },
23
- {
24
- id: 'diagram-horizontal-bar',
25
- icon: PrimeIcons.BARS,
26
- layout: "HORIZONTAL_BAR" /* DiagramType.HORIZONTAL_BAR */,
27
- tooltipKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.HORIZONTAL_BAR',
28
- labelKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.HORIZONTAL_BAR',
29
- },
30
- {
31
- id: 'diagram-vertical-bar',
32
- icon: PrimeIcons.CHART_BAR,
33
- layout: "VERTICAL_BAR" /* DiagramType.VERTICAL_BAR */,
34
- tooltipKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.VERTICAL_BAR',
35
- labelKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.VERTICAL_BAR',
36
- },
37
- ];
38
- export class DiagramComponent {
39
- get diagramType() {
40
- return this._diagramType;
41
- }
42
- set diagramType(value) {
43
- this._diagramType = value;
44
- this.selectedDiagramType = allDiagramTypes.find((v) => v.layout === value);
45
- this.chartType = this.diagramTypeToChartType(value);
46
- }
47
- get supportedDiagramTypes() {
48
- return this._supportedDiagramTypes;
49
- }
50
- set supportedDiagramTypes(value) {
51
- this._supportedDiagramTypes = value;
52
- this.shownDiagramTypes = allDiagramTypes.filter((vl) => this.supportedDiagramTypes.includes(vl.layout));
53
- }
54
- constructor(translateService) {
55
- this.translateService = translateService;
56
- this.sumKey = 'OCX_DIAGRAM.SUM';
57
- /**
58
- * This property determines if diagram should generate the colors for the data that does not have any set.
59
- *
60
- * Setting this property to false will result in using the provided colors only if every data item has one. In the scenario where at least one item does not have a color set, diagram will generate all colors.
61
- */
62
- this.fillMissingColors = true;
63
- this._diagramType = "PIE" /* DiagramType.PIE */;
64
- this.chartType = 'pie';
65
- this._supportedDiagramTypes = [];
66
- this.dataSelected = new EventEmitter();
67
- this.diagramTypeChanged = new EventEmitter();
68
- this.componentStateChanged = new EventEmitter();
69
- this.shownDiagramTypes = [];
70
- // Changing the colorRangeInfo, will change the range of the color palette of the diagram.
71
- this.colorRangeInfo = {
72
- colorStart: 0,
73
- colorEnd: 1,
74
- useEndAsStart: false,
75
- };
76
- // Changing the colorScale, will change the thematic color appearance of the diagram.
77
- this.colorScale = d3.interpolateCool;
78
- }
79
- ngOnChanges() {
80
- this.generateChart(this.colorScale, this.colorRangeInfo);
81
- }
82
- ngOnInit() {
83
- this.generateChart(this.colorScale, this.colorRangeInfo);
84
- }
85
- generateChart(colorScale, colorRangeInfo) {
86
- if (this.data) {
87
- const inputData = this.data.map((diagramData) => diagramData.value);
88
- this.amountOfData = this.data.reduce((acc, current) => acc + current.value, 0);
89
- const COLORS = this.generateColors(this.data, colorScale, colorRangeInfo);
90
- this.chartData = {
91
- labels: this.data.map((data) => data.label),
92
- datasets: [
93
- {
94
- data: inputData,
95
- backgroundColor: COLORS,
96
- },
97
- ],
98
- };
99
- }
100
- this.chartOptions = {
101
- plugins: {
102
- legend: {
103
- position: 'bottom',
104
- },
105
- },
106
- maintainAspectRatio: false,
107
- ...(this._diagramType === "VERTICAL_BAR" /* DiagramType.VERTICAL_BAR */ && {
108
- plugins: { legend: { display: false } },
109
- scales: { y: { ticks: { precision: 0 } } },
110
- }),
111
- ...(this._diagramType === "HORIZONTAL_BAR" /* DiagramType.HORIZONTAL_BAR */ && {
112
- indexAxis: 'y',
113
- plugins: { legend: { display: false } },
114
- scales: { x: { ticks: { precision: 0 } } },
115
- }),
116
- };
117
- }
118
- generateColors(data, colorScale, colorRangeInfo) {
119
- const dataColors = data.map((diagramData) => diagramData.backgroundColor);
120
- if (dataColors.filter((v) => v !== undefined).length === data.length) {
121
- return dataColors;
122
- }
123
- else if (this.fillMissingColors) {
124
- // it is intended to generate more colors than needed, so interval for generated colors is same as amount of items on the diagram
125
- const interpolatedColors = interpolateColors(dataColors.length, colorScale, colorRangeInfo);
126
- let interpolatedIndex = 0;
127
- return dataColors.map((color) => (color === undefined ? interpolatedColors[interpolatedIndex++] : color));
128
- }
129
- else {
130
- return interpolateColors(data.length, colorScale, colorRangeInfo);
131
- }
132
- }
133
- generateTotal(data) {
134
- return data.reduce((acc, current) => acc + current.value, 0);
135
- }
136
- generateDiagramValueString(data) {
137
- return data.map((item) => `${item.label}:${item.value}`).join(', ');
138
- }
139
- diagramTypeToChartType(value) {
140
- if (value === "PIE" /* DiagramType.PIE */)
141
- return 'pie';
142
- else if (value === "HORIZONTAL_BAR" /* DiagramType.HORIZONTAL_BAR */ || value === "VERTICAL_BAR" /* DiagramType.VERTICAL_BAR */)
143
- return 'bar';
144
- return 'pie';
145
- }
146
- dataClicked(event) {
147
- this.dataSelected.emit(event.length);
148
- }
149
- onDiagramTypeChanged(event) {
150
- this.diagramType = event.value.layout;
151
- this.generateChart(this.colorScale, this.colorRangeInfo);
152
- this.diagramTypeChanged.emit(event.value.layout);
153
- this.componentStateChanged.emit({
154
- activeDiagramType: event.value.layout,
155
- });
156
- }
157
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DiagramComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
158
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DiagramComponent, selector: "ocx-diagram", inputs: { data: "data", sumKey: "sumKey", fillMissingColors: "fillMissingColors", diagramType: "diagramType", supportedDiagramTypes: "supportedDiagramTypes" }, outputs: { dataSelected: "dataSelected", diagramTypeChanged: "diagramTypeChanged", componentStateChanged: "componentStateChanged" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"this.data\">\n <div class=\"flex justify-content-center pb-2\" *ngIf=\"shownDiagramTypes.length > 1\">\n <p-selectButton\n [options]=\"shownDiagramTypes\"\n [(ngModel)]=\"selectedDiagramType\"\n optionLabel=\"id\"\n (onChange)=\"onDiagramTypeChanged($event)\"\n name=\"diagram-type-select-button\"\n >\n <ng-template let-item pTemplate>\n <i\n [class]=\"item.icon\"\n [pTooltip]=\"item.tooltip || (item.tooltipKey | translate)\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n ></i>\n <label style=\"display: none\" id=\"{{item.id}}\"> {{item.label ? item.label : item.labelKey | translate}} </label>\n </ng-template>\n </p-selectButton>\n </div>\n <div class=\"w-full flex justify-content-center\">\n <p-chart\n id=\"diagram\"\n [type]=\"chartType\"\n [data]=\"chartData\"\n [responsive]=\"false\"\n [options]=\"chartOptions\"\n (onDataSelect)=\"dataClicked($event)\"\n [ariaLabel]=\"(data ? 'OCX_DIAGRAM.ARIA_LABEL' : 'OCX_DIAGRAM.EMPTY_ARIA_LABEL') | translate: {total: generateTotal(data), valueString: generateDiagramValueString(data)}\"\n ></p-chart>\n </div>\n <div class=\"w-full flex justify-content-center mt-2 sumKey\">\n <p class=\"text-md font-medium text-700\">\n <span name=\"sumLabel\"> {{ sumKey | translate }}</span> : <span name=\"amountOfData\">{{ amountOfData}}</span>\n </p>\n </div>\n</ng-container>\n\n<div *ngIf=\"!this.data\" class=\"w-full flex justify-content-center\">\n <p-message severity=\"info\" text=\"{{ 'OCX_DIAGRAM.NO_DATA' | translate }}\"></p-message>\n</div>\n", styles: ["::ng-deep .p-buttonset .p-button{min-width:auto}::ng-deep .p-buttonset{display:flex}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.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: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i5.SelectButton, selector: "p-selectButton", inputs: ["options", "optionLabel", "optionValue", "optionDisabled", "unselectable", "tabindex", "multiple", "allowEmpty", "style", "styleClass", "ariaLabelledBy", "disabled", "dataKey", "autofocus"], outputs: ["onOptionClick", "onChange"] }, { kind: "component", type: i6.UIChart, selector: "p-chart", inputs: ["type", "plugins", "width", "height", "responsive", "ariaLabel", "ariaLabelledBy", "data", "options"], outputs: ["onDataSelect"] }, { kind: "component", type: i7.UIMessage, selector: "p-message", inputs: ["severity", "text", "escape", "style", "styleClass"] }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] }); }
159
- }
160
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DiagramComponent, decorators: [{
161
- type: Component,
162
- args: [{ selector: 'ocx-diagram', template: "<ng-container *ngIf=\"this.data\">\n <div class=\"flex justify-content-center pb-2\" *ngIf=\"shownDiagramTypes.length > 1\">\n <p-selectButton\n [options]=\"shownDiagramTypes\"\n [(ngModel)]=\"selectedDiagramType\"\n optionLabel=\"id\"\n (onChange)=\"onDiagramTypeChanged($event)\"\n name=\"diagram-type-select-button\"\n >\n <ng-template let-item pTemplate>\n <i\n [class]=\"item.icon\"\n [pTooltip]=\"item.tooltip || (item.tooltipKey | translate)\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n ></i>\n <label style=\"display: none\" id=\"{{item.id}}\"> {{item.label ? item.label : item.labelKey | translate}} </label>\n </ng-template>\n </p-selectButton>\n </div>\n <div class=\"w-full flex justify-content-center\">\n <p-chart\n id=\"diagram\"\n [type]=\"chartType\"\n [data]=\"chartData\"\n [responsive]=\"false\"\n [options]=\"chartOptions\"\n (onDataSelect)=\"dataClicked($event)\"\n [ariaLabel]=\"(data ? 'OCX_DIAGRAM.ARIA_LABEL' : 'OCX_DIAGRAM.EMPTY_ARIA_LABEL') | translate: {total: generateTotal(data), valueString: generateDiagramValueString(data)}\"\n ></p-chart>\n </div>\n <div class=\"w-full flex justify-content-center mt-2 sumKey\">\n <p class=\"text-md font-medium text-700\">\n <span name=\"sumLabel\"> {{ sumKey | translate }}</span> : <span name=\"amountOfData\">{{ amountOfData}}</span>\n </p>\n </div>\n</ng-container>\n\n<div *ngIf=\"!this.data\" class=\"w-full flex justify-content-center\">\n <p-message severity=\"info\" text=\"{{ 'OCX_DIAGRAM.NO_DATA' | translate }}\"></p-message>\n</div>\n", styles: ["::ng-deep .p-buttonset .p-button{min-width:auto}::ng-deep .p-buttonset{display:flex}\n"] }]
163
- }], ctorParameters: () => [{ type: i1.TranslateService }], propDecorators: { data: [{
164
- type: Input
165
- }], sumKey: [{
166
- type: Input
167
- }], fillMissingColors: [{
168
- type: Input
169
- }], diagramType: [{
170
- type: Input
171
- }], supportedDiagramTypes: [{
172
- type: Input
173
- }], dataSelected: [{
174
- type: Output
175
- }], diagramTypeChanged: [{
176
- type: Output
177
- }], componentStateChanged: [{
178
- type: Output
179
- }] } });
180
- function interpolateColors(amountOfData, colorScale, colorRangeInfo) {
181
- return ColorUtils.interpolateColors(amountOfData, colorScale, colorRangeInfo);
182
- }
183
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"diagram.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/diagram/diagram.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/diagram/diagram.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAE,MAAM,eAAe,CAAA;AACzF,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAA;AAEtD,OAAO,KAAK,EAAE,MAAM,oBAAoB,CAAA;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAGxC,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAA;;;;;;;;;;AAiBnD,MAAM,eAAe,GAAqB;IACxC;QACE,EAAE,EAAE,aAAa;QACjB,IAAI,EAAE,UAAU,CAAC,SAAS;QAC1B,MAAM,6BAAiB;QACvB,UAAU,EAAE,qCAAqC;QACjD,QAAQ,EAAE,qCAAqC;KAChD;IACD;QACE,EAAE,EAAE,wBAAwB;QAC5B,IAAI,EAAE,UAAU,CAAC,IAAI;QACrB,MAAM,mDAA4B;QAClC,UAAU,EAAE,gDAAgD;QAC5D,QAAQ,EAAE,gDAAgD;KAC3D;IACD;QACE,EAAE,EAAE,sBAAsB;QAC1B,IAAI,EAAE,UAAU,CAAC,SAAS;QAC1B,MAAM,+CAA0B;QAChC,UAAU,EAAE,8CAA8C;QAC1D,QAAQ,EAAE,8CAA8C;KACzD;CACF,CAAA;AAOD,MAAM,OAAO,gBAAgB;IAY3B,IACI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAA;IAC1B,CAAC;IACD,IAAI,WAAW,CAAC,KAAkB;QAChC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAA;QACzB,IAAI,CAAC,mBAAmB,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,KAAK,CAAC,CAAA;QAC1E,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAA;IACrD,CAAC;IAED,IACI,qBAAqB;QACvB,OAAO,IAAI,CAAC,sBAAsB,CAAA;IACpC,CAAC;IACD,IAAI,qBAAqB,CAAC,KAAoB;QAC5C,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAA;QACnC,IAAI,CAAC,iBAAiB,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAA;IACzG,CAAC;IAiBD,YAAoB,gBAAkC;QAAlC,qBAAgB,GAAhB,gBAAgB,CAAkB;QA5C7C,WAAM,GAAG,iBAAiB,CAAA;QACnC;;;;WAIG;QACM,sBAAiB,GAAG,IAAI,CAAA;QACzB,iBAAY,+BAA+B;QAE5C,cAAS,GAAuF,KAAK,CAAA;QAUpG,2BAAsB,GAAkB,EAAE,CAAA;QASxC,iBAAY,GAAsB,IAAI,YAAY,EAAE,CAAA;QACpD,uBAAkB,GAA8B,IAAI,YAAY,EAAE,CAAA;QAClE,0BAAqB,GAAwC,IAAI,YAAY,EAAE,CAAA;QAIzF,sBAAiB,GAAqB,EAAE,CAAA;QACxC,0FAA0F;QAClF,mBAAc,GAAG;YACvB,UAAU,EAAE,CAAC;YACb,QAAQ,EAAE,CAAC;YACX,aAAa,EAAE,KAAK;SACrB,CAAA;QACD,qFAAqF;QAC7E,eAAU,GAAG,EAAE,CAAC,eAAe,CAAA;IAEkB,CAAC;IAE1D,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,cAAc,CAAC,CAAA;IAC1D,CAAC;IACD,QAAQ;QACN,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,cAAc,CAAC,CAAA;IAC1D,CAAC;IAEM,aAAa,CAAC,UAAe,EAAE,cAAmB;QACvD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,CAAA;YAEnE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE,CAAC,GAAG,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC,CAAA;YAC9E,MAAM,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,cAAc,CAAC,CAAA;YACzE,IAAI,CAAC,SAAS,GAAG;gBACf,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC;gBAC3C,QAAQ,EAAE;oBACR;wBACE,IAAI,EAAE,SAAS;wBACf,eAAe,EAAE,MAAM;qBACxB;iBACF;aACF,CAAA;QACH,CAAC;QAED,IAAI,CAAC,YAAY,GAAG;YAClB,OAAO,EAAE;gBACP,MAAM,EAAE;oBACN,QAAQ,EAAE,QAAQ;iBACnB;aACF;YACD,mBAAmB,EAAE,KAAK;YAC1B,GAAG,CAAC,IAAI,CAAC,YAAY,kDAA6B,IAAI;gBACpD,OAAO,EAAE,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;gBACvC,MAAM,EAAE,EAAE,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE;aAC3C,CAAC;YACF,GAAG,CAAC,IAAI,CAAC,YAAY,sDAA+B,IAAI;gBACtD,SAAS,EAAE,GAAG;gBACd,OAAO,EAAE,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;gBACvC,MAAM,EAAE,EAAE,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE;aAC3C,CAAC;SACH,CAAA;IACH,CAAC;IAED,cAAc,CAAC,IAAmB,EAAE,UAAe,EAAE,cAAmB;QACtE,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,eAAe,CAAC,CAAA;QACzE,IAAI,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE,CAAC;YACrE,OAAO,UAAU,CAAA;QACnB,CAAC;aAAM,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAClC,iIAAiI;YACjI,MAAM,kBAAkB,GAAG,iBAAiB,CAAC,UAAU,CAAC,MAAM,EAAE,UAAU,EAAE,cAAc,CAAC,CAAA;YAC3F,IAAI,iBAAiB,GAAG,CAAC,CAAA;YACzB,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,kBAAkB,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAA;QAC3G,CAAC;aAAM,CAAC;YACN,OAAO,iBAAiB,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,cAAc,CAAC,CAAA;QACnE,CAAC;IACH,CAAC;IAED,aAAa,CAAC,IAAmB;QAC/B,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE,CAAC,GAAG,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC,CAAA;IAC9D,CAAC;IAED,0BAA0B,CAAC,IAAmB;QAC5C,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACrE,CAAC;IAEO,sBAAsB,CAC5B,KAAkB;QAElB,IAAI,KAAK,gCAAoB;YAAE,OAAO,KAAK,CAAA;aACtC,IAAI,KAAK,sDAA+B,IAAI,KAAK,kDAA6B;YAAE,OAAO,KAAK,CAAA;QACjG,OAAO,KAAK,CAAA;IACd,CAAC;IAED,WAAW,CAAC,KAAS;QACnB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;IACtC,CAAC;IAED,oBAAoB,CAAC,KAAU;QAC7B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAA;QACrC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,cAAc,CAAC,CAAA;QACxD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;QAChD,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;YAC9B,iBAAiB,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM;SACtC,CAAC,CAAA;IACJ,CAAC;+GApIU,gBAAgB;mGAAhB,gBAAgB,6WCrD7B,ypDAyCA;;4FDYa,gBAAgB;kBAL5B,SAAS;+BACE,aAAa;qFAKd,IAAI;sBAAZ,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAMG,iBAAiB;sBAAzB,KAAK;gBAKF,WAAW;sBADd,KAAK;gBAWF,qBAAqB;sBADxB,KAAK;gBAQI,YAAY;sBAArB,MAAM;gBACG,kBAAkB;sBAA3B,MAAM;gBACG,qBAAqB;sBAA9B,MAAM;;AAsGT,SAAS,iBAAiB,CAAC,YAAoB,EAAE,UAAe,EAAE,cAAmB;IACnF,OAAO,UAAU,CAAC,iBAAiB,CAAC,YAAY,EAAE,UAAU,EAAE,cAAc,CAAC,CAAA;AAC/E,CAAC","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output } from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\nimport { ChartData, ChartOptions } from 'chart.js'\nimport * as d3 from 'd3-scale-chromatic'\nimport { PrimeIcons } from 'primeng/api'\nimport { DiagramData } from '../../model/diagram-data'\nimport { DiagramType } from '../../model/diagram-type'\nimport { ColorUtils } from '../../utils/colorutils'\nimport { PrimeIcon } from '../../utils/primeicon.utils'\n\nexport interface DiagramLayouts {\n  id: string\n  icon: PrimeIcon\n  layout: DiagramType\n  tooltip?: string\n  tooltipKey: string\n  label?: string\n  labelKey: string\n}\n\nexport interface DiagramComponentState {\n  activeDiagramType?: DiagramType\n}\n\nconst allDiagramTypes: DiagramLayouts[] = [\n  {\n    id: 'diagram-pie',\n    icon: PrimeIcons.CHART_PIE,\n    layout: DiagramType.PIE,\n    tooltipKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.PIE',\n    labelKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.PIE',\n  },\n  {\n    id: 'diagram-horizontal-bar',\n    icon: PrimeIcons.BARS,\n    layout: DiagramType.HORIZONTAL_BAR,\n    tooltipKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.HORIZONTAL_BAR',\n    labelKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.HORIZONTAL_BAR',\n  },\n  {\n    id: 'diagram-vertical-bar',\n    icon: PrimeIcons.CHART_BAR,\n    layout: DiagramType.VERTICAL_BAR,\n    tooltipKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.VERTICAL_BAR',\n    labelKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.VERTICAL_BAR',\n  },\n]\n\n@Component({\n  selector: 'ocx-diagram',\n  templateUrl: './diagram.component.html',\n  styleUrls: ['./diagram.component.scss'],\n})\nexport class DiagramComponent implements OnInit, OnChanges {\n  @Input() data: DiagramData[] | undefined\n  @Input() sumKey = 'OCX_DIAGRAM.SUM'\n  /**\n   * This property determines if diagram should generate the colors for the data that does not have any set.\n   *\n   * Setting this property to false will result in using the provided colors only if every data item has one. In the scenario where at least one item does not have a color set, diagram will generate all colors.\n   */\n  @Input() fillMissingColors = true\n  private _diagramType: DiagramType = DiagramType.PIE\n  selectedDiagramType: DiagramLayouts | undefined\n  public chartType: 'bar' | 'line' | 'scatter' | 'bubble' | 'pie' | 'doughnut' | 'polarArea' | 'radar' = 'pie'\n  @Input()\n  get diagramType(): DiagramType {\n    return this._diagramType\n  }\n  set diagramType(value: DiagramType) {\n    this._diagramType = value\n    this.selectedDiagramType = allDiagramTypes.find((v) => v.layout === value)\n    this.chartType = this.diagramTypeToChartType(value)\n  }\n  private _supportedDiagramTypes: DiagramType[] = []\n  @Input()\n  get supportedDiagramTypes(): DiagramType[] {\n    return this._supportedDiagramTypes\n  }\n  set supportedDiagramTypes(value: DiagramType[]) {\n    this._supportedDiagramTypes = value\n    this.shownDiagramTypes = allDiagramTypes.filter((vl) => this.supportedDiagramTypes.includes(vl.layout))\n  }\n  @Output() dataSelected: EventEmitter<any> = new EventEmitter()\n  @Output() diagramTypeChanged: EventEmitter<DiagramType> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<DiagramComponentState> = new EventEmitter()\n  chartOptions: ChartOptions | undefined\n  chartData: ChartData | undefined\n  amountOfData: number | undefined | null\n  shownDiagramTypes: DiagramLayouts[] = []\n  // Changing the colorRangeInfo, will change the range of the color palette of the diagram.\n  private colorRangeInfo = {\n    colorStart: 0,\n    colorEnd: 1,\n    useEndAsStart: false,\n  }\n  // Changing the colorScale, will change the thematic color appearance of the diagram.\n  private colorScale = d3.interpolateCool\n\n  constructor(private translateService: TranslateService) {}\n\n  ngOnChanges(): void {\n    this.generateChart(this.colorScale, this.colorRangeInfo)\n  }\n  ngOnInit(): void {\n    this.generateChart(this.colorScale, this.colorRangeInfo)\n  }\n\n  public generateChart(colorScale: any, colorRangeInfo: any) {\n    if (this.data) {\n      const inputData = this.data.map((diagramData) => diagramData.value)\n\n      this.amountOfData = this.data.reduce((acc, current) => acc + current.value, 0)\n      const COLORS = this.generateColors(this.data, colorScale, colorRangeInfo)\n      this.chartData = {\n        labels: this.data.map((data) => data.label),\n        datasets: [\n          {\n            data: inputData,\n            backgroundColor: COLORS,\n          },\n        ],\n      }\n    }\n\n    this.chartOptions = {\n      plugins: {\n        legend: {\n          position: 'bottom',\n        },\n      },\n      maintainAspectRatio: false,\n      ...(this._diagramType === DiagramType.VERTICAL_BAR && {\n        plugins: { legend: { display: false } },\n        scales: { y: { ticks: { precision: 0 } } },\n      }),\n      ...(this._diagramType === DiagramType.HORIZONTAL_BAR && {\n        indexAxis: 'y',\n        plugins: { legend: { display: false } },\n        scales: { x: { ticks: { precision: 0 } } },\n      }),\n    }\n  }\n\n  generateColors(data: DiagramData[], colorScale: any, colorRangeInfo: any) {\n    const dataColors = data.map((diagramData) => diagramData.backgroundColor)\n    if (dataColors.filter((v) => v !== undefined).length === data.length) {\n      return dataColors\n    } else if (this.fillMissingColors) {\n      // it is intended to generate more colors than needed, so interval for generated colors is same as amount of items on the diagram\n      const interpolatedColors = interpolateColors(dataColors.length, colorScale, colorRangeInfo)\n      let interpolatedIndex = 0\n      return dataColors.map((color) => (color === undefined ? interpolatedColors[interpolatedIndex++] : color))\n    } else {\n      return interpolateColors(data.length, colorScale, colorRangeInfo)\n    }\n  }\n\n  generateTotal(data: DiagramData[]): number {\n    return data.reduce((acc, current) => acc + current.value, 0)\n  }\n\n  generateDiagramValueString(data: DiagramData[]): string {\n    return data.map((item) => `${item.label}:${item.value}`).join(', ')\n  }\n\n  private diagramTypeToChartType(\n    value: DiagramType\n  ): 'bar' | 'line' | 'scatter' | 'bubble' | 'pie' | 'doughnut' | 'polarArea' | 'radar' {\n    if (value === DiagramType.PIE) return 'pie'\n    else if (value === DiagramType.HORIZONTAL_BAR || value === DiagramType.VERTICAL_BAR) return 'bar'\n    return 'pie'\n  }\n\n  dataClicked(event: []) {\n    this.dataSelected.emit(event.length)\n  }\n\n  onDiagramTypeChanged(event: any) {\n    this.diagramType = event.value.layout\n    this.generateChart(this.colorScale, this.colorRangeInfo)\n    this.diagramTypeChanged.emit(event.value.layout)\n    this.componentStateChanged.emit({\n      activeDiagramType: event.value.layout,\n    })\n  }\n}\nfunction interpolateColors(amountOfData: number, colorScale: any, colorRangeInfo: any) {\n  return ColorUtils.interpolateColors(amountOfData, colorScale, colorRangeInfo)\n}\n","<ng-container *ngIf=\"this.data\">\n  <div class=\"flex justify-content-center pb-2\" *ngIf=\"shownDiagramTypes.length > 1\">\n    <p-selectButton\n      [options]=\"shownDiagramTypes\"\n      [(ngModel)]=\"selectedDiagramType\"\n      optionLabel=\"id\"\n      (onChange)=\"onDiagramTypeChanged($event)\"\n      name=\"diagram-type-select-button\"\n    >\n      <ng-template let-item pTemplate>\n        <i\n          [class]=\"item.icon\"\n          [pTooltip]=\"item.tooltip || (item.tooltipKey | translate)\"\n          tooltipPosition=\"top\"\n          tooltipEvent=\"hover\"\n        ></i>\n        <label style=\"display: none\" id=\"{{item.id}}\"> {{item.label ? item.label : item.labelKey | translate}} </label>\n      </ng-template>\n    </p-selectButton>\n  </div>\n  <div class=\"w-full flex justify-content-center\">\n    <p-chart\n      id=\"diagram\"\n      [type]=\"chartType\"\n      [data]=\"chartData\"\n      [responsive]=\"false\"\n      [options]=\"chartOptions\"\n      (onDataSelect)=\"dataClicked($event)\"\n      [ariaLabel]=\"(data ? 'OCX_DIAGRAM.ARIA_LABEL' : 'OCX_DIAGRAM.EMPTY_ARIA_LABEL') | translate: {total: generateTotal(data), valueString: generateDiagramValueString(data)}\"\n    ></p-chart>\n  </div>\n  <div class=\"w-full flex justify-content-center mt-2 sumKey\">\n    <p class=\"text-md font-medium text-700\">\n      <span name=\"sumLabel\"> {{ sumKey | translate }}</span> : <span name=\"amountOfData\">{{ amountOfData}}</span>\n    </p>\n  </div>\n</ng-container>\n\n<div *ngIf=\"!this.data\" class=\"w-full flex justify-content-center\">\n  <p-message severity=\"info\" text=\"{{ 'OCX_DIAGRAM.NO_DATA' | translate }}\"></p-message>\n</div>\n"]}