@langchain/langgraph-sdk 1.6.4 → 1.7.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 (187) hide show
  1. package/dist/client.cjs +4 -2
  2. package/dist/client.cjs.map +1 -1
  3. package/dist/client.d.cts +7 -0
  4. package/dist/client.d.cts.map +1 -1
  5. package/dist/client.d.ts +7 -0
  6. package/dist/client.d.ts.map +1 -1
  7. package/dist/client.js +4 -2
  8. package/dist/client.js.map +1 -1
  9. package/dist/index.d.cts +4 -4
  10. package/dist/index.d.ts +4 -4
  11. package/dist/react/index.cjs +46 -10
  12. package/dist/react/index.cjs.map +1 -0
  13. package/dist/react/index.d.cts +14 -11
  14. package/dist/react/index.d.cts.map +1 -0
  15. package/dist/react/index.d.ts +14 -11
  16. package/dist/react/index.d.ts.map +1 -0
  17. package/dist/react/index.js +14 -4
  18. package/dist/react/index.js.map +1 -0
  19. package/dist/react-ui/index.cjs +38 -13
  20. package/dist/react-ui/index.d.cts +1 -2
  21. package/dist/react-ui/index.d.ts +1 -2
  22. package/dist/react-ui/index.js +2 -8
  23. package/dist/react-ui/server/index.cjs +14 -4
  24. package/dist/react-ui/server/index.d.cts +1 -2
  25. package/dist/react-ui/server/index.d.ts +1 -2
  26. package/dist/react-ui/server/index.js +1 -2
  27. package/dist/schema.d.cts +2 -0
  28. package/dist/schema.d.cts.map +1 -1
  29. package/dist/schema.d.ts +2 -0
  30. package/dist/schema.d.ts.map +1 -1
  31. package/dist/types.messages.d.cts +5 -3
  32. package/dist/types.messages.d.cts.map +1 -1
  33. package/dist/types.messages.d.ts +5 -3
  34. package/dist/types.messages.d.ts.map +1 -1
  35. package/dist/types.stream.d.cts +40 -2
  36. package/dist/types.stream.d.cts.map +1 -1
  37. package/dist/types.stream.d.ts +40 -2
  38. package/dist/types.stream.d.ts.map +1 -1
  39. package/dist/ui/branching.cjs +24 -0
  40. package/dist/ui/branching.cjs.map +1 -1
  41. package/dist/ui/branching.d.cts +26 -1
  42. package/dist/ui/branching.d.cts.map +1 -1
  43. package/dist/ui/branching.d.ts +26 -1
  44. package/dist/ui/branching.d.ts.map +1 -1
  45. package/dist/ui/branching.js +25 -1
  46. package/dist/ui/branching.js.map +1 -1
  47. package/dist/ui/index.cjs +30 -0
  48. package/dist/ui/index.d.cts +15 -0
  49. package/dist/ui/index.d.ts +15 -0
  50. package/dist/ui/index.js +11 -0
  51. package/dist/ui/interrupts.cjs +21 -0
  52. package/dist/ui/interrupts.cjs.map +1 -0
  53. package/dist/ui/interrupts.d.cts +11 -0
  54. package/dist/ui/interrupts.d.cts.map +1 -0
  55. package/dist/ui/interrupts.d.ts +11 -0
  56. package/dist/ui/interrupts.d.ts.map +1 -0
  57. package/dist/ui/interrupts.js +20 -0
  58. package/dist/ui/interrupts.js.map +1 -0
  59. package/dist/ui/manager.cjs +12 -3
  60. package/dist/ui/manager.cjs.map +1 -1
  61. package/dist/ui/manager.d.cts +224 -0
  62. package/dist/ui/manager.d.cts.map +1 -0
  63. package/dist/ui/manager.d.ts +224 -0
  64. package/dist/ui/manager.d.ts.map +1 -0
  65. package/dist/ui/manager.js +12 -3
  66. package/dist/ui/manager.js.map +1 -1
  67. package/dist/ui/messages.cjs +19 -0
  68. package/dist/ui/messages.cjs.map +1 -1
  69. package/dist/ui/messages.d.cts +36 -0
  70. package/dist/ui/messages.d.cts.map +1 -0
  71. package/dist/ui/messages.d.ts +36 -0
  72. package/dist/ui/messages.d.ts.map +1 -0
  73. package/dist/ui/messages.js +18 -1
  74. package/dist/ui/messages.js.map +1 -1
  75. package/dist/ui/queue.cjs +75 -0
  76. package/dist/ui/queue.cjs.map +1 -0
  77. package/dist/ui/queue.d.cts +72 -0
  78. package/dist/ui/queue.d.cts.map +1 -0
  79. package/dist/ui/queue.d.ts +72 -0
  80. package/dist/ui/queue.d.ts.map +1 -0
  81. package/dist/ui/queue.js +74 -0
  82. package/dist/ui/queue.js.map +1 -0
  83. package/dist/ui/stream/base.d.cts +17 -1
  84. package/dist/ui/stream/base.d.cts.map +1 -1
  85. package/dist/ui/stream/base.d.ts +17 -1
  86. package/dist/ui/stream/base.d.ts.map +1 -1
  87. package/dist/ui/stream/index.d.cts +4 -4
  88. package/dist/ui/stream/index.d.cts.map +1 -1
  89. package/dist/ui/stream/index.d.ts +4 -4
  90. package/dist/ui/stream/index.d.ts.map +1 -1
  91. package/dist/ui/subagents.cjs +4 -1
  92. package/dist/ui/subagents.cjs.map +1 -1
  93. package/dist/ui/subagents.d.cts +7 -0
  94. package/dist/ui/subagents.d.cts.map +1 -1
  95. package/dist/ui/subagents.d.ts +7 -0
  96. package/dist/ui/subagents.d.ts.map +1 -1
  97. package/dist/ui/subagents.js +4 -1
  98. package/dist/ui/subagents.js.map +1 -1
  99. package/dist/ui/transport.cjs +31 -0
  100. package/dist/ui/transport.cjs.map +1 -0
  101. package/dist/{react/stream.custom.d.cts → ui/transport.d.cts} +3 -3
  102. package/dist/ui/transport.d.cts.map +1 -0
  103. package/dist/{react/stream.custom.d.ts → ui/transport.d.ts} +3 -3
  104. package/dist/ui/transport.d.ts.map +1 -0
  105. package/dist/ui/transport.js +31 -0
  106. package/dist/ui/transport.js.map +1 -0
  107. package/dist/ui/types.d.cts +134 -18
  108. package/dist/ui/types.d.cts.map +1 -1
  109. package/dist/ui/types.d.ts +134 -18
  110. package/dist/ui/types.d.ts.map +1 -1
  111. package/dist/ui/utils.d.cts +7 -0
  112. package/dist/ui/utils.d.cts.map +1 -0
  113. package/dist/ui/utils.d.ts +7 -0
  114. package/dist/ui/utils.d.ts.map +1 -0
  115. package/dist/utils/index.cjs +9 -0
  116. package/dist/utils/index.d.cts +4 -0
  117. package/dist/utils/index.d.ts +4 -0
  118. package/dist/utils/index.js +5 -0
  119. package/dist/utils/sse.d.cts +11 -0
  120. package/dist/utils/sse.d.cts.map +1 -0
  121. package/dist/utils/sse.d.ts +11 -0
  122. package/dist/utils/sse.d.ts.map +1 -0
  123. package/dist/utils/stream.d.cts +19 -0
  124. package/dist/utils/stream.d.cts.map +1 -0
  125. package/dist/utils/stream.d.ts +19 -0
  126. package/dist/utils/stream.d.ts.map +1 -0
  127. package/dist/utils/tools.cjs +26 -17
  128. package/dist/utils/tools.cjs.map +1 -1
  129. package/dist/utils/tools.d.cts +7 -0
  130. package/dist/utils/tools.d.cts.map +1 -0
  131. package/dist/utils/tools.d.ts +7 -0
  132. package/dist/utils/tools.d.ts.map +1 -0
  133. package/dist/utils/tools.js +26 -17
  134. package/dist/utils/tools.js.map +1 -1
  135. package/package.json +42 -13
  136. package/dist/react/stream.cjs +0 -18
  137. package/dist/react/stream.cjs.map +0 -1
  138. package/dist/react/stream.custom.cjs +0 -164
  139. package/dist/react/stream.custom.cjs.map +0 -1
  140. package/dist/react/stream.custom.d.cts.map +0 -1
  141. package/dist/react/stream.custom.d.ts.map +0 -1
  142. package/dist/react/stream.custom.js +0 -162
  143. package/dist/react/stream.custom.js.map +0 -1
  144. package/dist/react/stream.d.cts +0 -174
  145. package/dist/react/stream.d.cts.map +0 -1
  146. package/dist/react/stream.d.ts +0 -174
  147. package/dist/react/stream.d.ts.map +0 -1
  148. package/dist/react/stream.js +0 -17
  149. package/dist/react/stream.js.map +0 -1
  150. package/dist/react/stream.lgp.cjs +0 -482
  151. package/dist/react/stream.lgp.cjs.map +0 -1
  152. package/dist/react/stream.lgp.js +0 -481
  153. package/dist/react/stream.lgp.js.map +0 -1
  154. package/dist/react/thread.cjs +0 -21
  155. package/dist/react/thread.cjs.map +0 -1
  156. package/dist/react/thread.js +0 -20
  157. package/dist/react/thread.js.map +0 -1
  158. package/dist/react/types.d.cts +0 -75
  159. package/dist/react/types.d.cts.map +0 -1
  160. package/dist/react/types.d.ts +0 -75
  161. package/dist/react/types.d.ts.map +0 -1
  162. package/dist/react-ui/client.cjs +0 -138
  163. package/dist/react-ui/client.cjs.map +0 -1
  164. package/dist/react-ui/client.d.cts +0 -76
  165. package/dist/react-ui/client.d.cts.map +0 -1
  166. package/dist/react-ui/client.d.ts +0 -76
  167. package/dist/react-ui/client.d.ts.map +0 -1
  168. package/dist/react-ui/client.js +0 -132
  169. package/dist/react-ui/client.js.map +0 -1
  170. package/dist/react-ui/index.cjs.map +0 -1
  171. package/dist/react-ui/index.js.map +0 -1
  172. package/dist/react-ui/server/server.cjs +0 -57
  173. package/dist/react-ui/server/server.cjs.map +0 -1
  174. package/dist/react-ui/server/server.d.cts +0 -54
  175. package/dist/react-ui/server/server.d.cts.map +0 -1
  176. package/dist/react-ui/server/server.d.ts +0 -54
  177. package/dist/react-ui/server/server.d.ts.map +0 -1
  178. package/dist/react-ui/server/server.js +0 -56
  179. package/dist/react-ui/server/server.js.map +0 -1
  180. package/dist/react-ui/types.cjs +0 -38
  181. package/dist/react-ui/types.cjs.map +0 -1
  182. package/dist/react-ui/types.d.cts +0 -25
  183. package/dist/react-ui/types.d.cts.map +0 -1
  184. package/dist/react-ui/types.d.ts +0 -25
  185. package/dist/react-ui/types.d.ts.map +0 -1
  186. package/dist/react-ui/types.js +0 -35
  187. package/dist/react-ui/types.js.map +0 -1
