@workflow/web-shared 4.0.1-beta.9 → 4.1.0-beta.46

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 (137) hide show
  1. package/README.md +2 -0
  2. package/dist/api/workflow-api-client.d.ts +325 -85
  3. package/dist/api/workflow-api-client.d.ts.map +1 -1
  4. package/dist/api/workflow-api-client.js +370 -214
  5. package/dist/api/workflow-api-client.js.map +1 -1
  6. package/dist/api/workflow-server-actions.d.ts +136 -3
  7. package/dist/api/workflow-server-actions.d.ts.map +1 -1
  8. package/dist/api/workflow-server-actions.js +649 -116
  9. package/dist/api/workflow-server-actions.js.map +1 -1
  10. package/dist/components/ui/card.d.ts +9 -0
  11. package/dist/components/ui/card.d.ts.map +1 -0
  12. package/dist/components/ui/card.js +18 -0
  13. package/dist/components/ui/card.js.map +1 -0
  14. package/dist/components/ui/error-card.d.ts +15 -0
  15. package/dist/components/ui/error-card.d.ts.map +1 -0
  16. package/dist/components/ui/error-card.js +14 -0
  17. package/dist/components/ui/error-card.js.map +1 -0
  18. package/dist/components/ui/skeleton.d.ts +3 -0
  19. package/dist/components/ui/skeleton.d.ts.map +1 -0
  20. package/dist/components/ui/skeleton.js +7 -0
  21. package/dist/components/ui/skeleton.js.map +1 -0
  22. package/dist/error-boundary.d.ts +28 -0
  23. package/dist/error-boundary.d.ts.map +1 -0
  24. package/dist/error-boundary.js +51 -0
  25. package/dist/error-boundary.js.map +1 -0
  26. package/dist/event-list-view.d.ts +13 -0
  27. package/dist/event-list-view.d.ts.map +1 -0
  28. package/dist/event-list-view.js +183 -0
  29. package/dist/event-list-view.js.map +1 -0
  30. package/dist/hook-actions.d.ts +59 -0
  31. package/dist/hook-actions.d.ts.map +1 -0
  32. package/dist/hook-actions.js +76 -0
  33. package/dist/hook-actions.js.map +1 -0
  34. package/dist/hooks/use-dark-mode.d.ts +9 -0
  35. package/dist/hooks/use-dark-mode.d.ts.map +1 -0
  36. package/dist/hooks/use-dark-mode.js +30 -0
  37. package/dist/hooks/use-dark-mode.js.map +1 -0
  38. package/dist/index.d.ts +14 -1
  39. package/dist/index.d.ts.map +1 -1
  40. package/dist/index.js +9 -1
  41. package/dist/index.js.map +1 -1
  42. package/dist/lib/event-analysis.d.ts +55 -0
  43. package/dist/lib/event-analysis.d.ts.map +1 -0
  44. package/dist/lib/event-analysis.js +161 -0
  45. package/dist/lib/event-analysis.js.map +1 -0
  46. package/dist/lib/utils.d.ts +44 -0
  47. package/dist/lib/utils.d.ts.map +1 -1
  48. package/dist/lib/utils.js +109 -0
  49. package/dist/lib/utils.js.map +1 -1
  50. package/dist/run-trace-view.d.ts.map +1 -1
  51. package/dist/run-trace-view.js +1 -1
  52. package/dist/run-trace-view.js.map +1 -1
  53. package/dist/sidebar/attribute-panel.d.ts +12 -2
  54. package/dist/sidebar/attribute-panel.d.ts.map +1 -1
  55. package/dist/sidebar/attribute-panel.js +368 -23
  56. package/dist/sidebar/attribute-panel.js.map +1 -1
  57. package/dist/sidebar/conversation-view.d.ts +7 -0
  58. package/dist/sidebar/conversation-view.d.ts.map +1 -0
  59. package/dist/sidebar/conversation-view.js +125 -0
  60. package/dist/sidebar/conversation-view.js.map +1 -0
  61. package/dist/sidebar/detail-card.d.ts.map +1 -1
  62. package/dist/sidebar/detail-card.js +2 -2
  63. package/dist/sidebar/detail-card.js.map +1 -1
  64. package/dist/sidebar/entity-detail-panel.d.ts +12 -0
  65. package/dist/sidebar/entity-detail-panel.d.ts.map +1 -0
  66. package/dist/sidebar/entity-detail-panel.js +190 -0
  67. package/dist/sidebar/entity-detail-panel.js.map +1 -0
  68. package/dist/sidebar/events-list.d.ts +2 -1
  69. package/dist/sidebar/events-list.d.ts.map +1 -1
  70. package/dist/sidebar/events-list.js +11 -10
  71. package/dist/sidebar/events-list.js.map +1 -1
  72. package/dist/sidebar/resolve-hook-modal.d.ts +16 -0
  73. package/dist/sidebar/resolve-hook-modal.d.ts.map +1 -0
  74. package/dist/sidebar/resolve-hook-modal.js +74 -0
  75. package/dist/sidebar/resolve-hook-modal.js.map +1 -0
  76. package/dist/stream-viewer.d.ts +13 -0
  77. package/dist/stream-viewer.d.ts.map +1 -0
  78. package/dist/stream-viewer.js +109 -0
  79. package/dist/stream-viewer.js.map +1 -0
  80. package/dist/trace-viewer/components/markers.d.ts.map +1 -1
  81. package/dist/trace-viewer/components/markers.js +3 -2
  82. package/dist/trace-viewer/components/markers.js.map +1 -1
  83. package/dist/trace-viewer/components/node.d.ts.map +1 -1
  84. package/dist/trace-viewer/components/node.js +1 -0
  85. package/dist/trace-viewer/components/node.js.map +1 -1
  86. package/dist/trace-viewer/components/search.d.ts.map +1 -1
  87. package/dist/trace-viewer/components/search.js +1 -0
  88. package/dist/trace-viewer/components/search.js.map +1 -1
  89. package/dist/trace-viewer/components/span-detail-panel.js +2 -2
  90. package/dist/trace-viewer/components/span-detail-panel.js.map +1 -1
  91. package/dist/trace-viewer/context.d.ts.map +1 -1
  92. package/dist/trace-viewer/context.js +1 -0
  93. package/dist/trace-viewer/context.js.map +1 -1
  94. package/dist/trace-viewer/trace-viewer.module.css +47 -30
  95. package/dist/trace-viewer/types.d.ts +11 -0
  96. package/dist/trace-viewer/types.d.ts.map +1 -1
  97. package/dist/trace-viewer/util/timing.d.ts +7 -1
  98. package/dist/trace-viewer/util/timing.d.ts.map +1 -1
  99. package/dist/trace-viewer/util/timing.js +7 -12
  100. package/dist/trace-viewer/util/timing.js.map +1 -1
  101. package/dist/trace-viewer/util/tree.d.ts.map +1 -1
  102. package/dist/trace-viewer/util/tree.js +4 -0
  103. package/dist/trace-viewer/util/tree.js.map +1 -1
  104. package/dist/trace-viewer/util/use-immediate-style.d.ts.map +1 -1
  105. package/dist/trace-viewer/util/use-immediate-style.js +1 -0
  106. package/dist/trace-viewer/util/use-immediate-style.js.map +1 -1
  107. package/dist/trace-viewer/util/use-streaming-spans.d.ts.map +1 -1
  108. package/dist/trace-viewer/util/use-streaming-spans.js +2 -1
  109. package/dist/trace-viewer/util/use-streaming-spans.js.map +1 -1
  110. package/dist/trace-viewer/util/use-trackpad-zoom.d.ts.map +1 -1
  111. package/dist/trace-viewer/util/use-trackpad-zoom.js +1 -0
  112. package/dist/trace-viewer/util/use-trackpad-zoom.js.map +1 -1
  113. package/dist/trace-viewer/worker.js +1 -1
  114. package/dist/trace-viewer/worker.js.map +1 -1
  115. package/dist/workflow-trace-view.d.ts +3 -1
  116. package/dist/workflow-trace-view.d.ts.map +1 -1
  117. package/dist/workflow-trace-view.js +28 -11
  118. package/dist/workflow-trace-view.js.map +1 -1
  119. package/dist/workflow-traces/event-colors.d.ts +1 -1
  120. package/dist/workflow-traces/event-colors.js +2 -2
  121. package/dist/workflow-traces/event-colors.js.map +1 -1
  122. package/dist/workflow-traces/trace-colors.d.ts.map +1 -1
  123. package/dist/workflow-traces/trace-colors.js +1 -3
  124. package/dist/workflow-traces/trace-colors.js.map +1 -1
  125. package/dist/workflow-traces/trace-span-construction.d.ts +18 -3
  126. package/dist/workflow-traces/trace-span-construction.d.ts.map +1 -1
  127. package/dist/workflow-traces/trace-span-construction.js +84 -31
  128. package/dist/workflow-traces/trace-span-construction.js.map +1 -1
  129. package/dist/workflow-traces/trace-time-utils.d.ts +2 -2
  130. package/dist/workflow-traces/trace-time-utils.d.ts.map +1 -1
  131. package/dist/workflow-traces/trace-time-utils.js +9 -0
  132. package/dist/workflow-traces/trace-time-utils.js.map +1 -1
  133. package/package.json +24 -14
  134. package/dist/sidebar/workflow-detail-panel.d.ts +0 -8
  135. package/dist/sidebar/workflow-detail-panel.d.ts.map +0 -1
  136. package/dist/sidebar/workflow-detail-panel.js +0 -56
  137. package/dist/sidebar/workflow-detail-panel.js.map +0 -1
