ngx-echarts
Advanced tools
Comparing version 4.0.1 to 4.1.0
(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":"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"} |
@@ -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":"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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"]} |
@@ -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":";;;;;;;;;AACA,MAEa,YAAY;;;;IACvB,YAAoB,QAAuB;QAAvB,aAAQ,GAAR,QAAQ,CAAe;KAAK;;;;;IAEhD,OAAO,EAAE,CAAC,OAAsB;QAC9B,OAAO,IAAI,YAAY,CAAC,OAAO,CAAC,CAAC;KAClC;;;;;;IAED,QAAQ,CAAI,GAAW;QACrB,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;;kBAChB,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,GAAG,CAAI,GAAW;QAChB,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;;kBAChB,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,QAAQ,CAAI,GAAW;QACrB,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,EAAE;;kBACvD,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,gBAAgB,CAAI,GAAW;QAC7B,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,EAAE;;kBACvD,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;CACF;;;;;;AC/CD,MASa,mBAAmB;;;;;IA8D9B,YAAoB,EAAc,EAAU,MAAc;QAAtC,OAAE,GAAF,EAAE,CAAY;QAAU,WAAM,GAAN,MAAM,CAAQ;QAnDjD,eAAU,GAAG,IAAI,CAAC;QAClB,gBAAW,GAAG,SAAS,CAAC;QAExB,uBAAkB,GAAG,IAAI,CAAC;;;QAGzB,cAAS,GAAG,IAAI,YAAY,EAAW,CAAC;;QAGxC,eAAU,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAC3C,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QACjD,mBAAc,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;QACnD,mBAAc,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;QACnD,iBAAY,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;QAC/C,mBAAc,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;QACnD,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QACjD,mBAAc,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;QACnD,qBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;;QAGvD,6BAAwB,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC;QACvE,wBAAmB,GAAG,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;QAC7D,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;QACjE,sBAAiB,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC;QACzD,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QACjD,2BAAsB,GAAG,IAAI,CAAC,eAAe,CAAC,mBAAmB,CAAC,CAAC;QACnE,yBAAoB,GAAG,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC;QAC/D,6BAAwB,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC;QACvE,iBAAY,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;QAC/C,yBAAoB,GAAG,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC;QAC/D,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;QACjE,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;QACjE,qBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;QACvD,uBAAkB,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;QAC3D,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;QACjE,qBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;QACvD,uBAAkB,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;QAC3D,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;QACjE,4BAAuB,GAAG,IAAI,CAAC,eAAe,CAAC,oBAAoB,CAAC,CAAC;QACrE,8BAAyB,GAAG,IAAI,CAAC,eAAe,CAAC,sBAAsB,CAAC,CAAC;QACzE,eAAU,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAC3C,uBAAkB,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;QAC3D,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QACjD,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QAGnD,uBAAkB,GAAG,CAAC,CAAC;QACvB,wBAAmB,GAAG,CAAC,CAAC;KAI+B;;;;;IAE/D,WAAW,CAAC,OAAsB;;cAC1B,MAAM,GAAG,YAAY,CAAC,EAAE,CAAC,OAAO,CAAC;QACvC,MAAM,CAAC,gBAAgB,CAAM,SAAS,CAAC,CAAC,SAAS,CAAC,GAAG,IAAI,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC;QACpF,MAAM,CAAC,gBAAgB,CAAM,OAAO,CAAC,CAAC,SAAS,CAAC,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;QAC5E,MAAM,CAAC,GAAG,CAAU,SAAS,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACvE,MAAM,CAAC,QAAQ,CAAS,OAAO,CAAC,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;KACvE;;;;IAED,QAAQ;QACN,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;YAC5E,IAAI,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,KAAK,IAAI,CAAC,kBAAkB,EAAE;gBACpE,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;gBAC9D,IAAI,CAAC,MAAM,EAAE,CAAC;aACf;SACF,CAAC,CAAC;KACJ;;;;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;QAC7B,IAAI,CAAC,OAAO,EAAE,CAAC;KAChB;;;;IAED,SAAS;;QAEP,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,EAAE;;kBAC3B,WAAW,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW;;kBAC/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,MAAM,EAAE,CAAC;aACf;SACF;KACF;;;;IAED,eAAe;QACb,UAAU,CAAC,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;KACpC;;;;IAEO,OAAO;QACb,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;YACrB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;SACnB;KACF;;;;IAEO,MAAM;QACZ,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;SACrB;KACF;;;;;IAEO,aAAa,CAAC,OAAgB;QACpC,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;SACjG;KACF;;;;;;IAEO,SAAS,CAAC,MAAW,EAAE,IAAU;QACvC,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;SACpC;KACF;;;;IAEO,YAAY;QAClB,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,SAAS,EAAE,CAAC;KAClB;;;;IAEO,WAAW;QACjB,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;;cACxD,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa;QAEjC,IAAI,MAAM,IAAI,MAAM,CAAC,gBAAgB,EAAE;;kBAC/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,MAAM,CAAC,iBAAiB,CAAC,MAAM,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;KAClF;;;;IAEO,SAAS;QACf,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEnC,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE;YAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC5B;KACF;;;;;IAEO,eAAe,CAAC,GAAiB;QACvC,IAAI,GAAG,EAAE;YACP,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;gBACf,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;gBAChC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACjC;YAED,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;SAC1C;KACF;;;;;;;;IAIO,eAAe,CAAI,SAAiB;QAC1C,0BAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CACxB,SAAS,CAAC,CAAC,KAAc,KAAK,IAAI,UAAU,CAAC,QAAQ;YACnD,KAAK,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,IAAO,KAAK,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAC7E,OAAO,IAAI,CAAC;SACb,CAAC,CAAC,CACJ,GAAoB;KACtB;;;YAxLF,SAAS,SAAC;gBACT,QAAQ,EAAE,oBAAoB;aAC/B;;;;YAR2C,UAAU;YAAuB,MAAM;;;sBAUhF,KAAK;oBACL,KAAK;sBACL,KAAK;uBACL,KAAK;oBAML,KAAK;yBACL,KAAK;0BACL,KAAK;0BACL,KAAK;iCACL,KAAK;wBAGL,MAAM;yBAGN,MAAM;4BACN,MAAM;6BACN,MAAM;6BACN,MAAM;2BACN,MAAM;6BACN,MAAM;4BACN,MAAM;6BACN,MAAM;+BACN,MAAM;uCAGN,MAAM;kCACN,MAAM;oCACN,MAAM;gCACN,MAAM;4BACN,MAAM;qCACN,MAAM;mCACN,MAAM;uCACN,MAAM;2BACN,MAAM;mCACN,MAAM;oCACN,MAAM;oCACN,MAAM;+BACN,MAAM;iCACN,MAAM;oCACN,MAAM;+BACN,MAAM;iCACN,MAAM;oCACN,MAAM;sCACN,MAAM;wCACN,MAAM;yBACN,MAAM;iCACN,MAAM;4BACN,MAAM;4BACN,MAAM;;;;;;;AC/DT,MAYa,gBAAgB;;;YAT5B,QAAQ,SAAC;gBACR,OAAO,EAAE,EAAE;gBACX,YAAY,EAAE;oBACZ,mBAAmB;iBACpB;gBACD,OAAO,EAAE;oBACP,mBAAmB;iBACpB;aACF;;;;;;;;;;;;;;;"} |
@@ -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":"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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":";;;;;;;;;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;IAuEE,6BAAoB,EAAc,EAAU,MAAc;QAAtC,OAAE,GAAF,EAAE,CAAY;QAAU,WAAM,GAAN,MAAM,CAAQ;QAnDjD,eAAU,GAAG,IAAI,CAAC;QAClB,gBAAW,GAAG,SAAS,CAAC;QAExB,uBAAkB,GAAG,IAAI,CAAC;;;QAGzB,cAAS,GAAG,IAAI,YAAY,EAAW,CAAC;;QAGxC,eAAU,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAC3C,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QACjD,mBAAc,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;QACnD,mBAAc,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;QACnD,iBAAY,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;QAC/C,mBAAc,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;QACnD,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QACjD,mBAAc,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;QACnD,qBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;;QAGvD,6BAAwB,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC;QACvE,wBAAmB,GAAG,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;QAC7D,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;QACjE,sBAAiB,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC;QACzD,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QACjD,2BAAsB,GAAG,IAAI,CAAC,eAAe,CAAC,mBAAmB,CAAC,CAAC;QACnE,yBAAoB,GAAG,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC;QAC/D,6BAAwB,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC;QACvE,iBAAY,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;QAC/C,yBAAoB,GAAG,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC;QAC/D,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;QACjE,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;QACjE,qBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;QACvD,uBAAkB,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;QAC3D,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;QACjE,qBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;QACvD,uBAAkB,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;QAC3D,0BAAqB,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;QACjE,4BAAuB,GAAG,IAAI,CAAC,eAAe,CAAC,oBAAoB,CAAC,CAAC;QACrE,8BAAyB,GAAG,IAAI,CAAC,eAAe,CAAC,sBAAsB,CAAC,CAAC;QACzE,eAAU,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAC3C,uBAAkB,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;QAC3D,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QACjD,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QAGnD,uBAAkB,GAAG,CAAC,CAAC;QACvB,wBAAmB,GAAG,CAAC,CAAC;KAI+B;;;;;IAE/D,yCAAW;;;;IAAX,UAAY,OAAsB;QAAlC,iBAMC;;YALO,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,CAAS,OAAO,CAAC,CAAC,SAAS,CAAC,cAAM,OAAA,KAAI,CAAC,YAAY,EAAE,GAAA,CAAC,CAAC;KACvE;;;;IAED,sCAAQ;;;IAAR;QAAA,iBASC;QARC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;YAC5E,IAAI,KAAI,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,KAAK,KAAI,CAAC,kBAAkB,EAAE;gBACpE,KAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC,UAAU,CAAC;gBAC5C,KAAI,CAAC,kBAAkB,GAAG,KAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC;gBAC5D,KAAI,CAAC,mBAAmB,GAAG,KAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY,CAAC;gBAC9D,KAAI,CAAC,MAAM,EAAE,CAAC;aACf;SACF,CAAC,CAAC;KACJ;;;;IAED,yCAAW;;;IAAX;QACE,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;QAC7B,IAAI,CAAC,OAAO,EAAE,CAAC;KAChB;;;;IAED,uCAAS;;;IAAT;;QAEE,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,EAAE;;gBAC3B,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,MAAM,EAAE,CAAC;aACf;SACF;KACF;;;;IAED,6CAAe;;;IAAf;QAAA,iBAEC;QADC,UAAU,CAAC,cAAM,OAAA,KAAI,CAAC,SAAS,EAAE,GAAA,CAAC,CAAC;KACpC;;;;IAEO,qCAAO;;;IAAf;QACE,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;YACrB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;SACnB;KACF;;;;IAEO,oCAAM;;;IAAd;QACE,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;SACrB;KACF;;;;;IAEO,2CAAa;;;;IAArB,UAAsB,OAAgB;QACpC,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;SACjG;KACF;;;;;;IAEO,uCAAS;;;;;IAAjB,UAAkB,MAAW,EAAE,IAAU;QACvC,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;SACpC;KACF;;;;IAEO,0CAAY;;;IAApB;QACE,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,SAAS,EAAE,CAAC;KAClB;;;;IAEO,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,MAAM,CAAC,iBAAiB,CAAC,cAAM,OAAA,IAAI,CAAC,GAAG,EAAE,KAAI,CAAC,KAAK,EAAE,KAAI,CAAC,QAAQ,CAAC,GAAA,CAAC,CAAC;KAClF;;;;IAEO,uCAAS;;;IAAjB;QACE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEnC,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE;YAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC5B;KACF;;;;;IAEO,6CAAe;;;;IAAvB,UAAwB,GAAiB;QACvC,IAAI,GAAG,EAAE;YACP,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;gBACf,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;gBAChC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACjC;YAED,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;SAC1C;KACF;;;;;;;;;;IAIO,6CAAe;;;;;;;;IAAvB,UAA2B,SAAiB;QAA5C,iBAOC;QANC,0BAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CACxB,SAAS,CAAC,UAAC,KAAc,IAAK,OAAA,IAAI,UAAU,CAAC,UAAA,QAAQ;YACnD,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;YAC7E,OAAO,IAAI,CAAC;SACb,CAAC,GAAA,CAAC,CACJ,GAAoB;KACtB;;gBAxLF,SAAS,SAAC;oBACT,QAAQ,EAAE,oBAAoB;iBAC/B;;;;gBAR2C,UAAU;gBAAuB,MAAM;;;0BAUhF,KAAK;wBACL,KAAK;0BACL,KAAK;2BACL,KAAK;wBAML,KAAK;6BACL,KAAK;8BACL,KAAK;8BACL,KAAK;qCACL,KAAK;4BAGL,MAAM;6BAGN,MAAM;gCACN,MAAM;iCACN,MAAM;iCACN,MAAM;+BACN,MAAM;iCACN,MAAM;gCACN,MAAM;iCACN,MAAM;mCACN,MAAM;2CAGN,MAAM;sCACN,MAAM;wCACN,MAAM;oCACN,MAAM;gCACN,MAAM;yCACN,MAAM;uCACN,MAAM;2CACN,MAAM;+BACN,MAAM;uCACN,MAAM;wCACN,MAAM;wCACN,MAAM;mCACN,MAAM;qCACN,MAAM;wCACN,MAAM;mCACN,MAAM;qCACN,MAAM;wCACN,MAAM;0CACN,MAAM;4CACN,MAAM;6BACN,MAAM;qCACN,MAAM;gCACN,MAAM;gCACN,MAAM;;IAiIT,0BAAC;CA1LD;;;;;;ACNA;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;;;;;;;;;;;;;;"} |
@@ -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
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
324
313264
26
2459
1