ngx-echarts
Version:
<!-- Badges section here. -->
312 lines • 40.3 kB
JavaScript
import { Directive, EventEmitter, Inject, InjectionToken, Input, Output, } from '@angular/core';
import { Observable, ReplaySubject, Subject, asyncScheduler } from 'rxjs';
import { switchMap, throttleTime } from 'rxjs/operators';
import { ChangeFilterV2 } from './change-filter-v2';
import * as i0 from "@angular/core";
export const NGX_ECHARTS_CONFIG = new InjectionToken('NGX_ECHARTS_CONFIG');
export class NgxEchartsDirective {
constructor(config, el, ngZone) {
this.el = el;
this.ngZone = ngZone;
this.options = null;
this.theme = null;
this.initOpts = null;
this.merge = null;
this.autoResize = true;
this.loading = false;
this.loadingType = 'default';
this.loadingOpts = null;
// ngx-echarts events
this.chartInit = new EventEmitter();
this.optionsError = 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 events
this.chartHighlight = this.createLazyEvent('highlight');
this.chartDownplay = this.createLazyEvent('downplay');
this.chartSelectChanged = this.createLazyEvent('selectchanged');
this.chartLegendSelectChanged = this.createLazyEvent('legendselectchanged');
this.chartLegendSelected = this.createLazyEvent('legendselected');
this.chartLegendUnselected = this.createLazyEvent('legendunselected');
this.chartLegendLegendSelectAll = this.createLazyEvent('legendselectall');
this.chartLegendLegendInverseSelect = this.createLazyEvent('legendinverseselect');
this.chartLegendScroll = this.createLazyEvent('legendscroll');
this.chartDataZoom = this.createLazyEvent('datazoom');
this.chartDataRangeSelected = this.createLazyEvent('datarangeselected');
this.chartGraphRoam = this.createLazyEvent('graphroam');
this.chartGeoRoam = this.createLazyEvent('georoam');
this.chartTreeRoam = this.createLazyEvent('treeroam');
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.chartGeoSelectChanged = this.createLazyEvent('geoselectchanged');
this.chartGeoSelected = this.createLazyEvent('geoselected');
this.chartGeoUnselected = this.createLazyEvent('geounselected');
this.chartAxisAreaSelected = this.createLazyEvent('axisareaselected');
this.chartBrush = this.createLazyEvent('brush');
this.chartBrushEnd = this.createLazyEvent('brushend');
this.chartBrushSelected = this.createLazyEvent('brushselected');
this.chartGlobalCursorTaken = this.createLazyEvent('globalcursortaken');
this.chartRendered = this.createLazyEvent('rendered');
this.chartFinished = this.createLazyEvent('finished');
this.animationFrameID = null;
this.chart$ = new ReplaySubject(1);
this.resize$ = new Subject();
this.changeFilter = new ChangeFilterV2();
this.echarts = config.echarts;
}
ngOnChanges(changes) {
this.changeFilter.doFilter(changes);
}
ngOnInit() {
if (!window.ResizeObserver) {
throw new Error('please install a polyfill for ResizeObserver');
}
this.resizeSub = this.resize$
.pipe(throttleTime(100, asyncScheduler, { leading: false, trailing: true }))
.subscribe(() => this.resize());
if (this.autoResize) {
this.resizeOb = this.ngZone.runOutsideAngular(() => new window.ResizeObserver(() => {
this.animationFrameID = window.requestAnimationFrame(() => this.resize$.next());
}));
this.resizeOb.observe(this.el.nativeElement);
}
this.changeFilter.notFirstAndEmpty('options', opt => this.onOptionsChange(opt));
this.changeFilter.notFirstAndEmpty('merge', opt => this.setOption(opt));
this.changeFilter.has('loading', v => this.toggleLoading(!!v));
this.changeFilter.notFirst('theme', () => this.refreshChart());
}
ngOnDestroy() {
window.clearTimeout(this.initChartTimer);
if (this.resizeSub) {
this.resizeSub.unsubscribe();
}
if (this.animationFrameID) {
window.cancelAnimationFrame(this.animationFrameID);
}
if (this.resizeOb) {
this.resizeOb.unobserve(this.el.nativeElement);
}
if (this.loadingSub) {
this.loadingSub.unsubscribe();
}
this.changeFilter.dispose();
this.dispose();
}
ngAfterViewInit() {
this.initChartTimer = window.setTimeout(() => this.initChart());
}
dispose() {
if (this.chart) {
if (!this.chart.isDisposed()) {
this.chart.dispose();
}
this.chart = null;
}
}
/**
* resize chart
*/
resize() {
if (this.chart) {
this.chart.resize();
}
}
toggleLoading(loading) {
if (this.chart) {
loading
? this.chart.showLoading(this.loadingType, this.loadingOpts)
: this.chart.hideLoading();
}
else {
this.loadingSub = this.chart$.subscribe(chart => loading ? chart.showLoading(this.loadingType, this.loadingOpts) : chart.hideLoading());
}
}
setOption(option, opts) {
if (this.chart) {
try {
this.chart.setOption(option, opts);
}
catch (e) {
console.error(e);
this.optionsError.emit(e);
}
}
}
/**
* dispose old chart and create a new one.
*/
async refreshChart() {
this.dispose();
await this.initChart();
}
createChart() {
const dom = this.el.nativeElement;
if (window && window.getComputedStyle) {
const prop = window.getComputedStyle(dom, null).getPropertyValue('height');
if ((!prop || prop === '0px') && (!dom.style.height || dom.style.height === '0px')) {
dom.style.height = '400px';
}
}
// here a bit tricky: we check if the echarts module is provided as function returning native import('...') then use the promise
// otherwise create the function that imitates behaviour above with a provided as is module
return this.ngZone.runOutsideAngular(() => {
const load = typeof this.echarts === 'function' ? this.echarts : () => Promise.resolve(this.echarts);
return load().then(({ init }) => init(dom, this.theme, this.initOpts));
});
}
async initChart() {
await this.onOptionsChange(this.options);
if (this.merge && this.chart) {
this.setOption(this.merge);
}
}
async onOptionsChange(opt) {
if (!opt) {
return;
}
if (this.chart) {
this.setOption(this.options, true);
}
else {
this.chart = await this.createChart();
this.chart$.next(this.chart);
this.chartInit.emit(this.chart);
this.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
createLazyEvent(eventName) {
return this.chartInit.pipe(switchMap((chart) => new Observable(observer => {
chart.on(eventName, (data) => this.ngZone.run(() => observer.next(data)));
return () => {
if (this.chart) {
if (!this.chart.isDisposed()) {
chart.off(eventName);
}
}
};
})));
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: NgxEchartsDirective, deps: [{ token: NGX_ECHARTS_CONFIG }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.1", type: NgxEchartsDirective, isStandalone: true, selector: "echarts, [echarts]", inputs: { options: "options", theme: "theme", initOpts: "initOpts", merge: "merge", autoResize: "autoResize", loading: "loading", loadingType: "loadingType", loadingOpts: "loadingOpts" }, outputs: { chartInit: "chartInit", optionsError: "optionsError", chartClick: "chartClick", chartDblClick: "chartDblClick", chartMouseDown: "chartMouseDown", chartMouseMove: "chartMouseMove", chartMouseUp: "chartMouseUp", chartMouseOver: "chartMouseOver", chartMouseOut: "chartMouseOut", chartGlobalOut: "chartGlobalOut", chartContextMenu: "chartContextMenu", chartHighlight: "chartHighlight", chartDownplay: "chartDownplay", chartSelectChanged: "chartSelectChanged", chartLegendSelectChanged: "chartLegendSelectChanged", chartLegendSelected: "chartLegendSelected", chartLegendUnselected: "chartLegendUnselected", chartLegendLegendSelectAll: "chartLegendLegendSelectAll", chartLegendLegendInverseSelect: "chartLegendLegendInverseSelect", chartLegendScroll: "chartLegendScroll", chartDataZoom: "chartDataZoom", chartDataRangeSelected: "chartDataRangeSelected", chartGraphRoam: "chartGraphRoam", chartGeoRoam: "chartGeoRoam", chartTreeRoam: "chartTreeRoam", chartTimelineChanged: "chartTimelineChanged", chartTimelinePlayChanged: "chartTimelinePlayChanged", chartRestore: "chartRestore", chartDataViewChanged: "chartDataViewChanged", chartMagicTypeChanged: "chartMagicTypeChanged", chartGeoSelectChanged: "chartGeoSelectChanged", chartGeoSelected: "chartGeoSelected", chartGeoUnselected: "chartGeoUnselected", chartAxisAreaSelected: "chartAxisAreaSelected", chartBrush: "chartBrush", chartBrushEnd: "chartBrushEnd", chartBrushSelected: "chartBrushSelected", chartGlobalCursorTaken: "chartGlobalCursorTaken", chartRendered: "chartRendered", chartFinished: "chartFinished" }, exportAs: ["echarts"], usesOnChanges: true, ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: NgxEchartsDirective, decorators: [{
type: Directive,
args: [{
standalone: true,
selector: 'echarts, [echarts]',
exportAs: 'echarts',
}]
}], ctorParameters: () => [{ type: undefined, decorators: [{
type: Inject,
args: [NGX_ECHARTS_CONFIG]
}] }, { type: i0.ElementRef }, { type: i0.NgZone }], propDecorators: { options: [{
type: Input
}], theme: [{
type: Input
}], initOpts: [{
type: Input
}], merge: [{
type: Input
}], autoResize: [{
type: Input
}], loading: [{
type: Input
}], loadingType: [{
type: Input
}], loadingOpts: [{
type: Input
}], chartInit: [{
type: Output
}], optionsError: [{
type: Output
}], chartClick: [{
type: Output
}], chartDblClick: [{
type: Output
}], chartMouseDown: [{
type: Output
}], chartMouseMove: [{
type: Output
}], chartMouseUp: [{
type: Output
}], chartMouseOver: [{
type: Output
}], chartMouseOut: [{
type: Output
}], chartGlobalOut: [{
type: Output
}], chartContextMenu: [{
type: Output
}], chartHighlight: [{
type: Output
}], chartDownplay: [{
type: Output
}], chartSelectChanged: [{
type: Output
}], chartLegendSelectChanged: [{
type: Output
}], chartLegendSelected: [{
type: Output
}], chartLegendUnselected: [{
type: Output
}], chartLegendLegendSelectAll: [{
type: Output
}], chartLegendLegendInverseSelect: [{
type: Output
}], chartLegendScroll: [{
type: Output
}], chartDataZoom: [{
type: Output
}], chartDataRangeSelected: [{
type: Output
}], chartGraphRoam: [{
type: Output
}], chartGeoRoam: [{
type: Output
}], chartTreeRoam: [{
type: Output
}], chartTimelineChanged: [{
type: Output
}], chartTimelinePlayChanged: [{
type: Output
}], chartRestore: [{
type: Output
}], chartDataViewChanged: [{
type: Output
}], chartMagicTypeChanged: [{
type: Output
}], chartGeoSelectChanged: [{
type: Output
}], chartGeoSelected: [{
type: Output
}], chartGeoUnselected: [{
type: Output
}], chartAxisAreaSelected: [{
type: Output
}], chartBrush: [{
type: Output
}], chartBrushEnd: [{
type: Output
}], chartBrushSelected: [{
type: Output
}], chartGlobalCursorTaken: [{
type: Output
}], chartRendered: [{
type: Output
}], chartFinished: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-echarts.directive.js","sourceRoot":"","sources":["../../../../projects/ngx-echarts/src/lib/ngx-echarts.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  InjectionToken,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { Observable, ReplaySubject, Subject, Subscription, asyncScheduler } from 'rxjs';\nimport { switchMap, throttleTime } from 'rxjs/operators';\nimport { ChangeFilterV2 } from './change-filter-v2';\nimport type { EChartsOption, ECharts, ECElementEvent } from 'echarts';\n\nexport interface NgxEchartsConfig {\n  echarts: any | (() => Promise<any>);\n}\n\nexport type ThemeOption = Record<string, any>;\n\nexport const NGX_ECHARTS_CONFIG = new InjectionToken<NgxEchartsConfig>('NGX_ECHARTS_CONFIG');\n\n@Directive({\n  standalone: true,\n  selector: 'echarts, [echarts]',\n  exportAs: 'echarts',\n})\nexport class NgxEchartsDirective implements OnChanges, OnDestroy, OnInit, AfterViewInit {\n  @Input() options: EChartsOption | null = null;\n  @Input() theme: string | ThemeOption | null = null;\n  @Input() initOpts: {\n    devicePixelRatio?: number;\n    renderer?: string;\n    width?: number | string;\n    height?: number | string;\n    locale?: string;\n  } | null = null;\n  @Input() merge: EChartsOption | null = null;\n  @Input() autoResize = true;\n  @Input() loading = false;\n  @Input() loadingType = 'default';\n  @Input() loadingOpts: object | null = null;\n\n  // ngx-echarts events\n  @Output() chartInit = new EventEmitter<any>();\n  @Output() optionsError = new EventEmitter<Error>();\n\n  // echarts mouse events\n  @Output() chartClick = this.createLazyEvent<ECElementEvent>('click');\n  @Output() chartDblClick = this.createLazyEvent<ECElementEvent>('dblclick');\n  @Output() chartMouseDown = this.createLazyEvent<ECElementEvent>('mousedown');\n  @Output() chartMouseMove = this.createLazyEvent<ECElementEvent>('mousemove');\n  @Output() chartMouseUp = this.createLazyEvent<ECElementEvent>('mouseup');\n  @Output() chartMouseOver = this.createLazyEvent<ECElementEvent>('mouseover');\n  @Output() chartMouseOut = this.createLazyEvent<ECElementEvent>('mouseout');\n  @Output() chartGlobalOut = this.createLazyEvent<ECElementEvent>('globalout');\n  @Output() chartContextMenu = this.createLazyEvent<ECElementEvent>('contextmenu');\n\n  // echarts events\n  @Output() chartHighlight = this.createLazyEvent<any>('highlight');\n  @Output() chartDownplay = this.createLazyEvent<any>('downplay');\n  @Output() chartSelectChanged = this.createLazyEvent<any>('selectchanged');\n  @Output() chartLegendSelectChanged = this.createLazyEvent<any>('legendselectchanged');\n  @Output() chartLegendSelected = this.createLazyEvent<any>('legendselected');\n  @Output() chartLegendUnselected = this.createLazyEvent<any>('legendunselected');\n  @Output() chartLegendLegendSelectAll = this.createLazyEvent<any>('legendselectall');\n  @Output() chartLegendLegendInverseSelect = this.createLazyEvent<any>('legendinverseselect');\n  @Output() chartLegendScroll = this.createLazyEvent<any>('legendscroll');\n  @Output() chartDataZoom = this.createLazyEvent<any>('datazoom');\n  @Output() chartDataRangeSelected = this.createLazyEvent<any>('datarangeselected');\n  @Output() chartGraphRoam = this.createLazyEvent<any>('graphroam');\n  @Output() chartGeoRoam = this.createLazyEvent<any>('georoam');\n  @Output() chartTreeRoam = this.createLazyEvent<any>('treeroam');\n  @Output() chartTimelineChanged = this.createLazyEvent<any>('timelinechanged');\n  @Output() chartTimelinePlayChanged = this.createLazyEvent<any>('timelineplaychanged');\n  @Output() chartRestore = this.createLazyEvent<any>('restore');\n  @Output() chartDataViewChanged = this.createLazyEvent<any>('dataviewchanged');\n  @Output() chartMagicTypeChanged = this.createLazyEvent<any>('magictypechanged');\n  @Output() chartGeoSelectChanged = this.createLazyEvent<any>('geoselectchanged');\n  @Output() chartGeoSelected = this.createLazyEvent<any>('geoselected');\n  @Output() chartGeoUnselected = this.createLazyEvent<any>('geounselected');\n  @Output() chartAxisAreaSelected = this.createLazyEvent<any>('axisareaselected');\n  @Output() chartBrush = this.createLazyEvent<any>('brush');\n  @Output() chartBrushEnd = this.createLazyEvent<any>('brushend');\n  @Output() chartBrushSelected = this.createLazyEvent<any>('brushselected');\n  @Output() chartGlobalCursorTaken = this.createLazyEvent<any>('globalcursortaken');\n  @Output() chartRendered = this.createLazyEvent<any>('rendered');\n  @Output() chartFinished = this.createLazyEvent<any>('finished');\n\n  public animationFrameID = null;\n  private chart: ECharts;\n  private chart$ = new ReplaySubject<ECharts>(1);\n  private echarts: any;\n  private resizeOb: ResizeObserver;\n  private resize$ = new Subject<void>();\n  private resizeSub: Subscription;\n  private initChartTimer?: number;\n  private changeFilter = new ChangeFilterV2();\n  private loadingSub: Subscription;\n\n  constructor(\n    @Inject(NGX_ECHARTS_CONFIG) config: NgxEchartsConfig,\n    private el: ElementRef,\n    private ngZone: NgZone\n  ) {\n    this.echarts = config.echarts;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    this.changeFilter.doFilter(changes);\n  }\n\n  ngOnInit() {\n    if (!window.ResizeObserver) {\n      throw new Error('please install a polyfill for ResizeObserver');\n    }\n    this.resizeSub = this.resize$\n      .pipe(throttleTime(100, asyncScheduler, { leading: false, trailing: true }))\n      .subscribe(() => this.resize());\n\n    if (this.autoResize) {\n      this.resizeOb = this.ngZone.runOutsideAngular(\n        () =>\n          new window.ResizeObserver(() => {\n            this.animationFrameID = window.requestAnimationFrame(() => this.resize$.next());\n          })\n      );\n      this.resizeOb.observe(this.el.nativeElement);\n    }\n\n    this.changeFilter.notFirstAndEmpty('options', opt => this.onOptionsChange(opt));\n    this.changeFilter.notFirstAndEmpty('merge', opt => this.setOption(opt));\n    this.changeFilter.has<boolean>('loading', v => this.toggleLoading(!!v));\n    this.changeFilter.notFirst<string | ThemeOption>('theme', () => this.refreshChart());\n  }\n\n  ngOnDestroy() {\n    window.clearTimeout(this.initChartTimer);\n    if (this.resizeSub) {\n      this.resizeSub.unsubscribe();\n    }\n    if (this.animationFrameID) {\n      window.cancelAnimationFrame(this.animationFrameID);\n    }\n    if (this.resizeOb) {\n      this.resizeOb.unobserve(this.el.nativeElement);\n    }\n    if (this.loadingSub) {\n      this.loadingSub.unsubscribe();\n    }\n    this.changeFilter.dispose();\n    this.dispose();\n  }\n\n  ngAfterViewInit() {\n    this.initChartTimer = window.setTimeout(() => this.initChart());\n  }\n\n  private dispose() {\n    if (this.chart) {\n      if (!this.chart.isDisposed()) {\n        this.chart.dispose();\n      }\n      this.chart = null;\n    }\n  }\n\n  /**\n   * resize chart\n   */\n  resize() {\n    if (this.chart) {\n      this.chart.resize();\n    }\n  }\n\n  private toggleLoading(loading: boolean) {\n    if (this.chart) {\n      loading\n        ? this.chart.showLoading(this.loadingType, this.loadingOpts)\n        : this.chart.hideLoading();\n    } else {\n      this.loadingSub = this.chart$.subscribe(chart =>\n        loading ? chart.showLoading(this.loadingType, this.loadingOpts) : chart.hideLoading()\n      );\n    }\n  }\n\n  private setOption(option: any, opts?: any) {\n    if (this.chart) {\n      try {\n        this.chart.setOption(option, opts);\n      } catch (e) {\n        console.error(e);\n        this.optionsError.emit(e);\n      }\n    }\n  }\n\n  /**\n   * dispose old chart and create a new one.\n   */\n  async refreshChart() {\n    this.dispose();\n    await this.initChart();\n  }\n\n  private createChart() {\n    const dom = this.el.nativeElement;\n\n    if (window && window.getComputedStyle) {\n      const prop = window.getComputedStyle(dom, null).getPropertyValue('height');\n      if ((!prop || prop === '0px') && (!dom.style.height || dom.style.height === '0px')) {\n        dom.style.height = '400px';\n      }\n    }\n\n    // here a bit tricky: we check if the echarts module is provided as function returning native import('...') then use the promise\n    // otherwise create the function that imitates behaviour above with a provided as is module\n    return this.ngZone.runOutsideAngular(() => {\n      const load =\n        typeof this.echarts === 'function' ? this.echarts : () => Promise.resolve(this.echarts);\n\n      return load().then(({ init }) => init(dom, this.theme, this.initOpts));\n    });\n  }\n\n  private async initChart() {\n    await this.onOptionsChange(this.options);\n\n    if (this.merge && this.chart) {\n      this.setOption(this.merge);\n    }\n  }\n\n  private async onOptionsChange(opt: any) {\n    if (!opt) {\n      return;\n    }\n\n    if (this.chart) {\n      this.setOption(this.options, true);\n    } else {\n      this.chart = await this.createChart();\n      this.chart$.next(this.chart);\n      this.chartInit.emit(this.chart);\n      this.setOption(this.options, true);\n    }\n  }\n\n  // allows to lazily bind to only those events that are requested through the `@Output` by parent components\n  // see https://stackoverflow.com/questions/51787972/optimal-reentering-the-ngzone-from-eventemitter-event for more info\n  private createLazyEvent<T>(eventName: string): EventEmitter<T> {\n    return this.chartInit.pipe(\n      switchMap(\n        (chart: any) =>\n          new Observable(observer => {\n            chart.on(eventName, (data: T) => this.ngZone.run(() => observer.next(data)));\n            return () => {\n              if (this.chart) {\n                if (!this.chart.isDisposed()) {\n                  chart.off(eventName);\n                }\n              }\n            };\n          })\n      )\n    ) as EventEmitter<T>;\n  }\n}\n"]}