@smartbit4all/ng-client 4.2.70 → 4.2.71
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/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 +1231 -180
- 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.71.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,341 @@
|
|
|
1
|
+
import { Component, EventEmitter, Inject, Input, Optional, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { Chart } from 'chart.js';
|
|
3
|
+
import AnnotationPlugin from 'chartjs-plugin-annotation';
|
|
4
|
+
import ZoomPlugin from 'chartjs-plugin-zoom';
|
|
5
|
+
import { COMPONENT_LIBRARY, ComponentLibrary } from '../../view-context/utility/componentLibrary';
|
|
6
|
+
import { lastValueFrom } from 'rxjs';
|
|
7
|
+
import { deepMerge } from './smart-diagram.util';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../api";
|
|
10
|
+
import * as i2 from "./default-smart-diagram-options.provider";
|
|
11
|
+
import * as i3 from "primeng/chart";
|
|
12
|
+
import * as i4 from "../../view-context/utility/componentLibrary";
|
|
13
|
+
export class SmartDiagramComponent {
|
|
14
|
+
constructor(diagramApi, diagramOptionProvider, compLib) {
|
|
15
|
+
this.diagramApi = diagramApi;
|
|
16
|
+
this.diagramOptionProvider = diagramOptionProvider;
|
|
17
|
+
this.plugins = [];
|
|
18
|
+
//Output events
|
|
19
|
+
this.elementSelect = new EventEmitter();
|
|
20
|
+
this.canvasClick = new EventEmitter();
|
|
21
|
+
this.dataClick = new EventEmitter();
|
|
22
|
+
this.componentLibrary = ComponentLibrary;
|
|
23
|
+
this.compLib = compLib ?? ComponentLibrary.PRIMENG;
|
|
24
|
+
Chart.register(AnnotationPlugin);
|
|
25
|
+
Chart.register(ZoomPlugin);
|
|
26
|
+
}
|
|
27
|
+
async load() {
|
|
28
|
+
this.diagramModel = await lastValueFrom(this.diagramApi.load(this.uuid, this.identifier));
|
|
29
|
+
this.setUp();
|
|
30
|
+
}
|
|
31
|
+
ngAfterViewInit() {
|
|
32
|
+
// This will run when we have an input model
|
|
33
|
+
if (!this.diagramModel) {
|
|
34
|
+
this.load();
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
ngOnInit() {
|
|
38
|
+
// This will run when we have an input model
|
|
39
|
+
this.setUp();
|
|
40
|
+
}
|
|
41
|
+
setUp() {
|
|
42
|
+
if (!this.diagramModel) {
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
let options = undefined;
|
|
46
|
+
const type = !!this.diagramModel.descriptor?.type ? this.diagramModel.descriptor.type : '';
|
|
47
|
+
const factory = this.diagramOptionProvider.getFactory(type);
|
|
48
|
+
this.type = factory.chartJsType;
|
|
49
|
+
options = factory.createOptions(this.diagramModel.diagramData);
|
|
50
|
+
if (this.diagramModel.descriptor) {
|
|
51
|
+
options = deepMerge(this.convertBackendOptions(this.diagramModel.descriptor), options);
|
|
52
|
+
}
|
|
53
|
+
if (this.options) {
|
|
54
|
+
options = deepMerge(this.options, options);
|
|
55
|
+
}
|
|
56
|
+
this.options = options;
|
|
57
|
+
this.data = factory.transformData(this.diagramModel.diagramData);
|
|
58
|
+
this.applyChartClass();
|
|
59
|
+
}
|
|
60
|
+
convertBackendOptions(descriptor) {
|
|
61
|
+
const options = {
|
|
62
|
+
plugins: {
|
|
63
|
+
legend: {
|
|
64
|
+
display: descriptor.showLegendForChart ?? true,
|
|
65
|
+
},
|
|
66
|
+
...(descriptor.title
|
|
67
|
+
? {
|
|
68
|
+
title: {
|
|
69
|
+
display: true,
|
|
70
|
+
text: descriptor.title.content ?? '',
|
|
71
|
+
color: descriptor.title.color
|
|
72
|
+
? `rgba(${descriptor.title.color.red ?? 0},
|
|
73
|
+
${descriptor.title.color.green ?? 0},
|
|
74
|
+
${descriptor.title.color.blue ?? 0},
|
|
75
|
+
${descriptor.title.color.alpha ?? 1})`
|
|
76
|
+
: '#000000ff',
|
|
77
|
+
font: {
|
|
78
|
+
size: descriptor.title.size ?? undefined,
|
|
79
|
+
weight: descriptor.title.weight ?? undefined,
|
|
80
|
+
style: descriptor.title.style ?? undefined,
|
|
81
|
+
family: descriptor.title.family ?? undefined,
|
|
82
|
+
},
|
|
83
|
+
},
|
|
84
|
+
}
|
|
85
|
+
: {}),
|
|
86
|
+
},
|
|
87
|
+
scales: {},
|
|
88
|
+
};
|
|
89
|
+
if (descriptor.minX !== undefined && descriptor.maxX !== undefined) {
|
|
90
|
+
options.scales.x = {
|
|
91
|
+
ticks: {
|
|
92
|
+
display: descriptor.showLabelsForXAxis ?? true,
|
|
93
|
+
},
|
|
94
|
+
min: descriptor.minX,
|
|
95
|
+
max: descriptor.maxX,
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
options.scales.x = {
|
|
100
|
+
ticks: {
|
|
101
|
+
display: descriptor.showLabelsForXAxis ?? true,
|
|
102
|
+
},
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
if (descriptor.minY !== undefined && descriptor.maxY !== undefined) {
|
|
106
|
+
options.scales.y = {
|
|
107
|
+
ticks: {
|
|
108
|
+
display: descriptor.showLabelsForYAxis ?? true,
|
|
109
|
+
},
|
|
110
|
+
min: descriptor.minY,
|
|
111
|
+
max: descriptor.maxY,
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
options.scales.y = {
|
|
116
|
+
ticks: {
|
|
117
|
+
display: descriptor.showLabelsForYAxis ?? true,
|
|
118
|
+
},
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
//Create shapes
|
|
122
|
+
if (descriptor.shapes) {
|
|
123
|
+
descriptor.shapes.forEach((shape, index) => {
|
|
124
|
+
options.plugins.annotation = options.plugins.annotation || {};
|
|
125
|
+
options.plugins.annotation.annotations = options.plugins.annotation.annotations || {};
|
|
126
|
+
let borderColor = `rgba(
|
|
127
|
+
${shape.borderColor?.red ?? 0},
|
|
128
|
+
${shape.borderColor?.green ?? 0},
|
|
129
|
+
${shape.borderColor?.blue ?? 0},
|
|
130
|
+
${shape.borderColor?.alpha ?? 1})`;
|
|
131
|
+
let backgroundColor = `rgba(
|
|
132
|
+
${shape.backgroundColor?.red ?? 0},
|
|
133
|
+
${shape.backgroundColor?.green ?? 0},
|
|
134
|
+
${shape.backgroundColor?.blue ?? 0},
|
|
135
|
+
${shape.backgroundColor?.alpha ?? 1})`;
|
|
136
|
+
let fontColor = `rgba(
|
|
137
|
+
${shape.labelText?.color?.red ?? 0},
|
|
138
|
+
${shape.labelText?.color?.green ?? 0},
|
|
139
|
+
${shape.labelText?.color?.blue ?? 0},
|
|
140
|
+
${shape.labelText?.color?.alpha ?? 1})`;
|
|
141
|
+
let borderDash;
|
|
142
|
+
if (shape.borderDashLength && shape.borderDashGap) {
|
|
143
|
+
borderDash = [shape.borderDashLength, shape.borderDashGap];
|
|
144
|
+
}
|
|
145
|
+
else {
|
|
146
|
+
borderDash = undefined;
|
|
147
|
+
}
|
|
148
|
+
const baseAnnotation = {
|
|
149
|
+
type: shape.shapeType ?? 'line',
|
|
150
|
+
backgroundColor: backgroundColor ?? undefined,
|
|
151
|
+
borderColor: borderColor ?? undefined,
|
|
152
|
+
borderWidth: shape.borderWidth ?? 1,
|
|
153
|
+
borderDash: borderDash ?? undefined,
|
|
154
|
+
drawTime: shape.drawTime ?? undefined,
|
|
155
|
+
};
|
|
156
|
+
switch (shape.shapeType) {
|
|
157
|
+
case 'box':
|
|
158
|
+
case 'line':
|
|
159
|
+
case 'ellipse':
|
|
160
|
+
options.plugins.annotation.annotations[`shape${index}`] = {
|
|
161
|
+
...baseAnnotation,
|
|
162
|
+
xMin: shape.xMin ?? undefined,
|
|
163
|
+
xMax: shape.xMax ?? undefined,
|
|
164
|
+
yMin: shape.yMin ?? undefined,
|
|
165
|
+
yMax: shape.yMax ?? undefined,
|
|
166
|
+
};
|
|
167
|
+
break;
|
|
168
|
+
case 'label':
|
|
169
|
+
options.plugins.annotation.annotations[`shape${index}`] = {
|
|
170
|
+
...baseAnnotation,
|
|
171
|
+
xValue: shape.xMin ?? undefined,
|
|
172
|
+
yValue: shape.yMin ?? undefined,
|
|
173
|
+
content: shape.labelText?.content ?? undefined,
|
|
174
|
+
textAlign: shape.labelText?.textAlign ?? undefined,
|
|
175
|
+
color: fontColor ?? undefined,
|
|
176
|
+
font: {
|
|
177
|
+
size: shape.labelText?.size ?? undefined,
|
|
178
|
+
weight: shape.labelText?.weight ?? undefined,
|
|
179
|
+
style: shape.labelText?.style ?? undefined,
|
|
180
|
+
},
|
|
181
|
+
backgroundColor: 'transparent',
|
|
182
|
+
borderColor: 'transparent',
|
|
183
|
+
};
|
|
184
|
+
break;
|
|
185
|
+
case 'point':
|
|
186
|
+
case 'polygon':
|
|
187
|
+
options.plugins.annotation.annotations[`shape${index}`] = {
|
|
188
|
+
...baseAnnotation,
|
|
189
|
+
xValue: shape.xMin ?? undefined,
|
|
190
|
+
yValue: shape.yMin ?? undefined,
|
|
191
|
+
};
|
|
192
|
+
break;
|
|
193
|
+
default:
|
|
194
|
+
// Optionally handle any other shape types
|
|
195
|
+
console.warn(`Unknown shape type: ${shape.shapeType}`);
|
|
196
|
+
break;
|
|
197
|
+
}
|
|
198
|
+
});
|
|
199
|
+
}
|
|
200
|
+
if (descriptor.backgroundColor) {
|
|
201
|
+
let backgroundColor = `rgba(
|
|
202
|
+
${descriptor.backgroundColor?.red ?? 0},
|
|
203
|
+
${descriptor.backgroundColor?.green ?? 0},
|
|
204
|
+
${descriptor.backgroundColor?.blue ?? 0},
|
|
205
|
+
${descriptor.backgroundColor?.alpha ?? 1})`;
|
|
206
|
+
let id = 'customCanvasBackgroundColor';
|
|
207
|
+
const plugin = {
|
|
208
|
+
id: id,
|
|
209
|
+
beforeDraw: (chart, args, options) => {
|
|
210
|
+
const { ctx, chartArea } = chart;
|
|
211
|
+
ctx.save();
|
|
212
|
+
ctx.globalCompositeOperation = 'destination-over';
|
|
213
|
+
ctx.fillStyle = backgroundColor;
|
|
214
|
+
ctx.fillRect(chartArea.left, chartArea.top, chartArea.right - chartArea.left, chartArea.bottom - chartArea.top);
|
|
215
|
+
ctx.restore();
|
|
216
|
+
},
|
|
217
|
+
};
|
|
218
|
+
this.plugins.push(plugin);
|
|
219
|
+
options.plugins[`${id}`] = {
|
|
220
|
+
color: backgroundColor,
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
return options;
|
|
224
|
+
}
|
|
225
|
+
onDataSelect(event) {
|
|
226
|
+
console.log({ event });
|
|
227
|
+
this.elementSelect.emit(event);
|
|
228
|
+
}
|
|
229
|
+
handleChartClick(event) {
|
|
230
|
+
console.log({ event });
|
|
231
|
+
this.canvasClick.emit(event);
|
|
232
|
+
}
|
|
233
|
+
handleOnDataClicked(event) {
|
|
234
|
+
const canvas = event.target;
|
|
235
|
+
const chart = Chart.getChart(canvas);
|
|
236
|
+
if (chart) {
|
|
237
|
+
const elements = chart.getElementsAtEventForMode(event, 'nearest', { intersect: true }, false);
|
|
238
|
+
if (elements.length === 0) {
|
|
239
|
+
return;
|
|
240
|
+
}
|
|
241
|
+
const clickedItems = chart.tooltip?.dataPoints?.map((item) => {
|
|
242
|
+
return {
|
|
243
|
+
datasetIndex: item.datasetIndex,
|
|
244
|
+
itemIndex: item.dataIndex,
|
|
245
|
+
element: item.element,
|
|
246
|
+
};
|
|
247
|
+
});
|
|
248
|
+
console.log({ event, clickedItems });
|
|
249
|
+
this.dataClick.emit({ event, clickedItems });
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
getBase64Image() {
|
|
253
|
+
return this.chart?.getBase64Image();
|
|
254
|
+
}
|
|
255
|
+
refresh() {
|
|
256
|
+
return this.chart?.refresh();
|
|
257
|
+
}
|
|
258
|
+
getChart() {
|
|
259
|
+
return this.chart?.chart;
|
|
260
|
+
}
|
|
261
|
+
getVisiblePoints() {
|
|
262
|
+
if (!this.chart)
|
|
263
|
+
return;
|
|
264
|
+
const chartInstance = this.chart.chart;
|
|
265
|
+
if (!chartInstance)
|
|
266
|
+
return;
|
|
267
|
+
const visiblePoints = [];
|
|
268
|
+
chartInstance.data.datasets.forEach((dataset, datasetIndex) => {
|
|
269
|
+
const meta = chartInstance.getDatasetMeta(datasetIndex);
|
|
270
|
+
// Check if the dataset is hidden
|
|
271
|
+
if (!chartInstance.isDatasetVisible(datasetIndex)) {
|
|
272
|
+
return;
|
|
273
|
+
}
|
|
274
|
+
const xMin = meta.xScale.min;
|
|
275
|
+
const xMax = meta.xScale.max;
|
|
276
|
+
const yMin = meta.yScale.min;
|
|
277
|
+
const yMax = meta.yScale.max;
|
|
278
|
+
dataset.data.forEach((point, dataIndex) => {
|
|
279
|
+
const { x, y } = point;
|
|
280
|
+
if (x >= xMin && x <= xMax && y >= yMin && y <= yMax) {
|
|
281
|
+
visiblePoints.push({
|
|
282
|
+
datasetIndex,
|
|
283
|
+
dataIndex,
|
|
284
|
+
x,
|
|
285
|
+
y,
|
|
286
|
+
});
|
|
287
|
+
}
|
|
288
|
+
});
|
|
289
|
+
});
|
|
290
|
+
return visiblePoints;
|
|
291
|
+
}
|
|
292
|
+
applyChartClass() {
|
|
293
|
+
if (!this.chart) {
|
|
294
|
+
return;
|
|
295
|
+
}
|
|
296
|
+
const chartElement = this.chart.el.nativeElement;
|
|
297
|
+
switch (this.type) {
|
|
298
|
+
case 'pie':
|
|
299
|
+
case 'doughnut':
|
|
300
|
+
case 'polarArea':
|
|
301
|
+
case 'radar':
|
|
302
|
+
chartElement.classList.add('pie-aspect-ratio');
|
|
303
|
+
break;
|
|
304
|
+
default:
|
|
305
|
+
chartElement.classList.add('default-aspect-ratio');
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartDiagramComponent, deps: [{ token: i1.DiagramServiceService }, { token: i2.DefaultChartOptionsProvider }, { token: COMPONENT_LIBRARY, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
309
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: SmartDiagramComponent, selector: "smart-diagram", inputs: { uuid: "uuid", identifier: "identifier", parent: "parent", diagramModel: "diagramModel", options: "options", plugins: "plugins" }, outputs: { elementSelect: "elementSelect", canvasClick: "canvasClick", dataClick: "dataClick" }, viewQueries: [{ propertyName: "chart", first: true, predicate: ["chartJSRef"], descendants: true }], ngImport: i0, template: "@if(compLib === componentLibrary.PRIMENG) {\r\n<p-chart\r\n #chartJSRef\r\n [type]=\"type\"\r\n [data]=\"data\"\r\n [options]=\"options\"\r\n [plugins]=\"plugins\"\r\n (onDataSelect)=\"onDataSelect($event)\"\r\n (click)=\"handleChartClick($event)\"\r\n (click)=\"handleOnDataClicked($event)\"\r\n/>\r\n} @else {\r\n<p>Only PrimeNg component library is supported</p>\r\n}\r\n", styles: [":host ::ng-deep .default-aspect-ratio div{width:100%;aspect-ratio:1.78}:host ::ng-deep .pie-aspect-ratio div{width:100%;aspect-ratio:1}\n"], dependencies: [{ kind: "component", type: i3.UIChart, selector: "p-chart", inputs: ["type", "plugins", "width", "height", "responsive", "ariaLabel", "ariaLabelledBy", "data", "options"], outputs: ["onDataSelect"] }] }); }
|
|
310
|
+
}
|
|
311
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartDiagramComponent, decorators: [{
|
|
312
|
+
type: Component,
|
|
313
|
+
args: [{ selector: 'smart-diagram', template: "@if(compLib === componentLibrary.PRIMENG) {\r\n<p-chart\r\n #chartJSRef\r\n [type]=\"type\"\r\n [data]=\"data\"\r\n [options]=\"options\"\r\n [plugins]=\"plugins\"\r\n (onDataSelect)=\"onDataSelect($event)\"\r\n (click)=\"handleChartClick($event)\"\r\n (click)=\"handleOnDataClicked($event)\"\r\n/>\r\n} @else {\r\n<p>Only PrimeNg component library is supported</p>\r\n}\r\n", styles: [":host ::ng-deep .default-aspect-ratio div{width:100%;aspect-ratio:1.78}:host ::ng-deep .pie-aspect-ratio div{width:100%;aspect-ratio:1}\n"] }]
|
|
314
|
+
}], ctorParameters: () => [{ type: i1.DiagramServiceService }, { type: i2.DefaultChartOptionsProvider }, { type: i4.ComponentLibrary, decorators: [{
|
|
315
|
+
type: Inject,
|
|
316
|
+
args: [COMPONENT_LIBRARY]
|
|
317
|
+
}, {
|
|
318
|
+
type: Optional
|
|
319
|
+
}] }], propDecorators: { chart: [{
|
|
320
|
+
type: ViewChild,
|
|
321
|
+
args: ['chartJSRef']
|
|
322
|
+
}], uuid: [{
|
|
323
|
+
type: Input
|
|
324
|
+
}], identifier: [{
|
|
325
|
+
type: Input
|
|
326
|
+
}], parent: [{
|
|
327
|
+
type: Input
|
|
328
|
+
}], diagramModel: [{
|
|
329
|
+
type: Input
|
|
330
|
+
}], options: [{
|
|
331
|
+
type: Input
|
|
332
|
+
}], plugins: [{
|
|
333
|
+
type: Input
|
|
334
|
+
}], elementSelect: [{
|
|
335
|
+
type: Output
|
|
336
|
+
}], canvasClick: [{
|
|
337
|
+
type: Output
|
|
338
|
+
}], dataClick: [{
|
|
339
|
+
type: Output
|
|
340
|
+
}] } });
|
|
341
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-diagram.component.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/smart-diagram/component/smart-diagram.component.ts","../../../../../../projects/smart-ng-client/src/lib/smart-diagram/component/smart-diagram.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Input, Optional, Output, ViewChild } from '@angular/core';\r\nimport { Chart } from 'chart.js';\r\nimport { UIChart } from 'primeng/chart';\r\nimport AnnotationPlugin from 'chartjs-plugin-annotation';\r\nimport ZoomPlugin from 'chartjs-plugin-zoom';\r\nimport { DiagramModel, DiagramDescriptor, DiagramShape, DiagramServiceService } from '../api';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../../view-context/utility/componentLibrary';\r\nimport { lastValueFrom } from 'rxjs';\r\nimport { deepMerge } from './smart-diagram.util';\r\nimport { DefaultChartOptionsProvider } from './default-smart-diagram-options.provider';\r\n\r\n@Component({\r\n  selector: 'smart-diagram',\r\n  templateUrl: './smart-diagram.component.html',\r\n  styleUrls: ['./smart-diagram.component.css'],\r\n})\r\nexport class SmartDiagramComponent {\r\n  @ViewChild('chartJSRef') chart?: UIChart;\r\n\r\n  //Widget inputs\r\n  @Input() uuid!: string;\r\n  @Input() identifier!: string;\r\n  @Input() parent?: any;\r\n\r\n  //Standalone inputs\r\n  @Input() diagramModel?: DiagramModel;\r\n  @Input() options?: any;\r\n  @Input() plugins: any[] = [];\r\n\r\n  //Output events\r\n  @Output() elementSelect = new EventEmitter<any>();\r\n  @Output() canvasClick = new EventEmitter<any>();\r\n  @Output() dataClick = new EventEmitter<any>();\r\n\r\n  data: any;\r\n  type: any;\r\n\r\n  compLib: ComponentLibrary;\r\n  componentLibrary = ComponentLibrary;\r\n\r\n  constructor(\r\n    private diagramApi: DiagramServiceService,\r\n    private diagramOptionProvider: DefaultChartOptionsProvider,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() compLib?: ComponentLibrary\r\n  ) {\r\n    this.compLib = compLib ?? ComponentLibrary.PRIMENG;\r\n    Chart.register(AnnotationPlugin);\r\n    Chart.register(ZoomPlugin);\r\n  }\r\n\r\n  async load(): Promise<void> {\r\n    this.diagramModel = await lastValueFrom(this.diagramApi.load(this.uuid, this.identifier));\r\n    this.setUp();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    // This will run when we have an input model\r\n    if (!this.diagramModel) {\r\n      this.load();\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    // This will run when we have an input model\r\n    this.setUp();\r\n  }\r\n\r\n  private setUp() {\r\n    if (!this.diagramModel) {\r\n      return;\r\n    }\r\n    let options = undefined;\r\n    const type = !!this.diagramModel.descriptor?.type ? this.diagramModel.descriptor.type : '';\r\n\r\n    const factory = this.diagramOptionProvider.getFactory(type);\r\n    this.type = factory.chartJsType;\r\n    options = factory.createOptions(this.diagramModel.diagramData!);\r\n    if (this.diagramModel.descriptor) {\r\n      options = deepMerge(this.convertBackendOptions(this.diagramModel.descriptor), options);\r\n    }\r\n    if (this.options) {\r\n      options = deepMerge(this.options, options);\r\n    }\r\n\r\n    this.options = options;\r\n    this.data = factory.transformData(this.diagramModel.diagramData!);\r\n    this.applyChartClass();\r\n  }\r\n\r\n  private convertBackendOptions(descriptor: DiagramDescriptor) {\r\n    const options: any = {\r\n      plugins: {\r\n        legend: {\r\n          display: descriptor.showLegendForChart ?? true,\r\n        },\r\n        ...(descriptor.title\r\n          ? {\r\n              title: {\r\n                display: true,\r\n                text: descriptor.title.content ?? '',\r\n                color: descriptor.title.color\r\n                  ? `rgba(${descriptor.title.color.red ?? 0},\r\n                       ${descriptor.title.color.green ?? 0},\r\n                       ${descriptor.title.color.blue ?? 0},\r\n                       ${descriptor.title.color.alpha ?? 1})`\r\n                  : '#000000ff',\r\n                font: {\r\n                  size: descriptor.title.size ?? undefined,\r\n                  weight: descriptor.title.weight ?? undefined,\r\n                  style: descriptor.title.style ?? undefined,\r\n                  family: descriptor.title.family ?? undefined,\r\n                },\r\n              },\r\n            }\r\n          : {}),\r\n      },\r\n      scales: {} as any,\r\n    };\r\n\r\n    if (descriptor.minX !== undefined && descriptor.maxX !== undefined) {\r\n      options.scales.x = {\r\n        ticks: {\r\n          display: descriptor.showLabelsForXAxis ?? true,\r\n        },\r\n        min: descriptor.minX,\r\n        max: descriptor.maxX,\r\n      };\r\n    } else {\r\n      options.scales.x = {\r\n        ticks: {\r\n          display: descriptor.showLabelsForXAxis ?? true,\r\n        },\r\n      };\r\n    }\r\n    if (descriptor.minY !== undefined && descriptor.maxY !== undefined) {\r\n      options.scales.y = {\r\n        ticks: {\r\n          display: descriptor.showLabelsForYAxis ?? true,\r\n        },\r\n        min: descriptor.minY,\r\n        max: descriptor.maxY,\r\n      };\r\n    } else {\r\n      options.scales.y = {\r\n        ticks: {\r\n          display: descriptor.showLabelsForYAxis ?? true,\r\n        },\r\n      };\r\n    }\r\n\r\n    //Create shapes\r\n    if (descriptor.shapes) {\r\n      descriptor.shapes.forEach((shape: DiagramShape, index: number) => {\r\n        options.plugins.annotation = options.plugins.annotation || {};\r\n        options.plugins.annotation.annotations = options.plugins.annotation.annotations || {};\r\n\r\n        let borderColor = `rgba(\r\n         ${shape.borderColor?.red ?? 0},\r\n         ${shape.borderColor?.green ?? 0},\r\n         ${shape.borderColor?.blue ?? 0},\r\n         ${shape.borderColor?.alpha ?? 1})`;\r\n        let backgroundColor = `rgba(\r\n         ${shape.backgroundColor?.red ?? 0},\r\n         ${shape.backgroundColor?.green ?? 0},\r\n         ${shape.backgroundColor?.blue ?? 0},\r\n         ${shape.backgroundColor?.alpha ?? 1})`;\r\n\r\n        let fontColor = `rgba(\r\n         ${shape.labelText?.color?.red ?? 0},\r\n         ${shape.labelText?.color?.green ?? 0},\r\n         ${shape.labelText?.color?.blue ?? 0},\r\n         ${shape.labelText?.color?.alpha ?? 1})`;\r\n\r\n        let borderDash;\r\n        if (shape.borderDashLength && shape.borderDashGap) {\r\n          borderDash = [shape.borderDashLength, shape.borderDashGap];\r\n        } else {\r\n          borderDash = undefined;\r\n        }\r\n\r\n        const baseAnnotation = {\r\n          type: shape.shapeType ?? 'line',\r\n          backgroundColor: backgroundColor ?? undefined,\r\n          borderColor: borderColor ?? undefined,\r\n          borderWidth: shape.borderWidth ?? 1,\r\n          borderDash: borderDash ?? undefined,\r\n          drawTime: shape.drawTime ?? undefined,\r\n        };\r\n\r\n        switch (shape.shapeType) {\r\n          case 'box':\r\n          case 'line':\r\n          case 'ellipse':\r\n            options.plugins.annotation.annotations[`shape${index}`] = {\r\n              ...baseAnnotation,\r\n              xMin: shape.xMin ?? undefined,\r\n              xMax: shape.xMax ?? undefined,\r\n              yMin: shape.yMin ?? undefined,\r\n              yMax: shape.yMax ?? undefined,\r\n            };\r\n            break;\r\n\r\n          case 'label':\r\n            options.plugins.annotation.annotations[`shape${index}`] = {\r\n              ...baseAnnotation,\r\n              xValue: shape.xMin ?? undefined,\r\n              yValue: shape.yMin ?? undefined,\r\n              content: shape.labelText?.content ?? undefined,\r\n              textAlign: shape.labelText?.textAlign ?? undefined,\r\n              color: fontColor ?? undefined,\r\n              font: {\r\n                size: shape.labelText?.size ?? undefined,\r\n                weight: shape.labelText?.weight ?? undefined,\r\n                style: shape.labelText?.style ?? undefined,\r\n              },\r\n              backgroundColor: 'transparent',\r\n              borderColor: 'transparent',\r\n            };\r\n            break;\r\n\r\n          case 'point':\r\n          case 'polygon':\r\n            options.plugins.annotation.annotations[`shape${index}`] = {\r\n              ...baseAnnotation,\r\n              xValue: shape.xMin ?? undefined,\r\n              yValue: shape.yMin ?? undefined,\r\n            };\r\n            break;\r\n\r\n          default:\r\n            // Optionally handle any other shape types\r\n            console.warn(`Unknown shape type: ${shape.shapeType}`);\r\n            break;\r\n        }\r\n      });\r\n    }\r\n\r\n    if (descriptor.backgroundColor) {\r\n      let backgroundColor = `rgba(\r\n        ${descriptor.backgroundColor?.red ?? 0},\r\n        ${descriptor.backgroundColor?.green ?? 0},\r\n        ${descriptor.backgroundColor?.blue ?? 0},\r\n        ${descriptor.backgroundColor?.alpha ?? 1})`;\r\n\r\n      let id = 'customCanvasBackgroundColor';\r\n      const plugin = {\r\n        id: id,\r\n        beforeDraw: (chart: any, args: any, options: any) => {\r\n          const { ctx, chartArea } = chart;\r\n\r\n          ctx.save();\r\n          ctx.globalCompositeOperation = 'destination-over';\r\n          ctx.fillStyle = backgroundColor;\r\n          ctx.fillRect(\r\n            chartArea.left,\r\n            chartArea.top,\r\n            chartArea.right - chartArea.left,\r\n            chartArea.bottom - chartArea.top\r\n          );\r\n          ctx.restore();\r\n        },\r\n      };\r\n      this.plugins.push(plugin);\r\n\r\n      options.plugins[`${id}`] = {\r\n        color: backgroundColor,\r\n      };\r\n    }\r\n    return options;\r\n  }\r\n\r\n  onDataSelect(event: any) {\r\n    console.log({ event });\r\n    this.elementSelect.emit(event);\r\n  }\r\n\r\n  handleChartClick(event: any): void {\r\n    console.log({ event });\r\n    this.canvasClick.emit(event);\r\n  }\r\n\r\n  handleOnDataClicked(event: any): void {\r\n    const canvas = event.target as HTMLCanvasElement;\r\n    const chart = Chart.getChart(canvas);\r\n\r\n    if (chart) {\r\n      const elements = chart.getElementsAtEventForMode(\r\n        event,\r\n        'nearest',\r\n        { intersect: true },\r\n        false\r\n      );\r\n      if (elements.length === 0) {\r\n        return;\r\n      }\r\n      const clickedItems = chart.tooltip?.dataPoints?.map((item) => {\r\n        return {\r\n          datasetIndex: item.datasetIndex,\r\n          itemIndex: item.dataIndex,\r\n          element: item.element,\r\n        };\r\n      });\r\n\r\n      console.log({ event, clickedItems });\r\n      this.dataClick.emit({ event, clickedItems });\r\n    }\r\n  }\r\n\r\n  getBase64Image() {\r\n    return this.chart?.getBase64Image();\r\n  }\r\n\r\n  refresh() {\r\n    return this.chart?.refresh();\r\n  }\r\n\r\n  getChart() {\r\n    return this.chart?.chart;\r\n  }\r\n  getVisiblePoints() {\r\n    if (!this.chart) return;\r\n\r\n    const chartInstance = this.chart.chart;\r\n    if (!chartInstance) return;\r\n\r\n    const visiblePoints: any = [];\r\n\r\n    chartInstance.data.datasets.forEach((dataset: any, datasetIndex: any) => {\r\n      const meta = chartInstance.getDatasetMeta(datasetIndex);\r\n\r\n      // Check if the dataset is hidden\r\n      if (!chartInstance.isDatasetVisible(datasetIndex)) {\r\n        return;\r\n      }\r\n\r\n      const xMin = meta.xScale.min;\r\n      const xMax = meta.xScale.max;\r\n      const yMin = meta.yScale.min;\r\n      const yMax = meta.yScale.max;\r\n\r\n      dataset.data.forEach((point: any, dataIndex: number) => {\r\n        const { x, y } = point;\r\n\r\n        if (x >= xMin && x <= xMax && y >= yMin && y <= yMax) {\r\n          visiblePoints.push({\r\n            datasetIndex,\r\n            dataIndex,\r\n            x,\r\n            y,\r\n          });\r\n        }\r\n      });\r\n    });\r\n\r\n    return visiblePoints;\r\n  }\r\n\r\n  applyChartClass() {\r\n    if (!this.chart) {\r\n      return;\r\n    }\r\n\r\n    const chartElement = this.chart.el.nativeElement;\r\n    switch (this.type) {\r\n      case 'pie':\r\n      case 'doughnut':\r\n      case 'polarArea':\r\n      case 'radar':\r\n        chartElement.classList.add('pie-aspect-ratio');\r\n        break;\r\n      default:\r\n        chartElement.classList.add('default-aspect-ratio');\r\n    }\r\n  }\r\n}\r\n","@if(compLib === componentLibrary.PRIMENG) {\r\n<p-chart\r\n  #chartJSRef\r\n  [type]=\"type\"\r\n  [data]=\"data\"\r\n  [options]=\"options\"\r\n  [plugins]=\"plugins\"\r\n  (onDataSelect)=\"onDataSelect($event)\"\r\n  (click)=\"handleChartClick($event)\"\r\n  (click)=\"handleOnDataClicked($event)\"\r\n/>\r\n} @else {\r\n<p>Only PrimeNg component library is supported</p>\r\n}\r\n"]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { BrowserModule } from '@angular/platform-browser';
|
|
3
|
+
import { ChartModule } from 'primeng/chart';
|
|
4
|
+
import { DefaultChartOptionsProvider as DefaultDiagramOptionsProvider, CUSTOM_DIAGRAM_OPTIONS, barChart, scatterChart, bubbleChart, horizontalBarChart, stackedBarChart, multiAxisLineChart, polarAreaChart, radarChart, doughnutChart, pieChart, } from './default-smart-diagram-options.provider';
|
|
5
|
+
import { SmartDiagramComponent } from './smart-diagram.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
const DEFAULT_PROVIDERS = [
|
|
8
|
+
DefaultDiagramOptionsProvider,
|
|
9
|
+
{ provide: CUSTOM_DIAGRAM_OPTIONS, useValue: barChart, multi: true },
|
|
10
|
+
{ provide: CUSTOM_DIAGRAM_OPTIONS, useValue: scatterChart, multi: true },
|
|
11
|
+
{ provide: CUSTOM_DIAGRAM_OPTIONS, useValue: bubbleChart, multi: true },
|
|
12
|
+
{ provide: CUSTOM_DIAGRAM_OPTIONS, useValue: horizontalBarChart, multi: true },
|
|
13
|
+
{ provide: CUSTOM_DIAGRAM_OPTIONS, useValue: stackedBarChart, multi: true },
|
|
14
|
+
{ provide: CUSTOM_DIAGRAM_OPTIONS, useValue: multiAxisLineChart, multi: true },
|
|
15
|
+
{ provide: CUSTOM_DIAGRAM_OPTIONS, useValue: polarAreaChart, multi: true },
|
|
16
|
+
{ provide: CUSTOM_DIAGRAM_OPTIONS, useValue: radarChart, multi: true },
|
|
17
|
+
{ provide: CUSTOM_DIAGRAM_OPTIONS, useValue: doughnutChart, multi: true },
|
|
18
|
+
{ provide: CUSTOM_DIAGRAM_OPTIONS, useValue: pieChart, multi: true },
|
|
19
|
+
];
|
|
20
|
+
export class SmartDiagramModule {
|
|
21
|
+
static forRoot(providers) {
|
|
22
|
+
return {
|
|
23
|
+
ngModule: SmartDiagramModule,
|
|
24
|
+
providers: [...DEFAULT_PROVIDERS, ...providers],
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartDiagramModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
28
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: SmartDiagramModule, declarations: [SmartDiagramComponent], imports: [BrowserModule, ChartModule], exports: [SmartDiagramComponent] }); }
|
|
29
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartDiagramModule, imports: [BrowserModule, ChartModule] }); }
|
|
30
|
+
}
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartDiagramModule, decorators: [{
|
|
32
|
+
type: NgModule,
|
|
33
|
+
args: [{
|
|
34
|
+
declarations: [SmartDiagramComponent],
|
|
35
|
+
imports: [BrowserModule, ChartModule],
|
|
36
|
+
exports: [SmartDiagramComponent],
|
|
37
|
+
}]
|
|
38
|
+
}] });
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtZGlhZ3JhbS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi9zbWFydC1kaWFncmFtL2NvbXBvbmVudC9zbWFydC1kaWFncmFtLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXVCLFFBQVEsRUFBWSxNQUFNLGVBQWUsQ0FBQztBQUN4RSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDMUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM1QyxPQUFPLEVBQ0wsMkJBQTJCLElBQUksNkJBQTZCLEVBQzVELHNCQUFzQixFQUN0QixRQUFRLEVBQ1IsWUFBWSxFQUNaLFdBQVcsRUFDWCxrQkFBa0IsRUFDbEIsZUFBZSxFQUNmLGtCQUFrQixFQUNsQixjQUFjLEVBQ2QsVUFBVSxFQUNWLGFBQWEsRUFDYixRQUFRLEdBQ1QsTUFBTSwwQ0FBMEMsQ0FBQztBQUNsRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQzs7QUFFbEUsTUFBTSxpQkFBaUIsR0FBZTtJQUNwQyw2QkFBNkI7SUFDN0IsRUFBRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFO0lBQ3BFLEVBQUUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRTtJQUN4RSxFQUFFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxRQUFRLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDdkUsRUFBRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsUUFBUSxFQUFFLGtCQUFrQixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDOUUsRUFBRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsUUFBUSxFQUFFLGVBQWUsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFO0lBQzNFLEVBQUUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLFFBQVEsRUFBRSxrQkFBa0IsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFO0lBQzlFLEVBQUUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLFFBQVEsRUFBRSxjQUFjLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRTtJQUMxRSxFQUFFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDdEUsRUFBRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFO0lBQ3pFLEVBQUUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRTtDQUNyRSxDQUFDO0FBT0YsTUFBTSxPQUFPLGtCQUFrQjtJQUM3QixNQUFNLENBQUMsT0FBTyxDQUFDLFNBQXFCO1FBQ2xDLE9BQU87WUFDTCxRQUFRLEVBQUUsa0JBQWtCO1lBQzVCLFNBQVMsRUFBRSxDQUFDLEdBQUcsaUJBQWlCLEVBQUUsR0FBRyxTQUFTLENBQUM7U0FDaEQsQ0FBQztJQUNKLENBQUM7K0dBTlUsa0JBQWtCO2dIQUFsQixrQkFBa0IsaUJBSmQscUJBQXFCLGFBQzFCLGFBQWEsRUFBRSxXQUFXLGFBQzFCLHFCQUFxQjtnSEFFcEIsa0JBQWtCLFlBSG5CLGFBQWEsRUFBRSxXQUFXOzs0RkFHekIsa0JBQWtCO2tCQUw5QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHFCQUFxQixDQUFDO29CQUNyQyxPQUFPLEVBQUUsQ0FBQyxhQUFhLEVBQUUsV0FBVyxDQUFDO29CQUNyQyxPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztpQkFDakMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNb2R1bGVXaXRoUHJvdmlkZXJzLCBOZ01vZHVsZSwgUHJvdmlkZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQnJvd3Nlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xyXG5pbXBvcnQgeyBDaGFydE1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvY2hhcnQnO1xyXG5pbXBvcnQge1xyXG4gIERlZmF1bHRDaGFydE9wdGlvbnNQcm92aWRlciBhcyBEZWZhdWx0RGlhZ3JhbU9wdGlvbnNQcm92aWRlcixcclxuICBDVVNUT01fRElBR1JBTV9PUFRJT05TLFxyXG4gIGJhckNoYXJ0LFxyXG4gIHNjYXR0ZXJDaGFydCxcclxuICBidWJibGVDaGFydCxcclxuICBob3Jpem9udGFsQmFyQ2hhcnQsXHJcbiAgc3RhY2tlZEJhckNoYXJ0LFxyXG4gIG11bHRpQXhpc0xpbmVDaGFydCxcclxuICBwb2xhckFyZWFDaGFydCxcclxuICByYWRhckNoYXJ0LFxyXG4gIGRvdWdobnV0Q2hhcnQsXHJcbiAgcGllQ2hhcnQsXHJcbn0gZnJvbSAnLi9kZWZhdWx0LXNtYXJ0LWRpYWdyYW0tb3B0aW9ucy5wcm92aWRlcic7XHJcbmltcG9ydCB7IFNtYXJ0RGlhZ3JhbUNvbXBvbmVudCB9IGZyb20gJy4vc21hcnQtZGlhZ3JhbS5jb21wb25lbnQnO1xyXG5cclxuY29uc3QgREVGQVVMVF9QUk9WSURFUlM6IFByb3ZpZGVyW10gPSBbXHJcbiAgRGVmYXVsdERpYWdyYW1PcHRpb25zUHJvdmlkZXIsXHJcbiAgeyBwcm92aWRlOiBDVVNUT01fRElBR1JBTV9PUFRJT05TLCB1c2VWYWx1ZTogYmFyQ2hhcnQsIG11bHRpOiB0cnVlIH0sXHJcbiAgeyBwcm92aWRlOiBDVVNUT01fRElBR1JBTV9PUFRJT05TLCB1c2VWYWx1ZTogc2NhdHRlckNoYXJ0LCBtdWx0aTogdHJ1ZSB9LFxyXG4gIHsgcHJvdmlkZTogQ1VTVE9NX0RJQUdSQU1fT1BUSU9OUywgdXNlVmFsdWU6IGJ1YmJsZUNoYXJ0LCBtdWx0aTogdHJ1ZSB9LFxyXG4gIHsgcHJvdmlkZTogQ1VTVE9NX0RJQUdSQU1fT1BUSU9OUywgdXNlVmFsdWU6IGhvcml6b250YWxCYXJDaGFydCwgbXVsdGk6IHRydWUgfSxcclxuICB7IHByb3ZpZGU6IENVU1RPTV9ESUFHUkFNX09QVElPTlMsIHVzZVZhbHVlOiBzdGFja2VkQmFyQ2hhcnQsIG11bHRpOiB0cnVlIH0sXHJcbiAgeyBwcm92aWRlOiBDVVNUT01fRElBR1JBTV9PUFRJT05TLCB1c2VWYWx1ZTogbXVsdGlBeGlzTGluZUNoYXJ0LCBtdWx0aTogdHJ1ZSB9LFxyXG4gIHsgcHJvdmlkZTogQ1VTVE9NX0RJQUdSQU1fT1BUSU9OUywgdXNlVmFsdWU6IHBvbGFyQXJlYUNoYXJ0LCBtdWx0aTogdHJ1ZSB9LFxyXG4gIHsgcHJvdmlkZTogQ1VTVE9NX0RJQUdSQU1fT1BUSU9OUywgdXNlVmFsdWU6IHJhZGFyQ2hhcnQsIG11bHRpOiB0cnVlIH0sXHJcbiAgeyBwcm92aWRlOiBDVVNUT01fRElBR1JBTV9PUFRJT05TLCB1c2VWYWx1ZTogZG91Z2hudXRDaGFydCwgbXVsdGk6IHRydWUgfSxcclxuICB7IHByb3ZpZGU6IENVU1RPTV9ESUFHUkFNX09QVElPTlMsIHVzZVZhbHVlOiBwaWVDaGFydCwgbXVsdGk6IHRydWUgfSxcclxuXTtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbU21hcnREaWFncmFtQ29tcG9uZW50XSxcclxuICBpbXBvcnRzOiBbQnJvd3Nlck1vZHVsZSwgQ2hhcnRNb2R1bGVdLFxyXG4gIGV4cG9ydHM6IFtTbWFydERpYWdyYW1Db21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU21hcnREaWFncmFtTW9kdWxlIHtcclxuICBzdGF0aWMgZm9yUm9vdChwcm92aWRlcnM6IFByb3ZpZGVyW10pOiBNb2R1bGVXaXRoUHJvdmlkZXJzPFNtYXJ0RGlhZ3JhbU1vZHVsZT4ge1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgbmdNb2R1bGU6IFNtYXJ0RGlhZ3JhbU1vZHVsZSxcclxuICAgICAgcHJvdmlkZXJzOiBbLi4uREVGQVVMVF9QUk9WSURFUlMsIC4uLnByb3ZpZGVyc10sXHJcbiAgICB9O1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export function deepMerge(target, source) {
|
|
2
|
+
for (const key of Object.keys(source)) {
|
|
3
|
+
if (source[key] instanceof Object && target[key]) {
|
|
4
|
+
Object.assign(source[key], deepMerge(target[key], source[key]));
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
Object.assign(target || {}, source);
|
|
8
|
+
return target;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtZGlhZ3JhbS51dGlsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvc21hcnQtZGlhZ3JhbS9jb21wb25lbnQvc21hcnQtZGlhZ3JhbS51dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sVUFBVSxTQUFTLENBQUMsTUFBVyxFQUFFLE1BQVc7SUFDaEQsS0FBSyxNQUFNLEdBQUcsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDdEMsSUFBSSxNQUFNLENBQUMsR0FBRyxDQUFDLFlBQVksTUFBTSxJQUFJLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ2pELE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUUsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNsRSxDQUFDO0lBQ0gsQ0FBQztJQUNELE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxJQUFJLEVBQUUsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNwQyxPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIGRlZXBNZXJnZSh0YXJnZXQ6IGFueSwgc291cmNlOiBhbnkpOiBhbnkge1xyXG4gIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKHNvdXJjZSkpIHtcclxuICAgIGlmIChzb3VyY2Vba2V5XSBpbnN0YW5jZW9mIE9iamVjdCAmJiB0YXJnZXRba2V5XSkge1xyXG4gICAgICBPYmplY3QuYXNzaWduKHNvdXJjZVtrZXldLCBkZWVwTWVyZ2UodGFyZ2V0W2tleV0sIHNvdXJjZVtrZXldKSk7XHJcbiAgICB9XHJcbiAgfVxyXG4gIE9iamVjdC5hc3NpZ24odGFyZ2V0IHx8IHt9LCBzb3VyY2UpO1xyXG4gIHJldHVybiB0YXJnZXQ7XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export * from './component/smart-diagram.module';
|
|
2
|
+
export * from './component/smart-diagram.component';
|
|
3
|
+
export * from './api/model/models';
|
|
4
|
+
export * from './component/default-smart-diagram-options.provider';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvamVjdHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi9zbWFydC1kaWFncmFtL3Byb2plY3RzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsb0RBQW9ELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudC9zbWFydC1kaWFncmFtLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50L3NtYXJ0LWRpYWdyYW0uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9hcGkvbW9kZWwvbW9kZWxzJztcclxuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnQvZGVmYXVsdC1zbWFydC1kaWFncmFtLW9wdGlvbnMucHJvdmlkZXInO1xyXG4iXX0=
|