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.
- package/esm2022/lib/components/ca-chart/ca-chart.component.mjs +200 -120
- package/esm2022/lib/components/ca-chart/enums/chart-annotation.enum.mjs +11 -0
- package/esm2022/lib/components/ca-chart/enums/chart-plugin-ids.enum.mjs +2 -1
- package/esm2022/lib/components/ca-chart/enums/index.mjs +2 -1
- package/esm2022/lib/components/ca-chart/models/chart-config.model.mjs +1 -1
- package/esm2022/lib/components/ca-chart/models/chart-legend-config.model.mjs +2 -0
- package/esm2022/lib/components/ca-chart/models/chart-legend-property.model.mjs +2 -0
- package/esm2022/lib/components/ca-chart/models/index.mjs +3 -1
- package/esm2022/lib/components/ca-chart/utils/helpers/chart.helper.mjs +2 -2
- package/esm2022/lib/components/ca-chart-manager/ca-chart-manager.component.mjs +4 -4
- package/esm2022/lib/components/ca-dropdown-menu/ca-dropdown-menu.component.mjs +3 -3
- package/esm2022/lib/components/ca-input-address-dropdown/ca-input-address-dropdown.component.mjs +21 -22
- package/esm2022/lib/components/ca-input-address-dropdown/enums/input-address-basic-string.enum.mjs +6 -0
- package/esm2022/lib/pipes/index.mjs +19 -0
- package/esm2022/lib/pipes/unit-position.pipe.mjs +24 -0
- package/fesm2022/ca-components.mjs +277 -163
- package/fesm2022/ca-components.mjs.map +1 -1
- package/lib/components/ca-chart/ca-chart.component.d.ts +9 -4
- package/lib/components/ca-chart/enums/chart-annotation.enum.d.ts +10 -0
- package/lib/components/ca-chart/enums/chart-plugin-ids.enum.d.ts +2 -1
- package/lib/components/ca-chart/enums/index.d.ts +1 -0
- package/lib/components/ca-chart/models/chart-config.model.d.ts +1 -0
- package/lib/components/ca-chart/models/chart-legend-config.model.d.ts +6 -0
- package/lib/components/ca-chart/models/chart-legend-property.model.d.ts +7 -0
- package/lib/components/ca-chart/models/index.d.ts +2 -0
- package/lib/components/ca-input-address-dropdown/enums/input-address-basic-string.enum.d.ts +4 -0
- package/lib/pipes/index.d.ts +18 -0
- package/lib/pipes/unit-position.pipe.d.ts +7 -0
- 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,
|
|
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.
|
|
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 =
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
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 =
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
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 = '
|
|
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
|
|
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
|
|
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,
|
|
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
|
|
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:
|
|
230
|
-
|
|
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
|
|
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.
|
|
293
|
-
|
|
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.
|
|
325
|
+
this.setOriginalDoughnutArcsColor();
|
|
307
326
|
if (this._chartConfig.chartType === "doughnut" /* ChartTypesStringEnum.DOUGHNUT */) {
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
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
|
-
|
|
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 ||
|
|
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
|
-
|
|
527
|
-
this._chartConfig
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
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(
|
|
582
|
+
setVerticalDashedAnnotationLine(event, color) {
|
|
583
|
+
const { left, right } = this.chart.chartArea;
|
|
535
584
|
const xScale = this.chart.scales[EChartEventProperties.X];
|
|
536
|
-
const
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
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.
|
|
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: "
|
|
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: [
|
|
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"]}
|