@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.
@@ -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