ca-components 1.0.70 → 1.0.72

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 (119) hide show
  1. package/esm2022/lib/ca-components.module.mjs +7 -1
  2. package/esm2022/lib/components/ca-chart/ca-chart.component.mjs +331 -118
  3. package/esm2022/lib/components/ca-chart/enums/chart-colors.enum.mjs +1 -1
  4. package/esm2022/lib/components/ca-chart/enums/chart-event-types.enum.mjs +1 -1
  5. package/esm2022/lib/components/ca-chart/enums/chart-font-properties.enum.mjs +1 -1
  6. package/esm2022/lib/components/ca-chart/enums/chart-plugin-ids.enum.mjs +2 -1
  7. package/esm2022/lib/components/ca-chart/models/chart-annotation.model.mjs +1 -1
  8. package/esm2022/lib/components/ca-chart/models/chart-base-dataset.model.mjs +1 -1
  9. package/esm2022/lib/components/ca-chart/models/chart-center-label.model.mjs +2 -0
  10. package/esm2022/lib/components/ca-chart/models/chart-config.model.mjs +1 -1
  11. package/esm2022/lib/components/ca-chart/models/chart-dataset-hover.model.mjs +2 -0
  12. package/esm2022/lib/components/ca-chart/models/chart-line-dataset.model.mjs +1 -1
  13. package/esm2022/lib/components/ca-chart/models/index.mjs +3 -1
  14. package/esm2022/lib/components/ca-chart/utils/constants/chart.constants.mjs +4 -0
  15. package/esm2022/lib/components/ca-chart/utils/constants/index.mjs +2 -0
  16. package/esm2022/lib/components/ca-chart/utils/helpers/chart.helper.mjs +74 -6
  17. package/esm2022/lib/components/ca-chart-manager/ca-chart-manager.component.mjs +108 -0
  18. package/esm2022/lib/components/ca-chart-manager/models/hover-state.model.mjs +2 -0
  19. package/esm2022/lib/components/ca-chart-manager/models/index.mjs +2 -0
  20. package/esm2022/lib/components/ca-chart-manager/services/chart-manager.service.mjs +21 -0
  21. package/esm2022/lib/components/ca-chart-manager/services/index.mjs +2 -0
  22. package/esm2022/lib/components/ca-dropdown-menu/ca-dropdown-menu.component.mjs +2 -1
  23. package/esm2022/lib/components/ca-dropdown-menu/models/dropdown-menu-option-emit.model.mjs +2 -0
  24. package/esm2022/lib/components/ca-dropdown-menu/models/index.mjs +2 -2
  25. package/esm2022/lib/components/ca-period-content/components/ca-period-content-payment/ca-period-content-payment.component.mjs +1 -1
  26. package/esm2022/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-single/ca-load-single.component.mjs +1 -1
  27. package/esm2022/lib/components/ca-tooltip-list/ca-tooltip-list.component.mjs +5 -4
  28. package/esm2022/lib/components/ca-tooltip-list/models/tooltip-list-item.model.mjs +1 -1
  29. package/esm2022/lib/components/ca-tooltip-list/models/tooltip-list.model.mjs +1 -1
  30. package/esm2022/lib/utils/helpers/dropdown-menu-content-conditional-items.helper.mjs +1 -1
  31. package/esm2022/lib/utils/helpers/dropdown-menu-content.helper.mjs +3 -1
  32. package/esm2022/public-api.mjs +2 -1
  33. package/fesm2022/ca-components.mjs +530 -129
  34. package/fesm2022/ca-components.mjs.map +1 -1
  35. package/lib/ca-components.module.d.ts +7 -6
  36. package/lib/components/ca-chart/ca-chart.component.d.ts +18 -10
  37. package/lib/components/ca-chart/enums/chart-colors.enum.d.ts +2 -1
  38. package/lib/components/ca-chart/enums/chart-plugin-ids.enum.d.ts +2 -1
  39. package/lib/components/ca-chart/models/chart-annotation.model.d.ts +1 -1
  40. package/lib/components/ca-chart/models/chart-base-dataset.model.d.ts +5 -2
  41. package/lib/components/ca-chart/models/chart-center-label.model.d.ts +11 -0
  42. package/lib/components/ca-chart/models/chart-config.model.d.ts +10 -3
  43. package/lib/components/ca-chart/models/chart-dataset-hover.model.d.ts +5 -0
  44. package/lib/components/ca-chart/models/chart-line-dataset.model.d.ts +0 -3
  45. package/lib/components/ca-chart/models/index.d.ts +2 -0
  46. package/lib/components/ca-chart/utils/constants/chart.constants.d.ts +3 -0
  47. package/lib/components/ca-chart/utils/constants/index.d.ts +1 -0
  48. package/lib/components/ca-chart/utils/helpers/chart.helper.d.ts +7 -1
  49. package/lib/components/ca-chart-manager/ca-chart-manager.component.d.ts +27 -0
  50. package/lib/components/ca-chart-manager/models/hover-state.model.d.ts +4 -0
  51. package/lib/components/ca-chart-manager/models/index.d.ts +1 -0
  52. package/lib/components/ca-chart-manager/services/chart-manager.service.d.ts +10 -0
  53. package/lib/components/ca-chart-manager/services/index.d.ts +1 -0
  54. package/lib/components/ca-dropdown-menu/ca-dropdown-menu.component.d.ts +2 -2
  55. package/lib/components/ca-dropdown-menu/models/{dropdown-option-emit.model.d.ts → dropdown-menu-option-emit.model.d.ts} +1 -1
  56. package/lib/components/ca-dropdown-menu/models/index.d.ts +1 -1
  57. package/lib/components/ca-filters/ca-filter.component.d.ts +2 -2
  58. package/lib/components/ca-period-content/components/ca-period-content-payment/ca-period-content-payment.component.d.ts +3 -3
  59. package/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-single/ca-load-single.component.d.ts +2 -2
  60. package/lib/components/ca-tooltip-list/ca-tooltip-list.component.d.ts +1 -1
  61. package/lib/components/ca-tooltip-list/models/tooltip-list-item.model.d.ts +0 -1
  62. package/lib/components/ca-tooltip-list/models/tooltip-list.model.d.ts +1 -3
  63. package/package.json +1 -1
  64. package/public-api.d.ts +1 -0
  65. package/src/assets/ca-components/svg/common/states/ic_alabama.svg +3 -0
  66. package/src/assets/ca-components/svg/common/states/ic_alaska.svg +14 -0
  67. package/src/assets/ca-components/svg/common/states/ic_arizona.svg +3 -0
  68. package/src/assets/ca-components/svg/common/states/ic_arkansas.svg +3 -0
  69. package/src/assets/ca-components/svg/common/states/ic_california.svg +3 -0
  70. package/src/assets/ca-components/svg/common/states/ic_colorado.svg +3 -0
  71. package/src/assets/ca-components/svg/common/states/ic_connecticut.svg +3 -0
  72. package/src/assets/ca-components/svg/common/states/ic_delaware.svg +3 -0
  73. package/src/assets/ca-components/svg/common/states/ic_florida.svg +3 -0
  74. package/src/assets/ca-components/svg/common/states/ic_georgia.svg +3 -0
  75. package/src/assets/ca-components/svg/common/states/ic_hawaii.svg +10 -0
  76. package/src/assets/ca-components/svg/common/states/ic_idaho.svg +3 -0
  77. package/src/assets/ca-components/svg/common/states/ic_illinois.svg +3 -0
  78. package/src/assets/ca-components/svg/common/states/ic_indiana.svg +3 -0
  79. package/src/assets/ca-components/svg/common/states/ic_iowa.svg +3 -0
  80. package/src/assets/ca-components/svg/common/states/ic_kansas.svg +3 -0
  81. package/src/assets/ca-components/svg/common/states/ic_kentucky.svg +3 -0
  82. package/src/assets/ca-components/svg/common/states/ic_louisiana.svg +4 -0
  83. package/src/assets/ca-components/svg/common/states/ic_maine.svg +9 -0
  84. package/src/assets/ca-components/svg/common/states/ic_maryland.svg +7 -0
  85. package/src/assets/ca-components/svg/common/states/ic_massachusetts.svg +7 -0
  86. package/src/assets/ca-components/svg/common/states/ic_michigan.svg +11 -0
  87. package/src/assets/ca-components/svg/common/states/ic_minnesota.svg +4 -0
  88. package/src/assets/ca-components/svg/common/states/ic_mississippi.svg +3 -0
  89. package/src/assets/ca-components/svg/common/states/ic_missouri.svg +3 -0
  90. package/src/assets/ca-components/svg/common/states/ic_montana.svg +3 -0
  91. package/src/assets/ca-components/svg/common/states/ic_nebraska.svg +3 -0
  92. package/src/assets/ca-components/svg/common/states/ic_nevada.svg +3 -0
  93. package/src/assets/ca-components/svg/common/states/ic_new_hampshire.svg +3 -0
  94. package/src/assets/ca-components/svg/common/states/ic_new_jersey.svg +5 -0
  95. package/src/assets/ca-components/svg/common/states/ic_new_mexico.svg +3 -0
  96. package/src/assets/ca-components/svg/common/states/ic_new_york.svg +4 -0
  97. package/src/assets/ca-components/svg/common/states/ic_north_carolina.svg +3 -0
  98. package/src/assets/ca-components/svg/common/states/ic_north_dakota.svg +3 -0
  99. package/src/assets/ca-components/svg/common/states/ic_ohio.svg +4 -0
  100. package/src/assets/ca-components/svg/common/states/ic_oklahoma.svg +3 -0
  101. package/src/assets/ca-components/svg/common/states/ic_oregon.svg +3 -0
  102. package/src/assets/ca-components/svg/common/states/ic_pennsylvania.svg +3 -0
  103. package/src/assets/ca-components/svg/common/states/ic_rhode_island.svg +8 -0
  104. package/src/assets/ca-components/svg/common/states/ic_south_carolina.svg +3 -0
  105. package/src/assets/ca-components/svg/common/states/ic_south_dakota.svg +3 -0
  106. package/src/assets/ca-components/svg/common/states/ic_tennessee.svg +3 -0
  107. package/src/assets/ca-components/svg/common/states/ic_texas.svg +3 -0
  108. package/src/assets/ca-components/svg/common/states/ic_utah.svg +3 -0
  109. package/src/assets/ca-components/svg/common/states/ic_vermont.svg +7 -0
  110. package/src/assets/ca-components/svg/common/states/ic_virginia.svg +4 -0
  111. package/src/assets/ca-components/svg/common/states/ic_washington.svg +15 -0
  112. package/src/assets/ca-components/svg/common/states/ic_west_virginia.svg +3 -0
  113. package/src/assets/ca-components/svg/common/states/ic_wisconsin.svg +4 -0
  114. package/src/assets/ca-components/svg/common/states/ic_wyoming.svg +3 -0
  115. package/esm2022/lib/components/ca-chart/config/ca-base-chart-dataset.config.mjs +0 -10
  116. package/esm2022/lib/components/ca-chart/config/index.mjs +0 -2
  117. package/esm2022/lib/components/ca-dropdown-menu/models/dropdown-option-emit.model.mjs +0 -2
  118. package/lib/components/ca-chart/config/ca-base-chart-dataset.config.d.ts +0 -4
  119. package/lib/components/ca-chart/config/index.d.ts +0 -1
