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.
Files changed (82) hide show
  1. package/README.md +412 -51
  2. package/dist/_virtual/index.cjs6.js +1 -1
  3. package/dist/_virtual/index.cjs8.js +1 -1
  4. package/dist/_virtual/index.es6.js +2 -2
  5. package/dist/_virtual/index.es8.js +2 -2
  6. package/dist/assets/langgraph-ui-components.css +1 -1
  7. package/dist/components/ChatBody.cjs.js +2 -2
  8. package/dist/components/ChatBody.cjs.js.map +1 -1
  9. package/dist/components/ChatBody.d.ts.map +1 -1
  10. package/dist/components/ChatBody.es.js +137 -98
  11. package/dist/components/ChatBody.es.js.map +1 -1
  12. package/dist/components/messages/AgentMessage.cjs.js +3 -1
  13. package/dist/components/messages/AgentMessage.cjs.js.map +1 -1
  14. package/dist/components/messages/AgentMessage.d.ts +3 -1
  15. package/dist/components/messages/AgentMessage.d.ts.map +1 -1
  16. package/dist/components/messages/AgentMessage.es.js +197 -112
  17. package/dist/components/messages/AgentMessage.es.js.map +1 -1
  18. package/dist/entries/components.cjs.js +1 -1
  19. package/dist/entries/components.d.ts.map +1 -1
  20. package/dist/entries/components.es.js +4 -5
  21. package/dist/entries/components.es.js.map +1 -1
  22. package/dist/entries/hooks.cjs.js +1 -1
  23. package/dist/entries/hooks.d.ts.map +1 -1
  24. package/dist/entries/hooks.es.js +5 -6
  25. package/dist/entries/hooks.es.js.map +1 -1
  26. package/dist/entries/providers.cjs.js +1 -1
  27. package/dist/entries/providers.d.ts +1 -1
  28. package/dist/entries/providers.d.ts.map +1 -1
  29. package/dist/entries/providers.es.js +18 -19
  30. package/dist/entries/providers.es.js.map +1 -1
  31. package/dist/index.cjs.js +1 -1
  32. package/dist/index.d.ts +1 -1
  33. package/dist/index.d.ts.map +1 -1
  34. package/dist/index.es.js +28 -29
  35. package/dist/index.es.js.map +1 -1
  36. package/dist/node_modules/.pnpm/eventemitter3@4.0.7/node_modules/eventemitter3/index.cjs.js +1 -1
  37. package/dist/node_modules/.pnpm/eventemitter3@4.0.7/node_modules/eventemitter3/index.es.js +1 -1
  38. package/dist/node_modules/.pnpm/p-timeout@3.2.0/node_modules/p-timeout/index.cjs.js +1 -1
  39. package/dist/node_modules/.pnpm/p-timeout@3.2.0/node_modules/p-timeout/index.es.js +1 -1
  40. 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
  41. 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
  42. package/dist/providers/ChatProvider.cjs.js +1 -1
  43. package/dist/providers/ChatProvider.cjs.js.map +1 -1
  44. package/dist/providers/ChatProvider.d.ts +17 -1
  45. package/dist/providers/ChatProvider.d.ts.map +1 -1
  46. package/dist/providers/ChatProvider.es.js +18 -17
  47. package/dist/providers/ChatProvider.es.js.map +1 -1
  48. package/dist/providers/ChatRuntime.es.js +4 -4
  49. package/dist/providers/CustomComponentProvider.cjs.js +1 -1
  50. package/dist/providers/CustomComponentProvider.cjs.js.map +1 -1
  51. package/dist/providers/CustomComponentProvider.d.ts +11 -0
  52. package/dist/providers/CustomComponentProvider.d.ts.map +1 -1
  53. package/dist/providers/CustomComponentProvider.es.js +51 -35
  54. package/dist/providers/CustomComponentProvider.es.js.map +1 -1
  55. package/dist/providers/Stream.cjs.js +1 -1
  56. package/dist/providers/Stream.cjs.js.map +1 -1
  57. package/dist/providers/Stream.d.ts.map +1 -1
  58. package/dist/providers/Stream.es.js +113 -94
  59. package/dist/providers/Stream.es.js.map +1 -1
  60. package/dist/providers/Thread.cjs.js +1 -1
  61. package/dist/providers/Thread.cjs.js.map +1 -1
  62. package/dist/providers/Thread.d.ts +2 -1
  63. package/dist/providers/Thread.d.ts.map +1 -1
  64. package/dist/providers/Thread.es.js +19 -19
  65. package/dist/providers/Thread.es.js.map +1 -1
  66. package/dist/styles.css +1 -1
  67. package/package.json +1 -1
  68. package/src/components/ChatBody.tsx +88 -28
  69. package/src/components/messages/AgentMessage.tsx +281 -81
  70. package/src/entries/components.ts +0 -2
  71. package/src/entries/hooks.ts +0 -2
  72. package/src/entries/providers.ts +1 -3
  73. package/src/index.css +2 -2
  74. package/src/index.ts +1 -3
  75. package/src/providers/ChatProvider.tsx +18 -1
  76. package/src/providers/CustomComponentProvider.tsx +41 -0
  77. package/src/providers/Stream.tsx +34 -15
  78. package/src/providers/Thread.tsx +2 -2
  79. package/dist/components/ToolCallFunctions.cjs.js +0 -2
  80. package/dist/components/ToolCallFunctions.cjs.js.map +0 -1
  81. package/dist/components/ToolCallFunctions.es.js +0 -75
  82. package/dist/components/ToolCallFunctions.es.js.map +0 -1
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const P=require("react/jsx-runtime"),H=require("./ChatRuntime.cjs.js"),h=require("../utils/logger.cjs.js");require("@langchain/langgraph-sdk");const O=require("@langchain/langgraph-sdk/react"),x=require("@langchain/langgraph-sdk/react-ui"),u=require("react"),V=require("sonner"),K=require("./Thread.cjs.js"),N=require("../node_modules/.pnpm/uuid@13.0.0/node_modules/uuid/dist/v4.cjs.js"),W=O.useStream,F=u.createContext(void 0);async function D(d,i){try{return(await fetch(`${d}/info`,{headers:i?{Authorization:`Bearer ${i}`}:void 0})).ok}catch{h.logger.error("Failed to initialize LangGraph Agent")}}async function J(d,i){try{const y=await fetch(`${d}/agents/catalog`,{headers:i?{Authorization:`Bearer ${i}`}:void 0});return y.ok?await y.json():null}catch{return h.logger.error("Failed to fetch LangGraph Catalog"),null}}async function Q(d=6e3){return new Promise(i=>setTimeout(i,d))}const X=({children:d})=>{const{apiUrl:i,assistantId:y,identity:l}=H.useChatRuntime(),{mode:k,threadId:C,setThreadId:T,getThreads:p,setThreads:z,configuration:v}=K.useThread(),[U,_]=u.useState([]),[S,M]=u.useState([]),[I,B]=u.useState(!1),[b,E]=u.useState(null),o=W({apiUrl:i,assistantId:y,threadId:k==="multi"?C:null,defaultHeaders:l?.authToken?{Authorization:`Bearer ${l?.authToken}`}:void 0,fetchStateHistory:!0,onUpdateEvent:(t,e)=>{const a=[],s=c=>{if(!c||typeof c!="object")return;const g=c;if(Array.isArray(g.messages))for(const r of g.messages){const n=r.additional_kwargs;r?.type==="ai"&&r.id&&typeof n?.reasoning_content=="string"&&n.reasoning_content.length>0&&a.push(r)}for(const r of Object.values(g))r&&typeof r=="object"&&!Array.isArray(r)&&s(r)};s(t),a.length>0&&e.mutate(c=>{const g=c.messages??[],r=new Set(g.map(m=>m.id).filter(Boolean)),n=a.filter(m=>!r.has(m.id));return n.length===0?c:{...c,messages:[...g,...n]}})},onCustomEvent:(t,e)=>{(x.isUIMessage(t)||x.isRemoveUIMessage(t))&&e.mutate(a=>{h.logger.debug("UI Event received in StreamProvider:",t);const s=x.uiMessageReducer(a.ui??[],t);return{...a,ui:s}})},onThreadId:t=>{t&&(k==="single"?C||T(t):(T(t),Q().then(()=>p().then(z).catch(e=>h.logger.error("Failed to refresh threads:",e)))))}}),A=u.useCallback(async(t,e)=>{const a=e?.id||N(),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(h.logger.debug("Sending message via sendMessage:",s),e?.type==="ai"){if(_(r=>[...r,s]),h.logger.debug("Appended AI message to localMessages:",e?.ui),e.ui&&e.ui.length>0){const r=e.ui.map((n,m)=>({...n,id:a,_key:n._key||`${a}-ui-${m}`}));M(n=>[...n,...r])}return}const c=o.messages||[],g=e?.context?{...l,...e.context,...v}:l||{};await o.submit({messages:[...c,s]},{context:g,streamMode:["values","messages-tuple","updates","custom"]})},[o,l,v,_,M]),f=u.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]),q=u.useMemo(()=>{h.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]),$=u.useCallback(async(t,e)=>{const a=f||[];await o.submit({messages:[...a,t]},{context:{...l,...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,l,f]),R=u.useCallback(async t=>{const e=f||[],a=e.findIndex(n=>n.id===t);if(a===-1){h.logger.error("Message not found for regeneration:",t);return}let s=a-1;for(;s>=0&&e[s].type!=="human";)s--;if(s===-1){h.logger.error("No human message found before AI message:",t);return}const c=e.slice(0,s+1),g=c.slice(0,-1),r=c[c.length-1];_(n=>n.filter(m=>e.findIndex(w=>w.id===m.id)<s)),M(n=>n.filter(m=>e.findIndex(w=>w.id===m.id)<s)),await o.submit({messages:[...g,r]},{streamMode:["values"],streamSubgraphs:!0,streamResumable:!0})},[f,o,l,v,_,M]);u.useEffect(()=>{D(i,l?.authToken).then(t=>{t||V.toast.error("Failed to connect to LangGraph server",{description:`Unable to reach ${i}`,duration:1e4})})},[i,l?.authToken]);const j=u.useCallback(async()=>{if(I&&b!==null)return b;if(!I){B(!0);const t=await J(i,l?.authToken);return E(t),t}return b},[i,l?.authToken,I,b]),L=u.useMemo(()=>({...o,messages:f,values:{...o.values,ui:q},sendMessage:A,submitMessage:$,regenerateMessage:R,fetchCatalog:j}),[o,f,q,A,$,R,j]);return P.jsx(F.Provider,{value:L,children:d})};function Y({children:d}){return P.jsx(X,{children:d})}function Z(){const d=u.useContext(F);if(!d)throw new Error("useStreamContext must be used within StreamProvider");return d}exports.StreamProvider=Y;exports.useStreamContext=Z;
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;AA8XF;;;;;;;;;;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
+ {"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 B } from "react/jsx-runtime";
1
+ import { jsx as E } from "react/jsx-runtime";
2
2
  import { useChatRuntime as O } from "./ChatRuntime.es.js";
3
- import { logger as g } from "../utils/logger.es.js";
3
+ import { logger as f } from "../utils/logger.es.js";
4
4
  import "@langchain/langgraph-sdk";
5
- import { useStream as K } from "@langchain/langgraph-sdk/react";
6
- import { isUIMessage as N, isRemoveUIMessage as W, uiMessageReducer as q } from "@langchain/langgraph-sdk/react-ui";
7
- import { useContext as D, createContext as J, useState as v, useCallback as I, useMemo as S, useEffect as Q } from "react";
8
- import { toast as X } from "sonner";
9
- import { useThread as Y } from "./Thread.es.js";
10
- import Z from "../node_modules/.pnpm/uuid@13.0.0/node_modules/uuid/dist/v4.es.js";
11
- const ee = K, E = J(void 0);
12
- async function te(u, i) {
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: i ? { Authorization: `Bearer ${i}` } : void 0
15
+ headers: l ? { Authorization: `Bearer ${l}` } : void 0
16
16
  })).ok;
17
17
  } catch {
18
- g.error("Failed to initialize LangGraph Agent");
18
+ f.error("Failed to initialize LangGraph Agent");
19
19
  }
