ca-components 1.0.9 → 1.0.11

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 (58) hide show
  1. package/esm2022/lib/components/ca-activity-log-list/ca-activity-log-list.component.mjs +21 -10
  2. package/esm2022/lib/components/ca-activity-log-list/models/activity-log-item-description.model.mjs +1 -1
  3. package/esm2022/lib/components/ca-chart/ca-chart.component.mjs +56 -72
  4. package/esm2022/lib/components/ca-chart/config/ca-base-chart-dataset.config.mjs +2 -3
  5. package/esm2022/lib/components/ca-chart/enums/chart-colors.enum.mjs +2 -0
  6. package/esm2022/lib/components/ca-chart/enums/{chart-event-properties-enum.mjs → chart-event-properties.enum.mjs} +1 -1
  7. package/esm2022/lib/components/ca-chart/enums/{chart-event-types-enum.mjs → chart-event-types.enum.mjs} +1 -1
  8. package/esm2022/lib/components/ca-chart/enums/chart-images.enum.mjs +2 -0
  9. package/esm2022/lib/components/ca-chart/enums/{chart-plugin-ids-enum.mjs → chart-plugin-ids.enum.mjs} +1 -1
  10. package/esm2022/lib/components/ca-chart/enums/chart-types.enum.mjs +2 -0
  11. package/esm2022/lib/components/ca-chart/enums/{cubic-interpolation-mode-enum.mjs → cubic-interpolation-mode.enum.mjs} +1 -1
  12. package/esm2022/lib/components/ca-chart/enums/index.mjs +8 -7
  13. package/esm2022/lib/components/ca-chart/models/chart-config.model.mjs +2 -0
  14. package/esm2022/lib/components/ca-chart/models/index.mjs +2 -1
  15. package/esm2022/lib/components/ca-chart/utils/guards/chart-type.guard.mjs +2 -3
  16. package/esm2022/lib/components/ca-chart/utils/helpers/chart.helper.mjs +4 -5
  17. package/esm2022/lib/components/ca-filters/ca-filter.component.mjs +6 -4
  18. package/esm2022/lib/components/ca-filters/components/ca-location-filter/ca-location-filter.component.mjs +8 -12
  19. package/esm2022/lib/components/ca-filters/utils/constants/directive.constants.mjs +25 -1
  20. package/esm2022/lib/components/ca-input-address-dropdown/ca-input-address-dropdown.component.mjs +4 -2
  21. package/esm2022/lib/components/ca-logo-change/ca-logo-change.component.mjs +3 -3
  22. package/esm2022/lib/components/ca-period-content/ca-period-content.component.mjs +2 -2
  23. package/esm2022/lib/components/ca-right-side-panel/ca-right-side-panel.component.mjs +27 -9
  24. package/esm2022/lib/components/ca-right-side-panel/components/ca-right-side-panel-menu/ca-right-side-panel-menu.component.mjs +4 -4
  25. package/esm2022/lib/components/ca-right-side-panel/components/ca-right-side-panel-top-bar/ca-right-side-panel-top-bar.component.mjs +42 -7
  26. package/esm2022/lib/components/ca-right-side-panel/config/ca-right-side-panel.config.mjs +2 -2
  27. package/esm2022/lib/components/ca-right-side-panel/models/activity-log-filter-params.model.mjs +1 -1
  28. package/fesm2022/ca-components.mjs +189 -133
  29. package/fesm2022/ca-components.mjs.map +1 -1
  30. package/lib/components/ca-activity-log-list/ca-activity-log-list.component.d.ts +8 -4
  31. package/lib/components/ca-activity-log-list/models/activity-log-item-description.model.d.ts +3 -3
  32. package/lib/components/ca-chart/ca-chart.component.d.ts +5 -10
  33. package/lib/components/ca-chart/enums/{chart-colors-enum.d.ts → chart-colors.enum.d.ts} +1 -1
  34. package/lib/components/ca-chart/enums/chart-images.enum.d.ts +7 -0
  35. package/lib/components/ca-chart/enums/{chart-types-enum.d.ts → chart-types.enum.d.ts} +1 -1
  36. package/lib/components/ca-chart/enums/index.d.ts +7 -6
  37. package/lib/components/ca-chart/models/chart-config.model.d.ts +10 -0
  38. package/lib/components/ca-chart/models/index.d.ts +1 -0
  39. package/lib/components/ca-filters/ca-filter.component.d.ts +3 -1
  40. package/lib/components/ca-filters/components/ca-location-filter/ca-location-filter.component.d.ts +4 -2
  41. package/lib/components/ca-filters/utils/constants/directive.constants.d.ts +2 -0
  42. package/lib/components/ca-input-address-dropdown/ca-input-address-dropdown.component.d.ts +2 -2
  43. package/lib/components/ca-right-side-panel/ca-right-side-panel.component.d.ts +8 -5
  44. package/lib/components/ca-right-side-panel/components/ca-right-side-panel-menu/ca-right-side-panel-menu.component.d.ts +1 -1
  45. package/lib/components/ca-right-side-panel/components/ca-right-side-panel-top-bar/ca-right-side-panel-top-bar.component.d.ts +3 -1
  46. package/lib/components/ca-right-side-panel/models/activity-log-filter-params.model.d.ts +2 -1
  47. package/package.json +1 -1
  48. package/src/assets/ca-components/svg/chart/chart_no_data_green.svg +242 -0
  49. package/src/assets/ca-components/svg/chart/chart_no_data_mixed.svg +62 -0
  50. package/src/assets/ca-components/svg/chart/chart_no_data_pay.svg +115 -0
  51. package/src/assets/ca-components/svg/chart/chart_no_data_stacked.svg +225 -0
  52. package/src/assets/ca-components/svg/chart/chart_no_data_yellow.svg +51 -0
  53. package/esm2022/lib/components/ca-chart/enums/chart-colors-enum.mjs +0 -7
  54. package/esm2022/lib/components/ca-chart/enums/chart-types-enum.mjs +0 -7
  55. /package/lib/components/ca-chart/enums/{chart-event-properties-enum.d.ts → chart-event-properties.enum.d.ts} +0 -0
  56. /package/lib/components/ca-chart/enums/{chart-event-types-enum.d.ts → chart-event-types.enum.d.ts} +0 -0
  57. /package/lib/components/ca-chart/enums/{chart-plugin-ids-enum.d.ts → chart-plugin-ids.enum.d.ts} +0 -0
  58. /package/lib/components/ca-chart/enums/{cubic-interpolation-mode-enum.d.ts → cubic-interpolation-mode.enum.d.ts} +0 -0
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aXZpdHktbG9nLWl0ZW0tZGVzY3JpcHRpb24ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1hY3Rpdml0eS1sb2ctbGlzdC9tb2RlbHMvYWN0aXZpdHktbG9nLWl0ZW0tZGVzY3JpcHRpb24ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQWN0aXZpdHlMb2dJdGVtRGVzY3JpcHRpb24ge1xuICBUaXRsZTogc3RyaW5nO1xuICBTdWJUaXRsZTogc3RyaW5nO1xuICBBZGRpdGlvbmFsOiBhbnk7IC8vIHRoaXMgd2lsbCBiZSBjaGFuZ2VkIHdoZW4gQWRkaXRpb25hbCBpcyBkZWZpbmVkXG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aXZpdHktbG9nLWl0ZW0tZGVzY3JpcHRpb24ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1hY3Rpdml0eS1sb2ctbGlzdC9tb2RlbHMvYWN0aXZpdHktbG9nLWl0ZW0tZGVzY3JpcHRpb24ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQWN0aXZpdHlMb2dJdGVtRGVzY3JpcHRpb24ge1xuICB0aXRsZTogc3RyaW5nO1xuICBzdWJUaXRsZTogc3RyaW5nO1xuICBhZGRpdGlvbmFsOiBhbnk7IC8vIHRoaXMgd2lsbCBiZSBjaGFuZ2VkIHdoZW4gQWRkaXRpb25hbCBpcyBkZWZpbmVkXG59XG4iXX0=
@@ -1,8 +1,9 @@
1
1
  import { Component, Input, ViewChild, } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { Chart, } from 'chart.js/auto';
4
- //Enum
5
- import { ChartColorsStringEnum, ChartEventProperties, ChartPluginIdsStringEnum, ChartTypesStringEnum, CubicInterpolationStringEnum, ChartEventTypesStringEnum } from './enums';
4
+ import { AngularSvgIconModule } from 'angular-svg-icon';
5
+ //Enums
6
+ import { ChartEventProperties, ChartPluginIdsStringEnum, CubicInterpolationStringEnum, ChartEventTypesStringEnum, } from './enums';
6
7
  //Helpers
