@copilotkit/react-ui 1.51.5-next.0 → 1.51.5-next.2

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