@kiwibit/chart 18.0.2 → 19.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 +8 -0
- package/fesm2022/kiwibit-chart.mjs +13 -12
- package/fesm2022/kiwibit-chart.mjs.map +1 -1
- package/lib/directives/kiwi-chart.directive.d.ts +8 -6
- package/package.json +7 -6
- package/esm2022/kiwibit-chart.mjs +0 -5
- package/esm2022/lib/components/chart.component.mjs +0 -97
- package/esm2022/lib/constants/chart.constants.mjs +0 -6
- package/esm2022/lib/directives/kiwi-chart.directive.mjs +0 -452
- package/esm2022/lib/models/chart.models.mjs +0 -28
- package/esm2022/public-api.mjs +0 -6
package/README.md
CHANGED
|
@@ -4,6 +4,8 @@ This project is an Angular library designed to simplify the process of 2D charts
|
|
|
4
4
|
|
|
5
5
|
### Latest versions @npm:
|
|
6
6
|
|
|
7
|
+
> **v19.x** for Angular >= **19.x**
|
|
8
|
+
>
|
|
7
9
|
> **v18.x** for Angular >= **18.x**
|
|
8
10
|
>
|
|
9
11
|
> **v17.x** for Angular >= **17.x**
|
|
@@ -59,6 +61,12 @@ npm install @kiwibit/chart
|
|
|
59
61
|
|
|
60
62
|
# Latest Updates
|
|
61
63
|
|
|
64
|
+
## [19.0.0] - 2025-01-23
|
|
65
|
+
|
|
66
|
+
### Added
|
|
67
|
+
|
|
68
|
+
- Upgrade to Angular 19.
|
|
69
|
+
|
|
62
70
|
## [18.0.2] - 2024-12-02
|
|
63
71
|
|
|
64
72
|
### Fixed
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { EventEmitter, Directive, Input, Output, HostListener, Component } from '@angular/core';
|
|
3
3
|
import * as echarts from 'echarts/core';
|
|
4
|
-
import { init } from 'echarts';
|
|
5
4
|
import { TitleComponent, TooltipComponent, GridComponent, LegendComponent, DataZoomComponent, ToolboxComponent } from 'echarts/components';
|
|
6
|
-
import { LineChart } from 'echarts/charts';
|
|
5
|
+
import { LineChart, ScatterChart } from 'echarts/charts';
|
|
7
6
|
import { CanvasRenderer } from 'echarts/renderers';
|
|
8
7
|
|
|
9
8
|
var TraceType;
|
|
@@ -46,6 +45,7 @@ echarts.use([
|
|
|
46
45
|
TooltipComponent,
|
|
47
46
|
GridComponent,
|
|
48
47
|
LineChart,
|
|
48
|
+
ScatterChart,
|
|
49
49
|
CanvasRenderer,
|
|
50
50
|
LegendComponent,
|
|
51
51
|
DataZoomComponent,
|
|
@@ -154,7 +154,7 @@ class KiwiChartDirective {
|
|
|
154
154
|
// Update ElementRef styles
|
|
155
155
|
this.el.nativeElement.style.width = this.width;
|
|
156
156
|
this.el.nativeElement.style.height = this.height;
|
|
157
|
-
this.echartsInstance = init(this.el.nativeElement, this.darkTheme ? 'dark' : 'default', {
|
|
157
|
+
this.echartsInstance = echarts.init(this.el.nativeElement, this.darkTheme ? 'dark' : 'default', {
|
|
158
158
|
renderer: 'svg'
|
|
159
159
|
});
|
|
160
160
|
if (chart) {
|
|
@@ -163,6 +163,7 @@ class KiwiChartDirective {
|
|
|
163
163
|
text: chart.title,
|
|
164
164
|
},
|
|
165
165
|
grid: {
|
|
166
|
+
id: 0,
|
|
166
167
|
width: '70%'
|
|
167
168
|
},
|
|
168
169
|
backgroundColor: this.darkTheme ? this.darkThemeBackground ?? '#303030' : 'transparent', tooltip: {
|
|
@@ -415,8 +416,8 @@ class KiwiChartDirective {
|
|
|
415
416
|
let active = option?.toolbox?.[0]?.feature?.myAddPoint?.iconStatus;
|
|
416
417
|
if (active && this.chart?.clickToAddPoint) {
|
|
417
418
|
const pointInPixel = [params.offsetX, params.offsetY];
|
|
418
|
-
const pointInGrid = ec.convertFromPixel(
|
|
419
|
-
if (ec.containPixel(
|
|
419
|
+
const pointInGrid = ec.convertFromPixel({ gridId: 0 }, pointInPixel);
|
|
420
|
+
if (ec.containPixel({ gridId: 0 }, pointInPixel) && pointInGrid) {
|
|
420
421
|
let newPoint = {
|
|
421
422
|
x: +pointInGrid[0].toFixed(3),
|
|
422
423
|
y: +pointInGrid[1].toFixed(3)
|
|
@@ -450,10 +451,10 @@ class KiwiChartDirective {
|
|
|
450
451
|
}
|
|
451
452
|
});
|
|
452
453
|
}
|
|
453
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
454
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
454
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.3", ngImport: i0, type: KiwiChartDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
455
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.1.3", 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 }); }
|
|
455
456
|
}
|
|
456
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
457
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.3", ngImport: i0, type: KiwiChartDirective, decorators: [{
|
|
457
458
|
type: Directive,
|
|
458
459
|
args: [{
|
|
459
460
|
selector: 'div[kiwi-chart]',
|
|
@@ -530,8 +531,8 @@ class KiwiChartComponent {
|
|
|
530
531
|
*/
|
|
531
532
|
this.chartHover = new EventEmitter();
|
|
532
533
|
}
|
|
533
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
534
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
534
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.3", ngImport: i0, type: KiwiChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
535
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.1.3", type: KiwiChartComponent, isStandalone: true, selector: "kiwi-chart", inputs: { chart: "chart", width: "width", height: "height", darkTheme: "darkTheme", darkThemeBackground: "darkThemeBackground" }, outputs: { addPoint: "addPoint", chartHover: "chartHover" }, ngImport: i0, template: `
|
|
535
536
|
<div
|
|
536
537
|
kiwi-chart
|
|
537
538
|
[chart]="chart"
|
|
@@ -544,7 +545,7 @@ class KiwiChartComponent {
|
|
|
544
545
|
></div>
|
|
545
546
|
`, isInline: true, styles: [""], dependencies: [{ kind: "directive", type: KiwiChartDirective, selector: "div[kiwi-chart]", inputs: ["chart", "width", "height", "darkTheme", "darkThemeBackground"], outputs: ["chartInit", "addPoint", "chartHover"] }] }); }
|
|
546
547
|
}
|
|
547
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
548
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.3", ngImport: i0, type: KiwiChartComponent, decorators: [{
|
|
548
549
|
type: Component,
|
|
549
550
|
args: [{ selector: 'kiwi-chart', template: `
|
|
550
551
|
<div
|
|
@@ -557,7 +558,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
557
558
|
(addPoint)="addPoint.emit($event)"
|
|
558
559
|
(chartHover)="chartHover.emit($event)"
|
|
559
560
|
></div>
|
|
560
|
-
`,
|
|
561
|
+
`, imports: [KiwiChartDirective] }]
|
|
561
562
|
}], propDecorators: { chart: [{
|
|
562
563
|
type: Input,
|
|
563
564
|
args: [{ required: true }]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"kiwibit-chart.mjs","sources":["../../../../projects/kiwibit/chart/src/lib/models/chart.models.ts","../../../../projects/kiwibit/chart/src/lib/constants/chart.constants.ts","../../../../projects/kiwibit/chart/src/lib/directives/kiwi-chart.directive.ts","../../../../projects/kiwibit/chart/src/lib/components/chart.component.ts","../../../../projects/kiwibit/chart/src/public-api.ts","../../../../projects/kiwibit/chart/src/kiwibit-chart.ts"],"sourcesContent":["/**\r\n * Interface to define the Chart model.\r\n *\r\n * @export\r\n * @interface Chart\r\n */\r\nexport interface Chart {\r\n title: string;\r\n showLegend?: boolean;\r\n xAxisType: AxisType;\r\n xAxisName: string;\r\n xAxisUom?: string;\r\n xMin?: number;\r\n xMax?: number;\r\n yAxisType: AxisType;\r\n yAxisName: string;\r\n yAxisUom?: string;\r\n yMin?: number;\r\n yMax?: number;\r\n /**\r\n * The maximum decimals that can have the values on the x and y axes.\r\n * If omitted the default is 3 decimals.\r\n *\r\n * @type {number}\r\n * @memberof Chart\r\n */\r\n maxAxesDecimals?: number;\r\n /**\r\n * If the chart should have rendering animations.\r\n *\r\n * @type {boolean}\r\n * @memberof Chart\r\n */\r\n hasAnimations?: boolean;\r\n /**\r\n * How long the animation should last.\r\n * Expressed in milliseconds. If omitted the Default is 500 ms.\r\n *\r\n * @type {number}\r\n * @memberof Chart\r\n */\r\n animationDuration?: number;\r\n /**\r\n * The list of Shapes that the chart must render.\r\n * Each Shape corrisponds to a single chart component.\r\n *\r\n * @type {Shape[]}\r\n * @memberof Chart\r\n */\r\n shapes: Shape[];\r\n /**\r\n * Adds interaction with the chart, so that when clicking\r\n * everywhere in the chart area a point gets added and it's coordinate are \r\n * emitted with an event to the parent component.\r\n *\r\n * @type {boolean}\r\n * @memberof Chart\r\n */\r\n clickToAddPoint?: boolean;\r\n /**\r\n * Custom name for the \"clickToAddPoint\" event related button. \r\n *\r\n * @type {string}\r\n * @memberof Chart\r\n */\r\n addPointCustomName?: string;\r\n /**\r\n * Adds the possibility to use the scroll \r\n * to zoom in/out the chart area.\r\n *\r\n * @type {boolean}\r\n * @memberof Chart\r\n */\r\n scrollToZoom?: boolean;\r\n /**\r\n * Tells the chart to render or not the grid lines.\r\n *\r\n * @type {boolean}\r\n * @memberof Chart\r\n */\r\n showGrid?: boolean;\r\n}\r\n\r\nexport type Shape = Trace;\r\n\r\nexport interface Trace {\r\n name?: string;\r\n /**\r\n * The variant of the Shape, must be of type Trace.\r\n *\r\n * @type {ShapeVariant}\r\n * @memberof Trace\r\n */\r\n variant: ShapeVariant;\r\n color?: string;\r\n /**\r\n * The type of the Trace drawn by the chart.\r\n * Can be a line or a scatter. \r\n *\r\n * @type {TraceType}\r\n * @memberof Trace\r\n */\r\n type: TraceType;\r\n width?: number;\r\n /**\r\n * The list of points that define the Trace.\r\n *\r\n * @type {Point[]}\r\n * @memberof Trace\r\n */\r\n points: Point[];\r\n /**\r\n * Whether to show a smooth curve or a segmented curve.\r\n *\r\n * @type {boolean}\r\n * @memberof Trace\r\n */\r\n smooth?: boolean;\r\n /**\r\n * The style of the Trace.\r\n * Can be solid, dashed or dotted.\r\n *\r\n * @type {TraceStyle}\r\n * @memberof Trace\r\n */\r\n style?: TraceStyle;\r\n /**\r\n * Option to make the Trace selected/deselected by default.\r\n * A deselected Trace is obscured from the chart and can be toggled from the legend. \r\n *\r\n * @type {boolean}\r\n * @memberof Trace\r\n */\r\n selectedByDefault?: boolean;\r\n opacity?: number;\r\n}\r\n\r\nexport interface Point extends BasePoint {\r\n name?: string;\r\n /**\r\n * Symbol used to represent the point in the chart.\r\n *\r\n * @type {PointSymbol}\r\n * @memberof Point\r\n */\r\n symbol?: PointSymbol;\r\n symbolSize?: number;\r\n color?: string;\r\n}\r\n\r\nexport interface BasePoint {\r\n x: number;\r\n y: number\r\n}\r\n\r\nexport enum TraceType {\r\n LINE = \"line\",\r\n SCATTER = \"scatter\"\r\n}\r\n\r\nexport enum PointSymbol {\r\n NONE = \"none\",\r\n CIRCLE = \"circle\",\r\n TRIANGLE = \"triangle\",\r\n PIN = \"pin\",\r\n DIAMOND = \"diamond\"\r\n}\r\n\r\nexport enum TraceStyle {\r\n SOLID = \"solid\",\r\n DASHED = \"dashed\",\r\n DOTTED = \"dotted\"\r\n}\r\n\r\nexport enum AxisType {\r\n VALUE = \"value\"\r\n}\r\n\r\nexport enum ShapeVariant {\r\n TRACE\r\n}\r\n\r\nexport type ChartTheme = 'default' | 'dark';","export const ZOOM_IN: string = \"M39.35 40.45 26.6 27.7q-1.55 1.35-3.6 2.025-2.05.675-4 .675-4.9 0-8.225-3.325Q7.45 23.75 7.45 18.9q0-4.9 3.325-8.225Q14.1 7.35 18.95 7.35q4.85 0 8.225 3.325t3.375 8.175q0 2.1-.725 4.1-.725 2-2.025 3.45l12.8 12.75ZM19 28.65q4.15 0 6.975-2.8 2.825-2.8 2.825-7 0-4.15-2.825-6.95T19 9.1q-4.2 0-7 2.8t-2.8 6.95q0 4.2 2.8 7t7 2.8Zm-.9-5.1V19.7h-3.85v-1.75h3.85v-3.8h1.75v3.8h3.8v1.75h-3.8v3.85Z\";\r\nexport const ZOOM_OUT: string = \"M41.25 39.35 29.55 27.7q-1.5 1.25-3.525 1.975Q24 30.4 22.05 30.4q-2.1 0-3.975-.725T14.9 27.65l1.2-1.2q1.2 1.1 2.65 1.65 1.45.55 3.25.55 4.2 0 7-2.8t2.8-7q0-4.15-2.8-6.95t-7-2.8q-4.15 0-7 2.8-2.85 2.8-2.75 6.95l3.2-3.4 1.3 1.3-5.35 5.35-5.3-5.35 1.3-1.3 3.05 3.3q0-4.85 3.4-8.125Q17.25 7.35 22 7.35q4.9 0 8.225 3.325Q33.55 14 33.55 18.85q0 2.1-.75 4.1-.75 2-1.95 3.45L42.5 38.05Z\";\r\nexport const SAVE_AS_SVG: string = \"M11.3 40.05q-1.35 0-2.35-1t-1-2.35V11.3q0-1.4 1-2.375 1-.975 2.35-.975h25.4q1.4 0 2.375.975.975.975.975 2.375v25.4q0 1.35-.975 2.35t-2.375 1Zm0-1.75h25.4q.6 0 1.1-.5.5-.5.5-1.1V11.3q0-.6-.5-1.1-.5-.5-1.1-.5H11.3q-.6 0-1.1.5-.5.5-.5 1.1v25.4q0 .6.5 1.1.5.5 1.1.5Zm4.1-5.15h17.65l-5.5-7.3-5.2 6.45-3.3-3.85ZM9.7 38.3V9.7v28.6Z\";\r\nexport const RESTORE: string = \"M24.2 25.65q-.65 0-1.125-.475T22.6 24q0-.7.475-1.2t1.175-.5q.65 0 1.175.525T25.95 24q0 .7-.55 1.175-.55.475-1.2.475Zm.1 14.55q-6.4 0-11.1-4.25Q8.5 31.7 8.1 25.4h1.8q.5 5.55 4.6 9.3 4.1 3.75 9.75 3.75 6.05 0 10.225-4.225T38.65 24.05q0-6.05-4.2-10.275Q30.25 9.55 24.3 9.55q-3.2 0-6.025 1.3t-4.875 3.6h4.95v1.75H10.4v-8h1.75v5.05q2.25-2.6 5.475-4.025Q20.85 7.8 24.3 7.8q3.3 0 6.225 1.25t5.125 3.475q2.2 2.225 3.475 5.175Q40.4 20.65 40.4 24q0 3.35-1.275 6.3-1.275 2.95-3.475 5.175-2.2 2.225-5.125 3.475T24.3 40.2Z\";\r\nexport const ADD_POINT: string = \"M222.895-189.538q-22.456 0-37.906-15.451-15.451-15.45-15.451-37.906v-474.21q0-22.456 15.451-37.906 15.45-15.451 38.088-15.451h322.346v28.924H223.077q-10.769 0-17.692 6.923t-6.923 17.692v473.846q0 10.769 6.923 17.692t17.692 6.923h473.846q10.77 0 17.693-6.923 6.923-6.923 6.923-17.692v-322.346h28.923v322.346q0 22.638-15.451 38.088-15.45 15.451-37.906 15.451h-474.21Zm78.028-121.539h28.923v-243.077h-28.923v243.077Zm144.923 0h28.923v-337.846h-28.923v337.846Zm144.308 0h28.923v-148.308h-28.923v148.308Zm100-327.692v-71.385h-71.385v-28.923h71.385v-71.385h28.923v71.385h71.385v28.923h-71.385v71.385h-28.923ZM460-480Z\";\r\n","// 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","// Angular General\r\nimport { Component, EventEmitter, Input, Output } from '@angular/core';\r\n// Kiwi Chart\r\nimport { Chart, BasePoint } from '../models/chart.models';\r\nimport { KiwiChartDirective } from '../directives/kiwi-chart.directive';\r\n\r\n@Component({\r\n selector: 'kiwi-chart',\r\n template: `\r\n <div \r\n kiwi-chart \r\n [chart]=\"chart\" \r\n [width]=\"width\"\r\n [height]=\"height\"\r\n [darkTheme]=\"darkTheme\"\r\n [darkThemeBackground]=\"darkThemeBackground\"\r\n (addPoint)=\"addPoint.emit($event)\"\r\n (chartHover)=\"chartHover.emit($event)\"\r\n ></div> \r\n `,\r\n styles: [``],\r\n standalone: true,\r\n imports: [KiwiChartDirective]\r\n})\r\nexport class KiwiChartComponent {\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({ 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 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 | null = null;\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","/*\r\n * Public API Surface of chart\r\n */\r\n\r\nexport * from './lib/components/chart.component';\r\nexport * from './lib/models/chart.models';","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"kiwibit-chart.mjs","sources":["../../../../projects/kiwibit/chart/src/lib/models/chart.models.ts","../../../../projects/kiwibit/chart/src/lib/constants/chart.constants.ts","../../../../projects/kiwibit/chart/src/lib/directives/kiwi-chart.directive.ts","../../../../projects/kiwibit/chart/src/lib/components/chart.component.ts","../../../../projects/kiwibit/chart/src/public-api.ts","../../../../projects/kiwibit/chart/src/kiwibit-chart.ts"],"sourcesContent":["/**\r\n * Interface to define the Chart model.\r\n *\r\n * @export\r\n * @interface Chart\r\n */\r\nexport interface Chart {\r\n title: string;\r\n showLegend?: boolean;\r\n xAxisType: AxisType;\r\n xAxisName: string;\r\n xAxisUom?: string;\r\n xMin?: number;\r\n xMax?: number;\r\n yAxisType: AxisType;\r\n yAxisName: string;\r\n yAxisUom?: string;\r\n yMin?: number;\r\n yMax?: number;\r\n /**\r\n * The maximum decimals that can have the values on the x and y axes.\r\n * If omitted the default is 3 decimals.\r\n *\r\n * @type {number}\r\n * @memberof Chart\r\n */\r\n maxAxesDecimals?: number;\r\n /**\r\n * If the chart should have rendering animations.\r\n *\r\n * @type {boolean}\r\n * @memberof Chart\r\n */\r\n hasAnimations?: boolean;\r\n /**\r\n * How long the animation should last.\r\n * Expressed in milliseconds. If omitted the Default is 500 ms.\r\n *\r\n * @type {number}\r\n * @memberof Chart\r\n */\r\n animationDuration?: number;\r\n /**\r\n * The list of Shapes that the chart must render.\r\n * Each Shape corrisponds to a single chart component.\r\n *\r\n * @type {Shape[]}\r\n * @memberof Chart\r\n */\r\n shapes: Shape[];\r\n /**\r\n * Adds interaction with the chart, so that when clicking\r\n * everywhere in the chart area a point gets added and it's coordinate are \r\n * emitted with an event to the parent component.\r\n *\r\n * @type {boolean}\r\n * @memberof Chart\r\n */\r\n clickToAddPoint?: boolean;\r\n /**\r\n * Custom name for the \"clickToAddPoint\" event related button. \r\n *\r\n * @type {string}\r\n * @memberof Chart\r\n */\r\n addPointCustomName?: string;\r\n /**\r\n * Adds the possibility to use the scroll \r\n * to zoom in/out the chart area.\r\n *\r\n * @type {boolean}\r\n * @memberof Chart\r\n */\r\n scrollToZoom?: boolean;\r\n /**\r\n * Tells the chart to render or not the grid lines.\r\n *\r\n * @type {boolean}\r\n * @memberof Chart\r\n */\r\n showGrid?: boolean;\r\n}\r\n\r\nexport type Shape = Trace;\r\n\r\nexport interface Trace {\r\n name?: string;\r\n /**\r\n * The variant of the Shape, must be of type Trace.\r\n *\r\n * @type {ShapeVariant}\r\n * @memberof Trace\r\n */\r\n variant: ShapeVariant;\r\n color?: string;\r\n /**\r\n * The type of the Trace drawn by the chart.\r\n * Can be a line or a scatter. \r\n *\r\n * @type {TraceType}\r\n * @memberof Trace\r\n */\r\n type: TraceType;\r\n width?: number;\r\n /**\r\n * The list of points that define the Trace.\r\n *\r\n * @type {Point[]}\r\n * @memberof Trace\r\n */\r\n points: Point[];\r\n /**\r\n * Whether to show a smooth curve or a segmented curve.\r\n *\r\n * @type {boolean}\r\n * @memberof Trace\r\n */\r\n smooth?: boolean;\r\n /**\r\n * The style of the Trace.\r\n * Can be solid, dashed or dotted.\r\n *\r\n * @type {TraceStyle}\r\n * @memberof Trace\r\n */\r\n style?: TraceStyle;\r\n /**\r\n * Option to make the Trace selected/deselected by default.\r\n * A deselected Trace is obscured from the chart and can be toggled from the legend. \r\n *\r\n * @type {boolean}\r\n * @memberof Trace\r\n */\r\n selectedByDefault?: boolean;\r\n opacity?: number;\r\n}\r\n\r\nexport interface Point extends BasePoint {\r\n name?: string;\r\n /**\r\n * Symbol used to represent the point in the chart.\r\n *\r\n * @type {PointSymbol}\r\n * @memberof Point\r\n */\r\n symbol?: PointSymbol;\r\n symbolSize?: number;\r\n color?: string;\r\n}\r\n\r\nexport interface BasePoint {\r\n x: number;\r\n y: number\r\n}\r\n\r\nexport enum TraceType {\r\n LINE = \"line\",\r\n SCATTER = \"scatter\"\r\n}\r\n\r\nexport enum PointSymbol {\r\n NONE = \"none\",\r\n CIRCLE = \"circle\",\r\n TRIANGLE = \"triangle\",\r\n PIN = \"pin\",\r\n DIAMOND = \"diamond\"\r\n}\r\n\r\nexport enum TraceStyle {\r\n SOLID = \"solid\",\r\n DASHED = \"dashed\",\r\n DOTTED = \"dotted\"\r\n}\r\n\r\nexport enum AxisType {\r\n VALUE = \"value\"\r\n}\r\n\r\nexport enum ShapeVariant {\r\n TRACE\r\n}\r\n\r\nexport type ChartTheme = 'default' | 'dark';","export const ZOOM_IN: string = \"M39.35 40.45 26.6 27.7q-1.55 1.35-3.6 2.025-2.05.675-4 .675-4.9 0-8.225-3.325Q7.45 23.75 7.45 18.9q0-4.9 3.325-8.225Q14.1 7.35 18.95 7.35q4.85 0 8.225 3.325t3.375 8.175q0 2.1-.725 4.1-.725 2-2.025 3.45l12.8 12.75ZM19 28.65q4.15 0 6.975-2.8 2.825-2.8 2.825-7 0-4.15-2.825-6.95T19 9.1q-4.2 0-7 2.8t-2.8 6.95q0 4.2 2.8 7t7 2.8Zm-.9-5.1V19.7h-3.85v-1.75h3.85v-3.8h1.75v3.8h3.8v1.75h-3.8v3.85Z\";\r\nexport const ZOOM_OUT: string = \"M41.25 39.35 29.55 27.7q-1.5 1.25-3.525 1.975Q24 30.4 22.05 30.4q-2.1 0-3.975-.725T14.9 27.65l1.2-1.2q1.2 1.1 2.65 1.65 1.45.55 3.25.55 4.2 0 7-2.8t2.8-7q0-4.15-2.8-6.95t-7-2.8q-4.15 0-7 2.8-2.85 2.8-2.75 6.95l3.2-3.4 1.3 1.3-5.35 5.35-5.3-5.35 1.3-1.3 3.05 3.3q0-4.85 3.4-8.125Q17.25 7.35 22 7.35q4.9 0 8.225 3.325Q33.55 14 33.55 18.85q0 2.1-.75 4.1-.75 2-1.95 3.45L42.5 38.05Z\";\r\nexport const SAVE_AS_SVG: string = \"M11.3 40.05q-1.35 0-2.35-1t-1-2.35V11.3q0-1.4 1-2.375 1-.975 2.35-.975h25.4q1.4 0 2.375.975.975.975.975 2.375v25.4q0 1.35-.975 2.35t-2.375 1Zm0-1.75h25.4q.6 0 1.1-.5.5-.5.5-1.1V11.3q0-.6-.5-1.1-.5-.5-1.1-.5H11.3q-.6 0-1.1.5-.5.5-.5 1.1v25.4q0 .6.5 1.1.5.5 1.1.5Zm4.1-5.15h17.65l-5.5-7.3-5.2 6.45-3.3-3.85ZM9.7 38.3V9.7v28.6Z\";\r\nexport const RESTORE: string = \"M24.2 25.65q-.65 0-1.125-.475T22.6 24q0-.7.475-1.2t1.175-.5q.65 0 1.175.525T25.95 24q0 .7-.55 1.175-.55.475-1.2.475Zm.1 14.55q-6.4 0-11.1-4.25Q8.5 31.7 8.1 25.4h1.8q.5 5.55 4.6 9.3 4.1 3.75 9.75 3.75 6.05 0 10.225-4.225T38.65 24.05q0-6.05-4.2-10.275Q30.25 9.55 24.3 9.55q-3.2 0-6.025 1.3t-4.875 3.6h4.95v1.75H10.4v-8h1.75v5.05q2.25-2.6 5.475-4.025Q20.85 7.8 24.3 7.8q3.3 0 6.225 1.25t5.125 3.475q2.2 2.225 3.475 5.175Q40.4 20.65 40.4 24q0 3.35-1.275 6.3-1.275 2.95-3.475 5.175-2.2 2.225-5.125 3.475T24.3 40.2Z\";\r\nexport const ADD_POINT: string = \"M222.895-189.538q-22.456 0-37.906-15.451-15.451-15.45-15.451-37.906v-474.21q0-22.456 15.451-37.906 15.45-15.451 38.088-15.451h322.346v28.924H223.077q-10.769 0-17.692 6.923t-6.923 17.692v473.846q0 10.769 6.923 17.692t17.692 6.923h473.846q10.77 0 17.693-6.923 6.923-6.923 6.923-17.692v-322.346h28.923v322.346q0 22.638-15.451 38.088-15.45 15.451-37.906 15.451h-474.21Zm78.028-121.539h28.923v-243.077h-28.923v243.077Zm144.923 0h28.923v-337.846h-28.923v337.846Zm144.308 0h28.923v-148.308h-28.923v148.308Zm100-327.692v-71.385h-71.385v-28.923h71.385v-71.385h28.923v71.385h71.385v28.923h-71.385v71.385h-28.923ZM460-480Z\";\r\n","// 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 LegendComponentOption,\r\n LineSeriesOption,\r\n ScatterSeriesOption,\r\n ToolboxComponentOption\r\n} from 'echarts/types/dist/shared'; \r\nimport { TitleComponent, TooltipComponent, GridComponent, LegendComponent, DataZoomComponent, ToolboxComponent, TitleComponentOption, TooltipComponentOption, GridComponentOption, DatasetComponentOption } from 'echarts/components';\r\nimport { LineChart, ScatterChart } 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 ScatterChart,\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.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.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: echarts.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 = echarts.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 id: 0,\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.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.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({gridId: 0}, pointInPixel);\r\n if (ec.containPixel({gridId: 0}, 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","// Angular General\r\nimport { Component, EventEmitter, Input, Output } from '@angular/core';\r\n// Kiwi Chart\r\nimport { Chart, BasePoint } from '../models/chart.models';\r\nimport { KiwiChartDirective } from '../directives/kiwi-chart.directive';\r\n\r\n@Component({\n selector: 'kiwi-chart',\n template: `\r\n <div \r\n kiwi-chart \r\n [chart]=\"chart\" \r\n [width]=\"width\"\r\n [height]=\"height\"\r\n [darkTheme]=\"darkTheme\"\r\n [darkThemeBackground]=\"darkThemeBackground\"\r\n (addPoint)=\"addPoint.emit($event)\"\r\n (chartHover)=\"chartHover.emit($event)\"\r\n ></div> \r\n `,\n styles: [``],\n imports: [KiwiChartDirective]\n})\r\nexport class KiwiChartComponent {\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({ 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 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 | null = null;\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","/*\r\n * Public API Surface of chart\r\n */\r\n\r\nexport * from './lib/components/chart.component';\r\nexport * from './lib/models/chart.models';","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { AfterViewInit, ElementRef, EventEmitter, OnChanges, SimpleChanges } from '@angular/core';
|
|
2
2
|
import { BasePoint, Chart, Shape, Trace } from '../models/chart.models';
|
|
3
|
-
import
|
|
3
|
+
import * as echarts from 'echarts/core';
|
|
4
|
+
import { ComposeOption, CustomSeriesOption, LegendComponentOption, LineSeriesOption, ScatterSeriesOption, ToolboxComponentOption } from 'echarts/types/dist/shared';
|
|
5
|
+
import { TitleComponentOption, TooltipComponentOption, GridComponentOption, DatasetComponentOption } from 'echarts/components';
|
|
4
6
|
import * as i0 from "@angular/core";
|
|
5
7
|
export type ECOption = ComposeOption<LineSeriesOption | TitleComponentOption | TooltipComponentOption | GridComponentOption | DatasetComponentOption | LegendComponentOption | ToolboxComponentOption>;
|
|
6
8
|
export declare class KiwiChartDirective implements OnChanges, AfterViewInit {
|
|
@@ -23,7 +25,7 @@ export declare class KiwiChartDirective implements OnChanges, AfterViewInit {
|
|
|
23
25
|
*/
|
|
24
26
|
width: string;
|
|
25
27
|
height: string;
|
|
26
|
-
chartInit: EventEmitter<ECharts>;
|
|
28
|
+
chartInit: EventEmitter<echarts.ECharts>;
|
|
27
29
|
/**
|
|
28
30
|
* Output event used to emit to the father component the coordinates
|
|
29
31
|
* of the point clicked in the chart area. This functionality to be used must
|
|
@@ -57,7 +59,7 @@ export declare class KiwiChartDirective implements OnChanges, AfterViewInit {
|
|
|
57
59
|
* @type {ECharts}
|
|
58
60
|
* @memberof KiwiChartDirective
|
|
59
61
|
*/
|
|
60
|
-
echartsInstance: ECharts | null;
|
|
62
|
+
echartsInstance: echarts.ECharts | null;
|
|
61
63
|
/**
|
|
62
64
|
* Default number of decimals that can have
|
|
63
65
|
* the values on the x and y axes.
|
|
@@ -75,7 +77,7 @@ export declare class KiwiChartDirective implements OnChanges, AfterViewInit {
|
|
|
75
77
|
* @type {(zrender.ZRenderType | null)}
|
|
76
78
|
* @memberof KiwiChartComponent
|
|
77
79
|
*/
|
|
78
|
-
zr: zrender.ZRenderType | null;
|
|
80
|
+
zr: echarts.zrender.ZRenderType | null;
|
|
79
81
|
/**
|
|
80
82
|
* If you resize the page, the chart is automatically re-rendered wiht the right proportions.
|
|
81
83
|
*
|
|
@@ -95,8 +97,8 @@ export declare class KiwiChartDirective implements OnChanges, AfterViewInit {
|
|
|
95
97
|
*
|
|
96
98
|
* @param ec
|
|
97
99
|
*/
|
|
98
|
-
setupLegendEventHandler(ec: ECharts): void;
|
|
99
|
-
setupZrEventHandler(ec: ECharts): void;
|
|
100
|
+
setupLegendEventHandler(ec: echarts.ECharts): void;
|
|
101
|
+
setupZrEventHandler(ec: echarts.ECharts): void;
|
|
100
102
|
static ɵfac: i0.ɵɵFactoryDeclaration<KiwiChartDirective, never>;
|
|
101
103
|
static ɵdir: i0.ɵɵDirectiveDeclaration<KiwiChartDirective, "div[kiwi-chart]", never, { "chart": { "alias": "chart"; "required": true; }; "width": { "alias": "width"; "required": false; }; "height": { "alias": "height"; "required": false; }; "darkTheme": { "alias": "darkTheme"; "required": false; }; "darkThemeBackground": { "alias": "darkThemeBackground"; "required": false; }; }, { "chartInit": "chartInit"; "addPoint": "addPoint"; "chartHover": "chartHover"; }, never, never, true, never>;
|
|
102
104
|
}
|
package/package.json
CHANGED
|
@@ -1,12 +1,15 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kiwibit/chart",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "19.0.0",
|
|
4
|
+
"engines": {
|
|
5
|
+
"node": "^18.19.1 || ^20.11.1 || ^22.0.0"
|
|
6
|
+
},
|
|
4
7
|
"peerDependencies": {
|
|
5
|
-
"@angular/common": "^
|
|
6
|
-
"@angular/core": "^
|
|
8
|
+
"@angular/common": "^19.1.3",
|
|
9
|
+
"@angular/core": "^19.1.3"
|
|
7
10
|
},
|
|
8
11
|
"dependencies": {
|
|
9
|
-
"echarts": "^5.
|
|
12
|
+
"echarts": "^5.6.0",
|
|
10
13
|
"tslib": "^2.3.0"
|
|
11
14
|
},
|
|
12
15
|
"licence": "MIT",
|
|
@@ -18,8 +21,6 @@
|
|
|
18
21
|
},
|
|
19
22
|
".": {
|
|
20
23
|
"types": "./index.d.ts",
|
|
21
|
-
"esm2022": "./esm2022/kiwibit-chart.mjs",
|
|
22
|
-
"esm": "./esm2022/kiwibit-chart.mjs",
|
|
23
24
|
"default": "./fesm2022/kiwibit-chart.mjs"
|
|
24
25
|
}
|
|
25
26
|
},
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './public-api';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2l3aWJpdC1jaGFydC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2tpd2liaXQvY2hhcnQvc3JjL2tpd2liaXQtY2hhcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -1,97 +0,0 @@
|
|
|
1
|
-
// Angular General
|
|
2
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
-
import { KiwiChartDirective } from '../directives/kiwi-chart.directive';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export class KiwiChartComponent {
|
|
6
|
-
constructor() {
|
|
7
|
-
/**
|
|
8
|
-
* The Chart Object rendered by the canvas. For all the available options refer
|
|
9
|
-
* to Chart interface in the models folder.
|
|
10
|
-
*
|
|
11
|
-
* @type {(Chart | null)}
|
|
12
|
-
* @memberof KiwiChartComponent
|
|
13
|
-
*/
|
|
14
|
-
this.chart = null;
|
|
15
|
-
/**
|
|
16
|
-
* Width and Height of the chart area. The dimensions refer to the father component
|
|
17
|
-
* into which the kiwi-chart is inserted. For example in an empty page the width/height
|
|
18
|
-
* of the chart can take the whole available space in the page.
|
|
19
|
-
*
|
|
20
|
-
* @type {string}
|
|
21
|
-
* @memberof KiwiChartComponent
|
|
22
|
-
*/
|
|
23
|
-
this.width = '100%';
|
|
24
|
-
this.height = '480px';
|
|
25
|
-
/**
|
|
26
|
-
* This property simply activates or not the dark theme of the chart
|
|
27
|
-
* defined by the Echarts library. In addition the background color can be custom
|
|
28
|
-
* so that the chart can match the background of the application in which it's used.
|
|
29
|
-
*
|
|
30
|
-
* @type {boolean}
|
|
31
|
-
* @memberof KiwiChartComponent
|
|
32
|
-
*/
|
|
33
|
-
this.darkTheme = false;
|
|
34
|
-
this.darkThemeBackground = null;
|
|
35
|
-
/**
|
|
36
|
-
* Output event used to emit to the father component the coordinates
|
|
37
|
-
* of the point clicked in the chart area. This functionality to be used must
|
|
38
|
-
* have the property "clickToAddPoint" in the Chart object set to true.
|
|
39
|
-
*
|
|
40
|
-
* @type {EventEmitter<BasePoint>}
|
|
41
|
-
* @memberof KiwiChartComponent
|
|
42
|
-
*/
|
|
43
|
-
this.addPoint = new EventEmitter();
|
|
44
|
-
/**
|
|
45
|
-
* When the cursor hovers the chart area it emits to the father component the
|
|
46
|
-
* x and y coordinates relative to the chart reference system.
|
|
47
|
-
*
|
|
48
|
-
* @type {EventEmitter<BasePoint>}
|
|
49
|
-
* @memberof KiwiChartComponent
|
|
50
|
-
*/
|
|
51
|
-
this.chartHover = new EventEmitter();
|
|
52
|
-
}
|
|
53
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: KiwiChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
54
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: KiwiChartComponent, isStandalone: true, selector: "kiwi-chart", inputs: { chart: "chart", width: "width", height: "height", darkTheme: "darkTheme", darkThemeBackground: "darkThemeBackground" }, outputs: { addPoint: "addPoint", chartHover: "chartHover" }, ngImport: i0, template: `
|
|
55
|
-
<div
|
|
56
|
-
kiwi-chart
|
|
57
|
-
[chart]="chart"
|
|
58
|
-
[width]="width"
|
|
59
|
-
[height]="height"
|
|
60
|
-
[darkTheme]="darkTheme"
|
|
61
|
-
[darkThemeBackground]="darkThemeBackground"
|
|
62
|
-
(addPoint)="addPoint.emit($event)"
|
|
63
|
-
(chartHover)="chartHover.emit($event)"
|
|
64
|
-
></div>
|
|
65
|
-
`, isInline: true, styles: [""], dependencies: [{ kind: "directive", type: KiwiChartDirective, selector: "div[kiwi-chart]", inputs: ["chart", "width", "height", "darkTheme", "darkThemeBackground"], outputs: ["chartInit", "addPoint", "chartHover"] }] }); }
|
|
66
|
-
}
|
|
67
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: KiwiChartComponent, decorators: [{
|
|
68
|
-
type: Component,
|
|
69
|
-
args: [{ selector: 'kiwi-chart', template: `
|
|
70
|
-
<div
|
|
71
|
-
kiwi-chart
|
|
72
|
-
[chart]="chart"
|
|
73
|
-
[width]="width"
|
|
74
|
-
[height]="height"
|
|
75
|
-
[darkTheme]="darkTheme"
|
|
76
|
-
[darkThemeBackground]="darkThemeBackground"
|
|
77
|
-
(addPoint)="addPoint.emit($event)"
|
|
78
|
-
(chartHover)="chartHover.emit($event)"
|
|
79
|
-
></div>
|
|
80
|
-
`, standalone: true, imports: [KiwiChartDirective] }]
|
|
81
|
-
}], propDecorators: { chart: [{
|
|
82
|
-
type: Input,
|
|
83
|
-
args: [{ required: true }]
|
|
84
|
-
}], width: [{
|
|
85
|
-
type: Input
|
|
86
|
-
}], height: [{
|
|
87
|
-
type: Input
|
|
88
|
-
}], darkTheme: [{
|
|
89
|
-
type: Input
|
|
90
|
-
}], darkThemeBackground: [{
|
|
91
|
-
type: Input
|
|
92
|
-
}], addPoint: [{
|
|
93
|
-
type: Output
|
|
94
|
-
}], chartHover: [{
|
|
95
|
-
type: Output
|
|
96
|
-
}] } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l3aWJpdC9jaGFydC9zcmMvbGliL2NvbXBvbmVudHMvY2hhcnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGtCQUFrQjtBQUNsQixPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR3ZFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDOztBQW9CeEUsTUFBTSxPQUFPLGtCQUFrQjtJQWxCL0I7UUFvQkU7Ozs7OztXQU1HO1FBQ3dCLFVBQUssR0FBaUIsSUFBSSxDQUFDO1FBRXREOzs7Ozs7O1dBT0c7UUFDTSxVQUFLLEdBQVcsTUFBTSxDQUFDO1FBQ3ZCLFdBQU0sR0FBVyxPQUFPLENBQUM7UUFFbEM7Ozs7Ozs7V0FPRztRQUNNLGNBQVMsR0FBWSxLQUFLLENBQUM7UUFDM0Isd0JBQW1CLEdBQWtCLElBQUksQ0FBQztRQUVuRDs7Ozs7OztXQU9HO1FBQ08sYUFBUSxHQUE0QixJQUFJLFlBQVksRUFBYSxDQUFDO1FBRTVFOzs7Ozs7V0FNRztRQUNPLGVBQVUsR0FBNEIsSUFBSSxZQUFZLEVBQWEsQ0FBQztLQUUvRTsrR0FwRFksa0JBQWtCO21HQUFsQixrQkFBa0IscVFBaEJuQjs7Ozs7Ozs7Ozs7R0FXVCwwRUFHUyxrQkFBa0I7OzRGQUVqQixrQkFBa0I7a0JBbEI5QixTQUFTOytCQUNFLFlBQVksWUFDWjs7Ozs7Ozs7Ozs7R0FXVCxjQUVXLElBQUksV0FDUCxDQUFDLGtCQUFrQixDQUFDOzhCQVdGLEtBQUs7c0JBQS9CLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO2dCQVVoQixLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQVVHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csbUJBQW1CO3NCQUEzQixLQUFLO2dCQVVJLFFBQVE7c0JBQWpCLE1BQU07Z0JBU0csVUFBVTtzQkFBbkIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbIi8vIEFuZ3VsYXIgR2VuZXJhbFxyXG5pbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG4vLyBLaXdpIENoYXJ0XHJcbmltcG9ydCB7IENoYXJ0LCBCYXNlUG9pbnQgfSBmcm9tICcuLi9tb2RlbHMvY2hhcnQubW9kZWxzJztcclxuaW1wb3J0IHsgS2l3aUNoYXJ0RGlyZWN0aXZlIH0gZnJvbSAnLi4vZGlyZWN0aXZlcy9raXdpLWNoYXJ0LmRpcmVjdGl2ZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2tpd2ktY2hhcnQnLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8ZGl2IFxyXG4gICAgICBraXdpLWNoYXJ0IFxyXG4gICAgICBbY2hhcnRdPVwiY2hhcnRcIiBcclxuICAgICAgW3dpZHRoXT1cIndpZHRoXCJcclxuICAgICAgW2hlaWdodF09XCJoZWlnaHRcIlxyXG4gICAgICBbZGFya1RoZW1lXT1cImRhcmtUaGVtZVwiXHJcbiAgICAgIFtkYXJrVGhlbWVCYWNrZ3JvdW5kXT1cImRhcmtUaGVtZUJhY2tncm91bmRcIlxyXG4gICAgICAoYWRkUG9pbnQpPVwiYWRkUG9pbnQuZW1pdCgkZXZlbnQpXCJcclxuICAgICAgKGNoYXJ0SG92ZXIpPVwiY2hhcnRIb3Zlci5lbWl0KCRldmVudClcIlxyXG4gICAgPjwvZGl2PiBcclxuICBgLFxyXG4gIHN0eWxlczogW2BgXSxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtLaXdpQ2hhcnREaXJlY3RpdmVdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLaXdpQ2hhcnRDb21wb25lbnQge1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgQ2hhcnQgT2JqZWN0IHJlbmRlcmVkIGJ5IHRoZSBjYW52YXMuIEZvciBhbGwgdGhlIGF2YWlsYWJsZSBvcHRpb25zIHJlZmVyIFxyXG4gICAqIHRvIENoYXJ0IGludGVyZmFjZSBpbiB0aGUgbW9kZWxzIGZvbGRlci5cclxuICAgKlxyXG4gICAqIEB0eXBlIHsoQ2hhcnQgfCBudWxsKX1cclxuICAgKiBAbWVtYmVyb2YgS2l3aUNoYXJ0Q29tcG9uZW50XHJcbiAgICovXHJcbiAgQElucHV0KHsgcmVxdWlyZWQ6IHRydWUgfSkgY2hhcnQ6IENoYXJ0IHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIC8qKlxyXG4gICAqIFdpZHRoIGFuZCBIZWlnaHQgb2YgdGhlIGNoYXJ0IGFyZWEuIFRoZSBkaW1lbnNpb25zIHJlZmVyIHRvIHRoZSBmYXRoZXIgY29tcG9uZW50IFxyXG4gICAqIGludG8gd2hpY2ggdGhlIGtpd2ktY2hhcnQgaXMgaW5zZXJ0ZWQuIEZvciBleGFtcGxlIGluIGFuIGVtcHR5IHBhZ2UgdGhlIHdpZHRoL2hlaWdodCBcclxuICAgKiBvZiB0aGUgY2hhcnQgY2FuIHRha2UgdGhlIHdob2xlIGF2YWlsYWJsZSBzcGFjZSBpbiB0aGUgcGFnZS5cclxuICAgKlxyXG4gICAqIEB0eXBlIHtzdHJpbmd9XHJcbiAgICogQG1lbWJlcm9mIEtpd2lDaGFydENvbXBvbmVudFxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHdpZHRoOiBzdHJpbmcgPSAnMTAwJSc7XHJcbiAgQElucHV0KCkgaGVpZ2h0OiBzdHJpbmcgPSAnNDgwcHgnO1xyXG5cclxuICAvKipcclxuICAgKiBUaGlzIHByb3BlcnR5IHNpbXBseSBhY3RpdmF0ZXMgb3Igbm90IHRoZSBkYXJrIHRoZW1lIG9mIHRoZSBjaGFydFxyXG4gICAqIGRlZmluZWQgYnkgdGhlIEVjaGFydHMgbGlicmFyeS4gSW4gYWRkaXRpb24gdGhlIGJhY2tncm91bmQgY29sb3IgY2FuIGJlIGN1c3RvbVxyXG4gICAqIHNvIHRoYXQgdGhlIGNoYXJ0IGNhbiBtYXRjaCB0aGUgYmFja2dyb3VuZCBvZiB0aGUgYXBwbGljYXRpb24gaW4gd2hpY2ggaXQncyB1c2VkLlxyXG4gICAqXHJcbiAgICogQHR5cGUge2Jvb2xlYW59XHJcbiAgICogQG1lbWJlcm9mIEtpd2lDaGFydENvbXBvbmVudFxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIGRhcmtUaGVtZTogYm9vbGVhbiA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpIGRhcmtUaGVtZUJhY2tncm91bmQ6IHN0cmluZyB8IG51bGwgPSBudWxsO1xyXG5cclxuICAvKipcclxuICAgKiBPdXRwdXQgZXZlbnQgdXNlZCB0byBlbWl0IHRvIHRoZSBmYXRoZXIgY29tcG9uZW50IHRoZSBjb29yZGluYXRlc1xyXG4gICAqIG9mIHRoZSBwb2ludCBjbGlja2VkIGluIHRoZSBjaGFydCBhcmVhLiBUaGlzIGZ1bmN0aW9uYWxpdHkgdG8gYmUgdXNlZCBtdXN0XHJcbiAgICogaGF2ZSB0aGUgcHJvcGVydHkgXCJjbGlja1RvQWRkUG9pbnRcIiBpbiB0aGUgQ2hhcnQgb2JqZWN0IHNldCB0byB0cnVlLlxyXG4gICAqXHJcbiAgICogQHR5cGUge0V2ZW50RW1pdHRlcjxCYXNlUG9pbnQ+fVxyXG4gICAqIEBtZW1iZXJvZiBLaXdpQ2hhcnRDb21wb25lbnRcclxuICAgKi9cclxuICBAT3V0cHV0KCkgYWRkUG9pbnQ6IEV2ZW50RW1pdHRlcjxCYXNlUG9pbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxCYXNlUG9pbnQ+KCk7XHJcblxyXG4gIC8qKlxyXG4gICAqIFdoZW4gdGhlIGN1cnNvciBob3ZlcnMgdGhlIGNoYXJ0IGFyZWEgaXQgZW1pdHMgdG8gdGhlIGZhdGhlciBjb21wb25lbnQgdGhlXHJcbiAgICogeCBhbmQgeSBjb29yZGluYXRlcyByZWxhdGl2ZSB0byB0aGUgY2hhcnQgcmVmZXJlbmNlIHN5c3RlbS5cclxuICAgKlxyXG4gICAqIEB0eXBlIHtFdmVudEVtaXR0ZXI8QmFzZVBvaW50Pn1cclxuICAgKiBAbWVtYmVyb2YgS2l3aUNoYXJ0Q29tcG9uZW50XHJcbiAgICovXHJcbiAgQE91dHB1dCgpIGNoYXJ0SG92ZXI6IEV2ZW50RW1pdHRlcjxCYXNlUG9pbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxCYXNlUG9pbnQ+KCk7XHJcblxyXG59XHJcbiJdfQ==
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
export const ZOOM_IN = "M39.35 40.45 26.6 27.7q-1.55 1.35-3.6 2.025-2.05.675-4 .675-4.9 0-8.225-3.325Q7.45 23.75 7.45 18.9q0-4.9 3.325-8.225Q14.1 7.35 18.95 7.35q4.85 0 8.225 3.325t3.375 8.175q0 2.1-.725 4.1-.725 2-2.025 3.45l12.8 12.75ZM19 28.65q4.15 0 6.975-2.8 2.825-2.8 2.825-7 0-4.15-2.825-6.95T19 9.1q-4.2 0-7 2.8t-2.8 6.95q0 4.2 2.8 7t7 2.8Zm-.9-5.1V19.7h-3.85v-1.75h3.85v-3.8h1.75v3.8h3.8v1.75h-3.8v3.85Z";
|
|
2
|
-
export const ZOOM_OUT = "M41.25 39.35 29.55 27.7q-1.5 1.25-3.525 1.975Q24 30.4 22.05 30.4q-2.1 0-3.975-.725T14.9 27.65l1.2-1.2q1.2 1.1 2.65 1.65 1.45.55 3.25.55 4.2 0 7-2.8t2.8-7q0-4.15-2.8-6.95t-7-2.8q-4.15 0-7 2.8-2.85 2.8-2.75 6.95l3.2-3.4 1.3 1.3-5.35 5.35-5.3-5.35 1.3-1.3 3.05 3.3q0-4.85 3.4-8.125Q17.25 7.35 22 7.35q4.9 0 8.225 3.325Q33.55 14 33.55 18.85q0 2.1-.75 4.1-.75 2-1.95 3.45L42.5 38.05Z";
|
|
3
|
-
export const SAVE_AS_SVG = "M11.3 40.05q-1.35 0-2.35-1t-1-2.35V11.3q0-1.4 1-2.375 1-.975 2.35-.975h25.4q1.4 0 2.375.975.975.975.975 2.375v25.4q0 1.35-.975 2.35t-2.375 1Zm0-1.75h25.4q.6 0 1.1-.5.5-.5.5-1.1V11.3q0-.6-.5-1.1-.5-.5-1.1-.5H11.3q-.6 0-1.1.5-.5.5-.5 1.1v25.4q0 .6.5 1.1.5.5 1.1.5Zm4.1-5.15h17.65l-5.5-7.3-5.2 6.45-3.3-3.85ZM9.7 38.3V9.7v28.6Z";
|
|
4
|
-
export const RESTORE = "M24.2 25.65q-.65 0-1.125-.475T22.6 24q0-.7.475-1.2t1.175-.5q.65 0 1.175.525T25.95 24q0 .7-.55 1.175-.55.475-1.2.475Zm.1 14.55q-6.4 0-11.1-4.25Q8.5 31.7 8.1 25.4h1.8q.5 5.55 4.6 9.3 4.1 3.75 9.75 3.75 6.05 0 10.225-4.225T38.65 24.05q0-6.05-4.2-10.275Q30.25 9.55 24.3 9.55q-3.2 0-6.025 1.3t-4.875 3.6h4.95v1.75H10.4v-8h1.75v5.05q2.25-2.6 5.475-4.025Q20.85 7.8 24.3 7.8q3.3 0 6.225 1.25t5.125 3.475q2.2 2.225 3.475 5.175Q40.4 20.65 40.4 24q0 3.35-1.275 6.3-1.275 2.95-3.475 5.175-2.2 2.225-5.125 3.475T24.3 40.2Z";
|
|
5
|
-
export const ADD_POINT = "M222.895-189.538q-22.456 0-37.906-15.451-15.451-15.45-15.451-37.906v-474.21q0-22.456 15.451-37.906 15.45-15.451 38.088-15.451h322.346v28.924H223.077q-10.769 0-17.692 6.923t-6.923 17.692v473.846q0 10.769 6.923 17.692t17.692 6.923h473.846q10.77 0 17.693-6.923 6.923-6.923 6.923-17.692v-322.346h28.923v322.346q0 22.638-15.451 38.088-15.45 15.451-37.906 15.451h-474.21Zm78.028-121.539h28.923v-243.077h-28.923v243.077Zm144.923 0h28.923v-337.846h-28.923v337.846Zm144.308 0h28.923v-148.308h-28.923v148.308Zm100-327.692v-71.385h-71.385v-28.923h71.385v-71.385h28.923v71.385h71.385v28.923h-71.385v71.385h-28.923ZM460-480Z";
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQuY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l3aWJpdC9jaGFydC9zcmMvbGliL2NvbnN0YW50cy9jaGFydC5jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFXLHNZQUFzWSxDQUFDO0FBQ3RhLE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBVyw0WEFBNFgsQ0FBQztBQUM3WixNQUFNLENBQUMsTUFBTSxXQUFXLEdBQVcsc1VBQXNVLENBQUM7QUFDMVcsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFXLCtmQUErZixDQUFDO0FBQy9oQixNQUFNLENBQUMsTUFBTSxTQUFTLEdBQVcscW1CQUFxbUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBaT09NX0lOOiBzdHJpbmcgPSBcIk0zOS4zNSA0MC40NSAyNi42IDI3LjdxLTEuNTUgMS4zNS0zLjYgMi4wMjUtMi4wNS42NzUtNCAuNjc1LTQuOSAwLTguMjI1LTMuMzI1UTcuNDUgMjMuNzUgNy40NSAxOC45cTAtNC45IDMuMzI1LTguMjI1UTE0LjEgNy4zNSAxOC45NSA3LjM1cTQuODUgMCA4LjIyNSAzLjMyNXQzLjM3NSA4LjE3NXEwIDIuMS0uNzI1IDQuMS0uNzI1IDItMi4wMjUgMy40NWwxMi44IDEyLjc1Wk0xOSAyOC42NXE0LjE1IDAgNi45NzUtMi44IDIuODI1LTIuOCAyLjgyNS03IDAtNC4xNS0yLjgyNS02Ljk1VDE5IDkuMXEtNC4yIDAtNyAyLjh0LTIuOCA2Ljk1cTAgNC4yIDIuOCA3dDcgMi44Wm0tLjktNS4xVjE5LjdoLTMuODV2LTEuNzVoMy44NXYtMy44aDEuNzV2My44aDMuOHYxLjc1aC0zLjh2My44NVpcIjtcclxuZXhwb3J0IGNvbnN0IFpPT01fT1VUOiBzdHJpbmcgPSBcIk00MS4yNSAzOS4zNSAyOS41NSAyNy43cS0xLjUgMS4yNS0zLjUyNSAxLjk3NVEyNCAzMC40IDIyLjA1IDMwLjRxLTIuMSAwLTMuOTc1LS43MjVUMTQuOSAyNy42NWwxLjItMS4ycTEuMiAxLjEgMi42NSAxLjY1IDEuNDUuNTUgMy4yNS41NSA0LjIgMCA3LTIuOHQyLjgtN3EwLTQuMTUtMi44LTYuOTV0LTctMi44cS00LjE1IDAtNyAyLjgtMi44NSAyLjgtMi43NSA2Ljk1bDMuMi0zLjQgMS4zIDEuMy01LjM1IDUuMzUtNS4zLTUuMzUgMS4zLTEuMyAzLjA1IDMuM3EwLTQuODUgMy40LTguMTI1UTE3LjI1IDcuMzUgMjIgNy4zNXE0LjkgMCA4LjIyNSAzLjMyNVEzMy41NSAxNCAzMy41NSAxOC44NXEwIDIuMS0uNzUgNC4xLS43NSAyLTEuOTUgMy40NUw0Mi41IDM4LjA1WlwiO1xyXG5leHBvcnQgY29uc3QgU0FWRV9BU19TVkc6IHN0cmluZyA9IFwiTTExLjMgNDAuMDVxLTEuMzUgMC0yLjM1LTF0LTEtMi4zNVYxMS4zcTAtMS40IDEtMi4zNzUgMS0uOTc1IDIuMzUtLjk3NWgyNS40cTEuNCAwIDIuMzc1Ljk3NS45NzUuOTc1Ljk3NSAyLjM3NXYyNS40cTAgMS4zNS0uOTc1IDIuMzV0LTIuMzc1IDFabTAtMS43NWgyNS40cS42IDAgMS4xLS41LjUtLjUuNS0xLjFWMTEuM3EwLS42LS41LTEuMS0uNS0uNS0xLjEtLjVIMTEuM3EtLjYgMC0xLjEuNS0uNS41LS41IDEuMXYyNS40cTAgLjYuNSAxLjEuNS41IDEuMS41Wm00LjEtNS4xNWgxNy42NWwtNS41LTcuMy01LjIgNi40NS0zLjMtMy44NVpNOS43IDM4LjNWOS43djI4LjZaXCI7XHJcbmV4cG9ydCBjb25zdCBSRVNUT1JFOiBzdHJpbmcgPSBcIk0yNC4yIDI1LjY1cS0uNjUgMC0xLjEyNS0uNDc1VDIyLjYgMjRxMC0uNy40NzUtMS4ydDEuMTc1LS41cS42NSAwIDEuMTc1LjUyNVQyNS45NSAyNHEwIC43LS41NSAxLjE3NS0uNTUuNDc1LTEuMi40NzVabS4xIDE0LjU1cS02LjQgMC0xMS4xLTQuMjVROC41IDMxLjcgOC4xIDI1LjRoMS44cS41IDUuNTUgNC42IDkuMyA0LjEgMy43NSA5Ljc1IDMuNzUgNi4wNSAwIDEwLjIyNS00LjIyNVQzOC42NSAyNC4wNXEwLTYuMDUtNC4yLTEwLjI3NVEzMC4yNSA5LjU1IDI0LjMgOS41NXEtMy4yIDAtNi4wMjUgMS4zdC00Ljg3NSAzLjZoNC45NXYxLjc1SDEwLjR2LThoMS43NXY1LjA1cTIuMjUtMi42IDUuNDc1LTQuMDI1UTIwLjg1IDcuOCAyNC4zIDcuOHEzLjMgMCA2LjIyNSAxLjI1dDUuMTI1IDMuNDc1cTIuMiAyLjIyNSAzLjQ3NSA1LjE3NVE0MC40IDIwLjY1IDQwLjQgMjRxMCAzLjM1LTEuMjc1IDYuMy0xLjI3NSAyLjk1LTMuNDc1IDUuMTc1LTIuMiAyLjIyNS01LjEyNSAzLjQ3NVQyNC4zIDQwLjJaXCI7XHJcbmV4cG9ydCBjb25zdCBBRERfUE9JTlQ6IHN0cmluZyA9IFwiTTIyMi44OTUtMTg5LjUzOHEtMjIuNDU2IDAtMzcuOTA2LTE1LjQ1MS0xNS40NTEtMTUuNDUtMTUuNDUxLTM3LjkwNnYtNDc0LjIxcTAtMjIuNDU2IDE1LjQ1MS0zNy45MDYgMTUuNDUtMTUuNDUxIDM4LjA4OC0xNS40NTFoMzIyLjM0NnYyOC45MjRIMjIzLjA3N3EtMTAuNzY5IDAtMTcuNjkyIDYuOTIzdC02LjkyMyAxNy42OTJ2NDczLjg0NnEwIDEwLjc2OSA2LjkyMyAxNy42OTJ0MTcuNjkyIDYuOTIzaDQ3My44NDZxMTAuNzcgMCAxNy42OTMtNi45MjMgNi45MjMtNi45MjMgNi45MjMtMTcuNjkydi0zMjIuMzQ2aDI4LjkyM3YzMjIuMzQ2cTAgMjIuNjM4LTE1LjQ1MSAzOC4wODgtMTUuNDUgMTUuNDUxLTM3LjkwNiAxNS40NTFoLTQ3NC4yMVptNzguMDI4LTEyMS41MzloMjguOTIzdi0yNDMuMDc3aC0yOC45MjN2MjQzLjA3N1ptMTQ0LjkyMyAwaDI4LjkyM3YtMzM3Ljg0NmgtMjguOTIzdjMzNy44NDZabTE0NC4zMDggMGgyOC45MjN2LTE0OC4zMDhoLTI4LjkyM3YxNDguMzA4Wm0xMDAtMzI3LjY5MnYtNzEuMzg1aC03MS4zODV2LTI4LjkyM2g3MS4zODV2LTcxLjM4NWgyOC45MjN2NzEuMzg1aDcxLjM4NXYyOC45MjNoLTcxLjM4NXY3MS4zODVoLTI4LjkyM1pNNDYwLTQ4MFpcIjtcclxuIl19
|
|
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2l3aS1jaGFydC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXdpYml0L2NoYXJ0L3NyYy9saWIvZGlyZWN0aXZlcy9raXdpLWNoYXJ0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxrQkFBa0I7QUFDbEIsT0FBTyxFQUFpQixTQUFTLEVBQWMsWUFBWSxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQWEsTUFBTSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUMxSSxxQkFBcUI7QUFDckIsT0FBTyxFQUFrQyxZQUFZLEVBQVMsTUFBTSx3QkFBd0IsQ0FBQztBQUM3RixPQUFPLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xHLGtCQUFrQjtBQUNsQixPQUFPLEtBQUssT0FBTyxNQUFNLGNBQWMsQ0FBQztBQUN4QyxPQUFPLEVBWUwsSUFBSSxFQUVMLE1BQU0sU0FBUyxDQUFDO0FBQ2pCLE9BQU8sRUFBRSxjQUFjLEVBQUUsZ0JBQWdCLEVBQUUsYUFBYSxFQUFFLGVBQWUsRUFBRSxpQkFBaUIsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQzNJLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBQ25ELE9BQU8sQ0FBQyxHQUFHLENBQUM7SUFDVixjQUFjO0lBQ2QsZ0JBQWdCO0lBQ2hCLGFBQWE7SUFDYixTQUFTO0lBQ1QsY0FBYztJQUNkLGVBQWU7SUFDZixpQkFBaUI7SUFDakIsZ0JBQWdCO0NBQ2pCLENBQUMsQ0FBQztBQWVILE1BQU0sT0FBTyxrQkFBa0I7SUFtRjdCOzs7O01BSUU7SUFFRixRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsZUFBZSxFQUFF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dCwgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBFdmVudEVtaXR0ZXIsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIE9uQ2hhbmdlcywgT3V0cHV0LCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbi8vIEtpd2kgQ2hhcnQgSW1wb3J0c1xyXG5pbXBvcnQgeyBCYXNlUG9pbnQsIENoYXJ0LCBQb2ludCwgU2hhcGUsIFNoYXBlVmFyaWFudCwgVHJhY2UgfSBmcm9tICcuLi9tb2RlbHMvY2hhcnQubW9kZWxzJztcclxuaW1wb3J0IHsgQUREX1BPSU5ULCBSRVNUT1JFLCBTQVZFX0FTX1NWRywgWk9PTV9JTiwgWk9PTV9PVVQgfSBmcm9tICcuLi9jb25zdGFudHMvY2hhcnQuY29uc3RhbnRzJztcclxuLy8gRWNoYXJ0cyBJbXBvcnRzXHJcbmltcG9ydCAqIGFzIGVjaGFydHMgZnJvbSAnZWNoYXJ0cy9jb3JlJztcclxuaW1wb3J0IHtcclxuICBDb21wb3NlT3B0aW9uLFxyXG4gIEN1c3RvbVNlcmllc09wdGlvbixcclxuICBEYXRhc2V0Q29tcG9uZW50T3B0aW9uLFxyXG4gIEVDaGFydHMsXHJcbiAgR3JpZENvbXBvbmVudE9wdGlvbixcclxuICBMZWdlbmRDb21wb25lbnRPcHRpb24sXHJcbiAgTGluZVNlcmllc09wdGlvbixcclxuICBTY2F0dGVyU2VyaWVzT3B0aW9uLFxyXG4gIFRpdGxlQ29tcG9uZW50T3B0aW9uLFxyXG4gIFRvb2xib3hDb21wb25lbnRPcHRpb24sXHJcbiAgVG9vbHRpcENvbXBvbmVudE9wdGlvbixcclxuICBpbml0LFxyXG4gIHpyZW5kZXJcclxufSBmcm9tICdlY2hhcnRzJztcclxuaW1wb3J0IHsgVGl0bGVDb21wb25lbnQsIFRvb2x0aXBDb21wb25lbnQsIEdyaWRDb21wb25lbnQsIExlZ2VuZENvbXBvbmVudCwgRGF0YVpvb21Db21wb25lbnQsIFRvb2xib3hDb21wb25lbnQgfSBmcm9tICdlY2hhcnRzL2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBMaW5lQ2hhcnQgfSBmcm9tICdlY2hhcnRzL2NoYXJ0cyc7XHJcbmltcG9ydCB7IENhbnZhc1JlbmRlcmVyIH0gZnJvbSAnZWNoYXJ0cy9yZW5kZXJlcnMnO1xyXG5lY2hhcnRzLnVzZShbXHJcbiAgVGl0bGVDb21wb25lbnQsXHJcbiAgVG9vbHRpcENvbXBvbmVudCxcclxuICBHcmlkQ29tcG9uZW50LFxyXG4gIExpbmVDaGFydCxcclxuICBDYW52YXNSZW5kZXJlcixcclxuICBMZWdlbmRDb21wb25lbnQsXHJcbiAgRGF0YVpvb21Db21wb25lbnQsXHJcbiAgVG9vbGJveENvbXBvbmVudCxcclxuXSk7XHJcbmV4cG9ydCB0eXBlIEVDT3B0aW9uID0gQ29tcG9zZU9wdGlvbjxcclxuICB8IExpbmVTZXJpZXNPcHRpb25cclxuICB8IFRpdGxlQ29tcG9uZW50T3B0aW9uXHJcbiAgfCBUb29sdGlwQ29tcG9uZW50T3B0aW9uXHJcbiAgfCBHcmlkQ29tcG9uZW50T3B0aW9uXHJcbiAgfCBEYXRhc2V0Q29tcG9uZW50T3B0aW9uXHJcbiAgfCBMZWdlbmRDb21wb25lbnRPcHRpb25cclxuICB8IFRvb2xib3hDb21wb25lbnRPcHRpb25cclxuPjtcclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiAnZGl2W2tpd2ktY2hhcnRdJyxcclxuICBzdGFuZGFsb25lOiB0cnVlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLaXdpQ2hhcnREaXJlY3RpdmUgaW1wbGVtZW50cyBPbkNoYW5nZXMsIEFmdGVyVmlld0luaXQge1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgQ2hhcnQgT2JqZWN0IHJlbmRlcmVkIGJ5IHRoZSBjYW52YXMuIEZvciBhbGwgdGhlIGF2YWlsYWJsZSBvcHRpb25zIHJlZmVyIFxyXG4gICAqIHRvIENoYXJ0IGludGVyZmFjZSBpbiB0aGUgbW9kZWxzIGZvbGRlci5cclxuICAgKlxyXG4gICAqIEB0eXBlIHsoQ2hhcnQgfCBudWxsKX1cclxuICAgKiBAbWVtYmVyb2YgS2l3aUNoYXJ0RGlyZWN0aXZlXHJcbiAgICovXHJcbiAgQElucHV0KHsgcmVxdWlyZWQ6IHRydWUgfSkgY2hhcnQ6IENoYXJ0IHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIC8qKlxyXG4gICAqIFdpZHRoIGFuZCBIZWlnaHQgb2YgdGhlIGNoYXJ0IGFyZWEuIFRoZSBkaW1lbnNpb25zIHJlZmVyIHRvIHRoZSBmYXRoZXIgY29tcG9uZW50IFxyXG4gICAqIGludG8gd2hpY2ggdGhlIGtpd2ktY2hhcnQgaXMgaW5zZXJ0ZWQuIEZvciBleGFtcGxlIGluIGFuIGVtcHR5IHBhZ2UgdGhlIHdpZHRoL2hlaWdodCBcclxuICAgKiBvZiB0aGUgY2hhcnQgY2FuIHRha2UgdGhlIHdob2xlIGF2YWlsYWJsZSBzcGFjZSBpbiB0aGUgcGFnZS5cclxuICAgKlxyXG4gICAqIEB0eXBlIHtzdHJpbmd9XHJcbiAgICogQG1lbWJlcm9mIEtpd2lDaGFydERpcmVjdGl2ZVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHdpZHRoOiBzdHJpbmcgPSAnMTAwJSc7XHJcbiAgQElucHV0KCkgaGVpZ2h0OiBzdHJpbmcgPSAnNDgwcHgnO1xyXG5cclxuICBAT3V0cHV0KCkgY2hhcnRJbml0ID0gbmV3IEV2ZW50RW1pdHRlcjxFQ2hhcnRzPigpO1xyXG5cclxuICAvKipcclxuICAgKiBPdXRwdXQgZXZlbnQgdXNlZCB0byBlbWl0IHRvIHRoZSBmYXRoZXIgY29tcG9uZW50IHRoZSBjb29yZGluYXRlc1xyXG4gICAqIG9mIHRoZSBwb2ludCBjbGlja2VkIGluIHRoZSBjaGFydCBhcmVhLiBUaGlzIGZ1bmN0aW9uYWxpdHkgdG8gYmUgdXNlZCBtdXN0XHJcbiAgICogaGF2ZSB0aGUgcHJvcGVydHkgXCJjbGlja1RvQWRkUG9pbnRcIiBpbiB0aGUgQ2hhcnQgb2JqZWN0IHNldCB0byB0cnVlLlxyXG4gICAqXHJcbiAgICogQHR5cGUge0V2ZW50RW1pdHRlcjxCYXNlUG9pbnQ+fVxyXG4gICAqIEBtZW1iZXJvZiBLaXdpQ2hhcnREaXJlY3RpdmVcclxuICAgKi9cclxuICBAT3V0cHV0KCkgYWRkUG9pbnQ6IEV2ZW50RW1pdHRlcjxCYXNlUG9pbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxCYXNlUG9pbnQ+KCk7XHJcblxyXG4gIC8qKlxyXG4gICAqIFdoZW4gdGhlIGN1cnNvciBob3ZlcnMgdGhlIGNoYXJ0IGFyZWEgaXQgZW1pdHMgdG8gdGhlIGZhdGhlciBjb21wb25lbnQgdGhlXHJcbiAgICogeCBhbmQgeSBjb29yZGluYXRlcyByZWxhdGl2ZSB0byB0aGUgY2hhcnQgcmVmZXJlbmNlIHN5c3RlbS5cclxuICAgKlxyXG4gICAqIEB0eXBlIHtFdmVudEVtaXR0ZXI8QmFzZVBvaW50Pn1cclxuICAgKiBAbWVtYmVyb2YgS2l3aUNoYXJ0RGlyZWN0aXZlXHJcbiAgICovXHJcbiAgQE91dHB1dCgpIGNoYXJ0SG92ZXI6IEV2ZW50RW1pdHRlcjxCYXNlUG9pbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxCYXNlUG9pbnQ+KCk7XHJcblxyXG4gIC8qKlxyXG4gICAqIFRoaXMgcHJvcGVydHkgc2ltcGx5IGFjdGl2YXRlcyBvciBub3QgdGhlIGRhcmsgdGhlbWUgb2YgdGhlIGNoYXJ0XHJcbiAgICogZGVmaW5lZCBieSB0aGUgRWNoYXJ0cyBsaWJyYXJ5LiBJbiBhZGRpdGlvbiB0aGUgYmFja2dyb3VuZCBjb2xvciBjYW4gYmUgY3VzdG9tXHJcbiAgICogc28gdGhhdCB0aGUgY2hhcnQgY2FuIG1hdGNoIHRoZSBiYWNrZ3JvdW5kIG9mIHRoZSBhcHBsaWNhdGlvbiBpbiB3aGljaCBpdCdzIHVzZWQuXHJcbiAgICpcclxuICAgKiBAdHlwZSB7Ym9vbGVhbn1cclxuICAgKiBAbWVtYmVyb2YgS2l3aUNoYXJ0RGlyZWN0aXZlXHJcbiAgICovXHJcbiAgQElucHV0KCkgZGFya1RoZW1lOiBib29sZWFuID0gZmFsc2U7XHJcbiAgQElucHV0KCkgZGFya1RoZW1lQmFja2dyb3VuZDogc3RyaW5nIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIC8qKlxyXG4gICAqIFRoZSBpbnN0YW5jZSBvZiB0aGUgQ2hhcnQuXHJcbiAgICpcclxuICAgKiBAdHlwZSB7RUNoYXJ0c31cclxuICAgKiBAbWVtYmVyb2YgS2l3aUNoYXJ0RGlyZWN0aXZlXHJcbiAgICovXHJcbiAgZWNoYXJ0c0luc3RhbmNlOiBFQ2hhcnRzIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIC8qKlxyXG4gICAqIERlZmF1bHQgbnVtYmVyIG9mIGRlY2ltYWxzIHRoYXQgY2FuIGhhdmVcclxuICAgKiB0aGUgdmFsdWVzIG9uIHRoZSB4IGFuZCB5IGF4ZXMuXHJcbiAgICpcclxuICAgKiBAcHJpdmF0ZVxyXG4gICAqIEB0eXBlIHtudW1iZXJ9XHJcbiAgICogQG1lbWJlcm9mIEtpd2lDaGFydERpcmVjdGl2ZVxyXG4gICAqL1xyXG4gIHByaXZhdGUgcmVhZG9ubHkgTUFYX0RFQ0lNQUxTOiBudW1iZXIgPSAzO1xyXG5cclxuICBwcml2YXRlIGxlZ2VuZFNlbGVjdGVkOiB7IFtrZXk6IHN0cmluZ106IGJvb2xlYW4gfSA9IHt9O1xyXG4gIHByaXZhdGUgaXNMZWdlbmRDbGlja2VkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIC8qKlxyXG4gICAqIFVzZWQgdG8gcGVyZm9ybSBhY3Rpb25zIChhcyBwb2ludCBhZGRpdGlvbiBiYXNlZCBvbiB0aGUgY3Vyc29yIHBvc2l0aW9uKSBvbiB0aGUgY2hhcnQuXHJcbiAgICpcclxuICAgKiBAdHlwZSB7KHpyZW5kZXIuWlJlbmRlclR5cGUgfCBudWxsKX1cclxuICAgKiBAbWVtYmVyb2YgS2l3aUNoYXJ0Q29tcG9uZW50XHJcbiAgICovXHJcbiAgenI6IHpyZW5kZXIuWlJlbmRlclR5cGUgfCBudWxsID0gbnVsbDtcclxuXHJcbiAgLyoqXHJcbiAgKiBJZiB5b3UgcmVzaXplIHRoZSBwYWdlLCB0aGUgY2hhcnQgaXMgYXV0b21hdGljYWxseSByZS1yZW5kZXJlZCB3aWh0IHRoZSByaWdodCBwcm9wb3J0aW9ucy5cclxuICAqXHJcbiAgKiBAbWVtYmVyb2YgRW5jaGFydGluZ0RpcmVjdGl2ZVxyXG4gICovXHJcbiAgQEhvc3RMaXN0ZW5lcignd2luZG93OnJlc2l6ZScsIFsnJGV2ZW50J10pXHJcbiAgb25SZXNpemUoKSB7XHJcbiAgICBpZiAodGhpcy5lY2hhcnRzSW5zdGFuY2UpIHtcclxuICAgICAgdGhpcy5lY2hhcnRzSW5zdGFuY2UucmVzaXplKCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgZWw6IEVsZW1lbnRSZWY8SFRNTERpdkVsZW1lbnQ+XHJcbiAgKSB7IH1cclxuXHJcbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgaWYgKHRoaXMuY2hhcnQpIHtcclxuICAgICAgdGhpcy5yZW5kZXJDaGFydCh0aGlzLmNoYXJ0KTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcclxuICAgIGxldCBjaGFydDogQ2hhcnQgPSBjaGFuZ2VzWydjaGFydCddPy5jdXJyZW50VmFsdWU7XHJcbiAgICBpZiAodGhpcy5lY2hhcnRzSW5zdGFuY2UpIHtcclxuICAgICAgLy8gRXZlcnkgdGltZSB3ZSBoYXZlIGFuIGV4dGVybmFsIGNoYW5nZSB3ZVxyXG4gICAgICAvLyBkZXN0cm95IHRoZSBjaGFydCBhbmQgcmUtaW5pdGlhbGl6ZSBpdFxyXG4gICAgICB0aGlzLmVjaGFydHNJbnN0YW5jZS5kaXNwb3NlKCk7XHJcbiAgICAgIHRoaXMucmVuZGVyQ2hhcnQoY2hhcnQpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcmVuZGVyQ2hhcnQoY2hhcnQ6IENoYXJ0KTogdm9pZCB7XHJcbiAgICAvLyBVcGRhdGUgRWxlbWVudFJlZiBzdHlsZXNcclxuICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5zdHlsZS53aWR0aCA9IHRoaXMud2lkdGg7XHJcbiAgICB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQuc3R5bGUuaGVpZ2h0ID0gdGhpcy5oZWlnaHQ7XHJcblxyXG4gICAgdGhpcy5lY2hhcnRzSW5zdGFuY2UgPSBpbml0KFxyXG4gICAgICB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQsXHJcbiAgICAgIHRoaXMuZGFya1RoZW1lID8gJ2RhcmsnIDogJ2RlZmF1bHQnLFxyXG4gICAgICB7XHJcbiAgICAgICAgcmVuZGVyZXI6ICdzdmcnXHJcbiAgICAgIH1cclxuICAgICk7XHJcblxyXG4gICAgaWYgKGNoYXJ0KSB7XHJcbiAgICAgIHRoaXMuZWNoYXJ0c0luc3RhbmNlLnNldE9wdGlvbih7XHJcbiAgICAgICAgdGl0bGU6IHtcclxuICAgICAgICAgIHRleHQ6IGNoYXJ0LnRpdGxlLFxyXG4gICAgICAgIH0sXHJcbiAgICAgICAgZ3JpZDoge1xyXG4gICAgICAgICAgd2lkdGg6ICc3MCUnXHJcbiAgICAgICAgfSxcclxuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoaXMuZGFya1RoZW1lID8gdGhpcy5kYXJrVGhlbWVCYWNrZ3JvdW5kID8/ICcjMzAzMDMwJyA6ICd0cmFuc3BhcmVudCcsIHRvb2x0aXA6IHtcclxuICAgICAgICAgIGF4aXNQb2ludGVyOiB7XHJcbiAgICAgICAgICAgIHR5cGU6ICdjcm9zcycsXHJcbiAgICAgICAgICAgIGNyb3NzU3R5bGU6IHtcclxuICAgICAgICAgICAgICBjb2xvcjogJyNiZWJlYmUnXHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgIH1cclxuICAgICAgICB9LFxyXG4gICAgICAgIHRvb2xib3g6IHtcclxuICAgICAgICAgIG9yaWVudDogJ2hvcml6b250YWwnLFxyXG4gICAgICAgICAgbGVmdDogJ2NlbnRlcicsXHJcbiAgICAgICAgICB0b3A6ICcyNXB4JyxcclxuICAgICAgICAgIGZlYXR1cmU6IHtcclxuICAgICAgICAgICAgZGF0YVpvb206IHtcclxuICAgICAgICAgICAgICBicnVzaFN0eWxlOiB7XHJcbiAgICAgICAgICAgICAgICBib3JkZXJDb2xvcjogJyMwMDAnLFxyXG4gICAgICAgICAgICAgICAgYm9yZGVyV2lkdGg6IDEsXHJcbiAgICAgICAgICAgICAgICBib3JkZXJUeXBlOiAnZGFzaGVkJ1xyXG4gICAgICAgICAgICAgIH0sXHJcbiAgICAgICAgICAgICAgZW1waGFzaXM6IHtcclxuICAgICAgICAgICAgICAgIGljb25TdHlsZToge1xyXG4gICAgICAgICAgICAgICAgICB0ZXh0UG9zaXRpb246ICd0b3AnLFxyXG4gICAgICAgICAgICAgICAgICB0ZXh0UGFkZGluZzogNVxyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgIH0sXHJcbiAgICAgICAgICAgICAgaWNvbjoge1xyXG4gICAgICAgICAgICAgICAgem9vbTogWk9PTV9JTixcclxuICAgICAgICAgICAgICAgIGJhY2s6IFpPT01fT1VUXHJcbiAgICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAgc2F2ZUFzSW1hZ2U6IHtcclxuICAgICAgICAgICAgICBlbXBoYXNpczoge1xyXG4gICAgICAgICAgICAgICAgaWNvblN0eWxlOiB7XHJcbiAgICAgICAgICAgICAgICAgIHRleHRQb3NpdGlvbjogJ3RvcCcsXHJcbiAgICAgICAgICAgICAgICAgIHRleHRQYWRkaW5nOiA1XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAgICBpY29uOiBTQVZFX0FTX1NWRyxcclxuICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAgcmVzdG9yZToge1xyXG4gICAgICAgICAgICAgIGVtcGhhc2lzOiB7XHJcbiAgICAgICAgICAgICAgICBpY29uU3R5bGU6IHtcclxuICAgICAgICAgICAgICAgICAgdGV4dFBvc2l0aW9uOiAndG9wJyxcclxuICAgICAgICAgICAgICAgICAgdGV4dFBhZGRpbmc6IDVcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICB9LFxyXG4gICAgICAgICAgICAgIGljb246IFJFU1RPUkUsXHJcbiAgICAgICAgICAgIH0sXHJcbiAgICAgICAgICAgIG15QWRkUG9pbnQ6IHtcclxuICAgICAgICAgICAgICBzaG93OiBjaGFydC5jbGlja1RvQWRkUG9pbnQgPz8gZmFsc2UsXHJcbiAgICAgICAgICAgICAgdGl0bGU6IGNoYXJ0LmFkZFBvaW50Q3VzdG9tTmFtZSA/PyAnQWRkIFBvaW50JyxcclxuICAgICAgICAgICAgICBpY29uOiBBRERfUE9JTlQsXHJcbiAgICAgICAgICAgICAgb25jbGljazogKCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgaWYgKHRoaXMuZWNoYXJ0c0luc3RhbmNlKSB7XHJcbiAgICAgICAgICAgICAgICAgIGNvbnN0IG9wdGlvbjogRUNPcHRpb24gPSB0aGlzLmVjaGFydHNJbnN0YW5jZS5nZXRPcHRpb24oKTtcclxuICAgICAgICAgICAgICAgICAgY29uc3QgdG9vbGJveCA9IG9wdGlvbi50b29sYm94IGFzIFRvb2xib3hDb21wb25lbnRPcHRpb25bXTtcclxuICAgICAgICAgICAgICAgICAgaWYgKHRvb2xib3gpIHtcclxuICAgICAgICAgICAgICAgICAgICBjb25zdCBzdGF0dXM6IGJvb2xlYW4gPSB0b29sYm94WzBdLmZlYXR1cmU/LlsnbXlBZGRQb2ludCddPy5pY29uU3RhdHVzO1xyXG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IG9mZkNvbG9yOiBzdHJpbmcgPSAncmdiKDEwMiwxMDIsMTAyKSc7XHJcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgaGlnaGxpZ2h0Q29sb3I6IHN0cmluZyA9ICdyZ2IoNjIsMTUyLDE5NyknO1xyXG4gICAgICAgICAgICAgICAgICAgIHRoaXMuZWNoYXJ0c0luc3RhbmNlLnNldE9wdGlvbih7XHJcbiAgICAgICAgICAgICAgICAgICAgICB0b29sYm94OiB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGZlYXR1cmU6IHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICBteUFkZFBvaW50OiB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBpY29uU3RhdHVzOiAhc3RhdHVzLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgaWNvblN0eWxlOiB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJvcmRlckNvbG9yOiAhc3RhdHVzID8gaGlnaGxpZ2h0Q29sb3IgOiBvZmZDb2xvclxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgIH0pO1xyXG4gICAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAgICBlbXBoYXNpczoge1xyXG4gICAgICAgICAgICAgICAgaWNvblN0eWxlOiB7XHJcbiAgICAgICAgICAgICAgICAgIHRleHRQb3NpdGlvbjogJ3RvcCcsXHJcbiAgICAgICAgICAgICAgICAgIHRleHRQYWRkaW5nOiA1XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9LFxyXG4gICAgICAgIH0sXHJcbiAgICAgICAgZGF0YVpvb206IFtcclxuICAgICAgICAgIHtcclxuICAgICAgICAgICAgdHlwZTogJ2luc2lkZScsXHJcbiAgICAgICAgICAgIHhBeGlzSW5kZXg6IFswXSxcclxuICAgICAgICAgICAgdGhyb3R0bGU6IDAsXHJcbiAgICAgICAgICAgIGZpbHRlck1vZGU6ICdub25lJyxcclxuICAgICAgICAgICAgZGlzYWJsZWQ6ICFjaGFydC5zY3JvbGxUb1pvb21cclxuICAgICAgICAgIH0sXHJcbiAgICAgICAgICB7XHJcbiAgICAgICAgICAgIHR5cGU6ICdpbnNpZGUnLFxyXG4gICAgICAgICAgICB5QXhpc0luZGV4OiBbMF0sXHJcbiAgICAgICAgICAgIHRocm90dGxlOiAwLFxyXG4gICAgICAgICAgICBmaWx0ZXJNb2RlOiAnbm9uZScsXHJcbiAgICAgICAgICAgIGRpc2FibGVkOiAhY2hhcnQuc2Nyb2xsVG9ab29tXHJcbiAgICAgICAgICB9LFxyXG4gICAgICAgIF0sXHJcbiAgICAgICAgbGVnZW5kOiB7XHJcbiAgICAgICAgICBpbmFjdGl2ZUNvbG9yOiB0aGlzLmRhcmtUaGVtZSA/ICcjOGI4YjhiJyA6ICcjY2NjJyxcclxuICAgICAgICAgIGRhdGE6IGNoYXJ0LnNoYXBlcy5tYXAoXHJcbiAgICAgICAgICAgIChzaGFwZTogU2hhcGUpID0+ICh7XHJcbiAgICAgICAgICAgICAgbmFtZTogc2hhcGUubmFtZSxcclxuICAgICAgICAgICAgICBpY29uOiAnY2lyY2xlJyxcclxuICAgICAgICAgICAgfSlcclxuICAgICAgICAgICksXHJcbiAgICAgICAgICBzZWxlY3RlZDogY2hhcnQuc2hhcGVzLnJlZHVjZShcclxuICAgICAgICAgICAgKGFjY3VtdWxhdG9yLCBzaGFwZTogU2hhcGUpID0+ICh7XHJcbiAgICAgICAgICAgICAgLi4uYWNjdW11bGF0b3IsXHJcbiAgICAgICAgICAgICAgW3NoYXBlLm5hbWUgYXMgc3RyaW5nXTogdGhpcy5nZXRMZWdlbmRJdGVtU2VsZWN0aW9uKHNoYXBlKSxcclxuICAgICAgICAgICAgfSksXHJcbiAgICAgICAgICAgIHt9KSxcclxuICAgICAgICAgIHNob3c6IGNoYXJ0LnNob3dMZWdlbmQgPz8gZmFsc2UsXHJcbiAgICAgICAgICBvcmllbnQ6ICd2ZXJ0aWNhbCcsXHJcbiAgICAgICAgICBsZWZ0OiAncmlnaHQnLFxyXG4gICAgICAgICAgcGFkZGluZzogWzYwLCAyMF0sXHJcbiAgICAgICAgICB0eXBlOiAnc2Nyb2xsJyxcclxuICAgICAgICAgIHRleHRTdHlsZToge1xyXG4gICAgICAgICAgICB3aWR0aDogMTIwLFxyXG4gICAgICAgICAgICBmb250V2VpZ2h0OiAnYm9sZCcsXHJcbiAgICAgICAgICAgIG92ZXJmbG93OiAnYnJlYWsnXHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfSxcclxuICAgICAgICB4QXhpczoge1xyXG4gICAgICAgICAgdHlwZTogY2hhcnQueEF4aXNUeXBlLFxyXG4gICAgICAgICAgbmFtZTogY2hhcnQueEF4aXNVb20gPyBgJHtjaGFydC54QXhpc05hbWV9IFsgJHtjaGFydC54QXhpc1VvbX0gXWAgOiBjaGFydC54QXhpc05hbWUsXHJcbiAgICAgICAgICBuYW1lTG9jYXRpb246ICdtaWRkbGUnLFxyXG4gICAgICAgICAgbmFtZUdhcDogMzAsXHJcbiAgICAgICAgICBzcGxpdExpbmU6IHtcclxuICAgICAgICAgICAgc2hvdzogY2hhcnQuc2hvd0dyaWQgPz8gdHJ1ZSxcclxuICAgICAgICAgICAgbGluZVN0eWxlOiB7XHJcbiAgICAgICAgICAgICAgY29sb3I6IHRoaXMuZGFya1RoZW1lID8gJyM1OTU5NTknIDogJyNjY2MnXHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgIH0sXHJcbiAgICAgICAgICBtaW46IGNoYXJ0LnhNaW4/LnRvRml4ZWQoY2hhcnQubWF4QXhlc0RlY2ltYWxzID8/IHRoaXMuTUFYX0RFQ0lNQUxTKSxcclxuICAgICAgICAgIG1heDogY2hhcnQueE1heD8udG9GaXhlZChjaGFydC5tYXhBeGVzRGVjaW1hbHMgPz8gdGhpcy5NQVhfREVDSU1BTFMpLFxyXG4gICAgICAgIH0sXHJcbiAgICAgICAgeUF4aXM6IHtcclxuICAgICAgICAgIHR5cGU6IGNoYXJ0LnlBeGlzVHlwZSxcclxuICAgICAgICAgIG5hbWU6IGNoYXJ0LnlBeGlzVW9tID8gYCR7Y2hhcnQueUF4aXNOYW1lfSBbICR7Y2hhcnQueUF4aXNVb219IF1gIDogY2hhcnQueUF4aXNOYW1lLFxyXG4gICAgICAgICAgbmFtZUxvY2F0aW9uOiAnbWlkZGxlJyxcclxuICAgICAgICAgIG5hbWVHYXA6IDUwLFxyXG4gICAgICAgICAgc3BsaXRMaW5lOiB7XHJcbiAgICAgICAgICAgIHNob3c6IGNoYXJ0LnNob3dHcmlkID8/IHRydWUsXHJcbiAgICAgICAgICAgIGxpbmVTdHlsZToge1xyXG4gICAgICAgICAgICAgIGNvbG9yOiB0aGlzLmRhcmtUaGVtZSA/ICcjNTk1OTU5JyA6ICcjY2NjJ1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9LFxyXG4gICAgICAgICAgbWluOiBjaGFydC55TWluPy50b0ZpeGVkKGNoYXJ0Lm1heEF4ZXNEZWNpbWFscyA/PyB0aGlzLk1BWF9ERUNJTUFMUyksXHJcbiAgICAgICAgICBtYXg6IGNoYXJ0LnlNYXg/LnRvRml4ZWQoY2hhcnQubWF4QXhlc0RlY2ltYWxzID8/IHRoaXMuTUFYX0RFQ0lNQUxTKSxcclxuICAgICAgICB9LFxyXG4gICAgICAgIHNlcmllczogdGhpcy5jcmVhdGVTZXJpZXMoY2hhcnQuc2hhcGVzKSxcclxuICAgICAgICBhbmltYXRpb246IGNoYXJ0Lmhhc0FuaW1hdGlvbnMsXHJcbiAgICAgICAgYW5pbWF0aW9uRHVyYXRpb246IGNoYXJ0LmFuaW1hdGlvbkR1cmF0aW9uID8/IDI1MCxcclxuICAgICAgICBhbmltYXRpb25FYXNpbmc6ICdjdWJpY091dCdcclxuICAgICAgfSxcclxuICAgICAgICB0cnVlLFxyXG4gICAgICAgIHRydWVcclxuICAgICAgKTtcclxuICAgIH1cclxuXHJcbiAgICB0aGlzLnNldHVwWnJFdmVudEhhbmRsZXIodGhpcy5lY2hhcnRzSW5zdGFuY2UpO1xyXG5cclxuICAgIHRoaXMuc2V0dXBMZWdlbmRFdmVudEhhbmRsZXIodGhpcy5lY2hhcnRzSW5zdGFuY2UpO1xyXG4gIH1cclxuXHJcbiAgY3JlYXRlU2VyaWVzKHNoYXBlczogU2hhcGVbXSk6IEFycmF5PExpbmVTZXJpZXNPcHRpb24gfCBDdXN0b21TZXJpZXNPcHRpb24gfCBTY2F0dGVyU2VyaWVzT3B0aW9uPiB7XHJcbiAgICBsZXQgc2VyaWVzOiBBcnJheTxMaW5lU2VyaWVzT3B0aW9uIHwgQ3VzdG9tU2VyaWVzT3B0aW9uIHwgU2NhdHRlclNlcmllc09wdGlvbj4gPSBbXTtcclxuICAgIHNoYXBlcy5mb3JFYWNoKFxyXG4gICAgICAoc2hhcGU6IFNoYXBlKSA9PiB7XHJcbiAgICAgICAgc3dpdGNoIChzaGFwZS52YXJpYW50KSB7XHJcbiAgICAgICAgICBjYXNlIFNoYXBlVmFyaWFudC5UUkFDRTpcclxuICAgICAgICAgICAgc2VyaWVzLnB1c2godGhpcy5jcmVhdGVUcmFjZShzaGFwZSBhcyBUcmFjZSkpXHJcbiAgICAgICAgICAgIGJyZWFrO1xyXG4gICAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgYnJlYWs7XHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICApO1xyXG4gICAgcmV0dXJuIHNlcmllcztcclxuICB9XHJcblxyXG4gIGNyZWF0ZVRyYWNlKHRyYWNlOiBUcmFjZSk6IExpbmVTZXJpZXNPcHRpb24gfCBTY2F0dGVyU2VyaWVzT3B0aW9uIHtcclxuICAgIHJldHVybiB7XHJcbiAgICAgIHR5cGU6IHRyYWNlLnR5cGUsXHJcbiAgICAgIG5hbWU6IHRyYWNlLm5hbWUsXHJcbiAgICAgIGRhdGE6IHRyYWNlLnBvaW50cy5tYXAoXHJcbiAgICAgICAgKHBvaW50OiBQb2ludCkgPT4gKHtcclxuICAgICAgICAgIHZhbHVlOiBbcG9pbnQueCwgcG9pbnQueV0sXHJcbiAgICAgICAgICBzeW1ib2w6IHBvaW50LnN5bWJvbCA/PyAnY2lyY2xlJyxcclxuICAgICAgICAgIG5hbWU6IHBvaW50Lm5hbWUsXHJcbiAgICAgICAgICBzeW1ib2xTaXplOiBwb2ludC5zeW1ib2xTaXplID8/IDIsXHJcbiAgICAgICAgICBpdGVtU3R5bGU6IHtcclxuICAgICAgICAgICAgY29sb3I6IHBvaW50LmNvbG9yXHJcbiAgICAgICAgICB9LFxyXG4gICAgICAgICAgZW1waGFzaXM6IHtcclxuICAgICAgICAgICAgZGlzYWJsZWQ6IHRydWVcclxuICAgICAgICAgIH0sXHJcbiAgICAgICAgICBsYWJlbDoge1xyXG4gICAgICAgICAgICBzaG93OiB0cnVlLFxyXG4gICAgICAgICAgICBwb3NpdGlvbjogJ2JvdHRvbScsXHJcbiAgICAgICAgICAgIGFsaWduOiAnbGVmdCcsXHJcbiAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdib3R0b20nLFxyXG4gICAgICAgICAgICBmb3JtYXR0ZXI6ICgpID0+IGAke3BvaW50Lm5hbWUgPz8gJyd9YCxcclxuICAgICAgICAgICAgZm9udFNpemU6IDEzLFxyXG4gICAgICAgICAgICBwYWRkaW5nOiBbMCwgMCwgMCwgMTBdLFxyXG4gICAgICAgICAgICB3aWR0aDogMTAwLFxyXG4gICAgICAgICAgICBvdmVyZmxvdzogJ3RydW5jYXRlJyxcclxuICAgICAgICAgICAgZWxsaXBzaXM6ICcuLi4nLFxyXG4gICAgICAgICAgICBmb250V2VpZ2h0OiAnYm9sZCcsXHJcbiAgICAgICAgICAgIGNvbG9yOiB0aGlzLmRhcmtUaGVtZSA/ICcjZmZmJyA6ICcjMDAwJ1xyXG4gICAgICAgICAgfSxcclxuICAgICAgICAgIHRvb2x0aXA6IHtcclxuICAgICAgICAgICAgZm9ybWF0dGVyOiAoeyB2YWx1ZSB9OiB7IHZhbHVlOiBudW1iZXJbXSB9KSA9PiBgXHJcbiAgICAgICAgICAgICAgPHN0cm9uZz4ke3RoaXMuY2hhcnQ/LnhBeGlzTmFtZX06PC9zdHJvbmc+ICR7dmFsdWVbMF0udG9GaXhlZCgzKS5yZXBsYWNlKC9bLixdMDAwJC8sIFwiXCIpfVxyXG4gICAgICAgICAgICAgIDxicj5cclxuICAgICAgICAgICAgICA8c3Ryb25nPiR7dGhpcy5jaGFydD8ueUF4aXNOYW1lfTo8L3N0cm9uZz4gJHt2YWx1ZVsxXS50b0ZpeGVkKDMpLnJlcGxhY2UoL1suLF0wMDAkLywgXCJcIil9XHJcbiAgICAgICAgICAgIGBcclxuICAgICAgICAgIH1cclxuICAgICAgICB9KVxyXG4gICAgICApLFxyXG4gICAgICBjb2xvcjogdHJhY2UuY29sb3IsXHJcbiAgICAgIGxpbmVTdHlsZToge1xyXG4gICAgICAgIHdpZHRoOiB0cmFjZS53aWR0aCxcclxuICAgICAgICB0eXBlOiB0cmFjZS5zdHlsZSxcclxuICAgICAgICBvcGFjaXR5OiB0cmFjZS5vcGFjaXR5ID8/IDFcclxuICAgICAgfSxcclxuICAgICAgc21vb3RoOiB0cmFjZS5zbW9vdGggPz8gZmFsc2VcclxuICAgIH07XHJcbiAgfVxyXG5cclxuICBnZXRMZWdlbmRJdGVtU2VsZWN0aW9uKHNoYXBlOiBTaGFwZSk6IGJvb2xlYW4ge1xyXG4gICAgaWYgKHRoaXMuaXNMZWdlbmRDbGlja2VkKSB7XHJcbiAgICAgIHJldHVybiB0aGlzLmxlZ2VuZFNlbGVjdGVkW3NoYXBlLm5hbWUgYXMgc3RyaW5nXSA/PyB0cnVlO1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgIHJldHVybiBzaGFwZS5zZWxlY3RlZEJ5RGVmYXVsdCA/PyB0cnVlXHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBpbnRlcmNlcHQgYSBzZWxlY3Rpb24gY2hhbmdlIGV2ZW50IG9uIHRoZSBsZWdlbmQgYW5kIHNhdmUgdGhlIHN0YXRlIFxyXG4gICAqIG9mIGFsbCBzZWxlY3Rpb25zIG9uIHRoZSBzdXBwb3J0aW5nIHZhcmlhYmxlIGxlZ2VuZFNlbGVjdGVkXHJcbiAgICogXHJcbiAgICogQHBhcmFtIGVjIFxyXG4gICAqL1xyXG4gIHNldHVwTGVnZW5kRXZlbnRIYW5kbGVyKGVjOiBFQ2hhcnRzKSB7XHJcbiAgICBpZiAodGhpcy5lY2hhcnRzSW5zdGFuY2UgIT0gbnVsbCkge1xyXG4gICAgICB0aGlzLmVjaGFydHNJbnN0YW5jZS5vbignbGVnZW5kc2VsZWN0Y2hhbmdlZCcsIChwYXJhbXM6IGFueSkgPT4ge1xyXG4gICAgICAgIHRoaXMuaXNMZWdlbmRDbGlja2VkID0gdHJ1ZTtcclxuICAgICAgICB0aGlzLmxlZ2VuZFNlbGVjdGVkID0gcGFyYW1zLnNlbGVjdGVkO1xyXG4gICAgICB9KTtcclxuICAgIH1cclxuXHJcbiAgfVxyXG5cclxuICBzZXR1cFpyRXZlbnRIYW5kbGVyKGVjOiBFQ2hhcnRzKSB7XHJcbiAgICB0aGlzLnpyID0gZWMuZ2V0WnIoKTtcclxuICAgIC8qKiBcclxuICAgICAqIEludGVyY2VwdHMgdGhlIGNsaWNrIGV2ZW50IG9uIHRoZSBjaGFydCAoaWYgdGhlIGNsaWNrVG9BZGRQb2ludCBwcm9wZXJ0eSBpcyBzZXQgdG8gdHJ1ZSlcclxuICAgICAqIGFuZCBlbWl0cyB0aGUgcG9pbnQgY29vcmRpbmF0ZXMgdG8gdGhlIGZhdGhlciBjb21wb25lbnQuXHJcbiAgICAgKi9cclxuICAgIHRoaXMuenIub24oJ2NsaWNrJywgcGFyYW1zID0+IHtcclxuICAgICAgbGV0IG9wdGlvbjogYW55ID0gZWMuZ2V0T3B0aW9uKCk7XHJcbiAgICAgIGxldCBhY3RpdmUgPSBvcHRpb24/LnRvb2xib3g/LlswXT8uZmVhdHVyZT8ubXlBZGRQb2ludD8uaWNvblN0YXR1cztcclxuICAgICAgaWYgKGFjdGl2ZSAmJiB0aGlzLmNoYXJ0Py5jbGlja1RvQWRkUG9pbnQpIHtcclxuICAgICAgICBjb25zdCBwb2ludEluUGl4ZWwgPSBbcGFyYW1zLm9mZnNldFgsIHBhcmFtcy5vZmZzZXRZXTtcclxuICAgICAgICBjb25zdCBwb2ludEluR3JpZCA9IGVjLmNvbnZlcnRGcm9tUGl4ZWwoJ2dyaWQnLCBwb2ludEluUGl4ZWwpO1xyXG4gICAgICAgIGlmIChlYy5jb250YWluUGl4ZWwoJ2dyaWQnLCBwb2ludEluUGl4ZWwpICYmIHBvaW50SW5HcmlkKSB7XHJcbiAgICAgICAgICBsZXQgbmV3UG9pbnQ6IHsgeDogbnVtYmVyLCB5OiBudW1iZXIgfSA9IHtcclxuICAgICAgICAgICAgeDogK3BvaW50SW5HcmlkWzBdLnRvRml4ZWQoMyksXHJcbiAgICAgICAgICAgIHk6ICtwb2ludEluR3JpZFsxXS50b0ZpeGVkKDMpXHJcbiAgICAgICAgICB9O1xyXG4gICAgICAgICAgdGhpcy5hZGRQb2ludC5lbWl0KG5ld1BvaW50KTtcclxuICAgICAgICB9XHJcbiAgICAgIH1cclxuICAgIH0pO1xyXG4gICAgLyoqIFxyXG4gICAgICogVGhpcyBpcyB1c2VkIHBlcmZvcm0gY3VzdG9tIGFjdGlvbnMgd2hlbiB0aGUgbW91c2UgaXMgaG92ZXJpbmcgdGhlIGNoYXJ0IGFyZWFcclxuICAgICAqL1xyXG4gICAgdGhpcy56ci5vbignbW91c2Vtb3ZlJywgcGFyYW1zID0+IHtcclxuICAgICAgY29uc3QgcG9pbnRJblBpeGVsID0gW3BhcmFtcy5vZmZzZXRYLCBwYXJhbXMub2Zmc2V0WV07XHJcbiAgICAgIGNvbnN0IHBvaW50SW5HcmlkID0gZWMuY29udmVydEZyb21QaXhlbCgnZ3JpZCcsIHBvaW50SW5QaXhlbCk7XHJcbiAgICAgIC8qIFxyXG4gICAgICAgKiBMb2dpYyB0byBlbWl0IHRvIHRoZSBmYXRoZXIgY29tcG9uZW50IHRoZSB4IGFuZCB5IGNkaW5hdGVzIHdoZW4gdGhlXHJcbiAgICAgICAqIGN1cnNvciBpcyBob3ZlcmluZyB0aGUgY2hhcnQgYXJlYSAuXHJcbiAgICAgICAqL1xyXG4gICAgICBpZiAoZWMuY29udGFpblBpeGVsKCdncmlkJywgcG9pbnRJblBpeGVsKSAmJiBwb2ludEluR3JpZCkge1xyXG4gICAgICAgIGxldCBuZXdQb2ludDogeyB4OiBudW1iZXIsIHk6IG51bWJlciB9ID0ge1xyXG4gICAgICAgICAgeDogK3BvaW50SW5HcmlkWzBdLnRvRml4ZWQoMyksXHJcbiAgICAgICAgICB5OiArcG9pbnRJbkdyaWRbMV0udG9GaXhlZCgzKVxyXG4gICAgICAgIH07XHJcbiAgICAgICAgdGhpcy5jaGFydEhvdmVyLmVtaXQobmV3UG9pbnQpO1xyXG4gICAgICB9XHJcbiAgICAgIC8qIExvZ2ljIHRvIGNoYW5nZSB0aGUgY3Vyc29yIGljb24gd2hlbiB0aGUgXCJDbGljayB0byBBZGQgUG9pbnRcIiBmZWF0dXJlIGlzIGFjdGl2ZSBhbmQgdmljZXZlcnNhLiAqL1xyXG4gICAgICBjb25zdCBvcHRpb246IGFueSA9IGVjLmdldE9wdGlvbigpO1xyXG4gICAgICBjb25zdCBhZGRQb2ludElzQWN0aXZlID0gb3B0aW9uPy50b29sYm94Py5bMF0/LmZlYXR1cmU/Lm15QWRkUG9pbnQ/Lmljb25TdGF0dXM7XHJcbiAgICAgIGlmIChhZGRQb2ludElzQWN0aXZlKSB7XHJcbiAgICAgICAgdGhpcy56cj8uc2V0Q3Vyc29yU3R5bGUoXHJcbiAgICAgICAgICBlYy5jb250YWluUGl4ZWwoJ2dyaWQnLCBwb2ludEluUGl4ZWwpID8gJ2NvcHknIDogJ2RlZmF1bHQnXHJcbiAgICAgICAgKTtcclxuICAgICAgfVxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxufVxyXG4iXX0=
|
|
@@ -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=
|
package/esm2022/public-api.mjs
DELETED
|
@@ -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==
|