@@ -0,0 +1,125 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Streamdown } from 'streamdown';
3
+ export function ConversationView({ messages }) {
4
+ if (messages.length === 0) {
5
+ return (_jsx("div", { className: "text-center py-8 text-[11px]", style: { color: 'var(--ds-gray-600)' }, children: "No messages" }));
6
+ }
7
+ return (_jsx("div", { className: "flex flex-col gap-3 p-3", children: messages.map((message, index) => (_jsx(MessageBubble, { message: message }, index))) }));
8
+ }
9
+ function MessageBubble({ message }) {
10
+ const role = message.role;
11
+ const parts = parseContent(message.content);
12
+ const style = getRoleStyle(role);
13
+ return (_jsxs("div", { className: "rounded-md border text-[11px]", style: {
14
+ backgroundColor: style.bg,
15
+ borderColor: style.border,
16
+ }, children: [_jsx("div", { className: "px-2.5 py-1 border-b text-[10px] font-medium uppercase tracking-wide", style: {
17
+ borderColor: style.border,
18
+ color: style.label,
19
+ }, children: role }), _jsx("div", { className: "px-2.5 py-2 space-y-2", children: parts.map((part, i) => (_jsx(ContentPart, { part: part, role: role }, i))) })] }));
20
+ }
21
+ function ContentPart({ part, role }) {
22
+ if (part.type === 'text') {
23
+ if (!part.text)
24
+ return null;
25
+ // Use Streamdown for assistant messages (they often contain markdown)
26
+ if (role === 'assistant') {
27
+ return (_jsx("div", { className: "prose prose-sm max-w-none text-[11px] [&>*:first-child]:mt-0 [&>*:last-child]:mb-0", style: { color: 'var(--ds-gray-1000)' }, children: _jsx(Streamdown, { children: part.text }) }));
28
+ }
29
+ return (_jsx("div", { className: "whitespace-pre-wrap break-words", style: { color: 'var(--ds-gray-1000)' }, children: part.text }));
30
+ }
31
+ if (part.type === 'tool-call') {
32
+ return (_jsxs("div", { className: "rounded border px-2 py-1.5", style: {
33
+ backgroundColor: 'var(--ds-purple-100)',
34
+ borderColor: 'var(--ds-purple-300)',
35
+ }, children: [_jsxs("div", { className: "flex items-center gap-1.5 text-[10px] font-medium", children: [_jsx("span", { children: "\uD83D\uDD27" }), _jsx("span", { style: { color: 'var(--ds-purple-900)' }, children: part.toolName })] }), part.input != null && (_jsx("pre", { className: "mt-1.5 text-[10px] overflow-x-auto p-1.5 rounded", style: {
36
+ backgroundColor: 'var(--ds-gray-100)',
37
+ color: 'var(--ds-gray-800)',
38
+ }, children: typeof part.input === 'string'
39
+ ? part.input
40
+ : JSON.stringify(part.input, null, 2) }))] }));
41
+ }
42
+ if (part.type === 'tool-result') {
43
+ const outputText = formatOutput(part.output);
44
+ return (_jsxs("div", { className: "rounded border px-2 py-1.5", style: {
45
+ backgroundColor: 'var(--ds-green-100)',
46
+ borderColor: 'var(--ds-green-300)',
47
+ }, children: [_jsxs("div", { className: "flex items-center gap-1.5 text-[10px] font-medium", children: [_jsx("span", { children: "\u2713" }), _jsxs("span", { style: { color: 'var(--ds-green-900)' }, children: [part.toolName, " result"] })] }), outputText && (_jsx("pre", { className: "mt-1.5 text-[10px] overflow-x-auto max-h-[80px] p-1.5 rounded", style: {
48
+ backgroundColor: 'var(--ds-gray-100)',
49
+ color: 'var(--ds-gray-800)',
50
+ }, children: outputText }))] }));
51
+ }
52
+ return null;
53
+ }
54
+ function getRoleStyle(role) {
55
+ switch (role) {
56
+ case 'user':
57
+ return {
58
+ bg: 'var(--ds-blue-100)',
59
+ border: 'var(--ds-blue-300)',
60
+ label: 'var(--ds-blue-700)',
61
+ };
62
+ case 'assistant':
63
+ return {
64
+ bg: 'var(--ds-gray-100)',
65
+ border: 'var(--ds-gray-300)',
66
+ label: 'var(--ds-gray-700)',
67
+ };
68
+ case 'system':
69
+ return {
70
+ bg: 'var(--ds-amber-100)',
71
+ border: 'var(--ds-amber-300)',
72
+ label: 'var(--ds-amber-700)',
73
+ };
74
+ case 'tool':
75
+ return {
76
+ bg: 'var(--ds-green-50)',
77
+ border: 'var(--ds-green-300)',
78
+ label: 'var(--ds-green-700)',
79
+ };
80
+ default:
81
+ return {
82
+ bg: 'var(--ds-gray-100)',
83
+ border: 'var(--ds-gray-300)',
84
+ label: 'var(--ds-gray-700)',
85
+ };
86
+ }
87
+ }
88
+ function parseContent(content) {
89
+ if (typeof content === 'string') {
90
+ return [{ type: 'text', text: content }];
91
+ }
92
+ if (Array.isArray(content)) {
93
+ return content.map((part) => {
94
+ if (typeof part === 'string') {
95
+ return { type: 'text', text: part };
96
+ }
97
+ if (part?.type === 'text') {
98
+ return { type: 'text', text: String(part.text ?? '') };
99
+ }
100
+ if (part?.type === 'tool-call') {
101
+ return {
102
+ type: 'tool-call',
103
+ toolName: part.toolName,
104
+ input: part.input,
105
+ };
106
+ }
107
+ if (part?.type === 'tool-result') {
108
+ return {
109
+ type: 'tool-result',
110
+ toolName: part.toolName,
111
+ output: part.output,
112
+ };
113
+ }
114
+ return { type: 'text', text: '' };
115
+ });
116
+ }
117
+ return [];
118
+ }
119
+ function formatOutput(output) {
120
+ if (output == null)
121
+ return null;
122
+ const text = typeof output === 'string' ? output : JSON.stringify(output, null, 2);
123
+ return text.length > 500 ? `${text.slice(0, 500)}...` : text;
124
+ }
125
+ //# sourceMappingURL=conversation-view.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"conversation-view.js","sourceRoot":"","sources":["../../src/sidebar/conversation-view.tsx"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"detail-card.d.ts","sourceRoot":"","sources":["../../src/sidebar/detail-card.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,wBAAgB,UAAU,CAAC,EACzB,OAAO,EACP,QAAQ,GACT,EAAE;IACD,OAAO,EAAE,SAAS,CAAC;IACnB,QAAQ,CAAC,EAAE,SAAS,CAAC;CACtB,2CAgBA"}
1
+ {"version":3,"file":"detail-card.d.ts","sourceRoot":"","sources":["../../src/sidebar/detail-card.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,wBAAgB,UAAU,CAAC,EACzB,OAAO,EACP,QAAQ,GACT,EAAE;IACD,OAAO,EAAE,SAAS,CAAC;IACnB,QAAQ,CAAC,EAAE,SAAS,CAAC;CACtB,2CAkCA"}
@@ -1,9 +1,9 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  export function DetailCard({ summary, children, }) {
3
- return (_jsxs("details", { className: "group", children: [_jsx("summary", { className: "cursor-pointer rounded-md border px-3 py-2 text-copy-14 hover:brightness-95", style: {
3
+ return (_jsxs("details", { className: "group", children: [_jsx("summary", { className: "cursor-pointer rounded-md border px-2.5 py-1.5 text-xs hover:brightness-95", style: {
4
4
  borderColor: 'var(--ds-gray-300)',
5
5
  backgroundColor: 'var(--ds-gray-100)',
6
6
  color: 'var(--ds-gray-900)',
7
- }, children: summary }), _jsx("div", { className: "p-2", children: children })] }));
7
+ }, children: summary }), _jsxs("div", { className: "relative pl-6 mt-3", children: [_jsx("div", { className: "absolute left-3 -top-3 w-px h-3", style: { backgroundColor: 'var(--ds-gray-400)' } }), _jsx("div", { className: "absolute left-3 top-0 w-3 h-3 border-l border-b rounded-bl-lg", style: { borderColor: 'var(--ds-gray-400)' } }), _jsx("div", { className: "absolute left-6 top-3 w-0 h-px -translate-y-px", style: { backgroundColor: 'var(--ds-gray-400)' } }), _jsx("div", { children: children })] })] }));
8
8
  }
9
9
  //# sourceMappingURL=detail-card.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"detail-card.js","sourceRoot":"","sources":["../../src/sidebar/detail-card.tsx"],"names":[],"mappings":";AAEA,MAAM,UAAU,UAAU,CAAC,EACzB,OAAO,EACP,QAAQ,GAIT;IACC,OAAO,CACL,mBAAS,SAAS,EAAC,OAAO,aACxB,kBACE,SAAS,EAAC,6EAA6E,EACvF,KAAK,EAAE;oBACL,WAAW,EAAE,oBAAoB;oBACjC,eAAe,EAAE,oBAAoB;oBACrC,KAAK,EAAE,oBAAoB;iBAC5B,YAEA,OAAO,GACA,EACV,cAAK,SAAS,EAAC,KAAK,YAAE,QAAQ,GAAO,IAC7B,CACX,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"detail-card.js","sourceRoot":"","sources":["../../src/sidebar/detail-card.tsx"],"names":[],"mappings":";AAEA,MAAM,UAAU,UAAU,CAAC,EACzB,OAAO,EACP,QAAQ,GAIT;IACC,OAAO,CACL,mBAAS,SAAS,EAAC,OAAO,aACxB,kBACE,SAAS,EAAC,4EAA4E,EACtF,KAAK,EAAE;oBACL,WAAW,EAAE,oBAAoB;oBACjC,eAAe,EAAE,oBAAoB;oBACrC,KAAK,EAAE,oBAAoB;iBAC5B,YAEA,OAAO,GACA,EAEV,eAAK,SAAS,EAAC,oBAAoB,aAEjC,cACE,SAAS,EAAC,iCAAiC,EAC3C,KAAK,EAAE,EAAE,eAAe,EAAE,oBAAoB,EAAE,GAChD,EAEF,cACE,SAAS,EAAC,+DAA+D,EACzE,KAAK,EAAE,EAAE,WAAW,EAAE,oBAAoB,EAAE,GAC5C,EAEF,cACE,SAAS,EAAC,gDAAgD,EAC1D,KAAK,EAAE,EAAE,eAAe,EAAE,oBAAoB,EAAE,GAChD,EACF,wBAAM,QAAQ,GAAO,IACjB,IACE,CACX,CAAC;AACJ,CAAC"}
@@ -0,0 +1,12 @@
1
+ import type { WorkflowRun } from '@workflow/world';
2
+ import { type EnvMap } from '../api/workflow-server-actions';
3
+ /**
4
+ * Custom panel component for workflow traces that displays entity details
5
+ */
6
+ export declare function EntityDetailPanel({ env, run, onStreamClick, }: {
7
+ env: EnvMap;
8
+ run: WorkflowRun;
9
+ /** Callback when a stream reference is clicked */
10
+ onStreamClick?: (streamId: string) => void;
11
+ }): React.JSX.Element | null;
12
+ //# sourceMappingURL=entity-detail-panel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"entity-detail-panel.d.ts","sourceRoot":"","sources":["../../src/sidebar/entity-detail-panel.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAqB,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAWtE,OAAO,EAAa,KAAK,MAAM,EAAE,MAAM,gCAAgC,CAAC;AAMxE;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,EAChC,GAAG,EACH,GAAG,EACH,aAAa,GACd,EAAE;IACD,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,WAAW,CAAC;IACjB,kDAAkD;IAClD,aAAa,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;CAC5C,GAAG,KAAK,CAAC,GAAG,CAAC,OAAO,GAAG,IAAI,CA2R3B"}
@@ -0,0 +1,190 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import clsx from 'clsx';
4
+ import { Send, Zap } from 'lucide-react';
5
+ import { useCallback, useEffect, useMemo, useState } from 'react';
6
+ import { toast } from 'sonner';
7
+ import { resumeHook, unwrapServerActionResult, useWorkflowResourceData, wakeUpRun, } from '../api/workflow-api-client';
8
+ import { fetchHook } from '../api/workflow-server-actions';
9
+ import { useTraceViewer } from '../trace-viewer';
10
+ import { AttributePanel } from './attribute-panel';
11
+ import { EventsList } from './events-list';
12
+ import { ResolveHookModal } from './resolve-hook-modal';
13
+ /**
14
+ * Custom panel component for workflow traces that displays entity details
15
+ */
16
+ export function EntityDetailPanel({ env, run, onStreamClick, }) {
17
+ const { state } = useTraceViewer();
18
+ const { selected } = state;
19
+ const [stoppingSleep, setStoppingSleep] = useState(false);
20
+ const [showResolveHookModal, setShowResolveHookModal] = useState(false);
21
+ const [resolvingHook, setResolvingHook] = useState(false);
22
+ const [resolvedHookToken, setResolvedHookToken] = useState(undefined);
23
+ const data = selected?.span.attributes?.data;
24
+ // Determine resource ID and runId (needed for steps)
25
+ const { resource, resourceId, runId } = useMemo(() => {
26
+ const resource = selected?.span.attributes?.resource;
27
+ if (resource === 'step') {
28
+ const step = data;
29
+ return { resource: 'step', resourceId: step.stepId, runId: step.runId };
30
+ }
31
+ else if (resource === 'run') {
32
+ const run = data;
33
+ return { resource: 'run', resourceId: run.runId, runId: undefined };
34
+ }
35
+ else if (resource === 'hook') {
36
+ const hook = data;
37
+ return { resource: 'hook', resourceId: hook.hookId, runId: undefined };
38
+ }
39
+ else if (resource === 'sleep') {
40
+ return {
41
+ resource: 'sleep',
42
+ resourceId: selected?.span?.spanId,
43
+ runId: undefined,
44
+ };
45
+ }
46
+ return { resource: undefined, resourceId: undefined, runId: undefined };
47
+ }, [selected, data]);
48
+ // Check if this sleep is still pending and can be woken up
49
+ // Requirements: no wait_completed event, resumeAt is in the future, run is not terminal
50
+ const spanEvents = selected?.span.events;
51
+ const spanEventsLength = spanEvents?.length ?? 0;
52
+ const canWakeUp = useMemo(() => {
53
+ void spanEventsLength; // Force dependency on length for reactivity
54
+ if (resource !== 'sleep' || !spanEvents)
55
+ return false;
56
+ // Check run is not in a terminal state
57
+ const terminalStates = ['completed', 'failed', 'cancelled'];
58
+ if (terminalStates.includes(run.status))
59
+ return false;
60
+ // Check if wait has already completed
61
+ const hasWaitCompleted = spanEvents.some((e) => e.name === 'wait_completed');
62
+ if (hasWaitCompleted)
63
+ return false;
64
+ // Check if resumeAt is in the future
65
+ const waitCreatedEvent = spanEvents.find((e) => e.name === 'wait_created');
66
+ const eventData = waitCreatedEvent?.attributes?.eventData;
67
+ const resumeAt = eventData?.resumeAt;
68
+ if (!resumeAt)
69
+ return false;
70
+ const resumeAtDate = new Date(resumeAt);
71
+ return resumeAtDate.getTime() > Date.now();
72
+ }, [resource, spanEvents, spanEventsLength, run.status]);
73
+ // Check if this hook can be resolved (not yet resolved, run is not terminal)
74
+ const canResolveHook = useMemo(() => {
75
+ void spanEventsLength; // Force dependency on length for reactivity
76
+ if (resource !== 'hook' || !spanEvents)
77
+ return false;
78
+ // Check run is not in a terminal state
79
+ const terminalStates = ['completed', 'failed', 'cancelled'];
80
+ if (terminalStates.includes(run.status))
81
+ return false;
82
+ // Check if hook has already been disposed
83
+ const hasHookDisposed = spanEvents.some((e) => e.name === 'hook_disposed');
84
+ if (hasHookDisposed)
85
+ return false;
86
+ // Hook can be resolved
87
+ return true;
88
+ }, [resource, spanEvents, spanEventsLength, run.status]);
89
+ // Fetch full resource data with events
90
+ const { data: fetchedData, error, loading, } = useWorkflowResourceData(env, resource, resourceId ?? '', { runId });
91
+ useEffect(() => {
92
+ if (resource !== 'hook' || !resourceId) {
93
+ setResolvedHookToken(undefined);
94
+ return;
95
+ }
96
+ let isMounted = true;
97
+ const fetchToken = async () => {
98
+ const { error, result } = await unwrapServerActionResult(fetchHook(env, resourceId));
99
+ if (!isMounted)
100
+ return;
101
+ if (error) {
102
+ console.error('Failed to fetch hook token:', error);
103
+ return;
104
+ }
105
+ setResolvedHookToken(result.token);
106
+ };
107
+ fetchToken();
108
+ return () => {
109
+ isMounted = false;
110
+ };
111
+ }, [env, resource, resourceId]);
112
+ // Get the hook token for resolving (prefer fetched data when available)
113
+ const hookToken = useMemo(() => {
114
+ if (resource !== 'hook')
115
+ return undefined;
116
+ if (resolvedHookToken)
117
+ return resolvedHookToken;
118
+ const hook = (fetchedData ?? data);
119
+ return hook?.token;
120
+ }, [resource, resolvedHookToken, fetchedData, data]);
121
+ useEffect(() => {
122
+ if (error && selected && resource) {
123
+ toast.error(`Failed to load ${resource} details`, {
124
+ description: error.message,
125
+ });
126
+ }
127
+ }, [error, resource, selected]);
128
+ const handleWakeUp = async () => {
129
+ if (stoppingSleep || !resourceId)
130
+ return;
131
+ try {
132
+ setStoppingSleep(true);
133
+ const result = await wakeUpRun(env, run.runId, {
134
+ correlationIds: [resourceId],
135
+ });
136
+ if (result.stoppedCount > 0) {
137
+ toast.success('Run woken up', {
138
+ description: 'The sleep call has been interrupted and the run woken up.',
139
+ });
140
+ }
141
+ else {
142
+ toast.info('Sleep already completed', {
143
+ description: 'This sleep call has already finished.',
144
+ });
145
+ }
146
+ }
147
+ catch (err) {
148
+ console.error('Failed to wake up run:', err);
149
+ toast.error('Failed to wake up run', {
150
+ description: err instanceof Error ? err.message : 'An unknown error occurred',
151
+ });
152
+ }
153
+ finally {
154
+ setStoppingSleep(false);
155
+ }
156
+ };
157
+ const handleResolveHook = useCallback(async (payload) => {
158
+ if (resolvingHook)
159
+ return;
160
+ if (!hookToken) {
161
+ toast.error('Unable to resolve hook', {
162
+ description: 'Missing hook token. Try refreshing the run data and retry.',
163
+ });
164
+ return;
165
+ }
166
+ try {
167
+ setResolvingHook(true);
168
+ await resumeHook(env, hookToken, payload);
169
+ toast.success('Hook resolved', {
170
+ description: 'The payload has been sent and the hook resolved.',
171
+ });
172
+ setShowResolveHookModal(false);
173
+ }
174
+ catch (err) {
175
+ console.error('Failed to resolve hook:', err);
176
+ toast.error('Failed to resolve hook', {
177
+ description: err instanceof Error ? err.message : 'An unknown error occurred',
178
+ });
179
+ }
180
+ finally {
181
+ setResolvingHook(false);
182
+ }
183
+ }, [env, hookToken, resolvingHook]);
184
+ if (!selected || !resource || !resourceId) {
185
+ return null;
186
+ }
187
+ const displayData = fetchedData || data;
188
+ return (_jsxs("div", { className: clsx('flex flex-col px-2'), children: [resource === 'sleep' && canWakeUp && (_jsxs("div", { className: "mb-3 pb-3 border-b border-gray-200 dark:border-gray-700", children: [_jsxs("button", { type: "button", onClick: handleWakeUp, disabled: stoppingSleep, className: clsx('flex items-center gap-2 px-3 py-2 text-sm font-medium rounded-md w-full', 'bg-amber-100 dark:bg-amber-900/30 text-amber-800 dark:text-amber-200', 'hover:bg-amber-200 dark:hover:bg-amber-900/50', 'disabled:opacity-50 disabled:cursor-not-allowed', 'transition-colors', stoppingSleep ? 'opacity-50 cursor-not-allowed' : 'cursor-pointer'), children: [_jsx(Zap, { className: "h-4 w-4" }), stoppingSleep ? 'Waking up...' : 'Wake up'] }), _jsx("p", { className: "mt-1.5 text-xs text-gray-500 dark:text-gray-400", children: "Interrupt this sleep call and wake up the run." })] })), resource === 'hook' && canResolveHook && (_jsxs("div", { className: "mb-3 pb-3 border-b border-gray-200 dark:border-gray-700", children: [_jsxs("button", { type: "button", onClick: () => setShowResolveHookModal(true), disabled: resolvingHook, className: clsx('flex items-center gap-2 px-3 py-2 text-sm font-medium rounded-md w-full', 'bg-primary text-primary-foreground hover:bg-primary/90', 'disabled:opacity-50 disabled:cursor-not-allowed', 'transition-colors', resolvingHook ? 'opacity-50 cursor-not-allowed' : 'cursor-pointer'), children: [_jsx(Send, { className: "h-4 w-4" }), "Resolve Hook"] }), _jsx("p", { className: "mt-1.5 text-xs text-gray-500 dark:text-gray-400", children: "Send a JSON payload to resolve this hook." })] })), _jsx(ResolveHookModal, { isOpen: showResolveHookModal, onClose: () => setShowResolveHookModal(false), onSubmit: handleResolveHook, isSubmitting: resolvingHook }), _jsx(AttributePanel, { data: displayData, expiredAt: run.expiredAt, isLoading: loading, error: error ?? undefined, onStreamClick: onStreamClick }), resource !== 'run' && (_jsx(EventsList, { correlationId: resourceId, env: env, events: selected.span.events, expiredAt: run.expiredAt }))] }));
189
+ }
190
+ //# sourceMappingURL=entity-detail-panel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"entity-detail-panel.js","sourceRoot":"","sources":["../../src/sidebar/entity-detail-panel.tsx"],"names":[],"mappings":"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"}
@@ -1,8 +1,9 @@
1
1
  import { type EnvMap } from '../api/workflow-server-actions';
2
2
  import type { SpanEvent } from '../trace-viewer/types';
3
- export declare function EventsList({ correlationId, env, events, }: {
3
+ export declare function EventsList({ correlationId, env, events, expiredAt, }: {
4
4
  correlationId: string;
5
5
  env: EnvMap;
6
6
  events: SpanEvent[];
7
+ expiredAt?: string | Date;
7
8
  }): import("react/jsx-runtime").JSX.Element;
8
9
  //# sourceMappingURL=events-list.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"events-list.d.ts","sourceRoot":"","sources":["../../src/sidebar/events-list.tsx"],"names":[],"mappings":"AAKA,OAAO,EACL,KAAK,MAAM,EAEZ,MAAM,gCAAgC,CAAC;AAExC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAKvD,wBAAgB,UAAU,CAAC,EACzB,aAAa,EACb,GAAG,EACH,MAAM,GACP,EAAE;IACD,aAAa,EAAE,MAAM,CAAC;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,SAAS,EAAE,CAAC;CACrB,2CAkGA"}
1
+ {"version":3,"file":"events-list.d.ts","sourceRoot":"","sources":["../../src/sidebar/events-list.tsx"],"names":[],"mappings":"AAIA,OAAO,EACL,KAAK,MAAM,EAEZ,MAAM,gCAAgC,CAAC;AAExC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAKvD,wBAAgB,UAAU,CAAC,EACzB,aAAa,EACb,GAAG,EACH,MAAM,EACN,SAAS,GACV,EAAE;IACD,aAAa,EAAE,MAAM,CAAC;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,SAAS,EAAE,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC3B,2CA2HA"}
@@ -1,35 +1,36 @@
1
1
  'use client';
2
2
  import { jsxs as _jsxs, jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
3
- import { AlertCircle } from 'lucide-react';
4
3
  import { useCallback } from 'react';
5
4
  import useSWR from 'swr';
6
5
  import { fetchEventsByCorrelationId, } from '../api/workflow-server-actions';
7
- import { Alert, AlertDescription, AlertTitle } from '../components/ui/alert';
6
+ import { ErrorCard } from '../components/ui/error-card';
8
7
  import { convertEventsToSpanEvents } from '../workflow-traces/trace-span-construction';
9
- import { AttributeBlock } from './attribute-panel';
8
+ import { AttributeBlock, localMillisecondTime } from './attribute-panel';
10
9
  import { DetailCard } from './detail-card';
11
- export function EventsList({ correlationId, env, events, }) {
10
+ export function EventsList({ correlationId, env, events, expiredAt, }) {
11
+ const hasExpired = expiredAt != null && new Date(expiredAt) < new Date();
12
12
  const fetchEvents = useCallback(() => {
13
13
  return fetchEventsByCorrelationId(env, correlationId, {
14
14
  sortOrder: 'asc',
15
15
  limit: 100,
16
- withData: true,
16
+ withData: !hasExpired,
17
17
  }).then((evts) => {
18
18
  if (!evts.success) {
19
19
  throw new Error(evts.error?.message || 'Failed to fetch events');
20
20
  }
21
21
  return convertEventsToSpanEvents(evts.data.data || [], false);
22
22
  });
23
- }, [env, correlationId]);
23
+ }, [env, correlationId, hasExpired]);
24
24
  const { data, error: eventError, isLoading: eventsLoading, } = useSWR(['workflow', 'events', correlationId], fetchEvents, {
25
25
  fallbackData: events,
26
26
  revalidateOnFocus: false,
27
27
  });
28
28
  const displayData = (data?.length ? data : events) || [];
29
- return (_jsxs("div", { className: "mt-2", style: { color: 'var(--ds-gray-1000)' }, children: [_jsxs("h3", { className: "text-heading-16 font-medium mt-4 mb-2", style: { color: 'var(--ds-gray-1000)' }, children: ["Events (", eventsLoading ? '...' : displayData.length, ")"] }), eventError ? (_jsxs(Alert, { variant: "destructive", className: "my-4", children: [_jsx(AlertCircle, { className: "h-4 w-4" }), _jsx(AlertTitle, { children: "Failed to load event data" }), _jsx(AlertDescription, { className: "text-sm", children: eventError.message })] })) : null, eventsLoading ? _jsx("div", { children: "Loading events..." }) : null, !eventsLoading && !eventError && displayData.length === 0 && (_jsx("div", { className: "text-sm", children: "No events found" })), displayData.length > 0 && !eventError ? (_jsx("div", { className: "flex flex-col gap-2", children: displayData.map((event, index) => (_jsx(DetailCard, { summary: _jsxs(_Fragment, { children: [_jsx("span", { className: "font-medium", style: { color: 'var(--ds-gray-1000)' }, children: event.name }), ' ', "-", ' ', _jsx("span", { style: { color: 'var(--ds-gray-700)' }, children: new Date(event.timestamp[0] * 1000 + event.timestamp[1] / 1e6).toLocaleString() })] }), children: _jsxs("div", { className: "mt-2 px-4", children: [Object.entries(event.attributes)
29
+ return (_jsxs("div", { className: "mt-2", style: { color: 'var(--ds-gray-1000)' }, children: [_jsxs("h3", { className: "text-heading-16 font-medium mt-4 mb-2", style: { color: 'var(--ds-gray-1000)' }, children: ["Events ", !eventsLoading && `(${displayData.length})`] }), eventError ? (_jsx(ErrorCard, { title: "Failed to load full event list", details: eventError?.message, className: "my-4" })) : null, eventsLoading ? _jsx("div", { children: "Loading events..." }) : null, !eventsLoading && !eventError && displayData.length === 0 && (_jsx("div", { className: "text-sm", children: "No events found" })), displayData.length > 0 && !eventError ? (_jsx("div", { className: "flex flex-col gap-2", children: displayData.map((event, index) => (_jsxs(DetailCard, { summary: _jsxs(_Fragment, { children: [_jsx("span", { className: "font-medium", style: { color: 'var(--ds-gray-1000)' }, children: event.name }), ' ', "-", ' ', _jsx("span", { style: { color: 'var(--ds-gray-700)' }, children: localMillisecondTime(event.timestamp[0] * 1000 + event.timestamp[1] / 1e6) })] }), children: [_jsx("div", { className: "flex flex-col divide-y rounded-md border overflow-hidden", style: {
30
+ borderColor: 'var(--ds-gray-300)',
31
+ backgroundColor: 'var(--ds-gray-100)',
32
+ }, children: Object.entries(event.attributes)
30
33
  .filter(([key]) => key !== 'eventData')
31
- .map(([key, value]) => (_jsx(AttributeBlock, { attribute: key, value: value }, key))), _jsxs("div", { className: "relative", children: [eventError && _jsx("div", { children: "Error loading event data" }), !eventError &&
32
- !eventsLoading &&
33
- event.attributes.eventData && (_jsx(AttributeBlock, { isLoading: eventsLoading, attribute: "eventData", value: event.attributes.eventData }))] })] }) }, `${event.name}-${index}`))) })) : null] }));
34
+ .map(([key, value]) => (_jsxs("div", { className: "flex items-center justify-between px-2.5 py-1.5", style: { borderColor: 'var(--ds-gray-300)' }, children: [_jsx("span", { className: "text-[11px] font-medium", style: { color: 'var(--ds-gray-700)' }, children: key }), _jsx("span", { className: "text-[11px] font-mono", style: { color: 'var(--ds-gray-1000)' }, children: String(value) })] }, key))) }), eventError && (_jsx("div", { className: "text-xs text-red-500 mt-2", children: "Error loading event data" })), !eventError && !eventsLoading && event.attributes.eventData && (_jsx("div", { className: "mt-2", children: _jsx(AttributeBlock, { isLoading: eventsLoading, attribute: "eventData", value: event.attributes.eventData }) }))] }, `${event.name}-${index}`))) })) : null] }));
34
35
  }
35
36
  //# sourceMappingURL=events-list.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"events-list.js","sourceRoot":"","sources":["../../src/sidebar/events-list.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"events-list.js","sourceRoot":"","sources":["../../src/sidebar/events-list.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACpC,OAAO,MAAM,MAAM,KAAK,CAAC;AACzB,OAAO,EAEL,0BAA0B,GAC3B,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AAExD,OAAO,EAAE,yBAAyB,EAAE,MAAM,4CAA4C,CAAC;AACvF,OAAO,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AACzE,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,MAAM,UAAU,UAAU,CAAC,EACzB,aAAa,EACb,GAAG,EACH,MAAM,EACN,SAAS,GAMV;IACC,MAAM,UAAU,GAAG,SAAS,IAAI,IAAI,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC;IACzE,MAAM,WAAW,GAAG,WAAW,CAAC,GAAG,EAAE;QACnC,OAAO,0BAA0B,CAAC,GAAG,EAAE,aAAa,EAAE;YACpD,SAAS,EAAE,KAAK;YAChB,KAAK,EAAE,GAAG;YACV,QAAQ,EAAE,CAAC,UAAU;SACtB,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;YACf,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;gBAClB,MAAM,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,IAAI,wBAAwB,CAAC,CAAC;YACnE,CAAC;YACD,OAAO,yBAAyB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,EAAE,KAAK,CAAC,CAAC;QAChE,CAAC,CAAC,CAAC;IACL,CAAC,EAAE,CAAC,GAAG,EAAE,aAAa,EAAE,UAAU,CAAC,CAAC,CAAC;IAErC,MAAM,EACJ,IAAI,EACJ,KAAK,EAAE,UAAU,EACjB,SAAS,EAAE,aAAa,GACzB,GAAG,MAAM,CACR,CAAC,UAAU,EAAE,QAAQ,EAAE,aAAa,CAAC,EACrC,WAAW,EACX;QACE,YAAY,EAAE,MAAM;QACpB,iBAAiB,EAAE,KAAK;KACzB,CACF,CAAC;IAEF,MAAM,WAAW,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IAEzD,OAAO,CACL,eAAK,SAAS,EAAC,MAAM,EAAC,KAAK,EAAE,EAAE,KAAK,EAAE,qBAAqB,EAAE,aAC3D,cACE,SAAS,EAAC,uCAAuC,EACjD,KAAK,EAAE,EAAE,KAAK,EAAE,qBAAqB,EAAE,wBAE/B,CAAC,aAAa,IAAI,IAAI,WAAW,CAAC,MAAM,GAAG,IAChD,EACJ,UAAU,CAAC,CAAC,CAAC,CACZ,KAAC,SAAS,IACR,KAAK,EAAC,gCAAgC,EACtC,OAAO,EAAE,UAAU,EAAE,OAAO,EAC5B,SAAS,EAAC,MAAM,GAChB,CACH,CAAC,CAAC,CAAC,IAAI,EACP,aAAa,CAAC,CAAC,CAAC,8CAA4B,CAAC,CAAC,CAAC,IAAI,EACnD,CAAC,aAAa,IAAI,CAAC,UAAU,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,IAAI,CAC5D,cAAK,SAAS,EAAC,SAAS,gCAAsB,CAC/C,EACA,WAAW,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CACvC,cAAK,SAAS,EAAC,qBAAqB,YACjC,WAAW,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CACjC,MAAC,UAAU,IAET,OAAO,EACL,8BACE,eACE,SAAS,EAAC,aAAa,EACvB,KAAK,EAAE,EAAE,KAAK,EAAE,qBAAqB,EAAE,YAEtC,KAAK,CAAC,IAAI,GACN,EAAC,GAAG,OACT,GAAG,EACL,eAAM,KAAK,EAAE,EAAE,KAAK,EAAE,oBAAoB,EAAE,YACzC,oBAAoB,CACnB,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,GAAG,CACrD,GACI,IACN,aAIL,cACE,SAAS,EAAC,0DAA0D,EACpE,KAAK,EAAE;gCACL,WAAW,EAAE,oBAAoB;gCACjC,eAAe,EAAE,oBAAoB;6BACtC,YAEA,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC;iCAC9B,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,GAAG,KAAK,WAAW,CAAC;iCACtC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CACrB,eAEE,SAAS,EAAC,iDAAiD,EAC3D,KAAK,EAAE,EAAE,WAAW,EAAE,oBAAoB,EAAE,aAE5C,eACE,SAAS,EAAC,yBAAyB,EACnC,KAAK,EAAE,EAAE,KAAK,EAAE,oBAAoB,EAAE,YAErC,GAAG,GACC,EACP,eACE,SAAS,EAAC,uBAAuB,EACjC,KAAK,EAAE,EAAE,KAAK,EAAE,qBAAqB,EAAE,YAEtC,MAAM,CAAC,KAAK,CAAC,GACT,KAfF,GAAG,CAgBJ,CACP,CAAC,GACA,EAEL,UAAU,IAAI,CACb,cAAK,SAAS,EAAC,2BAA2B,yCAEpC,CACP,EACA,CAAC,UAAU,IAAI,CAAC,aAAa,IAAI,KAAK,CAAC,UAAU,CAAC,SAAS,IAAI,CAC9D,cAAK,SAAS,EAAC,MAAM,YACnB,KAAC,cAAc,IACb,SAAS,EAAE,aAAa,EACxB,SAAS,EAAC,WAAW,EACrB,KAAK,EAAE,KAAK,CAAC,UAAU,CAAC,SAAS,GACjC,GACE,CACP,KA/DI,GAAG,KAAK,CAAC,IAAI,IAAI,KAAK,EAAE,CAgElB,CACd,CAAC,GACE,CACP,CAAC,CAAC,CAAC,IAAI,IACJ,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,16 @@
1
+ interface ResolveHookModalProps {
2
+ /** Whether the modal is open */
3
+ isOpen: boolean;
4
+ /** Callback when the modal should be closed */
5
+ onClose: () => void;
6
+ /** Callback when the form is submitted with the parsed JSON payload */
7
+ onSubmit: (payload: unknown) => Promise<void>;
8
+ /** Whether the submission is in progress */
9
+ isSubmitting?: boolean;
10
+ }
11
+ /**
12
+ * Modal component for resolving a hook by entering a JSON payload.
13
+ */
14
+ export declare function ResolveHookModal({ isOpen, onClose, onSubmit, isSubmitting, }: ResolveHookModalProps): React.JSX.Element | null;
15
+ export {};
16
+ //# sourceMappingURL=resolve-hook-modal.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resolve-hook-modal.d.ts","sourceRoot":"","sources":["../../src/sidebar/resolve-hook-modal.tsx"],"names":[],"mappings":"AAMA,UAAU,qBAAqB;IAC7B,gCAAgC;IAChC,MAAM,EAAE,OAAO,CAAC;IAChB,+CAA+C;IAC/C,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,uEAAuE;IACvE,QAAQ,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9C,4CAA4C;IAC5C,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,EAC/B,MAAM,EACN,OAAO,EACP,QAAQ,EACR,YAAoB,GACrB,EAAE,qBAAqB,GAAG,KAAK,CAAC,GAAG,CAAC,OAAO,GAAG,IAAI,CAiMlD"}
@@ -0,0 +1,74 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import clsx from 'clsx';
4
+ import { Send, X } from 'lucide-react';
5
+ import { useCallback, useEffect, useRef, useState } from 'react';
6
+ /**
7
+ * Modal component for resolving a hook by entering a JSON payload.
8
+ */
9
+ export function ResolveHookModal({ isOpen, onClose, onSubmit, isSubmitting = false, }) {
10
+ const [jsonInput, setJsonInput] = useState('');
11
+ const [parseError, setParseError] = useState(null);
12
+ const textareaRef = useRef(null);
13
+ // Focus the textarea when the modal opens
14
+ useEffect(() => {
15
+ if (isOpen && textareaRef.current) {
16
+ textareaRef.current.focus();
17
+ }
18
+ }, [isOpen]);
19
+ // Reset state when modal closes
20
+ useEffect(() => {
21
+ if (!isOpen) {
22
+ setJsonInput('');
23
+ setParseError(null);
24
+ }
25
+ }, [isOpen]);
26
+ // Handle escape key to close
27
+ useEffect(() => {
28
+ const handleKeyDown = (e) => {
29
+ if (e.key === 'Escape' && isOpen && !isSubmitting) {
30
+ onClose();
31
+ }
32
+ };
33
+ document.addEventListener('keydown', handleKeyDown);
34
+ return () => document.removeEventListener('keydown', handleKeyDown);
35
+ }, [isOpen, isSubmitting, onClose]);
36
+ const submitPayload = useCallback(async () => {
37
+ setParseError(null);
38
+ // Parse the JSON input
39
+ let payload;
40
+ try {
41
+ // Allow empty string as null payload
42
+ if (jsonInput.trim() === '') {
43
+ payload = null;
44
+ }
45
+ else {
46
+ payload = JSON.parse(jsonInput);
47
+ }
48
+ }
49
+ catch {
50
+ setParseError('Invalid JSON. Please check your input.');
51
+ return;
52
+ }
53
+ await onSubmit(payload);
54
+ }, [jsonInput, onSubmit]);
55
+ const handleSubmit = useCallback((e) => {
56
+ e.preventDefault();
57
+ void submitPayload();
58
+ }, [submitPayload]);
59
+ // Handle Cmd/Ctrl + Enter to submit
60
+ const handleKeyDown = useCallback((e) => {
61
+ if ((e.metaKey || e.ctrlKey) && e.key === 'Enter' && !isSubmitting) {
62
+ e.preventDefault();
63
+ handleSubmit(e);
64
+ }
65
+ }, [handleSubmit, isSubmitting]);
66
+ if (!isOpen) {
67
+ return null;
68
+ }
69
+ return (_jsxs("div", { className: "fixed inset-0 z-50 flex items-center justify-center", role: "dialog", "aria-modal": "true", "aria-labelledby": "resolve-hook-modal-title", children: [_jsx("div", { className: "absolute inset-0 bg-black/50 backdrop-blur-sm", onClick: isSubmitting ? undefined : onClose }), _jsxs("div", { className: clsx('relative z-10 w-full max-w-lg mx-4', 'bg-background text-foreground rounded-lg shadow-xl', 'border border-border'), children: [_jsxs("div", { className: "flex items-center justify-between px-4 py-3 border-b border-border", children: [_jsx("h2", { id: "resolve-hook-modal-title", className: "text-lg font-semibold text-foreground", children: "Resolve Hook" }), _jsx("button", { type: "button", onClick: onClose, disabled: isSubmitting, className: clsx('p-1 rounded-md transition-colors', 'text-muted-foreground hover:text-foreground', 'hover:bg-muted', 'disabled:opacity-50 disabled:cursor-not-allowed'), "aria-label": "Close modal", children: _jsx(X, { className: "h-5 w-5" }) })] }), _jsxs("form", { onSubmit: handleSubmit, children: [_jsxs("div", { className: "px-4 py-4", children: [_jsx("label", { htmlFor: "json-payload", className: "block text-sm font-medium text-foreground mb-2", children: "JSON Payload" }), _jsxs("p", { className: "text-xs text-muted-foreground mb-3", children: ["Enter a JSON value to send to the hook. Leave empty to send", ' ', _jsx("code", { className: "px-1 py-0.5 bg-muted rounded text-xs", children: "null" }), "."] }), _jsx("textarea", { ref: textareaRef, id: "json-payload", value: jsonInput, onChange: (e) => {
70
+ setJsonInput(e.target.value);
71
+ setParseError(null);
72
+ }, onKeyDown: handleKeyDown, disabled: isSubmitting, placeholder: '{"key": "value"}', className: clsx('w-full h-40 px-3 py-2 font-mono text-sm', 'text-foreground', 'bg-background', 'border rounded-md', 'focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 focus:ring-offset-background', 'disabled:opacity-50 disabled:cursor-not-allowed', 'placeholder:text-muted-foreground', parseError ? 'border-destructive' : 'border-input') }), parseError && (_jsx("p", { className: "mt-2 text-sm text-destructive", children: parseError }))] }), _jsxs("div", { className: "flex items-center justify-end gap-2 px-4 py-3 border-t border-border", children: [_jsx("button", { type: "button", onClick: onClose, disabled: isSubmitting, className: clsx('px-4 py-2 text-sm font-medium rounded-md transition-colors', 'bg-secondary text-secondary-foreground', 'hover:bg-secondary/80', 'disabled:opacity-50 disabled:cursor-not-allowed'), children: "Cancel" }), _jsxs("button", { type: "button", onClick: () => void submitPayload(), disabled: isSubmitting, className: clsx('flex items-center gap-2 px-3 py-2 text-sm font-medium rounded-md transition-colors', 'bg-primary text-primary-foreground hover:bg-primary/90', 'disabled:opacity-50 disabled:cursor-not-allowed'), children: [_jsx(Send, { className: "h-4 w-4" }), isSubmitting ? 'Sending...' : 'Send Payload'] })] })] })] })] }));
73
+ }
74
+ //# sourceMappingURL=resolve-hook-modal.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resolve-hook-modal.js","sourceRoot":"","sources":["../../src/sidebar/resolve-hook-modal.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import type { EnvMap } from './api/workflow-server-actions';
2
+ interface StreamViewerProps {
3
+ env: EnvMap;
4
+ streamId: string;
5
+ }
6
+ /**
7
+ * StreamViewer component that displays real-time stream data.
8
+ * It connects to a stream and displays chunks as they arrive,
9
+ * with auto-scroll functionality.
10
+ */
11
+ export declare function StreamViewer({ env, streamId }: StreamViewerProps): import("react/jsx-runtime").JSX.Element;
12
+ export {};
13
+ //# sourceMappingURL=stream-viewer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stream-viewer.d.ts","sourceRoot":"","sources":["../src/stream-viewer.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAC;AAE5D,UAAU,iBAAiB;IACzB,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,MAAM,CAAC;CAClB;AAOD;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,EAAE,iBAAiB,2CA0LhE"}