@copilotkit/react-ui 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 (395) hide show
  1. package/CHANGELOG.md +17415 -0
  2. package/LICENSE +21 -0
  3. package/README.md +141 -0
  4. package/dist/chunk-3W6J75HS.mjs +126 -0
  5. package/dist/chunk-3W6J75HS.mjs.map +1 -0
  6. package/dist/chunk-54JAUBUJ.mjs +26 -0
  7. package/dist/chunk-54JAUBUJ.mjs.map +1 -0
  8. package/dist/chunk-7OURDQZJ.mjs +133 -0
  9. package/dist/chunk-7OURDQZJ.mjs.map +1 -0
  10. package/dist/chunk-7PR2KJDO.mjs +222 -0
  11. package/dist/chunk-7PR2KJDO.mjs.map +1 -0
  12. package/dist/chunk-BH6PCAAL.mjs +81 -0
  13. package/dist/chunk-BH6PCAAL.mjs.map +1 -0
  14. package/dist/chunk-C3GSYRC3.mjs +118 -0
  15. package/dist/chunk-C3GSYRC3.mjs.map +1 -0
  16. package/dist/chunk-DBKRAOH7.mjs +34 -0
  17. package/dist/chunk-DBKRAOH7.mjs.map +1 -0
  18. package/dist/chunk-EFZPSZWO.mjs +1 -0
  19. package/dist/chunk-EFZPSZWO.mjs.map +1 -0
  20. package/dist/chunk-ELGRNEAO.mjs +32 -0
  21. package/dist/chunk-ELGRNEAO.mjs.map +1 -0
  22. package/dist/chunk-ELUJRANC.mjs +21 -0
  23. package/dist/chunk-ELUJRANC.mjs.map +1 -0
  24. package/dist/chunk-FFJHOZX6.mjs +202 -0
  25. package/dist/chunk-FFJHOZX6.mjs.map +1 -0
  26. package/dist/chunk-GDSZGYCE.mjs +32 -0
  27. package/dist/chunk-GDSZGYCE.mjs.map +1 -0
  28. package/dist/chunk-HIW7RXCD.mjs +184 -0
  29. package/dist/chunk-HIW7RXCD.mjs.map +1 -0
  30. package/dist/chunk-IEMQ2SQW.mjs +93 -0
  31. package/dist/chunk-IEMQ2SQW.mjs.map +1 -0
  32. package/dist/chunk-IHFR6PYG.mjs +116 -0
  33. package/dist/chunk-IHFR6PYG.mjs.map +1 -0
  34. package/dist/chunk-IK2BPURM.mjs +400 -0
  35. package/dist/chunk-IK2BPURM.mjs.map +1 -0
  36. package/dist/chunk-IU3WTXLQ.mjs +1 -0
  37. package/dist/chunk-IU3WTXLQ.mjs.map +1 -0
  38. package/dist/chunk-JGMFJZMG.mjs +11 -0
  39. package/dist/chunk-JGMFJZMG.mjs.map +1 -0
  40. package/dist/chunk-JY2CSDKN.mjs +135 -0
  41. package/dist/chunk-JY2CSDKN.mjs.map +1 -0
  42. package/dist/chunk-JZ3RFQQ6.mjs +128 -0
  43. package/dist/chunk-JZ3RFQQ6.mjs.map +1 -0
  44. package/dist/chunk-KXE2JCUH.mjs +1 -0
  45. package/dist/chunk-KXE2JCUH.mjs.map +1 -0
  46. package/dist/chunk-LQEFRHRT.mjs +30 -0
  47. package/dist/chunk-LQEFRHRT.mjs.map +1 -0
  48. package/dist/chunk-MMVDU6DF.mjs +1 -0
  49. package/dist/chunk-MMVDU6DF.mjs.map +1 -0
  50. package/dist/chunk-MRXNTQOX.mjs +59 -0
  51. package/dist/chunk-MRXNTQOX.mjs.map +1 -0
  52. package/dist/chunk-NCIAFFQ2.mjs +82 -0
  53. package/dist/chunk-NCIAFFQ2.mjs.map +1 -0
  54. package/dist/chunk-NGJ32FAP.mjs +30 -0
  55. package/dist/chunk-NGJ32FAP.mjs.map +1 -0
  56. package/dist/chunk-NRA3CFEE.mjs +97 -0
  57. package/dist/chunk-NRA3CFEE.mjs.map +1 -0
  58. package/dist/chunk-O72ZB5V3.mjs +140 -0
  59. package/dist/chunk-O72ZB5V3.mjs.map +1 -0
  60. package/dist/chunk-PLHTVHUW.mjs +82 -0
  61. package/dist/chunk-PLHTVHUW.mjs.map +1 -0
  62. package/dist/chunk-Q5V6S67N.mjs +103 -0
  63. package/dist/chunk-Q5V6S67N.mjs.map +1 -0
  64. package/dist/chunk-QB3GUN2N.mjs +31 -0
  65. package/dist/chunk-QB3GUN2N.mjs.map +1 -0
  66. package/dist/chunk-QIOJXTIQ.mjs +64 -0
  67. package/dist/chunk-QIOJXTIQ.mjs.map +1 -0
  68. package/dist/chunk-QPQRLXN3.mjs +435 -0
  69. package/dist/chunk-QPQRLXN3.mjs.map +1 -0
  70. package/dist/chunk-RYUCX3ZK.mjs +32 -0
  71. package/dist/chunk-RYUCX3ZK.mjs.map +1 -0
  72. package/dist/chunk-SC6JRFAJ.mjs +1 -0
  73. package/dist/chunk-SC6JRFAJ.mjs.map +1 -0
  74. package/dist/chunk-T26KLXLH.mjs +1 -0
  75. package/dist/chunk-T26KLXLH.mjs.map +1 -0
  76. package/dist/chunk-UFN2VWSR.mjs +25 -0
  77. package/dist/chunk-UFN2VWSR.mjs.map +1 -0
  78. package/dist/chunk-V7W6IM2V.mjs +1 -0
  79. package/dist/chunk-V7W6IM2V.mjs.map +1 -0
  80. package/dist/chunk-WB3YULQ4.mjs +1 -0
  81. package/dist/chunk-WB3YULQ4.mjs.map +1 -0
  82. package/dist/chunk-XWG3L6QC.mjs +258 -0
  83. package/dist/chunk-XWG3L6QC.mjs.map +1 -0
  84. package/dist/chunk-Y4FKRAKJ.mjs +12 -0
  85. package/dist/chunk-Y4FKRAKJ.mjs.map +1 -0
  86. package/dist/components/chat/Button.d.ts +9 -0
  87. package/dist/components/chat/Button.js +71 -0
  88. package/dist/components/chat/Button.js.map +1 -0
  89. package/dist/components/chat/Button.mjs +10 -0
  90. package/dist/components/chat/Button.mjs.map +1 -0
  91. package/dist/components/chat/Chat.d.ts +204 -0
  92. package/dist/components/chat/Chat.js +2270 -0
  93. package/dist/components/chat/Chat.js.map +1 -0
  94. package/dist/components/chat/Chat.mjs +29 -0
  95. package/dist/components/chat/Chat.mjs.map +1 -0
  96. package/dist/components/chat/ChatContext.d.ts +145 -0
  97. package/dist/components/chat/ChatContext.js +329 -0
  98. package/dist/components/chat/ChatContext.js.map +1 -0
  99. package/dist/components/chat/ChatContext.mjs +13 -0
  100. package/dist/components/chat/ChatContext.mjs.map +1 -0
  101. package/dist/components/chat/CodeBlock.d.ts +14 -0
  102. package/dist/components/chat/CodeBlock.js +510 -0
  103. package/dist/components/chat/CodeBlock.js.map +1 -0
  104. package/dist/components/chat/CodeBlock.mjs +14 -0
  105. package/dist/components/chat/CodeBlock.mjs.map +1 -0
  106. package/dist/components/chat/Header.d.ts +9 -0
  107. package/dist/components/chat/Header.js +582 -0
  108. package/dist/components/chat/Header.js.map +1 -0
  109. package/dist/components/chat/Header.mjs +17 -0
  110. package/dist/components/chat/Header.mjs.map +1 -0
  111. package/dist/components/chat/Icons.d.ts +20 -0
  112. package/dist/components/chat/Icons.js +297 -0
  113. package/dist/components/chat/Icons.js.map +1 -0
  114. package/dist/components/chat/Icons.mjs +38 -0
  115. package/dist/components/chat/Icons.mjs.map +1 -0
  116. package/dist/components/chat/ImageUploadQueue.d.ts +13 -0
  117. package/dist/components/chat/ImageUploadQueue.js +106 -0
  118. package/dist/components/chat/ImageUploadQueue.js.map +1 -0
  119. package/dist/components/chat/ImageUploadQueue.mjs +8 -0
  120. package/dist/components/chat/ImageUploadQueue.mjs.map +1 -0
  121. package/dist/components/chat/Input.d.ts +9 -0
  122. package/dist/components/chat/Input.js +396 -0
  123. package/dist/components/chat/Input.js.map +1 -0
  124. package/dist/components/chat/Input.mjs +14 -0
  125. package/dist/components/chat/Input.mjs.map +1 -0
  126. package/dist/components/chat/Markdown.d.ts +10 -0
  127. package/dist/components/chat/Markdown.js +652 -0
  128. package/dist/components/chat/Markdown.js.map +1 -0
  129. package/dist/components/chat/Markdown.mjs +11 -0
  130. package/dist/components/chat/Markdown.mjs.map +1 -0
  131. package/dist/components/chat/Messages.d.ts +13 -0
  132. package/dist/components/chat/Messages.js +1195 -0
  133. package/dist/components/chat/Messages.js.map +1 -0
  134. package/dist/components/chat/Messages.mjs +20 -0
  135. package/dist/components/chat/Messages.mjs.map +1 -0
  136. package/dist/components/chat/Modal.d.ts +51 -0
  137. package/dist/components/chat/Modal.js +3075 -0
  138. package/dist/components/chat/Modal.js.map +1 -0
  139. package/dist/components/chat/Modal.mjs +38 -0
  140. package/dist/components/chat/Modal.mjs.map +1 -0
  141. package/dist/components/chat/Popup.d.ts +13 -0
  142. package/dist/components/chat/Popup.js +3086 -0
  143. package/dist/components/chat/Popup.js.map +1 -0
  144. package/dist/components/chat/Popup.mjs +39 -0
  145. package/dist/components/chat/Popup.mjs.map +1 -0
  146. package/dist/components/chat/PoweredByTag.d.ts +7 -0
  147. package/dist/components/chat/PoweredByTag.js +61 -0
  148. package/dist/components/chat/PoweredByTag.js.map +1 -0
  149. package/dist/components/chat/PoweredByTag.mjs +9 -0
  150. package/dist/components/chat/PoweredByTag.mjs.map +1 -0
  151. package/dist/components/chat/Sidebar.d.ts +13 -0
  152. package/dist/components/chat/Sidebar.js +3095 -0
  153. package/dist/components/chat/Sidebar.js.map +1 -0
  154. package/dist/components/chat/Sidebar.mjs +39 -0
  155. package/dist/components/chat/Sidebar.mjs.map +1 -0
  156. package/dist/components/chat/Suggestion.d.ts +12 -0
  157. package/dist/components/chat/Suggestion.js +56 -0
  158. package/dist/components/chat/Suggestion.js.map +1 -0
  159. package/dist/components/chat/Suggestion.mjs +9 -0
  160. package/dist/components/chat/Suggestion.mjs.map +1 -0
  161. package/dist/components/chat/Suggestions.d.ts +9 -0
  162. package/dist/components/chat/Suggestions.js +81 -0
  163. package/dist/components/chat/Suggestions.js.map +1 -0
  164. package/dist/components/chat/Suggestions.mjs +10 -0
  165. package/dist/components/chat/Suggestions.mjs.map +1 -0
  166. package/dist/components/chat/Textarea.d.ts +15 -0
  167. package/dist/components/chat/Textarea.js +84 -0
  168. package/dist/components/chat/Textarea.js.map +1 -0
  169. package/dist/components/chat/Textarea.mjs +8 -0
  170. package/dist/components/chat/Textarea.mjs.map +1 -0
  171. package/dist/components/chat/Window.d.ts +9 -0
  172. package/dist/components/chat/Window.js +164 -0
  173. package/dist/components/chat/Window.js.map +1 -0
  174. package/dist/components/chat/Window.mjs +10 -0
  175. package/dist/components/chat/Window.mjs.map +1 -0
  176. package/dist/components/chat/index.d.ts +18 -0
  177. package/dist/components/chat/index.js +3122 -0
  178. package/dist/components/chat/index.js.map +1 -0
  179. package/dist/components/chat/index.mjs +69 -0
  180. package/dist/components/chat/index.mjs.map +1 -0
  181. package/dist/components/chat/messages/AssistantMessage.d.ts +9 -0
  182. package/dist/components/chat/messages/AssistantMessage.js +775 -0
  183. package/dist/components/chat/messages/AssistantMessage.js.map +1 -0
  184. package/dist/components/chat/messages/AssistantMessage.mjs +13 -0
  185. package/dist/components/chat/messages/AssistantMessage.mjs.map +1 -0
  186. package/dist/components/chat/messages/ErrorMessage.d.ts +9 -0
  187. package/dist/components/chat/messages/ErrorMessage.js +722 -0
  188. package/dist/components/chat/messages/ErrorMessage.js.map +1 -0
  189. package/dist/components/chat/messages/ErrorMessage.mjs +66 -0
  190. package/dist/components/chat/messages/ErrorMessage.mjs.map +1 -0
  191. package/dist/components/chat/messages/ImageRenderer.d.ts +12 -0
  192. package/dist/components/chat/messages/ImageRenderer.js +58 -0
  193. package/dist/components/chat/messages/ImageRenderer.js.map +1 -0
  194. package/dist/components/chat/messages/ImageRenderer.mjs +8 -0
  195. package/dist/components/chat/messages/ImageRenderer.mjs.map +1 -0
  196. package/dist/components/chat/messages/LegacyRenderMessage.d.ts +28 -0
  197. package/dist/components/chat/messages/LegacyRenderMessage.js +1023 -0
  198. package/dist/components/chat/messages/LegacyRenderMessage.js.map +1 -0
  199. package/dist/components/chat/messages/LegacyRenderMessage.mjs +17 -0
  200. package/dist/components/chat/messages/LegacyRenderMessage.mjs.map +1 -0
  201. package/dist/components/chat/messages/RenderMessage.d.ts +9 -0
  202. package/dist/components/chat/messages/RenderMessage.js +898 -0
  203. package/dist/components/chat/messages/RenderMessage.js.map +1 -0
  204. package/dist/components/chat/messages/RenderMessage.mjs +16 -0
  205. package/dist/components/chat/messages/RenderMessage.mjs.map +1 -0
  206. package/dist/components/chat/messages/UserMessage.d.ts +9 -0
  207. package/dist/components/chat/messages/UserMessage.js +56 -0
  208. package/dist/components/chat/messages/UserMessage.js.map +1 -0
  209. package/dist/components/chat/messages/UserMessage.mjs +8 -0
  210. package/dist/components/chat/messages/UserMessage.mjs.map +1 -0
  211. package/dist/components/chat/props.d.ts +298 -0
  212. package/dist/components/chat/props.js +19 -0
  213. package/dist/components/chat/props.js.map +1 -0
  214. package/dist/components/chat/props.mjs +2 -0
  215. package/dist/components/chat/props.mjs.map +1 -0
  216. package/dist/components/dev-console/console.d.ts +11 -0
  217. package/dist/components/dev-console/console.js +537 -0
  218. package/dist/components/dev-console/console.js.map +1 -0
  219. package/dist/components/dev-console/console.mjs +17 -0
  220. package/dist/components/dev-console/console.mjs.map +1 -0
  221. package/dist/components/dev-console/icons.d.ts +9 -0
  222. package/dist/components/dev-console/icons.js +131 -0
  223. package/dist/components/dev-console/icons.js.map +1 -0
  224. package/dist/components/dev-console/icons.mjs +16 -0
  225. package/dist/components/dev-console/icons.mjs.map +1 -0
  226. package/dist/components/dev-console/index.d.ts +3 -0
  227. package/dist/components/dev-console/index.js +537 -0
  228. package/dist/components/dev-console/index.js.map +1 -0
  229. package/dist/components/dev-console/index.mjs +18 -0
  230. package/dist/components/dev-console/index.mjs.map +1 -0
  231. package/dist/components/dev-console/types.d.ts +9 -0
  232. package/dist/components/dev-console/types.js +19 -0
  233. package/dist/components/dev-console/types.js.map +1 -0
  234. package/dist/components/dev-console/types.mjs +1 -0
  235. package/dist/components/dev-console/types.mjs.map +1 -0
  236. package/dist/components/dev-console/utils.d.ts +10 -0
  237. package/dist/components/dev-console/utils.js +177 -0
  238. package/dist/components/dev-console/utils.js.map +1 -0
  239. package/dist/components/dev-console/utils.mjs +16 -0
  240. package/dist/components/dev-console/utils.mjs.map +1 -0
  241. package/dist/components/help-modal/icons.d.ts +9 -0
  242. package/dist/components/help-modal/icons.js +107 -0
  243. package/dist/components/help-modal/icons.js.map +1 -0
  244. package/dist/components/help-modal/icons.mjs +12 -0
  245. package/dist/components/help-modal/icons.mjs.map +1 -0
  246. package/dist/components/help-modal/index.d.ts +2 -0
  247. package/dist/components/help-modal/index.js +137 -0
  248. package/dist/components/help-modal/index.js.map +1 -0
  249. package/dist/components/help-modal/index.mjs +10 -0
  250. package/dist/components/help-modal/index.mjs.map +1 -0
  251. package/dist/components/help-modal/modal.d.ts +5 -0
  252. package/dist/components/help-modal/modal.js +135 -0
  253. package/dist/components/help-modal/modal.js.map +1 -0
  254. package/dist/components/help-modal/modal.mjs +9 -0
  255. package/dist/components/help-modal/modal.mjs.map +1 -0
  256. package/dist/components/index.d.ts +19 -0
  257. package/dist/components/index.js +3126 -0
  258. package/dist/components/index.js.map +1 -0
  259. package/dist/components/index.mjs +76 -0
  260. package/dist/components/index.mjs.map +1 -0
  261. package/dist/context/index.d.ts +2 -0
  262. package/dist/context/index.js +19 -0
  263. package/dist/context/index.js.map +1 -0
  264. package/dist/context/index.mjs +2 -0
  265. package/dist/context/index.mjs.map +1 -0
  266. package/dist/hooks/index.d.ts +2 -0
  267. package/dist/hooks/index.js +36 -0
  268. package/dist/hooks/index.js.map +1 -0
  269. package/dist/hooks/index.mjs +9 -0
  270. package/dist/hooks/index.mjs.map +1 -0
  271. package/dist/hooks/use-copilot-chat-suggestions.d.ts +66 -0
  272. package/dist/hooks/use-copilot-chat-suggestions.js +34 -0
  273. package/dist/hooks/use-copilot-chat-suggestions.js.map +1 -0
  274. package/dist/hooks/use-copilot-chat-suggestions.mjs +8 -0
  275. package/dist/hooks/use-copilot-chat-suggestions.mjs.map +1 -0
  276. package/dist/hooks/use-copy-to-clipboard.d.ts +9 -0
  277. package/dist/hooks/use-copy-to-clipboard.js +60 -0
  278. package/dist/hooks/use-copy-to-clipboard.js.map +1 -0
  279. package/dist/hooks/use-copy-to-clipboard.mjs +8 -0
  280. package/dist/hooks/use-copy-to-clipboard.mjs.map +1 -0
  281. package/dist/hooks/use-dark-mode.d.ts +3 -0
  282. package/dist/hooks/use-dark-mode.js +35 -0
  283. package/dist/hooks/use-dark-mode.js.map +1 -0
  284. package/dist/hooks/use-dark-mode.mjs +8 -0
  285. package/dist/hooks/use-dark-mode.mjs.map +1 -0
  286. package/dist/hooks/use-push-to-talk.d.ts +19 -0
  287. package/dist/hooks/use-push-to-talk.js +195 -0
  288. package/dist/hooks/use-push-to-talk.js.map +1 -0
  289. package/dist/hooks/use-push-to-talk.mjs +12 -0
  290. package/dist/hooks/use-push-to-talk.mjs.map +1 -0
  291. package/dist/index.css +1258 -0
  292. package/dist/index.css.map +1 -0
  293. package/dist/index.d.ts +21 -0
  294. package/dist/index.js +3135 -0
  295. package/dist/index.js.map +1 -0
  296. package/dist/index.mjs +84 -0
  297. package/dist/index.mjs.map +1 -0
  298. package/dist/lib/utils.d.ts +4 -0
  299. package/dist/lib/utils.js +76 -0
  300. package/dist/lib/utils.js.map +1 -0
  301. package/dist/lib/utils.mjs +34 -0
  302. package/dist/lib/utils.mjs.map +1 -0
  303. package/dist/types/css.d.ts +22 -0
  304. package/dist/types/css.js +19 -0
  305. package/dist/types/css.js.map +1 -0
  306. package/dist/types/css.mjs +1 -0
  307. package/dist/types/css.mjs.map +1 -0
  308. package/dist/types/index.d.ts +3 -0
  309. package/dist/types/index.js +19 -0
  310. package/dist/types/index.js.map +1 -0
  311. package/dist/types/index.mjs +2 -0
  312. package/dist/types/index.mjs.map +1 -0
  313. package/dist/types/suggestions.d.ts +9 -0
  314. package/dist/types/suggestions.js +19 -0
  315. package/dist/types/suggestions.js.map +1 -0
  316. package/dist/types/suggestions.mjs +1 -0
  317. package/dist/types/suggestions.mjs.map +1 -0
  318. package/dist/v2/index.css +4 -0
  319. package/dist/v2/index.css.map +1 -0
  320. package/dist/v2/index.d.ts +2 -0
  321. package/dist/v2/index.js +2 -0
  322. package/dist/v2/index.js.map +1 -0
  323. package/dist/v2/index.mjs +2 -0
  324. package/dist/v2/index.mjs.map +1 -0
  325. package/jest.config.js +5 -0
  326. package/package.json +83 -0
  327. package/postcss.config.js +60 -0
  328. package/src/components/chat/Button.tsx +18 -0
  329. package/src/components/chat/Chat.tsx +795 -0
  330. package/src/components/chat/ChatContext.tsx +248 -0
  331. package/src/components/chat/CodeBlock.tsx +418 -0
  332. package/src/components/chat/Header.tsx +24 -0
  333. package/src/components/chat/Icons.tsx +237 -0
  334. package/src/components/chat/ImageUploadQueue.tsx +77 -0
  335. package/src/components/chat/Input.tsx +156 -0
  336. package/src/components/chat/Markdown.tsx +144 -0
  337. package/src/components/chat/Messages.tsx +206 -0
  338. package/src/components/chat/Modal.tsx +220 -0
  339. package/src/components/chat/Popup.tsx +77 -0
  340. package/src/components/chat/PoweredByTag.tsx +42 -0
  341. package/src/components/chat/Sidebar.tsx +96 -0
  342. package/src/components/chat/Suggestion.tsx +29 -0
  343. package/src/components/chat/Suggestions.tsx +23 -0
  344. package/src/components/chat/Textarea.tsx +77 -0
  345. package/src/components/chat/Window.tsx +152 -0
  346. package/src/components/chat/index.tsx +11 -0
  347. package/src/components/chat/messages/AssistantMessage.tsx +118 -0
  348. package/src/components/chat/messages/ErrorMessage.tsx +59 -0
  349. package/src/components/chat/messages/ImageRenderer.tsx +37 -0
  350. package/src/components/chat/messages/LegacyRenderMessage.tsx +150 -0
  351. package/src/components/chat/messages/RenderMessage.tsx +61 -0
  352. package/src/components/chat/messages/UserMessage.tsx +46 -0
  353. package/src/components/chat/props.ts +353 -0
  354. package/src/components/dev-console/console.tsx +242 -0
  355. package/src/components/dev-console/icons.tsx +99 -0
  356. package/src/components/dev-console/index.tsx +2 -0
  357. package/src/components/dev-console/types.ts +7 -0
  358. package/src/components/dev-console/utils.ts +142 -0
  359. package/src/components/help-modal/icons.tsx +68 -0
  360. package/src/components/help-modal/index.tsx +1 -0
  361. package/src/components/help-modal/modal.tsx +101 -0
  362. package/src/components/index.ts +2 -0
  363. package/src/context/index.ts +1 -0
  364. package/src/css/animations.css +35 -0
  365. package/src/css/button.css +67 -0
  366. package/src/css/colors.css +78 -0
  367. package/src/css/console.css +166 -0
  368. package/src/css/crew.css +277 -0
  369. package/src/css/header.css +65 -0
  370. package/src/css/input.css +152 -0
  371. package/src/css/markdown.css +150 -0
  372. package/src/css/messages.css +244 -0
  373. package/src/css/panel.css +39 -0
  374. package/src/css/popup.css +22 -0
  375. package/src/css/sidebar.css +34 -0
  376. package/src/css/suggestions.css +43 -0
  377. package/src/css/window.css +60 -0
  378. package/src/hooks/index.ts +1 -0
  379. package/src/hooks/use-copilot-chat-suggestions.tsx +71 -0
  380. package/src/hooks/use-copy-to-clipboard.tsx +29 -0
  381. package/src/hooks/use-dark-mode.ts +10 -0
  382. package/src/hooks/use-push-to-talk.tsx +167 -0
  383. package/src/index.tsx +7 -0
  384. package/src/lib/utils.test.ts +7 -0
  385. package/src/lib/utils.ts +27 -0
  386. package/src/styles.css +14 -0
  387. package/src/types/css.ts +21 -0
  388. package/src/types/index.ts +2 -0
  389. package/src/types/suggestions.ts +7 -0
  390. package/src/v2/index.ts +1 -0
  391. package/src/v2/styles.css +1 -0
  392. package/tailwind.config.js +7 -0
  393. package/tsconfig.json +12 -0
  394. package/tsup.config.ts +11 -0
  395. package/typedoc.json +4 -0
