@langchain/svelte 0.4.0 → 0.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -288,6 +288,12 @@ Object.defineProperty(exports, "calculateDepthFromNamespace", {
288
288
  return _langchain_langgraph_sdk_ui.calculateDepthFromNamespace;
289
289
  }
290
290
  });
291
+ Object.defineProperty(exports, "executeHeadlessTool", {
292
+ enumerable: true,
293
+ get: function() {
294
+ return _langchain_langgraph_sdk.executeHeadlessTool;
295
+ }
296
+ });
291
297
  Object.defineProperty(exports, "extractParentIdFromNamespace", {
292
298
  enumerable: true,
293
299
  get: function() {
@@ -300,14 +306,56 @@ Object.defineProperty(exports, "extractToolCallIdFromNamespace", {
300
306
  return _langchain_langgraph_sdk_ui.extractToolCallIdFromNamespace;
301
307
  }
302
308
  });
309
+ Object.defineProperty(exports, "filterOutHeadlessToolInterrupts", {
310
+ enumerable: true,
311
+ get: function() {
312
+ return _langchain_langgraph_sdk.filterOutHeadlessToolInterrupts;
313
+ }
314
+ });
315
+ Object.defineProperty(exports, "findHeadlessTool", {
316
+ enumerable: true,
317
+ get: function() {
318
+ return _langchain_langgraph_sdk.findHeadlessTool;
319
+ }
320
+ });
321
+ Object.defineProperty(exports, "flushPendingHeadlessToolInterrupts", {
322
+ enumerable: true,
323
+ get: function() {
324
+ return _langchain_langgraph_sdk.flushPendingHeadlessToolInterrupts;
325
+ }
326
+ });
303
327
  exports.getStream = getStream;
304
328
  exports.getStreamContext = getStreamContext;
329
+ Object.defineProperty(exports, "handleHeadlessToolInterrupt", {
330
+ enumerable: true,
331
+ get: function() {
332
+ return _langchain_langgraph_sdk.handleHeadlessToolInterrupt;
333
+ }
334
+ });
335
+ Object.defineProperty(exports, "headlessToolResumeCommand", {
336
+ enumerable: true,
337
+ get: function() {
338
+ return _langchain_langgraph_sdk.headlessToolResumeCommand;
339
+ }
340
+ });
341
+ Object.defineProperty(exports, "isHeadlessToolInterrupt", {
342
+ enumerable: true,
343
+ get: function() {
344
+ return _langchain_langgraph_sdk.isHeadlessToolInterrupt;
345
+ }
346
+ });
305
347
  Object.defineProperty(exports, "isSubagentNamespace", {
306
348
  enumerable: true,
307
349
  get: function() {
308
350
  return _langchain_langgraph_sdk_ui.isSubagentNamespace;
309
351
  }
310
352
  });
353
+ Object.defineProperty(exports, "parseHeadlessToolInterruptPayload", {
354
+ enumerable: true,
355
+ get: function() {
356
+ return _langchain_langgraph_sdk.parseHeadlessToolInterruptPayload;
357
+ }
358
+ });
311
359
  exports.provideStream = provideStream;
312
360
  exports.setStreamContext = setStreamContext;
313
361
  exports.useStream = useStream;
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","names":["useStreamCustom","Client","StreamOrchestrator"],"sources":["../src/index.ts"],"sourcesContent":["import { writable, derived, fromStore } from \"svelte/store\";\nimport { onDestroy, onMount, setContext, getContext } from \"svelte\";\n\nimport type {\n ToolMessage as CoreToolMessage,\n AIMessage as CoreAIMessage,\n} from \"@langchain/core/messages\";\nimport {\n StreamOrchestrator,\n FetchStreamTransport,\n ensureMessageInstances,\n type MessageMetadata,\n type AnyStreamOptions,\n type ResolveStreamInterface,\n type ResolveStreamOptions,\n type InferBag,\n type InferStateType,\n type UseStreamCustomOptions,\n type WithClassMessages,\n} from \"@langchain/langgraph-sdk/ui\";\nimport {\n Client,\n type BagTemplate,\n type Message,\n type ToolCallWithResult as _ToolCallWithResult,\n type DefaultToolCall,\n} from \"@langchain/langgraph-sdk\";\nimport { useStreamCustom } from \"./stream.custom.js\";\n\nexport { FetchStreamTransport };\n\nconst STREAM_CONTEXT_KEY = Symbol.for(\"langchain:stream-context\");\n\n/**\n * Provides a `useStream` return value to all descendant components via\n * Svelte's context API. Must be called during component initialisation\n * (i.e. at the top level of a `<script>` block).\n *\n * @example\n * ```svelte\n * <script lang=\"ts\">\n * import { useStream, setStreamContext } from \"@langchain/svelte\";\n *\n * const stream = useStream({ assistantId: \"agent\", apiUrl: \"...\" });\n * setStreamContext(stream);\n * </script>\n *\n * <ChildComponent />\n * ```\n */\nexport function setStreamContext<T extends ReturnType<typeof useStream>>(\n stream: T\n): T {\n setContext(STREAM_CONTEXT_KEY, stream);\n return stream;\n}\n\n/**\n * Retrieves the `useStream` instance previously provided by a parent\n * component via {@link setStreamContext} or {@link provideStream}.\n * Must be called during component initialisation.\n *\n * @throws If no stream context has been set by an ancestor component.\n *\n * @example\n * ```svelte\n * <script lang=\"ts\">\n * import { getStreamContext } from \"@langchain/svelte\";\n *\n * const stream = getStreamContext();\n * </script>\n * ```\n */\nexport function getStreamContext<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(): WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>> {\n const ctx = getContext(STREAM_CONTEXT_KEY);\n if (!ctx) {\n throw new Error(\n \"getStreamContext must be used within a component that has called setStreamContext\"\n );\n }\n return ctx as WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>>;\n}\n\n/**\n * Creates a shared `useStream` instance and makes it available to all\n * descendant components via Svelte's `setContext`/`getContext`.\n *\n * Call this in a parent component's `<script>` block. Children access\n * the shared stream via {@link getStream}.\n *\n * Uses the same context key as {@link setStreamContext}/{@link getStreamContext},\n * so both retrieval functions work interchangeably.\n *\n * @example\n * ```svelte\n * <!-- ChatContainer.svelte -->\n * <script lang=\"ts\">\n * import { provideStream } from \"@langchain/svelte\";\n *\n * provideStream({\n * assistantId: \"agent\",\n * apiUrl: \"http://localhost:2024\",\n * });\n * </script>\n *\n * <ChatHeader />\n * <MessageList />\n * <MessageInput />\n * ```\n *\n * @returns The stream instance (same as calling `useStream` directly).\n */\nexport function provideStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(\n options:\n | ResolveStreamOptions<T, InferBag<T, Bag>>\n | UseStreamCustomOptions<InferStateType<T>, InferBag<T, Bag>>\n): ReturnType<typeof useStream<T, Bag>> {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const stream = useStream<T, Bag>(options as any);\n setContext(STREAM_CONTEXT_KEY, stream);\n return stream;\n}\n\n/**\n * Retrieves the shared stream instance from the nearest ancestor that\n * called {@link provideStream} or {@link setStreamContext}.\n *\n * Throws if no ancestor has provided a stream.\n *\n * @example\n * ```svelte\n * <!-- MessageList.svelte -->\n * <script lang=\"ts\">\n * import { getStream } from \"@langchain/svelte\";\n *\n * const stream = getStream();\n * </script>\n *\n * {#each stream.messages as msg (msg.id)}\n * <div>{msg.content}</div>\n * {/each}\n * ```\n */\nexport function getStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(): ReturnType<typeof useStream<T, Bag>> {\n const context = getContext(STREAM_CONTEXT_KEY);\n if (context == null) {\n throw new Error(\n \"getStream() requires a parent component to call provideStream(). \" +\n \"Add provideStream({ assistantId: '...' }) in an ancestor component.\"\n );\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return context as any;\n}\n\nexport type { ClassSubagentStreamInterface } from \"@langchain/langgraph-sdk/ui\";\n\nexport function useStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(\n options: ResolveStreamOptions<T, InferBag<T, Bag>>\n): WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>>;\n\nexport function useStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(\n options: UseStreamCustomOptions<InferStateType<T>, InferBag<T, Bag>>\n): WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>>;\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function useStream(options: any): any {\n if (\"transport\" in options) {\n return useStreamCustom(options);\n }\n return useStreamLGP(options);\n}\n\nfunction useStreamLGP<\n StateType extends Record<string, unknown> = Record<string, unknown>,\n Bag extends {\n ConfigurableType?: Record<string, unknown>;\n InterruptType?: unknown;\n CustomEventType?: unknown;\n UpdateType?: unknown;\n } = BagTemplate,\n>(options: AnyStreamOptions<StateType, Bag>) {\n const client = options.client ?? new Client({ apiUrl: options.apiUrl });\n\n const orchestrator = new StreamOrchestrator<StateType, Bag>(options, {\n getClient: () => client,\n getAssistantId: () => options.assistantId,\n getMessagesKey: () => options.messagesKey ?? \"messages\",\n });\n\n orchestrator.initThreadId(options.threadId ?? undefined);\n\n const version = writable(0);\n const unsubscribe = orchestrator.subscribe(() => {\n version.update((v) => v + 1);\n });\n\n let fetchController: AbortController | null = null;\n\n // Subagent reconstruction\n const shouldReconstructSubagents = derived(version, () => {\n const hvMessages = orchestrator.messages;\n if (!options.filterSubagentMessages) return false;\n if (orchestrator.isLoading || orchestrator.historyData.isLoading)\n return false;\n return hvMessages.length > 0;\n });\n\n const unsubReconstruct = shouldReconstructSubagents.subscribe(($should) => {\n if ($should) {\n fetchController?.abort();\n const controller = orchestrator.reconstructSubagentsIfNeeded();\n fetchController = controller;\n }\n });\n\n // Queue draining - must track isLoading specifically (not just version)\n // so the drain fires exactly when stream transitions from loading → idle\n const isLoadingForDrain = derived(version, () => orchestrator.isLoading);\n const unsubDrain = isLoadingForDrain.subscribe(() => {\n orchestrator.drainQueue();\n });\n\n // Auto-reconnect\n let { shouldReconnect } = orchestrator;\n\n onMount(() => {\n if (shouldReconnect) {\n const reconnected = orchestrator.tryReconnect();\n if (reconnected) shouldReconnect = false;\n }\n });\n\n onDestroy(() => {\n fetchController?.abort();\n unsubscribe();\n unsubReconstruct();\n unsubDrain();\n orchestrator.dispose();\n });\n\n // Derived stores\n const valuesStore = derived(version, () => {\n orchestrator.trackStreamMode(\"values\");\n return orchestrator.values;\n });\n const errorStore = derived(version, () => orchestrator.error);\n const isLoadingStore = derived(version, () => orchestrator.isLoading);\n const branchStore = derived(version, () => orchestrator.branch);\n const messagesStore = derived(version, () => {\n orchestrator.trackStreamMode(\"messages-tuple\", \"values\");\n return ensureMessageInstances(orchestrator.messages);\n });\n const toolCallsStore = derived(version, () => {\n orchestrator.trackStreamMode(\"messages-tuple\", \"values\");\n return orchestrator.toolCalls;\n });\n const interruptStore = derived(version, () => orchestrator.interrupt);\n const interruptsStore = derived(version, () => orchestrator.interrupts);\n const historyListStore = derived(version, () => orchestrator.flatHistory);\n const isThreadLoadingStore = derived(\n version,\n () => orchestrator.isThreadLoading\n );\n const experimentalBranchTreeStore = derived(\n version,\n () => orchestrator.experimental_branchTree\n );\n const subagentsStore = derived(version, () => {\n orchestrator.trackStreamMode(\"updates\", \"messages-tuple\");\n return orchestrator.subagents;\n });\n const activeSubagentsStore = derived(version, () => {\n orchestrator.trackStreamMode(\"updates\", \"messages-tuple\");\n return orchestrator.activeSubagents;\n });\n const queueEntriesStore = derived(version, () => orchestrator.queueEntries);\n const queueSizeStore = derived(version, () => orchestrator.queueSize);\n\n // fromStore adapters for Svelte 5\n const valuesRef = fromStore(valuesStore);\n const errorRef = fromStore(errorStore);\n const isLoadingRef = fromStore(isLoadingStore);\n const branchRef = fromStore(branchStore);\n const messagesRef = fromStore(messagesStore);\n const toolCallsRef = fromStore(toolCallsStore);\n const interruptRef = fromStore(interruptStore);\n const interruptsRef = fromStore(interruptsStore);\n const historyListRef = fromStore(historyListStore);\n const isThreadLoadingRef = fromStore(isThreadLoadingStore);\n const experimentalBranchTreeRef = fromStore(experimentalBranchTreeStore);\n const subagentsRef = fromStore(subagentsStore);\n const activeSubagentsRef = fromStore(activeSubagentsStore);\n const queueEntriesRef = fromStore(queueEntriesStore);\n const queueSizeRef = fromStore(queueSizeStore);\n\n return {\n assistantId: options.assistantId,\n client,\n\n get values() {\n return valuesRef.current;\n },\n get error() {\n return errorRef.current;\n },\n get isLoading() {\n return isLoadingRef.current;\n },\n get isThreadLoading() {\n return isThreadLoadingRef.current;\n },\n\n get branch() {\n return branchRef.current;\n },\n setBranch(value: string) {\n orchestrator.setBranch(value);\n },\n\n get messages() {\n return messagesRef.current;\n },\n get toolCalls() {\n return toolCallsRef.current;\n },\n getToolCalls(message: Message) {\n return orchestrator.getToolCalls(message);\n },\n\n get interrupt() {\n return interruptRef.current;\n },\n get interrupts() {\n return interruptsRef.current;\n },\n\n get history() {\n return historyListRef.current;\n },\n get experimental_branchTree() {\n return experimentalBranchTreeRef.current;\n },\n\n getMessagesMetadata(\n message: Message,\n index?: number\n ): MessageMetadata<StateType> | undefined {\n return orchestrator.getMessagesMetadata(message, index);\n },\n\n submit: (...args: Parameters<typeof orchestrator.submit>) =>\n orchestrator.submit(...args),\n stop: () => orchestrator.stop(),\n joinStream: (...args: Parameters<typeof orchestrator.joinStream>) =>\n orchestrator.joinStream(...args),\n\n queue: {\n get entries() {\n return queueEntriesRef.current;\n },\n get size() {\n return queueSizeRef.current;\n },\n cancel: (id: string) => orchestrator.cancelQueueItem(id),\n clear: () => orchestrator.clearQueue(),\n },\n\n switchThread(newThreadId: string | null) {\n orchestrator.switchThread(newThreadId);\n },\n\n get subagents() {\n return subagentsRef.current;\n },\n get activeSubagents() {\n return activeSubagentsRef.current;\n },\n getSubagent(toolCallId: string) {\n return orchestrator.getSubagent(toolCallId);\n },\n getSubagentsByType(type: string) {\n return orchestrator.getSubagentsByType(type);\n },\n getSubagentsByMessage(messageId: string) {\n return orchestrator.getSubagentsByMessage(messageId);\n },\n };\n}\n\nexport type {\n BaseStream,\n UseAgentStream,\n UseAgentStreamOptions,\n UseDeepAgentStream,\n UseDeepAgentStreamOptions,\n ResolveStreamInterface,\n ResolveStreamOptions,\n InferStateType,\n InferToolCalls,\n InferSubagentStates,\n InferNodeNames,\n InferBag,\n MessageMetadata,\n UseStreamOptions,\n UseStreamCustomOptions,\n UseStreamTransport,\n UseStreamThread,\n GetToolCallsType,\n AgentTypeConfigLike,\n IsAgentLike,\n ExtractAgentConfig,\n InferAgentToolCalls,\n SubagentToolCall,\n SubagentStatus,\n SubagentApi,\n SubagentStream,\n SubagentStreamInterface,\n SubAgentLike,\n CompiledSubAgentLike,\n DeepAgentTypeConfigLike,\n IsDeepAgentLike,\n ExtractDeepAgentConfig,\n ExtractSubAgentMiddleware,\n InferDeepAgentSubagents,\n InferSubagentByName,\n InferSubagentState,\n InferSubagentNames,\n SubagentStateMap,\n DefaultSubagentStates,\n BaseSubagentState,\n QueueEntry,\n QueueInterface,\n} from \"@langchain/langgraph-sdk/ui\";\n\nexport type ToolCallWithResult<ToolCall = DefaultToolCall> =\n _ToolCallWithResult<ToolCall, CoreToolMessage, CoreAIMessage>;\nexport type {\n ToolCallState,\n DefaultToolCall,\n ToolCallFromTool,\n ToolCallsFromTools,\n} from \"@langchain/langgraph-sdk\";\n\nexport {\n SubagentManager,\n extractToolCallIdFromNamespace,\n calculateDepthFromNamespace,\n extractParentIdFromNamespace,\n isSubagentNamespace,\n} from \"@langchain/langgraph-sdk/ui\";\n"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs","names":["useStreamCustom","Client","StreamOrchestrator"],"sources":["../src/index.ts"],"sourcesContent":["import { writable, derived, fromStore } from \"svelte/store\";\nimport { onDestroy, onMount, setContext, getContext } from \"svelte\";\n\nimport type {\n ToolMessage as CoreToolMessage,\n AIMessage as CoreAIMessage,\n} from \"@langchain/core/messages\";\nimport {\n StreamOrchestrator,\n FetchStreamTransport,\n ensureMessageInstances,\n type MessageMetadata,\n type AnyStreamOptions,\n type ResolveStreamInterface,\n type ResolveStreamOptions,\n type InferBag,\n type InferStateType,\n type UseStreamCustomOptions,\n type WithClassMessages,\n} from \"@langchain/langgraph-sdk/ui\";\nimport {\n Client,\n type BagTemplate,\n type Message,\n type ToolCallWithResult as _ToolCallWithResult,\n type DefaultToolCall,\n} from \"@langchain/langgraph-sdk\";\nimport { useStreamCustom } from \"./stream.custom.js\";\n\nexport { FetchStreamTransport };\n\nconst STREAM_CONTEXT_KEY = Symbol.for(\"langchain:stream-context\");\n\n/**\n * Provides a `useStream` return value to all descendant components via\n * Svelte's context API. Must be called during component initialisation\n * (i.e. at the top level of a `<script>` block).\n *\n * @example\n * ```svelte\n * <script lang=\"ts\">\n * import { useStream, setStreamContext } from \"@langchain/svelte\";\n *\n * const stream = useStream({ assistantId: \"agent\", apiUrl: \"...\" });\n * setStreamContext(stream);\n * </script>\n *\n * <ChildComponent />\n * ```\n */\nexport function setStreamContext<T extends ReturnType<typeof useStream>>(\n stream: T\n): T {\n setContext(STREAM_CONTEXT_KEY, stream);\n return stream;\n}\n\n/**\n * Retrieves the `useStream` instance previously provided by a parent\n * component via {@link setStreamContext} or {@link provideStream}.\n * Must be called during component initialisation.\n *\n * @throws If no stream context has been set by an ancestor component.\n *\n * @example\n * ```svelte\n * <script lang=\"ts\">\n * import { getStreamContext } from \"@langchain/svelte\";\n *\n * const stream = getStreamContext();\n * </script>\n * ```\n */\nexport function getStreamContext<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(): WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>> {\n const ctx = getContext(STREAM_CONTEXT_KEY);\n if (!ctx) {\n throw new Error(\n \"getStreamContext must be used within a component that has called setStreamContext\"\n );\n }\n return ctx as WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>>;\n}\n\n/**\n * Creates a shared `useStream` instance and makes it available to all\n * descendant components via Svelte's `setContext`/`getContext`.\n *\n * Call this in a parent component's `<script>` block. Children access\n * the shared stream via {@link getStream}.\n *\n * Uses the same context key as {@link setStreamContext}/{@link getStreamContext},\n * so both retrieval functions work interchangeably.\n *\n * @example\n * ```svelte\n * <!-- ChatContainer.svelte -->\n * <script lang=\"ts\">\n * import { provideStream } from \"@langchain/svelte\";\n *\n * provideStream({\n * assistantId: \"agent\",\n * apiUrl: \"http://localhost:2024\",\n * });\n * </script>\n *\n * <ChatHeader />\n * <MessageList />\n * <MessageInput />\n * ```\n *\n * @returns The stream instance (same as calling `useStream` directly).\n */\nexport function provideStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(\n options:\n | ResolveStreamOptions<T, InferBag<T, Bag>>\n | UseStreamCustomOptions<InferStateType<T>, InferBag<T, Bag>>\n): ReturnType<typeof useStream<T, Bag>> {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const stream = useStream<T, Bag>(options as any);\n setContext(STREAM_CONTEXT_KEY, stream);\n return stream;\n}\n\n/**\n * Retrieves the shared stream instance from the nearest ancestor that\n * called {@link provideStream} or {@link setStreamContext}.\n *\n * Throws if no ancestor has provided a stream.\n *\n * @example\n * ```svelte\n * <!-- MessageList.svelte -->\n * <script lang=\"ts\">\n * import { getStream } from \"@langchain/svelte\";\n *\n * const stream = getStream();\n * </script>\n *\n * {#each stream.messages as msg (msg.id)}\n * <div>{msg.content}</div>\n * {/each}\n * ```\n */\nexport function getStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(): ReturnType<typeof useStream<T, Bag>> {\n const context = getContext(STREAM_CONTEXT_KEY);\n if (context == null) {\n throw new Error(\n \"getStream() requires a parent component to call provideStream(). \" +\n \"Add provideStream({ assistantId: '...' }) in an ancestor component.\"\n );\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return context as any;\n}\n\nexport type { ClassSubagentStreamInterface } from \"@langchain/langgraph-sdk/ui\";\n\nexport function useStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(\n options: ResolveStreamOptions<T, InferBag<T, Bag>>\n): WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>>;\n\nexport function useStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(\n options: UseStreamCustomOptions<InferStateType<T>, InferBag<T, Bag>>\n): WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>>;\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function useStream(options: any): any {\n if (\"transport\" in options) {\n return useStreamCustom(options);\n }\n return useStreamLGP(options);\n}\n\nfunction useStreamLGP<\n StateType extends Record<string, unknown> = Record<string, unknown>,\n Bag extends {\n ConfigurableType?: Record<string, unknown>;\n InterruptType?: unknown;\n CustomEventType?: unknown;\n UpdateType?: unknown;\n } = BagTemplate,\n>(options: AnyStreamOptions<StateType, Bag>) {\n const client = options.client ?? new Client({ apiUrl: options.apiUrl });\n\n const orchestrator = new StreamOrchestrator<StateType, Bag>(options, {\n getClient: () => client,\n getAssistantId: () => options.assistantId,\n getMessagesKey: () => options.messagesKey ?? \"messages\",\n });\n\n orchestrator.initThreadId(options.threadId ?? undefined);\n\n const version = writable(0);\n const unsubscribe = orchestrator.subscribe(() => {\n version.update((v) => v + 1);\n });\n\n let fetchController: AbortController | null = null;\n\n // Subagent reconstruction\n const shouldReconstructSubagents = derived(version, () => {\n const hvMessages = orchestrator.messages;\n if (!options.filterSubagentMessages) return false;\n if (orchestrator.isLoading || orchestrator.historyData.isLoading)\n return false;\n return hvMessages.length > 0;\n });\n\n const unsubReconstruct = shouldReconstructSubagents.subscribe(($should) => {\n if ($should) {\n fetchController?.abort();\n const controller = orchestrator.reconstructSubagentsIfNeeded();\n fetchController = controller;\n }\n });\n\n // Queue draining - must track isLoading specifically (not just version)\n // so the drain fires exactly when stream transitions from loading → idle\n const isLoadingForDrain = derived(version, () => orchestrator.isLoading);\n const unsubDrain = isLoadingForDrain.subscribe(() => {\n orchestrator.drainQueue();\n });\n\n // Auto-reconnect\n let { shouldReconnect } = orchestrator;\n\n onMount(() => {\n if (shouldReconnect) {\n const reconnected = orchestrator.tryReconnect();\n if (reconnected) shouldReconnect = false;\n }\n });\n\n onDestroy(() => {\n fetchController?.abort();\n unsubscribe();\n unsubReconstruct();\n unsubDrain();\n orchestrator.dispose();\n });\n\n // Derived stores\n const valuesStore = derived(version, () => {\n orchestrator.trackStreamMode(\"values\");\n return orchestrator.values;\n });\n const errorStore = derived(version, () => orchestrator.error);\n const isLoadingStore = derived(version, () => orchestrator.isLoading);\n const branchStore = derived(version, () => orchestrator.branch);\n const messagesStore = derived(version, () => {\n orchestrator.trackStreamMode(\"messages-tuple\", \"values\");\n return ensureMessageInstances(orchestrator.messages);\n });\n const toolCallsStore = derived(version, () => {\n orchestrator.trackStreamMode(\"messages-tuple\", \"values\");\n return orchestrator.toolCalls;\n });\n const interruptStore = derived(version, () => orchestrator.interrupt);\n const interruptsStore = derived(version, () => orchestrator.interrupts);\n const historyListStore = derived(version, () => orchestrator.flatHistory);\n const isThreadLoadingStore = derived(\n version,\n () => orchestrator.isThreadLoading\n );\n const experimentalBranchTreeStore = derived(\n version,\n () => orchestrator.experimental_branchTree\n );\n const subagentsStore = derived(version, () => {\n orchestrator.trackStreamMode(\"updates\", \"messages-tuple\");\n return orchestrator.subagents;\n });\n const activeSubagentsStore = derived(version, () => {\n orchestrator.trackStreamMode(\"updates\", \"messages-tuple\");\n return orchestrator.activeSubagents;\n });\n const queueEntriesStore = derived(version, () => orchestrator.queueEntries);\n const queueSizeStore = derived(version, () => orchestrator.queueSize);\n\n // fromStore adapters for Svelte 5\n const valuesRef = fromStore(valuesStore);\n const errorRef = fromStore(errorStore);\n const isLoadingRef = fromStore(isLoadingStore);\n const branchRef = fromStore(branchStore);\n const messagesRef = fromStore(messagesStore);\n const toolCallsRef = fromStore(toolCallsStore);\n const interruptRef = fromStore(interruptStore);\n const interruptsRef = fromStore(interruptsStore);\n const historyListRef = fromStore(historyListStore);\n const isThreadLoadingRef = fromStore(isThreadLoadingStore);\n const experimentalBranchTreeRef = fromStore(experimentalBranchTreeStore);\n const subagentsRef = fromStore(subagentsStore);\n const activeSubagentsRef = fromStore(activeSubagentsStore);\n const queueEntriesRef = fromStore(queueEntriesStore);\n const queueSizeRef = fromStore(queueSizeStore);\n\n return {\n assistantId: options.assistantId,\n client,\n\n get values() {\n return valuesRef.current;\n },\n get error() {\n return errorRef.current;\n },\n get isLoading() {\n return isLoadingRef.current;\n },\n get isThreadLoading() {\n return isThreadLoadingRef.current;\n },\n\n get branch() {\n return branchRef.current;\n },\n setBranch(value: string) {\n orchestrator.setBranch(value);\n },\n\n get messages() {\n return messagesRef.current;\n },\n get toolCalls() {\n return toolCallsRef.current;\n },\n getToolCalls(message: Message) {\n return orchestrator.getToolCalls(message);\n },\n\n get interrupt() {\n return interruptRef.current;\n },\n get interrupts() {\n return interruptsRef.current;\n },\n\n get history() {\n return historyListRef.current;\n },\n get experimental_branchTree() {\n return experimentalBranchTreeRef.current;\n },\n\n getMessagesMetadata(\n message: Message,\n index?: number\n ): MessageMetadata<StateType> | undefined {\n return orchestrator.getMessagesMetadata(message, index);\n },\n\n submit: (...args: Parameters<typeof orchestrator.submit>) =>\n orchestrator.submit(...args),\n stop: () => orchestrator.stop(),\n joinStream: (...args: Parameters<typeof orchestrator.joinStream>) =>\n orchestrator.joinStream(...args),\n\n queue: {\n get entries() {\n return queueEntriesRef.current;\n },\n get size() {\n return queueSizeRef.current;\n },\n cancel: (id: string) => orchestrator.cancelQueueItem(id),\n clear: () => orchestrator.clearQueue(),\n },\n\n switchThread(newThreadId: string | null) {\n orchestrator.switchThread(newThreadId);\n },\n\n get subagents() {\n return subagentsRef.current;\n },\n get activeSubagents() {\n return activeSubagentsRef.current;\n },\n getSubagent(toolCallId: string) {\n return orchestrator.getSubagent(toolCallId);\n },\n getSubagentsByType(type: string) {\n return orchestrator.getSubagentsByType(type);\n },\n getSubagentsByMessage(messageId: string) {\n return orchestrator.getSubagentsByMessage(messageId);\n },\n };\n}\n\nexport type {\n BaseStream,\n UseAgentStream,\n UseAgentStreamOptions,\n UseDeepAgentStream,\n UseDeepAgentStreamOptions,\n ResolveStreamInterface,\n ResolveStreamOptions,\n InferStateType,\n InferToolCalls,\n InferSubagentStates,\n InferNodeNames,\n InferBag,\n MessageMetadata,\n UseStreamOptions,\n UseStreamCustomOptions,\n UseStreamTransport,\n UseStreamThread,\n GetToolCallsType,\n AgentTypeConfigLike,\n IsAgentLike,\n ExtractAgentConfig,\n InferAgentToolCalls,\n SubagentToolCall,\n SubagentStatus,\n SubagentApi,\n SubagentStream,\n SubagentStreamInterface,\n SubAgentLike,\n CompiledSubAgentLike,\n DeepAgentTypeConfigLike,\n IsDeepAgentLike,\n ExtractDeepAgentConfig,\n ExtractSubAgentMiddleware,\n InferDeepAgentSubagents,\n InferSubagentByName,\n InferSubagentState,\n InferSubagentNames,\n SubagentStateMap,\n DefaultSubagentStates,\n BaseSubagentState,\n QueueEntry,\n QueueInterface,\n} from \"@langchain/langgraph-sdk/ui\";\n\nexport type ToolCallWithResult<ToolCall = DefaultToolCall> =\n _ToolCallWithResult<ToolCall, CoreToolMessage, CoreAIMessage>;\nexport type {\n ToolCallState,\n DefaultToolCall,\n ToolCallFromTool,\n ToolCallsFromTools,\n} from \"@langchain/langgraph-sdk\";\nexport type {\n HeadlessToolImplementation,\n AnyHeadlessToolImplementation,\n ToolEvent,\n HeadlessToolInterrupt,\n OnToolCallback,\n FlushPendingHeadlessToolInterruptsOptions,\n} from \"@langchain/langgraph-sdk\";\n\nexport {\n SubagentManager,\n extractToolCallIdFromNamespace,\n calculateDepthFromNamespace,\n extractParentIdFromNamespace,\n isSubagentNamespace,\n} from \"@langchain/langgraph-sdk/ui\";\nexport {\n isHeadlessToolInterrupt,\n parseHeadlessToolInterruptPayload,\n filterOutHeadlessToolInterrupts,\n findHeadlessTool,\n executeHeadlessTool,\n handleHeadlessToolInterrupt,\n headlessToolResumeCommand,\n flushPendingHeadlessToolInterrupts,\n} from \"@langchain/langgraph-sdk\";\n"],"mappings":"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"}
package/dist/index.d.cts CHANGED
@@ -1,6 +1,6 @@
1
1
  import { AIMessage, ToolMessage } from "@langchain/core/messages";
