nuxeo-development-framework 5.4.9 → 5.5.0

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 (48) hide show
  1. package/bundles/nuxeo-development-framework.umd.js +491 -288
  2. package/bundles/nuxeo-development-framework.umd.js.map +1 -1
  3. package/esm2015/lib/components/reports/charts/plugins/data-labels.js +166 -102
  4. package/esm2015/lib/components/reports/charts/utility/colors.js +13 -1
  5. package/esm2015/lib/components/reports/ndf-reports/base/base-chart.js +2 -2
  6. package/esm2015/lib/components/reports/ndf-reports/base/base-custom-report.js +16 -3
  7. package/esm2015/lib/components/reports/ndf-reports/base/base-graph.report.js +10 -22
  8. package/esm2015/lib/components/reports/ndf-reports/base/base-report.js +5 -2
  9. package/esm2015/lib/components/reports/ndf-reports/charts-components/custom-chart/custom-chart.component.js +68 -0
  10. package/esm2015/lib/components/reports/ndf-reports/charts-components/index.js +2 -1
  11. package/esm2015/lib/components/reports/ndf-reports/components/_parts/custom-chart-dialog/custom-chart-dialog.component.js +41 -0
  12. package/esm2015/lib/components/reports/ndf-reports/components/_parts/index.js +2 -1
  13. package/esm2015/lib/components/reports/ndf-reports/components/custom-report/custom-report.component.js +23 -37
  14. package/esm2015/lib/components/reports/ndf-reports/components/dynamic-timeline-report/dynamic-timeline-report.component.js +2 -6
  15. package/esm2015/lib/components/reports/ndf-reports/containers/ndf-report/ndf-report.component.js +4 -3
  16. package/esm2015/lib/components/reports/ndf-reports/containers/ndf-reports/ndf-reports.component.js +2 -2
  17. package/esm2015/lib/components/reports/ndf-reports/models/custom-definition.js +1 -1
  18. package/esm2015/lib/components/reports/ndf-reports/models/dialog-data.js +1 -1
  19. package/esm2015/lib/components/reports/ndf-reports/models/report-config.js +1 -1
  20. package/esm2015/lib/components/reports/ndf-reports/ndf-reports.module.js +5 -3
  21. package/esm2015/lib/components/reports/ndf-reports/public-api.js +2 -1
  22. package/esm2015/lib/components/reports/ndf-reports/services/chart-manager.service.js +15 -9
  23. package/esm2015/lib/components/reports/ndf-reports/services/custom-reports-registry.service.js +1 -1
  24. package/esm2015/lib/components/reports/ndf-reports/services/report-config-mapper.service.js +1 -1
  25. package/esm2015/lib/components/reports/ndf-reports/services/report-transform.service.js +2 -2
  26. package/esm2015/lib/components/reports/ndf-reports/services/reports-dialog.service.js +32 -0
  27. package/fesm2015/nuxeo-development-framework.js +452 -267
  28. package/fesm2015/nuxeo-development-framework.js.map +1 -1
  29. package/lib/components/reports/charts/utility/colors.d.ts +5 -0
  30. package/lib/components/reports/ndf-reports/base/base-chart.d.ts +1 -1
  31. package/lib/components/reports/ndf-reports/base/base-custom-report.d.ts +18 -13
  32. package/lib/components/reports/ndf-reports/base/base-graph.report.d.ts +5 -13
  33. package/lib/components/reports/ndf-reports/base/base-report.d.ts +4 -1
  34. package/lib/components/reports/ndf-reports/charts-components/custom-chart/custom-chart.component.d.ts +15 -0
  35. package/lib/components/reports/ndf-reports/charts-components/index.d.ts +1 -0
  36. package/lib/components/reports/ndf-reports/components/_parts/custom-chart-dialog/custom-chart-dialog.component.d.ts +14 -0
  37. package/lib/components/reports/ndf-reports/components/_parts/index.d.ts +1 -0
  38. package/lib/components/reports/ndf-reports/components/custom-report/custom-report.component.d.ts +8 -10
  39. package/lib/components/reports/ndf-reports/models/custom-definition.d.ts +3 -3
  40. package/lib/components/reports/ndf-reports/models/dialog-data.d.ts +8 -0
  41. package/lib/components/reports/ndf-reports/models/report-config.d.ts +2 -2
  42. package/lib/components/reports/ndf-reports/ndf-reports.module.d.ts +22 -20
  43. package/lib/components/reports/ndf-reports/public-api.d.ts +1 -0
  44. package/lib/components/reports/ndf-reports/services/chart-manager.service.d.ts +2 -2
  45. package/lib/components/reports/ndf-reports/services/custom-reports-registry.service.d.ts +3 -2
  46. package/lib/components/reports/ndf-reports/services/report-config-mapper.service.d.ts +2 -2
  47. package/lib/components/reports/ndf-reports/services/reports-dialog.service.d.ts +21 -0
  48. package/package.json +2 -2
@@ -1,144 +1,208 @@
1
1
  import { getColor, getTextColor } from '../utility';
