Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

ngx-echarts

Package Overview
Dependencies
Maintainers
1
Versions
63
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ngx-echarts - npm Package Compare versions

Comparing version 4.0.1 to 4.1.0

401

bundles/ngx-echarts.umd.js
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('rxjs'), require('@angular/core'), require('rxjs/operators'), require('echarts')) :
typeof define === 'function' && define.amd ? define('ngx-echarts', ['exports', 'rxjs', '@angular/core', 'rxjs/operators', 'echarts'], factory) :
(factory((global['ngx-echarts'] = {}),global.rxjs,global.ng.core,global.rxjs.operators,global.echarts));
}(this, (function (exports,rxjs,core,operators,echarts) { 'use strict';
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('rxjs'), require('@angular/core'), require('echarts'), require('rxjs/operators')) :
typeof define === 'function' && define.amd ? define('ngx-echarts', ['exports', 'rxjs', '@angular/core', 'echarts', 'rxjs/operators'], factory) :
(factory((global['ngx-echarts'] = {}),global.rxjs,global.ng.core,global.echarts,global.rxjs.operators));
}(this, (function (exports,rxjs,core,echarts,operators) { 'use strict';

@@ -109,109 +109,51 @@ /**

*/
var EChartEvents = /** @class */ (function () {
function EChartEvents() {
}
EChartEvents.Click = 'click';
EChartEvents.DblClick = 'dblclick';
EChartEvents.MouseDown = 'mousedown';
EChartEvents.MouseUp = 'mouseup';
EChartEvents.MouseOver = 'mouseover';
EChartEvents.MouseOut = 'mouseout';
EChartEvents.GlobalOut = 'globalout';
EChartEvents.ContextMenu = 'contextmenu';
EChartEvents.DataZoom = 'datazoom';
EChartEvents.MapSelectChanged = 'mapselectchanged';
EChartEvents.MapSelected = 'mapselected';
EChartEvents.MapUnselected = 'mapunselected';
EChartEvents.All = [
EChartEvents.Click,
EChartEvents.DblClick,
EChartEvents.MouseDown,
EChartEvents.MouseUp,
EChartEvents.MouseOver,
EChartEvents.MouseOut,
EChartEvents.GlobalOut,
EChartEvents.ContextMenu,
EChartEvents.DataZoom,
EChartEvents.MapSelectChanged,
EChartEvents.MapSelected,
EChartEvents.MapUnselected,
];
return EChartEvents;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var NgxEchartsDirective = /** @class */ (function () {
function NgxEchartsDirective(el, _ngZone) {
function NgxEchartsDirective(el, ngZone) {
this.el = el;
this._ngZone = _ngZone;
this.ngZone = ngZone;
this.autoResize = true;
this.loadingType = 'default';
/**
* Whether to register event handlers on echartInstance. Default is true.
* Use it to avoid unwanted change detection, if you want to optimize the performance.
*/
this.detectEventChanges = true;
// chart events:
this.detectEventChanges = true; // deprecated, left for compatibility reasons to avoid triggering major version
// deprecated, left for compatibility reasons to avoid triggering major version
// ngx-echarts events
this.chartInit = new core.EventEmitter();
this.chartClick = new core.EventEmitter();
this.chartDblClick = new core.EventEmitter();
this.chartMouseDown = new core.EventEmitter();
this.chartMouseUp = new core.EventEmitter();
this.chartMouseOver = new core.EventEmitter();
this.chartMouseOut = new core.EventEmitter();
this.chartGlobalOut = new core.EventEmitter();
this.chartContextMenu = new core.EventEmitter();
this.chartDataZoom = new core.EventEmitter();
this.chartMapSelectChanged = new core.EventEmitter();
this.chartMapSelected = new core.EventEmitter();
this.chartMapUnselected = new core.EventEmitter();
// echarts mouse events
this.chartClick = this.createLazyEvent('click');
this.chartDblClick = this.createLazyEvent('dblclick');
this.chartMouseDown = this.createLazyEvent('mousedown');
this.chartMouseMove = this.createLazyEvent('mousemove');
this.chartMouseUp = this.createLazyEvent('mouseup');
this.chartMouseOver = this.createLazyEvent('mouseover');
this.chartMouseOut = this.createLazyEvent('mouseout');
this.chartGlobalOut = this.createLazyEvent('globalout');
this.chartContextMenu = this.createLazyEvent('contextmenu');
// echarts mouse events
this.chartLegendSelectChanged = this.createLazyEvent('legendselectchanged');
this.chartLegendSelected = this.createLazyEvent('legendselected');
this.chartLegendUnselected = this.createLazyEvent('legendunselected');
this.chartLegendScroll = this.createLazyEvent('legendscroll');
this.chartDataZoom = this.createLazyEvent('datazoom');
this.chartDataRangeSelected = this.createLazyEvent('datarangeselected');
this.chartTimelineChanged = this.createLazyEvent('timelinechanged');
this.chartTimelinePlayChanged = this.createLazyEvent('timelineplaychanged');
this.chartRestore = this.createLazyEvent('restore');
this.chartDataViewChanged = this.createLazyEvent('dataviewchanged');
this.chartMagicTypeChanged = this.createLazyEvent('magictypechanged');
this.chartPieSelectChanged = this.createLazyEvent('pieselectchanged');
this.chartPieSelected = this.createLazyEvent('pieselected');
this.chartPieUnselected = this.createLazyEvent('pieunselected');
this.chartMapSelectChanged = this.createLazyEvent('mapselectchanged');
this.chartMapSelected = this.createLazyEvent('mapselected');
this.chartMapUnselected = this.createLazyEvent('mapunselected');
this.chartAxisAreaSelected = this.createLazyEvent('axisareaselected');
this.chartFocusNodeAdjacency = this.createLazyEvent('focusnodeadjacency');
this.chartUnfocusNodeAdjacency = this.createLazyEvent('unfocusnodeadjacency');
this.chartBrush = this.createLazyEvent('brush');
this.chartBrushSelected = this.createLazyEvent('brushselected');
this.chartRendered = this.createLazyEvent('rendered');
this.chartFinished = this.createLazyEvent('finished');
this.currentOffsetWidth = 0;
this.currentOffsetHeight = 0;
this._resize$ = new rxjs.Subject();
}
/**
* @return {?}
*/
NgxEchartsDirective.prototype.createChart = /**
* @return {?}
*/
function () {
var _this = this;
this.currentWindowWidth = window.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
/** @type {?} */
var dom = this.el.nativeElement;
if (window && window.getComputedStyle) {
/** @type {?} */
var prop = window.getComputedStyle(dom, null).getPropertyValue('height');
if ((!prop || prop === '0px') &&
(!dom.style.height || dom.style.height === '0px')) {
dom.style.height = '400px';
}
}
return this._ngZone.runOutsideAngular(function () { return echarts.init(dom, _this.theme || undefined, _this.initOpts || undefined); });
};
/**
* @param {?} event
* @return {?}
*/
NgxEchartsDirective.prototype.onWindowResize = /**
* @param {?} event
* @return {?}
*/
function (event) {
/** @type {?} */
var target = ( /** @type {?} */(event.target));
if (this.autoResize && target.innerWidth !== this.currentWindowWidth) {
this.currentWindowWidth = target.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
this._resize$.next();
}
};
/**
* @param {?} changes

@@ -231,3 +173,2 @@ * @return {?}

filter.has('loading').subscribe(function (v) { return _this.toggleLoading(!!v); });
filter.notFirst('detectEventChanges').subscribe(function (v) { return _this.toggleEventDetectors(!!v); });
filter.notFirst('theme').subscribe(function () { return _this.refreshChart(); });

@@ -238,2 +179,19 @@ };

*/
NgxEchartsDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.resizeSub = rxjs.fromEvent(window, 'resize').pipe(operators.debounceTime(50)).subscribe(function () {
if (_this.autoResize && window.innerWidth !== _this.currentWindowWidth) {
_this.currentWindowWidth = window.innerWidth;
_this.currentOffsetWidth = _this.el.nativeElement.offsetWidth;
_this.currentOffsetHeight = _this.el.nativeElement.offsetHeight;
_this.resize();
}
});
};
/**
* @return {?}
*/
NgxEchartsDirective.prototype.ngOnDestroy = /**

@@ -243,10 +201,4 @@ * @return {?}

function () {
if (this._resizeSub) {
this._resizeSub.unsubscribe();
this._resizeSub = null;
}
if (this._chart) {
this._chart.dispose();
this._chart = null;
}
this.resizeSub.unsubscribe();
this.dispose();
};

@@ -261,3 +213,3 @@ /**

// No heavy work in DoCheck!
if (this._chart && this.autoResize) {
if (this.chart && this.autoResize) {
/** @type {?} */

@@ -270,3 +222,3 @@ var offsetWidth = this.el.nativeElement.offsetWidth;

this.currentOffsetHeight = offsetHeight;
this._resize$.next();
this.resize();
}

@@ -288,68 +240,48 @@ }

*/
NgxEchartsDirective.prototype.initChart = /**
NgxEchartsDirective.prototype.dispose = /**
* @return {?}
*/
function () {
this.onOptionsChange(this.options);
if (this.merge && this._chart) {
this.setOption(this.merge);
if (this.chart) {
this.chart.dispose();
this.chart = null;
}
};
/**
* @param {?} opt
* @return {?}
*/
NgxEchartsDirective.prototype.onOptionsChange = /**
* @param {?} opt
NgxEchartsDirective.prototype.resize = /**
* @return {?}
*/
function (opt) {
var _this = this;
if (opt) {
if (!this._chart) {
this._chart = this.createChart();
// subscribe to _resize$ and debounced
this._resizeSub = this._resize$.pipe(operators.debounceTime(50)).subscribe(function () {
if (_this._chart) {
_this._chart.resize();
}
});
// output echart instance:
this.chartInit.emit(this._chart);
// register events:
if (this.detectEventChanges) {
this.registerEvents();
}
}
this._chart.setOption(this.options, true);
function () {
if (this.chart) {
this.chart.resize();
}
};
/**
* @param {?} loading
* @return {?}
*/
NgxEchartsDirective.prototype.registerEvents = /**
NgxEchartsDirective.prototype.toggleLoading = /**
* @param {?} loading
* @return {?}
*/
function () {
if (this._chart) {
/** @type {?} */
var events = EChartEvents.All;
for (var i = 0, len = events.length; i < len; i++) {
this._chart.on(events[i], this.eventHandler, this);
}
function (loading) {
if (this.chart) {
loading ? this.chart.showLoading(this.loadingType, this.loadingOpts) : this.chart.hideLoading();
}
};
/**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
NgxEchartsDirective.prototype.unregisterEvents = /**
NgxEchartsDirective.prototype.setOption = /**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
function () {
if (this._chart) {
/** @type {?} */
var events = EChartEvents.All;
for (var i = 0, len = events.length; i < len; i++) {
this._chart.off(events[i], this.eventHandler);
}
function (option, opts) {
if (this.chart) {
this.chart.setOption(option, opts);
}

@@ -360,110 +292,87 @@ };

*/
NgxEchartsDirective.prototype.clear = /**
NgxEchartsDirective.prototype.refreshChart = /**
* @return {?}
*/
function () {
if (this._chart) {
this._chart.clear();
}
this.dispose();
this.initChart();
};
/**
* @param {?} loading
* @return {?}
*/
NgxEchartsDirective.prototype.toggleLoading = /**
* @param {?} loading
NgxEchartsDirective.prototype.createChart = /**
* @return {?}
*/
function (loading) {
if (this._chart) {
loading ? this._chart.showLoading(this.loadingType, this.loadingOpts) : this._chart.hideLoading();
function () {
var _this = this;
this.currentWindowWidth = window.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
/** @type {?} */
var dom = this.el.nativeElement;
if (window && window.getComputedStyle) {
/** @type {?} */
var prop = window.getComputedStyle(dom, null).getPropertyValue('height');
if ((!prop || prop === '0px') &&
(!dom.style.height || dom.style.height === '0px')) {
dom.style.height = '400px';
}
}
return this.ngZone.runOutsideAngular(function () { return echarts.init(dom, _this.theme, _this.initOpts); });
};
/**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
NgxEchartsDirective.prototype.setOption = /**
* @param {?} option
* @param {?=} opts
NgxEchartsDirective.prototype.initChart = /**
* @return {?}
*/
function (option, opts) {
if (this._chart) {
this._chart.setOption(option, opts);
function () {
this.onOptionsChange(this.options);
if (this.merge && this.chart) {
this.setOption(this.merge);
}
};
/**
* @param {?} event
* @param {?} opt
* @return {?}
*/
NgxEchartsDirective.prototype.eventHandler = /**
* @param {?} event
NgxEchartsDirective.prototype.onOptionsChange = /**
* @param {?} opt
* @return {?}
*/
function (event) {
var _this = this;
switch (event.type) {
case EChartEvents.Click:
this._ngZone.run(function () { return _this.chartClick.emit(event); });
break;
case EChartEvents.DblClick:
this._ngZone.run(function () { return _this.chartDblClick.emit(event); });
break;
case EChartEvents.MouseDown:
this._ngZone.run(function () { return _this.chartMouseDown.emit(event); });
break;
case EChartEvents.MouseUp:
this._ngZone.run(function () { return _this.chartMouseUp.emit(event); });
break;
case EChartEvents.MouseOver:
this._ngZone.run(function () { return _this.chartMouseOver.emit(event); });
break;
case EChartEvents.MouseOut:
this._ngZone.run(function () { return _this.chartMouseOut.emit(event); });
break;
case EChartEvents.GlobalOut:
this._ngZone.run(function () { return _this.chartGlobalOut.emit(event); });
break;
case EChartEvents.ContextMenu:
this._ngZone.run(function () { return _this.chartContextMenu.emit(event); });
break;
case EChartEvents.DataZoom:
this._ngZone.run(function () { return _this.chartDataZoom.emit(event); });
break;
case EChartEvents.MapSelectChanged:
this._ngZone.run(function () { return _this.chartMapSelectChanged.emit(event); });
break;
case EChartEvents.MapSelected:
this._ngZone.run(function () { return _this.chartMapSelected.emit(event); });
break;
case EChartEvents.MapUnselected:
this._ngZone.run(function () { return _this.chartMapUnselected.emit(event); });
break;
function (opt) {
if (opt) {
if (!this.chart) {
this.chart = this.createChart();
this.chartInit.emit(this.chart);
}
this.chart.setOption(this.options, true);
}
};
// allows to lazily bind to only those events that are requested through the `@Output` by parent components
// see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info
// allows to lazily bind to only those events that are requested through the `@Output` by parent components
// see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info
/**
* @param {?} detect
* @template T
* @param {?} eventName
* @return {?}
*/
NgxEchartsDirective.prototype.toggleEventDetectors = /**
* @param {?} detect
* @return {?}
*/
function (detect) {
if (this._chart) {
detect ? this.registerEvents() : this.unregisterEvents();
}
NgxEchartsDirective.prototype.createLazyEvent =
// allows to lazily bind to only those events that are requested through the `@Output` by parent components
// see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info
/**
* @template T
* @param {?} eventName
* @return {?}
*/
function (eventName) {
var _this = this;
return ( /** @type {?} */(this.chartInit.pipe(operators.switchMap(function (chart) {
return new rxjs.Observable(function (observer) {
chart.on(eventName, function (data) { return _this.ngZone.run(function () { return observer.next(data); }); });
return null; // no need to react on unsubscribe as long as the `dispose()` is called in ngOnDestroy
});
}))));
};
/**
* @return {?}
*/
NgxEchartsDirective.prototype.refreshChart = /**
* @return {?}
*/
function () {
this.ngOnDestroy();
this.initChart();
};
NgxEchartsDirective.decorators = [

@@ -495,2 +404,3 @@ { type: core.Directive, args: [{

chartMouseDown: [{ type: core.Output }],
chartMouseMove: [{ type: core.Output }],
chartMouseUp: [{ type: core.Output }],

@@ -501,7 +411,26 @@ chartMouseOver: [{ type: core.Output }],

chartContextMenu: [{ type: core.Output }],
chartLegendSelectChanged: [{ type: core.Output }],
chartLegendSelected: [{ type: core.Output }],
chartLegendUnselected: [{ type: core.Output }],
chartLegendScroll: [{ type: core.Output }],
chartDataZoom: [{ type: core.Output }],
chartDataRangeSelected: [{ type: core.Output }],
chartTimelineChanged: [{ type: core.Output }],
chartTimelinePlayChanged: [{ type: core.Output }],
chartRestore: [{ type: core.Output }],
chartDataViewChanged: [{ type: core.Output }],
chartMagicTypeChanged: [{ type: core.Output }],
chartPieSelectChanged: [{ type: core.Output }],
chartPieSelected: [{ type: core.Output }],
chartPieUnselected: [{ type: core.Output }],
chartMapSelectChanged: [{ type: core.Output }],
chartMapSelected: [{ type: core.Output }],
chartMapUnselected: [{ type: core.Output }],
onWindowResize: [{ type: core.HostListener, args: ['window:resize', ['$event'],] }]
chartAxisAreaSelected: [{ type: core.Output }],
chartFocusNodeAdjacency: [{ type: core.Output }],
chartUnfocusNodeAdjacency: [{ type: core.Output }],
chartBrush: [{ type: core.Output }],
chartBrushSelected: [{ type: core.Output }],
chartRendered: [{ type: core.Output }],
chartFinished: [{ type: core.Output }]
};

@@ -549,2 +478,2 @@ return NgxEchartsDirective;

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-echarts.umd.js.map","sources":["ng://ngx-echarts/lib/change-filter.ts","ng://ngx-echarts/lib/echart-events.ts","ng://ngx-echarts/lib/ngx-echarts.directive.ts","ng://ngx-echarts/lib/ngx-echarts.module.ts"],"sourcesContent":["import { SimpleChanges } from '@angular/core';\r\nimport { Observable, of, empty } from 'rxjs';\r\n\r\nexport class ChangeFilter {\r\n  constructor(private _changes: SimpleChanges) { }\r\n\r\n  static of(changes: SimpleChanges) {\r\n    return new ChangeFilter(changes);\r\n  }\r\n\r\n  notEmpty<T>(key: string): Observable<T> {\r\n    if (this._changes[key]) {\r\n      const value: T = this._changes[key].currentValue;\r\n\r\n      if (value !== undefined && value !== null) {\r\n        return of(value);\r\n      }\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  has<T>(key: string): Observable<T> {\r\n    if (this._changes[key]) {\r\n      const value: T = this._changes[key].currentValue;\r\n      return of(value);\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  notFirst<T>(key: string): Observable<T> {\r\n    if (this._changes[key] && !this._changes[key].isFirstChange()) {\r\n      const value: T = this._changes[key].currentValue;\r\n      return of(value);\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  notFirstAndEmpty<T>(key: string): Observable<T> {\r\n    if (this._changes[key] && !this._changes[key].isFirstChange()) {\r\n      const value: T = this._changes[key].currentValue;\r\n\r\n      if (value !== undefined && value !== null) {\r\n        return of(value);\r\n      }\r\n    }\r\n    return empty();\r\n  }\r\n}\r\n","export class EChartEvents {\r\n  static Click = 'click';\r\n  static DblClick = 'dblclick';\r\n  static MouseDown = 'mousedown';\r\n  static MouseUp = 'mouseup';\r\n  static MouseOver = 'mouseover';\r\n  static MouseOut = 'mouseout';\r\n  static GlobalOut = 'globalout';\r\n  static ContextMenu = 'contextmenu';\r\n  static DataZoom = 'datazoom';\r\n  static MapSelectChanged = 'mapselectchanged';\r\n  static MapSelected = 'mapselected';\r\n  static MapUnselected = 'mapunselected';\r\n\r\n  static All = [\r\n    EChartEvents.Click,\r\n    EChartEvents.DblClick,\r\n    EChartEvents.MouseDown,\r\n    EChartEvents.MouseUp,\r\n    EChartEvents.MouseOver,\r\n    EChartEvents.MouseOut,\r\n    EChartEvents.GlobalOut,\r\n    EChartEvents.ContextMenu,\r\n    EChartEvents.DataZoom,\r\n    EChartEvents.MapSelectChanged,\r\n    EChartEvents.MapSelected,\r\n    EChartEvents.MapUnselected,\r\n  ];\r\n}\r\n","import {\r\n  Directive, ElementRef, Renderer, Input, Output, HostListener, EventEmitter,\r\n  OnChanges, OnDestroy, SimpleChanges, NgZone, DoCheck, AfterViewInit\r\n} from '@angular/core';\r\nimport { ChangeFilter } from './change-filter';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { init, ECharts, EChartOption } from 'echarts';\r\nimport { EChartEvents } from './echart-events';\r\n\r\n@Directive({\r\n  selector: 'echarts, [echarts]',\r\n})\r\nexport class NgxEchartsDirective implements OnChanges, OnDestroy, DoCheck, AfterViewInit {\r\n  @Input() options: EChartOption;\r\n  @Input() theme: string;\r\n  @Input() loading: boolean;\r\n  @Input() initOpts: {\r\n    devicePixelRatio?: number\r\n    renderer?: string\r\n    width?: number | string\r\n    height?: number | string\r\n  };\r\n  @Input() merge: EChartOption;\r\n  @Input() autoResize = true;\r\n  @Input() loadingType = 'default';\r\n  @Input() loadingOpts: object;\r\n\r\n  /**\r\n   * Whether to register event handlers on echartInstance. Default is true.\r\n   * Use it to avoid unwanted change detection, if you want to optimize the performance.\r\n   */\r\n  @Input() detectEventChanges = true;\r\n\r\n  // chart events:\r\n  @Output() chartInit = new EventEmitter<ECharts>();\r\n  @Output() chartClick = new EventEmitter<any>();\r\n  @Output() chartDblClick = new EventEmitter<any>();\r\n  @Output() chartMouseDown = new EventEmitter<any>();\r\n  @Output() chartMouseUp = new EventEmitter<any>();\r\n  @Output() chartMouseOver = new EventEmitter<any>();\r\n  @Output() chartMouseOut = new EventEmitter<any>();\r\n  @Output() chartGlobalOut = new EventEmitter<any>();\r\n  @Output() chartContextMenu = new EventEmitter<any>();\r\n  @Output() chartDataZoom = new EventEmitter<any>();\r\n  @Output() chartMapSelectChanged = new EventEmitter<any>();\r\n  @Output() chartMapSelected = new EventEmitter<any>();\r\n  @Output() chartMapUnselected = new EventEmitter<any>();\r\n\r\n  private _chart: ECharts;\r\n  private currentOffsetWidth = 0;\r\n  private currentOffsetHeight = 0;\r\n  private currentWindowWidth: number;\r\n  private _resize$ = new Subject<void>();\r\n  private _resizeSub: Subscription;\r\n\r\n  constructor(private el: ElementRef, private _ngZone: NgZone) { }\r\n\r\n  private createChart() {\r\n    this.currentWindowWidth = window.innerWidth;\r\n    this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n    this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n    const dom = this.el.nativeElement;\r\n\r\n    if (window && window.getComputedStyle) {\r\n      const prop = window.getComputedStyle(dom, null).getPropertyValue('height');\r\n      if ((!prop || prop === '0px') &&\r\n        (!dom.style.height || dom.style.height === '0px')) {\r\n        dom.style.height = '400px';\r\n      }\r\n    }\r\n\r\n    return this._ngZone.runOutsideAngular(() => init(dom, this.theme || undefined, this.initOpts || undefined));\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize(event: Event) {\r\n    const target = event.target as Window;\r\n\r\n    if (this.autoResize && target.innerWidth !== this.currentWindowWidth) {\r\n      this.currentWindowWidth = target.innerWidth;\r\n      this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n      this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      this._resize$.next();\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const filter = ChangeFilter.of(changes);\r\n    filter.notFirstAndEmpty<any>('options').subscribe(opt => this.onOptionsChange(opt));\r\n    filter.notFirstAndEmpty<any>('merge').subscribe(opt => this.setOption(opt));\r\n    filter.has<boolean>('loading').subscribe(v => this.toggleLoading(!!v));\r\n    filter.notFirst<boolean>('detectEventChanges').subscribe(v => this.toggleEventDetectors(!!v));\r\n    filter.notFirst<string>('theme').subscribe(() => this.refreshChart());\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this._resizeSub) {\r\n      this._resizeSub.unsubscribe();\r\n      this._resizeSub = null;\r\n    }\r\n\r\n    if (this._chart) {\r\n      this._chart.dispose();\r\n      this._chart = null;\r\n    }\r\n  }\r\n\r\n  ngDoCheck() {\r\n    // No heavy work in DoCheck!\r\n    if (this._chart && this.autoResize) {\r\n      const offsetWidth = this.el.nativeElement.offsetWidth;\r\n      const offsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      if (this.currentOffsetWidth !== offsetWidth || this.currentOffsetHeight !== offsetHeight) {\r\n        this.currentOffsetWidth = offsetWidth;\r\n        this.currentOffsetHeight = offsetHeight;\r\n        this._resize$.next();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    setTimeout(() => this.initChart());\r\n  }\r\n\r\n  private initChart() {\r\n    this.onOptionsChange(this.options);\r\n\r\n    if (this.merge && this._chart) {\r\n      this.setOption(this.merge);\r\n    }\r\n  }\r\n\r\n  private onOptionsChange(opt: EChartOption) {\r\n    if (opt) {\r\n      if (!this._chart) {\r\n        this._chart = this.createChart();\r\n\r\n        // subscribe to _resize$ and debounced\r\n        this._resizeSub = this._resize$.pipe(debounceTime(50)).subscribe(() => {\r\n          if (this._chart) {\r\n            this._chart.resize();\r\n          }\r\n        });\r\n\r\n        // output echart instance:\r\n        this.chartInit.emit(this._chart);\r\n\r\n        // register events:\r\n        if (this.detectEventChanges) {\r\n          this.registerEvents();\r\n        }\r\n      }\r\n\r\n      this._chart.setOption(this.options, true);\r\n    }\r\n  }\r\n\r\n  private registerEvents() {\r\n    if (this._chart) {\r\n      const events = EChartEvents.All;\r\n      for (let i = 0, len = events.length; i < len; i++) {\r\n        this._chart.on(events[i], this.eventHandler, this);\r\n      }\r\n    }\r\n  }\r\n\r\n  private unregisterEvents() {\r\n    if (this._chart) {\r\n      const events = EChartEvents.All;\r\n      for (let i = 0, len = events.length; i < len; i++) {\r\n        this._chart.off(events[i], this.eventHandler);\r\n      }\r\n    }\r\n  }\r\n\r\n  clear() {\r\n    if (this._chart) {\r\n      this._chart.clear();\r\n    }\r\n  }\r\n\r\n  toggleLoading(loading: boolean) {\r\n    if (this._chart) {\r\n      loading ? this._chart.showLoading(this.loadingType, this.loadingOpts) : this._chart.hideLoading();\r\n    }\r\n  }\r\n\r\n  setOption(option: any, opts?: any) {\r\n    if (this._chart) {\r\n      this._chart.setOption(option, opts);\r\n    }\r\n  }\r\n\r\n  private eventHandler(event) {\r\n    switch (event.type) {\r\n      case EChartEvents.Click:\r\n        this._ngZone.run(() => this.chartClick.emit(event));\r\n        break;\r\n      case EChartEvents.DblClick:\r\n        this._ngZone.run(() => this.chartDblClick.emit(event));\r\n        break;\r\n      case EChartEvents.MouseDown:\r\n        this._ngZone.run(() => this.chartMouseDown.emit(event));\r\n        break;\r\n      case EChartEvents.MouseUp:\r\n        this._ngZone.run(() => this.chartMouseUp.emit(event));\r\n        break;\r\n      case EChartEvents.MouseOver:\r\n        this._ngZone.run(() => this.chartMouseOver.emit(event));\r\n        break;\r\n      case EChartEvents.MouseOut:\r\n        this._ngZone.run(() => this.chartMouseOut.emit(event));\r\n        break;\r\n      case EChartEvents.GlobalOut:\r\n        this._ngZone.run(() => this.chartGlobalOut.emit(event));\r\n        break;\r\n      case EChartEvents.ContextMenu:\r\n        this._ngZone.run(() => this.chartContextMenu.emit(event));\r\n        break;\r\n      case EChartEvents.DataZoom:\r\n        this._ngZone.run(() => this.chartDataZoom.emit(event));\r\n        break;\r\n      case EChartEvents.MapSelectChanged:\r\n        this._ngZone.run(() => this.chartMapSelectChanged.emit(event));\r\n        break;\r\n      case EChartEvents.MapSelected:\r\n        this._ngZone.run(() => this.chartMapSelected.emit(event));\r\n        break;\r\n      case EChartEvents.MapUnselected:\r\n        this._ngZone.run(() => this.chartMapUnselected.emit(event));\r\n        break;\r\n    }\r\n  }\r\n\r\n  private toggleEventDetectors(detect: boolean) {\r\n    if (this._chart) {\r\n      detect ? this.registerEvents() : this.unregisterEvents();\r\n    }\r\n  }\r\n\r\n  private refreshChart() {\r\n    this.ngOnDestroy();\r\n    this.initChart();\r\n  }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { NgxEchartsDirective } from './ngx-echarts.directive';\r\n\r\n@NgModule({\r\n  imports: [],\r\n  declarations: [\r\n    NgxEchartsDirective\r\n  ],\r\n  exports: [\r\n    NgxEchartsDirective\r\n  ]\r\n})\r\nexport class NgxEchartsModule { }\r\n"],"names":["of","empty","EventEmitter","Subject","init","debounceTime","Directive","ElementRef","NgZone","Input","Output","HostListener","NgModule"],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-echarts.umd.js.map","sources":["ng://ngx-echarts/lib/change-filter.ts","ng://ngx-echarts/lib/ngx-echarts.directive.ts","ng://ngx-echarts/lib/ngx-echarts.module.ts"],"sourcesContent":["import { SimpleChanges } from '@angular/core';\r\nimport { Observable, of, empty } from 'rxjs';\r\n\r\nexport class ChangeFilter {\r\n  constructor(private _changes: SimpleChanges) { }\r\n\r\n  static of(changes: SimpleChanges) {\r\n    return new ChangeFilter(changes);\r\n  }\r\n\r\n  notEmpty<T>(key: string): Observable<T> {\r\n    if (this._changes[key]) {\r\n      const value: T = this._changes[key].currentValue;\r\n\r\n      if (value !== undefined && value !== null) {\r\n        return of(value);\r\n      }\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  has<T>(key: string): Observable<T> {\r\n    if (this._changes[key]) {\r\n      const value: T = this._changes[key].currentValue;\r\n      return of(value);\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  notFirst<T>(key: string): Observable<T> {\r\n    if (this._changes[key] && !this._changes[key].isFirstChange()) {\r\n      const value: T = this._changes[key].currentValue;\r\n      return of(value);\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  notFirstAndEmpty<T>(key: string): Observable<T> {\r\n    if (this._changes[key] && !this._changes[key].isFirstChange()) {\r\n      const value: T = this._changes[key].currentValue;\r\n\r\n      if (value !== undefined && value !== null) {\r\n        return of(value);\r\n      }\r\n    }\r\n    return empty();\r\n  }\r\n}\r\n","import { AfterViewInit, Directive, DoCheck, ElementRef, EventEmitter, Input, NgZone, OnChanges, OnDestroy, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { EChartOption, ECharts, init } from 'echarts';\r\nimport { fromEvent, Observable, Subscription } from 'rxjs';\r\nimport { debounceTime, switchMap } from 'rxjs/operators';\r\nimport { ChangeFilter } from './change-filter';\r\n\r\n@Directive({\r\n  selector: 'echarts, [echarts]',\r\n})\r\nexport class NgxEchartsDirective implements OnChanges, OnDestroy, OnInit, DoCheck, AfterViewInit {\r\n  @Input() options: EChartOption;\r\n  @Input() theme: string;\r\n  @Input() loading: boolean;\r\n  @Input() initOpts: {\r\n    devicePixelRatio?: number\r\n    renderer?: string\r\n    width?: number | string\r\n    height?: number | string\r\n  };\r\n  @Input() merge: EChartOption;\r\n  @Input() autoResize = true;\r\n  @Input() loadingType = 'default';\r\n  @Input() loadingOpts: object;\r\n  @Input() detectEventChanges = true; // deprecated, left for compatibility reasons to avoid triggering major version\r\n\r\n  // ngx-echarts events\r\n  @Output() chartInit = new EventEmitter<ECharts>();\r\n\r\n  // echarts mouse events\r\n  @Output() chartClick = this.createLazyEvent('click');\r\n  @Output() chartDblClick = this.createLazyEvent('dblclick');\r\n  @Output() chartMouseDown = this.createLazyEvent('mousedown');\r\n  @Output() chartMouseMove = this.createLazyEvent('mousemove');\r\n  @Output() chartMouseUp = this.createLazyEvent('mouseup');\r\n  @Output() chartMouseOver = this.createLazyEvent('mouseover');\r\n  @Output() chartMouseOut = this.createLazyEvent('mouseout');\r\n  @Output() chartGlobalOut = this.createLazyEvent('globalout');\r\n  @Output() chartContextMenu = this.createLazyEvent('contextmenu');\r\n\r\n  // echarts mouse events\r\n  @Output() chartLegendSelectChanged = this.createLazyEvent('legendselectchanged');\r\n  @Output() chartLegendSelected = this.createLazyEvent('legendselected');\r\n  @Output() chartLegendUnselected = this.createLazyEvent('legendunselected');\r\n  @Output() chartLegendScroll = this.createLazyEvent('legendscroll');\r\n  @Output() chartDataZoom = this.createLazyEvent('datazoom');\r\n  @Output() chartDataRangeSelected = this.createLazyEvent('datarangeselected');\r\n  @Output() chartTimelineChanged = this.createLazyEvent('timelinechanged');\r\n  @Output() chartTimelinePlayChanged = this.createLazyEvent('timelineplaychanged');\r\n  @Output() chartRestore = this.createLazyEvent('restore');\r\n  @Output() chartDataViewChanged = this.createLazyEvent('dataviewchanged');\r\n  @Output() chartMagicTypeChanged = this.createLazyEvent('magictypechanged');\r\n  @Output() chartPieSelectChanged = this.createLazyEvent('pieselectchanged');\r\n  @Output() chartPieSelected = this.createLazyEvent('pieselected');\r\n  @Output() chartPieUnselected = this.createLazyEvent('pieunselected');\r\n  @Output() chartMapSelectChanged = this.createLazyEvent('mapselectchanged');\r\n  @Output() chartMapSelected = this.createLazyEvent('mapselected');\r\n  @Output() chartMapUnselected = this.createLazyEvent('mapunselected');\r\n  @Output() chartAxisAreaSelected = this.createLazyEvent('axisareaselected');\r\n  @Output() chartFocusNodeAdjacency = this.createLazyEvent('focusnodeadjacency');\r\n  @Output() chartUnfocusNodeAdjacency = this.createLazyEvent('unfocusnodeadjacency');\r\n  @Output() chartBrush = this.createLazyEvent('brush');\r\n  @Output() chartBrushSelected = this.createLazyEvent('brushselected');\r\n  @Output() chartRendered = this.createLazyEvent('rendered');\r\n  @Output() chartFinished = this.createLazyEvent('finished');\r\n\r\n  private chart: ECharts;\r\n  private currentOffsetWidth = 0;\r\n  private currentOffsetHeight = 0;\r\n  private currentWindowWidth: number;\r\n  private resizeSub: Subscription;\r\n\r\n  constructor(private el: ElementRef, private ngZone: NgZone) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const filter = ChangeFilter.of(changes);\r\n    filter.notFirstAndEmpty<any>('options').subscribe(opt => this.onOptionsChange(opt));\r\n    filter.notFirstAndEmpty<any>('merge').subscribe(opt => this.setOption(opt));\r\n    filter.has<boolean>('loading').subscribe(v => this.toggleLoading(!!v));\r\n    filter.notFirst<string>('theme').subscribe(() => this.refreshChart());\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.resizeSub = fromEvent(window, 'resize').pipe(debounceTime(50)).subscribe(() => {\r\n      if (this.autoResize && window.innerWidth !== this.currentWindowWidth) {\r\n        this.currentWindowWidth = window.innerWidth;\r\n        this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n        this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n        this.resize();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.resizeSub.unsubscribe();\r\n    this.dispose();\r\n  }\r\n\r\n  ngDoCheck() {\r\n    // No heavy work in DoCheck!\r\n    if (this.chart && this.autoResize) {\r\n      const offsetWidth = this.el.nativeElement.offsetWidth;\r\n      const offsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      if (this.currentOffsetWidth !== offsetWidth || this.currentOffsetHeight !== offsetHeight) {\r\n        this.currentOffsetWidth = offsetWidth;\r\n        this.currentOffsetHeight = offsetHeight;\r\n        this.resize();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    setTimeout(() => this.initChart());\r\n  }\r\n\r\n  private dispose() {\r\n    if (this.chart) {\r\n      this.chart.dispose();\r\n      this.chart = null;\r\n    }\r\n  }\r\n\r\n  private resize() {\r\n    if (this.chart) {\r\n      this.chart.resize();\r\n    }\r\n  }\r\n\r\n  private toggleLoading(loading: boolean) {\r\n    if (this.chart) {\r\n      loading ? this.chart.showLoading(this.loadingType, this.loadingOpts) : this.chart.hideLoading();\r\n    }\r\n  }\r\n\r\n  private setOption(option: any, opts?: any) {\r\n    if (this.chart) {\r\n      this.chart.setOption(option, opts);\r\n    }\r\n  }\r\n\r\n  private refreshChart() {\r\n    this.dispose();\r\n    this.initChart();\r\n  }\r\n\r\n  private createChart() {\r\n    this.currentWindowWidth = window.innerWidth;\r\n    this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n    this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n    const dom = this.el.nativeElement;\r\n\r\n    if (window && window.getComputedStyle) {\r\n      const prop = window.getComputedStyle(dom, null).getPropertyValue('height');\r\n      if ((!prop || prop === '0px') &&\r\n        (!dom.style.height || dom.style.height === '0px')) {\r\n        dom.style.height = '400px';\r\n      }\r\n    }\r\n\r\n    return this.ngZone.runOutsideAngular(() => init(dom, this.theme, this.initOpts));\r\n  }\r\n\r\n  private initChart() {\r\n    this.onOptionsChange(this.options);\r\n\r\n    if (this.merge && this.chart) {\r\n      this.setOption(this.merge);\r\n    }\r\n  }\r\n\r\n  private onOptionsChange(opt: EChartOption) {\r\n    if (opt) {\r\n      if (!this.chart) {\r\n        this.chart = this.createChart();\r\n        this.chartInit.emit(this.chart);\r\n      }\r\n\r\n      this.chart.setOption(this.options, true);\r\n    }\r\n  }\r\n\r\n  // allows to lazily bind to only those events that are requested through the `@Output` by parent components\r\n  // see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info\r\n  private createLazyEvent<T>(eventName: string): EventEmitter<T> {\r\n    return this.chartInit.pipe(\r\n      switchMap((chart: ECharts) => new Observable(observer => {\r\n        chart.on(eventName, (data: T) => this.ngZone.run(() => observer.next(data)));\r\n        return null; // no need to react on unsubscribe as long as the `dispose()` is called in ngOnDestroy\r\n      }))\r\n    ) as EventEmitter<T>;\r\n  }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { NgxEchartsDirective } from './ngx-echarts.directive';\r\n\r\n@NgModule({\r\n  imports: [],\r\n  declarations: [\r\n    NgxEchartsDirective\r\n  ],\r\n  exports: [\r\n    NgxEchartsDirective\r\n  ]\r\n})\r\nexport class NgxEchartsModule { }\r\n"],"names":["of","empty","EventEmitter","fromEvent","debounceTime","init","switchMap","Observable","Directive","ElementRef","NgZone","Input","Output","NgModule"],"mappings":";;;;;;;;;;AACA,IAEA;QACE,sBAAoB,QAAuB;YAAvB,aAAQ,GAAR,QAAQ,CAAe;SAAK;;;;;QAEzC,eAAE;;;;YAAT,UAAU,OAAsB;gBAC9B,OAAO,IAAI,YAAY,CAAC,OAAO,CAAC,CAAC;aAClC;;;;;;QAED,+BAAQ;;;;;YAAR,UAAY,GAAW;gBACrB,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;;wBAChB,KAAK,GAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,YAAY;oBAEhD,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,EAAE;wBACzC,OAAOA,OAAE,CAAC,KAAK,CAAC,CAAC;qBAClB;iBACF;gBACD,OAAOC,UAAK,EAAE,CAAC;aAChB;;;;;;QAED,0BAAG;;;;;YAAH,UAAO,GAAW;gBAChB,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;;wBAChB,KAAK,GAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,YAAY;oBAChD,OAAOD,OAAE,CAAC,KAAK,CAAC,CAAC;iBAClB;gBACD,OAAOC,UAAK,EAAE,CAAC;aAChB;;;;;;QAED,+BAAQ;;;;;YAAR,UAAY,GAAW;gBACrB,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,EAAE;;wBACvD,KAAK,GAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,YAAY;oBAChD,OAAOD,OAAE,CAAC,KAAK,CAAC,CAAC;iBAClB;gBACD,OAAOC,UAAK,EAAE,CAAC;aAChB;;;;;;QAED,uCAAgB;;;;;YAAhB,UAAoB,GAAW;gBAC7B,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,EAAE;;wBACvD,KAAK,GAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,YAAY;oBAEhD,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,EAAE;wBACzC,OAAOD,OAAE,CAAC,KAAK,CAAC,CAAC;qBAClB;iBACF;gBACD,OAAOC,UAAK,EAAE,CAAC;aAChB;QACH,mBAAC;IAAD,CAAC,IAAA;;;;;;AC/CD;QAuEE,6BAAoB,EAAc,EAAU,MAAc;YAAtC,OAAE,GAAF,EAAE,CAAY;YAAU,WAAM,GAAN,MAAM,CAAQ;YAnDjD,eAAU,GAAG,IAAI,CAAC;YAClB,gBAAW,GAAG,SAAS,CAAC;YAExB,uBAAkB,GAAG,IAAI,CAAC;;;YAGzB,cAAS,GAAG,IAAIC,iBAAY,EAAW,CAAC;;YAGxC,eAAU,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;YAC3C,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;YACjD,mBAAc,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;YACnD,mBAAc,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;YACnD,iBAAY,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;YAC/C,mBAAc,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;YACnD,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;YACjD,mBAAc,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;YACnD,qBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;;YAGvD,6BAAwB,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC;YACvE,wBAAmB,GAAG,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;YAC7D,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;YACjE,sBAAiB,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC;YACzD,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;YACjD,2BAAsB,GAAG,IAAI,CAAC,eAAe,CAAC,mBAAmB,CAAC,CAAC;YACnE,yBAAoB,GAAG,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC;YAC/D,6BAAwB,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC;YACvE,iBAAY,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;YAC/C,yBAAoB,GAAG,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC;YAC/D,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;YACjE,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;YACjE,qBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;YACvD,uBAAkB,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;YAC3D,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;YACjE,qBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;YACvD,uBAAkB,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;YAC3D,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;YACjE,4BAAuB,GAAG,IAAI,CAAC,eAAe,CAAC,oBAAoB,CAAC,CAAC;YACrE,8BAAyB,GAAG,IAAI,CAAC,eAAe,CAAC,sBAAsB,CAAC,CAAC;YACzE,eAAU,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;YAC3C,uBAAkB,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;YAC3D,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;YACjD,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;YAGnD,uBAAkB,GAAG,CAAC,CAAC;YACvB,wBAAmB,GAAG,CAAC,CAAC;SAI+B;;;;;QAE/D,yCAAW;;;;YAAX,UAAY,OAAsB;gBAAlC,iBAMC;;oBALO,MAAM,GAAG,YAAY,CAAC,EAAE,CAAC,OAAO,CAAC;gBACvC,MAAM,CAAC,gBAAgB,CAAM,SAAS,CAAC,CAAC,SAAS,CAAC,UAAA,GAAG,IAAI,OAAA,KAAI,CAAC,eAAe,CAAC,GAAG,CAAC,GAAA,CAAC,CAAC;gBACpF,MAAM,CAAC,gBAAgB,CAAM,OAAO,CAAC,CAAC,SAAS,CAAC,UAAA,GAAG,IAAI,OAAA,KAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAA,CAAC,CAAC;gBAC5E,MAAM,CAAC,GAAG,CAAU,SAAS,CAAC,CAAC,SAAS,CAAC,UAAA,CAAC,IAAI,OAAA,KAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,GAAA,CAAC,CAAC;gBACvE,MAAM,CAAC,QAAQ,CAAS,OAAO,CAAC,CAAC,SAAS,CAAC,cAAM,OAAA,KAAI,CAAC,YAAY,EAAE,GAAA,CAAC,CAAC;aACvE;;;;QAED,sCAAQ;;;YAAR;gBAAA,iBASC;gBARC,IAAI,CAAC,SAAS,GAAGC,cAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,IAAI,CAACC,sBAAY,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;oBAC5E,IAAI,KAAI,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,KAAK,KAAI,CAAC,kBAAkB,EAAE;wBACpE,KAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC,UAAU,CAAC;wBAC5C,KAAI,CAAC,kBAAkB,GAAG,KAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC;wBAC5D,KAAI,CAAC,mBAAmB,GAAG,KAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY,CAAC;wBAC9D,KAAI,CAAC,MAAM,EAAE,CAAC;qBACf;iBACF,CAAC,CAAC;aACJ;;;;QAED,yCAAW;;;YAAX;gBACE,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;gBAC7B,IAAI,CAAC,OAAO,EAAE,CAAC;aAChB;;;;QAED,uCAAS;;;YAAT;;gBAEE,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,EAAE;;wBAC3B,WAAW,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW;;wBAC/C,YAAY,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY;oBAEvD,IAAI,IAAI,CAAC,kBAAkB,KAAK,WAAW,IAAI,IAAI,CAAC,mBAAmB,KAAK,YAAY,EAAE;wBACxF,IAAI,CAAC,kBAAkB,GAAG,WAAW,CAAC;wBACtC,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC;wBACxC,IAAI,CAAC,MAAM,EAAE,CAAC;qBACf;iBACF;aACF;;;;QAED,6CAAe;;;YAAf;gBAAA,iBAEC;gBADC,UAAU,CAAC,cAAM,OAAA,KAAI,CAAC,SAAS,EAAE,GAAA,CAAC,CAAC;aACpC;;;;QAEO,qCAAO;;;YAAf;gBACE,IAAI,IAAI,CAAC,KAAK,EAAE;oBACd,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;oBACrB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;iBACnB;aACF;;;;QAEO,oCAAM;;;YAAd;gBACE,IAAI,IAAI,CAAC,KAAK,EAAE;oBACd,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;iBACrB;aACF;;;;;QAEO,2CAAa;;;;YAArB,UAAsB,OAAgB;gBACpC,IAAI,IAAI,CAAC,KAAK,EAAE;oBACd,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;iBACjG;aACF;;;;;;QAEO,uCAAS;;;;;YAAjB,UAAkB,MAAW,EAAE,IAAU;gBACvC,IAAI,IAAI,CAAC,KAAK,EAAE;oBACd,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;iBACpC;aACF;;;;QAEO,0CAAY;;;YAApB;gBACE,IAAI,CAAC,OAAO,EAAE,CAAC;gBACf,IAAI,CAAC,SAAS,EAAE,CAAC;aAClB;;;;QAEO,yCAAW;;;YAAnB;gBAAA,iBAeC;gBAdC,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC,UAAU,CAAC;gBAC5C,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC;gBAC5D,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY,CAAC;;oBACxD,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa;gBAEjC,IAAI,MAAM,IAAI,MAAM,CAAC,gBAAgB,EAAE;;wBAC/B,IAAI,GAAG,MAAM,CAAC,gBAAgB,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,gBAAgB,CAAC,QAAQ,CAAC;oBAC1E,IAAI,CAAC,CAAC,IAAI,IAAI,IAAI,KAAK,KAAK;yBACzB,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,IAAI,GAAG,CAAC,KAAK,CAAC,MAAM,KAAK,KAAK,CAAC,EAAE;wBACnD,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,OAAO,CAAC;qBAC5B;iBACF;gBAED,OAAO,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,cAAM,OAAAC,YAAI,CAAC,GAAG,EAAE,KAAI,CAAC,KAAK,EAAE,KAAI,CAAC,QAAQ,CAAC,GAAA,CAAC,CAAC;aAClF;;;;QAEO,uCAAS;;;YAAjB;gBACE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBAEnC,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE;oBAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBAC5B;aACF;;;;;QAEO,6CAAe;;;;YAAvB,UAAwB,GAAiB;gBACvC,IAAI,GAAG,EAAE;oBACP,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;wBACf,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;wBAChC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;qBACjC;oBAED,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;iBAC1C;aACF;;;;;;;;;;QAIO,6CAAe;;;;;;;;YAAvB,UAA2B,SAAiB;gBAA5C,iBAOC;gBANC,0BAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CACxBC,mBAAS,CAAC,UAAC,KAAc;oBAAK,OAAA,IAAIC,eAAU,CAAC,UAAA,QAAQ;wBACnD,KAAK,CAAC,EAAE,CAAC,SAAS,EAAE,UAAC,IAAO,IAAK,OAAA,KAAI,CAAC,MAAM,CAAC,GAAG,CAAC,cAAM,OAAA,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAA,CAAC,GAAA,CAAC,CAAC;wBAC7E,OAAO,IAAI,CAAC;qBACb,CAAC;iBAAA,CAAC,CACJ,GAAoB;aACtB;;oBAxLFC,cAAS,SAAC;wBACT,QAAQ,EAAE,oBAAoB;qBAC/B;;;;;wBAR2CC,eAAU;wBAAuBC,WAAM;;;;8BAUhFC,UAAK;4BACLA,UAAK;8BACLA,UAAK;+BACLA,UAAK;4BAMLA,UAAK;iCACLA,UAAK;kCACLA,UAAK;kCACLA,UAAK;yCACLA,UAAK;gCAGLC,WAAM;iCAGNA,WAAM;oCACNA,WAAM;qCACNA,WAAM;qCACNA,WAAM;mCACNA,WAAM;qCACNA,WAAM;oCACNA,WAAM;qCACNA,WAAM;uCACNA,WAAM;+CAGNA,WAAM;0CACNA,WAAM;4CACNA,WAAM;wCACNA,WAAM;oCACNA,WAAM;6CACNA,WAAM;2CACNA,WAAM;+CACNA,WAAM;mCACNA,WAAM;2CACNA,WAAM;4CACNA,WAAM;4CACNA,WAAM;uCACNA,WAAM;yCACNA,WAAM;4CACNA,WAAM;uCACNA,WAAM;yCACNA,WAAM;4CACNA,WAAM;8CACNA,WAAM;gDACNA,WAAM;iCACNA,WAAM;yCACNA,WAAM;oCACNA,WAAM;oCACNA,WAAM;;QAiIT,0BAAC;KA1LD;;;;;;ACNA;QAGA;SASiC;;oBAThCC,aAAQ,SAAC;wBACR,OAAO,EAAE,EAAE;wBACX,YAAY,EAAE;4BACZ,mBAAmB;yBACpB;wBACD,OAAO,EAAE;4BACP,mBAAmB;yBACpB;qBACF;;QAC+B,uBAAC;KATjC;;;;;;;;;;;;;;;;;;;;;;;"}

@@ -1,2 +0,2 @@

!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("rxjs"),require("@angular/core"),require("rxjs/operators"),require("echarts")):"function"==typeof define&&define.amd?define("ngx-echarts",["exports","rxjs","@angular/core","rxjs/operators","echarts"],e):e(t["ngx-echarts"]={},t.rxjs,t.ng.core,t.rxjs.operators,t.echarts)}(this,function(t,n,r,i,s){"use strict";var o=function(){function e(t){this._changes=t}return e.of=function(t){return new e(t)},e.prototype.notEmpty=function(t){if(this._changes[t]){var e=this._changes[t].currentValue;if(e!==undefined&&null!==e)return n.of(e)}return n.empty()},e.prototype.has=function(t){if(this._changes[t]){var e=this._changes[t].currentValue;return n.of(e)}return n.empty()},e.prototype.notFirst=function(t){if(this._changes[t]&&!this._changes[t].isFirstChange()){var e=this._changes[t].currentValue;return n.of(e)}return n.empty()},e.prototype.notFirstAndEmpty=function(t){if(this._changes[t]&&!this._changes[t].isFirstChange()){var e=this._changes[t].currentValue;if(e!==undefined&&null!==e)return n.of(e)}return n.empty()},e}(),h=function(){function t(){}return t.All=[t.Click="click",t.DblClick="dblclick",t.MouseDown="mousedown",t.MouseUp="mouseup",t.MouseOver="mouseover",t.MouseOut="mouseout",t.GlobalOut="globalout",t.ContextMenu="contextmenu",t.DataZoom="datazoom",t.MapSelectChanged="mapselectchanged",t.MapSelected="mapselected",t.MapUnselected="mapunselected"],t}(),e=function(){function t(t,e){this.el=t,this._ngZone=e,this.autoResize=!0,this.loadingType="default",this.detectEventChanges=!0,this.chartInit=new r.EventEmitter,this.chartClick=new r.EventEmitter,this.chartDblClick=new r.EventEmitter,this.chartMouseDown=new r.EventEmitter,this.chartMouseUp=new r.EventEmitter,this.chartMouseOver=new r.EventEmitter,this.chartMouseOut=new r.EventEmitter,this.chartGlobalOut=new r.EventEmitter,this.chartContextMenu=new r.EventEmitter,this.chartDataZoom=new r.EventEmitter,this.chartMapSelectChanged=new r.EventEmitter,this.chartMapSelected=new r.EventEmitter,this.chartMapUnselected=new r.EventEmitter,this.currentOffsetWidth=0,this.currentOffsetHeight=0,this._resize$=new n.Subject}return t.prototype.createChart=function(){var t=this;this.currentWindowWidth=window.innerWidth,this.currentOffsetWidth=this.el.nativeElement.offsetWidth,this.currentOffsetHeight=this.el.nativeElement.offsetHeight;var e=this.el.nativeElement;if(window&&window.getComputedStyle){var n=window.getComputedStyle(e,null).getPropertyValue("height");n&&"0px"!==n||e.style.height&&"0px"!==e.style.height||(e.style.height="400px")}return this._ngZone.runOutsideAngular(function(){return s.init(e,t.theme||undefined,t.initOpts||undefined)})},t.prototype.onWindowResize=function(t){var e=t.target;this.autoResize&&e.innerWidth!==this.currentWindowWidth&&(this.currentWindowWidth=e.innerWidth,this.currentOffsetWidth=this.el.nativeElement.offsetWidth,this.currentOffsetHeight=this.el.nativeElement.offsetHeight,this._resize$.next())},t.prototype.ngOnChanges=function(t){var e=this,n=o.of(t);n.notFirstAndEmpty("options").subscribe(function(t){return e.onOptionsChange(t)}),n.notFirstAndEmpty("merge").subscribe(function(t){return e.setOption(t)}),n.has("loading").subscribe(function(t){return e.toggleLoading(!!t)}),n.notFirst("detectEventChanges").subscribe(function(t){return e.toggleEventDetectors(!!t)}),n.notFirst("theme").subscribe(function(){return e.refreshChart()})},t.prototype.ngOnDestroy=function(){this._resizeSub&&(this._resizeSub.unsubscribe(),this._resizeSub=null),this._chart&&(this._chart.dispose(),this._chart=null)},t.prototype.ngDoCheck=function(){if(this._chart&&this.autoResize){var t=this.el.nativeElement.offsetWidth,e=this.el.nativeElement.offsetHeight;this.currentOffsetWidth===t&&this.currentOffsetHeight===e||(this.currentOffsetWidth=t,this.currentOffsetHeight=e,this._resize$.next())}},t.prototype.ngAfterViewInit=function(){var t=this;setTimeout(function(){return t.initChart()})},t.prototype.initChart=function(){this.onOptionsChange(this.options),this.merge&&this._chart&&this.setOption(this.merge)},t.prototype.onOptionsChange=function(t){var e=this;t&&(this._chart||(this._chart=this.createChart(),this._resizeSub=this._resize$.pipe(i.debounceTime(50)).subscribe(function(){e._chart&&e._chart.resize()}),this.chartInit.emit(this._chart),this.detectEventChanges&&this.registerEvents()),this._chart.setOption(this.options,!0))},t.prototype.registerEvents=function(){if(this._chart)for(var t=h.All,e=0,n=t.length;e<n;e++)this._chart.on(t[e],this.eventHandler,this)},t.prototype.unregisterEvents=function(){if(this._chart)for(var t=h.All,e=0,n=t.length;e<n;e++)this._chart.off(t[e],this.eventHandler)},t.prototype.clear=function(){this._chart&&this._chart.clear()},t.prototype.toggleLoading=function(t){this._chart&&(t?this._chart.showLoading(this.loadingType,this.loadingOpts):this._chart.hideLoading())},t.prototype.setOption=function(t,e){this._chart&&this._chart.setOption(t,e)},t.prototype.eventHandler=function(t){var e=this;switch(t.type){case h.Click:this._ngZone.run(function(){return e.chartClick.emit(t)});break;case h.DblClick:this._ngZone.run(function(){return e.chartDblClick.emit(t)});break;case h.MouseDown:this._ngZone.run(function(){return e.chartMouseDown.emit(t)});break;case h.MouseUp:this._ngZone.run(function(){return e.chartMouseUp.emit(t)});break;case h.MouseOver:this._ngZone.run(function(){return e.chartMouseOver.emit(t)});break;case h.MouseOut:this._ngZone.run(function(){return e.chartMouseOut.emit(t)});break;case h.GlobalOut:this._ngZone.run(function(){return e.chartGlobalOut.emit(t)});break;case h.ContextMenu:this._ngZone.run(function(){return e.chartContextMenu.emit(t)});break;case h.DataZoom:this._ngZone.run(function(){return e.chartDataZoom.emit(t)});break;case h.MapSelectChanged:this._ngZone.run(function(){return e.chartMapSelectChanged.emit(t)});break;case h.MapSelected:this._ngZone.run(function(){return e.chartMapSelected.emit(t)});break;case h.MapUnselected:this._ngZone.run(function(){return e.chartMapUnselected.emit(t)})}},t.prototype.toggleEventDetectors=function(t){this._chart&&(t?this.registerEvents():this.unregisterEvents())},t.prototype.refreshChart=function(){this.ngOnDestroy(),this.initChart()},t.decorators=[{type:r.Directive,args:[{selector:"echarts, [echarts]"}]}],t.ctorParameters=function(){return[{type:r.ElementRef},{type:r.NgZone}]},t.propDecorators={options:[{type:r.Input}],theme:[{type:r.Input}],loading:[{type:r.Input}],initOpts:[{type:r.Input}],merge:[{type:r.Input}],autoResize:[{type:r.Input}],loadingType:[{type:r.Input}],loadingOpts:[{type:r.Input}],detectEventChanges:[{type:r.Input}],chartInit:[{type:r.Output}],chartClick:[{type:r.Output}],chartDblClick:[{type:r.Output}],chartMouseDown:[{type:r.Output}],chartMouseUp:[{type:r.Output}],chartMouseOver:[{type:r.Output}],chartMouseOut:[{type:r.Output}],chartGlobalOut:[{type:r.Output}],chartContextMenu:[{type:r.Output}],chartDataZoom:[{type:r.Output}],chartMapSelectChanged:[{type:r.Output}],chartMapSelected:[{type:r.Output}],chartMapUnselected:[{type:r.Output}],onWindowResize:[{type:r.HostListener,args:["window:resize",["$event"]]}]},t}(),u=function(){function t(){}return t.decorators=[{type:r.NgModule,args:[{imports:[],declarations:[e],exports:[e]}]}],t}();t.NgxEchartsModule=u,t.ɵa=e,Object.defineProperty(t,"__esModule",{value:!0})});
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("rxjs"),require("@angular/core"),require("echarts"),require("rxjs/operators")):"function"==typeof define&&define.amd?define("ngx-echarts",["exports","rxjs","@angular/core","echarts","rxjs/operators"],e):e(t["ngx-echarts"]={},t.rxjs,t.ng.core,t.echarts,t.rxjs.operators)}(this,function(t,r,n,i,e){"use strict";var h=function(){function e(t){this._changes=t}return e.of=function(t){return new e(t)},e.prototype.notEmpty=function(t){if(this._changes[t]){var e=this._changes[t].currentValue;if(e!==undefined&&null!==e)return r.of(e)}return r.empty()},e.prototype.has=function(t){if(this._changes[t]){var e=this._changes[t].currentValue;return r.of(e)}return r.empty()},e.prototype.notFirst=function(t){if(this._changes[t]&&!this._changes[t].isFirstChange()){var e=this._changes[t].currentValue;return r.of(e)}return r.empty()},e.prototype.notFirstAndEmpty=function(t){if(this._changes[t]&&!this._changes[t].isFirstChange()){var e=this._changes[t].currentValue;if(e!==undefined&&null!==e)return r.of(e)}return r.empty()},e}(),a=function(){function t(t,e){this.el=t,this.ngZone=e,this.autoResize=!0,this.loadingType="default",this.detectEventChanges=!0,this.chartInit=new n.EventEmitter,this.chartClick=this.createLazyEvent("click"),this.chartDblClick=this.createLazyEvent("dblclick"),this.chartMouseDown=this.createLazyEvent("mousedown"),this.chartMouseMove=this.createLazyEvent("mousemove"),this.chartMouseUp=this.createLazyEvent("mouseup"),this.chartMouseOver=this.createLazyEvent("mouseover"),this.chartMouseOut=this.createLazyEvent("mouseout"),this.chartGlobalOut=this.createLazyEvent("globalout"),this.chartContextMenu=this.createLazyEvent("contextmenu"),this.chartLegendSelectChanged=this.createLazyEvent("legendselectchanged"),this.chartLegendSelected=this.createLazyEvent("legendselected"),this.chartLegendUnselected=this.createLazyEvent("legendunselected"),this.chartLegendScroll=this.createLazyEvent("legendscroll"),this.chartDataZoom=this.createLazyEvent("datazoom"),this.chartDataRangeSelected=this.createLazyEvent("datarangeselected"),this.chartTimelineChanged=this.createLazyEvent("timelinechanged"),this.chartTimelinePlayChanged=this.createLazyEvent("timelineplaychanged"),this.chartRestore=this.createLazyEvent("restore"),this.chartDataViewChanged=this.createLazyEvent("dataviewchanged"),this.chartMagicTypeChanged=this.createLazyEvent("magictypechanged"),this.chartPieSelectChanged=this.createLazyEvent("pieselectchanged"),this.chartPieSelected=this.createLazyEvent("pieselected"),this.chartPieUnselected=this.createLazyEvent("pieunselected"),this.chartMapSelectChanged=this.createLazyEvent("mapselectchanged"),this.chartMapSelected=this.createLazyEvent("mapselected"),this.chartMapUnselected=this.createLazyEvent("mapunselected"),this.chartAxisAreaSelected=this.createLazyEvent("axisareaselected"),this.chartFocusNodeAdjacency=this.createLazyEvent("focusnodeadjacency"),this.chartUnfocusNodeAdjacency=this.createLazyEvent("unfocusnodeadjacency"),this.chartBrush=this.createLazyEvent("brush"),this.chartBrushSelected=this.createLazyEvent("brushselected"),this.chartRendered=this.createLazyEvent("rendered"),this.chartFinished=this.createLazyEvent("finished"),this.currentOffsetWidth=0,this.currentOffsetHeight=0}return t.prototype.ngOnChanges=function(t){var e=this,n=h.of(t);n.notFirstAndEmpty("options").subscribe(function(t){return e.onOptionsChange(t)}),n.notFirstAndEmpty("merge").subscribe(function(t){return e.setOption(t)}),n.has("loading").subscribe(function(t){return e.toggleLoading(!!t)}),n.notFirst("theme").subscribe(function(){return e.refreshChart()})},t.prototype.ngOnInit=function(){var t=this;this.resizeSub=r.fromEvent(window,"resize").pipe(e.debounceTime(50)).subscribe(function(){t.autoResize&&window.innerWidth!==t.currentWindowWidth&&(t.currentWindowWidth=window.innerWidth,t.currentOffsetWidth=t.el.nativeElement.offsetWidth,t.currentOffsetHeight=t.el.nativeElement.offsetHeight,t.resize())})},t.prototype.ngOnDestroy=function(){this.resizeSub.unsubscribe(),this.dispose()},t.prototype.ngDoCheck=function(){if(this.chart&&this.autoResize){var t=this.el.nativeElement.offsetWidth,e=this.el.nativeElement.offsetHeight;this.currentOffsetWidth===t&&this.currentOffsetHeight===e||(this.currentOffsetWidth=t,this.currentOffsetHeight=e,this.resize())}},t.prototype.ngAfterViewInit=function(){var t=this;setTimeout(function(){return t.initChart()})},t.prototype.dispose=function(){this.chart&&(this.chart.dispose(),this.chart=null)},t.prototype.resize=function(){this.chart&&this.chart.resize()},t.prototype.toggleLoading=function(t){this.chart&&(t?this.chart.showLoading(this.loadingType,this.loadingOpts):this.chart.hideLoading())},t.prototype.setOption=function(t,e){this.chart&&this.chart.setOption(t,e)},t.prototype.refreshChart=function(){this.dispose(),this.initChart()},t.prototype.createChart=function(){var t=this;this.currentWindowWidth=window.innerWidth,this.currentOffsetWidth=this.el.nativeElement.offsetWidth,this.currentOffsetHeight=this.el.nativeElement.offsetHeight;var e=this.el.nativeElement;if(window&&window.getComputedStyle){var n=window.getComputedStyle(e,null).getPropertyValue("height");n&&"0px"!==n||e.style.height&&"0px"!==e.style.height||(e.style.height="400px")}return this.ngZone.runOutsideAngular(function(){return i.init(e,t.theme,t.initOpts)})},t.prototype.initChart=function(){this.onOptionsChange(this.options),this.merge&&this.chart&&this.setOption(this.merge)},t.prototype.onOptionsChange=function(t){t&&(this.chart||(this.chart=this.createChart(),this.chartInit.emit(this.chart)),this.chart.setOption(this.options,!0))},t.prototype.createLazyEvent=function(n){var i=this;return this.chartInit.pipe(e.switchMap(function(t){return new r.Observable(function(e){return t.on(n,function(t){return i.ngZone.run(function(){return e.next(t)})}),null})}))},t.decorators=[{type:n.Directive,args:[{selector:"echarts, [echarts]"}]}],t.ctorParameters=function(){return[{type:n.ElementRef},{type:n.NgZone}]},t.propDecorators={options:[{type:n.Input}],theme:[{type:n.Input}],loading:[{type:n.Input}],initOpts:[{type:n.Input}],merge:[{type:n.Input}],autoResize:[{type:n.Input}],loadingType:[{type:n.Input}],loadingOpts:[{type:n.Input}],detectEventChanges:[{type:n.Input}],chartInit:[{type:n.Output}],chartClick:[{type:n.Output}],chartDblClick:[{type:n.Output}],chartMouseDown:[{type:n.Output}],chartMouseMove:[{type:n.Output}],chartMouseUp:[{type:n.Output}],chartMouseOver:[{type:n.Output}],chartMouseOut:[{type:n.Output}],chartGlobalOut:[{type:n.Output}],chartContextMenu:[{type:n.Output}],chartLegendSelectChanged:[{type:n.Output}],chartLegendSelected:[{type:n.Output}],chartLegendUnselected:[{type:n.Output}],chartLegendScroll:[{type:n.Output}],chartDataZoom:[{type:n.Output}],chartDataRangeSelected:[{type:n.Output}],chartTimelineChanged:[{type:n.Output}],chartTimelinePlayChanged:[{type:n.Output}],chartRestore:[{type:n.Output}],chartDataViewChanged:[{type:n.Output}],chartMagicTypeChanged:[{type:n.Output}],chartPieSelectChanged:[{type:n.Output}],chartPieSelected:[{type:n.Output}],chartPieUnselected:[{type:n.Output}],chartMapSelectChanged:[{type:n.Output}],chartMapSelected:[{type:n.Output}],chartMapUnselected:[{type:n.Output}],chartAxisAreaSelected:[{type:n.Output}],chartFocusNodeAdjacency:[{type:n.Output}],chartUnfocusNodeAdjacency:[{type:n.Output}],chartBrush:[{type:n.Output}],chartBrushSelected:[{type:n.Output}],chartRendered:[{type:n.Output}],chartFinished:[{type:n.Output}]},t}(),s=function(){function t(){}return t.decorators=[{type:n.NgModule,args:[{imports:[],declarations:[a],exports:[a]}]}],t}();t.NgxEchartsModule=s,t.ɵa=a,Object.defineProperty(t,"__esModule",{value:!0})});
//# sourceMappingURL=ngx-echarts.umd.min.js.map

@@ -5,75 +5,60 @@ /**

*/
import { Directive, ElementRef, Input, Output, HostListener, EventEmitter, NgZone } from '@angular/core';
import { Directive, ElementRef, EventEmitter, Input, NgZone, Output } from '@angular/core';
import { EChartOption, init } from 'echarts';
import { fromEvent, Observable } from 'rxjs';
import { debounceTime, switchMap } from 'rxjs/operators';
import { ChangeFilter } from './change-filter';
import { Subject } from 'rxjs';
import { debounceTime } from 'rxjs/operators';
import { init, EChartOption } from 'echarts';
import { EChartEvents } from './echart-events';
export class NgxEchartsDirective {
/**
* @param {?} el
* @param {?} _ngZone
* @param {?} ngZone
*/
constructor(el, _ngZone) {
constructor(el, ngZone) {
this.el = el;
this._ngZone = _ngZone;
this.ngZone = ngZone;
this.autoResize = true;
this.loadingType = 'default';
/**
* Whether to register event handlers on echartInstance. Default is true.
* Use it to avoid unwanted change detection, if you want to optimize the performance.
*/
this.detectEventChanges = true;
// chart events:
this.detectEventChanges = true; // deprecated, left for compatibility reasons to avoid triggering major version
// deprecated, left for compatibility reasons to avoid triggering major version
// ngx-echarts events
this.chartInit = new EventEmitter();
this.chartClick = new EventEmitter();
this.chartDblClick = new EventEmitter();
this.chartMouseDown = new EventEmitter();
this.chartMouseUp = new EventEmitter();
this.chartMouseOver = new EventEmitter();
this.chartMouseOut = new EventEmitter();
this.chartGlobalOut = new EventEmitter();
this.chartContextMenu = new EventEmitter();
this.chartDataZoom = new EventEmitter();
this.chartMapSelectChanged = new EventEmitter();
this.chartMapSelected = new EventEmitter();
this.chartMapUnselected = new EventEmitter();
// echarts mouse events
this.chartClick = this.createLazyEvent('click');
this.chartDblClick = this.createLazyEvent('dblclick');
this.chartMouseDown = this.createLazyEvent('mousedown');
this.chartMouseMove = this.createLazyEvent('mousemove');
this.chartMouseUp = this.createLazyEvent('mouseup');
this.chartMouseOver = this.createLazyEvent('mouseover');
this.chartMouseOut = this.createLazyEvent('mouseout');
this.chartGlobalOut = this.createLazyEvent('globalout');
this.chartContextMenu = this.createLazyEvent('contextmenu');
// echarts mouse events
this.chartLegendSelectChanged = this.createLazyEvent('legendselectchanged');
this.chartLegendSelected = this.createLazyEvent('legendselected');
this.chartLegendUnselected = this.createLazyEvent('legendunselected');
this.chartLegendScroll = this.createLazyEvent('legendscroll');
this.chartDataZoom = this.createLazyEvent('datazoom');
this.chartDataRangeSelected = this.createLazyEvent('datarangeselected');
this.chartTimelineChanged = this.createLazyEvent('timelinechanged');
this.chartTimelinePlayChanged = this.createLazyEvent('timelineplaychanged');
this.chartRestore = this.createLazyEvent('restore');
this.chartDataViewChanged = this.createLazyEvent('dataviewchanged');
this.chartMagicTypeChanged = this.createLazyEvent('magictypechanged');
this.chartPieSelectChanged = this.createLazyEvent('pieselectchanged');
this.chartPieSelected = this.createLazyEvent('pieselected');
this.chartPieUnselected = this.createLazyEvent('pieunselected');
this.chartMapSelectChanged = this.createLazyEvent('mapselectchanged');
this.chartMapSelected = this.createLazyEvent('mapselected');
this.chartMapUnselected = this.createLazyEvent('mapunselected');
this.chartAxisAreaSelected = this.createLazyEvent('axisareaselected');
this.chartFocusNodeAdjacency = this.createLazyEvent('focusnodeadjacency');
this.chartUnfocusNodeAdjacency = this.createLazyEvent('unfocusnodeadjacency');
this.chartBrush = this.createLazyEvent('brush');
this.chartBrushSelected = this.createLazyEvent('brushselected');
this.chartRendered = this.createLazyEvent('rendered');
this.chartFinished = this.createLazyEvent('finished');
this.currentOffsetWidth = 0;
this.currentOffsetHeight = 0;
this._resize$ = new Subject();
}
/**
* @return {?}
*/
createChart() {
this.currentWindowWidth = window.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
/** @type {?} */
const dom = this.el.nativeElement;
if (window && window.getComputedStyle) {
/** @type {?} */
const prop = window.getComputedStyle(dom, null).getPropertyValue('height');
if ((!prop || prop === '0px') &&
(!dom.style.height || dom.style.height === '0px')) {
dom.style.height = '400px';
}
}
return this._ngZone.runOutsideAngular(() => init(dom, this.theme || undefined, this.initOpts || undefined));
}
/**
* @param {?} event
* @return {?}
*/
onWindowResize(event) {
/** @type {?} */
const target = (/** @type {?} */ (event.target));
if (this.autoResize && target.innerWidth !== this.currentWindowWidth) {
this.currentWindowWidth = target.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
this._resize$.next();
}
}
/**
* @param {?} changes

@@ -88,3 +73,2 @@ * @return {?}

filter.has('loading').subscribe(v => this.toggleLoading(!!v));
filter.notFirst('detectEventChanges').subscribe(v => this.toggleEventDetectors(!!v));
filter.notFirst('theme').subscribe(() => this.refreshChart());

@@ -95,11 +79,18 @@ }

*/
ngOnInit() {
this.resizeSub = fromEvent(window, 'resize').pipe(debounceTime(50)).subscribe(() => {
if (this.autoResize && window.innerWidth !== this.currentWindowWidth) {
this.currentWindowWidth = window.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
this.resize();
}
});
}
/**
* @return {?}
*/
ngOnDestroy() {
if (this._resizeSub) {
this._resizeSub.unsubscribe();
this._resizeSub = null;
}
if (this._chart) {
this._chart.dispose();
this._chart = null;
}
this.resizeSub.unsubscribe();
this.dispose();
}

@@ -111,3 +102,3 @@ /**

// No heavy work in DoCheck!
if (this._chart && this.autoResize) {
if (this.chart && this.autoResize) {
/** @type {?} */

@@ -120,3 +111,3 @@ const offsetWidth = this.el.nativeElement.offsetWidth;

this.currentOffsetHeight = offsetHeight;
this._resize$.next();
this.resize();
}

@@ -134,54 +125,33 @@ }

*/
initChart() {
this.onOptionsChange(this.options);
if (this.merge && this._chart) {
this.setOption(this.merge);
dispose() {
if (this.chart) {
this.chart.dispose();
this.chart = null;
}
}
/**
* @param {?} opt
* @return {?}
*/
onOptionsChange(opt) {
if (opt) {
if (!this._chart) {
this._chart = this.createChart();
// subscribe to _resize$ and debounced
this._resizeSub = this._resize$.pipe(debounceTime(50)).subscribe(() => {
if (this._chart) {
this._chart.resize();
}
});
// output echart instance:
this.chartInit.emit(this._chart);
// register events:
if (this.detectEventChanges) {
this.registerEvents();
}
}
this._chart.setOption(this.options, true);
resize() {
if (this.chart) {
this.chart.resize();
}
}
/**
* @param {?} loading
* @return {?}
*/
registerEvents() {
if (this._chart) {
/** @type {?} */
const events = EChartEvents.All;
for (let i = 0, len = events.length; i < len; i++) {
this._chart.on(events[i], this.eventHandler, this);
}
toggleLoading(loading) {
if (this.chart) {
loading ? this.chart.showLoading(this.loadingType, this.loadingOpts) : this.chart.hideLoading();
}
}
/**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
unregisterEvents() {
if (this._chart) {
/** @type {?} */
const events = EChartEvents.All;
for (let i = 0, len = events.length; i < len; i++) {
this._chart.off(events[i], this.eventHandler);
}
setOption(option, opts) {
if (this.chart) {
this.chart.setOption(option, opts);
}

@@ -192,86 +162,60 @@ }

*/
clear() {
if (this._chart) {
this._chart.clear();
}
refreshChart() {
this.dispose();
this.initChart();
}
/**
* @param {?} loading
* @return {?}
*/
toggleLoading(loading) {
if (this._chart) {
loading ? this._chart.showLoading(this.loadingType, this.loadingOpts) : this._chart.hideLoading();
createChart() {
this.currentWindowWidth = window.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
/** @type {?} */
const dom = this.el.nativeElement;
if (window && window.getComputedStyle) {
/** @type {?} */
const prop = window.getComputedStyle(dom, null).getPropertyValue('height');
if ((!prop || prop === '0px') &&
(!dom.style.height || dom.style.height === '0px')) {
dom.style.height = '400px';
}
}
return this.ngZone.runOutsideAngular(() => init(dom, this.theme, this.initOpts));
}
/**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
setOption(option, opts) {
if (this._chart) {
this._chart.setOption(option, opts);
initChart() {
this.onOptionsChange(this.options);
if (this.merge && this.chart) {
this.setOption(this.merge);
}
}
/**
* @param {?} event
* @param {?} opt
* @return {?}
*/
eventHandler(event) {
switch (event.type) {
case EChartEvents.Click:
this._ngZone.run(() => this.chartClick.emit(event));
break;
case EChartEvents.DblClick:
this._ngZone.run(() => this.chartDblClick.emit(event));
break;
case EChartEvents.MouseDown:
this._ngZone.run(() => this.chartMouseDown.emit(event));
break;
case EChartEvents.MouseUp:
this._ngZone.run(() => this.chartMouseUp.emit(event));
break;
case EChartEvents.MouseOver:
this._ngZone.run(() => this.chartMouseOver.emit(event));
break;
case EChartEvents.MouseOut:
this._ngZone.run(() => this.chartMouseOut.emit(event));
break;
case EChartEvents.GlobalOut:
this._ngZone.run(() => this.chartGlobalOut.emit(event));
break;
case EChartEvents.ContextMenu:
this._ngZone.run(() => this.chartContextMenu.emit(event));
break;
case EChartEvents.DataZoom:
this._ngZone.run(() => this.chartDataZoom.emit(event));
break;
case EChartEvents.MapSelectChanged:
this._ngZone.run(() => this.chartMapSelectChanged.emit(event));
break;
case EChartEvents.MapSelected:
this._ngZone.run(() => this.chartMapSelected.emit(event));
break;
case EChartEvents.MapUnselected:
this._ngZone.run(() => this.chartMapUnselected.emit(event));
break;
onOptionsChange(opt) {
if (opt) {
if (!this.chart) {
this.chart = this.createChart();
this.chartInit.emit(this.chart);
}
this.chart.setOption(this.options, true);
}
}
// allows to lazily bind to only those events that are requested through the `@Output` by parent components
// see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info
/**
* @param {?} detect
* @template T
* @param {?} eventName
* @return {?}
*/
toggleEventDetectors(detect) {
if (this._chart) {
detect ? this.registerEvents() : this.unregisterEvents();
}
createLazyEvent(eventName) {
return (/** @type {?} */ (this.chartInit.pipe(switchMap((chart) => new Observable(observer => {
chart.on(eventName, (data) => this.ngZone.run(() => observer.next(data)));
return null; // no need to react on unsubscribe as long as the `dispose()` is called in ngOnDestroy
})))));
}
/**
* @return {?}
*/
refreshChart() {
this.ngOnDestroy();
this.initChart();
}
}

@@ -302,2 +246,3 @@ NgxEchartsDirective.decorators = [

chartMouseDown: [{ type: Output }],
chartMouseMove: [{ type: Output }],
chartMouseUp: [{ type: Output }],

@@ -308,7 +253,26 @@ chartMouseOver: [{ type: Output }],

chartContextMenu: [{ type: Output }],
chartLegendSelectChanged: [{ type: Output }],
chartLegendSelected: [{ type: Output }],
chartLegendUnselected: [{ type: Output }],
chartLegendScroll: [{ type: Output }],
chartDataZoom: [{ type: Output }],
chartDataRangeSelected: [{ type: Output }],
chartTimelineChanged: [{ type: Output }],
chartTimelinePlayChanged: [{ type: Output }],
chartRestore: [{ type: Output }],
chartDataViewChanged: [{ type: Output }],
chartMagicTypeChanged: [{ type: Output }],
chartPieSelectChanged: [{ type: Output }],
chartPieSelected: [{ type: Output }],
chartPieUnselected: [{ type: Output }],
chartMapSelectChanged: [{ type: Output }],
chartMapSelected: [{ type: Output }],
chartMapUnselected: [{ type: Output }],
onWindowResize: [{ type: HostListener, args: ['window:resize', ['$event'],] }]
chartAxisAreaSelected: [{ type: Output }],
chartFocusNodeAdjacency: [{ type: Output }],
chartUnfocusNodeAdjacency: [{ type: Output }],
chartBrush: [{ type: Output }],
chartBrushSelected: [{ type: Output }],
chartRendered: [{ type: Output }],
chartFinished: [{ type: Output }]
};

@@ -332,7 +296,3 @@ if (false) {

NgxEchartsDirective.prototype.loadingOpts;
/**
* Whether to register event handlers on echartInstance. Default is true.
* Use it to avoid unwanted change detection, if you want to optimize the performance.
* @type {?}
*/
/** @type {?} */
NgxEchartsDirective.prototype.detectEventChanges;

@@ -348,2 +308,4 @@ /** @type {?} */

/** @type {?} */
NgxEchartsDirective.prototype.chartMouseMove;
/** @type {?} */
NgxEchartsDirective.prototype.chartMouseUp;

@@ -359,4 +321,30 @@ /** @type {?} */

/** @type {?} */
NgxEchartsDirective.prototype.chartLegendSelectChanged;
/** @type {?} */
NgxEchartsDirective.prototype.chartLegendSelected;
/** @type {?} */
NgxEchartsDirective.prototype.chartLegendUnselected;
/** @type {?} */
NgxEchartsDirective.prototype.chartLegendScroll;
/** @type {?} */
NgxEchartsDirective.prototype.chartDataZoom;
/** @type {?} */
NgxEchartsDirective.prototype.chartDataRangeSelected;
/** @type {?} */
NgxEchartsDirective.prototype.chartTimelineChanged;
/** @type {?} */
NgxEchartsDirective.prototype.chartTimelinePlayChanged;
/** @type {?} */
NgxEchartsDirective.prototype.chartRestore;
/** @type {?} */
NgxEchartsDirective.prototype.chartDataViewChanged;
/** @type {?} */
NgxEchartsDirective.prototype.chartMagicTypeChanged;
/** @type {?} */
NgxEchartsDirective.prototype.chartPieSelectChanged;
/** @type {?} */
NgxEchartsDirective.prototype.chartPieSelected;
/** @type {?} */
NgxEchartsDirective.prototype.chartPieUnselected;
/** @type {?} */
NgxEchartsDirective.prototype.chartMapSelectChanged;

@@ -368,4 +356,18 @@ /** @type {?} */

/** @type {?} */
NgxEchartsDirective.prototype._chart;
NgxEchartsDirective.prototype.chartAxisAreaSelected;
/** @type {?} */
NgxEchartsDirective.prototype.chartFocusNodeAdjacency;
/** @type {?} */
NgxEchartsDirective.prototype.chartUnfocusNodeAdjacency;
/** @type {?} */
NgxEchartsDirective.prototype.chartBrush;
/** @type {?} */
NgxEchartsDirective.prototype.chartBrushSelected;
/** @type {?} */
NgxEchartsDirective.prototype.chartRendered;
/** @type {?} */
NgxEchartsDirective.prototype.chartFinished;
/** @type {?} */
NgxEchartsDirective.prototype.chart;
/** @type {?} */
NgxEchartsDirective.prototype.currentOffsetWidth;

@@ -377,10 +379,8 @@ /** @type {?} */

/** @type {?} */
NgxEchartsDirective.prototype._resize$;
NgxEchartsDirective.prototype.resizeSub;
/** @type {?} */
NgxEchartsDirective.prototype._resizeSub;
/** @type {?} */
NgxEchartsDirective.prototype.el;
/** @type {?} */
NgxEchartsDirective.prototype._ngZone;
NgxEchartsDirective.prototype.ngZone;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-echarts.directive.js","sourceRoot":"ng://ngx-echarts/","sources":["lib/ngx-echarts.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive, ElementRef, Renderer, Input, Output, HostListener, EventEmitter,\r\n  OnChanges, OnDestroy, SimpleChanges, NgZone, DoCheck, AfterViewInit\r\n} from '@angular/core';\r\nimport { ChangeFilter } from './change-filter';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { init, ECharts, EChartOption } from 'echarts';\r\nimport { EChartEvents } from './echart-events';\r\n\r\n@Directive({\r\n  selector: 'echarts, [echarts]',\r\n})\r\nexport class NgxEchartsDirective implements OnChanges, OnDestroy, DoCheck, AfterViewInit {\r\n  @Input() options: EChartOption;\r\n  @Input() theme: string;\r\n  @Input() loading: boolean;\r\n  @Input() initOpts: {\r\n    devicePixelRatio?: number\r\n    renderer?: string\r\n    width?: number | string\r\n    height?: number | string\r\n  };\r\n  @Input() merge: EChartOption;\r\n  @Input() autoResize = true;\r\n  @Input() loadingType = 'default';\r\n  @Input() loadingOpts: object;\r\n\r\n  /**\r\n   * Whether to register event handlers on echartInstance. Default is true.\r\n   * Use it to avoid unwanted change detection, if you want to optimize the performance.\r\n   */\r\n  @Input() detectEventChanges = true;\r\n\r\n  // chart events:\r\n  @Output() chartInit = new EventEmitter<ECharts>();\r\n  @Output() chartClick = new EventEmitter<any>();\r\n  @Output() chartDblClick = new EventEmitter<any>();\r\n  @Output() chartMouseDown = new EventEmitter<any>();\r\n  @Output() chartMouseUp = new EventEmitter<any>();\r\n  @Output() chartMouseOver = new EventEmitter<any>();\r\n  @Output() chartMouseOut = new EventEmitter<any>();\r\n  @Output() chartGlobalOut = new EventEmitter<any>();\r\n  @Output() chartContextMenu = new EventEmitter<any>();\r\n  @Output() chartDataZoom = new EventEmitter<any>();\r\n  @Output() chartMapSelectChanged = new EventEmitter<any>();\r\n  @Output() chartMapSelected = new EventEmitter<any>();\r\n  @Output() chartMapUnselected = new EventEmitter<any>();\r\n\r\n  private _chart: ECharts;\r\n  private currentOffsetWidth = 0;\r\n  private currentOffsetHeight = 0;\r\n  private currentWindowWidth: number;\r\n  private _resize$ = new Subject<void>();\r\n  private _resizeSub: Subscription;\r\n\r\n  constructor(private el: ElementRef, private _ngZone: NgZone) { }\r\n\r\n  private createChart() {\r\n    this.currentWindowWidth = window.innerWidth;\r\n    this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n    this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n    const dom = this.el.nativeElement;\r\n\r\n    if (window && window.getComputedStyle) {\r\n      const prop = window.getComputedStyle(dom, null).getPropertyValue('height');\r\n      if ((!prop || prop === '0px') &&\r\n        (!dom.style.height || dom.style.height === '0px')) {\r\n        dom.style.height = '400px';\r\n      }\r\n    }\r\n\r\n    return this._ngZone.runOutsideAngular(() => init(dom, this.theme || undefined, this.initOpts || undefined));\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize(event: Event) {\r\n    const target = event.target as Window;\r\n\r\n    if (this.autoResize && target.innerWidth !== this.currentWindowWidth) {\r\n      this.currentWindowWidth = target.innerWidth;\r\n      this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n      this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      this._resize$.next();\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const filter = ChangeFilter.of(changes);\r\n    filter.notFirstAndEmpty<any>('options').subscribe(opt => this.onOptionsChange(opt));\r\n    filter.notFirstAndEmpty<any>('merge').subscribe(opt => this.setOption(opt));\r\n    filter.has<boolean>('loading').subscribe(v => this.toggleLoading(!!v));\r\n    filter.notFirst<boolean>('detectEventChanges').subscribe(v => this.toggleEventDetectors(!!v));\r\n    filter.notFirst<string>('theme').subscribe(() => this.refreshChart());\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this._resizeSub) {\r\n      this._resizeSub.unsubscribe();\r\n      this._resizeSub = null;\r\n    }\r\n\r\n    if (this._chart) {\r\n      this._chart.dispose();\r\n      this._chart = null;\r\n    }\r\n  }\r\n\r\n  ngDoCheck() {\r\n    // No heavy work in DoCheck!\r\n    if (this._chart && this.autoResize) {\r\n      const offsetWidth = this.el.nativeElement.offsetWidth;\r\n      const offsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      if (this.currentOffsetWidth !== offsetWidth || this.currentOffsetHeight !== offsetHeight) {\r\n        this.currentOffsetWidth = offsetWidth;\r\n        this.currentOffsetHeight = offsetHeight;\r\n        this._resize$.next();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    setTimeout(() => this.initChart());\r\n  }\r\n\r\n  private initChart() {\r\n    this.onOptionsChange(this.options);\r\n\r\n    if (this.merge && this._chart) {\r\n      this.setOption(this.merge);\r\n    }\r\n  }\r\n\r\n  private onOptionsChange(opt: EChartOption) {\r\n    if (opt) {\r\n      if (!this._chart) {\r\n        this._chart = this.createChart();\r\n\r\n        // subscribe to _resize$ and debounced\r\n        this._resizeSub = this._resize$.pipe(debounceTime(50)).subscribe(() => {\r\n          if (this._chart) {\r\n            this._chart.resize();\r\n          }\r\n        });\r\n\r\n        // output echart instance:\r\n        this.chartInit.emit(this._chart);\r\n\r\n        // register events:\r\n        if (this.detectEventChanges) {\r\n          this.registerEvents();\r\n        }\r\n      }\r\n\r\n      this._chart.setOption(this.options, true);\r\n    }\r\n  }\r\n\r\n  private registerEvents() {\r\n    if (this._chart) {\r\n      const events = EChartEvents.All;\r\n      for (let i = 0, len = events.length; i < len; i++) {\r\n        this._chart.on(events[i], this.eventHandler, this);\r\n      }\r\n    }\r\n  }\r\n\r\n  private unregisterEvents() {\r\n    if (this._chart) {\r\n      const events = EChartEvents.All;\r\n      for (let i = 0, len = events.length; i < len; i++) {\r\n        this._chart.off(events[i], this.eventHandler);\r\n      }\r\n    }\r\n  }\r\n\r\n  clear() {\r\n    if (this._chart) {\r\n      this._chart.clear();\r\n    }\r\n  }\r\n\r\n  toggleLoading(loading: boolean) {\r\n    if (this._chart) {\r\n      loading ? this._chart.showLoading(this.loadingType, this.loadingOpts) : this._chart.hideLoading();\r\n    }\r\n  }\r\n\r\n  setOption(option: any, opts?: any) {\r\n    if (this._chart) {\r\n      this._chart.setOption(option, opts);\r\n    }\r\n  }\r\n\r\n  private eventHandler(event) {\r\n    switch (event.type) {\r\n      case EChartEvents.Click:\r\n        this._ngZone.run(() => this.chartClick.emit(event));\r\n        break;\r\n      case EChartEvents.DblClick:\r\n        this._ngZone.run(() => this.chartDblClick.emit(event));\r\n        break;\r\n      case EChartEvents.MouseDown:\r\n        this._ngZone.run(() => this.chartMouseDown.emit(event));\r\n        break;\r\n      case EChartEvents.MouseUp:\r\n        this._ngZone.run(() => this.chartMouseUp.emit(event));\r\n        break;\r\n      case EChartEvents.MouseOver:\r\n        this._ngZone.run(() => this.chartMouseOver.emit(event));\r\n        break;\r\n      case EChartEvents.MouseOut:\r\n        this._ngZone.run(() => this.chartMouseOut.emit(event));\r\n        break;\r\n      case EChartEvents.GlobalOut:\r\n        this._ngZone.run(() => this.chartGlobalOut.emit(event));\r\n        break;\r\n      case EChartEvents.ContextMenu:\r\n        this._ngZone.run(() => this.chartContextMenu.emit(event));\r\n        break;\r\n      case EChartEvents.DataZoom:\r\n        this._ngZone.run(() => this.chartDataZoom.emit(event));\r\n        break;\r\n      case EChartEvents.MapSelectChanged:\r\n        this._ngZone.run(() => this.chartMapSelectChanged.emit(event));\r\n        break;\r\n      case EChartEvents.MapSelected:\r\n        this._ngZone.run(() => this.chartMapSelected.emit(event));\r\n        break;\r\n      case EChartEvents.MapUnselected:\r\n        this._ngZone.run(() => this.chartMapUnselected.emit(event));\r\n        break;\r\n    }\r\n  }\r\n\r\n  private toggleEventDetectors(detect: boolean) {\r\n    if (this._chart) {\r\n      detect ? this.registerEvents() : this.unregisterEvents();\r\n    }\r\n  }\r\n\r\n  private refreshChart() {\r\n    this.ngOnDestroy();\r\n    this.initChart();\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-echarts.directive.js","sourceRoot":"ng://ngx-echarts/","sources":["lib/ngx-echarts.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, DoCheck, ElementRef, EventEmitter, Input, NgZone, OnChanges, OnDestroy, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { EChartOption, ECharts, init } from 'echarts';\r\nimport { fromEvent, Observable, Subscription } from 'rxjs';\r\nimport { debounceTime, switchMap } from 'rxjs/operators';\r\nimport { ChangeFilter } from './change-filter';\r\n\r\n@Directive({\r\n  selector: 'echarts, [echarts]',\r\n})\r\nexport class NgxEchartsDirective implements OnChanges, OnDestroy, OnInit, DoCheck, AfterViewInit {\r\n  @Input() options: EChartOption;\r\n  @Input() theme: string;\r\n  @Input() loading: boolean;\r\n  @Input() initOpts: {\r\n    devicePixelRatio?: number\r\n    renderer?: string\r\n    width?: number | string\r\n    height?: number | string\r\n  };\r\n  @Input() merge: EChartOption;\r\n  @Input() autoResize = true;\r\n  @Input() loadingType = 'default';\r\n  @Input() loadingOpts: object;\r\n  @Input() detectEventChanges = true; // deprecated, left for compatibility reasons to avoid triggering major version\r\n\r\n  // ngx-echarts events\r\n  @Output() chartInit = new EventEmitter<ECharts>();\r\n\r\n  // echarts mouse events\r\n  @Output() chartClick = this.createLazyEvent('click');\r\n  @Output() chartDblClick = this.createLazyEvent('dblclick');\r\n  @Output() chartMouseDown = this.createLazyEvent('mousedown');\r\n  @Output() chartMouseMove = this.createLazyEvent('mousemove');\r\n  @Output() chartMouseUp = this.createLazyEvent('mouseup');\r\n  @Output() chartMouseOver = this.createLazyEvent('mouseover');\r\n  @Output() chartMouseOut = this.createLazyEvent('mouseout');\r\n  @Output() chartGlobalOut = this.createLazyEvent('globalout');\r\n  @Output() chartContextMenu = this.createLazyEvent('contextmenu');\r\n\r\n  // echarts mouse events\r\n  @Output() chartLegendSelectChanged = this.createLazyEvent('legendselectchanged');\r\n  @Output() chartLegendSelected = this.createLazyEvent('legendselected');\r\n  @Output() chartLegendUnselected = this.createLazyEvent('legendunselected');\r\n  @Output() chartLegendScroll = this.createLazyEvent('legendscroll');\r\n  @Output() chartDataZoom = this.createLazyEvent('datazoom');\r\n  @Output() chartDataRangeSelected = this.createLazyEvent('datarangeselected');\r\n  @Output() chartTimelineChanged = this.createLazyEvent('timelinechanged');\r\n  @Output() chartTimelinePlayChanged = this.createLazyEvent('timelineplaychanged');\r\n  @Output() chartRestore = this.createLazyEvent('restore');\r\n  @Output() chartDataViewChanged = this.createLazyEvent('dataviewchanged');\r\n  @Output() chartMagicTypeChanged = this.createLazyEvent('magictypechanged');\r\n  @Output() chartPieSelectChanged = this.createLazyEvent('pieselectchanged');\r\n  @Output() chartPieSelected = this.createLazyEvent('pieselected');\r\n  @Output() chartPieUnselected = this.createLazyEvent('pieunselected');\r\n  @Output() chartMapSelectChanged = this.createLazyEvent('mapselectchanged');\r\n  @Output() chartMapSelected = this.createLazyEvent('mapselected');\r\n  @Output() chartMapUnselected = this.createLazyEvent('mapunselected');\r\n  @Output() chartAxisAreaSelected = this.createLazyEvent('axisareaselected');\r\n  @Output() chartFocusNodeAdjacency = this.createLazyEvent('focusnodeadjacency');\r\n  @Output() chartUnfocusNodeAdjacency = this.createLazyEvent('unfocusnodeadjacency');\r\n  @Output() chartBrush = this.createLazyEvent('brush');\r\n  @Output() chartBrushSelected = this.createLazyEvent('brushselected');\r\n  @Output() chartRendered = this.createLazyEvent('rendered');\r\n  @Output() chartFinished = this.createLazyEvent('finished');\r\n\r\n  private chart: ECharts;\r\n  private currentOffsetWidth = 0;\r\n  private currentOffsetHeight = 0;\r\n  private currentWindowWidth: number;\r\n  private resizeSub: Subscription;\r\n\r\n  constructor(private el: ElementRef, private ngZone: NgZone) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const filter = ChangeFilter.of(changes);\r\n    filter.notFirstAndEmpty<any>('options').subscribe(opt => this.onOptionsChange(opt));\r\n    filter.notFirstAndEmpty<any>('merge').subscribe(opt => this.setOption(opt));\r\n    filter.has<boolean>('loading').subscribe(v => this.toggleLoading(!!v));\r\n    filter.notFirst<string>('theme').subscribe(() => this.refreshChart());\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.resizeSub = fromEvent(window, 'resize').pipe(debounceTime(50)).subscribe(() => {\r\n      if (this.autoResize && window.innerWidth !== this.currentWindowWidth) {\r\n        this.currentWindowWidth = window.innerWidth;\r\n        this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n        this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n        this.resize();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.resizeSub.unsubscribe();\r\n    this.dispose();\r\n  }\r\n\r\n  ngDoCheck() {\r\n    // No heavy work in DoCheck!\r\n    if (this.chart && this.autoResize) {\r\n      const offsetWidth = this.el.nativeElement.offsetWidth;\r\n      const offsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      if (this.currentOffsetWidth !== offsetWidth || this.currentOffsetHeight !== offsetHeight) {\r\n        this.currentOffsetWidth = offsetWidth;\r\n        this.currentOffsetHeight = offsetHeight;\r\n        this.resize();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    setTimeout(() => this.initChart());\r\n  }\r\n\r\n  private dispose() {\r\n    if (this.chart) {\r\n      this.chart.dispose();\r\n      this.chart = null;\r\n    }\r\n  }\r\n\r\n  private resize() {\r\n    if (this.chart) {\r\n      this.chart.resize();\r\n    }\r\n  }\r\n\r\n  private toggleLoading(loading: boolean) {\r\n    if (this.chart) {\r\n      loading ? this.chart.showLoading(this.loadingType, this.loadingOpts) : this.chart.hideLoading();\r\n    }\r\n  }\r\n\r\n  private setOption(option: any, opts?: any) {\r\n    if (this.chart) {\r\n      this.chart.setOption(option, opts);\r\n    }\r\n  }\r\n\r\n  private refreshChart() {\r\n    this.dispose();\r\n    this.initChart();\r\n  }\r\n\r\n  private createChart() {\r\n    this.currentWindowWidth = window.innerWidth;\r\n    this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n    this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n    const dom = this.el.nativeElement;\r\n\r\n    if (window && window.getComputedStyle) {\r\n      const prop = window.getComputedStyle(dom, null).getPropertyValue('height');\r\n      if ((!prop || prop === '0px') &&\r\n        (!dom.style.height || dom.style.height === '0px')) {\r\n        dom.style.height = '400px';\r\n      }\r\n    }\r\n\r\n    return this.ngZone.runOutsideAngular(() => init(dom, this.theme, this.initOpts));\r\n  }\r\n\r\n  private initChart() {\r\n    this.onOptionsChange(this.options);\r\n\r\n    if (this.merge && this.chart) {\r\n      this.setOption(this.merge);\r\n    }\r\n  }\r\n\r\n  private onOptionsChange(opt: EChartOption) {\r\n    if (opt) {\r\n      if (!this.chart) {\r\n        this.chart = this.createChart();\r\n        this.chartInit.emit(this.chart);\r\n      }\r\n\r\n      this.chart.setOption(this.options, true);\r\n    }\r\n  }\r\n\r\n  // allows to lazily bind to only those events that are requested through the `@Output` by parent components\r\n  // see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info\r\n  private createLazyEvent<T>(eventName: string): EventEmitter<T> {\r\n    return this.chartInit.pipe(\r\n      switchMap((chart: ECharts) => new Observable(observer => {\r\n        chart.on(eventName, (data: T) => this.ngZone.run(() => observer.next(data)));\r\n        return null; // no need to react on unsubscribe as long as the `dispose()` is called in ngOnDestroy\r\n      }))\r\n    ) as EventEmitter<T>;\r\n  }\r\n\r\n}\r\n"]}

@@ -5,79 +5,56 @@ /**

*/
import { Directive, ElementRef, Input, Output, HostListener, EventEmitter, NgZone } from '@angular/core';
import { Directive, ElementRef, EventEmitter, Input, NgZone, Output } from '@angular/core';
import { EChartOption, init } from 'echarts';
import { fromEvent, Observable } from 'rxjs';
import { debounceTime, switchMap } from 'rxjs/operators';
import { ChangeFilter } from './change-filter';
import { Subject } from 'rxjs';
import { debounceTime } from 'rxjs/operators';
import { init, EChartOption } from 'echarts';
import { EChartEvents } from './echart-events';
var NgxEchartsDirective = /** @class */ (function () {
function NgxEchartsDirective(el, _ngZone) {
function NgxEchartsDirective(el, ngZone) {
this.el = el;
this._ngZone = _ngZone;
this.ngZone = ngZone;
this.autoResize = true;
this.loadingType = 'default';
/**
* Whether to register event handlers on echartInstance. Default is true.
* Use it to avoid unwanted change detection, if you want to optimize the performance.
*/
this.detectEventChanges = true;
// chart events:
this.detectEventChanges = true; // deprecated, left for compatibility reasons to avoid triggering major version
// deprecated, left for compatibility reasons to avoid triggering major version
// ngx-echarts events
this.chartInit = new EventEmitter();
this.chartClick = new EventEmitter();
this.chartDblClick = new EventEmitter();
this.chartMouseDown = new EventEmitter();
this.chartMouseUp = new EventEmitter();
this.chartMouseOver = new EventEmitter();
this.chartMouseOut = new EventEmitter();
this.chartGlobalOut = new EventEmitter();
this.chartContextMenu = new EventEmitter();
this.chartDataZoom = new EventEmitter();
this.chartMapSelectChanged = new EventEmitter();
this.chartMapSelected = new EventEmitter();
this.chartMapUnselected = new EventEmitter();
// echarts mouse events
this.chartClick = this.createLazyEvent('click');
this.chartDblClick = this.createLazyEvent('dblclick');
this.chartMouseDown = this.createLazyEvent('mousedown');
this.chartMouseMove = this.createLazyEvent('mousemove');
this.chartMouseUp = this.createLazyEvent('mouseup');
this.chartMouseOver = this.createLazyEvent('mouseover');
this.chartMouseOut = this.createLazyEvent('mouseout');
this.chartGlobalOut = this.createLazyEvent('globalout');
this.chartContextMenu = this.createLazyEvent('contextmenu');
// echarts mouse events
this.chartLegendSelectChanged = this.createLazyEvent('legendselectchanged');
this.chartLegendSelected = this.createLazyEvent('legendselected');
this.chartLegendUnselected = this.createLazyEvent('legendunselected');
this.chartLegendScroll = this.createLazyEvent('legendscroll');
this.chartDataZoom = this.createLazyEvent('datazoom');
this.chartDataRangeSelected = this.createLazyEvent('datarangeselected');
this.chartTimelineChanged = this.createLazyEvent('timelinechanged');
this.chartTimelinePlayChanged = this.createLazyEvent('timelineplaychanged');
this.chartRestore = this.createLazyEvent('restore');
this.chartDataViewChanged = this.createLazyEvent('dataviewchanged');
this.chartMagicTypeChanged = this.createLazyEvent('magictypechanged');
this.chartPieSelectChanged = this.createLazyEvent('pieselectchanged');
this.chartPieSelected = this.createLazyEvent('pieselected');
this.chartPieUnselected = this.createLazyEvent('pieunselected');
this.chartMapSelectChanged = this.createLazyEvent('mapselectchanged');
this.chartMapSelected = this.createLazyEvent('mapselected');
this.chartMapUnselected = this.createLazyEvent('mapunselected');
this.chartAxisAreaSelected = this.createLazyEvent('axisareaselected');
this.chartFocusNodeAdjacency = this.createLazyEvent('focusnodeadjacency');
this.chartUnfocusNodeAdjacency = this.createLazyEvent('unfocusnodeadjacency');
this.chartBrush = this.createLazyEvent('brush');
this.chartBrushSelected = this.createLazyEvent('brushselected');
this.chartRendered = this.createLazyEvent('rendered');
this.chartFinished = this.createLazyEvent('finished');
this.currentOffsetWidth = 0;
this.currentOffsetHeight = 0;
this._resize$ = new Subject();
}
/**
* @return {?}
*/
NgxEchartsDirective.prototype.createChart = /**
* @return {?}
*/
function () {
var _this = this;
this.currentWindowWidth = window.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
/** @type {?} */
var dom = this.el.nativeElement;
if (window && window.getComputedStyle) {
/** @type {?} */
var prop = window.getComputedStyle(dom, null).getPropertyValue('height');
if ((!prop || prop === '0px') &&
(!dom.style.height || dom.style.height === '0px')) {
dom.style.height = '400px';
}
}
return this._ngZone.runOutsideAngular(function () { return init(dom, _this.theme || undefined, _this.initOpts || undefined); });
};
/**
* @param {?} event
* @return {?}
*/
NgxEchartsDirective.prototype.onWindowResize = /**
* @param {?} event
* @return {?}
*/
function (event) {
/** @type {?} */
var target = (/** @type {?} */ (event.target));
if (this.autoResize && target.innerWidth !== this.currentWindowWidth) {
this.currentWindowWidth = target.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
this._resize$.next();
}
};
/**
* @param {?} changes

@@ -97,3 +74,2 @@ * @return {?}

filter.has('loading').subscribe(function (v) { return _this.toggleLoading(!!v); });
filter.notFirst('detectEventChanges').subscribe(function (v) { return _this.toggleEventDetectors(!!v); });
filter.notFirst('theme').subscribe(function () { return _this.refreshChart(); });

@@ -104,2 +80,19 @@ };

*/
NgxEchartsDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.resizeSub = fromEvent(window, 'resize').pipe(debounceTime(50)).subscribe(function () {
if (_this.autoResize && window.innerWidth !== _this.currentWindowWidth) {
_this.currentWindowWidth = window.innerWidth;
_this.currentOffsetWidth = _this.el.nativeElement.offsetWidth;
_this.currentOffsetHeight = _this.el.nativeElement.offsetHeight;
_this.resize();
}
});
};
/**
* @return {?}
*/
NgxEchartsDirective.prototype.ngOnDestroy = /**

@@ -109,10 +102,4 @@ * @return {?}

function () {
if (this._resizeSub) {
this._resizeSub.unsubscribe();
this._resizeSub = null;
}
if (this._chart) {
this._chart.dispose();
this._chart = null;
}
this.resizeSub.unsubscribe();
this.dispose();
};

@@ -127,3 +114,3 @@ /**

// No heavy work in DoCheck!
if (this._chart && this.autoResize) {
if (this.chart && this.autoResize) {
/** @type {?} */

@@ -136,3 +123,3 @@ var offsetWidth = this.el.nativeElement.offsetWidth;

this.currentOffsetHeight = offsetHeight;
this._resize$.next();
this.resize();
}

@@ -154,68 +141,48 @@ }

*/
NgxEchartsDirective.prototype.initChart = /**
NgxEchartsDirective.prototype.dispose = /**
* @return {?}
*/
function () {
this.onOptionsChange(this.options);
if (this.merge && this._chart) {
this.setOption(this.merge);
if (this.chart) {
this.chart.dispose();
this.chart = null;
}
};
/**
* @param {?} opt
* @return {?}
*/
NgxEchartsDirective.prototype.onOptionsChange = /**
* @param {?} opt
NgxEchartsDirective.prototype.resize = /**
* @return {?}
*/
function (opt) {
var _this = this;
if (opt) {
if (!this._chart) {
this._chart = this.createChart();
// subscribe to _resize$ and debounced
this._resizeSub = this._resize$.pipe(debounceTime(50)).subscribe(function () {
if (_this._chart) {
_this._chart.resize();
}
});
// output echart instance:
this.chartInit.emit(this._chart);
// register events:
if (this.detectEventChanges) {
this.registerEvents();
}
}
this._chart.setOption(this.options, true);
function () {
if (this.chart) {
this.chart.resize();
}
};
/**
* @param {?} loading
* @return {?}
*/
NgxEchartsDirective.prototype.registerEvents = /**
NgxEchartsDirective.prototype.toggleLoading = /**
* @param {?} loading
* @return {?}
*/
function () {
if (this._chart) {
/** @type {?} */
var events = EChartEvents.All;
for (var i = 0, len = events.length; i < len; i++) {
this._chart.on(events[i], this.eventHandler, this);
}
function (loading) {
if (this.chart) {
loading ? this.chart.showLoading(this.loadingType, this.loadingOpts) : this.chart.hideLoading();
}
};
/**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
NgxEchartsDirective.prototype.unregisterEvents = /**
NgxEchartsDirective.prototype.setOption = /**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
function () {
if (this._chart) {
/** @type {?} */
var events = EChartEvents.All;
for (var i = 0, len = events.length; i < len; i++) {
this._chart.off(events[i], this.eventHandler);
}
function (option, opts) {
if (this.chart) {
this.chart.setOption(option, opts);
}

@@ -226,109 +193,84 @@ };

*/
NgxEchartsDirective.prototype.clear = /**
NgxEchartsDirective.prototype.refreshChart = /**
* @return {?}
*/
function () {
if (this._chart) {
this._chart.clear();
}
this.dispose();
this.initChart();
};
/**
* @param {?} loading
* @return {?}
*/
NgxEchartsDirective.prototype.toggleLoading = /**
* @param {?} loading
NgxEchartsDirective.prototype.createChart = /**
* @return {?}
*/
function (loading) {
if (this._chart) {
loading ? this._chart.showLoading(this.loadingType, this.loadingOpts) : this._chart.hideLoading();
function () {
var _this = this;
this.currentWindowWidth = window.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
/** @type {?} */
var dom = this.el.nativeElement;
if (window && window.getComputedStyle) {
/** @type {?} */
var prop = window.getComputedStyle(dom, null).getPropertyValue('height');
if ((!prop || prop === '0px') &&
(!dom.style.height || dom.style.height === '0px')) {
dom.style.height = '400px';
}
}
return this.ngZone.runOutsideAngular(function () { return init(dom, _this.theme, _this.initOpts); });
};
/**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
NgxEchartsDirective.prototype.setOption = /**
* @param {?} option
* @param {?=} opts
NgxEchartsDirective.prototype.initChart = /**
* @return {?}
*/
function (option, opts) {
if (this._chart) {
this._chart.setOption(option, opts);
function () {
this.onOptionsChange(this.options);
if (this.merge && this.chart) {
this.setOption(this.merge);
}
};
/**
* @param {?} event
* @param {?} opt
* @return {?}
*/
NgxEchartsDirective.prototype.eventHandler = /**
* @param {?} event
NgxEchartsDirective.prototype.onOptionsChange = /**
* @param {?} opt
* @return {?}
*/
function (event) {
var _this = this;
switch (event.type) {
case EChartEvents.Click:
this._ngZone.run(function () { return _this.chartClick.emit(event); });
break;
case EChartEvents.DblClick:
this._ngZone.run(function () { return _this.chartDblClick.emit(event); });
break;
case EChartEvents.MouseDown:
this._ngZone.run(function () { return _this.chartMouseDown.emit(event); });
break;
case EChartEvents.MouseUp:
this._ngZone.run(function () { return _this.chartMouseUp.emit(event); });
break;
case EChartEvents.MouseOver:
this._ngZone.run(function () { return _this.chartMouseOver.emit(event); });
break;
case EChartEvents.MouseOut:
this._ngZone.run(function () { return _this.chartMouseOut.emit(event); });
break;
case EChartEvents.GlobalOut:
this._ngZone.run(function () { return _this.chartGlobalOut.emit(event); });
break;
case EChartEvents.ContextMenu:
this._ngZone.run(function () { return _this.chartContextMenu.emit(event); });
break;
case EChartEvents.DataZoom:
this._ngZone.run(function () { return _this.chartDataZoom.emit(event); });
break;
case EChartEvents.MapSelectChanged:
this._ngZone.run(function () { return _this.chartMapSelectChanged.emit(event); });
break;
case EChartEvents.MapSelected:
this._ngZone.run(function () { return _this.chartMapSelected.emit(event); });
break;
case EChartEvents.MapUnselected:
this._ngZone.run(function () { return _this.chartMapUnselected.emit(event); });
break;
function (opt) {
if (opt) {
if (!this.chart) {
this.chart = this.createChart();
this.chartInit.emit(this.chart);
}
this.chart.setOption(this.options, true);
}
};
// allows to lazily bind to only those events that are requested through the `@Output` by parent components
// see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info
// allows to lazily bind to only those events that are requested through the `@Output` by parent components
// see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info
/**
* @param {?} detect
* @template T
* @param {?} eventName
* @return {?}
*/
NgxEchartsDirective.prototype.toggleEventDetectors = /**
* @param {?} detect
* @return {?}
*/
function (detect) {
if (this._chart) {
detect ? this.registerEvents() : this.unregisterEvents();
}
};
NgxEchartsDirective.prototype.createLazyEvent =
// allows to lazily bind to only those events that are requested through the `@Output` by parent components
// see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info
/**
* @template T
* @param {?} eventName
* @return {?}
*/
NgxEchartsDirective.prototype.refreshChart = /**
* @return {?}
*/
function () {
this.ngOnDestroy();
this.initChart();
function (eventName) {
var _this = this;
return (/** @type {?} */ (this.chartInit.pipe(switchMap(function (chart) { return new Observable(function (observer) {
chart.on(eventName, function (data) { return _this.ngZone.run(function () { return observer.next(data); }); });
return null; // no need to react on unsubscribe as long as the `dispose()` is called in ngOnDestroy
}); }))));
};

@@ -359,2 +301,3 @@ NgxEchartsDirective.decorators = [

chartMouseDown: [{ type: Output }],
chartMouseMove: [{ type: Output }],
chartMouseUp: [{ type: Output }],

@@ -365,7 +308,26 @@ chartMouseOver: [{ type: Output }],

chartContextMenu: [{ type: Output }],
chartLegendSelectChanged: [{ type: Output }],
chartLegendSelected: [{ type: Output }],
chartLegendUnselected: [{ type: Output }],
chartLegendScroll: [{ type: Output }],
chartDataZoom: [{ type: Output }],
chartDataRangeSelected: [{ type: Output }],
chartTimelineChanged: [{ type: Output }],
chartTimelinePlayChanged: [{ type: Output }],
chartRestore: [{ type: Output }],
chartDataViewChanged: [{ type: Output }],
chartMagicTypeChanged: [{ type: Output }],
chartPieSelectChanged: [{ type: Output }],
chartPieSelected: [{ type: Output }],
chartPieUnselected: [{ type: Output }],
chartMapSelectChanged: [{ type: Output }],
chartMapSelected: [{ type: Output }],
chartMapUnselected: [{ type: Output }],
onWindowResize: [{ type: HostListener, args: ['window:resize', ['$event'],] }]
chartAxisAreaSelected: [{ type: Output }],
chartFocusNodeAdjacency: [{ type: Output }],
chartUnfocusNodeAdjacency: [{ type: Output }],
chartBrush: [{ type: Output }],
chartBrushSelected: [{ type: Output }],
chartRendered: [{ type: Output }],
chartFinished: [{ type: Output }]
};

@@ -392,7 +354,3 @@ return NgxEchartsDirective;

NgxEchartsDirective.prototype.loadingOpts;
/**
* Whether to register event handlers on echartInstance. Default is true.
* Use it to avoid unwanted change detection, if you want to optimize the performance.
* @type {?}
*/
/** @type {?} */
NgxEchartsDirective.prototype.detectEventChanges;

@@ -408,2 +366,4 @@ /** @type {?} */

/** @type {?} */
NgxEchartsDirective.prototype.chartMouseMove;
/** @type {?} */
NgxEchartsDirective.prototype.chartMouseUp;

@@ -419,4 +379,30 @@ /** @type {?} */

/** @type {?} */
NgxEchartsDirective.prototype.chartLegendSelectChanged;
/** @type {?} */
NgxEchartsDirective.prototype.chartLegendSelected;
/** @type {?} */
NgxEchartsDirective.prototype.chartLegendUnselected;
/** @type {?} */
NgxEchartsDirective.prototype.chartLegendScroll;
/** @type {?} */
NgxEchartsDirective.prototype.chartDataZoom;
/** @type {?} */
NgxEchartsDirective.prototype.chartDataRangeSelected;
/** @type {?} */
NgxEchartsDirective.prototype.chartTimelineChanged;
/** @type {?} */
NgxEchartsDirective.prototype.chartTimelinePlayChanged;
/** @type {?} */
NgxEchartsDirective.prototype.chartRestore;
/** @type {?} */
NgxEchartsDirective.prototype.chartDataViewChanged;
/** @type {?} */
NgxEchartsDirective.prototype.chartMagicTypeChanged;
/** @type {?} */
NgxEchartsDirective.prototype.chartPieSelectChanged;
/** @type {?} */
NgxEchartsDirective.prototype.chartPieSelected;
/** @type {?} */
NgxEchartsDirective.prototype.chartPieUnselected;
/** @type {?} */
NgxEchartsDirective.prototype.chartMapSelectChanged;

@@ -428,4 +414,18 @@ /** @type {?} */

/** @type {?} */
NgxEchartsDirective.prototype._chart;
NgxEchartsDirective.prototype.chartAxisAreaSelected;
/** @type {?} */
NgxEchartsDirective.prototype.chartFocusNodeAdjacency;
/** @type {?} */
NgxEchartsDirective.prototype.chartUnfocusNodeAdjacency;
/** @type {?} */
NgxEchartsDirective.prototype.chartBrush;
/** @type {?} */
NgxEchartsDirective.prototype.chartBrushSelected;
/** @type {?} */
NgxEchartsDirective.prototype.chartRendered;
/** @type {?} */
NgxEchartsDirective.prototype.chartFinished;
/** @type {?} */
NgxEchartsDirective.prototype.chart;
/** @type {?} */
NgxEchartsDirective.prototype.currentOffsetWidth;

@@ -437,10 +437,8 @@ /** @type {?} */

/** @type {?} */
NgxEchartsDirective.prototype._resize$;
NgxEchartsDirective.prototype.resizeSub;
/** @type {?} */
NgxEchartsDirective.prototype._resizeSub;
/** @type {?} */
NgxEchartsDirective.prototype.el;
/** @type {?} */
NgxEchartsDirective.prototype._ngZone;
NgxEchartsDirective.prototype.ngZone;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-echarts.directive.js","sourceRoot":"ng://ngx-echarts/","sources":["lib/ngx-echarts.directive.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EAAE,UAAU,EAAY,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,YAAY,EACrC,MAAM,EAC5C,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAgB,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,IAAI,EAAW,YAAY,EAAE,MAAM,SAAS,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C;IA8CE,6BAAoB,EAAc,EAAU,OAAe;QAAvC,OAAE,GAAF,EAAE,CAAY;QAAU,YAAO,GAAP,OAAO,CAAQ;QAhClD,eAAU,GAAG,IAAI,CAAC;QAClB,gBAAW,GAAG,SAAS,CAAC;;;;;QAOxB,uBAAkB,GAAG,IAAI,CAAC;;QAGzB,cAAS,GAAG,IAAI,YAAY,EAAW,CAAC;QACxC,eAAU,GAAG,IAAI,YAAY,EAAO,CAAC;QACrC,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACxC,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QACzC,iBAAY,GAAG,IAAI,YAAY,EAAO,CAAC;QACvC,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QACzC,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACxC,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QACzC,qBAAgB,GAAG,IAAI,YAAY,EAAO,CAAC;QAC3C,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACxC,0BAAqB,GAAG,IAAI,YAAY,EAAO,CAAC;QAChD,qBAAgB,GAAG,IAAI,YAAY,EAAO,CAAC;QAC3C,uBAAkB,GAAG,IAAI,YAAY,EAAO,CAAC;QAG/C,uBAAkB,GAAG,CAAC,CAAC;QACvB,wBAAmB,GAAG,CAAC,CAAC;QAExB,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IAGwB,CAAC;;;;IAExD,yCAAW;;;IAAnB;QAAA,iBAeC;QAdC,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC,UAAU,CAAC;QAC5C,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC;QAC5D,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY,CAAC;;YACxD,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa;QAEjC,IAAI,MAAM,IAAI,MAAM,CAAC,gBAAgB,EAAE;;gBAC/B,IAAI,GAAG,MAAM,CAAC,gBAAgB,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,gBAAgB,CAAC,QAAQ,CAAC;YAC1E,IAAI,CAAC,CAAC,IAAI,IAAI,IAAI,KAAK,KAAK,CAAC;gBAC3B,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,IAAI,GAAG,CAAC,KAAK,CAAC,MAAM,KAAK,KAAK,CAAC,EAAE;gBACnD,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,OAAO,CAAC;aAC5B;SACF;QAED,OAAO,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,cAAM,OAAA,IAAI,CAAC,GAAG,EAAE,KAAI,CAAC,KAAK,IAAI,SAAS,EAAE,KAAI,CAAC,QAAQ,IAAI,SAAS,CAAC,EAA9D,CAA8D,CAAC,CAAC;IAC9G,CAAC;;;;;IAGD,4CAAc;;;;IADd,UACe,KAAY;;YACnB,MAAM,GAAG,mBAAA,KAAK,CAAC,MAAM,EAAU;QAErC,IAAI,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,KAAK,IAAI,CAAC,kBAAkB,EAAE;YACpE,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC,UAAU,CAAC;YAC5C,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC;YAC5D,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY,CAAC;YAE9D,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;SACtB;IACH,CAAC;;;;;IAED,yCAAW;;;;IAAX,UAAY,OAAsB;QAAlC,iBAOC;;YANO,MAAM,GAAG,YAAY,CAAC,EAAE,CAAC,OAAO,CAAC;QACvC,MAAM,CAAC,gBAAgB,CAAM,SAAS,CAAC,CAAC,SAAS,CAAC,UAAA,GAAG,IAAI,OAAA,KAAI,CAAC,eAAe,CAAC,GAAG,CAAC,EAAzB,CAAyB,CAAC,CAAC;QACpF,MAAM,CAAC,gBAAgB,CAAM,OAAO,CAAC,CAAC,SAAS,CAAC,UAAA,GAAG,IAAI,OAAA,KAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAnB,CAAmB,CAAC,CAAC;QAC5E,MAAM,CAAC,GAAG,CAAU,SAAS,CAAC,CAAC,SAAS,CAAC,UAAA,CAAC,IAAI,OAAA,KAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,EAAvB,CAAuB,CAAC,CAAC;QACvE,MAAM,CAAC,QAAQ,CAAU,oBAAoB,CAAC,CAAC,SAAS,CAAC,UAAA,CAAC,IAAI,OAAA,KAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,CAAC,EAA9B,CAA8B,CAAC,CAAC;QAC9F,MAAM,CAAC,QAAQ,CAAS,OAAO,CAAC,CAAC,SAAS,CAAC,cAAM,OAAA,KAAI,CAAC,YAAY,EAAE,EAAnB,CAAmB,CAAC,CAAC;IACxE,CAAC;;;;IAED,yCAAW;;;IAAX;QACE,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;YAC9B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;SACxB;QAED,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACtB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SACpB;IACH,CAAC;;;;IAED,uCAAS;;;IAAT;QACE,4BAA4B;QAC5B,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,UAAU,EAAE;;gBAC5B,WAAW,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW;;gBAC/C,YAAY,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY;YAEvD,IAAI,IAAI,CAAC,kBAAkB,KAAK,WAAW,IAAI,IAAI,CAAC,mBAAmB,KAAK,YAAY,EAAE;gBACxF,IAAI,CAAC,kBAAkB,GAAG,WAAW,CAAC;gBACtC,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC;gBACxC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;aACtB;SACF;IACH,CAAC;;;;IAED,6CAAe;;;IAAf;QAAA,iBAEC;QADC,UAAU,CAAC,cAAM,OAAA,KAAI,CAAC,SAAS,EAAE,EAAhB,CAAgB,CAAC,CAAC;IACrC,CAAC;;;;IAEO,uCAAS;;;IAAjB;QACE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEnC,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE;YAC7B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC5B;IACH,CAAC;;;;;IAEO,6CAAe;;;;IAAvB,UAAwB,GAAiB;QAAzC,iBAuBC;QAtBC,IAAI,GAAG,EAAE;YACP,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;gBAChB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;gBAEjC,sCAAsC;gBACtC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;oBAC/D,IAAI,KAAI,CAAC,MAAM,EAAE;wBACf,KAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;qBACtB;gBACH,CAAC,CAAC,CAAC;gBAEH,0BAA0B;gBAC1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAEjC,mBAAmB;gBACnB,IAAI,IAAI,CAAC,kBAAkB,EAAE;oBAC3B,IAAI,CAAC,cAAc,EAAE,CAAC;iBACvB;aACF;YAED,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;SAC3C;IACH,CAAC;;;;IAEO,4CAAc;;;IAAtB;QACE,IAAI,IAAI,CAAC,MAAM,EAAE;;gBACT,MAAM,GAAG,YAAY,CAAC,GAAG;YAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;gBACjD,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;aACpD;SACF;IACH,CAAC;;;;IAEO,8CAAgB;;;IAAxB;QACE,IAAI,IAAI,CAAC,MAAM,EAAE;;gBACT,MAAM,GAAG,YAAY,CAAC,GAAG;YAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;gBACjD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;aAC/C;SACF;IACH,CAAC;;;;IAED,mCAAK;;;IAAL;QACE,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;SACrB;IACH,CAAC;;;;;IAED,2CAAa;;;;IAAb,UAAc,OAAgB;QAC5B,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;SACnG;IACH,CAAC;;;;;;IAED,uCAAS;;;;;IAAT,UAAU,MAAW,EAAE,IAAU;QAC/B,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;SACrC;IACH,CAAC;;;;;IAEO,0CAAY;;;;IAApB,UAAqB,KAAK;QAA1B,iBAuCC;QAtCC,QAAQ,KAAK,CAAC,IAAI,EAAE;YAClB,KAAK,YAAY,CAAC,KAAK;gBACrB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,EAA3B,CAA2B,CAAC,CAAC;gBACpD,MAAM;YACR,KAAK,YAAY,CAAC,QAAQ;gBACxB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,EAA9B,CAA8B,CAAC,CAAC;gBACvD,MAAM;YACR,KAAK,YAAY,CAAC,SAAS;gBACzB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,EAA/B,CAA+B,CAAC,CAAC;gBACxD,MAAM;YACR,KAAK,YAAY,CAAC,OAAO;gBACvB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,EAA7B,CAA6B,CAAC,CAAC;gBACtD,MAAM;YACR,KAAK,YAAY,CAAC,SAAS;gBACzB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,EAA/B,CAA+B,CAAC,CAAC;gBACxD,MAAM;YACR,KAAK,YAAY,CAAC,QAAQ;gBACxB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,EAA9B,CAA8B,CAAC,CAAC;gBACvD,MAAM;YACR,KAAK,YAAY,CAAC,SAAS;gBACzB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,EAA/B,CAA+B,CAAC,CAAC;gBACxD,MAAM;YACR,KAAK,YAAY,CAAC,WAAW;gBAC3B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAjC,CAAiC,CAAC,CAAC;gBAC1D,MAAM;YACR,KAAK,YAAY,CAAC,QAAQ;gBACxB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,EAA9B,CAA8B,CAAC,CAAC;gBACvD,MAAM;YACR,KAAK,YAAY,CAAC,gBAAgB;gBAChC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAtC,CAAsC,CAAC,CAAC;gBAC/D,MAAM;YACR,KAAK,YAAY,CAAC,WAAW;gBAC3B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAjC,CAAiC,CAAC,CAAC;gBAC1D,MAAM;YACR,KAAK,YAAY,CAAC,aAAa;gBAC7B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAnC,CAAmC,CAAC,CAAC;gBAC5D,MAAM;SACT;IACH,CAAC;;;;;IAEO,kDAAoB;;;;IAA5B,UAA6B,MAAe;QAC1C,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;SAC1D;IACH,CAAC;;;;IAEO,0CAAY;;;IAApB;QACE,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;;gBA5OF,SAAS,SAAC;oBACT,QAAQ,EAAE,oBAAoB;iBAC/B;;;;gBAXY,UAAU;gBACgB,MAAM;;;0BAY1C,KAAK;wBACL,KAAK;0BACL,KAAK;2BACL,KAAK;wBAML,KAAK;6BACL,KAAK;8BACL,KAAK;8BACL,KAAK;qCAML,KAAK;4BAGL,MAAM;6BACN,MAAM;gCACN,MAAM;iCACN,MAAM;+BACN,MAAM;iCACN,MAAM;gCACN,MAAM;iCACN,MAAM;mCACN,MAAM;gCACN,MAAM;wCACN,MAAM;mCACN,MAAM;qCACN,MAAM;iCA4BN,YAAY,SAAC,eAAe,EAAE,CAAC,QAAQ,CAAC;;IA4K3C,0BAAC;CAAA,AA7OD,IA6OC;SA1OY,mBAAmB;;;IAC9B,sCAA+B;;IAC/B,oCAAuB;;IACvB,sCAA0B;;IAC1B,uCAKE;;IACF,oCAA6B;;IAC7B,yCAA2B;;IAC3B,0CAAiC;;IACjC,0CAA6B;;;;;;IAM7B,iDAAmC;;IAGnC,wCAAkD;;IAClD,yCAA+C;;IAC/C,4CAAkD;;IAClD,6CAAmD;;IACnD,2CAAiD;;IACjD,6CAAmD;;IACnD,4CAAkD;;IAClD,6CAAmD;;IACnD,+CAAqD;;IACrD,4CAAkD;;IAClD,oDAA0D;;IAC1D,+CAAqD;;IACrD,iDAAuD;;IAEvD,qCAAwB;;IACxB,iDAA+B;;IAC/B,kDAAgC;;IAChC,iDAAmC;;IACnC,uCAAuC;;IACvC,yCAAiC;;IAErB,iCAAsB;;IAAE,sCAAuB","sourcesContent":["import {\r\n  Directive, ElementRef, Renderer, Input, Output, HostListener, EventEmitter,\r\n  OnChanges, OnDestroy, SimpleChanges, NgZone, DoCheck, AfterViewInit\r\n} from '@angular/core';\r\nimport { ChangeFilter } from './change-filter';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { init, ECharts, EChartOption } from 'echarts';\r\nimport { EChartEvents } from './echart-events';\r\n\r\n@Directive({\r\n  selector: 'echarts, [echarts]',\r\n})\r\nexport class NgxEchartsDirective implements OnChanges, OnDestroy, DoCheck, AfterViewInit {\r\n  @Input() options: EChartOption;\r\n  @Input() theme: string;\r\n  @Input() loading: boolean;\r\n  @Input() initOpts: {\r\n    devicePixelRatio?: number\r\n    renderer?: string\r\n    width?: number | string\r\n    height?: number | string\r\n  };\r\n  @Input() merge: EChartOption;\r\n  @Input() autoResize = true;\r\n  @Input() loadingType = 'default';\r\n  @Input() loadingOpts: object;\r\n\r\n  /**\r\n   * Whether to register event handlers on echartInstance. Default is true.\r\n   * Use it to avoid unwanted change detection, if you want to optimize the performance.\r\n   */\r\n  @Input() detectEventChanges = true;\r\n\r\n  // chart events:\r\n  @Output() chartInit = new EventEmitter<ECharts>();\r\n  @Output() chartClick = new EventEmitter<any>();\r\n  @Output() chartDblClick = new EventEmitter<any>();\r\n  @Output() chartMouseDown = new EventEmitter<any>();\r\n  @Output() chartMouseUp = new EventEmitter<any>();\r\n  @Output() chartMouseOver = new EventEmitter<any>();\r\n  @Output() chartMouseOut = new EventEmitter<any>();\r\n  @Output() chartGlobalOut = new EventEmitter<any>();\r\n  @Output() chartContextMenu = new EventEmitter<any>();\r\n  @Output() chartDataZoom = new EventEmitter<any>();\r\n  @Output() chartMapSelectChanged = new EventEmitter<any>();\r\n  @Output() chartMapSelected = new EventEmitter<any>();\r\n  @Output() chartMapUnselected = new EventEmitter<any>();\r\n\r\n  private _chart: ECharts;\r\n  private currentOffsetWidth = 0;\r\n  private currentOffsetHeight = 0;\r\n  private currentWindowWidth: number;\r\n  private _resize$ = new Subject<void>();\r\n  private _resizeSub: Subscription;\r\n\r\n  constructor(private el: ElementRef, private _ngZone: NgZone) { }\r\n\r\n  private createChart() {\r\n    this.currentWindowWidth = window.innerWidth;\r\n    this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n    this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n    const dom = this.el.nativeElement;\r\n\r\n    if (window && window.getComputedStyle) {\r\n      const prop = window.getComputedStyle(dom, null).getPropertyValue('height');\r\n      if ((!prop || prop === '0px') &&\r\n        (!dom.style.height || dom.style.height === '0px')) {\r\n        dom.style.height = '400px';\r\n      }\r\n    }\r\n\r\n    return this._ngZone.runOutsideAngular(() => init(dom, this.theme || undefined, this.initOpts || undefined));\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize(event: Event) {\r\n    const target = event.target as Window;\r\n\r\n    if (this.autoResize && target.innerWidth !== this.currentWindowWidth) {\r\n      this.currentWindowWidth = target.innerWidth;\r\n      this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n      this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      this._resize$.next();\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const filter = ChangeFilter.of(changes);\r\n    filter.notFirstAndEmpty<any>('options').subscribe(opt => this.onOptionsChange(opt));\r\n    filter.notFirstAndEmpty<any>('merge').subscribe(opt => this.setOption(opt));\r\n    filter.has<boolean>('loading').subscribe(v => this.toggleLoading(!!v));\r\n    filter.notFirst<boolean>('detectEventChanges').subscribe(v => this.toggleEventDetectors(!!v));\r\n    filter.notFirst<string>('theme').subscribe(() => this.refreshChart());\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this._resizeSub) {\r\n      this._resizeSub.unsubscribe();\r\n      this._resizeSub = null;\r\n    }\r\n\r\n    if (this._chart) {\r\n      this._chart.dispose();\r\n      this._chart = null;\r\n    }\r\n  }\r\n\r\n  ngDoCheck() {\r\n    // No heavy work in DoCheck!\r\n    if (this._chart && this.autoResize) {\r\n      const offsetWidth = this.el.nativeElement.offsetWidth;\r\n      const offsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      if (this.currentOffsetWidth !== offsetWidth || this.currentOffsetHeight !== offsetHeight) {\r\n        this.currentOffsetWidth = offsetWidth;\r\n        this.currentOffsetHeight = offsetHeight;\r\n        this._resize$.next();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    setTimeout(() => this.initChart());\r\n  }\r\n\r\n  private initChart() {\r\n    this.onOptionsChange(this.options);\r\n\r\n    if (this.merge && this._chart) {\r\n      this.setOption(this.merge);\r\n    }\r\n  }\r\n\r\n  private onOptionsChange(opt: EChartOption) {\r\n    if (opt) {\r\n      if (!this._chart) {\r\n        this._chart = this.createChart();\r\n\r\n        // subscribe to _resize$ and debounced\r\n        this._resizeSub = this._resize$.pipe(debounceTime(50)).subscribe(() => {\r\n          if (this._chart) {\r\n            this._chart.resize();\r\n          }\r\n        });\r\n\r\n        // output echart instance:\r\n        this.chartInit.emit(this._chart);\r\n\r\n        // register events:\r\n        if (this.detectEventChanges) {\r\n          this.registerEvents();\r\n        }\r\n      }\r\n\r\n      this._chart.setOption(this.options, true);\r\n    }\r\n  }\r\n\r\n  private registerEvents() {\r\n    if (this._chart) {\r\n      const events = EChartEvents.All;\r\n      for (let i = 0, len = events.length; i < len; i++) {\r\n        this._chart.on(events[i], this.eventHandler, this);\r\n      }\r\n    }\r\n  }\r\n\r\n  private unregisterEvents() {\r\n    if (this._chart) {\r\n      const events = EChartEvents.All;\r\n      for (let i = 0, len = events.length; i < len; i++) {\r\n        this._chart.off(events[i], this.eventHandler);\r\n      }\r\n    }\r\n  }\r\n\r\n  clear() {\r\n    if (this._chart) {\r\n      this._chart.clear();\r\n    }\r\n  }\r\n\r\n  toggleLoading(loading: boolean) {\r\n    if (this._chart) {\r\n      loading ? this._chart.showLoading(this.loadingType, this.loadingOpts) : this._chart.hideLoading();\r\n    }\r\n  }\r\n\r\n  setOption(option: any, opts?: any) {\r\n    if (this._chart) {\r\n      this._chart.setOption(option, opts);\r\n    }\r\n  }\r\n\r\n  private eventHandler(event) {\r\n    switch (event.type) {\r\n      case EChartEvents.Click:\r\n        this._ngZone.run(() => this.chartClick.emit(event));\r\n        break;\r\n      case EChartEvents.DblClick:\r\n        this._ngZone.run(() => this.chartDblClick.emit(event));\r\n        break;\r\n      case EChartEvents.MouseDown:\r\n        this._ngZone.run(() => this.chartMouseDown.emit(event));\r\n        break;\r\n      case EChartEvents.MouseUp:\r\n        this._ngZone.run(() => this.chartMouseUp.emit(event));\r\n        break;\r\n      case EChartEvents.MouseOver:\r\n        this._ngZone.run(() => this.chartMouseOver.emit(event));\r\n        break;\r\n      case EChartEvents.MouseOut:\r\n        this._ngZone.run(() => this.chartMouseOut.emit(event));\r\n        break;\r\n      case EChartEvents.GlobalOut:\r\n        this._ngZone.run(() => this.chartGlobalOut.emit(event));\r\n        break;\r\n      case EChartEvents.ContextMenu:\r\n        this._ngZone.run(() => this.chartContextMenu.emit(event));\r\n        break;\r\n      case EChartEvents.DataZoom:\r\n        this._ngZone.run(() => this.chartDataZoom.emit(event));\r\n        break;\r\n      case EChartEvents.MapSelectChanged:\r\n        this._ngZone.run(() => this.chartMapSelectChanged.emit(event));\r\n        break;\r\n      case EChartEvents.MapSelected:\r\n        this._ngZone.run(() => this.chartMapSelected.emit(event));\r\n        break;\r\n      case EChartEvents.MapUnselected:\r\n        this._ngZone.run(() => this.chartMapUnselected.emit(event));\r\n        break;\r\n    }\r\n  }\r\n\r\n  private toggleEventDetectors(detect: boolean) {\r\n    if (this._chart) {\r\n      detect ? this.registerEvents() : this.unregisterEvents();\r\n    }\r\n  }\r\n\r\n  private refreshChart() {\r\n    this.ngOnDestroy();\r\n    this.initChart();\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-echarts.directive.js","sourceRoot":"ng://ngx-echarts/","sources":["lib/ngx-echarts.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, DoCheck, ElementRef, EventEmitter, Input, NgZone, OnChanges, OnDestroy, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { EChartOption, ECharts, init } from 'echarts';\r\nimport { fromEvent, Observable, Subscription } from 'rxjs';\r\nimport { debounceTime, switchMap } from 'rxjs/operators';\r\nimport { ChangeFilter } from './change-filter';\r\n\r\n@Directive({\r\n  selector: 'echarts, [echarts]',\r\n})\r\nexport class NgxEchartsDirective implements OnChanges, OnDestroy, OnInit, DoCheck, AfterViewInit {\r\n  @Input() options: EChartOption;\r\n  @Input() theme: string;\r\n  @Input() loading: boolean;\r\n  @Input() initOpts: {\r\n    devicePixelRatio?: number\r\n    renderer?: string\r\n    width?: number | string\r\n    height?: number | string\r\n  };\r\n  @Input() merge: EChartOption;\r\n  @Input() autoResize = true;\r\n  @Input() loadingType = 'default';\r\n  @Input() loadingOpts: object;\r\n  @Input() detectEventChanges = true; // deprecated, left for compatibility reasons to avoid triggering major version\r\n\r\n  // ngx-echarts events\r\n  @Output() chartInit = new EventEmitter<ECharts>();\r\n\r\n  // echarts mouse events\r\n  @Output() chartClick = this.createLazyEvent('click');\r\n  @Output() chartDblClick = this.createLazyEvent('dblclick');\r\n  @Output() chartMouseDown = this.createLazyEvent('mousedown');\r\n  @Output() chartMouseMove = this.createLazyEvent('mousemove');\r\n  @Output() chartMouseUp = this.createLazyEvent('mouseup');\r\n  @Output() chartMouseOver = this.createLazyEvent('mouseover');\r\n  @Output() chartMouseOut = this.createLazyEvent('mouseout');\r\n  @Output() chartGlobalOut = this.createLazyEvent('globalout');\r\n  @Output() chartContextMenu = this.createLazyEvent('contextmenu');\r\n\r\n  // echarts mouse events\r\n  @Output() chartLegendSelectChanged = this.createLazyEvent('legendselectchanged');\r\n  @Output() chartLegendSelected = this.createLazyEvent('legendselected');\r\n  @Output() chartLegendUnselected = this.createLazyEvent('legendunselected');\r\n  @Output() chartLegendScroll = this.createLazyEvent('legendscroll');\r\n  @Output() chartDataZoom = this.createLazyEvent('datazoom');\r\n  @Output() chartDataRangeSelected = this.createLazyEvent('datarangeselected');\r\n  @Output() chartTimelineChanged = this.createLazyEvent('timelinechanged');\r\n  @Output() chartTimelinePlayChanged = this.createLazyEvent('timelineplaychanged');\r\n  @Output() chartRestore = this.createLazyEvent('restore');\r\n  @Output() chartDataViewChanged = this.createLazyEvent('dataviewchanged');\r\n  @Output() chartMagicTypeChanged = this.createLazyEvent('magictypechanged');\r\n  @Output() chartPieSelectChanged = this.createLazyEvent('pieselectchanged');\r\n  @Output() chartPieSelected = this.createLazyEvent('pieselected');\r\n  @Output() chartPieUnselected = this.createLazyEvent('pieunselected');\r\n  @Output() chartMapSelectChanged = this.createLazyEvent('mapselectchanged');\r\n  @Output() chartMapSelected = this.createLazyEvent('mapselected');\r\n  @Output() chartMapUnselected = this.createLazyEvent('mapunselected');\r\n  @Output() chartAxisAreaSelected = this.createLazyEvent('axisareaselected');\r\n  @Output() chartFocusNodeAdjacency = this.createLazyEvent('focusnodeadjacency');\r\n  @Output() chartUnfocusNodeAdjacency = this.createLazyEvent('unfocusnodeadjacency');\r\n  @Output() chartBrush = this.createLazyEvent('brush');\r\n  @Output() chartBrushSelected = this.createLazyEvent('brushselected');\r\n  @Output() chartRendered = this.createLazyEvent('rendered');\r\n  @Output() chartFinished = this.createLazyEvent('finished');\r\n\r\n  private chart: ECharts;\r\n  private currentOffsetWidth = 0;\r\n  private currentOffsetHeight = 0;\r\n  private currentWindowWidth: number;\r\n  private resizeSub: Subscription;\r\n\r\n  constructor(private el: ElementRef, private ngZone: NgZone) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const filter = ChangeFilter.of(changes);\r\n    filter.notFirstAndEmpty<any>('options').subscribe(opt => this.onOptionsChange(opt));\r\n    filter.notFirstAndEmpty<any>('merge').subscribe(opt => this.setOption(opt));\r\n    filter.has<boolean>('loading').subscribe(v => this.toggleLoading(!!v));\r\n    filter.notFirst<string>('theme').subscribe(() => this.refreshChart());\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.resizeSub = fromEvent(window, 'resize').pipe(debounceTime(50)).subscribe(() => {\r\n      if (this.autoResize && window.innerWidth !== this.currentWindowWidth) {\r\n        this.currentWindowWidth = window.innerWidth;\r\n        this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n        this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n        this.resize();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.resizeSub.unsubscribe();\r\n    this.dispose();\r\n  }\r\n\r\n  ngDoCheck() {\r\n    // No heavy work in DoCheck!\r\n    if (this.chart && this.autoResize) {\r\n      const offsetWidth = this.el.nativeElement.offsetWidth;\r\n      const offsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      if (this.currentOffsetWidth !== offsetWidth || this.currentOffsetHeight !== offsetHeight) {\r\n        this.currentOffsetWidth = offsetWidth;\r\n        this.currentOffsetHeight = offsetHeight;\r\n        this.resize();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    setTimeout(() => this.initChart());\r\n  }\r\n\r\n  private dispose() {\r\n    if (this.chart) {\r\n      this.chart.dispose();\r\n      this.chart = null;\r\n    }\r\n  }\r\n\r\n  private resize() {\r\n    if (this.chart) {\r\n      this.chart.resize();\r\n    }\r\n  }\r\n\r\n  private toggleLoading(loading: boolean) {\r\n    if (this.chart) {\r\n      loading ? this.chart.showLoading(this.loadingType, this.loadingOpts) : this.chart.hideLoading();\r\n    }\r\n  }\r\n\r\n  private setOption(option: any, opts?: any) {\r\n    if (this.chart) {\r\n      this.chart.setOption(option, opts);\r\n    }\r\n  }\r\n\r\n  private refreshChart() {\r\n    this.dispose();\r\n    this.initChart();\r\n  }\r\n\r\n  private createChart() {\r\n    this.currentWindowWidth = window.innerWidth;\r\n    this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n    this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n    const dom = this.el.nativeElement;\r\n\r\n    if (window && window.getComputedStyle) {\r\n      const prop = window.getComputedStyle(dom, null).getPropertyValue('height');\r\n      if ((!prop || prop === '0px') &&\r\n        (!dom.style.height || dom.style.height === '0px')) {\r\n        dom.style.height = '400px';\r\n      }\r\n    }\r\n\r\n    return this.ngZone.runOutsideAngular(() => init(dom, this.theme, this.initOpts));\r\n  }\r\n\r\n  private initChart() {\r\n    this.onOptionsChange(this.options);\r\n\r\n    if (this.merge && this.chart) {\r\n      this.setOption(this.merge);\r\n    }\r\n  }\r\n\r\n  private onOptionsChange(opt: EChartOption) {\r\n    if (opt) {\r\n      if (!this.chart) {\r\n        this.chart = this.createChart();\r\n        this.chartInit.emit(this.chart);\r\n      }\r\n\r\n      this.chart.setOption(this.options, true);\r\n    }\r\n  }\r\n\r\n  // allows to lazily bind to only those events that are requested through the `@Output` by parent components\r\n  // see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info\r\n  private createLazyEvent<T>(eventName: string): EventEmitter<T> {\r\n    return this.chartInit.pipe(\r\n      switchMap((chart: ECharts) => new Observable(observer => {\r\n        chart.on(eventName, (data: T) => this.ngZone.run(() => observer.next(data)));\r\n        return null; // no need to react on unsubscribe as long as the `dispose()` is called in ngOnDestroy\r\n      }))\r\n    ) as EventEmitter<T>;\r\n  }\r\n\r\n}\r\n"]}

@@ -1,5 +0,5 @@

import { of, empty, Subject } from 'rxjs';
import { Directive, ElementRef, Input, Output, HostListener, EventEmitter, NgZone, NgModule } from '@angular/core';
import { debounceTime } from 'rxjs/operators';
import { of, empty, fromEvent, Observable } from 'rxjs';
import { Directive, ElementRef, EventEmitter, Input, NgZone, Output, NgModule } from '@angular/core';
import { init } from 'echarts';
import { debounceTime, switchMap } from 'rxjs/operators';

@@ -86,102 +86,55 @@ /**

*/
class EChartEvents {
}
EChartEvents.Click = 'click';
EChartEvents.DblClick = 'dblclick';
EChartEvents.MouseDown = 'mousedown';
EChartEvents.MouseUp = 'mouseup';
EChartEvents.MouseOver = 'mouseover';
EChartEvents.MouseOut = 'mouseout';
EChartEvents.GlobalOut = 'globalout';
EChartEvents.ContextMenu = 'contextmenu';
EChartEvents.DataZoom = 'datazoom';
EChartEvents.MapSelectChanged = 'mapselectchanged';
EChartEvents.MapSelected = 'mapselected';
EChartEvents.MapUnselected = 'mapunselected';
EChartEvents.All = [
EChartEvents.Click,
EChartEvents.DblClick,
EChartEvents.MouseDown,
EChartEvents.MouseUp,
EChartEvents.MouseOver,
EChartEvents.MouseOut,
EChartEvents.GlobalOut,
EChartEvents.ContextMenu,
EChartEvents.DataZoom,
EChartEvents.MapSelectChanged,
EChartEvents.MapSelected,
EChartEvents.MapUnselected,
];
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
class NgxEchartsDirective {
/**
* @param {?} el
* @param {?} _ngZone
* @param {?} ngZone
*/
constructor(el, _ngZone) {
constructor(el, ngZone) {
this.el = el;
this._ngZone = _ngZone;
this.ngZone = ngZone;
this.autoResize = true;
this.loadingType = 'default';
/**
* Whether to register event handlers on echartInstance. Default is true.
* Use it to avoid unwanted change detection, if you want to optimize the performance.
*/
this.detectEventChanges = true;
// chart events:
this.detectEventChanges = true; // deprecated, left for compatibility reasons to avoid triggering major version
// deprecated, left for compatibility reasons to avoid triggering major version
// ngx-echarts events
this.chartInit = new EventEmitter();
this.chartClick = new EventEmitter();
this.chartDblClick = new EventEmitter();
this.chartMouseDown = new EventEmitter();
this.chartMouseUp = new EventEmitter();
this.chartMouseOver = new EventEmitter();
this.chartMouseOut = new EventEmitter();
this.chartGlobalOut = new EventEmitter();
this.chartContextMenu = new EventEmitter();
this.chartDataZoom = new EventEmitter();
this.chartMapSelectChanged = new EventEmitter();
this.chartMapSelected = new EventEmitter();
this.chartMapUnselected = new EventEmitter();
// echarts mouse events
this.chartClick = this.createLazyEvent('click');
this.chartDblClick = this.createLazyEvent('dblclick');
this.chartMouseDown = this.createLazyEvent('mousedown');
this.chartMouseMove = this.createLazyEvent('mousemove');
this.chartMouseUp = this.createLazyEvent('mouseup');
this.chartMouseOver = this.createLazyEvent('mouseover');
this.chartMouseOut = this.createLazyEvent('mouseout');
this.chartGlobalOut = this.createLazyEvent('globalout');
this.chartContextMenu = this.createLazyEvent('contextmenu');
// echarts mouse events
this.chartLegendSelectChanged = this.createLazyEvent('legendselectchanged');
this.chartLegendSelected = this.createLazyEvent('legendselected');
this.chartLegendUnselected = this.createLazyEvent('legendunselected');
this.chartLegendScroll = this.createLazyEvent('legendscroll');
this.chartDataZoom = this.createLazyEvent('datazoom');
this.chartDataRangeSelected = this.createLazyEvent('datarangeselected');
this.chartTimelineChanged = this.createLazyEvent('timelinechanged');
this.chartTimelinePlayChanged = this.createLazyEvent('timelineplaychanged');
this.chartRestore = this.createLazyEvent('restore');
this.chartDataViewChanged = this.createLazyEvent('dataviewchanged');
this.chartMagicTypeChanged = this.createLazyEvent('magictypechanged');
this.chartPieSelectChanged = this.createLazyEvent('pieselectchanged');
this.chartPieSelected = this.createLazyEvent('pieselected');
this.chartPieUnselected = this.createLazyEvent('pieunselected');
this.chartMapSelectChanged = this.createLazyEvent('mapselectchanged');
this.chartMapSelected = this.createLazyEvent('mapselected');
this.chartMapUnselected = this.createLazyEvent('mapunselected');
this.chartAxisAreaSelected = this.createLazyEvent('axisareaselected');
this.chartFocusNodeAdjacency = this.createLazyEvent('focusnodeadjacency');
this.chartUnfocusNodeAdjacency = this.createLazyEvent('unfocusnodeadjacency');
this.chartBrush = this.createLazyEvent('brush');
this.chartBrushSelected = this.createLazyEvent('brushselected');
this.chartRendered = this.createLazyEvent('rendered');
this.chartFinished = this.createLazyEvent('finished');
this.currentOffsetWidth = 0;
this.currentOffsetHeight = 0;
this._resize$ = new Subject();
}
/**
* @return {?}
*/
createChart() {
this.currentWindowWidth = window.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
/** @type {?} */
const dom = this.el.nativeElement;
if (window && window.getComputedStyle) {
/** @type {?} */
const prop = window.getComputedStyle(dom, null).getPropertyValue('height');
if ((!prop || prop === '0px') &&
(!dom.style.height || dom.style.height === '0px')) {
dom.style.height = '400px';
}
}
return this._ngZone.runOutsideAngular(() => init(dom, this.theme || undefined, this.initOpts || undefined));
}
/**
* @param {?} event
* @return {?}
*/
onWindowResize(event) {
/** @type {?} */
const target = (/** @type {?} */ (event.target));
if (this.autoResize && target.innerWidth !== this.currentWindowWidth) {
this.currentWindowWidth = target.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
this._resize$.next();
}
}
/**
* @param {?} changes

@@ -196,3 +149,2 @@ * @return {?}

filter.has('loading').subscribe(v => this.toggleLoading(!!v));
filter.notFirst('detectEventChanges').subscribe(v => this.toggleEventDetectors(!!v));
filter.notFirst('theme').subscribe(() => this.refreshChart());

@@ -203,11 +155,18 @@ }

*/
ngOnInit() {
this.resizeSub = fromEvent(window, 'resize').pipe(debounceTime(50)).subscribe(() => {
if (this.autoResize && window.innerWidth !== this.currentWindowWidth) {
this.currentWindowWidth = window.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
this.resize();
}
});
}
/**
* @return {?}
*/
ngOnDestroy() {
if (this._resizeSub) {
this._resizeSub.unsubscribe();
this._resizeSub = null;
}
if (this._chart) {
this._chart.dispose();
this._chart = null;
}
this.resizeSub.unsubscribe();
this.dispose();
}

@@ -219,3 +178,3 @@ /**

// No heavy work in DoCheck!
if (this._chart && this.autoResize) {
if (this.chart && this.autoResize) {
/** @type {?} */

@@ -228,3 +187,3 @@ const offsetWidth = this.el.nativeElement.offsetWidth;

this.currentOffsetHeight = offsetHeight;
this._resize$.next();
this.resize();
}

@@ -242,54 +201,33 @@ }

*/
initChart() {
this.onOptionsChange(this.options);
if (this.merge && this._chart) {
this.setOption(this.merge);
dispose() {
if (this.chart) {
this.chart.dispose();
this.chart = null;
}
}
/**
* @param {?} opt
* @return {?}
*/
onOptionsChange(opt) {
if (opt) {
if (!this._chart) {
this._chart = this.createChart();
// subscribe to _resize$ and debounced
this._resizeSub = this._resize$.pipe(debounceTime(50)).subscribe(() => {
if (this._chart) {
this._chart.resize();
}
});
// output echart instance:
this.chartInit.emit(this._chart);
// register events:
if (this.detectEventChanges) {
this.registerEvents();
}
}
this._chart.setOption(this.options, true);
resize() {
if (this.chart) {
this.chart.resize();
}
}
/**
* @param {?} loading
* @return {?}
*/
registerEvents() {
if (this._chart) {
/** @type {?} */
const events = EChartEvents.All;
for (let i = 0, len = events.length; i < len; i++) {
this._chart.on(events[i], this.eventHandler, this);
}
toggleLoading(loading) {
if (this.chart) {
loading ? this.chart.showLoading(this.loadingType, this.loadingOpts) : this.chart.hideLoading();
}
}
/**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
unregisterEvents() {
if (this._chart) {
/** @type {?} */
const events = EChartEvents.All;
for (let i = 0, len = events.length; i < len; i++) {
this._chart.off(events[i], this.eventHandler);
}
setOption(option, opts) {
if (this.chart) {
this.chart.setOption(option, opts);
}

@@ -300,86 +238,60 @@ }

*/
clear() {
if (this._chart) {
this._chart.clear();
}
refreshChart() {
this.dispose();
this.initChart();
}
/**
* @param {?} loading
* @return {?}
*/
toggleLoading(loading) {
if (this._chart) {
loading ? this._chart.showLoading(this.loadingType, this.loadingOpts) : this._chart.hideLoading();
createChart() {
this.currentWindowWidth = window.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
/** @type {?} */
const dom = this.el.nativeElement;
if (window && window.getComputedStyle) {
/** @type {?} */
const prop = window.getComputedStyle(dom, null).getPropertyValue('height');
if ((!prop || prop === '0px') &&
(!dom.style.height || dom.style.height === '0px')) {
dom.style.height = '400px';
}
}
return this.ngZone.runOutsideAngular(() => init(dom, this.theme, this.initOpts));
}
/**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
setOption(option, opts) {
if (this._chart) {
this._chart.setOption(option, opts);
initChart() {
this.onOptionsChange(this.options);
if (this.merge && this.chart) {
this.setOption(this.merge);
}
}
/**
* @param {?} event
* @param {?} opt
* @return {?}
*/
eventHandler(event) {
switch (event.type) {
case EChartEvents.Click:
this._ngZone.run(() => this.chartClick.emit(event));
break;
case EChartEvents.DblClick:
this._ngZone.run(() => this.chartDblClick.emit(event));
break;
case EChartEvents.MouseDown:
this._ngZone.run(() => this.chartMouseDown.emit(event));
break;
case EChartEvents.MouseUp:
this._ngZone.run(() => this.chartMouseUp.emit(event));
break;
case EChartEvents.MouseOver:
this._ngZone.run(() => this.chartMouseOver.emit(event));
break;
case EChartEvents.MouseOut:
this._ngZone.run(() => this.chartMouseOut.emit(event));
break;
case EChartEvents.GlobalOut:
this._ngZone.run(() => this.chartGlobalOut.emit(event));
break;
case EChartEvents.ContextMenu:
this._ngZone.run(() => this.chartContextMenu.emit(event));
break;
case EChartEvents.DataZoom:
this._ngZone.run(() => this.chartDataZoom.emit(event));
break;
case EChartEvents.MapSelectChanged:
this._ngZone.run(() => this.chartMapSelectChanged.emit(event));
break;
case EChartEvents.MapSelected:
this._ngZone.run(() => this.chartMapSelected.emit(event));
break;
case EChartEvents.MapUnselected:
this._ngZone.run(() => this.chartMapUnselected.emit(event));
break;
onOptionsChange(opt) {
if (opt) {
if (!this.chart) {
this.chart = this.createChart();
this.chartInit.emit(this.chart);
}
this.chart.setOption(this.options, true);
}
}
// allows to lazily bind to only those events that are requested through the `@Output` by parent components
// see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info
/**
* @param {?} detect
* @template T
* @param {?} eventName
* @return {?}
*/
toggleEventDetectors(detect) {
if (this._chart) {
detect ? this.registerEvents() : this.unregisterEvents();
}
createLazyEvent(eventName) {
return (/** @type {?} */ (this.chartInit.pipe(switchMap((chart) => new Observable(observer => {
chart.on(eventName, (data) => this.ngZone.run(() => observer.next(data)));
return null; // no need to react on unsubscribe as long as the `dispose()` is called in ngOnDestroy
})))));
}
/**
* @return {?}
*/
refreshChart() {
this.ngOnDestroy();
this.initChart();
}
}

@@ -410,2 +322,3 @@ NgxEchartsDirective.decorators = [

chartMouseDown: [{ type: Output }],
chartMouseMove: [{ type: Output }],
chartMouseUp: [{ type: Output }],

@@ -416,7 +329,26 @@ chartMouseOver: [{ type: Output }],

chartContextMenu: [{ type: Output }],
chartLegendSelectChanged: [{ type: Output }],
chartLegendSelected: [{ type: Output }],
chartLegendUnselected: [{ type: Output }],
chartLegendScroll: [{ type: Output }],
chartDataZoom: [{ type: Output }],
chartDataRangeSelected: [{ type: Output }],
chartTimelineChanged: [{ type: Output }],
chartTimelinePlayChanged: [{ type: Output }],
chartRestore: [{ type: Output }],
chartDataViewChanged: [{ type: Output }],
chartMagicTypeChanged: [{ type: Output }],
chartPieSelectChanged: [{ type: Output }],
chartPieSelected: [{ type: Output }],
chartPieUnselected: [{ type: Output }],
chartMapSelectChanged: [{ type: Output }],
chartMapSelected: [{ type: Output }],
chartMapUnselected: [{ type: Output }],
onWindowResize: [{ type: HostListener, args: ['window:resize', ['$event'],] }]
chartAxisAreaSelected: [{ type: Output }],
chartFocusNodeAdjacency: [{ type: Output }],
chartUnfocusNodeAdjacency: [{ type: Output }],
chartBrush: [{ type: Output }],
chartBrushSelected: [{ type: Output }],
chartRendered: [{ type: Output }],
chartFinished: [{ type: Output }]
};

@@ -454,2 +386,2 @@

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-echarts.js.map","sources":["ng://ngx-echarts/lib/change-filter.ts","ng://ngx-echarts/lib/echart-events.ts","ng://ngx-echarts/lib/ngx-echarts.directive.ts","ng://ngx-echarts/lib/ngx-echarts.module.ts"],"sourcesContent":["import { SimpleChanges } from '@angular/core';\r\nimport { Observable, of, empty } from 'rxjs';\r\n\r\nexport class ChangeFilter {\r\n  constructor(private _changes: SimpleChanges) { }\r\n\r\n  static of(changes: SimpleChanges) {\r\n    return new ChangeFilter(changes);\r\n  }\r\n\r\n  notEmpty<T>(key: string): Observable<T> {\r\n    if (this._changes[key]) {\r\n      const value: T = this._changes[key].currentValue;\r\n\r\n      if (value !== undefined && value !== null) {\r\n        return of(value);\r\n      }\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  has<T>(key: string): Observable<T> {\r\n    if (this._changes[key]) {\r\n      const value: T = this._changes[key].currentValue;\r\n      return of(value);\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  notFirst<T>(key: string): Observable<T> {\r\n    if (this._changes[key] && !this._changes[key].isFirstChange()) {\r\n      const value: T = this._changes[key].currentValue;\r\n      return of(value);\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  notFirstAndEmpty<T>(key: string): Observable<T> {\r\n    if (this._changes[key] && !this._changes[key].isFirstChange()) {\r\n      const value: T = this._changes[key].currentValue;\r\n\r\n      if (value !== undefined && value !== null) {\r\n        return of(value);\r\n      }\r\n    }\r\n    return empty();\r\n  }\r\n}\r\n","export class EChartEvents {\r\n  static Click = 'click';\r\n  static DblClick = 'dblclick';\r\n  static MouseDown = 'mousedown';\r\n  static MouseUp = 'mouseup';\r\n  static MouseOver = 'mouseover';\r\n  static MouseOut = 'mouseout';\r\n  static GlobalOut = 'globalout';\r\n  static ContextMenu = 'contextmenu';\r\n  static DataZoom = 'datazoom';\r\n  static MapSelectChanged = 'mapselectchanged';\r\n  static MapSelected = 'mapselected';\r\n  static MapUnselected = 'mapunselected';\r\n\r\n  static All = [\r\n    EChartEvents.Click,\r\n    EChartEvents.DblClick,\r\n    EChartEvents.MouseDown,\r\n    EChartEvents.MouseUp,\r\n    EChartEvents.MouseOver,\r\n    EChartEvents.MouseOut,\r\n    EChartEvents.GlobalOut,\r\n    EChartEvents.ContextMenu,\r\n    EChartEvents.DataZoom,\r\n    EChartEvents.MapSelectChanged,\r\n    EChartEvents.MapSelected,\r\n    EChartEvents.MapUnselected,\r\n  ];\r\n}\r\n","import {\r\n  Directive, ElementRef, Renderer, Input, Output, HostListener, EventEmitter,\r\n  OnChanges, OnDestroy, SimpleChanges, NgZone, DoCheck, AfterViewInit\r\n} from '@angular/core';\r\nimport { ChangeFilter } from './change-filter';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { init, ECharts, EChartOption } from 'echarts';\r\nimport { EChartEvents } from './echart-events';\r\n\r\n@Directive({\r\n  selector: 'echarts, [echarts]',\r\n})\r\nexport class NgxEchartsDirective implements OnChanges, OnDestroy, DoCheck, AfterViewInit {\r\n  @Input() options: EChartOption;\r\n  @Input() theme: string;\r\n  @Input() loading: boolean;\r\n  @Input() initOpts: {\r\n    devicePixelRatio?: number\r\n    renderer?: string\r\n    width?: number | string\r\n    height?: number | string\r\n  };\r\n  @Input() merge: EChartOption;\r\n  @Input() autoResize = true;\r\n  @Input() loadingType = 'default';\r\n  @Input() loadingOpts: object;\r\n\r\n  /**\r\n   * Whether to register event handlers on echartInstance. Default is true.\r\n   * Use it to avoid unwanted change detection, if you want to optimize the performance.\r\n   */\r\n  @Input() detectEventChanges = true;\r\n\r\n  // chart events:\r\n  @Output() chartInit = new EventEmitter<ECharts>();\r\n  @Output() chartClick = new EventEmitter<any>();\r\n  @Output() chartDblClick = new EventEmitter<any>();\r\n  @Output() chartMouseDown = new EventEmitter<any>();\r\n  @Output() chartMouseUp = new EventEmitter<any>();\r\n  @Output() chartMouseOver = new EventEmitter<any>();\r\n  @Output() chartMouseOut = new EventEmitter<any>();\r\n  @Output() chartGlobalOut = new EventEmitter<any>();\r\n  @Output() chartContextMenu = new EventEmitter<any>();\r\n  @Output() chartDataZoom = new EventEmitter<any>();\r\n  @Output() chartMapSelectChanged = new EventEmitter<any>();\r\n  @Output() chartMapSelected = new EventEmitter<any>();\r\n  @Output() chartMapUnselected = new EventEmitter<any>();\r\n\r\n  private _chart: ECharts;\r\n  private currentOffsetWidth = 0;\r\n  private currentOffsetHeight = 0;\r\n  private currentWindowWidth: number;\r\n  private _resize$ = new Subject<void>();\r\n  private _resizeSub: Subscription;\r\n\r\n  constructor(private el: ElementRef, private _ngZone: NgZone) { }\r\n\r\n  private createChart() {\r\n    this.currentWindowWidth = window.innerWidth;\r\n    this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n    this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n    const dom = this.el.nativeElement;\r\n\r\n    if (window && window.getComputedStyle) {\r\n      const prop = window.getComputedStyle(dom, null).getPropertyValue('height');\r\n      if ((!prop || prop === '0px') &&\r\n        (!dom.style.height || dom.style.height === '0px')) {\r\n        dom.style.height = '400px';\r\n      }\r\n    }\r\n\r\n    return this._ngZone.runOutsideAngular(() => init(dom, this.theme || undefined, this.initOpts || undefined));\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize(event: Event) {\r\n    const target = event.target as Window;\r\n\r\n    if (this.autoResize && target.innerWidth !== this.currentWindowWidth) {\r\n      this.currentWindowWidth = target.innerWidth;\r\n      this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n      this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      this._resize$.next();\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const filter = ChangeFilter.of(changes);\r\n    filter.notFirstAndEmpty<any>('options').subscribe(opt => this.onOptionsChange(opt));\r\n    filter.notFirstAndEmpty<any>('merge').subscribe(opt => this.setOption(opt));\r\n    filter.has<boolean>('loading').subscribe(v => this.toggleLoading(!!v));\r\n    filter.notFirst<boolean>('detectEventChanges').subscribe(v => this.toggleEventDetectors(!!v));\r\n    filter.notFirst<string>('theme').subscribe(() => this.refreshChart());\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this._resizeSub) {\r\n      this._resizeSub.unsubscribe();\r\n      this._resizeSub = null;\r\n    }\r\n\r\n    if (this._chart) {\r\n      this._chart.dispose();\r\n      this._chart = null;\r\n    }\r\n  }\r\n\r\n  ngDoCheck() {\r\n    // No heavy work in DoCheck!\r\n    if (this._chart && this.autoResize) {\r\n      const offsetWidth = this.el.nativeElement.offsetWidth;\r\n      const offsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      if (this.currentOffsetWidth !== offsetWidth || this.currentOffsetHeight !== offsetHeight) {\r\n        this.currentOffsetWidth = offsetWidth;\r\n        this.currentOffsetHeight = offsetHeight;\r\n        this._resize$.next();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    setTimeout(() => this.initChart());\r\n  }\r\n\r\n  private initChart() {\r\n    this.onOptionsChange(this.options);\r\n\r\n    if (this.merge && this._chart) {\r\n      this.setOption(this.merge);\r\n    }\r\n  }\r\n\r\n  private onOptionsChange(opt: EChartOption) {\r\n    if (opt) {\r\n      if (!this._chart) {\r\n        this._chart = this.createChart();\r\n\r\n        // subscribe to _resize$ and debounced\r\n        this._resizeSub = this._resize$.pipe(debounceTime(50)).subscribe(() => {\r\n          if (this._chart) {\r\n            this._chart.resize();\r\n          }\r\n        });\r\n\r\n        // output echart instance:\r\n        this.chartInit.emit(this._chart);\r\n\r\n        // register events:\r\n        if (this.detectEventChanges) {\r\n          this.registerEvents();\r\n        }\r\n      }\r\n\r\n      this._chart.setOption(this.options, true);\r\n    }\r\n  }\r\n\r\n  private registerEvents() {\r\n    if (this._chart) {\r\n      const events = EChartEvents.All;\r\n      for (let i = 0, len = events.length; i < len; i++) {\r\n        this._chart.on(events[i], this.eventHandler, this);\r\n      }\r\n    }\r\n  }\r\n\r\n  private unregisterEvents() {\r\n    if (this._chart) {\r\n      const events = EChartEvents.All;\r\n      for (let i = 0, len = events.length; i < len; i++) {\r\n        this._chart.off(events[i], this.eventHandler);\r\n      }\r\n    }\r\n  }\r\n\r\n  clear() {\r\n    if (this._chart) {\r\n      this._chart.clear();\r\n    }\r\n  }\r\n\r\n  toggleLoading(loading: boolean) {\r\n    if (this._chart) {\r\n      loading ? this._chart.showLoading(this.loadingType, this.loadingOpts) : this._chart.hideLoading();\r\n    }\r\n  }\r\n\r\n  setOption(option: any, opts?: any) {\r\n    if (this._chart) {\r\n      this._chart.setOption(option, opts);\r\n    }\r\n  }\r\n\r\n  private eventHandler(event) {\r\n    switch (event.type) {\r\n      case EChartEvents.Click:\r\n        this._ngZone.run(() => this.chartClick.emit(event));\r\n        break;\r\n      case EChartEvents.DblClick:\r\n        this._ngZone.run(() => this.chartDblClick.emit(event));\r\n        break;\r\n      case EChartEvents.MouseDown:\r\n        this._ngZone.run(() => this.chartMouseDown.emit(event));\r\n        break;\r\n      case EChartEvents.MouseUp:\r\n        this._ngZone.run(() => this.chartMouseUp.emit(event));\r\n        break;\r\n      case EChartEvents.MouseOver:\r\n        this._ngZone.run(() => this.chartMouseOver.emit(event));\r\n        break;\r\n      case EChartEvents.MouseOut:\r\n        this._ngZone.run(() => this.chartMouseOut.emit(event));\r\n        break;\r\n      case EChartEvents.GlobalOut:\r\n        this._ngZone.run(() => this.chartGlobalOut.emit(event));\r\n        break;\r\n      case EChartEvents.ContextMenu:\r\n        this._ngZone.run(() => this.chartContextMenu.emit(event));\r\n        break;\r\n      case EChartEvents.DataZoom:\r\n        this._ngZone.run(() => this.chartDataZoom.emit(event));\r\n        break;\r\n      case EChartEvents.MapSelectChanged:\r\n        this._ngZone.run(() => this.chartMapSelectChanged.emit(event));\r\n        break;\r\n      case EChartEvents.MapSelected:\r\n        this._ngZone.run(() => this.chartMapSelected.emit(event));\r\n        break;\r\n      case EChartEvents.MapUnselected:\r\n        this._ngZone.run(() => this.chartMapUnselected.emit(event));\r\n        break;\r\n    }\r\n  }\r\n\r\n  private toggleEventDetectors(detect: boolean) {\r\n    if (this._chart) {\r\n      detect ? this.registerEvents() : this.unregisterEvents();\r\n    }\r\n  }\r\n\r\n  private refreshChart() {\r\n    this.ngOnDestroy();\r\n    this.initChart();\r\n  }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { NgxEchartsDirective } from './ngx-echarts.directive';\r\n\r\n@NgModule({\r\n  imports: [],\r\n  declarations: [\r\n    NgxEchartsDirective\r\n  ],\r\n  exports: [\r\n    NgxEchartsDirective\r\n  ]\r\n})\r\nexport class NgxEchartsModule { }\r\n"],"names":[],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-echarts.js.map","sources":["ng://ngx-echarts/lib/change-filter.ts","ng://ngx-echarts/lib/ngx-echarts.directive.ts","ng://ngx-echarts/lib/ngx-echarts.module.ts"],"sourcesContent":["import { SimpleChanges } from '@angular/core';\r\nimport { Observable, of, empty } from 'rxjs';\r\n\r\nexport class ChangeFilter {\r\n  constructor(private _changes: SimpleChanges) { }\r\n\r\n  static of(changes: SimpleChanges) {\r\n    return new ChangeFilter(changes);\r\n  }\r\n\r\n  notEmpty<T>(key: string): Observable<T> {\r\n    if (this._changes[key]) {\r\n      const value: T = this._changes[key].currentValue;\r\n\r\n      if (value !== undefined && value !== null) {\r\n        return of(value);\r\n      }\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  has<T>(key: string): Observable<T> {\r\n    if (this._changes[key]) {\r\n      const value: T = this._changes[key].currentValue;\r\n      return of(value);\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  notFirst<T>(key: string): Observable<T> {\r\n    if (this._changes[key] && !this._changes[key].isFirstChange()) {\r\n      const value: T = this._changes[key].currentValue;\r\n      return of(value);\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  notFirstAndEmpty<T>(key: string): Observable<T> {\r\n    if (this._changes[key] && !this._changes[key].isFirstChange()) {\r\n      const value: T = this._changes[key].currentValue;\r\n\r\n      if (value !== undefined && value !== null) {\r\n        return of(value);\r\n      }\r\n    }\r\n    return empty();\r\n  }\r\n}\r\n","import { AfterViewInit, Directive, DoCheck, ElementRef, EventEmitter, Input, NgZone, OnChanges, OnDestroy, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { EChartOption, ECharts, init } from 'echarts';\r\nimport { fromEvent, Observable, Subscription } from 'rxjs';\r\nimport { debounceTime, switchMap } from 'rxjs/operators';\r\nimport { ChangeFilter } from './change-filter';\r\n\r\n@Directive({\r\n  selector: 'echarts, [echarts]',\r\n})\r\nexport class NgxEchartsDirective implements OnChanges, OnDestroy, OnInit, DoCheck, AfterViewInit {\r\n  @Input() options: EChartOption;\r\n  @Input() theme: string;\r\n  @Input() loading: boolean;\r\n  @Input() initOpts: {\r\n    devicePixelRatio?: number\r\n    renderer?: string\r\n    width?: number | string\r\n    height?: number | string\r\n  };\r\n  @Input() merge: EChartOption;\r\n  @Input() autoResize = true;\r\n  @Input() loadingType = 'default';\r\n  @Input() loadingOpts: object;\r\n  @Input() detectEventChanges = true; // deprecated, left for compatibility reasons to avoid triggering major version\r\n\r\n  // ngx-echarts events\r\n  @Output() chartInit = new EventEmitter<ECharts>();\r\n\r\n  // echarts mouse events\r\n  @Output() chartClick = this.createLazyEvent('click');\r\n  @Output() chartDblClick = this.createLazyEvent('dblclick');\r\n  @Output() chartMouseDown = this.createLazyEvent('mousedown');\r\n  @Output() chartMouseMove = this.createLazyEvent('mousemove');\r\n  @Output() chartMouseUp = this.createLazyEvent('mouseup');\r\n  @Output() chartMouseOver = this.createLazyEvent('mouseover');\r\n  @Output() chartMouseOut = this.createLazyEvent('mouseout');\r\n  @Output() chartGlobalOut = this.createLazyEvent('globalout');\r\n  @Output() chartContextMenu = this.createLazyEvent('contextmenu');\r\n\r\n  // echarts mouse events\r\n  @Output() chartLegendSelectChanged = this.createLazyEvent('legendselectchanged');\r\n  @Output() chartLegendSelected = this.createLazyEvent('legendselected');\r\n  @Output() chartLegendUnselected = this.createLazyEvent('legendunselected');\r\n  @Output() chartLegendScroll = this.createLazyEvent('legendscroll');\r\n  @Output() chartDataZoom = this.createLazyEvent('datazoom');\r\n  @Output() chartDataRangeSelected = this.createLazyEvent('datarangeselected');\r\n  @Output() chartTimelineChanged = this.createLazyEvent('timelinechanged');\r\n  @Output() chartTimelinePlayChanged = this.createLazyEvent('timelineplaychanged');\r\n  @Output() chartRestore = this.createLazyEvent('restore');\r\n  @Output() chartDataViewChanged = this.createLazyEvent('dataviewchanged');\r\n  @Output() chartMagicTypeChanged = this.createLazyEvent('magictypechanged');\r\n  @Output() chartPieSelectChanged = this.createLazyEvent('pieselectchanged');\r\n  @Output() chartPieSelected = this.createLazyEvent('pieselected');\r\n  @Output() chartPieUnselected = this.createLazyEvent('pieunselected');\r\n  @Output() chartMapSelectChanged = this.createLazyEvent('mapselectchanged');\r\n  @Output() chartMapSelected = this.createLazyEvent('mapselected');\r\n  @Output() chartMapUnselected = this.createLazyEvent('mapunselected');\r\n  @Output() chartAxisAreaSelected = this.createLazyEvent('axisareaselected');\r\n  @Output() chartFocusNodeAdjacency = this.createLazyEvent('focusnodeadjacency');\r\n  @Output() chartUnfocusNodeAdjacency = this.createLazyEvent('unfocusnodeadjacency');\r\n  @Output() chartBrush = this.createLazyEvent('brush');\r\n  @Output() chartBrushSelected = this.createLazyEvent('brushselected');\r\n  @Output() chartRendered = this.createLazyEvent('rendered');\r\n  @Output() chartFinished = this.createLazyEvent('finished');\r\n\r\n  private chart: ECharts;\r\n  private currentOffsetWidth = 0;\r\n  private currentOffsetHeight = 0;\r\n  private currentWindowWidth: number;\r\n  private resizeSub: Subscription;\r\n\r\n  constructor(private el: ElementRef, private ngZone: NgZone) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const filter = ChangeFilter.of(changes);\r\n    filter.notFirstAndEmpty<any>('options').subscribe(opt => this.onOptionsChange(opt));\r\n    filter.notFirstAndEmpty<any>('merge').subscribe(opt => this.setOption(opt));\r\n    filter.has<boolean>('loading').subscribe(v => this.toggleLoading(!!v));\r\n    filter.notFirst<string>('theme').subscribe(() => this.refreshChart());\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.resizeSub = fromEvent(window, 'resize').pipe(debounceTime(50)).subscribe(() => {\r\n      if (this.autoResize && window.innerWidth !== this.currentWindowWidth) {\r\n        this.currentWindowWidth = window.innerWidth;\r\n        this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n        this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n        this.resize();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.resizeSub.unsubscribe();\r\n    this.dispose();\r\n  }\r\n\r\n  ngDoCheck() {\r\n    // No heavy work in DoCheck!\r\n    if (this.chart && this.autoResize) {\r\n      const offsetWidth = this.el.nativeElement.offsetWidth;\r\n      const offsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      if (this.currentOffsetWidth !== offsetWidth || this.currentOffsetHeight !== offsetHeight) {\r\n        this.currentOffsetWidth = offsetWidth;\r\n        this.currentOffsetHeight = offsetHeight;\r\n        this.resize();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    setTimeout(() => this.initChart());\r\n  }\r\n\r\n  private dispose() {\r\n    if (this.chart) {\r\n      this.chart.dispose();\r\n      this.chart = null;\r\n    }\r\n  }\r\n\r\n  private resize() {\r\n    if (this.chart) {\r\n      this.chart.resize();\r\n    }\r\n  }\r\n\r\n  private toggleLoading(loading: boolean) {\r\n    if (this.chart) {\r\n      loading ? this.chart.showLoading(this.loadingType, this.loadingOpts) : this.chart.hideLoading();\r\n    }\r\n  }\r\n\r\n  private setOption(option: any, opts?: any) {\r\n    if (this.chart) {\r\n      this.chart.setOption(option, opts);\r\n    }\r\n  }\r\n\r\n  private refreshChart() {\r\n    this.dispose();\r\n    this.initChart();\r\n  }\r\n\r\n  private createChart() {\r\n    this.currentWindowWidth = window.innerWidth;\r\n    this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n    this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n    const dom = this.el.nativeElement;\r\n\r\n    if (window && window.getComputedStyle) {\r\n      const prop = window.getComputedStyle(dom, null).getPropertyValue('height');\r\n      if ((!prop || prop === '0px') &&\r\n        (!dom.style.height || dom.style.height === '0px')) {\r\n        dom.style.height = '400px';\r\n      }\r\n    }\r\n\r\n    return this.ngZone.runOutsideAngular(() => init(dom, this.theme, this.initOpts));\r\n  }\r\n\r\n  private initChart() {\r\n    this.onOptionsChange(this.options);\r\n\r\n    if (this.merge && this.chart) {\r\n      this.setOption(this.merge);\r\n    }\r\n  }\r\n\r\n  private onOptionsChange(opt: EChartOption) {\r\n    if (opt) {\r\n      if (!this.chart) {\r\n        this.chart = this.createChart();\r\n        this.chartInit.emit(this.chart);\r\n      }\r\n\r\n      this.chart.setOption(this.options, true);\r\n    }\r\n  }\r\n\r\n  // allows to lazily bind to only those events that are requested through the `@Output` by parent components\r\n  // see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info\r\n  private createLazyEvent<T>(eventName: string): EventEmitter<T> {\r\n    return this.chartInit.pipe(\r\n      switchMap((chart: ECharts) => new Observable(observer => {\r\n        chart.on(eventName, (data: T) => this.ngZone.run(() => observer.next(data)));\r\n        return null; // no need to react on unsubscribe as long as the `dispose()` is called in ngOnDestroy\r\n      }))\r\n    ) as EventEmitter<T>;\r\n  }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { NgxEchartsDirective } from './ngx-echarts.directive';\r\n\r\n@NgModule({\r\n  imports: [],\r\n  declarations: [\r\n    NgxEchartsDirective\r\n  ],\r\n  exports: [\r\n    NgxEchartsDirective\r\n  ]\r\n})\r\nexport class NgxEchartsModule { }\r\n"],"names":[],"mappings":"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"}

@@ -1,5 +0,5 @@

import { of, empty, Subject } from 'rxjs';
import { Directive, ElementRef, Input, Output, HostListener, EventEmitter, NgZone, NgModule } from '@angular/core';
import { debounceTime } from 'rxjs/operators';
import { of, empty, fromEvent, Observable } from 'rxjs';
import { Directive, ElementRef, EventEmitter, Input, NgZone, Output, NgModule } from '@angular/core';
import { init } from 'echarts';
import { debounceTime, switchMap } from 'rxjs/operators';

@@ -108,109 +108,51 @@ /**

*/
var EChartEvents = /** @class */ (function () {
function EChartEvents() {
}
EChartEvents.Click = 'click';
EChartEvents.DblClick = 'dblclick';
EChartEvents.MouseDown = 'mousedown';
EChartEvents.MouseUp = 'mouseup';
EChartEvents.MouseOver = 'mouseover';
EChartEvents.MouseOut = 'mouseout';
EChartEvents.GlobalOut = 'globalout';
EChartEvents.ContextMenu = 'contextmenu';
EChartEvents.DataZoom = 'datazoom';
EChartEvents.MapSelectChanged = 'mapselectchanged';
EChartEvents.MapSelected = 'mapselected';
EChartEvents.MapUnselected = 'mapunselected';
EChartEvents.All = [
EChartEvents.Click,
EChartEvents.DblClick,
EChartEvents.MouseDown,
EChartEvents.MouseUp,
EChartEvents.MouseOver,
EChartEvents.MouseOut,
EChartEvents.GlobalOut,
EChartEvents.ContextMenu,
EChartEvents.DataZoom,
EChartEvents.MapSelectChanged,
EChartEvents.MapSelected,
EChartEvents.MapUnselected,
];
return EChartEvents;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var NgxEchartsDirective = /** @class */ (function () {
function NgxEchartsDirective(el, _ngZone) {
function NgxEchartsDirective(el, ngZone) {
this.el = el;
this._ngZone = _ngZone;
this.ngZone = ngZone;
this.autoResize = true;
this.loadingType = 'default';
/**
* Whether to register event handlers on echartInstance. Default is true.
* Use it to avoid unwanted change detection, if you want to optimize the performance.
*/
this.detectEventChanges = true;
// chart events:
this.detectEventChanges = true; // deprecated, left for compatibility reasons to avoid triggering major version
// deprecated, left for compatibility reasons to avoid triggering major version
// ngx-echarts events
this.chartInit = new EventEmitter();
this.chartClick = new EventEmitter();
this.chartDblClick = new EventEmitter();
this.chartMouseDown = new EventEmitter();
this.chartMouseUp = new EventEmitter();
this.chartMouseOver = new EventEmitter();
this.chartMouseOut = new EventEmitter();
this.chartGlobalOut = new EventEmitter();
this.chartContextMenu = new EventEmitter();
this.chartDataZoom = new EventEmitter();
this.chartMapSelectChanged = new EventEmitter();
this.chartMapSelected = new EventEmitter();
this.chartMapUnselected = new EventEmitter();
// echarts mouse events
this.chartClick = this.createLazyEvent('click');
this.chartDblClick = this.createLazyEvent('dblclick');
this.chartMouseDown = this.createLazyEvent('mousedown');
this.chartMouseMove = this.createLazyEvent('mousemove');
this.chartMouseUp = this.createLazyEvent('mouseup');
this.chartMouseOver = this.createLazyEvent('mouseover');
this.chartMouseOut = this.createLazyEvent('mouseout');
this.chartGlobalOut = this.createLazyEvent('globalout');
this.chartContextMenu = this.createLazyEvent('contextmenu');
// echarts mouse events
this.chartLegendSelectChanged = this.createLazyEvent('legendselectchanged');
this.chartLegendSelected = this.createLazyEvent('legendselected');
this.chartLegendUnselected = this.createLazyEvent('legendunselected');
this.chartLegendScroll = this.createLazyEvent('legendscroll');
this.chartDataZoom = this.createLazyEvent('datazoom');
this.chartDataRangeSelected = this.createLazyEvent('datarangeselected');
this.chartTimelineChanged = this.createLazyEvent('timelinechanged');
this.chartTimelinePlayChanged = this.createLazyEvent('timelineplaychanged');
this.chartRestore = this.createLazyEvent('restore');
this.chartDataViewChanged = this.createLazyEvent('dataviewchanged');
this.chartMagicTypeChanged = this.createLazyEvent('magictypechanged');
this.chartPieSelectChanged = this.createLazyEvent('pieselectchanged');
this.chartPieSelected = this.createLazyEvent('pieselected');
this.chartPieUnselected = this.createLazyEvent('pieunselected');
this.chartMapSelectChanged = this.createLazyEvent('mapselectchanged');
this.chartMapSelected = this.createLazyEvent('mapselected');
this.chartMapUnselected = this.createLazyEvent('mapunselected');
this.chartAxisAreaSelected = this.createLazyEvent('axisareaselected');
this.chartFocusNodeAdjacency = this.createLazyEvent('focusnodeadjacency');
this.chartUnfocusNodeAdjacency = this.createLazyEvent('unfocusnodeadjacency');
this.chartBrush = this.createLazyEvent('brush');
this.chartBrushSelected = this.createLazyEvent('brushselected');
this.chartRendered = this.createLazyEvent('rendered');
this.chartFinished = this.createLazyEvent('finished');
this.currentOffsetWidth = 0;
this.currentOffsetHeight = 0;
this._resize$ = new Subject();
}
/**
* @return {?}
*/
NgxEchartsDirective.prototype.createChart = /**
* @return {?}
*/
function () {
var _this = this;
this.currentWindowWidth = window.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
/** @type {?} */
var dom = this.el.nativeElement;
if (window && window.getComputedStyle) {
/** @type {?} */
var prop = window.getComputedStyle(dom, null).getPropertyValue('height');
if ((!prop || prop === '0px') &&
(!dom.style.height || dom.style.height === '0px')) {
dom.style.height = '400px';
}
}
return this._ngZone.runOutsideAngular(function () { return init(dom, _this.theme || undefined, _this.initOpts || undefined); });
};
/**
* @param {?} event
* @return {?}
*/
NgxEchartsDirective.prototype.onWindowResize = /**
* @param {?} event
* @return {?}
*/
function (event) {
/** @type {?} */
var target = (/** @type {?} */ (event.target));
if (this.autoResize && target.innerWidth !== this.currentWindowWidth) {
this.currentWindowWidth = target.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
this._resize$.next();
}
};
/**
* @param {?} changes

@@ -230,3 +172,2 @@ * @return {?}

filter.has('loading').subscribe(function (v) { return _this.toggleLoading(!!v); });
filter.notFirst('detectEventChanges').subscribe(function (v) { return _this.toggleEventDetectors(!!v); });
filter.notFirst('theme').subscribe(function () { return _this.refreshChart(); });

@@ -237,2 +178,19 @@ };

*/
NgxEchartsDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.resizeSub = fromEvent(window, 'resize').pipe(debounceTime(50)).subscribe(function () {
if (_this.autoResize && window.innerWidth !== _this.currentWindowWidth) {
_this.currentWindowWidth = window.innerWidth;
_this.currentOffsetWidth = _this.el.nativeElement.offsetWidth;
_this.currentOffsetHeight = _this.el.nativeElement.offsetHeight;
_this.resize();
}
});
};
/**
* @return {?}
*/
NgxEchartsDirective.prototype.ngOnDestroy = /**

@@ -242,10 +200,4 @@ * @return {?}

function () {
if (this._resizeSub) {
this._resizeSub.unsubscribe();
this._resizeSub = null;
}
if (this._chart) {
this._chart.dispose();
this._chart = null;
}
this.resizeSub.unsubscribe();
this.dispose();
};

@@ -260,3 +212,3 @@ /**

// No heavy work in DoCheck!
if (this._chart && this.autoResize) {
if (this.chart && this.autoResize) {
/** @type {?} */

@@ -269,3 +221,3 @@ var offsetWidth = this.el.nativeElement.offsetWidth;

this.currentOffsetHeight = offsetHeight;
this._resize$.next();
this.resize();
}

@@ -287,68 +239,48 @@ }

*/
NgxEchartsDirective.prototype.initChart = /**
NgxEchartsDirective.prototype.dispose = /**
* @return {?}
*/
function () {
this.onOptionsChange(this.options);
if (this.merge && this._chart) {
this.setOption(this.merge);
if (this.chart) {
this.chart.dispose();
this.chart = null;
}
};
/**
* @param {?} opt
* @return {?}
*/
NgxEchartsDirective.prototype.onOptionsChange = /**
* @param {?} opt
NgxEchartsDirective.prototype.resize = /**
* @return {?}
*/
function (opt) {
var _this = this;
if (opt) {
if (!this._chart) {
this._chart = this.createChart();
// subscribe to _resize$ and debounced
this._resizeSub = this._resize$.pipe(debounceTime(50)).subscribe(function () {
if (_this._chart) {
_this._chart.resize();
}
});
// output echart instance:
this.chartInit.emit(this._chart);
// register events:
if (this.detectEventChanges) {
this.registerEvents();
}
}
this._chart.setOption(this.options, true);
function () {
if (this.chart) {
this.chart.resize();
}
};
/**
* @param {?} loading
* @return {?}
*/
NgxEchartsDirective.prototype.registerEvents = /**
NgxEchartsDirective.prototype.toggleLoading = /**
* @param {?} loading
* @return {?}
*/
function () {
if (this._chart) {
/** @type {?} */
var events = EChartEvents.All;
for (var i = 0, len = events.length; i < len; i++) {
this._chart.on(events[i], this.eventHandler, this);
}
function (loading) {
if (this.chart) {
loading ? this.chart.showLoading(this.loadingType, this.loadingOpts) : this.chart.hideLoading();
}
};
/**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
NgxEchartsDirective.prototype.unregisterEvents = /**
NgxEchartsDirective.prototype.setOption = /**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
function () {
if (this._chart) {
/** @type {?} */
var events = EChartEvents.All;
for (var i = 0, len = events.length; i < len; i++) {
this._chart.off(events[i], this.eventHandler);
}
function (option, opts) {
if (this.chart) {
this.chart.setOption(option, opts);
}

@@ -359,109 +291,84 @@ };

*/
NgxEchartsDirective.prototype.clear = /**
NgxEchartsDirective.prototype.refreshChart = /**
* @return {?}
*/
function () {
if (this._chart) {
this._chart.clear();
}
this.dispose();
this.initChart();
};
/**
* @param {?} loading
* @return {?}
*/
NgxEchartsDirective.prototype.toggleLoading = /**
* @param {?} loading
NgxEchartsDirective.prototype.createChart = /**
* @return {?}
*/
function (loading) {
if (this._chart) {
loading ? this._chart.showLoading(this.loadingType, this.loadingOpts) : this._chart.hideLoading();
function () {
var _this = this;
this.currentWindowWidth = window.innerWidth;
this.currentOffsetWidth = this.el.nativeElement.offsetWidth;
this.currentOffsetHeight = this.el.nativeElement.offsetHeight;
/** @type {?} */
var dom = this.el.nativeElement;
if (window && window.getComputedStyle) {
/** @type {?} */
var prop = window.getComputedStyle(dom, null).getPropertyValue('height');
if ((!prop || prop === '0px') &&
(!dom.style.height || dom.style.height === '0px')) {
dom.style.height = '400px';
}
}
return this.ngZone.runOutsideAngular(function () { return init(dom, _this.theme, _this.initOpts); });
};
/**
* @param {?} option
* @param {?=} opts
* @return {?}
*/
NgxEchartsDirective.prototype.setOption = /**
* @param {?} option
* @param {?=} opts
NgxEchartsDirective.prototype.initChart = /**
* @return {?}
*/
function (option, opts) {
if (this._chart) {
this._chart.setOption(option, opts);
function () {
this.onOptionsChange(this.options);
if (this.merge && this.chart) {
this.setOption(this.merge);
}
};
/**
* @param {?} event
* @param {?} opt
* @return {?}
*/
NgxEchartsDirective.prototype.eventHandler = /**
* @param {?} event
NgxEchartsDirective.prototype.onOptionsChange = /**
* @param {?} opt
* @return {?}
*/
function (event) {
var _this = this;
switch (event.type) {
case EChartEvents.Click:
this._ngZone.run(function () { return _this.chartClick.emit(event); });
break;
case EChartEvents.DblClick:
this._ngZone.run(function () { return _this.chartDblClick.emit(event); });
break;
case EChartEvents.MouseDown:
this._ngZone.run(function () { return _this.chartMouseDown.emit(event); });
break;
case EChartEvents.MouseUp:
this._ngZone.run(function () { return _this.chartMouseUp.emit(event); });
break;
case EChartEvents.MouseOver:
this._ngZone.run(function () { return _this.chartMouseOver.emit(event); });
break;
case EChartEvents.MouseOut:
this._ngZone.run(function () { return _this.chartMouseOut.emit(event); });
break;
case EChartEvents.GlobalOut:
this._ngZone.run(function () { return _this.chartGlobalOut.emit(event); });
break;
case EChartEvents.ContextMenu:
this._ngZone.run(function () { return _this.chartContextMenu.emit(event); });
break;
case EChartEvents.DataZoom:
this._ngZone.run(function () { return _this.chartDataZoom.emit(event); });
break;
case EChartEvents.MapSelectChanged:
this._ngZone.run(function () { return _this.chartMapSelectChanged.emit(event); });
break;
case EChartEvents.MapSelected:
this._ngZone.run(function () { return _this.chartMapSelected.emit(event); });
break;
case EChartEvents.MapUnselected:
this._ngZone.run(function () { return _this.chartMapUnselected.emit(event); });
break;
function (opt) {
if (opt) {
if (!this.chart) {
this.chart = this.createChart();
this.chartInit.emit(this.chart);
}
this.chart.setOption(this.options, true);
}
};
// allows to lazily bind to only those events that are requested through the `@Output` by parent components
// see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info
// allows to lazily bind to only those events that are requested through the `@Output` by parent components
// see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info
/**
* @param {?} detect
* @template T
* @param {?} eventName
* @return {?}
*/
NgxEchartsDirective.prototype.toggleEventDetectors = /**
* @param {?} detect
* @return {?}
*/
function (detect) {
if (this._chart) {
detect ? this.registerEvents() : this.unregisterEvents();
}
};
NgxEchartsDirective.prototype.createLazyEvent =
// allows to lazily bind to only those events that are requested through the `@Output` by parent components
// see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info
/**
* @template T
* @param {?} eventName
* @return {?}
*/
NgxEchartsDirective.prototype.refreshChart = /**
* @return {?}
*/
function () {
this.ngOnDestroy();
this.initChart();
function (eventName) {
var _this = this;
return (/** @type {?} */ (this.chartInit.pipe(switchMap(function (chart) { return new Observable(function (observer) {
chart.on(eventName, function (data) { return _this.ngZone.run(function () { return observer.next(data); }); });
return null; // no need to react on unsubscribe as long as the `dispose()` is called in ngOnDestroy
}); }))));
};

@@ -492,2 +399,3 @@ NgxEchartsDirective.decorators = [

chartMouseDown: [{ type: Output }],
chartMouseMove: [{ type: Output }],
chartMouseUp: [{ type: Output }],

@@ -498,7 +406,26 @@ chartMouseOver: [{ type: Output }],

chartContextMenu: [{ type: Output }],
chartLegendSelectChanged: [{ type: Output }],
chartLegendSelected: [{ type: Output }],
chartLegendUnselected: [{ type: Output }],
chartLegendScroll: [{ type: Output }],
chartDataZoom: [{ type: Output }],
chartDataRangeSelected: [{ type: Output }],
chartTimelineChanged: [{ type: Output }],
chartTimelinePlayChanged: [{ type: Output }],
chartRestore: [{ type: Output }],
chartDataViewChanged: [{ type: Output }],
chartMagicTypeChanged: [{ type: Output }],
chartPieSelectChanged: [{ type: Output }],
chartPieSelected: [{ type: Output }],
chartPieUnselected: [{ type: Output }],
chartMapSelectChanged: [{ type: Output }],
chartMapSelected: [{ type: Output }],
chartMapUnselected: [{ type: Output }],
onWindowResize: [{ type: HostListener, args: ['window:resize', ['$event'],] }]
chartAxisAreaSelected: [{ type: Output }],
chartFocusNodeAdjacency: [{ type: Output }],
chartUnfocusNodeAdjacency: [{ type: Output }],
chartBrush: [{ type: Output }],
chartBrushSelected: [{ type: Output }],
chartRendered: [{ type: Output }],
chartFinished: [{ type: Output }]
};

@@ -541,2 +468,2 @@ return NgxEchartsDirective;

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-echarts.js.map","sources":["ng://ngx-echarts/lib/change-filter.ts","ng://ngx-echarts/lib/echart-events.ts","ng://ngx-echarts/lib/ngx-echarts.directive.ts","ng://ngx-echarts/lib/ngx-echarts.module.ts"],"sourcesContent":["import { SimpleChanges } from '@angular/core';\r\nimport { Observable, of, empty } from 'rxjs';\r\n\r\nexport class ChangeFilter {\r\n  constructor(private _changes: SimpleChanges) { }\r\n\r\n  static of(changes: SimpleChanges) {\r\n    return new ChangeFilter(changes);\r\n  }\r\n\r\n  notEmpty<T>(key: string): Observable<T> {\r\n    if (this._changes[key]) {\r\n      const value: T = this._changes[key].currentValue;\r\n\r\n      if (value !== undefined && value !== null) {\r\n        return of(value);\r\n      }\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  has<T>(key: string): Observable<T> {\r\n    if (this._changes[key]) {\r\n      const value: T = this._changes[key].currentValue;\r\n      return of(value);\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  notFirst<T>(key: string): Observable<T> {\r\n    if (this._changes[key] && !this._changes[key].isFirstChange()) {\r\n      const value: T = this._changes[key].currentValue;\r\n      return of(value);\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  notFirstAndEmpty<T>(key: string): Observable<T> {\r\n    if (this._changes[key] && !this._changes[key].isFirstChange()) {\r\n      const value: T = this._changes[key].currentValue;\r\n\r\n      if (value !== undefined && value !== null) {\r\n        return of(value);\r\n      }\r\n    }\r\n    return empty();\r\n  }\r\n}\r\n","export class EChartEvents {\r\n  static Click = 'click';\r\n  static DblClick = 'dblclick';\r\n  static MouseDown = 'mousedown';\r\n  static MouseUp = 'mouseup';\r\n  static MouseOver = 'mouseover';\r\n  static MouseOut = 'mouseout';\r\n  static GlobalOut = 'globalout';\r\n  static ContextMenu = 'contextmenu';\r\n  static DataZoom = 'datazoom';\r\n  static MapSelectChanged = 'mapselectchanged';\r\n  static MapSelected = 'mapselected';\r\n  static MapUnselected = 'mapunselected';\r\n\r\n  static All = [\r\n    EChartEvents.Click,\r\n    EChartEvents.DblClick,\r\n    EChartEvents.MouseDown,\r\n    EChartEvents.MouseUp,\r\n    EChartEvents.MouseOver,\r\n    EChartEvents.MouseOut,\r\n    EChartEvents.GlobalOut,\r\n    EChartEvents.ContextMenu,\r\n    EChartEvents.DataZoom,\r\n    EChartEvents.MapSelectChanged,\r\n    EChartEvents.MapSelected,\r\n    EChartEvents.MapUnselected,\r\n  ];\r\n}\r\n","import {\r\n  Directive, ElementRef, Renderer, Input, Output, HostListener, EventEmitter,\r\n  OnChanges, OnDestroy, SimpleChanges, NgZone, DoCheck, AfterViewInit\r\n} from '@angular/core';\r\nimport { ChangeFilter } from './change-filter';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { init, ECharts, EChartOption } from 'echarts';\r\nimport { EChartEvents } from './echart-events';\r\n\r\n@Directive({\r\n  selector: 'echarts, [echarts]',\r\n})\r\nexport class NgxEchartsDirective implements OnChanges, OnDestroy, DoCheck, AfterViewInit {\r\n  @Input() options: EChartOption;\r\n  @Input() theme: string;\r\n  @Input() loading: boolean;\r\n  @Input() initOpts: {\r\n    devicePixelRatio?: number\r\n    renderer?: string\r\n    width?: number | string\r\n    height?: number | string\r\n  };\r\n  @Input() merge: EChartOption;\r\n  @Input() autoResize = true;\r\n  @Input() loadingType = 'default';\r\n  @Input() loadingOpts: object;\r\n\r\n  /**\r\n   * Whether to register event handlers on echartInstance. Default is true.\r\n   * Use it to avoid unwanted change detection, if you want to optimize the performance.\r\n   */\r\n  @Input() detectEventChanges = true;\r\n\r\n  // chart events:\r\n  @Output() chartInit = new EventEmitter<ECharts>();\r\n  @Output() chartClick = new EventEmitter<any>();\r\n  @Output() chartDblClick = new EventEmitter<any>();\r\n  @Output() chartMouseDown = new EventEmitter<any>();\r\n  @Output() chartMouseUp = new EventEmitter<any>();\r\n  @Output() chartMouseOver = new EventEmitter<any>();\r\n  @Output() chartMouseOut = new EventEmitter<any>();\r\n  @Output() chartGlobalOut = new EventEmitter<any>();\r\n  @Output() chartContextMenu = new EventEmitter<any>();\r\n  @Output() chartDataZoom = new EventEmitter<any>();\r\n  @Output() chartMapSelectChanged = new EventEmitter<any>();\r\n  @Output() chartMapSelected = new EventEmitter<any>();\r\n  @Output() chartMapUnselected = new EventEmitter<any>();\r\n\r\n  private _chart: ECharts;\r\n  private currentOffsetWidth = 0;\r\n  private currentOffsetHeight = 0;\r\n  private currentWindowWidth: number;\r\n  private _resize$ = new Subject<void>();\r\n  private _resizeSub: Subscription;\r\n\r\n  constructor(private el: ElementRef, private _ngZone: NgZone) { }\r\n\r\n  private createChart() {\r\n    this.currentWindowWidth = window.innerWidth;\r\n    this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n    this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n    const dom = this.el.nativeElement;\r\n\r\n    if (window && window.getComputedStyle) {\r\n      const prop = window.getComputedStyle(dom, null).getPropertyValue('height');\r\n      if ((!prop || prop === '0px') &&\r\n        (!dom.style.height || dom.style.height === '0px')) {\r\n        dom.style.height = '400px';\r\n      }\r\n    }\r\n\r\n    return this._ngZone.runOutsideAngular(() => init(dom, this.theme || undefined, this.initOpts || undefined));\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize(event: Event) {\r\n    const target = event.target as Window;\r\n\r\n    if (this.autoResize && target.innerWidth !== this.currentWindowWidth) {\r\n      this.currentWindowWidth = target.innerWidth;\r\n      this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n      this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      this._resize$.next();\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const filter = ChangeFilter.of(changes);\r\n    filter.notFirstAndEmpty<any>('options').subscribe(opt => this.onOptionsChange(opt));\r\n    filter.notFirstAndEmpty<any>('merge').subscribe(opt => this.setOption(opt));\r\n    filter.has<boolean>('loading').subscribe(v => this.toggleLoading(!!v));\r\n    filter.notFirst<boolean>('detectEventChanges').subscribe(v => this.toggleEventDetectors(!!v));\r\n    filter.notFirst<string>('theme').subscribe(() => this.refreshChart());\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this._resizeSub) {\r\n      this._resizeSub.unsubscribe();\r\n      this._resizeSub = null;\r\n    }\r\n\r\n    if (this._chart) {\r\n      this._chart.dispose();\r\n      this._chart = null;\r\n    }\r\n  }\r\n\r\n  ngDoCheck() {\r\n    // No heavy work in DoCheck!\r\n    if (this._chart && this.autoResize) {\r\n      const offsetWidth = this.el.nativeElement.offsetWidth;\r\n      const offsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      if (this.currentOffsetWidth !== offsetWidth || this.currentOffsetHeight !== offsetHeight) {\r\n        this.currentOffsetWidth = offsetWidth;\r\n        this.currentOffsetHeight = offsetHeight;\r\n        this._resize$.next();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    setTimeout(() => this.initChart());\r\n  }\r\n\r\n  private initChart() {\r\n    this.onOptionsChange(this.options);\r\n\r\n    if (this.merge && this._chart) {\r\n      this.setOption(this.merge);\r\n    }\r\n  }\r\n\r\n  private onOptionsChange(opt: EChartOption) {\r\n    if (opt) {\r\n      if (!this._chart) {\r\n        this._chart = this.createChart();\r\n\r\n        // subscribe to _resize$ and debounced\r\n        this._resizeSub = this._resize$.pipe(debounceTime(50)).subscribe(() => {\r\n          if (this._chart) {\r\n            this._chart.resize();\r\n          }\r\n        });\r\n\r\n        // output echart instance:\r\n        this.chartInit.emit(this._chart);\r\n\r\n        // register events:\r\n        if (this.detectEventChanges) {\r\n          this.registerEvents();\r\n        }\r\n      }\r\n\r\n      this._chart.setOption(this.options, true);\r\n    }\r\n  }\r\n\r\n  private registerEvents() {\r\n    if (this._chart) {\r\n      const events = EChartEvents.All;\r\n      for (let i = 0, len = events.length; i < len; i++) {\r\n        this._chart.on(events[i], this.eventHandler, this);\r\n      }\r\n    }\r\n  }\r\n\r\n  private unregisterEvents() {\r\n    if (this._chart) {\r\n      const events = EChartEvents.All;\r\n      for (let i = 0, len = events.length; i < len; i++) {\r\n        this._chart.off(events[i], this.eventHandler);\r\n      }\r\n    }\r\n  }\r\n\r\n  clear() {\r\n    if (this._chart) {\r\n      this._chart.clear();\r\n    }\r\n  }\r\n\r\n  toggleLoading(loading: boolean) {\r\n    if (this._chart) {\r\n      loading ? this._chart.showLoading(this.loadingType, this.loadingOpts) : this._chart.hideLoading();\r\n    }\r\n  }\r\n\r\n  setOption(option: any, opts?: any) {\r\n    if (this._chart) {\r\n      this._chart.setOption(option, opts);\r\n    }\r\n  }\r\n\r\n  private eventHandler(event) {\r\n    switch (event.type) {\r\n      case EChartEvents.Click:\r\n        this._ngZone.run(() => this.chartClick.emit(event));\r\n        break;\r\n      case EChartEvents.DblClick:\r\n        this._ngZone.run(() => this.chartDblClick.emit(event));\r\n        break;\r\n      case EChartEvents.MouseDown:\r\n        this._ngZone.run(() => this.chartMouseDown.emit(event));\r\n        break;\r\n      case EChartEvents.MouseUp:\r\n        this._ngZone.run(() => this.chartMouseUp.emit(event));\r\n        break;\r\n      case EChartEvents.MouseOver:\r\n        this._ngZone.run(() => this.chartMouseOver.emit(event));\r\n        break;\r\n      case EChartEvents.MouseOut:\r\n        this._ngZone.run(() => this.chartMouseOut.emit(event));\r\n        break;\r\n      case EChartEvents.GlobalOut:\r\n        this._ngZone.run(() => this.chartGlobalOut.emit(event));\r\n        break;\r\n      case EChartEvents.ContextMenu:\r\n        this._ngZone.run(() => this.chartContextMenu.emit(event));\r\n        break;\r\n      case EChartEvents.DataZoom:\r\n        this._ngZone.run(() => this.chartDataZoom.emit(event));\r\n        break;\r\n      case EChartEvents.MapSelectChanged:\r\n        this._ngZone.run(() => this.chartMapSelectChanged.emit(event));\r\n        break;\r\n      case EChartEvents.MapSelected:\r\n        this._ngZone.run(() => this.chartMapSelected.emit(event));\r\n        break;\r\n      case EChartEvents.MapUnselected:\r\n        this._ngZone.run(() => this.chartMapUnselected.emit(event));\r\n        break;\r\n    }\r\n  }\r\n\r\n  private toggleEventDetectors(detect: boolean) {\r\n    if (this._chart) {\r\n      detect ? this.registerEvents() : this.unregisterEvents();\r\n    }\r\n  }\r\n\r\n  private refreshChart() {\r\n    this.ngOnDestroy();\r\n    this.initChart();\r\n  }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { NgxEchartsDirective } from './ngx-echarts.directive';\r\n\r\n@NgModule({\r\n  imports: [],\r\n  declarations: [\r\n    NgxEchartsDirective\r\n  ],\r\n  exports: [\r\n    NgxEchartsDirective\r\n  ]\r\n})\r\nexport class NgxEchartsModule { }\r\n"],"names":[],"mappings":";;;;;;;;;AACA,AAEA;IACE,sBAAoB,QAAuB;QAAvB,aAAQ,GAAR,QAAQ,CAAe;KAAK;;;;;IAEzC,eAAE;;;;IAAT,UAAU,OAAsB;QAC9B,OAAO,IAAI,YAAY,CAAC,OAAO,CAAC,CAAC;KAClC;;;;;;IAED,+BAAQ;;;;;IAAR,UAAY,GAAW;QACrB,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;;gBAChB,KAAK,GAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,YAAY;YAEhD,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,EAAE;gBACzC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;aAClB;SACF;QACD,OAAO,KAAK,EAAE,CAAC;KAChB;;;;;;IAED,0BAAG;;;;;IAAH,UAAO,GAAW;QAChB,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;;gBAChB,KAAK,GAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,YAAY;YAChD,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;SAClB;QACD,OAAO,KAAK,EAAE,CAAC;KAChB;;;;;;IAED,+BAAQ;;;;;IAAR,UAAY,GAAW;QACrB,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,EAAE;;gBACvD,KAAK,GAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,YAAY;YAChD,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;SAClB;QACD,OAAO,KAAK,EAAE,CAAC;KAChB;;;;;;IAED,uCAAgB;;;;;IAAhB,UAAoB,GAAW;QAC7B,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,EAAE;;gBACvD,KAAK,GAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,YAAY;YAEhD,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,EAAE;gBACzC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;aAClB;SACF;QACD,OAAO,KAAK,EAAE,CAAC;KAChB;IACH,mBAAC;CAAA,IAAA;;;;;;AC/CD;IAAA;KA4BC;IA3BQ,kBAAK,GAAG,OAAO,CAAC;IAChB,qBAAQ,GAAG,UAAU,CAAC;IACtB,sBAAS,GAAG,WAAW,CAAC;IACxB,oBAAO,GAAG,SAAS,CAAC;IACpB,sBAAS,GAAG,WAAW,CAAC;IACxB,qBAAQ,GAAG,UAAU,CAAC;IACtB,sBAAS,GAAG,WAAW,CAAC;IACxB,wBAAW,GAAG,aAAa,CAAC;IAC5B,qBAAQ,GAAG,UAAU,CAAC;IACtB,6BAAgB,GAAG,kBAAkB,CAAC;IACtC,wBAAW,GAAG,aAAa,CAAC;IAC5B,0BAAa,GAAG,eAAe,CAAC;IAEhC,gBAAG,GAAG;QACX,YAAY,CAAC,KAAK;QAClB,YAAY,CAAC,QAAQ;QACrB,YAAY,CAAC,SAAS;QACtB,YAAY,CAAC,OAAO;QACpB,YAAY,CAAC,SAAS;QACtB,YAAY,CAAC,QAAQ;QACrB,YAAY,CAAC,SAAS;QACtB,YAAY,CAAC,WAAW;QACxB,YAAY,CAAC,QAAQ;QACrB,YAAY,CAAC,gBAAgB;QAC7B,YAAY,CAAC,WAAW;QACxB,YAAY,CAAC,aAAa;KAC3B,CAAC;IACJ,mBAAC;CA5BD,IA4BC;;;;;;AC5BD;IAwDE,6BAAoB,EAAc,EAAU,OAAe;QAAvC,OAAE,GAAF,EAAE,CAAY;QAAU,YAAO,GAAP,OAAO,CAAQ;QAhClD,eAAU,GAAG,IAAI,CAAC;QAClB,gBAAW,GAAG,SAAS,CAAC;;;;;QAOxB,uBAAkB,GAAG,IAAI,CAAC;;QAGzB,cAAS,GAAG,IAAI,YAAY,EAAW,CAAC;QACxC,eAAU,GAAG,IAAI,YAAY,EAAO,CAAC;QACrC,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACxC,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QACzC,iBAAY,GAAG,IAAI,YAAY,EAAO,CAAC;QACvC,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QACzC,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACxC,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QACzC,qBAAgB,GAAG,IAAI,YAAY,EAAO,CAAC;QAC3C,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACxC,0BAAqB,GAAG,IAAI,YAAY,EAAO,CAAC;QAChD,qBAAgB,GAAG,IAAI,YAAY,EAAO,CAAC;QAC3C,uBAAkB,GAAG,IAAI,YAAY,EAAO,CAAC;QAG/C,uBAAkB,GAAG,CAAC,CAAC;QACvB,wBAAmB,GAAG,CAAC,CAAC;QAExB,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;KAGyB;;;;IAExD,yCAAW;;;IAAnB;QAAA,iBAeC;QAdC,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC,UAAU,CAAC;QAC5C,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC;QAC5D,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY,CAAC;;YACxD,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa;QAEjC,IAAI,MAAM,IAAI,MAAM,CAAC,gBAAgB,EAAE;;gBAC/B,IAAI,GAAG,MAAM,CAAC,gBAAgB,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,gBAAgB,CAAC,QAAQ,CAAC;YAC1E,IAAI,CAAC,CAAC,IAAI,IAAI,IAAI,KAAK,KAAK;iBACzB,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,IAAI,GAAG,CAAC,KAAK,CAAC,MAAM,KAAK,KAAK,CAAC,EAAE;gBACnD,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,OAAO,CAAC;aAC5B;SACF;QAED,OAAO,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,cAAM,OAAA,IAAI,CAAC,GAAG,EAAE,KAAI,CAAC,KAAK,IAAI,SAAS,EAAE,KAAI,CAAC,QAAQ,IAAI,SAAS,CAAC,GAAA,CAAC,CAAC;KAC7G;;;;;IAGD,4CAAc;;;;IADd,UACe,KAAY;;YACnB,MAAM,sBAAG,KAAK,CAAC,MAAM,EAAU;QAErC,IAAI,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,KAAK,IAAI,CAAC,kBAAkB,EAAE;YACpE,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC,UAAU,CAAC;YAC5C,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC;YAC5D,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY,CAAC;YAE9D,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;SACtB;KACF;;;;;IAED,yCAAW;;;;IAAX,UAAY,OAAsB;QAAlC,iBAOC;;YANO,MAAM,GAAG,YAAY,CAAC,EAAE,CAAC,OAAO,CAAC;QACvC,MAAM,CAAC,gBAAgB,CAAM,SAAS,CAAC,CAAC,SAAS,CAAC,UAAA,GAAG,IAAI,OAAA,KAAI,CAAC,eAAe,CAAC,GAAG,CAAC,GAAA,CAAC,CAAC;QACpF,MAAM,CAAC,gBAAgB,CAAM,OAAO,CAAC,CAAC,SAAS,CAAC,UAAA,GAAG,IAAI,OAAA,KAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAA,CAAC,CAAC;QAC5E,MAAM,CAAC,GAAG,CAAU,SAAS,CAAC,CAAC,SAAS,CAAC,UAAA,CAAC,IAAI,OAAA,KAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,GAAA,CAAC,CAAC;QACvE,MAAM,CAAC,QAAQ,CAAU,oBAAoB,CAAC,CAAC,SAAS,CAAC,UAAA,CAAC,IAAI,OAAA,KAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,CAAC,GAAA,CAAC,CAAC;QAC9F,MAAM,CAAC,QAAQ,CAAS,OAAO,CAAC,CAAC,SAAS,CAAC,cAAM,OAAA,KAAI,CAAC,YAAY,EAAE,GAAA,CAAC,CAAC;KACvE;;;;IAED,yCAAW;;;IAAX;QACE,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;YAC9B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;SACxB;QAED,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACtB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SACpB;KACF;;;;IAED,uCAAS;;;IAAT;;QAEE,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,UAAU,EAAE;;gBAC5B,WAAW,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW;;gBAC/C,YAAY,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY;YAEvD,IAAI,IAAI,CAAC,kBAAkB,KAAK,WAAW,IAAI,IAAI,CAAC,mBAAmB,KAAK,YAAY,EAAE;gBACxF,IAAI,CAAC,kBAAkB,GAAG,WAAW,CAAC;gBACtC,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC;gBACxC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;aACtB;SACF;KACF;;;;IAED,6CAAe;;;IAAf;QAAA,iBAEC;QADC,UAAU,CAAC,cAAM,OAAA,KAAI,CAAC,SAAS,EAAE,GAAA,CAAC,CAAC;KACpC;;;;IAEO,uCAAS;;;IAAjB;QACE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEnC,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE;YAC7B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC5B;KACF;;;;;IAEO,6CAAe;;;;IAAvB,UAAwB,GAAiB;QAAzC,iBAuBC;QAtBC,IAAI,GAAG,EAAE;YACP,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;gBAChB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;;gBAGjC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;oBAC/D,IAAI,KAAI,CAAC,MAAM,EAAE;wBACf,KAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;qBACtB;iBACF,CAAC,CAAC;;gBAGH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;;gBAGjC,IAAI,IAAI,CAAC,kBAAkB,EAAE;oBAC3B,IAAI,CAAC,cAAc,EAAE,CAAC;iBACvB;aACF;YAED,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;SAC3C;KACF;;;;IAEO,4CAAc;;;IAAtB;QACE,IAAI,IAAI,CAAC,MAAM,EAAE;;gBACT,MAAM,GAAG,YAAY,CAAC,GAAG;YAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;gBACjD,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;aACpD;SACF;KACF;;;;IAEO,8CAAgB;;;IAAxB;QACE,IAAI,IAAI,CAAC,MAAM,EAAE;;gBACT,MAAM,GAAG,YAAY,CAAC,GAAG;YAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;gBACjD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;aAC/C;SACF;KACF;;;;IAED,mCAAK;;;IAAL;QACE,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;SACrB;KACF;;;;;IAED,2CAAa;;;;IAAb,UAAc,OAAgB;QAC5B,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;SACnG;KACF;;;;;;IAED,uCAAS;;;;;IAAT,UAAU,MAAW,EAAE,IAAU;QAC/B,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;SACrC;KACF;;;;;IAEO,0CAAY;;;;IAApB,UAAqB,KAAK;QAA1B,iBAuCC;QAtCC,QAAQ,KAAK,CAAC,IAAI;YAChB,KAAK,YAAY,CAAC,KAAK;gBACrB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,GAAA,CAAC,CAAC;gBACpD,MAAM;YACR,KAAK,YAAY,CAAC,QAAQ;gBACxB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,GAAA,CAAC,CAAC;gBACvD,MAAM;YACR,KAAK,YAAY,CAAC,SAAS;gBACzB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,GAAA,CAAC,CAAC;gBACxD,MAAM;YACR,KAAK,YAAY,CAAC,OAAO;gBACvB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,GAAA,CAAC,CAAC;gBACtD,MAAM;YACR,KAAK,YAAY,CAAC,SAAS;gBACzB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,GAAA,CAAC,CAAC;gBACxD,MAAM;YACR,KAAK,YAAY,CAAC,QAAQ;gBACxB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,GAAA,CAAC,CAAC;gBACvD,MAAM;YACR,KAAK,YAAY,CAAC,SAAS;gBACzB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,GAAA,CAAC,CAAC;gBACxD,MAAM;YACR,KAAK,YAAY,CAAC,WAAW;gBAC3B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,GAAA,CAAC,CAAC;gBAC1D,MAAM;YACR,KAAK,YAAY,CAAC,QAAQ;gBACxB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,GAAA,CAAC,CAAC;gBACvD,MAAM;YACR,KAAK,YAAY,CAAC,gBAAgB;gBAChC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,CAAC,GAAA,CAAC,CAAC;gBAC/D,MAAM;YACR,KAAK,YAAY,CAAC,WAAW;gBAC3B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,GAAA,CAAC,CAAC;gBAC1D,MAAM;YACR,KAAK,YAAY,CAAC,aAAa;gBAC7B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,GAAA,CAAC,CAAC;gBAC5D,MAAM;SACT;KACF;;;;;IAEO,kDAAoB;;;;IAA5B,UAA6B,MAAe;QAC1C,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,MAAM,GAAG,IAAI,CAAC,cAAc,EAAE,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;SAC1D;KACF;;;;IAEO,0CAAY;;;IAApB;QACE,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,SAAS,EAAE,CAAC;KAClB;;gBA5OF,SAAS,SAAC;oBACT,QAAQ,EAAE,oBAAoB;iBAC/B;;;;gBAXY,UAAU;gBACgB,MAAM;;;0BAY1C,KAAK;wBACL,KAAK;0BACL,KAAK;2BACL,KAAK;wBAML,KAAK;6BACL,KAAK;8BACL,KAAK;8BACL,KAAK;qCAML,KAAK;4BAGL,MAAM;6BACN,MAAM;gCACN,MAAM;iCACN,MAAM;+BACN,MAAM;iCACN,MAAM;gCACN,MAAM;iCACN,MAAM;mCACN,MAAM;gCACN,MAAM;wCACN,MAAM;mCACN,MAAM;qCACN,MAAM;iCA4BN,YAAY,SAAC,eAAe,EAAE,CAAC,QAAQ,CAAC;;IA4K3C,0BAAC;CA7OD;;;;;;ACVA;IAGA;KASiC;;gBAThC,QAAQ,SAAC;oBACR,OAAO,EAAE,EAAE;oBACX,YAAY,EAAE;wBACZ,mBAAmB;qBACpB;oBACD,OAAO,EAAE;wBACP,mBAAmB;qBACpB;iBACF;;IAC+B,uBAAC;CATjC;;;;;;;;;;;;;;"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-echarts.js.map","sources":["ng://ngx-echarts/lib/change-filter.ts","ng://ngx-echarts/lib/ngx-echarts.directive.ts","ng://ngx-echarts/lib/ngx-echarts.module.ts"],"sourcesContent":["import { SimpleChanges } from '@angular/core';\r\nimport { Observable, of, empty } from 'rxjs';\r\n\r\nexport class ChangeFilter {\r\n  constructor(private _changes: SimpleChanges) { }\r\n\r\n  static of(changes: SimpleChanges) {\r\n    return new ChangeFilter(changes);\r\n  }\r\n\r\n  notEmpty<T>(key: string): Observable<T> {\r\n    if (this._changes[key]) {\r\n      const value: T = this._changes[key].currentValue;\r\n\r\n      if (value !== undefined && value !== null) {\r\n        return of(value);\r\n      }\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  has<T>(key: string): Observable<T> {\r\n    if (this._changes[key]) {\r\n      const value: T = this._changes[key].currentValue;\r\n      return of(value);\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  notFirst<T>(key: string): Observable<T> {\r\n    if (this._changes[key] && !this._changes[key].isFirstChange()) {\r\n      const value: T = this._changes[key].currentValue;\r\n      return of(value);\r\n    }\r\n    return empty();\r\n  }\r\n\r\n  notFirstAndEmpty<T>(key: string): Observable<T> {\r\n    if (this._changes[key] && !this._changes[key].isFirstChange()) {\r\n      const value: T = this._changes[key].currentValue;\r\n\r\n      if (value !== undefined && value !== null) {\r\n        return of(value);\r\n      }\r\n    }\r\n    return empty();\r\n  }\r\n}\r\n","import { AfterViewInit, Directive, DoCheck, ElementRef, EventEmitter, Input, NgZone, OnChanges, OnDestroy, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { EChartOption, ECharts, init } from 'echarts';\r\nimport { fromEvent, Observable, Subscription } from 'rxjs';\r\nimport { debounceTime, switchMap } from 'rxjs/operators';\r\nimport { ChangeFilter } from './change-filter';\r\n\r\n@Directive({\r\n  selector: 'echarts, [echarts]',\r\n})\r\nexport class NgxEchartsDirective implements OnChanges, OnDestroy, OnInit, DoCheck, AfterViewInit {\r\n  @Input() options: EChartOption;\r\n  @Input() theme: string;\r\n  @Input() loading: boolean;\r\n  @Input() initOpts: {\r\n    devicePixelRatio?: number\r\n    renderer?: string\r\n    width?: number | string\r\n    height?: number | string\r\n  };\r\n  @Input() merge: EChartOption;\r\n  @Input() autoResize = true;\r\n  @Input() loadingType = 'default';\r\n  @Input() loadingOpts: object;\r\n  @Input() detectEventChanges = true; // deprecated, left for compatibility reasons to avoid triggering major version\r\n\r\n  // ngx-echarts events\r\n  @Output() chartInit = new EventEmitter<ECharts>();\r\n\r\n  // echarts mouse events\r\n  @Output() chartClick = this.createLazyEvent('click');\r\n  @Output() chartDblClick = this.createLazyEvent('dblclick');\r\n  @Output() chartMouseDown = this.createLazyEvent('mousedown');\r\n  @Output() chartMouseMove = this.createLazyEvent('mousemove');\r\n  @Output() chartMouseUp = this.createLazyEvent('mouseup');\r\n  @Output() chartMouseOver = this.createLazyEvent('mouseover');\r\n  @Output() chartMouseOut = this.createLazyEvent('mouseout');\r\n  @Output() chartGlobalOut = this.createLazyEvent('globalout');\r\n  @Output() chartContextMenu = this.createLazyEvent('contextmenu');\r\n\r\n  // echarts mouse events\r\n  @Output() chartLegendSelectChanged = this.createLazyEvent('legendselectchanged');\r\n  @Output() chartLegendSelected = this.createLazyEvent('legendselected');\r\n  @Output() chartLegendUnselected = this.createLazyEvent('legendunselected');\r\n  @Output() chartLegendScroll = this.createLazyEvent('legendscroll');\r\n  @Output() chartDataZoom = this.createLazyEvent('datazoom');\r\n  @Output() chartDataRangeSelected = this.createLazyEvent('datarangeselected');\r\n  @Output() chartTimelineChanged = this.createLazyEvent('timelinechanged');\r\n  @Output() chartTimelinePlayChanged = this.createLazyEvent('timelineplaychanged');\r\n  @Output() chartRestore = this.createLazyEvent('restore');\r\n  @Output() chartDataViewChanged = this.createLazyEvent('dataviewchanged');\r\n  @Output() chartMagicTypeChanged = this.createLazyEvent('magictypechanged');\r\n  @Output() chartPieSelectChanged = this.createLazyEvent('pieselectchanged');\r\n  @Output() chartPieSelected = this.createLazyEvent('pieselected');\r\n  @Output() chartPieUnselected = this.createLazyEvent('pieunselected');\r\n  @Output() chartMapSelectChanged = this.createLazyEvent('mapselectchanged');\r\n  @Output() chartMapSelected = this.createLazyEvent('mapselected');\r\n  @Output() chartMapUnselected = this.createLazyEvent('mapunselected');\r\n  @Output() chartAxisAreaSelected = this.createLazyEvent('axisareaselected');\r\n  @Output() chartFocusNodeAdjacency = this.createLazyEvent('focusnodeadjacency');\r\n  @Output() chartUnfocusNodeAdjacency = this.createLazyEvent('unfocusnodeadjacency');\r\n  @Output() chartBrush = this.createLazyEvent('brush');\r\n  @Output() chartBrushSelected = this.createLazyEvent('brushselected');\r\n  @Output() chartRendered = this.createLazyEvent('rendered');\r\n  @Output() chartFinished = this.createLazyEvent('finished');\r\n\r\n  private chart: ECharts;\r\n  private currentOffsetWidth = 0;\r\n  private currentOffsetHeight = 0;\r\n  private currentWindowWidth: number;\r\n  private resizeSub: Subscription;\r\n\r\n  constructor(private el: ElementRef, private ngZone: NgZone) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const filter = ChangeFilter.of(changes);\r\n    filter.notFirstAndEmpty<any>('options').subscribe(opt => this.onOptionsChange(opt));\r\n    filter.notFirstAndEmpty<any>('merge').subscribe(opt => this.setOption(opt));\r\n    filter.has<boolean>('loading').subscribe(v => this.toggleLoading(!!v));\r\n    filter.notFirst<string>('theme').subscribe(() => this.refreshChart());\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.resizeSub = fromEvent(window, 'resize').pipe(debounceTime(50)).subscribe(() => {\r\n      if (this.autoResize && window.innerWidth !== this.currentWindowWidth) {\r\n        this.currentWindowWidth = window.innerWidth;\r\n        this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n        this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n        this.resize();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.resizeSub.unsubscribe();\r\n    this.dispose();\r\n  }\r\n\r\n  ngDoCheck() {\r\n    // No heavy work in DoCheck!\r\n    if (this.chart && this.autoResize) {\r\n      const offsetWidth = this.el.nativeElement.offsetWidth;\r\n      const offsetHeight = this.el.nativeElement.offsetHeight;\r\n\r\n      if (this.currentOffsetWidth !== offsetWidth || this.currentOffsetHeight !== offsetHeight) {\r\n        this.currentOffsetWidth = offsetWidth;\r\n        this.currentOffsetHeight = offsetHeight;\r\n        this.resize();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    setTimeout(() => this.initChart());\r\n  }\r\n\r\n  private dispose() {\r\n    if (this.chart) {\r\n      this.chart.dispose();\r\n      this.chart = null;\r\n    }\r\n  }\r\n\r\n  private resize() {\r\n    if (this.chart) {\r\n      this.chart.resize();\r\n    }\r\n  }\r\n\r\n  private toggleLoading(loading: boolean) {\r\n    if (this.chart) {\r\n      loading ? this.chart.showLoading(this.loadingType, this.loadingOpts) : this.chart.hideLoading();\r\n    }\r\n  }\r\n\r\n  private setOption(option: any, opts?: any) {\r\n    if (this.chart) {\r\n      this.chart.setOption(option, opts);\r\n    }\r\n  }\r\n\r\n  private refreshChart() {\r\n    this.dispose();\r\n    this.initChart();\r\n  }\r\n\r\n  private createChart() {\r\n    this.currentWindowWidth = window.innerWidth;\r\n    this.currentOffsetWidth = this.el.nativeElement.offsetWidth;\r\n    this.currentOffsetHeight = this.el.nativeElement.offsetHeight;\r\n    const dom = this.el.nativeElement;\r\n\r\n    if (window && window.getComputedStyle) {\r\n      const prop = window.getComputedStyle(dom, null).getPropertyValue('height');\r\n      if ((!prop || prop === '0px') &&\r\n        (!dom.style.height || dom.style.height === '0px')) {\r\n        dom.style.height = '400px';\r\n      }\r\n    }\r\n\r\n    return this.ngZone.runOutsideAngular(() => init(dom, this.theme, this.initOpts));\r\n  }\r\n\r\n  private initChart() {\r\n    this.onOptionsChange(this.options);\r\n\r\n    if (this.merge && this.chart) {\r\n      this.setOption(this.merge);\r\n    }\r\n  }\r\n\r\n  private onOptionsChange(opt: EChartOption) {\r\n    if (opt) {\r\n      if (!this.chart) {\r\n        this.chart = this.createChart();\r\n        this.chartInit.emit(this.chart);\r\n      }\r\n\r\n      this.chart.setOption(this.options, true);\r\n    }\r\n  }\r\n\r\n  // allows to lazily bind to only those events that are requested through the `@Output` by parent components\r\n  // see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info\r\n  private createLazyEvent<T>(eventName: string): EventEmitter<T> {\r\n    return this.chartInit.pipe(\r\n      switchMap((chart: ECharts) => new Observable(observer => {\r\n        chart.on(eventName, (data: T) => this.ngZone.run(() => observer.next(data)));\r\n        return null; // no need to react on unsubscribe as long as the `dispose()` is called in ngOnDestroy\r\n      }))\r\n    ) as EventEmitter<T>;\r\n  }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { NgxEchartsDirective } from './ngx-echarts.directive';\r\n\r\n@NgModule({\r\n  imports: [],\r\n  declarations: [\r\n    NgxEchartsDirective\r\n  ],\r\n  exports: [\r\n    NgxEchartsDirective\r\n  ]\r\n})\r\nexport class NgxEchartsModule { }\r\n"],"names":[],"mappings":"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"}

@@ -1,6 +0,6 @@

import { ElementRef, EventEmitter, OnChanges, OnDestroy, SimpleChanges, NgZone, DoCheck, AfterViewInit } from '@angular/core';
import { AfterViewInit, DoCheck, ElementRef, EventEmitter, NgZone, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';
import { EChartOption } from 'echarts';
export declare class NgxEchartsDirective implements OnChanges, OnDestroy, DoCheck, AfterViewInit {
export declare class NgxEchartsDirective implements OnChanges, OnDestroy, OnInit, DoCheck, AfterViewInit {
private el;
private _ngZone;
private ngZone;
options: EChartOption;

@@ -19,43 +19,57 @@ theme: string;

loadingOpts: object;
/**
* Whether to register event handlers on echartInstance. Default is true.
* Use it to avoid unwanted change detection, if you want to optimize the performance.
*/
detectEventChanges: boolean;
chartInit: EventEmitter<any>;
chartClick: EventEmitter<any>;
chartDblClick: EventEmitter<any>;
chartMouseDown: EventEmitter<any>;
chartMouseUp: EventEmitter<any>;
chartMouseOver: EventEmitter<any>;
chartMouseOut: EventEmitter<any>;
chartGlobalOut: EventEmitter<any>;
chartContextMenu: EventEmitter<any>;
chartDataZoom: EventEmitter<any>;
chartMapSelectChanged: EventEmitter<any>;
chartMapSelected: EventEmitter<any>;
chartMapUnselected: EventEmitter<any>;
private _chart;
chartClick: EventEmitter<{}>;
chartDblClick: EventEmitter<{}>;
chartMouseDown: EventEmitter<{}>;
chartMouseMove: EventEmitter<{}>;
chartMouseUp: EventEmitter<{}>;
chartMouseOver: EventEmitter<{}>;
chartMouseOut: EventEmitter<{}>;
chartGlobalOut: EventEmitter<{}>;
chartContextMenu: EventEmitter<{}>;
chartLegendSelectChanged: EventEmitter<{}>;
chartLegendSelected: EventEmitter<{}>;
chartLegendUnselected: EventEmitter<{}>;
chartLegendScroll: EventEmitter<{}>;
chartDataZoom: EventEmitter<{}>;
chartDataRangeSelected: EventEmitter<{}>;
chartTimelineChanged: EventEmitter<{}>;
chartTimelinePlayChanged: EventEmitter<{}>;
chartRestore: EventEmitter<{}>;
chartDataViewChanged: EventEmitter<{}>;
chartMagicTypeChanged: EventEmitter<{}>;
chartPieSelectChanged: EventEmitter<{}>;
chartPieSelected: EventEmitter<{}>;
chartPieUnselected: EventEmitter<{}>;
chartMapSelectChanged: EventEmitter<{}>;
chartMapSelected: EventEmitter<{}>;
chartMapUnselected: EventEmitter<{}>;
chartAxisAreaSelected: EventEmitter<{}>;
chartFocusNodeAdjacency: EventEmitter<{}>;
chartUnfocusNodeAdjacency: EventEmitter<{}>;
chartBrush: EventEmitter<{}>;
chartBrushSelected: EventEmitter<{}>;
chartRendered: EventEmitter<{}>;
chartFinished: EventEmitter<{}>;
private chart;
private currentOffsetWidth;
private currentOffsetHeight;
private currentWindowWidth;
private _resize$;
private _resizeSub;
constructor(el: ElementRef, _ngZone: NgZone);
private createChart;
onWindowResize(event: Event): void;
private resizeSub;
constructor(el: ElementRef, ngZone: NgZone);
ngOnChanges(changes: SimpleChanges): void;
ngOnInit(): void;
ngOnDestroy(): void;
ngDoCheck(): void;
ngAfterViewInit(): void;
private dispose;
private resize;
private toggleLoading;
private setOption;
private refreshChart;
private createChart;
private initChart;
private onOptionsChange;
private registerEvents;
private unregisterEvents;
clear(): void;
toggleLoading(loading: boolean): void;
setOption(option: any, opts?: any): void;
private eventHandler;
private toggleEventDetectors;
private refreshChart;
private createLazyEvent;
}

@@ -1,1 +0,1 @@

{"__symbolic":"module","version":4,"metadata":{"NgxEchartsModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":3,"character":1},"arguments":[{"imports":[],"declarations":[{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":10,"character":1},"arguments":[{"selector":"echarts, [echarts]"}]}],"members":{"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":14,"character":3}}]}],"theme":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":15,"character":3}}]}],"loading":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":16,"character":3}}]}],"initOpts":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":17,"character":3}}]}],"merge":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":3}}]}],"autoResize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":24,"character":3}}]}],"loadingType":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":25,"character":3}}]}],"loadingOpts":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":26,"character":3}}]}],"detectEventChanges":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":32,"character":3}}]}],"chartInit":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":35,"character":3}}]}],"chartClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":36,"character":3}}]}],"chartDblClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":37,"character":3}}]}],"chartMouseDown":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":38,"character":3}}]}],"chartMouseUp":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":39,"character":3}}]}],"chartMouseOver":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":40,"character":3}}]}],"chartMouseOut":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":41,"character":3}}]}],"chartGlobalOut":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":42,"character":3}}]}],"chartContextMenu":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":43,"character":3}}]}],"chartDataZoom":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":44,"character":3}}]}],"chartMapSelectChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":45,"character":3}}]}],"chartMapSelected":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":46,"character":3}}]}],"chartMapUnselected":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":47,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":56,"character":26},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":56,"character":55}]}],"createChart":[{"__symbolic":"method"}],"onWindowResize":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":75,"character":3},"arguments":["window:resize",["$event"]]}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"ngDoCheck":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"initChart":[{"__symbolic":"method"}],"onOptionsChange":[{"__symbolic":"method"}],"registerEvents":[{"__symbolic":"method"}],"unregisterEvents":[{"__symbolic":"method"}],"clear":[{"__symbolic":"method"}],"toggleLoading":[{"__symbolic":"method"}],"setOption":[{"__symbolic":"method"}],"eventHandler":[{"__symbolic":"method"}],"toggleEventDetectors":[{"__symbolic":"method"}],"refreshChart":[{"__symbolic":"method"}]}}},"origins":{"NgxEchartsModule":"./lib/ngx-echarts.module","ɵa":"./lib/ngx-echarts.directive"},"importAs":"ngx-echarts"}
{"__symbolic":"module","version":4,"metadata":{"NgxEchartsModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":3,"character":1},"arguments":[{"imports":[],"declarations":[{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":6,"character":1},"arguments":[{"selector":"echarts, [echarts]"}]}],"members":{"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"theme":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":11,"character":3}}]}],"loading":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":12,"character":3}}]}],"initOpts":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":3}}]}],"merge":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"autoResize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"loadingType":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"loadingOpts":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":22,"character":3}}]}],"detectEventChanges":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":3}}]}],"chartInit":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":26,"character":3}}]}],"chartClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":29,"character":3}}]}],"chartDblClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":30,"character":3}}]}],"chartMouseDown":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":31,"character":3}}]}],"chartMouseMove":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":32,"character":3}}]}],"chartMouseUp":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":33,"character":3}}]}],"chartMouseOver":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":34,"character":3}}]}],"chartMouseOut":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":35,"character":3}}]}],"chartGlobalOut":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":36,"character":3}}]}],"chartContextMenu":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":37,"character":3}}]}],"chartLegendSelectChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":40,"character":3}}]}],"chartLegendSelected":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":41,"character":3}}]}],"chartLegendUnselected":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":42,"character":3}}]}],"chartLegendScroll":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":43,"character":3}}]}],"chartDataZoom":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":44,"character":3}}]}],"chartDataRangeSelected":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":45,"character":3}}]}],"chartTimelineChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":46,"character":3}}]}],"chartTimelinePlayChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":47,"character":3}}]}],"chartRestore":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":48,"character":3}}]}],"chartDataViewChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":49,"character":3}}]}],"chartMagicTypeChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":50,"character":3}}]}],"chartPieSelectChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":51,"character":3}}]}],"chartPieSelected":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":52,"character":3}}]}],"chartPieUnselected":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":53,"character":3}}]}],"chartMapSelectChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":54,"character":3}}]}],"chartMapSelected":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":55,"character":3}}]}],"chartMapUnselected":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":56,"character":3}}]}],"chartAxisAreaSelected":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":57,"character":3}}]}],"chartFocusNodeAdjacency":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":58,"character":3}}]}],"chartUnfocusNodeAdjacency":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":59,"character":3}}]}],"chartBrush":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":60,"character":3}}]}],"chartBrushSelected":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":61,"character":3}}]}],"chartRendered":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":62,"character":3}}]}],"chartFinished":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":63,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":71,"character":26},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":71,"character":54}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"ngDoCheck":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"dispose":[{"__symbolic":"method"}],"resize":[{"__symbolic":"method"}],"toggleLoading":[{"__symbolic":"method"}],"setOption":[{"__symbolic":"method"}],"refreshChart":[{"__symbolic":"method"}],"createChart":[{"__symbolic":"method"}],"initChart":[{"__symbolic":"method"}],"onOptionsChange":[{"__symbolic":"method"}],"createLazyEvent":[{"__symbolic":"method"}]}}},"origins":{"NgxEchartsModule":"./lib/ngx-echarts.module","ɵa":"./lib/ngx-echarts.directive"},"importAs":"ngx-echarts"}
{
"name": "ngx-echarts",
"version": "4.0.1",
"version": "4.1.0",
"author": "Xie, Ziyu",

@@ -5,0 +5,0 @@ "license": "MIT",

@@ -26,3 +26,3 @@ # ngx-echarts

Latest version @npm:
+ `v4.0.1` for Angular >= 6
+ `v4.1.0` for Angular >= 6
+ `v2.3.1` for Angular < 6 (Please refer to https://github.com/xieziyu/ngx-echarts/blob/v2.x/README.md)

@@ -33,2 +33,7 @@

# Latest Update
+ 2018.12.16: v4.1.0
+ Perfomance update: echarts events are now lazily bounded, so it won't trigger change dectection unexpectedly. Please refer to [PR #154](https://github.com/xieziyu/ngx-echarts/pull/154) for more details. Thanks to [smnbbrv](https://github.com/smnbbrv)!
+ `[detectEventChanges]` is now deprecated.
+ Plenty of echarts event are now [supported](#events).
+ 2018.11.11: v4.0.1

@@ -51,3 +56,2 @@ + Add map events support: (chartMapSelectChanged), (chartMapSelected), (chartMapUnselected). (by [amirch1](https://github.com/amirch1) - [PR #147](https://github.com/xieziyu/ngx-echarts/pull/147))

```
+ No need to configure `angular.json` any more. But we still need to configure `tsconfig.json` currently.
+ Import echarts theme files or other extension files in `main.ts`. Refer to [ECharts Extensions](#echarts-extensions)

@@ -103,30 +107,2 @@

+ tsconfig.json:
You need to map the echarts path to minified version of echarts in the **compilerOptions** of **"tsconfig.json"** in your project's root (this is important for AoT build):
```diff
{
...,
"compilerOptions": {
...,
+ "paths": {
+ "echarts": ["node_modules/echarts/dist/echarts.min.js"]
+ }
}
}
```
+ If you also installed ECharts GL:
```diff
{
...,
"compilerOptions": {
...,
"paths": {
"echarts": ["node_modules/echarts/dist/echarts.min.js"],
+ "echarts-gl": ["node_modules/echarts-gl/dist/echarts-gl.min.js"]
}
}
}
```
+ Import other extentions such as themes or `echarts-gl` in your `main.ts`: [ECharts Extensions](#echarts-extensions)

@@ -136,5 +112,5 @@

## Upgrade from v3.x
1. Remove ECharts related files from `scripts` in `angular.json`, including lib, theme and extension files.
2. Modify `tsconfig.json` according to the installation guidance above.
3. Import necessary theme or extension files in `main.ts`. Refer to [ECharts Extensions](#echarts-extensions).
1. Install `@types/echarts`
2. Import necessary theme or extension files in `main.ts`. Refer to [ECharts Extensions](#echarts-extensions).
3. Remove `echarts` related scripts in `angular.json`.

@@ -297,15 +273,41 @@ # Usage

It supports following event outputs:
+ `chartClick`: It emits the same `params` of `'click'` event
+ `chartDblClick`: It emits the same `params` of `'dblclick'` event
+ `chartMouseDown`: It emits the same `params` of `'mousedown'` event
+ `chartMouseUp`: It emits the same `params` of `'mouseup'` event
+ `chartMouseOver`: It emits the same `params` of `'mouseover'` event
+ `chartMouseOut`: It emits the same `params` of `'mouseout'` event
+ `chartGlobalOut`: It emits the same `params` of `'globalout'` event
+ `chartContextMenu`: It emits the same `params` of `'contextmenu'` event (since v1.2.1)
+ `chartDataZoom`: It emits the same `params` of `'dataZoom'` event (thanks to averhaegen)
+ `chartMapSelectChanged`: It emits the same `params` of `'mapselectchanged'` event (thanks to amirch1)
+ `chartMapSelected`: It emits the same `params` of `'mapselected'` event (thanks to amirch1)
+ `chartMapUnselected`: It emits the same `params` of `'mapunselected'` event (thanks to amirch1)
| @Output | Event |
| ------- | ----- |
| chartInit | Emitted when chart is intialized |
| chartClick | echarts event: `'click'` |
| chartDblClick | echarts event: `'dblclick'` |
| chartMouseDown | echarts event: `'mousedown'` |
| chartMouseMove | echarts event: `'mousemove'` |
| chartMouseUp | echarts event: `'mouseup'` |
| chartMouseOver | echarts event: `'mouseover'` |
| chartMouseOut | echarts event: `'mouseout'` |
| chartGlobalOut | echarts event: `'globalout'` |
| chartContextMenu | echarts event: `'contextmenu'` |
| chartLegendSelectChanged | echarts event: `'legendselectchanged'` |
| chartLegendSelected | echarts event: `'legendselected'` |
| chartLegendUnselected | echarts event: `'legendunselected'` |
| chartLegendScroll | echarts event: `'legendscroll'` |
| chartDataZoom | echarts event: `'datazoom'` |
| chartDataRangeSelected | echarts event: `'datarangeselected'` |
| chartTimelineChanged | echarts event: `'timelinechanged'` |
| chartTimelinePlayChanged | echarts event: `'timelineplaychanged'` |
| chartRestore | echarts event: `'restore'` |
| chartDataViewChanged | echarts event: `'dataviewchanged'` |
| chartMagicTypeChanged | echarts event: `'magictypechanged'` |
| chartPieSelectChanged | echarts event: `'pieselectchanged'` |
| chartPieSelected | echarts event: `'pieselected'` |
| chartPieUnselected | echarts event: `'pieunselected'` |
| chartMapSelectChanged | echarts event: `'mapselectchanged'` |
| chartMapSelected | echarts event: `'mapselected'` |
| chartMapUnselected | echarts event: `'mapunselected'` |
| chartAxisAreaSelected | echarts event: `'axisareaselected'` |
| chartFocusNodeAdjacency | echarts event: `'focusnodeadjacency'` |
| chartUnfocusNodeAdjacency | echarts event: `'unfocusnodeadjacency'` |
| chartBrush | echarts event: `'brush'` |
| chartBrushSelected | echarts event: `'brushselected'` |
| chartRendered | echarts event: `'rendered'` |
| chartFinished | echarts event: `'finished'` |
You can refer to the echarts tutorial: [Events and Actions in ECharts](https://ecomfe.github.io/echarts-doc/public/en/tutorial.html#Events%20and%20Actions%20in%20ECharts) for more details of the event params. You can also refer to the [demo](https://xieziyu.github.io/#/ngx-echarts/demo) page for the detailed example.

@@ -327,2 +329,2 @@

[npm-badge-url]: https://www.npmjs.com/package/ngx-echarts
[ci-url]: https://travis-ci.org/xieziyu/ngx-echarts
[ci-url]: https://travis-ci.org/xieziyu/ngx-echarts

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc