@langchain/vue 0.2.0 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +106 -456
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +0 -11
- package/dist/index.d.cts.map +1 -1
- package/dist/index.d.ts +0 -11
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +108 -458
- package/dist/index.js.map +1 -1
- package/dist/stream.custom.cjs +44 -152
- package/dist/stream.custom.cjs.map +1 -1
- package/dist/stream.custom.js +45 -153
- package/dist/stream.custom.js.map +1 -1
- package/package.json +3 -3
package/dist/stream.custom.js
CHANGED
|
@@ -1,162 +1,60 @@
|
|
|
1
1
|
import { onScopeDispose, ref, shallowRef, toValue, watch } from "vue";
|
|
2
|
-
import {
|
|
3
|
-
import { getToolCallsWithResults } from "@langchain/langgraph-sdk/utils";
|
|
2
|
+
import { CustomStreamOrchestrator, ensureMessageInstances } from "@langchain/langgraph-sdk/ui";
|
|
4
3
|
//#region src/stream.custom.ts
|
|
5
|
-
function createCustomTransportThreadState(values, threadId) {
|
|
6
|
-
return {
|
|
7
|
-
values,
|
|
8
|
-
next: [],
|
|
9
|
-
tasks: [],
|
|
10
|
-
metadata: void 0,
|
|
11
|
-
created_at: null,
|
|
12
|
-
checkpoint: {
|
|
13
|
-
thread_id: threadId,
|
|
14
|
-
checkpoint_id: null,
|
|
15
|
-
checkpoint_ns: "",
|
|
16
|
-
checkpoint_map: null
|
|
17
|
-
},
|
|
18
|
-
parent_checkpoint: null
|
|
19
|
-
};
|
|
20
|
-
}
|
|
21
4
|
function useStreamCustom(options) {
|
|
22
|
-
const
|
|
23
|
-
const stream = new StreamManager(messageManager, {
|
|
24
|
-
throttle: options.throttle ?? false,
|
|
25
|
-
subagentToolNames: options.subagentToolNames,
|
|
26
|
-
filterSubagentMessages: options.filterSubagentMessages,
|
|
27
|
-
toMessage: toMessageClass
|
|
28
|
-
});
|
|
29
|
-
const streamValues = shallowRef(stream.values);
|
|
30
|
-
const streamError = shallowRef(stream.error);
|
|
31
|
-
const isLoading = shallowRef(stream.isLoading);
|
|
32
|
-
const subagentVersion = shallowRef(0);
|
|
33
|
-
const unsubscribe = stream.subscribe(() => {
|
|
34
|
-
streamValues.value = stream.values;
|
|
35
|
-
streamError.value = stream.error;
|
|
36
|
-
isLoading.value = stream.isLoading;
|
|
37
|
-
subagentVersion.value += 1;
|
|
38
|
-
});
|
|
5
|
+
const orchestrator = new CustomStreamOrchestrator(options);
|
|
39
6
|
const branch = ref("");
|
|
40
7
|
let threadId = toValue(options.threadId) ?? null;
|
|
41
8
|
watch(() => toValue(options.threadId), (newId) => {
|
|
42
9
|
const resolved = newId ?? null;
|
|
43
10
|
if (resolved !== threadId) {
|
|
44
11
|
threadId = resolved;
|
|
45
|
-
|
|
12
|
+
orchestrator.syncThreadId(resolved);
|
|
46
13
|
}
|
|
47
14
|
}, { flush: "sync" });
|
|
48
|
-
const
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
const
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
15
|
+
const streamValues = shallowRef(null);
|
|
16
|
+
const streamError = shallowRef(void 0);
|
|
17
|
+
const isLoading = shallowRef(false);
|
|
18
|
+
const subagentsRef = shallowRef(orchestrator.subagents);
|
|
19
|
+
const activeSubagentsRef = shallowRef(orchestrator.activeSubagents);
|
|
20
|
+
const unsubscribe = orchestrator.subscribe(() => {
|
|
21
|
+
streamValues.value = orchestrator.streamValues;
|
|
22
|
+
streamError.value = orchestrator.error;
|
|
23
|
+
isLoading.value = orchestrator.isLoading;
|
|
24
|
+
subagentsRef.value = orchestrator.subagents;
|
|
25
|
+
activeSubagentsRef.value = orchestrator.activeSubagents;
|
|
26
|
+
});
|
|
60
27
|
onScopeDispose(() => {
|
|
61
28
|
unsubscribe();
|
|
62
|
-
|
|
29
|
+
orchestrator.dispose();
|
|
63
30
|
});
|
|
64
|
-
const historyMessages = getMessages(historyValues);
|
|
65
|
-
options.filterSubagentMessages && !stream.isLoading && historyMessages.length;
|
|
66
31
|
watch(() => ({
|
|
67
|
-
should: options.filterSubagentMessages && !isLoading.value &&
|
|
68
|
-
len:
|
|
32
|
+
should: options.filterSubagentMessages && !isLoading.value && streamValues.value != null && orchestrator.messages.length > 0,
|
|
33
|
+
len: orchestrator.messages.length
|
|
69
34
|
}), ({ should }) => {
|
|
70
|
-
if (should)
|
|
35
|
+
if (should) orchestrator.reconstructSubagentsIfNeeded();
|
|
71
36
|
}, { immediate: true });
|
|
72
|
-
function switchThread(newThreadId) {
|
|
73
|
-
if (newThreadId !== threadId) {
|
|
74
|
-
threadId = newThreadId;
|
|
75
|
-
stream.clear();
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
function stop() {
|
|
79
|
-
return stream.stop(historyValues, { onStop: options.onStop });
|
|
80
|
-
}
|
|
81
|
-
async function submitDirect(values, submitOptions) {
|
|
82
|
-
const currentThreadId = toValue(options.threadId) ?? null;
|
|
83
|
-
if (currentThreadId !== threadId) {
|
|
84
|
-
threadId = currentThreadId;
|
|
85
|
-
stream.clear();
|
|
86
|
-
}
|
|
87
|
-
let usableThreadId = threadId ?? submitOptions?.threadId;
|
|
88
|
-
stream.setStreamValues(() => {
|
|
89
|
-
if (submitOptions?.optimisticValues != null) return {
|
|
90
|
-
...historyValues,
|
|
91
|
-
...typeof submitOptions.optimisticValues === "function" ? submitOptions.optimisticValues(historyValues) : submitOptions.optimisticValues
|
|
92
|
-
};
|
|
93
|
-
return { ...historyValues };
|
|
94
|
-
});
|
|
95
|
-
await stream.start(async (signal) => {
|
|
96
|
-
if (!usableThreadId) {
|
|
97
|
-
usableThreadId = crypto.randomUUID();
|
|
98
|
-
threadId = usableThreadId;
|
|
99
|
-
options.onThreadId?.(usableThreadId);
|
|
100
|
-
}
|
|
101
|
-
if (!usableThreadId) throw new Error("Failed to obtain valid thread ID.");
|
|
102
|
-
return options.transport.stream({
|
|
103
|
-
input: values,
|
|
104
|
-
context: submitOptions?.context,
|
|
105
|
-
command: submitOptions?.command,
|
|
106
|
-
streamSubgraphs: submitOptions?.streamSubgraphs,
|
|
107
|
-
signal,
|
|
108
|
-
config: {
|
|
109
|
-
...submitOptions?.config,
|
|
110
|
-
configurable: {
|
|
111
|
-
thread_id: usableThreadId,
|
|
112
|
-
...submitOptions?.config?.configurable
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
});
|
|
116
|
-
}, {
|
|
117
|
-
getMessages,
|
|
118
|
-
setMessages,
|
|
119
|
-
initialValues: {},
|
|
120
|
-
callbacks: options,
|
|
121
|
-
onSuccess: () => {
|
|
122
|
-
if (!usableThreadId) return void 0;
|
|
123
|
-
const finalValues = stream.values ?? historyValues;
|
|
124
|
-
options.onFinish?.(createCustomTransportThreadState(finalValues, usableThreadId), void 0);
|
|
125
|
-
},
|
|
126
|
-
onError(error) {
|
|
127
|
-
options.onError?.(error, void 0);
|
|
128
|
-
submitOptions?.onError?.(error, void 0);
|
|
129
|
-
}
|
|
130
|
-
});
|
|
131
|
-
}
|
|
132
|
-
async function submit(values, submitOptions) {
|
|
133
|
-
await submitDirect(values, submitOptions);
|
|
134
|
-
}
|
|
135
|
-
function setBranch(value) {
|
|
136
|
-
branch.value = value;
|
|
137
|
-
}
|
|
138
|
-
function getMessagesMetadata(message, index) {
|
|
139
|
-
const streamMetadata = messageManager.get(message.id)?.metadata;
|
|
140
|
-
if (streamMetadata != null) return {
|
|
141
|
-
messageId: message.id ?? String(index),
|
|
142
|
-
firstSeenState: void 0,
|
|
143
|
-
branch: void 0,
|
|
144
|
-
branchOptions: void 0,
|
|
145
|
-
streamMetadata
|
|
146
|
-
};
|
|
147
|
-
}
|
|
148
37
|
return {
|
|
149
38
|
get values() {
|
|
150
39
|
return streamValues.value ?? {};
|
|
151
40
|
},
|
|
152
41
|
error: streamError,
|
|
153
42
|
isLoading,
|
|
154
|
-
stop,
|
|
155
|
-
submit,
|
|
156
|
-
|
|
43
|
+
stop: () => orchestrator.stop(),
|
|
44
|
+
submit: async (values, submitOptions) => {
|
|
45
|
+
await orchestrator.submit(values, submitOptions);
|
|
46
|
+
},
|
|
47
|
+
switchThread(newThreadId) {
|
|
48
|
+
orchestrator.switchThread(newThreadId);
|
|
49
|
+
},
|
|
157
50
|
branch,
|
|
158
|
-
setBranch
|
|
159
|
-
|
|
51
|
+
setBranch(value) {
|
|
52
|
+
branch.value = value;
|
|
53
|
+
orchestrator.setBranch(value);
|
|
54
|
+
},
|
|
55
|
+
getMessagesMetadata(message, index) {
|
|
56
|
+
return orchestrator.getMessagesMetadata(message, index);
|
|
57
|
+
},
|
|
160
58
|
queue: {
|
|
161
59
|
entries: [],
|
|
162
60
|
size: 0,
|
|
@@ -166,44 +64,38 @@ function useStreamCustom(options) {
|
|
|
166
64
|
async clear() {}
|
|
167
65
|
},
|
|
168
66
|
get interrupts() {
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
if (valueInterrupts.length === 0) return [{ when: "breakpoint" }];
|
|
172
|
-
return valueInterrupts;
|
|
173
|
-
}
|
|
174
|
-
return [];
|
|
67
|
+
isLoading.value;
|
|
68
|
+
return orchestrator.interrupts;
|
|
175
69
|
},
|
|
176
70
|
get interrupt() {
|
|
177
|
-
|
|
71
|
+
isLoading.value;
|
|
72
|
+
return orchestrator.interrupt;
|
|
178
73
|
},
|
|
179
74
|
get messages() {
|
|
180
75
|
if (!streamValues.value) return [];
|
|
181
|
-
return ensureMessageInstances(
|
|
76
|
+
return ensureMessageInstances(orchestrator.messages);
|
|
182
77
|
},
|
|
183
78
|
get toolCalls() {
|
|
184
79
|
if (!streamValues.value) return [];
|
|
185
|
-
return
|
|
80
|
+
return orchestrator.toolCalls;
|
|
186
81
|
},
|
|
187
82
|
getToolCalls(message) {
|
|
188
|
-
|
|
189
|
-
return getToolCallsWithResults(getMessages(streamValues.value)).filter((tc) => tc.aiMessage.id === message.id);
|
|
83
|
+
return orchestrator.getToolCalls(message);
|
|
190
84
|
},
|
|
191
85
|
get subagents() {
|
|
192
|
-
|
|
193
|
-
return stream.getSubagents();
|
|
86
|
+
return subagentsRef.value;
|
|
194
87
|
},
|
|
195
88
|
get activeSubagents() {
|
|
196
|
-
|
|
197
|
-
return stream.getActiveSubagents();
|
|
89
|
+
return activeSubagentsRef.value;
|
|
198
90
|
},
|
|
199
91
|
getSubagent(toolCallId) {
|
|
200
|
-
return
|
|
92
|
+
return orchestrator.getSubagent(toolCallId);
|
|
201
93
|
},
|
|
202
94
|
getSubagentsByType(type) {
|
|
203
|
-
return
|
|
95
|
+
return orchestrator.getSubagentsByType(type);
|
|
204
96
|
},
|
|
205
97
|
getSubagentsByMessage(messageId) {
|
|
206
|
-
return
|
|
98
|
+
return orchestrator.getSubagentsByMessage(messageId);
|
|
207
99
|
}
|
|
208
100
|
};
|
|
209
101
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stream.custom.js","names":[],"sources":["../src/stream.custom.ts"],"sourcesContent":["import { onScopeDispose, ref, shallowRef, toValue, watch } from \"vue\";\nimport {\n StreamManager,\n MessageTupleManager,\n extractInterrupts,\n toMessageClass,\n ensureMessageInstances,\n type EventStreamEvent,\n type GetUpdateType,\n type GetCustomEventType,\n type GetInterruptType,\n type GetConfigurableType,\n type AnyStreamCustomOptions,\n type CustomSubmitOptions,\n type MessageMetadata,\n} from \"@langchain/langgraph-sdk/ui\";\nimport { getToolCallsWithResults } from \"@langchain/langgraph-sdk/utils\";\nimport type {\n BagTemplate,\n Message,\n Interrupt,\n ThreadState,\n} from \"@langchain/langgraph-sdk\";\nimport type { VueReactiveOptions } from \"./types.js\";\n\nfunction createCustomTransportThreadState<\n StateType extends Record<string, unknown>,\n>(values: StateType, threadId: string): ThreadState<StateType> {\n return {\n values,\n next: [],\n tasks: [],\n metadata: undefined,\n created_at: null,\n checkpoint: {\n thread_id: threadId,\n checkpoint_id: null,\n checkpoint_ns: \"\",\n checkpoint_map: null,\n },\n parent_checkpoint: null,\n };\n}\n\nexport function useStreamCustom<\n StateType extends Record<string, unknown> = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(options: VueReactiveOptions<AnyStreamCustomOptions<StateType, Bag>>) {\n type UpdateType = GetUpdateType<Bag, StateType>;\n type CustomType = GetCustomEventType<Bag>;\n type InterruptType = GetInterruptType<Bag>;\n type ConfigurableType = GetConfigurableType<Bag>;\n\n const messageManager = new MessageTupleManager();\n const stream = new StreamManager<StateType, Bag>(messageManager, {\n throttle: options.throttle ?? false,\n subagentToolNames: options.subagentToolNames,\n filterSubagentMessages: options.filterSubagentMessages,\n toMessage: toMessageClass,\n });\n\n const streamValues = shallowRef<StateType | null>(stream.values);\n const streamError = shallowRef<unknown>(stream.error);\n const isLoading = shallowRef(stream.isLoading);\n\n const subagentVersion = shallowRef(0);\n\n const unsubscribe = stream.subscribe(() => {\n streamValues.value = stream.values;\n streamError.value = stream.error;\n isLoading.value = stream.isLoading;\n subagentVersion.value += 1;\n });\n\n const branch = ref<string>(\"\");\n\n let threadId: string | null = toValue(options.threadId) ?? null;\n\n watch(\n () => toValue(options.threadId),\n (newId) => {\n const resolved = newId ?? null;\n if (resolved !== threadId) {\n threadId = resolved;\n stream.clear();\n }\n },\n { flush: \"sync\" },\n );\n\n const getMessages = (value: StateType): Message[] => {\n const messagesKey = toValue(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 = toValue(options.messagesKey) ?? \"messages\";\n return { ...current, [messagesKey]: messages };\n };\n\n const historyValues = options.initialValues ?? ({} as StateType);\n\n onScopeDispose(() => {\n unsubscribe();\n void stream.stop(historyValues, { onStop: options.onStop });\n });\n\n const historyMessages = getMessages(historyValues);\n // @ts-expect-error used in watch callback below\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const shouldReconstructSubagents =\n options.filterSubagentMessages &&\n !stream.isLoading &&\n historyMessages.length > 0;\n\n watch(\n () => ({\n should:\n options.filterSubagentMessages &&\n !isLoading.value &&\n getMessages(historyValues).length > 0,\n len: getMessages(historyValues).length,\n }),\n ({ should }) => {\n if (should) {\n stream.reconstructSubagents(getMessages(historyValues), {\n skipIfPopulated: true,\n });\n }\n },\n { immediate: true },\n );\n\n function switchThread(newThreadId: string | null) {\n if (newThreadId !== threadId) {\n threadId = newThreadId;\n stream.clear();\n }\n }\n\n function stop() {\n return stream.stop(historyValues, { onStop: options.onStop });\n }\n\n async function submitDirect(\n values: UpdateType | null | undefined,\n submitOptions?: CustomSubmitOptions<StateType, ConfigurableType>,\n ) {\n const currentThreadId = toValue(options.threadId) ?? null;\n if (currentThreadId !== threadId) {\n threadId = currentThreadId;\n stream.clear();\n }\n\n let usableThreadId = threadId ?? submitOptions?.threadId;\n\n stream.setStreamValues(() => {\n if (submitOptions?.optimisticValues != null) {\n return {\n ...historyValues,\n ...(typeof submitOptions.optimisticValues === \"function\"\n ? submitOptions.optimisticValues(historyValues)\n : submitOptions.optimisticValues),\n };\n }\n\n return { ...historyValues };\n });\n\n await stream.start(\n async (signal: AbortSignal) => {\n if (!usableThreadId) {\n usableThreadId = crypto.randomUUID();\n threadId = usableThreadId;\n options.onThreadId?.(usableThreadId);\n }\n\n if (!usableThreadId) {\n throw new Error(\"Failed to obtain valid thread ID.\");\n }\n\n return options.transport.stream({\n input: values,\n context: submitOptions?.context,\n command: submitOptions?.command,\n streamSubgraphs: submitOptions?.streamSubgraphs,\n signal,\n config: {\n ...submitOptions?.config,\n configurable: {\n thread_id: usableThreadId,\n ...submitOptions?.config?.configurable,\n } as unknown as GetConfigurableType<Bag>,\n },\n }) as Promise<\n AsyncGenerator<EventStreamEvent<StateType, UpdateType, CustomType>>\n >;\n },\n {\n getMessages,\n setMessages,\n\n initialValues: {} as StateType,\n callbacks: options,\n\n onSuccess: () => {\n if (!usableThreadId) return undefined;\n\n const finalValues = stream.values ?? historyValues;\n options.onFinish?.(\n createCustomTransportThreadState(finalValues, usableThreadId),\n undefined,\n );\n\n return undefined;\n },\n onError(error) {\n options.onError?.(error, undefined);\n submitOptions?.onError?.(error, undefined);\n },\n },\n );\n }\n\n async function submit(\n values: UpdateType | null | undefined,\n submitOptions?: CustomSubmitOptions<StateType, ConfigurableType>,\n ) {\n await submitDirect(values, submitOptions);\n }\n\n function setBranch(value: string) {\n branch.value = value;\n }\n\n function getMessagesMetadata(\n message: Message,\n index?: number,\n ): MessageMetadata<StateType> | undefined {\n const streamMetadata = messageManager.get(message.id)?.metadata;\n if (streamMetadata != null) {\n return {\n messageId: message.id ?? String(index),\n firstSeenState: undefined,\n branch: undefined,\n branchOptions: undefined,\n streamMetadata,\n } as MessageMetadata<StateType>;\n }\n return undefined;\n }\n\n return {\n get values() {\n return streamValues.value ?? ({} as StateType);\n },\n\n error: streamError,\n isLoading,\n\n stop,\n submit,\n switchThread,\n\n branch,\n setBranch,\n getMessagesMetadata,\n\n queue: {\n entries: [],\n size: 0,\n async cancel() {\n return false;\n },\n async clear() {},\n },\n\n get interrupts(): Interrupt<InterruptType>[] {\n if (\n streamValues.value != null &&\n \"__interrupt__\" in streamValues.value &&\n Array.isArray(streamValues.value.__interrupt__)\n ) {\n const valueInterrupts = streamValues.value.__interrupt__;\n if (valueInterrupts.length === 0) return [{ when: \"breakpoint\" }];\n return valueInterrupts;\n }\n\n return [];\n },\n\n get interrupt(): Interrupt<InterruptType> | undefined {\n return extractInterrupts<InterruptType>(streamValues.value);\n },\n\n get messages() {\n if (!streamValues.value) return [];\n return ensureMessageInstances(getMessages(streamValues.value));\n },\n\n get toolCalls() {\n if (!streamValues.value) return [];\n return getToolCallsWithResults(getMessages(streamValues.value));\n },\n\n getToolCalls(message: Message) {\n if (!streamValues.value) return [];\n const allToolCalls = getToolCallsWithResults(\n getMessages(streamValues.value),\n );\n return allToolCalls.filter((tc) => tc.aiMessage.id === message.id);\n },\n\n get subagents() {\n void subagentVersion.value;\n return stream.getSubagents();\n },\n\n get activeSubagents() {\n void subagentVersion.value;\n return stream.getActiveSubagents();\n },\n\n getSubagent(toolCallId: string) {\n return stream.getSubagent(toolCallId);\n },\n\n getSubagentsByType(type: string) {\n return stream.getSubagentsByType(type);\n },\n\n getSubagentsByMessage(messageId: string) {\n return stream.getSubagentsByMessage(messageId);\n },\n };\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"stream.custom.js","names":[],"sources":["../src/stream.custom.ts"],"sourcesContent":["import { onScopeDispose, ref, shallowRef, toValue, watch } from \"vue\";\nimport {\n CustomStreamOrchestrator,\n ensureMessageInstances,\n type AnyStreamCustomOptions,\n type CustomSubmitOptions,\n type GetUpdateType,\n type GetInterruptType,\n type GetConfigurableType,\n type MessageMetadata,\n} from \"@langchain/langgraph-sdk/ui\";\nimport type { BagTemplate, Message, Interrupt } from \"@langchain/langgraph-sdk\";\nimport type { VueReactiveOptions } from \"./types.js\";\n\nexport function useStreamCustom<\n StateType extends Record<string, unknown> = Record<string, unknown>,\n Bag extends BagTemplate = BagTemplate,\n>(options: VueReactiveOptions<AnyStreamCustomOptions<StateType, Bag>>) {\n type UpdateType = GetUpdateType<Bag, StateType>;\n type InterruptType = GetInterruptType<Bag>;\n type ConfigurableType = GetConfigurableType<Bag>;\n\n const orchestrator = new CustomStreamOrchestrator<StateType, Bag>(\n options as unknown as AnyStreamCustomOptions<StateType, Bag>,\n );\n\n const branch = ref<string>(\"\");\n\n let threadId: string | null = toValue(options.threadId) ?? null;\n\n watch(\n () => toValue(options.threadId),\n (newId) => {\n const resolved = newId ?? null;\n if (resolved !== threadId) {\n threadId = resolved;\n orchestrator.syncThreadId(resolved);\n }\n },\n { flush: \"sync\" },\n );\n\n const streamValues = shallowRef<StateType | null>(null);\n const streamError = shallowRef<unknown>(undefined);\n const isLoading = shallowRef(false);\n const subagentsRef = shallowRef(orchestrator.subagents);\n const activeSubagentsRef = shallowRef(orchestrator.activeSubagents);\n\n const unsubscribe = orchestrator.subscribe(() => {\n streamValues.value = orchestrator.streamValues;\n streamError.value = orchestrator.error;\n isLoading.value = orchestrator.isLoading;\n subagentsRef.value = orchestrator.subagents;\n activeSubagentsRef.value = orchestrator.activeSubagents;\n });\n\n onScopeDispose(() => {\n unsubscribe();\n orchestrator.dispose();\n });\n\n watch(\n () => ({\n should:\n options.filterSubagentMessages &&\n !isLoading.value &&\n streamValues.value != null &&\n orchestrator.messages.length > 0,\n len: orchestrator.messages.length,\n }),\n ({ should }) => {\n if (should) {\n orchestrator.reconstructSubagentsIfNeeded();\n }\n },\n { immediate: true },\n );\n\n return {\n get values() {\n return streamValues.value ?? ({} as StateType);\n },\n\n error: streamError,\n isLoading,\n\n stop: () => orchestrator.stop(),\n\n submit: async (\n values: UpdateType | null | undefined,\n submitOptions?: CustomSubmitOptions<StateType, ConfigurableType>,\n ) => {\n await orchestrator.submit(values, submitOptions);\n },\n\n switchThread(newThreadId: string | null) {\n orchestrator.switchThread(newThreadId);\n },\n\n branch,\n setBranch(value: string) {\n branch.value = value;\n orchestrator.setBranch(value);\n },\n\n getMessagesMetadata(\n message: Message,\n index?: number,\n ): MessageMetadata<StateType> | undefined {\n return orchestrator.getMessagesMetadata(message, index);\n },\n\n queue: {\n entries: [],\n size: 0,\n async cancel() {\n return false;\n },\n async clear() {},\n },\n\n get interrupts(): Interrupt<InterruptType>[] {\n void isLoading.value;\n return orchestrator.interrupts as Interrupt<InterruptType>[];\n },\n\n get interrupt(): Interrupt<InterruptType> | undefined {\n void isLoading.value;\n return orchestrator.interrupt as Interrupt<InterruptType> | undefined;\n },\n\n get messages() {\n if (!streamValues.value) return [];\n return ensureMessageInstances(orchestrator.messages);\n },\n\n get toolCalls() {\n if (!streamValues.value) return [];\n return orchestrator.toolCalls;\n },\n\n getToolCalls(message: Message) {\n return orchestrator.getToolCalls(message);\n },\n\n get subagents() {\n return subagentsRef.value;\n },\n\n get activeSubagents() {\n return activeSubagentsRef.value;\n },\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"],"mappings":";;;AAcA,SAAgB,gBAGd,SAAqE;CAKrE,MAAM,eAAe,IAAI,yBACvB,QACD;CAED,MAAM,SAAS,IAAY,GAAG;CAE9B,IAAI,WAA0B,QAAQ,QAAQ,SAAS,IAAI;AAE3D,aACQ,QAAQ,QAAQ,SAAS,GAC9B,UAAU;EACT,MAAM,WAAW,SAAS;AAC1B,MAAI,aAAa,UAAU;AACzB,cAAW;AACX,gBAAa,aAAa,SAAS;;IAGvC,EAAE,OAAO,QAAQ,CAClB;CAED,MAAM,eAAe,WAA6B,KAAK;CACvD,MAAM,cAAc,WAAoB,KAAA,EAAU;CAClD,MAAM,YAAY,WAAW,MAAM;CACnC,MAAM,eAAe,WAAW,aAAa,UAAU;CACvD,MAAM,qBAAqB,WAAW,aAAa,gBAAgB;CAEnE,MAAM,cAAc,aAAa,gBAAgB;AAC/C,eAAa,QAAQ,aAAa;AAClC,cAAY,QAAQ,aAAa;AACjC,YAAU,QAAQ,aAAa;AAC/B,eAAa,QAAQ,aAAa;AAClC,qBAAmB,QAAQ,aAAa;GACxC;AAEF,sBAAqB;AACnB,eAAa;AACb,eAAa,SAAS;GACtB;AAEF,cACS;EACL,QACE,QAAQ,0BACR,CAAC,UAAU,SACX,aAAa,SAAS,QACtB,aAAa,SAAS,SAAS;EACjC,KAAK,aAAa,SAAS;EAC5B,IACA,EAAE,aAAa;AACd,MAAI,OACF,cAAa,8BAA8B;IAG/C,EAAE,WAAW,MAAM,CACpB;AAED,QAAO;EACL,IAAI,SAAS;AACX,UAAO,aAAa,SAAU,EAAE;;EAGlC,OAAO;EACP;EAEA,YAAY,aAAa,MAAM;EAE/B,QAAQ,OACN,QACA,kBACG;AACH,SAAM,aAAa,OAAO,QAAQ,cAAc;;EAGlD,aAAa,aAA4B;AACvC,gBAAa,aAAa,YAAY;;EAGxC;EACA,UAAU,OAAe;AACvB,UAAO,QAAQ;AACf,gBAAa,UAAU,MAAM;;EAG/B,oBACE,SACA,OACwC;AACxC,UAAO,aAAa,oBAAoB,SAAS,MAAM;;EAGzD,OAAO;GACL,SAAS,EAAE;GACX,MAAM;GACN,MAAM,SAAS;AACb,WAAO;;GAET,MAAM,QAAQ;GACf;EAED,IAAI,aAAyC;AACtC,aAAU;AACf,UAAO,aAAa;;EAGtB,IAAI,YAAkD;AAC/C,aAAU;AACf,UAAO,aAAa;;EAGtB,IAAI,WAAW;AACb,OAAI,CAAC,aAAa,MAAO,QAAO,EAAE;AAClC,UAAO,uBAAuB,aAAa,SAAS;;EAGtD,IAAI,YAAY;AACd,OAAI,CAAC,aAAa,MAAO,QAAO,EAAE;AAClC,UAAO,aAAa;;EAGtB,aAAa,SAAkB;AAC7B,UAAO,aAAa,aAAa,QAAQ;;EAG3C,IAAI,YAAY;AACd,UAAO,aAAa;;EAGtB,IAAI,kBAAkB;AACpB,UAAO,mBAAmB;;EAG5B,YAAY,YAAoB;AAC9B,UAAO,aAAa,YAAY,WAAW;;EAE7C,mBAAmB,MAAc;AAC/B,UAAO,aAAa,mBAAmB,KAAK;;EAE9C,sBAAsB,WAAmB;AACvC,UAAO,aAAa,sBAAsB,UAAU;;EAEvD"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@langchain/vue",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.3.0",
|
|
4
4
|
"description": "Vue integration for LangGraph & LangChain",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"license": "MIT",
|
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
"directory": "libs/sdk-vue"
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"@langchain/langgraph-sdk": "^1.
|
|
13
|
+
"@langchain/langgraph-sdk": "^1.8.0"
|
|
14
14
|
},
|
|
15
15
|
"devDependencies": {
|
|
16
16
|
"@hono/node-server": "^1.19.11",
|
|
@@ -38,7 +38,7 @@
|
|
|
38
38
|
"vue": "^3.5.30",
|
|
39
39
|
"webdriverio": "^9.25.0",
|
|
40
40
|
"zod": "^4.3.6",
|
|
41
|
-
"@langchain/langgraph": "1.2.
|
|
41
|
+
"@langchain/langgraph": "1.2.5",
|
|
42
42
|
"@langchain/langgraph-api": "1.1.16",
|
|
43
43
|
"@langchain/langgraph-checkpoint": "1.0.1"
|
|
44
44
|
},
|