@copilotkit/react-core 1.50.1-next.1 → 1.50.1-next.3

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 (51) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/{chunk-LCZZ7YGZ.mjs → chunk-3FHX5RLS.mjs} +2 -2
  3. package/dist/{chunk-YCG6SNAU.mjs → chunk-3MHWEKFN.mjs} +4 -4
  4. package/dist/{chunk-LDEWO5XH.mjs → chunk-CGKXLHL3.mjs} +31 -10
  5. package/dist/chunk-CGKXLHL3.mjs.map +1 -0
  6. package/dist/{chunk-5J7RRLRO.mjs → chunk-F62YUR4R.mjs} +2 -2
  7. package/dist/{chunk-HE22TZMF.mjs → chunk-INPM7YKW.mjs} +4 -4
  8. package/dist/{chunk-ZE4JVTEP.mjs → chunk-IZGUA5WC.mjs} +2 -2
  9. package/dist/{chunk-4YZA2BZC.mjs → chunk-RB2TXKFP.mjs} +13 -13
  10. package/dist/{chunk-LHERIF3L.mjs → chunk-SNON4QA6.mjs} +4 -4
  11. package/dist/components/copilot-provider/copilot-messages.mjs +2 -2
  12. package/dist/components/copilot-provider/copilotkit.mjs +8 -8
  13. package/dist/components/copilot-provider/index.mjs +8 -8
  14. package/dist/components/dev-console/console-trigger.mjs +2 -2
  15. package/dist/components/dev-console/developer-console-modal.mjs +2 -2
  16. package/dist/components/error-boundary/error-boundary.mjs +2 -2
  17. package/dist/components/index.mjs +8 -8
  18. package/dist/context/index.mjs +4 -4
  19. package/dist/hooks/index.d.ts +1 -1
  20. package/dist/hooks/index.js +27 -6
  21. package/dist/hooks/index.js.map +1 -1
  22. package/dist/hooks/index.mjs +30 -30
  23. package/dist/hooks/use-coagent-state-render-bridge.mjs +1 -1
  24. package/dist/hooks/use-copilot-chat-headless_c.js +27 -6
  25. package/dist/hooks/use-copilot-chat-headless_c.js.map +1 -1
  26. package/dist/hooks/use-copilot-chat-headless_c.mjs +6 -6
  27. package/dist/hooks/use-copilot-chat.js +27 -6
  28. package/dist/hooks/use-copilot-chat.js.map +1 -1
  29. package/dist/hooks/use-copilot-chat.mjs +6 -6
  30. package/dist/hooks/use-copilot-chat_internal.d.ts +24 -2
  31. package/dist/hooks/use-copilot-chat_internal.js +27 -6
  32. package/dist/hooks/use-copilot-chat_internal.js.map +1 -1
  33. package/dist/hooks/use-copilot-chat_internal.mjs +5 -5
  34. package/dist/hooks/use-langgraph-interrupt-render.mjs +1 -1
  35. package/dist/index.d.ts +1 -1
  36. package/dist/index.js +27 -6
  37. package/dist/index.js.map +1 -1
  38. package/dist/index.mjs +51 -51
  39. package/dist/lib/copilot-task.mjs +9 -9
  40. package/dist/lib/index.mjs +9 -9
  41. package/package.json +5 -5
  42. package/src/hooks/index.ts +6 -1
  43. package/src/hooks/use-copilot-chat_internal.ts +59 -3
  44. package/dist/chunk-LDEWO5XH.mjs.map +0 -1
  45. /package/dist/{chunk-LCZZ7YGZ.mjs.map → chunk-3FHX5RLS.mjs.map} +0 -0
  46. /package/dist/{chunk-YCG6SNAU.mjs.map → chunk-3MHWEKFN.mjs.map} +0 -0
  47. /package/dist/{chunk-5J7RRLRO.mjs.map → chunk-F62YUR4R.mjs.map} +0 -0
  48. /package/dist/{chunk-HE22TZMF.mjs.map → chunk-INPM7YKW.mjs.map} +0 -0
  49. /package/dist/{chunk-ZE4JVTEP.mjs.map → chunk-IZGUA5WC.mjs.map} +0 -0
  50. /package/dist/{chunk-4YZA2BZC.mjs.map → chunk-RB2TXKFP.mjs.map} +0 -0
  51. /package/dist/{chunk-LHERIF3L.mjs.map → chunk-SNON4QA6.mjs.map} +0 -0
package/CHANGELOG.md CHANGED
@@ -1,5 +1,21 @@
1
1
  # ui
2
2
 
3
+ ## 1.50.1-next.3
4
+
5
+ ### Patch Changes
6
+
7
+ - eac8b20: - fix: use latest vnext
8
+ - @copilotkit/runtime-client-gql@1.50.1-next.3
9
+ - @copilotkit/shared@1.50.1-next.3
10
+
11
+ ## 1.50.1-next.2
12
+
13
+ ### Patch Changes
14
+
15
+ - bdc7a8f: - fix: restore message callbacks
16
+ - @copilotkit/runtime-client-gql@1.50.1-next.2
17
+ - @copilotkit/shared@1.50.1-next.2
18
+
3
19
  ## 1.50.1-next.1
4
20
 
5
21
  ### Patch Changes
@@ -3,7 +3,7 @@ import {
3
3
  } from "./chunk-4CEQJ2X6.mjs";
