@smartbit4all/ng-client 4.2.70 → 4.2.72

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/esm2022/lib/smart-client/smart-component-api-client.mjs +15 -1
  2. package/esm2022/lib/smart-client/smart.component.mjs +9 -2
  3. package/esm2022/lib/smart-component-layout/api/model/componentWidgetType.mjs +2 -1
  4. package/esm2022/lib/smart-component-layout/api/model/layoutDefinitionDescriptor.mjs +2 -0
  5. package/esm2022/lib/smart-component-layout/api/model/models.mjs +2 -1
  6. package/esm2022/lib/smart-component-layout/api/model/smartComponentLayoutDefinition.mjs +1 -1
  7. package/esm2022/lib/smart-component-layout/smart-component-layout-utility.mjs +18 -1
  8. package/esm2022/lib/smart-component-layout/smart-component-layout.component.mjs +33 -3
  9. package/esm2022/lib/smart-component-layout/smart-component-layout.module.mjs +7 -3
  10. package/esm2022/lib/smart-diagram/api/api/api.mjs +4 -0
  11. package/esm2022/lib/smart-diagram/api/api/diagramService.service.mjs +141 -0
  12. package/esm2022/lib/smart-diagram/api/api.module.mjs +40 -0
  13. package/esm2022/lib/smart-diagram/api/configuration.mjs +91 -0
  14. package/esm2022/lib/smart-diagram/api/encoder.mjs +19 -0
  15. package/esm2022/lib/smart-diagram/api/index.mjs +7 -0
  16. package/esm2022/lib/smart-diagram/api/model/diagramColor.mjs +13 -0
  17. package/esm2022/lib/smart-diagram/api/model/diagramDataContainer.mjs +2 -0
  18. package/esm2022/lib/smart-diagram/api/model/diagramDataItem.mjs +13 -0
  19. package/esm2022/lib/smart-diagram/api/model/diagramDataSet.mjs +2 -0
  20. package/esm2022/lib/smart-diagram/api/model/diagramDescriptor.mjs +2 -0
  21. package/esm2022/lib/smart-diagram/api/model/diagramModel.mjs +2 -0
  22. package/esm2022/lib/smart-diagram/api/model/diagramShape.mjs +2 -0
  23. package/esm2022/lib/smart-diagram/api/model/drawTime.mjs +18 -0
  24. package/esm2022/lib/smart-diagram/api/model/labelText.mjs +2 -0
  25. package/esm2022/lib/smart-diagram/api/model/models.mjs +10 -0
  26. package/esm2022/lib/smart-diagram/api/param.mjs +2 -0
  27. package/esm2022/lib/smart-diagram/api/variables.mjs +9 -0
  28. package/esm2022/lib/smart-diagram/component/default-smart-diagram-options.provider.mjs +289 -0
  29. package/esm2022/lib/smart-diagram/component/smart-diagram.component.mjs +341 -0
  30. package/esm2022/lib/smart-diagram/component/smart-diagram.module.mjs +39 -0
  31. package/esm2022/lib/smart-diagram/component/smart-diagram.util.mjs +10 -0
  32. package/esm2022/lib/smart-diagram/projects.mjs +5 -0
  33. package/esm2022/lib/smart-form/services/smartform.service.mjs +4 -1
  34. package/esm2022/lib/smart-form/widgets/smartformwidget/smartformwidget.component.mjs +3 -3
  35. package/esm2022/lib/smart-grid/api/grid-api/model/gridExportDescriptor.mjs +1 -12
  36. package/esm2022/lib/smart-grid/api/grid-api/model/gridModel.mjs +1 -1
  37. package/esm2022/lib/smart-grid/smart-grid.component.mjs +4 -3
  38. package/esm2022/lib/smart-table/tables/material-table/material-table.component.mjs +3 -3
  39. package/esm2022/lib/smart-table/tables/table.mjs +1 -1
  40. package/esm2022/projects.mjs +2 -1
  41. package/fesm2022/smartbit4all-ng-client.mjs +1233 -179
  42. package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
  43. package/lib/smart-client/smart-component-api-client.d.ts +4 -1
  44. package/lib/smart-client/smart.component.d.ts +3 -0
  45. package/lib/smart-component-layout/api/model/componentWidgetType.d.ts +2 -1
  46. package/lib/smart-component-layout/api/model/layoutDefinitionDescriptor.d.ts +19 -0
  47. package/lib/smart-component-layout/api/model/models.d.ts +1 -0
  48. package/lib/smart-component-layout/api/model/smartComponentLayoutDefinition.d.ts +2 -0
  49. package/lib/smart-component-layout/smart-component-layout-utility.d.ts +2 -0
  50. package/lib/smart-component-layout/smart-component-layout.component.d.ts +7 -0
  51. package/lib/smart-component-layout/smart-component-layout.module.d.ts +2 -1
  52. package/lib/smart-diagram/api/api/api.d.ts +3 -0
  53. package/lib/smart-diagram/api/api/diagramService.service.d.ts +36 -0
  54. package/lib/smart-diagram/api/encoder.d.ts +11 -0
  55. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramColor.d.ts +2 -2
  56. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramDataContainer.d.ts +2 -3
  57. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramDataItem.d.ts +3 -3
  58. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramDataSet.d.ts +4 -4
  59. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramDescriptor.d.ts +10 -9
  60. package/{src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramUiModel.d.ts → lib/smart-diagram/api/model/diagramModel.d.ts} +5 -4
  61. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramShape.d.ts +2 -2
  62. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/drawTime.d.ts +2 -2
  63. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/labelText.d.ts +2 -2
  64. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/models.d.ts +1 -2
  65. package/lib/smart-diagram/component/default-smart-diagram-options.provider.d.ts +32 -0
  66. package/lib/smart-diagram/component/smart-diagram.component.d.ts +40 -0
  67. package/lib/smart-diagram/component/smart-diagram.module.d.ts +11 -0
  68. package/lib/smart-diagram/component/smart-diagram.util.d.ts +1 -0
  69. package/lib/smart-diagram/projects.d.ts +4 -0
  70. package/lib/smart-grid/api/grid-api/model/gridExportDescriptor.d.ts +2 -2
  71. package/lib/smart-grid/api/grid-api/model/gridModel.d.ts +1 -0
  72. package/lib/smart-table/tables/table.d.ts +1 -1
  73. package/package.json +1 -7
  74. package/projects.d.ts +1 -0
  75. package/smartbit4all-ng-client-4.2.72.tgz +0 -0
  76. package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartData.mjs +0 -2
  77. package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartDescriptor.mjs +0 -2
  78. package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartOrientation.mjs +0 -16
  79. package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartType.mjs +0 -21
  80. package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartValue.mjs +0 -13
  81. package/esm2022/src/lib/smart-chart/smart-chart/api/model/models.mjs +0 -7
  82. package/esm2022/src/lib/smart-chart/smart-chart/api/model/pieChartLegendPosition.mjs +0 -16
  83. package/esm2022/src/lib/smart-chart/smart-chart/default-chart-options.provider.mjs +0 -233
  84. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart.component.mjs +0 -285
  85. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart.module.mjs +0 -39
  86. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/api/api.mjs +0 -2
  87. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/api.module.mjs +0 -40
  88. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/configuration.mjs +0 -91
  89. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/index.mjs +0 -7
  90. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramColor.mjs +0 -13
  91. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataContainer.mjs +0 -2
  92. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataItem.mjs +0 -13
  93. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataSet.mjs +0 -2
  94. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataSetConstructionInstruction.mjs +0 -13
  95. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDescriptor.mjs +0 -2
  96. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramShape.mjs +0 -2
  97. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramUiModel.mjs +0 -2
  98. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/drawTime.mjs +0 -18
  99. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/labelText.mjs +0 -2
  100. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/models.mjs +0 -11
  101. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/param.mjs +0 -2
  102. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/variables.mjs +0 -9
  103. package/esm2022/src/lib/smart-chart/smart-chart-projects.mjs +0 -9
  104. package/esm2022/src/lib/smart-chart/smartbit4all-ng-client-src-lib-smart-chart.mjs +0 -5
  105. package/esm2022/src/lib/smart-chart/view-context/utility/componentLibrary.mjs +0 -9
  106. package/fesm2022/smartbit4all-ng-client-src-lib-smart-chart.mjs +0 -686
  107. package/fesm2022/smartbit4all-ng-client-src-lib-smart-chart.mjs.map +0 -1
  108. package/smartbit4all-ng-client-4.2.70.tgz +0 -0
  109. package/src/lib/smart-chart/index.d.ts +0 -5
  110. package/src/lib/smart-chart/smart-chart/api/model/chartData.d.ts +0 -16
  111. package/src/lib/smart-chart/smart-chart/api/model/chartDescriptor.d.ts +0 -37
  112. package/src/lib/smart-chart/smart-chart/api/model/chartOrientation.d.ts +0 -16
  113. package/src/lib/smart-chart/smart-chart/api/model/chartType.d.ts +0 -21
  114. package/src/lib/smart-chart/smart-chart/api/model/chartValue.d.ts +0 -16
  115. package/src/lib/smart-chart/smart-chart/api/model/models.d.ts +0 -6
  116. package/src/lib/smart-chart/smart-chart/api/model/pieChartLegendPosition.d.ts +0 -16
  117. package/src/lib/smart-chart/smart-chart/default-chart-options.provider.d.ts +0 -31
  118. package/src/lib/smart-chart/smart-chart/smart-chart.component.d.ts +0 -33
  119. package/src/lib/smart-chart/smart-chart/smart-chart.module.d.ts +0 -11
  120. package/src/lib/smart-chart/smart-chart/smart-chart2/api/api/api.d.ts +0 -1
  121. package/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataSetConstructionInstruction.d.ts +0 -21
  122. package/src/lib/smart-chart/smart-chart-projects.d.ts +0 -5
  123. package/src/lib/smart-chart/view-context/utility/componentLibrary.d.ts +0 -6
  124. /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/api.module.d.ts +0 -0
  125. /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/configuration.d.ts +0 -0
  126. /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/index.d.ts +0 -0
  127. /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/param.d.ts +0 -0
  128. /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/variables.d.ts +0 -0