2
2
  import { AgentTypeConfigLike, BaseStream, BaseSubagentState, ClassSubagentStreamInterface, CompiledSubAgentLike, DeepAgentTypeConfigLike, DefaultSubagentStates, ExtractAgentConfig, ExtractDeepAgentConfig, ExtractSubAgentMiddleware, FetchStreamTransport, GetToolCallsType, InferAgentToolCalls, InferBag, InferBag as InferBag$1, InferDeepAgentSubagents, InferNodeNames, InferStateType, InferStateType as InferStateType$1, InferSubagentByName, InferSubagentNames, InferSubagentState, InferSubagentStates, InferToolCalls, IsAgentLike, IsDeepAgentLike, MessageMetadata, QueueEntry, QueueInterface, ResolveStreamInterface, ResolveStreamInterface as ResolveStreamInterface$1, ResolveStreamOptions, ResolveStreamOptions as ResolveStreamOptions$1, SubAgentLike, SubagentApi, SubagentManager, SubagentStateMap, SubagentStatus, SubagentStream, SubagentStreamInterface, SubagentToolCall, UseAgentStream, UseAgentStreamOptions, UseDeepAgentStream, UseDeepAgentStreamOptions, UseStreamCustomOptions, UseStreamCustomOptions as UseStreamCustomOptions$1, UseStreamOptions, UseStreamThread, UseStreamTransport, WithClassMessages, calculateDepthFromNamespace, extractParentIdFromNamespace, extractToolCallIdFromNamespace, isSubagentNamespace } from "@langchain/langgraph-sdk/ui";
