@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.
- package/esm2022/lib/smart-client/smart-component-api-client.mjs +15 -1
- package/esm2022/lib/smart-client/smart.component.mjs +9 -2
- package/esm2022/lib/smart-component-layout/api/model/componentWidgetType.mjs +2 -1
- package/esm2022/lib/smart-component-layout/api/model/layoutDefinitionDescriptor.mjs +2 -0
- package/esm2022/lib/smart-component-layout/api/model/models.mjs +2 -1
- package/esm2022/lib/smart-component-layout/api/model/smartComponentLayoutDefinition.mjs +1 -1
- package/esm2022/lib/smart-component-layout/smart-component-layout-utility.mjs +18 -1
- package/esm2022/lib/smart-component-layout/smart-component-layout.component.mjs +33 -3
- package/esm2022/lib/smart-component-layout/smart-component-layout.module.mjs +7 -3
- package/esm2022/lib/smart-diagram/api/api/api.mjs +4 -0
- package/esm2022/lib/smart-diagram/api/api/diagramService.service.mjs +141 -0
- package/esm2022/lib/smart-diagram/api/api.module.mjs +40 -0
- package/esm2022/lib/smart-diagram/api/configuration.mjs +91 -0
- package/esm2022/lib/smart-diagram/api/encoder.mjs +19 -0
- package/esm2022/lib/smart-diagram/api/index.mjs +7 -0
- package/esm2022/lib/smart-diagram/api/model/diagramColor.mjs +13 -0
- package/esm2022/lib/smart-diagram/api/model/diagramDataContainer.mjs +2 -0
- package/esm2022/lib/smart-diagram/api/model/diagramDataItem.mjs +13 -0
- package/esm2022/lib/smart-diagram/api/model/diagramDataSet.mjs +2 -0
- package/esm2022/lib/smart-diagram/api/model/diagramDescriptor.mjs +2 -0
- package/esm2022/lib/smart-diagram/api/model/diagramModel.mjs +2 -0
- package/esm2022/lib/smart-diagram/api/model/diagramShape.mjs +2 -0
- package/esm2022/lib/smart-diagram/api/model/drawTime.mjs +18 -0
- package/esm2022/lib/smart-diagram/api/model/labelText.mjs +2 -0
- package/esm2022/lib/smart-diagram/api/model/models.mjs +10 -0
- package/esm2022/lib/smart-diagram/api/param.mjs +2 -0
- package/esm2022/lib/smart-diagram/api/variables.mjs +9 -0
- package/esm2022/lib/smart-diagram/component/default-smart-diagram-options.provider.mjs +289 -0
- package/esm2022/lib/smart-diagram/component/smart-diagram.component.mjs +341 -0
- package/esm2022/lib/smart-diagram/component/smart-diagram.module.mjs +39 -0
- package/esm2022/lib/smart-diagram/component/smart-diagram.util.mjs +10 -0
- package/esm2022/lib/smart-diagram/projects.mjs +5 -0
- package/esm2022/lib/smart-form/services/smartform.service.mjs +4 -1
- package/esm2022/lib/smart-form/widgets/smartformwidget/smartformwidget.component.mjs +3 -3
- package/esm2022/lib/smart-grid/api/grid-api/model/gridExportDescriptor.mjs +1 -12
- package/esm2022/lib/smart-grid/api/grid-api/model/gridModel.mjs +1 -1
- package/esm2022/lib/smart-grid/smart-grid.component.mjs +4 -3
- package/esm2022/lib/smart-table/tables/material-table/material-table.component.mjs +3 -3
- package/esm2022/lib/smart-table/tables/table.mjs +1 -1
- package/esm2022/projects.mjs +2 -1
- package/fesm2022/smartbit4all-ng-client.mjs +1233 -179
- package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
- package/lib/smart-client/smart-component-api-client.d.ts +4 -1
- package/lib/smart-client/smart.component.d.ts +3 -0
- package/lib/smart-component-layout/api/model/componentWidgetType.d.ts +2 -1
- package/lib/smart-component-layout/api/model/layoutDefinitionDescriptor.d.ts +19 -0
- package/lib/smart-component-layout/api/model/models.d.ts +1 -0
- package/lib/smart-component-layout/api/model/smartComponentLayoutDefinition.d.ts +2 -0
- package/lib/smart-component-layout/smart-component-layout-utility.d.ts +2 -0
- package/lib/smart-component-layout/smart-component-layout.component.d.ts +7 -0
- package/lib/smart-component-layout/smart-component-layout.module.d.ts +2 -1
- package/lib/smart-diagram/api/api/api.d.ts +3 -0
- package/lib/smart-diagram/api/api/diagramService.service.d.ts +36 -0
- package/lib/smart-diagram/api/encoder.d.ts +11 -0
- package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramColor.d.ts +2 -2
- package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramDataContainer.d.ts +2 -3
- package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramDataItem.d.ts +3 -3
- package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramDataSet.d.ts +4 -4
- package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramDescriptor.d.ts +10 -9
- package/{src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramUiModel.d.ts → lib/smart-diagram/api/model/diagramModel.d.ts} +5 -4
- package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramShape.d.ts +2 -2
- package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/drawTime.d.ts +2 -2
- package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/labelText.d.ts +2 -2
- package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/models.d.ts +1 -2
- package/lib/smart-diagram/component/default-smart-diagram-options.provider.d.ts +32 -0
- package/lib/smart-diagram/component/smart-diagram.component.d.ts +40 -0
- package/lib/smart-diagram/component/smart-diagram.module.d.ts +11 -0
- package/lib/smart-diagram/component/smart-diagram.util.d.ts +1 -0
- package/lib/smart-diagram/projects.d.ts +4 -0
- package/lib/smart-grid/api/grid-api/model/gridExportDescriptor.d.ts +2 -2
- package/lib/smart-grid/api/grid-api/model/gridModel.d.ts +1 -0
- package/lib/smart-table/tables/table.d.ts +1 -1
- package/package.json +1 -7
- package/projects.d.ts +1 -0
- package/smartbit4all-ng-client-4.2.72.tgz +0 -0
- package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartData.mjs +0 -2
- package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartDescriptor.mjs +0 -2
- package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartOrientation.mjs +0 -16
- package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartType.mjs +0 -21
- package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartValue.mjs +0 -13
- package/esm2022/src/lib/smart-chart/smart-chart/api/model/models.mjs +0 -7
- package/esm2022/src/lib/smart-chart/smart-chart/api/model/pieChartLegendPosition.mjs +0 -16
- package/esm2022/src/lib/smart-chart/smart-chart/default-chart-options.provider.mjs +0 -233
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart.component.mjs +0 -285
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart.module.mjs +0 -39
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/api/api.mjs +0 -2
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/api.module.mjs +0 -40
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/configuration.mjs +0 -91
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/index.mjs +0 -7
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramColor.mjs +0 -13
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataContainer.mjs +0 -2
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataItem.mjs +0 -13
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataSet.mjs +0 -2
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataSetConstructionInstruction.mjs +0 -13
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDescriptor.mjs +0 -2
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramShape.mjs +0 -2
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramUiModel.mjs +0 -2
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/drawTime.mjs +0 -18
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/labelText.mjs +0 -2
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/models.mjs +0 -11
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/param.mjs +0 -2
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/variables.mjs +0 -9
- package/esm2022/src/lib/smart-chart/smart-chart-projects.mjs +0 -9
- package/esm2022/src/lib/smart-chart/smartbit4all-ng-client-src-lib-smart-chart.mjs +0 -5
- package/esm2022/src/lib/smart-chart/view-context/utility/componentLibrary.mjs +0 -9
- package/fesm2022/smartbit4all-ng-client-src-lib-smart-chart.mjs +0 -686
- package/fesm2022/smartbit4all-ng-client-src-lib-smart-chart.mjs.map +0 -1
- package/smartbit4all-ng-client-4.2.70.tgz +0 -0
- package/src/lib/smart-chart/index.d.ts +0 -5
- package/src/lib/smart-chart/smart-chart/api/model/chartData.d.ts +0 -16
- package/src/lib/smart-chart/smart-chart/api/model/chartDescriptor.d.ts +0 -37
- package/src/lib/smart-chart/smart-chart/api/model/chartOrientation.d.ts +0 -16
- package/src/lib/smart-chart/smart-chart/api/model/chartType.d.ts +0 -21
- package/src/lib/smart-chart/smart-chart/api/model/chartValue.d.ts +0 -16
- package/src/lib/smart-chart/smart-chart/api/model/models.d.ts +0 -6
- package/src/lib/smart-chart/smart-chart/api/model/pieChartLegendPosition.d.ts +0 -16
- package/src/lib/smart-chart/smart-chart/default-chart-options.provider.d.ts +0 -31
- package/src/lib/smart-chart/smart-chart/smart-chart.component.d.ts +0 -33
- package/src/lib/smart-chart/smart-chart/smart-chart.module.d.ts +0 -11
- package/src/lib/smart-chart/smart-chart/smart-chart2/api/api/api.d.ts +0 -1
- package/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataSetConstructionInstruction.d.ts +0 -21
- package/src/lib/smart-chart/smart-chart-projects.d.ts +0 -5
- package/src/lib/smart-chart/view-context/utility/componentLibrary.d.ts +0 -6
- /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/api.module.d.ts +0 -0
- /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/configuration.d.ts +0 -0
- /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/index.d.ts +0 -0
- /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/param.d.ts +0 -0
- /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":"AAAA,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAE7E,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;;AAIjD,MAAM,CAAC,MAAM,sBAAsB,GAAG,IAAI,cAAc,CAAiB,wBAAwB,CAAC,CAAC;AASnG,MAAM,UAAU,4BAA4B,CAAC,SAA+B;IAC1E,OAAO;QACL,MAAM,EAAE,SAAS,CAAC,MAAM;QACxB,QAAQ,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACxC,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,mBAAmB,EAAE,CAAC;YACrD,OAAO;gBACL,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC;gBAC9C,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,eAAe,EAAE,KAAK;gBACtB,WAAW,EAAE,KAAK;aACnB,CAAC;QACJ,CAAC,CAAC;KACH,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,6BAA6B,CAAC,SAA+B;IAC3E,OAAO;QACL,MAAM,EAAE,SAAS,CAAC,MAAM;QACxB,QAAQ,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACxC,OAAO;gBACL,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC;gBAC9C,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,eAAe,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,IAAI,mBAAmB,EAAE,CAAC;gBACrF,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,IAAI,mBAAmB,EAAE,CAAC;aAClF,CAAC;QACJ,CAAC,CAAC;KACH,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,SAA+B;IACpE,OAAO;QACL,QAAQ,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACxC,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,mBAAmB,EAAE,CAAC;YACrD,OAAO;gBACL,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;oBACjC,CAAC,EAAE,IAAI,CAAC,MAAM;oBACd,CAAC,EAAE,IAAI,CAAC,MAAM;iBACf,CAAC,CAAC;gBACH,eAAe,EAAE,KAAK;gBACtB,WAAW,EAAE,KAAK;aACnB,CAAC;QACJ,CAAC,CAAC;KACH,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,qBAAqB,CAAC,SAA+B;IACnE,OAAO;QACL,QAAQ,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACxC,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,mBAAmB,EAAE,CAAC;YACrD,OAAO;gBACL,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;oBACjC,CAAC,EAAE,IAAI,CAAC,MAAM;oBACd,CAAC,EAAE,IAAI,CAAC,MAAM;oBACd,CAAC,EAAE,IAAI,CAAC,MAAM,IAAI,CAAC;iBACpB,CAAC,CAAC;gBACH,eAAe,EAAE,KAAK;gBACtB,WAAW,EAAE,KAAK;aACnB,CAAC;QACJ,CAAC,CAAC;KACH,CAAC;AACJ,CAAC;AACD,MAAM,UAAU,kBAAkB;IAChC,OAAO;QACL,MAAM,EAAE;YACN,CAAC,EAAE;gBACD,WAAW,EAAE,IAAI;gBACjB,KAAK,EAAE,IAAI;aACZ;SACF;QACD,WAAW,EAAE,IAAI;QACjB,UAAU,EAAE,IAAI;QAChB,mBAAmB,EAAE,IAAI;KAC1B,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,MAAM,QAAQ,GAAmB;IACtC,SAAS,EAAE,KAAK;IAChB,WAAW,EAAE,KAAK;IAClB,aAAa,EAAE,kBAAkB;IACjC,aAAa,EAAE,6BAA6B;CAC7C,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAmB;IAChD,SAAS,EAAE,eAAe;IAC1B,WAAW,EAAE,KAAK;IAClB,aAAa,EAAE,GAAG,EAAE,CAClB,SAAS,CAAC,kBAAkB,EAAE,EAAE;QAC9B,SAAS,EAAE,GAAG;QACd,MAAM,EAAE;YACN,OAAO,EAAE;gBACP,KAAK,EAAE,CAAC;aACT;SACF;KACF,CAAC;IACJ,aAAa,EAAE,6BAA6B;CAC7C,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAmB;IAC7C,SAAS,EAAE,YAAY;IACvB,WAAW,EAAE,KAAK;IAClB,aAAa,EAAE,GAAG,EAAE,CAClB,SAAS,CAAC,kBAAkB,EAAE,EAAE;QAC9B,MAAM,EAAE;YACN,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE;YACpB,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE;SACrB;KACF,CAAC;IACJ,aAAa,EAAE,4BAA4B;CAC5C,CAAC;AAEF,MAAM,CAAC,MAAM,QAAQ,GAAmB;IACtC,SAAS,EAAE,KAAK;IAChB,WAAW,EAAE,KAAK;IAClB,aAAa,EAAE,GAAG,EAAE;QAClB,OAAO;YACL,MAAM,EAAE,KAAK;YACb,MAAM,EAAE;gBACN,OAAO,EAAE,CAAC;aACX;YACD,WAAW,EAAE,CAAC;YACd,UAAU,EAAE,IAAI;YAChB,mBAAmB,EAAE,IAAI;SAC1B,CAAC;IACJ,CAAC;IACD,aAAa,EAAE,6BAA6B;CAC7C,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAmB;IAC3C,SAAS,EAAE,UAAU;IACrB,WAAW,EAAE,UAAU;IACvB,aAAa,EAAE,GAAG,EAAE;QAClB,OAAO;YACL,MAAM,EAAE,KAAK;YACb,MAAM,EAAE;gBACN,OAAO,EAAE,CAAC;aACX;YACD,WAAW,EAAE,CAAC;YACd,UAAU,EAAE,IAAI;YAChB,mBAAmB,EAAE,IAAI;SAC1B,CAAC;IACJ,CAAC;IACD,aAAa,EAAE,6BAA6B;CAC7C,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAmB;IAC5C,SAAS,EAAE,WAAW;IACtB,WAAW,EAAE,WAAW;IACxB,aAAa,EAAE,GAAG,EAAE;QAClB,OAAO;YACL,MAAM,EAAE,KAAK;YACb,MAAM,EAAE;gBACN,OAAO,EAAE,CAAC;aACX;YACD,WAAW,EAAE,CAAC;YACd,UAAU,EAAE,IAAI;YAChB,mBAAmB,EAAE,IAAI;SAC1B,CAAC;IACJ,CAAC;IACD,aAAa,EAAE,CAAC,SAA+B,EAAO,EAAE;QACtD,OAAO;YACL,MAAM,EAAE,SAAS,CAAC,MAAM;YACxB,QAAQ,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;gBAC1C,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC;gBAC9C,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC;gBACxD,eAAe,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC;aAC7D,CAAC,CAAC;SACJ,CAAC;IACJ,CAAC;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAmB;IACxC,SAAS,EAAE,OAAO;IAClB,WAAW,EAAE,OAAO;IACpB,aAAa,EAAE,GAAG,EAAE;QAClB,OAAO;YACL,WAAW,EAAE,CAAC;YACd,UAAU,EAAE,IAAI;YAChB,mBAAmB,EAAE,IAAI;SAC1B,CAAC;IACJ,CAAC;IACD,aAAa,EAAE,CAAC,SAA+B,EAAO,EAAE;QACtD,OAAO;YACL,MAAM,EAAE,SAAS,CAAC,MAAM;YACxB,QAAQ,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;gBAC1C,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC;gBAC9C,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,WAAW,EAAE,OAAO,CAAC,KAAK;gBAC1B,oBAAoB,EAAE,OAAO,CAAC,KAAK;gBACnC,gBAAgB,EAAE,OAAO,CAAC,KAAK;gBAC/B,yBAAyB,EAAE,SAAS;gBACpC,qBAAqB,EAAE,OAAO,CAAC,KAAK;aACrC,CAAC,CAAC;SACJ,CAAC;IACJ,CAAC;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAmB;IAC1C,SAAS,EAAE,SAAS;IACpB,WAAW,EAAE,SAAS;IACtB,aAAa,EAAE,GAAG,EAAE,CAClB,SAAS,CAAC,kBAAkB,EAAE,EAAE;QAC9B,MAAM,EAAE;YACN,CAAC,EAAE;gBACD,WAAW,EAAE,IAAI;gBACjB,KAAK,EAAE,IAAI;aACZ;YACD,CAAC,EAAE;gBACD,WAAW,EAAE,IAAI;gBACjB,KAAK,EAAE,IAAI;aACZ;SACF;KACF,CAAC;IACJ,aAAa,EAAE,sBAAsB;CACtC,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAmB;IACzC,SAAS,EAAE,QAAQ;IACnB,WAAW,EAAE,QAAQ;IACrB,aAAa,EAAE,GAAG,EAAE,CAClB,SAAS,CAAC,kBAAkB,EAAE,EAAE;QAC9B,MAAM,EAAE;YACN,CAAC,EAAE;gBACD,WAAW,EAAE,IAAI;gBACjB,KAAK,EAAE,IAAI;aACZ;YACD,CAAC,EAAE;gBACD,WAAW,EAAE,IAAI;gBACjB,KAAK,EAAE,IAAI;aACZ;SACF;KACF,CAAC;IACJ,aAAa,EAAE,qBAAqB;CACrC,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAmB;IAChD,SAAS,EAAE,eAAe;IAC1B,WAAW,EAAE,MAAM;IACnB,aAAa,EAAE,CAAC,SAA+B,EAAO,EAAE;QACtD,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;YACrD,EAAE,EAAE,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE;YACjC,IAAI,EAAE,QAAQ;YACd,QAAQ,EAAE,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO;SAC7C,CAAC,CAAC,CAAC;QACJ,OAAO;YACL,MAAM,EAAE;gBACN,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,IAAI,EAAE,EAAE;oBACjC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC;oBACpB,OAAO,GAAG,CAAC;gBACb,CAAC,EAAE,EAAE,CAAC;aACP;YACD,WAAW,EAAE,IAAI;YACjB,UAAU,EAAE,IAAI;YAChB,mBAAmB,EAAE,IAAI;SAC1B,CAAC;IACJ,CAAC;IACD,aAAa,EAAE,CAAC,SAA+B,EAAO,EAAE;QACtD,OAAO;YACL,MAAM,EAAE,SAAS,CAAC,MAAM;YACxB,QAAQ,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;gBACjD,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC;gBAC9C,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,OAAO,EAAE,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE;gBACtC,eAAe,EAAE,OAAO,CAAC,KAAK;gBAC9B,WAAW,EAAE,OAAO,CAAC,KAAK;aAC3B,CAAC,CAAC;SACJ,CAAC;IACJ,CAAC;CACF,CAAC;AAKF,MAAM,OAAO,2BAA2B;IAEtC,YAGE,SAAuC;QAEvC,IAAI,CAAC,eAAe,GAAG,IAAI,GAAG,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IAChF,CAAC;IAED,UAAU,CAAC,SAAiB;QAC1B,OAAO,CACL,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI;YACrC,SAAS,EAAE,SAAS;YACpB,WAAW,EAAE,SAAS;YACtB,aAAa,EAAE,4BAA4B;YAC3C,aAAa,EAAE,kBAAkB;SAClC,CACF,CAAC;IACJ,CAAC;+GAnBU,2BAA2B,kBAG5B,sBAAsB;mHAHrB,2BAA2B,cAF1B,MAAM;;4FAEP,2BAA2B;kBAHvC,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB;;0BAII,MAAM;2BAAC,sBAAsB;;0BAC7B,QAAQ;;AAkBb,SAAS,mBAAmB;IAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IACjE,OAAO,IAAI,QAAQ,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,MAAM,EAAE,CAAC;AACjE,CAAC","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"]}
|