@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.
Files changed (127) 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/widgets/smartformwidget/smartformwidget.component.mjs +3 -3
  34. package/esm2022/lib/smart-grid/api/grid-api/model/gridExportDescriptor.mjs +1 -12
  35. package/esm2022/lib/smart-grid/api/grid-api/model/gridModel.mjs +1 -1
  36. package/esm2022/lib/smart-grid/smart-grid.component.mjs +4 -3
  37. package/esm2022/lib/smart-table/tables/material-table/material-table.component.mjs +3 -3
  38. package/esm2022/lib/smart-table/tables/table.mjs +1 -1
  39. package/esm2022/projects.mjs +2 -1
  40. package/fesm2022/smartbit4all-ng-client.mjs +1231 -180
  41. package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
  42. package/lib/smart-client/smart-component-api-client.d.ts +4 -1
  43. package/lib/smart-client/smart.component.d.ts +3 -0
  44. package/lib/smart-component-layout/api/model/componentWidgetType.d.ts +2 -1
  45. package/lib/smart-component-layout/api/model/layoutDefinitionDescriptor.d.ts +19 -0
  46. package/lib/smart-component-layout/api/model/models.d.ts +1 -0
  47. package/lib/smart-component-layout/api/model/smartComponentLayoutDefinition.d.ts +2 -0
  48. package/lib/smart-component-layout/smart-component-layout-utility.d.ts +2 -0
  49. package/lib/smart-component-layout/smart-component-layout.component.d.ts +7 -0
  50. package/lib/smart-component-layout/smart-component-layout.module.d.ts +2 -1
  51. package/lib/smart-diagram/api/api/api.d.ts +3 -0
  52. package/lib/smart-diagram/api/api/diagramService.service.d.ts +36 -0
  53. package/lib/smart-diagram/api/encoder.d.ts +11 -0
  54. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramColor.d.ts +2 -2
  55. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramDataContainer.d.ts +2 -3
  56. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramDataItem.d.ts +3 -3
  57. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramDataSet.d.ts +4 -4
  58. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramDescriptor.d.ts +10 -9
  59. package/{src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramUiModel.d.ts → lib/smart-diagram/api/model/diagramModel.d.ts} +5 -4
  60. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/diagramShape.d.ts +2 -2
  61. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/drawTime.d.ts +2 -2
  62. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/labelText.d.ts +2 -2
  63. package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/model/models.d.ts +1 -2
  64. package/lib/smart-diagram/component/default-smart-diagram-options.provider.d.ts +32 -0
  65. package/lib/smart-diagram/component/smart-diagram.component.d.ts +40 -0
  66. package/lib/smart-diagram/component/smart-diagram.module.d.ts +11 -0
  67. package/lib/smart-diagram/component/smart-diagram.util.d.ts +1 -0
  68. package/lib/smart-diagram/projects.d.ts +4 -0
  69. package/lib/smart-grid/api/grid-api/model/gridExportDescriptor.d.ts +2 -2
  70. package/lib/smart-grid/api/grid-api/model/gridModel.d.ts +1 -0
  71. package/lib/smart-table/tables/table.d.ts +1 -1
  72. package/package.json +1 -7
  73. package/projects.d.ts +1 -0
  74. package/smartbit4all-ng-client-4.2.71.tgz +0 -0
  75. package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartData.mjs +0 -2
  76. package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartDescriptor.mjs +0 -2
  77. package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartOrientation.mjs +0 -16
  78. package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartType.mjs +0 -21
  79. package/esm2022/src/lib/smart-chart/smart-chart/api/model/chartValue.mjs +0 -13
  80. package/esm2022/src/lib/smart-chart/smart-chart/api/model/models.mjs +0 -7
  81. package/esm2022/src/lib/smart-chart/smart-chart/api/model/pieChartLegendPosition.mjs +0 -16
  82. package/esm2022/src/lib/smart-chart/smart-chart/default-chart-options.provider.mjs +0 -233
  83. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart.component.mjs +0 -285
  84. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart.module.mjs +0 -39
  85. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/api/api.mjs +0 -2
  86. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/api.module.mjs +0 -40
  87. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/configuration.mjs +0 -91
  88. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/index.mjs +0 -7
  89. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramColor.mjs +0 -13
  90. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataContainer.mjs +0 -2
  91. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataItem.mjs +0 -13
  92. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataSet.mjs +0 -2
  93. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataSetConstructionInstruction.mjs +0 -13
  94. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDescriptor.mjs +0 -2
  95. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramShape.mjs +0 -2
  96. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramUiModel.mjs +0 -2
  97. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/drawTime.mjs +0 -18
  98. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/labelText.mjs +0 -2
  99. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/models.mjs +0 -11
  100. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/param.mjs +0 -2
  101. package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/variables.mjs +0 -9
  102. package/esm2022/src/lib/smart-chart/smart-chart-projects.mjs +0 -9
  103. package/esm2022/src/lib/smart-chart/smartbit4all-ng-client-src-lib-smart-chart.mjs +0 -5
  104. package/esm2022/src/lib/smart-chart/view-context/utility/componentLibrary.mjs +0 -9
  105. package/fesm2022/smartbit4all-ng-client-src-lib-smart-chart.mjs +0 -686
  106. package/fesm2022/smartbit4all-ng-client-src-lib-smart-chart.mjs.map +0 -1
  107. package/smartbit4all-ng-client-4.2.70.tgz +0 -0
  108. package/src/lib/smart-chart/index.d.ts +0 -5
  109. package/src/lib/smart-chart/smart-chart/api/model/chartData.d.ts +0 -16
  110. package/src/lib/smart-chart/smart-chart/api/model/chartDescriptor.d.ts +0 -37
  111. package/src/lib/smart-chart/smart-chart/api/model/chartOrientation.d.ts +0 -16
  112. package/src/lib/smart-chart/smart-chart/api/model/chartType.d.ts +0 -21
  113. package/src/lib/smart-chart/smart-chart/api/model/chartValue.d.ts +0 -16
  114. package/src/lib/smart-chart/smart-chart/api/model/models.d.ts +0 -6
  115. package/src/lib/smart-chart/smart-chart/api/model/pieChartLegendPosition.d.ts +0 -16
  116. package/src/lib/smart-chart/smart-chart/default-chart-options.provider.d.ts +0 -31
  117. package/src/lib/smart-chart/smart-chart/smart-chart.component.d.ts +0 -33
  118. package/src/lib/smart-chart/smart-chart/smart-chart.module.d.ts +0 -11
  119. package/src/lib/smart-chart/smart-chart/smart-chart2/api/api/api.d.ts +0 -1
  120. package/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataSetConstructionInstruction.d.ts +0 -21
  121. package/src/lib/smart-chart/smart-chart-projects.d.ts +0 -5
  122. package/src/lib/smart-chart/view-context/utility/componentLibrary.d.ts +0 -6
  123. /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/api.module.d.ts +0 -0
  124. /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/configuration.d.ts +0 -0
  125. /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/index.d.ts +0 -0
  126. /package/{src/lib/smart-chart/smart-chart/smart-chart2 → lib/smart-diagram}/api/param.d.ts +0 -0
  127. /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=