@sentropic/design-system-vue 0.11.0 → 0.12.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/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/TimePicker.d.ts +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 +12 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -1
- package/dist/styles.css +721 -2
- package/package.json +1 -1
|
@@ -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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"}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
export type GaugeChartTone = "neutral" | "info" | "success" | "warning" | "error" | "category1" | "category2" | "category3" | "category4" | "category5" | "category6" | "category7" | "category8";
|
|
2
|
+
export type GaugeChartThreshold = {
|
|
3
|
+
value: number;
|
|
4
|
+
tone: GaugeChartTone;
|
|
5
|
+
};
|
|
6
|
+
export type GaugeChartFormat = "number" | "percent";
|
|
7
|
+
export type GaugeChartProps = {
|
|
8
|
+
value: number;
|
|
9
|
+
min?: number;
|
|
10
|
+
max?: number;
|
|
11
|
+
thresholds?: GaugeChartThreshold[];
|
|
12
|
+
label?: string;
|
|
13
|
+
format?: GaugeChartFormat;
|
|
14
|
+
unit?: string;
|
|
15
|
+
size?: number;
|
|
16
|
+
thickness?: number;
|
|
17
|
+
startAngle?: number;
|
|
18
|
+
endAngle?: number;
|
|
19
|
+
class?: string;
|
|
20
|
+
};
|
|
21
|
+
export declare const GaugeChart: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
|
|
22
|
+
value: {
|
|
23
|
+
type: NumberConstructor;
|
|
24
|
+
required: true;
|
|
25
|
+
};
|
|
26
|
+
min: {
|
|
27
|
+
type: NumberConstructor;
|
|
28
|
+
default: number;
|
|
29
|
+
};
|
|
30
|
+
max: {
|
|
31
|
+
type: NumberConstructor;
|
|
32
|
+
default: number;
|
|
33
|
+
};
|
|
34
|
+
thresholds: {
|
|
35
|
+
type: () => GaugeChartThreshold[];
|
|
36
|
+
default: undefined;
|
|
37
|
+
};
|
|
38
|
+
label: {
|
|
39
|
+
type: StringConstructor;
|
|
40
|
+
default: undefined;
|
|
41
|
+
};
|
|
42
|
+
format: {
|
|
43
|
+
type: () => GaugeChartFormat;
|
|
44
|
+
default: string;
|
|
45
|
+
};
|
|
46
|
+
unit: {
|
|
47
|
+
type: StringConstructor;
|
|
48
|
+
default: undefined;
|
|
49
|
+
};
|
|
50
|
+
size: {
|
|
51
|
+
type: NumberConstructor;
|
|
52
|
+
default: number;
|
|
53
|
+
};
|
|
54
|
+
thickness: {
|
|
55
|
+
type: NumberConstructor;
|
|
56
|
+
default: number;
|
|
57
|
+
};
|
|
58
|
+
startAngle: {
|
|
59
|
+
type: NumberConstructor;
|
|
60
|
+
default: number;
|
|
61
|
+
};
|
|
62
|
+
endAngle: {
|
|
63
|
+
type: NumberConstructor;
|
|
64
|
+
default: number;
|
|
65
|
+
};
|
|
66
|
+
class: {
|
|
67
|
+
type: StringConstructor;
|
|
68
|
+
default: undefined;
|
|
69
|
+
};
|
|
70
|
+
}>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
|
|
71
|
+
[key: string]: any;
|
|
72
|
+
}>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
|
|
73
|
+
value: {
|
|
74
|
+
type: NumberConstructor;
|
|
75
|
+
required: true;
|
|
76
|
+
};
|
|
77
|
+
min: {
|
|
78
|
+
type: NumberConstructor;
|
|
79
|
+
default: number;
|
|
80
|
+
};
|
|
81
|
+
max: {
|
|
82
|
+
type: NumberConstructor;
|
|
83
|
+
default: number;
|
|
84
|
+
};
|
|
85
|
+
thresholds: {
|
|
86
|
+
type: () => GaugeChartThreshold[];
|
|
87
|
+
default: undefined;
|
|
88
|
+
};
|
|
89
|
+
label: {
|
|
90
|
+
type: StringConstructor;
|
|
91
|
+
default: undefined;
|
|
92
|
+
};
|
|
93
|
+
format: {
|
|
94
|
+
type: () => GaugeChartFormat;
|
|
95
|
+
default: string;
|
|
96
|
+
};
|
|
97
|
+
unit: {
|
|
98
|
+
type: StringConstructor;
|
|
99
|
+
default: undefined;
|
|
100
|
+
};
|
|
101
|
+
size: {
|
|
102
|
+
type: NumberConstructor;
|
|
103
|
+
default: number;
|
|
104
|
+
};
|
|
105
|
+
thickness: {
|
|
106
|
+
type: NumberConstructor;
|
|
107
|
+
default: number;
|
|
108
|
+
};
|
|
109
|
+
startAngle: {
|
|
110
|
+
type: NumberConstructor;
|
|
111
|
+
default: number;
|
|
112
|
+
};
|
|
113
|
+
endAngle: {
|
|
114
|
+
type: NumberConstructor;
|
|
115
|
+
default: number;
|
|
116
|
+
};
|
|
117
|
+
class: {
|
|
118
|
+
type: StringConstructor;
|
|
119
|
+
default: undefined;
|
|
120
|
+
};
|
|
121
|
+
}>> & Readonly<{}>, {
|
|
122
|
+
class: string;
|
|
123
|
+
label: string;
|
|
124
|
+
min: number;
|
|
125
|
+
max: number;
|
|
126
|
+
size: number;
|
|
127
|
+
thickness: number;
|
|
128
|
+
thresholds: GaugeChartThreshold[];
|
|
129
|
+
format: GaugeChartFormat;
|
|
130
|
+
unit: string;
|
|
131
|
+
startAngle: number;
|
|
132
|
+
endAngle: number;
|
|
133
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
134
|
+
//# sourceMappingURL=GaugeChart.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GaugeChart.d.ts","sourceRoot":"","sources":["../src/GaugeChart.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,cAAc,GACtB,SAAS,GACT,MAAM,GACN,SAAS,GACT,SAAS,GACT,OAAO,GACP,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,CAAC;AAEhB,MAAM,MAAM,mBAAmB,GAAG;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,cAAc,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG,QAAQ,GAAG,SAAS,CAAC;AAEpD,MAAM,MAAM,eAAe,GAAG;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,mBAAmB,EAAE,CAAC;IACnC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,gBAAgB,CAAC;IAC1B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAWF,eAAO,MAAM,UAAU;;;;;;;;;;;;;;cAMU,MAAM,mBAAmB,EAAE;;;;;;;;cAE9B,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAFnB,MAAM,mBAAmB,EAAE;;;;;;;;cAE9B,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4EA8KlD,CAAC"}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { defineComponent, h } from "vue";
|
|
2
|
+
import { classNames } from "./classNames.js";
|
|
3
|
+
import { chartDataList } from "./chartScale.js";
|
|
4
|
+
const toRad = (deg) => (deg * Math.PI) / 180;
|
|
5
|
+
const polar = (radius, angle, centerX, centerY) => [centerX + radius * Math.cos(angle), centerY + radius * Math.sin(angle)];
|
|
6
|
+
export const GaugeChart = defineComponent({
|
|
7
|
+
name: "GaugeChart",
|
|
8
|
+
props: {
|
|
9
|
+
value: { type: Number, required: true },
|
|
10
|
+
min: { type: Number, default: 0 },
|
|
11
|
+
max: { type: Number, default: 100 },
|
|
12
|
+
thresholds: { type: Array, default: undefined },
|
|
13
|
+
label: { type: String, default: undefined },
|
|
14
|
+
format: { type: String, default: "number" },
|
|
15
|
+
unit: { type: String, default: undefined },
|
|
16
|
+
size: { type: Number, default: 220 },
|
|
17
|
+
thickness: { type: Number, default: 22 },
|
|
18
|
+
startAngle: { type: Number, default: 180 },
|
|
19
|
+
endAngle: { type: Number, default: 360 },
|
|
20
|
+
class: { type: String, default: undefined },
|
|
21
|
+
},
|
|
22
|
+
setup(props, { attrs }) {
|
|
23
|
+
return () => {
|
|
24
|
+
const value = props.value;
|
|
25
|
+
const min = props.min ?? 0;
|
|
26
|
+
const max = props.max ?? 100;
|
|
27
|
+
const thresholds = props.thresholds;
|
|
28
|
+
const label = props.label;
|
|
29
|
+
const format = props.format ?? "number";
|
|
30
|
+
const unit = props.unit;
|
|
31
|
+
const size = props.size ?? 220;
|
|
32
|
+
const thickness = props.thickness ?? 22;
|
|
33
|
+
const startAngle = props.startAngle ?? 180;
|
|
34
|
+
const endAngle = props.endAngle ?? 360;
|
|
35
|
+
const span = Math.max(max - min, 0);
|
|
36
|
+
const clamped = Math.min(Math.max(value, min), max);
|
|
37
|
+
const frac = span > 0 ? (clamped - min) / span : 0;
|
|
38
|
+
const cx = size / 2;
|
|
39
|
+
const r = size / 2 - thickness / 2 - 2;
|
|
40
|
+
const a0 = toRad(startAngle);
|
|
41
|
+
const a1 = toRad(endAngle);
|
|
42
|
+
const totalAngle = a1 - a0;
|
|
43
|
+
// Hauteur réelle de l'arc pour cadrer le viewBox.
|
|
44
|
+
const cyRaw = size / 2;
|
|
45
|
+
const samples = 64;
|
|
46
|
+
let minY = Infinity;
|
|
47
|
+
let maxY = -Infinity;
|
|
48
|
+
for (let i = 0; i <= samples; i++) {
|
|
49
|
+
const a = a0 + (totalAngle * i) / samples;
|
|
50
|
+
const yOuter = cyRaw + (r + thickness / 2) * Math.sin(a);
|
|
51
|
+
minY = Math.min(minY, yOuter);
|
|
52
|
+
maxY = Math.max(maxY, yOuter);
|
|
53
|
+
}
|
|
54
|
+
minY = Math.min(minY, cyRaw - (r + thickness / 2));
|
|
55
|
+
const vbHeightRaw = Math.min(maxY, size) - Math.max(minY, 0);
|
|
56
|
+
const geometry = { cy: cyRaw, vbTop: Math.max(minY, 0), vbHeight: Math.max(vbHeightRaw, thickness) };
|
|
57
|
+
const cy = geometry.cy;
|
|
58
|
+
const arcPath = (fromFrac, toFrac) => {
|
|
59
|
+
const from = a0 + totalAngle * fromFrac;
|
|
60
|
+
const to = a0 + totalAngle * toFrac;
|
|
61
|
+
const [x0, y0] = polar(r, from, cx, cy);
|
|
62
|
+
const [x1, y1] = polar(r, to, cx, cy);
|
|
63
|
+
const large = Math.abs(to - from) > Math.PI ? 1 : 0;
|
|
64
|
+
const sweep = totalAngle >= 0 ? 1 : 0;
|
|
65
|
+
return `M ${x0} ${y0} A ${r} ${r} 0 ${large} ${sweep} ${x1} ${y1}`;
|
|
66
|
+
};
|
|
67
|
+
let bands = [];
|
|
68
|
+
if (thresholds && thresholds.length > 0 && span > 0) {
|
|
69
|
+
const sorted = [...thresholds].sort((a, b) => a.value - b.value);
|
|
70
|
+
const segments = [];
|
|
71
|
+
let start = min;
|
|
72
|
+
for (const t of sorted) {
|
|
73
|
+
const end = Math.min(Math.max(t.value, min), max);
|
|
74
|
+
if (end <= start)
|
|
75
|
+
continue;
|
|
76
|
+
segments.push({ from: (start - min) / span, to: (end - min) / span, tone: t.tone });
|
|
77
|
+
start = end;
|
|
78
|
+
}
|
|
79
|
+
if (start < max) {
|
|
80
|
+
const lastTone = sorted[sorted.length - 1]?.tone ?? "neutral";
|
|
81
|
+
segments.push({ from: (start - min) / span, to: 1, tone: lastTone });
|
|
82
|
+
}
|
|
83
|
+
bands = segments;
|
|
84
|
+
}
|
|
85
|
+
const needleAngle = a0 + totalAngle * frac;
|
|
86
|
+
const tip = polar(r + thickness / 2, needleAngle, cx, cy);
|
|
87
|
+
const leftPt = polar(thickness * 0.18, needleAngle + Math.PI / 2, cx, cy);
|
|
88
|
+
const rightPt = polar(thickness * 0.18, needleAngle - Math.PI / 2, cx, cy);
|
|
89
|
+
const needle = `M ${leftPt[0]} ${leftPt[1]} L ${tip[0]} ${tip[1]} L ${rightPt[0]} ${rightPt[1]} Z`;
|
|
90
|
+
let formatted;
|
|
91
|
+
if (format === "percent") {
|
|
92
|
+
const pct = span > 0 ? Math.round(frac * 100) : 0;
|
|
93
|
+
formatted = `${pct}%`;
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
const num = Number.isInteger(clamped) ? String(clamped) : clamped.toFixed(1);
|
|
97
|
+
formatted = unit ? `${num} ${unit}` : num;
|
|
98
|
+
}
|
|
99
|
+
// Inclure la bande de seuil active dans aria-valuetext (a11y : zone succès/alerte/erreur).
|
|
100
|
+
let activeBandLabel;
|
|
101
|
+
if (bands.length > 0) {
|
|
102
|
+
const activeBand = bands.find((b) => b.to >= frac && b.from <= frac) ?? bands[bands.length - 1];
|
|
103
|
+
if (activeBand)
|
|
104
|
+
activeBandLabel = activeBand.tone;
|
|
105
|
+
}
|
|
106
|
+
const ariaValueText = [label ? `${label}: ${formatted}` : formatted, activeBandLabel ? `zone ${activeBandLabel}` : undefined]
|
|
107
|
+
.filter(Boolean)
|
|
108
|
+
.join(", ");
|
|
109
|
+
const dataValueItems = [`${label ? `${label}: ` : ""}${formatted} (min ${min}, max ${max})`];
|
|
110
|
+
const svgChildren = [
|
|
111
|
+
h("path", { class: "st-gaugeChart__track", d: arcPath(0, 1), fill: "none", "stroke-width": thickness }),
|
|
112
|
+
];
|
|
113
|
+
bands.forEach((band, i) => {
|
|
114
|
+
svgChildren.push(h("path", {
|
|
115
|
+
key: `band${i}`,
|
|
116
|
+
class: `st-gaugeChart__band st-gaugeChart__band--${band.tone}`,
|
|
117
|
+
d: arcPath(band.from, band.to),
|
|
118
|
+
fill: "none",
|
|
119
|
+
"stroke-width": thickness,
|
|
120
|
+
}));
|
|
121
|
+
});
|
|
122
|
+
if (bands.length === 0) {
|
|
123
|
+
svgChildren.push(h("path", { class: "st-gaugeChart__progress", d: arcPath(0, frac), fill: "none", "stroke-width": thickness }));
|
|
124
|
+
}
|
|
125
|
+
svgChildren.push(h("path", { class: "st-gaugeChart__needle", d: needle }), h("circle", { class: "st-gaugeChart__hub", cx, cy, r: Math.max(thickness * 0.22, 4) }), h("text", { class: "st-gaugeChart__value", x: cx, y: cy - thickness * 0.55, "text-anchor": "middle", "dominant-baseline": "auto" }, formatted));
|
|
126
|
+
if (label) {
|
|
127
|
+
svgChildren.push(h("text", { class: "st-gaugeChart__label", x: cx, y: cy - thickness * 0.05, "text-anchor": "middle", "dominant-baseline": "hanging" }, label));
|
|
128
|
+
}
|
|
129
|
+
return h("div", { ...attrs, class: classNames("st-gaugeChart", props.class) }, [
|
|
130
|
+
h("div", {
|
|
131
|
+
class: "st-gaugeChart__visual",
|
|
132
|
+
role: "meter",
|
|
133
|
+
"aria-valuenow": clamped,
|
|
134
|
+
"aria-valuemin": min,
|
|
135
|
+
"aria-valuemax": max,
|
|
136
|
+
"aria-valuetext": ariaValueText,
|
|
137
|
+
"aria-label": label,
|
|
138
|
+
}, [
|
|
139
|
+
h("svg", {
|
|
140
|
+
viewBox: `0 ${geometry.vbTop} ${size} ${geometry.vbHeight}`,
|
|
141
|
+
width: "100%",
|
|
142
|
+
height: "100%",
|
|
143
|
+
focusable: "false",
|
|
144
|
+
"aria-hidden": "true",
|
|
145
|
+
}, svgChildren),
|
|
146
|
+
]),
|
|
147
|
+
chartDataList(label ?? "gauge", dataValueItems),
|
|
148
|
+
]);
|
|
149
|
+
};
|
|
150
|
+
},
|
|
151
|
+
});
|
|
152
|
+
//# sourceMappingURL=GaugeChart.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GaugeChart.js","sourceRoot":"","sources":["../src/GaugeChart.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAuChD,MAAM,KAAK,GAAG,CAAC,GAAW,EAAE,EAAE,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AAErD,MAAM,KAAK,GAAG,CACZ,MAAc,EACd,KAAa,EACb,OAAe,EACf,OAAe,EACG,EAAE,CAAC,CAAC,OAAO,GAAG,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;AAEhG,MAAM,CAAC,MAAM,UAAU,GAAG,eAAe,CAAC;IACxC,IAAI,EAAE,YAAY;IAClB,KAAK,EAAE;QACL,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE;QACvC,GAAG,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,EAAE;QACjC,GAAG,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE;QACnC,UAAU,EAAE,EAAE,IAAI,EAAE,KAAoC,EAAE,OAAO,EAAE,SAAS,EAAE;QAC9E,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE;QAC3C,MAAM,EAAE,EAAE,IAAI,EAAE,MAAgC,EAAE,OAAO,EAAE,QAAQ,EAAE;QACrE,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE;QAC1C,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE;QACpC,SAAS,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE;QACxC,UAAU,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE;QAC1C,QAAQ,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE;QACxC,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE;KAC5C;IACD,KAAK,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE;QACpB,OAAO,GAAG,EAAE;YACV,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;YAC1B,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;YAC3B,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,IAAI,GAAG,CAAC;YAC7B,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;YACpC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;YAC1B,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,IAAI,QAAQ,CAAC;YACxC,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;YACxB,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,IAAI,GAAG,CAAC;YAC/B,MAAM,SAAS,GAAG,KAAK,CAAC,SAAS,IAAI,EAAE,CAAC;YACxC,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,IAAI,GAAG,CAAC;YAC3C,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,IAAI,GAAG,CAAC;YAEvC,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC;YACpC,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;YACpD,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,GAAG,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;YAEnD,MAAM,EAAE,GAAG,IAAI,GAAG,CAAC,CAAC;YACpB,MAAM,CAAC,GAAG,IAAI,GAAG,CAAC,GAAG,SAAS,GAAG,CAAC,GAAG,CAAC,CAAC;YACvC,MAAM,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,CAAC;YAC7B,MAAM,EAAE,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC;YAC3B,MAAM,UAAU,GAAG,EAAE,GAAG,EAAE,CAAC;YAE3B,kDAAkD;YAClD,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,CAAC;YACvB,MAAM,OAAO,GAAG,EAAE,CAAC;YACnB,IAAI,IAAI,GAAG,QAAQ,CAAC;YACpB,IAAI,IAAI,GAAG,CAAC,QAAQ,CAAC;YACrB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,OAAO,EAAE,CAAC,EAAE,EAAE,CAAC;gBAClC,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,OAAO,CAAC;gBAC1C,MAAM,MAAM,GAAG,KAAK,GAAG,CAAC,CAAC,GAAG,SAAS,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBACzD,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;gBAC9B,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;YAChC,CAAC;YACD,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,CAAC,GAAG,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC;YACnD,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YAC7D,MAAM,QAAQ,GAAG,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,SAAS,CAAC,EAAE,CAAC;YACrG,MAAM,EAAE,GAAG,QAAQ,CAAC,EAAE,CAAC;YAEvB,MAAM,OAAO,GAAG,CAAC,QAAgB,EAAE,MAAc,EAAU,EAAE;gBAC3D,MAAM,IAAI,GAAG,EAAE,GAAG,UAAU,GAAG,QAAQ,CAAC;gBACxC,MAAM,EAAE,GAAG,EAAE,GAAG,UAAU,GAAG,MAAM,CAAC;gBACpC,MAAM,CAAC,EAAE,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;gBACxC,MAAM,CAAC,EAAE,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;gBACtC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACpD,MAAM,KAAK,GAAG,UAAU,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACtC,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,KAAK,IAAI,KAAK,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC;YACrE,CAAC,CAAC;YAGF,IAAI,KAAK,GAAW,EAAE,CAAC;YACvB,IAAI,UAAU,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,EAAE,CAAC;gBACpD,MAAM,MAAM,GAAG,CAAC,GAAG,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;gBACjE,MAAM,QAAQ,GAAW,EAAE,CAAC;gBAC5B,IAAI,KAAK,GAAG,GAAG,CAAC;gBAChB,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE,CAAC;oBACvB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;oBAClD,IAAI,GAAG,IAAI,KAAK;wBAAE,SAAS;oBAC3B,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,IAAI,EAAE,EAAE,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;oBACpF,KAAK,GAAG,GAAG,CAAC;gBACd,CAAC;gBACD,IAAI,KAAK,GAAG,GAAG,EAAE,CAAC;oBAChB,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,IAAI,IAAI,SAAS,CAAC;oBAC9D,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,IAAI,EAAE,EAAE,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC;gBACvE,CAAC;gBACD,KAAK,GAAG,QAAQ,CAAC;YACnB,CAAC;YAED,MAAM,WAAW,GAAG,EAAE,GAAG,UAAU,GAAG,IAAI,CAAC;YAC3C,MAAM,GAAG,GAAG,KAAK,CAAC,CAAC,GAAG,SAAS,GAAG,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;YAC1D,MAAM,MAAM,GAAG,KAAK,CAAC,SAAS,GAAG,IAAI,EAAE,WAAW,GAAG,IAAI,CAAC,EAAE,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;YAC1E,MAAM,OAAO,GAAG,KAAK,CAAC,SAAS,GAAG,IAAI,EAAE,WAAW,GAAG,IAAI,CAAC,EAAE,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;YAC3E,MAAM,MAAM,GAAG,KAAK,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,MAAM,OAAO,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;YAEnG,IAAI,SAAiB,CAAC;YACtB,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;gBACzB,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAClD,SAAS,GAAG,GAAG,GAAG,GAAG,CAAC;YACxB,CAAC;iBAAM,CAAC;gBACN,MAAM,GAAG,GAAG,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC7E,SAAS,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC;YAC5C,CAAC;YAED,2FAA2F;YAC3F,IAAI,eAAmC,CAAC;YACxC,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACrB,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,IAAI,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;gBAChG,IAAI,UAAU;oBAAE,eAAe,GAAG,UAAU,CAAC,IAAI,CAAC;YACpD,CAAC;YACD,MAAM,aAAa,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,KAAK,SAAS,EAAE,CAAC,CAAC,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC,CAAC,QAAQ,eAAe,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;iBAC1H,MAAM,CAAC,OAAO,CAAC;iBACf,IAAI,CAAC,IAAI,CAAC,CAAC;YACd,MAAM,cAAc,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,GAAG,SAAS,SAAS,GAAG,SAAS,GAAG,GAAG,CAAC,CAAC;YAE7F,MAAM,WAAW,GAA2B;gBAC1C,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,sBAAsB,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,cAAc,EAAE,SAAS,EAAE,CAAC;aACxG,CAAC;YAEF,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE;gBACxB,WAAW,CAAC,IAAI,CACd,CAAC,CAAC,MAAM,EAAE;oBACR,GAAG,EAAE,OAAO,CAAC,EAAE;oBACf,KAAK,EAAE,4CAA4C,IAAI,CAAC,IAAI,EAAE;oBAC9D,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC;oBAC9B,IAAI,EAAE,MAAM;oBACZ,cAAc,EAAE,SAAS;iBAC1B,CAAC,CACH,CAAC;YACJ,CAAC,CAAC,CAAC;YAEH,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvB,WAAW,CAAC,IAAI,CACd,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,yBAAyB,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,cAAc,EAAE,SAAS,EAAE,CAAC,CAC9G,CAAC;YACJ,CAAC;YAED,WAAW,CAAC,IAAI,CACd,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,uBAAuB,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EACxD,CAAC,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,oBAAoB,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,EACtF,CAAC,CACC,MAAM,EACN,EAAE,KAAK,EAAE,sBAAsB,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,GAAG,SAAS,GAAG,IAAI,EAAE,aAAa,EAAE,QAAQ,EAAE,mBAAmB,EAAE,MAAM,EAAE,EACxH,SAAS,CACV,CACF,CAAC;YACF,IAAI,KAAK,EAAE,CAAC;gBACV,WAAW,CAAC,IAAI,CACd,CAAC,CACC,MAAM,EACN,EAAE,KAAK,EAAE,sBAAsB,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,GAAG,SAAS,GAAG,IAAI,EAAE,aAAa,EAAE,QAAQ,EAAE,mBAAmB,EAAE,SAAS,EAAE,EAC3H,KAAK,CACN,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;gBAC7E,CAAC,CACC,KAAK,EACL;oBACE,KAAK,EAAE,uBAAuB;oBAC9B,IAAI,EAAE,OAAO;oBACb,eAAe,EAAE,OAAO;oBACxB,eAAe,EAAE,GAAG;oBACpB,eAAe,EAAE,GAAG;oBACpB,gBAAgB,EAAE,aAAa;oBAC/B,YAAY,EAAE,KAAK;iBACpB,EACD;oBACE,CAAC,CACC,KAAK,EACL;wBACE,OAAO,EAAE,KAAK,QAAQ,CAAC,KAAK,IAAI,IAAI,IAAI,QAAQ,CAAC,QAAQ,EAAE;wBAC3D,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,IAAI,OAAO,EAAE,cAAc,CAAC;aAChD,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
export type KpiCardSize = "sm" | "md" | "lg";
|
|
2
|
+
export type KpiCardTrend = "up" | "down" | "flat";
|
|
3
|
+
export type KpiCardFormat = "number" | "currency" | "percent";
|
|
4
|
+
export type KpiCardDeltaFormat = "percent" | "absolute";
|
|
5
|
+
export type KpiCardTone = "category1" | "category2" | "category3" | "category4" | "category5" | "category6" | "category7" | "category8";
|
|
6
|
+
export type KpiCardProps = {
|
|
7
|
+
/**
|
|
8
|
+
* Valeur principale. Si `format="percent"`, `value` est une FRACTION (0–1) :
|
|
9
|
+
* passer `0.42` affiche « 42 % » (Intl multiplie par 100). Le formatage ne
|
|
10
|
+
* s'applique qu'aux `number` ; une `string` est rendue telle quelle.
|
|
11
|
+
*/
|
|
12
|
+
value: number | string;
|
|
13
|
+
label: string;
|
|
14
|
+
/**
|
|
15
|
+
* Variation. En `deltaFormat="percent"` (défaut), `delta` est une FRACTION :
|
|
16
|
+
* `0.12` → « +12 % ». NaN/Infinity sont rendus inertes.
|
|
17
|
+
*/
|
|
18
|
+
delta?: number;
|
|
19
|
+
deltaFormat?: KpiCardDeltaFormat;
|
|
20
|
+
trend?: KpiCardTrend;
|
|
21
|
+
format?: KpiCardFormat;
|
|
22
|
+
unit?: string;
|
|
23
|
+
currency?: string;
|
|
24
|
+
locale?: string;
|
|
25
|
+
sparkline?: number[];
|
|
26
|
+
size?: KpiCardSize;
|
|
27
|
+
tone?: KpiCardTone;
|
|
28
|
+
class?: string;
|
|
29
|
+
};
|
|
30
|
+
export declare const KpiCard: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
|
|
31
|
+
value: {
|
|
32
|
+
type: () => number | string;
|
|
33
|
+
required: true;
|
|
34
|
+
};
|
|
35
|
+
label: {
|
|
36
|
+
type: StringConstructor;
|
|
37
|
+
required: true;
|
|
38
|
+
};
|
|
39
|
+
delta: {
|
|
40
|
+
type: NumberConstructor;
|
|
41
|
+
default: undefined;
|
|
42
|
+
};
|
|
43
|
+
deltaFormat: {
|
|
44
|
+
type: () => KpiCardDeltaFormat;
|
|
45
|
+
default: string;
|
|
46
|
+
};
|
|
47
|
+
trend: {
|
|
48
|
+
type: () => KpiCardTrend;
|
|
49
|
+
default: undefined;
|
|
50
|
+
};
|
|
51
|
+
format: {
|
|
52
|
+
type: () => KpiCardFormat;
|
|
53
|
+
default: string;
|
|
54
|
+
};
|
|
55
|
+
unit: {
|
|
56
|
+
type: StringConstructor;
|
|
57
|
+
default: undefined;
|
|
58
|
+
};
|
|
59
|
+
currency: {
|
|
60
|
+
type: StringConstructor;
|
|
61
|
+
default: string;
|
|
62
|
+
};
|
|
63
|
+
locale: {
|
|
64
|
+
type: StringConstructor;
|
|
65
|
+
default: undefined;
|
|
66
|
+
};
|
|
67
|
+
sparkline: {
|
|
68
|
+
type: () => number[];
|
|
69
|
+
default: undefined;
|
|
70
|
+
};
|
|
71
|
+
size: {
|
|
72
|
+
type: () => KpiCardSize;
|
|
73
|
+
default: string;
|
|
74
|
+
};
|
|
75
|
+
tone: {
|
|
76
|
+
type: () => KpiCardTone;
|
|
77
|
+
default: undefined;
|
|
78
|
+
};
|
|
79
|
+
class: {
|
|
80
|
+
type: StringConstructor;
|
|
81
|
+
default: undefined;
|
|
82
|
+
};
|
|
83
|
+
}>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
|
|
84
|
+
[key: string]: any;
|
|
85
|
+
}>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
|
|
86
|
+
value: {
|
|
87
|
+
type: () => number | string;
|
|
88
|
+
required: true;
|
|
89
|
+
};
|
|
90
|
+
label: {
|
|
91
|
+
type: StringConstructor;
|
|
92
|
+
required: true;
|
|
93
|
+
};
|
|
94
|
+
delta: {
|
|
95
|
+
type: NumberConstructor;
|
|
96
|
+
default: undefined;
|
|
97
|
+
};
|
|
98
|
+
deltaFormat: {
|
|
99
|
+
type: () => KpiCardDeltaFormat;
|
|
100
|
+
default: string;
|
|
101
|
+
};
|
|
102
|
+
trend: {
|
|
103
|
+
type: () => KpiCardTrend;
|
|
104
|
+
default: undefined;
|
|
105
|
+
};
|
|
106
|
+
format: {
|
|
107
|
+
type: () => KpiCardFormat;
|
|
108
|
+
default: string;
|
|
109
|
+
};
|
|
110
|
+
unit: {
|
|
111
|
+
type: StringConstructor;
|
|
112
|
+
default: undefined;
|
|
113
|
+
};
|
|
114
|
+
currency: {
|
|
115
|
+
type: StringConstructor;
|
|
116
|
+
default: string;
|
|
117
|
+
};
|
|
118
|
+
locale: {
|
|
119
|
+
type: StringConstructor;
|
|
120
|
+
default: undefined;
|
|
121
|
+
};
|
|
122
|
+
sparkline: {
|
|
123
|
+
type: () => number[];
|
|
124
|
+
default: undefined;
|
|
125
|
+
};
|
|
126
|
+
size: {
|
|
127
|
+
type: () => KpiCardSize;
|
|
128
|
+
default: string;
|
|
129
|
+
};
|
|
130
|
+
tone: {
|
|
131
|
+
type: () => KpiCardTone;
|
|
132
|
+
default: undefined;
|
|
133
|
+
};
|
|
134
|
+
class: {
|
|
135
|
+
type: StringConstructor;
|
|
136
|
+
default: undefined;
|
|
137
|
+
};
|
|
138
|
+
}>> & Readonly<{}>, {
|
|
139
|
+
class: string;
|
|
140
|
+
tone: KpiCardTone;
|
|
141
|
+
locale: string;
|
|
142
|
+
size: KpiCardSize;
|
|
143
|
+
format: KpiCardFormat;
|
|
144
|
+
unit: string;
|
|
145
|
+
currency: string;
|
|
146
|
+
delta: number;
|
|
147
|
+
deltaFormat: KpiCardDeltaFormat;
|
|
148
|
+
trend: KpiCardTrend;
|
|
149
|
+
sparkline: number[];
|
|
150
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
151
|
+
//# sourceMappingURL=KpiCard.d.ts.map
|