ca-components 1.0.76 → 1.0.77

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.
Files changed (29) hide show
  1. package/esm2022/lib/components/ca-chart/ca-chart.component.mjs +200 -120
  2. package/esm2022/lib/components/ca-chart/enums/chart-annotation.enum.mjs +11 -0
  3. package/esm2022/lib/components/ca-chart/enums/chart-plugin-ids.enum.mjs +2 -1
  4. package/esm2022/lib/components/ca-chart/enums/index.mjs +2 -1
  5. package/esm2022/lib/components/ca-chart/models/chart-config.model.mjs +1 -1
  6. package/esm2022/lib/components/ca-chart/models/chart-legend-config.model.mjs +2 -0
  7. package/esm2022/lib/components/ca-chart/models/chart-legend-property.model.mjs +2 -0
  8. package/esm2022/lib/components/ca-chart/models/index.mjs +3 -1
  9. package/esm2022/lib/components/ca-chart/utils/helpers/chart.helper.mjs +2 -2
  10. package/esm2022/lib/components/ca-chart-manager/ca-chart-manager.component.mjs +4 -4
  11. package/esm2022/lib/components/ca-dropdown-menu/ca-dropdown-menu.component.mjs +3 -3
  12. package/esm2022/lib/components/ca-input-address-dropdown/ca-input-address-dropdown.component.mjs +21 -22
  13. package/esm2022/lib/components/ca-input-address-dropdown/enums/input-address-basic-string.enum.mjs +6 -0
  14. package/esm2022/lib/pipes/index.mjs +19 -0
  15. package/esm2022/lib/pipes/unit-position.pipe.mjs +24 -0
  16. package/fesm2022/ca-components.mjs +277 -163
  17. package/fesm2022/ca-components.mjs.map +1 -1
  18. package/lib/components/ca-chart/ca-chart.component.d.ts +9 -4
  19. package/lib/components/ca-chart/enums/chart-annotation.enum.d.ts +10 -0
  20. package/lib/components/ca-chart/enums/chart-plugin-ids.enum.d.ts +2 -1
  21. package/lib/components/ca-chart/enums/index.d.ts +1 -0
  22. package/lib/components/ca-chart/models/chart-config.model.d.ts +1 -0
  23. package/lib/components/ca-chart/models/chart-legend-config.model.d.ts +6 -0
  24. package/lib/components/ca-chart/models/chart-legend-property.model.d.ts +7 -0
  25. package/lib/components/ca-chart/models/index.d.ts +2 -0
  26. package/lib/components/ca-input-address-dropdown/enums/input-address-basic-string.enum.d.ts +4 -0
  27. package/lib/pipes/index.d.ts +18 -0
  28. package/lib/pipes/unit-position.pipe.d.ts +7 -0
  29. package/package.json +1 -1
@@ -1,17 +1,20 @@
1
1
  import { Component, Input, Output, Optional, ViewChild, EventEmitter, } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { AngularSvgIconModule } from 'angular-svg-icon';
4
+ import { Subject, takeUntil } from 'rxjs';
4
5
  // Charts
5
6
  import { Chart, } from 'chart.js/auto';
6
7
  import annotationPlugin from 'chartjs-plugin-annotation';
7
8
  // Enums
8
- import { EChartEventProperties, ChartPluginIdsStringEnum, CubicInterpolationStringEnum, ChartEventTypesStringEnum, ChartFontPropertiesStringEnum, EChartAnnotationType, } from './enums';
9
+ import { EChartEventProperties, ChartPluginIdsStringEnum, CubicInterpolationStringEnum, ChartEventTypesStringEnum, ChartFontPropertiesStringEnum, EChartAnnotation, } from './enums';
9
10
  // Helpers
10
11
  import { ChartHelper } from './utils/helpers';
11
12
  // Guards
12
13
  import { ChartTypeGuard } from './utils/guards';
13
14
  // Constants
14
15
  import { ChartConstants } from './utils/constants';
16
+ // Pipes
17
+ import { ThousandSeparatorPipe, UnitPositionPipe } from '../../pipes';
15
18
  import * as i0 from "@angular/core";
16
19
  import * as i1 from "../ca-chart-manager/services";
17
20
  import * as i2 from "@angular/common";
@@ -53,10 +56,20 @@ export class CaChartComponent {
53
56
  });
54
57
  });
55
58
  }
