@sentropic/design-system-vue 0.36.36 → 0.36.39
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/DecompositionTreeChart.d.ts +81 -0
- package/dist/DecompositionTreeChart.d.ts.map +1 -0
- package/dist/DecompositionTreeChart.js +206 -0
- package/dist/DecompositionTreeChart.js.map +1 -0
- package/dist/Density2DChart.d.ts +85 -0
- package/dist/Density2DChart.d.ts.map +1 -0
- package/dist/Density2DChart.js +254 -0
- package/dist/Density2DChart.js.map +1 -0
- package/dist/EventFeedPanel.d.ts +70 -0
- package/dist/EventFeedPanel.d.ts.map +1 -0
- package/dist/EventFeedPanel.js +73 -0
- package/dist/EventFeedPanel.js.map +1 -0
- package/dist/FlamegraphChart.d.ts +73 -0
- package/dist/FlamegraphChart.d.ts.map +1 -0
- package/dist/FlamegraphChart.js +146 -0
- package/dist/FlamegraphChart.js.map +1 -0
- package/dist/TraceWaterfallChart.d.ts +88 -0
- package/dist/TraceWaterfallChart.d.ts.map +1 -0
- package/dist/TraceWaterfallChart.js +278 -0
- package/dist/TraceWaterfallChart.js.map +1 -0
- package/dist/VectorFieldChart.d.ts +78 -0
- package/dist/VectorFieldChart.d.ts.map +1 -0
- package/dist/VectorFieldChart.js +159 -0
- package/dist/VectorFieldChart.js.map +1 -0
- 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 +585 -0
- package/package.json +1 -1
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
import { defineComponent, h, ref } from "vue";
|
|
2
|
+
import { classNames } from "./classNames.js";
|
|
3
|
+
import { chartDataList } from "./chartScale.js";
|
|
4
|
+
const MARGIN = { top: 16, right: 16, bottom: 32, left: 152 };
|
|
5
|
+
const INDENT = 10;
|
|
6
|
+
function scaleLinear(v, d0, d1, r0, r1) {
|
|
7
|
+
if (d1 === d0)
|
|
8
|
+
return r0;
|
|
9
|
+
return r0 + ((v - d0) * (r1 - r0)) / (d1 - d0);
|
|
10
|
+
}
|
|
11
|
+
function niceTicks(min, max, target = 5) {
|
|
12
|
+
if (!Number.isFinite(min) || !Number.isFinite(max) || min === max) {
|
|
13
|
+
const base = Number.isFinite(max) ? max : 0;
|
|
14
|
+
return [base];
|
|
15
|
+
}
|
|
16
|
+
const range = max - min;
|
|
17
|
+
const rough = range / Math.max(target - 1, 1);
|
|
18
|
+
const pow = Math.pow(10, Math.floor(Math.log10(rough)));
|
|
19
|
+
const norm = rough / pow;
|
|
20
|
+
let step;
|
|
21
|
+
if (norm < 1.5)
|
|
22
|
+
step = 1 * pow;
|
|
23
|
+
else if (norm < 3)
|
|
24
|
+
step = 2 * pow;
|
|
25
|
+
else if (norm < 7)
|
|
26
|
+
step = 5 * pow;
|
|
27
|
+
else
|
|
28
|
+
step = 10 * pow;
|
|
29
|
+
const start = Math.floor(min / step) * step;
|
|
30
|
+
const end = Math.ceil(max / step) * step;
|
|
31
|
+
const ticks = [];
|
|
32
|
+
for (let v = start; v <= end + step / 2; v += step) {
|
|
33
|
+
ticks.push(Number(v.toFixed(10)));
|
|
34
|
+
}
|
|
35
|
+
return ticks;
|
|
36
|
+
}
|
|
37
|
+
function formatTick(v) {
|
|
38
|
+
if (Math.abs(v) >= 1000)
|
|
39
|
+
return `${(v / 1000).toFixed(v % 1000 === 0 ? 0 : 1)}k`;
|
|
40
|
+
if (Number.isInteger(v))
|
|
41
|
+
return String(v);
|
|
42
|
+
return v.toFixed(1);
|
|
43
|
+
}
|
|
44
|
+
// Truncate a label to the left margin width (approx. by char count).
|
|
45
|
+
function ellipsize(text, maxChars) {
|
|
46
|
+
if (text.length <= maxChars)
|
|
47
|
+
return text;
|
|
48
|
+
if (maxChars <= 1)
|
|
49
|
+
return "…";
|
|
50
|
+
return `${text.slice(0, maxChars - 1)}…`;
|
|
51
|
+
}
|
|
52
|
+
export const TraceWaterfallChart = defineComponent({
|
|
53
|
+
name: "TraceWaterfallChart",
|
|
54
|
+
props: {
|
|
55
|
+
data: { type: Object, default: () => ({ spans: [] }) },
|
|
56
|
+
label: { type: String, default: undefined },
|
|
57
|
+
width: { type: Number, default: undefined },
|
|
58
|
+
height: { type: Number, default: 320 },
|
|
59
|
+
size: { type: Number, default: undefined },
|
|
60
|
+
class: { type: String, default: undefined },
|
|
61
|
+
},
|
|
62
|
+
setup(props, { attrs }) {
|
|
63
|
+
const hoveredIndex = ref(null);
|
|
64
|
+
function handleLeave() {
|
|
65
|
+
hoveredIndex.value = null;
|
|
66
|
+
}
|
|
67
|
+
function handlePointerMove(event) {
|
|
68
|
+
const target = event.target;
|
|
69
|
+
if (!(target instanceof Element)) {
|
|
70
|
+
hoveredIndex.value = null;
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
const idx = Number(target.getAttribute("data-chart-index"));
|
|
74
|
+
hoveredIndex.value = Number.isInteger(idx) ? idx : null;
|
|
75
|
+
}
|
|
76
|
+
return () => {
|
|
77
|
+
const label = props.label;
|
|
78
|
+
const height = props.height ?? 320;
|
|
79
|
+
const resolvedWidth = props.width ?? props.size ?? 640;
|
|
80
|
+
const plotWidth = Math.max(resolvedWidth - MARGIN.left - MARGIN.right, 1);
|
|
81
|
+
const plotHeight = Math.max(height - MARGIN.top - MARGIN.bottom, 1);
|
|
82
|
+
// Normalise: drop spans missing id/service or with non-finite start/duration.
|
|
83
|
+
const validSpans = (props.data?.spans ?? []).filter((s) => s &&
|
|
84
|
+
typeof s.spanId === "string" &&
|
|
85
|
+
s.spanId.length > 0 &&
|
|
86
|
+
typeof s.service === "string" &&
|
|
87
|
+
s.service.length > 0 &&
|
|
88
|
+
Number.isFinite(s.start) &&
|
|
89
|
+
Number.isFinite(s.duration));
|
|
90
|
+
// Hierarchical order: DFS from roots (missing/unknown parentSpanId).
|
|
91
|
+
let ordered = [];
|
|
92
|
+
if (validSpans.length > 0) {
|
|
93
|
+
const byId = new Map();
|
|
94
|
+
for (const s of validSpans)
|
|
95
|
+
if (!byId.has(s.spanId))
|
|
96
|
+
byId.set(s.spanId, s);
|
|
97
|
+
const childrenOf = new Map();
|
|
98
|
+
const roots = [];
|
|
99
|
+
for (const s of validSpans) {
|
|
100
|
+
const p = s.parentSpanId;
|
|
101
|
+
if (p == null || !byId.has(p) || p === s.spanId) {
|
|
102
|
+
roots.push(s);
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
const list = childrenOf.get(p) ?? [];
|
|
106
|
+
list.push(s);
|
|
107
|
+
childrenOf.set(p, list);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
const out = [];
|
|
111
|
+
const seen = new Set();
|
|
112
|
+
const visit = (s, depth) => {
|
|
113
|
+
if (seen.has(s.spanId))
|
|
114
|
+
return;
|
|
115
|
+
seen.add(s.spanId);
|
|
116
|
+
out.push({ span: s, depth });
|
|
117
|
+
for (const k of childrenOf.get(s.spanId) ?? [])
|
|
118
|
+
visit(k, depth + 1);
|
|
119
|
+
};
|
|
120
|
+
for (const r of roots)
|
|
121
|
+
visit(r, 0);
|
|
122
|
+
for (const s of validSpans)
|
|
123
|
+
if (!seen.has(s.spanId))
|
|
124
|
+
visit(s, 0);
|
|
125
|
+
ordered = out;
|
|
126
|
+
}
|
|
127
|
+
// Distinct services (DFS first-seen order) → categoryN index (1..8, cycled).
|
|
128
|
+
const serviceOrder = [];
|
|
129
|
+
for (const o of ordered) {
|
|
130
|
+
if (!serviceOrder.includes(o.span.service))
|
|
131
|
+
serviceOrder.push(o.span.service);
|
|
132
|
+
}
|
|
133
|
+
const toneOf = (service) => {
|
|
134
|
+
const idx = serviceOrder.indexOf(service);
|
|
135
|
+
return `category${((idx < 0 ? 0 : idx) % 8) + 1}`;
|
|
136
|
+
};
|
|
137
|
+
const legendItems = serviceOrder.map((service) => ({ service, tone: toneOf(service) }));
|
|
138
|
+
const hasLegend = serviceOrder.length > 0;
|
|
139
|
+
const vals = [];
|
|
140
|
+
for (const o of ordered)
|
|
141
|
+
vals.push(o.span.start, o.span.start + Math.max(o.span.duration, 0));
|
|
142
|
+
const rawMin = vals.length === 0 ? 0 : Math.min(...vals);
|
|
143
|
+
const rawMaxBase = vals.length === 0 ? 1 : Math.max(...vals);
|
|
144
|
+
const rawMax = rawMaxBase === rawMin ? rawMin + 1 : rawMaxBase;
|
|
145
|
+
const ticks = niceTicks(rawMin, rawMax, 5);
|
|
146
|
+
const domainMin = ticks[0] ?? rawMin;
|
|
147
|
+
const domainMax = ticks[ticks.length - 1] ?? rawMax;
|
|
148
|
+
const xOf = (v) => MARGIN.left + scaleLinear(v, domainMin, domainMax, 0, plotWidth);
|
|
149
|
+
let bars = [];
|
|
150
|
+
if (ordered.length > 0) {
|
|
151
|
+
const band = plotHeight / ordered.length;
|
|
152
|
+
const barHeight = Math.min(band * 0.62, 24);
|
|
153
|
+
bars = ordered.map((o, i) => {
|
|
154
|
+
const x0 = xOf(o.span.start);
|
|
155
|
+
const x1 = xOf(o.span.start + Math.max(o.span.duration, 0));
|
|
156
|
+
const x = Math.min(x0, x1);
|
|
157
|
+
const w = Math.max(Math.abs(x1 - x0), 1);
|
|
158
|
+
const y = MARGIN.top + band * i + (band - barHeight) / 2;
|
|
159
|
+
return {
|
|
160
|
+
span: o.span,
|
|
161
|
+
depth: o.depth,
|
|
162
|
+
index: i,
|
|
163
|
+
x,
|
|
164
|
+
y,
|
|
165
|
+
width: w,
|
|
166
|
+
height: barHeight,
|
|
167
|
+
rowCenterY: MARGIN.top + band * (i + 0.5),
|
|
168
|
+
cx: x + w / 2,
|
|
169
|
+
tone: toneOf(o.span.service),
|
|
170
|
+
};
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
const dataValueItems = ordered.map((o) => `${"·".repeat(o.depth)}${o.span.service}: ${o.span.start} → ${o.span.start + Math.max(o.span.duration, 0)}`);
|
|
174
|
+
const svgChildren = [];
|
|
175
|
+
// gridlines + tick labels (time axis)
|
|
176
|
+
for (const tick of ticks) {
|
|
177
|
+
const tx = xOf(tick);
|
|
178
|
+
svgChildren.push(h("line", {
|
|
179
|
+
key: `g${tick}`,
|
|
180
|
+
class: "st-traceWaterfallChart__grid",
|
|
181
|
+
x1: tx,
|
|
182
|
+
x2: tx,
|
|
183
|
+
y1: MARGIN.top,
|
|
184
|
+
y2: height - MARGIN.bottom,
|
|
185
|
+
}));
|
|
186
|
+
svgChildren.push(h("text", {
|
|
187
|
+
key: `t${tick}`,
|
|
188
|
+
class: "st-traceWaterfallChart__tickLabel",
|
|
189
|
+
x: tx,
|
|
190
|
+
y: height - MARGIN.bottom + 16,
|
|
191
|
+
"text-anchor": "middle",
|
|
192
|
+
}, formatTick(tick)));
|
|
193
|
+
}
|
|
194
|
+
// axes
|
|
195
|
+
svgChildren.push(h("line", {
|
|
196
|
+
class: "st-traceWaterfallChart__axis",
|
|
197
|
+
x1: MARGIN.left,
|
|
198
|
+
x2: MARGIN.left,
|
|
199
|
+
y1: MARGIN.top,
|
|
200
|
+
y2: height - MARGIN.bottom,
|
|
201
|
+
}));
|
|
202
|
+
svgChildren.push(h("line", {
|
|
203
|
+
class: "st-traceWaterfallChart__axis",
|
|
204
|
+
x1: MARGIN.left,
|
|
205
|
+
x2: resolvedWidth - MARGIN.right,
|
|
206
|
+
y1: height - MARGIN.bottom,
|
|
207
|
+
y2: height - MARGIN.bottom,
|
|
208
|
+
}));
|
|
209
|
+
// one bar per span + indented service label on the left
|
|
210
|
+
for (const bar of bars) {
|
|
211
|
+
const i = bar.index;
|
|
212
|
+
const isDim = hoveredIndex.value !== null && hoveredIndex.value !== i;
|
|
213
|
+
svgChildren.push(h("text", {
|
|
214
|
+
key: `lbl${i}`,
|
|
215
|
+
class: "st-traceWaterfallChart__spanLabel",
|
|
216
|
+
x: MARGIN.left - 8,
|
|
217
|
+
y: bar.rowCenterY,
|
|
218
|
+
"text-anchor": "end",
|
|
219
|
+
"dominant-baseline": "middle",
|
|
220
|
+
}, ellipsize(bar.span.service, Math.max(2, 16 - bar.depth))));
|
|
221
|
+
svgChildren.push(h("rect", {
|
|
222
|
+
key: `bar${i}-${bar.span.spanId}`,
|
|
223
|
+
class: classNames("st-traceWaterfallChart__bar", `st-traceWaterfallChart__bar--${bar.tone}`, isDim ? "st-traceWaterfallChart__bar--dim" : undefined),
|
|
224
|
+
x: bar.x + bar.depth * INDENT,
|
|
225
|
+
y: bar.y,
|
|
226
|
+
width: Math.max(bar.width - bar.depth * INDENT, 1),
|
|
227
|
+
height: bar.height,
|
|
228
|
+
rx: 2,
|
|
229
|
+
"data-chart-index": i,
|
|
230
|
+
}));
|
|
231
|
+
}
|
|
232
|
+
const hoveredBar = hoveredIndex.value !== null ? bars[hoveredIndex.value] : undefined;
|
|
233
|
+
const children = [
|
|
234
|
+
h("div", {
|
|
235
|
+
class: "st-traceWaterfallChart__visual",
|
|
236
|
+
role: "img",
|
|
237
|
+
"aria-label": label,
|
|
238
|
+
onPointermove: handlePointerMove,
|
|
239
|
+
onPointerleave: handleLeave,
|
|
240
|
+
}, [
|
|
241
|
+
h("svg", {
|
|
242
|
+
viewBox: `0 0 ${resolvedWidth} ${height}`,
|
|
243
|
+
preserveAspectRatio: "xMidYMid meet",
|
|
244
|
+
width: "100%",
|
|
245
|
+
height: "100%",
|
|
246
|
+
focusable: "false",
|
|
247
|
+
"aria-hidden": "true",
|
|
248
|
+
}, svgChildren),
|
|
249
|
+
]),
|
|
250
|
+
];
|
|
251
|
+
if (hasLegend) {
|
|
252
|
+
children.push(h("ul", {
|
|
253
|
+
class: "st-traceWaterfallChart__legend",
|
|
254
|
+
"aria-label": `Services de ${label ?? "trace"}`,
|
|
255
|
+
}, legendItems.map((item) => h("li", { key: item.service, class: "st-traceWaterfallChart__legendItem" }, [
|
|
256
|
+
h("span", {
|
|
257
|
+
class: `st-traceWaterfallChart__legendSwatch st-traceWaterfallChart__legendSwatch--${item.tone}`,
|
|
258
|
+
"aria-hidden": "true",
|
|
259
|
+
}),
|
|
260
|
+
item.service,
|
|
261
|
+
]))));
|
|
262
|
+
}
|
|
263
|
+
children.push(chartDataList(label ?? "trace waterfall", dataValueItems));
|
|
264
|
+
if (hoveredBar) {
|
|
265
|
+
children.push(h("div", {
|
|
266
|
+
class: "st-traceWaterfallChart__tooltip",
|
|
267
|
+
role: "presentation",
|
|
268
|
+
style: `left:${(hoveredBar.cx / resolvedWidth) * 100}%;top:${(hoveredBar.rowCenterY / height) * 100}%`,
|
|
269
|
+
}, [
|
|
270
|
+
h("span", { class: "st-traceWaterfallChart__tooltipLabel" }, hoveredBar.span.service),
|
|
271
|
+
h("span", { class: "st-traceWaterfallChart__tooltipValue" }, `${hoveredBar.span.start} → ${hoveredBar.span.start + Math.max(hoveredBar.span.duration, 0)}`),
|
|
272
|
+
]));
|
|
273
|
+
}
|
|
274
|
+
return h("div", { ...attrs, class: classNames("st-traceWaterfallChart", props.class) }, children);
|
|
275
|
+
};
|
|
276
|
+
},
|
|
277
|
+
});
|
|
278
|
+
//# sourceMappingURL=TraceWaterfallChart.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TraceWaterfallChart.js","sourceRoot":"","sources":["../src/TraceWaterfallChart.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
export type VectorFieldChartTone = "category1" | "category2" | "category3" | "category4" | "category5" | "category6" | "category7" | "category8";
|
|
2
|
+
export type VectorFieldChartDatum = {
|
|
3
|
+
x: number;
|
|
4
|
+
y: number;
|
|
5
|
+
/** Magnitude (≥ 0) : pilote la longueur normalisée et la couleur. */
|
|
6
|
+
length: number;
|
|
7
|
+
/** Direction en DEGRÉS (0° = +X, sens trigonométrique). */
|
|
8
|
+
direction: number;
|
|
9
|
+
};
|
|
10
|
+
export type VectorFieldChartProps = {
|
|
11
|
+
data: VectorFieldChartDatum[];
|
|
12
|
+
label?: string;
|
|
13
|
+
width?: number;
|
|
14
|
+
height?: number;
|
|
15
|
+
size?: number;
|
|
16
|
+
class?: string;
|
|
17
|
+
};
|
|
18
|
+
export declare const VectorFieldChart: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
|
|
19
|
+
data: {
|
|
20
|
+
type: () => VectorFieldChartDatum[];
|
|
21
|
+
default: () => never[];
|
|
22
|
+
};
|
|
23
|
+
label: {
|
|
24
|
+
type: StringConstructor;
|
|
25
|
+
default: undefined;
|
|
26
|
+
};
|
|
27
|
+
width: {
|
|
28
|
+
type: NumberConstructor;
|
|
29
|
+
default: number;
|
|
30
|
+
};
|
|
31
|
+
height: {
|
|
32
|
+
type: NumberConstructor;
|
|
33
|
+
default: number;
|
|
34
|
+
};
|
|
35
|
+
size: {
|
|
36
|
+
type: NumberConstructor;
|
|
37
|
+
default: number;
|
|
38
|
+
};
|
|
39
|
+
class: {
|
|
40
|
+
type: StringConstructor;
|
|
41
|
+
default: undefined;
|
|
42
|
+
};
|
|
43
|
+
}>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
|
|
44
|
+
[key: string]: any;
|
|
45
|
+
}>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
|
|
46
|
+
data: {
|
|
47
|
+
type: () => VectorFieldChartDatum[];
|
|
48
|
+
default: () => never[];
|
|
49
|
+
};
|
|
50
|
+
label: {
|
|
51
|
+
type: StringConstructor;
|
|
52
|
+
default: undefined;
|
|
53
|
+
};
|
|
54
|
+
width: {
|
|
55
|
+
type: NumberConstructor;
|
|
56
|
+
default: number;
|
|
57
|
+
};
|
|
58
|
+
height: {
|
|
59
|
+
type: NumberConstructor;
|
|
60
|
+
default: number;
|
|
61
|
+
};
|
|
62
|
+
size: {
|
|
63
|
+
type: NumberConstructor;
|
|
64
|
+
default: number;
|
|
65
|
+
};
|
|
66
|
+
class: {
|
|
67
|
+
type: StringConstructor;
|
|
68
|
+
default: undefined;
|
|
69
|
+
};
|
|
70
|
+
}>> & Readonly<{}>, {
|
|
71
|
+
size: number;
|
|
72
|
+
class: string;
|
|
73
|
+
data: VectorFieldChartDatum[];
|
|
74
|
+
label: string;
|
|
75
|
+
height: number;
|
|
76
|
+
width: number;
|
|
77
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
78
|
+
//# sourceMappingURL=VectorFieldChart.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VectorFieldChart.d.ts","sourceRoot":"","sources":["../src/VectorFieldChart.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,oBAAoB,GAC5B,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,CAAC;AAEhB,MAAM,MAAM,qBAAqB,GAAG;IAClC,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,qEAAqE;IACrE,MAAM,EAAE,MAAM,CAAC;IACf,2DAA2D;IAC3D,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG;IAClC,IAAI,EAAE,qBAAqB,EAAE,CAAC;IAC9B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAeF,eAAO,MAAM,gBAAgB;;cAGF,MAAM,qBAAqB,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;cAA7B,MAAM,qBAAqB,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4EA4MtD,CAAC"}
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
import { defineComponent, h, ref } from "vue";
|
|
2
|
+
import { classNames } from "./classNames.js";
|
|
3
|
+
import { chartDataList, formatTick, niceTicks, scaleLinear } from "./chartScale.js";
|
|
4
|
+
const MARGIN = { top: 16, right: 18, bottom: 36, left: 48 };
|
|
5
|
+
const TONES = [
|
|
6
|
+
"category1",
|
|
7
|
+
"category2",
|
|
8
|
+
"category3",
|
|
9
|
+
"category4",
|
|
10
|
+
"category5",
|
|
11
|
+
"category6",
|
|
12
|
+
"category7",
|
|
13
|
+
"category8",
|
|
14
|
+
];
|
|
15
|
+
export const VectorFieldChart = defineComponent({
|
|
16
|
+
name: "VectorFieldChart",
|
|
17
|
+
props: {
|
|
18
|
+
data: { type: Array, default: () => [] },
|
|
19
|
+
label: { type: String, default: undefined },
|
|
20
|
+
width: { type: Number, default: 640 },
|
|
21
|
+
height: { type: Number, default: 320 },
|
|
22
|
+
size: { type: Number, default: 26 },
|
|
23
|
+
class: { type: String, default: undefined },
|
|
24
|
+
},
|
|
25
|
+
setup(props, { attrs }) {
|
|
26
|
+
const hoveredKey = ref(null);
|
|
27
|
+
function handlePointerMove(event) {
|
|
28
|
+
const target = event.target;
|
|
29
|
+
if (!(target instanceof Element)) {
|
|
30
|
+
hoveredKey.value = null;
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
hoveredKey.value = target.getAttribute("data-chart-key");
|
|
34
|
+
}
|
|
35
|
+
return () => {
|
|
36
|
+
const data = props.data ?? [];
|
|
37
|
+
const label = props.label;
|
|
38
|
+
const width = props.width ?? 640;
|
|
39
|
+
const height = props.height ?? 320;
|
|
40
|
+
const size = props.size ?? 26;
|
|
41
|
+
// Points valides : coordonnées finies, magnitude finie ≥ 0.
|
|
42
|
+
const validData = data.filter((d) => d &&
|
|
43
|
+
Number.isFinite(d.x) &&
|
|
44
|
+
Number.isFinite(d.y) &&
|
|
45
|
+
Number.isFinite(d.length) &&
|
|
46
|
+
d.length >= 0 &&
|
|
47
|
+
Number.isFinite(d.direction));
|
|
48
|
+
const xs = validData.map((d) => d.x);
|
|
49
|
+
const ys = validData.map((d) => d.y);
|
|
50
|
+
const xTicks = niceTicks(Math.min(...xs), Math.max(...xs));
|
|
51
|
+
const yTicks = niceTicks(Math.min(...ys), Math.max(...ys));
|
|
52
|
+
const plotW = Math.max(width - MARGIN.left - MARGIN.right, 1);
|
|
53
|
+
const plotH = Math.max(height - MARGIN.top - MARGIN.bottom, 1);
|
|
54
|
+
const xMin = xTicks[0];
|
|
55
|
+
const xMax = xTicks[xTicks.length - 1];
|
|
56
|
+
const yMin = yTicks[0];
|
|
57
|
+
const yMax = yTicks[yTicks.length - 1];
|
|
58
|
+
const maxLength = validData.reduce((max, d) => (d.length > max ? d.length : max), 0);
|
|
59
|
+
// Une flèche par point : segment (base → pointe) + 2 traits de pointe.
|
|
60
|
+
const arrows = validData.map((d, i) => {
|
|
61
|
+
const cx = MARGIN.left + scaleLinear(d.x, xMin, xMax, 0, plotW);
|
|
62
|
+
const cy = MARGIN.top + scaleLinear(d.y, yMin, yMax, plotH, 0);
|
|
63
|
+
const max = maxLength > 0 ? maxLength : 1;
|
|
64
|
+
const len = (d.length / max) * size;
|
|
65
|
+
const rad = (d.direction * Math.PI) / 180;
|
|
66
|
+
const dx = Math.cos(rad) * len;
|
|
67
|
+
const dy = -Math.sin(rad) * len;
|
|
68
|
+
const x1 = cx - dx / 2;
|
|
69
|
+
const y1 = cy - dy / 2;
|
|
70
|
+
const x2 = cx + dx / 2;
|
|
71
|
+
const y2 = cy + dy / 2;
|
|
72
|
+
const head = Math.min(Math.max(len * 0.28, 3), 8);
|
|
73
|
+
const headAngle = (28 * Math.PI) / 180;
|
|
74
|
+
const baseAngle = Math.atan2(y2 - y1, x2 - x1);
|
|
75
|
+
const hx1 = x2 - head * Math.cos(baseAngle - headAngle);
|
|
76
|
+
const hy1 = y2 - head * Math.sin(baseAngle - headAngle);
|
|
77
|
+
const hx2 = x2 - head * Math.cos(baseAngle + headAngle);
|
|
78
|
+
const hy2 = y2 - head * Math.sin(baseAngle + headAngle);
|
|
79
|
+
const bin = Math.min(Math.floor((d.length / max) * TONES.length), TONES.length - 1);
|
|
80
|
+
return {
|
|
81
|
+
key: `${i}`,
|
|
82
|
+
datum: d,
|
|
83
|
+
cx,
|
|
84
|
+
cy,
|
|
85
|
+
x1,
|
|
86
|
+
y1,
|
|
87
|
+
x2,
|
|
88
|
+
y2,
|
|
89
|
+
hx1,
|
|
90
|
+
hy1,
|
|
91
|
+
hx2,
|
|
92
|
+
hy2,
|
|
93
|
+
tone: TONES[Math.max(0, bin)],
|
|
94
|
+
};
|
|
95
|
+
});
|
|
96
|
+
const dataValueItems = validData.map((d) => `x ${d.x}, y ${d.y} · |v| ${formatTick(d.length)} @ ${formatTick(d.direction)}°`);
|
|
97
|
+
const hoveredArrow = hoveredKey.value === null ? null : arrows.find((a) => a.key === hoveredKey.value) ?? null;
|
|
98
|
+
const svgChildren = [];
|
|
99
|
+
for (const t of yTicks) {
|
|
100
|
+
const y = MARGIN.top + scaleLinear(t, yMin, yMax, plotH, 0);
|
|
101
|
+
svgChildren.push(h("line", { key: `gy${t}`, class: "st-vectorFieldChart__grid", x1: MARGIN.left, x2: width - MARGIN.right, y1: y, y2: y }), h("text", { key: `ty${t}`, class: "st-vectorFieldChart__tick", x: MARGIN.left - 6, y, "text-anchor": "end", "dominant-baseline": "middle" }, formatTick(t)));
|
|
102
|
+
}
|
|
103
|
+
for (const t of xTicks) {
|
|
104
|
+
const x = MARGIN.left + scaleLinear(t, xMin, xMax, 0, plotW);
|
|
105
|
+
svgChildren.push(h("text", { key: `tx${t}`, class: "st-vectorFieldChart__tick", x, y: height - MARGIN.bottom + 16, "text-anchor": "middle" }, formatTick(t)));
|
|
106
|
+
}
|
|
107
|
+
svgChildren.push(h("line", { class: "st-vectorFieldChart__axis", x1: MARGIN.left, x2: MARGIN.left, y1: MARGIN.top, y2: height - MARGIN.bottom }), h("line", {
|
|
108
|
+
class: "st-vectorFieldChart__axis",
|
|
109
|
+
x1: MARGIN.left,
|
|
110
|
+
x2: width - MARGIN.right,
|
|
111
|
+
y1: height - MARGIN.bottom,
|
|
112
|
+
y2: height - MARGIN.bottom,
|
|
113
|
+
}));
|
|
114
|
+
arrows.forEach((a) => {
|
|
115
|
+
svgChildren.push(h("g", {
|
|
116
|
+
key: a.key,
|
|
117
|
+
class: classNames("st-vectorFieldChart__arrow", `st-vectorFieldChart__arrow--${a.tone}`, hoveredKey.value !== null && hoveredKey.value !== a.key ? "st-vectorFieldChart__arrow--dim" : undefined),
|
|
118
|
+
}, [
|
|
119
|
+
h("line", { class: "st-vectorFieldChart__shaft", x1: a.x1, y1: a.y1, x2: a.x2, y2: a.y2, "data-chart-key": a.key }),
|
|
120
|
+
h("line", { class: "st-vectorFieldChart__head", x1: a.x2, y1: a.y2, x2: a.hx1, y2: a.hy1 }),
|
|
121
|
+
h("line", { class: "st-vectorFieldChart__head", x1: a.x2, y1: a.y2, x2: a.hx2, y2: a.hy2 }),
|
|
122
|
+
]));
|
|
123
|
+
});
|
|
124
|
+
const children = [
|
|
125
|
+
h("div", {
|
|
126
|
+
class: "st-vectorFieldChart__visual",
|
|
127
|
+
role: "img",
|
|
128
|
+
"aria-label": label,
|
|
129
|
+
onPointermove: handlePointerMove,
|
|
130
|
+
onPointerleave: () => (hoveredKey.value = null),
|
|
131
|
+
}, [
|
|
132
|
+
h("svg", {
|
|
133
|
+
viewBox: `0 0 ${width} ${height}`,
|
|
134
|
+
preserveAspectRatio: "xMidYMid meet",
|
|
135
|
+
width: "100%",
|
|
136
|
+
height: "100%",
|
|
137
|
+
focusable: "false",
|
|
138
|
+
"aria-hidden": "true",
|
|
139
|
+
}, svgChildren),
|
|
140
|
+
]),
|
|
141
|
+
];
|
|
142
|
+
const list = chartDataList(label ?? "vector field", dataValueItems);
|
|
143
|
+
if (list)
|
|
144
|
+
children.push(list);
|
|
145
|
+
if (hoveredArrow) {
|
|
146
|
+
children.push(h("div", {
|
|
147
|
+
class: "st-vectorFieldChart__tooltip",
|
|
148
|
+
role: "presentation",
|
|
149
|
+
style: { left: `${(hoveredArrow.cx / width) * 100}%`, top: `${(hoveredArrow.cy / height) * 100}%` },
|
|
150
|
+
}, [
|
|
151
|
+
h("span", { class: "st-vectorFieldChart__tooltipLabel" }, `x ${hoveredArrow.datum.x} · y ${hoveredArrow.datum.y}`),
|
|
152
|
+
h("span", { class: "st-vectorFieldChart__tooltipValue" }, `|v| ${formatTick(hoveredArrow.datum.length)} @ ${formatTick(hoveredArrow.datum.direction)}°`),
|
|
153
|
+
]));
|
|
154
|
+
}
|
|
155
|
+
return h("div", { ...attrs, class: classNames("st-vectorFieldChart", props.class) }, children);
|
|
156
|
+
};
|
|
157
|
+
},
|
|
158
|
+
});
|
|
159
|
+
//# sourceMappingURL=VectorFieldChart.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VectorFieldChart.js","sourceRoot":"","sources":["../src/VectorFieldChart.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -190,12 +190,24 @@ export { StateTimelineChart } from "./StateTimelineChart.js";
|
|
|
190
190
|
export type { StateTimelineChartProps, StateTimelineTone, StateTimelineSegment, StateTimelineSeries, } from "./StateTimelineChart.js";
|
|
191
191
|
export { StatusHistoryChart } from "./StatusHistoryChart.js";
|
|
192
192
|
export type { StatusHistoryChartProps, StatusHistoryTone, StatusHistoryBucket, StatusHistorySeries, } from "./StatusHistoryChart.js";
|
|
193
|
+
export { EventFeedPanel } from "./EventFeedPanel.js";
|
|
194
|
+
export type { EventFeedPanelProps, EventFeedPanelEvent, EventFeedPanelSeverity } from "./EventFeedPanel.js";
|
|
195
|
+
export { VectorFieldChart } from "./VectorFieldChart.js";
|
|
196
|
+
export type { VectorFieldChartProps, VectorFieldChartDatum, VectorFieldChartTone } from "./VectorFieldChart.js";
|
|
193
197
|
export { WaffleChart } from "./WaffleChart.js";
|
|
194
198
|
export type { WaffleChartProps, WaffleTone, WaffleChartDatum, } from "./WaffleChart.js";
|
|
195
199
|
export { RibbonChart } from "./RibbonChart.js";
|
|
196
200
|
export type { RibbonChartProps, RibbonChartTone, RibbonChartDatum, } from "./RibbonChart.js";
|
|
197
201
|
export { AnomalySwimLaneChart } from "./AnomalySwimLaneChart.js";
|
|
198
202
|
export type { AnomalySwimLaneChartProps, AnomalySwimLaneTone, AnomalySwimLaneBucket, AnomalySwimLaneSeries, } from "./AnomalySwimLaneChart.js";
|
|
203
|
+
export { FlamegraphChart } from "./FlamegraphChart.js";
|
|
204
|
+
export type { FlamegraphChartProps, FlamegraphNode } from "./FlamegraphChart.js";
|
|
205
|
+
export { TraceWaterfallChart } from "./TraceWaterfallChart.js";
|
|
206
|
+
export type { TraceWaterfallChartProps, TraceSpan } from "./TraceWaterfallChart.js";
|
|
207
|
+
export { DecompositionTreeChart } from "./DecompositionTreeChart.js";
|
|
208
|
+
export type { DecompositionTreeChartProps, DecompositionTreeNode, DecompositionTreeLevel, DecompositionTreeData, } from "./DecompositionTreeChart.js";
|
|
209
|
+
export { Density2DChart } from "./Density2DChart.js";
|
|
210
|
+
export type { Density2DChartProps, Density2DTone, Density2DPoint } from "./Density2DChart.js";
|
|
199
211
|
export { GeoMap } from "./GeoMap.js";
|
|
200
212
|
export type { GeoMapProps, GeoMapTone, GeoMapCoordinate, GeoMapBounds, GeoMapProjection, GeoMapGeometryType, GeoMapGeometry, GeoMapFeature, GeoMapPoint, GeoMapFlow, GeoMapGeojsonLayer, GeoMapChoroplethLayer, GeoMapPointsLayer, GeoMapDensityLayer, GeoMapFlowLayer, GeoMapHexbinLayer, GeoMapClusterLayer, GeoMapLayer, } from "./GeoMap.js";
|
|
201
213
|
export { FunnelChart } from "./FunnelChart.js";
|