2
+ // Configuration constants
3
+ const LABEL_CONFIG = {
4
+ minFontSize: 10,
5
+ maxFontSize: 16,
6
+ defaultFontSize: 12,
7
+ textPadding: 8,
8
+ minAngleForPieLabel: 0.3,
9
+ arcRadiusMultiplier: {
10
+ pie: 0.7,
11
+ doughnut: 0.8
12
+ },
13
+ fontSizeCalculation: {
14
+ percentageDivisor: 3,
15
+ maxPercentageForFontSize: 20
16
+ }
17
+ };
18
+ // Main plugin
2
19
  export const chartDataLabels = {
3
20
  id: 'chartDataLabels',
4
21
  afterDatasetsDraw(chart, args, plugins) {
5
22
  var _a;
6
23
  const { ctx } = chart;
7
24
  ctx.save();
8
- switch ((_a = chart.config) === null || _a === void 0 ? void 0 : _a.type) {
9
- case 'bar':
10
- barChartLabels(chart);
11
- break;
12
- case 'pie':
13
- pieChartLabels(chart);
14
- break;
15
- case 'doughnut':
16
- doughnutChartLabels(chart);
17
- break;
25
+ const chartType = (_a = chart.config) === null || _a === void 0 ? void 0 : _a.type;
26
+ const renderer = getChartRenderer(chartType);
27
+ if (renderer) {
28
+ renderer(chart);
18
29
  }
19
30
  ctx.restore();
20
31
  }
21
32
  };
33
+ // Chart type router
34
+ function getChartRenderer(chartType) {
35
+ const renderers = {
36
+ bar: barChartLabels,
37
+ pie: pieChartLabels,
38
+ doughnut: doughnutChartLabels
39
+ };
40
+ return renderers[chartType];
41
+ }
42
+ // Core utility functions
43
+ function calculatePercentage(value, total) {
44
+ return total > 0 ? (value / total) * 100 : 0;
45
+ }
46
+ function calculateFontSize(percentage) {
47
+ const { percentageDivisor, maxPercentageForFontSize } = LABEL_CONFIG.fontSizeCalculation;
48
+ const calculatedSize = Math.min(percentage / percentageDivisor, maxPercentageForFontSize);
49
+ return Math.max(LABEL_CONFIG.minFontSize, Math.min(calculatedSize, LABEL_CONFIG.maxFontSize));
50
+ }
51
+ function getTextMetrics(ctx, text, fontSize) {
52
+ ctx.font = `normal ${fontSize}px sans-serif`;
53
+ const metrics = ctx.measureText(text);
54
+ const height = metrics.actualBoundingBoxAscent + metrics.actualBoundingBoxDescent || LABEL_CONFIG.defaultFontSize;
55
+ return {
56
+ width: metrics.width,
57
+ height
58
+ };
59
+ }
60
+ function prepareCanvasForText(ctx, fontSize, color) {
61
+ ctx.font = `bold ${fontSize}px sans-serif`;
62
+ ctx.textAlign = 'center';
63
+ ctx.textBaseline = 'middle';
64
+ ctx.fillStyle = color;
65
+ }
66
+ function extractLabelData(dataset, index, totalSum, chart) {
67
+ const value = dataset.data[index];
68
+ const percentage = calculatePercentage(value, totalSum);
69
+ const isVisible = chart.getDataVisibility(index);
70
+ if (!percentage || !isVisible) {
71
+ return null;
72
+ }
73
+ return {
74
+ text: `${percentage.toFixed(1)}%`,
75
+ percentage,
76
+ backgroundColor: Array.isArray(dataset.backgroundColor) ? dataset.backgroundColor[index] : dataset.backgroundColor,
77
+ isVisible
78
+ };
79
+ }
80
+ // Bar chart implementation
22
81
  function barChartLabels(chart) {
23
82
  var _a;
24
- const { ctx, data } = chart;
83
+ const { ctx } = chart;
25
84
  const isHorizontalChart = ((_a = chart.options) === null || _a === void 0 ? void 0 : _a.indexAxis) === 'y';
26
- const { isHorizontalReversed } = isBarChartReversed(chart);
85
+ const { isHorizontalReversed } = getBarChartOrientation(chart);
27
86
  chart.data.datasets.forEach((dataset, datasetIndex) => {
28
87
  const meta = chart.getDatasetMeta(datasetIndex);
29
- const totalSum = dataset.data.reduce((sum, currentValue) => sum + currentValue, 0);
88
+ const totalSum = dataset.data.reduce((sum, value) => sum + value, 0);
30
89
  meta.data.forEach((dataPoint, index) => {
31
90
  if (!dataPoint)
32
91
  return;
33
- const percentage = (dataset.data[index] / totalSum) * 100;
34
- const isVisible = chart.getDataVisibility(index);
35
- if (!percentage || !isVisible) {
92
+ const labelData = extractLabelData(dataset, index, totalSum, chart);
93
+ if (!labelData)
36
94
  return;
37
- }
38
- const bgColor = dataset.backgroundColor[index];
39
- const textColor = getTextColor(bgColor);
40
- const fontSize = Math.max(12, Math.min(percentage / 2, 14));
41
- ctx.textAlign = 'center';
42
- ctx.textBaseline = 'middle';
43
- ctx.font = `normal ${fontSize}px sans-serif`;
44
- ctx.fillStyle = textColor;
45
- const text = `${percentage.toFixed()}%`;
46
- const { width, height } = getTextMetrics(ctx, text);
47
- const textHeight = height || 12;
48
- const textWidth = width || 30;
49
- if (isHorizontalChart) {
50
- if ((dataPoint === null || dataPoint === void 0 ? void 0 : dataPoint.width) > 0) {
51
- const textPadding = 20;
52
- const offset = textPadding + textWidth <= dataPoint.width ? textWidth : textWidth >= dataPoint.width ? 0 : 10;
53
- const x = dataPoint.x + (isHorizontalReversed ? offset : -offset);
54
- ctx.fillStyle = dataPoint.width <= textWidth ? getColor('--chart-value-default-color', '#000') : textColor;
55
- if (percentage) {
56
- ctx.fillText(text, x, dataPoint.y);
57
- }
58
- }
59
- }
60
- else {
61
- if ((dataPoint === null || dataPoint === void 0 ? void 0 : dataPoint.height) > 0) {
62
- const y = textHeight >= dataPoint.height ? dataPoint.y - 10 : dataPoint.y + 10;
63
- ctx.fillStyle = textHeight >= dataPoint.height ? getColor('--chart-value-default-color', '#000') : textColor;
64
- if (!percentage) {
65
- return;
66
- }
67
- ctx.fillText(text, dataPoint.x, y);
68
- }
95
+ const fontSize = calculateFontSize(labelData.percentage);
96
+ const textMetrics = getTextMetrics(ctx, labelData.text, fontSize);
97
+ const position = calculateBarLabelPosition(dataPoint, textMetrics, isHorizontalChart, isHorizontalReversed, labelData.backgroundColor);
98
+ if (position) {
99
+ prepareCanvasForText(ctx, fontSize, position.color);
100
+ ctx.fillText(labelData.text, position.x, position.y);
69
101
  }
70
102
  });
71
103
  });
72
104
  }
73
- function doughnutChartLabels(chart) {
74
- const { ctx, data } = chart;
75
- chart.data.datasets.forEach((dataset, datasetIndex) => {
76
- const meta = chart.getDatasetMeta(datasetIndex);
77
- const totalSum = dataset.data.reduce((sum, currentValue) => sum + currentValue, 0);
78
- meta.data.forEach((arc, index) => {
79
- if (!arc)
80
- return;
81
- const percentage = (dataset.data[index] / totalSum) * 100;
82
- const isVisible = chart.getDataVisibility(index);
83
- if (!percentage || !isVisible) {
84
- return;
85
- }
86
- const midAngle = (arc.startAngle + arc.endAngle) / 2;
87
- const x = arc.x + Math.cos(midAngle) * (arc.outerRadius / 1.2);
88
- const y = arc.y + Math.sin(midAngle) * (arc.outerRadius / 1.2);
89
- const fontSize = Math.max(12, Math.min(percentage / 2, 14));
90
- const bgColor = dataset.backgroundColor[index] || '#00000';
91
- prepareText(ctx, fontSize, bgColor);
92
- ctx.fillText(`${percentage.toFixed()}%`, x, y);
93
- });
94
- });
105
+ function calculateBarLabelPosition(dataPoint, textMetrics, isHorizontal, isReversed, backgroundColor) {
106
+ const { textPadding } = LABEL_CONFIG;
107
+ if (isHorizontal) {
108
+ const fitsInside = textMetrics.width + textPadding * 2 <= dataPoint.width;
109
+ if (fitsInside) {
110
+ return {
111
+ x: dataPoint.x + (isReversed ? textMetrics.width / 2 : -textMetrics.width / 2),
112
+ y: dataPoint.y,
113
+ color: getTextColor(backgroundColor)
114
+ };
115
+ }
116
+ else {
117
+ return {
118
+ x: dataPoint.x + (isReversed ? -textMetrics.width / 2 - textPadding : textMetrics.width / 2 + textPadding),
119
+ y: dataPoint.y,
120
+ color: getColor('--chart-value-default-color', '#000')
121
+ };
122
+ }
123
+ }
124
+ else {
125
+ const fitsInside = textMetrics.height + textPadding * 2 <= dataPoint.height;
126
+ if (fitsInside) {
127
+ return {
128
+ x: dataPoint.x,
129
+ y: dataPoint.y,
130
+ color: getTextColor(backgroundColor)
131
+ };
132
+ }
133
+ else {
134
+ return {
135
+ x: dataPoint.x,
136
+ y: dataPoint.y - textMetrics.height / 2 - textPadding,
137
+ color: getColor('--chart-value-default-color', '#000')
138
+ };
139
+ }
140
+ }
95
141
  }
142
+ // Pie chart implementation
96
143
  function pieChartLabels(chart) {
97
- const { ctx, data } = chart;
144
+ renderArcLabels(chart, 'pie');
145
+ }
146
+ // Doughnut chart implementation
147
+ function doughnutChartLabels(chart) {
148
+ renderArcLabels(chart, 'doughnut');
149
+ }
150
+ function renderArcLabels(chart, chartType) {
151
+ const { ctx } = chart;
98
152
  chart.data.datasets.forEach((dataset, datasetIndex) => {
99
153
  const meta = chart.getDatasetMeta(datasetIndex);
100
- const totalSum = dataset.data.reduce((sum, currentValue) => sum + currentValue, 0);
154
+ const totalSum = dataset.data.reduce((sum, value) => sum + value, 0);
101
155
  meta.data.forEach((arc, index) => {
102
156
  if (!arc)
103
157
  return;
104
- const percentage = (dataset.data[index] / totalSum) * 100;
105
- const isVisible = chart.getDataVisibility(index);
106
- if (!percentage || !isVisible) {
158
+ const labelData = extractLabelData(dataset, index, totalSum, chart);
159
+ if (!labelData)
107
160
  return;
161
+ if (shouldShowArcLabel(arc, labelData.text, chartType)) {
162
+ const position = calculateArcLabelPosition(arc, chartType);
163
+ const fontSize = calculateFontSize(labelData.percentage);
164
+ const textColor = getTextColor(labelData.backgroundColor || '#000000');
165
+ prepareCanvasForText(ctx, fontSize, textColor);
166
+ ctx.fillText(labelData.text, position.x, position.y);
108
167
  }
109
- const midAngle = (arc.startAngle + arc.endAngle) / 2;
110
- const x = arc.x + Math.cos(midAngle) * (arc.outerRadius / 1.5);
111
- const y = arc.y + Math.sin(midAngle) * (arc.outerRadius / 1.5);
112
- const fontSize = Math.max(12, Math.min(percentage / 2, 14));
113
- const bgColor = dataset.backgroundColor[index] || '#00000';
114
- prepareText(ctx, fontSize, bgColor);
115
- ctx.fillText(`${percentage.toFixed()}%`, x, y);
116
168
  });
117
169
  });
118
170
  }
119
- function isBarChartReversed(chart) {
120
- var _a, _b;
121
- const scales = chart.options.scales;
122
- const isVerticalReversed = ((_a = scales === null || scales === void 0 ? void 0 : scales.y) === null || _a === void 0 ? void 0 : _a.reverse) === true;
123
- const isHorizontalReversed = ((_b = scales === null || scales === void 0 ? void 0 : scales.x) === null || _b === void 0 ? void 0 : _b.reverse) === true;
171
+ function shouldShowArcLabel(arc, text, chartType) {
172
+ const arcAngle = Math.abs(arc.endAngle - arc.startAngle);
173
+ // Don't show labels for very small slices
174
+ if (arcAngle < LABEL_CONFIG.minAngleForPieLabel) {
175
+ return false;
176
+ }
177
+ // For doughnut charts, also check if there's enough radial space
178
+ if (chartType === 'doughnut') {
179
+ const radialSpace = arc.outerRadius - arc.innerRadius;
180
+ return radialSpace >= LABEL_CONFIG.defaultFontSize * 1.5;
181
+ }
182
+ return true;
183
+ }
184
+ function calculateArcLabelPosition(arc, chartType) {
185
+ const midAngle = (arc.startAngle + arc.endAngle) / 2;
186
+ const radiusMultiplier = LABEL_CONFIG.arcRadiusMultiplier[chartType];
187
+ let radius;
188
+ if (chartType === 'doughnut') {
189
+ radius = (arc.outerRadius + arc.innerRadius) / 2;
190
+ }
191
+ else {
192
+ radius = arc.outerRadius * radiusMultiplier;
193
+ }
124
194
  return {
125
- isVerticalReversed,
126
- isHorizontalReversed
195
+ x: arc.x + Math.cos(midAngle) * radius,
196
+ y: arc.y + Math.sin(midAngle) * radius
127
197
  };
128
198
  }
129
- function getTextMetrics(ctx, text) {
130
- const metrics = ctx.measureText(text);
131
- const textHeight = metrics.actualBoundingBoxAscent + metrics.actualBoundingBoxDescent;
199
+ // Utility functions
200
+ function getBarChartOrientation(chart) {
201
+ var _a, _b;
202
+ const scales = chart.options.scales;
132
203
  return {
133
- height: textHeight,
134
- width: metrics.width
204
+ isVerticalReversed: ((_a = scales === null || scales === void 0 ? void 0 : scales.y) === null || _a === void 0 ? void 0 : _a.reverse) === true,
205
+ isHorizontalReversed: ((_b = scales === null || scales === void 0 ? void 0 : scales.x) === null || _b === void 0 ? void 0 : _b.reverse) === true
135
206
  };
136
207
  }
137
- function prepareText(ctx, fontSize, bgColor) {
138
- const textColor = getTextColor(bgColor || getColor('--chart-value-default-color', '#000'));
139
- ctx.font = `bold ${fontSize}px sans-serif`;
140
- ctx.textAlign = 'center';
141
- ctx.textBaseline = 'middle';
142
- ctx.fillStyle = textColor;
143
- }
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-labels.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/reports/charts/plugins/data-labels.ts"],"names":[],"mappings":"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","sourcesContent":["import { ArcElement, Chart, Plugin } from 'chart.js';\r\nimport { ChartConfiguration, ChartType } from 'chart.js/dist/types';\r\n\r\nimport BarElement from 'chart.js/dist/elements/element.bar';\r\nimport { getColor, getTextColor } from '../utility';\r\n\r\nexport const chartDataLabels: Plugin<ChartType> = {\r\n\tid: 'chartDataLabels',\r\n\tafterDatasetsDraw(chart, args, plugins) {\r\n\t\tconst { ctx } = chart;\r\n\t\tctx.save();\r\n\r\n\t\tswitch ((chart.config as ChartConfiguration)?.type) {\r\n\t\t\tcase 'bar':\r\n\t\t\t\tbarChartLabels(chart);\r\n\t\t\t\tbreak;\r\n\t\t\tcase 'pie':\r\n\t\t\t\tpieChartLabels(chart);\r\n\t\t\t\tbreak;\r\n\t\t\tcase 'doughnut':\r\n\t\t\t\tdoughnutChartLabels(chart);\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\r\n\t\tctx.restore();\r\n\t}\r\n};\r\n\r\nfunction barChartLabels(chart: Chart<ChartType, unknown, unknown>) {\r\n\tconst { ctx, data } = chart;\r\n\tconst isHorizontalChart = chart.options?.indexAxis === 'y';\r\n\tconst { isHorizontalReversed } = isBarChartReversed(chart);\r\n\r\n\tchart.data.datasets.forEach((dataset, datasetIndex) => {\r\n\t\tconst meta = chart.getDatasetMeta(datasetIndex);\r\n\r\n\t\tconst totalSum = (dataset.data as []).reduce((sum, currentValue) => sum + currentValue, 0);\r\n\r\n\t\tmeta.data.forEach((dataPoint: BarElement, index) => {\r\n\t\t\tif (!dataPoint) return;\r\n\t\t\tconst percentage = (dataset.data[index] / totalSum) * 100;\r\n\t\t\tconst isVisible = chart.getDataVisibility(index);\r\n\t\t\tif (!percentage || !isVisible) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tconst bgColor = dataset.backgroundColor[index];\r\n\t\t\tconst textColor = getTextColor(bgColor);\r\n\r\n\t\t\tconst fontSize = Math.max(12, Math.min(percentage / 2, 14));\r\n\r\n\t\t\tctx.textAlign = 'center';\r\n\t\t\tctx.textBaseline = 'middle';\r\n\t\t\tctx.font = `normal ${fontSize}px sans-serif`;\r\n\t\t\tctx.fillStyle = textColor;\r\n\r\n\t\t\tconst text = `${percentage.toFixed()}%`;\r\n\r\n\t\t\tconst { width, height } = getTextMetrics(ctx, text);\r\n\r\n\t\t\tconst textHeight = height || 12;\r\n\t\t\tconst textWidth = width || 30;\r\n\r\n\t\t\tif (isHorizontalChart) {\r\n\t\t\t\tif (dataPoint?.width > 0) {\r\n\t\t\t\t\tconst textPadding = 20;\r\n\t\t\t\t\tconst offset = textPadding + textWidth <= dataPoint.width ? textWidth : textWidth >= dataPoint.width ? 0 : 10;\r\n\r\n\t\t\t\t\tconst x = dataPoint.x + (isHorizontalReversed ? offset : -offset);\r\n\t\t\t\t\tctx.fillStyle = dataPoint.width <= textWidth ? getColor('--chart-value-default-color', '#000') : textColor;\r\n\r\n\t\t\t\t\tif (percentage) {\r\n\t\t\t\t\t\tctx.fillText(text, x, dataPoint.y);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\tif (dataPoint?.height > 0) {\r\n\t\t\t\t\tconst y = textHeight >= dataPoint.height ? dataPoint.y - 10 : dataPoint.y + 10;\r\n\t\t\t\t\tctx.fillStyle = textHeight >= dataPoint.height ? getColor('--chart-value-default-color', '#000') : textColor;\r\n\t\t\t\t\tif (!percentage) {\r\n\t\t\t\t\t\treturn;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tctx.fillText(text, dataPoint.x, y);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t});\r\n}\r\n\r\nfunction doughnutChartLabels(chart: Chart<ChartType, unknown, unknown>) {\r\n\tconst { ctx, data } = chart;\r\n\r\n\tchart.data.datasets.forEach((dataset, datasetIndex) => {\r\n\t\tconst meta = chart.getDatasetMeta(datasetIndex);\r\n\r\n\t\tconst totalSum = (dataset.data as []).reduce((sum, currentValue) => sum + currentValue, 0);\r\n\r\n\t\tmeta.data.forEach((arc: ArcElement, index) => {\r\n\t\t\tif (!arc) return;\r\n\r\n\t\t\tconst percentage = (dataset.data[index] / totalSum) * 100;\r\n\t\t\tconst isVisible = chart.getDataVisibility(index);\r\n\t\t\tif (!percentage || !isVisible) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tconst midAngle = (arc.startAngle + arc.endAngle) / 2;\r\n\t\t\tconst x = arc.x + Math.cos(midAngle) * (arc.outerRadius / 1.2);\r\n\t\t\tconst y = arc.y + Math.sin(midAngle) * (arc.outerRadius / 1.2);\r\n\r\n\t\t\tconst fontSize = Math.max(12, Math.min(percentage / 2, 14));\r\n\t\t\tconst bgColor = dataset.backgroundColor[index] || '#00000';\r\n\t\t\tprepareText(ctx, fontSize, bgColor);\r\n\t\t\tctx.fillText(`${percentage.toFixed()}%`, x, y);\r\n\t\t});\r\n\t});\r\n}\r\n\r\nfunction pieChartLabels(chart: Chart<ChartType, unknown, unknown>) {\r\n\tconst { ctx, data } = chart;\r\n\r\n\tchart.data.datasets.forEach((dataset, datasetIndex) => {\r\n\t\tconst meta = chart.getDatasetMeta(datasetIndex);\r\n\r\n\t\tconst totalSum = (dataset.data as []).reduce((sum, currentValue) => sum + currentValue, 0);\r\n\r\n\t\tmeta.data.forEach((arc: ArcElement, index) => {\r\n\t\t\tif (!arc) return;\r\n\r\n\t\t\tconst percentage = (dataset.data[index] / totalSum) * 100;\r\n\t\t\tconst isVisible = chart.getDataVisibility(index);\r\n\t\t\tif (!percentage || !isVisible) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tconst midAngle = (arc.startAngle + arc.endAngle) / 2;\r\n\r\n\t\t\tconst x = arc.x + Math.cos(midAngle) * (arc.outerRadius / 1.5);\r\n\r\n\t\t\tconst y = arc.y + Math.sin(midAngle) * (arc.outerRadius / 1.5);\r\n\r\n\t\t\tconst fontSize = Math.max(12, Math.min(percentage / 2, 14));\r\n\t\t\tconst bgColor = dataset.backgroundColor[index] || '#00000';\r\n\t\t\tprepareText(ctx, fontSize, bgColor);\r\n\r\n\t\t\tctx.fillText(`${percentage.toFixed()}%`, x, y);\r\n\t\t});\r\n\t});\r\n}\r\n\r\nfunction isBarChartReversed(chart: Chart<ChartType, unknown, unknown>) {\r\n\tconst scales = chart.options.scales;\r\n\r\n\tconst isVerticalReversed = scales?.y?.reverse === true;\r\n\r\n\tconst isHorizontalReversed = scales?.x?.reverse === true;\r\n\r\n\treturn {\r\n\t\tisVerticalReversed,\r\n\t\tisHorizontalReversed\r\n\t};\r\n}\r\n\r\nfunction getTextMetrics(ctx: CanvasRenderingContext2D, text: string) {\r\n\tconst metrics = ctx.measureText(text);\r\n\r\n\tconst textHeight = metrics.actualBoundingBoxAscent + metrics.actualBoundingBoxDescent;\r\n\treturn {\r\n\t\theight: textHeight,\r\n\t\twidth: metrics.width\r\n\t};\r\n}\r\n\r\nfunction prepareText(ctx: CanvasRenderingContext2D, fontSize: number, bgColor: string) {\r\n\tconst textColor = getTextColor(bgColor || getColor('--chart-value-default-color', '#000'));\r\n\tctx.font = `bold ${fontSize}px sans-serif`;\r\n\tctx.textAlign = 'center';\r\n\tctx.textBaseline = 'middle';\r\n\tctx.fillStyle = textColor;\r\n}\r\n"]}
208
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-labels.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/reports/charts/plugins/data-labels.ts"],"names":[],"mappings":"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","sourcesContent":["import { ArcElement, Chart, Plugin } from 'chart.js';\r\nimport { ChartConfiguration, ChartType } from 'chart.js/dist/types';\r\nimport BarElement from 'chart.js/dist/elements/element.bar';\r\nimport { getColor, getTextColor } from '../utility';\r\n\r\n// Configuration constants\r\nconst LABEL_CONFIG = {\r\n\tminFontSize: 10,\r\n\tmaxFontSize: 16,\r\n\tdefaultFontSize: 12,\r\n\ttextPadding: 8,\r\n\tminAngleForPieLabel: 0.3, // ~17 degrees\r\n\tarcRadiusMultiplier: {\r\n\t\tpie: 0.7,\r\n\t\tdoughnut: 0.8\r\n\t},\r\n\tfontSizeCalculation: {\r\n\t\tpercentageDivisor: 3,\r\n\t\tmaxPercentageForFontSize: 20\r\n\t}\r\n} as const;\r\n\r\n// Types\r\ninterface TextMetrics {\r\n\twidth: number;\r\n\theight: number;\r\n}\r\n\r\ninterface LabelData {\r\n\ttext: string;\r\n\tpercentage: number;\r\n\tbackgroundColor: string | undefined;\r\n\tisVisible: boolean;\r\n}\r\n\r\ninterface LabelPosition {\r\n\tx: number;\r\n\ty: number;\r\n\tcolor: string;\r\n}\r\n\r\n// Main plugin\r\nexport const chartDataLabels: Plugin<ChartType> = {\r\n\tid: 'chartDataLabels',\r\n\tafterDatasetsDraw(chart, args, plugins) {\r\n\t\tconst { ctx } = chart;\r\n\t\tctx.save();\r\n\r\n\t\tconst chartType = (chart.config as ChartConfiguration)?.type;\r\n\t\tconst renderer = getChartRenderer(chartType);\r\n\r\n\t\tif (renderer) {\r\n\t\t\trenderer(chart);\r\n\t\t}\r\n\r\n\t\tctx.restore();\r\n\t}\r\n};\r\n\r\n// Chart type router\r\nfunction getChartRenderer(chartType: string | undefined) {\r\n\tconst renderers = {\r\n\t\tbar: barChartLabels,\r\n\t\tpie: pieChartLabels,\r\n\t\tdoughnut: doughnutChartLabels\r\n\t};\r\n\r\n\treturn renderers[chartType as keyof typeof renderers];\r\n}\r\n\r\n// Core utility functions\r\nfunction calculatePercentage(value: number, total: number): number {\r\n\treturn total > 0 ? (value / total) * 100 : 0;\r\n}\r\n\r\nfunction calculateFontSize(percentage: number): number {\r\n\tconst { percentageDivisor, maxPercentageForFontSize } = LABEL_CONFIG.fontSizeCalculation;\r\n\tconst calculatedSize = Math.min(percentage / percentageDivisor, maxPercentageForFontSize);\r\n\treturn Math.max(LABEL_CONFIG.minFontSize, Math.min(calculatedSize, LABEL_CONFIG.maxFontSize));\r\n}\r\n\r\nfunction getTextMetrics(ctx: CanvasRenderingContext2D, text: string, fontSize: number): TextMetrics {\r\n\tctx.font = `normal ${fontSize}px sans-serif`;\r\n\tconst metrics = ctx.measureText(text);\r\n\tconst height = metrics.actualBoundingBoxAscent + metrics.actualBoundingBoxDescent || LABEL_CONFIG.defaultFontSize;\r\n\r\n\treturn {\r\n\t\twidth: metrics.width,\r\n\t\theight\r\n\t};\r\n}\r\n\r\nfunction prepareCanvasForText(ctx: CanvasRenderingContext2D, fontSize: number, color: string): void {\r\n\tctx.font = `bold ${fontSize}px sans-serif`;\r\n\tctx.textAlign = 'center';\r\n\tctx.textBaseline = 'middle';\r\n\tctx.fillStyle = color;\r\n}\r\n\r\nfunction extractLabelData(\r\n\tdataset: any,\r\n\tindex: number,\r\n\ttotalSum: number,\r\n\tchart: Chart<ChartType, unknown, unknown>\r\n): LabelData | null {\r\n\tconst value = dataset.data[index] as number;\r\n\tconst percentage = calculatePercentage(value, totalSum);\r\n\tconst isVisible = chart.getDataVisibility(index);\r\n\r\n\tif (!percentage || !isVisible) {\r\n\t\treturn null;\r\n\t}\r\n\r\n\treturn {\r\n\t\ttext: `${percentage.toFixed(1)}%`,\r\n\t\tpercentage,\r\n\t\tbackgroundColor: Array.isArray(dataset.backgroundColor) ? dataset.backgroundColor[index] : dataset.backgroundColor,\r\n\t\tisVisible\r\n\t};\r\n}\r\n\r\n// Bar chart implementation\r\nfunction barChartLabels(chart: Chart): void {\r\n\tconst { ctx } = chart;\r\n\tconst isHorizontalChart = chart.options?.indexAxis === 'y';\r\n\tconst { isHorizontalReversed } = getBarChartOrientation(chart);\r\n\r\n\tchart.data.datasets.forEach((dataset, datasetIndex) => {\r\n\t\tconst meta = chart.getDatasetMeta(datasetIndex);\r\n\t\tconst totalSum = (dataset.data as number[]).reduce((sum, value) => sum + value, 0);\r\n\r\n\t\tmeta.data.forEach((dataPoint: BarElement, index) => {\r\n\t\t\tif (!dataPoint) return;\r\n\r\n\t\t\tconst labelData = extractLabelData(dataset, index, totalSum, chart);\r\n\t\t\tif (!labelData) return;\r\n\r\n\t\t\tconst fontSize = calculateFontSize(labelData.percentage);\r\n\t\t\tconst textMetrics = getTextMetrics(ctx, labelData.text, fontSize);\r\n\r\n\t\t\tconst position = calculateBarLabelPosition(\r\n\t\t\t\tdataPoint,\r\n\t\t\t\ttextMetrics,\r\n\t\t\t\tisHorizontalChart,\r\n\t\t\t\tisHorizontalReversed,\r\n\t\t\t\tlabelData.backgroundColor\r\n\t\t\t);\r\n\r\n\t\t\tif (position) {\r\n\t\t\t\tprepareCanvasForText(ctx, fontSize, position.color);\r\n\t\t\t\tctx.fillText(labelData.text, position.x, position.y);\r\n\t\t\t}\r\n\t\t});\r\n\t});\r\n}\r\n\r\nfunction calculateBarLabelPosition(\r\n\tdataPoint: BarElement,\r\n\ttextMetrics: TextMetrics,\r\n\tisHorizontal: boolean,\r\n\tisReversed: boolean,\r\n\tbackgroundColor: string | undefined\r\n): LabelPosition | null {\r\n\tconst { textPadding } = LABEL_CONFIG;\r\n\r\n\tif (isHorizontal) {\r\n\t\tconst fitsInside = textMetrics.width + textPadding * 2 <= dataPoint.width;\r\n\r\n\t\tif (fitsInside) {\r\n\t\t\treturn {\r\n\t\t\t\tx: dataPoint.x + (isReversed ? textMetrics.width / 2 : -textMetrics.width / 2),\r\n\t\t\t\ty: dataPoint.y,\r\n\t\t\t\tcolor: getTextColor(backgroundColor)\r\n\t\t\t};\r\n\t\t} else {\r\n\t\t\treturn {\r\n\t\t\t\tx: dataPoint.x + (isReversed ? -textMetrics.width / 2 - textPadding : textMetrics.width / 2 + textPadding),\r\n\t\t\t\ty: dataPoint.y,\r\n\t\t\t\tcolor: getColor('--chart-value-default-color', '#000')\r\n\t\t\t};\r\n\t\t}\r\n\t} else {\r\n\t\tconst fitsInside = textMetrics.height + textPadding * 2 <= dataPoint.height;\r\n\r\n\t\tif (fitsInside) {\r\n\t\t\treturn {\r\n\t\t\t\tx: dataPoint.x,\r\n\t\t\t\ty: dataPoint.y,\r\n\t\t\t\tcolor: getTextColor(backgroundColor)\r\n\t\t\t};\r\n\t\t} else {\r\n\t\t\treturn {\r\n\t\t\t\tx: dataPoint.x,\r\n\t\t\t\ty: dataPoint.y - textMetrics.height / 2 - textPadding,\r\n\t\t\t\tcolor: getColor('--chart-value-default-color', '#000')\r\n\t\t\t};\r\n\t\t}\r\n\t}\r\n}\r\n\r\n// Pie chart implementation\r\nfunction pieChartLabels(chart: Chart<ChartType, unknown, unknown>): void {\r\n\trenderArcLabels(chart, 'pie');\r\n}\r\n\r\n// Doughnut chart implementation\r\nfunction doughnutChartLabels(chart: Chart<ChartType, unknown, unknown>): void {\r\n\trenderArcLabels(chart, 'doughnut');\r\n}\r\n\r\nfunction renderArcLabels(chart: Chart<ChartType, unknown, unknown>, chartType: 'pie' | 'doughnut'): void {\r\n\tconst { ctx } = chart;\r\n\r\n\tchart.data.datasets.forEach((dataset, datasetIndex) => {\r\n\t\tconst meta = chart.getDatasetMeta(datasetIndex);\r\n\t\tconst totalSum = (dataset.data as number[]).reduce((sum, value) => sum + value, 0);\r\n\r\n\t\tmeta.data.forEach((arc: ArcElement, index) => {\r\n\t\t\tif (!arc) return;\r\n\r\n\t\t\tconst labelData = extractLabelData(dataset, index, totalSum, chart);\r\n\t\t\tif (!labelData) return;\r\n\r\n\t\t\tif (shouldShowArcLabel(arc, labelData.text, chartType)) {\r\n\t\t\t\tconst position = calculateArcLabelPosition(arc, chartType);\r\n\t\t\t\tconst fontSize = calculateFontSize(labelData.percentage);\r\n\t\t\t\tconst textColor = getTextColor(labelData.backgroundColor || '#000000');\r\n\r\n\t\t\t\tprepareCanvasForText(ctx, fontSize, textColor);\r\n\t\t\t\tctx.fillText(labelData.text, position.x, position.y);\r\n\t\t\t}\r\n\t\t});\r\n\t});\r\n}\r\n\r\nfunction shouldShowArcLabel(arc: ArcElement, text: string, chartType: 'pie' | 'doughnut'): boolean {\r\n\tconst arcAngle = Math.abs(arc.endAngle - arc.startAngle);\r\n\r\n\t// Don't show labels for very small slices\r\n\tif (arcAngle < LABEL_CONFIG.minAngleForPieLabel) {\r\n\t\treturn false;\r\n\t}\r\n\r\n\t// For doughnut charts, also check if there's enough radial space\r\n\tif (chartType === 'doughnut') {\r\n\t\tconst radialSpace = arc.outerRadius - arc.innerRadius;\r\n\t\treturn radialSpace >= LABEL_CONFIG.defaultFontSize * 1.5;\r\n\t}\r\n\r\n\treturn true;\r\n}\r\n\r\nfunction calculateArcLabelPosition(arc: ArcElement, chartType: 'pie' | 'doughnut'): { x: number; y: number } {\r\n\tconst midAngle = (arc.startAngle + arc.endAngle) / 2;\r\n\tconst radiusMultiplier = LABEL_CONFIG.arcRadiusMultiplier[chartType];\r\n\r\n\tlet radius: number;\r\n\tif (chartType === 'doughnut') {\r\n\t\tradius = (arc.outerRadius + arc.innerRadius) / 2;\r\n\t} else {\r\n\t\tradius = arc.outerRadius * radiusMultiplier;\r\n\t}\r\n\r\n\treturn {\r\n\t\tx: arc.x + Math.cos(midAngle) * radius,\r\n\t\ty: arc.y + Math.sin(midAngle) * radius\r\n\t};\r\n}\r\n\r\n// Utility functions\r\nfunction getBarChartOrientation(chart: Chart<ChartType, unknown, unknown>) {\r\n\tconst scales = chart.options.scales;\r\n\treturn {\r\n\t\tisVerticalReversed: scales?.y?.reverse === true,\r\n\t\tisHorizontalReversed: scales?.x?.reverse === true\r\n\t};\r\n}\r\n"]}
@@ -71,4 +71,16 @@ export function createColorVariants(color, length, type = 'tint', amount = 43) {
71
71
  }
72
72
  return variants;
73
73
  }
74
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"colors.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/reports/charts/utility/colors.ts"],"names":[],"mappings":"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","sourcesContent":["import colorLib from '@kurkle/color';\r\n\r\nexport function transparentize(value: string, opacity: number) {\r\n\tvar alpha = opacity === undefined ? 0.5 : 1 - opacity;\r\n\treturn colorLib(value).alpha(alpha).rgbString();\r\n}\r\n\r\nexport function colorToHex(color) {\r\n\t// Helper function to convert a single component to hex\r\n\tfunction componentToHex(c) {\r\n\t\tconst hex = c.toString(16);\r\n\t\treturn hex.length === 1 ? '0' + hex : hex;\r\n\t}\r\n\r\n\t// Helper function to validate and parse a color component\r\n\tfunction parseComponent(value, maxValue) {\r\n\t\tvalue = parseFloat(value);\r\n\t\treturn isNaN(value) ? 0 : Math.min(maxValue, Math.max(0, value));\r\n\t}\r\n\r\n\tif (typeof color === 'string') {\r\n\t\t// If the input is a string, attempt to parse it as a CSS color\r\n\t\tconst tempDiv = document.createElement('div');\r\n\t\ttempDiv.style.color = color;\r\n\t\tdocument.body.appendChild(tempDiv);\r\n\t\tconst computedColor = window.getComputedStyle(tempDiv).color;\r\n\t\tdocument.body.removeChild(tempDiv);\r\n\t\tcolor = computedColor;\r\n\t}\r\n\r\n\tif (color.startsWith('#')) {\r\n\t\t// Hexadecimal color\r\n\t\treturn color.toUpperCase();\r\n\t} else if (color.startsWith('rgb') || color.startsWith('hsl')) {\r\n\t\t// RGB, RGBA, HSL, HSLA color\r\n\t\tconst rgba = color.match(/(0?\\.?\\d{1,3})%?\\b/g).map((component, index) => {\r\n\t\t\treturn index < 3 ? Math.round(parseComponent(component, 255)) : parseFloat(component);\r\n\t\t});\r\n\r\n\t\treturn `#${componentToHex(rgba[0])}${componentToHex(rgba[1])}${componentToHex(rgba[2])}`;\r\n\t}\r\n\r\n\t// Unsupported color format, return input\r\n\treturn color;\r\n}\r\n\r\n// Function to convert hex to RGB\r\nexport function hexToRgb(hex: string): { r: number; g: number; b: number } {\r\n\tlet r = parseInt(hex.slice(1, 3), 16);\r\n\tlet g = parseInt(hex.slice(3, 5), 16);\r\n\tlet b = parseInt(hex.slice(5, 7), 16);\r\n\treturn { r, g, b };\r\n}\r\n\r\n// Function to convert RGB to hex\r\nexport function rgbToHex(r: number, g: number, b: number): string {\r\n\treturn `#${((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1).toUpperCase()}`;\r\n}\r\n\r\n// Function to create a tint (lighten the color)\r\nexport function createTint(color: string, amount: number): string {\r\n\tconst { r, g, b } = hexToRgb(color);\r\n\treturn rgbToHex(Math.min(255, r + amount), Math.min(255, g + amount), Math.min(255, b + amount));\r\n}\r\n\r\n// Function to create a shade (darken the color)\r\nexport function createShade(color: string, amount: number): string {\r\n\tconst { r, g, b } = hexToRgb(color);\r\n\treturn rgbToHex(Math.max(0, r - amount), Math.max(0, g - amount), Math.max(0, b - amount));\r\n}\r\n\r\n// Function to create multiple tints or shades\r\nexport function createColorVariants(\r\n\tcolor: string,\r\n\tlength: number,\r\n\ttype: 'tint' | 'shade' = 'tint',\r\n\tamount = 43\r\n): string[] {\r\n\tlet variants: string[] = [];\r\n\tfor (let i = 1; i <= length; i++) {\r\n\t\tif (type === 'tint') {\r\n\t\t\tvariants.push(createTint(color, i * amount)); // Adjust the step size (here it's 40)\r\n\t\t} else {\r\n\t\t\tvariants.push(createShade(color, i * amount)); // Adjust the step size (here it's 20)\r\n\t\t}\r\n\t}\r\n\treturn variants;\r\n}\r\n"]}
74
+ export function createConicGradient(chart, colors) {
75
+ const { ctx, chartArea } = chart;
76
+ if (!chartArea || !('createConicGradient' in ctx)) {
77
+ return null;
78
+ }
79
+ const { left, width, top, height } = chartArea;
80
+ //@ts-ignore
81
+ const gradient = ctx.createConicGradient(0, left + width / 2, top + height / 2);
82
+ gradient.addColorStop(0, colors === null || colors === void 0 ? void 0 : colors.startColor);
83
+ gradient.addColorStop(1, colors === null || colors === void 0 ? void 0 : colors.endColor);
84
+ return gradient;
85
+ }
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"colors.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/reports/charts/utility/colors.ts"],"names":[],"mappings":"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","sourcesContent":["import colorLib from '@kurkle/color';\r\nimport { Chart } from 'chart.js';\r\n\r\nexport function transparentize(value: string, opacity: number) {\r\n\tvar alpha = opacity === undefined ? 0.5 : 1 - opacity;\r\n\treturn colorLib(value).alpha(alpha).rgbString();\r\n}\r\n\r\nexport function colorToHex(color) {\r\n\t// Helper function to convert a single component to hex\r\n\tfunction componentToHex(c) {\r\n\t\tconst hex = c.toString(16);\r\n\t\treturn hex.length === 1 ? '0' + hex : hex;\r\n\t}\r\n\r\n\t// Helper function to validate and parse a color component\r\n\tfunction parseComponent(value, maxValue) {\r\n\t\tvalue = parseFloat(value);\r\n\t\treturn isNaN(value) ? 0 : Math.min(maxValue, Math.max(0, value));\r\n\t}\r\n\r\n\tif (typeof color === 'string') {\r\n\t\t// If the input is a string, attempt to parse it as a CSS color\r\n\t\tconst tempDiv = document.createElement('div');\r\n\t\ttempDiv.style.color = color;\r\n\t\tdocument.body.appendChild(tempDiv);\r\n\t\tconst computedColor = window.getComputedStyle(tempDiv).color;\r\n\t\tdocument.body.removeChild(tempDiv);\r\n\t\tcolor = computedColor;\r\n\t}\r\n\r\n\tif (color.startsWith('#')) {\r\n\t\t// Hexadecimal color\r\n\t\treturn color.toUpperCase();\r\n\t} else if (color.startsWith('rgb') || color.startsWith('hsl')) {\r\n\t\t// RGB, RGBA, HSL, HSLA color\r\n\t\tconst rgba = color.match(/(0?\\.?\\d{1,3})%?\\b/g).map((component, index) => {\r\n\t\t\treturn index < 3 ? Math.round(parseComponent(component, 255)) : parseFloat(component);\r\n\t\t});\r\n\r\n\t\treturn `#${componentToHex(rgba[0])}${componentToHex(rgba[1])}${componentToHex(rgba[2])}`;\r\n\t}\r\n\r\n\t// Unsupported color format, return input\r\n\treturn color;\r\n}\r\n\r\n// Function to convert hex to RGB\r\nexport function hexToRgb(hex: string): { r: number; g: number; b: number } {\r\n\tlet r = parseInt(hex.slice(1, 3), 16);\r\n\tlet g = parseInt(hex.slice(3, 5), 16);\r\n\tlet b = parseInt(hex.slice(5, 7), 16);\r\n\treturn { r, g, b };\r\n}\r\n\r\n// Function to convert RGB to hex\r\nexport function rgbToHex(r: number, g: number, b: number): string {\r\n\treturn `#${((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1).toUpperCase()}`;\r\n}\r\n\r\n// Function to create a tint (lighten the color)\r\nexport function createTint(color: string, amount: number): string {\r\n\tconst { r, g, b } = hexToRgb(color);\r\n\treturn rgbToHex(Math.min(255, r + amount), Math.min(255, g + amount), Math.min(255, b + amount));\r\n}\r\n\r\n// Function to create a shade (darken the color)\r\nexport function createShade(color: string, amount: number): string {\r\n\tconst { r, g, b } = hexToRgb(color);\r\n\treturn rgbToHex(Math.max(0, r - amount), Math.max(0, g - amount), Math.max(0, b - amount));\r\n}\r\n\r\n// Function to create multiple tints or shades\r\nexport function createColorVariants(\r\n\tcolor: string,\r\n\tlength: number,\r\n\ttype: 'tint' | 'shade' = 'tint',\r\n\tamount = 43\r\n): string[] {\r\n\tlet variants: string[] = [];\r\n\tfor (let i = 1; i <= length; i++) {\r\n\t\tif (type === 'tint') {\r\n\t\t\tvariants.push(createTint(color, i * amount)); // Adjust the step size (here it's 40)\r\n\t\t} else {\r\n\t\t\tvariants.push(createShade(color, i * amount)); // Adjust the step size (here it's 20)\r\n\t\t}\r\n\t}\r\n\treturn variants;\r\n}\r\n\r\nexport function createConicGradient(chart: Chart, colors: { startColor: string; endColor: string }) {\r\n\tconst { ctx, chartArea } = chart;\r\n\tif (!chartArea || !('createConicGradient' in ctx)) {\r\n\t\treturn null;\r\n\t}\r\n\r\n\tconst { left, width, top, height } = chartArea;\r\n\r\n\t//@ts-ignore\r\n\tconst gradient = ctx.createConicGradient(0, left + width / 2, top + height / 2);\r\n\tgradient.addColorStop(0, colors?.startColor );\r\n\tgradient.addColorStop(1, colors?.endColor);\r\n\r\n\treturn gradient;\r\n}\r\n"]}
@@ -11,9 +11,9 @@ export class BaseChart extends DestroySubject {
11
11
  this.injector = injector;
12
12
  this._translateService = this.injector.get(TranslateService);
13
13
  this._rebuildTriggerSub = new BehaviorSubject(false);
14
- this._dataSub = new ReplaySubject(null);
15
14
  this._configSub = new ReplaySubject(null);
16
15
  this._isInitialized = false;
16
+ this._dataSub = new ReplaySubject(null);
17
17
  this.onReady = new EventEmitter();
18
18
  this._subscribeToLanguage();
19
19
  }
@@ -58,4 +58,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
58
58
  }], onReady: [{
59
59
  type: Output
60
60
  }] } });
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1jaGFydC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvcmVwb3J0cy9uZGYtcmVwb3J0cy9iYXNlL2Jhc2UtY2hhcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQVksS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFFL0QsT0FBTyxFQUFFLGVBQWUsRUFBYyxhQUFhLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFbEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdkQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUV6RSxPQUFPLENBQUMsTUFBTSxRQUFRLENBQUM7O0FBR3ZCLE1BQU0sT0FBZ0IsU0FBYSxTQUFRLGNBQWM7SUF5Q3hELFlBQW1CLFFBQWtCO1FBQ3BDLEtBQUssRUFBRSxDQUFDO1FBRFUsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQXRDM0Isc0JBQWlCLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUMvQyx1QkFBa0IsR0FBRyxJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNsRSxhQUFRLEdBQUcsSUFBSSxhQUFhLENBQXNCLElBQUksQ0FBQyxDQUFDO1FBQ3hELGVBQVUsR0FBRyxJQUFJLGFBQWEsQ0FBSSxJQUFJLENBQUMsQ0FBQztRQUV4QyxtQkFBYyxHQUFHLEtBQUssQ0FBQztRQStCdkIsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFTLENBQUM7UUFJN0MsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUM7SUFDN0IsQ0FBQztJQWpDRCxJQUFhLElBQUksQ0FBQyxJQUF5QjtRQUMxQyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQztRQUNsQixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMxQixDQUFDO0lBRUQsSUFBSSxJQUFJO1FBQ1AsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ25CLENBQUM7SUFHRCxJQUFhLE1BQU0sQ0FBQyxNQUFTO1FBQzVCLElBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNuQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVELElBQUksTUFBTTtRQUNULE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUNyQixDQUFDO0lBR0QsSUFBYSxRQUFRLENBQUMsS0FBb0I7UUFDekMsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDWCxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDdkIsQ0FBQztJQVNTLG9CQUFvQjtRQUM3QixJQUFJLENBQUMsaUJBQWlCLENBQUMsWUFBWTthQUNqQyxJQUFJLENBQ0osb0JBQW9CLENBQUMsQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsRUFDMUQsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsRUFDakMsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FDeEI7YUFDQSxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUNoQixJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3BDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7dUdBeERvQixTQUFTOzJGQUFULFNBQVM7NEZBQVQsU0FBUztrQkFEOUIsU0FBUzsrRkFZSSxJQUFJO3NCQUFoQixLQUFLO2dCQVVPLE1BQU07c0JBQWxCLEtBQUs7Z0JBVU8sUUFBUTtzQkFBcEIsS0FBSztnQkFRSSxPQUFPO3NCQUFoQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFdmVudEVtaXR0ZXIsIEluamVjdG9yLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBEZXN0cm95U3ViamVjdCB9IGZyb20gJy4uLy4uLy4uLy4uL3NoYXJlZC9jb21wb25lbnRzJztcclxuXHJcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSwgUmVwbGF5U3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgQ2hhcnQgZnJvbSAnY2hhcnQuanMvYXV0byc7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcclxuaW1wb3J0IHsgZGlzdGluY3RVbnRpbENoYW5nZWQsIGZpbHRlciwgdGFrZVVudGlsIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5pbXBvcnQgeyBDcml0ZXJpYU1vZGVsLCBSZXBvcnRSZXNwb25zZU1vZGVsIH0gZnJvbSAnLi4vbW9kZWxzJztcclxuaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcclxuXHJcbkBEaXJlY3RpdmUoKVxyXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZUNoYXJ0PFQ+IGV4dGVuZHMgRGVzdHJveVN1YmplY3Qge1xyXG5cdHB1YmxpYyBhYnN0cmFjdCByZXBvcnQkOiBPYnNlcnZhYmxlPGFueT47XHJcblxyXG5cdHByb3RlY3RlZCBfdHJhbnNsYXRlU2VydmljZSA9IHRoaXMuaW5qZWN0b3IuZ2V0KFRyYW5zbGF0ZVNlcnZpY2UpO1xyXG5cdHByb3RlY3RlZCByZWFkb25seSBfcmVidWlsZFRyaWdnZXJTdWIgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+KGZhbHNlKTtcclxuXHRwcm90ZWN0ZWQgX2RhdGFTdWIgPSBuZXcgUmVwbGF5U3ViamVjdDxSZXBvcnRSZXNwb25zZU1vZGVsPihudWxsKTtcclxuXHRwcm90ZWN0ZWQgX2NvbmZpZ1N1YiA9IG5ldyBSZXBsYXlTdWJqZWN0PFQ+KG51bGwpO1xyXG5cclxuXHRwcm90ZWN0ZWQgX2lzSW5pdGlhbGl6ZWQgPSBmYWxzZTtcclxuXHRwcml2YXRlIF9kYXRhOiBSZXBvcnRSZXNwb25zZU1vZGVsO1xyXG5cclxuXHRASW5wdXQoKSBzZXQgZGF0YShkYXRhOiBSZXBvcnRSZXNwb25zZU1vZGVsKSB7XHJcblx0XHR0aGlzLl9kYXRhID0gZGF0YTtcclxuXHRcdHRoaXMuX2RhdGFTdWIubmV4dChkYXRhKTtcclxuXHR9XHJcblxyXG5cdGdldCBkYXRhKCkge1xyXG5cdFx0cmV0dXJuIHRoaXMuX2RhdGE7XHJcblx0fVxyXG5cclxuXHRwcml2YXRlIF9jb25maWc6IFQ7XHJcblx0QElucHV0KCkgc2V0IGNvbmZpZyhjb25maWc6IFQpIHtcclxuXHRcdHRoaXMuX2NvbmZpZyA9IF8uY2xvbmVEZWVwKGNvbmZpZyk7XHJcblx0XHR0aGlzLl9jb25maWdTdWIubmV4dCh0aGlzLl9jb25maWcpO1xyXG5cdH1cclxuXHJcblx0Z2V0IGNvbmZpZygpIHtcclxuXHRcdHJldHVybiB0aGlzLl9jb25maWc7XHJcblx0fVxyXG5cclxuXHRwcml2YXRlIF9jcml0ZXJpYTogQ3JpdGVyaWFNb2RlbDtcclxuXHRASW5wdXQoKSBzZXQgY3JpdGVyaWEodmFsdWU6IENyaXRlcmlhTW9kZWwpIHtcclxuXHRcdHRoaXMuX2NyaXRlcmlhID0gXy5jbG9uZURlZXAodmFsdWUpO1xyXG5cdH1cclxuXHJcblx0Z2V0IGNyaXRlcmlhKCkge1xyXG5cdFx0cmV0dXJuIHRoaXMuX2NyaXRlcmlhO1xyXG5cdH1cclxuXHJcblx0QE91dHB1dCgpIG9uUmVhZHkgPSBuZXcgRXZlbnRFbWl0dGVyPENoYXJ0PigpO1xyXG5cclxuXHRjb25zdHJ1Y3RvcihwdWJsaWMgaW5qZWN0b3I6IEluamVjdG9yKSB7XHJcblx0XHRzdXBlcigpO1xyXG5cdFx0dGhpcy5fc3Vic2NyaWJlVG9MYW5ndWFnZSgpO1xyXG5cdH1cclxuXHJcblx0cHJvdGVjdGVkIF9zdWJzY3JpYmVUb0xhbmd1YWdlKCkge1xyXG5cdFx0dGhpcy5fdHJhbnNsYXRlU2VydmljZS5vbkxhbmdDaGFuZ2VcclxuXHRcdFx0LnBpcGUoXHJcblx0XHRcdFx0ZGlzdGluY3RVbnRpbENoYW5nZWQoKHByZSwgbmV4dCkgPT4gcHJlLmxhbmcgPT0gbmV4dC5sYW5nKSxcclxuXHRcdFx0XHRmaWx0ZXIoKCkgPT4gdGhpcy5faXNJbml0aWFsaXplZCksXHJcblx0XHRcdFx0dGFrZVVudGlsKHRoaXMuZGVzdHJveSQpXHJcblx0XHRcdClcclxuXHRcdFx0LnN1YnNjcmliZSgoXykgPT4ge1xyXG5cdFx0XHRcdHRoaXMuX3JlYnVpbGRUcmlnZ2VyU3ViLm5leHQodHJ1ZSk7XHJcblx0XHRcdH0pO1xyXG5cdH1cclxufVxyXG4iXX0=
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1jaGFydC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvcmVwb3J0cy9uZGYtcmVwb3J0cy9iYXNlL2Jhc2UtY2hhcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQVksS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFFL0QsT0FBTyxFQUFFLGVBQWUsRUFBYyxhQUFhLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFbEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdkQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUV6RSxPQUFPLENBQUMsTUFBTSxRQUFRLENBQUM7O0FBR3ZCLE1BQU0sT0FBZ0IsU0FBYSxTQUFRLGNBQWM7SUEwQ3hELFlBQW1CLFFBQWtCO1FBQ3BDLEtBQUssRUFBRSxDQUFDO1FBRFUsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQXZDM0Isc0JBQWlCLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUMvQyx1QkFBa0IsR0FBRyxJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNsRSxlQUFVLEdBQUcsSUFBSSxhQUFhLENBQUksSUFBSSxDQUFDLENBQUM7UUFHeEMsbUJBQWMsR0FBRyxLQUFLLENBQUM7UUFFdkIsYUFBUSxHQUFHLElBQUksYUFBYSxDQUFzQixJQUFJLENBQUMsQ0FBQztRQThCeEQsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFTLENBQUM7UUFJN0MsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUM7SUFDN0IsQ0FBQztJQWpDRCxJQUFhLElBQUksQ0FBQyxJQUF5QjtRQUMxQyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQztRQUNsQixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMxQixDQUFDO0lBRUQsSUFBSSxJQUFJO1FBQ1AsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ25CLENBQUM7SUFHRCxJQUFhLE1BQU0sQ0FBQyxNQUFTO1FBQzVCLElBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNuQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVELElBQUksTUFBTTtRQUNULE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUNyQixDQUFDO0lBR0QsSUFBYSxRQUFRLENBQUMsS0FBb0I7UUFDekMsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDWCxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDdkIsQ0FBQztJQVNTLG9CQUFvQjtRQUM3QixJQUFJLENBQUMsaUJBQWlCLENBQUMsWUFBWTthQUNqQyxJQUFJLENBQ0osb0JBQW9CLENBQUMsQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsRUFDMUQsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsRUFDakMsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FDeEI7YUFDQSxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUNoQixJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3BDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7dUdBekRvQixTQUFTOzJGQUFULFNBQVM7NEZBQVQsU0FBUztrQkFEOUIsU0FBUzsrRkFhSSxJQUFJO3NCQUFoQixLQUFLO2dCQVVPLE1BQU07c0JBQWxCLEtBQUs7Z0JBVU8sUUFBUTtzQkFBcEIsS0FBSztnQkFRSSxPQUFPO3NCQUFoQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFdmVudEVtaXR0ZXIsIEluamVjdG9yLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBEZXN0cm95U3ViamVjdCB9IGZyb20gJy4uLy4uLy4uLy4uL3NoYXJlZC9jb21wb25lbnRzJztcclxuXHJcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSwgUmVwbGF5U3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgQ2hhcnQgZnJvbSAnY2hhcnQuanMvYXV0byc7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcclxuaW1wb3J0IHsgZGlzdGluY3RVbnRpbENoYW5nZWQsIGZpbHRlciwgdGFrZVVudGlsIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5pbXBvcnQgeyBDcml0ZXJpYU1vZGVsLCBSZXBvcnRSZXNwb25zZU1vZGVsIH0gZnJvbSAnLi4vbW9kZWxzJztcclxuaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcclxuXHJcbkBEaXJlY3RpdmUoKVxyXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZUNoYXJ0PFQ+IGV4dGVuZHMgRGVzdHJveVN1YmplY3Qge1xyXG5cdHB1YmxpYyBhYnN0cmFjdCByZXBvcnQkOiBPYnNlcnZhYmxlPGFueT47XHJcblxyXG5cdHByb3RlY3RlZCBfdHJhbnNsYXRlU2VydmljZSA9IHRoaXMuaW5qZWN0b3IuZ2V0KFRyYW5zbGF0ZVNlcnZpY2UpO1xyXG5cdHByb3RlY3RlZCByZWFkb25seSBfcmVidWlsZFRyaWdnZXJTdWIgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+KGZhbHNlKTtcclxuXHRwcm90ZWN0ZWQgX2NvbmZpZ1N1YiA9IG5ldyBSZXBsYXlTdWJqZWN0PFQ+KG51bGwpO1xyXG5cclxuXHJcblx0cHJvdGVjdGVkIF9pc0luaXRpYWxpemVkID0gZmFsc2U7XHJcblxyXG5cdHByb3RlY3RlZCBfZGF0YVN1YiA9IG5ldyBSZXBsYXlTdWJqZWN0PFJlcG9ydFJlc3BvbnNlTW9kZWw+KG51bGwpO1xyXG5cdHByaXZhdGUgX2RhdGE6IFJlcG9ydFJlc3BvbnNlTW9kZWw7XHJcblx0QElucHV0KCkgc2V0IGRhdGEoZGF0YTogUmVwb3J0UmVzcG9uc2VNb2RlbCkge1xyXG5cdFx0dGhpcy5fZGF0YSA9IGRhdGE7XHJcblx0XHR0aGlzLl9kYXRhU3ViLm5leHQoZGF0YSk7XHJcblx0fVxyXG5cclxuXHRnZXQgZGF0YSgpIHtcclxuXHRcdHJldHVybiB0aGlzLl9kYXRhO1xyXG5cdH1cclxuXHJcblx0cHJpdmF0ZSBfY29uZmlnOiBUO1xyXG5cdEBJbnB1dCgpIHNldCBjb25maWcoY29uZmlnOiBUKSB7XHJcblx0XHR0aGlzLl9jb25maWcgPSBfLmNsb25lRGVlcChjb25maWcpO1xyXG5cdFx0dGhpcy5fY29uZmlnU3ViLm5leHQodGhpcy5fY29uZmlnKTtcclxuXHR9XHJcblxyXG5cdGdldCBjb25maWcoKSB7XHJcblx0XHRyZXR1cm4gdGhpcy5fY29uZmlnO1xyXG5cdH1cclxuXHJcblx0cHJpdmF0ZSBfY3JpdGVyaWE6IENyaXRlcmlhTW9kZWw7XHJcblx0QElucHV0KCkgc2V0IGNyaXRlcmlhKHZhbHVlOiBDcml0ZXJpYU1vZGVsKSB7XHJcblx0XHR0aGlzLl9jcml0ZXJpYSA9IF8uY2xvbmVEZWVwKHZhbHVlKTtcclxuXHR9XHJcblxyXG5cdGdldCBjcml0ZXJpYSgpIHtcclxuXHRcdHJldHVybiB0aGlzLl9jcml0ZXJpYTtcclxuXHR9XHJcblxyXG5cdEBPdXRwdXQoKSBvblJlYWR5ID0gbmV3IEV2ZW50RW1pdHRlcjxDaGFydD4oKTtcclxuXHJcblx0Y29uc3RydWN0b3IocHVibGljIGluamVjdG9yOiBJbmplY3Rvcikge1xyXG5cdFx0c3VwZXIoKTtcclxuXHRcdHRoaXMuX3N1YnNjcmliZVRvTGFuZ3VhZ2UoKTtcclxuXHR9XHJcblxyXG5cdHByb3RlY3RlZCBfc3Vic2NyaWJlVG9MYW5ndWFnZSgpIHtcclxuXHRcdHRoaXMuX3RyYW5zbGF0ZVNlcnZpY2Uub25MYW5nQ2hhbmdlXHJcblx0XHRcdC5waXBlKFxyXG5cdFx0XHRcdGRpc3RpbmN0VW50aWxDaGFuZ2VkKChwcmUsIG5leHQpID0+IHByZS5sYW5nID09IG5leHQubGFuZyksXHJcblx0XHRcdFx0ZmlsdGVyKCgpID0+IHRoaXMuX2lzSW5pdGlhbGl6ZWQpLFxyXG5cdFx0XHRcdHRha2VVbnRpbCh0aGlzLmRlc3Ryb3kkKVxyXG5cdFx0XHQpXHJcblx0XHRcdC5zdWJzY3JpYmUoKF8pID0+IHtcclxuXHRcdFx0XHR0aGlzLl9yZWJ1aWxkVHJpZ2dlclN1Yi5uZXh0KHRydWUpO1xyXG5cdFx0XHR9KTtcclxuXHR9XHJcbn1cclxuIl19
@@ -1,6 +1,6 @@
1
1
  import { Directive, Input } from '@angular/core';
2
- import { BehaviorSubject, ReplaySubject } from 'rxjs';
3
2
  import _ from 'lodash';
3
+ import { BehaviorSubject, ReplaySubject } from 'rxjs';
4
4
  import { DestroySubject } from '../../../../shared/components';
5
5
  import { ChartManagerService } from '../services';
6
6
  import * as i0 from "@angular/core";
@@ -10,15 +10,26 @@ export class BaseCustomReport extends DestroySubject {
10
10
  this.injector = injector;
11
11
  this._chartHelperService = this.injector.get(ChartManagerService);
12
12
  this.direction = 'rtl';
13
+ this._dataSub = new ReplaySubject(null);
13
14
  this._criteriaSub = new ReplaySubject(null);
14
15
  this.criteria$ = this._criteriaSub.asObservable();
15
16
  this._configSub = new BehaviorSubject(null);
16
17
  this.config$ = this._configSub.asObservable();
17
18
  }
19
+ set data(data) {
20
+ this._data = data;
21
+ this._dataSub.next(data);
22
+ }
23
+ get data() {
24
+ return this._data;
25
+ }
18
26
  set criteria(value) {
19
27
  this._criteria = _.cloneDeep(value);
20
28
  this._criteriaSub.next(this._criteria);
21
29
  }
30
+ get criteria() {
31
+ return this._criteria;
32
+ }
22
33
  set config(obj) {
23
34
  if (obj) {
24
35
  this._configSub.next(obj);
@@ -40,11 +51,13 @@ export class BaseCustomReport extends DestroySubject {
40
51
  }
41
52
  }
42
53
  BaseCustomReport.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: BaseCustomReport, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive });
43
- BaseCustomReport.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: BaseCustomReport, inputs: { direction: "direction", data: "data", criteria: "criteria", config: "config" }, usesInheritance: true, ngImport: i0 });
54
+ BaseCustomReport.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: BaseCustomReport, inputs: { direction: "direction", definition: "definition", data: "data", criteria: "criteria", config: "config" }, usesInheritance: true, ngImport: i0 });
44
55
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: BaseCustomReport, decorators: [{
45
56
  type: Directive
46
57
  }], ctorParameters: function () { return [{ type: i0.Injector }]; }, propDecorators: { direction: [{
47
58
  type: Input
59
+ }], definition: [{
60
+ type: Input
48
61
  }], data: [{
49
62
  type: Input
50
63
  }], criteria: [{
@@ -52,4 +65,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
52
65
  }], config: [{
53
66
  type: Input
54
67
  }] } });
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1jdXN0b20tcmVwb3J0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9yZXBvcnRzL25kZi1yZXBvcnRzL2Jhc2UvYmFzZS1jdXN0b20tcmVwb3J0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVksS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRzNELE9BQU8sRUFBRSxlQUFlLEVBQWMsYUFBYSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ2xFLE9BQU8sQ0FBQyxNQUFNLFFBQVEsQ0FBQztBQUN2QixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFJL0QsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sYUFBYSxDQUFDOztBQUdsRCxNQUFNLE9BQWdCLGdCQUFpQixTQUFRLGNBQWM7SUEwQjVELFlBQXNDLFFBQWtCO1FBQ3ZELEtBQUssRUFBRSxDQUFDO1FBRDZCLGFBQVEsR0FBUixRQUFRLENBQVU7UUF6QjlDLHdCQUFtQixHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLG1CQUFtQixDQUFDLENBQUM7UUFFOUQsY0FBUyxHQUFjLEtBQUssQ0FBQztRQUc1QixpQkFBWSxHQUFHLElBQUksYUFBYSxDQUFnQixJQUFJLENBQUMsQ0FBQztRQUNoRSxjQUFTLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQU9uQyxlQUFVLEdBQUcsSUFBSSxlQUFlLENBQW9CLElBQUksQ0FBQyxDQUFDO1FBQ3BFLFlBQU8sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBYXpDLENBQUM7SUFuQkQsSUFBYSxRQUFRLENBQUMsS0FBb0I7UUFDekMsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3BDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBS0QsSUFBYSxNQUFNLENBQUMsR0FBc0I7UUFDekMsSUFBSSxHQUFHLEVBQUU7WUFDUixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUMxQjtJQUNGLENBQUM7SUFDRCxJQUFJLE1BQU07UUFDVCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDbkMsQ0FBQztJQVdELFVBQVUsQ0FBQyxLQUFZO1FBQ3RCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDekMsSUFBSSxDQUFDLGNBQWMsR0FBRyxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQy9CLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDckIsQ0FBQyxDQUFDO1FBQ0YsTUFBTSxDQUFDLGdCQUFnQixDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDNUQsY0FBYyxDQUFDLEdBQUcsRUFBRTtZQUNuQixJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ3JCLENBQUMsQ0FBQyxDQUFDO0lBQ0osQ0FBQzs7OEdBN0NvQixnQkFBZ0I7a0dBQWhCLGdCQUFnQjs0RkFBaEIsZ0JBQWdCO2tCQURyQyxTQUFTOytGQUlBLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUtPLFFBQVE7c0JBQXBCLEtBQUs7Z0JBUU8sTUFBTTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSW5qZWN0b3IsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBEaXJlY3Rpb24gfSBmcm9tICdAYW5ndWxhci9jZGsvYmlkaSc7XHJcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSwgUmVwbGF5U3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xyXG5pbXBvcnQgeyBEZXN0cm95U3ViamVjdCB9IGZyb20gJy4uLy4uLy4uLy4uL3NoYXJlZC9jb21wb25lbnRzJztcclxuXHJcbmltcG9ydCB7IENyaXRlcmlhTW9kZWwsIEN1c3RvbUNoYXJ0Q29uZmlnLCBSZXBvcnRSZXNwb25zZU1vZGVsIH0gZnJvbSAnLi4vbW9kZWxzJztcclxuaW1wb3J0IENoYXJ0IGZyb20gJ2NoYXJ0LmpzL2F1dG8nO1xyXG5pbXBvcnQgeyBDaGFydE1hbmFnZXJTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMnO1xyXG5cclxuQERpcmVjdGl2ZSgpXHJcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlQ3VzdG9tUmVwb3J0IGV4dGVuZHMgRGVzdHJveVN1YmplY3Qge1xyXG5cdHByb3RlY3RlZCBfY2hhcnRIZWxwZXJTZXJ2aWNlID0gdGhpcy5pbmplY3Rvci5nZXQoQ2hhcnRNYW5hZ2VyU2VydmljZSk7XHJcblxyXG5cdEBJbnB1dCgpIGRpcmVjdGlvbjogRGlyZWN0aW9uID0gJ3J0bCc7XHJcblx0QElucHV0KCkgZGF0YTogUmVwb3J0UmVzcG9uc2VNb2RlbDtcclxuXHJcblx0cHJvdGVjdGVkIF9jcml0ZXJpYVN1YiA9IG5ldyBSZXBsYXlTdWJqZWN0PENyaXRlcmlhTW9kZWw+KG51bGwpO1xyXG5cdGNyaXRlcmlhJCA9IHRoaXMuX2NyaXRlcmlhU3ViLmFzT2JzZXJ2YWJsZSgpO1xyXG5cdHByaXZhdGUgX2NyaXRlcmlhOiBDcml0ZXJpYU1vZGVsO1xyXG5cdEBJbnB1dCgpIHNldCBjcml0ZXJpYSh2YWx1ZTogQ3JpdGVyaWFNb2RlbCkge1xyXG5cdFx0dGhpcy5fY3JpdGVyaWEgPSBfLmNsb25lRGVlcCh2YWx1ZSk7XHJcblx0XHR0aGlzLl9jcml0ZXJpYVN1Yi5uZXh0KHRoaXMuX2NyaXRlcmlhKTtcclxuXHR9XHJcblxyXG5cdHByb3RlY3RlZCBfY29uZmlnU3ViID0gbmV3IEJlaGF2aW9yU3ViamVjdDxDdXN0b21DaGFydENvbmZpZz4obnVsbCk7XHJcblx0Y29uZmlnJCA9IHRoaXMuX2NvbmZpZ1N1Yi5hc09ic2VydmFibGUoKTtcclxuXHJcblx0QElucHV0KCkgc2V0IGNvbmZpZyhvYmo6IEN1c3RvbUNoYXJ0Q29uZmlnKSB7XHJcblx0XHRpZiAob2JqKSB7XHJcblx0XHRcdHRoaXMuX2NvbmZpZ1N1Yi5uZXh0KG9iaik7XHJcblx0XHR9XHJcblx0fVxyXG5cdGdldCBjb25maWcoKSB7XHJcblx0XHRyZXR1cm4gdGhpcy5fY29uZmlnU3ViLmdldFZhbHVlKCk7XHJcblx0fVxyXG5cclxuXHRwcm90ZWN0ZWQgY29uc3RydWN0b3IocHVibGljIHJlYWRvbmx5IGluamVjdG9yOiBJbmplY3Rvcikge1xyXG5cdFx0c3VwZXIoKTtcclxuXHR9XHJcblxyXG5cdGNoYXJ0OiBDaGFydDtcclxuXHRwcm90ZWN0ZWQgX3ByaW50TGlzdGVuZXI6IEV2ZW50TGlzdGVuZXI7XHJcblxyXG5cdGFic3RyYWN0IHByaW50KCk6IHZvaWQ7XHJcblxyXG5cdGNoYXJ0UmVhZHkoY2hhcnQ6IENoYXJ0KSB7XHJcblx0XHR0aGlzLmNoYXJ0ID0gY2hhcnQ7XHJcblx0XHR0aGlzLl9jaGFydEhlbHBlclNlcnZpY2Uuc2V0Q2hhcnQoY2hhcnQpO1xyXG5cdFx0dGhpcy5fcHJpbnRMaXN0ZW5lciA9IChldmVudCkgPT4ge1xyXG5cdFx0XHR0aGlzLmNoYXJ0LnJlc2l6ZSgpO1xyXG5cdFx0fTtcclxuXHRcdHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKCdiZWZvcmVwcmludCcsIHRoaXMuX3ByaW50TGlzdGVuZXIpO1xyXG5cdFx0cXVldWVNaWNyb3Rhc2soKCkgPT4ge1xyXG5cdFx0XHR0aGlzLmNoYXJ0LnJlc2l6ZSgpO1xyXG5cdFx0fSk7XHJcblx0fVxyXG59XHJcbiJdfQ==
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1jdXN0b20tcmVwb3J0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9yZXBvcnRzL25kZi1yZXBvcnRzL2Jhc2UvYmFzZS1jdXN0b20tcmVwb3J0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVksS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRzNELE9BQU8sQ0FBQyxNQUFNLFFBQVEsQ0FBQztBQUN2QixPQUFPLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN0RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFJL0QsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sYUFBYSxDQUFDOztBQUlsRCxNQUFNLE9BQWdCLGdCQUFpQixTQUFRLGNBQWM7SUE4QzVELFlBQTRCLFFBQWtCO1FBQzdDLEtBQUssRUFBRSxDQUFDO1FBRG1CLGFBQVEsR0FBUixRQUFRLENBQVU7UUF6Q3BDLHdCQUFtQixHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLG1CQUFtQixDQUFDLENBQUM7UUFFOUQsY0FBUyxHQUFjLEtBQUssQ0FBQztRQUk1QixhQUFRLEdBQUcsSUFBSSxhQUFhLENBQXNCLElBQUksQ0FBQyxDQUFDO1FBV3hELGlCQUFZLEdBQUcsSUFBSSxhQUFhLENBQWdCLElBQUksQ0FBQyxDQUFDO1FBQ2hFLGNBQVMsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBV25DLGVBQVUsR0FBRyxJQUFJLGVBQWUsQ0FBYyxJQUFJLENBQUMsQ0FBQztRQUM5RCxZQUFPLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQWF6QyxDQUFDO0lBbkNELElBQWEsSUFBSSxDQUFDLElBQXlCO1FBQzFDLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1FBQ2xCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzFCLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDUCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDbkIsQ0FBQztJQUtELElBQWEsUUFBUSxDQUFDLEtBQW9CO1FBQ3pDLElBQUksQ0FBQyxTQUFTLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELElBQUksUUFBUTtRQUNYLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN2QixDQUFDO0lBS0QsSUFBYSxNQUFNLENBQUMsR0FBZ0I7UUFDbkMsSUFBSSxHQUFHLEVBQUU7WUFDUixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUMxQjtJQUNGLENBQUM7SUFDRCxJQUFJLE1BQU07UUFDVCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDbkMsQ0FBQztJQU1ELFVBQVUsQ0FBQyxLQUFZO1FBQ3RCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDekMsSUFBSSxDQUFDLGNBQWMsR0FBRyxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQy9CLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDckIsQ0FBQyxDQUFDO1FBQ0YsTUFBTSxDQUFDLGdCQUFnQixDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDNUQsY0FBYyxDQUFDLEdBQUcsRUFBRTtZQUNuQixJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ3JCLENBQUMsQ0FBQyxDQUFDO0lBQ0osQ0FBQzs7OEdBNURvQixnQkFBZ0I7a0dBQWhCLGdCQUFnQjs0RkFBaEIsZ0JBQWdCO2tCQURyQyxTQUFTOytGQVFBLFNBQVM7c0JBQWpCLEtBQUs7Z0JBRUcsVUFBVTtzQkFBbEIsS0FBSztnQkFJTyxJQUFJO3NCQUFoQixLQUFLO2dCQVlPLFFBQVE7c0JBQXBCLEtBQUs7Z0JBWU8sTUFBTTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSW5qZWN0b3IsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBEaXJlY3Rpb24gfSBmcm9tICdAYW5ndWxhci9jZGsvYmlkaSc7XHJcbmltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XHJcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgUmVwbGF5U3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBEZXN0cm95U3ViamVjdCB9IGZyb20gJy4uLy4uLy4uLy4uL3NoYXJlZC9jb21wb25lbnRzJztcclxuXHJcbmltcG9ydCBDaGFydCBmcm9tICdjaGFydC5qcy9hdXRvJztcclxuaW1wb3J0IHsgQ3JpdGVyaWFNb2RlbCwgQ3VzdG9tQ2hhcnQsIEN1c3RvbUNoYXJ0RGVmaW5pdGlvbiwgUmVwb3J0UmVzcG9uc2VNb2RlbCB9IGZyb20gJy4uL21vZGVscyc7XHJcbmltcG9ydCB7IENoYXJ0TWFuYWdlclNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcyc7XHJcblxyXG5cclxuQERpcmVjdGl2ZSgpXHJcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlQ3VzdG9tUmVwb3J0IGV4dGVuZHMgRGVzdHJveVN1YmplY3Qge1xyXG5cdHByb3RlY3RlZCBjaGFydDogQ2hhcnQ7XHJcblx0cHJvdGVjdGVkIF9wcmludExpc3RlbmVyOiBFdmVudExpc3RlbmVyO1xyXG5cdGFic3RyYWN0IHByaW50KCk6IHZvaWQ7XHJcblxyXG5cdHByb3RlY3RlZCBfY2hhcnRIZWxwZXJTZXJ2aWNlID0gdGhpcy5pbmplY3Rvci5nZXQoQ2hhcnRNYW5hZ2VyU2VydmljZSk7XHJcblxyXG5cdEBJbnB1dCgpIGRpcmVjdGlvbjogRGlyZWN0aW9uID0gJ3J0bCc7XHJcblxyXG5cdEBJbnB1dCgpIGRlZmluaXRpb246IEN1c3RvbUNoYXJ0RGVmaW5pdGlvbjtcclxuXHJcblx0cHJvdGVjdGVkIF9kYXRhU3ViID0gbmV3IFJlcGxheVN1YmplY3Q8UmVwb3J0UmVzcG9uc2VNb2RlbD4obnVsbCk7XHJcblx0cHJpdmF0ZSBfZGF0YTogUmVwb3J0UmVzcG9uc2VNb2RlbDtcclxuXHRASW5wdXQoKSBzZXQgZGF0YShkYXRhOiBSZXBvcnRSZXNwb25zZU1vZGVsKSB7XHJcblx0XHR0aGlzLl9kYXRhID0gZGF0YTtcclxuXHRcdHRoaXMuX2RhdGFTdWIubmV4dChkYXRhKTtcclxuXHR9XHJcblxyXG5cdGdldCBkYXRhKCkge1xyXG5cdFx0cmV0dXJuIHRoaXMuX2RhdGE7XHJcblx0fVxyXG5cclxuXHRwcm90ZWN0ZWQgX2NyaXRlcmlhU3ViID0gbmV3IFJlcGxheVN1YmplY3Q8Q3JpdGVyaWFNb2RlbD4obnVsbCk7XHJcblx0Y3JpdGVyaWEkID0gdGhpcy5fY3JpdGVyaWFTdWIuYXNPYnNlcnZhYmxlKCk7XHJcblx0cHJpdmF0ZSBfY3JpdGVyaWE6IENyaXRlcmlhTW9kZWw7XHJcblx0QElucHV0KCkgc2V0IGNyaXRlcmlhKHZhbHVlOiBDcml0ZXJpYU1vZGVsKSB7XHJcblx0XHR0aGlzLl9jcml0ZXJpYSA9IF8uY2xvbmVEZWVwKHZhbHVlKTtcclxuXHRcdHRoaXMuX2NyaXRlcmlhU3ViLm5leHQodGhpcy5fY3JpdGVyaWEpO1xyXG5cdH1cclxuXHJcblx0Z2V0IGNyaXRlcmlhKCkge1xyXG5cdFx0cmV0dXJuIHRoaXMuX2NyaXRlcmlhO1xyXG5cdH1cclxuXHJcblx0cHJvdGVjdGVkIF9jb25maWdTdWIgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PEN1c3RvbUNoYXJ0PihudWxsKTtcclxuXHRjb25maWckID0gdGhpcy5fY29uZmlnU3ViLmFzT2JzZXJ2YWJsZSgpO1xyXG5cclxuXHRASW5wdXQoKSBzZXQgY29uZmlnKG9iajogQ3VzdG9tQ2hhcnQpIHtcclxuXHRcdGlmIChvYmopIHtcclxuXHRcdFx0dGhpcy5fY29uZmlnU3ViLm5leHQob2JqKTtcclxuXHRcdH1cclxuXHR9XHJcblx0Z2V0IGNvbmZpZygpIHtcclxuXHRcdHJldHVybiB0aGlzLl9jb25maWdTdWIuZ2V0VmFsdWUoKTtcclxuXHR9XHJcblxyXG5cdGNvbnN0cnVjdG9yKHB1YmxpYyByZWFkb25seSBpbmplY3RvcjogSW5qZWN0b3IpIHtcclxuXHRcdHN1cGVyKCk7XHJcblx0fVxyXG5cclxuXHRjaGFydFJlYWR5KGNoYXJ0OiBDaGFydCkge1xyXG5cdFx0dGhpcy5jaGFydCA9IGNoYXJ0O1xyXG5cdFx0dGhpcy5fY2hhcnRIZWxwZXJTZXJ2aWNlLnNldENoYXJ0KGNoYXJ0KTtcclxuXHRcdHRoaXMuX3ByaW50TGlzdGVuZXIgPSAoZXZlbnQpID0+IHtcclxuXHRcdFx0dGhpcy5jaGFydC5yZXNpemUoKTtcclxuXHRcdH07XHJcblx0XHR3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcignYmVmb3JlcHJpbnQnLCB0aGlzLl9wcmludExpc3RlbmVyKTtcclxuXHRcdHF1ZXVlTWljcm90YXNrKCgpID0+IHtcclxuXHRcdFx0dGhpcy5jaGFydC5yZXNpemUoKTtcclxuXHRcdH0pO1xyXG5cdH1cclxufVxyXG4iXX0=