footprint-explainable-ui 0.3.2 → 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +42 -3
- package/dist/adapters/fromRuntimeSnapshot.d.ts +52 -0
- package/dist/adapters/fromRuntimeSnapshot.d.ts.map +1 -0
- package/dist/adapters/fromRuntimeSnapshot.js +97 -0
- package/dist/adapters/fromRuntimeSnapshot.js.map +1 -0
- package/dist/components/ExplainableShell/ExplainableShell.d.ts +26 -0
- package/dist/components/ExplainableShell/ExplainableShell.d.ts.map +1 -0
- package/dist/components/ExplainableShell/ExplainableShell.js +94 -0
- package/dist/components/ExplainableShell/ExplainableShell.js.map +1 -0
- package/dist/components/ExplainableShell/index.d.ts +3 -0
- package/dist/components/ExplainableShell/index.d.ts.map +1 -0
- package/dist/components/ExplainableShell/index.js +2 -0
- package/dist/components/ExplainableShell/index.js.map +1 -0
- package/dist/components/FlowchartView/FlowchartView.d.ts +20 -0
- package/dist/components/FlowchartView/FlowchartView.d.ts.map +1 -0
- package/dist/components/FlowchartView/FlowchartView.js +80 -0
- package/dist/components/FlowchartView/FlowchartView.js.map +1 -0
- package/dist/components/FlowchartView/SubflowBreadcrumb.d.ts +11 -0
- package/dist/components/FlowchartView/SubflowBreadcrumb.d.ts.map +1 -0
- package/dist/components/FlowchartView/SubflowBreadcrumb.js +49 -0
- package/dist/components/FlowchartView/SubflowBreadcrumb.js.map +1 -0
- package/dist/components/FlowchartView/SubflowTree.d.ts +36 -0
- package/dist/components/FlowchartView/SubflowTree.d.ts.map +1 -0
- package/dist/components/FlowchartView/SubflowTree.js +143 -0
- package/dist/components/FlowchartView/SubflowTree.js.map +1 -0
- package/dist/components/FlowchartView/TracedFlowchartView.d.ts +20 -0
- package/dist/components/FlowchartView/TracedFlowchartView.d.ts.map +1 -0
- package/dist/components/FlowchartView/TracedFlowchartView.js +101 -0
- package/dist/components/FlowchartView/TracedFlowchartView.js.map +1 -0
- package/dist/components/FlowchartView/index.d.ts +11 -0
- package/dist/components/FlowchartView/index.d.ts.map +1 -0
- package/dist/components/FlowchartView/index.js +6 -0
- package/dist/components/FlowchartView/index.js.map +1 -0
- package/dist/components/FlowchartView/specToReactFlow.d.ts +56 -0
- package/dist/components/FlowchartView/specToReactFlow.d.ts.map +1 -0
- package/dist/components/FlowchartView/specToReactFlow.js +202 -0
- package/dist/components/FlowchartView/specToReactFlow.js.map +1 -0
- package/dist/components/FlowchartView/useSubflowNavigation.d.ts +35 -0
- package/dist/components/FlowchartView/useSubflowNavigation.d.ts.map +1 -0
- package/dist/components/FlowchartView/useSubflowNavigation.js +80 -0
- package/dist/components/FlowchartView/useSubflowNavigation.js.map +1 -0
- package/dist/components/GanttTimeline/GanttTimeline.d.ts +18 -0
- package/dist/components/GanttTimeline/GanttTimeline.d.ts.map +1 -0
- package/dist/components/GanttTimeline/GanttTimeline.js +123 -0
- package/dist/components/GanttTimeline/GanttTimeline.js.map +1 -0
- package/dist/components/GanttTimeline/index.d.ts +3 -0
- package/dist/components/GanttTimeline/index.d.ts.map +1 -0
- package/dist/components/GanttTimeline/index.js +2 -0
- package/dist/components/GanttTimeline/index.js.map +1 -0
- package/dist/components/MemoryInspector/MemoryInspector.d.ts +19 -0
- package/dist/components/MemoryInspector/MemoryInspector.d.ts.map +1 -0
- package/dist/components/MemoryInspector/MemoryInspector.js +95 -0
- package/dist/components/MemoryInspector/MemoryInspector.js.map +1 -0
- package/dist/components/MemoryInspector/index.d.ts +3 -0
- package/dist/components/MemoryInspector/index.d.ts.map +1 -0
- package/dist/components/MemoryInspector/index.js +2 -0
- package/dist/components/MemoryInspector/index.js.map +1 -0
- package/dist/components/NarrativeLog/NarrativeLog.d.ts +15 -0
- package/dist/components/NarrativeLog/NarrativeLog.d.ts.map +1 -0
- package/dist/components/NarrativeLog/NarrativeLog.js +65 -0
- package/dist/components/NarrativeLog/NarrativeLog.js.map +1 -0
- package/dist/components/NarrativeLog/index.d.ts +3 -0
- package/dist/components/NarrativeLog/index.d.ts.map +1 -0
- package/dist/components/NarrativeLog/index.js +2 -0
- package/dist/components/NarrativeLog/index.js.map +1 -0
- package/dist/components/NarrativeTrace/NarrativeTrace.d.ts +13 -0
- package/dist/components/NarrativeTrace/NarrativeTrace.d.ts.map +1 -0
- package/dist/components/NarrativeTrace/NarrativeTrace.js +127 -0
- package/dist/components/NarrativeTrace/NarrativeTrace.js.map +1 -0
- package/dist/components/NarrativeTrace/index.d.ts +3 -0
- package/dist/components/NarrativeTrace/index.d.ts.map +1 -0
- package/dist/components/NarrativeTrace/index.js +2 -0
- package/dist/components/NarrativeTrace/index.js.map +1 -0
- package/dist/components/ResultPanel/ResultPanel.d.ts +11 -0
- package/dist/components/ResultPanel/ResultPanel.d.ts.map +1 -0
- package/dist/components/ResultPanel/ResultPanel.js +54 -0
- package/dist/components/ResultPanel/ResultPanel.js.map +1 -0
- package/dist/components/ResultPanel/index.d.ts +3 -0
- package/dist/components/ResultPanel/index.d.ts.map +1 -0
- package/dist/components/ResultPanel/index.js +2 -0
- package/dist/components/ResultPanel/index.js.map +1 -0
- package/dist/components/ScopeDiff/ScopeDiff.d.ts +17 -0
- package/dist/components/ScopeDiff/ScopeDiff.d.ts.map +1 -0
- package/dist/components/ScopeDiff/ScopeDiff.js +87 -0
- package/dist/components/ScopeDiff/ScopeDiff.js.map +1 -0
- package/dist/components/ScopeDiff/index.d.ts +3 -0
- package/dist/components/ScopeDiff/index.d.ts.map +1 -0
- package/dist/components/ScopeDiff/index.js +2 -0
- package/dist/components/ScopeDiff/index.js.map +1 -0
- package/dist/components/SnapshotPanel/SnapshotPanel.d.ts +17 -0
- package/dist/components/SnapshotPanel/SnapshotPanel.d.ts.map +1 -0
- package/dist/components/SnapshotPanel/SnapshotPanel.js +85 -0
- package/dist/components/SnapshotPanel/SnapshotPanel.js.map +1 -0
- package/dist/components/SnapshotPanel/index.d.ts +3 -0
- package/dist/components/SnapshotPanel/index.d.ts.map +1 -0
- package/dist/components/SnapshotPanel/index.js +2 -0
- package/dist/components/SnapshotPanel/index.js.map +1 -0
- package/dist/components/StageNode/StageNode.d.ts +31 -0
- package/dist/components/StageNode/StageNode.d.ts.map +1 -0
- package/dist/components/StageNode/StageNode.js +134 -0
- package/dist/components/StageNode/StageNode.js.map +1 -0
- package/dist/components/StageNode/index.d.ts +3 -0
- package/dist/components/StageNode/index.d.ts.map +1 -0
- package/dist/components/StageNode/index.js +2 -0
- package/dist/components/StageNode/index.js.map +1 -0
- package/dist/components/TimeTravelControls/TimeTravelControls.d.ts +13 -0
- package/dist/components/TimeTravelControls/TimeTravelControls.d.ts.map +1 -0
- package/dist/components/TimeTravelControls/TimeTravelControls.js +104 -0
- package/dist/components/TimeTravelControls/TimeTravelControls.js.map +1 -0
- package/dist/components/TimeTravelControls/index.d.ts +3 -0
- package/dist/components/TimeTravelControls/index.d.ts.map +1 -0
- package/dist/components/TimeTravelControls/index.js +2 -0
- package/dist/components/TimeTravelControls/index.js.map +1 -0
- package/dist/components/TimeTravelDebugger/TimeTravelDebugger.d.ts +22 -0
- package/dist/components/TimeTravelDebugger/TimeTravelDebugger.d.ts.map +1 -0
- package/dist/components/TimeTravelDebugger/TimeTravelDebugger.js +104 -0
- package/dist/components/TimeTravelDebugger/TimeTravelDebugger.js.map +1 -0
- package/dist/components/TimeTravelDebugger/index.d.ts +3 -0
- package/dist/components/TimeTravelDebugger/index.d.ts.map +1 -0
- package/dist/components/TimeTravelDebugger/index.js +2 -0
- package/dist/components/TimeTravelDebugger/index.js.map +1 -0
- package/dist/flowchart.cjs +704 -220
- package/dist/flowchart.cjs.map +1 -1
- package/dist/flowchart.d.cts +55 -1
- package/dist/flowchart.d.ts +55 -1
- package/dist/flowchart.d.ts.map +1 -0
- package/dist/flowchart.js +700 -214
- package/dist/flowchart.js.map +1 -1
- package/dist/index.cjs +849 -76
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +95 -3
- package/dist/index.d.ts +95 -3
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +851 -80
- package/dist/index.js.map +1 -1
- package/dist/theme/ThemeProvider.d.ts +13 -0
- package/dist/theme/ThemeProvider.d.ts.map +1 -0
- package/dist/theme/ThemeProvider.js +16 -0
- package/dist/theme/ThemeProvider.js.map +1 -0
- package/dist/theme/index.d.ts +7 -0
- package/dist/theme/index.d.ts.map +1 -0
- package/dist/theme/index.js +5 -0
- package/dist/theme/index.js.map +1 -0
- package/dist/theme/presets.d.ts +15 -0
- package/dist/theme/presets.d.ts.map +1 -0
- package/dist/theme/presets.js +70 -0
- package/dist/theme/presets.js.map +1 -0
- package/dist/theme/styles.d.ts +32 -0
- package/dist/theme/styles.d.ts.map +1 -0
- package/dist/theme/styles.js +37 -0
- package/dist/theme/styles.js.map +1 -0
- package/dist/theme/tokens.d.ts +28 -0
- package/dist/theme/tokens.d.ts.map +1 -0
- package/dist/theme/tokens.js +58 -0
- package/dist/theme/tokens.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/types.d.ts +35 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/package.json +10 -4
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { useState, useCallback, useMemo } from "react";
|
|
2
|
+
import { specToReactFlow } from "./specToReactFlow";
|
|
3
|
+
/**
|
|
4
|
+
* Hook that manages subflow drill-down navigation for a flowchart spec.
|
|
5
|
+
*
|
|
6
|
+
* Maintains a breadcrumb stack. When a subflow node is clicked, pushes its
|
|
7
|
+
* nested spec onto the stack and re-derives nodes/edges. Breadcrumb clicks
|
|
8
|
+
* pop back to that level.
|
|
9
|
+
*/
|
|
10
|
+
export function useSubflowNavigation(rootSpec, overlay, colors) {
|
|
11
|
+
const [stack, setStack] = useState([]);
|
|
12
|
+
// Current spec = top of stack, or root
|
|
13
|
+
const currentSpec = stack.length > 0 ? stack[stack.length - 1].spec : rootSpec;
|
|
14
|
+
// Derive nodes/edges from current spec
|
|
15
|
+
// Overlay is always passed through — consumer provides the appropriate overlay
|
|
16
|
+
// (root overlay at root level, subflow overlay when drilled in)
|
|
17
|
+
const { nodes, edges } = useMemo(() => {
|
|
18
|
+
if (!currentSpec)
|
|
19
|
+
return { nodes: [], edges: [] };
|
|
20
|
+
return specToReactFlow(currentSpec, overlay, colors);
|
|
21
|
+
}, [currentSpec, overlay, colors]);
|
|
22
|
+
// Build a lookup of subflow nodes at the current level
|
|
23
|
+
const subflowMap = useMemo(() => {
|
|
24
|
+
const map = new Map();
|
|
25
|
+
if (!currentSpec)
|
|
26
|
+
return map;
|
|
27
|
+
function collectSubflows(node) {
|
|
28
|
+
if (node.isSubflowRoot && node.subflowStructure) {
|
|
29
|
+
const id = node.name || node.id || "";
|
|
30
|
+
map.set(id, node);
|
|
31
|
+
}
|
|
32
|
+
if (node.children)
|
|
33
|
+
node.children.forEach(collectSubflows);
|
|
34
|
+
if (node.next)
|
|
35
|
+
collectSubflows(node.next);
|
|
36
|
+
}
|
|
37
|
+
collectSubflows(currentSpec);
|
|
38
|
+
return map;
|
|
39
|
+
}, [currentSpec]);
|
|
40
|
+
const breadcrumbs = useMemo(() => {
|
|
41
|
+
const root = {
|
|
42
|
+
label: rootSpec?.name || "Pipeline",
|
|
43
|
+
spec: rootSpec,
|
|
44
|
+
description: rootSpec?.description,
|
|
45
|
+
};
|
|
46
|
+
return [root, ...stack];
|
|
47
|
+
}, [rootSpec, stack]);
|
|
48
|
+
const handleNodeClick = useCallback((nodeId) => {
|
|
49
|
+
const subflowNode = subflowMap.get(nodeId);
|
|
50
|
+
if (!subflowNode?.subflowStructure)
|
|
51
|
+
return false;
|
|
52
|
+
setStack((prev) => [
|
|
53
|
+
...prev,
|
|
54
|
+
{
|
|
55
|
+
label: subflowNode.subflowName || subflowNode.name,
|
|
56
|
+
spec: subflowNode.subflowStructure,
|
|
57
|
+
description: subflowNode.description,
|
|
58
|
+
},
|
|
59
|
+
]);
|
|
60
|
+
return true;
|
|
61
|
+
}, [subflowMap]);
|
|
62
|
+
const navigateTo = useCallback((level) => {
|
|
63
|
+
if (level === 0) {
|
|
64
|
+
setStack([]);
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
setStack((prev) => prev.slice(0, level));
|
|
68
|
+
}
|
|
69
|
+
}, []);
|
|
70
|
+
return {
|
|
71
|
+
breadcrumbs,
|
|
72
|
+
nodes,
|
|
73
|
+
edges,
|
|
74
|
+
handleNodeClick,
|
|
75
|
+
navigateTo,
|
|
76
|
+
isInSubflow: stack.length > 0,
|
|
77
|
+
currentSubflowNodeName: stack.length > 0 ? stack[stack.length - 1].label : null,
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=useSubflowNavigation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useSubflowNavigation.js","sourceRoot":"","sources":["../../../src/components/FlowchartView/useSubflowNavigation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { StageSnapshot, BaseComponentProps } from "../../types";
|
|
2
|
+
export interface GanttTimelineProps extends BaseComponentProps {
|
|
3
|
+
/** Stage snapshots with timing info */
|
|
4
|
+
snapshots: StageSnapshot[];
|
|
5
|
+
/** Currently selected stage index */
|
|
6
|
+
selectedIndex?: number;
|
|
7
|
+
/** Callback when a stage bar is clicked */
|
|
8
|
+
onSelect?: (index: number) => void;
|
|
9
|
+
/** Max visible rows before collapsing (0 = no collapse). Default: 5 */
|
|
10
|
+
maxVisibleRows?: number;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Horizontal Gantt-style timeline showing stage durations and overlap.
|
|
14
|
+
* Collapses to `maxVisibleRows` with expand/collapse toggle.
|
|
15
|
+
* Auto-scrolls to keep the active stage visible when collapsed.
|
|
16
|
+
*/
|
|
17
|
+
export declare function GanttTimeline({ snapshots, selectedIndex, onSelect, size, unstyled, className, style, maxVisibleRows, }: GanttTimelineProps): import("react/jsx-runtime").JSX.Element;
|
|
18
|
+
//# sourceMappingURL=GanttTimeline.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GanttTimeline.d.ts","sourceRoot":"","sources":["../../../src/components/GanttTimeline/GanttTimeline.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAGrE,MAAM,WAAW,kBAAmB,SAAQ,kBAAkB;IAC5D,uCAAuC;IACvC,SAAS,EAAE,aAAa,EAAE,CAAC;IAC3B,qCAAqC;IACrC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,2CAA2C;IAC3C,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,uEAAuE;IACvE,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,EAC5B,SAAS,EACT,aAAiB,EACjB,QAAQ,EACR,IAAgB,EAChB,QAAgB,EAChB,SAAS,EACT,KAAK,EACL,cAAkB,GACnB,EAAE,kBAAkB,2CAiNpB"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useMemo, useRef, useEffect } from "react";
|
|
3
|
+
import { theme, fontSize, padding } from "../../theme";
|
|
4
|
+
/**
|
|
5
|
+
* Horizontal Gantt-style timeline showing stage durations and overlap.
|
|
6
|
+
* Collapses to `maxVisibleRows` with expand/collapse toggle.
|
|
7
|
+
* Auto-scrolls to keep the active stage visible when collapsed.
|
|
8
|
+
*/
|
|
9
|
+
export function GanttTimeline({ snapshots, selectedIndex = 0, onSelect, size = "default", unstyled = false, className, style, maxVisibleRows = 5, }) {
|
|
10
|
+
const [expanded, setExpanded] = useState(false);
|
|
11
|
+
const activeRowRef = useRef(null);
|
|
12
|
+
const scrollContainerRef = useRef(null);
|
|
13
|
+
const totalWallTime = useMemo(() => Math.max(...snapshots.map((s) => s.startMs + s.durationMs), 1), [snapshots]);
|
|
14
|
+
const fs = fontSize[size];
|
|
15
|
+
const pad = padding[size];
|
|
16
|
+
const labelWidth = size === "compact" ? 50 : size === "detailed" ? 100 : 80;
|
|
17
|
+
const msWidth = size === "compact" ? 28 : 36;
|
|
18
|
+
const rowHeight = size === "compact" ? 18 : 22;
|
|
19
|
+
const collapsible = maxVisibleRows > 0 && snapshots.length > maxVisibleRows;
|
|
20
|
+
const showAll = expanded || !collapsible;
|
|
21
|
+
// Auto-scroll to active row when collapsed
|
|
22
|
+
useEffect(() => {
|
|
23
|
+
if (!showAll && activeRowRef.current && scrollContainerRef.current) {
|
|
24
|
+
activeRowRef.current.scrollIntoView({
|
|
25
|
+
block: "nearest",
|
|
26
|
+
behavior: "smooth",
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
}, [selectedIndex, showAll]);
|
|
30
|
+
if (unstyled) {
|
|
31
|
+
return (_jsx("div", { className: className, style: style, "data-fp": "gantt-timeline", children: snapshots.map((snap, idx) => (_jsxs("div", { "data-fp": "gantt-bar", "data-selected": idx === selectedIndex, "data-visible": idx <= selectedIndex, onClick: () => onSelect?.(idx), children: [_jsx("span", { "data-fp": "gantt-label", children: snap.stageLabel }), _jsxs("span", { "data-fp": "gantt-duration", children: [snap.durationMs, "ms"] })] }, snap.stageName))) }));
|
|
32
|
+
}
|
|
33
|
+
return (_jsxs("div", { className: className, style: { padding: pad, fontFamily: theme.fontSans, ...style }, "data-fp": "gantt-timeline", children: [_jsxs("div", { style: {
|
|
34
|
+
display: "flex",
|
|
35
|
+
alignItems: "center",
|
|
36
|
+
justifyContent: "space-between",
|
|
37
|
+
}, children: [_jsx("span", { style: {
|
|
38
|
+
fontSize: fs.label,
|
|
39
|
+
fontWeight: 600,
|
|
40
|
+
color: theme.textMuted,
|
|
41
|
+
textTransform: "uppercase",
|
|
42
|
+
letterSpacing: "0.08em",
|
|
43
|
+
}, children: size === "compact" ? "Timeline" : "Execution Timeline" }), collapsible && (_jsx("button", { onClick: () => setExpanded((e) => !e), style: {
|
|
44
|
+
background: "none",
|
|
45
|
+
border: `1px solid ${theme.border}`,
|
|
46
|
+
borderRadius: 4,
|
|
47
|
+
color: theme.textSecondary,
|
|
48
|
+
fontSize: fs.small,
|
|
49
|
+
padding: "2px 8px",
|
|
50
|
+
cursor: "pointer",
|
|
51
|
+
fontFamily: theme.fontSans,
|
|
52
|
+
}, children: expanded
|
|
53
|
+
? "Collapse"
|
|
54
|
+
: `${snapshots.length - maxVisibleRows} more...` }))] }), _jsx("div", { ref: scrollContainerRef, style: {
|
|
55
|
+
marginTop: 8,
|
|
56
|
+
display: "flex",
|
|
57
|
+
flexDirection: "column",
|
|
58
|
+
gap: 4,
|
|
59
|
+
...(showAll
|
|
60
|
+
? {}
|
|
61
|
+
: {
|
|
62
|
+
maxHeight: maxVisibleRows * (rowHeight + 4),
|
|
63
|
+
overflowY: "auto",
|
|
64
|
+
scrollbarWidth: "thin",
|
|
65
|
+
}),
|
|
66
|
+
}, children: snapshots.map((snap, idx) => {
|
|
67
|
+
const leftPct = (snap.startMs / totalWallTime) * 100;
|
|
68
|
+
const widthPct = Math.max((snap.durationMs / totalWallTime) * 100, 1);
|
|
69
|
+
const isSelected = idx === selectedIndex;
|
|
70
|
+
const isVisible = idx <= selectedIndex;
|
|
71
|
+
return (_jsxs("div", { ref: isSelected ? activeRowRef : undefined, onClick: () => onSelect?.(idx), style: {
|
|
72
|
+
display: "flex",
|
|
73
|
+
alignItems: "center",
|
|
74
|
+
gap: size === "compact" ? 4 : 8,
|
|
75
|
+
cursor: onSelect ? "pointer" : "default",
|
|
76
|
+
opacity: isVisible ? 1 : 0.3,
|
|
77
|
+
transition: "opacity 0.3s ease",
|
|
78
|
+
height: rowHeight,
|
|
79
|
+
flexShrink: 0,
|
|
80
|
+
}, children: [_jsx("span", { style: {
|
|
81
|
+
width: labelWidth,
|
|
82
|
+
fontSize: fs.small,
|
|
83
|
+
color: isSelected ? theme.primary : theme.textMuted,
|
|
84
|
+
fontWeight: isSelected ? 600 : 400,
|
|
85
|
+
textAlign: "right",
|
|
86
|
+
flexShrink: 0,
|
|
87
|
+
overflow: "hidden",
|
|
88
|
+
textOverflow: "ellipsis",
|
|
89
|
+
whiteSpace: "nowrap",
|
|
90
|
+
}, children: snap.stageLabel }), _jsx("div", { style: {
|
|
91
|
+
flex: 1,
|
|
92
|
+
height: size === "compact" ? 6 : 8,
|
|
93
|
+
position: "relative",
|
|
94
|
+
background: theme.bgTertiary,
|
|
95
|
+
borderRadius: 3,
|
|
96
|
+
}, children: isVisible && (_jsx("div", { style: {
|
|
97
|
+
position: "absolute",
|
|
98
|
+
left: `${leftPct}%`,
|
|
99
|
+
top: 0,
|
|
100
|
+
width: `${widthPct}%`,
|
|
101
|
+
height: "100%",
|
|
102
|
+
borderRadius: 3,
|
|
103
|
+
background: isSelected ? theme.primary : theme.success,
|
|
104
|
+
transition: "width 0.3s ease",
|
|
105
|
+
} })) }), _jsxs("span", { style: {
|
|
106
|
+
fontSize: fs.small,
|
|
107
|
+
color: theme.textMuted,
|
|
108
|
+
fontFamily: theme.fontMono,
|
|
109
|
+
width: msWidth,
|
|
110
|
+
flexShrink: 0,
|
|
111
|
+
}, children: [snap.durationMs, "ms"] })] }, snap.stageName));
|
|
112
|
+
}) }), _jsxs("div", { style: {
|
|
113
|
+
marginTop: 4,
|
|
114
|
+
marginLeft: labelWidth + (size === "compact" ? 4 : 8),
|
|
115
|
+
marginRight: msWidth + (size === "compact" ? 4 : 8),
|
|
116
|
+
display: "flex",
|
|
117
|
+
justifyContent: "space-between",
|
|
118
|
+
fontSize: fs.small - 1,
|
|
119
|
+
color: theme.textMuted,
|
|
120
|
+
fontFamily: theme.fontMono,
|
|
121
|
+
}, children: [_jsx("span", { children: "0ms" }), size !== "compact" && (_jsxs("span", { children: [(totalWallTime / 2).toFixed(1), "ms"] })), _jsxs("span", { children: [totalWallTime.toFixed(1), "ms"] })] })] }));
|
|
122
|
+
}
|
|
123
|
+
//# sourceMappingURL=GanttTimeline.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GanttTimeline.js","sourceRoot":"","sources":["../../../src/components/GanttTimeline/GanttTimeline.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAE7D,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAavD;;;;GAIG;AACH,MAAM,UAAU,aAAa,CAAC,EAC5B,SAAS,EACT,aAAa,GAAG,CAAC,EACjB,QAAQ,EACR,IAAI,GAAG,SAAS,EAChB,QAAQ,GAAG,KAAK,EAChB,SAAS,EACT,KAAK,EACL,cAAc,GAAG,CAAC,GACC;IACnB,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAChD,MAAM,YAAY,GAAG,MAAM,CAAwB,IAAI,CAAC,CAAC;IACzD,MAAM,kBAAkB,GAAG,MAAM,CAAwB,IAAI,CAAC,CAAC;IAE/D,MAAM,aAAa,GAAG,OAAO,CAC3B,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,EACpE,CAAC,SAAS,CAAC,CACZ,CAAC;IAEF,MAAM,EAAE,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC1B,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1B,MAAM,UAAU,GAAG,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IAC5E,MAAM,OAAO,GAAG,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IAC7C,MAAM,SAAS,GAAG,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IAE/C,MAAM,WAAW,GAAG,cAAc,GAAG,CAAC,IAAI,SAAS,CAAC,MAAM,GAAG,cAAc,CAAC;IAC5E,MAAM,OAAO,GAAG,QAAQ,IAAI,CAAC,WAAW,CAAC;IAEzC,2CAA2C;IAC3C,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,OAAO,IAAI,YAAY,CAAC,OAAO,IAAI,kBAAkB,CAAC,OAAO,EAAE,CAAC;YACnE,YAAY,CAAC,OAAO,CAAC,cAAc,CAAC;gBAClC,KAAK,EAAE,SAAS;gBAChB,QAAQ,EAAE,QAAQ;aACnB,CAAC,CAAC;QACL,CAAC;IACH,CAAC,EAAE,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,CAAC;IAE7B,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,CACL,cAAK,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,aAAU,gBAAgB,YAC9D,SAAS,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,CAAC,CAC5B,0BAEU,WAAW,mBACJ,GAAG,KAAK,aAAa,kBACtB,GAAG,IAAI,aAAa,EAClC,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,aAE9B,0BAAc,aAAa,YAAE,IAAI,CAAC,UAAU,GAAQ,EACpD,2BAAc,gBAAgB,aAAE,IAAI,CAAC,UAAU,UAAU,KAPpD,IAAI,CAAC,SAAS,CAQf,CACP,CAAC,GACE,CACP,CAAC;IACJ,CAAC;IAED,OAAO,CACL,eACE,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,EAAE,OAAO,EAAE,GAAG,EAAE,UAAU,EAAE,KAAK,CAAC,QAAQ,EAAE,GAAG,KAAK,EAAE,aACrD,gBAAgB,aAGxB,eACE,KAAK,EAAE;oBACL,OAAO,EAAE,MAAM;oBACf,UAAU,EAAE,QAAQ;oBACpB,cAAc,EAAE,eAAe;iBAChC,aAED,eACE,KAAK,EAAE;4BACL,QAAQ,EAAE,EAAE,CAAC,KAAK;4BAClB,UAAU,EAAE,GAAG;4BACf,KAAK,EAAE,KAAK,CAAC,SAAS;4BACtB,aAAa,EAAE,WAAW;4BAC1B,aAAa,EAAE,QAAQ;yBACxB,YAEA,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,oBAAoB,GAClD,EACN,WAAW,IAAI,CACd,iBACE,OAAO,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,EACrC,KAAK,EAAE;4BACL,UAAU,EAAE,MAAM;4BAClB,MAAM,EAAE,aAAa,KAAK,CAAC,MAAM,EAAE;4BACnC,YAAY,EAAE,CAAC;4BACf,KAAK,EAAE,KAAK,CAAC,aAAa;4BAC1B,QAAQ,EAAE,EAAE,CAAC,KAAK;4BAClB,OAAO,EAAE,SAAS;4BAClB,MAAM,EAAE,SAAS;4BACjB,UAAU,EAAE,KAAK,CAAC,QAAQ;yBAC3B,YAEA,QAAQ;4BACP,CAAC,CAAC,UAAU;4BACZ,CAAC,CAAC,GAAG,SAAS,CAAC,MAAM,GAAG,cAAc,UAAU,GAC3C,CACV,IACG,EAGN,cACE,GAAG,EAAE,kBAAkB,EACvB,KAAK,EAAE;oBACL,SAAS,EAAE,CAAC;oBACZ,OAAO,EAAE,MAAM;oBACf,aAAa,EAAE,QAAQ;oBACvB,GAAG,EAAE,CAAC;oBACN,GAAG,CAAC,OAAO;wBACT,CAAC,CAAC,EAAE;wBACJ,CAAC,CAAC;4BACE,SAAS,EAAE,cAAc,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC;4BAC3C,SAAS,EAAE,MAAM;4BACjB,cAAc,EAAE,MAAM;yBACvB,CAAC;iBACP,YAEA,SAAS,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE;oBAC3B,MAAM,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,GAAG,aAAa,CAAC,GAAG,GAAG,CAAC;oBACrD,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,aAAa,CAAC,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC;oBACtE,MAAM,UAAU,GAAG,GAAG,KAAK,aAAa,CAAC;oBACzC,MAAM,SAAS,GAAG,GAAG,IAAI,aAAa,CAAC;oBAEvC,OAAO,CACL,eAEE,GAAG,EAAE,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,EAC1C,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,EAC9B,KAAK,EAAE;4BACL,OAAO,EAAE,MAAM;4BACf,UAAU,EAAE,QAAQ;4BACpB,GAAG,EAAE,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;4BAC/B,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;4BACxC,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG;4BAC5B,UAAU,EAAE,mBAAmB;4BAC/B,MAAM,EAAE,SAAS;4BACjB,UAAU,EAAE,CAAC;yBACd,aAED,eACE,KAAK,EAAE;oCACL,KAAK,EAAE,UAAU;oCACjB,QAAQ,EAAE,EAAE,CAAC,KAAK;oCAClB,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS;oCACnD,UAAU,EAAE,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG;oCAClC,SAAS,EAAE,OAAO;oCAClB,UAAU,EAAE,CAAC;oCACb,QAAQ,EAAE,QAAQ;oCAClB,YAAY,EAAE,UAAU;oCACxB,UAAU,EAAE,QAAQ;iCACrB,YAEA,IAAI,CAAC,UAAU,GACX,EACP,cACE,KAAK,EAAE;oCACL,IAAI,EAAE,CAAC;oCACP,MAAM,EAAE,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oCAClC,QAAQ,EAAE,UAAU;oCACpB,UAAU,EAAE,KAAK,CAAC,UAAU;oCAC5B,YAAY,EAAE,CAAC;iCAChB,YAEA,SAAS,IAAI,CACZ,cACE,KAAK,EAAE;wCACL,QAAQ,EAAE,UAAU;wCACpB,IAAI,EAAE,GAAG,OAAO,GAAG;wCACnB,GAAG,EAAE,CAAC;wCACN,KAAK,EAAE,GAAG,QAAQ,GAAG;wCACrB,MAAM,EAAE,MAAM;wCACd,YAAY,EAAE,CAAC;wCACf,UAAU,EAAE,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO;wCACtD,UAAU,EAAE,iBAAiB;qCAC9B,GACD,CACH,GACG,EACN,gBACE,KAAK,EAAE;oCACL,QAAQ,EAAE,EAAE,CAAC,KAAK;oCAClB,KAAK,EAAE,KAAK,CAAC,SAAS;oCACtB,UAAU,EAAE,KAAK,CAAC,QAAQ;oCAC1B,KAAK,EAAE,OAAO;oCACd,UAAU,EAAE,CAAC;iCACd,aAEA,IAAI,CAAC,UAAU,UACX,KA/DF,IAAI,CAAC,SAAS,CAgEf,CACP,CAAC;gBACJ,CAAC,CAAC,GACE,EAGN,eACE,KAAK,EAAE;oBACL,SAAS,EAAE,CAAC;oBACZ,UAAU,EAAE,UAAU,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACrD,WAAW,EAAE,OAAO,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACnD,OAAO,EAAE,MAAM;oBACf,cAAc,EAAE,eAAe;oBAC/B,QAAQ,EAAE,EAAE,CAAC,KAAK,GAAG,CAAC;oBACtB,KAAK,EAAE,KAAK,CAAC,SAAS;oBACtB,UAAU,EAAE,KAAK,CAAC,QAAQ;iBAC3B,aAED,iCAAgB,EACf,IAAI,KAAK,SAAS,IAAI,CACrB,2BAAO,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,CAChD,EACD,2BAAO,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,IACrC,IACF,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/GanttTimeline/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,YAAY,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/GanttTimeline/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { StageSnapshot, BaseComponentProps } from "../../types";
|
|
2
|
+
export interface MemoryInspectorProps extends BaseComponentProps {
|
|
3
|
+
/** Single memory object or snapshots (will accumulate up to selectedIndex) */
|
|
4
|
+
data?: Record<string, unknown>;
|
|
5
|
+
/** When using snapshots mode, pass these instead of data */
|
|
6
|
+
snapshots?: StageSnapshot[];
|
|
7
|
+
/** Index to accumulate up to (for time-travel) */
|
|
8
|
+
selectedIndex?: number;
|
|
9
|
+
/** Show data types alongside values */
|
|
10
|
+
showTypes?: boolean;
|
|
11
|
+
/** Highlight keys that are new at this step */
|
|
12
|
+
highlightNew?: boolean;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Displays pipeline memory state as formatted JSON.
|
|
16
|
+
* Supports both static (data prop) and time-travel (snapshots + selectedIndex) modes.
|
|
17
|
+
*/
|
|
18
|
+
export declare function MemoryInspector({ data, snapshots, selectedIndex, showTypes, highlightNew, size, unstyled, className, style, }: MemoryInspectorProps): import("react/jsx-runtime").JSX.Element;
|
|
19
|
+
//# sourceMappingURL=MemoryInspector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MemoryInspector.d.ts","sourceRoot":"","sources":["../../../src/components/MemoryInspector/MemoryInspector.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAGrE,MAAM,WAAW,oBAAqB,SAAQ,kBAAkB;IAC9D,8EAA8E;IAC9E,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,4DAA4D;IAC5D,SAAS,CAAC,EAAE,aAAa,EAAE,CAAC;IAC5B,kDAAkD;IAClD,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,uCAAuC;IACvC,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,+CAA+C;IAC/C,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB;AAED;;;GAGG;AACH,wBAAgB,eAAe,CAAC,EAC9B,IAAI,EACJ,SAAS,EACT,aAAiB,EACjB,SAAiB,EACjB,YAAmB,EACnB,IAAgB,EAChB,QAAgB,EAChB,SAAS,EACT,KAAK,GACN,EAAE,oBAAoB,2CAsItB"}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useMemo } from "react";
|
|
3
|
+
import { theme, fontSize, padding } from "../../theme";
|
|
4
|
+
/**
|
|
5
|
+
* Displays pipeline memory state as formatted JSON.
|
|
6
|
+
* Supports both static (data prop) and time-travel (snapshots + selectedIndex) modes.
|
|
7
|
+
*/
|
|
8
|
+
export function MemoryInspector({ data, snapshots, selectedIndex = 0, showTypes = false, highlightNew = true, size = "default", unstyled = false, className, style, }) {
|
|
9
|
+
// Compute accumulated memory from snapshots
|
|
10
|
+
const { memory, newKeys } = useMemo(() => {
|
|
11
|
+
if (data) {
|
|
12
|
+
return { memory: data, newKeys: new Set() };
|
|
13
|
+
}
|
|
14
|
+
if (!snapshots || snapshots.length === 0) {
|
|
15
|
+
return { memory: {}, newKeys: new Set() };
|
|
16
|
+
}
|
|
17
|
+
const merged = {};
|
|
18
|
+
for (let i = 0; i <= Math.min(selectedIndex, snapshots.length - 1); i++) {
|
|
19
|
+
Object.assign(merged, snapshots[i]?.memory);
|
|
20
|
+
}
|
|
21
|
+
const nk = new Set();
|
|
22
|
+
if (highlightNew && selectedIndex > 0) {
|
|
23
|
+
const prev = {};
|
|
24
|
+
for (let i = 0; i < selectedIndex; i++) {
|
|
25
|
+
Object.assign(prev, snapshots[i]?.memory);
|
|
26
|
+
}
|
|
27
|
+
const current = snapshots[selectedIndex]?.memory ?? {};
|
|
28
|
+
for (const k of Object.keys(current)) {
|
|
29
|
+
if (!(k in prev))
|
|
30
|
+
nk.add(k);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
else if (highlightNew && selectedIndex === 0 && snapshots[0]) {
|
|
34
|
+
for (const k of Object.keys(snapshots[0].memory))
|
|
35
|
+
nk.add(k);
|
|
36
|
+
}
|
|
37
|
+
return { memory: merged, newKeys: nk };
|
|
38
|
+
}, [data, snapshots, selectedIndex, highlightNew]);
|
|
39
|
+
const entries = Object.entries(memory);
|
|
40
|
+
const fs = fontSize[size];
|
|
41
|
+
const pad = padding[size];
|
|
42
|
+
if (unstyled) {
|
|
43
|
+
return (_jsxs("div", { className: className, style: style, "data-fp": "memory-inspector", children: [_jsx("div", { "data-fp": "memory-label", children: "Memory State" }), _jsx("pre", { "data-fp": "memory-json", children: JSON.stringify(memory, null, 2) })] }));
|
|
44
|
+
}
|
|
45
|
+
return (_jsxs("div", { className: className, style: {
|
|
46
|
+
padding: pad,
|
|
47
|
+
fontFamily: theme.fontSans,
|
|
48
|
+
...style,
|
|
49
|
+
}, "data-fp": "memory-inspector", children: [_jsx("span", { style: {
|
|
50
|
+
fontSize: fs.label,
|
|
51
|
+
fontWeight: 600,
|
|
52
|
+
color: theme.textMuted,
|
|
53
|
+
textTransform: "uppercase",
|
|
54
|
+
letterSpacing: "0.08em",
|
|
55
|
+
}, children: "Memory State" }), _jsxs("div", { style: {
|
|
56
|
+
marginTop: 8,
|
|
57
|
+
background: theme.bgSecondary,
|
|
58
|
+
border: `1px solid ${theme.border}`,
|
|
59
|
+
borderRadius: theme.radius,
|
|
60
|
+
padding: `${pad}px ${pad + 4}px`,
|
|
61
|
+
fontFamily: theme.fontMono,
|
|
62
|
+
fontSize: fs.body,
|
|
63
|
+
lineHeight: 1.8,
|
|
64
|
+
}, children: [_jsx("span", { style: { color: theme.textMuted }, children: "{" }), entries.length === 0 && (_jsx("div", { style: {
|
|
65
|
+
paddingLeft: 16,
|
|
66
|
+
color: theme.textMuted,
|
|
67
|
+
fontStyle: "italic",
|
|
68
|
+
}, children: "// empty" })), entries.map(([key, value], i) => {
|
|
69
|
+
const isNew = newKeys.has(key);
|
|
70
|
+
const isLast = i === entries.length - 1;
|
|
71
|
+
return (_jsxs("div", { style: {
|
|
72
|
+
paddingLeft: 16,
|
|
73
|
+
background: isNew
|
|
74
|
+
? `color-mix(in srgb, ${theme.success} 10%, transparent)`
|
|
75
|
+
: "transparent",
|
|
76
|
+
borderRadius: 4,
|
|
77
|
+
marginLeft: -4,
|
|
78
|
+
marginRight: -4,
|
|
79
|
+
paddingRight: 4,
|
|
80
|
+
}, children: [_jsxs("span", { style: { color: theme.primary }, children: ["\"", key, "\""] }), _jsx("span", { style: { color: theme.textMuted }, children: ": " }), _jsx("span", { style: { color: theme.success }, children: formatValue(value) }), showTypes && (_jsxs("span", { style: {
|
|
81
|
+
color: theme.textMuted,
|
|
82
|
+
fontSize: fs.small,
|
|
83
|
+
marginLeft: 8,
|
|
84
|
+
opacity: 0.6,
|
|
85
|
+
}, children: ["(", typeof value, ")"] })), !isLast && _jsx("span", { style: { color: theme.textMuted }, children: "," })] }, key));
|
|
86
|
+
}), _jsx("span", { style: { color: theme.textMuted }, children: "}" })] })] }));
|
|
87
|
+
}
|
|
88
|
+
function formatValue(value) {
|
|
89
|
+
if (typeof value === "string")
|
|
90
|
+
return `"${value}"`;
|
|
91
|
+
if (typeof value === "object" && value !== null)
|
|
92
|
+
return JSON.stringify(value);
|
|
93
|
+
return String(value);
|
|
94
|
+
}
|
|
95
|
+
//# sourceMappingURL=MemoryInspector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MemoryInspector.js","sourceRoot":"","sources":["../../../src/components/MemoryInspector/MemoryInspector.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/MemoryInspector/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,YAAY,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/MemoryInspector/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { StageSnapshot, BaseComponentProps } from "../../types";
|
|
2
|
+
export interface NarrativeLogProps extends BaseComponentProps {
|
|
3
|
+
/** Snapshots to display narratives from */
|
|
4
|
+
snapshots: StageSnapshot[];
|
|
5
|
+
/** Show narratives up to this index (for time-travel sync) */
|
|
6
|
+
selectedIndex?: number;
|
|
7
|
+
/** Show a single narrative string (simple mode) */
|
|
8
|
+
narrative?: string;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Timeline-style execution log showing what happened at each stage.
|
|
12
|
+
* Supports both full snapshots mode and single-narrative mode.
|
|
13
|
+
*/
|
|
14
|
+
export declare function NarrativeLog({ snapshots, selectedIndex, narrative, size, unstyled, className, style, }: NarrativeLogProps): import("react/jsx-runtime").JSX.Element;
|
|
15
|
+
//# sourceMappingURL=NarrativeLog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NarrativeLog.d.ts","sourceRoot":"","sources":["../../../src/components/NarrativeLog/NarrativeLog.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAGrE,MAAM,WAAW,iBAAkB,SAAQ,kBAAkB;IAC3D,2CAA2C;IAC3C,SAAS,EAAE,aAAa,EAAE,CAAC;IAC3B,8DAA8D;IAC9D,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,mDAAmD;IACnD,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;;GAGG;AACH,wBAAgB,YAAY,CAAC,EAC3B,SAAS,EACT,aAAa,EACb,SAAS,EACT,IAAgB,EAChB,QAAgB,EAChB,SAAS,EACT,KAAK,GACN,EAAE,iBAAiB,2CAqHnB"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useMemo } from "react";
|
|
3
|
+
import { theme, fontSize, padding } from "../../theme";
|
|
4
|
+
/**
|
|
5
|
+
* Timeline-style execution log showing what happened at each stage.
|
|
6
|
+
* Supports both full snapshots mode and single-narrative mode.
|
|
7
|
+
*/
|
|
8
|
+
export function NarrativeLog({ snapshots, selectedIndex, narrative, size = "default", unstyled = false, className, style, }) {
|
|
9
|
+
const entries = useMemo(() => {
|
|
10
|
+
if (narrative) {
|
|
11
|
+
return [{ label: "Output", text: narrative, isCurrent: true }];
|
|
12
|
+
}
|
|
13
|
+
const idx = selectedIndex ?? snapshots.length - 1;
|
|
14
|
+
return snapshots.slice(0, idx + 1).map((s, i) => ({
|
|
15
|
+
label: s.stageLabel,
|
|
16
|
+
text: s.narrative,
|
|
17
|
+
isCurrent: i === idx,
|
|
18
|
+
}));
|
|
19
|
+
}, [snapshots, selectedIndex, narrative]);
|
|
20
|
+
const fs = fontSize[size];
|
|
21
|
+
const pad = padding[size];
|
|
22
|
+
if (unstyled) {
|
|
23
|
+
return (_jsx("div", { className: className, style: style, "data-fp": "narrative-log", children: entries.map((entry, i) => (_jsxs("div", { "data-fp": "narrative-entry", "data-current": entry.isCurrent, children: [_jsx("strong", { children: entry.label }), _jsx("p", { children: entry.text })] }, i))) }));
|
|
24
|
+
}
|
|
25
|
+
return (_jsxs("div", { className: className, style: { padding: pad, fontFamily: theme.fontSans, ...style }, "data-fp": "narrative-log", children: [_jsx("span", { style: {
|
|
26
|
+
fontSize: fs.label,
|
|
27
|
+
fontWeight: 600,
|
|
28
|
+
color: theme.textMuted,
|
|
29
|
+
textTransform: "uppercase",
|
|
30
|
+
letterSpacing: "0.08em",
|
|
31
|
+
}, children: "Execution Log" }), _jsx("div", { style: { marginTop: 8, display: "flex", flexDirection: "column" }, children: entries.map((entry, i) => (_jsxs("div", { style: {
|
|
32
|
+
display: "flex",
|
|
33
|
+
gap: 10,
|
|
34
|
+
padding: `${pad}px 0`,
|
|
35
|
+
borderBottom: i < entries.length - 1 ? `1px solid ${theme.border}` : "none",
|
|
36
|
+
}, children: [_jsxs("div", { style: {
|
|
37
|
+
display: "flex",
|
|
38
|
+
flexDirection: "column",
|
|
39
|
+
alignItems: "center",
|
|
40
|
+
width: 12,
|
|
41
|
+
flexShrink: 0,
|
|
42
|
+
paddingTop: 5,
|
|
43
|
+
}, children: [_jsx("div", { style: {
|
|
44
|
+
width: 8,
|
|
45
|
+
height: 8,
|
|
46
|
+
borderRadius: "50%",
|
|
47
|
+
background: entry.isCurrent ? theme.primary : theme.success,
|
|
48
|
+
flexShrink: 0,
|
|
49
|
+
} }), i < entries.length - 1 && (_jsx("div", { style: {
|
|
50
|
+
width: 1,
|
|
51
|
+
flex: 1,
|
|
52
|
+
background: theme.border,
|
|
53
|
+
marginTop: 4,
|
|
54
|
+
} }))] }), _jsxs("div", { style: { flex: 1, minWidth: 0 }, children: [_jsx("span", { style: {
|
|
55
|
+
fontSize: fs.label,
|
|
56
|
+
fontWeight: 600,
|
|
57
|
+
color: entry.isCurrent ? theme.primary : theme.textMuted,
|
|
58
|
+
}, children: entry.label }), _jsx("div", { style: {
|
|
59
|
+
fontSize: fs.body,
|
|
60
|
+
lineHeight: 1.5,
|
|
61
|
+
color: entry.isCurrent ? theme.textPrimary : theme.textSecondary,
|
|
62
|
+
marginTop: 2,
|
|
63
|
+
}, children: entry.text })] })] }, i))) })] }));
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=NarrativeLog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NarrativeLog.js","sourceRoot":"","sources":["../../../src/components/NarrativeLog/NarrativeLog.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/NarrativeLog/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,YAAY,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/NarrativeLog/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { BaseComponentProps } from "../../types";
|
|
2
|
+
export interface NarrativeTraceProps extends BaseComponentProps {
|
|
3
|
+
/** All narrative lines (full trace) */
|
|
4
|
+
narrative: string[];
|
|
5
|
+
/** Number of lines currently revealed (for progressive reveal). Defaults to all. */
|
|
6
|
+
revealedCount?: number;
|
|
7
|
+
/** Start with all groups collapsed */
|
|
8
|
+
defaultCollapsed?: boolean;
|
|
9
|
+
/** Called when user clicks a stage header */
|
|
10
|
+
onStageClick?: (headerIndex: number) => void;
|
|
11
|
+
}
|
|
12
|
+
export declare function NarrativeTrace({ narrative, revealedCount, defaultCollapsed, onStageClick, size, unstyled, className, style, }: NarrativeTraceProps): import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
//# sourceMappingURL=NarrativeTrace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NarrativeTrace.d.ts","sourceRoot":"","sources":["../../../src/components/NarrativeTrace/NarrativeTrace.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAatD,MAAM,WAAW,mBAAoB,SAAQ,kBAAkB;IAC7D,uCAAuC;IACvC,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,oFAAoF;IACpF,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,sCAAsC;IACtC,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,6CAA6C;IAC7C,YAAY,CAAC,EAAE,CAAC,WAAW,EAAE,MAAM,KAAK,IAAI,CAAC;CAC9C;AA8BD,wBAAgB,cAAc,CAAC,EAC7B,SAAS,EACT,aAAa,EACb,gBAAwB,EACxB,YAAY,EACZ,IAAgB,EAChB,QAAgB,EAChB,SAAS,EACT,KAAK,GACN,EAAE,mBAAmB,2CAsMrB"}
|