ng-apexcharts
Version:
An angular implementation of ApexCharts
225 lines • 28 kB
JavaScript
import { Component, ElementRef, Input, Output, ViewChild, NgZone, ChangeDetectionStrategy, EventEmitter, } from "@angular/core";
import { asapScheduler } from "rxjs";
import ApexCharts from "apexcharts";
import * as i0 from "@angular/core";
export class ChartComponent {
constructor(ngZone) {
this.ngZone = ngZone;
this.autoUpdateSeries = true;
this.chartReady = new EventEmitter();
}
ngOnChanges(changes) {
asapScheduler.schedule(() => {
if (this.autoUpdateSeries &&
Object.keys(changes).filter((c) => c !== "series").length === 0) {
this.updateSeries(this.series, true);
return;
}
this.createElement();
});
}
ngOnDestroy() {
if (this.chartObj) {
this.chartObj.destroy();
}
}
createElement() {
const options = {};
if (this.annotations) {
options.annotations = this.annotations;
}
if (this.chart) {
options.chart = this.chart;
}
if (this.colors) {
options.colors = this.colors;
}
if (this.dataLabels) {
options.dataLabels = this.dataLabels;
}
if (this.series) {
options.series = this.series;
}
if (this.stroke) {
options.stroke = this.stroke;
}
if (this.labels) {
options.labels = this.labels;
}
if (this.legend) {
options.legend = this.legend;
}
if (this.fill) {
options.fill = this.fill;
}
if (this.tooltip) {
options.tooltip = this.tooltip;
}
if (this.plotOptions) {
options.plotOptions = this.plotOptions;
}
if (this.responsive) {
options.responsive = this.responsive;
}
if (this.markers) {
options.markers = this.markers;
}
if (this.noData) {
options.noData = this.noData;
}
if (this.xaxis) {
options.xaxis = this.xaxis;
}
if (this.yaxis) {
options.yaxis = this.yaxis;
}
if (this.forecastDataPoints) {
options.forecastDataPoints = this.forecastDataPoints;
}
if (this.grid) {
options.grid = this.grid;
}
if (this.states) {
options.states = this.states;
}
if (this.title) {
options.title = this.title;
}
if (this.subtitle) {
options.subtitle = this.subtitle;
}
if (this.theme) {
options.theme = this.theme;
}
if (this.chartObj) {
this.chartObj.destroy();
}
this.ngZone.runOutsideAngular(() => {
this.chartObj = new ApexCharts(this.chartElement.nativeElement, options);
});
this.render();
this.chartReady.emit({ chartObj: this.chartObj });
}
render() {
return this.ngZone.runOutsideAngular(() => this.chartObj.render());
}
updateOptions(options, redrawPaths, animate, updateSyncedCharts) {
return this.ngZone.runOutsideAngular(() => this.chartObj.updateOptions(options, redrawPaths, animate, updateSyncedCharts));
}
updateSeries(newSeries, animate) {
return this.ngZone.runOutsideAngular(() => this.chartObj.updateSeries(newSeries, animate));
}
appendSeries(newSeries, animate) {
this.ngZone.runOutsideAngular(() => this.chartObj.appendSeries(newSeries, animate));
}
appendData(newData) {
this.ngZone.runOutsideAngular(() => this.chartObj.appendData(newData));
}
toggleSeries(seriesName) {
return this.ngZone.runOutsideAngular(() => this.chartObj.toggleSeries(seriesName));
}
showSeries(seriesName) {
this.ngZone.runOutsideAngular(() => this.chartObj.showSeries(seriesName));
}
hideSeries(seriesName) {
this.ngZone.runOutsideAngular(() => this.chartObj.hideSeries(seriesName));
}
resetSeries() {
this.ngZone.runOutsideAngular(() => this.chartObj.resetSeries());
}
zoomX(min, max) {
this.ngZone.runOutsideAngular(() => this.chartObj.zoomX(min, max));
}
toggleDataPointSelection(seriesIndex, dataPointIndex) {
this.ngZone.runOutsideAngular(() => this.chartObj.toggleDataPointSelection(seriesIndex, dataPointIndex));
}
destroy() {
this.chartObj.destroy();
}
setLocale(localeName) {
this.ngZone.runOutsideAngular(() => this.chartObj.setLocale(localeName));
}
paper() {
this.ngZone.runOutsideAngular(() => this.chartObj.paper());
}
addXaxisAnnotation(options, pushToMemory, context) {
this.ngZone.runOutsideAngular(() => this.chartObj.addXaxisAnnotation(options, pushToMemory, context));
}
addYaxisAnnotation(options, pushToMemory, context) {
this.ngZone.runOutsideAngular(() => this.chartObj.addYaxisAnnotation(options, pushToMemory, context));
}
addPointAnnotation(options, pushToMemory, context) {
this.ngZone.runOutsideAngular(() => this.chartObj.addPointAnnotation(options, pushToMemory, context));
}
removeAnnotation(id, options) {
this.ngZone.runOutsideAngular(() => this.chartObj.removeAnnotation(id, options));
}
clearAnnotations(options) {
this.ngZone.runOutsideAngular(() => this.chartObj.clearAnnotations(options));
}
dataURI(options) {
return this.chartObj.dataURI(options);
}
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ChartComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.1", type: ChartComponent, selector: "apx-chart", inputs: { chart: "chart", annotations: "annotations", colors: "colors", dataLabels: "dataLabels", series: "series", stroke: "stroke", labels: "labels", legend: "legend", markers: "markers", noData: "noData", fill: "fill", tooltip: "tooltip", plotOptions: "plotOptions", responsive: "responsive", xaxis: "xaxis", yaxis: "yaxis", forecastDataPoints: "forecastDataPoints", grid: "grid", states: "states", title: "title", subtitle: "subtitle", theme: "theme", autoUpdateSeries: "autoUpdateSeries" }, outputs: { chartReady: "chartReady" }, viewQueries: [{ propertyName: "chartElement", first: true, predicate: ["chart"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: `<div #chart></div>`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ChartComponent, decorators: [{
type: Component,
args: [{
selector: "apx-chart",
template: `<div #chart></div>`,
changeDetection: ChangeDetectionStrategy.OnPush
}]
}], ctorParameters: () => [{ type: i0.NgZone }], propDecorators: { chart: [{
type: Input
}], annotations: [{
type: Input
}], colors: [{
type: Input
}], dataLabels: [{
type: Input
}], series: [{
type: Input
}], stroke: [{
type: Input
}], labels: [{
type: Input
}], legend: [{
type: Input
}], markers: [{
type: Input
}], noData: [{
type: Input
}], fill: [{
type: Input
}], tooltip: [{
type: Input
}], plotOptions: [{
type: Input
}], responsive: [{
type: Input
}], xaxis: [{
type: Input
}], yaxis: [{
type: Input
}], forecastDataPoints: [{
type: Input
}], grid: [{
type: Input
}], states: [{
type: Input
}], title: [{
type: Input
}], subtitle: [{
type: Input
}], theme: [{
type: Input
}], autoUpdateSeries: [{
type: Input
}], chartReady: [{
type: Output
}], chartElement: [{
type: ViewChild,
args: ["chart", { static: true }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.component.js","sourceRoot":"","sources":["../../../../../projects/ng-apexcharts/src/lib/chart/chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  Input,\n  Output,\n  OnChanges,\n  OnDestroy,\n  SimpleChanges,\n  ViewChild,\n  NgZone,\n  ChangeDetectionStrategy,\n  EventEmitter,\n} from \"@angular/core\";\nimport {\n  ApexAnnotations,\n  ApexAxisChartSeries,\n  ApexChart,\n  ApexDataLabels,\n  ApexFill,\n  ApexGrid,\n  ApexLegend,\n  ApexNonAxisChartSeries,\n  ApexMarkers,\n  ApexNoData,\n  ApexPlotOptions,\n  ApexResponsive,\n  ApexStates,\n  ApexStroke,\n  ApexTheme,\n  ApexTitleSubtitle,\n  ApexTooltip,\n  ApexXAxis,\n  ApexYAxis,\n  ApexForecastDataPoints,\n} from \"../model/apex-types\";\nimport { asapScheduler } from \"rxjs\";\n\nimport ApexCharts from \"apexcharts\";\n\n@Component({\n  selector: \"apx-chart\",\n  template: `<div #chart></div>`,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ChartComponent implements OnChanges, OnDestroy {\n  @Input() chart: ApexChart;\n  @Input() annotations: ApexAnnotations;\n  @Input() colors: any[];\n  @Input() dataLabels: ApexDataLabels;\n  @Input() series: ApexAxisChartSeries | ApexNonAxisChartSeries;\n  @Input() stroke: ApexStroke;\n  @Input() labels: string[];\n  @Input() legend: ApexLegend;\n  @Input() markers: ApexMarkers;\n  @Input() noData: ApexNoData;\n  @Input() fill: ApexFill;\n  @Input() tooltip: ApexTooltip;\n  @Input() plotOptions: ApexPlotOptions;\n  @Input() responsive: ApexResponsive[];\n  @Input() xaxis: ApexXAxis;\n  @Input() yaxis: ApexYAxis | ApexYAxis[];\n  @Input() forecastDataPoints: ApexForecastDataPoints;\n  @Input() grid: ApexGrid;\n  @Input() states: ApexStates;\n  @Input() title: ApexTitleSubtitle;\n  @Input() subtitle: ApexTitleSubtitle;\n  @Input() theme: ApexTheme;\n\n  @Input() autoUpdateSeries = true;\n\n  @Output() chartReady = new EventEmitter();\n\n  @ViewChild(\"chart\", { static: true }) private chartElement: ElementRef;\n  private chartObj: any;\n\n  constructor(private ngZone: NgZone) {\n\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    asapScheduler.schedule(() => {\n      if (\n        this.autoUpdateSeries &&\n        Object.keys(changes).filter((c) => c !== \"series\").length === 0\n      ) {\n        this.updateSeries(this.series, true);\n        return;\n      }\n\n      this.createElement();\n    });\n  }\n\n  ngOnDestroy() {\n    if (this.chartObj) {\n      this.chartObj.destroy();\n    }\n  }\n\n  private createElement() {\n    const options: any = {};\n\n    if (this.annotations) {\n      options.annotations = this.annotations;\n    }\n    if (this.chart) {\n      options.chart = this.chart;\n    }\n    if (this.colors) {\n      options.colors = this.colors;\n    }\n    if (this.dataLabels) {\n      options.dataLabels = this.dataLabels;\n    }\n    if (this.series) {\n      options.series = this.series;\n    }\n    if (this.stroke) {\n      options.stroke = this.stroke;\n    }\n    if (this.labels) {\n      options.labels = this.labels;\n    }\n    if (this.legend) {\n      options.legend = this.legend;\n    }\n    if (this.fill) {\n      options.fill = this.fill;\n    }\n    if (this.tooltip) {\n      options.tooltip = this.tooltip;\n    }\n    if (this.plotOptions) {\n      options.plotOptions = this.plotOptions;\n    }\n    if (this.responsive) {\n      options.responsive = this.responsive;\n    }\n    if (this.markers) {\n      options.markers = this.markers;\n    }\n    if (this.noData) {\n      options.noData = this.noData;\n    }\n    if (this.xaxis) {\n      options.xaxis = this.xaxis;\n    }\n    if (this.yaxis) {\n      options.yaxis = this.yaxis;\n    }\n    if (this.forecastDataPoints) {\n      options.forecastDataPoints = this.forecastDataPoints;\n    }\n    if (this.grid) {\n      options.grid = this.grid;\n    }\n    if (this.states) {\n      options.states = this.states;\n    }\n    if (this.title) {\n      options.title = this.title;\n    }\n    if (this.subtitle) {\n      options.subtitle = this.subtitle;\n    }\n    if (this.theme) {\n      options.theme = this.theme;\n    }\n\n    if (this.chartObj) {\n      this.chartObj.destroy();\n    }\n\n    this.ngZone.runOutsideAngular(() => {\n      this.chartObj = new ApexCharts(this.chartElement.nativeElement, options);\n    });\n\n    this.render();\n    this.chartReady.emit({chartObj: this.chartObj})\n  }\n\n  public render(): Promise<void> {\n    return this.ngZone.runOutsideAngular(() => this.chartObj.render());\n  }\n\n  public updateOptions(\n    options: any,\n    redrawPaths?: boolean,\n    animate?: boolean,\n    updateSyncedCharts?: boolean\n  ): Promise<void> {\n    return this.ngZone.runOutsideAngular(() => this.chartObj.updateOptions(\n      options,\n      redrawPaths,\n      animate,\n      updateSyncedCharts\n    ));\n  }\n\n  public updateSeries(\n    newSeries: ApexAxisChartSeries | ApexNonAxisChartSeries,\n    animate?: boolean\n  ) {\n    return this.ngZone.runOutsideAngular(() => this.chartObj.updateSeries(newSeries, animate));\n  }\n\n  public appendSeries(\n    newSeries: ApexAxisChartSeries | ApexNonAxisChartSeries,\n    animate?: boolean\n  ) {\n    this.ngZone.runOutsideAngular(() => this.chartObj.appendSeries(newSeries, animate));\n  }\n\n  public appendData(newData: any[]) {\n    this.ngZone.runOutsideAngular(() => this.chartObj.appendData(newData));\n  }\n\n  public toggleSeries(seriesName: string): any {\n    return this.ngZone.runOutsideAngular(() => this.chartObj.toggleSeries(seriesName));\n  }\n\n  public showSeries(seriesName: string) {\n    this.ngZone.runOutsideAngular(() => this.chartObj.showSeries(seriesName));\n  }\n\n  public hideSeries(seriesName: string) {\n    this.ngZone.runOutsideAngular(() => this.chartObj.hideSeries(seriesName));\n  }\n\n  public resetSeries() {\n    this.ngZone.runOutsideAngular(() => this.chartObj.resetSeries());\n  }\n\n  public zoomX(min: number, max: number) {\n    this.ngZone.runOutsideAngular(() => this.chartObj.zoomX(min, max));\n  }\n\n  public toggleDataPointSelection(\n    seriesIndex: number,\n    dataPointIndex?: number\n  ) {\n    this.ngZone.runOutsideAngular(() => this.chartObj.toggleDataPointSelection(seriesIndex, dataPointIndex));\n  }\n\n  public destroy() {\n    this.chartObj.destroy();\n  }\n\n  public setLocale(localeName?: string) {\n    this.ngZone.runOutsideAngular(() => this.chartObj.setLocale(localeName));\n  }\n\n  public paper() {\n    this.ngZone.runOutsideAngular(() => this.chartObj.paper());\n  }\n\n  public addXaxisAnnotation(\n    options: any,\n    pushToMemory?: boolean,\n    context?: any\n  ) {\n    this.ngZone.runOutsideAngular(() => this.chartObj.addXaxisAnnotation(options, pushToMemory, context));\n  }\n\n  public addYaxisAnnotation(\n    options: any,\n    pushToMemory?: boolean,\n    context?: any\n  ) {\n    this.ngZone.runOutsideAngular(() => this.chartObj.addYaxisAnnotation(options, pushToMemory, context));\n  }\n\n  public addPointAnnotation(\n    options: any,\n    pushToMemory?: boolean,\n    context?: any\n  ) {\n    this.ngZone.runOutsideAngular(() => this.chartObj.addPointAnnotation(options, pushToMemory, context));\n  }\n\n  public removeAnnotation(id: string, options?: any) {\n    this.ngZone.runOutsideAngular(() => this.chartObj.removeAnnotation(id, options));\n  }\n\n  public clearAnnotations(options?: any) {\n    this.ngZone.runOutsideAngular(() => this.chartObj.clearAnnotations(options));\n  }\n\n  public dataURI(options?: any): Promise<{ imgURI: string }> {\n    return this.chartObj.dataURI(options);\n  }\n}\n"]}