@kiwibit/chart 17.0.0 → 18.0.2
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/README.md +82 -6
- package/esm2022/lib/components/chart.component.mjs +97 -0
- package/esm2022/lib/constants/chart.constants.mjs +6 -4
- package/esm2022/lib/directives/kiwi-chart.directive.mjs +452 -0
- package/esm2022/lib/models/chart.models.mjs +1 -1
- package/esm2022/public-api.mjs +2 -4
- package/fesm2022/kiwibit-chart.mjs +284 -229
- package/fesm2022/kiwibit-chart.mjs.map +1 -1
- package/lib/components/chart.component.d.ts +52 -0
- package/lib/constants/chart.constants.d.ts +5 -3
- package/lib/{chart.component.d.ts → directives/kiwi-chart.directive.d.ts} +43 -52
- package/lib/models/chart.models.d.ts +1 -0
- package/package.json +4 -5
- package/public-api.d.ts +1 -3
- package/esm2022/lib/chart.component.mjs +0 -456
- package/esm2022/lib/chart.module.mjs +0 -41
- package/lib/chart.module.d.ts +0 -9
|
@@ -0,0 +1,452 @@
|
|
|
1
|
+
// Angular Imports
|
|
2
|
+
import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';
|
|
3
|
+
// Kiwi Chart Imports
|
|
4
|
+
import { ShapeVariant } from '../models/chart.models';
|
|
5
|
+
import { ADD_POINT, RESTORE, SAVE_AS_SVG, ZOOM_IN, ZOOM_OUT } from '../constants/chart.constants';
|
|
6
|
+
// Echarts Imports
|
|
7
|
+
import * as echarts from 'echarts/core';
|
|
8
|
+
import { init } from 'echarts';
|
|
9
|
+
import { TitleComponent, TooltipComponent, GridComponent, LegendComponent, DataZoomComponent, ToolboxComponent } from 'echarts/components';
|
|
10
|
+
import { LineChart } from 'echarts/charts';
|
|
11
|
+
import { CanvasRenderer } from 'echarts/renderers';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
echarts.use([
|
|
14
|
+
TitleComponent,
|
|
15
|
+
TooltipComponent,
|
|
16
|
+
GridComponent,
|
|
17
|
+
LineChart,
|
|
18
|
+
CanvasRenderer,
|
|
19
|
+
LegendComponent,
|
|
20
|
+
DataZoomComponent,
|
|
21
|
+
ToolboxComponent,
|
|
22
|
+
]);
|
|
23
|
+
export class KiwiChartDirective {
|
|
24
|
+
/**
|
|
25
|
+
* If you resize the page, the chart is automatically re-rendered wiht the right proportions.
|
|
26
|
+
*
|
|
27
|
+
* @memberof EnchartingDirective
|
|
28
|
+
*/
|
|
29
|
+
onResize() {
|
|
30
|
+
if (this.echartsInstance) {
|
|
31
|
+
this.echartsInstance.resize();
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
constructor(el) {
|
|
35
|
+
this.el = el;
|
|
36
|
+
/**
|
|
37
|
+
* The Chart Object rendered by the canvas. For all the available options refer
|
|
38
|
+
* to Chart interface in the models folder.
|
|
39
|
+
*
|
|
40
|
+
* @type {(Chart | null)}
|
|
41
|
+
* @memberof KiwiChartDirective
|
|
42
|
+
*/
|
|
43
|
+
this.chart = null;
|
|
44
|
+
/**
|
|
45
|
+
* Width and Height of the chart area. The dimensions refer to the father component
|
|
46
|
+
* into which the kiwi-chart is inserted. For example in an empty page the width/height
|
|
47
|
+
* of the chart can take the whole available space in the page.
|
|
48
|
+
*
|
|
49
|
+
* @type {string}
|
|
50
|
+
* @memberof KiwiChartDirective
|
|
51
|
+
*/
|
|
52
|
+
this.width = '100%';
|
|
53
|
+
this.height = '480px';
|
|
54
|
+
this.chartInit = new EventEmitter();
|
|
55
|
+
/**
|
|
56
|
+
* Output event used to emit to the father component the coordinates
|
|
57
|
+
* of the point clicked in the chart area. This functionality to be used must
|
|
58
|
+
* have the property "clickToAddPoint" in the Chart object set to true.
|
|
59
|
+
*
|
|
60
|
+
* @type {EventEmitter<BasePoint>}
|
|
61
|
+
* @memberof KiwiChartDirective
|
|
62
|
+
*/
|
|
63
|
+
this.addPoint = new EventEmitter();
|
|
64
|
+
/**
|
|
65
|
+
* When the cursor hovers the chart area it emits to the father component the
|
|
66
|
+
* x and y coordinates relative to the chart reference system.
|
|
67
|
+
*
|
|
68
|
+
* @type {EventEmitter<BasePoint>}
|
|
69
|
+
* @memberof KiwiChartDirective
|
|
70
|
+
*/
|
|
71
|
+
this.chartHover = new EventEmitter();
|
|
72
|
+
/**
|
|
73
|
+
* This property simply activates or not the dark theme of the chart
|
|
74
|
+
* defined by the Echarts library. In addition the background color can be custom
|
|
75
|
+
* so that the chart can match the background of the application in which it's used.
|
|
76
|
+
*
|
|
77
|
+
* @type {boolean}
|
|
78
|
+
* @memberof KiwiChartDirective
|
|
79
|
+
*/
|
|
80
|
+
this.darkTheme = false;
|
|
81
|
+
this.darkThemeBackground = null;
|
|
82
|
+
/**
|
|
83
|
+
* The instance of the Chart.
|
|
84
|
+
*
|
|
85
|
+
* @type {ECharts}
|
|
86
|
+
* @memberof KiwiChartDirective
|
|
87
|
+
*/
|
|
88
|
+
this.echartsInstance = null;
|
|
89
|
+
/**
|
|
90
|
+
* Default number of decimals that can have
|
|
91
|
+
* the values on the x and y axes.
|
|
92
|
+
*
|
|
93
|
+
* @private
|
|
94
|
+
* @type {number}
|
|
95
|
+
* @memberof KiwiChartDirective
|
|
96
|
+
*/
|
|
97
|
+
this.MAX_DECIMALS = 3;
|
|
98
|
+
this.legendSelected = {};
|
|
99
|
+
this.isLegendClicked = false;
|
|
100
|
+
/**
|
|
101
|
+
* Used to perform actions (as point addition based on the cursor position) on the chart.
|
|
102
|
+
*
|
|
103
|
+
* @type {(zrender.ZRenderType | null)}
|
|
104
|
+
* @memberof KiwiChartComponent
|
|
105
|
+
*/
|
|
106
|
+
this.zr = null;
|
|
107
|
+
}
|
|
108
|
+
ngAfterViewInit() {
|
|
109
|
+
if (this.chart) {
|
|
110
|
+
this.renderChart(this.chart);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
ngOnChanges(changes) {
|
|
114
|
+
let chart = changes['chart']?.currentValue;
|
|
115
|
+
if (this.echartsInstance) {
|
|
116
|
+
// Every time we have an external change we
|
|
117
|
+
// destroy the chart and re-initialize it
|
|
118
|
+
this.echartsInstance.dispose();
|
|
119
|
+
this.renderChart(chart);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
renderChart(chart) {
|
|
123
|
+
// Update ElementRef styles
|
|
124
|
+
this.el.nativeElement.style.width = this.width;
|
|
125
|
+
this.el.nativeElement.style.height = this.height;
|
|
126
|
+
this.echartsInstance = init(this.el.nativeElement, this.darkTheme ? 'dark' : 'default', {
|
|
127
|
+
renderer: 'svg'
|
|
128
|
+
});
|
|
129
|
+
if (chart) {
|
|
130
|
+
this.echartsInstance.setOption({
|
|
131
|
+
title: {
|
|
132
|
+
text: chart.title,
|
|
133
|
+
},
|
|
134
|
+
grid: {
|
|
135
|
+
width: '70%'
|
|
136
|
+
},
|
|
137
|
+
backgroundColor: this.darkTheme ? this.darkThemeBackground ?? '#303030' : 'transparent', tooltip: {
|
|
138
|
+
axisPointer: {
|
|
139
|
+
type: 'cross',
|
|
140
|
+
crossStyle: {
|
|
141
|
+
color: '#bebebe'
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
},
|
|
145
|
+
toolbox: {
|
|
146
|
+
orient: 'horizontal',
|
|
147
|
+
left: 'center',
|
|
148
|
+
top: '25px',
|
|
149
|
+
feature: {
|
|
150
|
+
dataZoom: {
|
|
151
|
+
brushStyle: {
|
|
152
|
+
borderColor: '#000',
|
|
153
|
+
borderWidth: 1,
|
|
154
|
+
borderType: 'dashed'
|
|
155
|
+
},
|
|
156
|
+
emphasis: {
|
|
157
|
+
iconStyle: {
|
|
158
|
+
textPosition: 'top',
|
|
159
|
+
textPadding: 5
|
|
160
|
+
}
|
|
161
|
+
},
|
|
162
|
+
icon: {
|
|
163
|
+
zoom: ZOOM_IN,
|
|
164
|
+
back: ZOOM_OUT
|
|
165
|
+
},
|
|
166
|
+
},
|
|
167
|
+
saveAsImage: {
|
|
168
|
+
emphasis: {
|
|
169
|
+
iconStyle: {
|
|
170
|
+
textPosition: 'top',
|
|
171
|
+
textPadding: 5
|
|
172
|
+
}
|
|
173
|
+
},
|
|
174
|
+
icon: SAVE_AS_SVG,
|
|
175
|
+
},
|
|
176
|
+
restore: {
|
|
177
|
+
emphasis: {
|
|
178
|
+
iconStyle: {
|
|
179
|
+
textPosition: 'top',
|
|
180
|
+
textPadding: 5
|
|
181
|
+
}
|
|
182
|
+
},
|
|
183
|
+
icon: RESTORE,
|
|
184
|
+
},
|
|
185
|
+
myAddPoint: {
|
|
186
|
+
show: chart.clickToAddPoint ?? false,
|
|
187
|
+
title: chart.addPointCustomName ?? 'Add Point',
|
|
188
|
+
icon: ADD_POINT,
|
|
189
|
+
onclick: () => {
|
|
190
|
+
if (this.echartsInstance) {
|
|
191
|
+
const option = this.echartsInstance.getOption();
|
|
192
|
+
const toolbox = option.toolbox;
|
|
193
|
+
if (toolbox) {
|
|
194
|
+
const status = toolbox[0].feature?.['myAddPoint']?.iconStatus;
|
|
195
|
+
const offColor = 'rgb(102,102,102)';
|
|
196
|
+
const highlightColor = 'rgb(62,152,197)';
|
|
197
|
+
this.echartsInstance.setOption({
|
|
198
|
+
toolbox: {
|
|
199
|
+
feature: {
|
|
200
|
+
myAddPoint: {
|
|
201
|
+
iconStatus: !status,
|
|
202
|
+
iconStyle: {
|
|
203
|
+
borderColor: !status ? highlightColor : offColor
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
},
|
|
212
|
+
emphasis: {
|
|
213
|
+
iconStyle: {
|
|
214
|
+
textPosition: 'top',
|
|
215
|
+
textPadding: 5
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
},
|
|
220
|
+
},
|
|
221
|
+
dataZoom: [
|
|
222
|
+
{
|
|
223
|
+
type: 'inside',
|
|
224
|
+
xAxisIndex: [0],
|
|
225
|
+
throttle: 0,
|
|
226
|
+
filterMode: 'none',
|
|
227
|
+
disabled: !chart.scrollToZoom
|
|
228
|
+
},
|
|
229
|
+
{
|
|
230
|
+
type: 'inside',
|
|
231
|
+
yAxisIndex: [0],
|
|
232
|
+
throttle: 0,
|
|
233
|
+
filterMode: 'none',
|
|
234
|
+
disabled: !chart.scrollToZoom
|
|
235
|
+
},
|
|
236
|
+
],
|
|
237
|
+
legend: {
|
|
238
|
+
inactiveColor: this.darkTheme ? '#8b8b8b' : '#ccc',
|
|
239
|
+
data: chart.shapes.map((shape) => ({
|
|
240
|
+
name: shape.name,
|
|
241
|
+
icon: 'circle',
|
|
242
|
+
})),
|
|
243
|
+
selected: chart.shapes.reduce((accumulator, shape) => ({
|
|
244
|
+
...accumulator,
|
|
245
|
+
[shape.name]: this.getLegendItemSelection(shape),
|
|
246
|
+
}), {}),
|
|
247
|
+
show: chart.showLegend ?? false,
|
|
248
|
+
orient: 'vertical',
|
|
249
|
+
left: 'right',
|
|
250
|
+
padding: [60, 20],
|
|
251
|
+
type: 'scroll',
|
|
252
|
+
textStyle: {
|
|
253
|
+
width: 120,
|
|
254
|
+
fontWeight: 'bold',
|
|
255
|
+
overflow: 'break'
|
|
256
|
+
}
|
|
257
|
+
},
|
|
258
|
+
xAxis: {
|
|
259
|
+
type: chart.xAxisType,
|
|
260
|
+
name: chart.xAxisUom ? `${chart.xAxisName} [ ${chart.xAxisUom} ]` : chart.xAxisName,
|
|
261
|
+
nameLocation: 'middle',
|
|
262
|
+
nameGap: 30,
|
|
263
|
+
splitLine: {
|
|
264
|
+
show: chart.showGrid ?? true,
|
|
265
|
+
lineStyle: {
|
|
266
|
+
color: this.darkTheme ? '#595959' : '#ccc'
|
|
267
|
+
}
|
|
268
|
+
},
|
|
269
|
+
min: chart.xMin?.toFixed(chart.maxAxesDecimals ?? this.MAX_DECIMALS),
|
|
270
|
+
max: chart.xMax?.toFixed(chart.maxAxesDecimals ?? this.MAX_DECIMALS),
|
|
271
|
+
},
|
|
272
|
+
yAxis: {
|
|
273
|
+
type: chart.yAxisType,
|
|
274
|
+
name: chart.yAxisUom ? `${chart.yAxisName} [ ${chart.yAxisUom} ]` : chart.yAxisName,
|
|
275
|
+
nameLocation: 'middle',
|
|
276
|
+
nameGap: 50,
|
|
277
|
+
splitLine: {
|
|
278
|
+
show: chart.showGrid ?? true,
|
|
279
|
+
lineStyle: {
|
|
280
|
+
color: this.darkTheme ? '#595959' : '#ccc'
|
|
281
|
+
}
|
|
282
|
+
},
|
|
283
|
+
min: chart.yMin?.toFixed(chart.maxAxesDecimals ?? this.MAX_DECIMALS),
|
|
284
|
+
max: chart.yMax?.toFixed(chart.maxAxesDecimals ?? this.MAX_DECIMALS),
|
|
285
|
+
},
|
|
286
|
+
series: this.createSeries(chart.shapes),
|
|
287
|
+
animation: chart.hasAnimations,
|
|
288
|
+
animationDuration: chart.animationDuration ?? 250,
|
|
289
|
+
animationEasing: 'cubicOut'
|
|
290
|
+
}, true, true);
|
|
291
|
+
}
|
|
292
|
+
this.setupZrEventHandler(this.echartsInstance);
|
|
293
|
+
this.setupLegendEventHandler(this.echartsInstance);
|
|
294
|
+
}
|
|
295
|
+
createSeries(shapes) {
|
|
296
|
+
let series = [];
|
|
297
|
+
shapes.forEach((shape) => {
|
|
298
|
+
switch (shape.variant) {
|
|
299
|
+
case ShapeVariant.TRACE:
|
|
300
|
+
series.push(this.createTrace(shape));
|
|
301
|
+
break;
|
|
302
|
+
default:
|
|
303
|
+
break;
|
|
304
|
+
}
|
|
305
|
+
});
|
|
306
|
+
return series;
|
|
307
|
+
}
|
|
308
|
+
createTrace(trace) {
|
|
309
|
+
return {
|
|
310
|
+
type: trace.type,
|
|
311
|
+
name: trace.name,
|
|
312
|
+
data: trace.points.map((point) => ({
|
|
313
|
+
value: [point.x, point.y],
|
|
314
|
+
symbol: point.symbol ?? 'circle',
|
|
315
|
+
name: point.name,
|
|
316
|
+
symbolSize: point.symbolSize ?? 2,
|
|
317
|
+
itemStyle: {
|
|
318
|
+
color: point.color
|
|
319
|
+
},
|
|
320
|
+
emphasis: {
|
|
321
|
+
disabled: true
|
|
322
|
+
},
|
|
323
|
+
label: {
|
|
324
|
+
show: true,
|
|
325
|
+
position: 'bottom',
|
|
326
|
+
align: 'left',
|
|
327
|
+
verticalAlign: 'bottom',
|
|
328
|
+
formatter: () => `${point.name ?? ''}`,
|
|
329
|
+
fontSize: 13,
|
|
330
|
+
padding: [0, 0, 0, 10],
|
|
331
|
+
width: 100,
|
|
332
|
+
overflow: 'truncate',
|
|
333
|
+
ellipsis: '...',
|
|
334
|
+
fontWeight: 'bold',
|
|
335
|
+
color: this.darkTheme ? '#fff' : '#000'
|
|
336
|
+
},
|
|
337
|
+
tooltip: {
|
|
338
|
+
formatter: ({ value }) => `
|
|
339
|
+
<strong>${this.chart?.xAxisName}:</strong> ${value[0].toFixed(3).replace(/[.,]000$/, "")}
|
|
340
|
+
<br>
|
|
341
|
+
<strong>${this.chart?.yAxisName}:</strong> ${value[1].toFixed(3).replace(/[.,]000$/, "")}
|
|
342
|
+
`
|
|
343
|
+
}
|
|
344
|
+
})),
|
|
345
|
+
color: trace.color,
|
|
346
|
+
lineStyle: {
|
|
347
|
+
width: trace.width,
|
|
348
|
+
type: trace.style,
|
|
349
|
+
opacity: trace.opacity ?? 1
|
|
350
|
+
},
|
|
351
|
+
smooth: trace.smooth ?? false
|
|
352
|
+
};
|
|
353
|
+
}
|
|
354
|
+
getLegendItemSelection(shape) {
|
|
355
|
+
if (this.isLegendClicked) {
|
|
356
|
+
return this.legendSelected[shape.name] ?? true;
|
|
357
|
+
}
|
|
358
|
+
else {
|
|
359
|
+
return shape.selectedByDefault ?? true;
|
|
360
|
+
}
|
|
361
|
+
}
|
|
362
|
+
/**
|
|
363
|
+
* intercept a selection change event on the legend and save the state
|
|
364
|
+
* of all selections on the supporting variable legendSelected
|
|
365
|
+
*
|
|
366
|
+
* @param ec
|
|
367
|
+
*/
|
|
368
|
+
setupLegendEventHandler(ec) {
|
|
369
|
+
if (this.echartsInstance != null) {
|
|
370
|
+
this.echartsInstance.on('legendselectchanged', (params) => {
|
|
371
|
+
this.isLegendClicked = true;
|
|
372
|
+
this.legendSelected = params.selected;
|
|
373
|
+
});
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
setupZrEventHandler(ec) {
|
|
377
|
+
this.zr = ec.getZr();
|
|
378
|
+
/**
|
|
379
|
+
* Intercepts the click event on the chart (if the clickToAddPoint property is set to true)
|
|
380
|
+
* and emits the point coordinates to the father component.
|
|
381
|
+
*/
|
|
382
|
+
this.zr.on('click', params => {
|
|
383
|
+
let option = ec.getOption();
|
|
384
|
+
let active = option?.toolbox?.[0]?.feature?.myAddPoint?.iconStatus;
|
|
385
|
+
if (active && this.chart?.clickToAddPoint) {
|
|
386
|
+
const pointInPixel = [params.offsetX, params.offsetY];
|
|
387
|
+
const pointInGrid = ec.convertFromPixel('grid', pointInPixel);
|
|
388
|
+
if (ec.containPixel('grid', pointInPixel) && pointInGrid) {
|
|
389
|
+
let newPoint = {
|
|
390
|
+
x: +pointInGrid[0].toFixed(3),
|
|
391
|
+
y: +pointInGrid[1].toFixed(3)
|
|
392
|
+
};
|
|
393
|
+
this.addPoint.emit(newPoint);
|
|
394
|
+
}
|
|
395
|
+
}
|
|
396
|
+
});
|
|
397
|
+
/**
|
|
398
|
+
* This is used perform custom actions when the mouse is hovering the chart area
|
|
399
|
+
*/
|
|
400
|
+
this.zr.on('mousemove', params => {
|
|
401
|
+
const pointInPixel = [params.offsetX, params.offsetY];
|
|
402
|
+
const pointInGrid = ec.convertFromPixel('grid', pointInPixel);
|
|
403
|
+
/*
|
|
404
|
+
* Logic to emit to the father component the x and y cdinates when the
|
|
405
|
+
* cursor is hovering the chart area .
|
|
406
|
+
*/
|
|
407
|
+
if (ec.containPixel('grid', pointInPixel) && pointInGrid) {
|
|
408
|
+
let newPoint = {
|
|
409
|
+
x: +pointInGrid[0].toFixed(3),
|
|
410
|
+
y: +pointInGrid[1].toFixed(3)
|
|
411
|
+
};
|
|
412
|
+
this.chartHover.emit(newPoint);
|
|
413
|
+
}
|
|
414
|
+
/* Logic to change the cursor icon when the "Click to Add Point" feature is active and viceversa. */
|
|
415
|
+
const option = ec.getOption();
|
|
416
|
+
const addPointIsActive = option?.toolbox?.[0]?.feature?.myAddPoint?.iconStatus;
|
|
417
|
+
if (addPointIsActive) {
|
|
418
|
+
this.zr?.setCursorStyle(ec.containPixel('grid', pointInPixel) ? 'copy' : 'default');
|
|
419
|
+
}
|
|
420
|
+
});
|
|
421
|
+
}
|
|
422
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: KiwiChartDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
423
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: KiwiChartDirective, isStandalone: true, selector: "div[kiwi-chart]", inputs: { chart: "chart", width: "width", height: "height", darkTheme: "darkTheme", darkThemeBackground: "darkThemeBackground" }, outputs: { chartInit: "chartInit", addPoint: "addPoint", chartHover: "chartHover" }, host: { listeners: { "window:resize": "onResize($event)" } }, usesOnChanges: true, ngImport: i0 }); }
|
|
424
|
+
}
|
|
425
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: KiwiChartDirective, decorators: [{
|
|
426
|
+
type: Directive,
|
|
427
|
+
args: [{
|
|
428
|
+
selector: 'div[kiwi-chart]',
|
|
429
|
+
standalone: true
|
|
430
|
+
}]
|
|
431
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { chart: [{
|
|
432
|
+
type: Input,
|
|
433
|
+
args: [{ required: true }]
|
|
434
|
+
}], width: [{
|
|
435
|
+
type: Input
|
|
436
|
+
}], height: [{
|
|
437
|
+
type: Input
|
|
438
|
+
}], chartInit: [{
|
|
439
|
+
type: Output
|
|
440
|
+
}], addPoint: [{
|
|
441
|
+
type: Output
|
|
442
|
+
}], chartHover: [{
|
|
443
|
+
type: Output
|
|
444
|
+
}], darkTheme: [{
|
|
445
|
+
type: Input
|
|
446
|
+
}], darkThemeBackground: [{
|
|
447
|
+
type: Input
|
|
448
|
+
}], onResize: [{
|
|
449
|
+
type: HostListener,
|
|
450
|
+
args: ['window:resize', ['$event']]
|
|
451
|
+
}] } });
|
|
452
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kiwi-chart.directive.js","sourceRoot":"","sources":["../../../../../../projects/kiwibit/chart/src/lib/directives/kiwi-chart.directive.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular Imports\r\nimport { AfterViewInit, Directive, ElementRef, EventEmitter, HostListener, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\r\n// Kiwi Chart Imports\r\nimport { BasePoint, Chart, Point, Shape, ShapeVariant, Trace } from '../models/chart.models';\r\nimport { ADD_POINT, RESTORE, SAVE_AS_SVG, ZOOM_IN, ZOOM_OUT } from '../constants/chart.constants';\r\n// Echarts Imports\r\nimport * as echarts from 'echarts/core';\r\nimport {\r\n  ComposeOption,\r\n  CustomSeriesOption,\r\n  DatasetComponentOption,\r\n  ECharts,\r\n  GridComponentOption,\r\n  LegendComponentOption,\r\n  LineSeriesOption,\r\n  ScatterSeriesOption,\r\n  TitleComponentOption,\r\n  ToolboxComponentOption,\r\n  TooltipComponentOption,\r\n  init,\r\n  zrender\r\n} from 'echarts';\r\nimport { TitleComponent, TooltipComponent, GridComponent, LegendComponent, DataZoomComponent, ToolboxComponent } from 'echarts/components';\r\nimport { LineChart } from 'echarts/charts';\r\nimport { CanvasRenderer } from 'echarts/renderers';\r\necharts.use([\r\n  TitleComponent,\r\n  TooltipComponent,\r\n  GridComponent,\r\n  LineChart,\r\n  CanvasRenderer,\r\n  LegendComponent,\r\n  DataZoomComponent,\r\n  ToolboxComponent,\r\n]);\r\nexport type ECOption = ComposeOption<\r\n  | LineSeriesOption\r\n  | TitleComponentOption\r\n  | TooltipComponentOption\r\n  | GridComponentOption\r\n  | DatasetComponentOption\r\n  | LegendComponentOption\r\n  | ToolboxComponentOption\r\n>;\r\n\r\n@Directive({\r\n  selector: 'div[kiwi-chart]',\r\n  standalone: true\r\n})\r\nexport class KiwiChartDirective implements OnChanges, AfterViewInit {\r\n\r\n  /**\r\n   * The Chart Object rendered by the canvas. For all the available options refer \r\n   * to Chart interface in the models folder.\r\n   *\r\n   * @type {(Chart | null)}\r\n   * @memberof KiwiChartDirective\r\n   */\r\n  @Input({ required: true }) chart: Chart | null = null;\r\n\r\n  /**\r\n   * Width and Height of the chart area. The dimensions refer to the father component \r\n   * into which the kiwi-chart is inserted. For example in an empty page the width/height \r\n   * of the chart can take the whole available space in the page.\r\n   *\r\n   * @type {string}\r\n   * @memberof KiwiChartDirective\r\n   */\r\n  @Input() width: string = '100%';\r\n  @Input() height: string = '480px';\r\n\r\n  @Output() chartInit = new EventEmitter<ECharts>();\r\n\r\n  /**\r\n   * Output event used to emit to the father component the coordinates\r\n   * of the point clicked in the chart area. This functionality to be used must\r\n   * have the property \"clickToAddPoint\" in the Chart object set to true.\r\n   *\r\n   * @type {EventEmitter<BasePoint>}\r\n   * @memberof KiwiChartDirective\r\n   */\r\n  @Output() addPoint: EventEmitter<BasePoint> = new EventEmitter<BasePoint>();\r\n\r\n  /**\r\n   * When the cursor hovers the chart area it emits to the father component the\r\n   * x and y coordinates relative to the chart reference system.\r\n   *\r\n   * @type {EventEmitter<BasePoint>}\r\n   * @memberof KiwiChartDirective\r\n   */\r\n  @Output() chartHover: EventEmitter<BasePoint> = new EventEmitter<BasePoint>();\r\n\r\n  /**\r\n   * This property simply activates or not the dark theme of the chart\r\n   * defined by the Echarts library. In addition the background color can be custom\r\n   * so that the chart can match the background of the application in which it's used.\r\n   *\r\n   * @type {boolean}\r\n   * @memberof KiwiChartDirective\r\n   */\r\n  @Input() darkTheme: boolean = false;\r\n  @Input() darkThemeBackground: string | null = null;\r\n\r\n  /**\r\n   * The instance of the Chart.\r\n   *\r\n   * @type {ECharts}\r\n   * @memberof KiwiChartDirective\r\n   */\r\n  echartsInstance: ECharts | null = null;\r\n\r\n  /**\r\n   * Default number of decimals that can have\r\n   * the values on the x and y axes.\r\n   *\r\n   * @private\r\n   * @type {number}\r\n   * @memberof KiwiChartDirective\r\n   */\r\n  private readonly MAX_DECIMALS: number = 3;\r\n\r\n  private legendSelected: { [key: string]: boolean } = {};\r\n  private isLegendClicked: boolean = false;\r\n\r\n  /**\r\n   * Used to perform actions (as point addition based on the cursor position) on the chart.\r\n   *\r\n   * @type {(zrender.ZRenderType | null)}\r\n   * @memberof KiwiChartComponent\r\n   */\r\n  zr: zrender.ZRenderType | null = null;\r\n\r\n  /**\r\n  * If you resize the page, the chart is automatically re-rendered wiht the right proportions.\r\n  *\r\n  * @memberof EnchartingDirective\r\n  */\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize() {\r\n    if (this.echartsInstance) {\r\n      this.echartsInstance.resize();\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private el: ElementRef<HTMLDivElement>\r\n  ) { }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.chart) {\r\n      this.renderChart(this.chart);\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    let chart: Chart = changes['chart']?.currentValue;\r\n    if (this.echartsInstance) {\r\n      // Every time we have an external change we\r\n      // destroy the chart and re-initialize it\r\n      this.echartsInstance.dispose();\r\n      this.renderChart(chart);\r\n    }\r\n  }\r\n\r\n  renderChart(chart: Chart): void {\r\n    // Update ElementRef styles\r\n    this.el.nativeElement.style.width = this.width;\r\n    this.el.nativeElement.style.height = this.height;\r\n\r\n    this.echartsInstance = init(\r\n      this.el.nativeElement,\r\n      this.darkTheme ? 'dark' : 'default',\r\n      {\r\n        renderer: 'svg'\r\n      }\r\n    );\r\n\r\n    if (chart) {\r\n      this.echartsInstance.setOption({\r\n        title: {\r\n          text: chart.title,\r\n        },\r\n        grid: {\r\n          width: '70%'\r\n        },\r\n        backgroundColor: this.darkTheme ? this.darkThemeBackground ?? '#303030' : 'transparent', tooltip: {\r\n          axisPointer: {\r\n            type: 'cross',\r\n            crossStyle: {\r\n              color: '#bebebe'\r\n            }\r\n          }\r\n        },\r\n        toolbox: {\r\n          orient: 'horizontal',\r\n          left: 'center',\r\n          top: '25px',\r\n          feature: {\r\n            dataZoom: {\r\n              brushStyle: {\r\n                borderColor: '#000',\r\n                borderWidth: 1,\r\n                borderType: 'dashed'\r\n              },\r\n              emphasis: {\r\n                iconStyle: {\r\n                  textPosition: 'top',\r\n                  textPadding: 5\r\n                }\r\n              },\r\n              icon: {\r\n                zoom: ZOOM_IN,\r\n                back: ZOOM_OUT\r\n              },\r\n            },\r\n            saveAsImage: {\r\n              emphasis: {\r\n                iconStyle: {\r\n                  textPosition: 'top',\r\n                  textPadding: 5\r\n                }\r\n              },\r\n              icon: SAVE_AS_SVG,\r\n            },\r\n            restore: {\r\n              emphasis: {\r\n                iconStyle: {\r\n                  textPosition: 'top',\r\n                  textPadding: 5\r\n                }\r\n              },\r\n              icon: RESTORE,\r\n            },\r\n            myAddPoint: {\r\n              show: chart.clickToAddPoint ?? false,\r\n              title: chart.addPointCustomName ?? 'Add Point',\r\n              icon: ADD_POINT,\r\n              onclick: () => {\r\n                if (this.echartsInstance) {\r\n                  const option: ECOption = this.echartsInstance.getOption();\r\n                  const toolbox = option.toolbox as ToolboxComponentOption[];\r\n                  if (toolbox) {\r\n                    const status: boolean = toolbox[0].feature?.['myAddPoint']?.iconStatus;\r\n                    const offColor: string = 'rgb(102,102,102)';\r\n                    const highlightColor: string = 'rgb(62,152,197)';\r\n                    this.echartsInstance.setOption({\r\n                      toolbox: {\r\n                        feature: {\r\n                          myAddPoint: {\r\n                            iconStatus: !status,\r\n                            iconStyle: {\r\n                              borderColor: !status ? highlightColor : offColor\r\n                            }\r\n                          }\r\n                        }\r\n                      }\r\n                    });\r\n                  }\r\n                }\r\n              },\r\n              emphasis: {\r\n                iconStyle: {\r\n                  textPosition: 'top',\r\n                  textPadding: 5\r\n                }\r\n              }\r\n            }\r\n          },\r\n        },\r\n        dataZoom: [\r\n          {\r\n            type: 'inside',\r\n            xAxisIndex: [0],\r\n            throttle: 0,\r\n            filterMode: 'none',\r\n            disabled: !chart.scrollToZoom\r\n          },\r\n          {\r\n            type: 'inside',\r\n            yAxisIndex: [0],\r\n            throttle: 0,\r\n            filterMode: 'none',\r\n            disabled: !chart.scrollToZoom\r\n          },\r\n        ],\r\n        legend: {\r\n          inactiveColor: this.darkTheme ? '#8b8b8b' : '#ccc',\r\n          data: chart.shapes.map(\r\n            (shape: Shape) => ({\r\n              name: shape.name,\r\n              icon: 'circle',\r\n            })\r\n          ),\r\n          selected: chart.shapes.reduce(\r\n            (accumulator, shape: Shape) => ({\r\n              ...accumulator,\r\n              [shape.name as string]: this.getLegendItemSelection(shape),\r\n            }),\r\n            {}),\r\n          show: chart.showLegend ?? false,\r\n          orient: 'vertical',\r\n          left: 'right',\r\n          padding: [60, 20],\r\n          type: 'scroll',\r\n          textStyle: {\r\n            width: 120,\r\n            fontWeight: 'bold',\r\n            overflow: 'break'\r\n          }\r\n        },\r\n        xAxis: {\r\n          type: chart.xAxisType,\r\n          name: chart.xAxisUom ? `${chart.xAxisName} [ ${chart.xAxisUom} ]` : chart.xAxisName,\r\n          nameLocation: 'middle',\r\n          nameGap: 30,\r\n          splitLine: {\r\n            show: chart.showGrid ?? true,\r\n            lineStyle: {\r\n              color: this.darkTheme ? '#595959' : '#ccc'\r\n            }\r\n          },\r\n          min: chart.xMin?.toFixed(chart.maxAxesDecimals ?? this.MAX_DECIMALS),\r\n          max: chart.xMax?.toFixed(chart.maxAxesDecimals ?? this.MAX_DECIMALS),\r\n        },\r\n        yAxis: {\r\n          type: chart.yAxisType,\r\n          name: chart.yAxisUom ? `${chart.yAxisName} [ ${chart.yAxisUom} ]` : chart.yAxisName,\r\n          nameLocation: 'middle',\r\n          nameGap: 50,\r\n          splitLine: {\r\n            show: chart.showGrid ?? true,\r\n            lineStyle: {\r\n              color: this.darkTheme ? '#595959' : '#ccc'\r\n            }\r\n          },\r\n          min: chart.yMin?.toFixed(chart.maxAxesDecimals ?? this.MAX_DECIMALS),\r\n          max: chart.yMax?.toFixed(chart.maxAxesDecimals ?? this.MAX_DECIMALS),\r\n        },\r\n        series: this.createSeries(chart.shapes),\r\n        animation: chart.hasAnimations,\r\n        animationDuration: chart.animationDuration ?? 250,\r\n        animationEasing: 'cubicOut'\r\n      },\r\n        true,\r\n        true\r\n      );\r\n    }\r\n\r\n    this.setupZrEventHandler(this.echartsInstance);\r\n\r\n    this.setupLegendEventHandler(this.echartsInstance);\r\n  }\r\n\r\n  createSeries(shapes: Shape[]): Array<LineSeriesOption | CustomSeriesOption | ScatterSeriesOption> {\r\n    let series: Array<LineSeriesOption | CustomSeriesOption | ScatterSeriesOption> = [];\r\n    shapes.forEach(\r\n      (shape: Shape) => {\r\n        switch (shape.variant) {\r\n          case ShapeVariant.TRACE:\r\n            series.push(this.createTrace(shape as Trace))\r\n            break;\r\n          default:\r\n            break;\r\n        }\r\n      }\r\n    );\r\n    return series;\r\n  }\r\n\r\n  createTrace(trace: Trace): LineSeriesOption | ScatterSeriesOption {\r\n    return {\r\n      type: trace.type,\r\n      name: trace.name,\r\n      data: trace.points.map(\r\n        (point: Point) => ({\r\n          value: [point.x, point.y],\r\n          symbol: point.symbol ?? 'circle',\r\n          name: point.name,\r\n          symbolSize: point.symbolSize ?? 2,\r\n          itemStyle: {\r\n            color: point.color\r\n          },\r\n          emphasis: {\r\n            disabled: true\r\n          },\r\n          label: {\r\n            show: true,\r\n            position: 'bottom',\r\n            align: 'left',\r\n            verticalAlign: 'bottom',\r\n            formatter: () => `${point.name ?? ''}`,\r\n            fontSize: 13,\r\n            padding: [0, 0, 0, 10],\r\n            width: 100,\r\n            overflow: 'truncate',\r\n            ellipsis: '...',\r\n            fontWeight: 'bold',\r\n            color: this.darkTheme ? '#fff' : '#000'\r\n          },\r\n          tooltip: {\r\n            formatter: ({ value }: { value: number[] }) => `\r\n              <strong>${this.chart?.xAxisName}:</strong> ${value[0].toFixed(3).replace(/[.,]000$/, \"\")}\r\n              <br>\r\n              <strong>${this.chart?.yAxisName}:</strong> ${value[1].toFixed(3).replace(/[.,]000$/, \"\")}\r\n            `\r\n          }\r\n        })\r\n      ),\r\n      color: trace.color,\r\n      lineStyle: {\r\n        width: trace.width,\r\n        type: trace.style,\r\n        opacity: trace.opacity ?? 1\r\n      },\r\n      smooth: trace.smooth ?? false\r\n    };\r\n  }\r\n\r\n  getLegendItemSelection(shape: Shape): boolean {\r\n    if (this.isLegendClicked) {\r\n      return this.legendSelected[shape.name as string] ?? true;\r\n    }\r\n    else {\r\n      return shape.selectedByDefault ?? true\r\n    }\r\n  }\r\n\r\n  /**\r\n   * intercept a selection change event on the legend and save the state \r\n   * of all selections on the supporting variable legendSelected\r\n   * \r\n   * @param ec \r\n   */\r\n  setupLegendEventHandler(ec: ECharts) {\r\n    if (this.echartsInstance != null) {\r\n      this.echartsInstance.on('legendselectchanged', (params: any) => {\r\n        this.isLegendClicked = true;\r\n        this.legendSelected = params.selected;\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n  setupZrEventHandler(ec: ECharts) {\r\n    this.zr = ec.getZr();\r\n    /** \r\n     * Intercepts the click event on the chart (if the clickToAddPoint property is set to true)\r\n     * and emits the point coordinates to the father component.\r\n     */\r\n    this.zr.on('click', params => {\r\n      let option: any = ec.getOption();\r\n      let active = option?.toolbox?.[0]?.feature?.myAddPoint?.iconStatus;\r\n      if (active && this.chart?.clickToAddPoint) {\r\n        const pointInPixel = [params.offsetX, params.offsetY];\r\n        const pointInGrid = ec.convertFromPixel('grid', pointInPixel);\r\n        if (ec.containPixel('grid', pointInPixel) && pointInGrid) {\r\n          let newPoint: { x: number, y: number } = {\r\n            x: +pointInGrid[0].toFixed(3),\r\n            y: +pointInGrid[1].toFixed(3)\r\n          };\r\n          this.addPoint.emit(newPoint);\r\n        }\r\n      }\r\n    });\r\n    /** \r\n     * This is used perform custom actions when the mouse is hovering the chart area\r\n     */\r\n    this.zr.on('mousemove', params => {\r\n      const pointInPixel = [params.offsetX, params.offsetY];\r\n      const pointInGrid = ec.convertFromPixel('grid', pointInPixel);\r\n      /* \r\n       * Logic to emit to the father component the x and y cdinates when the\r\n       * cursor is hovering the chart area .\r\n       */\r\n      if (ec.containPixel('grid', pointInPixel) && pointInGrid) {\r\n        let newPoint: { x: number, y: number } = {\r\n          x: +pointInGrid[0].toFixed(3),\r\n          y: +pointInGrid[1].toFixed(3)\r\n        };\r\n        this.chartHover.emit(newPoint);\r\n      }\r\n      /* Logic to change the cursor icon when the \"Click to Add Point\" feature is active and viceversa. */\r\n      const option: any = ec.getOption();\r\n      const addPointIsActive = option?.toolbox?.[0]?.feature?.myAddPoint?.iconStatus;\r\n      if (addPointIsActive) {\r\n        this.zr?.setCursorStyle(\r\n          ec.containPixel('grid', pointInPixel) ? 'copy' : 'default'\r\n        );\r\n      }\r\n    });\r\n  }\r\n\r\n}\r\n"]}
|
|
@@ -25,4 +25,4 @@ export var ShapeVariant;
|
|
|
25
25
|
(function (ShapeVariant) {
|
|
26
26
|
ShapeVariant[ShapeVariant["TRACE"] = 0] = "TRACE";
|
|
27
27
|
})(ShapeVariant || (ShapeVariant = {}));
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQubW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l3aWJpdC9jaGFydC9zcmMvbGliL21vZGVscy9jaGFydC5tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkpBLE1BQU0sQ0FBTixJQUFZLFNBR1g7QUFIRCxXQUFZLFNBQVM7SUFDakIsMEJBQWEsQ0FBQTtJQUNiLGdDQUFtQixDQUFBO0FBQ3ZCLENBQUMsRUFIVyxTQUFTLEtBQVQsU0FBUyxRQUdwQjtBQUVELE1BQU0sQ0FBTixJQUFZLFdBTVg7QUFORCxXQUFZLFdBQVc7SUFDbkIsNEJBQWEsQ0FBQTtJQUNiLGdDQUFpQixDQUFBO0lBQ2pCLG9DQUFxQixDQUFBO0lBQ3JCLDBCQUFXLENBQUE7SUFDWCxrQ0FBbUIsQ0FBQTtBQUN2QixDQUFDLEVBTlcsV0FBVyxLQUFYLFdBQVcsUUFNdEI7QUFFRCxNQUFNLENBQU4sSUFBWSxVQUlYO0FBSkQsV0FBWSxVQUFVO0lBQ2xCLDZCQUFlLENBQUE7SUFDZiwrQkFBaUIsQ0FBQTtJQUNqQiwrQkFBaUIsQ0FBQTtBQUNyQixDQUFDLEVBSlcsVUFBVSxLQUFWLFVBQVUsUUFJckI7QUFFRCxNQUFNLENBQU4sSUFBWSxRQUVYO0FBRkQsV0FBWSxRQUFRO0lBQ2hCLDJCQUFlLENBQUE7QUFDbkIsQ0FBQyxFQUZXLFFBQVEsS0FBUixRQUFRLFFBRW5CO0FBRUQsTUFBTSxDQUFOLElBQVksWUFFWDtBQUZELFdBQVksWUFBWTtJQUNwQixpREFBSyxDQUFBO0FBQ1QsQ0FBQyxFQUZXLFlBQVksS0FBWixZQUFZLFFBRXZCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIEludGVyZmFjZSB0byBkZWZpbmUgdGhlIENoYXJ0IG1vZGVsLlxyXG4gKlxyXG4gKiBAZXhwb3J0XHJcbiAqIEBpbnRlcmZhY2UgQ2hhcnRcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ2hhcnQge1xyXG4gICAgdGl0bGU6IHN0cmluZztcclxuICAgIHNob3dMZWdlbmQ/OiBib29sZWFuO1xyXG4gICAgeEF4aXNUeXBlOiBBeGlzVHlwZTtcclxuICAgIHhBeGlzTmFtZTogc3RyaW5nO1xyXG4gICAgeEF4aXNVb20/OiBzdHJpbmc7XHJcbiAgICB4TWluPzogbnVtYmVyO1xyXG4gICAgeE1heD86IG51bWJlcjtcclxuICAgIHlBeGlzVHlwZTogQXhpc1R5cGU7XHJcbiAgICB5QXhpc05hbWU6IHN0cmluZztcclxuICAgIHlBeGlzVW9tPzogc3RyaW5nO1xyXG4gICAgeU1pbj86IG51bWJlcjtcclxuICAgIHlNYXg/OiBudW1iZXI7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSBtYXhpbXVtIGRlY2ltYWxzIHRoYXQgY2FuIGhhdmUgdGhlIHZhbHVlcyBvbiB0aGUgeCBhbmQgeSBheGVzLlxyXG4gICAgICogSWYgb21pdHRlZCB0aGUgZGVmYXVsdCBpcyAzIGRlY2ltYWxzLlxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtudW1iZXJ9XHJcbiAgICAgKiBAbWVtYmVyb2YgQ2hhcnRcclxuICAgICAqL1xyXG4gICAgbWF4QXhlc0RlY2ltYWxzPzogbnVtYmVyO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJZiB0aGUgY2hhcnQgc2hvdWxkIGhhdmUgcmVuZGVyaW5nIGFuaW1hdGlvbnMuXHJcbiAgICAgKlxyXG4gICAgICogQHR5cGUge2Jvb2xlYW59XHJcbiAgICAgKiBAbWVtYmVyb2YgQ2hhcnRcclxuICAgICAqL1xyXG4gICAgaGFzQW5pbWF0aW9ucz86IGJvb2xlYW47XHJcbiAgICAvKipcclxuICAgICAqIEhvdyBsb25nIHRoZSBhbmltYXRpb24gc2hvdWxkIGxhc3QuXHJcbiAgICAgKiBFeHByZXNzZWQgaW4gbWlsbGlzZWNvbmRzLiBJZiBvbWl0dGVkIHRoZSBEZWZhdWx0IGlzIDUwMCBtcy5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7bnVtYmVyfVxyXG4gICAgICogQG1lbWJlcm9mIENoYXJ0XHJcbiAgICAgKi9cclxuICAgIGFuaW1hdGlvbkR1cmF0aW9uPzogbnVtYmVyO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgbGlzdCBvZiBTaGFwZXMgdGhhdCB0aGUgY2hhcnQgbXVzdCByZW5kZXIuXHJcbiAgICAgKiBFYWNoIFNoYXBlIGNvcnJpc3BvbmRzIHRvIGEgc2luZ2xlIGNoYXJ0IGNvbXBvbmVudC5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7U2hhcGVbXX1cclxuICAgICAqIEBtZW1iZXJvZiBDaGFydFxyXG4gICAgICovXHJcbiAgICBzaGFwZXM6IFNoYXBlW107XHJcbiAgICAvKipcclxuICAgICAqIEFkZHMgaW50ZXJhY3Rpb24gd2l0aCB0aGUgY2hhcnQsIHNvIHRoYXQgd2hlbiBjbGlja2luZ1xyXG4gICAgICogZXZlcnl3aGVyZSBpbiB0aGUgY2hhcnQgYXJlYSBhIHBvaW50IGdldHMgYWRkZWQgYW5kIGl0J3MgY29vcmRpbmF0ZSBhcmUgXHJcbiAgICAgKiBlbWl0dGVkIHdpdGggYW4gZXZlbnQgdG8gdGhlIHBhcmVudCBjb21wb25lbnQuXHJcbiAgICAgKlxyXG4gICAgICogQHR5cGUge2Jvb2xlYW59XHJcbiAgICAgKiBAbWVtYmVyb2YgQ2hhcnRcclxuICAgICAqL1xyXG4gICAgY2xpY2tUb0FkZFBvaW50PzogYm9vbGVhbjtcclxuICAgIC8qKlxyXG4gICAgICogQ3VzdG9tIG5hbWUgZm9yIHRoZSBcImNsaWNrVG9BZGRQb2ludFwiIGV2ZW50IHJlbGF0ZWQgYnV0dG9uLiBcclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7c3RyaW5nfVxyXG4gICAgICogQG1lbWJlcm9mIENoYXJ0XHJcbiAgICAgKi9cclxuICAgIGFkZFBvaW50Q3VzdG9tTmFtZT86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogQWRkcyB0aGUgcG9zc2liaWxpdHkgdG8gdXNlIHRoZSBzY3JvbGwgXHJcbiAgICAgKiB0byB6b29tIGluL291dCB0aGUgY2hhcnQgYXJlYS5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7Ym9vbGVhbn1cclxuICAgICAqIEBtZW1iZXJvZiBDaGFydFxyXG4gICAgICovXHJcbiAgICBzY3JvbGxUb1pvb20/OiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUZWxscyB0aGUgY2hhcnQgdG8gcmVuZGVyIG9yIG5vdCB0aGUgZ3JpZCBsaW5lcy5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7Ym9vbGVhbn1cclxuICAgICAqIEBtZW1iZXJvZiBDaGFydFxyXG4gICAgICovXHJcbiAgICBzaG93R3JpZD86IGJvb2xlYW47XHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIFNoYXBlID0gVHJhY2U7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRyYWNlIHtcclxuICAgIG5hbWU/OiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSB2YXJpYW50IG9mIHRoZSBTaGFwZSwgbXVzdCBiZSBvZiB0eXBlIFRyYWNlLlxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtTaGFwZVZhcmlhbnR9XHJcbiAgICAgKiBAbWVtYmVyb2YgVHJhY2VcclxuICAgICAqL1xyXG4gICAgdmFyaWFudDogU2hhcGVWYXJpYW50O1xyXG4gICAgY29sb3I/OiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSB0eXBlIG9mIHRoZSBUcmFjZSBkcmF3biBieSB0aGUgY2hhcnQuXHJcbiAgICAgKiBDYW4gYmUgYSBsaW5lIG9yIGEgc2NhdHRlci4gXHJcbiAgICAgKlxyXG4gICAgICogQHR5cGUge1RyYWNlVHlwZX1cclxuICAgICAqIEBtZW1iZXJvZiBUcmFjZVxyXG4gICAgICovXHJcbiAgICB0eXBlOiBUcmFjZVR5cGU7XHJcbiAgICB3aWR0aD86IG51bWJlcjtcclxuICAgIC8qKlxyXG4gICAgICogVGhlIGxpc3Qgb2YgcG9pbnRzIHRoYXQgZGVmaW5lIHRoZSBUcmFjZS5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7UG9pbnRbXX1cclxuICAgICAqIEBtZW1iZXJvZiBUcmFjZVxyXG4gICAgICovXHJcbiAgICBwb2ludHM6IFBvaW50W107XHJcbiAgICAvKipcclxuICAgICAqIFdoZXRoZXIgdG8gc2hvdyBhIHNtb290aCBjdXJ2ZSBvciBhIHNlZ21lbnRlZCBjdXJ2ZS5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7Ym9vbGVhbn1cclxuICAgICAqIEBtZW1iZXJvZiBUcmFjZVxyXG4gICAgICovXHJcbiAgICBzbW9vdGg/OiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgc3R5bGUgb2YgdGhlIFRyYWNlLlxyXG4gICAgICogQ2FuIGJlIHNvbGlkLCBkYXNoZWQgb3IgZG90dGVkLlxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtUcmFjZVN0eWxlfVxyXG4gICAgICogQG1lbWJlcm9mIFRyYWNlXHJcbiAgICAgKi9cclxuICAgIHN0eWxlPzogVHJhY2VTdHlsZTtcclxuICAgIC8qKlxyXG4gICAgICogT3B0aW9uIHRvIG1ha2UgdGhlIFRyYWNlIHNlbGVjdGVkL2Rlc2VsZWN0ZWQgYnkgZGVmYXVsdC5cclxuICAgICAqIEEgZGVzZWxlY3RlZCBUcmFjZSBpcyBvYnNjdXJlZCBmcm9tIHRoZSBjaGFydCBhbmQgY2FuIGJlIHRvZ2dsZWQgZnJvbSB0aGUgbGVnZW5kLiAgIFxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtib29sZWFufVxyXG4gICAgICogQG1lbWJlcm9mIFRyYWNlXHJcbiAgICAgKi9cclxuICAgIHNlbGVjdGVkQnlEZWZhdWx0PzogYm9vbGVhbjtcclxuICAgIG9wYWNpdHk/
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQubW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l3aWJpdC9jaGFydC9zcmMvbGliL21vZGVscy9jaGFydC5tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkpBLE1BQU0sQ0FBTixJQUFZLFNBR1g7QUFIRCxXQUFZLFNBQVM7SUFDakIsMEJBQWEsQ0FBQTtJQUNiLGdDQUFtQixDQUFBO0FBQ3ZCLENBQUMsRUFIVyxTQUFTLEtBQVQsU0FBUyxRQUdwQjtBQUVELE1BQU0sQ0FBTixJQUFZLFdBTVg7QUFORCxXQUFZLFdBQVc7SUFDbkIsNEJBQWEsQ0FBQTtJQUNiLGdDQUFpQixDQUFBO0lBQ2pCLG9DQUFxQixDQUFBO0lBQ3JCLDBCQUFXLENBQUE7SUFDWCxrQ0FBbUIsQ0FBQTtBQUN2QixDQUFDLEVBTlcsV0FBVyxLQUFYLFdBQVcsUUFNdEI7QUFFRCxNQUFNLENBQU4sSUFBWSxVQUlYO0FBSkQsV0FBWSxVQUFVO0lBQ2xCLDZCQUFlLENBQUE7SUFDZiwrQkFBaUIsQ0FBQTtJQUNqQiwrQkFBaUIsQ0FBQTtBQUNyQixDQUFDLEVBSlcsVUFBVSxLQUFWLFVBQVUsUUFJckI7QUFFRCxNQUFNLENBQU4sSUFBWSxRQUVYO0FBRkQsV0FBWSxRQUFRO0lBQ2hCLDJCQUFlLENBQUE7QUFDbkIsQ0FBQyxFQUZXLFFBQVEsS0FBUixRQUFRLFFBRW5CO0FBRUQsTUFBTSxDQUFOLElBQVksWUFFWDtBQUZELFdBQVksWUFBWTtJQUNwQixpREFBSyxDQUFBO0FBQ1QsQ0FBQyxFQUZXLFlBQVksS0FBWixZQUFZLFFBRXZCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIEludGVyZmFjZSB0byBkZWZpbmUgdGhlIENoYXJ0IG1vZGVsLlxyXG4gKlxyXG4gKiBAZXhwb3J0XHJcbiAqIEBpbnRlcmZhY2UgQ2hhcnRcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ2hhcnQge1xyXG4gICAgdGl0bGU6IHN0cmluZztcclxuICAgIHNob3dMZWdlbmQ/OiBib29sZWFuO1xyXG4gICAgeEF4aXNUeXBlOiBBeGlzVHlwZTtcclxuICAgIHhBeGlzTmFtZTogc3RyaW5nO1xyXG4gICAgeEF4aXNVb20/OiBzdHJpbmc7XHJcbiAgICB4TWluPzogbnVtYmVyO1xyXG4gICAgeE1heD86IG51bWJlcjtcclxuICAgIHlBeGlzVHlwZTogQXhpc1R5cGU7XHJcbiAgICB5QXhpc05hbWU6IHN0cmluZztcclxuICAgIHlBeGlzVW9tPzogc3RyaW5nO1xyXG4gICAgeU1pbj86IG51bWJlcjtcclxuICAgIHlNYXg/OiBudW1iZXI7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSBtYXhpbXVtIGRlY2ltYWxzIHRoYXQgY2FuIGhhdmUgdGhlIHZhbHVlcyBvbiB0aGUgeCBhbmQgeSBheGVzLlxyXG4gICAgICogSWYgb21pdHRlZCB0aGUgZGVmYXVsdCBpcyAzIGRlY2ltYWxzLlxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtudW1iZXJ9XHJcbiAgICAgKiBAbWVtYmVyb2YgQ2hhcnRcclxuICAgICAqL1xyXG4gICAgbWF4QXhlc0RlY2ltYWxzPzogbnVtYmVyO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJZiB0aGUgY2hhcnQgc2hvdWxkIGhhdmUgcmVuZGVyaW5nIGFuaW1hdGlvbnMuXHJcbiAgICAgKlxyXG4gICAgICogQHR5cGUge2Jvb2xlYW59XHJcbiAgICAgKiBAbWVtYmVyb2YgQ2hhcnRcclxuICAgICAqL1xyXG4gICAgaGFzQW5pbWF0aW9ucz86IGJvb2xlYW47XHJcbiAgICAvKipcclxuICAgICAqIEhvdyBsb25nIHRoZSBhbmltYXRpb24gc2hvdWxkIGxhc3QuXHJcbiAgICAgKiBFeHByZXNzZWQgaW4gbWlsbGlzZWNvbmRzLiBJZiBvbWl0dGVkIHRoZSBEZWZhdWx0IGlzIDUwMCBtcy5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7bnVtYmVyfVxyXG4gICAgICogQG1lbWJlcm9mIENoYXJ0XHJcbiAgICAgKi9cclxuICAgIGFuaW1hdGlvbkR1cmF0aW9uPzogbnVtYmVyO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgbGlzdCBvZiBTaGFwZXMgdGhhdCB0aGUgY2hhcnQgbXVzdCByZW5kZXIuXHJcbiAgICAgKiBFYWNoIFNoYXBlIGNvcnJpc3BvbmRzIHRvIGEgc2luZ2xlIGNoYXJ0IGNvbXBvbmVudC5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7U2hhcGVbXX1cclxuICAgICAqIEBtZW1iZXJvZiBDaGFydFxyXG4gICAgICovXHJcbiAgICBzaGFwZXM6IFNoYXBlW107XHJcbiAgICAvKipcclxuICAgICAqIEFkZHMgaW50ZXJhY3Rpb24gd2l0aCB0aGUgY2hhcnQsIHNvIHRoYXQgd2hlbiBjbGlja2luZ1xyXG4gICAgICogZXZlcnl3aGVyZSBpbiB0aGUgY2hhcnQgYXJlYSBhIHBvaW50IGdldHMgYWRkZWQgYW5kIGl0J3MgY29vcmRpbmF0ZSBhcmUgXHJcbiAgICAgKiBlbWl0dGVkIHdpdGggYW4gZXZlbnQgdG8gdGhlIHBhcmVudCBjb21wb25lbnQuXHJcbiAgICAgKlxyXG4gICAgICogQHR5cGUge2Jvb2xlYW59XHJcbiAgICAgKiBAbWVtYmVyb2YgQ2hhcnRcclxuICAgICAqL1xyXG4gICAgY2xpY2tUb0FkZFBvaW50PzogYm9vbGVhbjtcclxuICAgIC8qKlxyXG4gICAgICogQ3VzdG9tIG5hbWUgZm9yIHRoZSBcImNsaWNrVG9BZGRQb2ludFwiIGV2ZW50IHJlbGF0ZWQgYnV0dG9uLiBcclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7c3RyaW5nfVxyXG4gICAgICogQG1lbWJlcm9mIENoYXJ0XHJcbiAgICAgKi9cclxuICAgIGFkZFBvaW50Q3VzdG9tTmFtZT86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogQWRkcyB0aGUgcG9zc2liaWxpdHkgdG8gdXNlIHRoZSBzY3JvbGwgXHJcbiAgICAgKiB0byB6b29tIGluL291dCB0aGUgY2hhcnQgYXJlYS5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7Ym9vbGVhbn1cclxuICAgICAqIEBtZW1iZXJvZiBDaGFydFxyXG4gICAgICovXHJcbiAgICBzY3JvbGxUb1pvb20/OiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUZWxscyB0aGUgY2hhcnQgdG8gcmVuZGVyIG9yIG5vdCB0aGUgZ3JpZCBsaW5lcy5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7Ym9vbGVhbn1cclxuICAgICAqIEBtZW1iZXJvZiBDaGFydFxyXG4gICAgICovXHJcbiAgICBzaG93R3JpZD86IGJvb2xlYW47XHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIFNoYXBlID0gVHJhY2U7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRyYWNlIHtcclxuICAgIG5hbWU/OiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSB2YXJpYW50IG9mIHRoZSBTaGFwZSwgbXVzdCBiZSBvZiB0eXBlIFRyYWNlLlxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtTaGFwZVZhcmlhbnR9XHJcbiAgICAgKiBAbWVtYmVyb2YgVHJhY2VcclxuICAgICAqL1xyXG4gICAgdmFyaWFudDogU2hhcGVWYXJpYW50O1xyXG4gICAgY29sb3I/OiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSB0eXBlIG9mIHRoZSBUcmFjZSBkcmF3biBieSB0aGUgY2hhcnQuXHJcbiAgICAgKiBDYW4gYmUgYSBsaW5lIG9yIGEgc2NhdHRlci4gXHJcbiAgICAgKlxyXG4gICAgICogQHR5cGUge1RyYWNlVHlwZX1cclxuICAgICAqIEBtZW1iZXJvZiBUcmFjZVxyXG4gICAgICovXHJcbiAgICB0eXBlOiBUcmFjZVR5cGU7XHJcbiAgICB3aWR0aD86IG51bWJlcjtcclxuICAgIC8qKlxyXG4gICAgICogVGhlIGxpc3Qgb2YgcG9pbnRzIHRoYXQgZGVmaW5lIHRoZSBUcmFjZS5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7UG9pbnRbXX1cclxuICAgICAqIEBtZW1iZXJvZiBUcmFjZVxyXG4gICAgICovXHJcbiAgICBwb2ludHM6IFBvaW50W107XHJcbiAgICAvKipcclxuICAgICAqIFdoZXRoZXIgdG8gc2hvdyBhIHNtb290aCBjdXJ2ZSBvciBhIHNlZ21lbnRlZCBjdXJ2ZS5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7Ym9vbGVhbn1cclxuICAgICAqIEBtZW1iZXJvZiBUcmFjZVxyXG4gICAgICovXHJcbiAgICBzbW9vdGg/OiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgc3R5bGUgb2YgdGhlIFRyYWNlLlxyXG4gICAgICogQ2FuIGJlIHNvbGlkLCBkYXNoZWQgb3IgZG90dGVkLlxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtUcmFjZVN0eWxlfVxyXG4gICAgICogQG1lbWJlcm9mIFRyYWNlXHJcbiAgICAgKi9cclxuICAgIHN0eWxlPzogVHJhY2VTdHlsZTtcclxuICAgIC8qKlxyXG4gICAgICogT3B0aW9uIHRvIG1ha2UgdGhlIFRyYWNlIHNlbGVjdGVkL2Rlc2VsZWN0ZWQgYnkgZGVmYXVsdC5cclxuICAgICAqIEEgZGVzZWxlY3RlZCBUcmFjZSBpcyBvYnNjdXJlZCBmcm9tIHRoZSBjaGFydCBhbmQgY2FuIGJlIHRvZ2dsZWQgZnJvbSB0aGUgbGVnZW5kLiAgIFxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtib29sZWFufVxyXG4gICAgICogQG1lbWJlcm9mIFRyYWNlXHJcbiAgICAgKi9cclxuICAgIHNlbGVjdGVkQnlEZWZhdWx0PzogYm9vbGVhbjtcclxuICAgIG9wYWNpdHk/OiBudW1iZXI7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgUG9pbnQgZXh0ZW5kcyBCYXNlUG9pbnQge1xyXG4gICAgbmFtZT86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogU3ltYm9sIHVzZWQgdG8gcmVwcmVzZW50IHRoZSBwb2ludCBpbiB0aGUgY2hhcnQuXHJcbiAgICAgKlxyXG4gICAgICogQHR5cGUge1BvaW50U3ltYm9sfVxyXG4gICAgICogQG1lbWJlcm9mIFBvaW50XHJcbiAgICAgKi9cclxuICAgIHN5bWJvbD86IFBvaW50U3ltYm9sO1xyXG4gICAgc3ltYm9sU2l6ZT86IG51bWJlcjtcclxuICAgIGNvbG9yPzogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEJhc2VQb2ludCB7XHJcbiAgICB4OiBudW1iZXI7XHJcbiAgICB5OiBudW1iZXJcclxufVxyXG5cclxuZXhwb3J0IGVudW0gVHJhY2VUeXBlIHtcclxuICAgIExJTkUgPSBcImxpbmVcIixcclxuICAgIFNDQVRURVIgPSBcInNjYXR0ZXJcIlxyXG59XHJcblxyXG5leHBvcnQgZW51bSBQb2ludFN5bWJvbCB7XHJcbiAgICBOT05FID0gXCJub25lXCIsXHJcbiAgICBDSVJDTEUgPSBcImNpcmNsZVwiLFxyXG4gICAgVFJJQU5HTEUgPSBcInRyaWFuZ2xlXCIsXHJcbiAgICBQSU4gPSBcInBpblwiLFxyXG4gICAgRElBTU9ORCA9IFwiZGlhbW9uZFwiXHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIFRyYWNlU3R5bGUge1xyXG4gICAgU09MSUQgPSBcInNvbGlkXCIsXHJcbiAgICBEQVNIRUQgPSBcImRhc2hlZFwiLFxyXG4gICAgRE9UVEVEID0gXCJkb3R0ZWRcIlxyXG59XHJcblxyXG5leHBvcnQgZW51bSBBeGlzVHlwZSB7XHJcbiAgICBWQUxVRSA9IFwidmFsdWVcIlxyXG59XHJcblxyXG5leHBvcnQgZW51bSBTaGFwZVZhcmlhbnQge1xyXG4gICAgVFJBQ0VcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgQ2hhcnRUaGVtZSA9ICdkZWZhdWx0JyB8ICdkYXJrJzsiXX0=
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -1,8 +1,6 @@
|
|
|
1
1
|
/*
|
|
2
2
|
* Public API Surface of chart
|
|
3
3
|
*/
|
|
4
|
-
export * from './lib/chart.component';
|
|
5
|
-
export * from './lib/chart.module';
|
|
4
|
+
export * from './lib/components/chart.component';
|
|
6
5
|
export * from './lib/models/chart.models';
|
|
7
|
-
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2tpd2liaXQvY2hhcnQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGlDQUFpQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGNoYXJ0XHJcbiAqL1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hhcnQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hhcnQubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2NoYXJ0Lm1vZGVscyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbnN0YW50cy9jaGFydC5jb25zdGFudHMnOyJdfQ==
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2tpd2liaXQvY2hhcnQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsMkJBQTJCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgY2hhcnRcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2NoYXJ0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9jaGFydC5tb2RlbHMnOyJdfQ==
|