langgraph-ui-components 0.0.25 → 0.0.27
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/README.md +412 -51
- package/dist/_virtual/index.cjs6.js +1 -1
- package/dist/_virtual/index.cjs8.js +1 -1
- package/dist/_virtual/index.es6.js +2 -2
- package/dist/_virtual/index.es8.js +2 -2
- package/dist/assets/langgraph-ui-components.css +1 -1
- package/dist/components/ChatBody.cjs.js +2 -2
- package/dist/components/ChatBody.cjs.js.map +1 -1
- package/dist/components/ChatBody.d.ts.map +1 -1
- package/dist/components/ChatBody.es.js +137 -98
- package/dist/components/ChatBody.es.js.map +1 -1
- package/dist/components/messages/AgentMessage.cjs.js +3 -1
- package/dist/components/messages/AgentMessage.cjs.js.map +1 -1
- package/dist/components/messages/AgentMessage.d.ts +3 -1
- package/dist/components/messages/AgentMessage.d.ts.map +1 -1
- package/dist/components/messages/AgentMessage.es.js +197 -112
- package/dist/components/messages/AgentMessage.es.js.map +1 -1
- package/dist/entries/components.cjs.js +1 -1
- package/dist/entries/components.d.ts.map +1 -1
- package/dist/entries/components.es.js +4 -5
- package/dist/entries/components.es.js.map +1 -1
- package/dist/entries/hooks.cjs.js +1 -1
- package/dist/entries/hooks.d.ts.map +1 -1
- package/dist/entries/hooks.es.js +5 -6
- package/dist/entries/hooks.es.js.map +1 -1
- package/dist/entries/providers.cjs.js +1 -1
- package/dist/entries/providers.d.ts +1 -1
- package/dist/entries/providers.d.ts.map +1 -1
- package/dist/entries/providers.es.js +18 -19
- package/dist/entries/providers.es.js.map +1 -1
- package/dist/index.cjs.js +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.es.js +28 -29
- package/dist/index.es.js.map +1 -1
- package/dist/node_modules/.pnpm/eventemitter3@4.0.7/node_modules/eventemitter3/index.cjs.js +1 -1
- package/dist/node_modules/.pnpm/eventemitter3@4.0.7/node_modules/eventemitter3/index.es.js +1 -1
- package/dist/node_modules/.pnpm/p-timeout@3.2.0/node_modules/p-timeout/index.cjs.js +1 -1
- package/dist/node_modules/.pnpm/p-timeout@3.2.0/node_modules/p-timeout/index.es.js +1 -1
- package/dist/node_modules/.pnpm/react-syntax-highlighter@16.1.0_react@19.2.3/node_modules/react-syntax-highlighter/dist/cjs/styles/prism/index.cjs.js +1 -1
- package/dist/node_modules/.pnpm/react-syntax-highlighter@16.1.0_react@19.2.3/node_modules/react-syntax-highlighter/dist/cjs/styles/prism/index.es.js +1 -1
- package/dist/providers/ChatProvider.cjs.js +1 -1
- package/dist/providers/ChatProvider.cjs.js.map +1 -1
- package/dist/providers/ChatProvider.d.ts +17 -1
- package/dist/providers/ChatProvider.d.ts.map +1 -1
- package/dist/providers/ChatProvider.es.js +18 -17
- package/dist/providers/ChatProvider.es.js.map +1 -1
- package/dist/providers/ChatRuntime.es.js +4 -4
- package/dist/providers/CustomComponentProvider.cjs.js +1 -1
- package/dist/providers/CustomComponentProvider.cjs.js.map +1 -1
- package/dist/providers/CustomComponentProvider.d.ts +11 -0
- package/dist/providers/CustomComponentProvider.d.ts.map +1 -1
- package/dist/providers/CustomComponentProvider.es.js +51 -35
- package/dist/providers/CustomComponentProvider.es.js.map +1 -1
- package/dist/providers/Stream.cjs.js +1 -1
- package/dist/providers/Stream.cjs.js.map +1 -1
- package/dist/providers/Stream.d.ts.map +1 -1
- package/dist/providers/Stream.es.js +113 -94
- package/dist/providers/Stream.es.js.map +1 -1
- package/dist/providers/Thread.cjs.js +1 -1
- package/dist/providers/Thread.cjs.js.map +1 -1
- package/dist/providers/Thread.d.ts +2 -1
- package/dist/providers/Thread.d.ts.map +1 -1
- package/dist/providers/Thread.es.js +19 -19
- package/dist/providers/Thread.es.js.map +1 -1
- package/dist/styles.css +1 -1
- package/package.json +1 -1
- package/src/components/ChatBody.tsx +88 -28
- package/src/components/messages/AgentMessage.tsx +281 -81
- package/src/entries/components.ts +0 -2
- package/src/entries/hooks.ts +0 -2
- package/src/entries/providers.ts +1 -3
- package/src/index.css +2 -2
- package/src/index.ts +1 -3
- package/src/providers/ChatProvider.tsx +18 -1
- package/src/providers/CustomComponentProvider.tsx +41 -0
- package/src/providers/Stream.tsx +34 -15
- package/src/providers/Thread.tsx +2 -2
- package/dist/components/ToolCallFunctions.cjs.js +0 -2
- package/dist/components/ToolCallFunctions.cjs.js.map +0 -1
- package/dist/components/ToolCallFunctions.es.js +0 -75
- package/dist/components/ToolCallFunctions.es.js.map +0 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const p=require("react/jsx-runtime"),O=require("./ChatRuntime.cjs.js"),f=require("../utils/logger.cjs.js");require("@langchain/langgraph-sdk");const V=require("@langchain/langgraph-sdk/react"),x=require("@langchain/langgraph-sdk/react-ui"),l=require("react"),K=require("sonner"),N=require("./Thread.cjs.js"),W=require("../node_modules/.pnpm/uuid@13.0.0/node_modules/uuid/dist/v4.cjs.js"),D=V.useStream,F=l.createContext(void 0);async function J(g,u){try{return(await fetch(`${g}/info`,{headers:u?{Authorization:`Bearer ${u}`}:void 0})).ok}catch{f.logger.error("Failed to initialize LangGraph Agent")}}async function Q(g,u){try{const y=await fetch(`${g}/agents/catalog`,{headers:u?{Authorization:`Bearer ${u}`}:void 0});return y.ok?await y.json():null}catch{return f.logger.error("Failed to fetch LangGraph Catalog"),null}}async function X(g=6e3){return new Promise(u=>setTimeout(u,g))}const Y=({children:g})=>{const{apiUrl:u,assistantId:y,identity:c}=O.useChatRuntime(),{mode:C,threadId:T,setThreadId:A,getThreads:z,setThreads:B,configuration:v}=N.useThread(),[U,b]=l.useState([]),[S,w]=l.useState([]),[I,E]=l.useState(!1),[k,L]=l.useState(null),o=D({apiUrl:u,assistantId:y,threadId:C==="multi"?T:null,defaultHeaders:c?.authToken?{Authorization:`Bearer ${c?.authToken}`}:void 0,fetchStateHistory:!0,onUpdateEvent:(t,e)=>{const a=[],s=d=>{if(!d||typeof d!="object")return;const m=d;if(Array.isArray(m.messages))for(const r of m.messages){const n=r.additional_kwargs;if(r?.type==="ai"&&r.id&&n){const h=typeof n.reasoning_content=="string"&&n.reasoning_content.length>0,i=Array.isArray(n.tool_status)&&n.tool_status.length>0;(h||i)&&a.push(r)}}for(const r of Object.values(m))r&&typeof r=="object"&&!Array.isArray(r)&&s(r)};s(t),a.length>0&&e.mutate(d=>{const m=d.messages??[],r=new Map;for(const i of a)i.id&&r.set(i.id,i);let n=!1;const h=m.map(i=>{if(!i.id||!r.has(i.id))return i;const M=r.get(i.id);r.delete(i.id),n=!0;const H=M.additional_kwargs;return{...i,additional_kwargs:{...i.additional_kwargs??{},...H??{}}}});return n?{...d,messages:h}:d})},onCustomEvent:(t,e)=>{(x.isUIMessage(t)||x.isRemoveUIMessage(t))&&e.mutate(a=>{f.logger.debug("UI Event received in StreamProvider:",t);const s=x.uiMessageReducer(a.ui??[],t);return{...a,ui:s}})},onThreadId:t=>{t&&(C==="single"?T||A(t):(A(t),X().then(()=>z().then(B).catch(e=>f.logger.error("Failed to refresh threads:",e)))))}}),q=l.useCallback(async(t,e)=>{const a=e?.id||W(),s=typeof t=="string"?{id:a,type:e?.type??"human",content:t,...e?.name&&{name:e.name},...e?.tool_calls&&{tool_calls:e.tool_calls},...e?.invalid_tool_calls&&{invalid_tool_calls:e.invalid_tool_calls},...e?.tool_call_id&&{tool_call_id:e.tool_call_id},...(e?.additional_kwargs||e?.hidden)&&{additional_kwargs:{...e?.hidden&&{hidden:!0},...e?.additional_kwargs??{}}}}:{...t,id:a,...e?.tool_calls&&{tool_calls:e.tool_calls},...e?.additional_kwargs&&{additional_kwargs:{...t.additional_kwargs,...e.additional_kwargs}}};if(f.logger.debug("Sending message via sendMessage:",s),e?.type==="ai"){if(b(r=>[...r,s]),f.logger.debug("Appended AI message to localMessages:",e?.ui),e.ui&&e.ui.length>0){const r=e.ui.map((n,h)=>({...n,id:a,_key:n._key||`${a}-ui-${h}`}));w(n=>[...n,...r])}return}const d=o.messages||[],m=e?.context?{...c,...e.context,...v}:c||{};await o.submit({messages:[...d,s]},{context:m,streamMode:["values","messages-tuple","updates","custom"]})},[o,c,v,b,w]),_=l.useMemo(()=>{const t=[...U,...o.messages||[]],e=new Set;return t.filter(a=>a.id?e.has(a.id)?!1:(e.add(a.id),!0):!0)},[U,o.messages]),R=l.useMemo(()=>{f.logger.debug("Combining local UI with stream UI:",S,o.values?.ui);const t=[...S,...o.values?.ui||[]],e=new Set;return t.filter(a=>{const s=a._key||`${a.id}-${a.name}`;return e.has(s)?!1:(e.add(s),!0)})},[S,o.values?.ui]),$=l.useCallback(async(t,e)=>{const a=_||[];await o.submit({messages:[...a,t]},{context:{...c,...e?.contextValues},streamMode:e?.streamMode||["values","messages-tuple","updates","custom"],streamSubgraphs:e?.streamSubgraphs??!0,streamResumable:e?.streamResumable??!0,optimisticValues:s=>({...s,messages:[...a,t]})})},[o,c,_]),j=l.useCallback(async t=>{const e=_||[],a=e.findIndex(n=>n.id===t);if(a===-1){f.logger.error("Message not found for regeneration:",t);return}let s=a-1;for(;s>=0&&e[s].type!=="human";)s--;if(s===-1){f.logger.error("No human message found before AI message:",t);return}const d=e.slice(0,s+1),m=d.slice(0,-1),r=d[d.length-1];b(n=>n.filter(h=>e.findIndex(M=>M.id===h.id)<s)),w(n=>n.filter(h=>e.findIndex(M=>M.id===h.id)<s)),await o.submit({messages:[...m,r]},{streamMode:["values"],streamSubgraphs:!0,streamResumable:!0})},[_,o,c,v,b,w]);l.useEffect(()=>{J(u,c?.authToken).then(t=>{t||K.toast.error("Failed to connect to LangGraph server",{description:`Unable to reach ${u}`,duration:1e4})})},[u,c?.authToken]);const P=l.useCallback(async()=>{if(I&&k!==null)return k;if(!I){E(!0);const t=await Q(u,c?.authToken);return L(t),t}return k},[u,c?.authToken,I,k]),G=l.useMemo(()=>({...o,messages:_,values:{...o.values,ui:R},sendMessage:q,submitMessage:$,regenerateMessage:j,fetchCatalog:P}),[o,_,R,q,$,j,P]);return p.jsx(F.Provider,{value:G,children:g})};function Z({children:g}){return p.jsx(Y,{children:g})}function ee(){const g=l.useContext(F);if(!g)throw new Error("useStreamContext must be used within StreamProvider");return g}exports.StreamProvider=Z;exports.useStreamContext=ee;
|
|
2
2
|
//# sourceMappingURL=Stream.cjs.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Stream.cjs.js","sources":["../../src/providers/Stream.tsx"],"sourcesContent":["/* @refresh reset */\nimport { useChatRuntime } from \"@/providers/ChatRuntime\";\nimport { logger } from \"@/utils/logger\";\nimport { type AIMessage, type Message } from \"@langchain/langgraph-sdk\";\n\n// Derive the tool-call types from AIMessage since the SDK doesn't re-export them\ntype ToolCall = NonNullable<AIMessage[\"tool_calls\"]>[number];\ntype InvalidToolCall = NonNullable<AIMessage[\"invalid_tool_calls\"]>[number];\nimport { useStream, type UseStream } from \"@langchain/langgraph-sdk/react\";\nimport {\n isRemoveUIMessage,\n isUIMessage,\n type RemoveUIMessage,\n type UIMessage,\n uiMessageReducer,\n} from \"@langchain/langgraph-sdk/react-ui\";\nimport {\n createContext,\n type ReactNode,\n useCallback,\n useContext,\n useEffect,\n useMemo,\n useState,\n} from \"react\";\nimport { toast } from \"sonner\";\nimport { v4 as uuidv4 } from \"uuid\";\nimport { useThread } from \"./Thread\";\n\nexport type StateType = {\n messages: Message[];\n ui?: UIMessage[];\n suggestions?: string[];\n};\n\nconst useTypedStream = useStream<\n StateType,\n {\n UpdateType: {\n messages?: Message[] | Message | string;\n ui?: (UIMessage | RemoveUIMessage)[] | UIMessage | RemoveUIMessage;\n };\n CustomEventType: UIMessage | RemoveUIMessage;\n }\n>;\n\ntype StreamContextType = UseStream<StateType, {\n UpdateType: {\n\n messages?: Message[] | Message | string;\n ui?: (UIMessage | RemoveUIMessage)[] | UIMessage | RemoveUIMessage;\n };\n CustomEventType: UIMessage | RemoveUIMessage;\n}> & {\n sendMessage: (\n message: Message | string,\n options?: {\n /** If true, message is meant for agent only (not user-visible) */\n type?: Message[\"type\"];\n /** Name field required for function/tool messages */\n name?: string;\n /** If true, message is hidden from user UI */\n hidden?: boolean;\n /** Tool calls associated with this message */\n tool_calls?: ToolCall[];\n /** Invalid tool calls associated with this message */\n invalid_tool_calls?: InvalidToolCall[];\n /** If provided, use this ID for the message instead of generating one */\n tool_call_id?: string;\n /** Additional kwargs to attach to the message */\n additional_kwargs?: Record<string, unknown>;\n /** UI components to display alongside the message */\n ui?: UIMessage[];\n /** Custom ID for the message (will also be used for UI components) */\n id?: string;\n /** Custom context to override/merge with identity */\n context?: Record<string, unknown>;\n }\n ) => Promise<void>;\n submitMessage: (\n message: Message,\n options?: {\n streamMode?: (\"values\" | \"updates\" | \"messages\" | \"custom\" | \"debug\")[];\n streamSubgraphs?: boolean;\n streamResumable?: boolean;\n contextValues?: Record<string, unknown>;\n }\n ) => Promise<void>;\n regenerateMessage: (messageId: string) => Promise<void>;\n fetchCatalog: () => Promise<unknown>;\n};\n\nconst StreamContext = createContext<StreamContextType | undefined>(undefined);\n\nasync function checkGraphStatus(apiUrl: string, authToken: string | null | undefined) {\n try {\n const res = await fetch(`${apiUrl}/info`, {\n headers: authToken ? { Authorization: `Bearer ${authToken}` } : undefined,\n });\n return res.ok;\n } catch {\n logger.error(\"Failed to initialize LangGraph Agent\");\n }\n}\n\nasync function fetchCatalog(apiUrl: string, authToken: string | null | undefined) {\n try {\n const res = await fetch(`${apiUrl}/agents/catalog`, {\n headers: authToken ? { Authorization: `Bearer ${authToken}` } : undefined,\n });\n if (res.ok) {\n const data = await res.json();\n return data;\n }\n return null;\n }\n catch {\n logger.error(\"Failed to fetch LangGraph Catalog\");\n return null;\n }\n}\n\nasync function sleep(ms = 6000) {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n\nconst StreamSession = ({ children }: { children: ReactNode }) => {\n const { apiUrl, assistantId, identity } = useChatRuntime();\n const { mode, threadId, setThreadId, getThreads, setThreads, configuration } = useThread();\n\n // Store local-only AI messages that shouldn't trigger backend calls\n const [localMessages, setLocalMessages] = useState<Message[]>([]);\n // Store local-only UI components\n const [localUI, setLocalUI] = useState<UIMessage[]>([]);\n // Track if catalog has been fetched to prevent duplicate calls\n const [catalogFetched, setCatalogFetched] = useState(false);\n const [catalogCache, setCatalogCache] = useState<unknown>(null);\n\n const streamValue = useTypedStream({\n apiUrl,\n assistantId,\n threadId: mode === \"multi\" ? threadId : null,\n defaultHeaders: identity?.authToken\n ? { Authorization: `Bearer ${identity?.authToken}` }\n : undefined,\n fetchStateHistory: true,\n onUpdateEvent: (data, options) => {\n // Scan update data (potentially nested by node name) for AI messages\n // with reasoning_content. Inject them into state early so they're\n // visible during streaming of the final text response.\n const reasoningMessages: Message[] = [];\n\n const scan = (obj: unknown) => {\n if (!obj || typeof obj !== \"object\") return;\n const o = obj as Record<string, unknown>;\n if (Array.isArray(o.messages)) {\n for (const m of o.messages as Message[]) {\n const ak = (m as Record<string, unknown>).additional_kwargs as Record<string, unknown> | undefined;\n if (\n m?.type === \"ai\" &&\n m.id &&\n typeof ak?.reasoning_content === \"string\" &&\n ak.reasoning_content.length > 0\n ) {\n reasoningMessages.push(m);\n }\n }\n }\n for (const val of Object.values(o)) {\n if (val && typeof val === \"object\" && !Array.isArray(val)) {\n scan(val);\n }\n }\n };\n\n scan(data);\n\n if (reasoningMessages.length > 0) {\n options.mutate((prev) => {\n const prevMessages = (prev.messages ?? []) as Message[];\n const prevIds = new Set(prevMessages.map((m) => m.id).filter(Boolean));\n const newMessages = reasoningMessages.filter((m) => !prevIds.has(m.id!));\n if (newMessages.length === 0) return prev;\n return { ...prev, messages: [...prevMessages, ...newMessages] };\n });\n }\n },\n onCustomEvent: (event, options) => {\n if (isUIMessage(event) || isRemoveUIMessage(event)) {\n options.mutate((prev) => {\n logger.debug(\"UI Event received in StreamProvider:\", event);\n const ui = uiMessageReducer(prev.ui ?? [], event);\n return { ...prev, ui };\n });\n }\n },\n\n onThreadId: (id) => {\n if (!id) return;\n if (mode === \"single\") {\n // lock once\n if (!threadId) setThreadId(id);\n } else {\n // switch freely\n setThreadId(id);\n // Refetch threads list when thread ID changes.\n // Wait for some seconds before fetching so we're able to get the new thread that was created.\n sleep().then(() => getThreads().then(setThreads).catch((err) => logger.error(\"Failed to refresh threads:\", err)));\n }\n },\n });\n\n /**\n * Send a message to the agent programmatically\n * Useful for triggering agent actions without user-visible messages\n * e.g., \"login completed\", \"card clicked: {id}\"\n */\n const sendMessage = useCallback(\n async (\n message: Message | string,\n options?: {\n type?: Message[\"type\"];\n name?: string;\n hidden?: boolean;\n tool_calls?: ToolCall[];\n invalid_tool_calls?: InvalidToolCall[];\n tool_call_id?: string;\n additional_kwargs?: Record<string, unknown>;\n ui?: UIMessage[];\n id?: string; // Allow passing custom ID\n context?: Record<string, unknown>; // Allow passing custom context to override identity\n }\n ) => {\n // Use provided ID or generate new one\n const messageId = options?.id || uuidv4();\n\n const messageObj: Message =\n typeof message === \"string\"\n ? ({\n id: messageId, // Use the determined ID\n type: options?.type ?? \"human\",\n content: message,\n ...(options?.name && { name: options.name }),\n ...(options?.tool_calls && { tool_calls: options.tool_calls }),\n ...(options?.invalid_tool_calls && { invalid_tool_calls: options.invalid_tool_calls }),\n ...(options?.tool_call_id && { tool_call_id: options.tool_call_id }),\n ...((options?.additional_kwargs || options?.hidden) && {\n additional_kwargs: {\n ...(options?.hidden && { hidden: true }),\n ...(options?.additional_kwargs ?? {}),\n }\n }),\n } as Message)\n : {\n ...message,\n id: messageId, // Override with determined ID\n // Allow overriding message fields with options\n ...(options?.tool_calls && { tool_calls: options.tool_calls }),\n ...(options?.additional_kwargs && {\n additional_kwargs: {\n ...message.additional_kwargs,\n ...options.additional_kwargs,\n }\n }),\n };\n\n // console.log(\"Sending message via sendMessage:\", messageObj); → converted to debug log\n logger.debug(\"Sending message via sendMessage:\", messageObj);\n\n // If message type is \"ai\", just append to local state without submitting to agent\n // This is useful for injecting initial messages or system messages that don't need agent processing\n if (options?.type === \"ai\") {\n setLocalMessages((prev) => [...prev, messageObj]);\n logger.debug(\"Appended AI message to localMessages:\", options?.ui);\n // Also store any UI components, linking them to the message id\n if (options.ui && options.ui.length > 0) {\n const uiWithMessageId = options.ui.map((ui, index) => ({\n ...ui,\n id: messageId, // Link to the message ID so CustomComponentRender can find it\n // Ensure each UI component has a unique identifier for React keys\n _key: (ui as UIMessage & { _key?: string })._key || `${messageId}-ui-${index}`,\n })) as UIMessage[];\n setLocalUI((prev) => [...prev, ...uiWithMessageId]);\n }\n return;\n }\n\n // For non-AI messages, submit to the agent\n const currentMessages = streamValue.messages || [];\n // Merge identity with custom context, custom context takes precedence\n const mergedContext = options?.context\n ? { ...identity, ...options.context, ...configuration }\n : identity || {};\n\n await streamValue.submit(\n { messages: [...currentMessages, messageObj] },\n {\n context: mergedContext,\n streamMode: [\"values\", \"messages-tuple\", \"updates\", \"custom\"],\n }\n );\n },\n [streamValue, identity, configuration, setLocalMessages, setLocalUI]\n );\n\n // Combine stream messages with local AI messages, deduplicating by ID\n const combinedMessages = useMemo(() => {\n const allMessages = [...localMessages, ...(streamValue.messages || [])];\n // Deduplicate by message ID, keeping the first occurrence\n const seen = new Set<string>();\n return allMessages.filter(msg => {\n if (!msg.id) return true; // Keep messages without IDs\n if (seen.has(msg.id)) return false;\n seen.add(msg.id);\n return true;\n });\n }, [localMessages, streamValue.messages]);\n\n // Combine local UI with stream UI, deduplicating by unique key\n const combinedUI = useMemo(() => {\n logger.debug(\"Combining local UI with stream UI:\", localUI, streamValue.values?.ui);\n const allUI = [...localUI, ...(streamValue.values?.ui || [])];\n // Deduplicate by _key or id+name combination\n const seen = new Set<string>();\n return allUI.filter(ui => {\n const key = (ui as UIMessage & { _key?: string })._key || `${ui.id}-${ui.name}`;\n if (seen.has(key)) return false;\n seen.add(key);\n return true;\n });\n }, [localUI, streamValue.values?.ui]);\n\n const submitMessage = useCallback(\n async (\n message: Message,\n options?: {\n streamMode?: (\"values\" | \"updates\" | \"messages\" | \"custom\" | \"debug\")[];\n streamSubgraphs?: boolean;\n streamResumable?: boolean;\n contextValues?: Record<string, unknown>;\n }\n ) => {\n // Get ALL current messages (including local AI messages)\n const allCurrentMessages = combinedMessages || [];\n\n await streamValue.submit(\n { messages: [...allCurrentMessages, message] },\n {\n context: { ...identity, ...options?.contextValues },\n streamMode: options?.streamMode || [\"values\", \"messages-tuple\", \"updates\", \"custom\"],\n streamSubgraphs: options?.streamSubgraphs ?? true,\n streamResumable: options?.streamResumable ?? true,\n optimisticValues: (prev) => ({\n ...prev,\n messages: [...allCurrentMessages, message],\n }),\n }\n );\n },\n [streamValue, identity, combinedMessages]\n );\n\n /**\n * Regenerate an AI response by finding the last human message before the specified AI message\n * and resubmitting from that point\n */\n const regenerateMessage = useCallback(\n async (messageId: string) => {\n const allMessages = combinedMessages || [];\n const messageIndex = allMessages.findIndex((msg) => msg.id === messageId);\n\n if (messageIndex === -1) {\n logger.error(\"Message not found for regeneration:\", messageId);\n return;\n }\n\n // Find the last human message before this AI message\n let lastHumanIndex = messageIndex - 1;\n while (lastHumanIndex >= 0 && allMessages[lastHumanIndex].type !== \"human\") {\n lastHumanIndex--;\n }\n\n if (lastHumanIndex === -1) {\n logger.error(\"No human message found before AI message:\", messageId);\n return;\n }\n\n // Get all messages up to and including the last human message\n const messagesToKeep = allMessages.slice(0, lastHumanIndex + 1);\n\n // Remove the last human message from the list since we'll resubmit it\n const messagesBeforeHuman = messagesToKeep.slice(0, -1);\n const humanMessage = messagesToKeep[messagesToKeep.length - 1];\n\n // Clear local messages that came after the human message\n setLocalMessages((prev) =>\n prev.filter((msg) => {\n const msgIndex = allMessages.findIndex((m) => m.id === msg.id);\n return msgIndex < lastHumanIndex;\n })\n );\n\n // Clear local UI that came after the human message \n setLocalUI((prev) =>\n prev.filter((ui) => {\n const msgIndex = allMessages.findIndex((m) => m.id === ui.id);\n return msgIndex < lastHumanIndex;\n })\n );\n\n // Resubmit from the human message\n await streamValue.submit(\n { messages: [...messagesBeforeHuman, humanMessage] },\n {\n streamMode: [\"values\"],\n streamSubgraphs: true,\n streamResumable: true,\n }\n );\n },\n [combinedMessages, streamValue, identity, configuration, setLocalMessages, setLocalUI]\n );\n\n useEffect(() => {\n checkGraphStatus(apiUrl, identity?.authToken).then((ok) => {\n if (!ok) {\n toast.error(\"Failed to connect to LangGraph server\", {\n description: `Unable to reach ${apiUrl}`,\n duration: 10000,\n });\n }\n });\n }, [apiUrl, identity?.authToken]);\n\n const fetchCatalogMemoized = useCallback(async () => {\n // Return cached data if already fetched\n if (catalogFetched && catalogCache !== null) {\n return catalogCache;\n }\n\n // Fetch catalog only once\n if (!catalogFetched) {\n setCatalogFetched(true);\n const data = await fetchCatalog(apiUrl, identity?.authToken);\n setCatalogCache(data);\n return data;\n }\n\n return catalogCache;\n }, [apiUrl, identity?.authToken, catalogFetched, catalogCache]);\n\n const value = useMemo(\n () => ({\n ...streamValue,\n messages: combinedMessages, // Override with combined messages\n values: {\n ...streamValue.values,\n ui: combinedUI, // Override with combined UI\n },\n sendMessage,\n submitMessage,\n regenerateMessage,\n fetchCatalog: fetchCatalogMemoized,\n }),\n [streamValue, combinedMessages, combinedUI, sendMessage, submitMessage, regenerateMessage, fetchCatalogMemoized]\n );\n\n return (\n <StreamContext.Provider value={value}>{children}</StreamContext.Provider>\n );\n};\n\n/**\n * Provides streaming message functionality for real-time AI responses.\n * Manages message state, handles streaming updates, and provides submit/sendMessage functions.\n * \n * @example\n * ```tsx\n * <StreamProvider>\n * <ChatInterface />\n * </StreamProvider>\n * ```\n */\nexport function StreamProvider({ children }: { children: ReactNode }) {\n return <StreamSession>{children}</StreamSession>;\n}\n\n/**\n * Hook to access the streaming context.\n * Provides access to messages, loading state, and functions to submit messages.\n * \n * @throws {Error} If used outside of StreamProvider\n * \n * @example\n * ```tsx\n * const { messages, isLoading, submit, sendMessage } = useStreamContext();\n * ```\n */\nexport function useStreamContext(): StreamContextType {\n const ctx = useContext(StreamContext);\n if (!ctx) {\n throw new Error(\"useStreamContext must be used within StreamProvider\");\n }\n return ctx;\n}"],"names":["useTypedStream","useStream","StreamContext","createContext","checkGraphStatus","apiUrl","authToken","logger","fetchCatalog","res","sleep","ms","resolve","StreamSession","children","assistantId","identity","useChatRuntime","mode","threadId","setThreadId","getThreads","setThreads","configuration","useThread","localMessages","setLocalMessages","useState","localUI","setLocalUI","catalogFetched","setCatalogFetched","catalogCache","setCatalogCache","streamValue","data","options","reasoningMessages","scan","obj","o","m","ak","val","prev","prevMessages","prevIds","newMessages","event","isUIMessage","isRemoveUIMessage","ui","uiMessageReducer","id","err","sendMessage","useCallback","message","messageId","uuidv4","messageObj","uiWithMessageId","index","currentMessages","mergedContext","combinedMessages","useMemo","allMessages","seen","msg","combinedUI","allUI","key","submitMessage","allCurrentMessages","regenerateMessage","messageIndex","lastHumanIndex","messagesToKeep","messagesBeforeHuman","humanMessage","useEffect","ok","toast","fetchCatalogMemoized","value","jsx","StreamProvider","useStreamContext","ctx","useContext"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Stream.cjs.js","sources":["../../src/providers/Stream.tsx"],"sourcesContent":["/* @refresh reset */\nimport { useChatRuntime } from \"@/providers/ChatRuntime\";\nimport { logger } from \"@/utils/logger\";\nimport { type AIMessage, type Message } from \"@langchain/langgraph-sdk\";\n\n// Derive the tool-call types from AIMessage since the SDK doesn't re-export them\ntype ToolCall = NonNullable<AIMessage[\"tool_calls\"]>[number];\ntype InvalidToolCall = NonNullable<AIMessage[\"invalid_tool_calls\"]>[number];\nimport { useStream, type UseStream } from \"@langchain/langgraph-sdk/react\";\nimport {\n isRemoveUIMessage,\n isUIMessage,\n type RemoveUIMessage,\n type UIMessage,\n uiMessageReducer,\n} from \"@langchain/langgraph-sdk/react-ui\";\nimport {\n createContext,\n type ReactNode,\n useCallback,\n useContext,\n useEffect,\n useMemo,\n useState,\n} from \"react\";\nimport { toast } from \"sonner\";\nimport { v4 as uuidv4 } from \"uuid\";\nimport { useThread } from \"./Thread\";\n\nexport type StateType = {\n messages: Message[];\n ui?: UIMessage[];\n suggestions?: string[];\n};\n\nconst useTypedStream = useStream<\n StateType,\n {\n UpdateType: {\n messages?: Message[] | Message | string;\n ui?: (UIMessage | RemoveUIMessage)[] | UIMessage | RemoveUIMessage;\n };\n CustomEventType: UIMessage | RemoveUIMessage;\n }\n>;\n\ntype StreamContextType = UseStream<StateType, {\n UpdateType: {\n\n messages?: Message[] | Message | string;\n ui?: (UIMessage | RemoveUIMessage)[] | UIMessage | RemoveUIMessage;\n };\n CustomEventType: UIMessage | RemoveUIMessage;\n}> & {\n sendMessage: (\n message: Message | string,\n options?: {\n /** If true, message is meant for agent only (not user-visible) */\n type?: Message[\"type\"];\n /** Name field required for function/tool messages */\n name?: string;\n /** If true, message is hidden from user UI */\n hidden?: boolean;\n /** Tool calls associated with this message */\n tool_calls?: ToolCall[];\n /** Invalid tool calls associated with this message */\n invalid_tool_calls?: InvalidToolCall[];\n /** If provided, use this ID for the message instead of generating one */\n tool_call_id?: string;\n /** Additional kwargs to attach to the message */\n additional_kwargs?: Record<string, unknown>;\n /** UI components to display alongside the message */\n ui?: UIMessage[];\n /** Custom ID for the message (will also be used for UI components) */\n id?: string;\n /** Custom context to override/merge with identity */\n context?: Record<string, unknown>;\n }\n ) => Promise<void>;\n submitMessage: (\n message: Message,\n options?: {\n streamMode?: (\"values\" | \"updates\" | \"messages\" | \"custom\" | \"debug\")[];\n streamSubgraphs?: boolean;\n streamResumable?: boolean;\n contextValues?: Record<string, unknown>;\n }\n ) => Promise<void>;\n regenerateMessage: (messageId: string) => Promise<void>;\n fetchCatalog: () => Promise<unknown>;\n};\n\nconst StreamContext = createContext<StreamContextType | undefined>(undefined);\n\nasync function checkGraphStatus(apiUrl: string, authToken: string | null | undefined) {\n try {\n const res = await fetch(`${apiUrl}/info`, {\n headers: authToken ? { Authorization: `Bearer ${authToken}` } : undefined,\n });\n return res.ok;\n } catch {\n logger.error(\"Failed to initialize LangGraph Agent\");\n }\n}\n\nasync function fetchCatalog(apiUrl: string, authToken: string | null | undefined) {\n try {\n const res = await fetch(`${apiUrl}/agents/catalog`, {\n headers: authToken ? { Authorization: `Bearer ${authToken}` } : undefined,\n });\n if (res.ok) {\n const data = await res.json();\n return data;\n }\n return null;\n }\n catch {\n logger.error(\"Failed to fetch LangGraph Catalog\");\n return null;\n }\n}\n\nasync function sleep(ms = 6000) {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n\nconst StreamSession = ({ children }: { children: ReactNode }) => {\n const { apiUrl, assistantId, identity } = useChatRuntime();\n const { mode, threadId, setThreadId, getThreads, setThreads, configuration } = useThread();\n\n // Store local-only AI messages that shouldn't trigger backend calls\n const [localMessages, setLocalMessages] = useState<Message[]>([]);\n // Store local-only UI components\n const [localUI, setLocalUI] = useState<UIMessage[]>([]);\n // Track if catalog has been fetched to prevent duplicate calls\n const [catalogFetched, setCatalogFetched] = useState(false);\n const [catalogCache, setCatalogCache] = useState<unknown>(null);\n\n const streamValue = useTypedStream({\n apiUrl,\n assistantId,\n threadId: mode === \"multi\" ? threadId : null,\n defaultHeaders: identity?.authToken\n ? { Authorization: `Bearer ${identity?.authToken}` }\n : undefined,\n fetchStateHistory: true,\n onUpdateEvent: (data, options) => {\n // Scan update data (potentially nested by node name) for AI messages\n // with reasoning_content or tool_status in additional_kwargs.\n // Merge these into existing messages so they're available during streaming.\n const enrichedMessages: Message[] = [];\n\n const scan = (obj: unknown) => {\n if (!obj || typeof obj !== \"object\") return;\n const o = obj as Record<string, unknown>;\n if (Array.isArray(o.messages)) {\n for (const m of o.messages as Message[]) {\n const ak = (m as Record<string, unknown>).additional_kwargs as Record<string, unknown> | undefined;\n if (m?.type === \"ai\" && m.id && ak) {\n const hasReasoning = typeof ak.reasoning_content === \"string\" && ak.reasoning_content.length > 0;\n const hasToolStatus = Array.isArray(ak.tool_status) && (ak.tool_status as unknown[]).length > 0;\n if (hasReasoning || hasToolStatus) {\n enrichedMessages.push(m);\n }\n }\n }\n }\n for (const val of Object.values(o)) {\n if (val && typeof val === \"object\" && !Array.isArray(val)) {\n scan(val);\n }\n }\n };\n\n scan(data);\n\n if (enrichedMessages.length > 0) {\n options.mutate((prev) => {\n const prevMessages = (prev.messages ?? []) as Message[];\n const enrichedById = new Map<string, Message>();\n for (const m of enrichedMessages) {\n if (m.id) enrichedById.set(m.id, m);\n }\n\n let changed = false;\n const updatedMessages = prevMessages.map((m) => {\n if (!m.id || !enrichedById.has(m.id)) return m;\n const enriched = enrichedById.get(m.id)!;\n enrichedById.delete(m.id);\n changed = true;\n const enrichedKwargs = (enriched as Record<string, unknown>).additional_kwargs as Record<string, unknown> | undefined;\n return {\n ...m,\n additional_kwargs: {\n ...(m.additional_kwargs ?? {}),\n ...(enrichedKwargs ?? {}),\n },\n };\n });\n\n if (!changed) return prev;\n\n return { ...prev, messages: updatedMessages };\n });\n }\n },\n onCustomEvent: (event, options) => {\n if (isUIMessage(event) || isRemoveUIMessage(event)) {\n options.mutate((prev) => {\n logger.debug(\"UI Event received in StreamProvider:\", event);\n const ui = uiMessageReducer(prev.ui ?? [], event);\n return { ...prev, ui };\n });\n }\n },\n\n onThreadId: (id) => {\n if (!id) return;\n if (mode === \"single\") {\n // lock once\n if (!threadId) setThreadId(id);\n } else {\n // switch freely\n setThreadId(id);\n // Refetch threads list when thread ID changes.\n // Wait for some seconds before fetching so we're able to get the new thread that was created.\n sleep().then(() => getThreads().then(setThreads).catch((err) => logger.error(\"Failed to refresh threads:\", err)));\n }\n },\n });\n\n /**\n * Send a message to the agent programmatically\n * Useful for triggering agent actions without user-visible messages\n * e.g., \"login completed\", \"card clicked: {id}\"\n */\n const sendMessage = useCallback(\n async (\n message: Message | string,\n options?: {\n type?: Message[\"type\"];\n name?: string;\n hidden?: boolean;\n tool_calls?: ToolCall[];\n invalid_tool_calls?: InvalidToolCall[];\n tool_call_id?: string;\n additional_kwargs?: Record<string, unknown>;\n ui?: UIMessage[];\n id?: string; // Allow passing custom ID\n context?: Record<string, unknown>; // Allow passing custom context to override identity\n }\n ) => {\n // Use provided ID or generate new one\n const messageId = options?.id || uuidv4();\n\n const messageObj: Message =\n typeof message === \"string\"\n ? ({\n id: messageId, // Use the determined ID\n type: options?.type ?? \"human\",\n content: message,\n ...(options?.name && { name: options.name }),\n ...(options?.tool_calls && { tool_calls: options.tool_calls }),\n ...(options?.invalid_tool_calls && { invalid_tool_calls: options.invalid_tool_calls }),\n ...(options?.tool_call_id && { tool_call_id: options.tool_call_id }),\n ...((options?.additional_kwargs || options?.hidden) && {\n additional_kwargs: {\n ...(options?.hidden && { hidden: true }),\n ...(options?.additional_kwargs ?? {}),\n }\n }),\n } as Message)\n : {\n ...message,\n id: messageId, // Override with determined ID\n // Allow overriding message fields with options\n ...(options?.tool_calls && { tool_calls: options.tool_calls }),\n ...(options?.additional_kwargs && {\n additional_kwargs: {\n ...message.additional_kwargs,\n ...options.additional_kwargs,\n }\n }),\n };\n\n // console.log(\"Sending message via sendMessage:\", messageObj); → converted to debug log\n logger.debug(\"Sending message via sendMessage:\", messageObj);\n\n // If message type is \"ai\", just append to local state without submitting to agent\n // This is useful for injecting initial messages or system messages that don't need agent processing\n if (options?.type === \"ai\") {\n setLocalMessages((prev) => [...prev, messageObj]);\n logger.debug(\"Appended AI message to localMessages:\", options?.ui);\n // Also store any UI components, linking them to the message id\n if (options.ui && options.ui.length > 0) {\n const uiWithMessageId = options.ui.map((ui, index) => ({\n ...ui,\n id: messageId, // Link to the message ID so CustomComponentRender can find it\n // Ensure each UI component has a unique identifier for React keys\n _key: (ui as UIMessage & { _key?: string })._key || `${messageId}-ui-${index}`,\n })) as UIMessage[];\n setLocalUI((prev) => [...prev, ...uiWithMessageId]);\n }\n return;\n }\n\n // For non-AI messages, submit to the agent\n const currentMessages = streamValue.messages || [];\n // Merge identity with custom context, custom context takes precedence\n const mergedContext = options?.context\n ? { ...identity, ...options.context, ...configuration }\n : identity || {};\n\n await streamValue.submit(\n { messages: [...currentMessages, messageObj] },\n {\n context: mergedContext,\n streamMode: [\"values\", \"messages-tuple\", \"updates\", \"custom\"],\n }\n );\n },\n [streamValue, identity, configuration, setLocalMessages, setLocalUI]\n );\n\n // Combine stream messages with local AI messages, deduplicating by ID\n const combinedMessages = useMemo(() => {\n const allMessages = [...localMessages, ...(streamValue.messages || [])];\n // Deduplicate by message ID, keeping the first occurrence\n const seen = new Set<string>();\n return allMessages.filter(msg => {\n if (!msg.id) return true; // Keep messages without IDs\n if (seen.has(msg.id)) return false;\n seen.add(msg.id);\n return true;\n });\n }, [localMessages, streamValue.messages]);\n\n // Combine local UI with stream UI, deduplicating by unique key\n const combinedUI = useMemo(() => {\n logger.debug(\"Combining local UI with stream UI:\", localUI, streamValue.values?.ui);\n const allUI = [...localUI, ...(streamValue.values?.ui || [])];\n // Deduplicate by _key or id+name combination\n const seen = new Set<string>();\n return allUI.filter(ui => {\n const key = (ui as UIMessage & { _key?: string })._key || `${ui.id}-${ui.name}`;\n if (seen.has(key)) return false;\n seen.add(key);\n return true;\n });\n }, [localUI, streamValue.values?.ui]);\n\n const submitMessage = useCallback(\n async (\n message: Message,\n options?: {\n streamMode?: (\"values\" | \"updates\" | \"messages\" | \"custom\" | \"debug\")[];\n streamSubgraphs?: boolean;\n streamResumable?: boolean;\n contextValues?: Record<string, unknown>;\n }\n ) => {\n // Get ALL current messages (including local AI messages)\n const allCurrentMessages = combinedMessages || [];\n\n await streamValue.submit(\n { messages: [...allCurrentMessages, message] },\n {\n context: { ...identity, ...options?.contextValues },\n streamMode: options?.streamMode || [\"values\", \"messages-tuple\", \"updates\", \"custom\"],\n streamSubgraphs: options?.streamSubgraphs ?? true,\n streamResumable: options?.streamResumable ?? true,\n optimisticValues: (prev) => ({\n ...prev,\n messages: [...allCurrentMessages, message],\n }),\n }\n );\n },\n [streamValue, identity, combinedMessages]\n );\n\n /**\n * Regenerate an AI response by finding the last human message before the specified AI message\n * and resubmitting from that point\n */\n const regenerateMessage = useCallback(\n async (messageId: string) => {\n const allMessages = combinedMessages || [];\n const messageIndex = allMessages.findIndex((msg) => msg.id === messageId);\n\n if (messageIndex === -1) {\n logger.error(\"Message not found for regeneration:\", messageId);\n return;\n }\n\n // Find the last human message before this AI message\n let lastHumanIndex = messageIndex - 1;\n while (lastHumanIndex >= 0 && allMessages[lastHumanIndex].type !== \"human\") {\n lastHumanIndex--;\n }\n\n if (lastHumanIndex === -1) {\n logger.error(\"No human message found before AI message:\", messageId);\n return;\n }\n\n // Get all messages up to and including the last human message\n const messagesToKeep = allMessages.slice(0, lastHumanIndex + 1);\n\n // Remove the last human message from the list since we'll resubmit it\n const messagesBeforeHuman = messagesToKeep.slice(0, -1);\n const humanMessage = messagesToKeep[messagesToKeep.length - 1];\n\n // Clear local messages that came after the human message\n setLocalMessages((prev) =>\n prev.filter((msg) => {\n const msgIndex = allMessages.findIndex((m) => m.id === msg.id);\n return msgIndex < lastHumanIndex;\n })\n );\n\n // Clear local UI that came after the human message \n setLocalUI((prev) =>\n prev.filter((ui) => {\n const msgIndex = allMessages.findIndex((m) => m.id === ui.id);\n return msgIndex < lastHumanIndex;\n })\n );\n\n // Resubmit from the human message\n await streamValue.submit(\n { messages: [...messagesBeforeHuman, humanMessage] },\n {\n streamMode: [\"values\"],\n streamSubgraphs: true,\n streamResumable: true,\n }\n );\n },\n [combinedMessages, streamValue, identity, configuration, setLocalMessages, setLocalUI]\n );\n\n useEffect(() => {\n checkGraphStatus(apiUrl, identity?.authToken).then((ok) => {\n if (!ok) {\n toast.error(\"Failed to connect to LangGraph server\", {\n description: `Unable to reach ${apiUrl}`,\n duration: 10000,\n });\n }\n });\n }, [apiUrl, identity?.authToken]);\n\n const fetchCatalogMemoized = useCallback(async () => {\n // Return cached data if already fetched\n if (catalogFetched && catalogCache !== null) {\n return catalogCache;\n }\n\n // Fetch catalog only once\n if (!catalogFetched) {\n setCatalogFetched(true);\n const data = await fetchCatalog(apiUrl, identity?.authToken);\n setCatalogCache(data);\n return data;\n }\n\n return catalogCache;\n }, [apiUrl, identity?.authToken, catalogFetched, catalogCache]);\n\n const value = useMemo(\n () => ({\n ...streamValue,\n messages: combinedMessages, // Override with combined messages\n values: {\n ...streamValue.values,\n ui: combinedUI, // Override with combined UI\n },\n sendMessage,\n submitMessage,\n regenerateMessage,\n fetchCatalog: fetchCatalogMemoized,\n }),\n [streamValue, combinedMessages, combinedUI, sendMessage, submitMessage, regenerateMessage, fetchCatalogMemoized]\n );\n\n return (\n <StreamContext.Provider value={value}>{children}</StreamContext.Provider>\n );\n};\n\n/**\n * Provides streaming message functionality for real-time AI responses.\n * Manages message state, handles streaming updates, and provides submit/sendMessage functions.\n * \n * @example\n * ```tsx\n * <StreamProvider>\n * <ChatInterface />\n * </StreamProvider>\n * ```\n */\nexport function StreamProvider({ children }: { children: ReactNode }) {\n return <StreamSession>{children}</StreamSession>;\n}\n\n/**\n * Hook to access the streaming context.\n * Provides access to messages, loading state, and functions to submit messages.\n * \n * @throws {Error} If used outside of StreamProvider\n * \n * @example\n * ```tsx\n * const { messages, isLoading, submit, sendMessage } = useStreamContext();\n * ```\n */\nexport function useStreamContext(): StreamContextType {\n const ctx = useContext(StreamContext);\n if (!ctx) {\n throw new Error(\"useStreamContext must be used within StreamProvider\");\n }\n return ctx;\n}"],"names":["useTypedStream","useStream","StreamContext","createContext","checkGraphStatus","apiUrl","authToken","logger","fetchCatalog","res","sleep","ms","resolve","StreamSession","children","assistantId","identity","useChatRuntime","mode","threadId","setThreadId","getThreads","setThreads","configuration","useThread","localMessages","setLocalMessages","useState","localUI","setLocalUI","catalogFetched","setCatalogFetched","catalogCache","setCatalogCache","streamValue","data","options","enrichedMessages","scan","obj","o","m","ak","hasReasoning","hasToolStatus","val","prev","prevMessages","enrichedById","changed","updatedMessages","enriched","enrichedKwargs","event","isUIMessage","isRemoveUIMessage","ui","uiMessageReducer","id","err","sendMessage","useCallback","message","messageId","uuidv4","messageObj","uiWithMessageId","index","currentMessages","mergedContext","combinedMessages","useMemo","allMessages","seen","msg","combinedUI","allUI","key","submitMessage","allCurrentMessages","regenerateMessage","messageIndex","lastHumanIndex","messagesToKeep","messagesBeforeHuman","humanMessage","useEffect","ok","toast","fetchCatalogMemoized","value","jsx","StreamProvider","useStreamContext","ctx","useContext"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Stream.d.ts","sourceRoot":"","sources":["../../src/providers/Stream.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,OAAO,EAAE,MAAM,0BAA0B,CAAC;AAGxE,KAAK,QAAQ,GAAG,WAAW,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;AAC7D,KAAK,eAAe,GAAG,WAAW,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;AAC5E,OAAO,EAAa,KAAK,SAAS,EAAE,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAGL,KAAK,eAAe,EACpB,KAAK,SAAS,EAEf,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAEL,KAAK,SAAS,EAMf,MAAM,OAAO,CAAC;AAKf,MAAM,MAAM,SAAS,GAAG;IACtB,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAaF,KAAK,iBAAiB,GAAG,SAAS,CAAC,SAAS,EAAE;IAC5C,UAAU,EAAE;QAEV,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,GAAG,MAAM,CAAC;QACxC,EAAE,CAAC,EAAE,CAAC,SAAS,GAAG,eAAe,CAAC,EAAE,GAAG,SAAS,GAAG,eAAe,CAAC;KACpE,CAAC;IACF,eAAe,EAAE,SAAS,GAAG,eAAe,CAAC;CAC9C,CAAC,GAAG;IACH,WAAW,EAAE,CACX,OAAO,EAAE,OAAO,GAAG,MAAM,EACzB,OAAO,CAAC,EAAE;QACR,kEAAkE;QAClE,IAAI,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;QACvB,qDAAqD;QACrD,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,8CAA8C;QAC9C,MAAM,CAAC,EAAE,OAAO,CAAC;QACjB,8CAA8C;QAC9C,UAAU,CAAC,EAAE,QAAQ,EAAE,CAAC;QACxB,sDAAsD;QACtD,kBAAkB,CAAC,EAAE,eAAe,EAAE,CAAC;QACvC,yEAAyE;QACzE,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,iDAAiD;QACjD,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAC5C,qDAAqD;QACrD,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC;QACjB,sEAAsE;QACtE,EAAE,CAAC,EAAE,MAAM,CAAC;QACZ,qDAAqD;QACrD,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KACnC,KACE,OAAO,CAAC,IAAI,CAAC,CAAC;IACnB,aAAa,EAAE,CACb,OAAO,EAAE,OAAO,EAChB,OAAO,CAAC,EAAE;QACR,UAAU,CAAC,EAAE,CAAC,QAAQ,GAAG,SAAS,GAAG,UAAU,GAAG,QAAQ,GAAG,OAAO,CAAC,EAAE,CAAC;QACxE,eAAe,CAAC,EAAE,OAAO,CAAC;QAC1B,eAAe,CAAC,EAAE,OAAO,CAAC;QAC1B,aAAa,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KACzC,KACE,OAAO,CAAC,IAAI,CAAC,CAAC;IACnB,iBAAiB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACxD,YAAY,EAAE,MAAM,OAAO,CAAC,OAAO,CAAC,CAAC;CACtC,CAAC;
|
|
1
|
+
{"version":3,"file":"Stream.d.ts","sourceRoot":"","sources":["../../src/providers/Stream.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,OAAO,EAAE,MAAM,0BAA0B,CAAC;AAGxE,KAAK,QAAQ,GAAG,WAAW,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;AAC7D,KAAK,eAAe,GAAG,WAAW,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;AAC5E,OAAO,EAAa,KAAK,SAAS,EAAE,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAGL,KAAK,eAAe,EACpB,KAAK,SAAS,EAEf,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAEL,KAAK,SAAS,EAMf,MAAM,OAAO,CAAC;AAKf,MAAM,MAAM,SAAS,GAAG;IACtB,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAaF,KAAK,iBAAiB,GAAG,SAAS,CAAC,SAAS,EAAE;IAC5C,UAAU,EAAE;QAEV,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,GAAG,MAAM,CAAC;QACxC,EAAE,CAAC,EAAE,CAAC,SAAS,GAAG,eAAe,CAAC,EAAE,GAAG,SAAS,GAAG,eAAe,CAAC;KACpE,CAAC;IACF,eAAe,EAAE,SAAS,GAAG,eAAe,CAAC;CAC9C,CAAC,GAAG;IACH,WAAW,EAAE,CACX,OAAO,EAAE,OAAO,GAAG,MAAM,EACzB,OAAO,CAAC,EAAE;QACR,kEAAkE;QAClE,IAAI,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;QACvB,qDAAqD;QACrD,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,8CAA8C;QAC9C,MAAM,CAAC,EAAE,OAAO,CAAC;QACjB,8CAA8C;QAC9C,UAAU,CAAC,EAAE,QAAQ,EAAE,CAAC;QACxB,sDAAsD;QACtD,kBAAkB,CAAC,EAAE,eAAe,EAAE,CAAC;QACvC,yEAAyE;QACzE,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,iDAAiD;QACjD,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAC5C,qDAAqD;QACrD,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC;QACjB,sEAAsE;QACtE,EAAE,CAAC,EAAE,MAAM,CAAC;QACZ,qDAAqD;QACrD,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KACnC,KACE,OAAO,CAAC,IAAI,CAAC,CAAC;IACnB,aAAa,EAAE,CACb,OAAO,EAAE,OAAO,EAChB,OAAO,CAAC,EAAE;QACR,UAAU,CAAC,EAAE,CAAC,QAAQ,GAAG,SAAS,GAAG,UAAU,GAAG,QAAQ,GAAG,OAAO,CAAC,EAAE,CAAC;QACxE,eAAe,CAAC,EAAE,OAAO,CAAC;QAC1B,eAAe,CAAC,EAAE,OAAO,CAAC;QAC1B,aAAa,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KACzC,KACE,OAAO,CAAC,IAAI,CAAC,CAAC;IACnB,iBAAiB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACxD,YAAY,EAAE,MAAM,OAAO,CAAC,OAAO,CAAC,CAAC;CACtC,CAAC;AAiZF;;;;;;;;;;GAUG;AACH,wBAAgB,cAAc,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,2CAEnE;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,gBAAgB,IAAI,iBAAiB,CAMpD"}
|
|
@@ -1,73 +1,92 @@
|
|
|
1
|
-
import { jsx as
|
|
1
|
+
import { jsx as E } from "react/jsx-runtime";
|
|
2
2
|
import { useChatRuntime as O } from "./ChatRuntime.es.js";
|
|
3
|
-
import { logger as
|
|
3
|
+
import { logger as f } from "../utils/logger.es.js";
|
|
4
4
|
import "@langchain/langgraph-sdk";
|
|
5
|
-
import { useStream as
|
|
6
|
-
import { isUIMessage as
|
|
7
|
-
import { useContext as
|
|
8
|
-
import { toast as
|
|
9
|
-
import { useThread as
|
|
10
|
-
import
|
|
11
|
-
const
|
|
12
|
-
async function
|
|
5
|
+
import { useStream as N } from "@langchain/langgraph-sdk/react";
|
|
6
|
+
import { isUIMessage as W, isRemoveUIMessage as q, uiMessageReducer as D } from "@langchain/langgraph-sdk/react-ui";
|
|
7
|
+
import { useContext as J, createContext as Q, useState as v, useCallback as k, useMemo as C, useEffect as X } from "react";
|
|
8
|
+
import { toast as Y } from "sonner";
|
|
9
|
+
import { useThread as Z } from "./Thread.es.js";
|
|
10
|
+
import ee from "../node_modules/.pnpm/uuid@13.0.0/node_modules/uuid/dist/v4.es.js";
|
|
11
|
+
const te = N, L = Q(void 0);
|
|
12
|
+
async function ae(u, l) {
|
|
13
13
|
try {
|
|
14
14
|
return (await fetch(`${u}/info`, {
|
|
15
|
-
headers:
|
|
15
|
+
headers: l ? { Authorization: `Bearer ${l}` } : void 0
|
|
16
16
|
})).ok;
|
|
17
17
|
} catch {
|
|
18
|
-
|
|
18
|
+
f.error("Failed to initialize LangGraph Agent");
|
|
19
19
|
}
|
|
20
20
|
}
|
|
21
|
-
async function
|
|
21
|
+
async function se(u, l) {
|
|
22
22
|
try {
|
|
23
|
-
const
|
|
24
|
-
headers:
|
|
23
|
+
const _ = await fetch(`${u}/agents/catalog`, {
|
|
24
|
+
headers: l ? { Authorization: `Bearer ${l}` } : void 0
|
|
25
25
|
});
|
|
26
|
-
return
|
|
26
|
+
return _.ok ? await _.json() : null;
|
|
27
27
|
} catch {
|
|
28
|
-
return
|
|
28
|
+
return f.error("Failed to fetch LangGraph Catalog"), null;
|
|
29
29
|
}
|
|
30
30
|
}
|
|
31
|
-
async function
|
|
32
|
-
return new Promise((
|
|
31
|
+
async function re(u = 6e3) {
|
|
32
|
+
return new Promise((l) => setTimeout(l, u));
|
|
33
33
|
}
|
|
34
|
-
const
|
|
35
|
-
const { apiUrl:
|
|
36
|
-
apiUrl:
|
|
37
|
-
assistantId:
|
|
38
|
-
threadId:
|
|
39
|
-
defaultHeaders:
|
|
34
|
+
const ne = ({ children: u }) => {
|
|
35
|
+
const { apiUrl: l, assistantId: _, identity: c } = O(), { mode: p, threadId: A, setThreadId: T, getThreads: P, setThreads: j, configuration: b } = Z(), [U, w] = v([]), [x, M] = v([]), [S, G] = v(!1), [I, H] = v(null), o = te({
|
|
36
|
+
apiUrl: l,
|
|
37
|
+
assistantId: _,
|
|
38
|
+
threadId: p === "multi" ? A : null,
|
|
39
|
+
defaultHeaders: c?.authToken ? { Authorization: `Bearer ${c?.authToken}` } : void 0,
|
|
40
40
|
fetchStateHistory: !0,
|
|
41
41
|
onUpdateEvent: (t, e) => {
|
|
42
|
-
const a = [], s = (
|
|
43
|
-
if (!
|
|
44
|
-
const
|
|
45
|
-
if (Array.isArray(
|
|
46
|
-
for (const r of
|
|
42
|
+
const a = [], s = (d) => {
|
|
43
|
+
if (!d || typeof d != "object") return;
|
|
44
|
+
const g = d;
|
|
45
|
+
if (Array.isArray(g.messages))
|
|
46
|
+
for (const r of g.messages) {
|
|
47
47
|
const n = r.additional_kwargs;
|
|
48
|
-
r?.type === "ai" && r.id &&
|
|
48
|
+
if (r?.type === "ai" && r.id && n) {
|
|
49
|
+
const m = typeof n.reasoning_content == "string" && n.reasoning_content.length > 0, i = Array.isArray(n.tool_status) && n.tool_status.length > 0;
|
|
50
|
+
(m || i) && a.push(r);
|
|
51
|
+
}
|
|
49
52
|
}
|
|
50
|
-
for (const r of Object.values(
|
|
53
|
+
for (const r of Object.values(g))
|
|
51
54
|
r && typeof r == "object" && !Array.isArray(r) && s(r);
|
|
52
55
|
};
|
|
53
|
-
s(t), a.length > 0 && e.mutate((
|
|
54
|
-
const
|
|
55
|
-
|
|
56
|
+
s(t), a.length > 0 && e.mutate((d) => {
|
|
57
|
+
const g = d.messages ?? [], r = /* @__PURE__ */ new Map();
|
|
58
|
+
for (const i of a)
|
|
59
|
+
i.id && r.set(i.id, i);
|
|
60
|
+
let n = !1;
|
|
61
|
+
const m = g.map((i) => {
|
|
62
|
+
if (!i.id || !r.has(i.id)) return i;
|
|
63
|
+
const y = r.get(i.id);
|
|
64
|
+
r.delete(i.id), n = !0;
|
|
65
|
+
const K = y.additional_kwargs;
|
|
66
|
+
return {
|
|
67
|
+
...i,
|
|
68
|
+
additional_kwargs: {
|
|
69
|
+
...i.additional_kwargs ?? {},
|
|
70
|
+
...K ?? {}
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
});
|
|
74
|
+
return n ? { ...d, messages: m } : d;
|
|
56
75
|
});
|
|
57
76
|
},
|
|
58
77
|
onCustomEvent: (t, e) => {
|
|
59
|
-
(
|
|
60
|
-
|
|
61
|
-
const s =
|
|
78
|
+
(W(t) || q(t)) && e.mutate((a) => {
|
|
79
|
+
f.debug("UI Event received in StreamProvider:", t);
|
|
80
|
+
const s = D(a.ui ?? [], t);
|
|
62
81
|
return { ...a, ui: s };
|
|
63
82
|
});
|
|
64
83
|
},
|
|
65
84
|
onThreadId: (t) => {
|
|
66
|
-
t && (
|
|
85
|
+
t && (p === "single" ? A || T(t) : (T(t), re().then(() => P().then(j).catch((e) => f.error("Failed to refresh threads:", e)))));
|
|
67
86
|
}
|
|
68
|
-
}),
|
|
87
|
+
}), $ = k(
|
|
69
88
|
async (t, e) => {
|
|
70
|
-
const a = e?.id ||
|
|
89
|
+
const a = e?.id || ee(), s = typeof t == "string" ? {
|
|
71
90
|
id: a,
|
|
72
91
|
// Use the determined ID
|
|
73
92
|
type: e?.type ?? "human",
|
|
@@ -95,8 +114,8 @@ const re = ({ children: u }) => {
|
|
|
95
114
|
}
|
|
96
115
|
}
|
|
97
116
|
};
|
|
98
|
-
if (
|
|
99
|
-
if (
|
|
117
|
+
if (f.debug("Sending message via sendMessage:", s), e?.type === "ai") {
|
|
118
|
+
if (w((r) => [...r, s]), f.debug("Appended AI message to localMessages:", e?.ui), e.ui && e.ui.length > 0) {
|
|
100
119
|
const r = e.ui.map((n, m) => ({
|
|
101
120
|
...n,
|
|
102
121
|
id: a,
|
|
@@ -104,37 +123,37 @@ const re = ({ children: u }) => {
|
|
|
104
123
|
// Ensure each UI component has a unique identifier for React keys
|
|
105
124
|
_key: n._key || `${a}-ui-${m}`
|
|
106
125
|
}));
|
|
107
|
-
|
|
126
|
+
M((n) => [...n, ...r]);
|
|
108
127
|
}
|
|
109
128
|
return;
|
|
110
129
|
}
|
|
111
|
-
const
|
|
130
|
+
const d = o.messages || [], g = e?.context ? { ...c, ...e.context, ...b } : c || {};
|
|
112
131
|
await o.submit(
|
|
113
|
-
{ messages: [...
|
|
132
|
+
{ messages: [...d, s] },
|
|
114
133
|
{
|
|
115
|
-
context:
|
|
134
|
+
context: g,
|
|
116
135
|
streamMode: ["values", "messages-tuple", "updates", "custom"]
|
|
117
136
|
}
|
|
118
137
|
);
|
|
119
138
|
},
|
|
120
|
-
[o,
|
|
121
|
-
),
|
|
139
|
+
[o, c, b, w, M]
|
|
140
|
+
), h = C(() => {
|
|
122
141
|
const t = [...U, ...o.messages || []], e = /* @__PURE__ */ new Set();
|
|
123
142
|
return t.filter((a) => a.id ? e.has(a.id) ? !1 : (e.add(a.id), !0) : !0);
|
|
124
|
-
}, [U, o.messages]),
|
|
125
|
-
|
|
126
|
-
const t = [...
|
|
143
|
+
}, [U, o.messages]), R = C(() => {
|
|
144
|
+
f.debug("Combining local UI with stream UI:", x, o.values?.ui);
|
|
145
|
+
const t = [...x, ...o.values?.ui || []], e = /* @__PURE__ */ new Set();
|
|
127
146
|
return t.filter((a) => {
|
|
128
147
|
const s = a._key || `${a.id}-${a.name}`;
|
|
129
148
|
return e.has(s) ? !1 : (e.add(s), !0);
|
|
130
149
|
});
|
|
131
|
-
}, [
|
|
150
|
+
}, [x, o.values?.ui]), F = k(
|
|
132
151
|
async (t, e) => {
|
|
133
|
-
const a =
|
|
152
|
+
const a = h || [];
|
|
134
153
|
await o.submit(
|
|
135
154
|
{ messages: [...a, t] },
|
|
136
155
|
{
|
|
137
|
-
context: { ...
|
|
156
|
+
context: { ...c, ...e?.contextValues },
|
|
138
157
|
streamMode: e?.streamMode || ["values", "messages-tuple", "updates", "custom"],
|
|
139
158
|
streamSubgraphs: e?.streamSubgraphs ?? !0,
|
|
140
159
|
streamResumable: e?.streamResumable ?? !0,
|
|
@@ -145,28 +164,28 @@ const re = ({ children: u }) => {
|
|
|
145
164
|
}
|
|
146
165
|
);
|
|
147
166
|
},
|
|
148
|
-
[o,
|
|
149
|
-
),
|
|
167
|
+
[o, c, h]
|
|
168
|
+
), z = k(
|
|
150
169
|
async (t) => {
|
|
151
|
-
const e =
|
|
170
|
+
const e = h || [], a = e.findIndex((n) => n.id === t);
|
|
152
171
|
if (a === -1) {
|
|
153
|
-
|
|
172
|
+
f.error("Message not found for regeneration:", t);
|
|
154
173
|
return;
|
|
155
174
|
}
|
|
156
175
|
let s = a - 1;
|
|
157
176
|
for (; s >= 0 && e[s].type !== "human"; )
|
|
158
177
|
s--;
|
|
159
178
|
if (s === -1) {
|
|
160
|
-
|
|
179
|
+
f.error("No human message found before AI message:", t);
|
|
161
180
|
return;
|
|
162
181
|
}
|
|
163
|
-
const
|
|
164
|
-
|
|
165
|
-
(n) => n.filter((m) => e.findIndex((
|
|
166
|
-
),
|
|
167
|
-
(n) => n.filter((m) => e.findIndex((
|
|
182
|
+
const d = e.slice(0, s + 1), g = d.slice(0, -1), r = d[d.length - 1];
|
|
183
|
+
w(
|
|
184
|
+
(n) => n.filter((m) => e.findIndex((y) => y.id === m.id) < s)
|
|
185
|
+
), M(
|
|
186
|
+
(n) => n.filter((m) => e.findIndex((y) => y.id === m.id) < s)
|
|
168
187
|
), await o.submit(
|
|
169
|
-
{ messages: [...
|
|
188
|
+
{ messages: [...g, r] },
|
|
170
189
|
{
|
|
171
190
|
streamMode: ["values"],
|
|
172
191
|
streamSubgraphs: !0,
|
|
@@ -174,55 +193,55 @@ const re = ({ children: u }) => {
|
|
|
174
193
|
}
|
|
175
194
|
);
|
|
176
195
|
},
|
|
177
|
-
[
|
|
196
|
+
[h, o, c, b, w, M]
|
|
178
197
|
);
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
t ||
|
|
182
|
-
description: `Unable to reach ${
|
|
198
|
+
X(() => {
|
|
199
|
+
ae(l, c?.authToken).then((t) => {
|
|
200
|
+
t || Y.error("Failed to connect to LangGraph server", {
|
|
201
|
+
description: `Unable to reach ${l}`,
|
|
183
202
|
duration: 1e4
|
|
184
203
|
});
|
|
185
204
|
});
|
|
186
|
-
}, [
|
|
187
|
-
const
|
|
188
|
-
if (
|
|
189
|
-
return
|
|
190
|
-
if (!
|
|
191
|
-
|
|
192
|
-
const t = await
|
|
193
|
-
return
|
|
205
|
+
}, [l, c?.authToken]);
|
|
206
|
+
const B = k(async () => {
|
|
207
|
+
if (S && I !== null)
|
|
208
|
+
return I;
|
|
209
|
+
if (!S) {
|
|
210
|
+
G(!0);
|
|
211
|
+
const t = await se(l, c?.authToken);
|
|
212
|
+
return H(t), t;
|
|
194
213
|
}
|
|
195
|
-
return
|
|
196
|
-
}, [
|
|
214
|
+
return I;
|
|
215
|
+
}, [l, c?.authToken, S, I]), V = C(
|
|
197
216
|
() => ({
|
|
198
217
|
...o,
|
|
199
|
-
messages:
|
|
218
|
+
messages: h,
|
|
200
219
|
// Override with combined messages
|
|
201
220
|
values: {
|
|
202
221
|
...o.values,
|
|
203
|
-
ui:
|
|
222
|
+
ui: R
|
|
204
223
|
// Override with combined UI
|
|
205
224
|
},
|
|
206
|
-
sendMessage:
|
|
225
|
+
sendMessage: $,
|
|
207
226
|
submitMessage: F,
|
|
208
|
-
regenerateMessage:
|
|
209
|
-
fetchCatalog:
|
|
227
|
+
regenerateMessage: z,
|
|
228
|
+
fetchCatalog: B
|
|
210
229
|
}),
|
|
211
|
-
[o,
|
|
230
|
+
[o, h, R, $, F, z, B]
|
|
212
231
|
);
|
|
213
|
-
return /* @__PURE__ */
|
|
232
|
+
return /* @__PURE__ */ E(L.Provider, { value: V, children: u });
|
|
214
233
|
};
|
|
215
|
-
function
|
|
216
|
-
return /* @__PURE__ */
|
|
234
|
+
function _e({ children: u }) {
|
|
235
|
+
return /* @__PURE__ */ E(ne, { children: u });
|
|
217
236
|
}
|
|
218
|
-
function
|
|
219
|
-
const u =
|
|
237
|
+
function ye() {
|
|
238
|
+
const u = J(L);
|
|
220
239
|
if (!u)
|
|
221
240
|
throw new Error("useStreamContext must be used within StreamProvider");
|
|
222
241
|
return u;
|
|
223
242
|
}
|
|
224
243
|
export {
|
|
225
|
-
|
|
226
|
-
|
|
244
|
+
_e as StreamProvider,
|
|
245
|
+
ye as useStreamContext
|
|
227
246
|
};
|
|
228
247
|
//# sourceMappingURL=Stream.es.js.map
|