@kiwibit/chart 18.0.2 → 20.0.0

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.
@@ -1,452 +0,0 @@
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"]}
@@ -1,28 +0,0 @@
1
- export var TraceType;
2
- (function (TraceType) {
3
- TraceType["LINE"] = "line";
4
- TraceType["SCATTER"] = "scatter";
5
- })(TraceType || (TraceType = {}));
6
- export var PointSymbol;
7
- (function (PointSymbol) {
8
- PointSymbol["NONE"] = "none";
9
- PointSymbol["CIRCLE"] = "circle";
10
- PointSymbol["TRIANGLE"] = "triangle";
11
- PointSymbol["PIN"] = "pin";
12
- PointSymbol["DIAMOND"] = "diamond";
13
- })(PointSymbol || (PointSymbol = {}));
14
- export var TraceStyle;
15
- (function (TraceStyle) {
16
- TraceStyle["SOLID"] = "solid";
17
- TraceStyle["DASHED"] = "dashed";
18
- TraceStyle["DOTTED"] = "dotted";
19
- })(TraceStyle || (TraceStyle = {}));
20
- export var AxisType;
21
- (function (AxisType) {
22
- AxisType["VALUE"] = "value";
23
- })(AxisType || (AxisType = {}));
24
- export var ShapeVariant;
25
- (function (ShapeVariant) {
26
- ShapeVariant[ShapeVariant["TRACE"] = 0] = "TRACE";
27
- })(ShapeVariant || (ShapeVariant = {}));
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQubW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l3aWJpdC9jaGFydC9zcmMvbGliL21vZGVscy9jaGFydC5tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkpBLE1BQU0sQ0FBTixJQUFZLFNBR1g7QUFIRCxXQUFZLFNBQVM7SUFDakIsMEJBQWEsQ0FBQTtJQUNiLGdDQUFtQixDQUFBO0FBQ3ZCLENBQUMsRUFIVyxTQUFTLEtBQVQsU0FBUyxRQUdwQjtBQUVELE1BQU0sQ0FBTixJQUFZLFdBTVg7QUFORCxXQUFZLFdBQVc7SUFDbkIsNEJBQWEsQ0FBQTtJQUNiLGdDQUFpQixDQUFBO0lBQ2pCLG9DQUFxQixDQUFBO0lBQ3JCLDBCQUFXLENBQUE7SUFDWCxrQ0FBbUIsQ0FBQTtBQUN2QixDQUFDLEVBTlcsV0FBVyxLQUFYLFdBQVcsUUFNdEI7QUFFRCxNQUFNLENBQU4sSUFBWSxVQUlYO0FBSkQsV0FBWSxVQUFVO0lBQ2xCLDZCQUFlLENBQUE7SUFDZiwrQkFBaUIsQ0FBQTtJQUNqQiwrQkFBaUIsQ0FBQTtBQUNyQixDQUFDLEVBSlcsVUFBVSxLQUFWLFVBQVUsUUFJckI7QUFFRCxNQUFNLENBQU4sSUFBWSxRQUVYO0FBRkQsV0FBWSxRQUFRO0lBQ2hCLDJCQUFlLENBQUE7QUFDbkIsQ0FBQyxFQUZXLFFBQVEsS0FBUixRQUFRLFFBRW5CO0FBRUQsTUFBTSxDQUFOLElBQVksWUFFWDtBQUZELFdBQVksWUFBWTtJQUNwQixpREFBSyxDQUFBO0FBQ1QsQ0FBQyxFQUZXLFlBQVksS0FBWixZQUFZLFFBRXZCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIEludGVyZmFjZSB0byBkZWZpbmUgdGhlIENoYXJ0IG1vZGVsLlxyXG4gKlxyXG4gKiBAZXhwb3J0XHJcbiAqIEBpbnRlcmZhY2UgQ2hhcnRcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ2hhcnQge1xyXG4gICAgdGl0bGU6IHN0cmluZztcclxuICAgIHNob3dMZWdlbmQ/OiBib29sZWFuO1xyXG4gICAgeEF4aXNUeXBlOiBBeGlzVHlwZTtcclxuICAgIHhBeGlzTmFtZTogc3RyaW5nO1xyXG4gICAgeEF4aXNVb20/OiBzdHJpbmc7XHJcbiAgICB4TWluPzogbnVtYmVyO1xyXG4gICAgeE1heD86IG51bWJlcjtcclxuICAgIHlBeGlzVHlwZTogQXhpc1R5cGU7XHJcbiAgICB5QXhpc05hbWU6IHN0cmluZztcclxuICAgIHlBeGlzVW9tPzogc3RyaW5nO1xyXG4gICAgeU1pbj86IG51bWJlcjtcclxuICAgIHlNYXg/OiBudW1iZXI7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSBtYXhpbXVtIGRlY2ltYWxzIHRoYXQgY2FuIGhhdmUgdGhlIHZhbHVlcyBvbiB0aGUgeCBhbmQgeSBheGVzLlxyXG4gICAgICogSWYgb21pdHRlZCB0aGUgZGVmYXVsdCBpcyAzIGRlY2ltYWxzLlxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtudW1iZXJ9XHJcbiAgICAgKiBAbWVtYmVyb2YgQ2hhcnRcclxuICAgICAqL1xyXG4gICAgbWF4QXhlc0RlY2ltYWxzPzogbnVtYmVyO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJZiB0aGUgY2hhcnQgc2hvdWxkIGhhdmUgcmVuZGVyaW5nIGFuaW1hdGlvbnMuXHJcbiAgICAgKlxyXG4gICAgICogQHR5cGUge2Jvb2xlYW59XHJcbiAgICAgKiBAbWVtYmVyb2YgQ2hhcnRcclxuICAgICAqL1xyXG4gICAgaGFzQW5pbWF0aW9ucz86IGJvb2xlYW47XHJcbiAgICAvKipcclxuICAgICAqIEhvdyBsb25nIHRoZSBhbmltYXRpb24gc2hvdWxkIGxhc3QuXHJcbiAgICAgKiBFeHByZXNzZWQgaW4gbWlsbGlzZWNvbmRzLiBJZiBvbWl0dGVkIHRoZSBEZWZhdWx0IGlzIDUwMCBtcy5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7bnVtYmVyfVxyXG4gICAgICogQG1lbWJlcm9mIENoYXJ0XHJcbiAgICAgKi9cclxuICAgIGFuaW1hdGlvbkR1cmF0aW9uPzogbnVtYmVyO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgbGlzdCBvZiBTaGFwZXMgdGhhdCB0aGUgY2hhcnQgbXVzdCByZW5kZXIuXHJcbiAgICAgKiBFYWNoIFNoYXBlIGNvcnJpc3BvbmRzIHRvIGEgc2luZ2xlIGNoYXJ0IGNvbXBvbmVudC5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7U2hhcGVbXX1cclxuICAgICAqIEBtZW1iZXJvZiBDaGFydFxyXG4gICAgICovXHJcbiAgICBzaGFwZXM6IFNoYXBlW107XHJcbiAgICAvKipcclxuICAgICAqIEFkZHMgaW50ZXJhY3Rpb24gd2l0aCB0aGUgY2hhcnQsIHNvIHRoYXQgd2hlbiBjbGlja2luZ1xyXG4gICAgICogZXZlcnl3aGVyZSBpbiB0aGUgY2hhcnQgYXJlYSBhIHBvaW50IGdldHMgYWRkZWQgYW5kIGl0J3MgY29vcmRpbmF0ZSBhcmUgXHJcbiAgICAgKiBlbWl0dGVkIHdpdGggYW4gZXZlbnQgdG8gdGhlIHBhcmVudCBjb21wb25lbnQuXHJcbiAgICAgKlxyXG4gICAgICogQHR5cGUge2Jvb2xlYW59XHJcbiAgICAgKiBAbWVtYmVyb2YgQ2hhcnRcclxuICAgICAqL1xyXG4gICAgY2xpY2tUb0FkZFBvaW50PzogYm9vbGVhbjtcclxuICAgIC8qKlxyXG4gICAgICogQ3VzdG9tIG5hbWUgZm9yIHRoZSBcImNsaWNrVG9BZGRQb2ludFwiIGV2ZW50IHJlbGF0ZWQgYnV0dG9uLiBcclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7c3RyaW5nfVxyXG4gICAgICogQG1lbWJlcm9mIENoYXJ0XHJcbiAgICAgKi9cclxuICAgIGFkZFBvaW50Q3VzdG9tTmFtZT86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogQWRkcyB0aGUgcG9zc2liaWxpdHkgdG8gdXNlIHRoZSBzY3JvbGwgXHJcbiAgICAgKiB0byB6b29tIGluL291dCB0aGUgY2hhcnQgYXJlYS5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7Ym9vbGVhbn1cclxuICAgICAqIEBtZW1iZXJvZiBDaGFydFxyXG4gICAgICovXHJcbiAgICBzY3JvbGxUb1pvb20/OiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUZWxscyB0aGUgY2hhcnQgdG8gcmVuZGVyIG9yIG5vdCB0aGUgZ3JpZCBsaW5lcy5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7Ym9vbGVhbn1cclxuICAgICAqIEBtZW1iZXJvZiBDaGFydFxyXG4gICAgICovXHJcbiAgICBzaG93R3JpZD86IGJvb2xlYW47XHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIFNoYXBlID0gVHJhY2U7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRyYWNlIHtcclxuICAgIG5hbWU/OiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSB2YXJpYW50IG9mIHRoZSBTaGFwZSwgbXVzdCBiZSBvZiB0eXBlIFRyYWNlLlxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtTaGFwZVZhcmlhbnR9XHJcbiAgICAgKiBAbWVtYmVyb2YgVHJhY2VcclxuICAgICAqL1xyXG4gICAgdmFyaWFudDogU2hhcGVWYXJpYW50O1xyXG4gICAgY29sb3I/OiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSB0eXBlIG9mIHRoZSBUcmFjZSBkcmF3biBieSB0aGUgY2hhcnQuXHJcbiAgICAgKiBDYW4gYmUgYSBsaW5lIG9yIGEgc2NhdHRlci4gXHJcbiAgICAgKlxyXG4gICAgICogQHR5cGUge1RyYWNlVHlwZX1cclxuICAgICAqIEBtZW1iZXJvZiBUcmFjZVxyXG4gICAgICovXHJcbiAgICB0eXBlOiBUcmFjZVR5cGU7XHJcbiAgICB3aWR0aD86IG51bWJlcjtcclxuICAgIC8qKlxyXG4gICAgICogVGhlIGxpc3Qgb2YgcG9pbnRzIHRoYXQgZGVmaW5lIHRoZSBUcmFjZS5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7UG9pbnRbXX1cclxuICAgICAqIEBtZW1iZXJvZiBUcmFjZVxyXG4gICAgICovXHJcbiAgICBwb2ludHM6IFBvaW50W107XHJcbiAgICAvKipcclxuICAgICAqIFdoZXRoZXIgdG8gc2hvdyBhIHNtb290aCBjdXJ2ZSBvciBhIHNlZ21lbnRlZCBjdXJ2ZS5cclxuICAgICAqXHJcbiAgICAgKiBAdHlwZSB7Ym9vbGVhbn1cclxuICAgICAqIEBtZW1iZXJvZiBUcmFjZVxyXG4gICAgICovXHJcbiAgICBzbW9vdGg/OiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgc3R5bGUgb2YgdGhlIFRyYWNlLlxyXG4gICAgICogQ2FuIGJlIHNvbGlkLCBkYXNoZWQgb3IgZG90dGVkLlxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtUcmFjZVN0eWxlfVxyXG4gICAgICogQG1lbWJlcm9mIFRyYWNlXHJcbiAgICAgKi9cclxuICAgIHN0eWxlPzogVHJhY2VTdHlsZTtcclxuICAgIC8qKlxyXG4gICAgICogT3B0aW9uIHRvIG1ha2UgdGhlIFRyYWNlIHNlbGVjdGVkL2Rlc2VsZWN0ZWQgYnkgZGVmYXVsdC5cclxuICAgICAqIEEgZGVzZWxlY3RlZCBUcmFjZSBpcyBvYnNjdXJlZCBmcm9tIHRoZSBjaGFydCBhbmQgY2FuIGJlIHRvZ2dsZWQgZnJvbSB0aGUgbGVnZW5kLiAgIFxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtib29sZWFufVxyXG4gICAgICogQG1lbWJlcm9mIFRyYWNlXHJcbiAgICAgKi9cclxuICAgIHNlbGVjdGVkQnlEZWZhdWx0PzogYm9vbGVhbjtcclxuICAgIG9wYWNpdHk/OiBudW1iZXI7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgUG9pbnQgZXh0ZW5kcyBCYXNlUG9pbnQge1xyXG4gICAgbmFtZT86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogU3ltYm9sIHVzZWQgdG8gcmVwcmVzZW50IHRoZSBwb2ludCBpbiB0aGUgY2hhcnQuXHJcbiAgICAgKlxyXG4gICAgICogQHR5cGUge1BvaW50U3ltYm9sfVxyXG4gICAgICogQG1lbWJlcm9mIFBvaW50XHJcbiAgICAgKi9cclxuICAgIHN5bWJvbD86IFBvaW50U3ltYm9sO1xyXG4gICAgc3ltYm9sU2l6ZT86IG51bWJlcjtcclxuICAgIGNvbG9yPzogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEJhc2VQb2ludCB7XHJcbiAgICB4OiBudW1iZXI7XHJcbiAgICB5OiBudW1iZXJcclxufVxyXG5cclxuZXhwb3J0IGVudW0gVHJhY2VUeXBlIHtcclxuICAgIExJTkUgPSBcImxpbmVcIixcclxuICAgIFNDQVRURVIgPSBcInNjYXR0ZXJcIlxyXG59XHJcblxyXG5leHBvcnQgZW51bSBQb2ludFN5bWJvbCB7XHJcbiAgICBOT05FID0gXCJub25lXCIsXHJcbiAgICBDSVJDTEUgPSBcImNpcmNsZVwiLFxyXG4gICAgVFJJQU5HTEUgPSBcInRyaWFuZ2xlXCIsXHJcbiAgICBQSU4gPSBcInBpblwiLFxyXG4gICAgRElBTU9ORCA9IFwiZGlhbW9uZFwiXHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIFRyYWNlU3R5bGUge1xyXG4gICAgU09MSUQgPSBcInNvbGlkXCIsXHJcbiAgICBEQVNIRUQgPSBcImRhc2hlZFwiLFxyXG4gICAgRE9UVEVEID0gXCJkb3R0ZWRcIlxyXG59XHJcblxyXG5leHBvcnQgZW51bSBBeGlzVHlwZSB7XHJcbiAgICBWQUxVRSA9IFwidmFsdWVcIlxyXG59XHJcblxyXG5leHBvcnQgZW51bSBTaGFwZVZhcmlhbnQge1xyXG4gICAgVFJBQ0VcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgQ2hhcnRUaGVtZSA9ICdkZWZhdWx0JyB8ICdkYXJrJzsiXX0=
@@ -1,6 +0,0 @@
1
- /*
2
- * Public API Surface of chart
3
- */
4
- export * from './lib/components/chart.component';
5
- export * from './lib/models/chart.models';
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2tpd2liaXQvY2hhcnQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsMkJBQTJCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgY2hhcnRcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2NoYXJ0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9jaGFydC5tb2RlbHMnOyJdfQ==