20
20
  }
21
- async function ae(u, i) {
21
+ async function se(u, l) {
22
22
  try {
23
- const h = await fetch(`${u}/agents/catalog`, {
24
- headers: i ? { Authorization: `Bearer ${i}` } : void 0
23
+ const _ = await fetch(`${u}/agents/catalog`, {
24
+ headers: l ? { Authorization: `Bearer ${l}` } : void 0
25
25
  });
26
- return h.ok ? await h.json() : null;
26
+ return _.ok ? await _.json() : null;
27
27
  } catch {
28
- return g.error("Failed to fetch LangGraph Catalog"), null;
28
+ return f.error("Failed to fetch LangGraph Catalog"), null;
29
29
  }
30
30
  }
31
- async function se(u = 6e3) {
32
- return new Promise((i) => setTimeout(i, u));
31
+ async function re(u = 6e3) {
32
+ return new Promise((l) => setTimeout(l, u));
33
33
  }
34
- const re = ({ children: u }) => {
35
- const { apiUrl: i, assistantId: h, identity: l } = O(), { mode: C, threadId: p, setThreadId: T, getThreads: L, setThreads: P, configuration: w } = Y(), [U, _] = v([]), [b, y] = v([]), [x, j] = v(!1), [M, G] = v(null), o = ee({
36
- apiUrl: i,
37
- assistantId: h,
38
- threadId: C === "multi" ? p : null,
39
- defaultHeaders: l?.authToken ? { Authorization: `Bearer ${l?.authToken}` } : void 0,
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 = (c) => {
43
- if (!c || typeof c != "object") return;
44
- const d = c;
45
- if (Array.isArray(d.messages))
46
- for (const r of d.messages) {
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 && typeof n?.reasoning_content == "string" && n.reasoning_content.length > 0 && a.push(r);
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(d))
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((c) => {
54
- const d = c.messages ?? [], r = new Set(d.map((m) => m.id).filter(Boolean)), n = a.filter((m) => !r.has(m.id));
55
- return n.length === 0 ? c : { ...c, messages: [...d, ...n] };
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
- (N(t) || W(t)) && e.mutate((a) => {
60
- g.debug("UI Event received in StreamProvider:", t);
61
- const s = q(a.ui ?? [], t);
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 && (C === "single" ? p || T(t) : (T(t), se().then(() => L().then(P).catch((e) => g.error("Failed to refresh threads:", e)))));
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
- }), A = I(
87
+ }), $ = k(
69
88
  async (t, e) => {
70
- const a = e?.id || Z(), s = typeof t == "string" ? {
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 (g.debug("Sending message via sendMessage:", s), e?.type === "ai") {
99
- if (_((r) => [...r, s]), g.debug("Appended AI message to localMessages:", e?.ui), e.ui && e.ui.length > 0) {
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
- y((n) => [...n, ...r]);
126
+ M((n) => [...n, ...r]);
108
127
  }
109
128
  return;
110
129
  }
111
- const c = o.messages || [], d = e?.context ? { ...l, ...e.context, ...w } : l || {};
130
+ const d = o.messages || [], g = e?.context ? { ...c, ...e.context, ...b } : c || {};
112
131
  await o.submit(
113
- { messages: [...c, s] },
132
+ { messages: [...d, s] },
114
133
  {
115
- context: d,
134
+ context: g,
116
135
  streamMode: ["values", "messages-tuple", "updates", "custom"]
117
136
  }
118
137
  );
119
138
  },
120
- [o, l, w, _, y]
121
- ), f = S(() => {
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]), $ = S(() => {
125
- g.debug("Combining local UI with stream UI:", b, o.values?.ui);
126
- const t = [...b, ...o.values?.ui || []], e = /* @__PURE__ */ new Set();
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
- }, [b, o.values?.ui]), F = I(
150
+ }, [x, o.values?.ui]), F = k(
132
151
  async (t, e) => {
133
- const a = f || [];
152
+ const a = h || [];
134
153
  await o.submit(
135
154
  { messages: [...a, t] },
136
155
  {
137
- context: { ...l, ...e?.contextValues },
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, l, f]
149
- ), R = I(
167
+ [o, c, h]
168
+ ), z = k(
150
169
  async (t) => {
151
- const e = f || [], a = e.findIndex((n) => n.id === t);
170
+ const e = h || [], a = e.findIndex((n) => n.id === t);
152
171
  if (a === -1) {
153
- g.error("Message not found for regeneration:", t);
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
- g.error("No human message found before AI message:", t);
179
+ f.error("No human message found before AI message:", t);
161
180
  return;
162
181
  }
163
- const c = e.slice(0, s + 1), d = c.slice(0, -1), r = c[c.length - 1];
164
- _(
165
- (n) => n.filter((m) => e.findIndex((k) => k.id === m.id) < s)
166
- ), y(
167
- (n) => n.filter((m) => e.findIndex((k) => k.id === m.id) < s)
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: [...d, r] },
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
- [f, o, l, w, _, y]
196
+ [h, o, c, b, w, M]
178
197
  );
179
- Q(() => {
180
- te(i, l?.authToken).then((t) => {
181
- t || X.error("Failed to connect to LangGraph server", {
182
- description: `Unable to reach ${i}`,
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
- }, [i, l?.authToken]);
187
- const z = I(async () => {
188
- if (x && M !== null)
189
- return M;
190
- if (!x) {
191
- j(!0);
192
- const t = await ae(i, l?.authToken);
193
- return G(t), t;
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 M;
196
- }, [i, l?.authToken, x, M]), H = S(
214
+ return I;
215
+ }, [l, c?.authToken, S, I]), V = C(
197
216
  () => ({
198
217
  ...o,
199
- messages: f,
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: A,
225
+ sendMessage: $,
207
226
  submitMessage: F,
208
- regenerateMessage: R,
209
- fetchCatalog: z
227
+ regenerateMessage: z,
228
+ fetchCatalog: B
210
229
  }),
211
- [o, f, $, A, F, R, z]
230
+ [o, h, R, $, F, z, B]
212
231
  );
213
- return /* @__PURE__ */ B(E.Provider, { value: H, children: u });
232
+ return /* @__PURE__ */ E(L.Provider, { value: V, children: u });
214
233
  };
215
- function he({ children: u }) {
216
- return /* @__PURE__ */ B(re, { children: u });
234
+ function _e({ children: u }) {
235
+ return /* @__PURE__ */ E(ne, { children: u });
217
236
  }
218
- function _e() {
219
- const u = D(E);
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
- he as StreamProvider,
226
- _e as useStreamContext
244
+ _e as StreamProvider,
245
+ ye as useStreamContext
227
246
  };
228
247
  //# sourceMappingURL=Stream.es.js.map