@@ -1,482 +0,0 @@
1
- "use client";
2
-
3
- const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
4
- const require_client = require('../client.cjs');
5
- const require_errors = require('../ui/errors.cjs');
6
- const require_utils = require('../ui/utils.cjs');
7
- const require_branching = require('../ui/branching.cjs');
8
- const require_messages = require('../ui/messages.cjs');
9
- const require_tools = require('../utils/tools.cjs');
10
- const require_manager = require('../ui/manager.cjs');
11
- const require_thread = require('./thread.cjs');
12
- let react = require("react");
13
-
14
- //#region src/react/stream.lgp.tsx
15
- function getFetchHistoryKey(client, threadId, limit) {
16
- return [
17
- require_client.getClientConfigHash(client),
18
- threadId,
19
- limit
20
- ].join(":");
21
- }
22
- function fetchHistory(client, threadId, options) {
23
- if (options?.limit === false) return client.threads.getState(threadId).then((state) => {
24
- if (state.checkpoint == null) return [];
25
- return [state];
26
- });
27
- const limit = typeof options?.limit === "number" ? options.limit : 10;
28
- return client.threads.getHistory(threadId, { limit });
29
- }
30
- function useThreadHistory(client, threadId, limit, options) {
31
- const key = getFetchHistoryKey(client, threadId, limit);
32
- const [state, setState] = (0, react.useState)(() => ({
33
- key: void 0,
34
- data: void 0,
35
- error: void 0,
36
- isLoading: threadId != null
37
- }));
38
- const clientRef = (0, react.useRef)(client);
39
- clientRef.current = client;
40
- const onErrorRef = (0, react.useRef)(options?.onError);
41
- onErrorRef.current = options?.onError;
42
- const fetcher = (0, react.useCallback)((threadId, limit) => {
43
- if (options.passthrough) return Promise.resolve([]);
44
- const client = clientRef.current;
45
- const key = getFetchHistoryKey(client, threadId, limit);
46
- if (threadId != null) {
47
- setState((state) => {
48
- if (state.key === key) return {
49
- ...state,
50
- isLoading: true
51
- };
52
- return {
53
- key,
54
- data: void 0,
55
- error: void 0,
56
- isLoading: true
57
- };
58
- });
59
- return fetchHistory(client, threadId, { limit }).then((data) => {
60
- setState((state) => {
61
- if (state.key !== key) return state;
62
- return {
63
- key,
64
- data,
65
- error: void 0,
66
- isLoading: false
67
- };
68
- });
69
- return data;
70
- }, (error) => {
71
- setState((state) => {
72
- if (state.key !== key) return state;
73
- return {
74
- key,
75
- data: state.data,
76
- error,
77
- isLoading: false
78
- };
79
- });
80
- onErrorRef.current?.(error);
81
- return Promise.reject(error);
82
- });
83
- }
84
- setState({
85
- key,
86
- data: void 0,
87
- error: void 0,
88
- isLoading: false
89
- });
90
- return Promise.resolve([]);
91
- }, [options.passthrough]);
92
- (0, react.useEffect)(() => {
93
- if (options.submittingRef.current != null && options.submittingRef.current === threadId) return;
94
- fetcher(threadId, limit);
95
- }, [fetcher, key]);
96
- return {
97
- data: state.data,
98
- error: state.error,
99
- isLoading: state.isLoading,
100
- mutate: (mutateId) => fetcher(mutateId ?? threadId, limit)
101
- };
102
- }
103
- function useStreamLGP(options) {
104
- const reconnectOnMountRef = (0, react.useRef)(options.reconnectOnMount);
105
- const runMetadataStorage = (0, react.useMemo)(() => {
106
- if (typeof window === "undefined") return null;
107
- const storage = reconnectOnMountRef.current;
108
- if (storage === true) return window.sessionStorage;
109
- if (typeof storage === "function") return storage();
110
- return null;
111
- }, []);
112
- const client = (0, react.useMemo)(() => options.client ?? new require_client.Client({
113
- apiUrl: options.apiUrl,
114
- apiKey: options.apiKey,
115
- callerOptions: options.callerOptions,
116
- defaultHeaders: options.defaultHeaders
117
- }), [
118
- options.client,
119
- options.apiKey,
120
- options.apiUrl,
121
- options.callerOptions,
122
- options.defaultHeaders
123
- ]);
124
- const [messageManager] = (0, react.useState)(() => new require_messages.MessageTupleManager());
125
- const [stream] = (0, react.useState)(() => new require_manager.StreamManager(messageManager, {
126
- throttle: options.throttle ?? false,
127
- subagentToolNames: options.subagentToolNames,
128
- filterSubagentMessages: options.filterSubagentMessages
129
- }));
130
- (0, react.useSyncExternalStore)(stream.subscribe, stream.getSnapshot, stream.getSnapshot);
131
- const [threadId, onThreadId] = require_thread.useControllableThreadId(options);
132
- const trackStreamModeRef = (0, react.useRef)([]);
133
- const trackStreamMode = (0, react.useCallback)((...mode) => {
134
- const ref = trackStreamModeRef.current;
135
- for (const m of mode) if (!ref.includes(m)) ref.push(m);
136
- }, []);
137
- const hasUpdateListener = options.onUpdateEvent != null;
138
- const hasCustomListener = options.onCustomEvent != null;
139
- const hasLangChainListener = options.onLangChainEvent != null;
140
- const hasDebugListener = options.onDebugEvent != null;
141
- const hasCheckpointListener = options.onCheckpointEvent != null;
142
- const hasTaskListener = options.onTaskEvent != null;
143
- const callbackStreamMode = (0, react.useMemo)(() => {
144
- const modes = [];
145
- if (hasUpdateListener) modes.push("updates");
146
- if (hasCustomListener) modes.push("custom");
147
- if (hasLangChainListener) modes.push("events");
148
- if (hasDebugListener) modes.push("debug");
149
- if (hasCheckpointListener) modes.push("checkpoints");
150
- if (hasTaskListener) modes.push("tasks");
151
- return modes;
152
- }, [
153
- hasUpdateListener,
154
- hasCustomListener,
155
- hasLangChainListener,
156
- hasDebugListener,
157
- hasCheckpointListener,
158
- hasTaskListener
159
- ]);
160
- const threadIdRef = (0, react.useRef)(threadId);
161
- const threadIdStreamingRef = (0, react.useRef)(null);
162
- (0, react.useEffect)(() => {
163
- if (threadIdRef.current !== threadId) {
164
- threadIdRef.current = threadId;
165
- stream.clear();
166
- }
167
- }, [threadId, stream]);
168
- const historyLimit = typeof options.fetchStateHistory === "object" && options.fetchStateHistory != null ? options.fetchStateHistory.limit ?? false : options.fetchStateHistory ?? false;
169
- const builtInHistory = useThreadHistory(client, threadId, historyLimit, {
170
- passthrough: options.thread != null,
171
- submittingRef: threadIdStreamingRef,
172
- onError: options.onError
173
- });
174
- const history = options.thread ?? builtInHistory;
175
- const getMessages = (value) => {
176
- const messagesKey = options.messagesKey ?? "messages";
177
- return Array.isArray(value[messagesKey]) ? value[messagesKey] : [];
178
- };
179
- const setMessages = (current, messages) => {
180
- const messagesKey = options.messagesKey ?? "messages";
181
- return {
182
- ...current,
183
- [messagesKey]: messages
184
- };
185
- };
186
- const [branch, setBranch] = (0, react.useState)("");
187
- const branchContext = require_branching.getBranchContext(branch, history.data ?? void 0);
188
- const historyValues = branchContext.threadHead?.values ?? options.initialValues ?? {};
189
- const historyMessages = getMessages(historyValues);
190
- const shouldReconstructSubagents = options.filterSubagentMessages && !stream.isLoading && !history.isLoading && historyMessages.length > 0;
191
- (0, react.useEffect)(() => {
192
- if (shouldReconstructSubagents) stream.reconstructSubagents(historyMessages, { skipIfPopulated: true });
193
- }, [shouldReconstructSubagents, historyMessages.length]);
194
- const historyError = (() => {
195
- const error = branchContext.threadHead?.tasks?.at(-1)?.error;
196
- if (error == null) return void 0;
197
- try {
198
- const parsed = JSON.parse(error);
199
- if (require_errors.StreamError.isStructuredError(parsed)) return new require_errors.StreamError(parsed);
200
- return parsed;
201
- } catch {}
202
- return error;
203
- })();
204
- const messageMetadata = (() => {
205
- const alreadyShown = /* @__PURE__ */ new Set();
206
- return getMessages(historyValues).map((message, idx) => {
207
- const messageId = message.id ?? idx;
208
- const firstSeenState = require_utils.findLast(history.data ?? [], (state) => getMessages(state.values).map((m, idx) => m.id ?? idx).includes(messageId));
209
- const checkpointId = firstSeenState?.checkpoint?.checkpoint_id;
210
- let branch = checkpointId != null ? branchContext.branchByCheckpoint[checkpointId] : void 0;
211
- if (!branch?.branch?.length) branch = void 0;
212
- const optionsShown = branch?.branchOptions?.flat(2).join(",");
213
- if (optionsShown) {
214
- if (alreadyShown.has(optionsShown)) branch = void 0;
215
- alreadyShown.add(optionsShown);
216
- }
217
- return {
218
- messageId: messageId.toString(),
219
- firstSeenState,
220
- branch: branch?.branch,
221
- branchOptions: branch?.branchOptions
222
- };
223
- });
224
- })();
225
- const stop = () => stream.stop(historyValues, { onStop: (args) => {
226
- if (runMetadataStorage && threadId) {
227
- const runId = runMetadataStorage.getItem(`lg:stream:${threadId}`);
228
- if (runId) client.runs.cancel(threadId, runId);
229
- runMetadataStorage.removeItem(`lg:stream:${threadId}`);
230
- }
231
- options.onStop?.(args);
232
- } });
233
- const submit = async (values, submitOptions) => {
234
- const checkpointId = submitOptions?.checkpoint?.checkpoint_id;
235
- setBranch(checkpointId != null ? branchContext.branchByCheckpoint[checkpointId]?.branch ?? "" : "");
236
- const includeImplicitBranch = historyLimit === true || typeof historyLimit === "number";
237
- const shouldRefetch = options.onFinish != null || includeImplicitBranch;
238
- let callbackMeta;
239
- let rejoinKey;
240
- let usableThreadId = threadId;
241
- const shouldAbortPrevious = (submitOptions?.multitaskStrategy === "interrupt" || submitOptions?.multitaskStrategy === "rollback") && stream.isLoading;
242
- await stream.start(async (signal) => {
243
- stream.setStreamValues((values) => {
244
- const prev = {
245
- ...historyValues,
246
- ...values
247
- };
248
- if (submitOptions?.optimisticValues != null) return {
249
- ...prev,
250
- ...typeof submitOptions.optimisticValues === "function" ? submitOptions.optimisticValues(prev) : submitOptions.optimisticValues
251
- };
252
- return { ...prev };
253
- });
254
- if (!usableThreadId) {
255
- usableThreadId = (await client.threads.create({
256
- threadId: submitOptions?.threadId,
257
- metadata: submitOptions?.metadata,
258
- signal
259
- })).thread_id;
260
- threadIdRef.current = usableThreadId;
261
- threadIdStreamingRef.current = usableThreadId;
262
- onThreadId(usableThreadId);
263
- }
264
- if (!usableThreadId) throw new Error("Failed to obtain valid thread ID.");
265
- threadIdStreamingRef.current = usableThreadId;
266
- const streamMode = require_utils.unique([
267
- ...submitOptions?.streamMode ?? [],
268
- ...trackStreamModeRef.current,
269
- ...callbackStreamMode
270
- ]);
271
- let checkpoint = submitOptions?.checkpoint ?? (includeImplicitBranch ? branchContext.threadHead?.checkpoint : void 0) ?? void 0;
272
- if (submitOptions?.checkpoint === null) checkpoint = void 0;
273
- if (checkpoint != null) delete checkpoint.thread_id;
274
- const streamResumable = submitOptions?.streamResumable ?? !!runMetadataStorage;
275
- return client.runs.stream(usableThreadId, options.assistantId, {
276
- input: values,
277
- config: submitOptions?.config,
278
- context: submitOptions?.context,
279
- command: submitOptions?.command,
280
- interruptBefore: submitOptions?.interruptBefore,
281
- interruptAfter: submitOptions?.interruptAfter,
282
- metadata: submitOptions?.metadata,
283
- multitaskStrategy: submitOptions?.multitaskStrategy,
284
- onCompletion: submitOptions?.onCompletion,
285
- onDisconnect: submitOptions?.onDisconnect ?? (streamResumable ? "continue" : "cancel"),
286
- signal,
287
- checkpoint,
288
- streamMode,
289
- streamSubgraphs: submitOptions?.streamSubgraphs,
290
- streamResumable,
291
- durability: submitOptions?.durability,
292
- onRunCreated(params) {
293
- callbackMeta = {
294
- run_id: params.run_id,
295
- thread_id: params.thread_id ?? usableThreadId
296
- };
297
- if (runMetadataStorage) {
298
- rejoinKey = `lg:stream:${usableThreadId}`;
299
- runMetadataStorage.setItem(rejoinKey, callbackMeta.run_id);
300
- }
301
- options.onCreated?.(callbackMeta);
302
- }
303
- });
304
- }, {
305
- getMessages,
306
- setMessages,
307
- initialValues: historyValues,
308
- callbacks: options,
309
- async onSuccess() {
310
- if (rejoinKey) runMetadataStorage?.removeItem(rejoinKey);
311
- if (shouldRefetch) {
312
- const lastHead = (await history.mutate(usableThreadId))?.at(0);
313
- if (lastHead) {
314
- options.onFinish?.(lastHead, callbackMeta);
315
- return null;
316
- }
317
- }
318
- },
319
- onError(error) {
320
- options.onError?.(error, callbackMeta);
321
- },
322
- onFinish() {
323
- threadIdStreamingRef.current = null;
324
- }
325
- }, { abortPrevious: shouldAbortPrevious });
326
- };
327
- const joinStream = async (runId, lastEventId, joinOptions) => {
328
- lastEventId ??= "-1";
329
- if (!threadId) return;
330
- const callbackMeta = {
331
- thread_id: threadId,
332
- run_id: runId
333
- };
334
- await stream.start(async (signal) => {
335
- threadIdStreamingRef.current = threadId;
336
- const stream = client.runs.joinStream(threadId, runId, {
337
- signal,
338
- lastEventId,
339
- streamMode: joinOptions?.streamMode
340
- });
341
- return joinOptions?.filter != null ? require_utils.filterStream(stream, joinOptions.filter) : stream;
342
- }, {
343
- getMessages,
344
- setMessages,
345
- initialValues: historyValues,
346
- callbacks: options,
347
- async onSuccess() {
348
- runMetadataStorage?.removeItem(`lg:stream:${threadId}`);
349
- const lastHead = (await history.mutate(threadId))?.at(0);
350
- if (lastHead) options.onFinish?.(lastHead, callbackMeta);
351
- },
352
- onError(error) {
353
- options.onError?.(error, callbackMeta);
354
- },
355
- onFinish() {
356
- threadIdStreamingRef.current = null;
357
- }
358
- });
359
- };
360
- const reconnectKey = (0, react.useMemo)(() => {
361
- if (!runMetadataStorage || stream.isLoading) return void 0;
362
- if (typeof window === "undefined") return void 0;
363
- const runId = runMetadataStorage?.getItem(`lg:stream:${threadId}`);
364
- if (!runId) return void 0;
365
- return {
366
- runId,
367
- threadId
368
- };
369
- }, [
370
- runMetadataStorage,
371
- stream.isLoading,
372
- threadId
373
- ]);
374
- const shouldReconnect = !!runMetadataStorage;
375
- const reconnectRef = (0, react.useRef)({
376
- threadId,
377
- shouldReconnect
378
- });
379
- const joinStreamRef = (0, react.useRef)(joinStream);
380
- joinStreamRef.current = joinStream;
381
- (0, react.useEffect)(() => {
382
- if (reconnectRef.current.threadId !== threadId) reconnectRef.current = {
383
- threadId,
384
- shouldReconnect
385
- };
386
- }, [threadId, shouldReconnect]);
387
- (0, react.useEffect)(() => {
388
- if (reconnectKey && reconnectRef.current.shouldReconnect) {
389
- reconnectRef.current.shouldReconnect = false;
390
- joinStreamRef.current?.(reconnectKey.runId);
391
- }
392
- }, [reconnectKey]);
393
- const error = stream.error ?? historyError ?? history.error;
394
- const values = stream.values ?? historyValues;
395
- return {
396
- get values() {
397
- trackStreamMode("values");
398
- return values;
399
- },
400
- client,
401
- assistantId: options.assistantId,
402
- error,
403
- isLoading: stream.isLoading,
404
- stop,
405
- submit,
406
- joinStream,
407
- branch,
408
- setBranch,
409
- get history() {
410
- if (historyLimit === false) throw new Error("`fetchStateHistory` must be set to `true` to use `history`");
411
- return branchContext.flatHistory;
412
- },
413
- isThreadLoading: history.isLoading && history.data == null,
414
- get experimental_branchTree() {
415
- if (historyLimit === false) throw new Error("`fetchStateHistory` must be set to `true` to use `experimental_branchTree`");
416
- return branchContext.branchTree;
417
- },
418
- get interrupts() {
419
- if (values != null && "__interrupt__" in values && Array.isArray(values.__interrupt__)) {
420
- const valueInterrupts = values.__interrupt__;
421
- if (valueInterrupts.length === 0) return [{ when: "breakpoint" }];
422
- return valueInterrupts;
423
- }
424
- if (stream.isLoading) return [];
425
- const allInterrupts = (branchContext.threadHead?.tasks ?? []).flatMap((t) => t.interrupts ?? []);
426
- if (allInterrupts.length > 0) return allInterrupts;
427
- if (!(branchContext.threadHead?.next ?? []).length || error != null) return [];
428
- return [{ when: "breakpoint" }];
429
- },
430
- get interrupt() {
431
- const all = this.interrupts;
432
- if (all.length === 0) return void 0;
433
- if (all.length === 1) return all[0];
434
- return all;
435
- },
436
- get messages() {
437
- trackStreamMode("messages-tuple", "values");
438
- return getMessages(values);
439
- },
440
- get toolCalls() {
441
- trackStreamMode("messages-tuple", "values");
442
- return require_tools.getToolCallsWithResults(getMessages(values));
443
- },
444
- getToolCalls(message) {
445
- trackStreamMode("messages-tuple", "values");
446
- return require_tools.getToolCallsWithResults(getMessages(values)).filter((tc) => tc.aiMessage.id === message.id);
447
- },
448
- getMessagesMetadata(message, index) {
449
- trackStreamMode("values");
450
- const streamMetadata = messageManager.get(message.id)?.metadata;
451
- const historyMetadata = messageMetadata?.find((m) => m.messageId === (message.id ?? index));
452
- if (streamMetadata != null || historyMetadata != null) return {
453
- ...historyMetadata,
454
- streamMetadata
455
- };
456
- },
457
- get subagents() {
458
- trackStreamMode("updates", "messages-tuple");
459
- return stream.getSubagents();
460
- },
461
- get activeSubagents() {
462
- trackStreamMode("updates", "messages-tuple");
463
- return stream.getActiveSubagents();
464
- },
465
- getSubagent(toolCallId) {
466
- trackStreamMode("updates", "messages-tuple");
467
- return stream.getSubagent(toolCallId);
468
- },
469
- getSubagentsByType(type) {
470
- trackStreamMode("updates", "messages-tuple");
471
- return stream.getSubagentsByType(type);
472
- },
473
- getSubagentsByMessage(messageId) {
474
- trackStreamMode("updates", "messages-tuple");
475
- return stream.getSubagentsByMessage(messageId);
476
- }
477
- };
478
- }
479
-
480
- //#endregion
481
- exports.useStreamLGP = useStreamLGP;
482
- //# sourceMappingURL=stream.lgp.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"stream.lgp.cjs","names":["getClientConfigHash","Client","MessageTupleManager","StreamManager","useControllableThreadId","getBranchContext","StreamError","findLast","unique","filterStream","getToolCallsWithResults"],"sources":["../../src/react/stream.lgp.tsx"],"sourcesContent":["/* __LC_ALLOW_ENTRYPOINT_SIDE_EFFECTS__ */\n\n\"use client\";\n\nimport {\n type RefObject,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n useSyncExternalStore,\n} from \"react\";\nimport { filterStream, findLast, unique } from \"../ui/utils.js\";\nimport { StreamError } from \"../ui/errors.js\";\nimport { getBranchContext } from \"../ui/branching.js\";\nimport { EventStreamEvent, StreamManager } from \"../ui/manager.js\";\nimport type {\n AnyStreamOptions,\n GetUpdateType,\n GetCustomEventType,\n GetInterruptType,\n GetConfigurableType,\n GetToolCallsType,\n RunCallbackMeta,\n MessageMetadata,\n UseStreamThread,\n} from \"../ui/types.js\";\nimport type { UseStream, SubmitOptions } from \"./types.js\";\n\nimport { Client, getClientConfigHash } from \"../client.js\";\nimport { type Message } from \"../types.messages.js\";\nimport { getToolCallsWithResults } from \"../utils/tools.js\";\nimport type { Interrupt, ThreadState } from \"../schema.js\";\nimport type { StreamMode } from \"../types.stream.js\";\nimport { MessageTupleManager } from \"../ui/messages.js\";\nimport { useControllableThreadId } from \"./thread.js\";\nimport type { StreamEvent } from \"../types.js\";\nimport type { BagTemplate } from \"../types.template.js\";\n\nfunction getFetchHistoryKey(\n client: Client,\n threadId: string | undefined | null,\n limit: boolean | number\n) {\n return [getClientConfigHash(client), threadId, limit].join(\":\");\n}\n\nfunction fetchHistory<StateType extends Record<string, unknown>>(\n client: Client,\n threadId: string,\n options?: { limit?: boolean | number }\n) {\n if (options?.limit === false) {\n return client.threads.getState<StateType>(threadId).then((state) => {\n if (state.checkpoint == null) return [];\n return [state];\n });\n }\n\n const limit = typeof options?.limit === \"number\" ? options.limit : 10;\n return client.threads.getHistory<StateType>(threadId, { limit });\n}\n\nfunction useThreadHistory<StateType extends Record<string, unknown>>(\n client: Client,\n threadId: string | undefined | null,\n limit: boolean | number,\n options: {\n passthrough: boolean;\n submittingRef: RefObject<string | null>;\n onError?: (error: unknown, run?: RunCallbackMeta) => void;\n }\n): UseStreamThread<StateType> {\n const key = getFetchHistoryKey(client, threadId, limit);\n const [state, setState] = useState<{\n key: string | undefined;\n data: ThreadState<StateType>[] | undefined;\n error: unknown | undefined;\n isLoading: boolean;\n }>(() => ({\n key: undefined,\n data: undefined,\n error: undefined,\n isLoading: threadId != null,\n }));\n\n const clientRef = useRef(client);\n clientRef.current = client;\n\n const onErrorRef = useRef(options?.onError);\n onErrorRef.current = options?.onError;\n\n const fetcher = useCallback(\n (\n threadId: string | undefined | null,\n limit: boolean | number\n ): Promise<ThreadState<StateType>[]> => {\n // If only passthrough is enabled, don't fetch history\n if (options.passthrough) return Promise.resolve([]);\n\n const client = clientRef.current;\n const key = getFetchHistoryKey(client, threadId, limit);\n\n if (threadId != null) {\n setState((state) => {\n if (state.key === key) return { ...state, isLoading: true };\n return { key, data: undefined, error: undefined, isLoading: true };\n });\n return fetchHistory<StateType>(client, threadId, { limit }).then(\n (data) => {\n setState((state) => {\n if (state.key !== key) return state;\n return { key, data, error: undefined, isLoading: false };\n });\n return data;\n },\n (error) => {\n setState((state) => {\n if (state.key !== key) return state;\n return { key, data: state.data, error, isLoading: false };\n });\n onErrorRef.current?.(error);\n return Promise.reject(error);\n }\n );\n }\n\n setState({ key, data: undefined, error: undefined, isLoading: false });\n return Promise.resolve([]);\n },\n [options.passthrough]\n );\n\n useEffect(() => {\n // Skip if a stream is already in progress, no need to fetch history\n if (\n options.submittingRef.current != null &&\n options.submittingRef.current === threadId\n ) {\n return;\n }\n\n void fetcher(threadId, limit);\n // The `threadId` and `limit` arguments are already present in `key`\n // Thus we don't need to include them in the dependency array\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [fetcher, key]);\n\n return {\n data: state.data,\n error: state.error,\n isLoading: state.isLoading,\n mutate: (mutateId?: string) => fetcher(mutateId ?? threadId, limit),\n };\n}\n\nexport function useStreamLGP<\n StateType extends Record<string, unknown> = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate\n>(options: AnyStreamOptions<StateType, Bag>): UseStream<StateType, Bag> {\n type UpdateType = GetUpdateType<Bag, StateType>;\n type CustomType = GetCustomEventType<Bag>;\n type InterruptType = GetInterruptType<Bag>;\n type ConfigurableType = GetConfigurableType<Bag>;\n type ToolCallType = GetToolCallsType<StateType>;\n\n const reconnectOnMountRef = useRef(options.reconnectOnMount);\n const runMetadataStorage = useMemo(() => {\n if (typeof window === \"undefined\") return null;\n const storage = reconnectOnMountRef.current;\n if (storage === true) return window.sessionStorage;\n if (typeof storage === \"function\") return storage();\n return null;\n }, []);\n\n const client = useMemo(\n () =>\n options.client ??\n new Client({\n apiUrl: options.apiUrl,\n apiKey: options.apiKey,\n callerOptions: options.callerOptions,\n defaultHeaders: options.defaultHeaders,\n }),\n [\n options.client,\n options.apiKey,\n options.apiUrl,\n options.callerOptions,\n options.defaultHeaders,\n ]\n );\n\n const [messageManager] = useState(() => new MessageTupleManager());\n const [stream] = useState(\n () =>\n new StreamManager<StateType, Bag>(messageManager, {\n throttle: options.throttle ?? false,\n subagentToolNames: options.subagentToolNames,\n filterSubagentMessages: options.filterSubagentMessages,\n })\n );\n\n useSyncExternalStore(\n stream.subscribe,\n stream.getSnapshot,\n stream.getSnapshot\n );\n\n const [threadId, onThreadId] = useControllableThreadId(options);\n const trackStreamModeRef = useRef<Exclude<StreamMode, \"messages\">[]>([]);\n\n const trackStreamMode = useCallback(\n (...mode: Exclude<StreamMode, \"messages\">[]) => {\n const ref = trackStreamModeRef.current;\n for (const m of mode) {\n if (!ref.includes(m)) ref.push(m);\n }\n },\n []\n );\n\n const hasUpdateListener = options.onUpdateEvent != null;\n const hasCustomListener = options.onCustomEvent != null;\n const hasLangChainListener = options.onLangChainEvent != null;\n const hasDebugListener = options.onDebugEvent != null;\n const hasCheckpointListener = options.onCheckpointEvent != null;\n const hasTaskListener = options.onTaskEvent != null;\n\n const callbackStreamMode = useMemo(() => {\n const modes: Exclude<StreamMode, \"messages\">[] = [];\n if (hasUpdateListener) modes.push(\"updates\");\n if (hasCustomListener) modes.push(\"custom\");\n if (hasLangChainListener) modes.push(\"events\");\n if (hasDebugListener) modes.push(\"debug\");\n if (hasCheckpointListener) modes.push(\"checkpoints\");\n if (hasTaskListener) modes.push(\"tasks\");\n return modes;\n }, [\n hasUpdateListener,\n hasCustomListener,\n hasLangChainListener,\n hasDebugListener,\n hasCheckpointListener,\n hasTaskListener,\n ]);\n\n const threadIdRef = useRef<string | null>(threadId);\n const threadIdStreamingRef = useRef<string | null>(null);\n\n // Cancel the stream if thread ID has changed\n useEffect(() => {\n if (threadIdRef.current !== threadId) {\n threadIdRef.current = threadId;\n stream.clear();\n }\n }, [threadId, stream]);\n\n const historyLimit =\n typeof options.fetchStateHistory === \"object\" &&\n options.fetchStateHistory != null\n ? options.fetchStateHistory.limit ?? false\n : options.fetchStateHistory ?? false;\n\n const builtInHistory = useThreadHistory<StateType>(\n client,\n threadId,\n historyLimit,\n {\n passthrough: options.thread != null,\n submittingRef: threadIdStreamingRef,\n onError: options.onError,\n }\n );\n const history = options.thread ?? builtInHistory;\n\n const getMessages = (value: StateType): Message[] => {\n const messagesKey = options.messagesKey ?? \"messages\";\n return Array.isArray(value[messagesKey])\n ? (value[messagesKey] as Message[])\n : [];\n };\n\n const setMessages = (current: StateType, messages: Message[]): StateType => {\n const messagesKey = options.messagesKey ?? \"messages\";\n return { ...current, [messagesKey]: messages };\n };\n\n const [branch, setBranch] = useState<string>(\"\");\n const branchContext = getBranchContext(branch, history.data ?? undefined);\n\n const historyValues =\n branchContext.threadHead?.values ??\n options.initialValues ??\n ({} as StateType);\n\n // Reconstruct subagents from history when:\n // 1. History is loaded (not loading, has data)\n // 2. No active stream is running\n // 3. Subagent filtering is enabled (otherwise subagents aren't tracked)\n // This ensures subagent visualization persists after page refresh or stream completion\n const historyMessages = getMessages(historyValues);\n const shouldReconstructSubagents =\n options.filterSubagentMessages &&\n !stream.isLoading &&\n !history.isLoading &&\n historyMessages.length > 0;\n\n useEffect(() => {\n if (shouldReconstructSubagents) {\n // skipIfPopulated: true ensures we don't overwrite subagents from active streaming\n stream.reconstructSubagents(historyMessages, { skipIfPopulated: true });\n }\n // We intentionally only run this when shouldReconstructSubagents changes\n // to avoid unnecessary reconstructions during streaming\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [shouldReconstructSubagents, historyMessages.length]);\n\n const historyError = (() => {\n const error = branchContext.threadHead?.tasks?.at(-1)?.error;\n if (error == null) return undefined;\n try {\n const parsed = JSON.parse(error) as unknown;\n if (StreamError.isStructuredError(parsed)) return new StreamError(parsed);\n return parsed;\n } catch {\n // do nothing\n }\n return error;\n })();\n\n const messageMetadata = (() => {\n const alreadyShown = new Set<string>();\n return getMessages(historyValues).map(\n (message, idx): Omit<MessageMetadata<StateType>, \"streamMetadata\"> => {\n const messageId = message.id ?? idx;\n\n // Find the first checkpoint where the message was seen\n const firstSeenState = findLast(history.data ?? [], (state) =>\n getMessages(state.values)\n .map((m, idx) => m.id ?? idx)\n .includes(messageId)\n );\n\n const checkpointId = firstSeenState?.checkpoint?.checkpoint_id;\n let branch =\n checkpointId != null\n ? branchContext.branchByCheckpoint[checkpointId]\n : undefined;\n if (!branch?.branch?.length) branch = undefined;\n\n // serialize branches\n const optionsShown = branch?.branchOptions?.flat(2).join(\",\");\n if (optionsShown) {\n if (alreadyShown.has(optionsShown)) branch = undefined;\n alreadyShown.add(optionsShown);\n }\n\n return {\n messageId: messageId.toString(),\n firstSeenState,\n\n branch: branch?.branch,\n branchOptions: branch?.branchOptions,\n };\n }\n );\n })();\n\n const stop = () =>\n stream.stop(historyValues, {\n onStop: (args) => {\n if (runMetadataStorage && threadId) {\n const runId = runMetadataStorage.getItem(`lg:stream:${threadId}`);\n if (runId) void client.runs.cancel(threadId, runId);\n runMetadataStorage.removeItem(`lg:stream:${threadId}`);\n }\n\n options.onStop?.(args);\n },\n });\n\n // --- TRANSPORT ---\n const submit = async (\n values: UpdateType | null | undefined,\n submitOptions?: SubmitOptions<StateType, ConfigurableType>\n ) => {\n // Unbranch things\n const checkpointId = submitOptions?.checkpoint?.checkpoint_id;\n setBranch(\n checkpointId != null\n ? branchContext.branchByCheckpoint[checkpointId]?.branch ?? \"\"\n : \"\"\n );\n\n // When `fetchStateHistory` is requested, thus we assume that branching\n // is enabled. We then need to include the implicit branch.\n const includeImplicitBranch =\n historyLimit === true || typeof historyLimit === \"number\";\n\n const shouldRefetch =\n // We're expecting the whole thread state in onFinish\n options.onFinish != null ||\n // We're fetching history, thus we need the latest checkpoint\n // to ensure we're not accidentally submitting to a wrong branch\n includeImplicitBranch;\n\n let callbackMeta: RunCallbackMeta | undefined;\n let rejoinKey: `lg:stream:${string}` | undefined;\n let usableThreadId = threadId;\n\n const shouldAbortPrevious =\n (submitOptions?.multitaskStrategy === \"interrupt\" ||\n submitOptions?.multitaskStrategy === \"rollback\") &&\n stream.isLoading;\n\n await stream.start(\n async (signal: AbortSignal) => {\n stream.setStreamValues((values) => {\n const prev = { ...historyValues, ...values };\n if (submitOptions?.optimisticValues != null) {\n return {\n ...prev,\n ...(typeof submitOptions.optimisticValues === \"function\"\n ? submitOptions.optimisticValues(prev)\n : submitOptions.optimisticValues),\n };\n }\n\n return { ...prev };\n });\n\n if (!usableThreadId) {\n const thread = await client.threads.create({\n threadId: submitOptions?.threadId,\n metadata: submitOptions?.metadata,\n signal,\n });\n\n usableThreadId = thread.thread_id;\n\n // Pre-emptively update the thread ID before\n // stream cancellation is kicked off and thread\n // is being refetched\n threadIdRef.current = usableThreadId;\n threadIdStreamingRef.current = usableThreadId;\n\n onThreadId(usableThreadId);\n }\n\n if (!usableThreadId) {\n throw new Error(\"Failed to obtain valid thread ID.\");\n }\n\n threadIdStreamingRef.current = usableThreadId;\n\n const streamMode = unique([\n ...(submitOptions?.streamMode ?? []),\n ...trackStreamModeRef.current,\n ...callbackStreamMode,\n ]);\n\n let checkpoint =\n submitOptions?.checkpoint ??\n (includeImplicitBranch\n ? branchContext.threadHead?.checkpoint\n : undefined) ??\n undefined;\n\n // Avoid specifying a checkpoint if user explicitly set it to null\n if (submitOptions?.checkpoint === null) checkpoint = undefined;\n\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-expect-error\n if (checkpoint != null) delete checkpoint.thread_id;\n const streamResumable =\n submitOptions?.streamResumable ?? !!runMetadataStorage;\n\n return client.runs.stream(usableThreadId, options.assistantId, {\n input: values as Record<string, unknown>,\n config: submitOptions?.config,\n context: submitOptions?.context,\n command: submitOptions?.command,\n\n interruptBefore: submitOptions?.interruptBefore,\n interruptAfter: submitOptions?.interruptAfter,\n metadata: submitOptions?.metadata,\n multitaskStrategy: submitOptions?.multitaskStrategy,\n onCompletion: submitOptions?.onCompletion,\n onDisconnect:\n submitOptions?.onDisconnect ??\n (streamResumable ? \"continue\" : \"cancel\"),\n\n signal,\n\n checkpoint,\n streamMode,\n streamSubgraphs: submitOptions?.streamSubgraphs,\n streamResumable,\n durability: submitOptions?.durability,\n onRunCreated(params) {\n callbackMeta = {\n run_id: params.run_id,\n thread_id: params.thread_id ?? usableThreadId!,\n };\n\n if (runMetadataStorage) {\n rejoinKey = `lg:stream:${usableThreadId}`;\n runMetadataStorage.setItem(rejoinKey, callbackMeta.run_id);\n }\n\n options.onCreated?.(callbackMeta);\n },\n }) as AsyncGenerator<\n EventStreamEvent<StateType, UpdateType, CustomType>\n >;\n },\n {\n getMessages,\n setMessages,\n\n initialValues: historyValues,\n callbacks: options,\n\n async onSuccess() {\n if (rejoinKey) runMetadataStorage?.removeItem(rejoinKey);\n\n if (shouldRefetch) {\n const newHistory = await history.mutate(usableThreadId!);\n const lastHead = newHistory?.at(0);\n if (lastHead) {\n // We now have the latest update from /history\n // Thus we can clear the local stream state\n options.onFinish?.(lastHead, callbackMeta);\n return null;\n }\n }\n\n return undefined;\n },\n onError(error) {\n options.onError?.(error, callbackMeta);\n },\n onFinish() {\n threadIdStreamingRef.current = null;\n },\n },\n { abortPrevious: shouldAbortPrevious }\n );\n };\n\n const joinStream = async (\n runId: string,\n lastEventId?: string,\n joinOptions?: {\n streamMode?: StreamMode | StreamMode[];\n filter?: (event: {\n id?: string;\n event: StreamEvent;\n data: unknown;\n }) => boolean;\n }\n ) => {\n // eslint-disable-next-line no-param-reassign\n lastEventId ??= \"-1\";\n if (!threadId) return;\n\n const callbackMeta: RunCallbackMeta = {\n thread_id: threadId,\n run_id: runId,\n };\n\n await stream.start(\n async (signal: AbortSignal) => {\n threadIdStreamingRef.current = threadId;\n const stream = client.runs.joinStream(threadId, runId, {\n signal,\n lastEventId,\n streamMode: joinOptions?.streamMode,\n }) as AsyncGenerator<\n EventStreamEvent<StateType, UpdateType, CustomType>\n >;\n\n return joinOptions?.filter != null\n ? filterStream(stream, joinOptions.filter)\n : stream;\n },\n {\n getMessages,\n setMessages,\n\n initialValues: historyValues,\n callbacks: options,\n async onSuccess() {\n runMetadataStorage?.removeItem(`lg:stream:${threadId}`);\n const newHistory = await history.mutate(threadId);\n const lastHead = newHistory?.at(0);\n if (lastHead) options.onFinish?.(lastHead, callbackMeta);\n },\n onError(error) {\n options.onError?.(error, callbackMeta);\n },\n onFinish() {\n threadIdStreamingRef.current = null;\n },\n }\n );\n };\n\n const reconnectKey = useMemo(() => {\n if (!runMetadataStorage || stream.isLoading) return undefined;\n if (typeof window === \"undefined\") return undefined;\n const runId = runMetadataStorage?.getItem(`lg:stream:${threadId}`);\n if (!runId) return undefined;\n return { runId, threadId };\n }, [runMetadataStorage, stream.isLoading, threadId]);\n\n const shouldReconnect = !!runMetadataStorage;\n const reconnectRef = useRef({ threadId, shouldReconnect });\n\n const joinStreamRef = useRef<typeof joinStream>(joinStream);\n joinStreamRef.current = joinStream;\n\n useEffect(() => {\n // reset shouldReconnect when switching threads\n if (reconnectRef.current.threadId !== threadId) {\n reconnectRef.current = { threadId, shouldReconnect };\n }\n }, [threadId, shouldReconnect]);\n\n useEffect(() => {\n if (reconnectKey && reconnectRef.current.shouldReconnect) {\n reconnectRef.current.shouldReconnect = false;\n void joinStreamRef.current?.(reconnectKey.runId);\n }\n }, [reconnectKey]);\n\n const error = stream.error ?? historyError ?? history.error;\n const values = stream.values ?? historyValues;\n\n return {\n get values() {\n trackStreamMode(\"values\");\n return values;\n },\n\n client,\n assistantId: options.assistantId,\n\n error,\n isLoading: stream.isLoading,\n\n stop,\n submit,\n\n joinStream,\n\n branch,\n setBranch,\n\n get history() {\n if (historyLimit === false) {\n throw new Error(\n \"`fetchStateHistory` must be set to `true` to use `history`\"\n );\n }\n\n return branchContext.flatHistory;\n },\n\n isThreadLoading: history.isLoading && history.data == null,\n\n get experimental_branchTree() {\n if (historyLimit === false) {\n throw new Error(\n \"`fetchStateHistory` must be set to `true` to use `experimental_branchTree`\"\n );\n }\n\n return branchContext.branchTree;\n },\n\n get interrupts(): Interrupt<InterruptType>[] {\n if (\n values != null &&\n \"__interrupt__\" in values &&\n Array.isArray(values.__interrupt__)\n ) {\n const valueInterrupts = values.__interrupt__;\n if (valueInterrupts.length === 0) return [{ when: \"breakpoint\" }];\n return valueInterrupts;\n }\n\n // If we're deferring to old interrupt detection logic, don't show the interrupt if the stream is loading\n if (stream.isLoading) return [];\n\n // Collect interrupts from ALL tasks (not just the last one)\n const allTasks = branchContext.threadHead?.tasks ?? [];\n const allInterrupts = allTasks.flatMap((t) => t.interrupts ?? []);\n\n if (allInterrupts.length > 0) {\n return allInterrupts as Interrupt<InterruptType>[];\n }\n\n // check if there's a next task present (breakpoint-style interrupt)\n const next = branchContext.threadHead?.next ?? [];\n if (!next.length || error != null) return [];\n return [{ when: \"breakpoint\" }];\n },\n\n get interrupt() {\n const all = this.interrupts;\n if (all.length === 0) return undefined;\n if (all.length === 1) return all[0];\n\n // Multiple interrupts: return the array for backward compat\n return all as Interrupt<InterruptType>;\n },\n\n get messages(): Message<ToolCallType>[] {\n trackStreamMode(\"messages-tuple\", \"values\");\n return getMessages(values);\n },\n\n get toolCalls() {\n trackStreamMode(\"messages-tuple\", \"values\");\n const msgs = getMessages(values) as Message<ToolCallType>[];\n return getToolCallsWithResults<ToolCallType>(msgs);\n },\n\n getToolCalls(message) {\n trackStreamMode(\"messages-tuple\", \"values\");\n const msgs = getMessages(values) as Message<ToolCallType>[];\n const allToolCalls = getToolCallsWithResults<ToolCallType>(msgs);\n return allToolCalls.filter((tc) => tc.aiMessage.id === message.id);\n },\n\n getMessagesMetadata(\n message: Message<ToolCallType>,\n index?: number\n ): MessageMetadata<StateType> | undefined {\n trackStreamMode(\"values\");\n\n const streamMetadata = messageManager.get(message.id)?.metadata;\n const historyMetadata = messageMetadata?.find(\n (m) => m.messageId === (message.id ?? index)\n );\n\n if (streamMetadata != null || historyMetadata != null) {\n return {\n ...historyMetadata,\n streamMetadata,\n } as MessageMetadata<StateType>;\n }\n\n return undefined;\n },\n\n get subagents() {\n trackStreamMode(\"updates\", \"messages-tuple\");\n return stream.getSubagents();\n },\n\n get activeSubagents() {\n trackStreamMode(\"updates\", \"messages-tuple\");\n return stream.getActiveSubagents();\n },\n\n getSubagent(toolCallId: string) {\n trackStreamMode(\"updates\", \"messages-tuple\");\n return stream.getSubagent(toolCallId);\n },\n\n getSubagentsByType(type: string) {\n trackStreamMode(\"updates\", \"messages-tuple\");\n return stream.getSubagentsByType(type);\n },\n\n getSubagentsByMessage(messageId: string) {\n trackStreamMode(\"updates\", \"messages-tuple\");\n return stream.getSubagentsByMessage(messageId);\n },\n };\n}\n"],"mappings":"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"}