ng-apexcharts-gogo
Version:
An angular implementation of ApexCharts
336 lines • 21.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, Input, ViewChild } from '@angular/core';
import { asapScheduler } from 'rxjs';
var ChartComponent = /** @class */ (function () {
function ChartComponent() {
this.dataLabels = { enabled: false };
this.stroke = { curve: 'straight' };
this.grid = {
row: {
colors: ['#f3f3f3', 'transparent'],
opacity: 0.5
}
};
this.autoUpdateSeries = true;
}
/**
* @return {?}
*/
ChartComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
asapScheduler.schedule((/**
* @return {?}
*/
function () {
_this.createElement();
console.log('asu');
}));
};
/**
* @param {?} changes
* @return {?}
*/
ChartComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
var _this = this;
asapScheduler.schedule((/**
* @return {?}
*/
function () {
if (_this.autoUpdateSeries && Object.keys(changes).filter((/**
* @param {?} c
* @return {?}
*/
function (c) { return c !== 'series'; })).length === 0) {
_this.updateSeries(_this.series, true);
return;
}
_this.createElement();
}));
};
/**
* @private
* @return {?}
*/
ChartComponent.prototype.createElement = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var 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.xaxis) {
options.xaxis = this.xaxis;
}
if (this.yaxis) {
options.yaxis = this.yaxis;
}
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.chartObj = new ApexCharts(this.chartElement.nativeElement, options);
this.render();
};
/**
* @return {?}
*/
ChartComponent.prototype.render = /**
* @return {?}
*/
function () {
return this.chartObj.render();
};
/**
* @param {?} options
* @param {?} redrawPaths
* @param {?} animate
* @return {?}
*/
ChartComponent.prototype.updateOptions = /**
* @param {?} options
* @param {?} redrawPaths
* @param {?} animate
* @return {?}
*/
function (options, redrawPaths, animate) {
return this.chartObj.updateOptions(options, redrawPaths, animate);
};
/**
* @param {?} newSeries
* @param {?} animate
* @return {?}
*/
ChartComponent.prototype.updateSeries = /**
* @param {?} newSeries
* @param {?} animate
* @return {?}
*/
function (newSeries, animate) {
this.chartObj.updateSeries(newSeries, animate);
};
/**
* @param {?} seriesName
* @return {?}
*/
ChartComponent.prototype.toggleSeries = /**
* @param {?} seriesName
* @return {?}
*/
function (seriesName) {
this.chartObj.toggleSeries(seriesName);
};
/**
* @param {?} options
* @param {?=} pushToMemory
* @param {?=} context
* @return {?}
*/
ChartComponent.prototype.addXaxisAnnotation = /**
* @param {?} options
* @param {?=} pushToMemory
* @param {?=} context
* @return {?}
*/
function (options, pushToMemory, context) {
this.chartObj.addXaxisAnnotation(options, pushToMemory, context);
};
/**
* @param {?} options
* @param {?=} pushToMemory
* @param {?=} context
* @return {?}
*/
ChartComponent.prototype.addYaxisAnnotation = /**
* @param {?} options
* @param {?=} pushToMemory
* @param {?=} context
* @return {?}
*/
function (options, pushToMemory, context) {
this.chartObj.addYaxisAnnotation(options, pushToMemory, context);
};
/**
* @param {?} options
* @param {?=} pushToMemory
* @param {?=} context
* @return {?}
*/
ChartComponent.prototype.addPointAnnotation = /**
* @param {?} options
* @param {?=} pushToMemory
* @param {?=} context
* @return {?}
*/
function (options, pushToMemory, context) {
this.chartObj.addPointAnnotation(options, pushToMemory, context);
};
/**
* @param {?} options
* @param {?=} pushToMemory
* @param {?=} context
* @return {?}
*/
ChartComponent.prototype.addText = /**
* @param {?} options
* @param {?=} pushToMemory
* @param {?=} context
* @return {?}
*/
function (options, pushToMemory, context) {
this.chartObj.addText(options, pushToMemory, context);
};
/**
* @return {?}
*/
ChartComponent.prototype.dataURI = /**
* @return {?}
*/
function () {
return this.chartObj.dataURI();
};
ChartComponent.decorators = [
{ type: Component, args: [{
selector: 'apx-chart',
template: "<div #chart></div>\n",
styles: [""]
}] }
];
ChartComponent.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 }],
fill: [{ type: Input }],
tooltip: [{ type: Input }],
plotOptions: [{ type: Input }],
responsive: [{ type: Input }],
xaxis: [{ type: Input }],
yaxis: [{ type: Input }],
grid: [{ type: Input }],
states: [{ type: Input }],
title: [{ type: Input }],
subtitle: [{ type: Input }],
theme: [{ type: Input }],
autoUpdateSeries: [{ type: Input }],
chartElement: [{ type: ViewChild, args: ['chart',] }]
};
return ChartComponent;
}());
export { ChartComponent };
if (false) {
/** @type {?} */
ChartComponent.prototype.chart;
/** @type {?} */
ChartComponent.prototype.annotations;
/** @type {?} */
ChartComponent.prototype.colors;
/** @type {?} */
ChartComponent.prototype.dataLabels;
/** @type {?} */
ChartComponent.prototype.series;
/** @type {?} */
ChartComponent.prototype.stroke;
/** @type {?} */
ChartComponent.prototype.labels;
/** @type {?} */
ChartComponent.prototype.legend;
/** @type {?} */
ChartComponent.prototype.fill;
/** @type {?} */
ChartComponent.prototype.tooltip;
/** @type {?} */
ChartComponent.prototype.plotOptions;
/** @type {?} */
ChartComponent.prototype.responsive;
/** @type {?} */
ChartComponent.prototype.xaxis;
/** @type {?} */
ChartComponent.prototype.yaxis;
/** @type {?} */
ChartComponent.prototype.grid;
/** @type {?} */
ChartComponent.prototype.states;
/** @type {?} */
ChartComponent.prototype.title;
/** @type {?} */
ChartComponent.prototype.subtitle;
/** @type {?} */
ChartComponent.prototype.theme;
/** @type {?} */
ChartComponent.prototype.autoUpdateSeries;
/**
* @type {?}
* @private
*/
ChartComponent.prototype.chartElement;
/**
* @type {?}
* @private
*/
ChartComponent.prototype.chartObj;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.component.js","sourceRoot":"ng://ng-apexcharts/","sources":["lib/chart/chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Input, OnChanges, OnInit, SimpleChanges, ViewChild} from '@angular/core';\nimport {\n  ApexAnnotations,\n  ApexAxisChartSeries,\n  ApexChart,\n  ApexDataLabels,\n  ApexFill,\n  ApexGrid,\n  ApexLegend,\n  ApexNonAxisChartSeries,\n  ApexPlotOptions,\n  ApexResponsive,\n  ApexStates,\n  ApexStroke, ApexTheme, ApexTitleSubtitle,\n  ApexTooltip,\n  ApexXAxis,\n  ApexYAxis\n} from '../model/apex-types';\nimport { asapScheduler } from 'rxjs';\n\ndeclare var ApexCharts: any;\n\n@Component({\n  selector: 'apx-chart',\n  templateUrl: './chart.component.html',\n  styleUrls: ['./chart.component.css']\n})\nexport class ChartComponent implements OnInit, OnChanges {\n  @Input() chart: ApexChart;\n  @Input() annotations: ApexAnnotations;\n  @Input() colors: string[];\n  @Input() dataLabels: ApexDataLabels = {enabled: false};\n  @Input() series: ApexAxisChartSeries | ApexNonAxisChartSeries;\n  @Input() stroke: ApexStroke = {curve: 'straight'};\n  @Input() labels: string[];\n  @Input() legend: ApexLegend;\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\n  @Input() grid: ApexGrid = {\n    row: {\n      colors: ['#f3f3f3', 'transparent'],\n      opacity: 0.5\n    }\n  };\n\n  @Input() states: ApexStates;\n  @Input() title: ApexTitleSubtitle;\n  @Input() subtitle: ApexTitleSubtitle;\n  @Input() theme: ApexTheme;\n\n  @Input() autoUpdateSeries = true;\n\n  @ViewChild('chart') private chartElement: ElementRef;\n  private chartObj: any;\n\n  ngOnInit() {\n    asapScheduler.schedule(() => {\n      this.createElement();\n      console.log('asu');\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    asapScheduler.schedule(() => {\n      if (this.autoUpdateSeries && Object.keys(changes).filter(c => c !== 'series').length === 0) {\n        this.updateSeries(this.series, true);\n        return;\n      }\n\n      this.createElement();\n    });\n  }\n\n  private createElement() {\n    const options: any = {};\n\n    if (this.annotations) { options.annotations = this.annotations; }\n    if (this.chart) { options.chart = this.chart; }\n    if (this.colors) { options.colors = this.colors; }\n    if (this.dataLabels) { options.dataLabels = this.dataLabels; }\n    if (this.series) { options.series = this.series; }\n    if (this.stroke) { options.stroke = this.stroke; }\n    if (this.labels) { options.labels = this.labels; }\n    if (this.legend) { options.legend = this.legend; }\n    if (this.fill) { options.fill = this.fill; }\n    if (this.tooltip) { options.tooltip = this.tooltip; }\n    if (this.plotOptions) { options.plotOptions = this.plotOptions; }\n    if (this.responsive) { options.responsive = this.responsive; }\n    if (this.xaxis) { options.xaxis = this.xaxis; }\n    if (this.yaxis) { options.yaxis = this.yaxis; }\n    if (this.grid) { options.grid = this.grid; }\n    if (this.states) { options.states = this.states; }\n    if (this.title) { options.title = this.title; }\n    if (this.subtitle) { options.subtitle = this.subtitle; }\n    if (this.theme) { options.theme = this.theme; }\n\n    if (this.chartObj) {\n      this.chartObj.destroy();\n    }\n\n    this.chartObj = new ApexCharts(\n      this.chartElement.nativeElement,\n      options\n    );\n\n    this.render();\n  }\n\n  public render(): Promise<void> {\n    return this.chartObj.render();\n  }\n\n  public updateOptions(options: any, redrawPaths: boolean, animate: boolean): Promise<void> {\n    return this.chartObj.updateOptions(options, redrawPaths, animate);\n  }\n\n  public updateSeries(newSeries: ApexAxisChartSeries | ApexNonAxisChartSeries, animate: boolean) {\n    this.chartObj.updateSeries(newSeries, animate);\n  }\n\n  public toggleSeries(seriesName: string) {\n    this.chartObj.toggleSeries(seriesName);\n  }\n\n  public addXaxisAnnotation(options: any, pushToMemory?: boolean, context?: any) {\n    this.chartObj.addXaxisAnnotation(options, pushToMemory, context);\n  }\n\n  public addYaxisAnnotation(options: any, pushToMemory?: boolean, context?: any) {\n    this.chartObj.addYaxisAnnotation(options, pushToMemory, context);\n  }\n\n  public addPointAnnotation(options: any, pushToMemory?: boolean, context?: any) {\n    this.chartObj.addPointAnnotation(options, pushToMemory, context);\n  }\n\n  public addText(options: any, pushToMemory?: boolean, context?: any) {\n    this.chartObj.addText(options, pushToMemory, context);\n  }\n\n  public dataURI() {\n    return this.chartObj.dataURI();\n  }\n}\n"]}