3
- import { BagTemplate, DefaultToolCall, DefaultToolCall as DefaultToolCall$1, ToolCallFromTool, ToolCallState, ToolCallWithResult as ToolCallWithResult$1, ToolCallsFromTools } from "@langchain/langgraph-sdk";
3
+ import { AnyHeadlessToolImplementation, BagTemplate, DefaultToolCall, DefaultToolCall as DefaultToolCall$1, FlushPendingHeadlessToolInterruptsOptions, HeadlessToolImplementation, HeadlessToolInterrupt, OnToolCallback, ToolCallFromTool, ToolCallState, ToolCallWithResult as ToolCallWithResult$1, ToolCallsFromTools, ToolEvent, executeHeadlessTool, filterOutHeadlessToolInterrupts, findHeadlessTool, flushPendingHeadlessToolInterrupts, handleHeadlessToolInterrupt, headlessToolResumeCommand, isHeadlessToolInterrupt, parseHeadlessToolInterruptPayload } from "@langchain/langgraph-sdk";
4
4
 
5
5
  //#region src/index.d.ts
6
6
  /**
@@ -93,5 +93,5 @@ declare function useStream<T = Record<string, unknown>, Bag extends BagTemplate
93
93
  declare function useStream<T = Record<string, unknown>, Bag extends BagTemplate = BagTemplate>(options: UseStreamCustomOptions$1<InferStateType$1<T>, InferBag$1<T, Bag>>): WithClassMessages<ResolveStreamInterface$1<T, InferBag$1<T, Bag>>>;
94
94
  type ToolCallWithResult<ToolCall = DefaultToolCall$1> = ToolCallWithResult$1<ToolCall, ToolMessage, AIMessage>;
95
95
  //#endregion
96
- export { type AgentTypeConfigLike, type BaseStream, type BaseSubagentState, type ClassSubagentStreamInterface, type CompiledSubAgentLike, type DeepAgentTypeConfigLike, type DefaultSubagentStates, type DefaultToolCall, type ExtractAgentConfig, type ExtractDeepAgentConfig, type ExtractSubAgentMiddleware, FetchStreamTransport, type GetToolCallsType, type InferAgentToolCalls, type InferBag, type InferDeepAgentSubagents, type InferNodeNames, type InferStateType, type InferSubagentByName, type InferSubagentNames, type InferSubagentState, type InferSubagentStates, type InferToolCalls, type IsAgentLike, type IsDeepAgentLike, type MessageMetadata, type QueueEntry, type QueueInterface, type ResolveStreamInterface, type ResolveStreamOptions, type SubAgentLike, type SubagentApi, SubagentManager, type SubagentStateMap, type SubagentStatus, type SubagentStream, type SubagentStreamInterface, type SubagentToolCall, type ToolCallFromTool, type ToolCallState, ToolCallWithResult, type ToolCallsFromTools, type UseAgentStream, type UseAgentStreamOptions, type UseDeepAgentStream, type UseDeepAgentStreamOptions, type UseStreamCustomOptions, type UseStreamOptions, type UseStreamThread, type UseStreamTransport, calculateDepthFromNamespace, extractParentIdFromNamespace, extractToolCallIdFromNamespace, getStream, getStreamContext, isSubagentNamespace, provideStream, setStreamContext, useStream };
96
+ export { type AgentTypeConfigLike, type AnyHeadlessToolImplementation, type BaseStream, type BaseSubagentState, type ClassSubagentStreamInterface, type CompiledSubAgentLike, type DeepAgentTypeConfigLike, type DefaultSubagentStates, type DefaultToolCall, type ExtractAgentConfig, type ExtractDeepAgentConfig, type ExtractSubAgentMiddleware, FetchStreamTransport, type FlushPendingHeadlessToolInterruptsOptions, type GetToolCallsType, type HeadlessToolImplementation, type HeadlessToolInterrupt, type InferAgentToolCalls, type InferBag, type InferDeepAgentSubagents, type InferNodeNames, type InferStateType, type InferSubagentByName, type InferSubagentNames, type InferSubagentState, type InferSubagentStates, type InferToolCalls, type IsAgentLike, type IsDeepAgentLike, type MessageMetadata, type OnToolCallback, type QueueEntry, type QueueInterface, type ResolveStreamInterface, type ResolveStreamOptions, type SubAgentLike, type SubagentApi, SubagentManager, type SubagentStateMap, type SubagentStatus, type SubagentStream, type SubagentStreamInterface, type SubagentToolCall, type ToolCallFromTool, type ToolCallState, ToolCallWithResult, type ToolCallsFromTools, type ToolEvent, type UseAgentStream, type UseAgentStreamOptions, type UseDeepAgentStream, type UseDeepAgentStreamOptions, type UseStreamCustomOptions, type UseStreamOptions, type UseStreamThread, type UseStreamTransport, calculateDepthFromNamespace, executeHeadlessTool, extractParentIdFromNamespace, extractToolCallIdFromNamespace, filterOutHeadlessToolInterrupts, findHeadlessTool, flushPendingHeadlessToolInterrupts, getStream, getStreamContext, handleHeadlessToolInterrupt, headlessToolResumeCommand, isHeadlessToolInterrupt, isSubagentNamespace, parseHeadlessToolInterruptPayload, provideStream, setStreamContext, useStream };
97
97
  //# sourceMappingURL=index.d.cts.map
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import { AgentTypeConfigLike, BaseStream, BaseSubagentState, ClassSubagentStreamInterface, CompiledSubAgentLike, DeepAgentTypeConfigLike, DefaultSubagentStates, ExtractAgentConfig, ExtractDeepAgentConfig, ExtractSubAgentMiddleware, FetchStreamTransport, GetToolCallsType, InferAgentToolCalls, InferBag, InferBag as InferBag$1, InferDeepAgentSubagents, InferNodeNames, InferStateType, InferStateType as InferStateType$1, InferSubagentByName, InferSubagentNames, InferSubagentState, InferSubagentStates, InferToolCalls, IsAgentLike, IsDeepAgentLike, MessageMetadata, QueueEntry, QueueInterface, ResolveStreamInterface, ResolveStreamInterface as ResolveStreamInterface$1, ResolveStreamOptions, ResolveStreamOptions as ResolveStreamOptions$1, SubAgentLike, SubagentApi, SubagentManager, SubagentStateMap, SubagentStatus, SubagentStream, SubagentStreamInterface, SubagentToolCall, UseAgentStream, UseAgentStreamOptions, UseDeepAgentStream, UseDeepAgentStreamOptions, UseStreamCustomOptions, UseStreamCustomOptions as UseStreamCustomOptions$1, UseStreamOptions, UseStreamThread, UseStreamTransport, WithClassMessages, calculateDepthFromNamespace, extractParentIdFromNamespace, extractToolCallIdFromNamespace, isSubagentNamespace } from "@langchain/langgraph-sdk/ui";
2
- import { BagTemplate, DefaultToolCall, DefaultToolCall as DefaultToolCall$1, ToolCallFromTool, ToolCallState, ToolCallWithResult as ToolCallWithResult$1, ToolCallsFromTools } from "@langchain/langgraph-sdk";
2
+ import { AnyHeadlessToolImplementation, BagTemplate, DefaultToolCall, DefaultToolCall as DefaultToolCall$1, FlushPendingHeadlessToolInterruptsOptions, HeadlessToolImplementation, HeadlessToolInterrupt, OnToolCallback, ToolCallFromTool, ToolCallState, ToolCallWithResult as ToolCallWithResult$1, ToolCallsFromTools, ToolEvent, executeHeadlessTool, filterOutHeadlessToolInterrupts, findHeadlessTool, flushPendingHeadlessToolInterrupts, handleHeadlessToolInterrupt, headlessToolResumeCommand, isHeadlessToolInterrupt, parseHeadlessToolInterruptPayload } from "@langchain/langgraph-sdk";
3
3
  import { AIMessage, ToolMessage } from "@langchain/core/messages";
4
4
 
5
5
  //#region src/index.d.ts
@@ -93,5 +93,5 @@ declare function useStream<T = Record<string, unknown>, Bag extends BagTemplate
93
93
  declare function useStream<T = Record<string, unknown>, Bag extends BagTemplate = BagTemplate>(options: UseStreamCustomOptions$1<InferStateType$1<T>, InferBag$1<T, Bag>>): WithClassMessages<ResolveStreamInterface$1<T, InferBag$1<T, Bag>>>;
94
94
  type ToolCallWithResult<ToolCall = DefaultToolCall$1> = ToolCallWithResult$1<ToolCall, ToolMessage, AIMessage>;
95
95
  //#endregion
96
- export { type AgentTypeConfigLike, type BaseStream, type BaseSubagentState, type ClassSubagentStreamInterface, type CompiledSubAgentLike, type DeepAgentTypeConfigLike, type DefaultSubagentStates, type DefaultToolCall, type ExtractAgentConfig, type ExtractDeepAgentConfig, type ExtractSubAgentMiddleware, FetchStreamTransport, type GetToolCallsType, type InferAgentToolCalls, type InferBag, type InferDeepAgentSubagents, type InferNodeNames, type InferStateType, type InferSubagentByName, type InferSubagentNames, type InferSubagentState, type InferSubagentStates, type InferToolCalls, type IsAgentLike, type IsDeepAgentLike, type MessageMetadata, type QueueEntry, type QueueInterface, type ResolveStreamInterface, type ResolveStreamOptions, type SubAgentLike, type SubagentApi, SubagentManager, type SubagentStateMap, type SubagentStatus, type SubagentStream, type SubagentStreamInterface, type SubagentToolCall, type ToolCallFromTool, type ToolCallState, ToolCallWithResult, type ToolCallsFromTools, type UseAgentStream, type UseAgentStreamOptions, type UseDeepAgentStream, type UseDeepAgentStreamOptions, type UseStreamCustomOptions, type UseStreamOptions, type UseStreamThread, type UseStreamTransport, calculateDepthFromNamespace, extractParentIdFromNamespace, extractToolCallIdFromNamespace, getStream, getStreamContext, isSubagentNamespace, provideStream, setStreamContext, useStream };
96
+ export { type AgentTypeConfigLike, type AnyHeadlessToolImplementation, type BaseStream, type BaseSubagentState, type ClassSubagentStreamInterface, type CompiledSubAgentLike, type DeepAgentTypeConfigLike, type DefaultSubagentStates, type DefaultToolCall, type ExtractAgentConfig, type ExtractDeepAgentConfig, type ExtractSubAgentMiddleware, FetchStreamTransport, type FlushPendingHeadlessToolInterruptsOptions, type GetToolCallsType, type HeadlessToolImplementation, type HeadlessToolInterrupt, type InferAgentToolCalls, type InferBag, type InferDeepAgentSubagents, type InferNodeNames, type InferStateType, type InferSubagentByName, type InferSubagentNames, type InferSubagentState, type InferSubagentStates, type InferToolCalls, type IsAgentLike, type IsDeepAgentLike, type MessageMetadata, type OnToolCallback, type QueueEntry, type QueueInterface, type ResolveStreamInterface, type ResolveStreamOptions, type SubAgentLike, type SubagentApi, SubagentManager, type SubagentStateMap, type SubagentStatus, type SubagentStream, type SubagentStreamInterface, type SubagentToolCall, type ToolCallFromTool, type ToolCallState, ToolCallWithResult, type ToolCallsFromTools, type ToolEvent, type UseAgentStream, type UseAgentStreamOptions, type UseDeepAgentStream, type UseDeepAgentStreamOptions, type UseStreamCustomOptions, type UseStreamOptions, type UseStreamThread, type UseStreamTransport, calculateDepthFromNamespace, executeHeadlessTool, extractParentIdFromNamespace, extractToolCallIdFromNamespace, filterOutHeadlessToolInterrupts, findHeadlessTool, flushPendingHeadlessToolInterrupts, getStream, getStreamContext, handleHeadlessToolInterrupt, headlessToolResumeCommand, isHeadlessToolInterrupt, isSubagentNamespace, parseHeadlessToolInterruptPayload, provideStream, setStreamContext, useStream };
97
97
  //# sourceMappingURL=index.d.ts.map
package/dist/index.js CHANGED
@@ -2,7 +2,7 @@ import { useStreamCustom } from "./stream.custom.js";
2
2
  import { derived, fromStore, writable } from "svelte/store";
3
3
  import { getContext, onDestroy, onMount, setContext } from "svelte";
4
4
  import { FetchStreamTransport, StreamOrchestrator, SubagentManager, calculateDepthFromNamespace, ensureMessageInstances, extractParentIdFromNamespace, extractToolCallIdFromNamespace, isSubagentNamespace } from "@langchain/langgraph-sdk/ui";
5
- import { Client } from "@langchain/langgraph-sdk";
5
+ import { Client, executeHeadlessTool, filterOutHeadlessToolInterrupts, findHeadlessTool, flushPendingHeadlessToolInterrupts, handleHeadlessToolInterrupt, headlessToolResumeCommand, isHeadlessToolInterrupt, parseHeadlessToolInterruptPayload } from "@langchain/langgraph-sdk";
6
6
  //#region src/index.ts
7
7
  const STREAM_CONTEXT_KEY = Symbol.for("langchain:stream-context");
8
8
  /**
@@ -274,6 +274,6 @@ function useStreamLGP(options) {
274
274
  };
275
275
  }
276
276
  //#endregion
277
- export { FetchStreamTransport, SubagentManager, calculateDepthFromNamespace, extractParentIdFromNamespace, extractToolCallIdFromNamespace, getStream, getStreamContext, isSubagentNamespace, provideStream, setStreamContext, useStream };
277
+ export { FetchStreamTransport, SubagentManager, calculateDepthFromNamespace, executeHeadlessTool, extractParentIdFromNamespace, extractToolCallIdFromNamespace, filterOutHeadlessToolInterrupts, findHeadlessTool, flushPendingHeadlessToolInterrupts, getStream, getStreamContext, handleHeadlessToolInterrupt, headlessToolResumeCommand, isHeadlessToolInterrupt, isSubagentNamespace, parseHeadlessToolInterruptPayload, provideStream, setStreamContext, useStream };
278
278
 
279
279
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":[],"sources":["../src/index.ts"],"sourcesContent":["import { writable, derived, fromStore } from \"svelte/store\";\nimport { onDestroy, onMount, setContext, getContext } from \"svelte\";\n\nimport type {\n ToolMessage as CoreToolMessage,\n AIMessage as CoreAIMessage,\n} from \"@langchain/core/messages\";\nimport {\n StreamOrchestrator,\n FetchStreamTransport,\n ensureMessageInstances,\n type MessageMetadata,\n type AnyStreamOptions,\n type ResolveStreamInterface,\n type ResolveStreamOptions,\n type InferBag,\n type InferStateType,\n type UseStreamCustomOptions,\n type WithClassMessages,\n} from \"@langchain/langgraph-sdk/ui\";\nimport {\n Client,\n type BagTemplate,\n type Message,\n type ToolCallWithResult as _ToolCallWithResult,\n type DefaultToolCall,\n} from \"@langchain/langgraph-sdk\";\nimport { useStreamCustom } from \"./stream.custom.js\";\n\nexport { FetchStreamTransport };\n\nconst STREAM_CONTEXT_KEY = Symbol.for(\"langchain:stream-context\");\n\n/**\n * Provides a `useStream` return value to all descendant components via\n * Svelte's context API. Must be called during component initialisation\n * (i.e. at the top level of a `<script>` block).\n *\n * @example\n * ```svelte\n * <script lang=\"ts\">\n * import { useStream, setStreamContext } from \"@langchain/svelte\";\n *\n * const stream = useStream({ assistantId: \"agent\", apiUrl: \"...\" });\n * setStreamContext(stream);\n * </script>\n *\n * <ChildComponent />\n * ```\n */\nexport function setStreamContext<T extends ReturnType<typeof useStream>>(\n stream: T\n): T {\n setContext(STREAM_CONTEXT_KEY, stream);\n return stream;\n}\n\n/**\n * Retrieves the `useStream` instance previously provided by a parent\n * component via {@link setStreamContext} or {@link provideStream}.\n * Must be called during component initialisation.\n *\n * @throws If no stream context has been set by an ancestor component.\n *\n * @example\n * ```svelte\n * <script lang=\"ts\">\n * import { getStreamContext } from \"@langchain/svelte\";\n *\n * const stream = getStreamContext();\n * </script>\n * ```\n */\nexport function getStreamContext<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(): WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>> {\n const ctx = getContext(STREAM_CONTEXT_KEY);\n if (!ctx) {\n throw new Error(\n \"getStreamContext must be used within a component that has called setStreamContext\"\n );\n }\n return ctx as WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>>;\n}\n\n/**\n * Creates a shared `useStream` instance and makes it available to all\n * descendant components via Svelte's `setContext`/`getContext`.\n *\n * Call this in a parent component's `<script>` block. Children access\n * the shared stream via {@link getStream}.\n *\n * Uses the same context key as {@link setStreamContext}/{@link getStreamContext},\n * so both retrieval functions work interchangeably.\n *\n * @example\n * ```svelte\n * <!-- ChatContainer.svelte -->\n * <script lang=\"ts\">\n * import { provideStream } from \"@langchain/svelte\";\n *\n * provideStream({\n * assistantId: \"agent\",\n * apiUrl: \"http://localhost:2024\",\n * });\n * </script>\n *\n * <ChatHeader />\n * <MessageList />\n * <MessageInput />\n * ```\n *\n * @returns The stream instance (same as calling `useStream` directly).\n */\nexport function provideStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(\n options:\n | ResolveStreamOptions<T, InferBag<T, Bag>>\n | UseStreamCustomOptions<InferStateType<T>, InferBag<T, Bag>>\n): ReturnType<typeof useStream<T, Bag>> {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const stream = useStream<T, Bag>(options as any);\n setContext(STREAM_CONTEXT_KEY, stream);\n return stream;\n}\n\n/**\n * Retrieves the shared stream instance from the nearest ancestor that\n * called {@link provideStream} or {@link setStreamContext}.\n *\n * Throws if no ancestor has provided a stream.\n *\n * @example\n * ```svelte\n * <!-- MessageList.svelte -->\n * <script lang=\"ts\">\n * import { getStream } from \"@langchain/svelte\";\n *\n * const stream = getStream();\n * </script>\n *\n * {#each stream.messages as msg (msg.id)}\n * <div>{msg.content}</div>\n * {/each}\n * ```\n */\nexport function getStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(): ReturnType<typeof useStream<T, Bag>> {\n const context = getContext(STREAM_CONTEXT_KEY);\n if (context == null) {\n throw new Error(\n \"getStream() requires a parent component to call provideStream(). \" +\n \"Add provideStream({ assistantId: '...' }) in an ancestor component.\"\n );\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return context as any;\n}\n\nexport type { ClassSubagentStreamInterface } from \"@langchain/langgraph-sdk/ui\";\n\nexport function useStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(\n options: ResolveStreamOptions<T, InferBag<T, Bag>>\n): WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>>;\n\nexport function useStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(\n options: UseStreamCustomOptions<InferStateType<T>, InferBag<T, Bag>>\n): WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>>;\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function useStream(options: any): any {\n if (\"transport\" in options) {\n return useStreamCustom(options);\n }\n return useStreamLGP(options);\n}\n\nfunction useStreamLGP<\n StateType extends Record<string, unknown> = Record<string, unknown>,\n Bag extends {\n ConfigurableType?: Record<string, unknown>;\n InterruptType?: unknown;\n CustomEventType?: unknown;\n UpdateType?: unknown;\n } = BagTemplate,\n>(options: AnyStreamOptions<StateType, Bag>) {\n const client = options.client ?? new Client({ apiUrl: options.apiUrl });\n\n const orchestrator = new StreamOrchestrator<StateType, Bag>(options, {\n getClient: () => client,\n getAssistantId: () => options.assistantId,\n getMessagesKey: () => options.messagesKey ?? \"messages\",\n });\n\n orchestrator.initThreadId(options.threadId ?? undefined);\n\n const version = writable(0);\n const unsubscribe = orchestrator.subscribe(() => {\n version.update((v) => v + 1);\n });\n\n let fetchController: AbortController | null = null;\n\n // Subagent reconstruction\n const shouldReconstructSubagents = derived(version, () => {\n const hvMessages = orchestrator.messages;\n if (!options.filterSubagentMessages) return false;\n if (orchestrator.isLoading || orchestrator.historyData.isLoading)\n return false;\n return hvMessages.length > 0;\n });\n\n const unsubReconstruct = shouldReconstructSubagents.subscribe(($should) => {\n if ($should) {\n fetchController?.abort();\n const controller = orchestrator.reconstructSubagentsIfNeeded();\n fetchController = controller;\n }\n });\n\n // Queue draining - must track isLoading specifically (not just version)\n // so the drain fires exactly when stream transitions from loading → idle\n const isLoadingForDrain = derived(version, () => orchestrator.isLoading);\n const unsubDrain = isLoadingForDrain.subscribe(() => {\n orchestrator.drainQueue();\n });\n\n // Auto-reconnect\n let { shouldReconnect } = orchestrator;\n\n onMount(() => {\n if (shouldReconnect) {\n const reconnected = orchestrator.tryReconnect();\n if (reconnected) shouldReconnect = false;\n }\n });\n\n onDestroy(() => {\n fetchController?.abort();\n unsubscribe();\n unsubReconstruct();\n unsubDrain();\n orchestrator.dispose();\n });\n\n // Derived stores\n const valuesStore = derived(version, () => {\n orchestrator.trackStreamMode(\"values\");\n return orchestrator.values;\n });\n const errorStore = derived(version, () => orchestrator.error);\n const isLoadingStore = derived(version, () => orchestrator.isLoading);\n const branchStore = derived(version, () => orchestrator.branch);\n const messagesStore = derived(version, () => {\n orchestrator.trackStreamMode(\"messages-tuple\", \"values\");\n return ensureMessageInstances(orchestrator.messages);\n });\n const toolCallsStore = derived(version, () => {\n orchestrator.trackStreamMode(\"messages-tuple\", \"values\");\n return orchestrator.toolCalls;\n });\n const interruptStore = derived(version, () => orchestrator.interrupt);\n const interruptsStore = derived(version, () => orchestrator.interrupts);\n const historyListStore = derived(version, () => orchestrator.flatHistory);\n const isThreadLoadingStore = derived(\n version,\n () => orchestrator.isThreadLoading\n );\n const experimentalBranchTreeStore = derived(\n version,\n () => orchestrator.experimental_branchTree\n );\n const subagentsStore = derived(version, () => {\n orchestrator.trackStreamMode(\"updates\", \"messages-tuple\");\n return orchestrator.subagents;\n });\n const activeSubagentsStore = derived(version, () => {\n orchestrator.trackStreamMode(\"updates\", \"messages-tuple\");\n return orchestrator.activeSubagents;\n });\n const queueEntriesStore = derived(version, () => orchestrator.queueEntries);\n const queueSizeStore = derived(version, () => orchestrator.queueSize);\n\n // fromStore adapters for Svelte 5\n const valuesRef = fromStore(valuesStore);\n const errorRef = fromStore(errorStore);\n const isLoadingRef = fromStore(isLoadingStore);\n const branchRef = fromStore(branchStore);\n const messagesRef = fromStore(messagesStore);\n const toolCallsRef = fromStore(toolCallsStore);\n const interruptRef = fromStore(interruptStore);\n const interruptsRef = fromStore(interruptsStore);\n const historyListRef = fromStore(historyListStore);\n const isThreadLoadingRef = fromStore(isThreadLoadingStore);\n const experimentalBranchTreeRef = fromStore(experimentalBranchTreeStore);\n const subagentsRef = fromStore(subagentsStore);\n const activeSubagentsRef = fromStore(activeSubagentsStore);\n const queueEntriesRef = fromStore(queueEntriesStore);\n const queueSizeRef = fromStore(queueSizeStore);\n\n return {\n assistantId: options.assistantId,\n client,\n\n get values() {\n return valuesRef.current;\n },\n get error() {\n return errorRef.current;\n },\n get isLoading() {\n return isLoadingRef.current;\n },\n get isThreadLoading() {\n return isThreadLoadingRef.current;\n },\n\n get branch() {\n return branchRef.current;\n },\n setBranch(value: string) {\n orchestrator.setBranch(value);\n },\n\n get messages() {\n return messagesRef.current;\n },\n get toolCalls() {\n return toolCallsRef.current;\n },\n getToolCalls(message: Message) {\n return orchestrator.getToolCalls(message);\n },\n\n get interrupt() {\n return interruptRef.current;\n },\n get interrupts() {\n return interruptsRef.current;\n },\n\n get history() {\n return historyListRef.current;\n },\n get experimental_branchTree() {\n return experimentalBranchTreeRef.current;\n },\n\n getMessagesMetadata(\n message: Message,\n index?: number\n ): MessageMetadata<StateType> | undefined {\n return orchestrator.getMessagesMetadata(message, index);\n },\n\n submit: (...args: Parameters<typeof orchestrator.submit>) =>\n orchestrator.submit(...args),\n stop: () => orchestrator.stop(),\n joinStream: (...args: Parameters<typeof orchestrator.joinStream>) =>\n orchestrator.joinStream(...args),\n\n queue: {\n get entries() {\n return queueEntriesRef.current;\n },\n get size() {\n return queueSizeRef.current;\n },\n cancel: (id: string) => orchestrator.cancelQueueItem(id),\n clear: () => orchestrator.clearQueue(),\n },\n\n switchThread(newThreadId: string | null) {\n orchestrator.switchThread(newThreadId);\n },\n\n get subagents() {\n return subagentsRef.current;\n },\n get activeSubagents() {\n return activeSubagentsRef.current;\n },\n getSubagent(toolCallId: string) {\n return orchestrator.getSubagent(toolCallId);\n },\n getSubagentsByType(type: string) {\n return orchestrator.getSubagentsByType(type);\n },\n getSubagentsByMessage(messageId: string) {\n return orchestrator.getSubagentsByMessage(messageId);\n },\n };\n}\n\nexport type {\n BaseStream,\n UseAgentStream,\n UseAgentStreamOptions,\n UseDeepAgentStream,\n UseDeepAgentStreamOptions,\n ResolveStreamInterface,\n ResolveStreamOptions,\n InferStateType,\n InferToolCalls,\n InferSubagentStates,\n InferNodeNames,\n InferBag,\n MessageMetadata,\n UseStreamOptions,\n UseStreamCustomOptions,\n UseStreamTransport,\n UseStreamThread,\n GetToolCallsType,\n AgentTypeConfigLike,\n IsAgentLike,\n ExtractAgentConfig,\n InferAgentToolCalls,\n SubagentToolCall,\n SubagentStatus,\n SubagentApi,\n SubagentStream,\n SubagentStreamInterface,\n SubAgentLike,\n CompiledSubAgentLike,\n DeepAgentTypeConfigLike,\n IsDeepAgentLike,\n ExtractDeepAgentConfig,\n ExtractSubAgentMiddleware,\n InferDeepAgentSubagents,\n InferSubagentByName,\n InferSubagentState,\n InferSubagentNames,\n SubagentStateMap,\n DefaultSubagentStates,\n BaseSubagentState,\n QueueEntry,\n QueueInterface,\n} from \"@langchain/langgraph-sdk/ui\";\n\nexport type ToolCallWithResult<ToolCall = DefaultToolCall> =\n _ToolCallWithResult<ToolCall, CoreToolMessage, CoreAIMessage>;\nexport type {\n ToolCallState,\n DefaultToolCall,\n ToolCallFromTool,\n ToolCallsFromTools,\n} from \"@langchain/langgraph-sdk\";\n\nexport {\n SubagentManager,\n extractToolCallIdFromNamespace,\n calculateDepthFromNamespace,\n extractParentIdFromNamespace,\n isSubagentNamespace,\n} from \"@langchain/langgraph-sdk/ui\";\n"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","names":[],"sources":["../src/index.ts"],"sourcesContent":["import { writable, derived, fromStore } from \"svelte/store\";\nimport { onDestroy, onMount, setContext, getContext } from \"svelte\";\n\nimport type {\n ToolMessage as CoreToolMessage,\n AIMessage as CoreAIMessage,\n} from \"@langchain/core/messages\";\nimport {\n StreamOrchestrator,\n FetchStreamTransport,\n ensureMessageInstances,\n type MessageMetadata,\n type AnyStreamOptions,\n type ResolveStreamInterface,\n type ResolveStreamOptions,\n type InferBag,\n type InferStateType,\n type UseStreamCustomOptions,\n type WithClassMessages,\n} from \"@langchain/langgraph-sdk/ui\";\nimport {\n Client,\n type BagTemplate,\n type Message,\n type ToolCallWithResult as _ToolCallWithResult,\n type DefaultToolCall,\n} from \"@langchain/langgraph-sdk\";\nimport { useStreamCustom } from \"./stream.custom.js\";\n\nexport { FetchStreamTransport };\n\nconst STREAM_CONTEXT_KEY = Symbol.for(\"langchain:stream-context\");\n\n/**\n * Provides a `useStream` return value to all descendant components via\n * Svelte's context API. Must be called during component initialisation\n * (i.e. at the top level of a `<script>` block).\n *\n * @example\n * ```svelte\n * <script lang=\"ts\">\n * import { useStream, setStreamContext } from \"@langchain/svelte\";\n *\n * const stream = useStream({ assistantId: \"agent\", apiUrl: \"...\" });\n * setStreamContext(stream);\n * </script>\n *\n * <ChildComponent />\n * ```\n */\nexport function setStreamContext<T extends ReturnType<typeof useStream>>(\n stream: T\n): T {\n setContext(STREAM_CONTEXT_KEY, stream);\n return stream;\n}\n\n/**\n * Retrieves the `useStream` instance previously provided by a parent\n * component via {@link setStreamContext} or {@link provideStream}.\n * Must be called during component initialisation.\n *\n * @throws If no stream context has been set by an ancestor component.\n *\n * @example\n * ```svelte\n * <script lang=\"ts\">\n * import { getStreamContext } from \"@langchain/svelte\";\n *\n * const stream = getStreamContext();\n * </script>\n * ```\n */\nexport function getStreamContext<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(): WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>> {\n const ctx = getContext(STREAM_CONTEXT_KEY);\n if (!ctx) {\n throw new Error(\n \"getStreamContext must be used within a component that has called setStreamContext\"\n );\n }\n return ctx as WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>>;\n}\n\n/**\n * Creates a shared `useStream` instance and makes it available to all\n * descendant components via Svelte's `setContext`/`getContext`.\n *\n * Call this in a parent component's `<script>` block. Children access\n * the shared stream via {@link getStream}.\n *\n * Uses the same context key as {@link setStreamContext}/{@link getStreamContext},\n * so both retrieval functions work interchangeably.\n *\n * @example\n * ```svelte\n * <!-- ChatContainer.svelte -->\n * <script lang=\"ts\">\n * import { provideStream } from \"@langchain/svelte\";\n *\n * provideStream({\n * assistantId: \"agent\",\n * apiUrl: \"http://localhost:2024\",\n * });\n * </script>\n *\n * <ChatHeader />\n * <MessageList />\n * <MessageInput />\n * ```\n *\n * @returns The stream instance (same as calling `useStream` directly).\n */\nexport function provideStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(\n options:\n | ResolveStreamOptions<T, InferBag<T, Bag>>\n | UseStreamCustomOptions<InferStateType<T>, InferBag<T, Bag>>\n): ReturnType<typeof useStream<T, Bag>> {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const stream = useStream<T, Bag>(options as any);\n setContext(STREAM_CONTEXT_KEY, stream);\n return stream;\n}\n\n/**\n * Retrieves the shared stream instance from the nearest ancestor that\n * called {@link provideStream} or {@link setStreamContext}.\n *\n * Throws if no ancestor has provided a stream.\n *\n * @example\n * ```svelte\n * <!-- MessageList.svelte -->\n * <script lang=\"ts\">\n * import { getStream } from \"@langchain/svelte\";\n *\n * const stream = getStream();\n * </script>\n *\n * {#each stream.messages as msg (msg.id)}\n * <div>{msg.content}</div>\n * {/each}\n * ```\n */\nexport function getStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(): ReturnType<typeof useStream<T, Bag>> {\n const context = getContext(STREAM_CONTEXT_KEY);\n if (context == null) {\n throw new Error(\n \"getStream() requires a parent component to call provideStream(). \" +\n \"Add provideStream({ assistantId: '...' }) in an ancestor component.\"\n );\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return context as any;\n}\n\nexport type { ClassSubagentStreamInterface } from \"@langchain/langgraph-sdk/ui\";\n\nexport function useStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(\n options: ResolveStreamOptions<T, InferBag<T, Bag>>\n): WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>>;\n\nexport function useStream<\n T = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(\n options: UseStreamCustomOptions<InferStateType<T>, InferBag<T, Bag>>\n): WithClassMessages<ResolveStreamInterface<T, InferBag<T, Bag>>>;\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function useStream(options: any): any {\n if (\"transport\" in options) {\n return useStreamCustom(options);\n }\n return useStreamLGP(options);\n}\n\nfunction useStreamLGP<\n StateType extends Record<string, unknown> = Record<string, unknown>,\n Bag extends {\n ConfigurableType?: Record<string, unknown>;\n InterruptType?: unknown;\n CustomEventType?: unknown;\n UpdateType?: unknown;\n } = BagTemplate,\n>(options: AnyStreamOptions<StateType, Bag>) {\n const client = options.client ?? new Client({ apiUrl: options.apiUrl });\n\n const orchestrator = new StreamOrchestrator<StateType, Bag>(options, {\n getClient: () => client,\n getAssistantId: () => options.assistantId,\n getMessagesKey: () => options.messagesKey ?? \"messages\",\n });\n\n orchestrator.initThreadId(options.threadId ?? undefined);\n\n const version = writable(0);\n const unsubscribe = orchestrator.subscribe(() => {\n version.update((v) => v + 1);\n });\n\n let fetchController: AbortController | null = null;\n\n // Subagent reconstruction\n const shouldReconstructSubagents = derived(version, () => {\n const hvMessages = orchestrator.messages;\n if (!options.filterSubagentMessages) return false;\n if (orchestrator.isLoading || orchestrator.historyData.isLoading)\n return false;\n return hvMessages.length > 0;\n });\n\n const unsubReconstruct = shouldReconstructSubagents.subscribe(($should) => {\n if ($should) {\n fetchController?.abort();\n const controller = orchestrator.reconstructSubagentsIfNeeded();\n fetchController = controller;\n }\n });\n\n // Queue draining - must track isLoading specifically (not just version)\n // so the drain fires exactly when stream transitions from loading → idle\n const isLoadingForDrain = derived(version, () => orchestrator.isLoading);\n const unsubDrain = isLoadingForDrain.subscribe(() => {\n orchestrator.drainQueue();\n });\n\n // Auto-reconnect\n let { shouldReconnect } = orchestrator;\n\n onMount(() => {\n if (shouldReconnect) {\n const reconnected = orchestrator.tryReconnect();\n if (reconnected) shouldReconnect = false;\n }\n });\n\n onDestroy(() => {\n fetchController?.abort();\n unsubscribe();\n unsubReconstruct();\n unsubDrain();\n orchestrator.dispose();\n });\n\n // Derived stores\n const valuesStore = derived(version, () => {\n orchestrator.trackStreamMode(\"values\");\n return orchestrator.values;\n });\n const errorStore = derived(version, () => orchestrator.error);\n const isLoadingStore = derived(version, () => orchestrator.isLoading);\n const branchStore = derived(version, () => orchestrator.branch);\n const messagesStore = derived(version, () => {\n orchestrator.trackStreamMode(\"messages-tuple\", \"values\");\n return ensureMessageInstances(orchestrator.messages);\n });\n const toolCallsStore = derived(version, () => {\n orchestrator.trackStreamMode(\"messages-tuple\", \"values\");\n return orchestrator.toolCalls;\n });\n const interruptStore = derived(version, () => orchestrator.interrupt);\n const interruptsStore = derived(version, () => orchestrator.interrupts);\n const historyListStore = derived(version, () => orchestrator.flatHistory);\n const isThreadLoadingStore = derived(\n version,\n () => orchestrator.isThreadLoading\n );\n const experimentalBranchTreeStore = derived(\n version,\n () => orchestrator.experimental_branchTree\n );\n const subagentsStore = derived(version, () => {\n orchestrator.trackStreamMode(\"updates\", \"messages-tuple\");\n return orchestrator.subagents;\n });\n const activeSubagentsStore = derived(version, () => {\n orchestrator.trackStreamMode(\"updates\", \"messages-tuple\");\n return orchestrator.activeSubagents;\n });\n const queueEntriesStore = derived(version, () => orchestrator.queueEntries);\n const queueSizeStore = derived(version, () => orchestrator.queueSize);\n\n // fromStore adapters for Svelte 5\n const valuesRef = fromStore(valuesStore);\n const errorRef = fromStore(errorStore);\n const isLoadingRef = fromStore(isLoadingStore);\n const branchRef = fromStore(branchStore);\n const messagesRef = fromStore(messagesStore);\n const toolCallsRef = fromStore(toolCallsStore);\n const interruptRef = fromStore(interruptStore);\n const interruptsRef = fromStore(interruptsStore);\n const historyListRef = fromStore(historyListStore);\n const isThreadLoadingRef = fromStore(isThreadLoadingStore);\n const experimentalBranchTreeRef = fromStore(experimentalBranchTreeStore);\n const subagentsRef = fromStore(subagentsStore);\n const activeSubagentsRef = fromStore(activeSubagentsStore);\n const queueEntriesRef = fromStore(queueEntriesStore);\n const queueSizeRef = fromStore(queueSizeStore);\n\n return {\n assistantId: options.assistantId,\n client,\n\n get values() {\n return valuesRef.current;\n },\n get error() {\n return errorRef.current;\n },\n get isLoading() {\n return isLoadingRef.current;\n },\n get isThreadLoading() {\n return isThreadLoadingRef.current;\n },\n\n get branch() {\n return branchRef.current;\n },\n setBranch(value: string) {\n orchestrator.setBranch(value);\n },\n\n get messages() {\n return messagesRef.current;\n },\n get toolCalls() {\n return toolCallsRef.current;\n },\n getToolCalls(message: Message) {\n return orchestrator.getToolCalls(message);\n },\n\n get interrupt() {\n return interruptRef.current;\n },\n get interrupts() {\n return interruptsRef.current;\n },\n\n get history() {\n return historyListRef.current;\n },\n get experimental_branchTree() {\n return experimentalBranchTreeRef.current;\n },\n\n getMessagesMetadata(\n message: Message,\n index?: number\n ): MessageMetadata<StateType> | undefined {\n return orchestrator.getMessagesMetadata(message, index);\n },\n\n submit: (...args: Parameters<typeof orchestrator.submit>) =>\n orchestrator.submit(...args),\n stop: () => orchestrator.stop(),\n joinStream: (...args: Parameters<typeof orchestrator.joinStream>) =>\n orchestrator.joinStream(...args),\n\n queue: {\n get entries() {\n return queueEntriesRef.current;\n },\n get size() {\n return queueSizeRef.current;\n },\n cancel: (id: string) => orchestrator.cancelQueueItem(id),\n clear: () => orchestrator.clearQueue(),\n },\n\n switchThread(newThreadId: string | null) {\n orchestrator.switchThread(newThreadId);\n },\n\n get subagents() {\n return subagentsRef.current;\n },\n get activeSubagents() {\n return activeSubagentsRef.current;\n },\n getSubagent(toolCallId: string) {\n return orchestrator.getSubagent(toolCallId);\n },\n getSubagentsByType(type: string) {\n return orchestrator.getSubagentsByType(type);\n },\n getSubagentsByMessage(messageId: string) {\n return orchestrator.getSubagentsByMessage(messageId);\n },\n };\n}\n\nexport type {\n BaseStream,\n UseAgentStream,\n UseAgentStreamOptions,\n UseDeepAgentStream,\n UseDeepAgentStreamOptions,\n ResolveStreamInterface,\n ResolveStreamOptions,\n InferStateType,\n InferToolCalls,\n InferSubagentStates,\n InferNodeNames,\n InferBag,\n MessageMetadata,\n UseStreamOptions,\n UseStreamCustomOptions,\n UseStreamTransport,\n UseStreamThread,\n GetToolCallsType,\n AgentTypeConfigLike,\n IsAgentLike,\n ExtractAgentConfig,\n InferAgentToolCalls,\n SubagentToolCall,\n SubagentStatus,\n SubagentApi,\n SubagentStream,\n SubagentStreamInterface,\n SubAgentLike,\n CompiledSubAgentLike,\n DeepAgentTypeConfigLike,\n IsDeepAgentLike,\n ExtractDeepAgentConfig,\n ExtractSubAgentMiddleware,\n InferDeepAgentSubagents,\n InferSubagentByName,\n InferSubagentState,\n InferSubagentNames,\n SubagentStateMap,\n DefaultSubagentStates,\n BaseSubagentState,\n QueueEntry,\n QueueInterface,\n} from \"@langchain/langgraph-sdk/ui\";\n\nexport type ToolCallWithResult<ToolCall = DefaultToolCall> =\n _ToolCallWithResult<ToolCall, CoreToolMessage, CoreAIMessage>;\nexport type {\n ToolCallState,\n DefaultToolCall,\n ToolCallFromTool,\n ToolCallsFromTools,\n} from \"@langchain/langgraph-sdk\";\nexport type {\n HeadlessToolImplementation,\n AnyHeadlessToolImplementation,\n ToolEvent,\n HeadlessToolInterrupt,\n OnToolCallback,\n FlushPendingHeadlessToolInterruptsOptions,\n} from \"@langchain/langgraph-sdk\";\n\nexport {\n SubagentManager,\n extractToolCallIdFromNamespace,\n calculateDepthFromNamespace,\n extractParentIdFromNamespace,\n isSubagentNamespace,\n} from \"@langchain/langgraph-sdk/ui\";\nexport {\n isHeadlessToolInterrupt,\n parseHeadlessToolInterruptPayload,\n filterOutHeadlessToolInterrupts,\n findHeadlessTool,\n executeHeadlessTool,\n handleHeadlessToolInterrupt,\n headlessToolResumeCommand,\n flushPendingHeadlessToolInterrupts,\n} from \"@langchain/langgraph-sdk\";\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@langchain/svelte",
3
- "version": "0.4.0",
3
+ "version": "0.4.2",
4
4
  "description": "Svelte integration for LangGraph & LangChain",
5
5
  "type": "module",
6
6
  "license": "MIT",
@@ -10,7 +10,7 @@
10
10
  "directory": "libs/sdk-svelte"
11
11
  },
12
12
  "dependencies": {
13
- "@langchain/langgraph-sdk": "^1.8.5"
13
+ "@langchain/langgraph-sdk": "^1.8.7"
14
14
  },
15
15
  "devDependencies": {
16
16
  "@hono/node-server": "^1.19.11",