59
+ set selectedIndex(value) {
60
+ if (!this.chart || !this.isChartDataAvailable)
61
+ return;
62
+ if (value !== null)
63
+ this.focusDoughnutArc(value);
64
+ else
65
+ this.setOriginalDoughnutArcsColor();
66
+ this.chart.update();
67
+ }
56
68
  constructor(changeDetector, chartManagerService) {
57
69
  this.changeDetector = changeDetector;
58
70
  this.chartManagerService = chartManagerService;
59
71
  this.hoveredIndex = new EventEmitter();
72
+ this.destroy$ = new Subject();
60
73
  this.areAnimationsCompleated = false;
61
74
  this._hoveredIndex = null;
62
75
  this.isChartDataAvailable = false;
@@ -73,7 +86,10 @@ export class CaChartComponent {
73
86
  initializeChartManagerService() {
74
87
  if (!this.chartManagerService)
75
88
  return;
76
- this.subscription = this.chartManagerService.hoverState$.subscribe(({ index, chartId }) => {
89
+ this.chartManagerService.
90
+ hoverState$.
91
+ pipe(takeUntil(this.destroy$))
92
+ .subscribe(({ index, chartId }) => {
77
93
  if (chartId !== this.chartId) {
78
94
  this._hoveredIndex = index;
79
95
  if (this.chart)
@@ -89,45 +105,54 @@ export class CaChartComponent {
89
105
  return;
90
106
  if (chartDatasetHover.isHoverd) {
91
107
  const gradient = ChartHelper.createGradient(this.chartContext, this.chartCanvas, chartDatasetHover.color, chartDatasetHover.color, 0.6, 0.1, true);
92
- this.chart.data.datasets = this.chart.data.datasets.map((dataset) => {
93
- if (dataset.hidden)
94
- return dataset;
95
- if (dataset.label?.toUpperCase() === chartDatasetHover.label.toUpperCase()) {
96
- const hoverdDataSet = {
97
- ...dataset,
98
- fill: true,
99
- backgroundColor: gradient,
100
- borderColor: chartDatasetHover.color,
101
- order: 1,
102
- };
103
- return hoverdDataSet;
104
- }
105
- else {
106
- const borderColorWithOpacity = ChartHelper.changeOpacityOfRgbOrRgba(dataset.borderColor, 0.2);
107
- return {
108
- ...dataset,
109
- fill: false,
110
- borderColor: borderColorWithOpacity,
111
- };
112
- }
113
- });
108
+ this.chart.data.datasets =
109
+ this.chart?.
110
+ data?.
111
+ datasets?.
112
+ map((dataset) => {
113
+ if (dataset.hidden)
114
+ return dataset;
115
+ if (dataset?.label?.toUpperCase() ===
116
+ chartDatasetHover?.label?.toUpperCase()) {
117
+ const hoverdDataSet = {
118
+ ...dataset,
119
+ fill: true,
120
+ backgroundColor: gradient,
121
+ borderColor: chartDatasetHover.color,
122
+ order: 1,
123
+ };
124
+ return hoverdDataSet;
125
+ }
126
+ else {
127
+ const borderColorWithOpacity = ChartHelper.changeOpacityOfRgbOrRgba(dataset.borderColor, 0.2);
128
+ return {
129
+ ...dataset,
130
+ fill: false,
131
+ borderColor: borderColorWithOpacity,
132
+ };
133
+ }
134
+ });
114
135
  }
115
136
  else {
116
- this.chart.data.datasets = this.chart.data.datasets.map((dataset) => {
117
- if (!dataset.hidden) {
118
- const originalColor = dataset.borderColor
119
- ? ChartHelper.changeOpacityOfRgbOrRgba(dataset.borderColor, 1)
120
- : ChartConstants.STRING_EMPTY;
121
- return {
122
- ...dataset,
123
- fill: false,
124
- borderColor: originalColor,
125
- backgroundColor: ChartConstants.STRING_EMPTY,
126
- };
127
- }
128
- else
129
- return dataset;
130
- });
137
+ this.chart.data.datasets =
138
+ this.chart
139
+ .data
140
+ .datasets
141
+ .map((dataset) => {
142
+ if (!dataset.hidden) {
143
+ const originalColor = dataset.borderColor
144
+ ? ChartHelper.changeOpacityOfRgbOrRgba(dataset.borderColor, 1)
145
+ : ChartConstants.STRING_EMPTY;
146
+ return {
147
+ ...dataset,
148
+ fill: false,
149
+ borderColor: originalColor,
150
+ backgroundColor: ChartConstants.STRING_EMPTY,
151
+ };
152
+ }
153
+ else
154
+ return dataset;
155
+ });
131
156
  }
132
157
  this.chart.update();
133
158
  }
@@ -142,14 +167,14 @@ export class CaChartComponent {
142
167
  this.chart.destroy();
143
168
  this.initializeAnnotationPlugin();
144
169
  if (this._chartConfig.chartType === "doughnut" /* ChartTypesStringEnum.DOUGHNUT */)
145
- Chart.overrides.doughnut.cutout = '80%';
170
+ Chart.overrides.doughnut.cutout = '88%';
146
171
  this.chart = new Chart(this.chartContext, {
147
172
  type: this._chartConfig.chartType,
148
173
  data: this._chartConfig.chartData,
149
174
  options: this._chartConfig.chartOptions,
150
175
  plugins: this.plugins,
151
176
  });
152
- if (!this._chartConfig.isDashboardChart) {
177
+ if (!this._chartConfig.isDashboardChart)
153
178
  this.chart.config.data.datasets = [
154
179
  ...this._chartConfig?.
155
180
  chartData?.
@@ -162,23 +187,22 @@ export class CaChartComponent {
162
187
  };
163
188
  this.updateChartAnnotations(item, indx);
164
189
  const yScale = this.chart.scales[EChartEventProperties.Y_AXIS_0];
190
+ const backgroundColor = (item?.color &&
191
+ item?.color2) ?
192
+ ChartHelper.createGradient(this.chartContext, this.chartCanvas, item?.color, item?.color2) : item?.color;
165
193
  const datasetConfig = {
166
194
  ...item,
167
195
  pointBorderColor: item.color,
168
196
  ...pointConfig,
169
- backgroundColor: item?.color &&
170
- item?.color2 &&
171
- item?.color !== item?.color2 ?
172
- ChartHelper.createGradient(this.chartContext, this.chartCanvas, item?.color, item?.color2) : item?.color,
197
+ backgroundColor,
173
198
  fill: item?.fill
174
199
  };
175
- if (this._chartConfig.chartType === "doughnut" /* ChartTypesStringEnum.DOUGHNUT */) {
200
+ if (this._chartConfig.chartType === "doughnut" /* ChartTypesStringEnum.DOUGHNUT */)
176
201
  return {
177
202
  ...datasetConfig,
178
203
  backgroundColor: item.backgroundColor
179
204
  };
180
- }
181
- if (!item.shiftValue) {
205
+ if (!item.shiftValue)
182
206
  return {
183
207
  ...datasetConfig,
184
208
  backgroundColor: item?.color &&
@@ -186,26 +210,26 @@ export class CaChartComponent {
186
210
  item?.color !== item?.color2 ?
187
211
  ChartHelper.createGradient(this.chartContext, this.chartCanvas, item?.color, item?.color2) : item?.color,
188
212
  };
189
- }
190
213
  const shiftValuePx = yScale.getPixelForValue(item.shiftValue || 0);
191
214
  const shiftValueAdjusted = shiftValuePx / yScale.maxHeight;
192
- const borderColor = ChartHelper.createGradientWithShiftValue(this.chartContext, yScale.maxHeight, item.color || ChartConstants.STRING_EMPTY, item.color2 || ChartConstants.STRING_EMPTY, shiftValueAdjusted);
215
+ const color1 = item.color || ChartConstants.STRING_EMPTY;
216
+ const color2 = item.color2 || ChartConstants.STRING_EMPTY;
217
+ const borderColor = ChartHelper.createGradientWithShiftValue(this.chartContext, yScale.maxHeight, color1, color2, shiftValueAdjusted);
193
218
  return {
194
219
  ...item,
195
220
  ...pointConfig,
196
221
  pointBorderColor: borderColor,
197
- backgroundColor: ChartHelper.createGradientWithShiftValue(this.chartContext, yScale.maxHeight, item.color || ChartConstants.STRING_EMPTY, item.color2 || ChartConstants.STRING_EMPTY, shiftValueAdjusted, true),
222
+ backgroundColor: ChartHelper.createGradientWithShiftValue(this.chartContext, yScale.maxHeight, color1, color2, shiftValueAdjusted, true),
198
223
  borderColor,
199
224
  fill: true
200
225
  };
201
226
  })
202
227
  ];
203
- }
204
228
  this.chart.update();
205
229
  }
206
230
  updateChart() {
207
231
  if (this.chart)
208
- this.chart?.destroy();
232
+ this.chart.update();
209
233
  this.createChart();
210
234
  }
211
235
  setChartOptionsProperties() {
@@ -226,8 +250,14 @@ export class CaChartComponent {
226
250
  },
227
251
  layout: {
228
252
  padding: {
229
- top: 0,
230
- bottom: 0,
253
+ top: this._chartConfig.chartType ===
254
+ "doughnut" /* ChartTypesStringEnum.DOUGHNUT */ ?
255
+ 8 :
256
+ 0,
257
+ bottom: this._chartConfig.chartType ===
258
+ "doughnut" /* ChartTypesStringEnum.DOUGHNUT */ ?
259
+ 8 :
260
+ 0,
231
261
  left: this._chartConfig.chartType === "bar" /* ChartTypesStringEnum.BAR */ &&
232
262
  this._chartConfig.verticalyAlignBarChartWithLineCart
233
263
  ? 6
@@ -268,7 +298,7 @@ export class CaChartComponent {
268
298
  autoSkipPadding: 12,
269
299
  maxRotation: 0,
270
300
  minRotation: 0,
271
- //Label written in 2 lines, will be ujusted with new design
301
+ //Label written in 2 lines, will be adjusted with new design
272
302
  callback: function (value, index) {
273
303
  const label = labels[index];
274
304
  const multiLineLabel = label ? label.split(' ') : [];
@@ -288,38 +318,47 @@ export class CaChartComponent {
288
318
  },
289
319
  },
290
320
  onHover: (event, item) => {
291
- if (this._chartConfig.hasVerticalDashedAnnotation)
292
- this.resetAnnotations();
293
- if (this._chartConfig.chartType === "doughnut" /* ChartTypesStringEnum.DOUGHNUT */) {
294
- const colors = this.chart.data.datasets[0].backgroundColor;
295
- this.chart.data.datasets[0].backgroundColor =
296
- colors.map((color) => {
297
- return ChartHelper.convertRgbToRgba(color);
298
- });
299
- this.chart.update();
300
- }
301
- if (!item ||
302
- !item?.length) {
303
- this.hoveredIndex.emit(null);
304
- return;
321
+ if (this._chartConfig.hasVerticalDashedAnnotation) {
322
+ this.removeVerticalDashedLine();
323
+ this.setVerticalDashedAnnotationLine(event);
305
324
  }
306
- this.hoveredIndex.emit(item[0].index);
325
+ this.setOriginalDoughnutArcsColor();
307
326
  if (this._chartConfig.chartType === "doughnut" /* ChartTypesStringEnum.DOUGHNUT */) {
308
- const colors = this.chart.data.datasets[0].backgroundColor;
309
- const updatedColors = colors.map((color, indx) => {
310
- if (indx === item[0].index)
311
- return color;
312
- const convertedValue = ChartHelper.convertRgbToRgba(color, 0.2);
313
- return convertedValue;
314
- });
315
- this.chart.data.datasets[0].backgroundColor = updatedColors;
327
+ this.hoveredIndex.emit(item[0]?.index || null);
328
+ item[0]?.index >= 0 ?
329
+ this.focusDoughnutArc(item[0]?.index) :
330
+ this.setOriginalDoughnutArcsColor();
316
331
  }
317
- if (this._chartConfig.hasVerticalDashedAnnotation)
318
- this.setVerticalDashedAnnotationLine(item[0].element.x);
332
+ ;
319
333
  this.chart.update();
320
334
  },
321
335
  };
322
336
  }
337
+ focusDoughnutArc(index) {
338
+ if (this._chartConfig.chartType !== "doughnut" /* ChartTypesStringEnum.DOUGHNUT */ ||
339
+ index === this.chart.data.datasets[0].data.length - 1)
340
+ return;
341
+ const colors = this.chart?.
342
+ data?.
343
+ datasets[0]?.backgroundColor;
344
+ const updatedColors = colors.map((color, indx) => {
345
+ if (indx === index)
346
+ return color;
347
+ const convertedValue = ChartHelper.convertRgbToRgba(color, 0.2);
348
+ return convertedValue;
349
+ });
350
+ this.chart.data.datasets[0].backgroundColor = updatedColors;
351
+ }
352
+ setOriginalDoughnutArcsColor() {
353
+ if (this._chartConfig.chartType !== "doughnut" /* ChartTypesStringEnum.DOUGHNUT */)
354
+ return;
355
+ const colors = this.chart.data.datasets[0].backgroundColor;
356
+ this.chart.data.datasets[0].backgroundColor =
357
+ [...colors.map((color) => {
358
+ return ChartHelper.rgbToRgba(color, 1);
359
+ })];
360
+ this.chart.update();
361
+ }
323
362
  setChartDataProperties() {
324
363
  if ((this._chartConfig.chartType === "line" /* ChartTypesStringEnum.LINE */)) {
325
364
  this._chartConfig.chartData.datasets.forEach((dataset) => {
@@ -342,13 +381,10 @@ export class CaChartComponent {
342
381
  }
343
382
  }
344
383
  setChartPluginsProperties() {
345
- let hoveredIndex = null;
346
384
  this.plugins = [
347
385
  {
348
386
  id: ChartPluginIdsStringEnum.HIGHLIGHT_SEGMENT_ON_HOVER,
349
387
  afterEvent: (chart, event) => {
350
- if (!this._chartConfig.showTooltipBackground)
351
- return;
352
388
  const nativeEvent = event.event.native;
353
389
  if (event.event.type === ChartEventTypesStringEnum.MOUSE_OUT) {
354
390
  const boundingRect = this.chart.canvas.getBoundingClientRect();
@@ -359,10 +395,13 @@ export class CaChartComponent {
359
395
  if (isMouseOutsideChart) {
360
396
  this._hoveredIndex = null;
361
397
  this.chartManagerService?.setHoverState(null, this.chartId);
398
+ this.removeVerticalDashedLineAndFocus();
362
399
  this.chart.draw();
363
400
  }
364
401
  return;
365
402
  }
403
+ if (!this._chartConfig.showTooltipBackground)
404
+ return;
366
405
  const boundingRect = this.chart.canvas.getBoundingClientRect();
367
406
  const mouseHorizontalCoordinate = nativeEvent.clientX - boundingRect.left;
368
407
  const { left, right } = this.chart.chartArea;
@@ -473,7 +512,9 @@ export class CaChartComponent {
473
512
  type: annotation.type,
474
513
  scaleID: annotation.axis || item.yAxisID,
475
514
  value: annotation.value || item.shiftValue,
476
- borderColor: annotation.color || '#DADADA',
515
+ borderColor: annotation.color ||
516
+ "#DADADA" /* ChartColorsStringEnum.
517
+ BORDER_BOTTOM_LINE_CHART_COLOR */,
477
518
  borderWidth: annotation.borderWidth || 2,
478
519
  borderDash: annotation.borderDash || [0, 0],
479
520
  },
@@ -484,7 +525,6 @@ export class CaChartComponent {
484
525
  this.chart.update();
485
526
  }
486
527
  setMultipleYAxis(chartData) {
487
- let absoluteMax;
488
528
  chartData.datasets.forEach((dataset, index) => {
489
529
  if (dataset.type === "line" /* ChartTypesStringEnum.LINE */ ||
490
530
  dataset.type === "bar" /* ChartTypesStringEnum.BAR */) {
@@ -523,63 +563,103 @@ export class CaChartComponent {
523
563
  }
524
564
  });
525
565
  }
526
- resetAnnotations() {
527
- this._chartConfig.chartOptions.plugins =
528
- {
529
- ...this._chartConfig.chartOptions.plugins,
530
- annotation: {}
531
- };
566
+ removeVerticalDashedLine() {
567
+ const annotations = this._chartConfig?.
568
+ chartOptions?.
569
+ plugins?.
570
+ annotation?.
571
+ annotations;
572
+ const key = ChartPluginIdsStringEnum.X_DASHED;
573
+ if (annotations) {
574
+ delete this._chartConfig?.
575
+ chartOptions?.
576
+ plugins?.
577
+ annotation?.
578
+ annotations?.[key];
579
+ }
532
580
  this.chart.update();
533
581
  }
534
- setVerticalDashedAnnotationLine(xCord, color) {
582
+ setVerticalDashedAnnotationLine(event, color) {
583
+ const { left, right } = this.chart.chartArea;
535
584
  const xScale = this.chart.scales[EChartEventProperties.X];
536
- const valueFromPixel = xScale.getValueForPixel(xCord);
537
- if (valueFromPixel === undefined)
538
- return;
539
- this._chartConfig.chartOptions.plugins = {
540
- ...this._chartConfig.chartOptions.plugins,
541
- annotation: {
542
- ...this._chartConfig.chartOptions?.plugins?.annotation,
543
- annotations: {
544
- ...this._chartConfig.
545
- chartOptions?.
546
- plugins?.
547
- annotation?.
548
- annotations,
549
- [`x-dashed`]: {
550
- id: `x-dashed`,
551
- type: EChartAnnotationType.LINE,
552
- scaleID: EChartEventProperties.X,
553
- value: valueFromPixel,
554
- borderColor: color || '#DADADA',
555
- borderWidth: 2,
556
- borderDash: [5, 5],
585
+ const tickPositions = this._chartConfig?.
586
+ chartData?.labels?.
587
+ map((label, index) => {
588
+ return xScale.getPixelForValue(index);
589
+ });
590
+ const segmentBoundaries = tickPositions.map((tickPos, index) => {
591
+ const leftBoundary = index === 0 ? left : (tickPos + tickPositions[index - 1]) / 2;
592
+ const rightBoundary = index === tickPositions.length - 1
593
+ ? right
594
+ : (tickPos + tickPositions[index + 1]) / 2;
595
+ return { leftBoundary, rightBoundary };
596
+ });
597
+ const nativeEvent = event.native;
598
+ const boundingRect = this.chart.canvas.getBoundingClientRect();
599
+ const mouseHorizontalCoordinate = nativeEvent.clientX - boundingRect.left;
600
+ const newHoveredIndex = segmentBoundaries.findIndex((boundary) => mouseHorizontalCoordinate >= boundary.leftBoundary &&
601
+ mouseHorizontalCoordinate < boundary.rightBoundary);
602
+ if (newHoveredIndex >= 0) {
603
+ this._chartConfig.chartOptions.plugins = {
604
+ ...this._chartConfig.chartOptions.plugins,
605
+ annotation: {
606
+ ...this._chartConfig.chartOptions?.plugins?.annotation,
607
+ annotations: {
608
+ ...this._chartConfig.
609
+ chartOptions?.
610
+ plugins?.
611
+ annotation?.
612
+ annotations,
613
+ [ChartPluginIdsStringEnum.X_DASHED]: {
614
+ ...EChartAnnotation.X_DASHED,
615
+ value: newHoveredIndex,
616
+ borderColor: color || "#DADADA" /* ChartColorsStringEnum.
617
+ BORDER_BOTTOM_LINE_CHART_COLOR */,
618
+ },
557
619
  },
558
620
  },
559
- },
560
- };
621
+ };
622
+ }
623
+ ;
624
+ this.hoveredIndex.emit(newHoveredIndex);
625
+ this.chart.update();
626
+ }
627
+ removeVerticalDashedLineAndFocus() {
628
+ this.hoveredIndex.emit(null);
629
+ if (this._chartConfig.hasVerticalDashedAnnotation)
630
+ this.removeVerticalDashedLine();
561
631
  }
562
632
  ngOnDestroy() {
563
- this.subscription?.unsubscribe();
633
+ this.destroy$.next();
634
+ this.destroy$.complete();
564
635
  }
565
636
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaChartComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.ChartManagerService, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
566
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CaChartComponent, isStandalone: true, selector: "app-ca-chart", inputs: { chartId: "chartId", chartDatasetHover: "chartDatasetHover", chartConfig: "chartConfig" }, outputs: { hoveredIndex: "hoveredIndex" }, viewQueries: [{ propertyName: "chartCanvas", first: true, predicate: ["chartCanvas"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"isChartDataAvailable; else noDataTemplate\">\n <div\n [ngStyle]=\"{\n height: _chartConfig.height + 'px',\n width: _chartConfig.width + '%',\n }\"\n >\n <canvas #chartCanvas></canvas>\n </div>\n</ng-container>\n<ng-template #noDataTemplate>\n <div\n class=\"d-flex justify-content-center align-items-center\"\n [ngStyle]=\"{\n height: _chartConfig.height + 'px',\n width: _chartConfig.width + '%',\n }\"\n >\n <svg-icon\n [src]=\"_chartConfig.noDataImage\"\n alt=\"No data available\"\n class=\"no-data-svg\"\n ></svg-icon>\n </div>\n</ng-template>\n", styles: [".no-data-svg{width:100%;height:auto;max-width:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: AngularSvgIconModule }, { kind: "component", type: i3.SvgIconComponent, selector: "svg-icon", inputs: ["src", "name", "stretch", "applyClass", "applyCss", "svgClass", "class", "viewBox", "svgAriaLabel", "svgStyle"] }] }); }
637
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CaChartComponent, isStandalone: true, selector: "app-ca-chart", inputs: { legendData: "legendData", chartId: "chartId", chartDatasetHover: "chartDatasetHover", chartConfig: "chartConfig", selectedIndex: "selectedIndex" }, outputs: { hoveredIndex: "hoveredIndex" }, viewQueries: [{ propertyName: "chartCanvas", first: true, predicate: ["chartCanvas"], descendants: true }], ngImport: i0, template: "@if (isChartDataAvailable) {\n <ng-container\n *ngTemplateOutlet=\"\n legend;\n context: {\n config: legendData,\n }\n \"\n ></ng-container>\n <div\n [ngStyle]=\"{\n height: _chartConfig.height + 'px',\n width: _chartConfig.width + '%',\n }\"\n >\n <canvas #chartCanvas></canvas>\n </div>\n} @else {\n <div\n class=\"d-flex justify-content-center align-items-center\"\n [ngStyle]=\"{\n height: _chartConfig.height + 'px',\n width: _chartConfig.width + '%',\n }\"\n >\n <svg-icon\n [src]=\"_chartConfig.noDataImage\"\n alt=\"No data available\"\n class=\"no-data-svg\"\n ></svg-icon>\n </div>\n}\n<ng-template #legend let-config=\"config\">\n @if (config?.data) {\n <div\n [ngClass]=\"config.hasHighlightedBackground && 'colored-background'\"\n >\n @if (config.title) {\n <div class=\"legend-title font-size-14 ta-font-extra-bold\">\n {{ config.title }}\n </div>\n }\n <div class=\"legend-wrapper d-flex\">\n @for (\n item of config.data;\n let index = $index;\n track item.name\n ) {\n <div class=\"w-100\">\n <div\n class=\"d-flex align-content-center text-size-11 ta-font-bold\"\n >\n <span>{{ item?.name }}</span>\n <span\n [ngClass]=\"\n item?.isLineIndicator\n ? 'line-indicator'\n : 'circle-indicator'\n \"\n [ngStyle]=\"{ background: item?.color }\"\n ></span>\n </div>\n <div class=\"text-size-18\">\n {{\n (item?.value !== 0\n ? (item?.value | thousandSeparator)\n : 0\n ) | unitPosition: item?.unit\n }}\n </div>\n </div>\n }\n </div>\n </div>\n }\n</ng-template>\n", styles: ["@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.no-data-svg{width:100%;height:auto;max-width:100%}.legend-title{margin:6px;height:26px;line-height:26px;border-bottom:1px solid #dadada}.legend-wrapper{width:100%;min-height:46px;padding:4px 6px}.legend-wrapper .circle-indicator{height:10px;width:10px;border-radius:50px;margin:2px 4px}.legend-wrapper .line-indicator{height:2px;width:10px;margin:auto 4px}.colored-background{background-color:#eee;padding:0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: AngularSvgIconModule }, { kind: "component", type: i3.SvgIconComponent, selector: "svg-icon", inputs: ["src", "name", "stretch", "applyClass", "applyCss", "svgClass", "class", "viewBox", "svgAriaLabel", "svgStyle"] }, { kind: "pipe", type: UnitPositionPipe, name: "unitPosition" }, { kind: "pipe", type: ThousandSeparatorPipe, name: "thousandSeparator" }] }); }
567
638
  }
568
639
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaChartComponent, decorators: [{
569
640
  type: Component,
570
- args: [{ selector: 'app-ca-chart', standalone: true, imports: [CommonModule, AngularSvgIconModule], template: "<ng-container *ngIf=\"isChartDataAvailable; else noDataTemplate\">\n <div\n [ngStyle]=\"{\n height: _chartConfig.height + 'px',\n width: _chartConfig.width + '%',\n }\"\n >\n <canvas #chartCanvas></canvas>\n </div>\n</ng-container>\n<ng-template #noDataTemplate>\n <div\n class=\"d-flex justify-content-center align-items-center\"\n [ngStyle]=\"{\n height: _chartConfig.height + 'px',\n width: _chartConfig.width + '%',\n }\"\n >\n <svg-icon\n [src]=\"_chartConfig.noDataImage\"\n alt=\"No data available\"\n class=\"no-data-svg\"\n ></svg-icon>\n </div>\n</ng-template>\n", styles: [".no-data-svg{width:100%;height:auto;max-width:100%}\n"] }]
641
+ args: [{ selector: 'app-ca-chart', standalone: true, imports: [
642
+ CommonModule,
643
+ AngularSvgIconModule,
644
+ UnitPositionPipe,
645
+ ThousandSeparatorPipe,
646
+ ], template: "@if (isChartDataAvailable) {\n <ng-container\n *ngTemplateOutlet=\"\n legend;\n context: {\n config: legendData,\n }\n \"\n ></ng-container>\n <div\n [ngStyle]=\"{\n height: _chartConfig.height + 'px',\n width: _chartConfig.width + '%',\n }\"\n >\n <canvas #chartCanvas></canvas>\n </div>\n} @else {\n <div\n class=\"d-flex justify-content-center align-items-center\"\n [ngStyle]=\"{\n height: _chartConfig.height + 'px',\n width: _chartConfig.width + '%',\n }\"\n >\n <svg-icon\n [src]=\"_chartConfig.noDataImage\"\n alt=\"No data available\"\n class=\"no-data-svg\"\n ></svg-icon>\n </div>\n}\n<ng-template #legend let-config=\"config\">\n @if (config?.data) {\n <div\n [ngClass]=\"config.hasHighlightedBackground && 'colored-background'\"\n >\n @if (config.title) {\n <div class=\"legend-title font-size-14 ta-font-extra-bold\">\n {{ config.title }}\n </div>\n }\n <div class=\"legend-wrapper d-flex\">\n @for (\n item of config.data;\n let index = $index;\n track item.name\n ) {\n <div class=\"w-100\">\n <div\n class=\"d-flex align-content-center text-size-11 ta-font-bold\"\n >\n <span>{{ item?.name }}</span>\n <span\n [ngClass]=\"\n item?.isLineIndicator\n ? 'line-indicator'\n : 'circle-indicator'\n \"\n [ngStyle]=\"{ background: item?.color }\"\n ></span>\n </div>\n <div class=\"text-size-18\">\n {{\n (item?.value !== 0\n ? (item?.value | thousandSeparator)\n : 0\n ) | unitPosition: item?.unit\n }}\n </div>\n </div>\n }\n </div>\n </div>\n }\n</ng-template>\n", styles: ["@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.no-data-svg{width:100%;height:auto;max-width:100%}.legend-title{margin:6px;height:26px;line-height:26px;border-bottom:1px solid #dadada}.legend-wrapper{width:100%;min-height:46px;padding:4px 6px}.legend-wrapper .circle-indicator{height:10px;width:10px;border-radius:50px;margin:2px 4px}.legend-wrapper .line-indicator{height:2px;width:10px;margin:auto 4px}.colored-background{background-color:#eee;padding:0}\n"] }]
571
647
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.ChartManagerService, decorators: [{
572
648
  type: Optional
573
649
  }] }], propDecorators: { chartCanvas: [{
574
650
  type: ViewChild,
575
651
  args: ['chartCanvas', { static: false }]
652
+ }], legendData: [{
653
+ type: Input
576
654
  }], chartId: [{
577
655
  type: Input
578
656
  }], chartDatasetHover: [{
579
657
  type: Input
580
658
  }], chartConfig: [{
581
659
  type: Input
660
+ }], selectedIndex: [{
661
+ type: Input
582
662
  }], hoveredIndex: [{
583
663
  type: Output
584
664
  }] } });
585
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-chart.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-chart/ca-chart.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-chart/ca-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  Output,\n  Optional,\n  ViewChild,\n  EventEmitter,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { AnyObject } from 'chart.js/dist/types/basic';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { Subscription } from 'rxjs';\n\n// Charts\nimport {\n  CategoryScale,\n  Chart,\n  ChartEvent,\n  LinearScale,\n  Plugin,\n} from 'chart.js/auto';\nimport annotationPlugin from 'chartjs-plugin-annotation';\nimport { ChartType } from 'chart.js';\n\n// Enums\nimport {\n  ChartColorsStringEnum,\n  EChartEventProperties,\n  ChartPluginIdsStringEnum,\n  ChartTypesStringEnum,\n  CubicInterpolationStringEnum,\n  ChartEventTypesStringEnum,\n  ChartFontPropertiesStringEnum,\n  EChartAnnotationType,\n} from './enums';\n\n// Helpers\nimport { ChartHelper } from './utils/helpers';\n\n// Guards\nimport { ChartTypeGuard } from './utils/guards';\n\n//Models\nimport {\n  IChartData,\n  ILineDataset,\n  IChartConfiguration,\n  IBaseDataset,\n  IChartAnnotation,\n  IChartDatasetHover,\n  IChartCenterLabel\n} from './models';\nimport { ActiveElement } from 'chart.js/dist/plugins/plugin.tooltip';\n\n//Services\nimport { ChartManagerService } from '../ca-chart-manager/services';\n\n// Constants\nimport { ChartConstants } from './utils/constants';\n\n@Component({\n  selector: 'app-ca-chart',\n  templateUrl: './ca-chart.component.html',\n  styleUrls: ['./ca-chart.component.scss'],\n  standalone: true,\n  imports: [CommonModule, AngularSvgIconModule],\n})\nexport class CaChartComponent implements AfterViewInit {\n  @ViewChild('chartCanvas', { static: false }) chartCanvas!: ElementRef;\n\n  @Input() chartId!: string;\n  @Input()\n  set chartDatasetHover(value: IChartDatasetHover | null) {\n    if (value) this.updateDatasetBackgroundOnHover(value);\n  }\n  @Input() set chartConfig(value: IChartConfiguration) {\n    this._chartConfig = value;\n    this.isChartDataAvailable = false;\n    this._chartConfig?.\n      chartData?.\n      datasets?.\n      forEach((item: IBaseDataset) => {\n        item.data.forEach((value: number | number[]) => {\n          if (Array.isArray(value)) {\n            if (value[0] !== 0 || value[1] !== 0)\n              this.isChartDataAvailable = true;\n          }\n          else\n            if (value !== 0)\n              this.isChartDataAvailable = true;\n        })\n      });\n    this.changeDetector.detectChanges();\n    if (this.isChartDataAvailable)\n      this.updateChart();\n\n\n    this._chartConfig.chartData.datasets.forEach((item: IBaseDataset) => {\n      item.data.forEach((value: number | number[]) => {\n        if (Array.isArray(value)) {\n          if (value[0] !== 0 || value[1] !== 0)\n            this.isChartDataAvailable = true;\n        } else {\n          if (value !== 0) this.isChartDataAvailable = true;\n        }\n      });\n    });\n  }\n\n  @Output() hoveredIndex: EventEmitter<number | null> = new EventEmitter();\n\n  private chart!: Chart;\n  private chartContext!: CanvasRenderingContext2D;\n  private subscription!: Subscription;\n  private plugins?: Plugin<ChartType, AnyObject>[];\n  private areAnimationsCompleated: boolean = false;\n  private _hoveredIndex: number | null = null;\n\n  public _chartConfig!: IChartConfiguration;\n  public isChartDataAvailable: boolean = false;\n\n  constructor(\n    private changeDetector: ChangeDetectorRef,\n    @Optional() private chartManagerService?: ChartManagerService\n  ) { }\n\n  ngAfterViewInit(): void {\n    if (this.isChartDataAvailable) {\n      this.initializeAnnotationPlugin();\n      this.createChart();\n    }\n  }\n\n  ngOnInit(): void {\n    this.initializeChartManagerService();\n  }\n\n  private initializeChartManagerService(): void {\n    if (!this.chartManagerService) return;\n\n    this.subscription = this.chartManagerService.hoverState$.subscribe(\n      ({ index, chartId }) => {\n        if (chartId !== this.chartId) {\n          this._hoveredIndex = index;\n          if (this.chart) this.chart.draw();\n        }\n      }\n    );\n\n  }\n\n  private initializeAnnotationPlugin(): void {\n    Chart.register(annotationPlugin);\n  }\n\n  public updateDatasetBackgroundOnHover(\n    chartDatasetHover: IChartDatasetHover\n  ): void {\n    if (!this.chart || !this.chart.data.datasets) return;\n\n    if (chartDatasetHover.isHoverd) {\n      const gradient = ChartHelper.createGradient(\n        this.chartContext,\n        this.chartCanvas,\n        chartDatasetHover.color,\n        chartDatasetHover.color,\n        0.6,\n        0.1,\n        true\n      );\n      this.chart.data.datasets = this.chart.data.datasets.map((dataset) => {\n        if (dataset.hidden) return dataset;\n\n        if (\n          dataset.label?.toUpperCase() === chartDatasetHover.label.toUpperCase()\n        ) {\n          const hoverdDataSet = {\n            ...dataset,\n            fill: true,\n            backgroundColor: gradient,\n            borderColor: chartDatasetHover.color,\n            order: 1,\n          };\n          return hoverdDataSet;\n        } else {\n          const borderColorWithOpacity = ChartHelper.changeOpacityOfRgbOrRgba(\n            dataset.borderColor as string,\n            0.2\n          );\n          return {\n            ...dataset,\n            fill: false,\n            borderColor: borderColorWithOpacity,\n          };\n        }\n      });\n    } else {\n      this.chart.data.datasets = this.chart.data.datasets.map((dataset) => {\n        if (!dataset.hidden) {\n          const originalColor = dataset.borderColor\n            ? ChartHelper.changeOpacityOfRgbOrRgba(\n              dataset.borderColor as string,\n              1\n            )\n            : ChartConstants.STRING_EMPTY;\n\n          return {\n            ...dataset,\n            fill: false,\n            borderColor: originalColor,\n            backgroundColor: ChartConstants.STRING_EMPTY,\n          };\n        } else return dataset;\n      });\n    }\n\n    this.chart.update();\n  }\n\n  private createChart(): void {\n    this.chartContext = this.chartCanvas?.\n      nativeElement?.\n      getContext('2d');\n\n    this.setChartOptionsProperties();\n    this.setChartDataProperties();\n    this.setChartPluginsProperties();\n\n    if (this.chart) this.chart.destroy();\n\n    this.initializeAnnotationPlugin();\n    if (this._chartConfig.chartType === ChartTypesStringEnum.DOUGHNUT)\n      Chart.overrides.doughnut.cutout = '80%';\n    this.chart = new Chart(this.chartContext, {\n      type: this._chartConfig.chartType,\n      data: this._chartConfig.chartData,\n      options: this._chartConfig.chartOptions,\n      plugins: this.plugins,\n    });\n\n    if (!this._chartConfig.isDashboardChart) {\n      this.chart.config.data.datasets = [\n        ...this._chartConfig?.\n          chartData?.\n          datasets?.\n          map((item: IBaseDataset, indx: number) => {\n            const pointConfig = {\n              pointBackgroundColor: ChartColorsStringEnum.WHITE,\n              pointBorderWidth: 2,\n              pointRadius: 3,\n            };\n\n            this.updateChartAnnotations(item, indx);\n\n            const yScale = this.chart.scales[EChartEventProperties.Y_AXIS_0] as\n              | CategoryScale\n              | LinearScale;\n\n            const datasetConfig = {\n              ...item,\n              pointBorderColor: item.color,\n              ...pointConfig,\n              backgroundColor:\n                item?.color &&\n                  item?.color2 &&\n                  item?.color !== item?.color2 ?\n                  ChartHelper.createGradient(\n                    this.chartContext,\n                    this.chartCanvas,\n                    item?.color,\n                    item?.color2 ,\n                  ) : item?.color,\n              fill: item?.fill\n            }\n\n            if (this._chartConfig.chartType === ChartTypesStringEnum.DOUGHNUT) {\n              return {\n                ...datasetConfig,\n                backgroundColor: item.backgroundColor\n              }\n            }\n\n            if (!item.shiftValue) {\n              return {\n                ...datasetConfig,\n                backgroundColor:\n                  item?.color &&\n                    item?.color2 &&\n                    item?.color !== item?.color2 ?\n                    ChartHelper.createGradient(\n                      this.chartContext,\n                      this.chartCanvas,\n                      item?.color,\n                      item?.color2 ,\n                    ) : item?.color,\n              }\n            }\n\n            const shiftValuePx: number = yScale.getPixelForValue(item.shiftValue || 0);\n            const shiftValueAdjusted: number =\n              shiftValuePx / yScale.maxHeight;\n\n            const borderColor: CanvasGradient = ChartHelper.createGradientWithShiftValue(\n              this.chartContext,\n              yScale.maxHeight,\n              item.color || ChartConstants.STRING_EMPTY,\n              item.color2 || ChartConstants.STRING_EMPTY,\n              shiftValueAdjusted,\n            );\n\n            return {\n              ...item,\n              ...pointConfig,\n              pointBorderColor: borderColor,\n              backgroundColor: ChartHelper.createGradientWithShiftValue(\n                this.chartContext,\n                yScale.maxHeight,\n                item.color || ChartConstants.STRING_EMPTY,\n                item.color2 || ChartConstants.STRING_EMPTY,\n                shiftValueAdjusted,\n                true\n              ),\n              borderColor,\n              fill: true\n            }\n          })\n      ];\n    }\n    this.chart.update();\n  }\n\n  private updateChart(): void {\n    if (this.chart)\n      this.chart?.destroy();\n    this.createChart();\n  }\n\n  private setChartOptionsProperties(): void {\n    const labels = this._chartConfig.chartData.labels;\n\n    this._chartConfig.chartOptions = {\n      responsive: true,\n      maintainAspectRatio: false,\n      clip: false,\n      animation: {\n        onComplete: () => {\n          this.areAnimationsCompleated = true;\n          this.chart.draw();\n        },\n        onProgress: () => {\n          this.areAnimationsCompleated = false;\n          this.chart.draw();\n        },\n      },\n      layout: {\n        padding: {\n          top: 0,\n          bottom: 0,\n          left:\n            this._chartConfig.chartType === ChartTypesStringEnum.BAR &&\n              this._chartConfig.verticalyAlignBarChartWithLineCart\n              ? 6\n              : 0,\n          right:\n            this._chartConfig.chartType === ChartTypesStringEnum.BAR &&\n              this._chartConfig.verticalyAlignBarChartWithLineCart\n              ? 6\n              : 0,\n        },\n      },\n      plugins: {\n        legend: {\n          display: false,\n        },\n        tooltip: {\n          enabled: false,\n        },\n      },\n      scales: {\n        x: {\n          title: {\n            display: true,\n          },\n          position: 'bottom',\n          grid: {\n            display: false,\n          },\n          ticks: {\n            display: true,\n            padding: 0,\n            color: ChartColorsStringEnum.X_AXIS_LABEL_COLOR,\n            font: {\n              size: 11,\n              family: ChartFontPropertiesStringEnum.FONT_FAMILY_MONTSERRAT,\n              weight: ChartFontPropertiesStringEnum.FONT_WEIGHT_BOLDER,\n            },\n            autoSkip: true,\n            autoSkipPadding: 12,\n            maxRotation: 0,\n            minRotation: 0,\n            //Label written in 2 lines, will be ujusted with new design\n            callback: function (\n              value: string | number,\n              index: number\n            ): string | string[] {\n              const label = labels[index];\n              const multiLineLabel = label ? label.split(' ') : [];\n              return multiLineLabel;\n            },\n          },\n          display: this._chartConfig.showXAxisLabels,\n          beginAtZero: true,\n          offset: true,\n        },\n        y: {\n          display: false,\n          beginAtZero: true,\n          min: 0,\n          max: 1,\n          offset: false,\n        },\n      },\n      onHover: (event: ChartEvent, item: ActiveElement[]) => {\n        if (this._chartConfig.hasVerticalDashedAnnotation)\n          this.resetAnnotations();\n\n        if (this._chartConfig.chartType === ChartTypesStringEnum.DOUGHNUT) {\n          const colors: string[] =\n            this.chart.data.datasets[0].backgroundColor as string[];\n\n          this.chart.data.datasets[0].backgroundColor =\n            colors.map((color: string) => {\n              return ChartHelper.convertRgbToRgba(color);\n            });\n          this.chart.update();\n        }\n\n        if (\n          !item ||\n          !item?.length\n        ) {\n          this.hoveredIndex.emit(null);\n          return;\n        }\n\n        this.hoveredIndex.emit(item[0].index);\n\n        if (this._chartConfig.chartType === ChartTypesStringEnum.DOUGHNUT) {\n          const colors: string[] = this.chart.data.datasets[0].backgroundColor as string[];\n          const updatedColors: string[] = colors.map((color: string, indx: number) => {\n            if (indx === item[0].index) return color;\n\n            const convertedValue = ChartHelper.convertRgbToRgba(color, 0.2);\n\n            return convertedValue;\n\n          });\n\n          this.chart.data.datasets[0].backgroundColor = updatedColors;\n        }\n\n        if (this._chartConfig.hasVerticalDashedAnnotation)\n          this.setVerticalDashedAnnotationLine(item[0].element.x);\n\n        this.chart.update();\n      },\n    };\n  }\n\n  private setChartDataProperties(): void {\n    if ((this._chartConfig.chartType === ChartTypesStringEnum.LINE)) {\n      this._chartConfig.chartData.datasets.forEach((dataset) => {\n        dataset.order = dataset.order;\n        if (ChartTypeGuard.isLineDataset(dataset)) {\n          dataset.tension = dataset.tension ?? 0.5;\n          dataset.cubicInterpolationMode =\n            dataset.cubicInterpolationMode ??\n            CubicInterpolationStringEnum.MONOTONE;\n          dataset.pointBorderColor =\n            dataset.pointBorderColor ?? ChartColorsStringEnum.TRANSPARENT;\n          dataset.pointBackgroundColor =\n            dataset.pointBackgroundColor ?? ChartColorsStringEnum.TRANSPARENT;\n          dataset.pointBorderWidth = dataset.pointBorderWidth ?? 2;\n          dataset.spanGaps = dataset.spanGaps ?? false;\n          dataset.showLine = dataset.showLine ?? true;\n        }\n      });\n      this.setMultipleYAxis(this._chartConfig.chartData);\n    }\n  }\n\n  private setChartPluginsProperties(): void {\n    let hoveredIndex: number | null = null;\n\n    this.plugins = [\n      {\n        id: ChartPluginIdsStringEnum.HIGHLIGHT_SEGMENT_ON_HOVER,\n        afterEvent: (chart, event) => {\n          if (!this._chartConfig.showTooltipBackground) return;\n\n          const nativeEvent = event.event.native as MouseEvent;\n\n          if (event.event.type === ChartEventTypesStringEnum.MOUSE_OUT) {\n            const boundingRect = this.chart.canvas.getBoundingClientRect();\n            const isMouseOutsideChart =\n              nativeEvent.clientX < boundingRect.left ||\n              nativeEvent.clientX > boundingRect.right ||\n              nativeEvent.clientY < boundingRect.top ||\n              nativeEvent.clientY > boundingRect.bottom;\n\n            if (isMouseOutsideChart) {\n              this._hoveredIndex = null;\n              this.chartManagerService?.setHoverState(null, this.chartId);\n              this.chart.draw();\n            }\n            return;\n          }\n\n          const boundingRect = this.chart.canvas.getBoundingClientRect();\n          const mouseHorizontalCoordinate =\n            nativeEvent.clientX - boundingRect.left;\n\n          const { left, right } = this.chart.chartArea;\n\n          if (\n            mouseHorizontalCoordinate < left ||\n            mouseHorizontalCoordinate > right\n          ) {\n            this._hoveredIndex = null;\n            this.chartManagerService?.setHoverState(null, this.chartId);\n            this.chart.draw();\n            return;\n          }\n\n          const xScale = this.chart.scales[EChartEventProperties.X] as\n            | CategoryScale\n            | LinearScale;\n\n          const tickPositions = xScale.ticks.map((tick) =>\n            xScale.getPixelForValue(tick.value)\n          );\n\n          const segmentBoundaries = tickPositions.map((tickPos, index) => {\n            const leftBoundary =\n              index === 0 ? left : (tickPos + tickPositions[index - 1]) / 2;\n            const rightBoundary =\n              index === tickPositions.length - 1\n                ? right\n                : (tickPos + tickPositions[index + 1]) / 2;\n\n            return { leftBoundary, rightBoundary };\n          });\n\n          const newHoveredIndex = segmentBoundaries.findIndex(\n            (boundary) =>\n              mouseHorizontalCoordinate >= boundary.leftBoundary &&\n              mouseHorizontalCoordinate < boundary.rightBoundary\n          );\n\n          if (newHoveredIndex !== this._hoveredIndex) {\n            this._hoveredIndex = newHoveredIndex === -1 ? null : newHoveredIndex;\n            this.chartManagerService?.setHoverState(\n              this._hoveredIndex,\n              this.chartId\n            );\n            this.chart.draw();\n          }\n        },\n\n        beforeDraw: () => {\n          if (this._hoveredIndex !== null) {\n            const {\n              chartArea,\n              scales: { x: xScale },\n            } = this.chart;\n\n            ChartHelper.highlightSegment(\n              this.chartContext,\n              xScale as CategoryScale | LinearScale,\n              chartArea,\n              this._chartConfig.height,\n              this._hoveredIndex\n            );\n          }\n        },\n      },\n      {\n        id: ChartPluginIdsStringEnum.HIGHLIGHT_POINT_ON_HOVER,\n        afterDraw: () => {\n          if (\n            this._hoveredIndex !== null &&\n            this._chartConfig.showHighlightPointOnHover &&\n            this.areAnimationsCompleated\n          ) {\n            const visibleDatasets = this._chartConfig.chartData.datasets.filter(\n              (dataset) => !dataset.hidden\n            );\n            ChartHelper.highlightPoint(\n              this.chartContext,\n              this.chart,\n              this._hoveredIndex,\n              { ...this._chartConfig.chartData, datasets: visibleDatasets }\n            );\n          }\n        },\n      },\n      {\n        id: ChartPluginIdsStringEnum.BORDER_BOTTOM_LINE_CHART,\n        beforeDraw: () => {\n          if (this._chartConfig?.showBottomLineOnLineChart) {\n            const {\n              ctx,\n              data,\n              chartArea,\n              scales: { x: xScale },\n            } = this.chart;\n            const dataset = data.datasets[0];\n\n            const firstIndex = 0;\n            const lastIndex = dataset.data.length - 1;\n\n            const firstValue = dataset.data[firstIndex];\n            const lastValue = dataset.data[lastIndex];\n\n            if (firstValue !== undefined && lastValue !== undefined) {\n              const xStart = xScale.getPixelForValue(firstIndex);\n\n              const xEnd = xScale.getPixelForValue(lastIndex);\n              const yBottom = chartArea.bottom;\n\n              ctx.save();\n              ctx.strokeStyle =\n                ChartColorsStringEnum.BORDER_BOTTOM_LINE_CHART_COLOR;\n              ctx.lineWidth = 1;\n              ctx.beginPath();\n              ctx.moveTo(xStart, yBottom);\n              ctx.lineTo(xEnd, yBottom);\n              ctx.stroke();\n              ctx.restore();\n            }\n          }\n        },\n      },\n    ];\n\n    if (this._chartConfig.chartType === ChartTypesStringEnum.DOUGHNUT)\n      this.plugins = [\n        ...this.plugins,\n        {\n          id: 'doughnut-label',\n          beforeDatasetDraw: (chart: Chart) => {\n            this._chartConfig.centerLabels?.map(\n              (label: IChartCenterLabel, indx: number) => {\n                ChartHelper.drawDoughnutLegend(\n                  chart,\n                  {\n                    indx,\n                    offsetTop: label.position?.top || 0\n                  },\n                  label.value,\n                  label.fontSize,\n                  label.color)\n              });\n          },\n        }\n      ];\n  }\n\n  private updateChartAnnotations(item: IBaseDataset, indx: number): void {\n    if (!this._chartConfig.annotations?.length) return;\n\n    this._chartConfig.\n      annotations?.\n      forEach((annotation: IChartAnnotation, key: number) => {\n        this._chartConfig.chartOptions.plugins = {\n          ...this._chartConfig.chartOptions.plugins,\n          annotation: {\n            ...this._chartConfig.chartOptions?.plugins?.annotation,\n            annotations: {\n              ...this._chartConfig.\n                chartOptions?.\n                plugins?.\n                annotation?.\n                annotations,\n              [`${item.label}-${indx}-${key}`]: {\n                id: annotation.id || `annotation-${indx}-${key}`,\n                type: annotation.type,\n                scaleID: annotation.axis || item.yAxisID,\n                value: annotation.value || item.shiftValue,\n                borderColor: annotation.color || '#DADADA',\n                borderWidth: annotation.borderWidth || 2,\n                borderDash: annotation.borderDash || [0, 0],\n              },\n            },\n          },\n        };\n      });\n    this.chart.update();\n\n  }\n\n  private setMultipleYAxis(chartData: IChartData<ILineDataset>): void {\n    let absoluteMax: number;\n    chartData.datasets.forEach((dataset, index) => {\n      if (\n        dataset.type === ChartTypesStringEnum.LINE ||\n        dataset.type === ChartTypesStringEnum.BAR\n      ) {\n        const yAxisID = this._chartConfig.isMultiYAxis\n          ? `y-axis-${index}`\n          : dataset.yAxisID || 'y-axis-0';\n\n        // Detect if the dataset is all 0\n        const isAllZeroDataset = (dataset.data as number[]).every(\n          (val: number) => val === 0\n        );\n\n        let minValue = ChartHelper.calculateMinValue(dataset.data as number[]);\n        let maxValue = ChartHelper.calculateMaxValue(dataset.data as number[]);\n        const padding = maxValue * 0.03;\n\n        // Adjust scaling for all 0 datasets\n        if (isAllZeroDataset) {\n          minValue = 0;\n          maxValue = 1;\n        } else {\n          minValue = maxValue === minValue ? minValue - 0.1 : minValue;\n          maxValue =\n            maxValue === minValue ? maxValue + 0.1 : maxValue + padding;\n        }\n\n        this._chartConfig.chartOptions.scales = {\n          ...this._chartConfig.chartOptions.scales,\n          [yAxisID]: {\n            display: false,\n            beginAtZero: true,\n            min: minValue,\n            max: maxValue,\n            stacked: this._chartConfig.isStacked,\n          },\n        };\n\n        chartData.datasets[index] = {\n          ...dataset,\n          yAxisID,\n        };\n      }\n    });\n  }\n\n  private resetAnnotations(): void {\n    this._chartConfig.chartOptions.plugins =\n    {\n      ...this._chartConfig.chartOptions.plugins,\n      annotation: {}\n    }\n    this.chart.update();\n  }\n\n  private setVerticalDashedAnnotationLine(xCord: number, color?: string): void {\n    const xScale = this.chart.scales[EChartEventProperties.X] as\n      | CategoryScale\n      | LinearScale;\n\n    const valueFromPixel: number | undefined = xScale.getValueForPixel(xCord);\n\n    if (valueFromPixel === undefined) return;\n\n    this._chartConfig.chartOptions.plugins = {\n      ...this._chartConfig.chartOptions.plugins,\n      annotation: {\n        ...this._chartConfig.chartOptions?.plugins?.annotation,\n        annotations: {\n          ...this._chartConfig.\n            chartOptions?.\n            plugins?.\n            annotation?.\n            annotations,\n          [`x-dashed`]: {\n            id: `x-dashed`,\n            type: EChartAnnotationType.LINE,\n            scaleID: EChartEventProperties.X,\n            value: valueFromPixel,\n            borderColor: color || '#DADADA',\n            borderWidth: 2,\n            borderDash: [5, 5],\n          },\n        },\n      },\n    };\n  }\n\n  ngOnDestroy(): void {\n    this.subscription?.unsubscribe();\n  }\n}\n","<ng-container *ngIf=\"isChartDataAvailable; else noDataTemplate\">\n  <div\n    [ngStyle]=\"{\n      height: _chartConfig.height + 'px',\n      width: _chartConfig.width + '%',\n    }\"\n  >\n    <canvas #chartCanvas></canvas>\n  </div>\n</ng-container>\n<ng-template #noDataTemplate>\n  <div\n    class=\"d-flex justify-content-center align-items-center\"\n    [ngStyle]=\"{\n      height: _chartConfig.height + 'px',\n      width: _chartConfig.width + '%',\n    }\"\n  >\n    <svg-icon\n      [src]=\"_chartConfig.noDataImage\"\n      alt=\"No data available\"\n      class=\"no-data-svg\"\n    ></svg-icon>\n  </div>\n</ng-template>\n"]}
665
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-chart.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-chart/ca-chart.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-chart/ca-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  Output,\n  Optional,\n  ViewChild,\n  EventEmitter,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { AnyObject } from 'chart.js/dist/types/basic';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { Subject, takeUntil } from 'rxjs';\n\n// Charts\nimport {\n  CategoryScale,\n  Chart,\n  ChartEvent,\n  LinearScale,\n  Plugin,\n} from 'chart.js/auto';\nimport annotationPlugin from 'chartjs-plugin-annotation';\nimport { ChartType } from 'chart.js';\n\n// Enums\nimport {\n  ChartColorsStringEnum,\n  EChartEventProperties,\n  ChartPluginIdsStringEnum,\n  ChartTypesStringEnum,\n  CubicInterpolationStringEnum,\n  ChartEventTypesStringEnum,\n  ChartFontPropertiesStringEnum,\n  EChartAnnotationType,\n  EChartAnnotation,\n} from './enums';\n\n// Helpers\nimport { ChartHelper } from './utils/helpers';\n\n// Guards\nimport { ChartTypeGuard } from './utils/guards';\n\n//Models\nimport {\n  IChartData,\n  ILineDataset,\n  IChartConfiguration,\n  IBaseDataset,\n  IChartAnnotation,\n  IChartDatasetHover,\n  IChartCenterLabel,\n  IChartLegendConfig\n} from './models';\nimport { ActiveElement } from 'chart.js/dist/plugins/plugin.tooltip';\n\n//Services\nimport { ChartManagerService } from '../ca-chart-manager/services';\n\n// Constants\nimport { ChartConstants } from './utils/constants';\nimport { _DeepPartialArray, _DeepPartialObject } from 'chart.js/dist/types/utils';\n\n// Pipes\nimport {\n  ThousandSeparatorPipe,\n  UnitPositionPipe\n} from '../../pipes';\n\n@Component({\n  selector: 'app-ca-chart',\n  templateUrl: './ca-chart.component.html',\n  styleUrls: ['./ca-chart.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    AngularSvgIconModule,\n    UnitPositionPipe,\n    ThousandSeparatorPipe,\n  ],\n})\nexport class CaChartComponent implements AfterViewInit {\n  @ViewChild('chartCanvas', { static: false }) chartCanvas!: ElementRef;\n\n  @Input() legendData!: IChartLegendConfig;\n  @Input() chartId!: string;\n  @Input()\n  set chartDatasetHover(value: IChartDatasetHover | null) {\n    if (value) this.updateDatasetBackgroundOnHover(value);\n  }\n  @Input() set chartConfig(value: IChartConfiguration) {\n    this._chartConfig = value;\n    this.isChartDataAvailable = false;\n    this._chartConfig?.\n      chartData?.\n      datasets?.\n      forEach((item: IBaseDataset) => {\n        item.data.forEach((value: number | number[]) => {\n          if (Array.isArray(value)) {\n            if (value[0] !== 0 || value[1] !== 0)\n              this.isChartDataAvailable = true;\n          }\n          else\n            if (value !== 0)\n              this.isChartDataAvailable = true;\n        })\n      });\n    this.changeDetector.detectChanges();\n\n    if (this.isChartDataAvailable)\n      this.updateChart();\n\n    this._chartConfig.chartData.datasets.forEach((item: IBaseDataset) => {\n      item.data.forEach((value: number | number[]) => {\n        if (Array.isArray(value)) {\n          if (value[0] !== 0 || value[1] !== 0)\n            this.isChartDataAvailable = true;\n        } else {\n          if (value !== 0) this.isChartDataAvailable = true;\n        }\n      });\n    });\n  }\n  @Input() set selectedIndex(value: number) {\n    if (!this.chart || !this.isChartDataAvailable) return;\n\n    if (value !== null) this.focusDoughnutArc(value);\n    else this.setOriginalDoughnutArcsColor();\n\n    this.chart.update();\n  }\n\n  @Output() hoveredIndex: EventEmitter<number | null> = new EventEmitter();\n\n  private destroy$ = new Subject<void>();\n\n  private chart!: Chart;\n  private chartContext!: CanvasRenderingContext2D;\n  private plugins?: Plugin<ChartType, AnyObject>[];\n  private areAnimationsCompleated: boolean = false;\n  private _hoveredIndex: number | null = null;\n\n  public _chartConfig!: IChartConfiguration;\n  public isChartDataAvailable: boolean = false;\n\n  constructor(\n    private changeDetector: ChangeDetectorRef,\n    @Optional() private chartManagerService?: ChartManagerService\n  ) { }\n\n  ngAfterViewInit(): void {\n    if (this.isChartDataAvailable) {\n      this.initializeAnnotationPlugin();\n      this.createChart();\n    }\n  }\n\n  ngOnInit(): void {\n    this.initializeChartManagerService();\n  }\n\n  private initializeChartManagerService(): void {\n    if (!this.chartManagerService) return;\n\n    this.chartManagerService.\n      hoverState$.\n      pipe(takeUntil(this.destroy$))\n      .subscribe(\n        ({ index, chartId }) => {\n          if (chartId !== this.chartId) {\n            this._hoveredIndex = index;\n            if (this.chart) this.chart.draw();\n          }\n        }\n      );\n  }\n\n  private initializeAnnotationPlugin(): void {\n    Chart.register(annotationPlugin);\n  }\n\n  public updateDatasetBackgroundOnHover(\n    chartDatasetHover: IChartDatasetHover\n  ): void {\n    if (!this.chart || !this.chart.data.datasets) return;\n\n    if (chartDatasetHover.isHoverd) {\n      const gradient = ChartHelper.createGradient(\n        this.chartContext,\n        this.chartCanvas,\n        chartDatasetHover.color,\n        chartDatasetHover.color,\n        0.6,\n        0.1,\n        true\n      );\n      this.chart.data.datasets =\n        this.chart?.\n          data?.\n          datasets?.\n          map((dataset) => {\n            if (dataset.hidden) return dataset;\n\n            if (\n              dataset?.label?.toUpperCase() ===\n              chartDatasetHover?.label?.toUpperCase()\n            ) {\n              const hoverdDataSet = {\n                ...dataset,\n                fill: true,\n                backgroundColor: gradient,\n                borderColor: chartDatasetHover.color,\n                order: 1,\n              };\n              return hoverdDataSet;\n            } else {\n              const borderColorWithOpacity = ChartHelper.changeOpacityOfRgbOrRgba(\n                dataset.borderColor as string,\n                0.2\n              );\n              return {\n                ...dataset,\n                fill: false,\n                borderColor: borderColorWithOpacity,\n              };\n            }\n          });\n    } else {\n      this.chart.data.datasets =\n        this.chart\n          .data\n          .datasets\n          .map((dataset) => {\n            if (!dataset.hidden) {\n              const originalColor = dataset.borderColor\n                ? ChartHelper.changeOpacityOfRgbOrRgba(\n                  dataset.borderColor as string,\n                  1\n                )\n                : ChartConstants.STRING_EMPTY;\n\n              return {\n                ...dataset,\n                fill: false,\n                borderColor: originalColor,\n                backgroundColor: ChartConstants.STRING_EMPTY,\n              };\n            } else return dataset;\n          });\n    }\n\n    this.chart.update();\n  }\n\n  private createChart(): void {\n    this.chartContext = this.chartCanvas?.\n      nativeElement?.\n      getContext('2d');\n\n    this.setChartOptionsProperties();\n    this.setChartDataProperties();\n    this.setChartPluginsProperties();\n\n    if (this.chart) this.chart.destroy();\n\n    this.initializeAnnotationPlugin();\n    if (this._chartConfig.chartType === ChartTypesStringEnum.DOUGHNUT)\n      Chart.overrides.doughnut.cutout = '88%';\n\n    this.chart = new Chart(this.chartContext, {\n      type: this._chartConfig.chartType,\n      data: this._chartConfig.chartData,\n      options: this._chartConfig.chartOptions,\n      plugins: this.plugins,\n    });\n\n    if (!this._chartConfig.isDashboardChart)\n      this.chart.config.data.datasets = [\n        ...this._chartConfig?.\n          chartData?.\n          datasets?.\n          map((item: IBaseDataset, indx: number) => {\n            const pointConfig = {\n              pointBackgroundColor: ChartColorsStringEnum.WHITE,\n              pointBorderWidth: 2,\n              pointRadius: 3,\n            };\n\n            this.updateChartAnnotations(item, indx);\n\n            const yScale = this.chart.scales[EChartEventProperties.Y_AXIS_0] as\n              | CategoryScale\n              | LinearScale;\n\n            const backgroundColor =\n              (item?.color &&\n                item?.color2) ?\n                ChartHelper.createGradient(\n                  this.chartContext,\n                  this.chartCanvas,\n                  item?.color,\n                  item?.color2,\n                ) : item?.color;\n\n            const datasetConfig = {\n              ...item,\n              pointBorderColor: item.color,\n              ...pointConfig,\n              backgroundColor,\n              fill: item?.fill\n            }\n\n            if (this._chartConfig.chartType === ChartTypesStringEnum.DOUGHNUT)\n              return {\n                ...datasetConfig,\n                backgroundColor: item.backgroundColor\n              }\n\n            if (!item.shiftValue)\n              return {\n                ...datasetConfig,\n                backgroundColor:\n                  item?.color &&\n                    item?.color2 &&\n                    item?.color !== item?.color2 ?\n                    ChartHelper.createGradient(\n                      this.chartContext,\n                      this.chartCanvas,\n                      item?.color,\n                      item?.color2 ,\n                    ) : item?.color,\n              }\n\n            const shiftValuePx: number = yScale.getPixelForValue(item.shiftValue || 0);\n            const shiftValueAdjusted: number =\n              shiftValuePx / yScale.maxHeight;\n\n            const color1: string = item.color || ChartConstants.STRING_EMPTY;\n            const color2: string = item.color2 || ChartConstants.STRING_EMPTY;\n\n            const borderColor: CanvasGradient = ChartHelper.createGradientWithShiftValue(\n              this.chartContext,\n              yScale.maxHeight,\n              color1,\n              color2,\n              shiftValueAdjusted,\n            );\n\n            return {\n              ...item,\n              ...pointConfig,\n              pointBorderColor: borderColor,\n              backgroundColor: ChartHelper.createGradientWithShiftValue(\n                this.chartContext,\n                yScale.maxHeight,\n                color1,\n                color2,\n                shiftValueAdjusted,\n                true\n              ),\n              borderColor,\n              fill: true\n            }\n          })\n      ];\n\n    this.chart.update();\n  }\n\n  private updateChart(): void {\n    if (this.chart)\n      this.chart.update();\n    this.createChart();\n  }\n\n  private setChartOptionsProperties(): void {\n    const labels = this._chartConfig.chartData.labels;\n\n    this._chartConfig.chartOptions = {\n      responsive: true,\n      maintainAspectRatio: false,\n      clip: false,\n      animation: {\n        onComplete: () => {\n          this.areAnimationsCompleated = true;\n          this.chart.draw();\n        },\n        onProgress: () => {\n          this.areAnimationsCompleated = false;\n          this.chart.draw();\n        },\n      },\n      layout: {\n        padding: {\n          top: this._chartConfig.chartType ===\n            ChartTypesStringEnum.DOUGHNUT ?\n            8 :\n            0,\n          bottom: this._chartConfig.chartType ===\n            ChartTypesStringEnum.DOUGHNUT ?\n            8 :\n            0,\n          left:\n            this._chartConfig.chartType === ChartTypesStringEnum.BAR &&\n              this._chartConfig.verticalyAlignBarChartWithLineCart\n              ? 6\n              : 0,\n          right:\n            this._chartConfig.chartType === ChartTypesStringEnum.BAR &&\n              this._chartConfig.verticalyAlignBarChartWithLineCart\n              ? 6\n              : 0,\n        },\n      },\n      plugins: {\n        legend: {\n          display: false,\n        },\n        tooltip: {\n          enabled: false,\n        },\n      },\n      scales: {\n        x: {\n          title: {\n            display: true,\n          },\n          position: 'bottom',\n          grid: {\n            display: false,\n          },\n          ticks: {\n            display: true,\n            padding: 0,\n            color: ChartColorsStringEnum.X_AXIS_LABEL_COLOR,\n            font: {\n              size: 11,\n              family: ChartFontPropertiesStringEnum.FONT_FAMILY_MONTSERRAT,\n              weight: ChartFontPropertiesStringEnum.FONT_WEIGHT_BOLDER,\n            },\n            autoSkip: true,\n            autoSkipPadding: 12,\n            maxRotation: 0,\n            minRotation: 0,\n            //Label written in 2 lines, will be adjusted with new design\n            callback: function (\n              value: string | number,\n              index: number\n            ): string | string[] {\n              const label = labels[index];\n              const multiLineLabel = label ? label.split(' ') : [];\n              return multiLineLabel;\n            },\n          },\n          display: this._chartConfig.showXAxisLabels,\n          beginAtZero: true,\n          offset: true,\n        },\n        y: {\n          display: false,\n          beginAtZero: true,\n          min: 0,\n          max: 1,\n          offset: false,\n        },\n      },\n      onHover: (event: ChartEvent, item: ActiveElement[]) => {\n\n        if (this._chartConfig.hasVerticalDashedAnnotation) {\n          this.removeVerticalDashedLine();\n          this.setVerticalDashedAnnotationLine(event);\n        }\n\n        this.setOriginalDoughnutArcsColor();\n\n        if (this._chartConfig.chartType === ChartTypesStringEnum.DOUGHNUT) {\n          this.hoveredIndex.emit(item[0]?.index || null);\n\n          item[0]?.index >= 0 ?\n            this.focusDoughnutArc(item[0]?.index) :\n            this.setOriginalDoughnutArcsColor();\n        };\n        this.chart.update();\n      },\n    };\n  }\n\n  private focusDoughnutArc(index: number | null): void {\n    if (this._chartConfig.chartType !== ChartTypesStringEnum.DOUGHNUT ||\n      index === this.chart.data.datasets[0].data.length - 1) return;\n    const colors: string[] = this.chart?.\n      data?.\n      datasets[0]?.backgroundColor as string[];\n    const updatedColors: string[] = colors.map(\n      (color: string, indx: number) => {\n        if (indx === index) return color;\n        const convertedValue = ChartHelper.convertRgbToRgba(color, 0.2);\n        return convertedValue;\n      });\n\n    this.chart.data.datasets[0].backgroundColor = updatedColors;\n  }\n\n  private setOriginalDoughnutArcsColor(): void {\n    if (this._chartConfig.chartType !== ChartTypesStringEnum.DOUGHNUT) return;\n\n    const colors: string[] =\n      this.chart.data.datasets[0].backgroundColor as string[];\n\n    this.chart.data.datasets[0].backgroundColor =\n      [...colors.map((color: string) => {\n        return ChartHelper.rgbToRgba(color, 1);\n      })];\n\n    this.chart.update();\n\n  }\n  private setChartDataProperties(): void {\n    if ((this._chartConfig.chartType === ChartTypesStringEnum.LINE)) {\n      this._chartConfig.chartData.datasets.forEach((dataset) => {\n        dataset.order = dataset.order;\n        if (ChartTypeGuard.isLineDataset(dataset)) {\n          dataset.tension = dataset.tension ?? 0.5;\n          dataset.cubicInterpolationMode =\n            dataset.cubicInterpolationMode ??\n            CubicInterpolationStringEnum.MONOTONE;\n          dataset.pointBorderColor =\n            dataset.pointBorderColor ?? ChartColorsStringEnum.TRANSPARENT;\n          dataset.pointBackgroundColor =\n            dataset.pointBackgroundColor ?? ChartColorsStringEnum.TRANSPARENT;\n          dataset.pointBorderWidth = dataset.pointBorderWidth ?? 2;\n          dataset.spanGaps = dataset.spanGaps ?? false;\n          dataset.showLine = dataset.showLine ?? true;\n        }\n      });\n      this.setMultipleYAxis(this._chartConfig.chartData);\n    }\n  }\n\n  private setChartPluginsProperties(): void {\n    this.plugins = [\n      {\n        id: ChartPluginIdsStringEnum.HIGHLIGHT_SEGMENT_ON_HOVER,\n        afterEvent: (chart, event) => {\n\n          const nativeEvent = event.event.native as MouseEvent;\n\n          if (event.event.type === ChartEventTypesStringEnum.MOUSE_OUT) {\n            const boundingRect = this.chart.canvas.getBoundingClientRect();\n            const isMouseOutsideChart =\n              nativeEvent.clientX < boundingRect.left ||\n              nativeEvent.clientX > boundingRect.right ||\n              nativeEvent.clientY < boundingRect.top ||\n              nativeEvent.clientY > boundingRect.bottom;\n\n            if (isMouseOutsideChart) {\n              this._hoveredIndex = null;\n              this.chartManagerService?.setHoverState(null, this.chartId);\n              this.removeVerticalDashedLineAndFocus();\n              this.chart.draw();\n            }\n            return;\n          }\n\n          if (!this._chartConfig.showTooltipBackground) return;\n\n          const boundingRect = this.chart.canvas.getBoundingClientRect();\n          const mouseHorizontalCoordinate =\n            nativeEvent.clientX - boundingRect.left;\n\n          const { left, right } = this.chart.chartArea;\n\n          if (\n            mouseHorizontalCoordinate < left ||\n            mouseHorizontalCoordinate > right\n          ) {\n            this._hoveredIndex = null;\n            this.chartManagerService?.setHoverState(null, this.chartId);\n            this.chart.draw();\n            return;\n          }\n\n          const xScale = this.chart.scales[EChartEventProperties.X] as\n            | CategoryScale\n            | LinearScale;\n\n          const tickPositions = xScale.ticks.map((tick) =>\n            xScale.getPixelForValue(tick.value)\n          );\n\n          const segmentBoundaries = tickPositions.map((tickPos, index) => {\n            const leftBoundary =\n              index === 0 ? left : (tickPos + tickPositions[index - 1]) / 2;\n            const rightBoundary =\n              index === tickPositions.length - 1\n                ? right\n                : (tickPos + tickPositions[index + 1]) / 2;\n\n            return { leftBoundary, rightBoundary };\n          });\n\n          const newHoveredIndex = segmentBoundaries.findIndex(\n            (boundary) =>\n              mouseHorizontalCoordinate >= boundary.leftBoundary &&\n              mouseHorizontalCoordinate < boundary.rightBoundary\n          );\n\n          if (newHoveredIndex !== this._hoveredIndex) {\n            this._hoveredIndex = newHoveredIndex === -1 ? null : newHoveredIndex;\n            this.chartManagerService?.setHoverState(\n              this._hoveredIndex,\n              this.chartId\n            );\n            this.chart.draw();\n          }\n        },\n\n        beforeDraw: () => {\n          if (this._hoveredIndex !== null) {\n            const {\n              chartArea,\n              scales: { x: xScale },\n            } = this.chart;\n\n            ChartHelper.highlightSegment(\n              this.chartContext,\n              xScale as CategoryScale | LinearScale,\n              chartArea,\n              this._chartConfig.height,\n              this._hoveredIndex\n            );\n          }\n        },\n      },\n      {\n        id: ChartPluginIdsStringEnum.HIGHLIGHT_POINT_ON_HOVER,\n        afterDraw: () => {\n          if (\n            this._hoveredIndex !== null &&\n            this._chartConfig.showHighlightPointOnHover &&\n            this.areAnimationsCompleated\n          ) {\n            const visibleDatasets = this._chartConfig.chartData.datasets.filter(\n              (dataset) => !dataset.hidden\n            );\n            ChartHelper.highlightPoint(\n              this.chartContext,\n              this.chart,\n              this._hoveredIndex,\n              { ...this._chartConfig.chartData, datasets: visibleDatasets }\n            );\n          }\n        },\n      },\n      {\n        id: ChartPluginIdsStringEnum.BORDER_BOTTOM_LINE_CHART,\n        beforeDraw: () => {\n          if (this._chartConfig?.showBottomLineOnLineChart) {\n            const {\n              ctx,\n              data,\n              chartArea,\n              scales: { x: xScale },\n            } = this.chart;\n            const dataset = data.datasets[0];\n\n            const firstIndex = 0;\n            const lastIndex = dataset.data.length - 1;\n\n            const firstValue = dataset.data[firstIndex];\n            const lastValue = dataset.data[lastIndex];\n\n            if (firstValue !== undefined && lastValue !== undefined) {\n              const xStart = xScale.getPixelForValue(firstIndex);\n\n              const xEnd = xScale.getPixelForValue(lastIndex);\n              const yBottom = chartArea.bottom;\n\n              ctx.save();\n              ctx.strokeStyle =\n                ChartColorsStringEnum.BORDER_BOTTOM_LINE_CHART_COLOR;\n              ctx.lineWidth = 1;\n              ctx.beginPath();\n              ctx.moveTo(xStart, yBottom);\n              ctx.lineTo(xEnd, yBottom);\n              ctx.stroke();\n              ctx.restore();\n            }\n          }\n        },\n      },\n    ];\n\n    if (this._chartConfig.chartType === ChartTypesStringEnum.DOUGHNUT)\n      this.plugins = [\n        ...this.plugins,\n        {\n          id: 'doughnut-label',\n          beforeDatasetDraw: (chart: Chart) => {\n            this._chartConfig.centerLabels?.map(\n              (label: IChartCenterLabel, indx: number) => {\n                ChartHelper.drawDoughnutLegend(\n                  chart,\n                  {\n                    indx,\n                    offsetTop: label.position?.top || 0\n                  },\n                  label.value,\n                  label.fontSize,\n                  label.color)\n              });\n          },\n        }\n      ];\n  }\n\n  private updateChartAnnotations(item: IBaseDataset, indx: number): void {\n    if (!this._chartConfig.annotations?.length) return;\n\n    this._chartConfig.\n      annotations?.\n      forEach((annotation: IChartAnnotation, key: number) => {\n        this._chartConfig.chartOptions.plugins = {\n          ...this._chartConfig.chartOptions.plugins,\n          annotation: {\n            ...this._chartConfig.chartOptions?.plugins?.annotation,\n            annotations: {\n              ...this._chartConfig.\n                chartOptions?.\n                plugins?.\n                annotation?.\n                annotations,\n              [`${item.label}-${indx}-${key}`]: {\n                id: annotation.id || `annotation-${indx}-${key}`,\n                type: annotation.type,\n                scaleID: annotation.axis || item.yAxisID,\n                value: annotation.value || item.shiftValue,\n                borderColor: annotation.color ||\n                  ChartColorsStringEnum.\n                    BORDER_BOTTOM_LINE_CHART_COLOR,\n                borderWidth: annotation.borderWidth || 2,\n                borderDash: annotation.borderDash || [0, 0],\n              },\n            },\n          },\n        };\n      });\n    this.chart.update();\n\n  }\n\n  private setMultipleYAxis(chartData: IChartData<ILineDataset>): void {\n    chartData.datasets.forEach((dataset, index) => {\n      if (\n        dataset.type === ChartTypesStringEnum.LINE ||\n        dataset.type === ChartTypesStringEnum.BAR\n      ) {\n        const yAxisID = this._chartConfig.isMultiYAxis\n          ? `y-axis-${index}`\n          : dataset.yAxisID || 'y-axis-0';\n\n        // Detect if the dataset is all 0\n        const isAllZeroDataset = (dataset.data as number[]).every(\n          (val: number) => val === 0\n        );\n\n        let minValue = ChartHelper.calculateMinValue(dataset.data as number[]);\n        let maxValue = ChartHelper.calculateMaxValue(dataset.data as number[]);\n        const padding = maxValue * 0.03;\n\n        // Adjust scaling for all 0 datasets\n        if (isAllZeroDataset) {\n          minValue = 0;\n          maxValue = 1;\n        } else {\n          minValue = maxValue === minValue ? minValue - 0.1 : minValue;\n          maxValue =\n            maxValue === minValue ? maxValue + 0.1 : maxValue + padding;\n        }\n\n        this._chartConfig.chartOptions.scales = {\n          ...this._chartConfig.chartOptions.scales,\n          [yAxisID]: {\n            display: false,\n            beginAtZero: true,\n            min: minValue,\n            max: maxValue,\n            stacked: this._chartConfig.isStacked,\n          },\n        };\n\n        chartData.datasets[index] = {\n          ...dataset,\n          yAxisID,\n        };\n      }\n    });\n  }\n\n  private removeVerticalDashedLine(): void {\n    const annotations =\n      this._chartConfig?.\n        chartOptions?.\n        plugins?.\n        annotation?.\n        annotations;\n\n    const key: string = ChartPluginIdsStringEnum.X_DASHED;\n\n    if (annotations) {\n      delete this._chartConfig?.\n        chartOptions?.\n        plugins?.\n        annotation?.\n        annotations?.\n      [key as keyof typeof annotations];\n    }\n\n    this.chart.update();\n  }\n\n  private setVerticalDashedAnnotationLine(event: ChartEvent, color?: string): void {\n    const { left, right } = this.chart.chartArea;\n\n    const xScale = this.chart.scales[EChartEventProperties.X] as\n      | CategoryScale\n      | LinearScale;\n\n    const tickPositions =\n      this._chartConfig?.\n        chartData?.labels?.\n        map(\n          (\n            label: string,\n            index: number\n          ) => {\n            return xScale.getPixelForValue(index)\n          }\n        );\n    const segmentBoundaries = tickPositions.map((tickPos, index) => {\n      const leftBoundary =\n        index === 0 ? left : (tickPos + tickPositions[index - 1]) / 2;\n      const rightBoundary =\n        index === tickPositions.length - 1\n          ? right\n          : (tickPos + tickPositions[index + 1]) / 2;\n\n      return { leftBoundary, rightBoundary };\n    });\n\n    const nativeEvent = event.native as MouseEvent;\n\n    const boundingRect = this.chart.canvas.getBoundingClientRect();\n    const mouseHorizontalCoordinate =\n      nativeEvent.clientX - boundingRect.left;\n\n    const newHoveredIndex = segmentBoundaries.findIndex(\n      (boundary) =>\n        mouseHorizontalCoordinate >= boundary.leftBoundary &&\n        mouseHorizontalCoordinate < boundary.rightBoundary\n    );\n\n    if (newHoveredIndex >= 0) {\n      this._chartConfig.chartOptions.plugins = {\n        ...this._chartConfig.chartOptions.plugins,\n        annotation: {\n          ...this._chartConfig.chartOptions?.plugins?.annotation,\n          annotations: {\n            ...this._chartConfig.\n              chartOptions?.\n              plugins?.\n              annotation?.\n              annotations,\n            [ChartPluginIdsStringEnum.X_DASHED]: {\n              ...EChartAnnotation.X_DASHED,\n              value: newHoveredIndex,\n              borderColor: color || ChartColorsStringEnum.\n                BORDER_BOTTOM_LINE_CHART_COLOR,\n            },\n          },\n        },\n      };\n    };\n\n    this.hoveredIndex.emit(newHoveredIndex);\n    this.chart.update();\n  }\n\n  public removeVerticalDashedLineAndFocus(): void {\n    this.hoveredIndex.emit(null);\n    if (this._chartConfig.hasVerticalDashedAnnotation)\n      this.removeVerticalDashedLine();\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n","@if (isChartDataAvailable) {\n    <ng-container\n        *ngTemplateOutlet=\"\n            legend;\n            context: {\n                config: legendData,\n            }\n        \"\n    ></ng-container>\n    <div\n        [ngStyle]=\"{\n            height: _chartConfig.height + 'px',\n            width: _chartConfig.width + '%',\n        }\"\n    >\n        <canvas #chartCanvas></canvas>\n    </div>\n} @else {\n    <div\n        class=\"d-flex justify-content-center align-items-center\"\n        [ngStyle]=\"{\n            height: _chartConfig.height + 'px',\n            width: _chartConfig.width + '%',\n        }\"\n    >\n        <svg-icon\n            [src]=\"_chartConfig.noDataImage\"\n            alt=\"No data available\"\n            class=\"no-data-svg\"\n        ></svg-icon>\n    </div>\n}\n<ng-template #legend let-config=\"config\">\n    @if (config?.data) {\n        <div\n            [ngClass]=\"config.hasHighlightedBackground && 'colored-background'\"\n        >\n            @if (config.title) {\n                <div class=\"legend-title font-size-14 ta-font-extra-bold\">\n                    {{ config.title }}\n                </div>\n            }\n            <div class=\"legend-wrapper d-flex\">\n                @for (\n                    item of config.data;\n                    let index = $index;\n                    track item.name\n                ) {\n                    <div class=\"w-100\">\n                        <div\n                            class=\"d-flex align-content-center text-size-11 ta-font-bold\"\n                        >\n                            <span>{{ item?.name }}</span>\n                            <span\n                                [ngClass]=\"\n                                    item?.isLineIndicator\n                                        ? 'line-indicator'\n                                        : 'circle-indicator'\n                                \"\n                                [ngStyle]=\"{ background: item?.color }\"\n                            ></span>\n                        </div>\n                        <div class=\"text-size-18\">\n                            {{\n                                (item?.value !== 0\n                                    ? (item?.value | thousandSeparator)\n                                    : 0\n                                ) | unitPosition: item?.unit\n                            }}\n                        </div>\n                    </div>\n                }\n            </div>\n        </div>\n    }\n</ng-template>\n"]}