@sentropic/design-system-vue 0.11.0 → 0.13.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/dist/Calendar.d.ts.map +1 -1
- package/dist/Calendar.js +235 -74
- package/dist/Calendar.js.map +1 -1
- package/dist/ComboChart.d.ts +119 -0
- package/dist/ComboChart.d.ts.map +1 -0
- package/dist/ComboChart.js +280 -0
- package/dist/ComboChart.js.map +1 -0
- package/dist/FunnelChart.d.ts +103 -0
- package/dist/FunnelChart.d.ts.map +1 -0
- package/dist/FunnelChart.js +191 -0
- package/dist/FunnelChart.js.map +1 -0
- package/dist/GaugeChart.d.ts +134 -0
- package/dist/GaugeChart.d.ts.map +1 -0
- package/dist/GaugeChart.js +152 -0
- package/dist/GaugeChart.js.map +1 -0
- package/dist/KpiCard.d.ts +151 -0
- package/dist/KpiCard.d.ts.map +1 -0
- package/dist/KpiCard.js +155 -0
- package/dist/KpiCard.js.map +1 -0
- package/dist/Popper.d.ts +58 -0
- package/dist/Popper.d.ts.map +1 -1
- package/dist/Popper.js +136 -5
- package/dist/Popper.js.map +1 -1
- package/dist/Rating.d.ts.map +1 -1
- package/dist/Rating.js +111 -18
- package/dist/Rating.js.map +1 -1
- package/dist/SelectableList.d.ts +2 -0
- package/dist/SelectableList.d.ts.map +1 -1
- package/dist/SelectableList.js +72 -21
- package/dist/SelectableList.js.map +1 -1
- package/dist/SelectableRow.d.ts +2 -2
- package/dist/SelectableRow.d.ts.map +1 -1
- package/dist/SelectableRow.js +15 -5
- package/dist/SelectableRow.js.map +1 -1
- package/dist/SlideIndicator.d.ts.map +1 -1
- package/dist/SlideIndicator.js +12 -5
- package/dist/SlideIndicator.js.map +1 -1
- package/dist/TimePicker.d.ts +1 -1
- package/dist/TimePicker.d.ts.map +1 -1
- package/dist/TimePicker.js +150 -14
- package/dist/TimePicker.js.map +1 -1
- package/dist/TreemapChart.d.ts +95 -0
- package/dist/TreemapChart.d.ts.map +1 -0
- package/dist/TreemapChart.js +255 -0
- package/dist/TreemapChart.js.map +1 -0
- package/dist/WaterfallChart.d.ts +84 -0
- package/dist/WaterfallChart.d.ts.map +1 -0
- package/dist/WaterfallChart.js +186 -0
- package/dist/WaterfallChart.js.map +1 -0
- package/dist/chartScale.d.ts +4 -0
- package/dist/chartScale.d.ts.map +1 -1
- package/dist/chartScale.js +44 -0
- package/dist/chartScale.js.map +1 -1
- package/dist/index.d.ts +14 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +7 -1
- package/dist/index.js.map +1 -1
- package/dist/styles.css +721 -2
- package/package.json +1 -1
|
@@ -0,0 +1,280 @@
|
|
|
1
|
+
import { defineComponent, h, ref } from "vue";
|
|
2
|
+
import { classNames } from "./classNames.js";
|
|
3
|
+
import { buildLinearPath, buildSmoothPath, chartDataList, formatTick, niceTicks, scaleLinear } from "./chartScale.js";
|
|
4
|
+
const MARGIN = { top: 12, right: 52, bottom: 32, left: 52 };
|
|
5
|
+
export const ComboChart = defineComponent({
|
|
6
|
+
name: "ComboChart",
|
|
7
|
+
props: {
|
|
8
|
+
categories: { type: Array, required: true },
|
|
9
|
+
bars: { type: Array, default: () => [] },
|
|
10
|
+
lines: { type: Array, default: () => [] },
|
|
11
|
+
leftAxisLabel: { type: String, default: undefined },
|
|
12
|
+
rightAxisLabel: { type: String, default: undefined },
|
|
13
|
+
legend: { type: Boolean, default: true },
|
|
14
|
+
width: { type: Number, default: 480 },
|
|
15
|
+
height: { type: Number, default: 240 },
|
|
16
|
+
label: { type: String, required: true },
|
|
17
|
+
class: { type: String, default: undefined },
|
|
18
|
+
},
|
|
19
|
+
setup(props, { attrs }) {
|
|
20
|
+
const hovered = ref(null);
|
|
21
|
+
function handleLeave() {
|
|
22
|
+
hovered.value = null;
|
|
23
|
+
}
|
|
24
|
+
function handleVisualPointerMove(event) {
|
|
25
|
+
const target = event.target;
|
|
26
|
+
if (!(target instanceof Element)) {
|
|
27
|
+
hovered.value = null;
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
const kind = target.getAttribute("data-chart-kind");
|
|
31
|
+
const a = Number(target.getAttribute("data-chart-a"));
|
|
32
|
+
const b = Number(target.getAttribute("data-chart-b"));
|
|
33
|
+
if (kind === "bar" && Number.isInteger(a) && Number.isInteger(b)) {
|
|
34
|
+
hovered.value = { kind: "bar", gi: a, si: b };
|
|
35
|
+
}
|
|
36
|
+
else if (kind === "line" && Number.isInteger(a) && Number.isInteger(b)) {
|
|
37
|
+
hovered.value = { kind: "line", li: a, pi: b };
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
hovered.value = null;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
return () => {
|
|
44
|
+
const width = props.width ?? 480;
|
|
45
|
+
const height = props.height ?? 240;
|
|
46
|
+
const categories = props.categories;
|
|
47
|
+
const bars = props.bars ?? [];
|
|
48
|
+
const lines = props.lines ?? [];
|
|
49
|
+
const leftAxisLabel = props.leftAxisLabel;
|
|
50
|
+
const rightAxisLabel = props.rightAxisLabel;
|
|
51
|
+
const legend = props.legend ?? true;
|
|
52
|
+
const label = props.label;
|
|
53
|
+
const plotWidth = Math.max(width - MARGIN.left - MARGIN.right, 1);
|
|
54
|
+
const plotHeight = Math.max(height - MARGIN.top - MARGIN.bottom, 1);
|
|
55
|
+
// Une valeur n'est « présente » que si elle est un nombre fini : un trou
|
|
56
|
+
// (undefined/null/NaN) reste un trou, jamais un 0 fantôme.
|
|
57
|
+
const hasValue = (v) => typeof v === "number" && Number.isFinite(v);
|
|
58
|
+
// Left axis (bars): include zero.
|
|
59
|
+
const leftValues = bars.flatMap((s) => s.data).filter(hasValue);
|
|
60
|
+
const leftMinRaw = Math.min(0, ...(leftValues.length ? leftValues : [0]));
|
|
61
|
+
const leftMaxRaw = Math.max(0, ...(leftValues.length ? leftValues : [0]));
|
|
62
|
+
const leftTicks = niceTicks(leftMinRaw, leftMaxRaw, 5);
|
|
63
|
+
const leftScale = { ticks: leftTicks, domainMin: leftTicks[0], domainMax: leftTicks[leftTicks.length - 1] };
|
|
64
|
+
// Right axis (lines): padded domain.
|
|
65
|
+
let rightScale;
|
|
66
|
+
const rightValues = lines.flatMap((s) => s.data).filter(hasValue);
|
|
67
|
+
if (rightValues.length === 0) {
|
|
68
|
+
const ticks = niceTicks(0, 1, 5);
|
|
69
|
+
rightScale = { ticks, domainMin: ticks[0], domainMax: ticks[ticks.length - 1] };
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
const minRaw = Math.min(...rightValues);
|
|
73
|
+
const maxRaw = Math.max(...rightValues);
|
|
74
|
+
const padded = (maxRaw - minRaw) * 0.08 || Math.max(Math.abs(maxRaw), 1) * 0.1;
|
|
75
|
+
const ticks = niceTicks(minRaw - padded, maxRaw + padded, 5);
|
|
76
|
+
rightScale = { ticks, domainMin: ticks[0], domainMax: ticks[ticks.length - 1] };
|
|
77
|
+
}
|
|
78
|
+
const bandCenter = (i) => {
|
|
79
|
+
const band = plotWidth / Math.max(categories.length, 1);
|
|
80
|
+
return MARGIN.left + band * (i + 0.5);
|
|
81
|
+
};
|
|
82
|
+
let barGroups = [];
|
|
83
|
+
if (categories.length !== 0 && bars.length !== 0) {
|
|
84
|
+
const { domainMin, domainMax } = leftScale;
|
|
85
|
+
const band = plotWidth / categories.length;
|
|
86
|
+
const groupWidth = band * 0.62;
|
|
87
|
+
const barWidth = groupWidth / bars.length;
|
|
88
|
+
const zeroY = scaleLinear(0, domainMin, domainMax, plotHeight, 0);
|
|
89
|
+
barGroups = categories.map((_, ci) => {
|
|
90
|
+
const groupX = MARGIN.left + band * ci + (band - groupWidth) / 2;
|
|
91
|
+
return bars.map((series, si) => {
|
|
92
|
+
const value = series.data[ci];
|
|
93
|
+
if (!hasValue(value))
|
|
94
|
+
return null; // trou : pas de barre fantôme à 0.
|
|
95
|
+
const valueY = scaleLinear(value, domainMin, domainMax, plotHeight, 0);
|
|
96
|
+
const y = Math.min(valueY, zeroY);
|
|
97
|
+
const hh = Math.abs(zeroY - valueY);
|
|
98
|
+
return {
|
|
99
|
+
x: groupX + barWidth * si,
|
|
100
|
+
y: MARGIN.top + y,
|
|
101
|
+
width: barWidth,
|
|
102
|
+
height: Math.max(hh, 0.5),
|
|
103
|
+
cx: groupX + barWidth * (si + 0.5),
|
|
104
|
+
cy: MARGIN.top + valueY,
|
|
105
|
+
value,
|
|
106
|
+
seriesLabel: series.label,
|
|
107
|
+
category: categories[ci],
|
|
108
|
+
tone: series.tone ?? `category${(si % 8) + 1}`,
|
|
109
|
+
};
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
let lineSeries = [];
|
|
114
|
+
if (categories.length !== 0 && lines.length !== 0) {
|
|
115
|
+
const { domainMin, domainMax } = rightScale;
|
|
116
|
+
lineSeries = lines.map((series, li) => {
|
|
117
|
+
const points = categories.map((_, ci) => {
|
|
118
|
+
const value = series.data[ci] ?? 0;
|
|
119
|
+
return {
|
|
120
|
+
x: bandCenter(ci),
|
|
121
|
+
y: MARGIN.top + scaleLinear(value, domainMin, domainMax, plotHeight, 0),
|
|
122
|
+
value,
|
|
123
|
+
category: categories[ci],
|
|
124
|
+
};
|
|
125
|
+
});
|
|
126
|
+
const path = series.smooth ? buildSmoothPath(points) : buildLinearPath(points);
|
|
127
|
+
return {
|
|
128
|
+
path,
|
|
129
|
+
points,
|
|
130
|
+
seriesLabel: series.label,
|
|
131
|
+
tone: series.tone ?? `category${((bars.length + li) % 8) + 1}`,
|
|
132
|
+
};
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
const leftGridLines = leftScale.ticks.map((tick) => ({
|
|
136
|
+
value: tick,
|
|
137
|
+
y: MARGIN.top + scaleLinear(tick, leftScale.domainMin, leftScale.domainMax, plotHeight, 0),
|
|
138
|
+
}));
|
|
139
|
+
const rightTickEntries = lines.length === 0
|
|
140
|
+
? []
|
|
141
|
+
: rightScale.ticks.map((tick) => ({
|
|
142
|
+
value: tick,
|
|
143
|
+
y: MARGIN.top + scaleLinear(tick, rightScale.domainMin, rightScale.domainMax, plotHeight, 0),
|
|
144
|
+
}));
|
|
145
|
+
const legendItems = [
|
|
146
|
+
...bars.map((s, i) => ({
|
|
147
|
+
key: `bar-${i}`,
|
|
148
|
+
label: s.label,
|
|
149
|
+
tone: s.tone ?? `category${(i % 8) + 1}`,
|
|
150
|
+
kind: "bar",
|
|
151
|
+
})),
|
|
152
|
+
...lines.map((s, i) => ({
|
|
153
|
+
key: `line-${i}`,
|
|
154
|
+
label: s.label,
|
|
155
|
+
tone: s.tone ?? `category${((bars.length + i) % 8) + 1}`,
|
|
156
|
+
kind: "line",
|
|
157
|
+
})),
|
|
158
|
+
];
|
|
159
|
+
const dataValueItems = [
|
|
160
|
+
...bars.flatMap((s) => categories.map((c, ci) => `${s.label}, ${c}: ${s.data[ci] ?? 0}`)),
|
|
161
|
+
...lines.flatMap((s) => categories.map((c, ci) => `${s.label}, ${c}: ${s.data[ci] ?? 0}`)),
|
|
162
|
+
];
|
|
163
|
+
let tooltip = null;
|
|
164
|
+
const hov = hovered.value;
|
|
165
|
+
if (hov) {
|
|
166
|
+
if (hov.kind === "bar") {
|
|
167
|
+
const seg = barGroups[hov.gi]?.[hov.si];
|
|
168
|
+
if (seg)
|
|
169
|
+
tooltip = { cx: seg.cx, cy: seg.cy, label: `${seg.seriesLabel} · ${seg.category}`, value: seg.value };
|
|
170
|
+
}
|
|
171
|
+
else {
|
|
172
|
+
const series = lineSeries[hov.li];
|
|
173
|
+
const p = series?.points[hov.pi];
|
|
174
|
+
if (series && p)
|
|
175
|
+
tooltip = { cx: p.x, cy: p.y, label: `${series.seriesLabel} · ${p.category}`, value: p.value };
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
const svgChildren = [];
|
|
179
|
+
for (const g of leftGridLines) {
|
|
180
|
+
svgChildren.push(h("line", { key: `lg${g.value}`, class: "st-comboChart__grid", x1: MARGIN.left, x2: MARGIN.left + plotWidth, y1: g.y, y2: g.y }), h("text", { key: `lt${g.value}`, class: "st-comboChart__tickLabel", x: MARGIN.left - 6, y: g.y, "text-anchor": "end", "dominant-baseline": "middle" }, formatTick(g.value)));
|
|
181
|
+
}
|
|
182
|
+
for (const g of rightTickEntries) {
|
|
183
|
+
svgChildren.push(h("text", { key: `rt${g.value}`, class: "st-comboChart__tickLabel", x: MARGIN.left + plotWidth + 6, y: g.y, "text-anchor": "start", "dominant-baseline": "middle" }, formatTick(g.value)));
|
|
184
|
+
}
|
|
185
|
+
svgChildren.push(h("line", { class: "st-comboChart__axis", x1: MARGIN.left, x2: MARGIN.left, y1: MARGIN.top, y2: height - MARGIN.bottom }), h("line", { class: "st-comboChart__axis", x1: MARGIN.left, x2: width - MARGIN.right, y1: height - MARGIN.bottom, y2: height - MARGIN.bottom }));
|
|
186
|
+
if (lines.length > 0) {
|
|
187
|
+
svgChildren.push(h("line", { class: "st-comboChart__axis", x1: MARGIN.left + plotWidth, x2: MARGIN.left + plotWidth, y1: MARGIN.top, y2: height - MARGIN.bottom }));
|
|
188
|
+
}
|
|
189
|
+
if (leftAxisLabel) {
|
|
190
|
+
svgChildren.push(h("text", { class: "st-comboChart__axisLabel", "text-anchor": "middle", transform: `translate(${MARGIN.left - 40}, ${MARGIN.top + plotHeight / 2}) rotate(-90)` }, leftAxisLabel));
|
|
191
|
+
}
|
|
192
|
+
if (rightAxisLabel) {
|
|
193
|
+
svgChildren.push(h("text", { class: "st-comboChart__axisLabel", "text-anchor": "middle", transform: `translate(${MARGIN.left + plotWidth + 40}, ${MARGIN.top + plotHeight / 2}) rotate(90)` }, rightAxisLabel));
|
|
194
|
+
}
|
|
195
|
+
categories.forEach((category, ci) => {
|
|
196
|
+
svgChildren.push(h("text", { key: `cat${ci}`, class: "st-comboChart__categoryLabel", x: bandCenter(ci), y: height - MARGIN.bottom + 16, "text-anchor": "middle" }, category));
|
|
197
|
+
});
|
|
198
|
+
barGroups.forEach((group, gi) => {
|
|
199
|
+
group.forEach((seg, si) => {
|
|
200
|
+
if (!seg)
|
|
201
|
+
return;
|
|
202
|
+
svgChildren.push(h("rect", {
|
|
203
|
+
key: `bar${gi}-${si}`,
|
|
204
|
+
class: `st-comboChart__bar st-comboChart__bar--${seg.tone}`,
|
|
205
|
+
x: seg.x,
|
|
206
|
+
y: seg.y,
|
|
207
|
+
width: seg.width,
|
|
208
|
+
height: seg.height,
|
|
209
|
+
rx: "2",
|
|
210
|
+
"data-chart-kind": "bar",
|
|
211
|
+
"data-chart-a": gi,
|
|
212
|
+
"data-chart-b": si,
|
|
213
|
+
}));
|
|
214
|
+
});
|
|
215
|
+
});
|
|
216
|
+
lineSeries.forEach((series, li) => {
|
|
217
|
+
svgChildren.push(h("path", {
|
|
218
|
+
key: `line${li}`,
|
|
219
|
+
class: `st-comboChart__line st-comboChart__line--${series.tone}`,
|
|
220
|
+
d: series.path,
|
|
221
|
+
fill: "none",
|
|
222
|
+
"stroke-width": "2",
|
|
223
|
+
"stroke-linecap": "round",
|
|
224
|
+
"stroke-linejoin": "round",
|
|
225
|
+
}));
|
|
226
|
+
series.points.forEach((p, pi) => {
|
|
227
|
+
svgChildren.push(h("circle", {
|
|
228
|
+
key: `dot${li}-${pi}`,
|
|
229
|
+
class: `st-comboChart__dot st-comboChart__dot--${series.tone}`,
|
|
230
|
+
cx: p.x,
|
|
231
|
+
cy: p.y,
|
|
232
|
+
r: "4",
|
|
233
|
+
"data-chart-kind": "line",
|
|
234
|
+
"data-chart-a": li,
|
|
235
|
+
"data-chart-b": pi,
|
|
236
|
+
}));
|
|
237
|
+
});
|
|
238
|
+
});
|
|
239
|
+
const children = [
|
|
240
|
+
h("div", {
|
|
241
|
+
class: "st-comboChart__visual",
|
|
242
|
+
role: "img",
|
|
243
|
+
"aria-label": label,
|
|
244
|
+
onPointermove: handleVisualPointerMove,
|
|
245
|
+
onPointerleave: handleLeave,
|
|
246
|
+
}, [
|
|
247
|
+
h("svg", {
|
|
248
|
+
viewBox: `0 0 ${width} ${height}`,
|
|
249
|
+
preserveAspectRatio: "xMidYMid meet",
|
|
250
|
+
width: "100%",
|
|
251
|
+
height: "100%",
|
|
252
|
+
focusable: "false",
|
|
253
|
+
"aria-hidden": "true",
|
|
254
|
+
}, svgChildren),
|
|
255
|
+
]),
|
|
256
|
+
chartDataList(label, dataValueItems),
|
|
257
|
+
];
|
|
258
|
+
if (legend && legendItems.length > 0) {
|
|
259
|
+
children.push(h("ul", { class: "st-comboChart__legend", "aria-hidden": "true" }, legendItems.map((item) => h("li", { key: item.key, class: "st-comboChart__legendItem" }, [
|
|
260
|
+
h("span", {
|
|
261
|
+
class: `st-comboChart__legendSwatch st-comboChart__legendSwatch--${item.kind} st-comboChart__legendSwatch--${item.tone}`,
|
|
262
|
+
}),
|
|
263
|
+
` ${item.label}`,
|
|
264
|
+
]))));
|
|
265
|
+
}
|
|
266
|
+
if (tooltip) {
|
|
267
|
+
children.push(h("div", {
|
|
268
|
+
class: "st-comboChart__tooltip",
|
|
269
|
+
role: "presentation",
|
|
270
|
+
style: `left: ${(tooltip.cx / width) * 100}%; top: ${(tooltip.cy / height) * 100}%`,
|
|
271
|
+
}, [
|
|
272
|
+
h("span", { class: "st-comboChart__tooltipLabel" }, tooltip.label),
|
|
273
|
+
h("span", { class: "st-comboChart__tooltipValue" }, String(tooltip.value)),
|
|
274
|
+
]));
|
|
275
|
+
}
|
|
276
|
+
return h("div", { ...attrs, class: classNames("st-comboChart", props.class) }, children);
|
|
277
|
+
};
|
|
278
|
+
},
|
|
279
|
+
});
|
|
280
|
+
//# sourceMappingURL=ComboChart.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ComboChart.js","sourceRoot":"","sources":["../src/ComboChart.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,CAAC,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,aAAa,EAAE,UAAU,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAsCtH,MAAM,MAAM,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC;AAO5D,MAAM,CAAC,MAAM,UAAU,GAAG,eAAe,CAAC;IACxC,IAAI,EAAE,YAAY;IAClB,KAAK,EAAE;QACL,UAAU,EAAE,EAAE,IAAI,EAAE,KAAuB,EAAE,QAAQ,EAAE,IAAI,EAAE;QAC7D,IAAI,EAAE,EAAE,IAAI,EAAE,KAAoC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;QACvE,KAAK,EAAE,EAAE,IAAI,EAAE,KAAqC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;QACzE,aAAa,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE;QACnD,cAAc,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE;QACpD,MAAM,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE;QACxC,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE;QACrC,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE;QACtC,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE;QACvC,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE;KAC5C;IACD,KAAK,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE;QACpB,MAAM,OAAO,GAAG,GAAG,CAAQ,IAAI,CAAC,CAAC;QAEjC,SAAS,WAAW;YAClB,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,uBAAuB,CAAC,KAAmB;YAClD,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;YAC5B,IAAI,CAAC,CAAC,MAAM,YAAY,OAAO,CAAC,EAAE,CAAC;gBACjC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;gBACrB,OAAO;YACT,CAAC;YACD,MAAM,IAAI,GAAG,MAAM,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC;YACpD,MAAM,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC,CAAC;YACtD,MAAM,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC,CAAC;YACtD,IAAI,IAAI,KAAK,KAAK,IAAI,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;gBACjE,OAAO,CAAC,KAAK,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC;YAChD,CAAC;iBAAM,IAAI,IAAI,KAAK,MAAM,IAAI,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;gBACzE,OAAO,CAAC,KAAK,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC;YACjD,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;YACvB,CAAC;QACH,CAAC;QAED,OAAO,GAAG,EAAE;YACV,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,GAAG,CAAC;YACjC,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,IAAI,GAAG,CAAC;YACnC,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;YACpC,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC;YAC9B,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,EAAE,CAAC;YAChC,MAAM,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;YAC1C,MAAM,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;YAC5C,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC;YACpC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;YAE1B,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAClE,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAEpE,yEAAyE;YACzE,2DAA2D;YAC3D,MAAM,QAAQ,GAAG,CAAC,CAAqB,EAAe,EAAE,CAAC,OAAO,CAAC,KAAK,QAAQ,IAAI,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YAErG,kCAAkC;YAClC,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YAChE,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC1E,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC1E,MAAM,SAAS,GAAG,SAAS,CAAC,UAAU,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;YACvD,MAAM,SAAS,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,SAAS,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC;YAE5G,qCAAqC;YACrC,IAAI,UAAqE,CAAC;YAC1E,MAAM,WAAW,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YAClE,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC7B,MAAM,KAAK,GAAG,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;gBACjC,UAAU,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC;YAClF,CAAC;iBAAM,CAAC;gBACN,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,CAAC;gBACxC,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,CAAC;gBACxC,MAAM,MAAM,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,IAAI,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,GAAG,GAAG,CAAC;gBAC/E,MAAM,KAAK,GAAG,SAAS,CAAC,MAAM,GAAG,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC,CAAC,CAAC;gBAC7D,UAAU,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC;YAClF,CAAC;YAED,MAAM,UAAU,GAAG,CAAC,CAAS,EAAU,EAAE;gBACvC,MAAM,IAAI,GAAG,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;gBACxD,OAAO,MAAM,CAAC,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;YACxC,CAAC,CAAC;YAeF,IAAI,SAAS,GAAwB,EAAE,CAAC;YACxC,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACjD,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,SAAS,CAAC;gBAC3C,MAAM,IAAI,GAAG,SAAS,GAAG,UAAU,CAAC,MAAM,CAAC;gBAC3C,MAAM,UAAU,GAAG,IAAI,GAAG,IAAI,CAAC;gBAC/B,MAAM,QAAQ,GAAG,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC;gBAC1C,MAAM,KAAK,GAAG,WAAW,CAAC,CAAC,EAAE,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;gBAClE,SAAS,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE;oBACnC,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,GAAG,IAAI,GAAG,EAAE,GAAG,CAAC,IAAI,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC;oBACjE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE;wBAC7B,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;wBAC9B,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;4BAAE,OAAO,IAAI,CAAC,CAAC,mCAAmC;wBACtE,MAAM,MAAM,GAAG,WAAW,CAAC,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;wBACvE,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;wBAClC,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,MAAM,CAAC,CAAC;wBACpC,OAAO;4BACL,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,EAAE;4BACzB,CAAC,EAAE,MAAM,CAAC,GAAG,GAAG,CAAC;4BACjB,KAAK,EAAE,QAAQ;4BACf,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC;4BACzB,EAAE,EAAE,MAAM,GAAG,QAAQ,GAAG,CAAC,EAAE,GAAG,GAAG,CAAC;4BAClC,EAAE,EAAE,MAAM,CAAC,GAAG,GAAG,MAAM;4BACvB,KAAK;4BACL,WAAW,EAAE,MAAM,CAAC,KAAK;4BACzB,QAAQ,EAAE,UAAU,CAAC,EAAE,CAAC;4BACxB,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,WAAW,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE;yBAC/C,CAAC;oBACJ,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;YACL,CAAC;YAID,IAAI,UAAU,GAAsB,EAAE,CAAC;YACvC,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAClD,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,UAAU,CAAC;gBAC5C,UAAU,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE;oBACpC,MAAM,MAAM,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE;wBACtC,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;wBACnC,OAAO;4BACL,CAAC,EAAE,UAAU,CAAC,EAAE,CAAC;4BACjB,CAAC,EAAE,MAAM,CAAC,GAAG,GAAG,WAAW,CAAC,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC,CAAC;4BACvE,KAAK;4BACL,QAAQ,EAAE,UAAU,CAAC,EAAE,CAAC;yBACzB,CAAC;oBACJ,CAAC,CAAC,CAAC;oBACH,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;oBAC/E,OAAO;wBACL,IAAI;wBACJ,MAAM;wBACN,WAAW,EAAE,MAAM,CAAC,KAAK;wBACzB,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,WAAW,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE;qBAC/D,CAAC;gBACJ,CAAC,CAAC,CAAC;YACL,CAAC;YAED,MAAM,aAAa,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;gBACnD,KAAK,EAAE,IAAI;gBACX,CAAC,EAAE,MAAM,CAAC,GAAG,GAAG,WAAW,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,EAAE,SAAS,CAAC,SAAS,EAAE,UAAU,EAAE,CAAC,CAAC;aAC3F,CAAC,CAAC,CAAC;YAEJ,MAAM,gBAAgB,GACpB,KAAK,CAAC,MAAM,KAAK,CAAC;gBAChB,CAAC,CAAC,EAAE;gBACJ,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;oBAC9B,KAAK,EAAE,IAAI;oBACX,CAAC,EAAE,MAAM,CAAC,GAAG,GAAG,WAAW,CAAC,IAAI,EAAE,UAAU,CAAC,SAAS,EAAE,UAAU,CAAC,SAAS,EAAE,UAAU,EAAE,CAAC,CAAC;iBAC7F,CAAC,CAAC,CAAC;YAEV,MAAM,WAAW,GAAG;gBAClB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;oBACrB,GAAG,EAAE,OAAO,CAAC,EAAE;oBACf,KAAK,EAAE,CAAC,CAAC,KAAK;oBACd,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,WAAW,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE;oBACxC,IAAI,EAAE,KAAc;iBACrB,CAAC,CAAC;gBACH,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;oBACtB,GAAG,EAAE,QAAQ,CAAC,EAAE;oBAChB,KAAK,EAAE,CAAC,CAAC,KAAK;oBACd,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,WAAW,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE;oBACxD,IAAI,EAAE,MAAe;iBACtB,CAAC,CAAC;aACJ,CAAC;YAEF,MAAM,cAAc,GAAG;gBACrB,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBACzF,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;aAC3F,CAAC;YAEF,IAAI,OAAO,GAAoE,IAAI,CAAC;YACpF,MAAM,GAAG,GAAG,OAAO,CAAC,KAAK,CAAC;YAC1B,IAAI,GAAG,EAAE,CAAC;gBACR,IAAI,GAAG,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;oBACvB,MAAM,GAAG,GAAG,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;oBACxC,IAAI,GAAG;wBAAE,OAAO,GAAG,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE,KAAK,EAAE,GAAG,GAAG,CAAC,WAAW,MAAM,GAAG,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,GAAG,CAAC,KAAK,EAAE,CAAC;gBACjH,CAAC;qBAAM,CAAC;oBACN,MAAM,MAAM,GAAG,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;oBAClC,MAAM,CAAC,GAAG,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;oBACjC,IAAI,MAAM,IAAI,CAAC;wBAAE,OAAO,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC,WAAW,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC;gBAClH,CAAC;YACH,CAAC;YAED,MAAM,WAAW,GAA2B,EAAE,CAAC;YAE/C,KAAK,MAAM,CAAC,IAAI,aAAa,EAAE,CAAC;gBAC9B,WAAW,CAAC,IAAI,CACd,CAAC,CAAC,MAAM,EAAE,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,qBAAqB,EAAE,EAAE,EAAE,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,MAAM,CAAC,IAAI,GAAG,SAAS,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAChI,CAAC,CACC,MAAM,EACN,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,0BAA0B,EAAE,CAAC,EAAE,MAAM,CAAC,IAAI,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,KAAK,EAAE,mBAAmB,EAAE,QAAQ,EAAE,EAC3I,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CACpB,CACF,CAAC;YACJ,CAAC;YAED,KAAK,MAAM,CAAC,IAAI,gBAAgB,EAAE,CAAC;gBACjC,WAAW,CAAC,IAAI,CACd,CAAC,CACC,MAAM,EACN,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,0BAA0B,EAAE,CAAC,EAAE,MAAM,CAAC,IAAI,GAAG,SAAS,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,EACzJ,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CACpB,CACF,CAAC;YACJ,CAAC;YAED,WAAW,CAAC,IAAI,CACd,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,qBAAqB,EAAE,EAAE,EAAE,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,MAAM,CAAC,GAAG,EAAE,EAAE,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EACzH,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,qBAAqB,EAAE,EAAE,EAAE,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,KAAK,GAAG,MAAM,CAAC,KAAK,EAAE,EAAE,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,CAC/I,CAAC;YACF,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACrB,WAAW,CAAC,IAAI,CACd,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,qBAAqB,EAAE,EAAE,EAAE,MAAM,CAAC,IAAI,GAAG,SAAS,EAAE,EAAE,EAAE,MAAM,CAAC,IAAI,GAAG,SAAS,EAAE,EAAE,EAAE,MAAM,CAAC,GAAG,EAAE,EAAE,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,CAClJ,CAAC;YACJ,CAAC;YAED,IAAI,aAAa,EAAE,CAAC;gBAClB,WAAW,CAAC,IAAI,CACd,CAAC,CACC,MAAM,EACN,EAAE,KAAK,EAAE,0BAA0B,EAAE,aAAa,EAAE,QAAQ,EAAE,SAAS,EAAE,aAAa,MAAM,CAAC,IAAI,GAAG,EAAE,KAAK,MAAM,CAAC,GAAG,GAAG,UAAU,GAAG,CAAC,eAAe,EAAE,EACvJ,aAAa,CACd,CACF,CAAC;YACJ,CAAC;YACD,IAAI,cAAc,EAAE,CAAC;gBACnB,WAAW,CAAC,IAAI,CACd,CAAC,CACC,MAAM,EACN,EAAE,KAAK,EAAE,0BAA0B,EAAE,aAAa,EAAE,QAAQ,EAAE,SAAS,EAAE,aAAa,MAAM,CAAC,IAAI,GAAG,SAAS,GAAG,EAAE,KAAK,MAAM,CAAC,GAAG,GAAG,UAAU,GAAG,CAAC,cAAc,EAAE,EAClK,cAAc,CACf,CACF,CAAC;YACJ,CAAC;YAED,UAAU,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE,EAAE,EAAE;gBAClC,WAAW,CAAC,IAAI,CACd,CAAC,CACC,MAAM,EACN,EAAE,GAAG,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,8BAA8B,EAAE,CAAC,EAAE,UAAU,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,GAAG,EAAE,EAAE,aAAa,EAAE,QAAQ,EAAE,EACtI,QAAQ,CACT,CACF,CAAC;YACJ,CAAC,CAAC,CAAC;YAEH,SAAS,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE;gBAC9B,KAAK,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE;oBACxB,IAAI,CAAC,GAAG;wBAAE,OAAO;oBACjB,WAAW,CAAC,IAAI,CACd,CAAC,CAAC,MAAM,EAAE;wBACR,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE;wBACrB,KAAK,EAAE,0CAA0C,GAAG,CAAC,IAAI,EAAE;wBAC3D,CAAC,EAAE,GAAG,CAAC,CAAC;wBACR,CAAC,EAAE,GAAG,CAAC,CAAC;wBACR,KAAK,EAAE,GAAG,CAAC,KAAK;wBAChB,MAAM,EAAE,GAAG,CAAC,MAAM;wBAClB,EAAE,EAAE,GAAG;wBACP,iBAAiB,EAAE,KAAK;wBACxB,cAAc,EAAE,EAAE;wBAClB,cAAc,EAAE,EAAE;qBACnB,CAAC,CACH,CAAC;gBACJ,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YAEH,UAAU,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE;gBAChC,WAAW,CAAC,IAAI,CACd,CAAC,CAAC,MAAM,EAAE;oBACR,GAAG,EAAE,OAAO,EAAE,EAAE;oBAChB,KAAK,EAAE,4CAA4C,MAAM,CAAC,IAAI,EAAE;oBAChE,CAAC,EAAE,MAAM,CAAC,IAAI;oBACd,IAAI,EAAE,MAAM;oBACZ,cAAc,EAAE,GAAG;oBACnB,gBAAgB,EAAE,OAAO;oBACzB,iBAAiB,EAAE,OAAO;iBAC3B,CAAC,CACH,CAAC;gBACF,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE;oBAC9B,WAAW,CAAC,IAAI,CACd,CAAC,CAAC,QAAQ,EAAE;wBACV,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE;wBACrB,KAAK,EAAE,0CAA0C,MAAM,CAAC,IAAI,EAAE;wBAC9D,EAAE,EAAE,CAAC,CAAC,CAAC;wBACP,EAAE,EAAE,CAAC,CAAC,CAAC;wBACP,CAAC,EAAE,GAAG;wBACN,iBAAiB,EAAE,MAAM;wBACzB,cAAc,EAAE,EAAE;wBAClB,cAAc,EAAE,EAAE;qBACnB,CAAC,CACH,CAAC;gBACJ,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YAEH,MAAM,QAAQ,GAAoC;gBAChD,CAAC,CACC,KAAK,EACL;oBACE,KAAK,EAAE,uBAAuB;oBAC9B,IAAI,EAAE,KAAK;oBACX,YAAY,EAAE,KAAK;oBACnB,aAAa,EAAE,uBAAuB;oBACtC,cAAc,EAAE,WAAW;iBAC5B,EACD;oBACE,CAAC,CACC,KAAK,EACL;wBACE,OAAO,EAAE,OAAO,KAAK,IAAI,MAAM,EAAE;wBACjC,mBAAmB,EAAE,eAAe;wBACpC,KAAK,EAAE,MAAM;wBACb,MAAM,EAAE,MAAM;wBACd,SAAS,EAAE,OAAO;wBAClB,aAAa,EAAE,MAAM;qBACtB,EACD,WAAW,CACZ;iBACF,CACF;gBACD,aAAa,CAAC,KAAK,EAAE,cAAc,CAAC;aACrC,CAAC;YAEF,IAAI,MAAM,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACrC,QAAQ,CAAC,IAAI,CACX,CAAC,CACC,IAAI,EACJ,EAAE,KAAK,EAAE,uBAAuB,EAAE,aAAa,EAAE,MAAM,EAAE,EACzD,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CACvB,CAAC,CAAC,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,KAAK,EAAE,2BAA2B,EAAE,EAAE;oBAC7D,CAAC,CAAC,MAAM,EAAE;wBACR,KAAK,EAAE,4DAA4D,IAAI,CAAC,IAAI,iCAAiC,IAAI,CAAC,IAAI,EAAE;qBACzH,CAAC;oBACF,IAAI,IAAI,CAAC,KAAK,EAAE;iBACjB,CAAC,CACH,CACF,CACF,CAAC;YACJ,CAAC;YAED,IAAI,OAAO,EAAE,CAAC;gBACZ,QAAQ,CAAC,IAAI,CACX,CAAC,CACC,KAAK,EACL;oBACE,KAAK,EAAE,wBAAwB;oBAC/B,IAAI,EAAE,cAAc;oBACpB,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC,EAAE,GAAG,KAAK,CAAC,GAAG,GAAG,WAAW,CAAC,OAAO,CAAC,EAAE,GAAG,MAAM,CAAC,GAAG,GAAG,GAAG;iBACpF,EACD;oBACE,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,6BAA6B,EAAE,EAAE,OAAO,CAAC,KAAK,CAAC;oBAClE,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,6BAA6B,EAAE,EAAE,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;iBAC3E,CACF,CACF,CAAC;YACJ,CAAC;YAED,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,GAAG,KAAK,EAAE,KAAK,EAAE,UAAU,CAAC,eAAe,EAAE,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;QAC3F,CAAC,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
export type FunnelChartTone = "category1" | "category2" | "category3" | "category4" | "category5" | "category6" | "category7" | "category8";
|
|
2
|
+
export type FunnelChartDatum = {
|
|
3
|
+
label: string;
|
|
4
|
+
value: number;
|
|
5
|
+
tone?: FunnelChartTone;
|
|
6
|
+
};
|
|
7
|
+
export type FunnelChartProps = {
|
|
8
|
+
data: FunnelChartDatum[];
|
|
9
|
+
orientation?: "vertical" | "horizontal";
|
|
10
|
+
showPercentages?: boolean;
|
|
11
|
+
percentMode?: "ofFirst" | "ofPrevious";
|
|
12
|
+
legend?: boolean;
|
|
13
|
+
label: string;
|
|
14
|
+
width?: number;
|
|
15
|
+
height?: number;
|
|
16
|
+
class?: string;
|
|
17
|
+
};
|
|
18
|
+
export declare const FunnelChart: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
|
|
19
|
+
data: {
|
|
20
|
+
type: () => FunnelChartDatum[];
|
|
21
|
+
required: true;
|
|
22
|
+
};
|
|
23
|
+
orientation: {
|
|
24
|
+
type: () => "vertical" | "horizontal";
|
|
25
|
+
default: string;
|
|
26
|
+
};
|
|
27
|
+
showPercentages: {
|
|
28
|
+
type: BooleanConstructor;
|
|
29
|
+
default: boolean;
|
|
30
|
+
};
|
|
31
|
+
percentMode: {
|
|
32
|
+
type: () => "ofFirst" | "ofPrevious";
|
|
33
|
+
default: string;
|
|
34
|
+
};
|
|
35
|
+
legend: {
|
|
36
|
+
type: BooleanConstructor;
|
|
37
|
+
default: boolean;
|
|
38
|
+
};
|
|
39
|
+
label: {
|
|
40
|
+
type: StringConstructor;
|
|
41
|
+
required: true;
|
|
42
|
+
};
|
|
43
|
+
width: {
|
|
44
|
+
type: NumberConstructor;
|
|
45
|
+
default: number;
|
|
46
|
+
};
|
|
47
|
+
height: {
|
|
48
|
+
type: NumberConstructor;
|
|
49
|
+
default: number;
|
|
50
|
+
};
|
|
51
|
+
class: {
|
|
52
|
+
type: StringConstructor;
|
|
53
|
+
default: undefined;
|
|
54
|
+
};
|
|
55
|
+
}>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
|
|
56
|
+
[key: string]: any;
|
|
57
|
+
}>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
|
|
58
|
+
data: {
|
|
59
|
+
type: () => FunnelChartDatum[];
|
|
60
|
+
required: true;
|
|
61
|
+
};
|
|
62
|
+
orientation: {
|
|
63
|
+
type: () => "vertical" | "horizontal";
|
|
64
|
+
default: string;
|
|
65
|
+
};
|
|
66
|
+
showPercentages: {
|
|
67
|
+
type: BooleanConstructor;
|
|
68
|
+
default: boolean;
|
|
69
|
+
};
|
|
70
|
+
percentMode: {
|
|
71
|
+
type: () => "ofFirst" | "ofPrevious";
|
|
72
|
+
default: string;
|
|
73
|
+
};
|
|
74
|
+
legend: {
|
|
75
|
+
type: BooleanConstructor;
|
|
76
|
+
default: boolean;
|
|
77
|
+
};
|
|
78
|
+
label: {
|
|
79
|
+
type: StringConstructor;
|
|
80
|
+
required: true;
|
|
81
|
+
};
|
|
82
|
+
width: {
|
|
83
|
+
type: NumberConstructor;
|
|
84
|
+
default: number;
|
|
85
|
+
};
|
|
86
|
+
height: {
|
|
87
|
+
type: NumberConstructor;
|
|
88
|
+
default: number;
|
|
89
|
+
};
|
|
90
|
+
class: {
|
|
91
|
+
type: StringConstructor;
|
|
92
|
+
default: undefined;
|
|
93
|
+
};
|
|
94
|
+
}>> & Readonly<{}>, {
|
|
95
|
+
class: string;
|
|
96
|
+
legend: boolean;
|
|
97
|
+
width: number;
|
|
98
|
+
height: number;
|
|
99
|
+
orientation: "horizontal" | "vertical";
|
|
100
|
+
showPercentages: boolean;
|
|
101
|
+
percentMode: "ofFirst" | "ofPrevious";
|
|
102
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
103
|
+
//# sourceMappingURL=FunnelChart.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FunnelChart.d.ts","sourceRoot":"","sources":["../src/FunnelChart.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,eAAe,GACvB,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,CAAC;AAEhB,MAAM,MAAM,gBAAgB,GAAG;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,eAAe,CAAC;CACxB,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,IAAI,EAAE,gBAAgB,EAAE,CAAC;IACzB,WAAW,CAAC,EAAE,UAAU,GAAG,YAAY,CAAC;IACxC,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,WAAW,CAAC,EAAE,SAAS,GAAG,YAAY,CAAC;IACvC,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AA4BF,eAAO,MAAM,WAAW;;cAGG,MAAM,gBAAgB,EAAE;;;;cAChB,MAAM,UAAU,GAAG,YAAY;;;;;;;;cAE/B,MAAM,SAAS,GAAG,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;cAHtC,MAAM,gBAAgB,EAAE;;;;cAChB,MAAM,UAAU,GAAG,YAAY;;;;;;;;cAE/B,MAAM,SAAS,GAAG,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4EAkO/D,CAAC"}
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
import { defineComponent, h, ref } from "vue";
|
|
2
|
+
import { classNames } from "./classNames.js";
|
|
3
|
+
import { chartDataList, labelColorForTone } from "./chartScale.js";
|
|
4
|
+
const MARGIN = { top: 16, right: 16, bottom: 16, left: 16 };
|
|
5
|
+
const GAP = 6;
|
|
6
|
+
const TONES = [
|
|
7
|
+
"category1",
|
|
8
|
+
"category2",
|
|
9
|
+
"category3",
|
|
10
|
+
"category4",
|
|
11
|
+
"category5",
|
|
12
|
+
"category6",
|
|
13
|
+
"category7",
|
|
14
|
+
"category8",
|
|
15
|
+
];
|
|
16
|
+
/**
|
|
17
|
+
* Magnitude normalisée d'une étape : un entonnoir ne représente que des
|
|
18
|
+
* grandeurs positives. Les valeurs non finies ou négatives sont ramenées à 0.
|
|
19
|
+
*/
|
|
20
|
+
function magnitude(v) {
|
|
21
|
+
return Number.isFinite(v) && v > 0 ? v : 0;
|
|
22
|
+
}
|
|
23
|
+
function formatPercent(p) {
|
|
24
|
+
if (!Number.isFinite(p))
|
|
25
|
+
return "0%";
|
|
26
|
+
return `${p % 1 === 0 ? p.toFixed(0) : p.toFixed(1)}%`;
|
|
27
|
+
}
|
|
28
|
+
export const FunnelChart = defineComponent({
|
|
29
|
+
name: "FunnelChart",
|
|
30
|
+
props: {
|
|
31
|
+
data: { type: Array, required: true },
|
|
32
|
+
orientation: { type: String, default: "vertical" },
|
|
33
|
+
showPercentages: { type: Boolean, default: true },
|
|
34
|
+
percentMode: { type: String, default: "ofFirst" },
|
|
35
|
+
legend: { type: Boolean, default: false },
|
|
36
|
+
label: { type: String, required: true },
|
|
37
|
+
width: { type: Number, default: 480 },
|
|
38
|
+
height: { type: Number, default: 280 },
|
|
39
|
+
class: { type: String, default: undefined },
|
|
40
|
+
},
|
|
41
|
+
setup(props, { attrs }) {
|
|
42
|
+
const hoveredIndex = ref(null);
|
|
43
|
+
function handleLeave() {
|
|
44
|
+
hoveredIndex.value = null;
|
|
45
|
+
}
|
|
46
|
+
function handleVisualPointerMove(event) {
|
|
47
|
+
const target = event.target;
|
|
48
|
+
if (!(target instanceof Element)) {
|
|
49
|
+
hoveredIndex.value = null;
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
const index = Number(target.getAttribute("data-chart-index"));
|
|
53
|
+
hoveredIndex.value = Number.isInteger(index) ? index : null;
|
|
54
|
+
}
|
|
55
|
+
return () => {
|
|
56
|
+
const data = props.data ?? [];
|
|
57
|
+
const orientation = props.orientation ?? "vertical";
|
|
58
|
+
const showPercentages = props.showPercentages ?? true;
|
|
59
|
+
const percentMode = props.percentMode ?? "ofFirst";
|
|
60
|
+
const legend = props.legend ?? false;
|
|
61
|
+
const label = props.label;
|
|
62
|
+
const width = props.width ?? 480;
|
|
63
|
+
const height = props.height ?? 280;
|
|
64
|
+
const first = magnitude(data[0]?.value ?? 0);
|
|
65
|
+
const percents = data.map((d, i) => {
|
|
66
|
+
const value = magnitude(d.value);
|
|
67
|
+
const ref0 = percentMode === "ofPrevious" ? magnitude(data[i - 1]?.value ?? d.value) : first;
|
|
68
|
+
return ref0 === 0 ? 0 : (value / ref0) * 100;
|
|
69
|
+
});
|
|
70
|
+
let segments = [];
|
|
71
|
+
if (data.length !== 0) {
|
|
72
|
+
const maxValue = Math.max(0, ...data.map((d) => magnitude(d.value)));
|
|
73
|
+
const safeMax = maxValue === 0 ? 1 : maxValue;
|
|
74
|
+
const plotW = Math.max(width - MARGIN.left - MARGIN.right, 1);
|
|
75
|
+
const plotH = Math.max(height - MARGIN.top - MARGIN.bottom, 1);
|
|
76
|
+
if (orientation === "vertical") {
|
|
77
|
+
const band = plotH / data.length;
|
|
78
|
+
const segH = Math.max(band - GAP, 1);
|
|
79
|
+
const cx = MARGIN.left + plotW / 2;
|
|
80
|
+
segments = data.map((d, i) => {
|
|
81
|
+
const tone = d.tone ?? TONES[i % TONES.length];
|
|
82
|
+
const topHalf = (magnitude(d.value) / safeMax) * (plotW / 2);
|
|
83
|
+
const nextVal = data[i + 1] ? magnitude(data[i + 1].value) : magnitude(d.value);
|
|
84
|
+
// Forme strictement décroissante : le bas ne dépasse jamais le haut.
|
|
85
|
+
const botHalf = Math.min((nextVal / safeMax) * (plotW / 2), topHalf);
|
|
86
|
+
const y0 = MARGIN.top + band * i;
|
|
87
|
+
const y1 = y0 + segH;
|
|
88
|
+
const points = [
|
|
89
|
+
`${cx - topHalf},${y0}`,
|
|
90
|
+
`${cx + topHalf},${y0}`,
|
|
91
|
+
`${cx + botHalf},${y1}`,
|
|
92
|
+
`${cx - botHalf},${y1}`,
|
|
93
|
+
].join(" ");
|
|
94
|
+
return {
|
|
95
|
+
points,
|
|
96
|
+
datum: d,
|
|
97
|
+
tone,
|
|
98
|
+
textColor: labelColorForTone(tone),
|
|
99
|
+
cx,
|
|
100
|
+
cy: (y0 + y1) / 2,
|
|
101
|
+
labelX: cx,
|
|
102
|
+
labelY: (y0 + y1) / 2,
|
|
103
|
+
percent: percents[i],
|
|
104
|
+
};
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
else {
|
|
108
|
+
const band = plotW / data.length;
|
|
109
|
+
const segW = Math.max(band - GAP, 1);
|
|
110
|
+
const cy = MARGIN.top + plotH / 2;
|
|
111
|
+
segments = data.map((d, i) => {
|
|
112
|
+
const tone = d.tone ?? TONES[i % TONES.length];
|
|
113
|
+
const leftHalf = (magnitude(d.value) / safeMax) * (plotH / 2);
|
|
114
|
+
const nextVal = data[i + 1] ? magnitude(data[i + 1].value) : magnitude(d.value);
|
|
115
|
+
const rightHalf = Math.min((nextVal / safeMax) * (plotH / 2), leftHalf);
|
|
116
|
+
const x0 = MARGIN.left + band * i;
|
|
117
|
+
const x1 = x0 + segW;
|
|
118
|
+
const points = [
|
|
119
|
+
`${x0},${cy - leftHalf}`,
|
|
120
|
+
`${x1},${cy - rightHalf}`,
|
|
121
|
+
`${x1},${cy + rightHalf}`,
|
|
122
|
+
`${x0},${cy + leftHalf}`,
|
|
123
|
+
].join(" ");
|
|
124
|
+
return {
|
|
125
|
+
points,
|
|
126
|
+
datum: d,
|
|
127
|
+
tone,
|
|
128
|
+
textColor: labelColorForTone(tone),
|
|
129
|
+
cx: (x0 + x1) / 2,
|
|
130
|
+
cy,
|
|
131
|
+
labelX: (x0 + x1) / 2,
|
|
132
|
+
labelY: cy,
|
|
133
|
+
percent: percents[i],
|
|
134
|
+
};
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
const dataValueItems = data.map((d, i) => showPercentages ? `${d.label}: ${d.value} (${formatPercent(percents[i])})` : `${d.label}: ${d.value}`);
|
|
139
|
+
const legendItems = data.map((d, i) => ({ label: d.label, tone: d.tone ?? TONES[i % TONES.length] }));
|
|
140
|
+
const hoveredIdx = hoveredIndex.value;
|
|
141
|
+
const polygons = segments.map((seg, i) => h("polygon", {
|
|
142
|
+
key: `p${seg.datum.label}`,
|
|
143
|
+
class: classNames("st-funnelChart__segment", `st-funnelChart__segment--${seg.tone}`, hoveredIdx !== null && hoveredIdx !== i && "st-funnelChart__segment--dim"),
|
|
144
|
+
points: seg.points,
|
|
145
|
+
"data-chart-index": i,
|
|
146
|
+
}));
|
|
147
|
+
const textChildren = [];
|
|
148
|
+
segments.forEach((seg) => {
|
|
149
|
+
textChildren.push(h("text", { key: `lbl${seg.datum.label}`, class: "st-funnelChart__label", x: seg.labelX, y: seg.labelY - 6, "text-anchor": "middle", "dominant-baseline": "middle", style: `fill: ${seg.textColor}` }, seg.datum.label), h("text", { key: `val${seg.datum.label}`, class: "st-funnelChart__value", x: seg.labelX, y: seg.labelY + 8, "text-anchor": "middle", "dominant-baseline": "middle", style: `fill: ${seg.textColor}` }, showPercentages ? `${seg.datum.value} · ${formatPercent(seg.percent)}` : String(seg.datum.value)));
|
|
150
|
+
});
|
|
151
|
+
const children = [
|
|
152
|
+
h("div", {
|
|
153
|
+
class: "st-funnelChart__visual",
|
|
154
|
+
role: "img",
|
|
155
|
+
"aria-label": label,
|
|
156
|
+
onPointermove: handleVisualPointerMove,
|
|
157
|
+
onPointerleave: handleLeave,
|
|
158
|
+
}, [
|
|
159
|
+
h("svg", {
|
|
160
|
+
viewBox: `0 0 ${width} ${height}`,
|
|
161
|
+
preserveAspectRatio: "xMidYMid meet",
|
|
162
|
+
width: "100%",
|
|
163
|
+
height: "100%",
|
|
164
|
+
focusable: "false",
|
|
165
|
+
"aria-hidden": "true",
|
|
166
|
+
}, [...polygons, ...textChildren]),
|
|
167
|
+
]),
|
|
168
|
+
chartDataList(label, dataValueItems),
|
|
169
|
+
];
|
|
170
|
+
if (hoveredIdx !== null && segments[hoveredIdx]) {
|
|
171
|
+
const seg = segments[hoveredIdx];
|
|
172
|
+
children.push(h("div", {
|
|
173
|
+
class: "st-funnelChart__tooltip",
|
|
174
|
+
role: "presentation",
|
|
175
|
+
style: `left: ${(seg.cx / width) * 100}%; top: ${(seg.cy / height) * 100}%`,
|
|
176
|
+
}, [
|
|
177
|
+
h("span", { class: "st-funnelChart__tooltipLabel" }, seg.datum.label),
|
|
178
|
+
h("span", { class: "st-funnelChart__tooltipValue" }, showPercentages ? `${seg.datum.value} · ${formatPercent(seg.percent)}` : String(seg.datum.value)),
|
|
179
|
+
]));
|
|
180
|
+
}
|
|
181
|
+
if (legend && legendItems.length > 0) {
|
|
182
|
+
children.push(h("ul", { class: "st-funnelChart__legend", "aria-hidden": "true" }, legendItems.map((item) => h("li", { key: item.label, class: "st-funnelChart__legendItem" }, [
|
|
183
|
+
h("span", { class: `st-funnelChart__legendSwatch st-funnelChart__legendSwatch--${item.tone}`, "aria-hidden": "true" }),
|
|
184
|
+
` ${item.label}`,
|
|
185
|
+
]))));
|
|
186
|
+
}
|
|
187
|
+
return h("div", { ...attrs, class: classNames("st-funnelChart", props.class) }, children);
|
|
188
|
+
};
|
|
189
|
+
},
|
|
190
|
+
});
|
|
191
|
+
//# sourceMappingURL=FunnelChart.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FunnelChart.js","sourceRoot":"","sources":["../src/FunnelChart.ts"],"names":[],"mappings":"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"}
|