4
4
  import {
5
5
  defaultCopilotContextCategories
6
- } from "./chunk-4YZA2BZC.mjs";
6
+ } from "./chunk-RB2TXKFP.mjs";
7
7
  import {
8
8
  __async,
9
9
  __spreadValues
@@ -117,4 +117,4 @@ ${instructions}
117
117
  export {
118
118
  CopilotTask
119
119
  };
120
- //# sourceMappingURL=chunk-LCZZ7YGZ.mjs.map
120
+ //# sourceMappingURL=chunk-3FHX5RLS.mjs.map
@@ -3,12 +3,12 @@ import {
3
3
  CopilotKitIcon,
4
4
  ExclamationMarkTriangleIcon
5
5
  } from "./chunk-PIF5KJYI.mjs";
6
- import {
7
- useCopilotContext
8
- } from "./chunk-AFNWX62Q.mjs";
9
6
  import {
10
7
  useCopilotMessagesContext
11
8
  } from "./chunk-DMLQZG75.mjs";
9
+ import {
10
+ useCopilotContext
11
+ } from "./chunk-AFNWX62Q.mjs";
12
12
 
13
13
  // src/components/dev-console/developer-console-modal.tsx
14
14
  import { COPILOTKIT_VERSION } from "@copilotkit/shared";
@@ -756,4 +756,4 @@ function ContextTab({ context }) {
756
756
  export {
757
757
  DeveloperConsoleModal
758
758
  };
759
- //# sourceMappingURL=chunk-YCG6SNAU.mjs.map
759
+ //# sourceMappingURL=chunk-3MHWEKFN.mjs.map
@@ -1,9 +1,9 @@
1
- import {
2
- useLangGraphInterruptRender
3
- } from "./chunk-VV56AVPB.mjs";
4
1
  import {
5
2
  useLazyToolRenderer
6
3
  } from "./chunk-ZVF5Q6IH.mjs";
4
+ import {
5
+ useLangGraphInterruptRender
6
+ } from "./chunk-VV56AVPB.mjs";
7
7
  import {
8
8
  useAsyncCallback
9
9
  } from "./chunk-6PUNP7CD.mjs";
@@ -31,7 +31,11 @@ import {
31
31
  } from "@copilotkitnext/react";
32
32
  import { AGUIConnectNotImplementedError } from "@ag-ui/client";
33
33
  function useCopilotChatInternal({
34
- suggestions
34
+ suggestions,
35
+ onInProgress,
36
+ onSubmitMessage,
37
+ onStopGeneration,
38
+ onReloadMessages
35
39
  } = {}) {
36
40
  var _a, _b, _c;
37
41
  const { copilotkit } = useCopilotKit();
@@ -60,6 +64,9 @@ function useCopilotChatInternal({
60
64
  return () => {
61
65
  };
62
66
  }, [existingConfig == null ? void 0 : existingConfig.threadId, agent, copilotkit, resolvedAgentId]);
67
+ useEffect(() => {
68
+ onInProgress == null ? void 0 : onInProgress(Boolean(agent == null ? void 0 : agent.isRunning));
69
+ }, [agent == null ? void 0 : agent.isRunning, onInProgress]);
63
70
  const interrupt = useLangGraphInterruptRender(agent);
64
71
  const reset = () => {
65
72
  agent == null ? void 0 : agent.setMessages([]);
@@ -140,8 +147,12 @@ function useCopilotChatInternal({
140
147
  console.error("CopilotChat: runAgent failed", error);
141
148
  }
142
149
  }
150
+ if (onSubmitMessage) {
151
+ const content = typeof message.content === "string" ? message.content : message.content && "text" in message.content ? message.content.text : message.content && "filename" in message.content ? message.content.filename : "";
152
+ onSubmitMessage(content);
153
+ }
143
154
  }),
144
- [agent, copilotkit, resolvedAgentId]
155
+ [agent, copilotkit, resolvedAgentId, onSubmitMessage]
145
156
  );
146
157
  const latestAppendFunc = useAsyncCallback(
147
158
  (message, options) => __async(this, null, function* () {
@@ -162,14 +173,24 @@ function useCopilotChatInternal({
162
173
  const latestReload = useUpdatedRef(reload);
163
174
  const latestReloadFunc = useAsyncCallback(
164
175
  (messageId) => __async(this, null, function* () {
176
+ var _a2;
177
+ onReloadMessages == null ? void 0 : onReloadMessages({
178
+ messageId,
179
+ currentAgentName: agent == null ? void 0 : agent.agentId,
180
+ messages: (_a2 = agent == null ? void 0 : agent.messages) != null ? _a2 : []
181
+ });
165
182
  return yield latestReload.current(messageId);
166
183
  }),
167
- [latestReload]
184
+ [latestReload, agent, onReloadMessages]
168
185
  );
169
186
  const latestStopFunc = useCallback(() => {
170
- var _a2;
171
- return (_a2 = agent == null ? void 0 : agent.abortRun) == null ? void 0 : _a2.call(agent);
172
- }, [agent == null ? void 0 : agent.abortRun]);
187
+ var _a2, _b2;
188
+ onStopGeneration == null ? void 0 : onStopGeneration({
189
+ currentAgentName: agent == null ? void 0 : agent.agentId,
190
+ messages: (_a2 = agent == null ? void 0 : agent.messages) != null ? _a2 : []
191
+ });
192
+ return (_b2 = agent == null ? void 0 : agent.abortRun) == null ? void 0 : _b2.call(agent);
193
+ }, [onStopGeneration, agent]);
173
194
  const latestReset = useUpdatedRef(reset);
174
195
  const latestResetFunc = useCallback(() => {
175
196
  return latestReset.current();
@@ -325,4 +346,4 @@ export {
325
346
  useCopilotChatInternal,
326
347
  defaultSystemMessage
327
348
  };
328
- //# sourceMappingURL=chunk-LDEWO5XH.mjs.map
349
+ //# sourceMappingURL=chunk-CGKXLHL3.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/hooks/use-copilot-chat_internal.ts"],"sourcesContent":["import { useRef, useEffect, useCallback, useMemo, useState, createElement } from \"react\";\nimport { useCopilotContext } from \"../context/copilot-context\";\nimport { SystemMessageFunction } from \"../types\";\nimport { useAsyncCallback } from \"../components/error-boundary/error-utils\";\nimport { Message } from \"@copilotkit/shared\";\nimport { gqlToAGUI, Message as DeprecatedGqlMessage } from \"@copilotkit/runtime-client-gql\";\nimport { useLangGraphInterruptRender } from \"./use-langgraph-interrupt-render\";\nimport {\n useAgent,\n useCopilotChatConfiguration,\n useCopilotKit,\n useRenderCustomMessages,\n useSuggestions,\n} from \"@copilotkitnext/react\";\nimport { Suggestion } from \"@copilotkitnext/core\";\nimport { useLazyToolRenderer } from \"./use-lazy-tool-renderer\";\nimport { AbstractAgent, AGUIConnectNotImplementedError } from \"@ag-ui/client\";\nimport {\n CoAgentStateRenderBridge,\n type CoAgentStateRenderBridgeProps,\n} from \"./use-coagent-state-render-bridge\";\n\n/**\n * The type of suggestions to use in the chat.\n *\n * `auto` - Suggestions are generated automatically.\n * `manual` - Suggestions are controlled programmatically.\n * `SuggestionItem[]` - Static suggestions array.\n */\nexport type ChatSuggestions = \"auto\" | \"manual\" | Omit<Suggestion, \"isLoading\">[];\n\nexport interface AppendMessageOptions {\n /**\n * Whether to run the chat completion after appending the message. Defaults to `true`.\n */\n followUp?: boolean;\n /**\n * Whether to clear the suggestions after appending the message. Defaults to `true`.\n */\n clearSuggestions?: boolean;\n}\n\nexport interface OnStopGenerationArguments {\n /**\n * The name of the currently executing agent.\n */\n currentAgentName: string | undefined;\n\n /**\n * The messages in the chat.\n */\n messages: Message[];\n}\n\nexport type OnReloadMessagesArguments = OnStopGenerationArguments & {\n /**\n * The message on which \"regenerate\" was pressed\n */\n messageId: string;\n};\n\nexport type OnStopGeneration = (args: OnStopGenerationArguments) => void;\n\nexport type OnReloadMessages = (args: OnReloadMessagesArguments) => void;\n\nexport interface UseCopilotChatOptions {\n /**\n * A unique identifier for the chat. If not provided, a random one will be\n * generated. When provided, the `useChat` hook with the same `id` will\n * have shared states across components.\n */\n id?: string;\n\n /**\n * HTTP headers to be sent with the API request.\n */\n headers?: Record<string, string> | Headers;\n\n /**\n * Initial messages to populate the chat with.\n */\n initialMessages?: Message[];\n\n /**\n * A function to generate the system message. Defaults to `defaultSystemMessage`.\n */\n makeSystemMessage?: SystemMessageFunction;\n\n /**\n * Disables inclusion of CopilotKit’s default system message. When true, no system message is sent (this also suppresses any custom message from <code>makeSystemMessage</code>).\n */\n disableSystemMessage?: boolean;\n /**\n * Controls the behavior of suggestions in the chat interface.\n *\n * `auto` (default) - Suggestions are generated automatically:\n * - When the chat is first opened (empty state)\n * - After each message exchange completes\n * - Uses configuration from `useCopilotChatSuggestions` hooks\n *\n * `manual` - Suggestions are controlled programmatically:\n * - Use `setSuggestions()` to set custom suggestions\n * - Use `generateSuggestions()` to trigger AI generation\n * - Access via `useCopilotChat` hook\n *\n * `SuggestionItem[]` - Static suggestions array:\n * - Always shows the same suggestions\n * - No AI generation involved\n */\n suggestions?: ChatSuggestions;\n\n onInProgress?: (isLoading: boolean) => void;\n onSubmitMessage?: (messageContent: string) => Promise<void> | void;\n onStopGeneration?: OnStopGeneration;\n onReloadMessages?: OnReloadMessages;\n}\n\nexport interface MCPServerConfig {\n endpoint: string;\n apiKey?: string;\n}\n\n// Old suggestion item interface, for returning from useCopilotChatInternal\ninterface SuggestionItem {\n title: string;\n message: string;\n partial?: boolean;\n className?: string;\n}\n\nexport interface UseCopilotChatReturn {\n /**\n * @deprecated use `messages` instead, this is an old non ag-ui version of the messages\n * Array of messages currently visible in the chat interface\n *\n * This is the visible messages, not the raw messages from the runtime client.\n */\n visibleMessages: DeprecatedGqlMessage[];\n\n /**\n * The messages that are currently in the chat in AG-UI format.\n */\n messages: Message[];\n\n /** @deprecated use `sendMessage` in `useCopilotChatHeadless_c` instead. This will be removed in a future major version. */\n appendMessage: (message: DeprecatedGqlMessage, options?: AppendMessageOptions) => Promise<void>;\n\n /**\n * Send a new message to the chat\n *\n * ```tsx\n * await sendMessage({\n * id: \"123\",\n * role: \"user\",\n * content: \"Hello, process this request\",\n * });\n * ```\n */\n sendMessage: (message: Message, options?: AppendMessageOptions) => Promise<void>;\n\n /**\n * Replace all messages in the chat\n *\n * ```tsx\n * setMessages([\n * { id: \"123\", role: \"user\", content: \"Hello, process this request\" },\n * { id: \"456\", role: \"assistant\", content: \"Hello, I'm the assistant\" },\n * ]);\n * ```\n *\n * **Deprecated** non-ag-ui version:\n *\n * ```tsx\n * setMessages([\n * new TextMessage({\n * content: \"Hello, process this request\",\n * role: gqlRole.User,\n * }),\n * new TextMessage({\n * content: \"Hello, I'm the assistant\",\n * role: gqlRole.Assistant,\n * ]);\n * ```\n *\n */\n setMessages: (messages: Message[] | DeprecatedGqlMessage[]) => void;\n\n /**\n * Remove a specific message by ID\n *\n * ```tsx\n * deleteMessage(\"123\");\n * ```\n */\n deleteMessage: (messageId: string) => void;\n\n /**\n * Regenerate the response for a specific message\n *\n * ```tsx\n * reloadMessages(\"123\");\n * ```\n */\n reloadMessages: (messageId: string) => Promise<void>;\n\n /**\n * Stop the current message generation\n *\n * ```tsx\n * if (isLoading) {\n * stopGeneration();\n * }\n * ```\n */\n stopGeneration: () => void;\n\n /**\n * Clear all messages and reset chat state\n *\n * ```tsx\n * reset();\n * console.log(messages); // []\n * ```\n */\n reset: () => void;\n\n /**\n * Whether the chat is currently generating a response\n *\n * ```tsx\n * if (isLoading) {\n * console.log(\"Loading...\");\n * } else {\n * console.log(\"Not loading\");\n * }\n */\n isLoading: boolean;\n\n /**\n * Whether the chat agent is available to generate responses\n *\n * ```tsx\n * if (isAvailable) {\n * console.log(\"Loading...\");\n * } else {\n * console.log(\"Not loading\");\n * }\n */\n isAvailable: boolean;\n\n /** Manually trigger chat completion (advanced usage) */\n runChatCompletion: () => Promise<Message[]>;\n\n /** MCP (Model Context Protocol) server configurations */\n mcpServers: MCPServerConfig[];\n\n /** Update MCP server configurations */\n setMcpServers: (mcpServers: MCPServerConfig[]) => void;\n\n /**\n * Current suggestions array\n * Use this to read the current suggestions or in conjunction with setSuggestions for manual control\n */\n suggestions: Suggestion[];\n\n /**\n * Manually set suggestions\n * Useful for manual mode or custom suggestion workflows\n */\n setSuggestions: (suggestions: Omit<Suggestion, \"isLoading\">[]) => void;\n\n /**\n * Trigger AI-powered suggestion generation\n * Uses configurations from useCopilotChatSuggestions hooks\n * Respects global debouncing - only one generation can run at a time\n *\n * ```tsx\n * generateSuggestions();\n * console.log(suggestions); // [suggestion1, suggestion2, suggestion3]\n * ```\n */\n generateSuggestions: () => Promise<void>;\n\n /**\n * Clear all current suggestions\n * Also resets suggestion generation state\n */\n resetSuggestions: () => void;\n\n /** Whether suggestions are currently being generated */\n isLoadingSuggestions: boolean;\n\n /** Interrupt content for human-in-the-loop workflows */\n interrupt: string | React.ReactElement | null;\n\n agent?: ReturnType<typeof useAgent>[\"agent\"];\n\n threadId?: string;\n}\n\nexport function useCopilotChatInternal({\n suggestions,\n onInProgress,\n onSubmitMessage,\n onStopGeneration,\n onReloadMessages,\n}: UseCopilotChatOptions = {}): UseCopilotChatReturn {\n const { copilotkit } = useCopilotKit();\n const { threadId, agentSession } = useCopilotContext();\n const existingConfig = useCopilotChatConfiguration();\n const [agentAvailable, setAgentAvailable] = useState(false);\n\n // Apply priority: props > existing config > defaults\n const resolvedAgentId = existingConfig?.agentId ?? \"default\";\n const { agent } = useAgent({ agentId: resolvedAgentId });\n\n useEffect(() => {\n const connect = async (agent: AbstractAgent) => {\n setAgentAvailable(false);\n try {\n await copilotkit.connectAgent({ agent });\n setAgentAvailable(true);\n } catch (error) {\n if (error instanceof AGUIConnectNotImplementedError) {\n // connect not implemented, ignore\n } else {\n throw error;\n }\n }\n };\n if (agent && existingConfig?.threadId && agent.threadId !== existingConfig.threadId) {\n agent.threadId = existingConfig.threadId;\n connect(agent);\n }\n return () => {};\n }, [existingConfig?.threadId, agent, copilotkit, resolvedAgentId]);\n\n useEffect(() => {\n onInProgress?.(Boolean(agent?.isRunning));\n }, [agent?.isRunning, onInProgress]);\n\n const interrupt = useLangGraphInterruptRender(agent);\n\n const reset = () => {\n agent?.setMessages([]);\n agent?.setState(null);\n };\n\n const deleteMessage = useCallback(\n (messageId: string) => {\n const filteredMessages = (agent?.messages ?? []).filter(\n (message) => message.id !== messageId,\n );\n agent?.setMessages(filteredMessages);\n },\n [agent?.setMessages, agent?.messages],\n );\n\n const latestDelete = useUpdatedRef(deleteMessage);\n const latestDeleteFunc = useCallback(\n (messageId: string) => {\n return latestDelete.current(messageId);\n },\n [latestDelete],\n );\n\n const currentSuggestions = useSuggestions({ agentId: resolvedAgentId });\n\n const reload = useAsyncCallback(\n async (reloadMessageId: string): Promise<void> => {\n const messages = agent?.messages ?? [];\n // TODO: get isLoading\n const isLoading = false;\n if (isLoading || messages.length === 0) {\n return;\n }\n\n const reloadMessageIndex = messages.findIndex((msg) => msg.id === reloadMessageId);\n if (reloadMessageIndex === -1) {\n console.warn(`Message with id ${reloadMessageId} not found`);\n return;\n }\n\n const reloadMessageRole = messages[reloadMessageIndex].role;\n if (reloadMessageRole !== \"assistant\") {\n console.warn(`Regenerate cannot be performed on ${reloadMessageRole} role`);\n return;\n }\n let historyCutoff: Message[] = [messages[0]];\n\n if (messages.length > 2 && reloadMessageIndex !== 0) {\n // message to regenerate from is now first.\n // Work backwards to find the first the closest user message\n const lastUserMessageBeforeRegenerate = messages\n .slice(0, reloadMessageIndex)\n .reverse()\n .find((msg) => msg.role === \"user\");\n\n if (!lastUserMessageBeforeRegenerate) {\n historyCutoff = [messages[0]];\n } else {\n const indexOfLastUserMessageBeforeRegenerate = messages.findIndex(\n (msg) => msg.id === lastUserMessageBeforeRegenerate.id,\n );\n // Include the user message, remove everything after it\n historyCutoff = messages.slice(0, indexOfLastUserMessageBeforeRegenerate + 1);\n }\n } else if (messages.length > 2 && reloadMessageIndex === 0) {\n historyCutoff = [messages[0], messages[1]];\n }\n\n agent?.setMessages(historyCutoff);\n\n if (agent) {\n copilotkit.runAgent({ agent });\n }\n return;\n },\n [agent?.setMessages, copilotkit?.runAgent],\n );\n\n const latestSendMessageFunc = useAsyncCallback(\n async (message: Message, options?: AppendMessageOptions) => {\n if (!agent) return;\n const followUp = options?.followUp ?? true;\n if (options?.clearSuggestions) {\n copilotkit.clearSuggestions(resolvedAgentId);\n }\n agent?.addMessage(message);\n if (followUp) {\n try {\n await copilotkit.runAgent({ agent });\n } catch (error) {\n console.error(\"CopilotChat: runAgent failed\", error);\n }\n }\n if (onSubmitMessage) {\n const content =\n typeof message.content === \"string\"\n ? message.content\n : message.content && \"text\" in message.content\n ? message.content.text\n : message.content && \"filename\" in message.content\n ? message.content.filename\n : \"\";\n onSubmitMessage(content);\n }\n },\n [agent, copilotkit, resolvedAgentId, onSubmitMessage],\n );\n\n const latestAppendFunc = useAsyncCallback(\n async (message: DeprecatedGqlMessage, options?: AppendMessageOptions) => {\n return latestSendMessageFunc(gqlToAGUI([message])[0], options);\n },\n [latestSendMessageFunc],\n );\n\n const latestSetMessagesFunc = useCallback(\n (messages: Message[] | DeprecatedGqlMessage[]) => {\n if (messages.every((message) => message instanceof DeprecatedGqlMessage)) {\n return agent?.setMessages?.(gqlToAGUI(messages));\n }\n return agent?.setMessages?.(messages);\n },\n [agent?.setMessages, agent],\n );\n\n const latestReload = useUpdatedRef(reload);\n const latestReloadFunc = useAsyncCallback(\n async (messageId: string) => {\n onReloadMessages?.({\n messageId,\n currentAgentName: agent?.agentId,\n messages: agent?.messages ?? [],\n });\n return await latestReload.current(messageId);\n },\n [latestReload, agent, onReloadMessages],\n );\n\n const latestStopFunc = useCallback(() => {\n onStopGeneration?.({\n currentAgentName: agent?.agentId,\n messages: agent?.messages ?? [],\n });\n return agent?.abortRun?.();\n }, [onStopGeneration, agent]);\n\n const latestReset = useUpdatedRef(reset);\n const latestResetFunc = useCallback(() => {\n return latestReset.current();\n }, [latestReset]);\n\n const lazyToolRendered = useLazyToolRenderer();\n const renderCustomMessage = useRenderCustomMessages();\n const legacyCustomMessageRenderer = useLegacyCoagentRenderer({\n copilotkit,\n agent,\n agentId: resolvedAgentId,\n threadId: existingConfig?.threadId ?? threadId,\n });\n const allMessages = agent?.messages ?? [];\n const resolvedMessages = useMemo(() => {\n let processedMessages = allMessages.map((message) => {\n if (message.role !== \"assistant\") {\n return message;\n }\n\n const lazyRendered = lazyToolRendered(message, allMessages);\n if (lazyRendered) {\n const renderedGenUi = lazyRendered();\n if (renderedGenUi) {\n return { ...message, generativeUI: () => renderedGenUi };\n }\n }\n\n const bridgeRenderer =\n legacyCustomMessageRenderer || renderCustomMessage\n ? () => {\n const customRender = renderCustomMessage?.({\n message,\n position: \"before\",\n });\n if (customRender) {\n return customRender;\n }\n return legacyCustomMessageRenderer?.({ message, position: \"before\" });\n }\n : null;\n\n if (bridgeRenderer) {\n return { ...message, generativeUI: bridgeRenderer };\n }\n return message;\n });\n\n const hasAssistantMessages = processedMessages.some((msg) => msg.role === \"assistant\");\n\n // TODO: what is this?\n // if (legacyCustomMessageRenderer && !hasAssistantMessages) {\n // const placeholderId = `coagent-state-render-${resolvedAgentId}`;\n // const placeholderMessage: Message = {\n // id: placeholderId,\n // role: \"assistant\",\n // content: \"\",\n // name: \"coagent-state-render\",\n // };\n // processedMessages = [\n // ...processedMessages,\n // {\n // ...placeholderMessage,\n // generativeUI: () =>\n // legacyCustomMessageRenderer({\n // message: placeholderMessage,\n // position: \"before\",\n // }),\n // } as Message,\n // ];\n // }\n\n return processedMessages;\n }, [\n agent?.messages,\n lazyToolRendered,\n allMessages,\n renderCustomMessage,\n // legacyCustomMessageRenderer,\n resolvedAgentId,\n ]);\n\n const renderedSuggestions = useMemo(() => {\n if (Array.isArray(suggestions)) {\n return {\n suggestions: suggestions.map((s) => ({ ...s, isLoading: false })),\n isLoading: false,\n };\n }\n return currentSuggestions;\n }, [suggestions, currentSuggestions]);\n\n // @ts-ignore\n return {\n messages: resolvedMessages,\n sendMessage: latestSendMessageFunc,\n appendMessage: latestAppendFunc,\n setMessages: latestSetMessagesFunc,\n reloadMessages: latestReloadFunc,\n stopGeneration: latestStopFunc,\n reset: latestResetFunc,\n deleteMessage: latestDeleteFunc,\n isAvailable: agentAvailable,\n isLoading: Boolean(agent?.isRunning),\n // mcpServers,\n // setMcpServers,\n suggestions: renderedSuggestions.suggestions,\n setSuggestions: (suggestions: Omit<Suggestion, \"isLoading\">[]) =>\n copilotkit.addSuggestionsConfig({ suggestions }),\n generateSuggestions: async () => copilotkit.reloadSuggestions(resolvedAgentId),\n resetSuggestions: () => copilotkit.clearSuggestions(resolvedAgentId),\n isLoadingSuggestions: renderedSuggestions.isLoading,\n interrupt,\n agent,\n threadId,\n };\n}\n\n// store `value` in a ref and update\n// it whenever it changes.\nfunction useUpdatedRef<T>(value: T) {\n const ref = useRef(value);\n\n useEffect(() => {\n ref.current = value;\n }, [value]);\n\n return ref;\n}\n\ntype LegacyRenderParams = {\n message: Message;\n position: \"before\" | \"after\";\n};\n\ntype LegacyRenderer = ((args: LegacyRenderParams) => any) | null;\n\nfunction useLegacyCoagentRenderer({\n copilotkit,\n agent,\n agentId,\n threadId,\n}: {\n copilotkit: ReturnType<typeof useCopilotKit>[\"copilotkit\"];\n agent?: AbstractAgent;\n agentId: string;\n threadId?: string;\n}): LegacyRenderer {\n return useMemo(() => {\n if (!copilotkit || !agent) {\n return null;\n }\n\n return ({ message, position }: LegacyRenderParams) => {\n const effectiveThreadId = threadId ?? agent.threadId ?? \"default\";\n const existingRunId = copilotkit.getRunIdForMessage(agentId, effectiveThreadId, message.id);\n const runId = existingRunId || `pending:${message.id}`;\n const messageIndex = Math.max(\n agent.messages.findIndex((msg) => msg.id === message.id),\n 0,\n );\n\n const bridgeProps: CoAgentStateRenderBridgeProps = {\n message: message as any,\n position,\n runId,\n messageIndex,\n messageIndexInRun: 0,\n numberOfMessagesInRun: 1,\n agentId,\n stateSnapshot: (message as any).state,\n };\n\n return createElement(CoAgentStateRenderBridge, bridgeProps) as any;\n };\n }, [agent, agentId, copilotkit, threadId]);\n}\n\nexport function defaultSystemMessage(\n contextString: string,\n additionalInstructions?: string,\n): string {\n return (\n `\nPlease act as an efficient, competent, conscientious, and industrious professional assistant.\n\nHelp the user achieve their goals, and you do so in a way that is as efficient as possible, without unnecessary fluff, but also without sacrificing professionalism.\nAlways be polite and respectful, and prefer brevity over verbosity.\n\nThe user has provided you with the following context:\n\\`\\`\\`\n${contextString}\n\\`\\`\\`\n\nThey have also provided you with functions you can call to initiate actions on their behalf, or functions you can call to receive more information.\n\nPlease assist them as best you can.\n\nYou can ask them for clarifying questions if needed, but don't be annoying about it. If you can reasonably 'fill in the blanks' yourself, do so.\n\nIf you would like to call a function, call it without saying anything else.\nIn case of a function error:\n- If this error stems from incorrect function parameters or syntax, you may retry with corrected arguments.\n- If the error's source is unclear or seems unrelated to your input, do not attempt further retries.\n` + (additionalInstructions ? `\\n\\n${additionalInstructions}` : \"\")\n );\n}\n"],"mappings":"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","names":["agent","_a","_b","suggestions"]}
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  useCopilotChatInternal
3
- } from "./chunk-LDEWO5XH.mjs";
3
+ } from "./chunk-CGKXLHL3.mjs";
4
4
  import {
5
5
  useCopilotContext
6
6
  } from "./chunk-AFNWX62Q.mjs";
@@ -83,4 +83,4 @@ function useCopilotChatHeadless_c(options = {}) {
83
83
  export {
84
84
  useCopilotChatHeadless_c
85
85
  };
86
- //# sourceMappingURL=chunk-5J7RRLRO.mjs.map
86
+ //# sourceMappingURL=chunk-F62YUR4R.mjs.map
@@ -4,12 +4,12 @@ import {
4
4
  import {
5
5
  useToast
6
6
  } from "./chunk-EFL5OBKN.mjs";
7
- import {
8
- useCopilotContext
9
- } from "./chunk-AFNWX62Q.mjs";
10
7
  import {
11
8
  CopilotMessagesContext
12
9
  } from "./chunk-DMLQZG75.mjs";
10
+ import {
11
+ useCopilotContext
12
+ } from "./chunk-AFNWX62Q.mjs";
13
13
  import {
14
14
  __async
15
15
  } from "./chunk-SKC7AJIV.mjs";
@@ -183,4 +183,4 @@ export {
183
183
  MessagesTapProvider,
184
184
  CopilotMessages
185
185
  };
186
- //# sourceMappingURL=chunk-HE22TZMF.mjs.map
186
+ //# sourceMappingURL=chunk-INPM7YKW.mjs.map
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  useCopilotChatInternal
3
- } from "./chunk-LDEWO5XH.mjs";
3
+ } from "./chunk-CGKXLHL3.mjs";
4
4
 
5
5
  // src/hooks/use-copilot-chat.ts
6
6
  function useCopilotChat(options = {}) {
@@ -33,4 +33,4 @@ function useCopilotChat(options = {}) {
33
33
  export {
34
34
  useCopilotChat
35
35
  };
36
- //# sourceMappingURL=chunk-ZE4JVTEP.mjs.map
36
+ //# sourceMappingURL=chunk-IZGUA5WC.mjs.map
@@ -1,10 +1,10 @@
1
1
  import {
2
2
  CopilotErrorBoundary
3
- } from "./chunk-LHERIF3L.mjs";
3
+ } from "./chunk-SNON4QA6.mjs";
4
4
  import {
5
5
  CopilotMessages,
6
6
  MessagesTapProvider
7
- } from "./chunk-HE22TZMF.mjs";
7
+ } from "./chunk-INPM7YKW.mjs";
8
8
  import {
9
9
  shouldShowDevConsole
10
10
  } from "./chunk-ICIK2BSB.mjs";
@@ -14,23 +14,23 @@ import {
14
14
  import {
15
15
  use_flat_category_store_default
16
16
  } from "./chunk-YYN33GSG.mjs";
17
- import {
18
- CoAgentStateRenderBridge
19
- } from "./chunk-QNUAXSDP.mjs";
20
- import {
21
- ThreadsProvider,
22
- useThreads
23
- } from "./chunk-F555TVE4.mjs";
24
17
  import {
25
18
  CopilotListeners
26
19
  } from "./chunk-WF65O6HX.mjs";
27
- import {
28
- ToastProvider
29
- } from "./chunk-EFL5OBKN.mjs";
30
20
  import {
31
21
  UsageBanner,
32
22
  getErrorActions
33
23
  } from "./chunk-6ZLPNY7X.mjs";
24
+ import {
25
+ ToastProvider
26
+ } from "./chunk-EFL5OBKN.mjs";
27
+ import {
28
+ CoAgentStateRenderBridge
29
+ } from "./chunk-QNUAXSDP.mjs";
30
+ import {
31
+ ThreadsProvider,
32
+ useThreads
33
+ } from "./chunk-F555TVE4.mjs";
34
34
  import {
35
35
  CoAgentStateRendersProvider
36
36
  } from "./chunk-FDOMAPJY.mjs";
@@ -548,4 +548,4 @@ export {
548
548
  CopilotKitInternal,
549
549
  defaultCopilotContextCategories
550
550
  };
551
- //# sourceMappingURL=chunk-4YZA2BZC.mjs.map
551
+ //# sourceMappingURL=chunk-RB2TXKFP.mjs.map
@@ -1,13 +1,13 @@
1
1
  import {
2
2
  StatusChecker
3
3
  } from "./chunk-PMAFHQ7P.mjs";
4
- import {
5
- useErrorToast
6
- } from "./chunk-6PUNP7CD.mjs";
7
4
  import {
8
5
  UsageBanner,
9
6
  getErrorActions
10
7
  } from "./chunk-6ZLPNY7X.mjs";
8
+ import {
9
+ useErrorToast
10
+ } from "./chunk-6PUNP7CD.mjs";
11
11
 
12
12
  // src/components/error-boundary/error-boundary.tsx
13
13
  import React, { useEffect } from "react";
@@ -80,4 +80,4 @@ export {
80
80
  CopilotErrorBoundary,
81
81
  ErrorToast
82
82
  };
83
- //# sourceMappingURL=chunk-LHERIF3L.mjs.map
83
+ //# sourceMappingURL=chunk-SNON4QA6.mjs.map
@@ -2,11 +2,11 @@ import {
2
2
  CopilotMessages,
3
3
  MessagesTapProvider,
4
4
  useMessagesTap
5
- } from "../../chunk-HE22TZMF.mjs";
5
+ } from "../../chunk-INPM7YKW.mjs";
6
6
  import "../../chunk-ICIK2BSB.mjs";
7
7
  import "../../chunk-EFL5OBKN.mjs";
8
- import "../../chunk-AFNWX62Q.mjs";
9
8
  import "../../chunk-DMLQZG75.mjs";
9
+ import "../../chunk-AFNWX62Q.mjs";
10
10
  import "../../chunk-SKC7AJIV.mjs";
11
11
  export {
12
12
  CopilotMessages,
@@ -2,26 +2,26 @@ import {
2
2
  CopilotKit,
3
3
  CopilotKitInternal,
4
4
  defaultCopilotContextCategories
5
- } from "../../chunk-4YZA2BZC.mjs";
6
- import "../../chunk-LHERIF3L.mjs";
7
- import "../../chunk-HE22TZMF.mjs";
5
+ } from "../../chunk-RB2TXKFP.mjs";
6
+ import "../../chunk-SNON4QA6.mjs";
7
+ import "../../chunk-INPM7YKW.mjs";
8
8
  import "../../chunk-CYDWEPFL.mjs";
9
9
  import "../../chunk-2IDV5OHF.mjs";
10
10
  import "../../chunk-ICIK2BSB.mjs";
11
- import "../../chunk-RKTVJRK7.mjs";
12
11
  import "../../chunk-PMAFHQ7P.mjs";
12
+ import "../../chunk-RKTVJRK7.mjs";
13
13
  import "../../chunk-YYN33GSG.mjs";
14
+ import "../../chunk-WF65O6HX.mjs";
15
+ import "../../chunk-6ZLPNY7X.mjs";
14
16
  import "../../chunk-6PUNP7CD.mjs";
15
17
  import "../../chunk-O7ARI5CV.mjs";
18
+ import "../../chunk-EFL5OBKN.mjs";
16
19
  import "../../chunk-QNUAXSDP.mjs";
17
20
  import "../../chunk-NB2FKV2V.mjs";
18
21
  import "../../chunk-F555TVE4.mjs";
19
- import "../../chunk-WF65O6HX.mjs";
20
- import "../../chunk-EFL5OBKN.mjs";
21
- import "../../chunk-6ZLPNY7X.mjs";
22
+ import "../../chunk-DMLQZG75.mjs";
22
23
  import "../../chunk-FDOMAPJY.mjs";
23
24
  import "../../chunk-AFNWX62Q.mjs";
24
- import "../../chunk-DMLQZG75.mjs";
25
25
  import "../../chunk-SKC7AJIV.mjs";
26
26
  export {
27
27
  CopilotKit,
@@ -2,26 +2,26 @@ import "../../chunk-SPCZTZCY.mjs";
2
2
  import {
3
3
  CopilotKit,
4
4
  defaultCopilotContextCategories
5
- } from "../../chunk-4YZA2BZC.mjs";
6
- import "../../chunk-LHERIF3L.mjs";
7
- import "../../chunk-HE22TZMF.mjs";
5
+ } from "../../chunk-RB2TXKFP.mjs";
6
+ import "../../chunk-SNON4QA6.mjs";
7
+ import "../../chunk-INPM7YKW.mjs";
8
8
  import "../../chunk-CYDWEPFL.mjs";
9
9
  import "../../chunk-2IDV5OHF.mjs";
10
10
  import "../../chunk-ICIK2BSB.mjs";
11
- import "../../chunk-RKTVJRK7.mjs";
12
11
  import "../../chunk-PMAFHQ7P.mjs";
12
+ import "../../chunk-RKTVJRK7.mjs";
13
13
  import "../../chunk-YYN33GSG.mjs";
14
+ import "../../chunk-WF65O6HX.mjs";
15
+ import "../../chunk-6ZLPNY7X.mjs";
14
16
  import "../../chunk-6PUNP7CD.mjs";
15
17
  import "../../chunk-O7ARI5CV.mjs";
18
+ import "../../chunk-EFL5OBKN.mjs";
16
19
  import "../../chunk-QNUAXSDP.mjs";
17
20
  import "../../chunk-NB2FKV2V.mjs";
18
21
  import "../../chunk-F555TVE4.mjs";
19
- import "../../chunk-WF65O6HX.mjs";
20
- import "../../chunk-EFL5OBKN.mjs";
21
- import "../../chunk-6ZLPNY7X.mjs";
22
+ import "../../chunk-DMLQZG75.mjs";
22
23
  import "../../chunk-FDOMAPJY.mjs";
23
24
  import "../../chunk-AFNWX62Q.mjs";
24
- import "../../chunk-DMLQZG75.mjs";
25
25
  import "../../chunk-SKC7AJIV.mjs";
26
26
  export {
27
27
  CopilotKit,
@@ -1,14 +1,14 @@
1
1
  "use client";
2
2
  import {
3
3
  DeveloperConsoleModal
4
- } from "../../chunk-YCG6SNAU.mjs";
4
+ } from "../../chunk-3MHWEKFN.mjs";
5
5
  import {
6
6
  CopilotKitIcon
7
7
  } from "../../chunk-PIF5KJYI.mjs";
8
+ import "../../chunk-DMLQZG75.mjs";
8
9
  import {
9
10
  useCopilotContext
10
11
  } from "../../chunk-AFNWX62Q.mjs";
11
- import "../../chunk-DMLQZG75.mjs";
12
12
  import "../../chunk-SKC7AJIV.mjs";
13
13
 
14
14
  // src/components/dev-console/console-trigger.tsx
@@ -1,10 +1,10 @@
1
1
  "use client";
2
2
  import {
3
3
  DeveloperConsoleModal
4
- } from "../../chunk-YCG6SNAU.mjs";
4
+ } from "../../chunk-3MHWEKFN.mjs";
5
5
  import "../../chunk-PIF5KJYI.mjs";
6
- import "../../chunk-AFNWX62Q.mjs";
7
6
  import "../../chunk-DMLQZG75.mjs";
7
+ import "../../chunk-AFNWX62Q.mjs";
8
8
  import "../../chunk-SKC7AJIV.mjs";
9
9
  export {
10
10
  DeveloperConsoleModal
@@ -1,12 +1,12 @@
1
1
  import {
2
2
  CopilotErrorBoundary,
3
3
  ErrorToast
4
- } from "../../chunk-LHERIF3L.mjs";
4
+ } from "../../chunk-SNON4QA6.mjs";
5
5
  import "../../chunk-PMAFHQ7P.mjs";
6
+ import "../../chunk-6ZLPNY7X.mjs";
6
7
  import "../../chunk-6PUNP7CD.mjs";
7
8
  import "../../chunk-O7ARI5CV.mjs";
8
9
  import "../../chunk-EFL5OBKN.mjs";
9
- import "../../chunk-6ZLPNY7X.mjs";
10
10
  import "../../chunk-SKC7AJIV.mjs";
11
11
  export {
12
12
  CopilotErrorBoundary,
@@ -3,26 +3,26 @@ import "../chunk-SPCZTZCY.mjs";
3
3
  import {
4
4
  CopilotKit,
5
5
  defaultCopilotContextCategories
6
- } from "../chunk-4YZA2BZC.mjs";
7
- import "../chunk-LHERIF3L.mjs";
8
- import "../chunk-HE22TZMF.mjs";
6
+ } from "../chunk-RB2TXKFP.mjs";
7
+ import "../chunk-SNON4QA6.mjs";
8
+ import "../chunk-INPM7YKW.mjs";
9
9
  import "../chunk-CYDWEPFL.mjs";
10
10
  import "../chunk-2IDV5OHF.mjs";
11
11
  import "../chunk-ICIK2BSB.mjs";
12
- import "../chunk-RKTVJRK7.mjs";
13
12
  import "../chunk-PMAFHQ7P.mjs";
13
+ import "../chunk-RKTVJRK7.mjs";
14
14
  import "../chunk-YYN33GSG.mjs";
15
+ import "../chunk-WF65O6HX.mjs";
16
+ import "../chunk-6ZLPNY7X.mjs";
15
17
  import "../chunk-6PUNP7CD.mjs";
16
18
  import "../chunk-O7ARI5CV.mjs";
19
+ import "../chunk-EFL5OBKN.mjs";
17
20
  import "../chunk-QNUAXSDP.mjs";
18
21
  import "../chunk-NB2FKV2V.mjs";
19
22
  import "../chunk-F555TVE4.mjs";
20
- import "../chunk-WF65O6HX.mjs";
21
- import "../chunk-EFL5OBKN.mjs";
22
- import "../chunk-6ZLPNY7X.mjs";
23
+ import "../chunk-DMLQZG75.mjs";
23
24
  import "../chunk-FDOMAPJY.mjs";
24
25
  import "../chunk-AFNWX62Q.mjs";
25
- import "../chunk-DMLQZG75.mjs";
26
26
  import "../chunk-SKC7AJIV.mjs";
27
27
  export {
28
28
  CopilotKit,
@@ -4,6 +4,10 @@ import {
4
4
  ThreadsProvider,
5
5
  useThreads
6
6
  } from "../chunk-F555TVE4.mjs";
7
+ import {
8
+ CopilotMessagesContext,
9
+ useCopilotMessagesContext
10
+ } from "../chunk-DMLQZG75.mjs";
7
11
  import {
8
12
  CoAgentStateRendersContext,
9
13
  CoAgentStateRendersProvider,
@@ -13,10 +17,6 @@ import {
13
17
  CopilotContext,
14
18
  useCopilotContext
15
19
  } from "../chunk-AFNWX62Q.mjs";
16
- import {
17
- CopilotMessagesContext,
18
- useCopilotMessagesContext
19
- } from "../chunk-DMLQZG75.mjs";
20
20
  import "../chunk-SKC7AJIV.mjs";
21
21
  export {
22
22
  CoAgentStateRendersContext,
@@ -1,5 +1,5 @@
1
1
  export { UseCopilotChatReturn, useCopilotChat } from './use-copilot-chat.js';
2
- export { ChatSuggestions, UseCopilotChatOptions, UseCopilotChatOptions as UseCopilotChatOptions_c, UseCopilotChatReturn as UseCopilotChatReturn_c, useCopilotChatInternal } from './use-copilot-chat_internal.js';
2
+ export { ChatSuggestions, OnReloadMessages, OnStopGeneration, UseCopilotChatOptions, UseCopilotChatOptions as UseCopilotChatOptions_c, UseCopilotChatReturn as UseCopilotChatReturn_c, useCopilotChatInternal } from './use-copilot-chat_internal.js';
3
3
  export { useCopilotChatHeadless_c } from './use-copilot-chat-headless_c.js';
4
4
  export { useCopilotAction } from './use-copilot-action.js';
5
5
  export { useCoAgentStateRender } from './use-coagent-state-render.js';
@@ -677,7 +677,11 @@ function CoAgentStateRenderBridge(props) {
677
677
 
678
678
  // src/hooks/use-copilot-chat_internal.ts
679
679
  function useCopilotChatInternal({
680
- suggestions
680
+ suggestions,
681
+ onInProgress,
682
+ onSubmitMessage,
683
+ onStopGeneration,
684
+ onReloadMessages
681
685
  } = {}) {
682
686
  var _a, _b, _c;
683
687
  const { copilotkit } = (0, import_react14.useCopilotKit)();
@@ -706,6 +710,9 @@ function useCopilotChatInternal({
706
710
  return () => {
707
711
  };
708
712
  }, [existingConfig == null ? void 0 : existingConfig.threadId, agent, copilotkit, resolvedAgentId]);
713
+ (0, import_react13.useEffect)(() => {
714
+ onInProgress == null ? void 0 : onInProgress(Boolean(agent == null ? void 0 : agent.isRunning));
715
+ }, [agent == null ? void 0 : agent.isRunning, onInProgress]);
709
716
  const interrupt = useLangGraphInterruptRender(agent);
710
717
  const reset = () => {
711
718
  agent == null ? void 0 : agent.setMessages([]);
@@ -786,8 +793,12 @@ function useCopilotChatInternal({
786
793
  console.error("CopilotChat: runAgent failed", error);
787
794
  }
788
795
  }
796
+ if (onSubmitMessage) {
797
+ const content = typeof message.content === "string" ? message.content : message.content && "text" in message.content ? message.content.text : message.content && "filename" in message.content ? message.content.filename : "";
798
+ onSubmitMessage(content);
799
+ }
789
800
  }),
790
- [agent, copilotkit, resolvedAgentId]
801
+ [agent, copilotkit, resolvedAgentId, onSubmitMessage]
791
802
  );
792
803
  const latestAppendFunc = useAsyncCallback(
793
804
  (message, options) => __async(this, null, function* () {
@@ -808,14 +819,24 @@ function useCopilotChatInternal({
808
819
  const latestReload = useUpdatedRef(reload);
809
820
  const latestReloadFunc = useAsyncCallback(
810
821
  (messageId) => __async(this, null, function* () {
822
+ var _a2;
823
+ onReloadMessages == null ? void 0 : onReloadMessages({
824
+ messageId,
825
+ currentAgentName: agent == null ? void 0 : agent.agentId,
826
+ messages: (_a2 = agent == null ? void 0 : agent.messages) != null ? _a2 : []
827
+ });
811
828
  return yield latestReload.current(messageId);
812
829
  }),
813
- [latestReload]
830
+ [latestReload, agent, onReloadMessages]
814
831
  );
815
832
  const latestStopFunc = (0, import_react13.useCallback)(() => {
816
- var _a2;
817
- return (_a2 = agent == null ? void 0 : agent.abortRun) == null ? void 0 : _a2.call(agent);
818
- }, [agent == null ? void 0 : agent.abortRun]);
833
+ var _a2, _b2;
834
+ onStopGeneration == null ? void 0 : onStopGeneration({
835
+ currentAgentName: agent == null ? void 0 : agent.agentId,
836
+ messages: (_a2 = agent == null ? void 0 : agent.messages) != null ? _a2 : []
837
+ });
838
+ return (_b2 = agent == null ? void 0 : agent.abortRun) == null ? void 0 : _b2.call(agent);
839
+ }, [onStopGeneration, agent]);
819
840
  const latestReset = useUpdatedRef(reset);
820
841
  const latestResetFunc = (0, import_react13.useCallback)(() => {
821
842
  return latestReset.current();