@copilotkit/react-core 0.0.0-0.0.0-max-changeset-10101010101010-20260109191632
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +4188 -0
- package/LICENSE +21 -0
- package/README.md +141 -0
- package/dist/chunk-2IDV5OHF.mjs +11 -0
- package/dist/chunk-2IDV5OHF.mjs.map +1 -0
- package/dist/chunk-336QEM3A.mjs +349 -0
- package/dist/chunk-336QEM3A.mjs.map +1 -0
- package/dist/chunk-36KQV2NA.mjs +1 -0
- package/dist/chunk-36KQV2NA.mjs.map +1 -0
- package/dist/chunk-3MHWEKFN.mjs +759 -0
- package/dist/chunk-3MHWEKFN.mjs.map +1 -0
- package/dist/chunk-4CEQJ2X6.mjs +31 -0
- package/dist/chunk-4CEQJ2X6.mjs.map +1 -0
- package/dist/chunk-4RRMC7L2.mjs +32 -0
- package/dist/chunk-4RRMC7L2.mjs.map +1 -0
- package/dist/chunk-6ESSSQ7Q.mjs +134 -0
- package/dist/chunk-6ESSSQ7Q.mjs.map +1 -0
- package/dist/chunk-6PUNP7CD.mjs +102 -0
- package/dist/chunk-6PUNP7CD.mjs.map +1 -0
- package/dist/chunk-6YOKPWQ7.mjs +1 -0
- package/dist/chunk-6YOKPWQ7.mjs.map +1 -0
- package/dist/chunk-6ZLPNY7X.mjs +225 -0
- package/dist/chunk-6ZLPNY7X.mjs.map +1 -0
- package/dist/chunk-7DTB7S5V.mjs +83 -0
- package/dist/chunk-7DTB7S5V.mjs.map +1 -0
- package/dist/chunk-7IBF6RBW.mjs +23 -0
- package/dist/chunk-7IBF6RBW.mjs.map +1 -0
- package/dist/chunk-7X3E6GHT.mjs +83 -0
- package/dist/chunk-7X3E6GHT.mjs.map +1 -0
- package/dist/chunk-A6NKSGH3.mjs +1 -0
- package/dist/chunk-A6NKSGH3.mjs.map +1 -0
- package/dist/chunk-ABWT4DRT.mjs +24 -0
- package/dist/chunk-ABWT4DRT.mjs.map +1 -0
- package/dist/chunk-AFNWX62Q.mjs +110 -0
- package/dist/chunk-AFNWX62Q.mjs.map +1 -0
- package/dist/chunk-BUSWSDYO.mjs +17 -0
- package/dist/chunk-BUSWSDYO.mjs.map +1 -0
- package/dist/chunk-CDUIA2WM.mjs +60 -0
- package/dist/chunk-CDUIA2WM.mjs.map +1 -0
- package/dist/chunk-CYDWEPFL.mjs +1 -0
- package/dist/chunk-CYDWEPFL.mjs.map +1 -0
- package/dist/chunk-DMLQZG75.mjs +25 -0
- package/dist/chunk-DMLQZG75.mjs.map +1 -0
- package/dist/chunk-E7SE25ZU.mjs +59 -0
- package/dist/chunk-E7SE25ZU.mjs.map +1 -0
- package/dist/chunk-EFL5OBKN.mjs +310 -0
- package/dist/chunk-EFL5OBKN.mjs.map +1 -0
- package/dist/chunk-F555TVE4.mjs +33 -0
- package/dist/chunk-F555TVE4.mjs.map +1 -0
- package/dist/chunk-FD6FGKYY.mjs +1 -0
- package/dist/chunk-FD6FGKYY.mjs.map +1 -0
- package/dist/chunk-FDOMAPJY.mjs +59 -0
- package/dist/chunk-FDOMAPJY.mjs.map +1 -0
- package/dist/chunk-GJOR3RI6.mjs +120 -0
- package/dist/chunk-GJOR3RI6.mjs.map +1 -0
- package/dist/chunk-GPEJNVE5.mjs +80 -0
- package/dist/chunk-GPEJNVE5.mjs.map +1 -0
- package/dist/chunk-HM6ON7AM.mjs +86 -0
- package/dist/chunk-HM6ON7AM.mjs.map +1 -0
- package/dist/chunk-I76HKHPJ.mjs +32 -0
- package/dist/chunk-I76HKHPJ.mjs.map +1 -0
- package/dist/chunk-ICIK2BSB.mjs +17 -0
- package/dist/chunk-ICIK2BSB.mjs.map +1 -0
- package/dist/chunk-JD7BAH7U.mjs +1 -0
- package/dist/chunk-JD7BAH7U.mjs.map +1 -0
- package/dist/chunk-LUGEI4YQ.mjs +1 -0
- package/dist/chunk-LUGEI4YQ.mjs.map +1 -0
- package/dist/chunk-N7FZFIWO.mjs +551 -0
- package/dist/chunk-N7FZFIWO.mjs.map +1 -0
- package/dist/chunk-NB2FKV2V.mjs +1 -0
- package/dist/chunk-NB2FKV2V.mjs.map +1 -0
- package/dist/chunk-NBK4KBLX.mjs +54 -0
- package/dist/chunk-NBK4KBLX.mjs.map +1 -0
- package/dist/chunk-O7ARI5CV.mjs +31 -0
- package/dist/chunk-O7ARI5CV.mjs.map +1 -0
- package/dist/chunk-P2YEE2ZI.mjs +36 -0
- package/dist/chunk-P2YEE2ZI.mjs.map +1 -0
- package/dist/chunk-PIF5KJYI.mjs +103 -0
- package/dist/chunk-PIF5KJYI.mjs.map +1 -0
- package/dist/chunk-PMAFHQ7P.mjs +65 -0
- package/dist/chunk-PMAFHQ7P.mjs.map +1 -0
- package/dist/chunk-QNUAXSDP.mjs +166 -0
- package/dist/chunk-QNUAXSDP.mjs.map +1 -0
- package/dist/chunk-RKTVJRK7.mjs +143 -0
- package/dist/chunk-RKTVJRK7.mjs.map +1 -0
- package/dist/chunk-SKC7AJIV.mjs +61 -0
- package/dist/chunk-SKC7AJIV.mjs.map +1 -0
- package/dist/chunk-SPCZTZCY.mjs +1 -0
- package/dist/chunk-SPCZTZCY.mjs.map +1 -0
- package/dist/chunk-SQDOUMPZ.mjs +125 -0
- package/dist/chunk-SQDOUMPZ.mjs.map +1 -0
- package/dist/chunk-WF65O6HX.mjs +66 -0
- package/dist/chunk-WF65O6HX.mjs.map +1 -0
- package/dist/chunk-XDFVCQD3.mjs +27 -0
- package/dist/chunk-XDFVCQD3.mjs.map +1 -0
- package/dist/chunk-YJ2KZDZJ.mjs +186 -0
- package/dist/chunk-YJ2KZDZJ.mjs.map +1 -0
- package/dist/chunk-YTQHRJUA.mjs +86 -0
- package/dist/chunk-YTQHRJUA.mjs.map +1 -0
- package/dist/chunk-YYN33GSG.mjs +73 -0
- package/dist/chunk-YYN33GSG.mjs.map +1 -0
- package/dist/chunk-Z6JV2LRY.mjs +37 -0
- package/dist/chunk-Z6JV2LRY.mjs.map +1 -0
- package/dist/chunk-ZVF5Q6IH.mjs +29 -0
- package/dist/chunk-ZVF5Q6IH.mjs.map +1 -0
- package/dist/chunk-ZYTXB6HH.mjs +151 -0
- package/dist/chunk-ZYTXB6HH.mjs.map +1 -0
- package/dist/components/CopilotListeners.d.ts +3 -0
- package/dist/components/CopilotListeners.js +101 -0
- package/dist/components/CopilotListeners.js.map +1 -0
- package/dist/components/CopilotListeners.mjs +9 -0
- package/dist/components/CopilotListeners.mjs.map +1 -0
- package/dist/components/copilot-provider/copilot-messages.d.ts +24 -0
- package/dist/components/copilot-provider/copilot-messages.js +351 -0
- package/dist/components/copilot-provider/copilot-messages.js.map +1 -0
- package/dist/components/copilot-provider/copilot-messages.mjs +16 -0
- package/dist/components/copilot-provider/copilot-messages.mjs.map +1 -0
- package/dist/components/copilot-provider/copilotkit-props.d.ts +160 -0
- package/dist/components/copilot-provider/copilotkit-props.js +19 -0
- package/dist/components/copilot-provider/copilotkit-props.js.map +1 -0
- package/dist/components/copilot-provider/copilotkit-props.mjs +1 -0
- package/dist/components/copilot-provider/copilotkit-props.mjs.map +1 -0
- package/dist/components/copilot-provider/copilotkit.d.ts +19 -0
- package/dist/components/copilot-provider/copilotkit.js +1960 -0
- package/dist/components/copilot-provider/copilotkit.js.map +1 -0
- package/dist/components/copilot-provider/copilotkit.mjs +31 -0
- package/dist/components/copilot-provider/copilotkit.mjs.map +1 -0
- package/dist/components/copilot-provider/index.d.ts +14 -0
- package/dist/components/copilot-provider/index.js +1960 -0
- package/dist/components/copilot-provider/index.js.map +1 -0
- package/dist/components/copilot-provider/index.mjs +30 -0
- package/dist/components/copilot-provider/index.mjs.map +1 -0
- package/dist/components/dev-console/console-trigger.d.ts +8 -0
- package/dist/components/dev-console/console-trigger.js +1202 -0
- package/dist/components/dev-console/console-trigger.js.map +1 -0
- package/dist/components/dev-console/console-trigger.mjs +233 -0
- package/dist/components/dev-console/console-trigger.mjs.map +1 -0
- package/dist/components/dev-console/developer-console-modal.d.ts +10 -0
- package/dist/components/dev-console/developer-console-modal.js +987 -0
- package/dist/components/dev-console/developer-console-modal.js.map +1 -0
- package/dist/components/dev-console/developer-console-modal.mjs +12 -0
- package/dist/components/dev-console/developer-console-modal.mjs.map +1 -0
- package/dist/components/dev-console/icons.d.ts +9 -0
- package/dist/components/dev-console/icons.js +131 -0
- package/dist/components/dev-console/icons.js.map +1 -0
- package/dist/components/dev-console/icons.mjs +16 -0
- package/dist/components/dev-console/icons.mjs.map +1 -0
- package/dist/components/error-boundary/error-boundary.d.ts +31 -0
- package/dist/components/error-boundary/error-boundary.js +500 -0
- package/dist/components/error-boundary/error-boundary.js.map +1 -0
- package/dist/components/error-boundary/error-boundary.mjs +15 -0
- package/dist/components/error-boundary/error-boundary.mjs.map +1 -0
- package/dist/components/error-boundary/error-utils.d.ts +11 -0
- package/dist/components/error-boundary/error-utils.js +190 -0
- package/dist/components/error-boundary/error-utils.js.map +1 -0
- package/dist/components/error-boundary/error-utils.mjs +14 -0
- package/dist/components/error-boundary/error-utils.mjs.map +1 -0
- package/dist/components/index.d.ts +14 -0
- package/dist/components/index.js +1960 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/index.mjs +31 -0
- package/dist/components/index.mjs.map +1 -0
- package/dist/components/toast/exclamation-mark-icon.d.ts +9 -0
- package/dist/components/toast/exclamation-mark-icon.js +55 -0
- package/dist/components/toast/exclamation-mark-icon.js.map +1 -0
- package/dist/components/toast/exclamation-mark-icon.mjs +8 -0
- package/dist/components/toast/exclamation-mark-icon.mjs.map +1 -0
- package/dist/components/toast/toast-provider.d.ts +27 -0
- package/dist/components/toast/toast-provider.js +347 -0
- package/dist/components/toast/toast-provider.js.map +1 -0
- package/dist/components/toast/toast-provider.mjs +10 -0
- package/dist/components/toast/toast-provider.mjs.map +1 -0
- package/dist/components/usage-banner.d.ts +29 -0
- package/dist/components/usage-banner.js +247 -0
- package/dist/components/usage-banner.js.map +1 -0
- package/dist/components/usage-banner.mjs +12 -0
- package/dist/components/usage-banner.mjs.map +1 -0
- package/dist/context/coagent-state-renders-context.d.ts +24 -0
- package/dist/context/coagent-state-renders-context.js +91 -0
- package/dist/context/coagent-state-renders-context.js.map +1 -0
- package/dist/context/coagent-state-renders-context.mjs +12 -0
- package/dist/context/coagent-state-renders-context.mjs.map +1 -0
- package/dist/context/copilot-context.d.ts +10 -0
- package/dist/context/copilot-context.js +161 -0
- package/dist/context/copilot-context.js.map +1 -0
- package/dist/context/copilot-context.mjs +10 -0
- package/dist/context/copilot-context.mjs.map +1 -0
- package/dist/context/copilot-messages-context.d.ts +18 -0
- package/dist/context/copilot-messages-context.js +60 -0
- package/dist/context/copilot-messages-context.js.map +1 -0
- package/dist/context/copilot-messages-context.mjs +10 -0
- package/dist/context/copilot-messages-context.mjs.map +1 -0
- package/dist/context/index.d.ts +15 -0
- package/dist/context/index.js +285 -0
- package/dist/context/index.js.map +1 -0
- package/dist/context/index.mjs +33 -0
- package/dist/context/index.mjs.map +1 -0
- package/dist/context/threads-context.d.ts +16 -0
- package/dist/context/threads-context.js +59 -0
- package/dist/context/threads-context.js.map +1 -0
- package/dist/context/threads-context.mjs +12 -0
- package/dist/context/threads-context.mjs.map +1 -0
- package/dist/copilot-context-ec77e921.d.ts +209 -0
- package/dist/hooks/index.d.ts +33 -0
- package/dist/hooks/index.js +1774 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/index.mjs +91 -0
- package/dist/hooks/index.mjs.map +1 -0
- package/dist/hooks/use-agent-nodename.d.ts +3 -0
- package/dist/hooks/use-agent-nodename.js +56 -0
- package/dist/hooks/use-agent-nodename.js.map +1 -0
- package/dist/hooks/use-agent-nodename.mjs +8 -0
- package/dist/hooks/use-agent-nodename.mjs.map +1 -0
- package/dist/hooks/use-coagent-state-render-bridge.d.ts +100 -0
- package/dist/hooks/use-coagent-state-render-bridge.js +214 -0
- package/dist/hooks/use-coagent-state-render-bridge.js.map +1 -0
- package/dist/hooks/use-coagent-state-render-bridge.mjs +15 -0
- package/dist/hooks/use-coagent-state-render-bridge.mjs.map +1 -0
- package/dist/hooks/use-coagent-state-render.d.ts +55 -0
- package/dist/hooks/use-coagent-state-render.js +255 -0
- package/dist/hooks/use-coagent-state-render.js.map +1 -0
- package/dist/hooks/use-coagent-state-render.mjs +11 -0
- package/dist/hooks/use-coagent-state-render.mjs.map +1 -0
- package/dist/hooks/use-coagent.d.ts +192 -0
- package/dist/hooks/use-coagent.js +233 -0
- package/dist/hooks/use-coagent.js.map +1 -0
- package/dist/hooks/use-coagent.mjs +9 -0
- package/dist/hooks/use-coagent.mjs.map +1 -0
- package/dist/hooks/use-configure-chat-suggestions.d.ts +36 -0
- package/dist/hooks/use-configure-chat-suggestions.js +79 -0
- package/dist/hooks/use-configure-chat-suggestions.js.map +1 -0
- package/dist/hooks/use-configure-chat-suggestions.mjs +47 -0
- package/dist/hooks/use-configure-chat-suggestions.mjs.map +1 -0
- package/dist/hooks/use-copilot-action.d.ts +103 -0
- package/dist/hooks/use-copilot-action.js +295 -0
- package/dist/hooks/use-copilot-action.js.map +1 -0
- package/dist/hooks/use-copilot-action.mjs +11 -0
- package/dist/hooks/use-copilot-action.mjs.map +1 -0
- package/dist/hooks/use-copilot-additional-instructions.d.ts +26 -0
- package/dist/hooks/use-copilot-additional-instructions.js +177 -0
- package/dist/hooks/use-copilot-additional-instructions.js.map +1 -0
- package/dist/hooks/use-copilot-additional-instructions.mjs +9 -0
- package/dist/hooks/use-copilot-additional-instructions.mjs.map +1 -0
- package/dist/hooks/use-copilot-authenticated-action.d.ts +18 -0
- package/dist/hooks/use-copilot-authenticated-action.js +462 -0
- package/dist/hooks/use-copilot-authenticated-action.js.map +1 -0
- package/dist/hooks/use-copilot-authenticated-action.mjs +13 -0
- package/dist/hooks/use-copilot-authenticated-action.mjs.map +1 -0
- package/dist/hooks/use-copilot-chat-headless_c.d.ts +25 -0
- package/dist/hooks/use-copilot-chat-headless_c.js +1044 -0
- package/dist/hooks/use-copilot-chat-headless_c.js.map +1 -0
- package/dist/hooks/use-copilot-chat-headless_c.mjs +24 -0
- package/dist/hooks/use-copilot-chat-headless_c.mjs.map +1 -0
- package/dist/hooks/use-copilot-chat-suggestions.d.ts +35 -0
- package/dist/hooks/use-copilot-chat-suggestions.js +60 -0
- package/dist/hooks/use-copilot-chat-suggestions.js.map +1 -0
- package/dist/hooks/use-copilot-chat-suggestions.mjs +8 -0
- package/dist/hooks/use-copilot-chat-suggestions.mjs.map +1 -0
- package/dist/hooks/use-copilot-chat.d.ts +92 -0
- package/dist/hooks/use-copilot-chat.js +978 -0
- package/dist/hooks/use-copilot-chat.js.map +1 -0
- package/dist/hooks/use-copilot-chat.mjs +21 -0
- package/dist/hooks/use-copilot-chat.mjs.map +1 -0
- package/dist/hooks/use-copilot-chat_internal.d.ts +244 -0
- package/dist/hooks/use-copilot-chat_internal.js +976 -0
- package/dist/hooks/use-copilot-chat_internal.js.map +1 -0
- package/dist/hooks/use-copilot-chat_internal.mjs +22 -0
- package/dist/hooks/use-copilot-chat_internal.mjs.map +1 -0
- package/dist/hooks/use-copilot-readable.d.ts +37 -0
- package/dist/hooks/use-copilot-readable.js +61 -0
- package/dist/hooks/use-copilot-readable.js.map +1 -0
- package/dist/hooks/use-copilot-readable.mjs +8 -0
- package/dist/hooks/use-copilot-readable.mjs.map +1 -0
- package/dist/hooks/use-copilot-runtime-client.d.ts +10 -0
- package/dist/hooks/use-copilot-runtime-client.js +203 -0
- package/dist/hooks/use-copilot-runtime-client.js.map +1 -0
- package/dist/hooks/use-copilot-runtime-client.mjs +9 -0
- package/dist/hooks/use-copilot-runtime-client.mjs.map +1 -0
- package/dist/hooks/use-default-tool.d.ts +8 -0
- package/dist/hooks/use-default-tool.js +302 -0
- package/dist/hooks/use-default-tool.js.map +1 -0
- package/dist/hooks/use-default-tool.mjs +12 -0
- package/dist/hooks/use-default-tool.mjs.map +1 -0
- package/dist/hooks/use-flat-category-store.d.ts +9 -0
- package/dist/hooks/use-flat-category-store.js +93 -0
- package/dist/hooks/use-flat-category-store.js.map +1 -0
- package/dist/hooks/use-flat-category-store.mjs +8 -0
- package/dist/hooks/use-flat-category-store.mjs.map +1 -0
- package/dist/hooks/use-frontend-tool.d.ts +11 -0
- package/dist/hooks/use-frontend-tool.js +104 -0
- package/dist/hooks/use-frontend-tool.js.map +1 -0
- package/dist/hooks/use-frontend-tool.mjs +8 -0
- package/dist/hooks/use-frontend-tool.mjs.map +1 -0
- package/dist/hooks/use-human-in-the-loop.d.ts +13 -0
- package/dist/hooks/use-human-in-the-loop.js +122 -0
- package/dist/hooks/use-human-in-the-loop.js.map +1 -0
- package/dist/hooks/use-human-in-the-loop.mjs +8 -0
- package/dist/hooks/use-human-in-the-loop.mjs.map +1 -0
- package/dist/hooks/use-langgraph-interrupt-render.d.ts +6 -0
- package/dist/hooks/use-langgraph-interrupt-render.js +318 -0
- package/dist/hooks/use-langgraph-interrupt-render.js.map +1 -0
- package/dist/hooks/use-langgraph-interrupt-render.mjs +14 -0
- package/dist/hooks/use-langgraph-interrupt-render.mjs.map +1 -0
- package/dist/hooks/use-langgraph-interrupt.d.ts +14 -0
- package/dist/hooks/use-langgraph-interrupt.js +201 -0
- package/dist/hooks/use-langgraph-interrupt.js.map +1 -0
- package/dist/hooks/use-langgraph-interrupt.mjs +10 -0
- package/dist/hooks/use-langgraph-interrupt.mjs.map +1 -0
- package/dist/hooks/use-lazy-tool-renderer.d.ts +6 -0
- package/dist/hooks/use-lazy-tool-renderer.js +53 -0
- package/dist/hooks/use-lazy-tool-renderer.js.map +1 -0
- package/dist/hooks/use-lazy-tool-renderer.mjs +8 -0
- package/dist/hooks/use-lazy-tool-renderer.mjs.map +1 -0
- package/dist/hooks/use-make-copilot-document-readable.d.ts +12 -0
- package/dist/hooks/use-make-copilot-document-readable.js +176 -0
- package/dist/hooks/use-make-copilot-document-readable.js.map +1 -0
- package/dist/hooks/use-make-copilot-document-readable.mjs +9 -0
- package/dist/hooks/use-make-copilot-document-readable.mjs.map +1 -0
- package/dist/hooks/use-render-tool-call.d.ts +12 -0
- package/dist/hooks/use-render-tool-call.js +90 -0
- package/dist/hooks/use-render-tool-call.js.map +1 -0
- package/dist/hooks/use-render-tool-call.mjs +8 -0
- package/dist/hooks/use-render-tool-call.mjs.map +1 -0
- package/dist/hooks/use-tree.d.ts +19 -0
- package/dist/hooks/use-tree.js +175 -0
- package/dist/hooks/use-tree.js.map +1 -0
- package/dist/hooks/use-tree.mjs +8 -0
- package/dist/hooks/use-tree.mjs.map +1 -0
- package/dist/index.d.ts +43 -0
- package/dist/index.js +3528 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +149 -0
- package/dist/index.mjs.map +1 -0
- package/dist/lib/copilot-task.d.ts +97 -0
- package/dist/lib/copilot-task.js +194 -0
- package/dist/lib/copilot-task.js.map +1 -0
- package/dist/lib/copilot-task.mjs +31 -0
- package/dist/lib/copilot-task.mjs.map +1 -0
- package/dist/lib/index.d.ts +11 -0
- package/dist/lib/index.js +196 -0
- package/dist/lib/index.js.map +1 -0
- package/dist/lib/index.mjs +32 -0
- package/dist/lib/index.mjs.map +1 -0
- package/dist/lib/status-checker.d.ts +17 -0
- package/dist/lib/status-checker.js +102 -0
- package/dist/lib/status-checker.js.map +1 -0
- package/dist/lib/status-checker.mjs +8 -0
- package/dist/lib/status-checker.mjs.map +1 -0
- package/dist/setupTests.d.ts +2 -0
- package/dist/setupTests.js +26 -0
- package/dist/setupTests.js.map +1 -0
- package/dist/setupTests.mjs +24 -0
- package/dist/setupTests.mjs.map +1 -0
- package/dist/types/chat-suggestion-configuration.d.ts +22 -0
- package/dist/types/chat-suggestion-configuration.js +19 -0
- package/dist/types/chat-suggestion-configuration.js.map +1 -0
- package/dist/types/chat-suggestion-configuration.mjs +1 -0
- package/dist/types/chat-suggestion-configuration.mjs.map +1 -0
- package/dist/types/coagent-action.d.ts +29 -0
- package/dist/types/coagent-action.js +19 -0
- package/dist/types/coagent-action.js.map +1 -0
- package/dist/types/coagent-action.mjs +1 -0
- package/dist/types/coagent-action.mjs.map +1 -0
- package/dist/types/coagent-state.d.ts +15 -0
- package/dist/types/coagent-state.js +19 -0
- package/dist/types/coagent-state.js.map +1 -0
- package/dist/types/coagent-state.mjs +1 -0
- package/dist/types/coagent-state.mjs.map +1 -0
- package/dist/types/crew.d.ts +79 -0
- package/dist/types/crew.js +19 -0
- package/dist/types/crew.js.map +1 -0
- package/dist/types/crew.mjs +2 -0
- package/dist/types/crew.mjs.map +1 -0
- package/dist/types/document-pointer.d.ts +9 -0
- package/dist/types/document-pointer.js +19 -0
- package/dist/types/document-pointer.js.map +1 -0
- package/dist/types/document-pointer.mjs +1 -0
- package/dist/types/document-pointer.mjs.map +1 -0
- package/dist/types/frontend-action.d.ts +127 -0
- package/dist/types/frontend-action.js +53 -0
- package/dist/types/frontend-action.js.map +1 -0
- package/dist/types/frontend-action.mjs +8 -0
- package/dist/types/frontend-action.mjs.map +1 -0
- package/dist/types/index.d.ts +12 -0
- package/dist/types/index.js +19 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/index.mjs +4 -0
- package/dist/types/index.mjs.map +1 -0
- package/dist/types/interrupt-action.d.ts +10 -0
- package/dist/types/interrupt-action.js +19 -0
- package/dist/types/interrupt-action.js.map +1 -0
- package/dist/types/interrupt-action.mjs +2 -0
- package/dist/types/interrupt-action.mjs.map +1 -0
- package/dist/types/system-message.d.ts +3 -0
- package/dist/types/system-message.js +19 -0
- package/dist/types/system-message.js.map +1 -0
- package/dist/types/system-message.mjs +1 -0
- package/dist/types/system-message.mjs.map +1 -0
- package/dist/utils/dev-console.d.ts +3 -0
- package/dist/utils/dev-console.js +41 -0
- package/dist/utils/dev-console.js.map +1 -0
- package/dist/utils/dev-console.mjs +8 -0
- package/dist/utils/dev-console.mjs.map +1 -0
- package/dist/utils/index.d.ts +2 -0
- package/dist/utils/index.js +52 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/index.mjs +13 -0
- package/dist/utils/index.mjs.map +1 -0
- package/dist/utils/suggestions-constants.d.ts +9 -0
- package/dist/utils/suggestions-constants.js +35 -0
- package/dist/utils/suggestions-constants.js.map +1 -0
- package/dist/utils/suggestions-constants.mjs +8 -0
- package/dist/utils/suggestions-constants.mjs.map +1 -0
- package/dist/utils/utils.d.ts +2 -0
- package/dist/utils/utils.js +19 -0
- package/dist/utils/utils.js.map +1 -0
- package/dist/utils/utils.mjs +1 -0
- package/dist/utils/utils.mjs.map +1 -0
- package/dist/v2/index.css +4 -0
- package/dist/v2/index.css.map +1 -0
- package/dist/v2/index.d.ts +2 -0
- package/dist/v2/index.js +27 -0
- package/dist/v2/index.js.map +1 -0
- package/dist/v2/index.mjs +6 -0
- package/dist/v2/index.mjs.map +1 -0
- package/jest.config.js +25 -0
- package/package.json +92 -0
- package/src/components/CopilotListeners.tsx +81 -0
- package/src/components/copilot-provider/__tests__/copilotkit-error.test.tsx +75 -0
- package/src/components/copilot-provider/copilot-messages.tsx +274 -0
- package/src/components/copilot-provider/copilotkit-props.tsx +169 -0
- package/src/components/copilot-provider/copilotkit.tsx +671 -0
- package/src/components/copilot-provider/index.ts +3 -0
- package/src/components/dev-console/console-trigger.tsx +254 -0
- package/src/components/dev-console/developer-console-modal.tsx +866 -0
- package/src/components/dev-console/icons.tsx +101 -0
- package/src/components/error-boundary/error-boundary.tsx +91 -0
- package/src/components/error-boundary/error-utils.tsx +100 -0
- package/src/components/index.ts +1 -0
- package/src/components/toast/exclamation-mark-icon.tsx +27 -0
- package/src/components/toast/toast-provider.tsx +363 -0
- package/src/components/usage-banner.tsx +259 -0
- package/src/context/coagent-state-renders-context.tsx +76 -0
- package/src/context/copilot-context.tsx +332 -0
- package/src/context/copilot-messages-context.tsx +35 -0
- package/src/context/index.ts +16 -0
- package/src/context/threads-context.tsx +41 -0
- package/src/hooks/__tests__/use-coagent-config.test.ts +351 -0
- package/src/hooks/index.ts +34 -0
- package/src/hooks/use-agent-nodename.ts +30 -0
- package/src/hooks/use-coagent-state-render-bridge.tsx +293 -0
- package/src/hooks/use-coagent-state-render.ts +152 -0
- package/src/hooks/use-coagent.ts +366 -0
- package/src/hooks/use-configure-chat-suggestions.tsx +86 -0
- package/src/hooks/use-copilot-action.ts +236 -0
- package/src/hooks/use-copilot-additional-instructions.ts +85 -0
- package/src/hooks/use-copilot-authenticated-action.ts +70 -0
- package/src/hooks/use-copilot-chat-headless_c.ts +258 -0
- package/src/hooks/use-copilot-chat-suggestions.tsx +124 -0
- package/src/hooks/use-copilot-chat.ts +130 -0
- package/src/hooks/use-copilot-chat_internal.ts +696 -0
- package/src/hooks/use-copilot-readable.ts +135 -0
- package/src/hooks/use-copilot-runtime-client.ts +164 -0
- package/src/hooks/use-default-tool.ts +7 -0
- package/src/hooks/use-flat-category-store.ts +105 -0
- package/src/hooks/use-frontend-tool.ts +96 -0
- package/src/hooks/use-human-in-the-loop.ts +122 -0
- package/src/hooks/use-langgraph-interrupt-render.ts +136 -0
- package/src/hooks/use-langgraph-interrupt.ts +36 -0
- package/src/hooks/use-lazy-tool-renderer.tsx +30 -0
- package/src/hooks/use-make-copilot-document-readable.ts +30 -0
- package/src/hooks/use-render-tool-call.ts +80 -0
- package/src/hooks/use-tree.ts +207 -0
- package/src/index.tsx +7 -0
- package/src/lib/copilot-task.ts +201 -0
- package/src/lib/index.ts +1 -0
- package/src/lib/status-checker.ts +64 -0
- package/src/setupTests.ts +26 -0
- package/src/types/chat-suggestion-configuration.ts +23 -0
- package/src/types/coagent-action.ts +31 -0
- package/src/types/coagent-state.ts +13 -0
- package/src/types/crew.ts +89 -0
- package/src/types/document-pointer.ts +7 -0
- package/src/types/frontend-action.ts +202 -0
- package/src/types/index.ts +17 -0
- package/src/types/interrupt-action.ts +43 -0
- package/src/types/system-message.ts +4 -0
- package/src/utils/dev-console.ts +19 -0
- package/src/utils/index.ts +2 -0
- package/src/utils/suggestions-constants.ts +8 -0
- package/src/utils/utils.test.ts +7 -0
- package/src/utils/utils.ts +8 -0
- package/src/v2/index.css +1 -0
- package/src/v2/index.ts +4 -0
- package/tsconfig.json +8 -0
- package/tsup.config.ts +16 -0
- package/typedoc.json +4 -0
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* The useCoAgentStateRender hook allows you to render UI or text based components on a Agentic Copilot's state in the chat.
|
|
3
|
+
* This is particularly useful for showing intermediate state or progress during Agentic Copilot operations.
|
|
4
|
+
*
|
|
5
|
+
* ## Usage
|
|
6
|
+
*
|
|
7
|
+
* ### Simple Usage
|
|
8
|
+
*
|
|
9
|
+
* ```tsx
|
|
10
|
+
* import { useCoAgentStateRender } from "@copilotkit/react-core";
|
|
11
|
+
*
|
|
12
|
+
* type YourAgentState = {
|
|
13
|
+
* agent_state_property: string;
|
|
14
|
+
* }
|
|
15
|
+
*
|
|
16
|
+
* useCoAgentStateRender<YourAgentState>({
|
|
17
|
+
* name: "basic_agent",
|
|
18
|
+
* nodeName: "optionally_specify_a_specific_node",
|
|
19
|
+
* render: ({ status, state, nodeName }) => {
|
|
20
|
+
* return (
|
|
21
|
+
* <YourComponent
|
|
22
|
+
* agentStateProperty={state.agent_state_property}
|
|
23
|
+
* status={status}
|
|
24
|
+
* nodeName={nodeName}
|
|
25
|
+
* />
|
|
26
|
+
* );
|
|
27
|
+
* },
|
|
28
|
+
* });
|
|
29
|
+
* ```
|
|
30
|
+
*
|
|
31
|
+
* This allows for you to render UI components or text based on what is happening within the agent.
|
|
32
|
+
*
|
|
33
|
+
* ### Example
|
|
34
|
+
* A great example of this is in our Perplexity Clone where we render the progress of an agent's internet search as it is happening.
|
|
35
|
+
* You can play around with it below or learn how to build it with its [demo](/coagents/videos/perplexity-clone).
|
|
36
|
+
*
|
|
37
|
+
* <Callout type="info">
|
|
38
|
+
* This example is hosted on Vercel and may take a few seconds to load.
|
|
39
|
+
* </Callout>
|
|
40
|
+
*
|
|
41
|
+
* <iframe src="https://examples-coagents-ai-researcher-ui.vercel.app/" className="w-full rounded-lg border h-[700px] my-4" />
|
|
42
|
+
*/
|
|
43
|
+
|
|
44
|
+
import { useRef, useContext, useEffect } from "react";
|
|
45
|
+
import { CopilotContext } from "../context/copilot-context";
|
|
46
|
+
import { randomId, CopilotKitAgentDiscoveryError } from "@copilotkit/shared";
|
|
47
|
+
import { CoAgentStateRender } from "../types/coagent-action";
|
|
48
|
+
import { useToast } from "../components/toast/toast-provider";
|
|
49
|
+
import { useCoAgentStateRenders } from "../context/coagent-state-renders-context";
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* This hook is used to render agent state with custom UI components or text. This is particularly
|
|
53
|
+
* useful for showing intermediate state or progress during Agentic Copilot operations.
|
|
54
|
+
* To get started using rendering intermediate state through this hook, checkout the documentation.
|
|
55
|
+
*
|
|
56
|
+
* https://docs.copilotkit.ai/coagents/shared-state/predictive-state-updates
|
|
57
|
+
*/
|
|
58
|
+
|
|
59
|
+
// We implement useCoAgentStateRender dependency handling so that
|
|
60
|
+
// the developer has the option to not provide any dependencies.
|
|
61
|
+
// see useCopilotAction for more details about this approach.
|
|
62
|
+
export function useCoAgentStateRender<T = any>(
|
|
63
|
+
action: CoAgentStateRender<T>,
|
|
64
|
+
dependencies?: any[],
|
|
65
|
+
): void {
|
|
66
|
+
const { chatComponentsCache, availableAgents } = useContext(CopilotContext);
|
|
67
|
+
const { setCoAgentStateRender, removeCoAgentStateRender, coAgentStateRenders } =
|
|
68
|
+
useCoAgentStateRenders();
|
|
69
|
+
const idRef = useRef<string>(randomId());
|
|
70
|
+
const { setBannerError, addToast } = useToast();
|
|
71
|
+
|
|
72
|
+
useEffect(() => {
|
|
73
|
+
if (availableAgents?.length && !availableAgents.some((a) => a.name === action.name)) {
|
|
74
|
+
const message = `(useCoAgentStateRender): Agent "${action.name}" not found. Make sure the agent exists and is properly configured.`;
|
|
75
|
+
|
|
76
|
+
// Route to banner instead of toast for consistency
|
|
77
|
+
const agentError = new CopilotKitAgentDiscoveryError({
|
|
78
|
+
agentName: action.name,
|
|
79
|
+
availableAgents: availableAgents.map((a) => ({ name: a.name, id: a.id })),
|
|
80
|
+
});
|
|
81
|
+
setBannerError(agentError);
|
|
82
|
+
}
|
|
83
|
+
}, [availableAgents]);
|
|
84
|
+
|
|
85
|
+
const key = `${action.name}-${action.nodeName || "global"}`;
|
|
86
|
+
|
|
87
|
+
if (dependencies === undefined) {
|
|
88
|
+
if (coAgentStateRenders[idRef.current]) {
|
|
89
|
+
coAgentStateRenders[idRef.current].handler = action.handler as any;
|
|
90
|
+
if (typeof action.render === "function") {
|
|
91
|
+
if (chatComponentsCache.current !== null) {
|
|
92
|
+
chatComponentsCache.current.coAgentStateRenders[key] = action.render;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
useEffect(() => {
|
|
99
|
+
// Check for duplicates by comparing against all other actions
|
|
100
|
+
const currentId = idRef.current;
|
|
101
|
+
const hasDuplicate = Object.entries(coAgentStateRenders).some(([id, otherAction]) => {
|
|
102
|
+
// Skip comparing with self
|
|
103
|
+
if (id === currentId) return false;
|
|
104
|
+
|
|
105
|
+
// Different agent names are never duplicates
|
|
106
|
+
if (otherAction.name !== action.name) return false;
|
|
107
|
+
|
|
108
|
+
// Same agent names:
|
|
109
|
+
const hasNodeName = !!action.nodeName;
|
|
110
|
+
const hasOtherNodeName = !!otherAction.nodeName;
|
|
111
|
+
|
|
112
|
+
// If neither has nodeName, they're duplicates
|
|
113
|
+
if (!hasNodeName && !hasOtherNodeName) return true;
|
|
114
|
+
|
|
115
|
+
// If one has nodeName and other doesn't, they're not duplicates
|
|
116
|
+
if (hasNodeName !== hasOtherNodeName) return false;
|
|
117
|
+
|
|
118
|
+
// If both have nodeName, they're duplicates only if the names match
|
|
119
|
+
return action.nodeName === otherAction.nodeName;
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
if (hasDuplicate) {
|
|
123
|
+
const message = action.nodeName
|
|
124
|
+
? `Found multiple state renders for agent ${action.name} and node ${action.nodeName}. State renders might get overridden`
|
|
125
|
+
: `Found multiple state renders for agent ${action.name}. State renders might get overridden`;
|
|
126
|
+
|
|
127
|
+
addToast({
|
|
128
|
+
type: "warning",
|
|
129
|
+
message,
|
|
130
|
+
id: `dup-action-${action.name}`,
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
}, [coAgentStateRenders]);
|
|
134
|
+
|
|
135
|
+
useEffect(() => {
|
|
136
|
+
setCoAgentStateRender(idRef.current, action as any);
|
|
137
|
+
if (chatComponentsCache.current !== null && action.render !== undefined) {
|
|
138
|
+
chatComponentsCache.current.coAgentStateRenders[key] = action.render;
|
|
139
|
+
}
|
|
140
|
+
return () => {
|
|
141
|
+
removeCoAgentStateRender(idRef.current);
|
|
142
|
+
};
|
|
143
|
+
}, [
|
|
144
|
+
setCoAgentStateRender,
|
|
145
|
+
removeCoAgentStateRender,
|
|
146
|
+
action.name,
|
|
147
|
+
// include render only if it's a string
|
|
148
|
+
typeof action.render === "string" ? action.render : undefined,
|
|
149
|
+
// dependencies set by the developer
|
|
150
|
+
...(dependencies || []),
|
|
151
|
+
]);
|
|
152
|
+
}
|
|
@@ -0,0 +1,366 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* <Callout type="info">
|
|
3
|
+
* Usage of this hook assumes some additional setup in your application, for more information
|
|
4
|
+
* on that see the CoAgents <span className="text-blue-500">[getting started guide](/coagents/quickstart/langgraph)</span>.
|
|
5
|
+
* </Callout>
|
|
6
|
+
* <Frame className="my-12">
|
|
7
|
+
* <img
|
|
8
|
+
* src="https://cdn.copilotkit.ai/docs/copilotkit/images/coagents/SharedStateCoAgents.gif"
|
|
9
|
+
* alt="CoAgents demonstration"
|
|
10
|
+
* className="w-auto"
|
|
11
|
+
* />
|
|
12
|
+
* </Frame>
|
|
13
|
+
*
|
|
14
|
+
* This hook is used to integrate an agent into your application. With its use, you can
|
|
15
|
+
* render and update the state of an agent, allowing for a dynamic and interactive experience.
|
|
16
|
+
* We call these shared state experiences agentic copilots, or CoAgents for short.
|
|
17
|
+
*
|
|
18
|
+
* ## Usage
|
|
19
|
+
*
|
|
20
|
+
* ### Simple Usage
|
|
21
|
+
*
|
|
22
|
+
* ```tsx
|
|
23
|
+
* import { useCoAgent } from "@copilotkit/react-core";
|
|
24
|
+
*
|
|
25
|
+
* type AgentState = {
|
|
26
|
+
* count: number;
|
|
27
|
+
* }
|
|
28
|
+
*
|
|
29
|
+
* const agent = useCoAgent<AgentState>({
|
|
30
|
+
* name: "my-agent",
|
|
31
|
+
* initialState: {
|
|
32
|
+
* count: 0,
|
|
33
|
+
* },
|
|
34
|
+
* });
|
|
35
|
+
*
|
|
36
|
+
* ```
|
|
37
|
+
*
|
|
38
|
+
* `useCoAgent` returns an object with the following properties:
|
|
39
|
+
*
|
|
40
|
+
* ```tsx
|
|
41
|
+
* const {
|
|
42
|
+
* name, // The name of the agent currently being used.
|
|
43
|
+
* nodeName, // The name of the current LangGraph node.
|
|
44
|
+
* state, // The current state of the agent.
|
|
45
|
+
* setState, // A function to update the state of the agent.
|
|
46
|
+
* running, // A boolean indicating if the agent is currently running.
|
|
47
|
+
* start, // A function to start the agent.
|
|
48
|
+
* stop, // A function to stop the agent.
|
|
49
|
+
* run, // A function to re-run the agent. Takes a HintFunction to inform the agent why it is being re-run.
|
|
50
|
+
* } = agent;
|
|
51
|
+
* ```
|
|
52
|
+
*
|
|
53
|
+
* Finally we can leverage these properties to create reactive experiences with the agent!
|
|
54
|
+
*
|
|
55
|
+
* ```tsx
|
|
56
|
+
* const { state, setState } = useCoAgent<AgentState>({
|
|
57
|
+
* name: "my-agent",
|
|
58
|
+
* initialState: {
|
|
59
|
+
* count: 0,
|
|
60
|
+
* },
|
|
61
|
+
* });
|
|
62
|
+
*
|
|
63
|
+
* return (
|
|
64
|
+
* <div>
|
|
65
|
+
* <p>Count: {state.count}</p>
|
|
66
|
+
* <button onClick={() => setState({ count: state.count + 1 })}>Increment</button>
|
|
67
|
+
* </div>
|
|
68
|
+
* );
|
|
69
|
+
* ```
|
|
70
|
+
*
|
|
71
|
+
* This reactivity is bidirectional, meaning that changes to the state from the agent will be reflected in the UI and vice versa.
|
|
72
|
+
*
|
|
73
|
+
* ## Parameters
|
|
74
|
+
* <PropertyReference name="options" type="UseCoagentOptions<T>" required>
|
|
75
|
+
* The options to use when creating the coagent.
|
|
76
|
+
* <PropertyReference name="name" type="string" required>
|
|
77
|
+
* The name of the agent to use.
|
|
78
|
+
* </PropertyReference>
|
|
79
|
+
* <PropertyReference name="initialState" type="T | any">
|
|
80
|
+
* The initial state of the agent.
|
|
81
|
+
* </PropertyReference>
|
|
82
|
+
* <PropertyReference name="state" type="T | any">
|
|
83
|
+
* State to manage externally if you are using this hook with external state management.
|
|
84
|
+
* </PropertyReference>
|
|
85
|
+
* <PropertyReference name="setState" type="(newState: T | ((prevState: T | undefined) => T)) => void">
|
|
86
|
+
* A function to update the state of the agent if you are using this hook with external state management.
|
|
87
|
+
* </PropertyReference>
|
|
88
|
+
* </PropertyReference>
|
|
89
|
+
*/
|
|
90
|
+
|
|
91
|
+
import { useCallback, useEffect, useMemo, useRef, useState } from "react";
|
|
92
|
+
import { Message } from "@copilotkit/shared";
|
|
93
|
+
import { useAgent, useCopilotKit } from "@copilotkitnext/react";
|
|
94
|
+
import { type AgentSubscriber } from "@ag-ui/client";
|
|
95
|
+
import { useAgentNodeName } from "./use-agent-nodename";
|
|
96
|
+
|
|
97
|
+
interface UseCoagentOptionsBase {
|
|
98
|
+
/**
|
|
99
|
+
* The name of the agent being used.
|
|
100
|
+
*/
|
|
101
|
+
name: string;
|
|
102
|
+
/**
|
|
103
|
+
* @deprecated - use "config.configurable"
|
|
104
|
+
* Config to pass to a LangGraph Agent
|
|
105
|
+
*/
|
|
106
|
+
configurable?: Record<string, any>;
|
|
107
|
+
/**
|
|
108
|
+
* Config to pass to a LangGraph Agent
|
|
109
|
+
*/
|
|
110
|
+
config?: {
|
|
111
|
+
configurable?: Record<string, any>;
|
|
112
|
+
[key: string]: any;
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
interface WithInternalStateManagementAndInitial<T> extends UseCoagentOptionsBase {
|
|
117
|
+
/**
|
|
118
|
+
* The initial state of the agent.
|
|
119
|
+
*/
|
|
120
|
+
initialState: T;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
interface WithInternalStateManagement extends UseCoagentOptionsBase {
|
|
124
|
+
/**
|
|
125
|
+
* Optional initialState with default type any
|
|
126
|
+
*/
|
|
127
|
+
initialState?: any;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
interface WithExternalStateManagement<T> extends UseCoagentOptionsBase {
|
|
131
|
+
/**
|
|
132
|
+
* The current state of the agent.
|
|
133
|
+
*/
|
|
134
|
+
state: T;
|
|
135
|
+
/**
|
|
136
|
+
* A function to update the state of the agent.
|
|
137
|
+
*/
|
|
138
|
+
setState: (newState: T | ((prevState: T | undefined) => T)) => void;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
type UseCoagentOptions<T> =
|
|
142
|
+
| WithInternalStateManagementAndInitial<T>
|
|
143
|
+
| WithInternalStateManagement
|
|
144
|
+
| WithExternalStateManagement<T>;
|
|
145
|
+
|
|
146
|
+
export interface UseCoagentReturnType<T> {
|
|
147
|
+
/**
|
|
148
|
+
* The name of the agent being used.
|
|
149
|
+
*/
|
|
150
|
+
name: string;
|
|
151
|
+
/**
|
|
152
|
+
* The name of the current LangGraph node.
|
|
153
|
+
*/
|
|
154
|
+
nodeName?: string;
|
|
155
|
+
/**
|
|
156
|
+
* The ID of the thread the agent is running in.
|
|
157
|
+
*/
|
|
158
|
+
threadId?: string;
|
|
159
|
+
/**
|
|
160
|
+
* A boolean indicating if the agent is currently running.
|
|
161
|
+
*/
|
|
162
|
+
running: boolean;
|
|
163
|
+
/**
|
|
164
|
+
* The current state of the agent.
|
|
165
|
+
*/
|
|
166
|
+
state: T;
|
|
167
|
+
/**
|
|
168
|
+
* A function to update the state of the agent.
|
|
169
|
+
*/
|
|
170
|
+
setState: (newState: T | ((prevState: T | undefined) => T)) => void;
|
|
171
|
+
/**
|
|
172
|
+
* A function to start the agent.
|
|
173
|
+
*/
|
|
174
|
+
start: () => void;
|
|
175
|
+
/**
|
|
176
|
+
* A function to stop the agent.
|
|
177
|
+
*/
|
|
178
|
+
stop: () => void;
|
|
179
|
+
/**
|
|
180
|
+
* A function to re-run the agent. The hint function can be used to provide a hint to the agent
|
|
181
|
+
* about why it is being re-run again.
|
|
182
|
+
*/
|
|
183
|
+
run: (...args: any[]) => Promise<any>;
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
export interface HintFunctionParams {
|
|
187
|
+
/**
|
|
188
|
+
* The previous state of the agent.
|
|
189
|
+
*/
|
|
190
|
+
previousState: any;
|
|
191
|
+
/**
|
|
192
|
+
* The current state of the agent.
|
|
193
|
+
*/
|
|
194
|
+
currentState: any;
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
export type HintFunction = (params: HintFunctionParams) => Message | undefined;
|
|
198
|
+
|
|
199
|
+
/**
|
|
200
|
+
* This hook is used to integrate an agent into your application. With its use, you can
|
|
201
|
+
* render and update the state of the agent, allowing for a dynamic and interactive experience.
|
|
202
|
+
* We call these shared state experiences "agentic copilots". To get started using agentic copilots, which
|
|
203
|
+
* we refer to as CoAgents, checkout the documentation at https://docs.copilotkit.ai/coagents/quickstart/langgraph.
|
|
204
|
+
*/
|
|
205
|
+
export function useCoAgent<T = any>(options: UseCoagentOptions<T>): UseCoagentReturnType<T> {
|
|
206
|
+
const { agent } = useAgent({ agentId: options.name });
|
|
207
|
+
const { copilotkit } = useCopilotKit();
|
|
208
|
+
const nodeName = useAgentNodeName(options.name);
|
|
209
|
+
|
|
210
|
+
const handleStateUpdate = useCallback(
|
|
211
|
+
(newState: T | ((prevState: T | undefined) => T)) => {
|
|
212
|
+
if (!agent) return;
|
|
213
|
+
|
|
214
|
+
if (typeof newState === "function") {
|
|
215
|
+
const updater = newState as (prevState: T | undefined) => T;
|
|
216
|
+
agent.setState(updater(agent.state));
|
|
217
|
+
} else {
|
|
218
|
+
agent.setState({ ...agent.state, ...newState });
|
|
219
|
+
}
|
|
220
|
+
},
|
|
221
|
+
[agent?.state, agent?.setState],
|
|
222
|
+
);
|
|
223
|
+
|
|
224
|
+
useEffect(() => {
|
|
225
|
+
if (!options.config && !options.configurable) return;
|
|
226
|
+
|
|
227
|
+
let config = options.config ?? {};
|
|
228
|
+
if (options.configurable) {
|
|
229
|
+
config = {
|
|
230
|
+
...config,
|
|
231
|
+
configurable: {
|
|
232
|
+
...options.configurable,
|
|
233
|
+
...config.configurable,
|
|
234
|
+
},
|
|
235
|
+
};
|
|
236
|
+
}
|
|
237
|
+
copilotkit.setProperties(config);
|
|
238
|
+
}, [options.config, options.configurable]);
|
|
239
|
+
|
|
240
|
+
const externalStateStr = useMemo(
|
|
241
|
+
() => (isExternalStateManagement(options) ? JSON.stringify(options.state) : undefined),
|
|
242
|
+
[isExternalStateManagement(options) ? JSON.stringify(options.state) : undefined],
|
|
243
|
+
);
|
|
244
|
+
|
|
245
|
+
// Sync internal state with external state if state management is external
|
|
246
|
+
useEffect(() => {
|
|
247
|
+
if (
|
|
248
|
+
agent?.state &&
|
|
249
|
+
isExternalStateManagement(options) &&
|
|
250
|
+
JSON.stringify(options.state) !== JSON.stringify(agent.state)
|
|
251
|
+
) {
|
|
252
|
+
handleStateUpdate(options.state);
|
|
253
|
+
}
|
|
254
|
+
}, [agent, externalStateStr, handleStateUpdate]);
|
|
255
|
+
|
|
256
|
+
const hasStateValues = useCallback((value?: Record<string, any>) => {
|
|
257
|
+
return Boolean(value && Object.keys(value).length);
|
|
258
|
+
}, []);
|
|
259
|
+
|
|
260
|
+
const initialStateRef = useRef<any>(
|
|
261
|
+
isExternalStateManagement(options)
|
|
262
|
+
? options.state
|
|
263
|
+
: "initialState" in options
|
|
264
|
+
? options.initialState
|
|
265
|
+
: undefined,
|
|
266
|
+
);
|
|
267
|
+
|
|
268
|
+
useEffect(() => {
|
|
269
|
+
if (isExternalStateManagement(options)) {
|
|
270
|
+
initialStateRef.current = options.state;
|
|
271
|
+
} else if ("initialState" in options) {
|
|
272
|
+
initialStateRef.current = options.initialState;
|
|
273
|
+
}
|
|
274
|
+
}, [
|
|
275
|
+
isExternalStateManagement(options)
|
|
276
|
+
? JSON.stringify(options.state)
|
|
277
|
+
: "initialState" in options
|
|
278
|
+
? JSON.stringify(options.initialState)
|
|
279
|
+
: undefined,
|
|
280
|
+
]);
|
|
281
|
+
|
|
282
|
+
useEffect(() => {
|
|
283
|
+
if (!agent) return;
|
|
284
|
+
const subscriber: AgentSubscriber = {
|
|
285
|
+
onStateChanged: (args: any) => {
|
|
286
|
+
if (isExternalStateManagement(options)) {
|
|
287
|
+
options.setState(args.state);
|
|
288
|
+
}
|
|
289
|
+
},
|
|
290
|
+
onRunInitialized: (args: any) => {
|
|
291
|
+
const runHasState = hasStateValues(args.state);
|
|
292
|
+
if (runHasState) {
|
|
293
|
+
handleStateUpdate(args.state);
|
|
294
|
+
return;
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
if (hasStateValues(agent.state)) {
|
|
298
|
+
return;
|
|
299
|
+
}
|
|
300
|
+
|
|
301
|
+
if (initialStateRef.current !== undefined) {
|
|
302
|
+
handleStateUpdate(initialStateRef.current);
|
|
303
|
+
}
|
|
304
|
+
},
|
|
305
|
+
};
|
|
306
|
+
|
|
307
|
+
const subscription = agent.subscribe(subscriber);
|
|
308
|
+
return () => {
|
|
309
|
+
subscription.unsubscribe();
|
|
310
|
+
};
|
|
311
|
+
}, [agent, handleStateUpdate, hasStateValues]);
|
|
312
|
+
|
|
313
|
+
// Return a consistent shape whether or not the agent is available
|
|
314
|
+
return useMemo<UseCoagentReturnType<T>>(() => {
|
|
315
|
+
if (!agent) {
|
|
316
|
+
const noop = () => {};
|
|
317
|
+
const noopAsync = async () => {};
|
|
318
|
+
const initialState =
|
|
319
|
+
// prefer externally provided state if available
|
|
320
|
+
("state" in options && (options as any).state) ??
|
|
321
|
+
// then initialState if provided
|
|
322
|
+
("initialState" in options && (options as any).initialState) ??
|
|
323
|
+
({} as T);
|
|
324
|
+
return {
|
|
325
|
+
name: options.name,
|
|
326
|
+
nodeName,
|
|
327
|
+
threadId: undefined,
|
|
328
|
+
running: false,
|
|
329
|
+
state: initialState as T,
|
|
330
|
+
setState: noop,
|
|
331
|
+
start: noop,
|
|
332
|
+
stop: noop,
|
|
333
|
+
run: noopAsync,
|
|
334
|
+
};
|
|
335
|
+
}
|
|
336
|
+
|
|
337
|
+
return {
|
|
338
|
+
name: agent?.agentId ?? options.name,
|
|
339
|
+
nodeName,
|
|
340
|
+
threadId: agent.threadId,
|
|
341
|
+
running: agent.isRunning,
|
|
342
|
+
state: agent.state,
|
|
343
|
+
setState: handleStateUpdate,
|
|
344
|
+
// TODO: start and run both have same thing. need to figure out
|
|
345
|
+
start: agent.runAgent,
|
|
346
|
+
stop: agent.abortRun,
|
|
347
|
+
run: agent.runAgent,
|
|
348
|
+
};
|
|
349
|
+
}, [
|
|
350
|
+
agent?.state,
|
|
351
|
+
agent?.runAgent,
|
|
352
|
+
agent?.abortRun,
|
|
353
|
+
agent?.runAgent,
|
|
354
|
+
agent?.threadId,
|
|
355
|
+
agent?.isRunning,
|
|
356
|
+
agent?.agentId,
|
|
357
|
+
handleStateUpdate,
|
|
358
|
+
options.name,
|
|
359
|
+
]);
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
const isExternalStateManagement = <T>(
|
|
363
|
+
options: UseCoagentOptions<T>,
|
|
364
|
+
): options is WithExternalStateManagement<T> => {
|
|
365
|
+
return "state" in options && "setState" in options;
|
|
366
|
+
};
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import {
|
|
2
|
+
useConfigureSuggestions,
|
|
3
|
+
useCopilotChatConfiguration,
|
|
4
|
+
useCopilotKit,
|
|
5
|
+
useSuggestions,
|
|
6
|
+
} from "@copilotkitnext/react";
|
|
7
|
+
import { StaticSuggestionsConfig, Suggestion } from "@copilotkitnext/core";
|
|
8
|
+
import { useCopilotContext } from "../context";
|
|
9
|
+
import { useEffect, useMemo } from "react";
|
|
10
|
+
|
|
11
|
+
type StaticSuggestionInput = Omit<Suggestion, "isLoading"> & Partial<Pick<Suggestion, "isLoading">>;
|
|
12
|
+
|
|
13
|
+
type StaticSuggestionsConfigInput = Omit<StaticSuggestionsConfig, "suggestions"> & {
|
|
14
|
+
suggestions: StaticSuggestionInput[];
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
type DynamicSuggestionsConfigInput = {
|
|
18
|
+
/**
|
|
19
|
+
* A prompt or instructions for the GPT to generate suggestions.
|
|
20
|
+
*/
|
|
21
|
+
instructions: string;
|
|
22
|
+
/**
|
|
23
|
+
* The minimum number of suggestions to generate. Defaults to `1`.
|
|
24
|
+
* @default 1
|
|
25
|
+
*/
|
|
26
|
+
minSuggestions?: number;
|
|
27
|
+
/**
|
|
28
|
+
* The maximum number of suggestions to generate. Defaults to `3`.
|
|
29
|
+
* @default 1
|
|
30
|
+
*/
|
|
31
|
+
maxSuggestions?: number;
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Whether the suggestions are available. Defaults to `enabled`.
|
|
35
|
+
* @default enabled
|
|
36
|
+
*/
|
|
37
|
+
available?: "enabled" | "disabled" | "always" | "before-first-message" | "after-first-message";
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* An optional class name to apply to the suggestions.
|
|
41
|
+
*/
|
|
42
|
+
className?: string;
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
export type UseCopilotChatSuggestionsConfiguration =
|
|
46
|
+
| DynamicSuggestionsConfigInput
|
|
47
|
+
| StaticSuggestionsConfigInput;
|
|
48
|
+
|
|
49
|
+
export function useConfigureChatSuggestions(
|
|
50
|
+
config: UseCopilotChatSuggestionsConfiguration,
|
|
51
|
+
dependencies: any[] = [],
|
|
52
|
+
): ReturnType<typeof useSuggestions> {
|
|
53
|
+
const existingConfig = useCopilotChatConfiguration();
|
|
54
|
+
const resolvedAgentId = existingConfig?.agentId ?? "default";
|
|
55
|
+
const { copilotkit } = useCopilotKit();
|
|
56
|
+
|
|
57
|
+
const available = config.available === "enabled" ? "always" : config.available;
|
|
58
|
+
|
|
59
|
+
const finalSuggestionConfig = {
|
|
60
|
+
...config,
|
|
61
|
+
available,
|
|
62
|
+
consumerAgentId: resolvedAgentId, // Use chatConfig.agentId here
|
|
63
|
+
};
|
|
64
|
+
useConfigureSuggestions(finalSuggestionConfig, dependencies);
|
|
65
|
+
|
|
66
|
+
const result = useSuggestions({ agentId: resolvedAgentId });
|
|
67
|
+
|
|
68
|
+
useEffect(() => {
|
|
69
|
+
if (finalSuggestionConfig.available === "disabled") return;
|
|
70
|
+
const subscription = copilotkit.subscribe({
|
|
71
|
+
onAgentsChanged: () => {
|
|
72
|
+
// When agents change, check if our target agent now exists and reload
|
|
73
|
+
const agent = copilotkit.getAgent(resolvedAgentId);
|
|
74
|
+
if (agent && !agent.isRunning && !result.suggestions.length) {
|
|
75
|
+
copilotkit.reloadSuggestions(resolvedAgentId);
|
|
76
|
+
}
|
|
77
|
+
},
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
return () => {
|
|
81
|
+
subscription.unsubscribe();
|
|
82
|
+
};
|
|
83
|
+
}, [resolvedAgentId]);
|
|
84
|
+
|
|
85
|
+
return result;
|
|
86
|
+
}
|