@coreui/angular-chartjs 4.2.15 → 4.2.35

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,213 +1,217 @@
1
- import { Component, EventEmitter, HostBinding, Input, Output, ViewChild } from '@angular/core';
2
- import { coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';
3
- import merge from 'lodash-es/merge';
4
- import { Chart, registerables } from 'chart.js';
5
- import { customTooltips as cuiCustomTooltips } from '@coreui/chartjs';
6
- import * as i0 from "@angular/core";
7
- Chart.register(...registerables);
8
- let nextId = 0;
9
- export class ChartjsComponent {
10
- constructor(elementRef, ngZone, renderer) {
11
- this.elementRef = elementRef;
12
- this.ngZone = ngZone;
13
- this.renderer = renderer;
14
- this.customTooltips = true;
15
- this.id = `c-chartjs-${nextId++}`;
16
- this.plugins = [];
17
- this._redraw = false;
18
- this.type = 'bar';
19
- this.wrapper = true;
20
- this.getDatasetAtEvent = new EventEmitter();
21
- this.getElementAtEvent = new EventEmitter();
22
- this.getElementsAtEvent = new EventEmitter();
23
- }
24
- set height(value) {
25
- this._height = coerceNumberProperty(value);
26
- }
27
- get height() {
28
- return this._height;
29
- }
30
- set redraw(value) {
31
- this._redraw = coerceBooleanProperty(value);
32
- }
33
- get redraw() {
34
- return this._redraw;
35
- }
36
- set width(value) {
37
- this._width = coerceNumberProperty(value);
38
- }
39
- get width() {
40
- return this._width;
41
- }
42
- get hostClasses() {
43
- return {
44
- 'chart-wrapper': this.wrapper
45
- };
46
- }
47
- ngAfterViewInit() {
48
- this.chartRender();
49
- // this.chartUpdate();
50
- }
51
- ngOnChanges(changes) {
52
- if (changes['data'] && !changes['data'].firstChange) {
53
- this.chartUpdate();
54
- }
55
- }
56
- ngOnDestroy() {
57
- this.chartDestroy();
58
- }
59
- handleOnClick($event) {
60
- if (!this.chart)
61
- return;
62
- const datasetAtEvent = this.chart.getElementsAtEventForMode($event, 'dataset', { intersect: true }, false);
63
- this.getDatasetAtEvent.emit(datasetAtEvent);
64
- const elementAtEvent = this.chart.getElementsAtEventForMode($event, 'nearest', { intersect: true }, false);
65
- this.getElementAtEvent.emit(elementAtEvent);
66
- const elementsAtEvent = this.chart.getElementsAtEventForMode($event, 'index', { intersect: true }, false);
67
- this.getElementsAtEvent.emit(elementsAtEvent);
68
- }
69
- chartDestroy() {
70
- this.chart?.destroy();
71
- }
72
- chartRender() {
73
- if (!this.canvasElement)
74
- return;
75
- const ctx = this.canvasElement.nativeElement.getContext('2d');
76
- this.ngZone.runOutsideAngular(() => {
77
- const config = this.chartConfig();
78
- if (config) {
79
- setTimeout(() => {
80
- this.chart = new Chart(ctx, config);
81
- this.renderer.setStyle(this.canvasElement.nativeElement, 'display', 'block');
82
- });
83
- }
84
- });
85
- }
86
- chartUpdate() {
87
- if (!this.chart)
88
- return;
89
- if (this.redraw) {
90
- this.chartDestroy();
91
- setTimeout(() => {
92
- this.chartRender();
93
- });
94
- return;
95
- }
96
- const config = this.chartConfig();
97
- if (this.options) {
98
- // todo
99
- // @ts-ignore
100
- Object.assign(this.chart.options, config.options);
101
- }
102
- if (!this.chart.config.data) {
103
- this.chart.config.data = { ...config.data };
104
- this.chartUpdateOutsideAngular();
105
- }
106
- if (this.chart) {
107
- // todo
108
- // @ts-ignore
109
- Object.assign(this.chart.config.options, config.options);
110
- // todo
111
- // @ts-ignore
112
- Object.assign(this.chart.config.plugins, config.plugins);
113
- Object.assign(this.chart.config.data, config.data);
114
- }
115
- this.chartUpdateOutsideAngular();
116
- }
117
- chartUpdateOutsideAngular() {
118
- setTimeout(() => {
119
- this.ngZone.runOutsideAngular(() => {
120
- this.chart?.update();
121
- });
122
- });
123
- }
124
- chartToBase64Image() {
125
- return this.chart?.toBase64Image();
126
- }
127
- chartDataConfig() {
128
- return {
129
- labels: this.data?.labels ?? [],
130
- datasets: this.data?.datasets ?? []
131
- };
132
- }
133
- chartOptions() {
134
- return this.options;
135
- }
136
- chartConfig() {
137
- this.chartCustomTooltips();
138
- return {
139
- data: this.chartDataConfig(),
140
- options: this.chartOptions(),
141
- plugins: this.plugins,
142
- type: this.type
143
- };
144
- }
145
- chartCustomTooltips() {
146
- if (this.customTooltips) {
147
- const options = this.options;
148
- // @ts-ignore
149
- const plugins = this.options?.plugins;
150
- // @ts-ignore
151
- const tooltip = this.options?.plugins?.tooltip;
152
- this.options = merge({
153
- ...options,
154
- plugins: {
155
- ...plugins,
156
- tooltip: {
157
- ...tooltip,
158
- enabled: false,
159
- mode: 'index',
160
- position: 'nearest',
161
- external: cuiCustomTooltips
162
- }
163
- }
164
- });
165
- }
166
- }
167
- ;
168
- }
169
- ChartjsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ChartjsComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
170
- ChartjsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ChartjsComponent, selector: "c-chart", inputs: { customTooltips: "customTooltips", data: "data", height: "height", id: "id", options: "options", plugins: "plugins", redraw: "redraw", type: "type", width: "width", wrapper: "wrapper" }, outputs: { getDatasetAtEvent: "getDatasetAtEvent", getElementAtEvent: "getElementAtEvent", getElementsAtEvent: "getElementsAtEvent" }, host: { properties: { "style.height.px": "this.height", "style.width.px": "this.width", "class": "this.hostClasses" } }, viewQueries: [{ propertyName: "canvasElement", first: true, predicate: ["canvasElement"], descendants: true }], exportAs: ["cChart"], usesOnChanges: true, ngImport: i0, template: "<canvas\r\n #canvasElement\r\n (click)=\"handleOnClick($event)\"\r\n [height]=\"height\"\r\n [id]=\"id\"\r\n [width]=\"width\"\r\n role=\"img\"\r\n style=\"display: none;\"\r\n>\r\n <ng-content></ng-content>\r\n</canvas>\r\n", styles: [":host.chart-wrapper{display:block}\n"] });
171
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ChartjsComponent, decorators: [{
172
- type: Component,
173
- args: [{ selector: 'c-chart', exportAs: 'cChart', template: "<canvas\r\n #canvasElement\r\n (click)=\"handleOnClick($event)\"\r\n [height]=\"height\"\r\n [id]=\"id\"\r\n [width]=\"width\"\r\n role=\"img\"\r\n style=\"display: none;\"\r\n>\r\n <ng-content></ng-content>\r\n</canvas>\r\n", styles: [":host.chart-wrapper{display:block}\n"] }]
174
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i0.Renderer2 }]; }, propDecorators: { customTooltips: [{
175
- type: Input
176
- }], data: [{
177
- type: Input
178
- }], height: [{
179
- type: HostBinding,
180
- args: ['style.height.px']
181
- }, {
182
- type: Input
183
- }], id: [{
184
- type: Input
185
- }], options: [{
186
- type: Input
187
- }], plugins: [{
188
- type: Input
189
- }], redraw: [{
190
- type: Input
191
- }], type: [{
192
- type: Input
193
- }], width: [{
194
- type: HostBinding,
195
- args: ['style.width.px']
196
- }, {
197
- type: Input
198
- }], wrapper: [{
199
- type: Input
200
- }], getDatasetAtEvent: [{
201
- type: Output
202
- }], getElementAtEvent: [{
203
- type: Output
204
- }], getElementsAtEvent: [{
205
- type: Output
206
- }], canvasElement: [{
207
- type: ViewChild,
208
- args: ['canvasElement']
209
- }], hostClasses: [{
210
- type: HostBinding,
211
- args: ['class']
212
- }] } });
213
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chartjs.component.js","sourceRoot":"","sources":["../../../../projects/coreui-angular-chartjs/src/lib/chartjs.component.ts","../../../../projects/coreui-angular-chartjs/src/lib/chartjs.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  NgZone,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { BooleanInput, coerceBooleanProperty, coerceNumberProperty, NumberInput } from '@angular/cdk/coercion';\r\n\r\nimport merge from 'lodash-es/merge';\r\n\r\nimport { Chart, ChartConfiguration, ChartOptions, ChartType, DefaultDataPoint, registerables } from 'chart.js';\r\nimport { customTooltips as cuiCustomTooltips } from '@coreui/chartjs';\r\n\r\nChart.register(...registerables);\r\n\r\nlet nextId = 0;\r\n\r\n@Component({\r\n  selector: 'c-chart',\r\n  templateUrl: './chartjs.component.html',\r\n  styleUrls: ['./chartjs.component.scss'],\r\n  exportAs: 'cChart'\r\n})\r\nexport class ChartjsComponent<TType extends ChartType = ChartType, TData = DefaultDataPoint<TType>, TLabel = unknown> implements AfterViewInit, OnDestroy, OnChanges {\r\n\r\n  static ngAcceptInputType_height: NumberInput;\r\n  static ngAcceptInputType_width: NumberInput;\r\n  static ngAcceptInputType_redraw: BooleanInput;\r\n\r\n  @Input() customTooltips = true;\r\n  @Input() data?: ChartConfiguration<TType, TData, TLabel>['data'];\r\n\r\n  @HostBinding('style.height.px')\r\n  @Input()\r\n  set height(value: number | undefined) {\r\n    this._height = coerceNumberProperty(value);\r\n  }\r\n\r\n  get height() {\r\n    return this._height;\r\n  }\r\n\r\n  private _height: number | undefined;\r\n\r\n  @Input() id = `c-chartjs-${nextId++}`;\r\n  @Input() options?: ChartConfiguration<TType, TData, TLabel>['options'];\r\n  @Input() plugins: ChartConfiguration<TType, TData, TLabel>['plugins'] = [];\r\n\r\n  @Input()\r\n  set redraw(value: boolean) {\r\n    this._redraw = coerceBooleanProperty(value);\r\n  }\r\n\r\n  get redraw(): boolean {\r\n    return this._redraw;\r\n  }\r\n\r\n  private _redraw = false;\r\n\r\n  @Input() type: ChartConfiguration<TType, TData, TLabel>['type'] = 'bar' as TType;\r\n\r\n  @HostBinding('style.width.px')\r\n  @Input()\r\n  set width(value: number | undefined) {\r\n    this._width = coerceNumberProperty(value);\r\n  }\r\n\r\n  get width() {\r\n    return this._width;\r\n  }\r\n\r\n  private _width: number | undefined;\r\n\r\n  @Input() wrapper = true;\r\n\r\n  @Output() getDatasetAtEvent = new EventEmitter<any>();\r\n  @Output() getElementAtEvent = new EventEmitter<any>();\r\n  @Output() getElementsAtEvent = new EventEmitter<any>();\r\n\r\n  @ViewChild('canvasElement') canvasElement!: ElementRef;\r\n\r\n  chart!: Chart<TType, TData, TLabel>;\r\n\r\n  @HostBinding('class')\r\n  get hostClasses() {\r\n    return {\r\n      'chart-wrapper': this.wrapper\r\n    };\r\n  }\r\n\r\n  constructor(\r\n    private elementRef: ElementRef,\r\n    private ngZone: NgZone,\r\n    private renderer: Renderer2\r\n  ) {}\r\n\r\n  ngAfterViewInit(): void {\r\n    this.chartRender();\r\n    // this.chartUpdate();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['data'] && !changes['data'].firstChange) {\r\n      this.chartUpdate();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.chartDestroy();\r\n  }\r\n\r\n  public handleOnClick($event: MouseEvent) {\r\n    if (!this.chart) return;\r\n\r\n    const datasetAtEvent = this.chart.getElementsAtEventForMode($event, 'dataset', { intersect: true }, false);\r\n    this.getDatasetAtEvent.emit(datasetAtEvent);\r\n\r\n    const elementAtEvent = this.chart.getElementsAtEventForMode($event, 'nearest', { intersect: true }, false);\r\n    this.getElementAtEvent.emit(elementAtEvent);\r\n\r\n    const elementsAtEvent = this.chart.getElementsAtEventForMode($event, 'index', { intersect: true }, false);\r\n    this.getElementsAtEvent.emit(elementsAtEvent);\r\n  }\r\n\r\n  public chartDestroy() {\r\n    this.chart?.destroy();\r\n  }\r\n\r\n  public chartRender() {\r\n    if (!this.canvasElement) return;\r\n\r\n    const ctx: CanvasRenderingContext2D = this.canvasElement.nativeElement.getContext('2d');\r\n\r\n    this.ngZone.runOutsideAngular(() => {\r\n      const config = this.chartConfig();\r\n      if (config) {\r\n        setTimeout(() => {\r\n          this.chart = new Chart(ctx, config);\r\n          this.renderer.setStyle(this.canvasElement.nativeElement, 'display', 'block');\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  chartUpdate() {\r\n    if (!this.chart) return;\r\n\r\n    if (this.redraw) {\r\n      this.chartDestroy();\r\n      setTimeout(() => {\r\n        this.chartRender();\r\n      });\r\n      return;\r\n    }\r\n\r\n    const config = this.chartConfig();\r\n\r\n    if (this.options) {\r\n      // todo\r\n      // @ts-ignore\r\n      Object.assign(this.chart.options, config.options);\r\n    }\r\n\r\n    if (!this.chart.config.data) {\r\n      this.chart.config.data = { ...config.data };\r\n      this.chartUpdateOutsideAngular();\r\n    }\r\n\r\n    if (this.chart) {\r\n      // todo\r\n      // @ts-ignore\r\n      Object.assign(this.chart.config.options, config.options);\r\n      // todo\r\n      // @ts-ignore\r\n      Object.assign(this.chart.config.plugins, config.plugins);\r\n      Object.assign(this.chart.config.data, config.data);\r\n    }\r\n\r\n    this.chartUpdateOutsideAngular();\r\n  }\r\n\r\n  private chartUpdateOutsideAngular() {\r\n    setTimeout(() => {\r\n      this.ngZone.runOutsideAngular(() => {\r\n        this.chart?.update();\r\n      });\r\n    });\r\n  }\r\n\r\n  public chartToBase64Image(): string | undefined {\r\n    return this.chart?.toBase64Image();\r\n  }\r\n\r\n  private chartDataConfig(): ChartConfiguration<TType, TData, TLabel>['data'] {\r\n    return {\r\n      labels: this.data?.labels ?? [],\r\n      datasets: this.data?.datasets ?? []\r\n    };\r\n  }\r\n\r\n  private chartOptions(): ChartConfiguration<TType, TData, TLabel>['options'] {\r\n    return this.options;\r\n  }\r\n\r\n  private chartConfig(): ChartConfiguration<TType, TData, TLabel> {\r\n    this.chartCustomTooltips();\r\n    return {\r\n      data: this.chartDataConfig(),\r\n      options: this.chartOptions(),\r\n      plugins: this.plugins,\r\n      type: this.type\r\n    };\r\n  }\r\n\r\n  private chartCustomTooltips() {\r\n    if (this.customTooltips) {\r\n      const options = this.options;\r\n      // @ts-ignore\r\n      const plugins = this.options?.plugins;\r\n      // @ts-ignore\r\n      const tooltip = this.options?.plugins?.tooltip;\r\n      this.options = merge({\r\n        ...options,\r\n        plugins: {\r\n          ...plugins,\r\n          tooltip: {\r\n            ...tooltip,\r\n            enabled: false,\r\n            mode: 'index',\r\n            position: 'nearest',\r\n            external: cuiCustomTooltips\r\n          }\r\n        }\r\n      });\r\n    }\r\n  };\r\n}\r\n","<canvas\r\n  #canvasElement\r\n  (click)=\"handleOnClick($event)\"\r\n  [height]=\"height\"\r\n  [id]=\"id\"\r\n  [width]=\"width\"\r\n  role=\"img\"\r\n  style=\"display: none;\"\r\n>\r\n  <ng-content></ng-content>\r\n</canvas>\r\n"]}
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output, ViewChild } from '@angular/core';
2
+ import { coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';
3
+ import merge from 'lodash-es/merge';
4
+ import { Chart, registerables } from 'chart.js';
5
+ import { customTooltips as cuiCustomTooltips } from '@coreui/chartjs';
6
+ import * as i0 from "@angular/core";
7
+ Chart.register(...registerables);
8
+ let nextId = 0;
9
+ export class ChartjsComponent {
10
+ constructor(elementRef, ngZone, renderer, changeDetectorRef) {
11
+ this.elementRef = elementRef;
12
+ this.ngZone = ngZone;
13
+ this.renderer = renderer;
14
+ this.changeDetectorRef = changeDetectorRef;
15
+ this.customTooltips = true;
16
+ this.id = `c-chartjs-${nextId++}`;
17
+ this.plugins = [];
18
+ this._redraw = false;
19
+ this.type = 'bar';
20
+ this.wrapper = true;
21
+ this.getDatasetAtEvent = new EventEmitter();
22
+ this.getElementAtEvent = new EventEmitter();
23
+ this.getElementsAtEvent = new EventEmitter();
24
+ this.chartRef = new EventEmitter();
25
+ }
26
+ set height(value) {
27
+ this._height = coerceNumberProperty(value);
28
+ }
29
+ get height() {
30
+ return this._height;
31
+ }
32
+ set redraw(value) {
33
+ this._redraw = coerceBooleanProperty(value);
34
+ }
35
+ get redraw() {
36
+ return this._redraw;
37
+ }
38
+ set width(value) {
39
+ this._width = coerceNumberProperty(value);
40
+ }
41
+ get width() {
42
+ return this._width;
43
+ }
44
+ get hostClasses() {
45
+ return {
46
+ 'chart-wrapper': this.wrapper
47
+ };
48
+ }
49
+ ngAfterViewInit() {
50
+ this.chartRender();
51
+ }
52
+ ngOnChanges(changes) {
53
+ if (changes['data'] && !changes['data'].firstChange) {
54
+ this.chartUpdate();
55
+ }
56
+ }
57
+ ngOnDestroy() {
58
+ this.chartDestroy();
59
+ }
60
+ handleClick($event) {
61
+ if (!this.chart) {
62
+ return;
63
+ }
64
+ const datasetAtEvent = this.chart.getElementsAtEventForMode($event, 'dataset', { intersect: true }, false);
65
+ this.getDatasetAtEvent.emit(datasetAtEvent);
66
+ const elementAtEvent = this.chart.getElementsAtEventForMode($event, 'nearest', { intersect: true }, false);
67
+ this.getElementAtEvent.emit(elementAtEvent);
68
+ const elementsAtEvent = this.chart.getElementsAtEventForMode($event, 'index', { intersect: true }, false);
69
+ this.getElementsAtEvent.emit(elementsAtEvent);
70
+ }
71
+ chartDestroy() {
72
+ this.chart?.destroy();
73
+ this.chartRef.emit(undefined);
74
+ }
75
+ chartRender() {
76
+ if (!this.canvasElement) {
77
+ return;
78
+ }
79
+ const ctx = this.canvasElement.nativeElement.getContext('2d');
80
+ this.ngZone.runOutsideAngular(() => {
81
+ const config = this.chartConfig();
82
+ if (config) {
83
+ setTimeout(() => {
84
+ this.chart = new Chart(ctx, config);
85
+ this.renderer.setStyle(this.canvasElement.nativeElement, 'display', 'block');
86
+ this.changeDetectorRef.markForCheck();
87
+ this.chartRef.emit(this.chart);
88
+ });
89
+ }
90
+ });
91
+ }
92
+ chartUpdate() {
93
+ if (!this.chart) {
94
+ return;
95
+ }
96
+ if (this.redraw) {
97
+ this.chartDestroy();
98
+ setTimeout(() => {
99
+ this.chartRender();
100
+ });
101
+ return;
102
+ }
103
+ const config = this.chartConfig();
104
+ if (this.options) {
105
+ Object.assign(this.chart.options ?? {}, config.options ?? {});
106
+ }
107
+ if (!this.chart.config.data) {
108
+ this.chart.config.data = { ...config.data };
109
+ this.chartUpdateOutsideAngular();
110
+ }
111
+ if (this.chart) {
112
+ Object.assign(this.chart.config.options ?? {}, config.options ?? {});
113
+ Object.assign(this.chart.config.plugins ?? [], config.plugins ?? []);
114
+ Object.assign(this.chart.config.data, config.data);
115
+ }
116
+ this.chartUpdateOutsideAngular();
117
+ }
118
+ chartUpdateOutsideAngular() {
119
+ setTimeout(() => {
120
+ this.ngZone.runOutsideAngular(() => {
121
+ this.chart?.update();
122
+ this.changeDetectorRef.markForCheck();
123
+ });
124
+ });
125
+ }
126
+ chartToBase64Image() {
127
+ return this.chart?.toBase64Image();
128
+ }
129
+ chartDataConfig() {
130
+ return {
131
+ labels: this.data?.labels ?? [],
132
+ datasets: this.data?.datasets ?? []
133
+ };
134
+ }
135
+ chartOptions() {
136
+ return this.options;
137
+ }
138
+ chartConfig() {
139
+ this.chartCustomTooltips();
140
+ return {
141
+ data: this.chartDataConfig(),
142
+ options: this.chartOptions(),
143
+ plugins: this.plugins,
144
+ type: this.type
145
+ };
146
+ }
147
+ chartCustomTooltips() {
148
+ if (this.customTooltips) {
149
+ const options = this.options;
150
+ // @ts-ignore
151
+ const plugins = this.options?.plugins;
152
+ // @ts-ignore
153
+ const tooltip = this.options?.plugins?.tooltip;
154
+ this.options = merge({
155
+ ...options,
156
+ plugins: {
157
+ ...plugins,
158
+ tooltip: {
159
+ ...tooltip,
160
+ enabled: false,
161
+ mode: 'index',
162
+ position: 'nearest',
163
+ external: cuiCustomTooltips
164
+ }
165
+ }
166
+ });
167
+ }
168
+ }
169
+ ;
170
+ }
171
+ ChartjsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ChartjsComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
172
+ ChartjsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ChartjsComponent, isStandalone: true, selector: "c-chart", inputs: { customTooltips: "customTooltips", data: "data", height: "height", id: "id", options: "options", plugins: "plugins", redraw: "redraw", type: "type", width: "width", wrapper: "wrapper" }, outputs: { getDatasetAtEvent: "getDatasetAtEvent", getElementAtEvent: "getElementAtEvent", getElementsAtEvent: "getElementsAtEvent", chartRef: "chartRef" }, host: { properties: { "style.height.px": "this.height", "style.width.px": "this.width", "class": "this.hostClasses" } }, viewQueries: [{ propertyName: "canvasElement", first: true, predicate: ["canvasElement"], descendants: true }], exportAs: ["cChart"], usesOnChanges: true, ngImport: i0, template: "<canvas\n #canvasElement\n (click)=\"handleClick($event)\"\n [height]=\"height\"\n [id]=\"id\"\n [width]=\"width\"\n role=\"img\"\n style=\"display: none;\"\n>\n <ng-content></ng-content>\n</canvas>\n", styles: [":host.chart-wrapper{display:block}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
173
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ChartjsComponent, decorators: [{
174
+ type: Component,
175
+ args: [{ selector: 'c-chart', exportAs: 'cChart', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<canvas\n #canvasElement\n (click)=\"handleClick($event)\"\n [height]=\"height\"\n [id]=\"id\"\n [width]=\"width\"\n role=\"img\"\n style=\"display: none;\"\n>\n <ng-content></ng-content>\n</canvas>\n", styles: [":host.chart-wrapper{display:block}\n"] }]
176
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { customTooltips: [{
177
+ type: Input
178
+ }], data: [{
179
+ type: Input
180
+ }], height: [{
181
+ type: HostBinding,
182
+ args: ['style.height.px']
183
+ }, {
184
+ type: Input
185
+ }], id: [{
186
+ type: Input
187
+ }], options: [{
188
+ type: Input
189
+ }], plugins: [{
190
+ type: Input
191
+ }], redraw: [{
192
+ type: Input
193
+ }], type: [{
194
+ type: Input
195
+ }], width: [{
196
+ type: HostBinding,
197
+ args: ['style.width.px']
198
+ }, {
199
+ type: Input
200
+ }], wrapper: [{
201
+ type: Input
202
+ }], getDatasetAtEvent: [{
203
+ type: Output
204
+ }], getElementAtEvent: [{
205
+ type: Output
206
+ }], getElementsAtEvent: [{
207
+ type: Output
208
+ }], chartRef: [{
209
+ type: Output
210
+ }], canvasElement: [{
211
+ type: ViewChild,
212
+ args: ['canvasElement']
213
+ }], hostClasses: [{
214
+ type: HostBinding,
215
+ args: ['class']
216
+ }] } });
217
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chartjs.component.js","sourceRoot":"","sources":["../../../../projects/coreui-angular-chartjs/src/lib/chartjs.component.ts","../../../../projects/coreui-angular-chartjs/src/lib/chartjs.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  Output,\n  Renderer2,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { BooleanInput, coerceBooleanProperty, coerceNumberProperty, NumberInput } from '@angular/cdk/coercion';\n\nimport merge from 'lodash-es/merge';\n\nimport { Chart, ChartConfiguration, ChartType, DefaultDataPoint, registerables } from 'chart.js';\nimport { customTooltips as cuiCustomTooltips } from '@coreui/chartjs';\n\nChart.register(...registerables);\n\nlet nextId = 0;\n\n@Component({\n  selector: 'c-chart',\n  templateUrl: './chartjs.component.html',\n  styleUrls: ['./chartjs.component.scss'],\n  exportAs: 'cChart',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ChartjsComponent<TType extends ChartType = ChartType, TData = DefaultDataPoint<TType>, TLabel = unknown> implements AfterViewInit, OnDestroy, OnChanges {\n\n  static ngAcceptInputType_height: NumberInput;\n  static ngAcceptInputType_width: NumberInput;\n  static ngAcceptInputType_redraw: BooleanInput;\n\n  @Input() customTooltips = true;\n  @Input() data?: ChartConfiguration<TType, TData, TLabel>['data'];\n\n  @HostBinding('style.height.px')\n  @Input()\n  set height(value: number | undefined) {\n    this._height = coerceNumberProperty(value);\n  }\n\n  get height() {\n    return this._height;\n  }\n\n  private _height: number | undefined;\n\n  @Input() id = `c-chartjs-${nextId++}`;\n  @Input() options?: ChartConfiguration<TType, TData, TLabel>['options'];\n  @Input() plugins: ChartConfiguration<TType, TData, TLabel>['plugins'] = [];\n\n  @Input()\n  set redraw(value: boolean) {\n    this._redraw = coerceBooleanProperty(value);\n  }\n\n  get redraw(): boolean {\n    return this._redraw;\n  }\n\n  private _redraw = false;\n\n  @Input() type: ChartConfiguration<TType, TData, TLabel>['type'] = 'bar' as TType;\n\n  @HostBinding('style.width.px')\n  @Input()\n  set width(value: number | undefined) {\n    this._width = coerceNumberProperty(value);\n  }\n\n  get width() {\n    return this._width;\n  }\n\n  private _width: number | undefined;\n\n  @Input() wrapper = true;\n\n  @Output() readonly getDatasetAtEvent = new EventEmitter<any>();\n  @Output() readonly getElementAtEvent = new EventEmitter<any>();\n  @Output() readonly getElementsAtEvent = new EventEmitter<any>();\n\n  @Output() readonly chartRef = new EventEmitter<any>();\n\n  @ViewChild('canvasElement') canvasElement!: ElementRef;\n\n  chart!: Chart<TType, TData, TLabel>;\n\n  @HostBinding('class')\n  get hostClasses() {\n    return {\n      'chart-wrapper': this.wrapper\n    };\n  }\n\n  constructor(\n    private elementRef: ElementRef,\n    private ngZone: NgZone,\n    private renderer: Renderer2,\n    private changeDetectorRef: ChangeDetectorRef\n  ) {}\n\n  ngAfterViewInit(): void {\n    this.chartRender();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['data'] && !changes['data'].firstChange) {\n      this.chartUpdate();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.chartDestroy();\n  }\n\n  public handleClick($event: MouseEvent) {\n    if (!this.chart) {\n      return;\n    }\n\n    const datasetAtEvent = this.chart.getElementsAtEventForMode($event, 'dataset', { intersect: true }, false);\n    this.getDatasetAtEvent.emit(datasetAtEvent);\n\n    const elementAtEvent = this.chart.getElementsAtEventForMode($event, 'nearest', { intersect: true }, false);\n    this.getElementAtEvent.emit(elementAtEvent);\n\n    const elementsAtEvent = this.chart.getElementsAtEventForMode($event, 'index', { intersect: true }, false);\n    this.getElementsAtEvent.emit(elementsAtEvent);\n  }\n\n  public chartDestroy() {\n    this.chart?.destroy();\n    this.chartRef.emit(undefined);\n  }\n\n  public chartRender() {\n    if (!this.canvasElement) {\n      return;\n    }\n\n    const ctx: CanvasRenderingContext2D = this.canvasElement.nativeElement.getContext('2d');\n\n    this.ngZone.runOutsideAngular(() => {\n      const config = this.chartConfig();\n      if (config) {\n        setTimeout(() => {\n          this.chart = new Chart(ctx, config);\n          this.renderer.setStyle(this.canvasElement.nativeElement, 'display', 'block');\n          this.changeDetectorRef.markForCheck();\n          this.chartRef.emit(this.chart);\n        });\n      }\n    });\n  }\n\n  chartUpdate() {\n    if (!this.chart) {\n      return;\n    }\n\n    if (this.redraw) {\n      this.chartDestroy();\n      setTimeout(() => {\n        this.chartRender();\n      });\n      return;\n    }\n\n    const config = this.chartConfig();\n\n    if (this.options) {\n      Object.assign(this.chart.options ?? {}, config.options ?? {});\n    }\n\n    if (!this.chart.config.data) {\n      this.chart.config.data = { ...config.data };\n      this.chartUpdateOutsideAngular();\n    }\n\n    if (this.chart) {\n      Object.assign(this.chart.config.options ?? {}, config.options ?? {});\n      Object.assign(this.chart.config.plugins ?? [], config.plugins ?? []);\n      Object.assign(this.chart.config.data, config.data);\n    }\n\n    this.chartUpdateOutsideAngular();\n  }\n\n  private chartUpdateOutsideAngular() {\n    setTimeout(() => {\n      this.ngZone.runOutsideAngular(() => {\n        this.chart?.update();\n        this.changeDetectorRef.markForCheck();\n      });\n    });\n  }\n\n  public chartToBase64Image(): string | undefined {\n    return this.chart?.toBase64Image();\n  }\n\n  private chartDataConfig(): ChartConfiguration<TType, TData, TLabel>['data'] {\n    return {\n      labels: this.data?.labels ?? [],\n      datasets: this.data?.datasets ?? []\n    };\n  }\n\n  private chartOptions(): ChartConfiguration<TType, TData, TLabel>['options'] {\n    return this.options;\n  }\n\n  private chartConfig(): ChartConfiguration<TType, TData, TLabel> {\n    this.chartCustomTooltips();\n    return {\n      data: this.chartDataConfig(),\n      options: this.chartOptions(),\n      plugins: this.plugins,\n      type: this.type\n    };\n  }\n\n  private chartCustomTooltips() {\n    if (this.customTooltips) {\n      const options = this.options;\n      // @ts-ignore\n      const plugins = this.options?.plugins;\n      // @ts-ignore\n      const tooltip = this.options?.plugins?.tooltip;\n      this.options = merge({\n        ...options,\n        plugins: {\n          ...plugins,\n          tooltip: {\n            ...tooltip,\n            enabled: false,\n            mode: 'index',\n            position: 'nearest',\n            external: cuiCustomTooltips\n          }\n        }\n      });\n    }\n  };\n}\n","<canvas\n  #canvasElement\n  (click)=\"handleClick($event)\"\n  [height]=\"height\"\n  [id]=\"id\"\n  [width]=\"width\"\n  role=\"img\"\n  style=\"display: none;\"\n>\n  <ng-content></ng-content>\n</canvas>\n"]}
@@ -1,20 +1,20 @@
1
- import { NgModule } from '@angular/core';
2
- import { ChartjsComponent } from './chartjs.component';
3
- import * as i0 from "@angular/core";
4
- export class ChartjsModule {
5
- }
6
- ChartjsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ChartjsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
7
- ChartjsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: ChartjsModule, declarations: [ChartjsComponent], exports: [ChartjsComponent] });
8
- ChartjsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ChartjsModule });
9
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ChartjsModule, decorators: [{
10
- type: NgModule,
11
- args: [{
12
- declarations: [
13
- ChartjsComponent
14
- ],
15
- exports: [
16
- ChartjsComponent
17
- ]
18
- }]
19
- }] });
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnRqcy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JldWktYW5ndWxhci1jaGFydGpzL3NyYy9saWIvY2hhcnRqcy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7QUFVdkQsTUFBTSxPQUFPLGFBQWE7OzJHQUFiLGFBQWE7NEdBQWIsYUFBYSxpQkFOdEIsZ0JBQWdCLGFBR2hCLGdCQUFnQjs0R0FHUCxhQUFhOzRGQUFiLGFBQWE7a0JBUnpCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGdCQUFnQjtxQkFDakI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGdCQUFnQjtxQkFDakI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDaGFydGpzQ29tcG9uZW50IH0gZnJvbSAnLi9jaGFydGpzLmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgQ2hhcnRqc0NvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgQ2hhcnRqc0NvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIENoYXJ0anNNb2R1bGUgeyB9XHJcbiJdfQ==
1
+ import { NgModule } from '@angular/core';
2
+ import { ChartjsComponent } from './chartjs.component';
3
+ import * as i0 from "@angular/core";
4
+ export class ChartjsModule {
5
+ }
6
+ ChartjsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ChartjsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
7
+ ChartjsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: ChartjsModule, imports: [ChartjsComponent], exports: [ChartjsComponent] });
8
+ ChartjsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ChartjsModule, imports: [ChartjsComponent] });
9
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ChartjsModule, decorators: [{
10
+ type: NgModule,
11
+ args: [{
12
+ imports: [
13
+ ChartjsComponent
14
+ ],
15
+ exports: [
16
+ ChartjsComponent
17
+ ]
18
+ }]
19
+ }] });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnRqcy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JldWktYW5ndWxhci1jaGFydGpzL3NyYy9saWIvY2hhcnRqcy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7QUFVdkQsTUFBTSxPQUFPLGFBQWE7OzBHQUFiLGFBQWE7MkdBQWIsYUFBYSxZQU50QixnQkFBZ0IsYUFHaEIsZ0JBQWdCOzJHQUdQLGFBQWEsWUFOdEIsZ0JBQWdCOzJGQU1QLGFBQWE7a0JBUnpCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLGdCQUFnQjtxQkFDakI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGdCQUFnQjtxQkFDakI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ2hhcnRqc0NvbXBvbmVudCB9IGZyb20gJy4vY2hhcnRqcy5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ2hhcnRqc0NvbXBvbmVudFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgQ2hhcnRqc0NvbXBvbmVudFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIENoYXJ0anNNb2R1bGUge31cbiJdfQ==
@@ -1,6 +1,6 @@
1
- /*
2
- * Public API Surface of coreui-angular-chartjs
3
- */
4
- export * from './lib/chartjs.component';
5
- export * from './lib/chartjs.module';
1
+ /*
2
+ * Public API Surface of coreui-angular-chartjs
3
+ */
4
+ export * from './lib/chartjs.component';
5
+ export * from './lib/chartjs.module';
6
6
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2NvcmV1aS1hbmd1bGFyLWNoYXJ0anMvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsc0JBQXNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGNvcmV1aS1hbmd1bGFyLWNoYXJ0anNcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFydGpzLm1vZHVsZSc7XG4iXX0=