@kiwibit/chart 15.0.1 → 17.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.
package/README.md CHANGED
@@ -4,6 +4,10 @@
4
4
 
5
5
  ### Latest versions @npm:
6
6
 
7
+ > **v17.x** for Angular >= **17.x**
8
+ >
9
+ > **v16.x** for Angular >= **16.x**
10
+ >
7
11
  > **v15.x** for Angular >= **15.x**
8
12
  >
9
13
  > **v14.x** for Angular >= **14.x**
@@ -53,6 +57,14 @@ npm install @kiwibit/chart
53
57
 
54
58
  # Latest Updates
55
59
 
60
+ ## [17.0.0] - 2024-03-21
61
+ ### Added
62
+ - Upgrade to Angular 17.
63
+
64
+ ## [16.0.0] - 2024-03-05
65
+ ### Added
66
+ - Upgrade to Angular 16.
67
+
56
68
  ## [15.0.1] - 2022-11-30
57
69
  ### Added
58
70
  - Added initial chart configuration if not passed as an input to the chart, in order to suppress the echarts warning.
@@ -1,5 +1,5 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './public-api';
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
5
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2l3aWJpdC1jaGFydC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2tpd2liaXQvY2hhcnQvc3JjL2tpd2liaXQtY2hhcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -0,0 +1,456 @@
1
+ // Angular General
2
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
3
+ import { interval, Subject, takeUntil } from 'rxjs';
4
+ // Kiwi Chart
5
+ import { ADD_POINT_IMG_OFF_DARK, ADD_POINT_IMG_OFF_LIGHT, ADD_POINT_IMG_ON } from './constants/chart.constants';
6
+ import { ShapeVariant, TraceType } from './models/chart.models';
7
+ import { NgStyle } from '@angular/common';
8
+ import { NgxEchartsDirective } from 'ngx-echarts';
9
+ import * as i0 from "@angular/core";
10
+ export class KiwiChartComponent {
11
+ constructor(cd) {
12
+ this.cd = cd;
13
+ /**
14
+ * The Chart Object rendered by the canvas. For all the available options refer
15
+ * to Chart interface in the models folder.
16
+ *
17
+ * @type {(Chart | null)}
18
+ * @memberof KiwiChartComponent
19
+ */
20
+ this.chart = null;
21
+ /**
22
+ * Width and Height of the chart area. The dimensions refer to the father component
23
+ * into which the kiwi-chart is inserted. For example in an empty page the width/height
24
+ * of the chart can take the whole available space in the page.
25
+ *
26
+ * @type {string}
27
+ * @memberof KiwiChartComponent
28
+ */
29
+ this.width = '100%';
30
+ this.height = '480px';
31
+ /**
32
+ * This property simply activates or not the dark theme of the chart
33
+ * defined by the Echarts library. In addition the background color can be custom
34
+ * so that the chart can match the background of the application in which it's used.
35
+ *
36
+ * @type {boolean}
37
+ * @memberof KiwiChartComponent
38
+ */
39
+ this.darkTheme = false;
40
+ /**
41
+ * Output event used to emit to the father component the coordinates
42
+ * of the point clicked in the chart area. This functionality to be used must
43
+ * have the property "clickToAddPoint" in the Chart object set to true.
44
+ *
45
+ * @type {EventEmitter<BasePoint>}
46
+ * @memberof KiwiChartComponent
47
+ */
48
+ this.addPoint = new EventEmitter();
49
+ /**
50
+ * When the cursor hovers the chart area it emits to the father component the
51
+ * x and y coordinates relative to the chart reference system.
52
+ *
53
+ * @type {EventEmitter<BasePoint>}
54
+ * @memberof KiwiChartComponent
55
+ */
56
+ this.chartHover = new EventEmitter();
57
+ /**
58
+ * The object used by echarts to initially create the Chart.
59
+ * Has a default configuration that can be totally overrided using specific properties.
60
+ *
61
+ * @type {EChartsOption}
62
+ * @memberof KiwiChartComponent
63
+ */
64
+ this.chartOption = {
65
+ title: {
66
+ text: 'Kiwi Chart'
67
+ },
68
+ xAxis: {
69
+ name: 'X'
70
+ },
71
+ yAxis: {
72
+ name: 'Y'
73
+ },
74
+ series: [
75
+ {
76
+ type: TraceType.LINE,
77
+ data: [[0, 0]]
78
+ }
79
+ ]
80
+ };
81
+ /**
82
+ * The instance of the Chart.
83
+ *
84
+ * @type {(ECharts | null)}
85
+ * @memberof KiwiChartComponent
86
+ */
87
+ this.echartsInstance = null;
88
+ /**
89
+ * Used to perform actions (as point addition based on the cursor position) on the chart.
90
+ *
91
+ * @type {(zrender.ZRenderType | null)}
92
+ * @memberof KiwiChartComponent
93
+ */
94
+ this.zr = null;
95
+ /**
96
+ * Subject used to unsubscribe once the component gets destroyed.
97
+ *
98
+ * @private
99
+ * @type {Subject<void>}
100
+ * @memberof KiwiChartComponent
101
+ */
102
+ this.destroyed$ = new Subject();
103
+ /**
104
+ * Default number of decimals that can have
105
+ * the values on the x and y axes.
106
+ *
107
+ * @private
108
+ * @type {number}
109
+ * @memberof KiwiChartComponent
110
+ */
111
+ this.MAX_DECIMALS = 3;
112
+ this.legendSelected = {};
113
+ this.isLegendClicked = false;
114
+ }
115
+ ngOnInit() {
116
+ /**
117
+ * This is a manual change detection running every 200ms, the memory should not be much afflicted.
118
+ * It's necessary because when interacting with the chart (for example addPoint),
119
+ * Angular loses the change detection and the point is not added in the chart canvas.
120
+ */
121
+ interval(200)
122
+ .pipe(takeUntil(this.destroyed$))
123
+ .subscribe({
124
+ next: () => {
125
+ this.cd.detectChanges();
126
+ }
127
+ });
128
+ }
129
+ onChartInit(ec) {
130
+ this.echartsInstance = ec;
131
+ this.setupZrEventHandler(ec);
132
+ this.setupLegendEventHandler(ec);
133
+ }
134
+ /**
135
+ * intercept a selection change event on the legend and save the state
136
+ * of all selections on the supporting variable legendSelected
137
+ *
138
+ * @param ec
139
+ */
140
+ setupLegendEventHandler(ec) {
141
+ if (this.echartsInstance != null) {
142
+ this.echartsInstance.on('legendselectchanged', (params) => {
143
+ this.isLegendClicked = true;
144
+ this.legendSelected = params.selected;
145
+ });
146
+ }
147
+ }
148
+ setupZrEventHandler(ec) {
149
+ this.zr = ec.getZr();
150
+ /**
151
+ * Intercepts the click event on the chart (if the clickToAddPoint property is set to true)
152
+ * and emits the point coordinates to the father component.
153
+ */
154
+ this.zr.on('click', params => {
155
+ let option = ec.getOption();
156
+ let active = option?.toolbox?.[0]?.feature?.myAddPoint?.iconStatus;
157
+ if (active && this.chart?.clickToAddPoint) {
158
+ const pointInPixel = [params.offsetX, params.offsetY];
159
+ const pointInGrid = ec.convertFromPixel('grid', pointInPixel);
160
+ if (ec.containPixel('grid', pointInPixel) && pointInGrid) {
161
+ let newPoint = {
162
+ x: +pointInGrid[0].toFixed(3),
163
+ y: +pointInGrid[1].toFixed(3)
164
+ };
165
+ this.addPoint.emit(newPoint);
166
+ }
167
+ }
168
+ });
169
+ /**
170
+ * This is used perform custom actions when the mouse is hovering the chart area
171
+ */
172
+ this.zr.on('mousemove', params => {
173
+ const pointInPixel = [params.offsetX, params.offsetY];
174
+ const pointInGrid = ec.convertFromPixel('grid', pointInPixel);
175
+ /*
176
+ * Logic to emit to the father component the x and y cdinates when the
177
+ * cursor is hovering the chart area .
178
+ */
179
+ if (ec.containPixel('grid', pointInPixel) && pointInGrid) {
180
+ let newPoint = {
181
+ x: +pointInGrid[0].toFixed(3),
182
+ y: +pointInGrid[1].toFixed(3)
183
+ };
184
+ this.chartHover.emit(newPoint);
185
+ }
186
+ /* Logic to change the cursor icon when the "Click to Add Point" feature is active and viceversa. */
187
+ const option = ec.getOption();
188
+ const addPointIsActive = option?.toolbox?.[0]?.feature?.myAddPoint?.iconStatus;
189
+ if (addPointIsActive) {
190
+ this.zr?.setCursorStyle(ec.containPixel('grid', pointInPixel) ? 'copy' : 'default');
191
+ }
192
+ });
193
+ }
194
+ getLegendItemSelection(shape) {
195
+ if (this.isLegendClicked) {
196
+ return this.legendSelected[shape.name] ?? true;
197
+ }
198
+ else {
199
+ return shape.selectedByDefault ?? true;
200
+ }
201
+ }
202
+ ngOnChanges(changes) {
203
+ let chart = changes['chart']?.currentValue;
204
+ if (chart) {
205
+ this.chartOption = {
206
+ title: {
207
+ text: chart.title,
208
+ },
209
+ grid: {
210
+ width: '70%'
211
+ },
212
+ backgroundColor: this.darkTheme ? this.darkThemeBackground ?? '#303030' : 'transparent', tooltip: {
213
+ axisPointer: {
214
+ type: 'cross',
215
+ crossStyle: {
216
+ color: '#bebebe'
217
+ }
218
+ }
219
+ },
220
+ toolbox: {
221
+ orient: 'horizontal',
222
+ left: 'center',
223
+ top: '25px',
224
+ feature: {
225
+ dataZoom: {
226
+ brushStyle: {
227
+ borderColor: '#000',
228
+ borderWidth: 1,
229
+ borderType: 'dashed'
230
+ },
231
+ emphasis: {
232
+ iconStyle: {
233
+ textPosition: 'top'
234
+ }
235
+ }
236
+ },
237
+ saveAsImage: {
238
+ emphasis: {
239
+ iconStyle: {
240
+ textPosition: 'top'
241
+ }
242
+ }
243
+ },
244
+ restore: {
245
+ emphasis: {
246
+ iconStyle: {
247
+ textPosition: 'top'
248
+ }
249
+ }
250
+ },
251
+ myAddPoint: {
252
+ show: chart.clickToAddPoint ?? false,
253
+ title: chart.addPointCustomName ?? 'Add Point',
254
+ icon: this.darkTheme ? ADD_POINT_IMG_OFF_DARK : ADD_POINT_IMG_OFF_LIGHT,
255
+ iconStatus: false,
256
+ onclick: () => {
257
+ let option = this.echartsInstance?.getOption();
258
+ let status = option.toolbox[0].feature.myAddPoint.iconStatus;
259
+ this.echartsInstance?.setOption({
260
+ toolbox: {
261
+ feature: {
262
+ myAddPoint: {
263
+ iconStatus: !status,
264
+ icon: !status ? ADD_POINT_IMG_ON : this.darkTheme ? ADD_POINT_IMG_OFF_DARK : ADD_POINT_IMG_OFF_LIGHT
265
+ }
266
+ }
267
+ }
268
+ });
269
+ },
270
+ emphasis: {
271
+ iconStyle: {
272
+ textPosition: 'top'
273
+ }
274
+ }
275
+ }
276
+ },
277
+ },
278
+ dataZoom: [
279
+ {
280
+ type: 'inside',
281
+ xAxisIndex: [0],
282
+ throttle: 0,
283
+ filterMode: 'none',
284
+ disabled: !chart.scrollToZoom
285
+ },
286
+ {
287
+ type: 'inside',
288
+ yAxisIndex: [0],
289
+ throttle: 0,
290
+ filterMode: 'none',
291
+ disabled: !chart.scrollToZoom
292
+ },
293
+ ],
294
+ legend: {
295
+ inactiveColor: this.darkTheme ? '#8b8b8b' : '#ccc',
296
+ data: chart.shapes.map((shape) => ({
297
+ name: shape.name,
298
+ icon: 'circle',
299
+ })),
300
+ selected: chart.shapes.reduce((accumulator, shape) => ({
301
+ ...accumulator,
302
+ [shape.name]: this.getLegendItemSelection(shape),
303
+ }), {}),
304
+ show: chart.showLegend ?? false,
305
+ orient: 'vertical',
306
+ left: 'right',
307
+ padding: [60, 20],
308
+ type: 'scroll',
309
+ textStyle: {
310
+ width: 120,
311
+ fontWeight: 'bold',
312
+ overflow: 'break'
313
+ }
314
+ },
315
+ xAxis: {
316
+ type: chart.xAxisType,
317
+ name: chart.xAxisUom ? `${chart.xAxisName} [ ${chart.xAxisUom} ]` : chart.xAxisName,
318
+ nameLocation: 'middle',
319
+ nameGap: 30,
320
+ splitLine: {
321
+ show: chart.showGrid ?? true,
322
+ lineStyle: {
323
+ color: this.darkTheme ? '#595959' : '#ccc'
324
+ }
325
+ },
326
+ min: chart.xMin?.toFixed(chart.maxAxesDecimals ?? this.MAX_DECIMALS),
327
+ max: chart.xMax?.toFixed(chart.maxAxesDecimals ?? this.MAX_DECIMALS),
328
+ },
329
+ yAxis: {
330
+ type: chart.yAxisType,
331
+ name: chart.yAxisUom ? `${chart.yAxisName} [ ${chart.yAxisUom} ]` : chart.yAxisName,
332
+ nameLocation: 'middle',
333
+ nameGap: 50,
334
+ splitLine: {
335
+ show: chart.showGrid ?? true,
336
+ lineStyle: {
337
+ color: this.darkTheme ? '#595959' : '#ccc'
338
+ }
339
+ },
340
+ min: chart.yMin?.toFixed(chart.maxAxesDecimals ?? this.MAX_DECIMALS),
341
+ max: chart.yMax?.toFixed(chart.maxAxesDecimals ?? this.MAX_DECIMALS),
342
+ },
343
+ series: this.createSeries(chart.shapes),
344
+ animation: chart.hasAnimations,
345
+ animationDuration: chart.animationDuration ?? 500,
346
+ animationEasing: 'cubicOut'
347
+ };
348
+ }
349
+ }
350
+ createSeries(shapes) {
351
+ let series = [];
352
+ shapes.forEach((shape) => {
353
+ switch (shape.variant) {
354
+ case ShapeVariant.TRACE:
355
+ series.push(this.createTrace(shape));
356
+ break;
357
+ default:
358
+ break;
359
+ }
360
+ });
361
+ return series;
362
+ }
363
+ createTrace(trace) {
364
+ return {
365
+ type: trace.type,
366
+ name: trace.name,
367
+ data: trace.points.map((point) => ({
368
+ value: [point.x, point.y],
369
+ symbol: point.symbol ?? 'circle',
370
+ name: point.name,
371
+ symbolSize: point.symbolSize ?? 2,
372
+ itemStyle: {
373
+ color: point.color
374
+ },
375
+ emphasis: {
376
+ disabled: true
377
+ },
378
+ label: {
379
+ show: true,
380
+ position: 'bottom',
381
+ align: 'left',
382
+ verticalAlign: 'bottom',
383
+ formatter: () => `${point.name ?? ''}`,
384
+ fontSize: 13,
385
+ padding: [0, 0, 0, 10],
386
+ width: 100,
387
+ overflow: 'truncate',
388
+ ellipsis: '...',
389
+ fontWeight: 'bold',
390
+ color: this.darkTheme ? '#fff' : '#000'
391
+ },
392
+ tooltip: {
393
+ formatter: ({ value }) => `
394
+ <strong>${this.chart?.xAxisName}:</strong> ${value[0].toFixed(3).replace(/[.,]000$/, "")}
395
+ <br>
396
+ <strong>${this.chart?.yAxisName}:</strong> ${value[1].toFixed(3).replace(/[.,]000$/, "")}
397
+ `
398
+ }
399
+ })),
400
+ color: trace.color,
401
+ lineStyle: {
402
+ width: trace.width,
403
+ type: trace.style,
404
+ opacity: trace.opacity ?? 1
405
+ },
406
+ smooth: trace.smooth ?? false
407
+ };
408
+ }
409
+ ngOnDestroy() {
410
+ this.destroyed$.next();
411
+ this.destroyed$.complete();
412
+ }
413
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.1", ngImport: i0, type: KiwiChartComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
414
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.1", type: KiwiChartComponent, isStandalone: true, selector: "kiwi-chart", inputs: { chart: "chart", width: "width", height: "height", darkTheme: "darkTheme", darkThemeBackground: "darkThemeBackground" }, outputs: { addPoint: "addPoint", chartHover: "chartHover" }, usesOnChanges: true, ngImport: i0, template: `
415
+ <div
416
+ echarts
417
+ [options]="chartOption"
418
+ [ngStyle]="{
419
+ 'width': width,
420
+ 'height': height
421
+ }"
422
+ (chartInit)="onChartInit($event)"
423
+ [theme]="darkTheme ? 'dark' : ''"
424
+ ></div>
425
+ `, isInline: true, styles: [""], dependencies: [{ kind: "directive", type: NgxEchartsDirective, selector: "echarts, [echarts]", inputs: ["options", "theme", "initOpts", "merge", "autoResize", "loading", "loadingType", "loadingOpts"], outputs: ["chartInit", "optionsError", "chartClick", "chartDblClick", "chartMouseDown", "chartMouseMove", "chartMouseUp", "chartMouseOver", "chartMouseOut", "chartGlobalOut", "chartContextMenu", "chartHighlight", "chartDownplay", "chartSelectChanged", "chartLegendSelectChanged", "chartLegendSelected", "chartLegendUnselected", "chartLegendLegendSelectAll", "chartLegendLegendInverseSelect", "chartLegendScroll", "chartDataZoom", "chartDataRangeSelected", "chartGraphRoam", "chartGeoRoam", "chartTreeRoam", "chartTimelineChanged", "chartTimelinePlayChanged", "chartRestore", "chartDataViewChanged", "chartMagicTypeChanged", "chartGeoSelectChanged", "chartGeoSelected", "chartGeoUnselected", "chartAxisAreaSelected", "chartBrush", "chartBrushEnd", "chartBrushSelected", "chartGlobalCursorTaken", "chartRendered", "chartFinished"], exportAs: ["echarts"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
426
+ }
427
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.1", ngImport: i0, type: KiwiChartComponent, decorators: [{
428
+ type: Component,
429
+ args: [{ selector: 'kiwi-chart', template: `
430
+ <div
431
+ echarts
432
+ [options]="chartOption"
433
+ [ngStyle]="{
434
+ 'width': width,
435
+ 'height': height
436
+ }"
437
+ (chartInit)="onChartInit($event)"
438
+ [theme]="darkTheme ? 'dark' : ''"
439
+ ></div>
440
+ `, standalone: true, imports: [NgxEchartsDirective, NgStyle] }]
441
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { chart: [{
442
+ type: Input
443
+ }], width: [{
444
+ type: Input
445
+ }], height: [{
446
+ type: Input
447
+ }], darkTheme: [{
448
+ type: Input
449
+ }], darkThemeBackground: [{
450
+ type: Input
451
+ }], addPoint: [{
452
+ type: Output
453
+ }], chartHover: [{
454
+ type: Output
455
+ }] } });
456
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.component.js","sourceRoot":"","sources":["../../../../../projects/kiwibit/chart/src/lib/chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular General\r\nimport { ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { interval, Subject, takeUntil } from 'rxjs';\r\n// Echarts\r\nimport { CustomSeriesOption, ECharts, EChartsOption, LineSeriesOption, ScatterSeriesOption, zrender } from 'echarts';\r\n// Kiwi Chart\r\nimport { ADD_POINT_IMG_OFF_DARK, ADD_POINT_IMG_OFF_LIGHT, ADD_POINT_IMG_ON } from './constants/chart.constants';\r\nimport { Chart, Shape, ShapeVariant, Trace, Point, BasePoint, TraceType } from './models/chart.models';\r\nimport { NgStyle } from '@angular/common';\r\nimport { NgxEchartsDirective } from 'ngx-echarts';\r\n@Component({\r\n  selector: 'kiwi-chart',\r\n  template: `\r\n    <div \r\n      echarts \r\n      [options]=\"chartOption\" \r\n      [ngStyle]=\"{\r\n        'width': width,\r\n        'height': height\r\n      }\"\r\n      (chartInit)=\"onChartInit($event)\"\r\n      [theme]=\"darkTheme ? 'dark' : ''\"\r\n    ></div> \r\n  `,\r\n  styles: [`\r\n  `],\r\n  standalone: true,\r\n  imports: [NgxEchartsDirective, NgStyle]\r\n})\r\nexport class KiwiChartComponent implements OnInit, OnChanges, OnDestroy {\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 KiwiChartComponent\r\n   */\r\n  @Input() 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 KiwiChartComponent\r\n   */\r\n  @Input() width: string = '100%';\r\n  @Input() height: string = '480px';\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 KiwiChartComponent\r\n   */\r\n  @Input() darkTheme: boolean = false;\r\n  @Input() darkThemeBackground?: string;\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 KiwiChartComponent\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 KiwiChartComponent\r\n   */\r\n  @Output() chartHover: EventEmitter<BasePoint> = new EventEmitter<BasePoint>();\r\n\r\n  /**\r\n   * The object used by echarts to initially create the Chart.\r\n   * Has a default configuration that can be totally overrided using specific properties.\r\n   *\r\n   * @type {EChartsOption}\r\n   * @memberof KiwiChartComponent\r\n   */\r\n  chartOption: EChartsOption = {\r\n    title: {\r\n      text: 'Kiwi Chart'\r\n    },\r\n    xAxis: {\r\n      name: 'X'\r\n    },\r\n    yAxis: {\r\n      name: 'Y'\r\n    },\r\n    series: [\r\n      {\r\n        type: TraceType.LINE,\r\n        data: [[0, 0]]\r\n      }\r\n    ]\r\n  };\r\n\r\n  /**\r\n   * The instance of the Chart.\r\n   *\r\n   * @type {(ECharts | null)}\r\n   * @memberof KiwiChartComponent\r\n   */\r\n  echartsInstance: ECharts | null = null;\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   * Subject used to unsubscribe once the component gets destroyed.\r\n   *\r\n   * @private\r\n   * @type {Subject<void>}\r\n   * @memberof KiwiChartComponent\r\n   */\r\n  private destroyed$: Subject<void> = new Subject<void>();\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 KiwiChartComponent\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  constructor(\r\n    private cd: ChangeDetectorRef\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    /** \r\n     * This is a manual change detection running every 200ms, the memory should not be much afflicted.\r\n     * It's necessary because when interacting with the chart (for example addPoint),\r\n     * Angular loses the change detection and the point is not added in the chart canvas.\r\n     */\r\n    interval(200)\r\n      .pipe(\r\n        takeUntil(this.destroyed$)\r\n      )\r\n      .subscribe({\r\n        next: () => {\r\n          this.cd.detectChanges();\r\n        }\r\n      });\r\n  }\r\n\r\n  onChartInit(ec: ECharts) {\r\n    this.echartsInstance = ec;\r\n    this.setupZrEventHandler(ec);\r\n    this.setupLegendEventHandler(ec);\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  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  ngOnChanges(changes: SimpleChanges): void {\r\n    let chart: Chart = changes['chart']?.currentValue;\r\n    if (chart) {\r\n      this.chartOption = {\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                }\r\n              }\r\n            },\r\n            saveAsImage: {\r\n              emphasis: {\r\n                iconStyle: {\r\n                  textPosition: 'top'\r\n                }\r\n              }\r\n            },\r\n            restore: {\r\n              emphasis: {\r\n                iconStyle: {\r\n                  textPosition: 'top'\r\n                }\r\n              }\r\n            },\r\n            myAddPoint: {\r\n              show: chart.clickToAddPoint ?? false,\r\n              title: chart.addPointCustomName ?? 'Add Point',\r\n              icon: this.darkTheme ? ADD_POINT_IMG_OFF_DARK : ADD_POINT_IMG_OFF_LIGHT,\r\n              iconStatus: false,\r\n              onclick: () => {\r\n                let option: any = this.echartsInstance?.getOption();\r\n                let status = option.toolbox[0].feature.myAddPoint.iconStatus;\r\n                this.echartsInstance?.setOption({\r\n                  toolbox: {\r\n                    feature: {\r\n                      myAddPoint: {\r\n                        iconStatus: !status,\r\n                        icon: !status ? ADD_POINT_IMG_ON : this.darkTheme ? ADD_POINT_IMG_OFF_DARK : ADD_POINT_IMG_OFF_LIGHT\r\n                      }\r\n                    }\r\n                  }\r\n                });\r\n              },\r\n              emphasis: {\r\n                iconStyle: {\r\n                  textPosition: 'top'\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 ?? 500,\r\n        animationEasing: 'cubicOut'\r\n      };\r\n    }\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  ngOnDestroy() {\r\n    this.destroyed$.next();\r\n    this.destroyed$.complete();\r\n  }\r\n\r\n}\r\n"]}
@@ -0,0 +1,41 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { KiwiChartComponent } from './chart.component';
4
+ import { NgxEchartsModule } from 'ngx-echarts';
5
+ import * as echarts from 'echarts/core';
6
+ import { TitleComponent, TooltipComponent, GridComponent, LegendComponent, DataZoomComponent, ToolboxComponent } from 'echarts/components';
7
+ import { LineChart, ScatterChart } from 'echarts/charts';
8
+ import { CanvasRenderer } from 'echarts/renderers';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "ngx-echarts";
11
+ echarts.use([
12
+ TitleComponent,
13
+ TooltipComponent,
14
+ GridComponent,
15
+ LineChart,
16
+ CanvasRenderer,
17
+ LegendComponent,
18
+ DataZoomComponent,
19
+ ToolboxComponent,
20
+ ScatterChart
21
+ ]);
22
+ export class KiwiChartModule {
23
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.1", ngImport: i0, type: KiwiChartModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
24
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.1", ngImport: i0, type: KiwiChartModule, imports: [CommonModule, i1.NgxEchartsModule, KiwiChartComponent], exports: [KiwiChartComponent] }); }
25
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.1", ngImport: i0, type: KiwiChartModule, imports: [CommonModule,
26
+ NgxEchartsModule.forRoot({ echarts })] }); }
27
+ }
28
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.1", ngImport: i0, type: KiwiChartModule, decorators: [{
29
+ type: NgModule,
30
+ args: [{
31
+ imports: [
32
+ CommonModule,
33
+ NgxEchartsModule.forRoot({ echarts }),
34
+ KiwiChartComponent
35
+ ],
36
+ exports: [
37
+ KiwiChartComponent
38
+ ]
39
+ }]
40
+ }] });
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l3aWJpdC9jaGFydC9zcmMvbGliL2NoYXJ0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDL0MsT0FBTyxLQUFLLE9BQU8sTUFBTSxjQUFjLENBQUM7QUFDeEMsT0FBTyxFQUFFLGNBQWMsRUFBRSxnQkFBZ0IsRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLGlCQUFpQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDM0ksT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7OztBQUNuRCxPQUFPLENBQUMsR0FBRyxDQUFDO0lBQ1YsY0FBYztJQUNkLGdCQUFnQjtJQUNoQixhQUFhO0lBQ2IsU0FBUztJQUNULGNBQWM7SUFDZCxlQUFlO0lBQ2YsaUJBQWlCO0lBQ2pCLGdCQUFnQjtJQUNoQixZQUFZO0NBQ2IsQ0FBQyxDQUFDO0FBYUgsTUFBTSxPQUFPLGVBQWU7OEdBQWYsZUFBZTsrR0FBZixlQUFlLFlBUnBCLFlBQVksdUJBRVosa0JBQWtCLGFBR2xCLGtCQUFrQjsrR0FHYixlQUFlLFlBUnBCLFlBQVk7WUFDWixnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQzs7MkZBT2hDLGVBQWU7a0JBVjNCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osZ0JBQWdCLENBQUMsT0FBTyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUM7d0JBQ3JDLGtCQUFrQjtxQkFDckI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLGtCQUFrQjtxQkFDckI7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBLaXdpQ2hhcnRDb21wb25lbnQgfSBmcm9tICcuL2NoYXJ0LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE5neEVjaGFydHNNb2R1bGUgfSBmcm9tICduZ3gtZWNoYXJ0cyc7XHJcbmltcG9ydCAqIGFzIGVjaGFydHMgZnJvbSAnZWNoYXJ0cy9jb3JlJztcclxuaW1wb3J0IHsgVGl0bGVDb21wb25lbnQsIFRvb2x0aXBDb21wb25lbnQsIEdyaWRDb21wb25lbnQsIExlZ2VuZENvbXBvbmVudCwgRGF0YVpvb21Db21wb25lbnQsIFRvb2xib3hDb21wb25lbnQgfSBmcm9tICdlY2hhcnRzL2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBMaW5lQ2hhcnQsIFNjYXR0ZXJDaGFydCB9IGZyb20gJ2VjaGFydHMvY2hhcnRzJztcclxuaW1wb3J0IHsgQ2FudmFzUmVuZGVyZXIgfSBmcm9tICdlY2hhcnRzL3JlbmRlcmVycyc7XHJcbmVjaGFydHMudXNlKFtcclxuICBUaXRsZUNvbXBvbmVudCxcclxuICBUb29sdGlwQ29tcG9uZW50LFxyXG4gIEdyaWRDb21wb25lbnQsXHJcbiAgTGluZUNoYXJ0LFxyXG4gIENhbnZhc1JlbmRlcmVyLFxyXG4gIExlZ2VuZENvbXBvbmVudCxcclxuICBEYXRhWm9vbUNvbXBvbmVudCxcclxuICBUb29sYm94Q29tcG9uZW50LFxyXG4gIFNjYXR0ZXJDaGFydFxyXG5dKTtcclxuXHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZSxcclxuICAgICAgICBOZ3hFY2hhcnRzTW9kdWxlLmZvclJvb3QoeyBlY2hhcnRzIH0pLFxyXG4gICAgICAgIEtpd2lDaGFydENvbXBvbmVudFxyXG4gICAgXSxcclxuICAgIGV4cG9ydHM6IFtcclxuICAgICAgICBLaXdpQ2hhcnRDb21wb25lbnRcclxuICAgIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEtpd2lDaGFydE1vZHVsZSB7IH1cclxuIl19
@@ -1,4 +1,4 @@
1
- export const ADD_POINT_IMG_OFF_LIGHT = "image://data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAABmJLR0QA/wD/AP+gvaeTAAADkUlEQVR4nO2bz0sUYRjHv8/otviDGDuWrhKdskBaQZi57MmLgVpIkJ06bH9AEdF/kF46dEg726liBSGwBEFnTm0oaF3s4lhdh1BhNuTpsDPLu+MvmHXm0ZzP6X2feWfn+3x33nf3fXlfIOV8Q0dd7O3tvaDr+igzDxPRLQCdANqSkRaZHQBbzPyViEqu65bW19crhzU+1ADDMO4S0QSAq3GoTJAfAJ5alvXhoItN4cDY2FiTruuTRPQSQEfc6hLgEoB7uVyu3XGcBQCsXtxngJ/846TUJYjR3d3dsrm5+VkN1nUB/7V/F7rRI6IpAG9bW1vX5ufnd+JW2giDg4Ntu7u7N5h5HEARQFa9rmna6NLSUimo1wzwB7zvqO/zP4loaHl5eTVu4XFgGEYfEc0BuKKEN1zX7Q0GRi2I6ro+ivrkvbOcPADYtr3CzLcBeEr4WkdHx3BQqRnAzMPqzUQ0dZaTD7BtewXAGzWm5lozgIjyaqO9vb2Z2NUlRziX/qCgKcHLaotsNvstTkVJkslk1kKh2pigGtCutlhcXNyOU1SSHJBLLVcN55xmqQcbhjFERNMA9gA8sizro4QOsTdA07TXqI47XQCmxHRIPZiZO5Vql5SOcz8GpAZIC5AmNUBagDSpAdICpEkNkBYgTWqAtABpUgOkBUgTeT3An89PoX7JOTKmafLxrfZDRFvMXIy6nhD5DfDn8yeSfCP40+rI6wnnvgtENoCZi0S0dZJiIuIQUTHqzZHHAL/PRV7JCfd5y7KO3KsQF2kXkBYgTWqAtABpUgOkBUiTGiAtQJrUAGkB0qQGSAuQJjVA6sGhqbQjpUNyg0SwntDQfL5RxPYINbqecFKkY4BSrttLVygU2vGfMDAwcDEU+hMUVAN+qS08z7sep6gkaW5uDufyOyiom6XLagtN0x7ErCtJxkP1L0FB3SxdCjUqGobRF6eqJPBzqPuVYeZarjUDXNctoXrAKCBLRHNn2QTlwMQFJbzhed5sUKlbijZN8w6A96HPqQCYBjCTyWTWTvsm6kKh0F6pVG4S0X1Uv3k1eTDziG3bBxsAAKZpTgJ4ErtSAZj5hW3bz9TYvlNjjuMs5HK5VgBmYsoSgIgmLMt6juOOzQFgx3E+9fT0rDJzP6rn7s4yG8z80LKsVwglDxxzdDafz2daWlpG/DM2eVSPzp72P0jbALYAlJm55HnebLlc/istKuW08g8wjAev/BoR3wAAAABJRU5ErkJggg==";
2
- export const ADD_POINT_IMG_OFF_DARK = "image://data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAABmJLR0QA/wD/AP+gvaeTAAADgUlEQVR4nO2bz04TURTGvzNtaQOVB1BgYVhZDbSUDixZYwLoTlzXB5CI8QUM4ANQXeOCqCkJiUuWtpNCIaG6gRWoeyx/CmGOC5hyZ/izmDJzgM5vdefMafudr/femd65BQKaG7rqZKVSadndORhjohGAUwB1AGjzSZtbdgHeBmiFmPNt7bF8IpE4vCz5UgMKhZXnBJoG+KE3On2CsEkmv8kM9n27+LSD+fn5UFdX9xQBr71X5x8E/tCvpyaJyFTjmjPxLhYPAAyaMAqr751xWw846fb44sioMSPHbH5ubY2s9/T07HqstSHW1tba9vaOHmuaNg4gC0bUlkA0puvJfP3QalQqlZbqv8NfjjH/G4RhXU+tea7cAwyj3MsmLwJ4oIQ34veiCWtirA+B3Z2DMVvxhNptLh4AMpnkKmn0FISaEu6uVg9HrIO6ASeXujOYkbvNxVtkMslVmPhkj5rnDQDQp6aETG3OU2U+wsT2Whhpq6kacF/NqdYiP72V5R/7+7F1e4Tqc4JqQFxNGRpKVD1V5SMX1FKv9dx9QLMRlvrgYrE8TMwfGTjWGK/6B1PfJXTI9QDmWT6ZdzpNQk5KhuQQ6FDanVIimn4OCAyQFiBNYIC0AGkCA6QFSBMYIC1AmsAAaQHSBAZIC5DG9XpAsVgeBnMO9iVn1xQLK+zypdsaI+t2PcF9D2CexTUV3yAdjawnNP0QcG2AxsgC2L5GLW7ZIpOzbl/seg44HXOuV3KcY14fSF25V8ErgiEgLUCawABpAdIEBkgLkCYwQFqANIEB0gKkCQyQFiBNYIDgZ6s/pbekRIgZoKwnNPR7vlHE9gg1up5wXQRzgNK27aVbWqrEcUcoFArtjtCO1VAN+KNmxKNHj7wU5S8RRy3812qpBiyrKWbIfOmpJh8hpnF7ACWrqZ0lcR52soZR7vVWmvcYRrkXBNtVhpnqtdYNaGuP5UHYPMtClE1evM0mKH+YaFHCG+GwuWAd2JaijR/Lz5joq+N9DsH4yMRz+/ux9Zu+iXppqRJvba09gYkXp9+8WjwYNDowkLzYAAAwCsszDJrwQav/EKZ0PfVWDZ27D+jXU5MAz/inyieYpjOZ5Dtn+NKnMcVieRTMMwC6PRXmPRsMmlC7vcqVj6NKpVLk+Dg0CpgjzNRHJxucb/oNUpWBbSJeZqZ8OGwupNPpI2lRATeV/+HNFJvPZJXuAAAAAElFTkSuQmCC";
3
- export const ADD_POINT_IMG_ON = "image://data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAABmJLR0QA/wD/AP+gvaeTAAADjUlEQVR4nO2by08TURTGvzNAK49oDCsRNqbFxPogtsQ/AhNAowsxLksTlxIxrtwZwJUJsa07E1wQNSUh8X+wrQFDNSklMQGVjRgMj7TIHBcww50WWEyZOTzmt7pz7pn2O1/n3pne3gIeJxvarzM0nvM1LPl7GegGcB3gVgCN7kizzSpACwA+E3NqrbmUyt0NlfZK3tOAyKv8bRANA7jghEoXmSPw43Ss/cNunRUG3Bnnmu+/C0NMeOS8Nvdg8IvsYnAQz0hX41p54nEsHgAINBA5N/e8Mq6wfdm/K8spElNC1/S3G/XrM18eXFt1VGmVXH0z3Vi3Xn+ZGH0ARQH41X4m6s32B1LGsWlAaDznq1/yfYMy5hn4UQO961Ps4rQb4g+azmS+Q9dpkoDzZpBQWD9bChkTozkEGpb8vbBOeMWjXDwApKPtU5rGNwEUzSAjcOqPr9s41Hbi6FZPJqbEUS7eIB1tnwLhtSXIqDQA4LA1Z3PMYW2uoW/CUguBIkZbvQu0qEnr+r+vDutyjSKXZqwRNucE1YAmNSX3MLTiqCoX2aUWs9aK54CTRq3UG4cT+S7SKQnCJjTqz0QDHyV0iF0BxBQHoQVAG3ROSOmQHAKtSrtNSsSJnwM8A6QFSOMZIC1AGs8AaQHSeAZIC5DGM0BagDSeAdICpLG9HhBO5LvAlLAsOVdBJD7LNk9dgEZRu+sJtq8AYoofVPFV0lrNesKJHwL2DdAoCmDh4KTYZp62fgKzhe05YHvM2V7JKR/zmVhw370KTuENAWkB0ngGSAuQxjNAWoA0ngHSAqTxDJAWII1ngLQAaTwDBN9b/So9LyVCzoCd9YSqvs9Xi9geoWrXEw4Kbw5Q2pa9dKHRXBOOCTdezp4uC/01GqoBP9WMeq32kpOi3GSjFmW10C+jpRhAWWsO3XdUlYtoNehTjxmcMfuMBjGnYIGincl8h9PinKYzme8Aw3KXIcCs1TRgrbmUAjCn5Pl1nSaPsgnGHyYA+MwgocC0PLFzqJ4Qz99i0Puy1ymBkNQ3MVbk0sxh30QdGs01Ndb4ruiEe9ufvK8spScTC+5uAACE4/kRAg04LVQCAobSseATNVbxHJBdDA4CNOKeLJcgGk4vBp5WhPfKDycKPQQeASPgrDKHIRTAGFAve2v3PoQTmTrgTA8Y3QSEsbXB+bA/IK0AWGAgS0CKaXki2x/ZkBblcVj5D1vBAfS1aXiGAAAAAElFTkSuQmCC";
1
+ export const ADD_POINT_IMG_OFF_LIGHT = "image://data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAABmJLR0QA/wD/AP+gvaeTAAADkUlEQVR4nO2bz0sUYRjHv8/otviDGDuWrhKdskBaQZi57MmLgVpIkJ06bH9AEdF/kF46dEg726liBSGwBEFnTm0oaF3s4lhdh1BhNuTpsDPLu+MvmHXm0ZzP6X2feWfn+3x33nf3fXlfIOV8Q0dd7O3tvaDr+igzDxPRLQCdANqSkRaZHQBbzPyViEqu65bW19crhzU+1ADDMO4S0QSAq3GoTJAfAJ5alvXhoItN4cDY2FiTruuTRPQSQEfc6hLgEoB7uVyu3XGcBQCsXtxngJ/846TUJYjR3d3dsrm5+VkN1nUB/7V/F7rRI6IpAG9bW1vX5ufnd+JW2giDg4Ntu7u7N5h5HEARQFa9rmna6NLSUimo1wzwB7zvqO/zP4loaHl5eTVu4XFgGEYfEc0BuKKEN1zX7Q0GRi2I6ro+ivrkvbOcPADYtr3CzLcBeEr4WkdHx3BQqRnAzMPqzUQ0dZaTD7BtewXAGzWm5lozgIjyaqO9vb2Z2NUlRziX/qCgKcHLaotsNvstTkVJkslk1kKh2pigGtCutlhcXNyOU1SSHJBLLVcN55xmqQcbhjFERNMA9gA8sizro4QOsTdA07TXqI47XQCmxHRIPZiZO5Vql5SOcz8GpAZIC5AmNUBagDSpAdICpEkNkBYgTWqAtABpUgOkBUgTeT3An89PoX7JOTKmafLxrfZDRFvMXIy6nhD5DfDn8yeSfCP40+rI6wnnvgtENoCZi0S0dZJiIuIQUTHqzZHHAL/PRV7JCfd5y7KO3KsQF2kXkBYgTWqAtABpUgOkBUiTGiAtQJrUAGkB0qQGSAuQJjVA6sGhqbQjpUNyg0SwntDQfL5RxPYINbqecFKkY4BSrttLVygU2vGfMDAwcDEU+hMUVAN+qS08z7sep6gkaW5uDufyOyiom6XLagtN0x7ErCtJxkP1L0FB3SxdCjUqGobRF6eqJPBzqPuVYeZarjUDXNctoXrAKCBLRHNn2QTlwMQFJbzhed5sUKlbijZN8w6A96HPqQCYBjCTyWTWTvsm6kKh0F6pVG4S0X1Uv3k1eTDziG3bBxsAAKZpTgJ4ErtSAZj5hW3bz9TYvlNjjuMs5HK5VgBmYsoSgIgmLMt6juOOzQFgx3E+9fT0rDJzP6rn7s4yG8z80LKsVwglDxxzdDafz2daWlpG/DM2eVSPzp72P0jbALYAlJm55HnebLlc/istKuW08g8wjAev/BoR3wAAAABJRU5ErkJggg==";
2
+ export const ADD_POINT_IMG_OFF_DARK = "image://data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAABmJLR0QA/wD/AP+gvaeTAAADgUlEQVR4nO2bz04TURTGvzNtaQOVB1BgYVhZDbSUDixZYwLoTlzXB5CI8QUM4ANQXeOCqCkJiUuWtpNCIaG6gRWoeyx/CmGOC5hyZ/izmDJzgM5vdefMafudr/femd65BQKaG7rqZKVSadndORhjohGAUwB1AGjzSZtbdgHeBmiFmPNt7bF8IpE4vCz5UgMKhZXnBJoG+KE3On2CsEkmv8kM9n27+LSD+fn5UFdX9xQBr71X5x8E/tCvpyaJyFTjmjPxLhYPAAyaMAqr751xWw846fb44sioMSPHbH5ubY2s9/T07HqstSHW1tba9vaOHmuaNg4gC0bUlkA0puvJfP3QalQqlZbqv8NfjjH/G4RhXU+tea7cAwyj3MsmLwJ4oIQ34veiCWtirA+B3Z2DMVvxhNptLh4AMpnkKmn0FISaEu6uVg9HrIO6ASeXujOYkbvNxVtkMslVmPhkj5rnDQDQp6aETG3OU2U+wsT2Whhpq6kacF/NqdYiP72V5R/7+7F1e4Tqc4JqQFxNGRpKVD1V5SMX1FKv9dx9QLMRlvrgYrE8TMwfGTjWGK/6B1PfJXTI9QDmWT6ZdzpNQk5KhuQQ6FDanVIimn4OCAyQFiBNYIC0AGkCA6QFSBMYIC1AmsAAaQHSBAZIC5DG9XpAsVgeBnMO9iVn1xQLK+zypdsaI+t2PcF9D2CexTUV3yAdjawnNP0QcG2AxsgC2L5GLW7ZIpOzbl/seg44HXOuV3KcY14fSF25V8ErgiEgLUCawABpAdIEBkgLkCYwQFqANIEB0gKkCQyQFiBNYIDgZ6s/pbekRIgZoKwnNPR7vlHE9gg1up5wXQRzgNK27aVbWqrEcUcoFArtjtCO1VAN+KNmxKNHj7wU5S8RRy3812qpBiyrKWbIfOmpJh8hpnF7ACWrqZ0lcR52soZR7vVWmvcYRrkXBNtVhpnqtdYNaGuP5UHYPMtClE1evM0mKH+YaFHCG+GwuWAd2JaijR/Lz5joq+N9DsH4yMRz+/ux9Zu+iXppqRJvba09gYkXp9+8WjwYNDowkLzYAAAwCsszDJrwQav/EKZ0PfVWDZ27D+jXU5MAz/inyieYpjOZ5Dtn+NKnMcVieRTMMwC6PRXmPRsMmlC7vcqVj6NKpVLk+Dg0CpgjzNRHJxucb/oNUpWBbSJeZqZ8OGwupNPpI2lRATeV/+HNFJvPZJXuAAAAAElFTkSuQmCC";
3
+ export const ADD_POINT_IMG_ON = "image://data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAABmJLR0QA/wD/AP+gvaeTAAADjUlEQVR4nO2by08TURTGvzNAK49oDCsRNqbFxPogtsQ/AhNAowsxLksTlxIxrtwZwJUJsa07E1wQNSUh8X+wrQFDNSklMQGVjRgMj7TIHBcww50WWEyZOTzmt7pz7pn2O1/n3pne3gIeJxvarzM0nvM1LPl7GegGcB3gVgCN7kizzSpACwA+E3NqrbmUyt0NlfZK3tOAyKv8bRANA7jghEoXmSPw43Ss/cNunRUG3Bnnmu+/C0NMeOS8Nvdg8IvsYnAQz0hX41p54nEsHgAINBA5N/e8Mq6wfdm/K8spElNC1/S3G/XrM18eXFt1VGmVXH0z3Vi3Xn+ZGH0ARQH41X4m6s32B1LGsWlAaDznq1/yfYMy5hn4UQO961Ps4rQb4g+azmS+Q9dpkoDzZpBQWD9bChkTozkEGpb8vbBOeMWjXDwApKPtU5rGNwEUzSAjcOqPr9s41Hbi6FZPJqbEUS7eIB1tnwLhtSXIqDQA4LA1Z3PMYW2uoW/CUguBIkZbvQu0qEnr+r+vDutyjSKXZqwRNucE1YAmNSX3MLTiqCoX2aUWs9aK54CTRq3UG4cT+S7SKQnCJjTqz0QDHyV0iF0BxBQHoQVAG3ROSOmQHAKtSrtNSsSJnwM8A6QFSOMZIC1AGs8AaQHSeAZIC5DGM0BagDSeAdICpLG9HhBO5LvAlLAsOVdBJD7LNk9dgEZRu+sJtq8AYoofVPFV0lrNesKJHwL2DdAoCmDh4KTYZp62fgKzhe05YHvM2V7JKR/zmVhw370KTuENAWkB0ngGSAuQxjNAWoA0ngHSAqTxDJAWII1ngLQAaTwDBN9b/So9LyVCzoCd9YSqvs9Xi9geoWrXEw4Kbw5Q2pa9dKHRXBOOCTdezp4uC/01GqoBP9WMeq32kpOi3GSjFmW10C+jpRhAWWsO3XdUlYtoNehTjxmcMfuMBjGnYIGincl8h9PinKYzme8Aw3KXIcCs1TRgrbmUAjCn5Pl1nSaPsgnGHyYA+MwgocC0PLFzqJ4Qz99i0Puy1ymBkNQ3MVbk0sxh30QdGs01Ndb4ruiEe9ufvK8spScTC+5uAACE4/kRAg04LVQCAobSseATNVbxHJBdDA4CNOKeLJcgGk4vBp5WhPfKDycKPQQeASPgrDKHIRTAGFAve2v3PoQTmTrgTA8Y3QSEsbXB+bA/IK0AWGAgS0CKaXki2x/ZkBblcVj5D1vBAfS1aXiGAAAAAElFTkSuQmCC";
4
4
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQuY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l3aWJpdC9jaGFydC9zcmMvbGliL2NvbnN0YW50cy9jaGFydC5jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUcsdzBDQUF3MEMsQ0FBQztBQUNoM0MsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsZ3pDQUFnekMsQ0FBQztBQUN2MUMsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsZzBDQUFnMEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBBRERfUE9JTlRfSU1HX09GRl9MSUdIVCA9IFwiaW1hZ2U6Ly9kYXRhOmltYWdlL3BuZztiYXNlNjQsaVZCT1J3MEtHZ29BQUFBTlNVaEVVZ0FBQUVBQUFBQkFDQVlBQUFDcWFYSGVBQUFBQm1KTFIwUUEvd0QvQVArZ3ZhZVRBQUFEa1VsRVFWUjRuTzJiejBzVVlSakh2OC9vdHZpREdEdVdyaEtkc2tCYVFaaTU3TW1MZ1ZwSWtKMDZiSDlBRWRGL2tGNDZkRWc3MjZsaUJTR3dCRUZuVG0wb2FGM3M0bGhkaDFCaE51VHBzRFBMdStNdm1IWG0wWnpQNlgyZmVXZm4rM3gzM25mM2ZYbGZJT1Y4UTBkZDdPM3R2YURyK2lnekR4UFJMUUNkQU5xU2tSYVpIUUJielB5VmlFcXU2NWJXMTljcmh6VSsxQURETU80UzBRU0FxM0dvVEpBZkFKNWFsdlhob0l0TjRjRFkyRmlUcnV1VFJQUVNRRWZjNmhMZ0VvQjd1Vnl1M1hHY0JRQ3NYdHhuZ0ovODQ2VFVKWWpSM2QzZHNybTUrVmtOMW5VQi83Vi9GN3JSSTZJcEFHOWJXMXZYNXVmbmQrSlcyZ2lEZzROdHU3dTdONWg1SEVBUlFGYTlybW5hNk5MU1VpbW8xd3p3Qjd6dnFPL3pQNGxvYUhsNWVUVnU0WEZnR0VZZkVjMEJ1S0tFTjF6WDdRMEdSaTJJNnJvK2l2cmt2Yk9jUEFEWXRyM0N6TGNCZUVyNFdrZEh4M0JRcVJuQXpNUHF6VVEwZFphVEQ3QnRld1hBR3pXbTVsb3pnSWp5YXFPOXZiMloyTlVsUnppWC9xQ2dLY0hMYW90c052c3RUa1ZKa3NsazFrS2gycGlnR3RDdXRsaGNYTnlPVTFTU0hKQkxMVmNONTV4bXFRY2JoakZFUk5NQTlnQThzaXpybzRRT3NUZEEwN1RYcUk0N1hRQ214SFJJUFppWk81VnFsNVNPY3o4R3BBWklDNUFtTlVCYWdEU3BBZElDcEVrTmtCWWdUV3FBdEFCcFVnT2tCVWdUZVQzQW44OVBvWDdKT1RLbWFmTHhyZlpEUkZ2TVhJeTZuaEQ1RGZEbjh5ZVNmQ1A0MCtySTZ3bm52Z3RFTm9DWmkwUzBkWkppSXVJUVVUSHF6WkhIQUwvUFJWN0pDZmQ1eTdLTzNLc1FGMmtYa0JZZ1RXcUF0QUJwVWdPa0JVaVRHaUF0UUpyVUFHa0IwcVFHU0F1UUpqVkE2c0docWJRanBVTnlnMFN3bnREUWZMNVJ4UFlJTmJxZWNGS2tZNEJTcnR0TFZ5Z1UydkdmTURBd2NERVUraE1VVkFOK3FTMDh6N3NlcDZna2FXNXVEdWZ5T3lpb202WExhZ3ROMHg3RXJDdEp4a1AxTDBGQjNTeGRDalVxR29iUkY2ZXFKUEJ6cVB1VlllWmFyalVEWE5jdG9YckFLQ0JMUkhObjJRVGx3TVFGSmJ6aGVkNXNVS2xiaWpaTjh3NkE5NkhQcVFDWUJqQ1R5V1RXVHZzbTZrS2gwRjZwVkc0UzBYMVV2M2sxZVREemlHM2JCeHNBQUtacFRnSjRFcnRTQVpqNWhXM2J6OVRZdmxOamp1TXM1SEs1VmdCbVlzb1NnSWdtTE10Nmp1T096UUZneDNFKzlmVDByREp6UDZybjdzNHlHOHo4MExLc1Z3Z2xEeHh6ZERhZnoyZGFXbHBHL0RNMmVWU1B6cDcyUDBqYkFMWUFsSm01NUhuZWJMbGMvaXN0S3VXMDhnOHdqQWV2L0JvUjN3QUFBQUJKUlU1RXJrSmdnZz09XCI7XHJcbmV4cG9ydCBjb25zdCBBRERfUE9JTlRfSU1HX09GRl9EQVJLID0gXCJpbWFnZTovL2RhdGE6aW1hZ2UvcG5nO2Jhc2U2NCxpVkJPUncwS0dnb0FBQUFOU1VoRVVnQUFBRUFBQUFCQUNBWUFBQUNxYVhIZUFBQUFCbUpMUjBRQS93RC9BUCtndmFlVEFBQURnVWxFUVZSNG5PMmJ6MDRUVVJUR3Z6TnRhUU9WQjFCZ1lWaFpEYlNVRGl4Wll3TG9UbHpYQjVDSThRVU00QU5RWGVPQ3FDa0ppVXVXdHBOQ0lhRzZnUldvZXl4L0NtR09DNWh5Wi9pem1ESnpnTTV2ZGVmTWFmdWRyL2ZlbWQ2NUJRS2FHN3JxWktWU2FkbmRPUmhqb2hHQVV3QjFBR2p6U1p0YmRnSGVCbWlGbVBOdDdiRjhJcEU0dkN6NVVnTUtoWlhuQkpvRytLRTNPbjJDc0VrbXY4a005bjI3K0xTRCtmbjVVRmRYOXhRQnI3MVg1eDhFL3RDdnB5YUp5RlRqbWpQeExoWVBBQXlhTUFxcjc1MXhXdzg0NmZiNDRzaW9NU1BIYkg1dWJZMnM5L1QwN0hxc3RTSFcxdGJhOXZhT0htdWFOZzRnQzBiVWxrQTBwdXZKZlAzUWFsUXFsWmJxdjhOZmpqSC9HNFJoWFUrdGVhN2NBd3lqM01zbUx3SjRvSVEzNHZlaUNXdGlyQStCM1oyRE1WdnhoTnB0TGg0QU1wbmtLbW4wRklTYUV1NnVWZzlIcklPNkFTZVh1ak9Za2J2TnhWdGtNc2xWbVBoa2o1cm5EUURRcDZhRVRHM09VMlUrd3NUMldoaHBxNmthY0YvTnFkWWlQNzJWNVIvNys3RjFlNFRxYzRKcVFGeE5HUnBLVkQxVjVTTVgxRkt2OWR4OVFMTVJsdnJnWXJFOFRNd2ZHVGpXR0svNkIxUGZKWFRJOVFEbVdUNlpkenBOUWs1S2h1UVE2RkRhblZJaW1uNE9DQXlRRmlCTllJQzBBR2tDQTZRRlNCTVlJQzFBbXNBQWFRSFNCQVpJQzVERzlYcEFzVmdlQm5NTzlpVm4xeFFMSyt6eXBkc2FJK3QyUGNGOUQyQ2V4VFVWM3lBZGphd25OUDBRY0cyQXhzZ0MyTDVHTFc3WklwT3pibC9zZWc0NEhYT3VWM0tjWTE0ZlNGMjVWOEVyZ2lFZ0xVQ2F3QUJwQWRJRUJrZ0xrQ1l3UUZxQU5JRUIwZ0trQ1F5UUZpQk5ZSURnWjZzL3BiZWtSSWdab0t3bk5QUjd2bEhFOWdnMXVwNXdYUVJ6Z05LMjdhVmJXcXJFY1Vjb0ZBcnRqdENPMVZBTitLTm14S05Iajd3VTVTOFJSeTM4MTJxcEJpeXJLV2JJZk9tcEpoOGhwbkY3QUNXcnFaMGxjUjUyc29aUjd2VldtdmNZUnJrWEJOdFZocG5xdGRZTmFHdVA1VUhZUE10Q2xFMWV2TTBtS0grWWFGSENHK0d3dVdBZDJKYWlqUi9MejVqb3ErTjlEc0g0eU1SeisvdXg5WnUraVhwcHFSSnZiYTA5Z1lrWHA5KzhXandZTkRvd2tMellBQUF3Q3NzekRKcndRYXYvRUtaMFBmVldEWjI3RCtqWFU1TUF6L2lueWllWXBqT1o1RHRuK05Lbk1jVmllUlRNTXdDNlBSWG1QUnNNbWxDN3ZjcVZqNk5LcFZMaytEZzBDcGdqek5SSEp4dWNiL29OVXBXQmJTSmVacVo4T0d3dXBOUHBJMmxSQVRlVi8rSE5GSnZQWkpYdUFBQUFBRWxGVGtTdVFtQ0NcIjtcclxuZXhwb3J0IGNvbnN0IEFERF9QT0lOVF9JTUdfT04gPSBcImltYWdlOi8vZGF0YTppbWFnZS9wbmc7YmFzZTY0LGlWQk9SdzBLR2dvQUFBQU5TVWhFVWdBQUFFQUFBQUJBQ0FZQUFBQ3FhWEhlQUFBQUJtSkxSMFFBL3dEL0FQK2d2YWVUQUFBRGpVbEVRVlI0bk8yYnkwOFRVUlRHdnpOQUs0OW9EQ3NSTnFiRnhQb2d0c1EvQWhOQW93c3hMa3NUbHhJeHJ0d1p3SlVKc2EwN0Uxd1FOU1VoOFgrd3JRRkROU2tsTVFHVmpSZ01qN1RJSEJjd3c1MFdXRXlaT1R6bXQ3cHo3cG4yTzEvbjNwbmUzZ0llSnh2YXJ6TTBudk0xTFBsN0dlZ0djQjNnVmdDTjdraXp6U3BBQ3dBK0UzTnFyYm1VeXQwTmxmWkszdE9BeUt2OGJSQU5BN2pnaEVvWG1TUHc0M1NzL2NOdW5SVUczQm5ubXUrL0MwTk1lT1M4TnZkZzhJdnNZbkFRejBoWDQxcDU0bkVzSGdBSU5CQTVOL2U4TXE2d2ZkbS9LOHNwRWxOQzEvUzNHL1hyTTE4ZVhGdDFWR21WWEgwejNWaTNYbitaR0gwQVJRSDQxWDRtNnMzMkIxTEdzV2xBYUR6bnExL3lmWU15NWhuNFVRTzk2MVBzNHJRYjRnK2F6bVMrUTlkcGtvRHpacEJRV0Q5YkNoa1RvemtFR3BiOHZiQk9lTVdqWER3QXBLUHRVNXJHTndFVXpTQWpjT3FQcjlzNDFIYmk2RlpQSnFiRVVTN2VJQjF0bndMaHRTWElxRFFBNExBMVozUE1ZVzJ1b1cvQ1VndUJJa1pidlF1MHFFbnIrcit2RHV0eWpTS1hacXdSTnVjRTFZQW1OU1gzTUxUaXFDb1gyYVVXczlhSzU0Q1RScTNVRzRjVCtTN1NLUW5DSmpUcXowUURIeVYwaUYwQnhCUUhvUVZBRzNST1NPbVFIQUt0U3J0TlNzU0pud004QTZRRlNPTVpJQzFBR3M4QWFRSFNlQVpJQzVER00wQmFnRFNlQWRJQ3BMRzlIaEJPNUx2QWxMQXNPVmRCSkQ3TE5rOWRnRVpSdStzSnRxOEFZb29mVlBGVjBsck5lc0tKSHdMMkRkQW9DbURoNEtUWVpwNjJmZ0t6aGUwNVlIdk0yVjdKS1Ivem1WaHczNzBLVHVFTkFXa0IwbmdHU0F1UXhqTkFXb0EwbmdIU0FxVHhESkFXSUkxbmdMUUFhVHdEQk45Yi9TbzlMeVZDem9DZDlZU3F2czlYaTlnZW9XclhFdzRLYnc1UTJwYTlkS0hSWEJPT0NUZGV6cDR1Qy8wMUdxb0JQOVdNZXEzMmtwT2kzR1NqRm1XMTBDK2pwUmhBV1dzTzNYZFVsWXRvTmVoVGp4bWNNZnVNQmpHbllJR2luY2w4aDlQaW5LWXptZThBdzNLWEljQ3MxVFJncmJtVUFqQ241UGwxblNhUHNnbkdIeVlBK013Z29jQzBQTEZ6cUo0UXo5OWkwUHV5MXltQmtOUTNNVmJrMHN4aDMwUWRHczAxTmRiNHJ1aUVlOXVmdks4c3BTY1RDKzV1QUFDRTQva1JBZzA0TFZRQ0FvYlNzZUFUTlZieEhKQmREQTRDTk9LZUxKY2dHazR2QnA1V2hQZktEeWNLUFFRZUFTUGdyREtISVJUQUdGQXZlMnYzUG9RVG1UcmdUQThZM1FTRXNiWEIrYkEvSUswQVdHQWdTMENLYVhraTJ4L1prQmJsY1ZqNUQxdkJBZlMxYVhpR0FBQUFBRWxGVGtTdVFtQ0NcIjsiXX0=