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.
Files changed (161) hide show
  1. package/README.md +42 -3
  2. package/dist/adapters/fromRuntimeSnapshot.d.ts +52 -0
  3. package/dist/adapters/fromRuntimeSnapshot.d.ts.map +1 -0
  4. package/dist/adapters/fromRuntimeSnapshot.js +97 -0
  5. package/dist/adapters/fromRuntimeSnapshot.js.map +1 -0
  6. package/dist/components/ExplainableShell/ExplainableShell.d.ts +26 -0
  7. package/dist/components/ExplainableShell/ExplainableShell.d.ts.map +1 -0
  8. package/dist/components/ExplainableShell/ExplainableShell.js +94 -0
  9. package/dist/components/ExplainableShell/ExplainableShell.js.map +1 -0
  10. package/dist/components/ExplainableShell/index.d.ts +3 -0
  11. package/dist/components/ExplainableShell/index.d.ts.map +1 -0
  12. package/dist/components/ExplainableShell/index.js +2 -0
  13. package/dist/components/ExplainableShell/index.js.map +1 -0
  14. package/dist/components/FlowchartView/FlowchartView.d.ts +20 -0
  15. package/dist/components/FlowchartView/FlowchartView.d.ts.map +1 -0
  16. package/dist/components/FlowchartView/FlowchartView.js +80 -0
  17. package/dist/components/FlowchartView/FlowchartView.js.map +1 -0
  18. package/dist/components/FlowchartView/SubflowBreadcrumb.d.ts +11 -0
  19. package/dist/components/FlowchartView/SubflowBreadcrumb.d.ts.map +1 -0
  20. package/dist/components/FlowchartView/SubflowBreadcrumb.js +49 -0
  21. package/dist/components/FlowchartView/SubflowBreadcrumb.js.map +1 -0
  22. package/dist/components/FlowchartView/SubflowTree.d.ts +36 -0
  23. package/dist/components/FlowchartView/SubflowTree.d.ts.map +1 -0
  24. package/dist/components/FlowchartView/SubflowTree.js +143 -0
  25. package/dist/components/FlowchartView/SubflowTree.js.map +1 -0
  26. package/dist/components/FlowchartView/TracedFlowchartView.d.ts +20 -0
  27. package/dist/components/FlowchartView/TracedFlowchartView.d.ts.map +1 -0
  28. package/dist/components/FlowchartView/TracedFlowchartView.js +101 -0
  29. package/dist/components/FlowchartView/TracedFlowchartView.js.map +1 -0
  30. package/dist/components/FlowchartView/index.d.ts +11 -0
  31. package/dist/components/FlowchartView/index.d.ts.map +1 -0
  32. package/dist/components/FlowchartView/index.js +6 -0
  33. package/dist/components/FlowchartView/index.js.map +1 -0
  34. package/dist/components/FlowchartView/specToReactFlow.d.ts +56 -0
  35. package/dist/components/FlowchartView/specToReactFlow.d.ts.map +1 -0
  36. package/dist/components/FlowchartView/specToReactFlow.js +202 -0
  37. package/dist/components/FlowchartView/specToReactFlow.js.map +1 -0
  38. package/dist/components/FlowchartView/useSubflowNavigation.d.ts +35 -0
  39. package/dist/components/FlowchartView/useSubflowNavigation.d.ts.map +1 -0
  40. package/dist/components/FlowchartView/useSubflowNavigation.js +80 -0
  41. package/dist/components/FlowchartView/useSubflowNavigation.js.map +1 -0
  42. package/dist/components/GanttTimeline/GanttTimeline.d.ts +18 -0
  43. package/dist/components/GanttTimeline/GanttTimeline.d.ts.map +1 -0
  44. package/dist/components/GanttTimeline/GanttTimeline.js +123 -0
  45. package/dist/components/GanttTimeline/GanttTimeline.js.map +1 -0
  46. package/dist/components/GanttTimeline/index.d.ts +3 -0
  47. package/dist/components/GanttTimeline/index.d.ts.map +1 -0
  48. package/dist/components/GanttTimeline/index.js +2 -0
  49. package/dist/components/GanttTimeline/index.js.map +1 -0
  50. package/dist/components/MemoryInspector/MemoryInspector.d.ts +19 -0
  51. package/dist/components/MemoryInspector/MemoryInspector.d.ts.map +1 -0
  52. package/dist/components/MemoryInspector/MemoryInspector.js +95 -0
  53. package/dist/components/MemoryInspector/MemoryInspector.js.map +1 -0
  54. package/dist/components/MemoryInspector/index.d.ts +3 -0
  55. package/dist/components/MemoryInspector/index.d.ts.map +1 -0
  56. package/dist/components/MemoryInspector/index.js +2 -0
  57. package/dist/components/MemoryInspector/index.js.map +1 -0
  58. package/dist/components/NarrativeLog/NarrativeLog.d.ts +15 -0
  59. package/dist/components/NarrativeLog/NarrativeLog.d.ts.map +1 -0
  60. package/dist/components/NarrativeLog/NarrativeLog.js +65 -0
  61. package/dist/components/NarrativeLog/NarrativeLog.js.map +1 -0
  62. package/dist/components/NarrativeLog/index.d.ts +3 -0
  63. package/dist/components/NarrativeLog/index.d.ts.map +1 -0
  64. package/dist/components/NarrativeLog/index.js +2 -0
  65. package/dist/components/NarrativeLog/index.js.map +1 -0
  66. package/dist/components/NarrativeTrace/NarrativeTrace.d.ts +13 -0
  67. package/dist/components/NarrativeTrace/NarrativeTrace.d.ts.map +1 -0
  68. package/dist/components/NarrativeTrace/NarrativeTrace.js +127 -0
  69. package/dist/components/NarrativeTrace/NarrativeTrace.js.map +1 -0
  70. package/dist/components/NarrativeTrace/index.d.ts +3 -0
  71. package/dist/components/NarrativeTrace/index.d.ts.map +1 -0
  72. package/dist/components/NarrativeTrace/index.js +2 -0
  73. package/dist/components/NarrativeTrace/index.js.map +1 -0
  74. package/dist/components/ResultPanel/ResultPanel.d.ts +11 -0
  75. package/dist/components/ResultPanel/ResultPanel.d.ts.map +1 -0
  76. package/dist/components/ResultPanel/ResultPanel.js +54 -0
  77. package/dist/components/ResultPanel/ResultPanel.js.map +1 -0
  78. package/dist/components/ResultPanel/index.d.ts +3 -0
  79. package/dist/components/ResultPanel/index.d.ts.map +1 -0
  80. package/dist/components/ResultPanel/index.js +2 -0
  81. package/dist/components/ResultPanel/index.js.map +1 -0
  82. package/dist/components/ScopeDiff/ScopeDiff.d.ts +17 -0
  83. package/dist/components/ScopeDiff/ScopeDiff.d.ts.map +1 -0
  84. package/dist/components/ScopeDiff/ScopeDiff.js +87 -0
  85. package/dist/components/ScopeDiff/ScopeDiff.js.map +1 -0
  86. package/dist/components/ScopeDiff/index.d.ts +3 -0
  87. package/dist/components/ScopeDiff/index.d.ts.map +1 -0
  88. package/dist/components/ScopeDiff/index.js +2 -0
  89. package/dist/components/ScopeDiff/index.js.map +1 -0
  90. package/dist/components/SnapshotPanel/SnapshotPanel.d.ts +17 -0
  91. package/dist/components/SnapshotPanel/SnapshotPanel.d.ts.map +1 -0
  92. package/dist/components/SnapshotPanel/SnapshotPanel.js +85 -0
  93. package/dist/components/SnapshotPanel/SnapshotPanel.js.map +1 -0
  94. package/dist/components/SnapshotPanel/index.d.ts +3 -0
  95. package/dist/components/SnapshotPanel/index.d.ts.map +1 -0
  96. package/dist/components/SnapshotPanel/index.js +2 -0
  97. package/dist/components/SnapshotPanel/index.js.map +1 -0
  98. package/dist/components/StageNode/StageNode.d.ts +31 -0
  99. package/dist/components/StageNode/StageNode.d.ts.map +1 -0
  100. package/dist/components/StageNode/StageNode.js +134 -0
  101. package/dist/components/StageNode/StageNode.js.map +1 -0
  102. package/dist/components/StageNode/index.d.ts +3 -0
  103. package/dist/components/StageNode/index.d.ts.map +1 -0
  104. package/dist/components/StageNode/index.js +2 -0
  105. package/dist/components/StageNode/index.js.map +1 -0
  106. package/dist/components/TimeTravelControls/TimeTravelControls.d.ts +13 -0
  107. package/dist/components/TimeTravelControls/TimeTravelControls.d.ts.map +1 -0
  108. package/dist/components/TimeTravelControls/TimeTravelControls.js +104 -0
  109. package/dist/components/TimeTravelControls/TimeTravelControls.js.map +1 -0
  110. package/dist/components/TimeTravelControls/index.d.ts +3 -0
  111. package/dist/components/TimeTravelControls/index.d.ts.map +1 -0
  112. package/dist/components/TimeTravelControls/index.js +2 -0
  113. package/dist/components/TimeTravelControls/index.js.map +1 -0
  114. package/dist/components/TimeTravelDebugger/TimeTravelDebugger.d.ts +22 -0
  115. package/dist/components/TimeTravelDebugger/TimeTravelDebugger.d.ts.map +1 -0
  116. package/dist/components/TimeTravelDebugger/TimeTravelDebugger.js +104 -0
  117. package/dist/components/TimeTravelDebugger/TimeTravelDebugger.js.map +1 -0
  118. package/dist/components/TimeTravelDebugger/index.d.ts +3 -0
  119. package/dist/components/TimeTravelDebugger/index.d.ts.map +1 -0
  120. package/dist/components/TimeTravelDebugger/index.js +2 -0
  121. package/dist/components/TimeTravelDebugger/index.js.map +1 -0
  122. package/dist/flowchart.cjs +704 -220
  123. package/dist/flowchart.cjs.map +1 -1
  124. package/dist/flowchart.d.cts +55 -1
  125. package/dist/flowchart.d.ts +55 -1
  126. package/dist/flowchart.d.ts.map +1 -0
  127. package/dist/flowchart.js +700 -214
  128. package/dist/flowchart.js.map +1 -1
  129. package/dist/index.cjs +849 -76
  130. package/dist/index.cjs.map +1 -1
  131. package/dist/index.d.cts +95 -3
  132. package/dist/index.d.ts +95 -3
  133. package/dist/index.d.ts.map +1 -0
  134. package/dist/index.js +851 -80
  135. package/dist/index.js.map +1 -1
  136. package/dist/theme/ThemeProvider.d.ts +13 -0
  137. package/dist/theme/ThemeProvider.d.ts.map +1 -0
  138. package/dist/theme/ThemeProvider.js +16 -0
  139. package/dist/theme/ThemeProvider.js.map +1 -0
  140. package/dist/theme/index.d.ts +7 -0
  141. package/dist/theme/index.d.ts.map +1 -0
  142. package/dist/theme/index.js +5 -0
  143. package/dist/theme/index.js.map +1 -0
  144. package/dist/theme/presets.d.ts +15 -0
  145. package/dist/theme/presets.d.ts.map +1 -0
  146. package/dist/theme/presets.js +70 -0
  147. package/dist/theme/presets.js.map +1 -0
  148. package/dist/theme/styles.d.ts +32 -0
  149. package/dist/theme/styles.d.ts.map +1 -0
  150. package/dist/theme/styles.js +37 -0
  151. package/dist/theme/styles.js.map +1 -0
  152. package/dist/theme/tokens.d.ts +28 -0
  153. package/dist/theme/tokens.d.ts.map +1 -0
  154. package/dist/theme/tokens.js +58 -0
  155. package/dist/theme/tokens.js.map +1 -0
  156. package/dist/tsconfig.tsbuildinfo +1 -0
  157. package/dist/types.d.ts +35 -0
  158. package/dist/types.d.ts.map +1 -0
  159. package/dist/types.js +2 -0
  160. package/dist/types.js.map +1 -0
  161. 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":"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"}
@@ -0,0 +1,3 @@
1
+ export { GanttTimeline } from "./GanttTimeline";
2
+ export type { GanttTimelineProps } from "./GanttTimeline";
3
+ //# sourceMappingURL=index.d.ts.map
@@ -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,2 @@
1
+ export { GanttTimeline } from "./GanttTimeline";
2
+ //# sourceMappingURL=index.js.map
@@ -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,3 @@
1
+ export { MemoryInspector } from "./MemoryInspector";
2
+ export type { MemoryInspectorProps } from "./MemoryInspector";
3
+ //# sourceMappingURL=index.d.ts.map
@@ -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,2 @@
1
+ export { MemoryInspector } from "./MemoryInspector";
2
+ //# sourceMappingURL=index.js.map
@@ -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,3 @@
1
+ export { NarrativeLog } from "./NarrativeLog";
2
+ export type { NarrativeLogProps } from "./NarrativeLog";
3
+ //# sourceMappingURL=index.d.ts.map
@@ -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,2 @@
1
+ export { NarrativeLog } from "./NarrativeLog";
2
+ //# sourceMappingURL=index.js.map
@@ -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"}