@@ -0,0 +1,289 @@
1
+ import { Injectable, InjectionToken, Optional, Inject } from '@angular/core';
2
+ import { deepMerge } from './smart-diagram.util';
3
+ import * as i0 from "@angular/core";
4
+ export const CUSTOM_DIAGRAM_OPTIONS = new InjectionToken('CUSTOM_DIAGRAM_OPTIONS');
5
+ export function transformDataToBasicDataSets(chartData) {
6
+ return {
7
+ labels: chartData.labels,
8
+ datasets: chartData.items.map((dataset) => {
9
+ const color = dataset.color || generateRandomColor();
10
+ return {
11
+ data: dataset.items.map((item) => item.xValue),
12
+ label: dataset.label,
13
+ backgroundColor: color,
14
+ borderColor: color,
15
+ };
16
+ }),
17
+ };
18
+ }
19
+ export function transformDataToBarLikeDataSet(chartData) {
20
+ return {
21
+ labels: chartData.labels,
22
+ datasets: chartData.items.map((dataset) => {
23
+ return {
24
+ data: dataset.items.map((item) => item.xValue),
25
+ label: dataset.label,
26
+ backgroundColor: dataset.items.map((item) => item.itemColor || generateRandomColor()),
27
+ borderColor: dataset.items.map((item) => item.itemColor || generateRandomColor()),
28
+ };
29
+ }),
30
+ };
31
+ }
32
+ export function transformDataToScatter(chartData) {
33
+ return {
34
+ datasets: chartData.items.map((dataset) => {
35
+ const color = dataset.color || generateRandomColor();
36
+ return {
37
+ label: dataset.label,
38
+ data: dataset.items.map((item) => ({
39
+ x: item.xValue,
40
+ y: item.yValue,
41
+ })),
42
+ backgroundColor: color,
43
+ borderColor: color,
44
+ };
45
+ }),
46
+ };
47
+ }
48
+ export function transformDataToBubble(chartData) {
49
+ return {
50
+ datasets: chartData.items.map((dataset) => {
51
+ const color = dataset.color || generateRandomColor();
52
+ return {
53
+ label: dataset.label,
54
+ data: dataset.items.map((item) => ({
55
+ x: item.xValue,
56
+ y: item.yValue,
57
+ r: item.rValue ?? 5,
58
+ })),
59
+ backgroundColor: color,
60
+ borderColor: color,
61
+ };
62
+ }),
63
+ };
64
+ }
65
+ export function createBasicOptions() {
66
+ return {
67
+ scales: {
68
+ y: {
69
+ beginAtZero: true,
70
+ grace: '5%',
71
+ },
72
+ },
73
+ aspectRatio: 1.78,
74
+ responsive: true,
75
+ maintainAspectRatio: true,
76
+ };
77
+ }
78
+ export const barChart = {
79
+ chartType: 'bar',
80
+ chartJsType: 'bar',
81
+ createOptions: createBasicOptions,
82
+ transformData: transformDataToBarLikeDataSet,
83
+ };
84
+ export const horizontalBarChart = {
85
+ chartType: 'horizontalBar',
86
+ chartJsType: 'bar',
87
+ createOptions: () => deepMerge(createBasicOptions(), {
88
+ indexAxis: 'y',
89
+ layout: {
90
+ padding: {
91
+ right: 5,
92
+ },
93
+ },
94
+ }),
95
+ transformData: transformDataToBarLikeDataSet,
96
+ };
97
+ export const stackedBarChart = {
98
+ chartType: 'stackedBar',
99
+ chartJsType: 'bar',
100
+ createOptions: () => deepMerge(createBasicOptions(), {
101
+ scales: {
102
+ x: { stacked: true },
103
+ y: { stacked: true },
104
+ },
105
+ }),
106
+ transformData: transformDataToBasicDataSets,
107
+ };
108
+ export const pieChart = {
109
+ chartType: 'pie',
110
+ chartJsType: 'pie',
111
+ createOptions: () => {
112
+ return {
113
+ radius: '95%',
114
+ layout: {
115
+ padding: 0,
116
+ },
117
+ aspectRatio: 1,
118
+ responsive: true,
119
+ maintainAspectRatio: true,
120
+ };
121
+ },
122
+ transformData: transformDataToBarLikeDataSet,
123
+ };
124
+ export const doughnutChart = {
125
+ chartType: 'doughnut',
126
+ chartJsType: 'doughnut',
127
+ createOptions: () => {
128
+ return {
129
+ radius: '95%',
130
+ layout: {
131
+ padding: 0,
132
+ },
133
+ aspectRatio: 1,
134
+ responsive: true,
135
+ maintainAspectRatio: true,
136
+ };
137
+ },
138
+ transformData: transformDataToBarLikeDataSet,
139
+ };
140
+ export const polarAreaChart = {
141
+ chartType: 'polarArea',
142
+ chartJsType: 'polarArea',
143
+ createOptions: () => {
144
+ return {
145
+ radius: '95%',
146
+ layout: {
147
+ padding: 0,
148
+ },
149
+ aspectRatio: 1,
150
+ responsive: true,
151
+ maintainAspectRatio: true,
152
+ };
153
+ },
154
+ transformData: (chartData) => {
155
+ return {
156
+ labels: chartData.labels,
157
+ datasets: chartData.items.map((dataset) => ({
158
+ data: dataset.items.map((item) => item.xValue),
159
+ label: dataset.label,
160
+ borderColor: dataset.items.map((item) => item.itemColor),
161
+ backgroundColor: dataset.items.map((item) => item.itemColor),
162
+ })),
163
+ };
164
+ },
165
+ };
166
+ export const radarChart = {
167
+ chartType: 'radar',
168
+ chartJsType: 'radar',
169
+ createOptions: () => {
170
+ return {
171
+ aspectRatio: 1,
172
+ responsive: true,
173
+ maintainAspectRatio: true,
174
+ };
175
+ },
176
+ transformData: (chartData) => {
177
+ return {
178
+ labels: chartData.labels,
179
+ datasets: chartData.items.map((dataset) => ({
180
+ data: dataset.items.map((item) => item.xValue),
181
+ label: dataset.label,
182
+ borderColor: dataset.color,
183
+ pointBackgroundColor: dataset.color,
184
+ pointBorderColor: dataset.color,
185
+ pointHoverBackgroundColor: '#000000',
186
+ pointHoverBorderColor: dataset.color,
187
+ })),
188
+ };
189
+ },
190
+ };
191
+ export const scatterChart = {
192
+ chartType: 'scatter',
193
+ chartJsType: 'scatter',
194
+ createOptions: () => deepMerge(createBasicOptions(), {
195
+ scales: {
196
+ y: {
197
+ beginAtZero: true,
198
+ grace: '5%',
199
+ },
200
+ x: {
201
+ beginAtZero: true,
202
+ grace: '5%',
203
+ },
204
+ },
205
+ }),
206
+ transformData: transformDataToScatter,
207
+ };
208
+ export const bubbleChart = {
209
+ chartType: 'bubble',
210
+ chartJsType: 'bubble',
211
+ createOptions: () => deepMerge(createBasicOptions(), {
212
+ scales: {
213
+ y: {
214
+ beginAtZero: true,
215
+ grace: '5%',
216
+ },
217
+ x: {
218
+ beginAtZero: true,
219
+ grace: '5%',
220
+ },
221
+ },
222
+ }),
223
+ transformData: transformDataToBubble,
224
+ };
225
+ export const multiAxisLineChart = {
226
+ chartType: 'multiAxisLine',
227
+ chartJsType: 'line',
228
+ createOptions: (chartData) => {
229
+ const yAxes = chartData.items.map((dataset, index) => ({
230
+ id: `y${index == 1 ? '' : index}`,
231
+ type: 'linear',
232
+ position: index % 2 === 0 ? 'left' : 'right',
233
+ }));
234
+ return {
235
+ scales: {
236
+ ...yAxes.reduce((acc, axis) => {
237
+ acc[axis.id] = axis;
238
+ return acc;
239
+ }, {}),
240
+ },
241
+ aspectRatio: 1.78,
242
+ responsive: true,
243
+ maintainAspectRatio: true,
244
+ };
245
+ },
246
+ transformData: (chartData) => {
247
+ return {
248
+ labels: chartData.labels,
249
+ datasets: chartData.items.map((dataset, index) => ({
250
+ data: dataset.items.map((item) => item.xValue),
251
+ label: dataset.label,
252
+ yAxisID: `y${index == 1 ? '' : index}`,
253
+ backgroundColor: dataset.color,
254
+ borderColor: dataset.color,
255
+ })),
256
+ };
257
+ },
258
+ };
259
+ export class DefaultChartOptionsProvider {
260
+ constructor(factories) {
261
+ this.factoriesByType = new Map(factories?.map((f) => [f.chartType, f]) ?? []);
262
+ }
263
+ getFactory(chartType) {
264
+ return (this.factoriesByType.get(chartType) ?? {
265
+ chartType: chartType,
266
+ chartJsType: chartType,
267
+ transformData: transformDataToBasicDataSets,
268
+ createOptions: createBasicOptions,
269
+ });
270
+ }
271
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DefaultChartOptionsProvider, deps: [{ token: CUSTOM_DIAGRAM_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
272
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DefaultChartOptionsProvider, providedIn: 'root' }); }
273
+ }
274
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DefaultChartOptionsProvider, decorators: [{
275
+ type: Injectable,
276
+ args: [{
277
+ providedIn: 'root',
278
+ }]
279
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
280
+ type: Inject,
281
+ args: [CUSTOM_DIAGRAM_OPTIONS]
282
+ }, {
283
+ type: Optional
284
+ }] }] });
285
+ function generateRandomColor() {
286
+ const random = Math.floor(Math.random() * 16777215).toString(16);
287
+ return `#${'000000'.substring(0, 6 - random.length) + random}`;
288
+ }
289
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-smart-diagram-options.provider.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/smart-diagram/component/default-smart-diagram-options.provider.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, InjectionToken, Optional, Inject } from '@angular/core';\r\nimport { DiagramDataContainer } from '../api';\r\nimport { deepMerge } from './smart-diagram.util';\r\nimport { X } from '@angular/cdk/keycodes';\r\nimport { layouts } from 'chart.js';\r\n\r\nexport const CUSTOM_DIAGRAM_OPTIONS = new InjectionToken<DiagramFactory>('CUSTOM_DIAGRAM_OPTIONS');\r\n\r\nexport interface DiagramFactory {\r\n  readonly chartType: string;\r\n  readonly chartJsType: string;\r\n  createOptions(chartData: DiagramDataContainer): any;\r\n  transformData(chartData: DiagramDataContainer): any;\r\n}\r\n\r\nexport function transformDataToBasicDataSets(chartData: DiagramDataContainer): any {\r\n  return {\r\n    labels: chartData.labels,\r\n    datasets: chartData.items.map((dataset) => {\r\n      const color = dataset.color || generateRandomColor();\r\n      return {\r\n        data: dataset.items.map((item) => item.xValue),\r\n        label: dataset.label,\r\n        backgroundColor: color,\r\n        borderColor: color,\r\n      };\r\n    }),\r\n  };\r\n}\r\n\r\nexport function transformDataToBarLikeDataSet(chartData: DiagramDataContainer): any {\r\n  return {\r\n    labels: chartData.labels,\r\n    datasets: chartData.items.map((dataset) => {\r\n      return {\r\n        data: dataset.items.map((item) => item.xValue),\r\n        label: dataset.label,\r\n        backgroundColor: dataset.items.map((item) => item.itemColor || generateRandomColor()),\r\n        borderColor: dataset.items.map((item) => item.itemColor || generateRandomColor()),\r\n      };\r\n    }),\r\n  };\r\n}\r\n\r\nexport function transformDataToScatter(chartData: DiagramDataContainer): any {\r\n  return {\r\n    datasets: chartData.items.map((dataset) => {\r\n      const color = dataset.color || generateRandomColor();\r\n      return {\r\n        label: dataset.label,\r\n        data: dataset.items.map((item) => ({\r\n          x: item.xValue,\r\n          y: item.yValue,\r\n        })),\r\n        backgroundColor: color,\r\n        borderColor: color,\r\n      };\r\n    }),\r\n  };\r\n}\r\n\r\nexport function transformDataToBubble(chartData: DiagramDataContainer): any {\r\n  return {\r\n    datasets: chartData.items.map((dataset) => {\r\n      const color = dataset.color || generateRandomColor();\r\n      return {\r\n        label: dataset.label,\r\n        data: dataset.items.map((item) => ({\r\n          x: item.xValue,\r\n          y: item.yValue,\r\n          r: item.rValue ?? 5,\r\n        })),\r\n        backgroundColor: color,\r\n        borderColor: color,\r\n      };\r\n    }),\r\n  };\r\n}\r\nexport function createBasicOptions(): any {\r\n  return {\r\n    scales: {\r\n      y: {\r\n        beginAtZero: true,\r\n        grace: '5%',\r\n      },\r\n    },\r\n    aspectRatio: 1.78,\r\n    responsive: true,\r\n    maintainAspectRatio: true,\r\n  };\r\n}\r\n\r\nexport const barChart: DiagramFactory = {\r\n  chartType: 'bar',\r\n  chartJsType: 'bar',\r\n  createOptions: createBasicOptions,\r\n  transformData: transformDataToBarLikeDataSet,\r\n};\r\n\r\nexport const horizontalBarChart: DiagramFactory = {\r\n  chartType: 'horizontalBar',\r\n  chartJsType: 'bar',\r\n  createOptions: () =>\r\n    deepMerge(createBasicOptions(), {\r\n      indexAxis: 'y',\r\n      layout: {\r\n        padding: {\r\n          right: 5,\r\n        },\r\n      },\r\n    }),\r\n  transformData: transformDataToBarLikeDataSet,\r\n};\r\n\r\nexport const stackedBarChart: DiagramFactory = {\r\n  chartType: 'stackedBar',\r\n  chartJsType: 'bar',\r\n  createOptions: () =>\r\n    deepMerge(createBasicOptions(), {\r\n      scales: {\r\n        x: { stacked: true },\r\n        y: { stacked: true },\r\n      },\r\n    }),\r\n  transformData: transformDataToBasicDataSets,\r\n};\r\n\r\nexport const pieChart: DiagramFactory = {\r\n  chartType: 'pie',\r\n  chartJsType: 'pie',\r\n  createOptions: () => {\r\n    return {\r\n      radius: '95%',\r\n      layout: {\r\n        padding: 0,\r\n      },\r\n      aspectRatio: 1,\r\n      responsive: true,\r\n      maintainAspectRatio: true,\r\n    };\r\n  },\r\n  transformData: transformDataToBarLikeDataSet,\r\n};\r\n\r\nexport const doughnutChart: DiagramFactory = {\r\n  chartType: 'doughnut',\r\n  chartJsType: 'doughnut',\r\n  createOptions: () => {\r\n    return {\r\n      radius: '95%',\r\n      layout: {\r\n        padding: 0,\r\n      },\r\n      aspectRatio: 1,\r\n      responsive: true,\r\n      maintainAspectRatio: true,\r\n    };\r\n  },\r\n  transformData: transformDataToBarLikeDataSet,\r\n};\r\n\r\nexport const polarAreaChart: DiagramFactory = {\r\n  chartType: 'polarArea',\r\n  chartJsType: 'polarArea',\r\n  createOptions: () => {\r\n    return {\r\n      radius: '95%',\r\n      layout: {\r\n        padding: 0,\r\n      },\r\n      aspectRatio: 1,\r\n      responsive: true,\r\n      maintainAspectRatio: true,\r\n    };\r\n  },\r\n  transformData: (chartData: DiagramDataContainer): any => {\r\n    return {\r\n      labels: chartData.labels,\r\n      datasets: chartData.items.map((dataset) => ({\r\n        data: dataset.items.map((item) => item.xValue),\r\n        label: dataset.label,\r\n        borderColor: dataset.items.map((item) => item.itemColor),\r\n        backgroundColor: dataset.items.map((item) => item.itemColor),\r\n      })),\r\n    };\r\n  },\r\n};\r\n\r\nexport const radarChart: DiagramFactory = {\r\n  chartType: 'radar',\r\n  chartJsType: 'radar',\r\n  createOptions: () => {\r\n    return {\r\n      aspectRatio: 1,\r\n      responsive: true,\r\n      maintainAspectRatio: true,\r\n    };\r\n  },\r\n  transformData: (chartData: DiagramDataContainer): any => {\r\n    return {\r\n      labels: chartData.labels,\r\n      datasets: chartData.items.map((dataset) => ({\r\n        data: dataset.items.map((item) => item.xValue),\r\n        label: dataset.label,\r\n        borderColor: dataset.color,\r\n        pointBackgroundColor: dataset.color,\r\n        pointBorderColor: dataset.color,\r\n        pointHoverBackgroundColor: '#000000',\r\n        pointHoverBorderColor: dataset.color,\r\n      })),\r\n    };\r\n  },\r\n};\r\n\r\nexport const scatterChart: DiagramFactory = {\r\n  chartType: 'scatter',\r\n  chartJsType: 'scatter',\r\n  createOptions: () =>\r\n    deepMerge(createBasicOptions(), {\r\n      scales: {\r\n        y: {\r\n          beginAtZero: true,\r\n          grace: '5%',\r\n        },\r\n        x: {\r\n          beginAtZero: true,\r\n          grace: '5%',\r\n        },\r\n      },\r\n    }),\r\n  transformData: transformDataToScatter,\r\n};\r\n\r\nexport const bubbleChart: DiagramFactory = {\r\n  chartType: 'bubble',\r\n  chartJsType: 'bubble',\r\n  createOptions: () =>\r\n    deepMerge(createBasicOptions(), {\r\n      scales: {\r\n        y: {\r\n          beginAtZero: true,\r\n          grace: '5%',\r\n        },\r\n        x: {\r\n          beginAtZero: true,\r\n          grace: '5%',\r\n        },\r\n      },\r\n    }),\r\n  transformData: transformDataToBubble,\r\n};\r\n\r\nexport const multiAxisLineChart: DiagramFactory = {\r\n  chartType: 'multiAxisLine',\r\n  chartJsType: 'line',\r\n  createOptions: (chartData: DiagramDataContainer): any => {\r\n    const yAxes = chartData.items.map((dataset, index) => ({\r\n      id: `y${index == 1 ? '' : index}`,\r\n      type: 'linear',\r\n      position: index % 2 === 0 ? 'left' : 'right',\r\n    }));\r\n    return {\r\n      scales: {\r\n        ...yAxes.reduce((acc: any, axis) => {\r\n          acc[axis.id] = axis;\r\n          return acc;\r\n        }, {}),\r\n      },\r\n      aspectRatio: 1.78,\r\n      responsive: true,\r\n      maintainAspectRatio: true,\r\n    };\r\n  },\r\n  transformData: (chartData: DiagramDataContainer): any => {\r\n    return {\r\n      labels: chartData.labels,\r\n      datasets: chartData.items.map((dataset, index) => ({\r\n        data: dataset.items.map((item) => item.xValue),\r\n        label: dataset.label,\r\n        yAxisID: `y${index == 1 ? '' : index}`,\r\n        backgroundColor: dataset.color,\r\n        borderColor: dataset.color,\r\n      })),\r\n    };\r\n  },\r\n};\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class DefaultChartOptionsProvider {\r\n  private readonly factoriesByType: Map<string, DiagramFactory>;\r\n  constructor(\r\n    @Inject(CUSTOM_DIAGRAM_OPTIONS)\r\n    @Optional()\r\n    factories: DiagramFactory[] | undefined\r\n  ) {\r\n    this.factoriesByType = new Map(factories?.map((f) => [f.chartType, f]) ?? []);\r\n  }\r\n\r\n  getFactory(chartType: string): DiagramFactory {\r\n    return (\r\n      this.factoriesByType.get(chartType) ?? {\r\n        chartType: chartType,\r\n        chartJsType: chartType,\r\n        transformData: transformDataToBasicDataSets,\r\n        createOptions: createBasicOptions,\r\n      }\r\n    );\r\n  }\r\n}\r\n\r\nfunction generateRandomColor(): string {\r\n  const random = Math.floor(Math.random() * 16777215).toString(16);\r\n  return `#${'000000'.substring(0, 6 - random.length) + random}`;\r\n}\r\n"]}