@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.
Files changed (497) hide show
  1. package/CHANGELOG.md +4188 -0
  2. package/LICENSE +21 -0
  3. package/README.md +141 -0
  4. package/dist/chunk-2IDV5OHF.mjs +11 -0
  5. package/dist/chunk-2IDV5OHF.mjs.map +1 -0
  6. package/dist/chunk-336QEM3A.mjs +349 -0
  7. package/dist/chunk-336QEM3A.mjs.map +1 -0
  8. package/dist/chunk-36KQV2NA.mjs +1 -0
  9. package/dist/chunk-36KQV2NA.mjs.map +1 -0
  10. package/dist/chunk-3MHWEKFN.mjs +759 -0
  11. package/dist/chunk-3MHWEKFN.mjs.map +1 -0
  12. package/dist/chunk-4CEQJ2X6.mjs +31 -0
  13. package/dist/chunk-4CEQJ2X6.mjs.map +1 -0
  14. package/dist/chunk-4RRMC7L2.mjs +32 -0
  15. package/dist/chunk-4RRMC7L2.mjs.map +1 -0
  16. package/dist/chunk-6ESSSQ7Q.mjs +134 -0
  17. package/dist/chunk-6ESSSQ7Q.mjs.map +1 -0
  18. package/dist/chunk-6PUNP7CD.mjs +102 -0
  19. package/dist/chunk-6PUNP7CD.mjs.map +1 -0
  20. package/dist/chunk-6YOKPWQ7.mjs +1 -0
  21. package/dist/chunk-6YOKPWQ7.mjs.map +1 -0
  22. package/dist/chunk-6ZLPNY7X.mjs +225 -0
  23. package/dist/chunk-6ZLPNY7X.mjs.map +1 -0
  24. package/dist/chunk-7DTB7S5V.mjs +83 -0
  25. package/dist/chunk-7DTB7S5V.mjs.map +1 -0
  26. package/dist/chunk-7IBF6RBW.mjs +23 -0
  27. package/dist/chunk-7IBF6RBW.mjs.map +1 -0
  28. package/dist/chunk-7X3E6GHT.mjs +83 -0
  29. package/dist/chunk-7X3E6GHT.mjs.map +1 -0
  30. package/dist/chunk-A6NKSGH3.mjs +1 -0
  31. package/dist/chunk-A6NKSGH3.mjs.map +1 -0
  32. package/dist/chunk-ABWT4DRT.mjs +24 -0
  33. package/dist/chunk-ABWT4DRT.mjs.map +1 -0
  34. package/dist/chunk-AFNWX62Q.mjs +110 -0
  35. package/dist/chunk-AFNWX62Q.mjs.map +1 -0
  36. package/dist/chunk-BUSWSDYO.mjs +17 -0
  37. package/dist/chunk-BUSWSDYO.mjs.map +1 -0
  38. package/dist/chunk-CDUIA2WM.mjs +60 -0
  39. package/dist/chunk-CDUIA2WM.mjs.map +1 -0
  40. package/dist/chunk-CYDWEPFL.mjs +1 -0
  41. package/dist/chunk-CYDWEPFL.mjs.map +1 -0
  42. package/dist/chunk-DMLQZG75.mjs +25 -0
  43. package/dist/chunk-DMLQZG75.mjs.map +1 -0
  44. package/dist/chunk-E7SE25ZU.mjs +59 -0
  45. package/dist/chunk-E7SE25ZU.mjs.map +1 -0
  46. package/dist/chunk-EFL5OBKN.mjs +310 -0
  47. package/dist/chunk-EFL5OBKN.mjs.map +1 -0
  48. package/dist/chunk-F555TVE4.mjs +33 -0
  49. package/dist/chunk-F555TVE4.mjs.map +1 -0
  50. package/dist/chunk-FD6FGKYY.mjs +1 -0
  51. package/dist/chunk-FD6FGKYY.mjs.map +1 -0
  52. package/dist/chunk-FDOMAPJY.mjs +59 -0
  53. package/dist/chunk-FDOMAPJY.mjs.map +1 -0
  54. package/dist/chunk-GJOR3RI6.mjs +120 -0
  55. package/dist/chunk-GJOR3RI6.mjs.map +1 -0
  56. package/dist/chunk-GPEJNVE5.mjs +80 -0
  57. package/dist/chunk-GPEJNVE5.mjs.map +1 -0
  58. package/dist/chunk-HM6ON7AM.mjs +86 -0
  59. package/dist/chunk-HM6ON7AM.mjs.map +1 -0
  60. package/dist/chunk-I76HKHPJ.mjs +32 -0
  61. package/dist/chunk-I76HKHPJ.mjs.map +1 -0
  62. package/dist/chunk-ICIK2BSB.mjs +17 -0
  63. package/dist/chunk-ICIK2BSB.mjs.map +1 -0
  64. package/dist/chunk-JD7BAH7U.mjs +1 -0
  65. package/dist/chunk-JD7BAH7U.mjs.map +1 -0
  66. package/dist/chunk-LUGEI4YQ.mjs +1 -0
  67. package/dist/chunk-LUGEI4YQ.mjs.map +1 -0
  68. package/dist/chunk-N7FZFIWO.mjs +551 -0
  69. package/dist/chunk-N7FZFIWO.mjs.map +1 -0
  70. package/dist/chunk-NB2FKV2V.mjs +1 -0
  71. package/dist/chunk-NB2FKV2V.mjs.map +1 -0
  72. package/dist/chunk-NBK4KBLX.mjs +54 -0
  73. package/dist/chunk-NBK4KBLX.mjs.map +1 -0
  74. package/dist/chunk-O7ARI5CV.mjs +31 -0
  75. package/dist/chunk-O7ARI5CV.mjs.map +1 -0
  76. package/dist/chunk-P2YEE2ZI.mjs +36 -0
  77. package/dist/chunk-P2YEE2ZI.mjs.map +1 -0
  78. package/dist/chunk-PIF5KJYI.mjs +103 -0
  79. package/dist/chunk-PIF5KJYI.mjs.map +1 -0
  80. package/dist/chunk-PMAFHQ7P.mjs +65 -0
  81. package/dist/chunk-PMAFHQ7P.mjs.map +1 -0
  82. package/dist/chunk-QNUAXSDP.mjs +166 -0
  83. package/dist/chunk-QNUAXSDP.mjs.map +1 -0
  84. package/dist/chunk-RKTVJRK7.mjs +143 -0
  85. package/dist/chunk-RKTVJRK7.mjs.map +1 -0
  86. package/dist/chunk-SKC7AJIV.mjs +61 -0
  87. package/dist/chunk-SKC7AJIV.mjs.map +1 -0
  88. package/dist/chunk-SPCZTZCY.mjs +1 -0
  89. package/dist/chunk-SPCZTZCY.mjs.map +1 -0
  90. package/dist/chunk-SQDOUMPZ.mjs +125 -0
  91. package/dist/chunk-SQDOUMPZ.mjs.map +1 -0
  92. package/dist/chunk-WF65O6HX.mjs +66 -0
  93. package/dist/chunk-WF65O6HX.mjs.map +1 -0
  94. package/dist/chunk-XDFVCQD3.mjs +27 -0
  95. package/dist/chunk-XDFVCQD3.mjs.map +1 -0
  96. package/dist/chunk-YJ2KZDZJ.mjs +186 -0
  97. package/dist/chunk-YJ2KZDZJ.mjs.map +1 -0
  98. package/dist/chunk-YTQHRJUA.mjs +86 -0
  99. package/dist/chunk-YTQHRJUA.mjs.map +1 -0
  100. package/dist/chunk-YYN33GSG.mjs +73 -0
  101. package/dist/chunk-YYN33GSG.mjs.map +1 -0
  102. package/dist/chunk-Z6JV2LRY.mjs +37 -0
  103. package/dist/chunk-Z6JV2LRY.mjs.map +1 -0
  104. package/dist/chunk-ZVF5Q6IH.mjs +29 -0
  105. package/dist/chunk-ZVF5Q6IH.mjs.map +1 -0
  106. package/dist/chunk-ZYTXB6HH.mjs +151 -0
  107. package/dist/chunk-ZYTXB6HH.mjs.map +1 -0
  108. package/dist/components/CopilotListeners.d.ts +3 -0
  109. package/dist/components/CopilotListeners.js +101 -0
  110. package/dist/components/CopilotListeners.js.map +1 -0
  111. package/dist/components/CopilotListeners.mjs +9 -0
  112. package/dist/components/CopilotListeners.mjs.map +1 -0
  113. package/dist/components/copilot-provider/copilot-messages.d.ts +24 -0
  114. package/dist/components/copilot-provider/copilot-messages.js +351 -0
  115. package/dist/components/copilot-provider/copilot-messages.js.map +1 -0
  116. package/dist/components/copilot-provider/copilot-messages.mjs +16 -0
  117. package/dist/components/copilot-provider/copilot-messages.mjs.map +1 -0
  118. package/dist/components/copilot-provider/copilotkit-props.d.ts +160 -0
  119. package/dist/components/copilot-provider/copilotkit-props.js +19 -0
  120. package/dist/components/copilot-provider/copilotkit-props.js.map +1 -0
  121. package/dist/components/copilot-provider/copilotkit-props.mjs +1 -0
  122. package/dist/components/copilot-provider/copilotkit-props.mjs.map +1 -0
  123. package/dist/components/copilot-provider/copilotkit.d.ts +19 -0
  124. package/dist/components/copilot-provider/copilotkit.js +1960 -0
  125. package/dist/components/copilot-provider/copilotkit.js.map +1 -0
  126. package/dist/components/copilot-provider/copilotkit.mjs +31 -0
  127. package/dist/components/copilot-provider/copilotkit.mjs.map +1 -0
  128. package/dist/components/copilot-provider/index.d.ts +14 -0
  129. package/dist/components/copilot-provider/index.js +1960 -0
  130. package/dist/components/copilot-provider/index.js.map +1 -0
  131. package/dist/components/copilot-provider/index.mjs +30 -0
  132. package/dist/components/copilot-provider/index.mjs.map +1 -0
  133. package/dist/components/dev-console/console-trigger.d.ts +8 -0
  134. package/dist/components/dev-console/console-trigger.js +1202 -0
  135. package/dist/components/dev-console/console-trigger.js.map +1 -0
  136. package/dist/components/dev-console/console-trigger.mjs +233 -0
  137. package/dist/components/dev-console/console-trigger.mjs.map +1 -0
  138. package/dist/components/dev-console/developer-console-modal.d.ts +10 -0
  139. package/dist/components/dev-console/developer-console-modal.js +987 -0
  140. package/dist/components/dev-console/developer-console-modal.js.map +1 -0
  141. package/dist/components/dev-console/developer-console-modal.mjs +12 -0
  142. package/dist/components/dev-console/developer-console-modal.mjs.map +1 -0
  143. package/dist/components/dev-console/icons.d.ts +9 -0
  144. package/dist/components/dev-console/icons.js +131 -0
  145. package/dist/components/dev-console/icons.js.map +1 -0
  146. package/dist/components/dev-console/icons.mjs +16 -0
  147. package/dist/components/dev-console/icons.mjs.map +1 -0
  148. package/dist/components/error-boundary/error-boundary.d.ts +31 -0
  149. package/dist/components/error-boundary/error-boundary.js +500 -0
  150. package/dist/components/error-boundary/error-boundary.js.map +1 -0
  151. package/dist/components/error-boundary/error-boundary.mjs +15 -0
  152. package/dist/components/error-boundary/error-boundary.mjs.map +1 -0
  153. package/dist/components/error-boundary/error-utils.d.ts +11 -0
  154. package/dist/components/error-boundary/error-utils.js +190 -0
  155. package/dist/components/error-boundary/error-utils.js.map +1 -0
  156. package/dist/components/error-boundary/error-utils.mjs +14 -0
  157. package/dist/components/error-boundary/error-utils.mjs.map +1 -0
  158. package/dist/components/index.d.ts +14 -0
  159. package/dist/components/index.js +1960 -0
  160. package/dist/components/index.js.map +1 -0
  161. package/dist/components/index.mjs +31 -0
  162. package/dist/components/index.mjs.map +1 -0
  163. package/dist/components/toast/exclamation-mark-icon.d.ts +9 -0
  164. package/dist/components/toast/exclamation-mark-icon.js +55 -0
  165. package/dist/components/toast/exclamation-mark-icon.js.map +1 -0
  166. package/dist/components/toast/exclamation-mark-icon.mjs +8 -0
  167. package/dist/components/toast/exclamation-mark-icon.mjs.map +1 -0
  168. package/dist/components/toast/toast-provider.d.ts +27 -0
  169. package/dist/components/toast/toast-provider.js +347 -0
  170. package/dist/components/toast/toast-provider.js.map +1 -0
  171. package/dist/components/toast/toast-provider.mjs +10 -0
  172. package/dist/components/toast/toast-provider.mjs.map +1 -0
  173. package/dist/components/usage-banner.d.ts +29 -0
  174. package/dist/components/usage-banner.js +247 -0
  175. package/dist/components/usage-banner.js.map +1 -0
  176. package/dist/components/usage-banner.mjs +12 -0
  177. package/dist/components/usage-banner.mjs.map +1 -0
  178. package/dist/context/coagent-state-renders-context.d.ts +24 -0
  179. package/dist/context/coagent-state-renders-context.js +91 -0
  180. package/dist/context/coagent-state-renders-context.js.map +1 -0
  181. package/dist/context/coagent-state-renders-context.mjs +12 -0
  182. package/dist/context/coagent-state-renders-context.mjs.map +1 -0
  183. package/dist/context/copilot-context.d.ts +10 -0
  184. package/dist/context/copilot-context.js +161 -0
  185. package/dist/context/copilot-context.js.map +1 -0
  186. package/dist/context/copilot-context.mjs +10 -0
  187. package/dist/context/copilot-context.mjs.map +1 -0
  188. package/dist/context/copilot-messages-context.d.ts +18 -0
  189. package/dist/context/copilot-messages-context.js +60 -0
  190. package/dist/context/copilot-messages-context.js.map +1 -0
  191. package/dist/context/copilot-messages-context.mjs +10 -0
  192. package/dist/context/copilot-messages-context.mjs.map +1 -0
  193. package/dist/context/index.d.ts +15 -0
  194. package/dist/context/index.js +285 -0
  195. package/dist/context/index.js.map +1 -0
  196. package/dist/context/index.mjs +33 -0
  197. package/dist/context/index.mjs.map +1 -0
  198. package/dist/context/threads-context.d.ts +16 -0
  199. package/dist/context/threads-context.js +59 -0
  200. package/dist/context/threads-context.js.map +1 -0
  201. package/dist/context/threads-context.mjs +12 -0
  202. package/dist/context/threads-context.mjs.map +1 -0
  203. package/dist/copilot-context-ec77e921.d.ts +209 -0
  204. package/dist/hooks/index.d.ts +33 -0
  205. package/dist/hooks/index.js +1774 -0
  206. package/dist/hooks/index.js.map +1 -0
  207. package/dist/hooks/index.mjs +91 -0
  208. package/dist/hooks/index.mjs.map +1 -0
  209. package/dist/hooks/use-agent-nodename.d.ts +3 -0
  210. package/dist/hooks/use-agent-nodename.js +56 -0
  211. package/dist/hooks/use-agent-nodename.js.map +1 -0
  212. package/dist/hooks/use-agent-nodename.mjs +8 -0
  213. package/dist/hooks/use-agent-nodename.mjs.map +1 -0
  214. package/dist/hooks/use-coagent-state-render-bridge.d.ts +100 -0
  215. package/dist/hooks/use-coagent-state-render-bridge.js +214 -0
  216. package/dist/hooks/use-coagent-state-render-bridge.js.map +1 -0
  217. package/dist/hooks/use-coagent-state-render-bridge.mjs +15 -0
  218. package/dist/hooks/use-coagent-state-render-bridge.mjs.map +1 -0
  219. package/dist/hooks/use-coagent-state-render.d.ts +55 -0
  220. package/dist/hooks/use-coagent-state-render.js +255 -0
  221. package/dist/hooks/use-coagent-state-render.js.map +1 -0
  222. package/dist/hooks/use-coagent-state-render.mjs +11 -0
  223. package/dist/hooks/use-coagent-state-render.mjs.map +1 -0
  224. package/dist/hooks/use-coagent.d.ts +192 -0
  225. package/dist/hooks/use-coagent.js +233 -0
  226. package/dist/hooks/use-coagent.js.map +1 -0
  227. package/dist/hooks/use-coagent.mjs +9 -0
  228. package/dist/hooks/use-coagent.mjs.map +1 -0
  229. package/dist/hooks/use-configure-chat-suggestions.d.ts +36 -0
  230. package/dist/hooks/use-configure-chat-suggestions.js +79 -0
  231. package/dist/hooks/use-configure-chat-suggestions.js.map +1 -0
  232. package/dist/hooks/use-configure-chat-suggestions.mjs +47 -0
  233. package/dist/hooks/use-configure-chat-suggestions.mjs.map +1 -0
  234. package/dist/hooks/use-copilot-action.d.ts +103 -0
  235. package/dist/hooks/use-copilot-action.js +295 -0
  236. package/dist/hooks/use-copilot-action.js.map +1 -0
  237. package/dist/hooks/use-copilot-action.mjs +11 -0
  238. package/dist/hooks/use-copilot-action.mjs.map +1 -0
  239. package/dist/hooks/use-copilot-additional-instructions.d.ts +26 -0
  240. package/dist/hooks/use-copilot-additional-instructions.js +177 -0
  241. package/dist/hooks/use-copilot-additional-instructions.js.map +1 -0
  242. package/dist/hooks/use-copilot-additional-instructions.mjs +9 -0
  243. package/dist/hooks/use-copilot-additional-instructions.mjs.map +1 -0
  244. package/dist/hooks/use-copilot-authenticated-action.d.ts +18 -0
  245. package/dist/hooks/use-copilot-authenticated-action.js +462 -0
  246. package/dist/hooks/use-copilot-authenticated-action.js.map +1 -0
  247. package/dist/hooks/use-copilot-authenticated-action.mjs +13 -0
  248. package/dist/hooks/use-copilot-authenticated-action.mjs.map +1 -0
  249. package/dist/hooks/use-copilot-chat-headless_c.d.ts +25 -0
  250. package/dist/hooks/use-copilot-chat-headless_c.js +1044 -0
  251. package/dist/hooks/use-copilot-chat-headless_c.js.map +1 -0
  252. package/dist/hooks/use-copilot-chat-headless_c.mjs +24 -0
  253. package/dist/hooks/use-copilot-chat-headless_c.mjs.map +1 -0
  254. package/dist/hooks/use-copilot-chat-suggestions.d.ts +35 -0
  255. package/dist/hooks/use-copilot-chat-suggestions.js +60 -0
  256. package/dist/hooks/use-copilot-chat-suggestions.js.map +1 -0
  257. package/dist/hooks/use-copilot-chat-suggestions.mjs +8 -0
  258. package/dist/hooks/use-copilot-chat-suggestions.mjs.map +1 -0
  259. package/dist/hooks/use-copilot-chat.d.ts +92 -0
  260. package/dist/hooks/use-copilot-chat.js +978 -0
  261. package/dist/hooks/use-copilot-chat.js.map +1 -0
  262. package/dist/hooks/use-copilot-chat.mjs +21 -0
  263. package/dist/hooks/use-copilot-chat.mjs.map +1 -0
  264. package/dist/hooks/use-copilot-chat_internal.d.ts +244 -0
  265. package/dist/hooks/use-copilot-chat_internal.js +976 -0
  266. package/dist/hooks/use-copilot-chat_internal.js.map +1 -0
  267. package/dist/hooks/use-copilot-chat_internal.mjs +22 -0
  268. package/dist/hooks/use-copilot-chat_internal.mjs.map +1 -0
  269. package/dist/hooks/use-copilot-readable.d.ts +37 -0
  270. package/dist/hooks/use-copilot-readable.js +61 -0
  271. package/dist/hooks/use-copilot-readable.js.map +1 -0
  272. package/dist/hooks/use-copilot-readable.mjs +8 -0
  273. package/dist/hooks/use-copilot-readable.mjs.map +1 -0
  274. package/dist/hooks/use-copilot-runtime-client.d.ts +10 -0
  275. package/dist/hooks/use-copilot-runtime-client.js +203 -0
  276. package/dist/hooks/use-copilot-runtime-client.js.map +1 -0
  277. package/dist/hooks/use-copilot-runtime-client.mjs +9 -0
  278. package/dist/hooks/use-copilot-runtime-client.mjs.map +1 -0
  279. package/dist/hooks/use-default-tool.d.ts +8 -0
  280. package/dist/hooks/use-default-tool.js +302 -0
  281. package/dist/hooks/use-default-tool.js.map +1 -0
  282. package/dist/hooks/use-default-tool.mjs +12 -0
  283. package/dist/hooks/use-default-tool.mjs.map +1 -0
  284. package/dist/hooks/use-flat-category-store.d.ts +9 -0
  285. package/dist/hooks/use-flat-category-store.js +93 -0
  286. package/dist/hooks/use-flat-category-store.js.map +1 -0
  287. package/dist/hooks/use-flat-category-store.mjs +8 -0
  288. package/dist/hooks/use-flat-category-store.mjs.map +1 -0
  289. package/dist/hooks/use-frontend-tool.d.ts +11 -0
  290. package/dist/hooks/use-frontend-tool.js +104 -0
  291. package/dist/hooks/use-frontend-tool.js.map +1 -0
  292. package/dist/hooks/use-frontend-tool.mjs +8 -0
  293. package/dist/hooks/use-frontend-tool.mjs.map +1 -0
  294. package/dist/hooks/use-human-in-the-loop.d.ts +13 -0
  295. package/dist/hooks/use-human-in-the-loop.js +122 -0
  296. package/dist/hooks/use-human-in-the-loop.js.map +1 -0
  297. package/dist/hooks/use-human-in-the-loop.mjs +8 -0
  298. package/dist/hooks/use-human-in-the-loop.mjs.map +1 -0
  299. package/dist/hooks/use-langgraph-interrupt-render.d.ts +6 -0
  300. package/dist/hooks/use-langgraph-interrupt-render.js +318 -0
  301. package/dist/hooks/use-langgraph-interrupt-render.js.map +1 -0
  302. package/dist/hooks/use-langgraph-interrupt-render.mjs +14 -0
  303. package/dist/hooks/use-langgraph-interrupt-render.mjs.map +1 -0
  304. package/dist/hooks/use-langgraph-interrupt.d.ts +14 -0
  305. package/dist/hooks/use-langgraph-interrupt.js +201 -0
  306. package/dist/hooks/use-langgraph-interrupt.js.map +1 -0
  307. package/dist/hooks/use-langgraph-interrupt.mjs +10 -0
  308. package/dist/hooks/use-langgraph-interrupt.mjs.map +1 -0
  309. package/dist/hooks/use-lazy-tool-renderer.d.ts +6 -0
  310. package/dist/hooks/use-lazy-tool-renderer.js +53 -0
  311. package/dist/hooks/use-lazy-tool-renderer.js.map +1 -0
  312. package/dist/hooks/use-lazy-tool-renderer.mjs +8 -0
  313. package/dist/hooks/use-lazy-tool-renderer.mjs.map +1 -0
  314. package/dist/hooks/use-make-copilot-document-readable.d.ts +12 -0
  315. package/dist/hooks/use-make-copilot-document-readable.js +176 -0
  316. package/dist/hooks/use-make-copilot-document-readable.js.map +1 -0
  317. package/dist/hooks/use-make-copilot-document-readable.mjs +9 -0
  318. package/dist/hooks/use-make-copilot-document-readable.mjs.map +1 -0
  319. package/dist/hooks/use-render-tool-call.d.ts +12 -0
  320. package/dist/hooks/use-render-tool-call.js +90 -0
  321. package/dist/hooks/use-render-tool-call.js.map +1 -0
  322. package/dist/hooks/use-render-tool-call.mjs +8 -0
  323. package/dist/hooks/use-render-tool-call.mjs.map +1 -0
  324. package/dist/hooks/use-tree.d.ts +19 -0
  325. package/dist/hooks/use-tree.js +175 -0
  326. package/dist/hooks/use-tree.js.map +1 -0
  327. package/dist/hooks/use-tree.mjs +8 -0
  328. package/dist/hooks/use-tree.mjs.map +1 -0
  329. package/dist/index.d.ts +43 -0
  330. package/dist/index.js +3528 -0
  331. package/dist/index.js.map +1 -0
  332. package/dist/index.mjs +149 -0
  333. package/dist/index.mjs.map +1 -0
  334. package/dist/lib/copilot-task.d.ts +97 -0
  335. package/dist/lib/copilot-task.js +194 -0
  336. package/dist/lib/copilot-task.js.map +1 -0
  337. package/dist/lib/copilot-task.mjs +31 -0
  338. package/dist/lib/copilot-task.mjs.map +1 -0
  339. package/dist/lib/index.d.ts +11 -0
  340. package/dist/lib/index.js +196 -0
  341. package/dist/lib/index.js.map +1 -0
  342. package/dist/lib/index.mjs +32 -0
  343. package/dist/lib/index.mjs.map +1 -0
  344. package/dist/lib/status-checker.d.ts +17 -0
  345. package/dist/lib/status-checker.js +102 -0
  346. package/dist/lib/status-checker.js.map +1 -0
  347. package/dist/lib/status-checker.mjs +8 -0
  348. package/dist/lib/status-checker.mjs.map +1 -0
  349. package/dist/setupTests.d.ts +2 -0
  350. package/dist/setupTests.js +26 -0
  351. package/dist/setupTests.js.map +1 -0
  352. package/dist/setupTests.mjs +24 -0
  353. package/dist/setupTests.mjs.map +1 -0
  354. package/dist/types/chat-suggestion-configuration.d.ts +22 -0
  355. package/dist/types/chat-suggestion-configuration.js +19 -0
  356. package/dist/types/chat-suggestion-configuration.js.map +1 -0
  357. package/dist/types/chat-suggestion-configuration.mjs +1 -0
  358. package/dist/types/chat-suggestion-configuration.mjs.map +1 -0
  359. package/dist/types/coagent-action.d.ts +29 -0
  360. package/dist/types/coagent-action.js +19 -0
  361. package/dist/types/coagent-action.js.map +1 -0
  362. package/dist/types/coagent-action.mjs +1 -0
  363. package/dist/types/coagent-action.mjs.map +1 -0
  364. package/dist/types/coagent-state.d.ts +15 -0
  365. package/dist/types/coagent-state.js +19 -0
  366. package/dist/types/coagent-state.js.map +1 -0
  367. package/dist/types/coagent-state.mjs +1 -0
  368. package/dist/types/coagent-state.mjs.map +1 -0
  369. package/dist/types/crew.d.ts +79 -0
  370. package/dist/types/crew.js +19 -0
  371. package/dist/types/crew.js.map +1 -0
  372. package/dist/types/crew.mjs +2 -0
  373. package/dist/types/crew.mjs.map +1 -0
  374. package/dist/types/document-pointer.d.ts +9 -0
  375. package/dist/types/document-pointer.js +19 -0
  376. package/dist/types/document-pointer.js.map +1 -0
  377. package/dist/types/document-pointer.mjs +1 -0
  378. package/dist/types/document-pointer.mjs.map +1 -0
  379. package/dist/types/frontend-action.d.ts +127 -0
  380. package/dist/types/frontend-action.js +53 -0
  381. package/dist/types/frontend-action.js.map +1 -0
  382. package/dist/types/frontend-action.mjs +8 -0
  383. package/dist/types/frontend-action.mjs.map +1 -0
  384. package/dist/types/index.d.ts +12 -0
  385. package/dist/types/index.js +19 -0
  386. package/dist/types/index.js.map +1 -0
  387. package/dist/types/index.mjs +4 -0
  388. package/dist/types/index.mjs.map +1 -0
  389. package/dist/types/interrupt-action.d.ts +10 -0
  390. package/dist/types/interrupt-action.js +19 -0
  391. package/dist/types/interrupt-action.js.map +1 -0
  392. package/dist/types/interrupt-action.mjs +2 -0
  393. package/dist/types/interrupt-action.mjs.map +1 -0
  394. package/dist/types/system-message.d.ts +3 -0
  395. package/dist/types/system-message.js +19 -0
  396. package/dist/types/system-message.js.map +1 -0
  397. package/dist/types/system-message.mjs +1 -0
  398. package/dist/types/system-message.mjs.map +1 -0
  399. package/dist/utils/dev-console.d.ts +3 -0
  400. package/dist/utils/dev-console.js +41 -0
  401. package/dist/utils/dev-console.js.map +1 -0
  402. package/dist/utils/dev-console.mjs +8 -0
  403. package/dist/utils/dev-console.mjs.map +1 -0
  404. package/dist/utils/index.d.ts +2 -0
  405. package/dist/utils/index.js +52 -0
  406. package/dist/utils/index.js.map +1 -0
  407. package/dist/utils/index.mjs +13 -0
  408. package/dist/utils/index.mjs.map +1 -0
  409. package/dist/utils/suggestions-constants.d.ts +9 -0
  410. package/dist/utils/suggestions-constants.js +35 -0
  411. package/dist/utils/suggestions-constants.js.map +1 -0
  412. package/dist/utils/suggestions-constants.mjs +8 -0
  413. package/dist/utils/suggestions-constants.mjs.map +1 -0
  414. package/dist/utils/utils.d.ts +2 -0
  415. package/dist/utils/utils.js +19 -0
  416. package/dist/utils/utils.js.map +1 -0
  417. package/dist/utils/utils.mjs +1 -0
  418. package/dist/utils/utils.mjs.map +1 -0
  419. package/dist/v2/index.css +4 -0
  420. package/dist/v2/index.css.map +1 -0
  421. package/dist/v2/index.d.ts +2 -0
  422. package/dist/v2/index.js +27 -0
  423. package/dist/v2/index.js.map +1 -0
  424. package/dist/v2/index.mjs +6 -0
  425. package/dist/v2/index.mjs.map +1 -0
  426. package/jest.config.js +25 -0
  427. package/package.json +92 -0
  428. package/src/components/CopilotListeners.tsx +81 -0
  429. package/src/components/copilot-provider/__tests__/copilotkit-error.test.tsx +75 -0
  430. package/src/components/copilot-provider/copilot-messages.tsx +274 -0
  431. package/src/components/copilot-provider/copilotkit-props.tsx +169 -0
  432. package/src/components/copilot-provider/copilotkit.tsx +671 -0
  433. package/src/components/copilot-provider/index.ts +3 -0
  434. package/src/components/dev-console/console-trigger.tsx +254 -0
  435. package/src/components/dev-console/developer-console-modal.tsx +866 -0
  436. package/src/components/dev-console/icons.tsx +101 -0
  437. package/src/components/error-boundary/error-boundary.tsx +91 -0
  438. package/src/components/error-boundary/error-utils.tsx +100 -0
  439. package/src/components/index.ts +1 -0
  440. package/src/components/toast/exclamation-mark-icon.tsx +27 -0
  441. package/src/components/toast/toast-provider.tsx +363 -0
  442. package/src/components/usage-banner.tsx +259 -0
  443. package/src/context/coagent-state-renders-context.tsx +76 -0
  444. package/src/context/copilot-context.tsx +332 -0
  445. package/src/context/copilot-messages-context.tsx +35 -0
  446. package/src/context/index.ts +16 -0
  447. package/src/context/threads-context.tsx +41 -0
  448. package/src/hooks/__tests__/use-coagent-config.test.ts +351 -0
  449. package/src/hooks/index.ts +34 -0
  450. package/src/hooks/use-agent-nodename.ts +30 -0
  451. package/src/hooks/use-coagent-state-render-bridge.tsx +293 -0
  452. package/src/hooks/use-coagent-state-render.ts +152 -0
  453. package/src/hooks/use-coagent.ts +366 -0
  454. package/src/hooks/use-configure-chat-suggestions.tsx +86 -0
  455. package/src/hooks/use-copilot-action.ts +236 -0
  456. package/src/hooks/use-copilot-additional-instructions.ts +85 -0
  457. package/src/hooks/use-copilot-authenticated-action.ts +70 -0
  458. package/src/hooks/use-copilot-chat-headless_c.ts +258 -0
  459. package/src/hooks/use-copilot-chat-suggestions.tsx +124 -0
  460. package/src/hooks/use-copilot-chat.ts +130 -0
  461. package/src/hooks/use-copilot-chat_internal.ts +696 -0
  462. package/src/hooks/use-copilot-readable.ts +135 -0
  463. package/src/hooks/use-copilot-runtime-client.ts +164 -0
  464. package/src/hooks/use-default-tool.ts +7 -0
  465. package/src/hooks/use-flat-category-store.ts +105 -0
  466. package/src/hooks/use-frontend-tool.ts +96 -0
  467. package/src/hooks/use-human-in-the-loop.ts +122 -0
  468. package/src/hooks/use-langgraph-interrupt-render.ts +136 -0
  469. package/src/hooks/use-langgraph-interrupt.ts +36 -0
  470. package/src/hooks/use-lazy-tool-renderer.tsx +30 -0
  471. package/src/hooks/use-make-copilot-document-readable.ts +30 -0
  472. package/src/hooks/use-render-tool-call.ts +80 -0
  473. package/src/hooks/use-tree.ts +207 -0
  474. package/src/index.tsx +7 -0
  475. package/src/lib/copilot-task.ts +201 -0
  476. package/src/lib/index.ts +1 -0
  477. package/src/lib/status-checker.ts +64 -0
  478. package/src/setupTests.ts +26 -0
  479. package/src/types/chat-suggestion-configuration.ts +23 -0
  480. package/src/types/coagent-action.ts +31 -0
  481. package/src/types/coagent-state.ts +13 -0
  482. package/src/types/crew.ts +89 -0
  483. package/src/types/document-pointer.ts +7 -0
  484. package/src/types/frontend-action.ts +202 -0
  485. package/src/types/index.ts +17 -0
  486. package/src/types/interrupt-action.ts +43 -0
  487. package/src/types/system-message.ts +4 -0
  488. package/src/utils/dev-console.ts +19 -0
  489. package/src/utils/index.ts +2 -0
  490. package/src/utils/suggestions-constants.ts +8 -0
  491. package/src/utils/utils.test.ts +7 -0
  492. package/src/utils/utils.ts +8 -0
  493. package/src/v2/index.css +1 -0
  494. package/src/v2/index.ts +4 -0
  495. package/tsconfig.json +8 -0
  496. package/tsup.config.ts +16 -0
  497. 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
+ }