UNPKG

40.3 kBJavaScriptView Raw
1import { Directive, EventEmitter, Inject, InjectionToken, Input, Output, } from '@angular/core';
2import { Observable, ReplaySubject, Subject, asyncScheduler } from 'rxjs';
3import { switchMap, throttleTime } from 'rxjs/operators';
4import { ChangeFilterV2 } from './change-filter-v2';
5import * as i0 from "@angular/core";
6export const NGX_ECHARTS_CONFIG = new InjectionToken('NGX_ECHARTS_CONFIG');
7export class NgxEchartsDirective {
8 constructor(config, el, ngZone) {
9 this.el = el;
10 this.ngZone = ngZone;
11 this.options = null;
12 this.theme = null;
13 this.initOpts = null;
14 this.merge = null;
15 this.autoResize = true;
16 this.loading = false;
17 this.loadingType = 'default';
18 this.loadingOpts = null;
19 // ngx-echarts events
20 this.chartInit = new EventEmitter();
21 this.optionsError = new EventEmitter();
22 // echarts mouse events
23 this.chartClick = this.createLazyEvent('click');
24 this.chartDblClick = this.createLazyEvent('dblclick');
25 this.chartMouseDown = this.createLazyEvent('mousedown');
26 this.chartMouseMove = this.createLazyEvent('mousemove');
27 this.chartMouseUp = this.createLazyEvent('mouseup');
28 this.chartMouseOver = this.createLazyEvent('mouseover');
29 this.chartMouseOut = this.createLazyEvent('mouseout');
30 this.chartGlobalOut = this.createLazyEvent('globalout');
31 this.chartContextMenu = this.createLazyEvent('contextmenu');
32 // echarts events
33 this.chartHighlight = this.createLazyEvent('highlight');
34 this.chartDownplay = this.createLazyEvent('downplay');
35 this.chartSelectChanged = this.createLazyEvent('selectchanged');
36 this.chartLegendSelectChanged = this.createLazyEvent('legendselectchanged');
37 this.chartLegendSelected = this.createLazyEvent('legendselected');
38 this.chartLegendUnselected = this.createLazyEvent('legendunselected');
39 this.chartLegendLegendSelectAll = this.createLazyEvent('legendselectall');
40 this.chartLegendLegendInverseSelect = this.createLazyEvent('legendinverseselect');
41 this.chartLegendScroll = this.createLazyEvent('legendscroll');
42 this.chartDataZoom = this.createLazyEvent('datazoom');
43 this.chartDataRangeSelected = this.createLazyEvent('datarangeselected');
44 this.chartGraphRoam = this.createLazyEvent('graphroam');
45 this.chartGeoRoam = this.createLazyEvent('georoam');
46 this.chartTreeRoam = this.createLazyEvent('treeroam');
47 this.chartTimelineChanged = this.createLazyEvent('timelinechanged');
48 this.chartTimelinePlayChanged = this.createLazyEvent('timelineplaychanged');
49 this.chartRestore = this.createLazyEvent('restore');
50 this.chartDataViewChanged = this.createLazyEvent('dataviewchanged');
51 this.chartMagicTypeChanged = this.createLazyEvent('magictypechanged');
52 this.chartGeoSelectChanged = this.createLazyEvent('geoselectchanged');
53 this.chartGeoSelected = this.createLazyEvent('geoselected');
54 this.chartGeoUnselected = this.createLazyEvent('geounselected');
55 this.chartAxisAreaSelected = this.createLazyEvent('axisareaselected');
56 this.chartBrush = this.createLazyEvent('brush');
57 this.chartBrushEnd = this.createLazyEvent('brushend');
58 this.chartBrushSelected = this.createLazyEvent('brushselected');
59 this.chartGlobalCursorTaken = this.createLazyEvent('globalcursortaken');
60 this.chartRendered = this.createLazyEvent('rendered');
61 this.chartFinished = this.createLazyEvent('finished');
62 this.animationFrameID = null;
63 this.chart$ = new ReplaySubject(1);
64 this.resize$ = new Subject();
65 this.changeFilter = new ChangeFilterV2();
66 this.echarts = config.echarts;
67 }
68 ngOnChanges(changes) {
69 this.changeFilter.doFilter(changes);
70 }
71 ngOnInit() {
72 if (!window.ResizeObserver) {
73 throw new Error('please install a polyfill for ResizeObserver');
74 }
75 this.resizeSub = this.resize$
76 .pipe(throttleTime(100, asyncScheduler, { leading: false, trailing: true }))
77 .subscribe(() => this.resize());
78 if (this.autoResize) {
79 this.resizeOb = this.ngZone.runOutsideAngular(() => new window.ResizeObserver(() => {
80 this.animationFrameID = window.requestAnimationFrame(() => this.resize$.next());
81 }));
82 this.resizeOb.observe(this.el.nativeElement);
83 }
84 this.changeFilter.notFirstAndEmpty('options', opt => this.onOptionsChange(opt));
85 this.changeFilter.notFirstAndEmpty('merge', opt => this.setOption(opt));
86 this.changeFilter.has('loading', v => this.toggleLoading(!!v));
87 this.changeFilter.notFirst('theme', () => this.refreshChart());
88 }
89 ngOnDestroy() {
90 window.clearTimeout(this.initChartTimer);
91 if (this.resizeSub) {
92 this.resizeSub.unsubscribe();
93 }
94 if (this.animationFrameID) {
95 window.cancelAnimationFrame(this.animationFrameID);
96 }
97 if (this.resizeOb) {
98 this.resizeOb.unobserve(this.el.nativeElement);
99 }
100 if (this.loadingSub) {
101 this.loadingSub.unsubscribe();
102 }
103 this.changeFilter.dispose();
104 this.dispose();
105 }
106 ngAfterViewInit() {
107 this.initChartTimer = window.setTimeout(() => this.initChart());
108 }
109 dispose() {
110 if (this.chart) {
111 if (!this.chart.isDisposed()) {
112 this.chart.dispose();
113 }
114 this.chart = null;
115 }
116 }
117 /**
118 * resize chart
119 */
120 resize() {
121 if (this.chart) {
122 this.chart.resize();
123 }
124 }
125 toggleLoading(loading) {
126 if (this.chart) {
127 loading
128 ? this.chart.showLoading(this.loadingType, this.loadingOpts)
129 : this.chart.hideLoading();
130 }
131 else {
132 this.loadingSub = this.chart$.subscribe(chart => loading ? chart.showLoading(this.loadingType, this.loadingOpts) : chart.hideLoading());
133 }
134 }
135 setOption(option, opts) {
136 if (this.chart) {
137 try {
138 this.chart.setOption(option, opts);
139 }
140 catch (e) {
141 console.error(e);
142 this.optionsError.emit(e);
143 }
144 }
145 }
146 /**
147 * dispose old chart and create a new one.
148 */
149 async refreshChart() {
150 this.dispose();
151 await this.initChart();
152 }
153 createChart() {
154 const dom = this.el.nativeElement;
155 if (window && window.getComputedStyle) {
156 const prop = window.getComputedStyle(dom, null).getPropertyValue('height');
157 if ((!prop || prop === '0px') && (!dom.style.height || dom.style.height === '0px')) {
158 dom.style.height = '400px';
159 }
160 }
161 // here a bit tricky: we check if the echarts module is provided as function returning native import('...') then use the promise
162 // otherwise create the function that imitates behaviour above with a provided as is module
163 return this.ngZone.runOutsideAngular(() => {
164 const load = typeof this.echarts === 'function' ? this.echarts : () => Promise.resolve(this.echarts);
165 return load().then(({ init }) => init(dom, this.theme, this.initOpts));
166 });
167 }
168 async initChart() {
169 await this.onOptionsChange(this.options);
170 if (this.merge && this.chart) {
171 this.setOption(this.merge);
172 }
173 }
174 async onOptionsChange(opt) {
175 if (!opt) {
176 return;
177 }
178 if (this.chart) {
179 this.setOption(this.options, true);
180 }
181 else {
182 this.chart = await this.createChart();
183 this.chart$.next(this.chart);
184 this.chartInit.emit(this.chart);
185 this.setOption(this.options, true);
186 }
187 }
188 // allows to lazily bind to only those events that are requested through the `@Output` by parent components
189 // see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info
190 createLazyEvent(eventName) {
191 return this.chartInit.pipe(switchMap((chart) => new Observable(observer => {
192 chart.on(eventName, (data) => this.ngZone.run(() => observer.next(data)));
193 return () => {
194 if (this.chart) {
195 if (!this.chart.isDisposed()) {
196 chart.off(eventName);
197 }
198 }
199 };
200 })));
201 }
202 static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: NgxEchartsDirective, deps: [{ token: NGX_ECHARTS_CONFIG }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
203 static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.1", type: NgxEchartsDirective, isStandalone: true, selector: "echarts, [echarts]", inputs: { options: "options", theme: "theme", initOpts: "initOpts", merge: "merge", autoResize: "autoResize", loading: "loading", loadingType: "loadingType", loadingOpts: "loadingOpts" }, outputs: { chartInit: "chartInit", optionsError: "optionsError", chartClick: "chartClick", chartDblClick: "chartDblClick", chartMouseDown: "chartMouseDown", chartMouseMove: "chartMouseMove", chartMouseUp: "chartMouseUp", chartMouseOver: "chartMouseOver", chartMouseOut: "chartMouseOut", chartGlobalOut: "chartGlobalOut", chartContextMenu: "chartContextMenu", chartHighlight: "chartHighlight", chartDownplay: "chartDownplay", chartSelectChanged: "chartSelectChanged", chartLegendSelectChanged: "chartLegendSelectChanged", chartLegendSelected: "chartLegendSelected", chartLegendUnselected: "chartLegendUnselected", chartLegendLegendSelectAll: "chartLegendLegendSelectAll", chartLegendLegendInverseSelect: "chartLegendLegendInverseSelect", chartLegendScroll: "chartLegendScroll", chartDataZoom: "chartDataZoom", chartDataRangeSelected: "chartDataRangeSelected", chartGraphRoam: "chartGraphRoam", chartGeoRoam: "chartGeoRoam", chartTreeRoam: "chartTreeRoam", chartTimelineChanged: "chartTimelineChanged", chartTimelinePlayChanged: "chartTimelinePlayChanged", chartRestore: "chartRestore", chartDataViewChanged: "chartDataViewChanged", chartMagicTypeChanged: "chartMagicTypeChanged", chartGeoSelectChanged: "chartGeoSelectChanged", chartGeoSelected: "chartGeoSelected", chartGeoUnselected: "chartGeoUnselected", chartAxisAreaSelected: "chartAxisAreaSelected", chartBrush: "chartBrush", chartBrushEnd: "chartBrushEnd", chartBrushSelected: "chartBrushSelected", chartGlobalCursorTaken: "chartGlobalCursorTaken", chartRendered: "chartRendered", chartFinished: "chartFinished" }, exportAs: ["echarts"], usesOnChanges: true, ngImport: i0 }); }
204}
205i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: NgxEchartsDirective, decorators: [{
206 type: Directive,
207 args: [{
208 standalone: true,
209 selector: 'echarts, [echarts]',
210 exportAs: 'echarts',
211 }]
212 }], ctorParameters: () => [{ type: undefined, decorators: [{
213 type: Inject,
214 args: [NGX_ECHARTS_CONFIG]
215 }] }, { type: i0.ElementRef }, { type: i0.NgZone }], propDecorators: { options: [{
216 type: Input
217 }], theme: [{
218 type: Input
219 }], initOpts: [{
220 type: Input
221 }], merge: [{
222 type: Input
223 }], autoResize: [{
224 type: Input
225 }], loading: [{
226 type: Input
227 }], loadingType: [{
228 type: Input
229 }], loadingOpts: [{
230 type: Input
231 }], chartInit: [{
232 type: Output
233 }], optionsError: [{
234 type: Output
235 }], chartClick: [{
236 type: Output
237 }], chartDblClick: [{
238 type: Output
239 }], chartMouseDown: [{
240 type: Output
241 }], chartMouseMove: [{
242 type: Output
243 }], chartMouseUp: [{
244 type: Output
245 }], chartMouseOver: [{
246 type: Output
247 }], chartMouseOut: [{
248 type: Output
249 }], chartGlobalOut: [{
250 type: Output
251 }], chartContextMenu: [{
252 type: Output
253 }], chartHighlight: [{
254 type: Output
255 }], chartDownplay: [{
256 type: Output
257 }], chartSelectChanged: [{
258 type: Output
259 }], chartLegendSelectChanged: [{
260 type: Output
261 }], chartLegendSelected: [{
262 type: Output
263 }], chartLegendUnselected: [{
264 type: Output
265 }], chartLegendLegendSelectAll: [{
266 type: Output
267 }], chartLegendLegendInverseSelect: [{
268 type: Output
269 }], chartLegendScroll: [{
270 type: Output
271 }], chartDataZoom: [{
272 type: Output
273 }], chartDataRangeSelected: [{
274 type: Output
275 }], chartGraphRoam: [{
276 type: Output
277 }], chartGeoRoam: [{
278 type: Output
279 }], chartTreeRoam: [{
280 type: Output
281 }], chartTimelineChanged: [{
282 type: Output
283 }], chartTimelinePlayChanged: [{
284 type: Output
285 }], chartRestore: [{
286 type: Output
287 }], chartDataViewChanged: [{
288 type: Output
289 }], chartMagicTypeChanged: [{
290 type: Output
291 }], chartGeoSelectChanged: [{
292 type: Output
293 }], chartGeoSelected: [{
294 type: Output
295 }], chartGeoUnselected: [{
296 type: Output
297 }], chartAxisAreaSelected: [{
298 type: Output
299 }], chartBrush: [{
300 type: Output
301 }], chartBrushEnd: [{
302 type: Output
303 }], chartBrushSelected: [{
304 type: Output
305 }], chartGlobalCursorTaken: [{
306 type: Output
307 }], chartRendered: [{
308 type: Output
309 }], chartFinished: [{
310 type: Output
311 }] } });
312//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-echarts.directive.js","sourceRoot":"","sources":["../../../../projects/ngx-echarts/src/lib/ngx-echarts.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  InjectionToken,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { Observable, ReplaySubject, Subject, Subscription, asyncScheduler } from 'rxjs';\nimport { switchMap, throttleTime } from 'rxjs/operators';\nimport { ChangeFilterV2 } from './change-filter-v2';\nimport type { EChartsOption, ECharts, ECElementEvent } from 'echarts';\n\nexport interface NgxEchartsConfig {\n  echarts: any | (() => Promise<any>);\n}\n\nexport type ThemeOption = Record<string, any>;\n\nexport const NGX_ECHARTS_CONFIG = new InjectionToken<NgxEchartsConfig>('NGX_ECHARTS_CONFIG');\n\n@Directive({\n  standalone: true,\n  selector: 'echarts, [echarts]',\n  exportAs: 'echarts',\n})\nexport class NgxEchartsDirective implements OnChanges, OnDestroy, OnInit, AfterViewInit {\n  @Input() options: EChartsOption | null = null;\n  @Input() theme: string | ThemeOption | null = null;\n  @Input() initOpts: {\n    devicePixelRatio?: number;\n    renderer?: string;\n    width?: number | string;\n    height?: number | string;\n    locale?: string;\n  } | null = null;\n  @Input() merge: EChartsOption | null = null;\n  @Input() autoResize = true;\n  @Input() loading = false;\n  @Input() loadingType = 'default';\n  @Input() loadingOpts: object | null = null;\n\n  // ngx-echarts events\n  @Output() chartInit = new EventEmitter<any>();\n  @Output() optionsError = new EventEmitter<Error>();\n\n  // echarts mouse events\n  @Output() chartClick = this.createLazyEvent<ECElementEvent>('click');\n  @Output() chartDblClick = this.createLazyEvent<ECElementEvent>('dblclick');\n  @Output() chartMouseDown = this.createLazyEvent<ECElementEvent>('mousedown');\n  @Output() chartMouseMove = this.createLazyEvent<ECElementEvent>('mousemove');\n  @Output() chartMouseUp = this.createLazyEvent<ECElementEvent>('mouseup');\n  @Output() chartMouseOver = this.createLazyEvent<ECElementEvent>('mouseover');\n  @Output() chartMouseOut = this.createLazyEvent<ECElementEvent>('mouseout');\n  @Output() chartGlobalOut = this.createLazyEvent<ECElementEvent>('globalout');\n  @Output() chartContextMenu = this.createLazyEvent<ECElementEvent>('contextmenu');\n\n  // echarts events\n  @Output() chartHighlight = this.createLazyEvent<any>('highlight');\n  @Output() chartDownplay = this.createLazyEvent<any>('downplay');\n  @Output() chartSelectChanged = this.createLazyEvent<any>('selectchanged');\n  @Output() chartLegendSelectChanged = this.createLazyEvent<any>('legendselectchanged');\n  @Output() chartLegendSelected = this.createLazyEvent<any>('legendselected');\n  @Output() chartLegendUnselected = this.createLazyEvent<any>('legendunselected');\n  @Output() chartLegendLegendSelectAll = this.createLazyEvent<any>('legendselectall');\n  @Output() chartLegendLegendInverseSelect = this.createLazyEvent<any>('legendinverseselect');\n  @Output() chartLegendScroll = this.createLazyEvent<any>('legendscroll');\n  @Output() chartDataZoom = this.createLazyEvent<any>('datazoom');\n  @Output() chartDataRangeSelected = this.createLazyEvent<any>('datarangeselected');\n  @Output() chartGraphRoam = this.createLazyEvent<any>('graphroam');\n  @Output() chartGeoRoam = this.createLazyEvent<any>('georoam');\n  @Output() chartTreeRoam = this.createLazyEvent<any>('treeroam');\n  @Output() chartTimelineChanged = this.createLazyEvent<any>('timelinechanged');\n  @Output() chartTimelinePlayChanged = this.createLazyEvent<any>('timelineplaychanged');\n  @Output() chartRestore = this.createLazyEvent<any>('restore');\n  @Output() chartDataViewChanged = this.createLazyEvent<any>('dataviewchanged');\n  @Output() chartMagicTypeChanged = this.createLazyEvent<any>('magictypechanged');\n  @Output() chartGeoSelectChanged = this.createLazyEvent<any>('geoselectchanged');\n  @Output() chartGeoSelected = this.createLazyEvent<any>('geoselected');\n  @Output() chartGeoUnselected = this.createLazyEvent<any>('geounselected');\n  @Output() chartAxisAreaSelected = this.createLazyEvent<any>('axisareaselected');\n  @Output() chartBrush = this.createLazyEvent<any>('brush');\n  @Output() chartBrushEnd = this.createLazyEvent<any>('brushend');\n  @Output() chartBrushSelected = this.createLazyEvent<any>('brushselected');\n  @Output() chartGlobalCursorTaken = this.createLazyEvent<any>('globalcursortaken');\n  @Output() chartRendered = this.createLazyEvent<any>('rendered');\n  @Output() chartFinished = this.createLazyEvent<any>('finished');\n\n  public animationFrameID = null;\n  private chart: ECharts;\n  private chart$ = new ReplaySubject<ECharts>(1);\n  private echarts: any;\n  private resizeOb: ResizeObserver;\n  private resize$ = new Subject<void>();\n  private resizeSub: Subscription;\n  private initChartTimer?: number;\n  private changeFilter = new ChangeFilterV2();\n  private loadingSub: Subscription;\n\n  constructor(\n    @Inject(NGX_ECHARTS_CONFIG) config: NgxEchartsConfig,\n    private el: ElementRef,\n    private ngZone: NgZone\n  ) {\n    this.echarts = config.echarts;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    this.changeFilter.doFilter(changes);\n  }\n\n  ngOnInit() {\n    if (!window.ResizeObserver) {\n      throw new Error('please install a polyfill for ResizeObserver');\n    }\n    this.resizeSub = this.resize$\n      .pipe(throttleTime(100, asyncScheduler, { leading: false, trailing: true }))\n      .subscribe(() => this.resize());\n\n    if (this.autoResize) {\n      this.resizeOb = this.ngZone.runOutsideAngular(\n        () =>\n          new window.ResizeObserver(() => {\n            this.animationFrameID = window.requestAnimationFrame(() => this.resize$.next());\n          })\n      );\n      this.resizeOb.observe(this.el.nativeElement);\n    }\n\n    this.changeFilter.notFirstAndEmpty('options', opt => this.onOptionsChange(opt));\n    this.changeFilter.notFirstAndEmpty('merge', opt => this.setOption(opt));\n    this.changeFilter.has<boolean>('loading', v => this.toggleLoading(!!v));\n    this.changeFilter.notFirst<string | ThemeOption>('theme', () => this.refreshChart());\n  }\n\n  ngOnDestroy() {\n    window.clearTimeout(this.initChartTimer);\n    if (this.resizeSub) {\n      this.resizeSub.unsubscribe();\n    }\n    if (this.animationFrameID) {\n      window.cancelAnimationFrame(this.animationFrameID);\n    }\n    if (this.resizeOb) {\n      this.resizeOb.unobserve(this.el.nativeElement);\n    }\n    if (this.loadingSub) {\n      this.loadingSub.unsubscribe();\n    }\n    this.changeFilter.dispose();\n    this.dispose();\n  }\n\n  ngAfterViewInit() {\n    this.initChartTimer = window.setTimeout(() => this.initChart());\n  }\n\n  private dispose() {\n    if (this.chart) {\n      if (!this.chart.isDisposed()) {\n        this.chart.dispose();\n      }\n      this.chart = null;\n    }\n  }\n\n  /**\n   * resize chart\n   */\n  resize() {\n    if (this.chart) {\n      this.chart.resize();\n    }\n  }\n\n  private toggleLoading(loading: boolean) {\n    if (this.chart) {\n      loading\n        ? this.chart.showLoading(this.loadingType, this.loadingOpts)\n        : this.chart.hideLoading();\n    } else {\n      this.loadingSub = this.chart$.subscribe(chart =>\n        loading ? chart.showLoading(this.loadingType, this.loadingOpts) : chart.hideLoading()\n      );\n    }\n  }\n\n  private setOption(option: any, opts?: any) {\n    if (this.chart) {\n      try {\n        this.chart.setOption(option, opts);\n      } catch (e) {\n        console.error(e);\n        this.optionsError.emit(e);\n      }\n    }\n  }\n\n  /**\n   * dispose old chart and create a new one.\n   */\n  async refreshChart() {\n    this.dispose();\n    await this.initChart();\n  }\n\n  private createChart() {\n    const dom = this.el.nativeElement;\n\n    if (window && window.getComputedStyle) {\n      const prop = window.getComputedStyle(dom, null).getPropertyValue('height');\n      if ((!prop || prop === '0px') && (!dom.style.height || dom.style.height === '0px')) {\n        dom.style.height = '400px';\n      }\n    }\n\n    // here a bit tricky: we check if the echarts module is provided as function returning native import('...') then use the promise\n    // otherwise create the function that imitates behaviour above with a provided as is module\n    return this.ngZone.runOutsideAngular(() => {\n      const load =\n        typeof this.echarts === 'function' ? this.echarts : () => Promise.resolve(this.echarts);\n\n      return load().then(({ init }) => init(dom, this.theme, this.initOpts));\n    });\n  }\n\n  private async initChart() {\n    await this.onOptionsChange(this.options);\n\n    if (this.merge && this.chart) {\n      this.setOption(this.merge);\n    }\n  }\n\n  private async onOptionsChange(opt: any) {\n    if (!opt) {\n      return;\n    }\n\n    if (this.chart) {\n      this.setOption(this.options, true);\n    } else {\n      this.chart = await this.createChart();\n      this.chart$.next(this.chart);\n      this.chartInit.emit(this.chart);\n      this.setOption(this.options, true);\n    }\n  }\n\n  // allows to lazily bind to only those events that are requested through the `@Output` by parent components\n  // see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info\n  private createLazyEvent<T>(eventName: string): EventEmitter<T> {\n    return this.chartInit.pipe(\n      switchMap(\n        (chart: any) =>\n          new Observable(observer => {\n            chart.on(eventName, (data: T) => this.ngZone.run(() => observer.next(data)));\n            return () => {\n              if (this.chart) {\n                if (!this.chart.isDisposed()) {\n                  chart.off(eventName);\n                }\n              }\n            };\n          })\n      )\n    ) as EventEmitter<T>;\n  }\n}\n"]}
\No newline at end of file