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.
- package/bundles/nuxeo-development-framework.umd.js +491 -288
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/reports/charts/plugins/data-labels.js +166 -102
- package/esm2015/lib/components/reports/charts/utility/colors.js +13 -1
- package/esm2015/lib/components/reports/ndf-reports/base/base-chart.js +2 -2
- package/esm2015/lib/components/reports/ndf-reports/base/base-custom-report.js +16 -3
- package/esm2015/lib/components/reports/ndf-reports/base/base-graph.report.js +10 -22
- package/esm2015/lib/components/reports/ndf-reports/base/base-report.js +5 -2
- package/esm2015/lib/components/reports/ndf-reports/charts-components/custom-chart/custom-chart.component.js +68 -0
- package/esm2015/lib/components/reports/ndf-reports/charts-components/index.js +2 -1
- package/esm2015/lib/components/reports/ndf-reports/components/_parts/custom-chart-dialog/custom-chart-dialog.component.js +41 -0
- package/esm2015/lib/components/reports/ndf-reports/components/_parts/index.js +2 -1
- package/esm2015/lib/components/reports/ndf-reports/components/custom-report/custom-report.component.js +23 -37
- package/esm2015/lib/components/reports/ndf-reports/components/dynamic-timeline-report/dynamic-timeline-report.component.js +2 -6
- package/esm2015/lib/components/reports/ndf-reports/containers/ndf-report/ndf-report.component.js +4 -3
- package/esm2015/lib/components/reports/ndf-reports/containers/ndf-reports/ndf-reports.component.js +2 -2
- package/esm2015/lib/components/reports/ndf-reports/models/custom-definition.js +1 -1
- package/esm2015/lib/components/reports/ndf-reports/models/dialog-data.js +1 -1
- package/esm2015/lib/components/reports/ndf-reports/models/report-config.js +1 -1
- package/esm2015/lib/components/reports/ndf-reports/ndf-reports.module.js +5 -3
- package/esm2015/lib/components/reports/ndf-reports/public-api.js +2 -1
- package/esm2015/lib/components/reports/ndf-reports/services/chart-manager.service.js +15 -9
- package/esm2015/lib/components/reports/ndf-reports/services/custom-reports-registry.service.js +1 -1
- package/esm2015/lib/components/reports/ndf-reports/services/report-config-mapper.service.js +1 -1
- package/esm2015/lib/components/reports/ndf-reports/services/report-transform.service.js +2 -2
- package/esm2015/lib/components/reports/ndf-reports/services/reports-dialog.service.js +32 -0
- package/fesm2015/nuxeo-development-framework.js +452 -267
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/reports/charts/utility/colors.d.ts +5 -0
- package/lib/components/reports/ndf-reports/base/base-chart.d.ts +1 -1
- package/lib/components/reports/ndf-reports/base/base-custom-report.d.ts +18 -13
- package/lib/components/reports/ndf-reports/base/base-graph.report.d.ts +5 -13
- package/lib/components/reports/ndf-reports/base/base-report.d.ts +4 -1
- package/lib/components/reports/ndf-reports/charts-components/custom-chart/custom-chart.component.d.ts +15 -0
- package/lib/components/reports/ndf-reports/charts-components/index.d.ts +1 -0
- package/lib/components/reports/ndf-reports/components/_parts/custom-chart-dialog/custom-chart-dialog.component.d.ts +14 -0
- package/lib/components/reports/ndf-reports/components/_parts/index.d.ts +1 -0
- package/lib/components/reports/ndf-reports/components/custom-report/custom-report.component.d.ts +8 -10
- package/lib/components/reports/ndf-reports/models/custom-definition.d.ts +3 -3
- package/lib/components/reports/ndf-reports/models/dialog-data.d.ts +8 -0
- package/lib/components/reports/ndf-reports/models/report-config.d.ts +2 -2
- package/lib/components/reports/ndf-reports/ndf-reports.module.d.ts +22 -20
- package/lib/components/reports/ndf-reports/public-api.d.ts +1 -0
- package/lib/components/reports/ndf-reports/services/chart-manager.service.d.ts +2 -2
- package/lib/components/reports/ndf-reports/services/custom-reports-registry.service.d.ts +3 -2
- package/lib/components/reports/ndf-reports/services/report-config-mapper.service.d.ts +2 -2
- package/lib/components/reports/ndf-reports/services/reports-dialog.service.d.ts +21 -0
- 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
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
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
|
|
83
|
+
const { ctx } = chart;
|
|
25
84
|
const isHorizontalChart = ((_a = chart.options) === null || _a === void 0 ? void 0 : _a.indexAxis) === 'y';
|
|
26
|
-
const { isHorizontalReversed } =
|
|
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,
|
|
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
|
|
34
|
-
|
|
35
|
-
if (!percentage || !isVisible) {
|
|
92
|
+
const labelData = extractLabelData(dataset, index, totalSum, chart);
|
|
93
|
+
if (!labelData)
|
|
36
94
|
return;
|
|
37
|
-
|
|
38
|
-
const
|
|
39
|
-
const
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
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
|
|
74
|
-
const {
|
|
75
|
-
|
|
76
|
-
const
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
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
|
-
|
|
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,
|
|
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
|
|
105
|
-
|
|
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
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
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
|
-
|
|
126
|
-
|
|
195
|
+
x: arc.x + Math.cos(midAngle) * radius,
|
|
196
|
+
y: arc.y + Math.sin(midAngle) * radius
|
|
127
197
|
};
|
|
128
198
|
}
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
199
|
+
// Utility functions
|
|
200
|
+
function getBarChartOrientation(chart) {
|
|
201
|
+
var _a, _b;
|
|
202
|
+
const scales = chart.options.scales;
|
|
132
203
|
return {
|
|
133
|
-
|
|
134
|
-
|
|
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
|
-
|
|
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,
|
|
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,
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1jdXN0b20tcmVwb3J0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9yZXBvcnRzL25kZi1yZXBvcnRzL2Jhc2UvYmFzZS1jdXN0b20tcmVwb3J0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVksS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRzNELE9BQU8sQ0FBQyxNQUFNLFFBQVEsQ0FBQztBQUN2QixPQUFPLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN0RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFJL0QsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sYUFBYSxDQUFDOztBQUlsRCxNQUFNLE9BQWdCLGdCQUFpQixTQUFRLGNBQWM7SUE4QzVELFlBQTRCLFFBQWtCO1FBQzdDLEtBQUssRUFBRSxDQUFDO1FBRG1CLGFBQVEsR0FBUixRQUFRLENBQVU7UUF6Q3BDLHdCQUFtQixHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLG1CQUFtQixDQUFDLENBQUM7UUFFOUQsY0FBUyxHQUFjLEtBQUssQ0FBQztRQUk1QixhQUFRLEdBQUcsSUFBSSxhQUFhLENBQXNCLElBQUksQ0FBQyxDQUFDO1FBV3hELGlCQUFZLEdBQUcsSUFBSSxhQUFhLENBQWdCLElBQUksQ0FBQyxDQUFDO1FBQ2hFLGNBQVMsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBV25DLGVBQVUsR0FBRyxJQUFJLGVBQWUsQ0FBYyxJQUFJLENBQUMsQ0FBQztRQUM5RCxZQUFPLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQWF6QyxDQUFDO0lBbkNELElBQWEsSUFBSSxDQUFDLElBQXlCO1FBQzFDLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1FBQ2xCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzFCLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDUCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDbkIsQ0FBQztJQUtELElBQWEsUUFBUSxDQUFDLEtBQW9CO1FBQ3pDLElBQUksQ0FBQyxTQUFTLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELElBQUksUUFBUTtRQUNYLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN2QixDQUFDO0lBS0QsSUFBYSxNQUFNLENBQUMsR0FBZ0I7UUFDbkMsSUFBSSxHQUFHLEVBQUU7WUFDUixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUMxQjtJQUNGLENBQUM7SUFDRCxJQUFJLE1BQU07UUFDVCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDbkMsQ0FBQztJQU1ELFVBQVUsQ0FBQyxLQUFZO1FBQ3RCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDekMsSUFBSSxDQUFDLGNBQWMsR0FBRyxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQy9CLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDckIsQ0FBQyxDQUFDO1FBQ0YsTUFBTSxDQUFDLGdCQUFnQixDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDNUQsY0FBYyxDQUFDLEdBQUcsRUFBRTtZQUNuQixJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ3JCLENBQUMsQ0FBQyxDQUFDO0lBQ0osQ0FBQzs7OEdBNURvQixnQkFBZ0I7a0dBQWhCLGdCQUFnQjs0RkFBaEIsZ0JBQWdCO2tCQURyQyxTQUFTOytGQVFBLFNBQVM7c0JBQWpCLEtBQUs7Z0JBRUcsVUFBVTtzQkFBbEIsS0FBSztnQkFJTyxJQUFJO3NCQUFoQixLQUFLO2dCQVlPLFFBQVE7c0JBQXBCLEtBQUs7Z0JBWU8sTUFBTTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSW5qZWN0b3IsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBEaXJlY3Rpb24gfSBmcm9tICdAYW5ndWxhci9jZGsvYmlkaSc7XHJcbmltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XHJcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgUmVwbGF5U3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBEZXN0cm95U3ViamVjdCB9IGZyb20gJy4uLy4uLy4uLy4uL3NoYXJlZC9jb21wb25lbnRzJztcclxuXHJcbmltcG9ydCBDaGFydCBmcm9tICdjaGFydC5qcy9hdXRvJztcclxuaW1wb3J0IHsgQ3JpdGVyaWFNb2RlbCwgQ3VzdG9tQ2hhcnQsIEN1c3RvbUNoYXJ0RGVmaW5pdGlvbiwgUmVwb3J0UmVzcG9uc2VNb2RlbCB9IGZyb20gJy4uL21vZGVscyc7XHJcbmltcG9ydCB7IENoYXJ0TWFuYWdlclNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcyc7XHJcblxyXG5cclxuQERpcmVjdGl2ZSgpXHJcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlQ3VzdG9tUmVwb3J0IGV4dGVuZHMgRGVzdHJveVN1YmplY3Qge1xyXG5cdHByb3RlY3RlZCBjaGFydDogQ2hhcnQ7XHJcblx0cHJvdGVjdGVkIF9wcmludExpc3RlbmVyOiBFdmVudExpc3RlbmVyO1xyXG5cdGFic3RyYWN0IHByaW50KCk6IHZvaWQ7XHJcblxyXG5cdHByb3RlY3RlZCBfY2hhcnRIZWxwZXJTZXJ2aWNlID0gdGhpcy5pbmplY3Rvci5nZXQoQ2hhcnRNYW5hZ2VyU2VydmljZSk7XHJcblxyXG5cdEBJbnB1dCgpIGRpcmVjdGlvbjogRGlyZWN0aW9uID0gJ3J0bCc7XHJcblxyXG5cdEBJbnB1dCgpIGRlZmluaXRpb246IEN1c3RvbUNoYXJ0RGVmaW5pdGlvbjtcclxuXHJcblx0cHJvdGVjdGVkIF9kYXRhU3ViID0gbmV3IFJlcGxheVN1YmplY3Q8UmVwb3J0UmVzcG9uc2VNb2RlbD4obnVsbCk7XHJcblx0cHJpdmF0ZSBfZGF0YTogUmVwb3J0UmVzcG9uc2VNb2RlbDtcclxuXHRASW5wdXQoKSBzZXQgZGF0YShkYXRhOiBSZXBvcnRSZXNwb25zZU1vZGVsKSB7XHJcblx0XHR0aGlzLl9kYXRhID0gZGF0YTtcclxuXHRcdHRoaXMuX2RhdGFTdWIubmV4dChkYXRhKTtcclxuXHR9XHJcblxyXG5cdGdldCBkYXRhKCkge1xyXG5cdFx0cmV0dXJuIHRoaXMuX2RhdGE7XHJcblx0fVxyXG5cclxuXHRwcm90ZWN0ZWQgX2NyaXRlcmlhU3ViID0gbmV3IFJlcGxheVN1YmplY3Q8Q3JpdGVyaWFNb2RlbD4obnVsbCk7XHJcblx0Y3JpdGVyaWEkID0gdGhpcy5fY3JpdGVyaWFTdWIuYXNPYnNlcnZhYmxlKCk7XHJcblx0cHJpdmF0ZSBfY3JpdGVyaWE6IENyaXRlcmlhTW9kZWw7XHJcblx0QElucHV0KCkgc2V0IGNyaXRlcmlhKHZhbHVlOiBDcml0ZXJpYU1vZGVsKSB7XHJcblx0XHR0aGlzLl9jcml0ZXJpYSA9IF8uY2xvbmVEZWVwKHZhbHVlKTtcclxuXHRcdHRoaXMuX2NyaXRlcmlhU3ViLm5leHQodGhpcy5fY3JpdGVyaWEpO1xyXG5cdH1cclxuXHJcblx0Z2V0IGNyaXRlcmlhKCkge1xyXG5cdFx0cmV0dXJuIHRoaXMuX2NyaXRlcmlhO1xyXG5cdH1cclxuXHJcblx0cHJvdGVjdGVkIF9jb25maWdTdWIgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PEN1c3RvbUNoYXJ0PihudWxsKTtcclxuXHRjb25maWckID0gdGhpcy5fY29uZmlnU3ViLmFzT2JzZXJ2YWJsZSgpO1xyXG5cclxuXHRASW5wdXQoKSBzZXQgY29uZmlnKG9iajogQ3VzdG9tQ2hhcnQpIHtcclxuXHRcdGlmIChvYmopIHtcclxuXHRcdFx0dGhpcy5fY29uZmlnU3ViLm5leHQob2JqKTtcclxuXHRcdH1cclxuXHR9XHJcblx0Z2V0IGNvbmZpZygpIHtcclxuXHRcdHJldHVybiB0aGlzLl9jb25maWdTdWIuZ2V0VmFsdWUoKTtcclxuXHR9XHJcblxyXG5cdGNvbnN0cnVjdG9yKHB1YmxpYyByZWFkb25seSBpbmplY3RvcjogSW5qZWN0b3IpIHtcclxuXHRcdHN1cGVyKCk7XHJcblx0fVxyXG5cclxuXHRjaGFydFJlYWR5KGNoYXJ0OiBDaGFydCkge1xyXG5cdFx0dGhpcy5jaGFydCA9IGNoYXJ0O1xyXG5cdFx0dGhpcy5fY2hhcnRIZWxwZXJTZXJ2aWNlLnNldENoYXJ0KGNoYXJ0KTtcclxuXHRcdHRoaXMuX3ByaW50TGlzdGVuZXIgPSAoZXZlbnQpID0+IHtcclxuXHRcdFx0dGhpcy5jaGFydC5yZXNpemUoKTtcclxuXHRcdH07XHJcblx0XHR3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcignYmVmb3JlcHJpbnQnLCB0aGlzLl9wcmludExpc3RlbmVyKTtcclxuXHRcdHF1ZXVlTWljcm90YXNrKCgpID0+IHtcclxuXHRcdFx0dGhpcy5jaGFydC5yZXNpemUoKTtcclxuXHRcdH0pO1xyXG5cdH1cclxufVxyXG4iXX0=
|