@@ -1,4 +1,4 @@
1
- import { Component, Input, ViewChild, } from '@angular/core';
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
4
  // Charts
@@ -10,16 +10,24 @@ import { EChartEventProperties, ChartPluginIdsStringEnum, CubicInterpolationStri
10
10
  import { ChartHelper } from './utils/helpers';
11
11
  // Guards
12
12
  import { ChartTypeGuard } from './utils/guards';
13
- //Config
14
- import { CaBaseChartDatasetConfig } from './config';
13
+ // Constants
14
+ import { ChartConstants } from './utils/constants';
15
15
  import * as i0 from "@angular/core";
16
- import * as i1 from "@angular/common";
17
- import * as i2 from "angular-svg-icon";
16
+ import * as i1 from "../ca-chart-manager/services";
17
+ import * as i2 from "@angular/common";
18
+ import * as i3 from "angular-svg-icon";
18
19
  export class CaChartComponent {
20
+ set chartDatasetHover(value) {
21
+ if (value)
22
+ this.updateDatasetBackgroundOnHover(value);
23
+ }
19
24
  set chartConfig(value) {
20
25
  this._chartConfig = value;
21
26
  this.isChartDataAvailable = false;
22
- this._chartConfig.chartData.datasets.forEach((item) => {
27
+ this._chartConfig?.
28
+ chartData?.
29
+ datasets?.
30
+ forEach((item) => {
23
31
  item.data.forEach((value) => {
24
32
  if (Array.isArray(value)) {
25
33
  if (value[0] !== 0 || value[1] !== 0)
@@ -29,21 +37,29 @@ export class CaChartComponent {
29
37
  this.isChartDataAvailable = true;
30
38
  });
31
39
  });
32
- }
33
- //for testing hover state on dataset
34
- set isDatasetHovered(value) {
35
- this._isDatasetHovered = value;
36
- if (this.chart) {
37
- this.updateDatasetBackgroundOnHover('Sales', '#6692F1', this._isDatasetHovered);
38
- }
39
- }
40
- constructor() {
41
- this.originalChartDataset = CaBaseChartDatasetConfig.getBaseChartDatasetConfig();
42
- this.isChartDataAvailable = true;
43
- }
44
- ngOnChanges(changes) {
45
- if (this.isChartDataAvailable && !changes['chartConfig'].firstChange)
40
+ this.changeDetector.detectChanges();
41
+ if (this.isChartDataAvailable)
46
42
  this.updateChart();
43
+ this._chartConfig.chartData.datasets.forEach((item) => {
44
+ item.data.forEach((value) => {
45
+ if (Array.isArray(value)) {
46
+ if (value[0] !== 0 || value[1] !== 0)
47
+ this.isChartDataAvailable = true;
48
+ }
49
+ else {
50
+ if (value !== 0)
51
+ this.isChartDataAvailable = true;
52
+ }
53
+ });
54
+ });
55
+ }
56
+ constructor(changeDetector, chartManagerService) {
57
+ this.changeDetector = changeDetector;
58
+ this.chartManagerService = chartManagerService;
59
+ this.hoveredIndex = new EventEmitter();
60
+ this.areAnimationsCompleated = false;
61
+ this._hoveredIndex = null;
62
+ this.isChartDataAvailable = false;
47
63
  }
48
64
  ngAfterViewInit() {
49
65
  if (this.isChartDataAvailable) {
@@ -51,77 +67,145 @@ export class CaChartComponent {
51
67
  this.createChart();
52
68
  }
53
69
  }
70
+ ngOnInit() {
71
+ this.initializeChartManagerService();
72
+ }
73
+ initializeChartManagerService() {
74
+ if (!this.chartManagerService)
75
+ return;
76
+ this.subscription = this.chartManagerService.hoverState$.subscribe(({ index, chartId }) => {
77
+ if (chartId !== this.chartId) {
78
+ this._hoveredIndex = index;
79
+ if (this.chart)
80
+ this.chart.draw();
81
+ }
82
+ });
83
+ }
54
84
  initializeAnnotationPlugin() {
55
85
  Chart.register(annotationPlugin);
56
86
  }
57
- updateDatasetBackgroundOnHover(dataSetLabel, color, isDatasetHovered) {
58
- if (isDatasetHovered) {
59
- this.originalChartDataset = JSON.parse(JSON.stringify(this._chartConfig.chartData.datasets));
60
- const gradient = ChartHelper.createGradient(this.chartContext, this.chartCanvas, color, color);
61
- this._chartConfig.chartData.datasets =
62
- this._chartConfig.chartData.datasets.map((dataset) => {
63
- if (dataset.label === dataSetLabel) {
64
- return {
65
- ...dataset,
66
- fill: true,
67
- backgroundColor: gradient,
68
- borderColor: color,
69
- };
70
- }
71
- else {
72
- const borderColorWithOpacity = ChartHelper.rgbToRgba(dataset.borderColor, 0.2);
73
- return {
74
- ...dataset,
75
- fill: false,
76
- borderColor: borderColorWithOpacity,
77
- };
78
- }
79
- });
87
+ updateDatasetBackgroundOnHover(chartDatasetHover) {
88
+ if (!this.chart || !this.chart.data.datasets)
89
+ return;
90
+ if (chartDatasetHover.isHoverd) {
91
+ 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
+ });
114
+ }
115
+ 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
+ });
80
131
  }
81
- else
82
- this._chartConfig.chartData.datasets = JSON.parse(JSON.stringify(this.originalChartDataset));
83
132
  this.chart.update();
84
133
  }
85
134
  createChart() {
86
- this.chartContext = this.chartCanvas.nativeElement.getContext('2d');
135
+ this.chartContext = this.chartCanvas?.
136
+ nativeElement?.
137
+ getContext('2d');
87
138
  this.setChartOptionsProperties();
88
139
  this.setChartDataProperties();
89
140
  this.setChartPluginsProperties();
141
+ if (this.chart)
142
+ this.chart.destroy();
143
+ this.initializeAnnotationPlugin();
144
+ if (this._chartConfig.chartType === "doughnut" /* ChartTypesStringEnum.DOUGHNUT */)
145
+ Chart.overrides.doughnut.cutout = '80%';
90
146
  this.chart = new Chart(this.chartContext, {
91
147
  type: this._chartConfig.chartType,
92
148
  data: this._chartConfig.chartData,
93
149
  options: this._chartConfig.chartOptions,
94
150
  plugins: this.plugins,
95
151
  });
96
- this.chart.config.data.datasets = [
97
- ...this._chartConfig?.
98
- chartData?.
99
- datasets?.map((item, indx) => {
100
- if (!item.shiftValue)
101
- return {
152
+ if (!this._chartConfig.isDashboardChart) {
153
+ this.chart.config.data.datasets = [
154
+ ...this._chartConfig?.
155
+ chartData?.
156
+ datasets?.
157
+ map((item, indx) => {
158
+ const pointConfig = {
159
+ pointBackgroundColor: "#FFFFFF" /* ChartColorsStringEnum.WHITE */,
160
+ pointBorderWidth: 2,
161
+ pointRadius: 3,
162
+ };
163
+ this.updateChartAnnotations(item, indx);
164
+ const yScale = this.chart.scales[EChartEventProperties.Y_AXIS_0];
165
+ const datasetConfig = {
102
166
  ...item,
167
+ pointBorderColor: item.color,
168
+ ...pointConfig,
103
169
  backgroundColor: item?.color &&
104
170
  item?.color2 &&
105
171
  item?.color !== item?.color2 ?
106
172
  ChartHelper.createGradient(this.chartContext, this.chartCanvas, item?.color, item?.color2) : item?.color,
107
173
  fill: item?.fill
108
174
  };
109
- this.updateChartAnnotations(item, indx);
110
- const yScale = this.chart.scales[EChartEventProperties.Y_AXIS_0];
111
- const shiftValuePx = yScale.getPixelForValue(item.shiftValue || 0);
112
- const shiftValueAdjusted = shiftValuePx / yScale.maxHeight;
113
- return {
114
- ...item,
115
- backgroundColor: ChartHelper.createGradientWithShiftValue(this.chartContext, yScale.maxHeight, item.color || '', item.color2 || '', shiftValueAdjusted, true),
116
- borderColor: ChartHelper.createGradientWithShiftValue(this.chartContext, yScale.maxHeight, item.color || '', item.color2 || '', shiftValueAdjusted),
117
- fill: true
118
- };
119
- })
120
- ];
175
+ if (this._chartConfig.chartType === "doughnut" /* ChartTypesStringEnum.DOUGHNUT */) {
176
+ return {
177
+ ...datasetConfig,
178
+ backgroundColor: item.backgroundColor
179
+ };
180
+ }
181
+ if (!item.shiftValue) {
182
+ return {
183
+ ...datasetConfig,
184
+ backgroundColor: item?.color &&
185
+ item?.color2 &&
186
+ item?.color !== item?.color2 ?
187
+ ChartHelper.createGradient(this.chartContext, this.chartCanvas, item?.color, item?.color2) : item?.color,
188
+ };
189
+ }
190
+ const shiftValuePx = yScale.getPixelForValue(item.shiftValue || 0);
191
+ 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);
193
+ return {
194
+ ...item,
195
+ ...pointConfig,
196
+ pointBorderColor: borderColor,
197
+ backgroundColor: ChartHelper.createGradientWithShiftValue(this.chartContext, yScale.maxHeight, item.color || ChartConstants.STRING_EMPTY, item.color2 || ChartConstants.STRING_EMPTY, shiftValueAdjusted, true),
198
+ borderColor,
199
+ fill: true
200
+ };
201
+ })
202
+ ];
203
+ }
121
204
  this.chart.update();
122
205
  }
123
206
  updateChart() {
124
- this.chart?.destroy();
207
+ if (this.chart)
208
+ this.chart?.destroy();
125
209
  this.createChart();
126
210
  }
127
211
  setChartOptionsProperties() {
@@ -130,16 +214,37 @@ export class CaChartComponent {
130
214
  responsive: true,
131
215
  maintainAspectRatio: false,
132
216
  clip: false,
217
+ animation: {
218
+ onComplete: () => {
219
+ this.areAnimationsCompleated = true;
220
+ this.chart.draw();
221
+ },
222
+ onProgress: () => {
223
+ this.areAnimationsCompleated = false;
224
+ this.chart.draw();
225
+ },
226
+ },
133
227
  layout: {
134
228
  padding: {
135
229
  top: 0,
136
- bottom: -25
137
- }
230
+ bottom: 0,
231
+ left: this._chartConfig.chartType === "bar" /* ChartTypesStringEnum.BAR */ &&
232
+ this._chartConfig.verticalyAlignBarChartWithLineCart
233
+ ? 6
234
+ : 0,
235
+ right: this._chartConfig.chartType === "bar" /* ChartTypesStringEnum.BAR */ &&
236
+ this._chartConfig.verticalyAlignBarChartWithLineCart
237
+ ? 6
238
+ : 0,
239
+ },
138
240
  },
139
241
  plugins: {
140
242
  legend: {
141
243
  display: false,
142
244
  },
245
+ tooltip: {
246
+ enabled: false,
247
+ },
143
248
  },
144
249
  scales: {
145
250
  x: {
@@ -151,6 +256,7 @@ export class CaChartComponent {
151
256
  display: false,
152
257
  },
153
258
  ticks: {
259
+ display: true,
154
260
  padding: 0,
155
261
  color: "#919191" /* ChartColorsStringEnum.X_AXIS_LABEL_COLOR */,
156
262
  font: {
@@ -162,7 +268,7 @@ export class CaChartComponent {
162
268
  autoSkipPadding: 12,
163
269
  maxRotation: 0,
164
270
  minRotation: 0,
165
- //ispis lable u 2 reda za dane - ceka se dizaj za prikaz dana
271
+ //Label written in 2 lines, will be ujusted with new design
166
272
  callback: function (value, index) {
167
273
  const label = labels[index];
168
274
  const multiLineLabel = label ? label.split(' ') : [];
@@ -178,20 +284,44 @@ export class CaChartComponent {
178
284
  beginAtZero: true,
179
285
  min: 0,
180
286
  max: 1,
287
+ offset: false,
181
288
  },
182
289
  },
183
- onHover: (event, dataItem) => {
184
- if (!this._chartConfig.hasVerticalDashedAnnotation)
185
- return;
186
- this.resetAnnotations();
187
- if (!dataItem || !dataItem?.length)
290
+ 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);
188
304
  return;
189
- this.setVerticalDashedAnnotationLine(dataItem[0].element.x);
305
+ }
306
+ this.hoveredIndex.emit(item[0].index);
307
+ 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;
316
+ }
317
+ if (this._chartConfig.hasVerticalDashedAnnotation)
318
+ this.setVerticalDashedAnnotationLine(item[0].element.x);
319
+ this.chart.update();
190
320
  },
191
321
  };
192
322
  }
193
323
  setChartDataProperties() {
194
- if ((this._chartConfig.chartType = "line" /* ChartTypesStringEnum.LINE */)) {
324
+ if ((this._chartConfig.chartType === "line" /* ChartTypesStringEnum.LINE */)) {
195
325
  this._chartConfig.chartData.datasets.forEach((dataset) => {
196
326
  dataset.order = dataset.order;
197
327
  if (ChartTypeGuard.isLineDataset(dataset)) {
@@ -217,43 +347,110 @@ export class CaChartComponent {
217
347
  {
218
348
  id: ChartPluginIdsStringEnum.HIGHLIGHT_SEGMENT_ON_HOVER,
219
349
  afterEvent: (chart, event) => {
220
- if (!this._chartConfig.showTooltipBackground) {
350
+ if (!this._chartConfig.showTooltipBackground)
221
351
  return;
222
- }
223
352
  const nativeEvent = event.event.native;
224
- if (event.event.type === ChartEventTypesStringEnum.MOUSE_OUT &&
225
- hoveredIndex !== null) {
226
- hoveredIndex = null;
353
+ if (event.event.type === ChartEventTypesStringEnum.MOUSE_OUT) {
354
+ const boundingRect = this.chart.canvas.getBoundingClientRect();
355
+ const isMouseOutsideChart = nativeEvent.clientX < boundingRect.left ||
356
+ nativeEvent.clientX > boundingRect.right ||
357
+ nativeEvent.clientY < boundingRect.top ||
358
+ nativeEvent.clientY > boundingRect.bottom;
359
+ if (isMouseOutsideChart) {
360
+ this._hoveredIndex = null;
361
+ this.chartManagerService?.setHoverState(null, this.chartId);
362
+ this.chart.draw();
363
+ }
364
+ return;
365
+ }
366
+ const boundingRect = this.chart.canvas.getBoundingClientRect();
367
+ const mouseHorizontalCoordinate = nativeEvent.clientX - boundingRect.left;
368
+ const { left, right } = this.chart.chartArea;
369
+ if (mouseHorizontalCoordinate < left ||
370
+ mouseHorizontalCoordinate > right) {
371
+ this._hoveredIndex = null;
372
+ this.chartManagerService?.setHoverState(null, this.chartId);
227
373
  this.chart.draw();
228
374
  return;
229
375
  }
230
- const mouseHorizontalCoordinate = nativeEvent[EChartEventProperties.X];
231
376
  const xScale = this.chart.scales[EChartEventProperties.X];
232
- const tickPositions = ChartHelper.calculateTickPositions(xScale);
233
- const newHoveredIndex = tickPositions.findIndex((tickPos) => mouseHorizontalCoordinate >
234
- tickPos - (tickPositions[1] - tickPositions[0]) / 2 &&
235
- mouseHorizontalCoordinate <=
236
- tickPos + (tickPositions[1] - tickPositions[0]) / 2);
237
- if (newHoveredIndex !== hoveredIndex) {
238
- hoveredIndex = newHoveredIndex === -1 ? null : newHoveredIndex;
377
+ const tickPositions = xScale.ticks.map((tick) => xScale.getPixelForValue(tick.value));
378
+ const segmentBoundaries = tickPositions.map((tickPos, index) => {
379
+ const leftBoundary = index === 0 ? left : (tickPos + tickPositions[index - 1]) / 2;
380
+ const rightBoundary = index === tickPositions.length - 1
381
+ ? right
382
+ : (tickPos + tickPositions[index + 1]) / 2;
383
+ return { leftBoundary, rightBoundary };
384
+ });
385
+ const newHoveredIndex = segmentBoundaries.findIndex((boundary) => mouseHorizontalCoordinate >= boundary.leftBoundary &&
386
+ mouseHorizontalCoordinate < boundary.rightBoundary);
387
+ if (newHoveredIndex !== this._hoveredIndex) {
388
+ this._hoveredIndex = newHoveredIndex === -1 ? null : newHoveredIndex;
389
+ this.chartManagerService?.setHoverState(this._hoveredIndex, this.chartId);
239
390
  this.chart.draw();
240
391
  }
241
392
  },
242
393
  beforeDraw: () => {
243
- if (hoveredIndex !== null) {
394
+ if (this._hoveredIndex !== null) {
244
395
  const { chartArea, scales: { x: xScale }, } = this.chart;
245
- ChartHelper.highlightSegment(this.chartContext, xScale, chartArea, this._chartConfig.height, hoveredIndex);
396
+ ChartHelper.highlightSegment(this.chartContext, xScale, chartArea, this._chartConfig.height, this._hoveredIndex);
246
397
  }
247
398
  },
248
399
  },
249
400
  {
250
401
  id: ChartPluginIdsStringEnum.HIGHLIGHT_POINT_ON_HOVER,
251
402
  afterDraw: () => {
252
- if (hoveredIndex !== null)
253
- ChartHelper.highlightPoint(this.chartContext, this.chart, hoveredIndex, this._chartConfig.chartData);
403
+ if (this._hoveredIndex !== null &&
404
+ this._chartConfig.showHighlightPointOnHover &&
405
+ this.areAnimationsCompleated) {
406
+ const visibleDatasets = this._chartConfig.chartData.datasets.filter((dataset) => !dataset.hidden);
407
+ ChartHelper.highlightPoint(this.chartContext, this.chart, this._hoveredIndex, { ...this._chartConfig.chartData, datasets: visibleDatasets });
408
+ }
409
+ },
410
+ },
411
+ {
412
+ id: ChartPluginIdsStringEnum.BORDER_BOTTOM_LINE_CHART,
413
+ beforeDraw: () => {
414
+ if (this._chartConfig?.showBottomLineOnLineChart) {
415
+ const { ctx, data, chartArea, scales: { x: xScale }, } = this.chart;
416
+ const dataset = data.datasets[0];
417
+ const firstIndex = 0;
418
+ const lastIndex = dataset.data.length - 1;
419
+ const firstValue = dataset.data[firstIndex];
420
+ const lastValue = dataset.data[lastIndex];
421
+ if (firstValue !== undefined && lastValue !== undefined) {
422
+ const xStart = xScale.getPixelForValue(firstIndex);
423
+ const xEnd = xScale.getPixelForValue(lastIndex);
424
+ const yBottom = chartArea.bottom;
425
+ ctx.save();
426
+ ctx.strokeStyle =
427
+ "#DADADA" /* ChartColorsStringEnum.BORDER_BOTTOM_LINE_CHART_COLOR */;
428
+ ctx.lineWidth = 1;
429
+ ctx.beginPath();
430
+ ctx.moveTo(xStart, yBottom);
431
+ ctx.lineTo(xEnd, yBottom);
432
+ ctx.stroke();
433
+ ctx.restore();
434
+ }
435
+ }
254
436
  },
255
437
  },
256
438
  ];
439
+ if (this._chartConfig.chartType === "doughnut" /* ChartTypesStringEnum.DOUGHNUT */)
440
+ this.plugins = [
441
+ ...this.plugins,
442
+ {
443
+ id: 'doughnut-label',
444
+ beforeDatasetDraw: (chart) => {
445
+ this._chartConfig.centerLabels?.map((label, indx) => {
446
+ ChartHelper.drawDoughnutLegend(chart, {
447
+ indx,
448
+ offsetTop: label.position?.top || 0
449
+ }, label.value, label.fontSize, label.color);
450
+ });
451
+ },
452
+ }
453
+ ];
257
454
  }
258
455
  updateChartAnnotations(item, indx) {
259
456
  if (!this._chartConfig.annotations?.length)
@@ -274,7 +471,7 @@ export class CaChartComponent {
274
471
  [`${item.label}-${indx}-${key}`]: {
275
472
  id: annotation.id || `annotation-${indx}-${key}`,
276
473
  type: annotation.type,
277
- scaleID: annotation.axis || item.yAxisId,
474
+ scaleID: annotation.axis || item.yAxisID,
278
475
  value: annotation.value || item.shiftValue,
279
476
  borderColor: annotation.color || '#DADADA',
280
477
  borderWidth: annotation.borderWidth || 2,
@@ -284,37 +481,45 @@ export class CaChartComponent {
284
481
  },
285
482
  };
286
483
  });
484
+ this.chart.update();
287
485
  }
288
486
  setMultipleYAxis(chartData) {
289
487
  let absoluteMax;
290
488
  chartData.datasets.forEach((dataset, index) => {
291
- if (dataset.type == "line" /* ChartTypesStringEnum.LINE */ ||
292
- dataset.type == "bar" /* ChartTypesStringEnum.BAR */) {
489
+ if (dataset.type === "line" /* ChartTypesStringEnum.LINE */ ||
490
+ dataset.type === "bar" /* ChartTypesStringEnum.BAR */) {
293
491
  const yAxisID = this._chartConfig.isMultiYAxis
294
492
  ? `y-axis-${index}`
295
- : dataset.yAxisId || 'y-axis-0';
296
- chartData.datasets[index] = {
297
- ...dataset,
298
- yAxisID,
299
- };
300
- const minValue = ChartHelper.calculateMinValue(dataset.data);
301
- const maxValue = ChartHelper.calculateMaxValue(dataset.data);
302
- if (!absoluteMax || maxValue > absoluteMax)
303
- absoluteMax = maxValue;
493
+ : dataset.yAxisID || 'y-axis-0';
494
+ // Detect if the dataset is all 0
495
+ const isAllZeroDataset = dataset.data.every((val) => val === 0);
496
+ let minValue = ChartHelper.calculateMinValue(dataset.data);
497
+ let maxValue = ChartHelper.calculateMaxValue(dataset.data);
304
498
  const padding = maxValue * 0.03;
305
- const minValueAdjusted = padding == 0 ? minValue : 0;
306
- const maxValueAdjusted = absoluteMax + padding;
499
+ // Adjust scaling for all 0 datasets
500
+ if (isAllZeroDataset) {
501
+ minValue = 0;
502
+ maxValue = 1;
503
+ }
504
+ else {
505
+ minValue = maxValue === minValue ? minValue - 0.1 : minValue;
506
+ maxValue =
507
+ maxValue === minValue ? maxValue + 0.1 : maxValue + padding;
508
+ }
307
509
  this._chartConfig.chartOptions.scales = {
308
510
  ...this._chartConfig.chartOptions.scales,
309
511
  [yAxisID]: {
310
512
  display: false,
311
513
  beginAtZero: true,
312
- min: minValueAdjusted,
313
- max: maxValueAdjusted,
314
- // Ovo je jako bitno, moramo ovu osu sa stacked parametrom namjestiti
514
+ min: minValue,
515
+ max: maxValue,
315
516
  stacked: this._chartConfig.isStacked,
316
517
  },
317
518
  };
519
+ chartData.datasets[index] = {
520
+ ...dataset,
521
+ yAxisID,
522
+ };
318
523
  }
319
524
  });
320
525
  }
@@ -353,20 +558,28 @@ export class CaChartComponent {
353
558
  },
354
559
  },
355
560
  };
356
- this.chart.update();
357
561
  }
358
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
359
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CaChartComponent, isStandalone: true, selector: "app-ca-chart", inputs: { chartConfig: "chartConfig", isDatasetHovered: "isDatasetHovered" }, viewQueries: [{ propertyName: "chartCanvas", first: true, predicate: ["chartCanvas"], descendants: true }], usesOnChanges: 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: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: AngularSvgIconModule }, { kind: "component", type: i2.SvgIconComponent, selector: "svg-icon", inputs: ["src", "name", "stretch", "applyClass", "applyCss", "svgClass", "class", "viewBox", "svgAriaLabel", "svgStyle"] }] }); }
562
+ ngOnDestroy() {
563
+ this.subscription?.unsubscribe();
564
+ }
565
+ 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"] }] }); }
360
567
  }
361
568
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaChartComponent, decorators: [{
362
569
  type: Component,
363
- 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"] }]
364
- }], ctorParameters: () => [], propDecorators: { chartCanvas: [{
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"] }]
571
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.ChartManagerService, decorators: [{
572
+ type: Optional
573
+ }] }], propDecorators: { chartCanvas: [{
365
574
  type: ViewChild,
366
- args: ['chartCanvas']
367
- }], chartConfig: [{
575
+ args: ['chartCanvas', { static: false }]
576
+ }], chartId: [{
368
577
  type: Input
369
- }], isDatasetHovered: [{
578
+ }], chartDatasetHover: [{
579
+ type: Input
580
+ }], chartConfig: [{
370
581
  type: Input
582
+ }], hoveredIndex: [{
583
+ type: Output
371
584
  }] } });
372
- //# 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  Component,\n  ElementRef,\n  Input,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { AnyObject } from 'chart.js/dist/types/basic';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n// Charts\nimport {\n  CategoryScale,\n  Chart,\n  ChartEvent,\n  ChartType,\n  LinearScale,\n  Plugin,\n} from 'chart.js/auto';\nimport annotationPlugin from 'chartjs-plugin-annotation';\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} from './models';\nimport { ActiveElement } from 'chart.js/dist/plugins/plugin.tooltip';\n\n//Config\nimport { CaBaseChartDatasetConfig } from './config';\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') chartCanvas!: ElementRef;\n\n  @Input() set chartConfig(value: IChartConfiguration) {\n    this._chartConfig = value;\n    this.isChartDataAvailable = false;\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        }\n        else\n          if (value !== 0)\n            this.isChartDataAvailable = true;\n      })\n    })\n  }\n\n  //for testing hover state on dataset\n  @Input() set isDatasetHovered(value: boolean) {\n    this._isDatasetHovered = value;\n    if (this.chart) {\n      this.updateDatasetBackgroundOnHover(\n        'Sales',\n        '#6692F1',\n        this._isDatasetHovered\n      );\n    }\n  }\n\n  private chart!: Chart;\n  private chartContext!: CanvasRenderingContext2D;\n  private plugins?: Plugin<ChartType, AnyObject>[];\n  private _isDatasetHovered!: boolean;\n  private originalChartDataset =\n    CaBaseChartDatasetConfig.getBaseChartDatasetConfig();\n\n  public _chartConfig!: IChartConfiguration;\n  public isChartDataAvailable: boolean = true;\n\n  constructor() { }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.isChartDataAvailable && !changes['chartConfig'].firstChange)\n      this.updateChart();\n  }\n\n  ngAfterViewInit(): void {\n    if (this.isChartDataAvailable) {\n      this.initializeAnnotationPlugin();\n      this.createChart();\n    }\n  }\n\n  private initializeAnnotationPlugin(): void {\n    Chart.register(annotationPlugin);\n  }\n\n  public updateDatasetBackgroundOnHover(\n    dataSetLabel: string,\n    color: string,\n    isDatasetHovered: boolean\n  ): void {\n    if (isDatasetHovered) {\n      this.originalChartDataset = JSON.parse(\n        JSON.stringify(this._chartConfig.chartData.datasets)\n      );\n      const gradient = ChartHelper.createGradient(\n        this.chartContext,\n        this.chartCanvas,\n        color,\n        color\n      );\n\n      this._chartConfig.chartData.datasets =\n        this._chartConfig.chartData.datasets.map((dataset) => {\n          if (dataset.label === dataSetLabel) {\n            return {\n              ...dataset,\n              fill: true,\n              backgroundColor: gradient,\n              borderColor: color,\n            };\n          } else {\n            const borderColorWithOpacity = ChartHelper.rgbToRgba(\n              dataset.borderColor,\n              0.2\n            );\n            return {\n              ...dataset,\n              fill: false,\n              borderColor: borderColorWithOpacity,\n            };\n          }\n        });\n    } else\n      this._chartConfig.chartData.datasets = JSON.parse(\n        JSON.stringify(this.originalChartDataset)\n      );\n\n    this.chart.update();\n  }\n\n  private createChart(): void {\n    this.chartContext = this.chartCanvas.nativeElement.getContext('2d');\n    this.setChartOptionsProperties();\n    this.setChartDataProperties();\n    this.setChartPluginsProperties();\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    this.chart.config.data.datasets = [\n      ...this._chartConfig?.\n        chartData?.\n        datasets?.map((item: IBaseDataset, indx: number) => {\n          if (!item.shiftValue)\n            return {\n              ...item,\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          this.updateChartAnnotations(item, indx);\n\n          const yScale = this.chart.scales[EChartEventProperties.Y_AXIS_0] as\n            | CategoryScale\n            | LinearScale;\n\n          const shiftValuePx: number = yScale.getPixelForValue(item.shiftValue || 0);\n          const shiftValueAdjusted: number =\n            shiftValuePx / yScale.maxHeight;\n\n          return {\n            ...item,\n            backgroundColor: ChartHelper.createGradientWithShiftValue(\n              this.chartContext,\n              yScale.maxHeight,\n              item.color || '',\n              item.color2 || '',\n              shiftValueAdjusted,\n              true\n            ),\n            borderColor:\n              ChartHelper.createGradientWithShiftValue(\n                this.chartContext,\n                yScale.maxHeight,\n                item.color || '',\n                item.color2 || '',\n                shiftValueAdjusted,\n              ),\n            fill: true\n          }\n        })\n    ];\n    this.chart.update();\n  }\n\n  private updateChart(): void {\n    this.chart?.destroy();\n    this.createChart();\n  }\n\n  private setChartOptionsProperties(): void {\n    const labels = this._chartConfig.chartData.labels;\n    this._chartConfig.chartOptions = {\n      responsive: true,\n      maintainAspectRatio: false,\n      clip: false,\n      layout: {\n        padding: {\n          top: 0,\n          bottom: -25\n        }\n      },\n      plugins: {\n        legend: {\n          display: 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            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            //ispis lable u 2 reda za dane - ceka se dizaj za prikaz dana\n            callback: function (value: string | number, index: number): 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        },\n      },\n      onHover: (event: ChartEvent, dataItem: ActiveElement[]) => {\n        if (!this._chartConfig.hasVerticalDashedAnnotation) return;\n\n        this.resetAnnotations();\n\n        if (!dataItem || !dataItem?.length) return;\n\n        this.setVerticalDashedAnnotationLine(dataItem[0].element.x);\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) {\n            return;\n          }\n\n          const nativeEvent = event.event.native as MouseEvent;\n\n          if (\n            event.event.type === ChartEventTypesStringEnum.MOUSE_OUT &&\n            hoveredIndex !== null\n          ) {\n            hoveredIndex = null;\n            this.chart.draw();\n            return;\n          }\n\n          const mouseHorizontalCoordinate = nativeEvent[EChartEventProperties.X];\n          const xScale = this.chart.scales[EChartEventProperties.X] as\n            | CategoryScale\n            | LinearScale;\n\n          const tickPositions = ChartHelper.calculateTickPositions(xScale);\n          const newHoveredIndex = tickPositions.findIndex(\n            (tickPos) =>\n              mouseHorizontalCoordinate >\n              tickPos - (tickPositions[1] - tickPositions[0]) / 2 &&\n              mouseHorizontalCoordinate <=\n              tickPos + (tickPositions[1] - tickPositions[0]) / 2\n          );\n\n          if (newHoveredIndex !== hoveredIndex) {\n            hoveredIndex = newHoveredIndex === -1 ? null : newHoveredIndex;\n            this.chart.draw();\n          }\n        },\n        beforeDraw: () => {\n          if (hoveredIndex !== null) {\n            const {\n              chartArea,\n              scales: { x: xScale },\n            } = this.chart;\n            ChartHelper.highlightSegment(\n              this.chartContext,\n              xScale as CategoryScale | LinearScale,\n              chartArea,\n              this._chartConfig.height,\n              hoveredIndex\n            );\n          }\n        },\n      },\n      {\n        id: ChartPluginIdsStringEnum.HIGHLIGHT_POINT_ON_HOVER,\n        afterDraw: () => {\n          if (hoveredIndex !== null)\n            ChartHelper.highlightPoint(\n              this.chartContext,\n              this.chart,\n              hoveredIndex,\n              this._chartConfig.chartData\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  }\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        chartData.datasets[index] = {\n          ...dataset,\n          yAxisID,\n        };\n        const minValue = ChartHelper.calculateMinValue(\n          dataset.data as number[]\n        );\n        const maxValue = ChartHelper.calculateMaxValue(\n          dataset.data as number[]\n        );\n        if (!absoluteMax || maxValue > absoluteMax) absoluteMax = maxValue;\n        const padding = maxValue * 0.03;\n        const minValueAdjusted = padding == 0 ? minValue : 0;\n        const maxValueAdjusted = absoluteMax + padding;\n\n        this._chartConfig.chartOptions.scales = {\n          ...this._chartConfig.chartOptions.scales,\n          [yAxisID]: {\n            display: false,\n            beginAtZero: true,\n            min: minValueAdjusted,\n            max: maxValueAdjusted,\n            // Ovo je jako bitno, moramo ovu osu sa stacked parametrom namjestiti\n            stacked: this._chartConfig.isStacked,\n          },\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    this.chart.update();\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"]}
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"]}