primeng
Version:
[](https://opensource.org/licenses/MIT) [](https://badge.fury.io/js/primeng) [ || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
import { NgModule, Component, ElementRef, AfterViewInit, OnDestroy, Input, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';
import { CommonModule } from '@angular/common';
import * as Chart from 'chart.js';
var UIChart = /** @class */ (function () {
function UIChart(el) {
this.el = el;
this.options = {};
this.plugins = [];
this.responsive = true;
this.onDataSelect = new EventEmitter();
}
Object.defineProperty(UIChart.prototype, "data", {
get: function () {
return this._data;
},
set: function (val) {
this._data = val;
this.reinit();
},
enumerable: true,
configurable: true
});
UIChart.prototype.ngAfterViewInit = function () {
this.initChart();
this.initialized = true;
};
UIChart.prototype.onCanvasClick = function (event) {
if (this.chart) {
var element = this.chart.getElementAtEvent(event);
var dataset = this.chart.getDatasetAtEvent(event);
if (element && element[0] && dataset) {
this.onDataSelect.emit({ originalEvent: event, element: element[0], dataset: dataset });
}
}
};
UIChart.prototype.initChart = function () {
var opts = this.options || {};
opts.responsive = this.responsive;
// allows chart to resize in responsive mode
if (opts.responsive && (this.height || this.width)) {
opts.maintainAspectRatio = false;
}
this.chart = new Chart(this.el.nativeElement.children[0].children[0], {
type: this.type,
data: this.data,
options: this.options,
plugins: this.plugins
});
};
UIChart.prototype.getCanvas = function () {
return this.el.nativeElement.children[0].children[0];
};
UIChart.prototype.getBase64Image = function () {
return this.chart.toBase64Image();
};
UIChart.prototype.generateLegend = function () {
if (this.chart) {
return this.chart.generateLegend();
}
};
UIChart.prototype.refresh = function () {
if (this.chart) {
this.chart.update();
}
};
UIChart.prototype.reinit = function () {
if (this.chart) {
this.chart.destroy();
this.initChart();
}
};
UIChart.prototype.ngOnDestroy = function () {
if (this.chart) {
this.chart.destroy();
this.initialized = false;
this.chart = null;
}
};
UIChart.ctorParameters = function () { return [
{ type: ElementRef }
]; };
__decorate([
Input()
], UIChart.prototype, "type", void 0);
__decorate([
Input()
], UIChart.prototype, "options", void 0);
__decorate([
Input()
], UIChart.prototype, "plugins", void 0);
__decorate([
Input()
], UIChart.prototype, "width", void 0);
__decorate([
Input()
], UIChart.prototype, "height", void 0);
__decorate([
Input()
], UIChart.prototype, "responsive", void 0);
__decorate([
Output()
], UIChart.prototype, "onDataSelect", void 0);
__decorate([
Input()
], UIChart.prototype, "data", null);
UIChart = __decorate([
Component({
selector: 'p-chart',
template: "\n <div style=\"position:relative\" [style.width]=\"responsive && !width ? null : width\" [style.height]=\"responsive && !height ? null : height\">\n <canvas [attr.width]=\"responsive && !width ? null : width\" [attr.height]=\"responsive && !height ? null : height\" (click)=\"onCanvasClick($event)\"></canvas>\n </div>\n ",
changeDetection: ChangeDetectionStrategy.Default
})
], UIChart);
return UIChart;
}());
export { UIChart };
var ChartModule = /** @class */ (function () {
function ChartModule() {
}
ChartModule = __decorate([
NgModule({
imports: [CommonModule],
exports: [UIChart],
declarations: [UIChart]
})
], ChartModule);
return ChartModule;
}());
export { ChartModule };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.js","sourceRoot":"ng://primeng/chart/","sources":["chart.ts"],"names":[],"mappings":"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","sourcesContent":["import {NgModule,Component,ElementRef,AfterViewInit,OnDestroy,Input,Output,EventEmitter,ChangeDetectionStrategy} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport * as Chart from 'chart.js';\n\n@Component({\n    selector: 'p-chart',\n    template: `\n        <div style=\"position:relative\" [style.width]=\"responsive && !width ? null : width\" [style.height]=\"responsive && !height ? null : height\">\n            <canvas [attr.width]=\"responsive && !width ? null : width\" [attr.height]=\"responsive && !height ? null : height\" (click)=\"onCanvasClick($event)\"></canvas>\n        </div>\n    `,\n    changeDetection: ChangeDetectionStrategy.Default\n})\nexport class UIChart implements AfterViewInit, OnDestroy {\n\n    @Input() type: string;\n\n    @Input() options: any = {};\n\n    @Input() plugins: any[] = [];\n    \n    @Input() width: string;\n    \n    @Input() height: string;\n\n    @Input() responsive: boolean = true;\n    \n    @Output() onDataSelect: EventEmitter<any> = new EventEmitter();\n\n    initialized: boolean;\n    \n    _data: any;\n\n    chart: any;\n\n    constructor(public el: ElementRef) {}\n    \n    @Input() get data(): any {\n        return this._data;\n    }\n\n    set data(val:any) {\n        this._data = val;\n        this.reinit();\n    }\n\n    ngAfterViewInit() {\n        this.initChart();\n        this.initialized = true;\n    }\n\n    onCanvasClick(event) {\n        if (this.chart) {\n            let element = this.chart.getElementAtEvent(event);\n            let dataset = this.chart.getDatasetAtEvent(event);\n            if (element&&element[0]&&dataset) {\n                this.onDataSelect.emit({originalEvent: event, element: element[0], dataset: dataset});\n            }\n        }\n    }\n\n    initChart() {\n        let opts = this.options||{};\n        opts.responsive = this.responsive;\n\n        // allows chart to resize in responsive mode\n        if (opts.responsive&&(this.height||this.width)) {\n            opts.maintainAspectRatio = false;\n        }\n\n        this.chart = new Chart(this.el.nativeElement.children[0].children[0], {\n            type: this.type,\n            data: this.data,\n            options: this.options,\n            plugins: this.plugins\n        });\n    }\n    \n    getCanvas() {\n        return this.el.nativeElement.children[0].children[0];\n    }\n    \n    getBase64Image() {\n        return this.chart.toBase64Image();\n    }\n    \n    generateLegend() {\n        if (this.chart) {\n            return this.chart.generateLegend();\n        }\n    }\n    \n    refresh() {\n        if (this.chart) {\n            this.chart.update();\n        }\n    }\n    \n    reinit() {\n        if (this.chart) {\n            this.chart.destroy();\n            this.initChart();\n        }\n    }\n    \n    ngOnDestroy() {\n        if (this.chart) {\n            this.chart.destroy();\n            this.initialized = false;\n            this.chart = null;\n        }\n    }\n}\n\n@NgModule({\n    imports: [CommonModule],\n    exports: [UIChart],\n    declarations: [UIChart]\n})\nexport class ChartModule { }\n"]}