7
8
  import { ChartHelper } from './utils/helpers';
8
9
  //Guards
@@ -11,27 +12,11 @@ import { ChartTypeGuard } from './utils/guards';
11
12
  import { CaBaseChartDatasetConfig } from './config';
12
13
  import * as i0 from "@angular/core";
13
14
  import * as i1 from "@angular/common";
15
+ import * as i2 from "angular-svg-icon";
14
16
  export class CaChartComponent {
15
- set chartType(value) {
16
- this._chartType = value;
17
- if (this.chart) {
18
- this.chart.destroy();
19
- this.createChart();
20
- }
21
- }
22
- set chartData(value) {
23
- this._chartData = value;
24
- if (this.chart) {
25
- this.chart.data = this._chartData;
26
- this.chart.update();
27
- }
28
- }
29
- set chartOptions(value) {
30
- this._chartOptions = value;
31
- if (this.chart) {
32
- this.chart.options = this.chartOptions;
33
- this.chart.update();
34
- }
17
+ set chartConfig(value) {
18
+ this._chartConfig = value;
19
+ this.isChartDataAvailable = this._chartConfig.chartData.datasets.length > 0;
35
20
  }
36
21
  //for testing hover state on dataset
37
22
  set isDatasetHovered(value) {
@@ -41,37 +26,39 @@ export class CaChartComponent {
41
26
  }
42
27
  }
43
28
  constructor() {
44
- this.chartHeight = 500;
45
29
  this.originalChartDataset = CaBaseChartDatasetConfig.getBaseChartDatasetConfig();
30
+ this.isChartDataAvailable = true;
46
31
  }
47
32
  ngAfterViewInit() {
48
- this.createChart();
33
+ if (this.isChartDataAvailable)
34
+ this.createChart();
49
35
  }
50
36
  updateDatasetBackgroundOnHover(dataSetLabel, color, isDatasetHovered) {
51
37
  if (isDatasetHovered) {
52
- this.originalChartDataset = JSON.parse(JSON.stringify(this._chartData.datasets));
38
+ this.originalChartDataset = JSON.parse(JSON.stringify(this._chartConfig.chartData.datasets));
53
39
  const gradient = ChartHelper.createGradient(this.chartContext, this.chartCanvas, color, color);
54
- this._chartData.datasets = this._chartData.datasets.map((dataset) => {
55
- if (dataset.label === dataSetLabel) {
56
- return {
57
- ...dataset,
58
- fill: true,
59
- backgroundColor: gradient,
60
- borderColor: color,
61
- };
62
- }
63
- else {
64
- const borderColorWithOpacity = ChartHelper.rgbToRgba(dataset.borderColor, 0.2);
65
- return {
66
- ...dataset,
67
- fill: false,
68
- borderColor: borderColorWithOpacity,
69
- };
70
- }
71
- });
40
+ this._chartConfig.chartData.datasets =
41
+ this._chartConfig.chartData.datasets.map((dataset) => {
42
+ if (dataset.label === dataSetLabel) {
43
+ return {
44
+ ...dataset,
45
+ fill: true,
46
+ backgroundColor: gradient,
47
+ borderColor: color,
48
+ };
49
+ }
50
+ else {
51
+ const borderColorWithOpacity = ChartHelper.rgbToRgba(dataset.borderColor, 0.2);
52
+ return {
53
+ ...dataset,
54
+ fill: false,
55
+ borderColor: borderColorWithOpacity,
56
+ };
57
+ }
58
+ });
72
59
  }
73
60
  else
74
- this._chartData.datasets = JSON.parse(JSON.stringify(this.originalChartDataset));
61
+ this._chartConfig.chartData.datasets = JSON.parse(JSON.stringify(this.originalChartDataset));
75
62
  this.chart.update();
76
63
  }
77
64
  createChart() {
@@ -80,14 +67,14 @@ export class CaChartComponent {
80
67
  this.setChartDataProperties();
81
68
  this.setChartPluginsProperties();
82
69
  this.chart = new Chart(this.chartContext, {
83
- type: this._chartType,
84
- data: this._chartData,
85
- options: this._chartOptions,
70
+ type: this._chartConfig.chartType,
71
+ data: this._chartConfig.chartData,
72
+ options: this._chartConfig.chartOptions,
86
73
  plugins: this.plugins,
87
74
  });
88
75
  }
89
76
  setChartOptionsProperties() {
90
- this._chartOptions = {
77
+ this._chartConfig.chartOptions = {
91
78
  responsive: true,
92
79
  maintainAspectRatio: false,
93
80
  clip: false,
@@ -112,23 +99,23 @@ export class CaChartComponent {
112
99
  };
113
100
  }
114
101
  setChartDataProperties() {
115
- if ((this._chartType = ChartTypesStringEnum.LINE)) {
116
- this._chartData.datasets.forEach((dataset) => {
102
+ if ((this._chartConfig.chartType = "line" /* ChartTypesStringEnum.LINE */)) {
103
+ this._chartConfig.chartData.datasets.forEach((dataset) => {
117
104
  if (ChartTypeGuard.isLineDataset(dataset)) {
118
105
  dataset.tension = dataset.tension ?? 0.5;
119
106
  dataset.cubicInterpolationMode =
120
107
  dataset.cubicInterpolationMode ??
121
108
  CubicInterpolationStringEnum.MONOTONE;
122
109
  dataset.pointBorderColor =
123
- dataset.pointBorderColor ?? ChartColorsStringEnum.TRANSPARENT;
110
+ dataset.pointBorderColor ?? "transparent" /* ChartColorsStringEnum.TRANSPARENT */;
124
111
  dataset.pointBackgroundColor =
125
- dataset.pointBackgroundColor ?? ChartColorsStringEnum.TRANSPARENT;
112
+ dataset.pointBackgroundColor ?? "transparent" /* ChartColorsStringEnum.TRANSPARENT */;
126
113
  dataset.pointBorderWidth = dataset.pointBorderWidth ?? 2;
127
114
  dataset.spanGaps = dataset.spanGaps ?? false;
128
115
  dataset.showLine = dataset.showLine ?? true;
129
116
  }
130
117
  });
131
- this.setMultipleYAxis(this._chartData);
118
+ this.setMultipleYAxis(this._chartConfig.chartData);
132
119
  }
133
120
  }
134
121
  setChartPluginsProperties() {
@@ -138,7 +125,8 @@ export class CaChartComponent {
138
125
  id: ChartPluginIdsStringEnum.HIGHLIGHT_SEGMENT_ON_HOVER,
139
126
  afterEvent: (chart, event) => {
140
127
  const nativeEvent = event.event.native;
141
- if (event.event.type === ChartEventTypesStringEnum.MOUSE_OUT && hoveredIndex !== null) {
128
+ if (event.event.type === ChartEventTypesStringEnum.MOUSE_OUT &&
129
+ hoveredIndex !== null) {
142
130
  hoveredIndex = null;
143
131
  this.chart.draw();
144
132
  return;
@@ -146,8 +134,10 @@ export class CaChartComponent {
146
134
  const mouseHorizontalCoordinate = nativeEvent[ChartEventProperties.X];
147
135
  const xScale = this.chart.scales[ChartEventProperties.X];
148
136
  const tickPositions = ChartHelper.calculateTickPositions(xScale);
149
- const newHoveredIndex = tickPositions.findIndex((tickPos) => mouseHorizontalCoordinate > tickPos - (tickPositions[1] - tickPositions[0]) / 2 &&
150
- mouseHorizontalCoordinate <= tickPos + (tickPositions[1] - tickPositions[0]) / 2);
137
+ const newHoveredIndex = tickPositions.findIndex((tickPos) => mouseHorizontalCoordinate >
138
+ tickPos - (tickPositions[1] - tickPositions[0]) / 2 &&
139
+ mouseHorizontalCoordinate <=
140
+ tickPos + (tickPositions[1] - tickPositions[0]) / 2);
151
141
  if (newHoveredIndex !== hoveredIndex) {
152
142
  hoveredIndex = newHoveredIndex === -1 ? null : newHoveredIndex;
153
143
  this.chart.draw();
@@ -156,7 +146,7 @@ export class CaChartComponent {
156
146
  beforeDraw: () => {
157
147
  if (hoveredIndex !== null) {
158
148
  const { chartArea, scales: { x: xScale }, } = this.chart;
159
- ChartHelper.highlightSegment(this.chartContext, xScale, chartArea, this.chartHeight, hoveredIndex);
149
+ ChartHelper.highlightSegment(this.chartContext, xScale, chartArea, this._chartConfig.height, hoveredIndex);
160
150
  }
161
151
  },
162
152
  },
@@ -164,15 +154,15 @@ export class CaChartComponent {
164
154
  id: ChartPluginIdsStringEnum.HIGHLIGHT_POINT_ON_HOVER,
165
155
  afterDraw: () => {
166
156
  if (hoveredIndex !== null)
167
- ChartHelper.highlightPoint(this.chartContext, this.chart, hoveredIndex, this._chartData);
157
+ ChartHelper.highlightPoint(this.chartContext, this.chart, hoveredIndex, this._chartConfig.chartData);
168
158
  },
169
159
  },
170
160
  ];
171
161
  }
172
162
  setMultipleYAxis(chartData) {
173
163
  chartData.datasets.forEach((dataset, index) => {
174
- if (dataset.type == ChartTypesStringEnum.LINE ||
175
- dataset.type == ChartTypesStringEnum.BAR) {
164
+ if (dataset.type == "line" /* ChartTypesStringEnum.LINE */ ||
165
+ dataset.type == "bar" /* ChartTypesStringEnum.BAR */) {
176
166
  const yAxisID = `y-axis-${index}`;
177
167
  chartData.datasets[index] = {
178
168
  ...dataset,
@@ -183,8 +173,8 @@ export class CaChartComponent {
183
173
  const padding = maxValue * 0.03;
184
174
  const minValueAjusted = padding == 0 ? minValue + 0.1 : 0;
185
175
  const maxValueAjusted = maxValue + padding;
186
- this._chartOptions.scales = {
187
- ...this._chartOptions.scales,
176
+ this._chartConfig.chartOptions.scales = {
177
+ ...this._chartConfig.chartOptions.scales,
188
178
  [yAxisID]: {
189
179
  display: false,
190
180
  beginAtZero: true,
@@ -196,23 +186,17 @@ export class CaChartComponent {
196
186
  });
197
187
  }
198
188
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CaChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
199
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CaChartComponent, isStandalone: true, selector: "app-ca-chart", inputs: { chartHeight: "chartHeight", chartType: "chartType", chartData: "chartData", chartOptions: "chartOptions", isDatasetHovered: "isDatasetHovered" }, viewQueries: [{ propertyName: "chartCanvas", first: true, predicate: ["chartCanvas"], descendants: true }], ngImport: i0, template: "<div [ngStyle]=\"{ height: chartHeight + 'px', width: '100%' }\">\n <canvas #chartCanvas> </canvas>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
189
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CaChartComponent, isStandalone: true, selector: "app-ca-chart", inputs: { chartConfig: "chartConfig", isDatasetHovered: "isDatasetHovered" }, 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=\"no-data-container\"\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 ></svg-icon>\n </div>\n</ng-template>\n", styles: [".no-data-container img{height:100%;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"] }] }); }
200
190
  }
201
191
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CaChartComponent, decorators: [{
202
192
  type: Component,
203
- args: [{ selector: 'app-ca-chart', standalone: true, imports: [CommonModule], template: "<div [ngStyle]=\"{ height: chartHeight + 'px', width: '100%' }\">\n <canvas #chartCanvas> </canvas>\n</div>\n" }]
193
+ 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=\"no-data-container\"\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 ></svg-icon>\n </div>\n</ng-template>\n", styles: [".no-data-container img{height:100%;width:100%}\n"] }]
204
194
  }], ctorParameters: function () { return []; }, propDecorators: { chartCanvas: [{
205
195
  type: ViewChild,
206
196
  args: ['chartCanvas']
207
- }], chartHeight: [{
208
- type: Input
209
- }], chartType: [{
210
- type: Input
211
- }], chartData: [{
212
- type: Input
213
- }], chartOptions: [{
197
+ }], chartConfig: [{
214
198
  type: Input
215
199
  }], isDatasetHovered: [{
216
200
  type: Input
217
201
  }] } });
218
- //# 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  ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport {\n  CategoryScale,\n  Chart,\n  ChartOptions,\n  ChartType,\n  LinearScale,\n  Plugin,\n} from 'chart.js/auto';\nimport { AnyObject } from 'chart.js/dist/types/basic';\n\n//Enum\nimport {\n  ChartColorsStringEnum,\n  ChartEventProperties,\n  ChartPluginIdsStringEnum,\n  ChartTypesStringEnum,\n  CubicInterpolationStringEnum,\n  ChartEventTypesStringEnum\n} from './enums';\n\n//Helpers\nimport { ChartHelper } from './utils/helpers';\n\n//Guards\nimport { ChartTypeGuard } from './utils/guards';\n\n//Models\nimport { IChartData, IBaseDataset, ILineDataset } from './models';\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.css'],\n  standalone: true,\n  imports: [CommonModule],\n})\nexport class CaChartComponent implements AfterViewInit {\n  @ViewChild('chartCanvas') chartCanvas!: ElementRef;\n\n  @Input() chartHeight: number = 500;\n\n  @Input() set chartType(value: ChartType) {\n    this._chartType = value;\n\n    if (this.chart) {\n      this.chart.destroy();\n      this.createChart();\n    }\n  }\n\n  @Input() set chartData(value: IChartData<IBaseDataset>) {\n    this._chartData = value;\n\n    if (this.chart) {\n      this.chart.data = this._chartData;\n      this.chart.update();\n    }\n  }\n\n  @Input() set chartOptions(value: ChartOptions) {\n    this._chartOptions = value;\n\n    if (this.chart) {\n      this.chart.options = this.chartOptions;\n      this.chart.update();\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 _chartType!: ChartType;\n  private _chartData!: IChartData<IBaseDataset>;\n  private _chartOptions!: ChartOptions;\n  private plugins?: Plugin<ChartType, AnyObject>[];\n  private _isDatasetHovered!: boolean;\n  private originalChartDataset =\n    CaBaseChartDatasetConfig.getBaseChartDatasetConfig();\n\n  constructor() {}\n\n  ngAfterViewInit(): void {\n    this.createChart();\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._chartData.datasets)\n      );\n      const gradient = ChartHelper.createGradient(\n        this.chartContext,\n        this.chartCanvas,\n        color,\n        color\n      );\n      this._chartData.datasets = this._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._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._chartType,\n      data: this._chartData,\n      options: this._chartOptions,\n      plugins: this.plugins,\n    });\n  }\n\n  private setChartOptionsProperties(): void {\n    this._chartOptions = {\n      responsive: true,\n      maintainAspectRatio: false,\n      clip: false,\n      plugins: {\n        legend: {\n          display: false,\n        },\n      },\n      scales: {\n        x: {\n          display: false,\n          beginAtZero: true,\n          offset: true,\n        },\n        y: {\n          display: false,\n          beginAtZero: true,\n          min: 0,\n          max: 1,\n        },\n      },\n    };\n  }\n\n  private setChartDataProperties(): void {\n    if ((this._chartType = ChartTypesStringEnum.LINE)) {\n      this._chartData.datasets.forEach((dataset) => {\n        if (ChartTypeGuard.isLineDataset(dataset)) {\n          dataset.tension = dataset.tension ?? 0.5;\n          dataset.cubicInterpolationMode =\n            dataset.cubicInterpolationMode ??\n            CubicInterpolationStringEnum.MONOTONE;\n\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._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          const nativeEvent = event.event.native as MouseEvent;\n\n          if (event.event.type === ChartEventTypesStringEnum.MOUSE_OUT && hoveredIndex !== null) {\n            hoveredIndex = null;\n            this.chart.draw();\n            return;\n          }\n\n          const mouseHorizontalCoordinate = nativeEvent[ChartEventProperties.X];\n          const xScale = this.chart.scales[ChartEventProperties.X] as CategoryScale | LinearScale;\n          const tickPositions = ChartHelper.calculateTickPositions(xScale);\n          const newHoveredIndex = tickPositions.findIndex(\n            (tickPos) =>\n              mouseHorizontalCoordinate > tickPos - (tickPositions[1] - tickPositions[0]) / 2 &&\n            mouseHorizontalCoordinate <= 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.chartHeight,\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._chartData\n            );\n        },\n      },\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 = `y-axis-${index}`;\n        chartData.datasets[index] = {\n          ...dataset,\n          yAxisID,\n        };\n        const minValue = ChartHelper.calculateMinValue(dataset.data);\n        const maxValue = ChartHelper.calculateMaxValue(dataset.data);\n        const padding = maxValue * 0.03;\n        const minValueAjusted = padding == 0 ? minValue + 0.1 : 0;\n        const maxValueAjusted = maxValue + padding;\n\n        this._chartOptions.scales = {\n          ...this._chartOptions.scales,\n          [yAxisID]: {\n            display: false,\n            beginAtZero: true,\n            min: minValueAjusted,\n            max: maxValueAjusted,\n          },\n        };\n      }\n    });\n  }\n}\n","<div [ngStyle]=\"{ height: chartHeight + 'px', width: '100%' }\">\n  <canvas #chartCanvas> </canvas>\n</div>\n"]}
202
+ //# 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  ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport {\n  CategoryScale,\n  Chart,\n  ChartType,\n  LinearScale,\n  Plugin,\n} from 'chart.js/auto';\nimport { AnyObject } from 'chart.js/dist/types/basic';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n//Enums\nimport {\n  ChartColorsStringEnum,\n  ChartEventProperties,\n  ChartPluginIdsStringEnum,\n  ChartTypesStringEnum,\n  CubicInterpolationStringEnum,\n  ChartEventTypesStringEnum,\n} from './enums';\n\n//Helpers\nimport { ChartHelper } from './utils/helpers';\n\n//Guards\nimport { ChartTypeGuard } from './utils/guards';\n\n//Models\nimport { IChartData, ILineDataset, IChartConfiguaration } from './models';\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: IChartConfiguaration) {\n    this._chartConfig = value;\n    this.isChartDataAvailable = this._chartConfig.chartData.datasets.length > 0;\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!: IChartConfiguaration;\n  public isChartDataAvailable: boolean = true;\n\n  constructor() {}\n\n  ngAfterViewInit(): void {\n    if (this.isChartDataAvailable) \n      this.createChart();\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      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\n  private setChartOptionsProperties(): void {\n    this._chartConfig.chartOptions = {\n      responsive: true,\n      maintainAspectRatio: false,\n      clip: false,\n      plugins: {\n        legend: {\n          display: false,\n        },\n      },\n      scales: {\n        x: {\n          display: false,\n          beginAtZero: true,\n          offset: true,\n        },\n        y: {\n          display: false,\n          beginAtZero: true,\n          min: 0,\n          max: 1,\n        },\n      },\n    };\n  }\n\n  private setChartDataProperties(): void {\n    if ((this._chartConfig.chartType = ChartTypesStringEnum.LINE)) {\n      this._chartConfig.chartData.datasets.forEach((dataset) => {\n        if (ChartTypeGuard.isLineDataset(dataset)) {\n          dataset.tension = dataset.tension ?? 0.5;\n          dataset.cubicInterpolationMode =\n            dataset.cubicInterpolationMode ??\n            CubicInterpolationStringEnum.MONOTONE;\n\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          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[ChartEventProperties.X];\n          const xScale = this.chart.scales[ChartEventProperties.X] as\n            | CategoryScale\n            | LinearScale;\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 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 = `y-axis-${index}`;\n        chartData.datasets[index] = {\n          ...dataset,\n          yAxisID,\n        };\n        const minValue = ChartHelper.calculateMinValue(dataset.data);\n        const maxValue = ChartHelper.calculateMaxValue(dataset.data);\n        const padding = maxValue * 0.03;\n        const minValueAjusted = padding == 0 ? minValue + 0.1 : 0;\n        const maxValueAjusted = maxValue + padding;\n\n        this._chartConfig.chartOptions.scales = {\n          ...this._chartConfig.chartOptions.scales,\n          [yAxisID]: {\n            display: false,\n            beginAtZero: true,\n            min: minValueAjusted,\n            max: maxValueAjusted,\n          },\n        };\n      }\n    });\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=\"no-data-container\"\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    ></svg-icon>\n  </div>\n</ng-template>\n"]}
@@ -1,11 +1,10 @@
1
- import { ChartTypesStringEnum } from '../enums';
2
1
  export class CaBaseChartDatasetConfig {
3
2
  static getBaseChartDatasetConfig() {
4
3
  return {
5
- type: ChartTypesStringEnum.LINE,
4
+ type: "line" /* ChartTypesStringEnum.LINE */,
6
5
  label: '',
7
6
  data: [],
8
7
  };
9
8
  }
10
9
  }
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2EtYmFzZS1jaGFydC1kYXRhc2V0LmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWNoYXJ0L2NvbmZpZy9jYS1iYXNlLWNoYXJ0LWRhdGFzZXQuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUdoRCxNQUFNLE9BQU8sd0JBQXdCO0lBQ25DLE1BQU0sQ0FBQyx5QkFBeUI7UUFDOUIsT0FBTztZQUNMLElBQUksRUFBRSxvQkFBb0IsQ0FBQyxJQUFJO1lBQy9CLEtBQUssRUFBRSxFQUFFO1lBQ1QsSUFBSSxFQUFFLEVBQUU7U0FDVCxDQUFDO0lBQ0osQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhcnRUeXBlc1N0cmluZ0VudW0gfSBmcm9tICcuLi9lbnVtcyc7XG5pbXBvcnQgeyBJQmFzZURhdGFzZXQgfSBmcm9tICcuLi9tb2RlbHMnO1xuXG5leHBvcnQgY2xhc3MgQ2FCYXNlQ2hhcnREYXRhc2V0Q29uZmlnIHtcbiAgc3RhdGljIGdldEJhc2VDaGFydERhdGFzZXRDb25maWcoKTogSUJhc2VEYXRhc2V0IHtcbiAgICByZXR1cm4ge1xuICAgICAgdHlwZTogQ2hhcnRUeXBlc1N0cmluZ0VudW0uTElORSxcbiAgICAgIGxhYmVsOiAnJyxcbiAgICAgIGRhdGE6IFtdLFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2EtYmFzZS1jaGFydC1kYXRhc2V0LmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWNoYXJ0L2NvbmZpZy9jYS1iYXNlLWNoYXJ0LWRhdGFzZXQuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE1BQU0sT0FBTyx3QkFBd0I7SUFDbkMsTUFBTSxDQUFDLHlCQUF5QjtRQUM5QixPQUFPO1lBQ0wsSUFBSSx3Q0FBMkI7WUFDL0IsS0FBSyxFQUFFLEVBQUU7WUFDVCxJQUFJLEVBQUUsRUFBRTtTQUNULENBQUM7SUFDSixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFydFR5cGVzU3RyaW5nRW51bSB9IGZyb20gJy4uL2VudW1zJztcbmltcG9ydCB7IElCYXNlRGF0YXNldCB9IGZyb20gJy4uL21vZGVscyc7XG5cbmV4cG9ydCBjbGFzcyBDYUJhc2VDaGFydERhdGFzZXRDb25maWcge1xuICBzdGF0aWMgZ2V0QmFzZUNoYXJ0RGF0YXNldENvbmZpZygpOiBJQmFzZURhdGFzZXQge1xuICAgIHJldHVybiB7XG4gICAgICB0eXBlOiBDaGFydFR5cGVzU3RyaW5nRW51bS5MSU5FLFxuICAgICAgbGFiZWw6ICcnLFxuICAgICAgZGF0YTogW10sXG4gICAgfTtcbiAgfVxufVxuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtY29sb3JzLmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1jaGFydC9lbnVtcy9jaGFydC1jb2xvcnMuZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGVudW0gQ2hhcnRDb2xvcnNTdHJpbmdFbnVtIHtcbiAgV0hJVEUgPSAnI0ZGRkZGRicsXG4gIEhPVkVSX1NFR01FTlQgPSAnI0VFRUVFRScsXG4gIFRSQU5TUEFSRU5UID0gJ3RyYW5zcGFyZW50Jyxcbn1cbiJdfQ==
@@ -2,4 +2,4 @@ export var ChartEventProperties;
2
2
  (function (ChartEventProperties) {
3
3
  ChartEventProperties["X"] = "x";
4
4
  })(ChartEventProperties || (ChartEventProperties = {}));
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtZXZlbnQtcHJvcGVydGllcy1lbnVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtY2hhcnQvZW51bXMvY2hhcnQtZXZlbnQtcHJvcGVydGllcy1lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLG9CQUVYO0FBRkQsV0FBWSxvQkFBb0I7SUFDNUIsK0JBQU8sQ0FBQTtBQUNYLENBQUMsRUFGVyxvQkFBb0IsS0FBcEIsb0JBQW9CLFFBRS9CIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gQ2hhcnRFdmVudFByb3BlcnRpZXMge1xuICAgIFggPSAneCcsXG59Il19
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtZXZlbnQtcHJvcGVydGllcy5lbnVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtY2hhcnQvZW51bXMvY2hhcnQtZXZlbnQtcHJvcGVydGllcy5lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLG9CQUVYO0FBRkQsV0FBWSxvQkFBb0I7SUFDNUIsK0JBQU8sQ0FBQTtBQUNYLENBQUMsRUFGVyxvQkFBb0IsS0FBcEIsb0JBQW9CLFFBRS9CIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gQ2hhcnRFdmVudFByb3BlcnRpZXMge1xuICAgIFggPSAneCcsXG59Il19
@@ -2,4 +2,4 @@ export var ChartEventTypesStringEnum;
2
2
  (function (ChartEventTypesStringEnum) {
3
3
  ChartEventTypesStringEnum["MOUSE_OUT"] = "mouseout";
4
4
  })(ChartEventTypesStringEnum || (ChartEventTypesStringEnum = {}));
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtZXZlbnQtdHlwZXMtZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWNoYXJ0L2VudW1zL2NoYXJ0LWV2ZW50LXR5cGVzLWVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVkseUJBRVg7QUFGRCxXQUFZLHlCQUF5QjtJQUNqQyxtREFBc0IsQ0FBQTtBQUMxQixDQUFDLEVBRlcseUJBQXlCLEtBQXpCLHlCQUF5QixRQUVwQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIENoYXJ0RXZlbnRUeXBlc1N0cmluZ0VudW0ge1xuICAgIE1PVVNFX09VVCA9ICdtb3VzZW91dCdcbn0iXX0=
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtZXZlbnQtdHlwZXMuZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWNoYXJ0L2VudW1zL2NoYXJ0LWV2ZW50LXR5cGVzLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVkseUJBRVg7QUFGRCxXQUFZLHlCQUF5QjtJQUNqQyxtREFBc0IsQ0FBQTtBQUMxQixDQUFDLEVBRlcseUJBQXlCLEtBQXpCLHlCQUF5QixRQUVwQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIENoYXJ0RXZlbnRUeXBlc1N0cmluZ0VudW0ge1xuICAgIE1PVVNFX09VVCA9ICdtb3VzZW91dCdcbn0iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtaW1hZ2VzLmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1jaGFydC9lbnVtcy9jaGFydC1pbWFnZXMuZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGVudW0gQ2hhcnRJbWFnZXNTdHJpbmdFbnVtIHtcbiAgQ0hBUlRfTk9fREFUQV9HUkVFTiA9ICdhc3NldHMvY2EtY29tcG9uZW50cy9zdmcvY2hhcnQvY2hhcnRfbm9fZGF0YV9ncmVlbi5zdmcnLFxuICBDSEFSVF9OT19EQVRBX1lFTExPVyA9ICdhc3NldHMvY2EtY29tcG9uZW50cy9zdmcvY2hhcnQvY2hhcnRfbm9fZGF0YV95ZWxsb3cuc3ZnJyxcbiAgQ0hBUlRfTk9fREFUQV9QQVkgPSAnYXNzZXRzL2NhLWNvbXBvbmVudHMvc3ZnL2NoYXJ0L2NoYXJ0X25vX2RhdGFfcGF5LnN2ZycsXG4gIENIQVJUX05PX0RBVEFfU1RBQ0tFRCA9ICdhc3NldHMvY2EtY29tcG9uZW50cy9zdmcvY2hhcnQvY2hhcnRfbm9fZGF0YV9zdGFja2VkLnN2ZycsXG4gIENIQVJUX05PX0RBVEFfTUlYRUQgPSAnYXNzZXRzL2NhLWNvbXBvbmVudHMvc3ZnL2NoYXJ0L2NoYXJ0X25vX2RhdGFfbWl4ZWQuc3ZnJ1xufVxuIl19
@@ -3,4 +3,4 @@ export var ChartPluginIdsStringEnum;
3
3
  ChartPluginIdsStringEnum["HIGHLIGHT_SEGMENT_ON_HOVER"] = "highlightSegmentOnHover";
4
4
  ChartPluginIdsStringEnum["HIGHLIGHT_POINT_ON_HOVER"] = "highlightPointOnHover";
5
5
  })(ChartPluginIdsStringEnum || (ChartPluginIdsStringEnum = {}));
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtcGx1Z2luLWlkcy1lbnVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtY2hhcnQvZW51bXMvY2hhcnQtcGx1Z2luLWlkcy1lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLHdCQUdUO0FBSEgsV0FBWSx3QkFBd0I7SUFDaEMsa0ZBQXNELENBQUE7SUFDdEQsOEVBQWtELENBQUE7QUFDcEQsQ0FBQyxFQUhTLHdCQUF3QixLQUF4Qix3QkFBd0IsUUFHakMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBDaGFydFBsdWdpbklkc1N0cmluZ0VudW0ge1xuICAgIEhJR0hMSUdIVF9TRUdNRU5UX09OX0hPVkVSID0gJ2hpZ2hsaWdodFNlZ21lbnRPbkhvdmVyJyxcbiAgICBISUdITElHSFRfUE9JTlRfT05fSE9WRVIgPSAnaGlnaGxpZ2h0UG9pbnRPbkhvdmVyJ1xuICB9Il19
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtcGx1Z2luLWlkcy5lbnVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtY2hhcnQvZW51bXMvY2hhcnQtcGx1Z2luLWlkcy5lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLHdCQUdUO0FBSEgsV0FBWSx3QkFBd0I7SUFDaEMsa0ZBQXNELENBQUE7SUFDdEQsOEVBQWtELENBQUE7QUFDcEQsQ0FBQyxFQUhTLHdCQUF3QixLQUF4Qix3QkFBd0IsUUFHakMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBDaGFydFBsdWdpbklkc1N0cmluZ0VudW0ge1xuICAgIEhJR0hMSUdIVF9TRUdNRU5UX09OX0hPVkVSID0gJ2hpZ2hsaWdodFNlZ21lbnRPbkhvdmVyJyxcbiAgICBISUdITElHSFRfUE9JTlRfT05fSE9WRVIgPSAnaGlnaGxpZ2h0UG9pbnRPbkhvdmVyJ1xuICB9Il19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtdHlwZXMuZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWNoYXJ0L2VudW1zL2NoYXJ0LXR5cGVzLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBlbnVtIENoYXJ0VHlwZXNTdHJpbmdFbnVtIHtcbiAgTElORSA9ICdsaW5lJyxcbiAgQkFSID0gJ2JhcicsXG4gIERPVUdITlVUID0gJ2RvdWdobnV0Jyxcbn1cbiJdfQ==
@@ -3,4 +3,4 @@ export var CubicInterpolationStringEnum;
3
3
  CubicInterpolationStringEnum["DEFAULT"] = "default";
4
4
  CubicInterpolationStringEnum["MONOTONE"] = "monotone";
5
5
  })(CubicInterpolationStringEnum || (CubicInterpolationStringEnum = {}));
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3ViaWMtaW50ZXJwb2xhdGlvbi1tb2RlLWVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1jaGFydC9lbnVtcy9jdWJpYy1pbnRlcnBvbGF0aW9uLW1vZGUtZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSw0QkFHWDtBQUhELFdBQVksNEJBQTRCO0lBQ3RDLG1EQUFtQixDQUFBO0lBQ25CLHFEQUFxQixDQUFBO0FBQ3ZCLENBQUMsRUFIVyw0QkFBNEIsS0FBNUIsNEJBQTRCLFFBR3ZDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gQ3ViaWNJbnRlcnBvbGF0aW9uU3RyaW5nRW51bSB7XG4gIERFRkFVTFQgPSAnZGVmYXVsdCcsXG4gIE1PTk9UT05FID0gJ21vbm90b25lJyxcbn1cbiJdfQ==
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3ViaWMtaW50ZXJwb2xhdGlvbi1tb2RlLmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1jaGFydC9lbnVtcy9jdWJpYy1pbnRlcnBvbGF0aW9uLW1vZGUuZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSw0QkFHWDtBQUhELFdBQVksNEJBQTRCO0lBQ3RDLG1EQUFtQixDQUFBO0lBQ25CLHFEQUFxQixDQUFBO0FBQ3ZCLENBQUMsRUFIVyw0QkFBNEIsS0FBNUIsNEJBQTRCLFFBR3ZDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gQ3ViaWNJbnRlcnBvbGF0aW9uU3RyaW5nRW51bSB7XG4gIERFRkFVTFQgPSAnZGVmYXVsdCcsXG4gIE1PTk9UT05FID0gJ21vbm90b25lJyxcbn1cbiJdfQ==
@@ -1,7 +1,8 @@
1
- export * from './chart-types-enum';
2
- export * from './cubic-interpolation-mode-enum';
3
- export * from './chart-colors-enum';
4
- export * from './chart-plugin-ids-enum';
5
- export * from './chart-event-types-enum';
6
- export * from './chart-event-properties-enum';
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1jaGFydC9lbnVtcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYywrQkFBK0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2hhcnQtdHlwZXMtZW51bSc7XG5leHBvcnQgKiBmcm9tICcuL2N1YmljLWludGVycG9sYXRpb24tbW9kZS1lbnVtJztcbmV4cG9ydCAqIGZyb20gJy4vY2hhcnQtY29sb3JzLWVudW0nO1xuZXhwb3J0ICogZnJvbSAnLi9jaGFydC1wbHVnaW4taWRzLWVudW0nO1xuZXhwb3J0ICogZnJvbSAnLi9jaGFydC1ldmVudC10eXBlcy1lbnVtJztcbmV4cG9ydCAqIGZyb20gJy4vY2hhcnQtZXZlbnQtcHJvcGVydGllcy1lbnVtJztcbiJdfQ==
1
+ export * from './chart-types.enum';
2
+ export * from './cubic-interpolation-mode.enum';
3
+ export * from './chart-colors.enum';
4
+ export * from './chart-plugin-ids.enum';
5
+ export * from './chart-event-types.enum';
6
+ export * from './chart-event-properties.enum';
7
+ export * from './chart-images.enum';
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1jaGFydC9lbnVtcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHFCQUFxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jaGFydC10eXBlcy5lbnVtJztcbmV4cG9ydCAqIGZyb20gJy4vY3ViaWMtaW50ZXJwb2xhdGlvbi1tb2RlLmVudW0nO1xuZXhwb3J0ICogZnJvbSAnLi9jaGFydC1jb2xvcnMuZW51bSc7XG5leHBvcnQgKiBmcm9tICcuL2NoYXJ0LXBsdWdpbi1pZHMuZW51bSc7XG5leHBvcnQgKiBmcm9tICcuL2NoYXJ0LWV2ZW50LXR5cGVzLmVudW0nO1xuZXhwb3J0ICogZnJvbSAnLi9jaGFydC1ldmVudC1wcm9wZXJ0aWVzLmVudW0nO1xuZXhwb3J0ICogZnJvbSAnLi9jaGFydC1pbWFnZXMuZW51bSc7XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtY29uZmlnLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtY2hhcnQvbW9kZWxzL2NoYXJ0LWNvbmZpZy5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhcnRPcHRpb25zLCBDaGFydFR5cGUgfSBmcm9tICdjaGFydC5qcyc7XG5pbXBvcnQgeyBJQmFzZURhdGFzZXQsIElDaGFydERhdGEgfSBmcm9tICcuLi9tb2RlbHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElDaGFydENvbmZpZ3VhcmF0aW9uIHtcbiAgY2hhcnRUeXBlOiBDaGFydFR5cGU7XG4gIGNoYXJ0RGF0YTogSUNoYXJ0RGF0YTxJQmFzZURhdGFzZXQ+O1xuICBjaGFydE9wdGlvbnM6IENoYXJ0T3B0aW9ucztcbiAgaGVpZ2h0OiBudW1iZXI7XG4gIHdpZHRoOiBudW1iZXI7XG4gIG5vRGF0YUltYWdlOiBzdHJpbmc7XG59XG4iXX0=
@@ -1,4 +1,5 @@
1
1
  export * from './chart-data.model';
2
2
  export * from './chart-base-dataset.model';
3
3
  export * from './chart-line-dataset.model';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1jaGFydC9tb2RlbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsNEJBQTRCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NoYXJ0LWRhdGEubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9jaGFydC1iYXNlLWRhdGFzZXQubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9jaGFydC1saW5lLWRhdGFzZXQubW9kZWwnO1xuIl19
4
+ export * from './chart-config.model';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1jaGFydC9tb2RlbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxzQkFBc0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2hhcnQtZGF0YS5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2NoYXJ0LWJhc2UtZGF0YXNldC5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2NoYXJ0LWxpbmUtZGF0YXNldC5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2NoYXJ0LWNvbmZpZy5tb2RlbCc7Il19
@@ -1,8 +1,7 @@
1
- import { ChartTypesStringEnum } from '../../enums';
2
1
  export class ChartTypeGuard {
3
2
  static isLineDataset(dataset) {
4
- const isLineDataset = dataset.type === ChartTypesStringEnum.LINE;
3
+ const isLineDataset = dataset.type === "line" /* ChartTypesStringEnum.LINE */;
5
4
  return isLineDataset;
6
5
  }
7
6
  }
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtdHlwZS5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWNoYXJ0L3V0aWxzL2d1YXJkcy9jaGFydC10eXBlLmd1YXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUduRCxNQUFNLE9BQU8sY0FBYztJQUN6QixNQUFNLENBQUMsYUFBYSxDQUFDLE9BQXFCO1FBQ3hDLE1BQU0sYUFBYSxHQUFHLE9BQU8sQ0FBQyxJQUFJLEtBQUssb0JBQW9CLENBQUMsSUFBSSxDQUFDO1FBRWpFLE9BQU8sYUFBYSxDQUFDO0lBQ3ZCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYXJ0VHlwZXNTdHJpbmdFbnVtIH0gZnJvbSAnLi4vLi4vZW51bXMnO1xuaW1wb3J0IHsgSUJhc2VEYXRhc2V0LCBJTGluZURhdGFzZXQgfSBmcm9tICcuLi8uLi9tb2RlbHMnO1xuXG5leHBvcnQgY2xhc3MgQ2hhcnRUeXBlR3VhcmQge1xuICBzdGF0aWMgaXNMaW5lRGF0YXNldChkYXRhc2V0OiBJQmFzZURhdGFzZXQpOiBkYXRhc2V0IGlzIElMaW5lRGF0YXNldCB7XG4gICAgY29uc3QgaXNMaW5lRGF0YXNldCA9IGRhdGFzZXQudHlwZSA9PT0gQ2hhcnRUeXBlc1N0cmluZ0VudW0uTElORTtcblxuICAgIHJldHVybiBpc0xpbmVEYXRhc2V0O1xuICB9XG59XG4iXX0=
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtdHlwZS5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWNoYXJ0L3V0aWxzL2d1YXJkcy9jaGFydC10eXBlLmd1YXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE1BQU0sT0FBTyxjQUFjO0lBQ3pCLE1BQU0sQ0FBQyxhQUFhLENBQUMsT0FBcUI7UUFDeEMsTUFBTSxhQUFhLEdBQUcsT0FBTyxDQUFDLElBQUksMkNBQThCLENBQUM7UUFFakUsT0FBTyxhQUFhLENBQUM7SUFDdkIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhcnRUeXBlc1N0cmluZ0VudW0gfSBmcm9tICcuLi8uLi9lbnVtcyc7XG5pbXBvcnQgeyBJQmFzZURhdGFzZXQsIElMaW5lRGF0YXNldCB9IGZyb20gJy4uLy4uL21vZGVscyc7XG5cbmV4cG9ydCBjbGFzcyBDaGFydFR5cGVHdWFyZCB7XG4gIHN0YXRpYyBpc0xpbmVEYXRhc2V0KGRhdGFzZXQ6IElCYXNlRGF0YXNldCk6IGRhdGFzZXQgaXMgSUxpbmVEYXRhc2V0IHtcbiAgICBjb25zdCBpc0xpbmVEYXRhc2V0ID0gZGF0YXNldC50eXBlID09PSBDaGFydFR5cGVzU3RyaW5nRW51bS5MSU5FO1xuXG4gICAgcmV0dXJuIGlzTGluZURhdGFzZXQ7XG4gIH1cbn1cbiJdfQ==
@@ -1,4 +1,3 @@
1
- import { ChartColorsStringEnum } from '../../enums';
2
1
  export class ChartHelper {
3
2
  static hexToRgba(colorHex, opacity = 1) {
4
3
  colorHex = colorHex.replace(/^#/, '');
@@ -47,7 +46,7 @@ export class ChartHelper {
47
46
  const { segmentStart, segmentWidth } = ChartHelper.getSegmentPosition(xScale, index);
48
47
  const borderRadius = 2;
49
48
  ctx.save();
50
- ctx.fillStyle = ChartColorsStringEnum.HOVER_SEGMENT;
49
+ ctx.fillStyle = "#EEEEEE" /* ChartColorsStringEnum.HOVER_SEGMENT */;
51
50
  // Draw segment with border-radius at the top corners
52
51
  ctx.beginPath();
53
52
  ctx.moveTo(segmentStart + borderRadius, chartArea.top);
@@ -69,11 +68,11 @@ export class ChartHelper {
69
68
  ctx.save();
70
69
  ctx.beginPath();
71
70
  ctx.arc(point.x, point.y, 4, 0, 2 * Math.PI);
72
- ctx.fillStyle = ChartColorsStringEnum.WHITE;
71
+ ctx.fillStyle = "#FFFFFF" /* ChartColorsStringEnum.WHITE */;
73
72
  ctx.fill();
74
73
  ctx.lineWidth = 2;
75
74
  ctx.strokeStyle =
76
- dataset.borderColor || ChartColorsStringEnum.TRANSPARENT;
75
+ dataset.borderColor || "transparent" /* ChartColorsStringEnum.TRANSPARENT */;
77
76
  ctx.stroke();
78
77
  ctx.restore();
79
78
  }
@@ -86,4 +85,4 @@ export class ChartHelper {
86
85
  return { segmentStart, segmentWidth };
87
86
  }
88
87
  }
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.helper.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-chart/utils/helpers/chart.helper.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAGpD,MAAM,OAAO,WAAW;IACtB,MAAM,CAAC,SAAS,CAAC,QAAgB,EAAE,UAAkB,CAAC;QACpD,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QAEtC,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;YACzB,QAAQ;iBACL,KAAK,CAAC,EAAE,CAAC;iBACT,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,GAAG,IAAI,CAAC;iBAC1B,IAAI,CAAC,EAAE,CAAC,CAAC;SACb;QAED,MAAM,MAAM,GAAG,QAAQ,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QACtC,MAAM,GAAG,GAAG,CAAC,MAAM,IAAI,EAAE,CAAC,GAAG,GAAG,CAAC;QACjC,MAAM,KAAK,GAAG,CAAC,MAAM,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC;QAClC,MAAM,IAAI,GAAG,MAAM,GAAG,GAAG,CAAC;QAE1B,OAAO,QAAQ,GAAG,KAAK,KAAK,KAAK,IAAI,KAAK,OAAO,GAAG,CAAC;IACvD,CAAC;IAED,MAAM,CAAC,SAAS,CAAC,MAAc,cAAc,EAAE,OAAe;QAC5D,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAEpC,IAAI,SAAS,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;YACvC,MAAM,GAAG,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;YACzB,MAAM,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;YAC3B,MAAM,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;YAE1B,OAAO,QAAQ,GAAG,KAAK,KAAK,KAAK,IAAI,KAAK,OAAO,GAAG,CAAC;SACtD;;YAAM,OAAO,GAAG,CAAC;IACpB,CAAC;IAED,MAAM,CAAC,iBAAiB,CAAC,IAAc;QACrC,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;IAC3B,CAAC;IAED,MAAM,CAAC,iBAAiB,CAAC,IAAc;QACrC,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;IAC3B,CAAC;IAED,MAAM,CAAC,cAAc,CACnB,YAAsC,EACtC,WAAuB,EACvB,MAAc,EACd,MAAc;QAEd,MAAM,QAAQ,GAAG,YAAY,CAAC,oBAAoB,CAChD,CAAC,EACD,CAAC,EACD,CAAC,EACD,WAAW,CAAC,aAAa,CAAC,MAAM,CACjC,CAAC;QAEF,MAAM,OAAO,GAAG,GAAG,CAAC;QACpB,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QACrD,MAAM,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QAClD,QAAQ,CAAC,YAAY,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC;QACvC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC;QAE5C,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,MAAM,CAAC,sBAAsB,CAAC,MAAmC;QAC/D,OAAO,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAa,EAAE,EAAE,CAC3C,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAC9B,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,gBAAgB,CACrB,GAA6B,EAC7B,MAAmC,EACnC,SAAoB,EACpB,WAAmB,EACnB,KAAa;QAEb,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,GAAG,WAAW,CAAC,kBAAkB,CACnE,MAAM,EACN,KAAK,CACN,CAAC;QACF,MAAM,YAAY,GAAG,CAAC,CAAC;QAEvB,GAAG,CAAC,IAAI,EAAE,CAAC;QACX,GAAG,CAAC,SAAS,GAAG,qBAAqB,CAAC,aAAa,CAAC;QAEpD,qDAAqD;QACrD,GAAG,CAAC,SAAS,EAAE,CAAC;QAChB,GAAG,CAAC,MAAM,CAAC,YAAY,GAAG,YAAY,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC;QACvD,GAAG,CAAC,MAAM,CAAC,YAAY,GAAG,YAAY,GAAG,YAAY,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC;QACtE,GAAG,CAAC,KAAK,CACP,YAAY,GAAG,YAAY,EAC3B,SAAS,CAAC,GAAG,EACb,YAAY,GAAG,YAAY,EAC3B,SAAS,CAAC,GAAG,GAAG,YAAY,EAC5B,YAAY,CACb,CAAC;QACF,GAAG,CAAC,MAAM,CAAC,YAAY,GAAG,YAAY,EAAE,WAAW,CAAC,CAAC;QACrD,GAAG,CAAC,MAAM,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;QACtC,GAAG,CAAC,MAAM,CAAC,YAAY,EAAE,SAAS,CAAC,GAAG,GAAG,YAAY,CAAC,CAAC;QACvD,GAAG,CAAC,KAAK,CACP,YAAY,EACZ,SAAS,CAAC,GAAG,EACb,YAAY,GAAG,YAAY,EAC3B,SAAS,CAAC,GAAG,EACb,YAAY,CACb,CAAC;QACF,GAAG,CAAC,SAAS,EAAE,CAAC;QAEhB,GAAG,CAAC,IAAI,EAAE,CAAC;QACX,GAAG,CAAC,OAAO,EAAE,CAAC;IAChB,CAAC;IAED,MAAM,CAAC,cAAc,CACnB,GAA6B,EAC7B,KAAY,EACZ,KAAa,EACb,SAAmC;QAEnC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,EAAE;YACnD,MAAM,IAAI,GAAG,KAAK,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;YAChD,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAE/B,IAAI,KAAK,EAAE;gBACT,GAAG,CAAC,IAAI,EAAE,CAAC;gBACX,GAAG,CAAC,SAAS,EAAE,CAAC;gBAChB,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;gBAC7C,GAAG,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC;gBAC5C,GAAG,CAAC,IAAI,EAAE,CAAC;gBACX,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC;gBAClB,GAAG,CAAC,WAAW;oBACb,OAAO,CAAC,WAAW,IAAI,qBAAqB,CAAC,WAAW,CAAC;gBAC3D,GAAG,CAAC,MAAM,EAAE,CAAC;gBACb,GAAG,CAAC,OAAO,EAAE,CAAC;aACf;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,MAAM,CAAC,kBAAkB,CAC/B,MAAmC,EACnC,KAAa;QAEb,MAAM,aAAa,GAAG,WAAW,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAC;QACjE,MAAM,YAAY,GAAG,aAAa,CAAC,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC,CAAC;QACzD,MAAM,YAAY,GAAG,aAAa,CAAC,KAAK,CAAC,GAAG,YAAY,GAAG,CAAC,CAAC;QAC7D,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC;IACxC,CAAC;CACF","sourcesContent":["import { ElementRef } from '@angular/core';\nimport Chart, {\n  CategoryScale,\n  ChartArea,\n  LinearScale,\n} from 'chart.js/auto';\nimport { ChartColorsStringEnum } from '../../enums';\nimport { IBaseDataset, IChartData } from '../../models';\n\nexport class ChartHelper {\n  static hexToRgba(colorHex: string, opacity: number = 1): string {\n    colorHex = colorHex.replace(/^#/, '');\n\n    if (colorHex.length === 3) {\n      colorHex\n        .split('')\n        .map((char) => char + char)\n        .join('');\n    }\n\n    const bigint = parseInt(colorHex, 16);\n    const red = (bigint >> 16) & 255;\n    const green = (bigint >> 8) & 255;\n    const blue = bigint & 255;\n\n    return `rgba(${red}, ${green}, ${blue}, ${opacity})`;\n  }\n\n  static rgbToRgba(rgb: string = 'rgb(0, 0, 0)', opacity: number): string {\n    const rgbValues = rgb.match(/\\d+/g);\n\n    if (rgbValues && rgbValues.length === 3) {\n      const red = rgbValues[0];\n      const green = rgbValues[1];\n      const blue = rgbValues[2];\n\n      return `rgba(${red}, ${green}, ${blue}, ${opacity})`;\n    } else return rgb;\n  }\n\n  static calculateMinValue(data: number[]): number {\n    return Math.min(...data);\n  }\n\n  static calculateMaxValue(data: number[]): number {\n    return Math.max(...data);\n  }\n\n  static createGradient(\n    chartContext: CanvasRenderingContext2D,\n    chartCanvas: ElementRef,\n    color1: string,\n    color2: string\n  ): CanvasGradient {\n    const gradient = chartContext.createLinearGradient(\n      0,\n      0,\n      0,\n      chartCanvas.nativeElement.height\n    );\n\n    const opacity = 0.4;\n    const fillColorTop = this.hexToRgba(color1, opacity);\n    const fillColorBottom = this.hexToRgba(color2, 0);\n    gradient.addColorStop(0, fillColorTop);\n    gradient.addColorStop(0.8, fillColorBottom);\n\n    return gradient;\n  }\n\n  static calculateTickPositions(xScale: CategoryScale | LinearScale): number[] {\n    return xScale.ticks.map((_, index: number) =>\n      xScale.getPixelForTick(index)\n    );\n  }\n\n  static highlightSegment(\n    ctx: CanvasRenderingContext2D,\n    xScale: CategoryScale | LinearScale,\n    chartArea: ChartArea,\n    chartHeight: number,\n    index: number\n  ): void {\n    const { segmentStart, segmentWidth } = ChartHelper.getSegmentPosition(\n      xScale,\n      index\n    );\n    const borderRadius = 2;\n\n    ctx.save();\n    ctx.fillStyle = ChartColorsStringEnum.HOVER_SEGMENT;\n\n    // Draw segment with border-radius at the top corners\n    ctx.beginPath();\n    ctx.moveTo(segmentStart + borderRadius, chartArea.top);\n    ctx.lineTo(segmentStart + segmentWidth - borderRadius, chartArea.top);\n    ctx.arcTo(\n      segmentStart + segmentWidth,\n      chartArea.top,\n      segmentStart + segmentWidth,\n      chartArea.top + borderRadius,\n      borderRadius\n    );\n    ctx.lineTo(segmentStart + segmentWidth, chartHeight);\n    ctx.lineTo(segmentStart, chartHeight);\n    ctx.lineTo(segmentStart, chartArea.top + borderRadius);\n    ctx.arcTo(\n      segmentStart,\n      chartArea.top,\n      segmentStart + borderRadius,\n      chartArea.top,\n      borderRadius\n    );\n    ctx.closePath();\n\n    ctx.fill();\n    ctx.restore();\n  }\n\n  static highlightPoint(\n    ctx: CanvasRenderingContext2D,\n    chart: Chart,\n    index: number,\n    chartData: IChartData<IBaseDataset>\n  ): void {\n    chartData.datasets.forEach((dataset, datasetIndex) => {\n      const meta = chart.getDatasetMeta(datasetIndex);\n      const point = meta.data[index];\n\n      if (point) {\n        ctx.save();\n        ctx.beginPath();\n        ctx.arc(point.x, point.y, 4, 0, 2 * Math.PI);\n        ctx.fillStyle = ChartColorsStringEnum.WHITE;\n        ctx.fill();\n        ctx.lineWidth = 2;\n        ctx.strokeStyle =\n          dataset.borderColor || ChartColorsStringEnum.TRANSPARENT;\n        ctx.stroke();\n        ctx.restore();\n      }\n    });\n  }\n\n  private static getSegmentPosition(\n    xScale: CategoryScale | LinearScale,\n    index: number\n  ): { segmentStart: number; segmentWidth: number } {\n    const tickPositions = ChartHelper.calculateTickPositions(xScale);\n    const segmentWidth = tickPositions[1] - tickPositions[0];\n    const segmentStart = tickPositions[index] - segmentWidth / 2;\n    return { segmentStart, segmentWidth };\n  }\n}\n"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.helper.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-chart/utils/helpers/chart.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef } from '@angular/core';\nimport Chart, {\n  CategoryScale,\n  ChartArea,\n  LinearScale,\n} from 'chart.js/auto';\nimport { ChartColorsStringEnum } from '../../enums';\nimport { IBaseDataset, IChartData } from '../../models';\n\nexport class ChartHelper {\n  static hexToRgba(colorHex: string, opacity: number = 1): string {\n    colorHex = colorHex.replace(/^#/, '');\n\n    if (colorHex.length === 3) {\n      colorHex\n        .split('')\n        .map((char) => char + char)\n        .join('');\n    }\n\n    const bigint = parseInt(colorHex, 16);\n    const red = (bigint >> 16) & 255;\n    const green = (bigint >> 8) & 255;\n    const blue = bigint & 255;\n\n    return `rgba(${red}, ${green}, ${blue}, ${opacity})`;\n  }\n\n  static rgbToRgba(rgb: string = 'rgb(0, 0, 0)', opacity: number): string {\n    const rgbValues = rgb.match(/\\d+/g);\n\n    if (rgbValues && rgbValues.length === 3) {\n      const red = rgbValues[0];\n      const green = rgbValues[1];\n      const blue = rgbValues[2];\n\n      return `rgba(${red}, ${green}, ${blue}, ${opacity})`;\n    } else return rgb;\n  }\n\n  static calculateMinValue(data: number[]): number {\n    return Math.min(...data);\n  }\n\n  static calculateMaxValue(data: number[]): number {\n    return Math.max(...data);\n  }\n\n  static createGradient(\n    chartContext: CanvasRenderingContext2D,\n    chartCanvas: ElementRef,\n    color1: string,\n    color2: string\n  ): CanvasGradient {\n    const gradient = chartContext.createLinearGradient(\n      0,\n      0,\n      0,\n      chartCanvas.nativeElement.height\n    );\n\n    const opacity = 0.4;\n    const fillColorTop = this.hexToRgba(color1, opacity);\n    const fillColorBottom = this.hexToRgba(color2, 0);\n    gradient.addColorStop(0, fillColorTop);\n    gradient.addColorStop(0.8, fillColorBottom);\n\n    return gradient;\n  }\n\n  static calculateTickPositions(xScale: CategoryScale | LinearScale): number[] {\n    return xScale.ticks.map((_, index: number) =>\n      xScale.getPixelForTick(index)\n    );\n  }\n\n  static highlightSegment(\n    ctx: CanvasRenderingContext2D,\n    xScale: CategoryScale | LinearScale,\n    chartArea: ChartArea,\n    chartHeight: number,\n    index: number\n  ): void {\n    const { segmentStart, segmentWidth } = ChartHelper.getSegmentPosition(\n      xScale,\n      index\n    );\n    const borderRadius = 2;\n\n    ctx.save();\n    ctx.fillStyle = ChartColorsStringEnum.HOVER_SEGMENT;\n\n    // Draw segment with border-radius at the top corners\n    ctx.beginPath();\n    ctx.moveTo(segmentStart + borderRadius, chartArea.top);\n    ctx.lineTo(segmentStart + segmentWidth - borderRadius, chartArea.top);\n    ctx.arcTo(\n      segmentStart + segmentWidth,\n      chartArea.top,\n      segmentStart + segmentWidth,\n      chartArea.top + borderRadius,\n      borderRadius\n    );\n    ctx.lineTo(segmentStart + segmentWidth, chartHeight);\n    ctx.lineTo(segmentStart, chartHeight);\n    ctx.lineTo(segmentStart, chartArea.top + borderRadius);\n    ctx.arcTo(\n      segmentStart,\n      chartArea.top,\n      segmentStart + borderRadius,\n      chartArea.top,\n      borderRadius\n    );\n    ctx.closePath();\n\n    ctx.fill();\n    ctx.restore();\n  }\n\n  static highlightPoint(\n    ctx: CanvasRenderingContext2D,\n    chart: Chart,\n    index: number,\n    chartData: IChartData<IBaseDataset>\n  ): void {\n    chartData.datasets.forEach((dataset, datasetIndex) => {\n      const meta = chart.getDatasetMeta(datasetIndex);\n      const point = meta.data[index];\n\n      if (point) {\n        ctx.save();\n        ctx.beginPath();\n        ctx.arc(point.x, point.y, 4, 0, 2 * Math.PI);\n        ctx.fillStyle = ChartColorsStringEnum.WHITE;\n        ctx.fill();\n        ctx.lineWidth = 2;\n        ctx.strokeStyle =\n          dataset.borderColor || ChartColorsStringEnum.TRANSPARENT;\n        ctx.stroke();\n        ctx.restore();\n      }\n    });\n  }\n\n  private static getSegmentPosition(\n    xScale: CategoryScale | LinearScale,\n    index: number\n  ): { segmentStart: number; segmentWidth: number } {\n    const tickPositions = ChartHelper.calculateTickPositions(xScale);\n    const segmentWidth = tickPositions[1] - tickPositions[0];\n    const segmentStart = tickPositions[index] - segmentWidth / 2;\n    return { segmentStart, segmentWidth };\n  }\n}\n"]}