@@ -0,0 +1,1195 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __defProps = Object.defineProperties;
5
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
7
+ var __getOwnPropNames = Object.getOwnPropertyNames;
8
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
9
+ var __getProtoOf = Object.getPrototypeOf;
10
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
11
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
12
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
13
+ var __spreadValues = (a, b) => {
14
+ for (var prop in b || (b = {}))
15
+ if (__hasOwnProp.call(b, prop))
16
+ __defNormalProp(a, prop, b[prop]);
17
+ if (__getOwnPropSymbols)
18
+ for (var prop of __getOwnPropSymbols(b)) {
19
+ if (__propIsEnum.call(b, prop))
20
+ __defNormalProp(a, prop, b[prop]);
21
+ }
22
+ return a;
23
+ };
24
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
25
+ var __objRest = (source, exclude) => {
26
+ var target = {};
27
+ for (var prop in source)
28
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
29
+ target[prop] = source[prop];
30
+ if (source != null && __getOwnPropSymbols)
31
+ for (var prop of __getOwnPropSymbols(source)) {
32
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
33
+ target[prop] = source[prop];
34
+ }
35
+ return target;
36
+ };
37
+ var __export = (target, all) => {
38
+ for (var name in all)
39
+ __defProp(target, name, { get: all[name], enumerable: true });
40
+ };
41
+ var __copyProps = (to, from, except, desc) => {
42
+ if (from && typeof from === "object" || typeof from === "function") {
43
+ for (let key of __getOwnPropNames(from))
44
+ if (!__hasOwnProp.call(to, key) && key !== except)
45
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
46
+ }
47
+ return to;
48
+ };
49
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
50
+ // If the importer is in node compatibility mode or this is not an ESM
51
+ // file that has been converted to a CommonJS file using a Babel-
52
+ // compatible transform (i.e. "__esModule" has not been set), then set
53
+ // "default" to the CommonJS "module.exports" for node compatibility.
54
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
55
+ mod
56
+ ));
57
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
58
+
59
+ // src/components/chat/Messages.tsx
60
+ var Messages_exports = {};
61
+ __export(Messages_exports, {
62
+ Messages: () => Messages,
63
+ useScrollToBottom: () => useScrollToBottom
64
+ });
65
+ module.exports = __toCommonJS(Messages_exports);
66
+ var import_react6 = require("react");
67
+
68
+ // src/components/chat/ChatContext.tsx
69
+ var import_react = __toESM(require("react"));
70
+
71
+ // src/components/chat/Icons.tsx
72
+ var import_jsx_runtime = require("react/jsx-runtime");
73
+ var CopyIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
74
+ "svg",
75
+ {
76
+ xmlns: "http://www.w3.org/2000/svg",
77
+ fill: "none",
78
+ viewBox: "0 0 24 24",
79
+ strokeWidth: "2",
80
+ stroke: "currentColor",
81
+ width: "16",
82
+ height: "16",
83
+ style: { minWidth: "16px", minHeight: "16px" },
84
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
85
+ "path",
86
+ {
87
+ strokeLinecap: "round",
88
+ strokeLinejoin: "round",
89
+ d: "M15.75 17.25v3.375c0 .621-.504 1.125-1.125 1.125h-9.75a1.125 1.125 0 01-1.125-1.125V7.875c0-.621.504-1.125 1.125-1.125H6.75a9.06 9.06 0 011.5.124m7.5 10.376h3.375c.621 0 1.125-.504 1.125-1.125V11.25c0-4.46-3.243-8.161-7.5-8.876a9.06 9.06 0 00-1.5-.124H9.375c-.621 0-1.125.504-1.125 1.125v3.5m7.5 10.375H9.375a1.125 1.125 0 01-1.125-1.125v-9.25m12 6.625v-1.875a3.375 3.375 0 00-3.375-3.375h-1.5a1.125 1.125 0 01-1.125-1.125v-1.5a3.375 3.375 0 00-3.375-3.375H9.75"
90
+ }
91
+ )
92
+ }
93
+ );
94
+ var DownloadIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
95
+ "svg",
96
+ {
97
+ xmlns: "http://www.w3.org/2000/svg",
98
+ fill: "none",
99
+ viewBox: "0 0 24 24",
100
+ strokeWidth: "2",
101
+ stroke: "currentColor",
102
+ width: "16",
103
+ height: "16",
104
+ style: { minWidth: "16px", minHeight: "16px" },
105
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
106
+ "path",
107
+ {
108
+ strokeLinecap: "round",
109
+ strokeLinejoin: "round",
110
+ d: "M3 16.5v2.25A2.25 2.25 0 005.25 21h13.5A2.25 2.25 0 0021 18.75V16.5M16.5 12L12 16.5m0 0L7.5 12m4.5 4.5V3"
111
+ }
112
+ )
113
+ }
114
+ );
115
+ var CheckIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
116
+ "svg",
117
+ {
118
+ xmlns: "http://www.w3.org/2000/svg",
119
+ fill: "none",
120
+ viewBox: "0 0 24 24",
121
+ strokeWidth: "2",
122
+ stroke: "currentColor",
123
+ width: "16",
124
+ height: "16",
125
+ style: { minWidth: "16px", minHeight: "16px" },
126
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M4.5 12.75l6 6 9-13.5" })
127
+ }
128
+ );
129
+
130
+ // src/components/chat/ChatContext.tsx
131
+ var import_jsx_runtime2 = require("react/jsx-runtime");
132
+ var ChatContext = import_react.default.createContext(void 0);
133
+ function useChatContext() {
134
+ const context = import_react.default.useContext(ChatContext);
135
+ if (context === void 0) {
136
+ throw new Error(
137
+ "Context not found. Did you forget to wrap your app in a <ChatContextProvider> component?"
138
+ );
139
+ }
140
+ return context;
141
+ }
142
+
143
+ // src/components/chat/Messages.tsx
144
+ var import_react_core = require("@copilotkit/react-core");
145
+
146
+ // src/components/chat/messages/UserMessage.tsx
147
+ var import_jsx_runtime3 = require("react/jsx-runtime");
148
+ var getTextContent = (content) => {
149
+ if (typeof content === "undefined") {
150
+ return void 0;
151
+ }
152
+ if (typeof content === "string") {
153
+ return content;
154
+ }
155
+ return content.map((part) => {
156
+ if (part.type === "text") {
157
+ return part.text;
158
+ }
159
+ return void 0;
160
+ }).filter((value) => typeof value === "string" && value.length > 0).join(" ").trim() || void 0;
161
+ };
162
+ var UserMessage = (props) => {
163
+ const { message, ImageRenderer: ImageRenderer2 } = props;
164
+ const isImageMessage = message && "image" in message && Boolean(message.image);
165
+ if (isImageMessage) {
166
+ const imageMessage = message;
167
+ const content2 = getTextContent(imageMessage == null ? void 0 : imageMessage.content);
168
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)("div", { className: "copilotKitMessage copilotKitUserMessage", children: /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(ImageRenderer2, { image: imageMessage.image, content: content2 }) });
169
+ }
170
+ const content = getTextContent(message == null ? void 0 : message.content);
171
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)("div", { className: "copilotKitMessage copilotKitUserMessage", children: content });
172
+ };
173
+
174
+ // src/components/chat/Markdown.tsx
175
+ var import_react3 = require("react");
176
+ var import_react_markdown = __toESM(require("react-markdown"));
177
+
178
+ // src/components/chat/CodeBlock.tsx
179
+ var import_react2 = require("react");
180
+ var import_react_syntax_highlighter = require("react-syntax-highlighter");
181
+
182
+ // src/hooks/use-copy-to-clipboard.tsx
183
+ var React2 = __toESM(require("react"));
184
+ function useCopyToClipboard({ timeout = 2e3 }) {
185
+ const [isCopied, setIsCopied] = React2.useState(false);
186
+ const copyToClipboard = (value) => {
187
+ var _a;
188
+ if (typeof window === "undefined" || !((_a = navigator.clipboard) == null ? void 0 : _a.writeText)) {
189
+ return;
190
+ }
191
+ if (!value) {
192
+ return;
193
+ }
194
+ navigator.clipboard.writeText(value).then(() => {
195
+ setIsCopied(true);
196
+ setTimeout(() => {
197
+ setIsCopied(false);
198
+ }, timeout);
199
+ });
200
+ };
201
+ return { isCopied, copyToClipboard };
202
+ }
203
+
204
+ // src/components/chat/CodeBlock.tsx
205
+ var import_jsx_runtime4 = require("react/jsx-runtime");
206
+ var programmingLanguages = {
207
+ javascript: ".js",
208
+ python: ".py",
209
+ java: ".java",
210
+ c: ".c",
211
+ cpp: ".cpp",
212
+ "c++": ".cpp",
213
+ "c#": ".cs",
214
+ ruby: ".rb",
215
+ php: ".php",
216
+ swift: ".swift",
217
+ "objective-c": ".m",
218
+ kotlin: ".kt",
219
+ typescript: ".ts",
220
+ go: ".go",
221
+ perl: ".pl",
222
+ rust: ".rs",
223
+ scala: ".scala",
224
+ haskell: ".hs",
225
+ lua: ".lua",
226
+ shell: ".sh",
227
+ sql: ".sql",
228
+ html: ".html",
229
+ css: ".css"
230
+ // add more file extensions here, make sure the key is same as language prop in CodeBlock.tsx component
231
+ };
232
+ var generateRandomString = (length, lowercase = false) => {
233
+ const chars = "ABCDEFGHJKLMNPQRSTUVWXY3456789";
234
+ let result = "";
235
+ for (let i = 0; i < length; i++) {
236
+ result += chars.charAt(Math.floor(Math.random() * chars.length));
237
+ }
238
+ return lowercase ? result.toLowerCase() : result;
239
+ };
240
+ var CodeBlock = (0, import_react2.memo)(({ language, value }) => {
241
+ const { isCopied, copyToClipboard } = useCopyToClipboard({ timeout: 2e3 });
242
+ const [SyntaxHighlighter, setSyntaxHighlighter] = (0, import_react2.useState)(
243
+ () => import_react_syntax_highlighter.Light
244
+ );
245
+ (0, import_react2.useEffect)(() => {
246
+ try {
247
+ new RegExp("(?<=#)\\w+");
248
+ setSyntaxHighlighter(() => import_react_syntax_highlighter.Prism);
249
+ } catch (e) {
250
+ setSyntaxHighlighter(() => import_react_syntax_highlighter.Light);
251
+ }
252
+ }, []);
253
+ const downloadAsFile = () => {
254
+ if (typeof window === "undefined") {
255
+ return;
256
+ }
257
+ const fileExtension = programmingLanguages[language] || ".file";
258
+ const suggestedFileName = `file-${generateRandomString(3, true)}${fileExtension}`;
259
+ const fileName = window.prompt("Enter file name", suggestedFileName);
260
+ if (!fileName) {
261
+ return;
262
+ }
263
+ const blob = new Blob([value], { type: "text/plain" });
264
+ const url = URL.createObjectURL(blob);
265
+ const link = document.createElement("a");
266
+ link.download = fileName;
267
+ link.href = url;
268
+ link.style.display = "none";
269
+ document.body.appendChild(link);
270
+ link.click();
271
+ document.body.removeChild(link);
272
+ URL.revokeObjectURL(url);
273
+ };
274
+ const onCopy = () => {
275
+ if (isCopied)
276
+ return;
277
+ copyToClipboard(value);
278
+ };
279
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "copilotKitCodeBlock", children: [
280
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "copilotKitCodeBlockToolbar", children: [
281
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("span", { className: "copilotKitCodeBlockToolbarLanguage", children: language }),
282
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "copilotKitCodeBlockToolbarButtons", children: [
283
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("button", { className: "copilotKitCodeBlockToolbarButton", onClick: downloadAsFile, children: DownloadIcon }),
284
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("button", { className: "copilotKitCodeBlockToolbarButton", onClick: onCopy, children: isCopied ? CheckIcon : CopyIcon })
285
+ ] })
286
+ ] }),
287
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
288
+ SyntaxHighlighter,
289
+ {
290
+ language,
291
+ style: highlightStyle,
292
+ PreTag: "div",
293
+ customStyle: {
294
+ margin: 0,
295
+ borderBottomLeftRadius: "0.375rem",
296
+ borderBottomRightRadius: "0.375rem"
297
+ },
298
+ children: value
299
+ }
300
+ )
301
+ ] });
302
+ });
303
+ CodeBlock.displayName = "CodeBlock";
304
+ var highlightStyle = {
305
+ 'pre[class*="language-"]': {
306
+ color: "#d4d4d4",
307
+ fontSize: "13px",
308
+ textShadow: "none",
309
+ fontFamily: 'Menlo, Monaco, Consolas, "Andale Mono", "Ubuntu Mono", "Courier New", monospace',
310
+ direction: "ltr",
311
+ textAlign: "left",
312
+ whiteSpace: "pre",
313
+ wordSpacing: "normal",
314
+ wordBreak: "normal",
315
+ lineHeight: "1.5",
316
+ MozTabSize: "4",
317
+ OTabSize: "4",
318
+ tabSize: "4",
319
+ WebkitHyphens: "none",
320
+ MozHyphens: "none",
321
+ msHyphens: "none",
322
+ hyphens: "none",
323
+ padding: "1em",
324
+ margin: ".5em 0",
325
+ overflow: "auto",
326
+ background: "#1e1e1e"
327
+ },
328
+ 'code[class*="language-"]': {
329
+ color: "#d4d4d4",
330
+ fontSize: "13px",
331
+ textShadow: "none",
332
+ fontFamily: 'Menlo, Monaco, Consolas, "Andale Mono", "Ubuntu Mono", "Courier New", monospace',
333
+ direction: "ltr",
334
+ textAlign: "left",
335
+ whiteSpace: "pre",
336
+ wordSpacing: "normal",
337
+ wordBreak: "normal",
338
+ lineHeight: "1.5",
339
+ MozTabSize: "4",
340
+ OTabSize: "4",
341
+ tabSize: "4",
342
+ WebkitHyphens: "none",
343
+ MozHyphens: "none",
344
+ msHyphens: "none",
345
+ hyphens: "none"
346
+ },
347
+ 'pre[class*="language-"]::selection': {
348
+ textShadow: "none",
349
+ background: "#264F78"
350
+ },
351
+ 'code[class*="language-"]::selection': {
352
+ textShadow: "none",
353
+ background: "#264F78"
354
+ },
355
+ 'pre[class*="language-"] *::selection': {
356
+ textShadow: "none",
357
+ background: "#264F78"
358
+ },
359
+ 'code[class*="language-"] *::selection': {
360
+ textShadow: "none",
361
+ background: "#264F78"
362
+ },
363
+ ':not(pre) > code[class*="language-"]': {
364
+ padding: ".1em .3em",
365
+ borderRadius: ".3em",
366
+ color: "#db4c69",
367
+ background: "#1e1e1e"
368
+ },
369
+ ".namespace": {
370
+ Opacity: ".7"
371
+ },
372
+ "doctype.doctype-tag": {
373
+ color: "#569CD6"
374
+ },
375
+ "doctype.name": {
376
+ color: "#9cdcfe"
377
+ },
378
+ comment: {
379
+ color: "#6a9955"
380
+ },
381
+ prolog: {
382
+ color: "#6a9955"
383
+ },
384
+ punctuation: {
385
+ color: "#d4d4d4"
386
+ },
387
+ ".language-html .language-css .token.punctuation": {
388
+ color: "#d4d4d4"
389
+ },
390
+ ".language-html .language-javascript .token.punctuation": {
391
+ color: "#d4d4d4"
392
+ },
393
+ property: {
394
+ color: "#9cdcfe"
395
+ },
396
+ tag: {
397
+ color: "#569cd6"
398
+ },
399
+ boolean: {
400
+ color: "#569cd6"
401
+ },
402
+ number: {
403
+ color: "#b5cea8"
404
+ },
405
+ constant: {
406
+ color: "#9cdcfe"
407
+ },
408
+ symbol: {
409
+ color: "#b5cea8"
410
+ },
411
+ inserted: {
412
+ color: "#b5cea8"
413
+ },
414
+ unit: {
415
+ color: "#b5cea8"
416
+ },
417
+ selector: {
418
+ color: "#d7ba7d"
419
+ },
420
+ "attr-name": {
421
+ color: "#9cdcfe"
422
+ },
423
+ string: {
424
+ color: "#ce9178"
425
+ },
426
+ char: {
427
+ color: "#ce9178"
428
+ },
429
+ builtin: {
430
+ color: "#ce9178"
431
+ },
432
+ deleted: {
433
+ color: "#ce9178"
434
+ },
435
+ ".language-css .token.string.url": {
436
+ textDecoration: "underline"
437
+ },
438
+ operator: {
439
+ color: "#d4d4d4"
440
+ },
441
+ entity: {
442
+ color: "#569cd6"
443
+ },
444
+ "operator.arrow": {
445
+ color: "#569CD6"
446
+ },
447
+ atrule: {
448
+ color: "#ce9178"
449
+ },
450
+ "atrule.rule": {
451
+ color: "#c586c0"
452
+ },
453
+ "atrule.url": {
454
+ color: "#9cdcfe"
455
+ },
456
+ "atrule.url.function": {
457
+ color: "#dcdcaa"
458
+ },
459
+ "atrule.url.punctuation": {
460
+ color: "#d4d4d4"
461
+ },
462
+ keyword: {
463
+ color: "#569CD6"
464
+ },
465
+ "keyword.module": {
466
+ color: "#c586c0"
467
+ },
468
+ "keyword.control-flow": {
469
+ color: "#c586c0"
470
+ },
471
+ function: {
472
+ color: "#dcdcaa"
473
+ },
474
+ "function.maybe-class-name": {
475
+ color: "#dcdcaa"
476
+ },
477
+ regex: {
478
+ color: "#d16969"
479
+ },
480
+ important: {
481
+ color: "#569cd6"
482
+ },
483
+ italic: {
484
+ fontStyle: "italic"
485
+ },
486
+ "class-name": {
487
+ color: "#4ec9b0"
488
+ },
489
+ "maybe-class-name": {
490
+ color: "#4ec9b0"
491
+ },
492
+ console: {
493
+ color: "#9cdcfe"
494
+ },
495
+ parameter: {
496
+ color: "#9cdcfe"
497
+ },
498
+ interpolation: {
499
+ color: "#9cdcfe"
500
+ },
501
+ "punctuation.interpolation-punctuation": {
502
+ color: "#569cd6"
503
+ },
504
+ variable: {
505
+ color: "#9cdcfe"
506
+ },
507
+ "imports.maybe-class-name": {
508
+ color: "#9cdcfe"
509
+ },
510
+ "exports.maybe-class-name": {
511
+ color: "#9cdcfe"
512
+ },
513
+ escape: {
514
+ color: "#d7ba7d"
515
+ },
516
+ "tag.punctuation": {
517
+ color: "#808080"
518
+ },
519
+ cdata: {
520
+ color: "#808080"
521
+ },
522
+ "attr-value": {
523
+ color: "#ce9178"
524
+ },
525
+ "attr-value.punctuation": {
526
+ color: "#ce9178"
527
+ },
528
+ "attr-value.punctuation.attr-equals": {
529
+ color: "#d4d4d4"
530
+ },
531
+ namespace: {
532
+ color: "#4ec9b0"
533
+ },
534
+ 'pre[class*="language-javascript"]': {
535
+ color: "#9cdcfe"
536
+ },
537
+ 'code[class*="language-javascript"]': {
538
+ color: "#9cdcfe"
539
+ },
540
+ 'pre[class*="language-jsx"]': {
541
+ color: "#9cdcfe"
542
+ },
543
+ 'code[class*="language-jsx"]': {
544
+ color: "#9cdcfe"
545
+ },
546
+ 'pre[class*="language-typescript"]': {
547
+ color: "#9cdcfe"
548
+ },
549
+ 'code[class*="language-typescript"]': {
550
+ color: "#9cdcfe"
551
+ },
552
+ 'pre[class*="language-tsx"]': {
553
+ color: "#9cdcfe"
554
+ },
555
+ 'code[class*="language-tsx"]': {
556
+ color: "#9cdcfe"
557
+ },
558
+ 'pre[class*="language-css"]': {
559
+ color: "#ce9178"
560
+ },
561
+ 'code[class*="language-css"]': {
562
+ color: "#ce9178"
563
+ },
564
+ 'pre[class*="language-html"]': {
565
+ color: "#d4d4d4"
566
+ },
567
+ 'code[class*="language-html"]': {
568
+ color: "#d4d4d4"
569
+ },
570
+ ".language-regex .token.anchor": {
571
+ color: "#dcdcaa"
572
+ },
573
+ ".language-html .token.punctuation": {
574
+ color: "#808080"
575
+ },
576
+ 'pre[class*="language-"] > code[class*="language-"]': {
577
+ position: "relative",
578
+ zIndex: "1"
579
+ },
580
+ ".line-highlight.line-highlight": {
581
+ background: "#f7ebc6",
582
+ boxShadow: "inset 5px 0 0 #f7d87c",
583
+ zIndex: "0"
584
+ }
585
+ };
586
+
587
+ // src/components/chat/Markdown.tsx
588
+ var import_remark_gfm = __toESM(require("remark-gfm"));
589
+ var import_remark_math = __toESM(require("remark-math"));
590
+ var import_rehype_raw = __toESM(require("rehype-raw"));
591
+ var import_jsx_runtime5 = require("react/jsx-runtime");
592
+ var defaultComponents = {
593
+ a(_a) {
594
+ var _b = _a, { children } = _b, props = __objRest(_b, ["children"]);
595
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("a", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { target: "_blank", rel: "noopener noreferrer", children }));
596
+ },
597
+ // @ts-expect-error -- inline
598
+ code(_c) {
599
+ var _d = _c, { children, className, inline } = _d, props = __objRest(_d, ["children", "className", "inline"]);
600
+ if (Array.isArray(children) && children.length) {
601
+ if (children[0] == "\u258D") {
602
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
603
+ "span",
604
+ {
605
+ style: {
606
+ animation: "pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite",
607
+ marginTop: "0.25rem"
608
+ },
609
+ children: "\u258D"
610
+ }
611
+ );
612
+ }
613
+ children[0] = (children == null ? void 0 : children[0]).replace("`\u258D`", "\u258D");
614
+ }
615
+ const match = /language-(\w+)/.exec(className || "");
616
+ const hasLanguage = match && match[1];
617
+ const content = String(children);
618
+ const hasNewlines = content.includes("\n");
619
+ const isInline = !hasLanguage && !hasNewlines;
620
+ if (isInline) {
621
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
622
+ "code",
623
+ __spreadProps(__spreadValues({
624
+ className: `copilotKitMarkdownElement copilotKitInlineCode ${className || ""}`
625
+ }, props), {
626
+ children
627
+ })
628
+ );
629
+ }
630
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
631
+ CodeBlock,
632
+ __spreadValues({
633
+ language: match && match[1] || "",
634
+ value: String(children).replace(/\n$/, "")
635
+ }, props),
636
+ Math.random()
637
+ );
638
+ },
639
+ h1: (_e) => {
640
+ var _f = _e, { children } = _f, props = __objRest(_f, ["children"]);
641
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("h1", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
642
+ },
643
+ h2: (_g) => {
644
+ var _h = _g, { children } = _h, props = __objRest(_h, ["children"]);
645
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("h2", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
646
+ },
647
+ h3: (_i) => {
648
+ var _j = _i, { children } = _j, props = __objRest(_j, ["children"]);
649
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("h3", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
650
+ },
651
+ h4: (_k) => {
652
+ var _l = _k, { children } = _l, props = __objRest(_l, ["children"]);
653
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("h4", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
654
+ },
655
+ h5: (_m) => {
656
+ var _n = _m, { children } = _n, props = __objRest(_n, ["children"]);
657
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("h5", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
658
+ },
659
+ h6: (_o) => {
660
+ var _p = _o, { children } = _p, props = __objRest(_p, ["children"]);
661
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("h6", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
662
+ },
663
+ p: (_q) => {
664
+ var _r = _q, { children } = _r, props = __objRest(_r, ["children"]);
665
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("p", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
666
+ },
667
+ pre: (_s) => {
668
+ var _t = _s, { children } = _t, props = __objRest(_t, ["children"]);
669
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("pre", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
670
+ },
671
+ blockquote: (_u) => {
672
+ var _v = _u, { children } = _v, props = __objRest(_v, ["children"]);
673
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("blockquote", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
674
+ },
675
+ ul: (_w) => {
676
+ var _x = _w, { children } = _x, props = __objRest(_x, ["children"]);
677
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("ul", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
678
+ },
679
+ li: (_y) => {
680
+ var _z = _y, { children } = _z, props = __objRest(_z, ["children"]);
681
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("li", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
682
+ }
683
+ };
684
+ var MemoizedReactMarkdown = (0, import_react3.memo)(
685
+ import_react_markdown.default,
686
+ (prevProps, nextProps) => prevProps.children === nextProps.children && prevProps.components === nextProps.components
687
+ );
688
+ var Markdown = ({ content, components }) => {
689
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("div", { className: "copilotKitMarkdown", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
690
+ MemoizedReactMarkdown,
691
+ {
692
+ components: __spreadValues(__spreadValues({}, defaultComponents), components),
693
+ remarkPlugins: [import_remark_gfm.default, [import_remark_math.default, { singleDollarTextMath: false }]],
694
+ rehypePlugins: [import_rehype_raw.default],
695
+ children: content
696
+ }
697
+ ) });
698
+ };
699
+
700
+ // src/components/chat/messages/AssistantMessage.tsx
701
+ var import_react4 = require("react");
702
+ var import_jsx_runtime6 = require("react/jsx-runtime");
703
+ var AssistantMessage = (props) => {
704
+ var _a;
705
+ const { icons, labels } = useChatContext();
706
+ const {
707
+ message,
708
+ isLoading,
709
+ onRegenerate,
710
+ onCopy,
711
+ onThumbsUp,
712
+ onThumbsDown,
713
+ isCurrentMessage,
714
+ feedback,
715
+ markdownTagRenderers
716
+ } = props;
717
+ const [copied, setCopied] = (0, import_react4.useState)(false);
718
+ const handleCopy = () => {
719
+ const content2 = (message == null ? void 0 : message.content) || "";
720
+ if (content2 && onCopy) {
721
+ navigator.clipboard.writeText(content2);
722
+ setCopied(true);
723
+ onCopy(content2);
724
+ setTimeout(() => setCopied(false), 2e3);
725
+ } else if (content2) {
726
+ navigator.clipboard.writeText(content2);
727
+ setCopied(true);
728
+ setTimeout(() => setCopied(false), 2e3);
729
+ }
730
+ };
731
+ const handleRegenerate = () => {
732
+ if (onRegenerate)
733
+ onRegenerate();
734
+ };
735
+ const handleThumbsUp = () => {
736
+ if (onThumbsUp && message) {
737
+ onThumbsUp(message);
738
+ }
739
+ };
740
+ const handleThumbsDown = () => {
741
+ if (onThumbsDown && message) {
742
+ onThumbsDown(message);
743
+ }
744
+ };
745
+ const LoadingIcon = () => /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("span", { children: icons.activityIcon });
746
+ const content = (message == null ? void 0 : message.content) || "";
747
+ const subComponent = (_a = message == null ? void 0 : message.generativeUI) == null ? void 0 : _a.call(message);
748
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(import_jsx_runtime6.Fragment, { children: [
749
+ content && /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { className: "copilotKitMessage copilotKitAssistantMessage", children: [
750
+ content && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(Markdown, { content, components: markdownTagRenderers }),
751
+ content && !isLoading && /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
752
+ "div",
753
+ {
754
+ className: `copilotKitMessageControls ${isCurrentMessage ? "currentMessage" : ""}`,
755
+ children: [
756
+ /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
757
+ "button",
758
+ {
759
+ className: "copilotKitMessageControlButton",
760
+ onClick: handleRegenerate,
761
+ "aria-label": labels.regenerateResponse,
762
+ title: labels.regenerateResponse,
763
+ children: icons.regenerateIcon
764
+ }
765
+ ),
766
+ /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
767
+ "button",
768
+ {
769
+ className: "copilotKitMessageControlButton",
770
+ onClick: handleCopy,
771
+ "aria-label": labels.copyToClipboard,
772
+ title: labels.copyToClipboard,
773
+ children: copied ? /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("span", { style: { fontSize: "10px", fontWeight: "bold" }, children: "\u2713" }) : icons.copyIcon
774
+ }
775
+ ),
776
+ onThumbsUp && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
777
+ "button",
778
+ {
779
+ className: `copilotKitMessageControlButton ${feedback === "thumbsUp" ? "active" : ""}`,
780
+ onClick: handleThumbsUp,
781
+ "aria-label": labels.thumbsUp,
782
+ title: labels.thumbsUp,
783
+ children: icons.thumbsUpIcon
784
+ }
785
+ ),
786
+ onThumbsDown && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
787
+ "button",
788
+ {
789
+ className: `copilotKitMessageControlButton ${feedback === "thumbsDown" ? "active" : ""}`,
790
+ onClick: handleThumbsDown,
791
+ "aria-label": labels.thumbsDown,
792
+ title: labels.thumbsDown,
793
+ children: icons.thumbsDownIcon
794
+ }
795
+ )
796
+ ]
797
+ }
798
+ )
799
+ ] }),
800
+ /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { marginBottom: "0.5rem" }, children: subComponent }),
801
+ isLoading && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(LoadingIcon, {})
802
+ ] });
803
+ };
804
+
805
+ // src/components/chat/messages/ImageRenderer.tsx
806
+ var import_react5 = require("react");
807
+ var import_jsx_runtime7 = require("react/jsx-runtime");
808
+ var ImageRenderer = ({ image, content, className = "" }) => {
809
+ const [imageError, setImageError] = (0, import_react5.useState)(false);
810
+ const imageSrc = `data:image/${image.format};base64,${image.bytes}`;
811
+ const altText = content || "User uploaded image";
812
+ const handleImageError = () => {
813
+ setImageError(true);
814
+ };
815
+ if (imageError) {
816
+ return /* @__PURE__ */ (0, import_jsx_runtime7.jsxs)("div", { className: `copilotKitImageRendering copilotKitImageRenderingError ${className}`, children: [
817
+ /* @__PURE__ */ (0, import_jsx_runtime7.jsx)("div", { className: "copilotKitImageRenderingErrorMessage", children: "Failed to load image" }),
818
+ content && /* @__PURE__ */ (0, import_jsx_runtime7.jsx)("div", { className: "copilotKitImageRenderingContent", children: content })
819
+ ] });
820
+ }
821
+ return /* @__PURE__ */ (0, import_jsx_runtime7.jsxs)("div", { className: `copilotKitImageRendering ${className}`, children: [
822
+ /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
823
+ "img",
824
+ {
825
+ src: imageSrc,
826
+ alt: altText,
827
+ className: "copilotKitImageRenderingImage",
828
+ onError: handleImageError
829
+ }
830
+ ),
831
+ content && /* @__PURE__ */ (0, import_jsx_runtime7.jsx)("div", { className: "copilotKitImageRenderingContent", children: content })
832
+ ] });
833
+ };
834
+
835
+ // src/components/chat/messages/RenderMessage.tsx
836
+ var import_jsx_runtime8 = require("react/jsx-runtime");
837
+ function RenderMessage(_a) {
838
+ var _b = _a, {
839
+ UserMessage: UserMessage2 = UserMessage,
840
+ AssistantMessage: AssistantMessage2 = AssistantMessage,
841
+ ImageRenderer: ImageRenderer2 = ImageRenderer
842
+ } = _b, props = __objRest(_b, [
843
+ "UserMessage",
844
+ "AssistantMessage",
845
+ "ImageRenderer"
846
+ ]);
847
+ var _a2;
848
+ const {
849
+ message,
850
+ messages,
851
+ inProgress,
852
+ index,
853
+ isCurrentMessage,
854
+ onRegenerate,
855
+ onCopy,
856
+ onThumbsUp,
857
+ onThumbsDown,
858
+ messageFeedback,
859
+ markdownTagRenderers
860
+ } = props;
861
+ switch (message.role) {
862
+ case "user":
863
+ return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
864
+ UserMessage2,
865
+ {
866
+ rawData: message,
867
+ "data-message-role": "user",
868
+ message,
869
+ ImageRenderer: ImageRenderer2
870
+ },
871
+ index
872
+ );
873
+ case "assistant":
874
+ return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
875
+ AssistantMessage2,
876
+ {
877
+ "data-message-role": "assistant",
878
+ subComponent: (_a2 = message.generativeUI) == null ? void 0 : _a2.call(message),
879
+ rawData: message,
880
+ message,
881
+ messages,
882
+ isLoading: inProgress && isCurrentMessage && !message.content,
883
+ isGenerating: inProgress && isCurrentMessage && !!message.content,
884
+ isCurrentMessage,
885
+ onRegenerate: () => onRegenerate == null ? void 0 : onRegenerate(message.id),
886
+ onCopy,
887
+ onThumbsUp,
888
+ onThumbsDown,
889
+ feedback: (messageFeedback == null ? void 0 : messageFeedback[message.id]) || null,
890
+ markdownTagRenderers,
891
+ ImageRenderer: ImageRenderer2
892
+ },
893
+ index
894
+ );
895
+ default:
896
+ return null;
897
+ }
898
+ }
899
+
900
+ // src/components/chat/messages/LegacyRenderMessage.tsx
901
+ var import_runtime_client_gql = require("@copilotkit/runtime-client-gql");
902
+ var import_jsx_runtime9 = require("react/jsx-runtime");
903
+ var LegacyRenderMessage = ({
904
+ message,
905
+ messages,
906
+ inProgress,
907
+ index,
908
+ isCurrentMessage,
909
+ actionResult,
910
+ AssistantMessage: AssistantMessage2,
911
+ UserMessage: UserMessage2,
912
+ ImageRenderer: ImageRenderer2,
913
+ onRegenerate,
914
+ onCopy,
915
+ onThumbsUp,
916
+ onThumbsDown,
917
+ markdownTagRenderers,
918
+ legacyProps
919
+ }) => {
920
+ var _a;
921
+ const {
922
+ RenderTextMessage,
923
+ RenderActionExecutionMessage,
924
+ RenderAgentStateMessage,
925
+ RenderResultMessage,
926
+ RenderImageMessage
927
+ } = legacyProps;
928
+ const deprecatedMessage = (_a = (0, import_runtime_client_gql.aguiToGQL)(message)[0]) != null ? _a : void 0;
929
+ if (deprecatedMessage.isTextMessage() && RenderTextMessage) {
930
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
931
+ RenderTextMessage,
932
+ {
933
+ message,
934
+ messages,
935
+ inProgress,
936
+ index,
937
+ isCurrentMessage,
938
+ AssistantMessage: AssistantMessage2,
939
+ UserMessage: UserMessage2,
940
+ onRegenerate,
941
+ onCopy,
942
+ onThumbsUp,
943
+ onThumbsDown,
944
+ markdownTagRenderers
945
+ }
946
+ );
947
+ }
948
+ if (deprecatedMessage.isActionExecutionMessage() && RenderActionExecutionMessage) {
949
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
950
+ RenderActionExecutionMessage,
951
+ {
952
+ messages,
953
+ message,
954
+ inProgress,
955
+ index,
956
+ isCurrentMessage,
957
+ actionResult,
958
+ AssistantMessage: AssistantMessage2,
959
+ UserMessage: UserMessage2
960
+ }
961
+ );
962
+ }
963
+ if (deprecatedMessage.isAgentStateMessage() && RenderAgentStateMessage) {
964
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
965
+ RenderAgentStateMessage,
966
+ {
967
+ messages,
968
+ message,
969
+ inProgress,
970
+ index,
971
+ isCurrentMessage,
972
+ AssistantMessage: AssistantMessage2,
973
+ UserMessage: UserMessage2
974
+ }
975
+ );
976
+ }
977
+ if (deprecatedMessage.isResultMessage() && RenderResultMessage) {
978
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
979
+ RenderResultMessage,
980
+ {
981
+ messages,
982
+ message,
983
+ inProgress,
984
+ index,
985
+ isCurrentMessage,
986
+ AssistantMessage: AssistantMessage2,
987
+ UserMessage: UserMessage2
988
+ }
989
+ );
990
+ }
991
+ if (deprecatedMessage.isImageMessage() && RenderImageMessage) {
992
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
993
+ RenderImageMessage,
994
+ {
995
+ messages,
996
+ message,
997
+ inProgress,
998
+ index,
999
+ isCurrentMessage,
1000
+ AssistantMessage: AssistantMessage2,
1001
+ UserMessage: UserMessage2
1002
+ }
1003
+ );
1004
+ }
1005
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
1006
+ RenderMessage,
1007
+ {
1008
+ messages,
1009
+ message,
1010
+ inProgress,
1011
+ index,
1012
+ isCurrentMessage,
1013
+ AssistantMessage: AssistantMessage2,
1014
+ UserMessage: UserMessage2,
1015
+ ImageRenderer: ImageRenderer2,
1016
+ onRegenerate,
1017
+ onCopy,
1018
+ onThumbsUp,
1019
+ onThumbsDown,
1020
+ markdownTagRenderers
1021
+ }
1022
+ );
1023
+ };
1024
+
1025
+ // src/components/chat/Messages.tsx
1026
+ var import_jsx_runtime10 = require("react/jsx-runtime");
1027
+ var Messages = ({
1028
+ inProgress,
1029
+ children,
1030
+ RenderMessage: RenderMessage2,
1031
+ AssistantMessage: AssistantMessage2,
1032
+ UserMessage: UserMessage2,
1033
+ ErrorMessage,
1034
+ ImageRenderer: ImageRenderer2,
1035
+ onRegenerate,
1036
+ onCopy,
1037
+ onThumbsUp,
1038
+ onThumbsDown,
1039
+ messageFeedback,
1040
+ markdownTagRenderers,
1041
+ chatError,
1042
+ // Legacy props
1043
+ RenderTextMessage,
1044
+ RenderActionExecutionMessage,
1045
+ RenderAgentStateMessage,
1046
+ RenderResultMessage,
1047
+ RenderImageMessage
1048
+ }) => {
1049
+ var _a;
1050
+ const { labels, icons } = useChatContext();
1051
+ const { messages: visibleMessages, interrupt } = (0, import_react_core.useCopilotChatInternal)();
1052
+ const initialMessages = (0, import_react6.useMemo)(() => makeInitialMessages(labels.initial), [labels.initial]);
1053
+ const messages = [...initialMessages, ...visibleMessages];
1054
+ const { messagesContainerRef, messagesEndRef } = useScrollToBottom(messages);
1055
+ const hasLegacyProps = !!(RenderTextMessage || RenderActionExecutionMessage || RenderAgentStateMessage || RenderResultMessage || RenderImageMessage);
1056
+ (0, import_react6.useEffect)(() => {
1057
+ if (hasLegacyProps) {
1058
+ console.warn(
1059
+ "[CopilotKit] Legacy message render props (RenderTextMessage, RenderActionExecutionMessage, etc.) are deprecated. Please use the unified 'RenderMessage' prop instead. See migration guide: https://docs.copilotkit.ai/migration/render-message"
1060
+ );
1061
+ }
1062
+ }, [hasLegacyProps]);
1063
+ const legacyProps = (0, import_react6.useMemo)(
1064
+ () => ({
1065
+ RenderTextMessage,
1066
+ RenderActionExecutionMessage,
1067
+ RenderAgentStateMessage,
1068
+ RenderResultMessage,
1069
+ RenderImageMessage
1070
+ }),
1071
+ [
1072
+ RenderTextMessage,
1073
+ RenderActionExecutionMessage,
1074
+ RenderAgentStateMessage,
1075
+ RenderResultMessage,
1076
+ RenderImageMessage
1077
+ ]
1078
+ );
1079
+ const MessageRenderer = hasLegacyProps ? (props) => /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(LegacyRenderMessage, __spreadProps(__spreadValues({}, props), { legacyProps })) : RenderMessage2;
1080
+ const LoadingIcon = () => /* @__PURE__ */ (0, import_jsx_runtime10.jsx)("span", { children: icons.activityIcon });
1081
+ return /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)("div", { className: "copilotKitMessages", ref: messagesContainerRef, children: [
1082
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)("div", { className: "copilotKitMessagesContainer", children: [
1083
+ messages.map((message, index) => {
1084
+ const isCurrentMessage = index === messages.length - 1;
1085
+ return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(
1086
+ MessageRenderer,
1087
+ {
1088
+ message,
1089
+ messages,
1090
+ inProgress,
1091
+ index,
1092
+ isCurrentMessage,
1093
+ AssistantMessage: AssistantMessage2,
1094
+ UserMessage: UserMessage2,
1095
+ ImageRenderer: ImageRenderer2,
1096
+ onRegenerate,
1097
+ onCopy,
1098
+ onThumbsUp,
1099
+ onThumbsDown,
1100
+ messageFeedback,
1101
+ markdownTagRenderers
1102
+ },
1103
+ index
1104
+ );
1105
+ }),
1106
+ ((_a = messages[messages.length - 1]) == null ? void 0 : _a.role) === "user" && inProgress && /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(LoadingIcon, {}),
1107
+ interrupt,
1108
+ chatError && ErrorMessage && /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(ErrorMessage, { error: chatError, isCurrentMessage: true })
1109
+ ] }),
1110
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsx)("footer", { className: "copilotKitMessagesFooter", ref: messagesEndRef, children })
1111
+ ] });
1112
+ };
1113
+ function makeInitialMessages(initial) {
1114
+ if (!initial)
1115
+ return [];
1116
+ if (Array.isArray(initial)) {
1117
+ return initial.map((message) => {
1118
+ return {
1119
+ id: message,
1120
+ role: "assistant",
1121
+ content: message
1122
+ };
1123
+ });
1124
+ }
1125
+ return [
1126
+ {
1127
+ id: initial,
1128
+ role: "assistant",
1129
+ content: initial
1130
+ }
1131
+ ];
1132
+ }
1133
+ function useScrollToBottom(messages) {
1134
+ const messagesEndRef = (0, import_react6.useRef)(null);
1135
+ const messagesContainerRef = (0, import_react6.useRef)(null);
1136
+ const isProgrammaticScrollRef = (0, import_react6.useRef)(false);
1137
+ const isUserScrollUpRef = (0, import_react6.useRef)(false);
1138
+ const scrollToBottom = () => {
1139
+ if (messagesContainerRef.current && messagesEndRef.current) {
1140
+ isProgrammaticScrollRef.current = true;
1141
+ messagesContainerRef.current.scrollTop = messagesContainerRef.current.scrollHeight;
1142
+ }
1143
+ };
1144
+ const handleScroll = () => {
1145
+ if (isProgrammaticScrollRef.current) {
1146
+ isProgrammaticScrollRef.current = false;
1147
+ return;
1148
+ }
1149
+ if (messagesContainerRef.current) {
1150
+ const { scrollTop, scrollHeight, clientHeight } = messagesContainerRef.current;
1151
+ isUserScrollUpRef.current = scrollTop + clientHeight < scrollHeight;
1152
+ }
1153
+ };
1154
+ (0, import_react6.useEffect)(() => {
1155
+ const container = messagesContainerRef.current;
1156
+ if (container) {
1157
+ container.addEventListener("scroll", handleScroll);
1158
+ }
1159
+ return () => {
1160
+ if (container) {
1161
+ container.removeEventListener("scroll", handleScroll);
1162
+ }
1163
+ };
1164
+ }, []);
1165
+ (0, import_react6.useEffect)(() => {
1166
+ const container = messagesContainerRef.current;
1167
+ if (!container) {
1168
+ return;
1169
+ }
1170
+ const mutationObserver = new MutationObserver(() => {
1171
+ if (!isUserScrollUpRef.current) {
1172
+ scrollToBottom();
1173
+ }
1174
+ });
1175
+ mutationObserver.observe(container, {
1176
+ childList: true,
1177
+ subtree: true,
1178
+ characterData: true
1179
+ });
1180
+ return () => {
1181
+ mutationObserver.disconnect();
1182
+ };
1183
+ }, []);
1184
+ (0, import_react6.useEffect)(() => {
1185
+ isUserScrollUpRef.current = false;
1186
+ scrollToBottom();
1187
+ }, [messages.filter((m) => m.role === "user").length]);
1188
+ return { messagesEndRef, messagesContainerRef };
1189
+ }
1190
+ // Annotate the CommonJS export names for ESM import in node:
1191
+ 0 && (module.exports = {
1192
+ Messages,
1193
+ useScrollToBottom
1194
+ });
1195
+ //# sourceMappingURL=Messages.js.map