@copilotkit/react-ui 1.5.8 → 1.5.10-next.0

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 (288) hide show
  1. package/CHANGELOG.md +45 -0
  2. package/dist/chunk-22XXW3F6.mjs +304 -0
  3. package/dist/chunk-22XXW3F6.mjs.map +1 -0
  4. package/dist/chunk-3E7HY2UN.mjs +85 -0
  5. package/dist/chunk-3E7HY2UN.mjs.map +1 -0
  6. package/dist/chunk-3XAXY2Z3.mjs +18 -0
  7. package/dist/chunk-3XAXY2Z3.mjs.map +1 -0
  8. package/dist/chunk-54JAUBUJ.mjs +26 -0
  9. package/dist/chunk-54JAUBUJ.mjs.map +1 -0
  10. package/dist/chunk-6INMITFA.mjs +18 -0
  11. package/dist/chunk-6INMITFA.mjs.map +1 -0
  12. package/dist/chunk-6RN2UVSW.mjs +30 -0
  13. package/dist/chunk-6RN2UVSW.mjs.map +1 -0
  14. package/dist/chunk-7II4YL7R.mjs +170 -0
  15. package/dist/chunk-7II4YL7R.mjs.map +1 -0
  16. package/dist/chunk-BH6PCAAL.mjs +81 -0
  17. package/dist/chunk-BH6PCAAL.mjs.map +1 -0
  18. package/dist/chunk-CBBFRI3Q.mjs +81 -0
  19. package/dist/chunk-CBBFRI3Q.mjs.map +1 -0
  20. package/dist/chunk-D2AA7PDR.mjs +21 -0
  21. package/dist/chunk-D2AA7PDR.mjs.map +1 -0
  22. package/dist/chunk-EFZPSZWO.mjs +1 -0
  23. package/dist/chunk-EFZPSZWO.mjs.map +1 -0
  24. package/dist/chunk-EMQEEXUB.mjs +97 -0
  25. package/dist/chunk-EMQEEXUB.mjs.map +1 -0
  26. package/dist/chunk-FZC7X5PK.mjs +262 -0
  27. package/dist/chunk-FZC7X5PK.mjs.map +1 -0
  28. package/dist/chunk-HZGELGAZ.mjs +232 -0
  29. package/dist/chunk-HZGELGAZ.mjs.map +1 -0
  30. package/dist/chunk-IU3WTXLQ.mjs +1 -0
  31. package/dist/chunk-IU3WTXLQ.mjs.map +1 -0
  32. package/dist/chunk-KXE2JCUH.mjs +1 -0
  33. package/dist/chunk-KXE2JCUH.mjs.map +1 -0
  34. package/dist/chunk-MMVDU6DF.mjs +1 -0
  35. package/dist/chunk-MMVDU6DF.mjs.map +1 -0
  36. package/dist/chunk-MRFF7GSQ.mjs +1 -0
  37. package/dist/chunk-MRFF7GSQ.mjs.map +1 -0
  38. package/dist/chunk-MRXNTQOX.mjs +59 -0
  39. package/dist/chunk-MRXNTQOX.mjs.map +1 -0
  40. package/dist/chunk-NLZW3ZOG.mjs +95 -0
  41. package/dist/chunk-NLZW3ZOG.mjs.map +1 -0
  42. package/dist/chunk-OTPAZXVR.mjs +92 -0
  43. package/dist/chunk-OTPAZXVR.mjs.map +1 -0
  44. package/dist/chunk-PNQVKBPN.mjs +146 -0
  45. package/dist/chunk-PNQVKBPN.mjs.map +1 -0
  46. package/dist/chunk-RJCZRKTV.mjs +106 -0
  47. package/dist/chunk-RJCZRKTV.mjs.map +1 -0
  48. package/dist/chunk-RQNJNK2W.mjs +25 -0
  49. package/dist/chunk-RQNJNK2W.mjs.map +1 -0
  50. package/dist/chunk-RU73BEZM.mjs +41 -0
  51. package/dist/chunk-RU73BEZM.mjs.map +1 -0
  52. package/dist/chunk-S5MBUNGN.mjs +140 -0
  53. package/dist/chunk-S5MBUNGN.mjs.map +1 -0
  54. package/dist/chunk-T26KLXLH.mjs +1 -0
  55. package/dist/chunk-T26KLXLH.mjs.map +1 -0
  56. package/dist/chunk-TI7SY2RI.mjs +164 -0
  57. package/dist/chunk-TI7SY2RI.mjs.map +1 -0
  58. package/dist/chunk-UPTB2MVO.mjs +395 -0
  59. package/dist/chunk-UPTB2MVO.mjs.map +1 -0
  60. package/dist/chunk-V7W6IM2V.mjs +1 -0
  61. package/dist/chunk-V7W6IM2V.mjs.map +1 -0
  62. package/dist/chunk-VEC45H6Q.mjs +18 -0
  63. package/dist/chunk-VEC45H6Q.mjs.map +1 -0
  64. package/dist/chunk-WB3YULQ4.mjs +1 -0
  65. package/dist/chunk-WB3YULQ4.mjs.map +1 -0
  66. package/dist/chunk-YAGE7RCE.mjs +118 -0
  67. package/dist/chunk-YAGE7RCE.mjs.map +1 -0
  68. package/dist/chunk-YQ3D5IQV.mjs +75 -0
  69. package/dist/chunk-YQ3D5IQV.mjs.map +1 -0
  70. package/dist/chunk-YQFVRDNC.mjs +53 -0
  71. package/dist/chunk-YQFVRDNC.mjs.map +1 -0
  72. package/dist/chunk-Z2UZSN3K.mjs +29 -0
  73. package/dist/chunk-Z2UZSN3K.mjs.map +1 -0
  74. package/dist/chunk-ZABXREBH.mjs +65 -0
  75. package/dist/chunk-ZABXREBH.mjs.map +1 -0
  76. package/dist/components/chat/Button.d.ts +7 -0
  77. package/dist/components/chat/Button.js +71 -0
  78. package/dist/components/chat/Button.js.map +1 -0
  79. package/dist/components/chat/Button.mjs +10 -0
  80. package/dist/components/chat/Button.mjs.map +1 -0
  81. package/dist/components/chat/Chat.d.ts +148 -0
  82. package/dist/components/chat/Chat.js +2427 -0
  83. package/dist/components/chat/Chat.js.map +1 -0
  84. package/dist/components/chat/Chat.mjs +34 -0
  85. package/dist/components/chat/Chat.mjs.map +1 -0
  86. package/dist/components/chat/ChatContext.d.ts +105 -0
  87. package/dist/components/chat/ChatContext.js +279 -0
  88. package/dist/components/chat/ChatContext.js.map +1 -0
  89. package/dist/components/chat/ChatContext.mjs +13 -0
  90. package/dist/components/chat/ChatContext.mjs.map +1 -0
  91. package/dist/components/chat/CodeBlock.d.ts +14 -0
  92. package/dist/components/chat/CodeBlock.js +523 -0
  93. package/dist/components/chat/CodeBlock.js.map +1 -0
  94. package/dist/components/chat/CodeBlock.mjs +14 -0
  95. package/dist/components/chat/CodeBlock.mjs.map +1 -0
  96. package/dist/components/chat/Header.d.ts +7 -0
  97. package/dist/components/chat/Header.js +64 -0
  98. package/dist/components/chat/Header.js.map +1 -0
  99. package/dist/components/chat/Header.mjs +10 -0
  100. package/dist/components/chat/Header.mjs.map +1 -0
  101. package/dist/components/chat/Icons.d.ts +18 -0
  102. package/dist/components/chat/Icons.js +321 -0
  103. package/dist/components/chat/Icons.js.map +1 -0
  104. package/dist/components/chat/Icons.mjs +32 -0
  105. package/dist/components/chat/Icons.mjs.map +1 -0
  106. package/dist/components/chat/Input.d.ts +7 -0
  107. package/dist/components/chat/Input.js +324 -0
  108. package/dist/components/chat/Input.js.map +1 -0
  109. package/dist/components/chat/Input.mjs +12 -0
  110. package/dist/components/chat/Input.mjs.map +1 -0
  111. package/dist/components/chat/Markdown.d.ts +8 -0
  112. package/dist/components/chat/Markdown.js +583 -0
  113. package/dist/components/chat/Markdown.js.map +1 -0
  114. package/dist/components/chat/Markdown.mjs +11 -0
  115. package/dist/components/chat/Markdown.mjs.map +1 -0
  116. package/dist/components/chat/Messages.d.ts +12 -0
  117. package/dist/components/chat/Messages.js +217 -0
  118. package/dist/components/chat/Messages.js.map +1 -0
  119. package/dist/components/chat/Messages.mjs +12 -0
  120. package/dist/components/chat/Messages.mjs.map +1 -0
  121. package/dist/components/chat/Modal.d.ts +51 -0
  122. package/dist/components/chat/Modal.js +2626 -0
  123. package/dist/components/chat/Modal.js.map +1 -0
  124. package/dist/components/chat/Modal.mjs +34 -0
  125. package/dist/components/chat/Modal.mjs.map +1 -0
  126. package/dist/components/chat/Popup.d.ts +13 -0
  127. package/dist/components/chat/Popup.js +2637 -0
  128. package/dist/components/chat/Popup.js.map +1 -0
  129. package/dist/components/chat/Popup.mjs +35 -0
  130. package/dist/components/chat/Popup.mjs.map +1 -0
  131. package/dist/components/chat/Response.d.ts +7 -0
  132. package/dist/components/chat/Response.js +64 -0
  133. package/dist/components/chat/Response.js.map +1 -0
  134. package/dist/components/chat/Response.mjs +10 -0
  135. package/dist/components/chat/Response.mjs.map +1 -0
  136. package/dist/components/chat/Sidebar.d.ts +13 -0
  137. package/dist/components/chat/Sidebar.js +2646 -0
  138. package/dist/components/chat/Sidebar.js.map +1 -0
  139. package/dist/components/chat/Sidebar.mjs +35 -0
  140. package/dist/components/chat/Sidebar.mjs.map +1 -0
  141. package/dist/components/chat/Suggestion.d.ts +14 -0
  142. package/dist/components/chat/Suggestion.js +181 -0
  143. package/dist/components/chat/Suggestion.js.map +1 -0
  144. package/dist/components/chat/Suggestion.mjs +11 -0
  145. package/dist/components/chat/Suggestion.mjs.map +1 -0
  146. package/dist/components/chat/Textarea.d.ts +13 -0
  147. package/dist/components/chat/Textarea.js +73 -0
  148. package/dist/components/chat/Textarea.js.map +1 -0
  149. package/dist/components/chat/Textarea.mjs +8 -0
  150. package/dist/components/chat/Textarea.mjs.map +1 -0
  151. package/dist/components/chat/Window.d.ts +7 -0
  152. package/dist/components/chat/Window.js +164 -0
  153. package/dist/components/chat/Window.js.map +1 -0
  154. package/dist/components/chat/Window.mjs +10 -0
  155. package/dist/components/chat/Window.mjs.map +1 -0
  156. package/dist/components/chat/index.d.ts +11 -0
  157. package/dist/components/chat/index.js +2661 -0
  158. package/dist/components/chat/index.js.map +1 -0
  159. package/dist/components/chat/index.mjs +47 -0
  160. package/dist/components/chat/index.mjs.map +1 -0
  161. package/dist/components/chat/messages/RenderActionExecutionMessage.d.ts +7 -0
  162. package/dist/components/chat/messages/RenderActionExecutionMessage.js +131 -0
  163. package/dist/components/chat/messages/RenderActionExecutionMessage.js.map +1 -0
  164. package/dist/components/chat/messages/RenderActionExecutionMessage.mjs +10 -0
  165. package/dist/components/chat/messages/RenderActionExecutionMessage.mjs.map +1 -0
  166. package/dist/components/chat/messages/RenderAgentStateMessage.d.ts +7 -0
  167. package/dist/components/chat/messages/RenderAgentStateMessage.js +111 -0
  168. package/dist/components/chat/messages/RenderAgentStateMessage.js.map +1 -0
  169. package/dist/components/chat/messages/RenderAgentStateMessage.mjs +10 -0
  170. package/dist/components/chat/messages/RenderAgentStateMessage.mjs.map +1 -0
  171. package/dist/components/chat/messages/RenderResultMessage.d.ts +7 -0
  172. package/dist/components/chat/messages/RenderResultMessage.js +64 -0
  173. package/dist/components/chat/messages/RenderResultMessage.js.map +1 -0
  174. package/dist/components/chat/messages/RenderResultMessage.mjs +10 -0
  175. package/dist/components/chat/messages/RenderResultMessage.mjs.map +1 -0
  176. package/dist/components/chat/messages/RenderTextMessage.d.ts +7 -0
  177. package/dist/components/chat/messages/RenderTextMessage.js +629 -0
  178. package/dist/components/chat/messages/RenderTextMessage.js.map +1 -0
  179. package/dist/components/chat/messages/RenderTextMessage.mjs +13 -0
  180. package/dist/components/chat/messages/RenderTextMessage.mjs.map +1 -0
  181. package/dist/components/chat/props.d.ts +46 -0
  182. package/dist/components/chat/props.js +19 -0
  183. package/dist/components/chat/props.js.map +1 -0
  184. package/dist/components/chat/props.mjs +2 -0
  185. package/dist/components/chat/props.mjs.map +1 -0
  186. package/dist/components/dev-console/console.d.ts +10 -0
  187. package/dist/components/dev-console/console.js +720 -0
  188. package/dist/components/dev-console/console.js.map +1 -0
  189. package/dist/components/dev-console/console.mjs +17 -0
  190. package/dist/components/dev-console/console.mjs.map +1 -0
  191. package/dist/components/dev-console/icons.d.ts +9 -0
  192. package/dist/components/dev-console/icons.js +120 -0
  193. package/dist/components/dev-console/icons.js.map +1 -0
  194. package/dist/components/dev-console/icons.mjs +16 -0
  195. package/dist/components/dev-console/icons.mjs.map +1 -0
  196. package/dist/components/dev-console/index.d.ts +5 -0
  197. package/dist/components/dev-console/index.js +720 -0
  198. package/dist/components/dev-console/index.js.map +1 -0
  199. package/dist/components/dev-console/index.mjs +18 -0
  200. package/dist/components/dev-console/index.mjs.map +1 -0
  201. package/dist/components/dev-console/types.d.ts +9 -0
  202. package/dist/components/dev-console/types.js +19 -0
  203. package/dist/components/dev-console/types.js.map +1 -0
  204. package/dist/components/dev-console/types.mjs +1 -0
  205. package/dist/components/dev-console/types.mjs.map +1 -0
  206. package/dist/components/dev-console/utils.d.ts +10 -0
  207. package/dist/components/dev-console/utils.js +188 -0
  208. package/dist/components/dev-console/utils.js.map +1 -0
  209. package/dist/components/dev-console/utils.mjs +16 -0
  210. package/dist/components/dev-console/utils.mjs.map +1 -0
  211. package/dist/components/help-modal/icons.d.ts +9 -0
  212. package/dist/components/help-modal/icons.js +107 -0
  213. package/dist/components/help-modal/icons.js.map +1 -0
  214. package/dist/components/help-modal/icons.mjs +12 -0
  215. package/dist/components/help-modal/icons.mjs.map +1 -0
  216. package/dist/components/help-modal/index.d.ts +2 -0
  217. package/dist/components/help-modal/index.js +255 -0
  218. package/dist/components/help-modal/index.js.map +1 -0
  219. package/dist/components/help-modal/index.mjs +10 -0
  220. package/dist/components/help-modal/index.mjs.map +1 -0
  221. package/dist/components/help-modal/modal.d.ts +5 -0
  222. package/dist/components/help-modal/modal.js +253 -0
  223. package/dist/components/help-modal/modal.js.map +1 -0
  224. package/dist/components/help-modal/modal.mjs +9 -0
  225. package/dist/components/help-modal/modal.mjs.map +1 -0
  226. package/dist/components/index.d.ts +14 -0
  227. package/dist/components/index.js +2665 -0
  228. package/dist/components/index.js.map +1 -0
  229. package/dist/components/index.mjs +54 -0
  230. package/dist/components/index.mjs.map +1 -0
  231. package/dist/context/index.d.ts +2 -0
  232. package/dist/context/index.js +19 -0
  233. package/dist/context/index.js.map +1 -0
  234. package/dist/context/index.mjs +2 -0
  235. package/dist/context/index.mjs.map +1 -0
  236. package/dist/hooks/index.d.ts +1 -0
  237. package/dist/hooks/index.js +55 -0
  238. package/dist/hooks/index.js.map +1 -0
  239. package/dist/hooks/index.mjs +9 -0
  240. package/dist/hooks/index.mjs.map +1 -0
  241. package/dist/hooks/use-copilot-chat-suggestions.d.ts +83 -0
  242. package/dist/hooks/use-copilot-chat-suggestions.js +53 -0
  243. package/dist/hooks/use-copilot-chat-suggestions.js.map +1 -0
  244. package/dist/hooks/use-copilot-chat-suggestions.mjs +8 -0
  245. package/dist/hooks/use-copilot-chat-suggestions.mjs.map +1 -0
  246. package/dist/hooks/use-copy-to-clipboard.d.ts +9 -0
  247. package/dist/hooks/use-copy-to-clipboard.js +60 -0
  248. package/dist/hooks/use-copy-to-clipboard.js.map +1 -0
  249. package/dist/hooks/use-copy-to-clipboard.mjs +8 -0
  250. package/dist/hooks/use-copy-to-clipboard.mjs.map +1 -0
  251. package/dist/hooks/use-push-to-talk.d.ts +19 -0
  252. package/dist/hooks/use-push-to-talk.js +195 -0
  253. package/dist/hooks/use-push-to-talk.js.map +1 -0
  254. package/dist/hooks/use-push-to-talk.mjs +12 -0
  255. package/dist/hooks/use-push-to-talk.mjs.map +1 -0
  256. package/dist/index.css +751 -0
  257. package/dist/index.css.map +1 -0
  258. package/dist/index.d.ts +16 -0
  259. package/dist/index.js +2693 -0
  260. package/dist/index.js.map +1 -0
  261. package/dist/index.mjs +62 -0
  262. package/dist/index.mjs.map +1 -0
  263. package/dist/lib/utils.d.ts +4 -0
  264. package/dist/lib/utils.js +76 -0
  265. package/dist/lib/utils.js.map +1 -0
  266. package/dist/lib/utils.mjs +34 -0
  267. package/dist/lib/utils.mjs.map +1 -0
  268. package/dist/lib/utils.test.d.ts +2 -0
  269. package/dist/lib/utils.test.js +9 -0
  270. package/dist/lib/utils.test.js.map +1 -0
  271. package/dist/lib/utils.test.mjs +7 -0
  272. package/dist/lib/utils.test.mjs.map +1 -0
  273. package/dist/types/css.d.ts +16 -0
  274. package/dist/types/css.js +19 -0
  275. package/dist/types/css.js.map +1 -0
  276. package/dist/types/css.mjs +1 -0
  277. package/dist/types/css.mjs.map +1 -0
  278. package/dist/types/index.d.ts +2 -0
  279. package/dist/types/index.js +19 -0
  280. package/dist/types/index.js.map +1 -0
  281. package/dist/types/index.mjs +2 -0
  282. package/dist/types/index.mjs.map +1 -0
  283. package/dist/types/suggestions.d.ts +8 -0
  284. package/dist/types/suggestions.js +19 -0
  285. package/dist/types/suggestions.js.map +1 -0
  286. package/dist/types/suggestions.mjs +1 -0
  287. package/dist/types/suggestions.mjs.map +1 -0
  288. package/package.json +4 -4
package/dist/index.js ADDED
@@ -0,0 +1,2693 @@
1
+ "use strict";
2
+ "use client";
3
+ var __create = Object.create;
4
+ var __defProp = Object.defineProperty;
5
+ var __defProps = Object.defineProperties;
6
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
7
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
8
+ var __getOwnPropNames = Object.getOwnPropertyNames;
9
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
10
+ var __getProtoOf = Object.getPrototypeOf;
11
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
12
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
13
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
14
+ var __spreadValues = (a, b) => {
15
+ for (var prop in b || (b = {}))
16
+ if (__hasOwnProp.call(b, prop))
17
+ __defNormalProp(a, prop, b[prop]);
18
+ if (__getOwnPropSymbols)
19
+ for (var prop of __getOwnPropSymbols(b)) {
20
+ if (__propIsEnum.call(b, prop))
21
+ __defNormalProp(a, prop, b[prop]);
22
+ }
23
+ return a;
24
+ };
25
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
26
+ var __objRest = (source, exclude) => {
27
+ var target = {};
28
+ for (var prop in source)
29
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
30
+ target[prop] = source[prop];
31
+ if (source != null && __getOwnPropSymbols)
32
+ for (var prop of __getOwnPropSymbols(source)) {
33
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
34
+ target[prop] = source[prop];
35
+ }
36
+ return target;
37
+ };
38
+ var __export = (target, all) => {
39
+ for (var name in all)
40
+ __defProp(target, name, { get: all[name], enumerable: true });
41
+ };
42
+ var __copyProps = (to, from, except, desc) => {
43
+ if (from && typeof from === "object" || typeof from === "function") {
44
+ for (let key of __getOwnPropNames(from))
45
+ if (!__hasOwnProp.call(to, key) && key !== except)
46
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
47
+ }
48
+ return to;
49
+ };
50
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
51
+ // If the importer is in node compatibility mode or this is not an ESM
52
+ // file that has been converted to a CommonJS file using a Babel-
53
+ // compatible transform (i.e. "__esModule" has not been set), then set
54
+ // "default" to the CommonJS "module.exports" for node compatibility.
55
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
56
+ mod
57
+ ));
58
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
59
+ var __async = (__this, __arguments, generator) => {
60
+ return new Promise((resolve, reject) => {
61
+ var fulfilled = (value) => {
62
+ try {
63
+ step(generator.next(value));
64
+ } catch (e) {
65
+ reject(e);
66
+ }
67
+ };
68
+ var rejected = (value) => {
69
+ try {
70
+ step(generator.throw(value));
71
+ } catch (e) {
72
+ reject(e);
73
+ }
74
+ };
75
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
76
+ step((generator = generator.apply(__this, __arguments)).next());
77
+ });
78
+ };
79
+
80
+ // src/index.tsx
81
+ var src_exports = {};
82
+ __export(src_exports, {
83
+ CopilotChat: () => CopilotChat,
84
+ CopilotDevConsole: () => CopilotDevConsole,
85
+ CopilotPopup: () => CopilotPopup,
86
+ CopilotSidebar: () => CopilotSidebar,
87
+ shouldShowDevConsole: () => shouldShowDevConsole,
88
+ useChatContext: () => useChatContext,
89
+ useCopilotChatSuggestions: () => useCopilotChatSuggestions
90
+ });
91
+ module.exports = __toCommonJS(src_exports);
92
+
93
+ // src/components/chat/Modal.tsx
94
+ var import_react13 = __toESM(require("react"));
95
+
96
+ // src/components/chat/ChatContext.tsx
97
+ var import_react = __toESM(require("react"));
98
+
99
+ // src/components/chat/Icons.tsx
100
+ var import_jsx_runtime = require("react/jsx-runtime");
101
+ var OpenIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
102
+ "svg",
103
+ {
104
+ xmlns: "http://www.w3.org/2000/svg",
105
+ viewBox: "0 0 24 24",
106
+ fill: "currentColor",
107
+ width: "24",
108
+ height: "24",
109
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { transform: "translate(24, 0) scale(-1, 1)", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
110
+ "path",
111
+ {
112
+ fillRule: "evenodd",
113
+ d: "M5.337 21.718a6.707 6.707 0 01-.533-.074.75.75 0 01-.44-1.223 3.73 3.73 0 00.814-1.686c.023-.115-.022-.317-.254-.543C3.274 16.587 2.25 14.41 2.25 12c0-5.03 4.428-9 9.75-9s9.75 3.97 9.75 9c0 5.03-4.428 9-9.75 9-.833 0-1.643-.097-2.417-.279a6.721 6.721 0 01-4.246.997z",
114
+ clipRule: "evenodd"
115
+ }
116
+ ) })
117
+ }
118
+ );
119
+ var CloseIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
120
+ "svg",
121
+ {
122
+ xmlns: "http://www.w3.org/2000/svg",
123
+ fill: "none",
124
+ viewBox: "0 0 24 24",
125
+ strokeWidth: "1.5",
126
+ stroke: "currentColor",
127
+ width: "24",
128
+ height: "24",
129
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M19.5 8.25l-7.5 7.5-7.5-7.5" })
130
+ }
131
+ );
132
+ var HeaderCloseIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
133
+ "svg",
134
+ {
135
+ xmlns: "http://www.w3.org/2000/svg",
136
+ fill: "none",
137
+ viewBox: "0 0 24 24",
138
+ strokeWidth: "1.5",
139
+ stroke: "currentColor",
140
+ width: "24",
141
+ height: "24",
142
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M6 18L18 6M6 6l12 12" })
143
+ }
144
+ );
145
+ var SendIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
146
+ "svg",
147
+ {
148
+ xmlns: "http://www.w3.org/2000/svg",
149
+ fill: "none",
150
+ viewBox: "0 0 24 24",
151
+ strokeWidth: 1.5,
152
+ stroke: "currentColor",
153
+ width: "24",
154
+ height: "24",
155
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
156
+ "path",
157
+ {
158
+ strokeLinecap: "round",
159
+ strokeLinejoin: "round",
160
+ d: "M6 12L3.269 3.126A59.768 59.768 0 0121.485 12 59.77 59.77 0 013.27 20.876L5.999 12zm0 0h7.5"
161
+ }
162
+ )
163
+ }
164
+ );
165
+ var SpinnerIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
166
+ "svg",
167
+ {
168
+ style: {
169
+ animation: "copilotKitSpinAnimation 1s linear infinite",
170
+ color: "rgb(107 114 128)"
171
+ },
172
+ width: "24",
173
+ height: "24",
174
+ xmlns: "http://www.w3.org/2000/svg",
175
+ fill: "none",
176
+ viewBox: "0 0 24 24",
177
+ children: [
178
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
179
+ "circle",
180
+ {
181
+ style: { opacity: 0.25 },
182
+ cx: "12",
183
+ cy: "12",
184
+ r: "10",
185
+ stroke: "currentColor",
186
+ strokeWidth: "4"
187
+ }
188
+ ),
189
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
190
+ "path",
191
+ {
192
+ style: { opacity: 0.75 },
193
+ fill: "currentColor",
194
+ d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
195
+ }
196
+ )
197
+ ]
198
+ }
199
+ );
200
+ var SmallSpinnerIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
201
+ "svg",
202
+ {
203
+ style: {
204
+ animation: "copilotKitSpinAnimation 1s linear infinite"
205
+ },
206
+ width: "13",
207
+ height: "13",
208
+ xmlns: "http://www.w3.org/2000/svg",
209
+ fill: "none",
210
+ viewBox: "0 0 24 24",
211
+ children: [
212
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
213
+ "circle",
214
+ {
215
+ style: { opacity: 0.25 },
216
+ cx: "12",
217
+ cy: "12",
218
+ r: "10",
219
+ stroke: "currentColor",
220
+ strokeWidth: "4"
221
+ }
222
+ ),
223
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
224
+ "path",
225
+ {
226
+ style: { opacity: 0.75 },
227
+ fill: "currentColor",
228
+ d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
229
+ }
230
+ )
231
+ ]
232
+ }
233
+ );
234
+ var ActivityIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
235
+ "svg",
236
+ {
237
+ style: {
238
+ display: "inline-block",
239
+ marginLeft: "0.25rem",
240
+ marginRight: "0.25rem"
241
+ },
242
+ height: "24",
243
+ width: "24",
244
+ viewBox: "0 0 27 27",
245
+ xmlns: "http://www.w3.org/2000/svg",
246
+ fill: "currentColor",
247
+ children: [
248
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("circle", { className: "copilotKitActivityDot1", cx: "4", cy: "12", r: "3" }),
249
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("circle", { className: "copilotKitActivityDot1 copilotKitActivityDot2", cx: "12", cy: "12", r: "3" }),
250
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("circle", { className: "copilotKitActivityDot1 copilotKitActivityDot3", cx: "20", cy: "12", r: "3" })
251
+ ]
252
+ }
253
+ );
254
+ function CheckIcon(_a) {
255
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
256
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
257
+ "svg",
258
+ __spreadProps(__spreadValues({
259
+ xmlns: "http://www.w3.org/2000/svg",
260
+ viewBox: "0 0 256 256",
261
+ fill: "currentColor",
262
+ style: { height: "1rem", width: "1rem" },
263
+ className
264
+ }, props), {
265
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { d: "m229.66 77.66-128 128a8 8 0 0 1-11.32 0l-56-56a8 8 0 0 1 11.32-11.32L96 188.69 218.34 66.34a8 8 0 0 1 11.32 11.32Z" })
266
+ })
267
+ );
268
+ }
269
+ function DownloadIcon(_a) {
270
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
271
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
272
+ "svg",
273
+ __spreadProps(__spreadValues({
274
+ xmlns: "http://www.w3.org/2000/svg",
275
+ viewBox: "0 0 256 256",
276
+ fill: "currentColor",
277
+ style: { height: "1rem", width: "1rem" },
278
+ className
279
+ }, props), {
280
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { d: "M224 152v56a16 16 0 0 1-16 16H48a16 16 0 0 1-16-16v-56a8 8 0 0 1 16 0v56h160v-56a8 8 0 0 1 16 0Zm-101.66 5.66a8 8 0 0 0 11.32 0l40-40a8 8 0 0 0-11.32-11.32L136 132.69V40a8 8 0 0 0-16 0v92.69l-26.34-26.35a8 8 0 0 0-11.32 11.32Z" })
281
+ })
282
+ );
283
+ }
284
+ function CopyIcon(_a) {
285
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
286
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
287
+ "svg",
288
+ __spreadProps(__spreadValues({
289
+ xmlns: "http://www.w3.org/2000/svg",
290
+ viewBox: "0 0 256 256",
291
+ fill: "currentColor",
292
+ style: { height: "1rem", width: "1rem" },
293
+ className
294
+ }, props), {
295
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { d: "M216 32H88a8 8 0 0 0-8 8v40H40a8 8 0 0 0-8 8v128a8 8 0 0 0 8 8h128a8 8 0 0 0 8-8v-40h40a8 8 0 0 0 8-8V40a8 8 0 0 0-8-8Zm-56 176H48V96h112Zm48-48h-32V88a8 8 0 0 0-8-8H96V48h112Z" })
296
+ })
297
+ );
298
+ }
299
+ var StopIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
300
+ "svg",
301
+ {
302
+ xmlns: "http://www.w3.org/2000/svg",
303
+ viewBox: "0 0 256 256",
304
+ fill: "currentColor",
305
+ style: { height: "1rem", width: "1rem" },
306
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { d: "M128 24a104 104 0 1 0 104 104A104.11 104.11 0 0 0 128 24Zm0 192a88 88 0 1 1 88-88 88.1 88.1 0 0 1-88 88Zm24-120h-48a8 8 0 0 0-8 8v48a8 8 0 0 0 8 8h48a8 8 0 0 0 8-8v-48a8 8 0 0 0-8-8Zm-8 48h-32v-32h32Z" })
307
+ }
308
+ );
309
+ var RegenerateIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
310
+ "svg",
311
+ {
312
+ xmlns: "http://www.w3.org/2000/svg",
313
+ viewBox: "0 0 256 256",
314
+ fill: "currentColor",
315
+ style: { height: "1rem", width: "1rem" },
316
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { d: "M197.67 186.37a8 8 0 0 1 0 11.29C196.58 198.73 170.82 224 128 224c-37.39 0-64.53-22.4-80-39.85V208a8 8 0 0 1-16 0v-48a8 8 0 0 1 8-8h48a8 8 0 0 1 0 16H55.44C67.76 183.35 93 208 128 208c36 0 58.14-21.46 58.36-21.68a8 8 0 0 1 11.31.05ZM216 40a8 8 0 0 0-8 8v23.85C192.53 54.4 165.39 32 128 32c-42.82 0-68.58 25.27-69.66 26.34a8 8 0 0 0 11.3 11.34C69.86 69.46 92 48 128 48c35 0 60.24 24.65 72.56 40H168a8 8 0 0 0 0 16h48a8 8 0 0 0 8-8V48a8 8 0 0 0-8-8Z" })
317
+ }
318
+ );
319
+ var PushToTalkIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
320
+ "svg",
321
+ {
322
+ xmlns: "http://www.w3.org/2000/svg",
323
+ fill: "none",
324
+ viewBox: "0 0 24 24",
325
+ strokeWidth: 1.5,
326
+ stroke: "currentColor",
327
+ className: "w-6 h-6",
328
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
329
+ "path",
330
+ {
331
+ strokeLinecap: "round",
332
+ strokeLinejoin: "round",
333
+ d: "M12 18.75a6 6 0 0 0 6-6v-1.5m-6 7.5a6 6 0 0 1-6-6v-1.5m6 7.5v3.75m-3.75 0h7.5M12 15.75a3 3 0 0 1-3-3V4.5a3 3 0 1 1 6 0v8.25a3 3 0 0 1-3 3Z"
334
+ }
335
+ )
336
+ }
337
+ );
338
+
339
+ // src/components/chat/ChatContext.tsx
340
+ var import_jsx_runtime2 = require("react/jsx-runtime");
341
+ var ChatContext = import_react.default.createContext(void 0);
342
+ function useChatContext() {
343
+ const context = import_react.default.useContext(ChatContext);
344
+ if (context === void 0) {
345
+ throw new Error(
346
+ "Context not found. Did you forget to wrap your app in a <ChatContextProvider> component?"
347
+ );
348
+ }
349
+ return context;
350
+ }
351
+ var ChatContextProvider = ({
352
+ // temperature,
353
+ // instructions,
354
+ // maxFeedback,
355
+ labels,
356
+ icons,
357
+ children,
358
+ open,
359
+ setOpen
360
+ }) => {
361
+ const memoizedLabels = (0, import_react.useMemo)(
362
+ () => __spreadValues(__spreadValues({}, {
363
+ initial: "",
364
+ title: "CopilotKit",
365
+ placeholder: "Type a message...",
366
+ error: "\u274C An error occurred. Please try again.",
367
+ stopGenerating: "Stop generating",
368
+ regenerateResponse: "Regenerate response"
369
+ }), labels),
370
+ [labels]
371
+ );
372
+ const memoizedIcons = (0, import_react.useMemo)(
373
+ () => __spreadValues(__spreadValues({}, {
374
+ openIcon: OpenIcon,
375
+ closeIcon: CloseIcon,
376
+ headerCloseIcon: HeaderCloseIcon,
377
+ sendIcon: SendIcon,
378
+ activityIcon: ActivityIcon,
379
+ spinnerIcon: SpinnerIcon,
380
+ stopIcon: StopIcon,
381
+ regenerateIcon: RegenerateIcon,
382
+ pushToTalkIcon: PushToTalkIcon
383
+ }), icons),
384
+ [icons]
385
+ );
386
+ const context = (0, import_react.useMemo)(
387
+ () => ({
388
+ labels: memoizedLabels,
389
+ icons: memoizedIcons,
390
+ open,
391
+ setOpen
392
+ }),
393
+ [memoizedLabels, memoizedIcons, open, setOpen]
394
+ );
395
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(ChatContext.Provider, { value: context, children });
396
+ };
397
+
398
+ // src/components/chat/Window.tsx
399
+ var import_react2 = __toESM(require("react"));
400
+ var import_jsx_runtime3 = require("react/jsx-runtime");
401
+ var Window = ({
402
+ children,
403
+ clickOutsideToClose,
404
+ shortcut,
405
+ hitEscapeToClose
406
+ }) => {
407
+ const windowRef = import_react2.default.useRef(null);
408
+ const { open, setOpen } = useChatContext();
409
+ const handleClickOutside = (0, import_react2.useCallback)(
410
+ (event) => {
411
+ var _a;
412
+ if (!clickOutsideToClose) {
413
+ return;
414
+ }
415
+ const parentElement = (_a = windowRef.current) == null ? void 0 : _a.parentElement;
416
+ let className = "";
417
+ if (event.target instanceof HTMLElement) {
418
+ className = event.target.className;
419
+ }
420
+ if (open && parentElement && !parentElement.contains(event.target) && // prevent closing the window when clicking on the debug menu
421
+ !className.includes("copilotKitDebugMenu")) {
422
+ setOpen(false);
423
+ }
424
+ },
425
+ [clickOutsideToClose, open, setOpen]
426
+ );
427
+ const handleKeyDown = (0, import_react2.useCallback)(
428
+ (event) => {
429
+ var _a;
430
+ const target = event.target;
431
+ const isInput = target.tagName === "INPUT" || target.tagName === "SELECT" || target.tagName === "TEXTAREA" || target.isContentEditable;
432
+ const isDescendantOfWrapper = (_a = windowRef.current) == null ? void 0 : _a.contains(target);
433
+ if (open && event.key === "Escape" && (!isInput || isDescendantOfWrapper) && hitEscapeToClose) {
434
+ setOpen(false);
435
+ } else if (event.key === shortcut && (isMacOS() && event.metaKey || !isMacOS() && event.ctrlKey) && (!isInput || isDescendantOfWrapper)) {
436
+ setOpen(!open);
437
+ }
438
+ },
439
+ [hitEscapeToClose, shortcut, open, setOpen]
440
+ );
441
+ const adjustForMobile = (0, import_react2.useCallback)(() => {
442
+ const copilotKitWindow = windowRef.current;
443
+ const vv = window.visualViewport;
444
+ if (!copilotKitWindow || !vv) {
445
+ return;
446
+ }
447
+ if (window.innerWidth < 640 && open) {
448
+ copilotKitWindow.style.height = `${vv.height}px`;
449
+ copilotKitWindow.style.left = `${vv.offsetLeft}px`;
450
+ copilotKitWindow.style.top = `${vv.offsetTop}px`;
451
+ document.body.style.position = "fixed";
452
+ document.body.style.width = "100%";
453
+ document.body.style.height = `${window.innerHeight}px`;
454
+ document.body.style.overflow = "hidden";
455
+ document.body.style.touchAction = "none";
456
+ document.body.addEventListener("touchmove", preventScroll, {
457
+ passive: false
458
+ });
459
+ } else {
460
+ copilotKitWindow.style.height = "";
461
+ copilotKitWindow.style.left = "";
462
+ copilotKitWindow.style.top = "";
463
+ document.body.style.position = "";
464
+ document.body.style.height = "";
465
+ document.body.style.width = "";
466
+ document.body.style.overflow = "";
467
+ document.body.style.top = "";
468
+ document.body.style.touchAction = "";
469
+ document.body.removeEventListener("touchmove", preventScroll);
470
+ }
471
+ }, [open]);
472
+ (0, import_react2.useEffect)(() => {
473
+ document.addEventListener("mousedown", handleClickOutside);
474
+ document.addEventListener("keydown", handleKeyDown);
475
+ if (window.visualViewport) {
476
+ window.visualViewport.addEventListener("resize", adjustForMobile);
477
+ adjustForMobile();
478
+ }
479
+ return () => {
480
+ document.removeEventListener("mousedown", handleClickOutside);
481
+ document.removeEventListener("keydown", handleKeyDown);
482
+ if (window.visualViewport) {
483
+ window.visualViewport.removeEventListener("resize", adjustForMobile);
484
+ }
485
+ };
486
+ }, [adjustForMobile, handleClickOutside, handleKeyDown]);
487
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)("div", { className: `copilotKitWindow${open ? " open" : ""}`, ref: windowRef, children });
488
+ };
489
+ var preventScroll = (event) => {
490
+ let targetElement = event.target;
491
+ const hasParentWithClass = (element, className) => {
492
+ while (element && element !== document.body) {
493
+ if (element.classList.contains(className)) {
494
+ return true;
495
+ }
496
+ element = element.parentElement;
497
+ }
498
+ return false;
499
+ };
500
+ if (!hasParentWithClass(targetElement, "copilotKitMessages")) {
501
+ event.preventDefault();
502
+ }
503
+ };
504
+ function isMacOS() {
505
+ return /Mac|iMac|Macintosh/i.test(navigator.userAgent);
506
+ }
507
+
508
+ // src/components/chat/Button.tsx
509
+ var import_jsx_runtime4 = require("react/jsx-runtime");
510
+ var Button = ({}) => {
511
+ const { open, setOpen, icons } = useChatContext();
512
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { onClick: () => setOpen(!open), children: /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)(
513
+ "button",
514
+ {
515
+ className: `copilotKitButton ${open ? "open" : ""}`,
516
+ "aria-label": open ? "Close Chat" : "Open Chat",
517
+ children: [
518
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { className: "copilotKitButtonIcon copilotKitButtonIconOpen", children: icons.openIcon }),
519
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { className: "copilotKitButtonIcon copilotKitButtonIconClose", children: icons.closeIcon })
520
+ ]
521
+ }
522
+ ) });
523
+ };
524
+
525
+ // src/components/chat/Header.tsx
526
+ var import_jsx_runtime5 = require("react/jsx-runtime");
527
+ var Header = ({}) => {
528
+ const { setOpen, icons, labels } = useChatContext();
529
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "copilotKitHeader", children: [
530
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("div", { children: labels.title }),
531
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("button", { onClick: () => setOpen(false), "aria-label": "Close", children: icons.headerCloseIcon })
532
+ ] });
533
+ };
534
+
535
+ // src/components/chat/Messages.tsx
536
+ var import_react3 = require("react");
537
+ var import_runtime_client_gql = require("@copilotkit/runtime-client-gql");
538
+ var import_jsx_runtime6 = require("react/jsx-runtime");
539
+ var Messages = ({
540
+ messages,
541
+ inProgress,
542
+ children,
543
+ RenderTextMessage: RenderTextMessage2,
544
+ RenderActionExecutionMessage: RenderActionExecutionMessage2,
545
+ RenderAgentStateMessage: RenderAgentStateMessage2,
546
+ RenderResultMessage: RenderResultMessage2
547
+ }) => {
548
+ const context = useChatContext();
549
+ const initialMessages = (0, import_react3.useMemo)(
550
+ () => makeInitialMessages(context.labels.initial),
551
+ [context.labels.initial]
552
+ );
553
+ messages = [...initialMessages, ...messages];
554
+ const actionResults = {};
555
+ for (let i = 0; i < messages.length; i++) {
556
+ if (messages[i].isActionExecutionMessage()) {
557
+ const id = messages[i].id;
558
+ const resultMessage = messages.find(
559
+ (message) => message.isResultMessage() && message.actionExecutionId === id
560
+ );
561
+ if (resultMessage) {
562
+ actionResults[id] = import_runtime_client_gql.ResultMessage.decodeResult(resultMessage.result || "");
563
+ }
564
+ }
565
+ }
566
+ const { messagesEndRef, messagesContainerRef } = useScrollToBottom(messages);
567
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { className: "copilotKitMessages", ref: messagesContainerRef, children: [
568
+ messages.map((message, index) => {
569
+ const isCurrentMessage = index === messages.length - 1;
570
+ if (message.isTextMessage()) {
571
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
572
+ RenderTextMessage2,
573
+ {
574
+ message,
575
+ inProgress,
576
+ index,
577
+ isCurrentMessage
578
+ },
579
+ index
580
+ );
581
+ } else if (message.isActionExecutionMessage()) {
582
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
583
+ RenderActionExecutionMessage2,
584
+ {
585
+ message,
586
+ inProgress,
587
+ index,
588
+ isCurrentMessage,
589
+ actionResult: actionResults[message.id]
590
+ },
591
+ index
592
+ );
593
+ } else if (message.isAgentStateMessage()) {
594
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
595
+ RenderAgentStateMessage2,
596
+ {
597
+ message,
598
+ inProgress,
599
+ index,
600
+ isCurrentMessage
601
+ },
602
+ index
603
+ );
604
+ } else if (message.isResultMessage()) {
605
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
606
+ RenderResultMessage2,
607
+ {
608
+ message,
609
+ inProgress,
610
+ index,
611
+ isCurrentMessage
612
+ },
613
+ index
614
+ );
615
+ }
616
+ }),
617
+ /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("footer", { ref: messagesEndRef, children })
618
+ ] });
619
+ };
620
+ function makeInitialMessages(initial) {
621
+ let initialArray = [];
622
+ if (initial) {
623
+ if (Array.isArray(initial)) {
624
+ initialArray.push(...initial);
625
+ } else {
626
+ initialArray.push(initial);
627
+ }
628
+ }
629
+ return initialArray.map(
630
+ (message) => new import_runtime_client_gql.TextMessage({
631
+ role: import_runtime_client_gql.Role.Assistant,
632
+ content: message
633
+ })
634
+ );
635
+ }
636
+ function useScrollToBottom(messages) {
637
+ const messagesEndRef = (0, import_react3.useRef)(null);
638
+ const messagesContainerRef = (0, import_react3.useRef)(null);
639
+ const isProgrammaticScrollRef = (0, import_react3.useRef)(false);
640
+ const isUserScrollUpRef = (0, import_react3.useRef)(false);
641
+ const scrollToBottom = () => {
642
+ if (messagesEndRef.current) {
643
+ isProgrammaticScrollRef.current = true;
644
+ messagesEndRef.current.scrollIntoView({
645
+ behavior: "auto"
646
+ });
647
+ }
648
+ };
649
+ const handleScroll = () => {
650
+ if (isProgrammaticScrollRef.current) {
651
+ isProgrammaticScrollRef.current = false;
652
+ return;
653
+ }
654
+ if (messagesContainerRef.current) {
655
+ const { scrollTop, scrollHeight, clientHeight } = messagesContainerRef.current;
656
+ isUserScrollUpRef.current = scrollTop + clientHeight < scrollHeight;
657
+ }
658
+ };
659
+ (0, import_react3.useEffect)(() => {
660
+ const container = messagesContainerRef.current;
661
+ if (container) {
662
+ container.addEventListener("scroll", handleScroll);
663
+ }
664
+ return () => {
665
+ if (container) {
666
+ container.removeEventListener("scroll", handleScroll);
667
+ }
668
+ };
669
+ }, []);
670
+ (0, import_react3.useEffect)(() => {
671
+ const container = messagesContainerRef.current;
672
+ if (!container) {
673
+ return;
674
+ }
675
+ const mutationObserver = new MutationObserver(() => {
676
+ if (!isUserScrollUpRef.current) {
677
+ scrollToBottom();
678
+ }
679
+ });
680
+ mutationObserver.observe(container, {
681
+ childList: true,
682
+ subtree: true,
683
+ characterData: true
684
+ });
685
+ return () => {
686
+ mutationObserver.disconnect();
687
+ };
688
+ }, []);
689
+ (0, import_react3.useEffect)(() => {
690
+ isUserScrollUpRef.current = false;
691
+ scrollToBottom();
692
+ }, [messages.filter((m) => m.isTextMessage() && m.role === import_runtime_client_gql.Role.User).length]);
693
+ return { messagesEndRef, messagesContainerRef };
694
+ }
695
+
696
+ // src/components/chat/Input.tsx
697
+ var import_react6 = require("react");
698
+
699
+ // src/components/chat/Textarea.tsx
700
+ var import_react4 = require("react");
701
+ var import_jsx_runtime7 = require("react/jsx-runtime");
702
+ var AutoResizingTextarea = (0, import_react4.forwardRef)(
703
+ ({ maxRows = 1, placeholder, value, onChange, onKeyDown, autoFocus }, ref) => {
704
+ const internalTextareaRef = (0, import_react4.useRef)(null);
705
+ const [maxHeight, setMaxHeight] = (0, import_react4.useState)(0);
706
+ (0, import_react4.useImperativeHandle)(ref, () => internalTextareaRef.current);
707
+ (0, import_react4.useEffect)(() => {
708
+ const calculateMaxHeight = () => {
709
+ const textarea = internalTextareaRef.current;
710
+ if (textarea) {
711
+ textarea.style.height = "auto";
712
+ const singleRowHeight = textarea.scrollHeight;
713
+ setMaxHeight(singleRowHeight * maxRows);
714
+ if (autoFocus) {
715
+ textarea.focus();
716
+ }
717
+ }
718
+ };
719
+ calculateMaxHeight();
720
+ }, [maxRows]);
721
+ (0, import_react4.useEffect)(() => {
722
+ const textarea = internalTextareaRef.current;
723
+ if (textarea) {
724
+ textarea.style.height = "auto";
725
+ textarea.style.height = `${Math.min(textarea.scrollHeight, maxHeight)}px`;
726
+ }
727
+ }, [value, maxHeight]);
728
+ return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
729
+ "textarea",
730
+ {
731
+ ref: internalTextareaRef,
732
+ value,
733
+ onChange,
734
+ onKeyDown,
735
+ placeholder,
736
+ style: {
737
+ overflow: "auto",
738
+ resize: "none",
739
+ maxHeight: `${maxHeight}px`
740
+ },
741
+ rows: 1
742
+ }
743
+ );
744
+ }
745
+ );
746
+ var Textarea_default = AutoResizingTextarea;
747
+
748
+ // src/hooks/use-push-to-talk.tsx
749
+ var import_react_core = require("@copilotkit/react-core");
750
+ var import_react5 = require("react");
751
+ var startRecording = (mediaStreamRef, mediaRecorderRef, audioContextRef, recordedChunks, onStop) => __async(void 0, null, function* () {
752
+ if (!mediaStreamRef.current || !audioContextRef.current) {
753
+ mediaStreamRef.current = yield navigator.mediaDevices.getUserMedia({ audio: true });
754
+ audioContextRef.current = new window.AudioContext();
755
+ yield audioContextRef.current.resume();
756
+ }
757
+ mediaRecorderRef.current = new MediaRecorder(mediaStreamRef.current);
758
+ mediaRecorderRef.current.start(1e3);
759
+ mediaRecorderRef.current.ondataavailable = (event) => {
760
+ recordedChunks.push(event.data);
761
+ };
762
+ mediaRecorderRef.current.onstop = onStop;
763
+ });
764
+ var stopRecording = (mediaRecorderRef) => {
765
+ if (mediaRecorderRef.current && mediaRecorderRef.current.state !== "inactive") {
766
+ mediaRecorderRef.current.stop();
767
+ }
768
+ };
769
+ var transcribeAudio = (recordedChunks, transcribeAudioUrl) => __async(void 0, null, function* () {
770
+ const completeBlob = new Blob(recordedChunks, { type: "audio/mp4" });
771
+ const formData = new FormData();
772
+ formData.append("file", completeBlob, "recording.mp4");
773
+ const response = yield fetch(transcribeAudioUrl, {
774
+ method: "POST",
775
+ body: formData
776
+ });
777
+ if (!response.ok) {
778
+ throw new Error(`Error: ${response.statusText}`);
779
+ }
780
+ const transcription = yield response.json();
781
+ return transcription.text;
782
+ });
783
+ var playAudioResponse = (text, textToSpeechUrl, audioContext) => {
784
+ const encodedText = encodeURIComponent(text);
785
+ const url = `${textToSpeechUrl}?text=${encodedText}`;
786
+ fetch(url).then((response) => response.arrayBuffer()).then((arrayBuffer) => audioContext.decodeAudioData(arrayBuffer)).then((audioBuffer) => {
787
+ const source = audioContext.createBufferSource();
788
+ source.buffer = audioBuffer;
789
+ source.connect(audioContext.destination);
790
+ source.start(0);
791
+ }).catch((error) => {
792
+ console.error("Error with decoding audio data", error);
793
+ });
794
+ };
795
+ var usePushToTalk = ({
796
+ sendFunction,
797
+ inProgress
798
+ }) => {
799
+ const [pushToTalkState, setPushToTalkState] = (0, import_react5.useState)("idle");
800
+ const mediaStreamRef = (0, import_react5.useRef)(null);
801
+ const audioContextRef = (0, import_react5.useRef)(null);
802
+ const mediaRecorderRef = (0, import_react5.useRef)(null);
803
+ const recordedChunks = (0, import_react5.useRef)([]);
804
+ const generalContext = (0, import_react_core.useCopilotContext)();
805
+ const messagesContext = (0, import_react_core.useCopilotMessagesContext)();
806
+ const context = __spreadValues(__spreadValues({}, generalContext), messagesContext);
807
+ const [startReadingFromMessageId, setStartReadingFromMessageId] = (0, import_react5.useState)(null);
808
+ (0, import_react5.useEffect)(() => {
809
+ if (pushToTalkState === "recording") {
810
+ startRecording(
811
+ mediaStreamRef,
812
+ mediaRecorderRef,
813
+ audioContextRef,
814
+ recordedChunks.current,
815
+ () => {
816
+ setPushToTalkState("transcribing");
817
+ }
818
+ );
819
+ } else {
820
+ stopRecording(mediaRecorderRef);
821
+ if (pushToTalkState === "transcribing") {
822
+ transcribeAudio(recordedChunks.current, context.copilotApiConfig.transcribeAudioUrl).then(
823
+ (transcription) => __async(void 0, null, function* () {
824
+ recordedChunks.current = [];
825
+ setPushToTalkState("idle");
826
+ const message = yield sendFunction(transcription);
827
+ setStartReadingFromMessageId(message.id);
828
+ })
829
+ );
830
+ }
831
+ }
832
+ return () => {
833
+ stopRecording(mediaRecorderRef);
834
+ };
835
+ }, [pushToTalkState]);
836
+ (0, import_react5.useEffect)(() => {
837
+ if (inProgress === false && startReadingFromMessageId) {
838
+ const lastMessageIndex = context.messages.findIndex(
839
+ (message) => message.id === startReadingFromMessageId
840
+ );
841
+ const messagesAfterLast = context.messages.slice(lastMessageIndex + 1).filter(
842
+ (message) => message.isTextMessage() && message.role === "assistant"
843
+ );
844
+ const text = messagesAfterLast.map((message) => message.content).join("\n");
845
+ playAudioResponse(text, context.copilotApiConfig.textToSpeechUrl, audioContextRef.current);
846
+ setStartReadingFromMessageId(null);
847
+ }
848
+ }, [startReadingFromMessageId, inProgress]);
849
+ return { pushToTalkState, setPushToTalkState };
850
+ };
851
+
852
+ // src/components/chat/Input.tsx
853
+ var import_react_core2 = require("@copilotkit/react-core");
854
+ var import_jsx_runtime8 = require("react/jsx-runtime");
855
+ var Input = ({ inProgress, onSend, isVisible = false }) => {
856
+ const context = useChatContext();
857
+ const copilotContext = (0, import_react_core2.useCopilotContext)();
858
+ const pushToTalkConfigured = copilotContext.copilotApiConfig.textToSpeechUrl !== void 0 && copilotContext.copilotApiConfig.transcribeAudioUrl !== void 0;
859
+ const textareaRef = (0, import_react6.useRef)(null);
860
+ const handleDivClick = (event) => {
861
+ var _a;
862
+ if (event.target !== event.currentTarget)
863
+ return;
864
+ (_a = textareaRef.current) == null ? void 0 : _a.focus();
865
+ };
866
+ const [text, setText] = (0, import_react6.useState)("");
867
+ const send = () => {
868
+ var _a;
869
+ if (inProgress)
870
+ return;
871
+ onSend(text);
872
+ setText("");
873
+ (_a = textareaRef.current) == null ? void 0 : _a.focus();
874
+ };
875
+ (0, import_react6.useEffect)(() => {
876
+ var _a;
877
+ if (isVisible) {
878
+ (_a = textareaRef.current) == null ? void 0 : _a.focus();
879
+ }
880
+ }, [isVisible]);
881
+ const { pushToTalkState, setPushToTalkState } = usePushToTalk({
882
+ sendFunction: onSend,
883
+ inProgress
884
+ });
885
+ const sendIcon = inProgress || pushToTalkState === "transcribing" ? context.icons.activityIcon : context.icons.sendIcon;
886
+ const showPushToTalk = pushToTalkConfigured && (pushToTalkState === "idle" || pushToTalkState === "recording") && !inProgress;
887
+ const canSend = () => {
888
+ return !inProgress && text.trim().length > 0 && pushToTalkState === "idle";
889
+ };
890
+ const sendDisabled = !canSend();
891
+ return /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)("div", { className: "copilotKitInput", onClick: handleDivClick, children: [
892
+ /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
893
+ Textarea_default,
894
+ {
895
+ ref: textareaRef,
896
+ placeholder: context.labels.placeholder,
897
+ autoFocus: true,
898
+ maxRows: 5,
899
+ value: text,
900
+ onChange: (event) => setText(event.target.value),
901
+ onKeyDown: (event) => {
902
+ if (event.key === "Enter" && !event.shiftKey) {
903
+ event.preventDefault();
904
+ if (canSend()) {
905
+ send();
906
+ }
907
+ }
908
+ }
909
+ }
910
+ ),
911
+ /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)("div", { className: "copilotKitInputControls", children: [
912
+ showPushToTalk && /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
913
+ "button",
914
+ {
915
+ onClick: () => setPushToTalkState(pushToTalkState === "idle" ? "recording" : "transcribing"),
916
+ className: pushToTalkState === "recording" ? "copilotKitPushToTalkRecording" : "",
917
+ children: context.icons.pushToTalkIcon
918
+ }
919
+ ),
920
+ /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
921
+ "button",
922
+ {
923
+ disabled: sendDisabled,
924
+ onClick: send,
925
+ "data-copilotkit-in-progress": !!inProgress,
926
+ "data-testid": inProgress ? "copilot-chat-request-in-progress" : void 0,
927
+ children: sendIcon
928
+ }
929
+ )
930
+ ] })
931
+ ] });
932
+ };
933
+
934
+ // src/components/chat/Response.tsx
935
+ var import_jsx_runtime9 = require("react/jsx-runtime");
936
+ var ResponseButton = ({ onClick, inProgress }) => {
937
+ const context = useChatContext();
938
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)("button", { onClick, className: "copilotKitResponseButton", children: [
939
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)("span", { children: inProgress ? context.icons.stopIcon : context.icons.regenerateIcon }),
940
+ inProgress ? context.labels.stopGenerating : context.labels.regenerateResponse
941
+ ] });
942
+ };
943
+
944
+ // src/components/chat/Markdown.tsx
945
+ var import_react8 = require("react");
946
+ var import_react_markdown = __toESM(require("react-markdown"));
947
+
948
+ // src/components/chat/CodeBlock.tsx
949
+ var import_react7 = require("react");
950
+ var import_react_syntax_highlighter = require("react-syntax-highlighter");
951
+
952
+ // src/hooks/use-copy-to-clipboard.tsx
953
+ var React5 = __toESM(require("react"));
954
+ function useCopyToClipboard({ timeout = 2e3 }) {
955
+ const [isCopied, setIsCopied] = React5.useState(false);
956
+ const copyToClipboard = (value) => {
957
+ var _a;
958
+ if (typeof window === "undefined" || !((_a = navigator.clipboard) == null ? void 0 : _a.writeText)) {
959
+ return;
960
+ }
961
+ if (!value) {
962
+ return;
963
+ }
964
+ navigator.clipboard.writeText(value).then(() => {
965
+ setIsCopied(true);
966
+ setTimeout(() => {
967
+ setIsCopied(false);
968
+ }, timeout);
969
+ });
970
+ };
971
+ return { isCopied, copyToClipboard };
972
+ }
973
+
974
+ // src/components/chat/CodeBlock.tsx
975
+ var import_jsx_runtime10 = require("react/jsx-runtime");
976
+ var programmingLanguages = {
977
+ javascript: ".js",
978
+ python: ".py",
979
+ java: ".java",
980
+ c: ".c",
981
+ cpp: ".cpp",
982
+ "c++": ".cpp",
983
+ "c#": ".cs",
984
+ ruby: ".rb",
985
+ php: ".php",
986
+ swift: ".swift",
987
+ "objective-c": ".m",
988
+ kotlin: ".kt",
989
+ typescript: ".ts",
990
+ go: ".go",
991
+ perl: ".pl",
992
+ rust: ".rs",
993
+ scala: ".scala",
994
+ haskell: ".hs",
995
+ lua: ".lua",
996
+ shell: ".sh",
997
+ sql: ".sql",
998
+ html: ".html",
999
+ css: ".css"
1000
+ // add more file extensions here, make sure the key is same as language prop in CodeBlock.tsx component
1001
+ };
1002
+ var generateRandomString = (length, lowercase = false) => {
1003
+ const chars = "ABCDEFGHJKLMNPQRSTUVWXY3456789";
1004
+ let result = "";
1005
+ for (let i = 0; i < length; i++) {
1006
+ result += chars.charAt(Math.floor(Math.random() * chars.length));
1007
+ }
1008
+ return lowercase ? result.toLowerCase() : result;
1009
+ };
1010
+ var CodeBlock = (0, import_react7.memo)(({ language, value }) => {
1011
+ const { isCopied, copyToClipboard } = useCopyToClipboard({ timeout: 2e3 });
1012
+ const downloadAsFile = () => {
1013
+ if (typeof window === "undefined") {
1014
+ return;
1015
+ }
1016
+ const fileExtension = programmingLanguages[language] || ".file";
1017
+ const suggestedFileName = `file-${generateRandomString(3, true)}${fileExtension}`;
1018
+ const fileName = window.prompt("Enter file name", suggestedFileName);
1019
+ if (!fileName) {
1020
+ return;
1021
+ }
1022
+ const blob = new Blob([value], { type: "text/plain" });
1023
+ const url = URL.createObjectURL(blob);
1024
+ const link = document.createElement("a");
1025
+ link.download = fileName;
1026
+ link.href = url;
1027
+ link.style.display = "none";
1028
+ document.body.appendChild(link);
1029
+ link.click();
1030
+ document.body.removeChild(link);
1031
+ URL.revokeObjectURL(url);
1032
+ };
1033
+ const onCopy = () => {
1034
+ if (isCopied)
1035
+ return;
1036
+ copyToClipboard(value);
1037
+ };
1038
+ return /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)("div", { className: "copilotKitCodeBlock", children: [
1039
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)("div", { className: "copilotKitCodeBlockToolbar", children: [
1040
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsx)("span", { className: "copilotKitCodeBlockToolbarLanguage", children: language }),
1041
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)("div", { className: "copilotKitCodeBlockToolbarButtons", children: [
1042
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)("button", { className: "copilotKitCodeBlockToolbarButton", onClick: downloadAsFile, children: [
1043
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(DownloadIcon, {}),
1044
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsx)("span", { className: "sr-only", children: "Download" })
1045
+ ] }),
1046
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)("button", { className: "copilotKitCodeBlockToolbarButton", onClick: onCopy, children: [
1047
+ isCopied ? /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(CheckIcon, {}) : /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(CopyIcon, {}),
1048
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsx)("span", { className: "sr-only", children: "Copy code" })
1049
+ ] })
1050
+ ] })
1051
+ ] }),
1052
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(
1053
+ import_react_syntax_highlighter.Prism,
1054
+ {
1055
+ language,
1056
+ style: highlightStyle,
1057
+ PreTag: "div",
1058
+ customStyle: {
1059
+ margin: 0,
1060
+ borderBottomLeftRadius: "0.375rem",
1061
+ borderBottomRightRadius: "0.375rem"
1062
+ },
1063
+ children: value
1064
+ }
1065
+ )
1066
+ ] });
1067
+ });
1068
+ CodeBlock.displayName = "CodeBlock";
1069
+ var highlightStyle = {
1070
+ 'pre[class*="language-"]': {
1071
+ color: "#d4d4d4",
1072
+ fontSize: "13px",
1073
+ textShadow: "none",
1074
+ fontFamily: 'Menlo, Monaco, Consolas, "Andale Mono", "Ubuntu Mono", "Courier New", monospace',
1075
+ direction: "ltr",
1076
+ textAlign: "left",
1077
+ whiteSpace: "pre",
1078
+ wordSpacing: "normal",
1079
+ wordBreak: "normal",
1080
+ lineHeight: "1.5",
1081
+ MozTabSize: "4",
1082
+ OTabSize: "4",
1083
+ tabSize: "4",
1084
+ WebkitHyphens: "none",
1085
+ MozHyphens: "none",
1086
+ msHyphens: "none",
1087
+ hyphens: "none",
1088
+ padding: "1em",
1089
+ margin: ".5em 0",
1090
+ overflow: "auto",
1091
+ background: "#1e1e1e"
1092
+ },
1093
+ 'code[class*="language-"]': {
1094
+ color: "#d4d4d4",
1095
+ fontSize: "13px",
1096
+ textShadow: "none",
1097
+ fontFamily: 'Menlo, Monaco, Consolas, "Andale Mono", "Ubuntu Mono", "Courier New", monospace',
1098
+ direction: "ltr",
1099
+ textAlign: "left",
1100
+ whiteSpace: "pre",
1101
+ wordSpacing: "normal",
1102
+ wordBreak: "normal",
1103
+ lineHeight: "1.5",
1104
+ MozTabSize: "4",
1105
+ OTabSize: "4",
1106
+ tabSize: "4",
1107
+ WebkitHyphens: "none",
1108
+ MozHyphens: "none",
1109
+ msHyphens: "none",
1110
+ hyphens: "none"
1111
+ },
1112
+ 'pre[class*="language-"]::selection': {
1113
+ textShadow: "none",
1114
+ background: "#264F78"
1115
+ },
1116
+ 'code[class*="language-"]::selection': {
1117
+ textShadow: "none",
1118
+ background: "#264F78"
1119
+ },
1120
+ 'pre[class*="language-"] *::selection': {
1121
+ textShadow: "none",
1122
+ background: "#264F78"
1123
+ },
1124
+ 'code[class*="language-"] *::selection': {
1125
+ textShadow: "none",
1126
+ background: "#264F78"
1127
+ },
1128
+ ':not(pre) > code[class*="language-"]': {
1129
+ padding: ".1em .3em",
1130
+ borderRadius: ".3em",
1131
+ color: "#db4c69",
1132
+ background: "#1e1e1e"
1133
+ },
1134
+ ".namespace": {
1135
+ Opacity: ".7"
1136
+ },
1137
+ "doctype.doctype-tag": {
1138
+ color: "#569CD6"
1139
+ },
1140
+ "doctype.name": {
1141
+ color: "#9cdcfe"
1142
+ },
1143
+ comment: {
1144
+ color: "#6a9955"
1145
+ },
1146
+ prolog: {
1147
+ color: "#6a9955"
1148
+ },
1149
+ punctuation: {
1150
+ color: "#d4d4d4"
1151
+ },
1152
+ ".language-html .language-css .token.punctuation": {
1153
+ color: "#d4d4d4"
1154
+ },
1155
+ ".language-html .language-javascript .token.punctuation": {
1156
+ color: "#d4d4d4"
1157
+ },
1158
+ property: {
1159
+ color: "#9cdcfe"
1160
+ },
1161
+ tag: {
1162
+ color: "#569cd6"
1163
+ },
1164
+ boolean: {
1165
+ color: "#569cd6"
1166
+ },
1167
+ number: {
1168
+ color: "#b5cea8"
1169
+ },
1170
+ constant: {
1171
+ color: "#9cdcfe"
1172
+ },
1173
+ symbol: {
1174
+ color: "#b5cea8"
1175
+ },
1176
+ inserted: {
1177
+ color: "#b5cea8"
1178
+ },
1179
+ unit: {
1180
+ color: "#b5cea8"
1181
+ },
1182
+ selector: {
1183
+ color: "#d7ba7d"
1184
+ },
1185
+ "attr-name": {
1186
+ color: "#9cdcfe"
1187
+ },
1188
+ string: {
1189
+ color: "#ce9178"
1190
+ },
1191
+ char: {
1192
+ color: "#ce9178"
1193
+ },
1194
+ builtin: {
1195
+ color: "#ce9178"
1196
+ },
1197
+ deleted: {
1198
+ color: "#ce9178"
1199
+ },
1200
+ ".language-css .token.string.url": {
1201
+ textDecoration: "underline"
1202
+ },
1203
+ operator: {
1204
+ color: "#d4d4d4"
1205
+ },
1206
+ entity: {
1207
+ color: "#569cd6"
1208
+ },
1209
+ "operator.arrow": {
1210
+ color: "#569CD6"
1211
+ },
1212
+ atrule: {
1213
+ color: "#ce9178"
1214
+ },
1215
+ "atrule.rule": {
1216
+ color: "#c586c0"
1217
+ },
1218
+ "atrule.url": {
1219
+ color: "#9cdcfe"
1220
+ },
1221
+ "atrule.url.function": {
1222
+ color: "#dcdcaa"
1223
+ },
1224
+ "atrule.url.punctuation": {
1225
+ color: "#d4d4d4"
1226
+ },
1227
+ keyword: {
1228
+ color: "#569CD6"
1229
+ },
1230
+ "keyword.module": {
1231
+ color: "#c586c0"
1232
+ },
1233
+ "keyword.control-flow": {
1234
+ color: "#c586c0"
1235
+ },
1236
+ function: {
1237
+ color: "#dcdcaa"
1238
+ },
1239
+ "function.maybe-class-name": {
1240
+ color: "#dcdcaa"
1241
+ },
1242
+ regex: {
1243
+ color: "#d16969"
1244
+ },
1245
+ important: {
1246
+ color: "#569cd6"
1247
+ },
1248
+ italic: {
1249
+ fontStyle: "italic"
1250
+ },
1251
+ "class-name": {
1252
+ color: "#4ec9b0"
1253
+ },
1254
+ "maybe-class-name": {
1255
+ color: "#4ec9b0"
1256
+ },
1257
+ console: {
1258
+ color: "#9cdcfe"
1259
+ },
1260
+ parameter: {
1261
+ color: "#9cdcfe"
1262
+ },
1263
+ interpolation: {
1264
+ color: "#9cdcfe"
1265
+ },
1266
+ "punctuation.interpolation-punctuation": {
1267
+ color: "#569cd6"
1268
+ },
1269
+ variable: {
1270
+ color: "#9cdcfe"
1271
+ },
1272
+ "imports.maybe-class-name": {
1273
+ color: "#9cdcfe"
1274
+ },
1275
+ "exports.maybe-class-name": {
1276
+ color: "#9cdcfe"
1277
+ },
1278
+ escape: {
1279
+ color: "#d7ba7d"
1280
+ },
1281
+ "tag.punctuation": {
1282
+ color: "#808080"
1283
+ },
1284
+ cdata: {
1285
+ color: "#808080"
1286
+ },
1287
+ "attr-value": {
1288
+ color: "#ce9178"
1289
+ },
1290
+ "attr-value.punctuation": {
1291
+ color: "#ce9178"
1292
+ },
1293
+ "attr-value.punctuation.attr-equals": {
1294
+ color: "#d4d4d4"
1295
+ },
1296
+ namespace: {
1297
+ color: "#4ec9b0"
1298
+ },
1299
+ 'pre[class*="language-javascript"]': {
1300
+ color: "#9cdcfe"
1301
+ },
1302
+ 'code[class*="language-javascript"]': {
1303
+ color: "#9cdcfe"
1304
+ },
1305
+ 'pre[class*="language-jsx"]': {
1306
+ color: "#9cdcfe"
1307
+ },
1308
+ 'code[class*="language-jsx"]': {
1309
+ color: "#9cdcfe"
1310
+ },
1311
+ 'pre[class*="language-typescript"]': {
1312
+ color: "#9cdcfe"
1313
+ },
1314
+ 'code[class*="language-typescript"]': {
1315
+ color: "#9cdcfe"
1316
+ },
1317
+ 'pre[class*="language-tsx"]': {
1318
+ color: "#9cdcfe"
1319
+ },
1320
+ 'code[class*="language-tsx"]': {
1321
+ color: "#9cdcfe"
1322
+ },
1323
+ 'pre[class*="language-css"]': {
1324
+ color: "#ce9178"
1325
+ },
1326
+ 'code[class*="language-css"]': {
1327
+ color: "#ce9178"
1328
+ },
1329
+ 'pre[class*="language-html"]': {
1330
+ color: "#d4d4d4"
1331
+ },
1332
+ 'code[class*="language-html"]': {
1333
+ color: "#d4d4d4"
1334
+ },
1335
+ ".language-regex .token.anchor": {
1336
+ color: "#dcdcaa"
1337
+ },
1338
+ ".language-html .token.punctuation": {
1339
+ color: "#808080"
1340
+ },
1341
+ 'pre[class*="language-"] > code[class*="language-"]': {
1342
+ position: "relative",
1343
+ zIndex: "1"
1344
+ },
1345
+ ".line-highlight.line-highlight": {
1346
+ background: "#f7ebc6",
1347
+ boxShadow: "inset 5px 0 0 #f7d87c",
1348
+ zIndex: "0"
1349
+ }
1350
+ };
1351
+
1352
+ // src/components/chat/Markdown.tsx
1353
+ var import_remark_gfm = __toESM(require("remark-gfm"));
1354
+ var import_remark_math = __toESM(require("remark-math"));
1355
+ var import_jsx_runtime11 = require("react/jsx-runtime");
1356
+ var MemoizedReactMarkdown = (0, import_react8.memo)(
1357
+ import_react_markdown.default,
1358
+ (prevProps, nextProps) => prevProps.children === nextProps.children && prevProps.className === nextProps.className
1359
+ );
1360
+ var Markdown = ({ content }) => {
1361
+ return /* @__PURE__ */ (0, import_jsx_runtime11.jsx)("div", { className: "copilotKitMarkdown", children: /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(MemoizedReactMarkdown, { components, remarkPlugins: [import_remark_gfm.default, import_remark_math.default], children: content }) });
1362
+ };
1363
+ var components = {
1364
+ p({ children }) {
1365
+ return /* @__PURE__ */ (0, import_jsx_runtime11.jsx)("p", { children });
1366
+ },
1367
+ a(_a) {
1368
+ var _b = _a, { children } = _b, props = __objRest(_b, ["children"]);
1369
+ return /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(
1370
+ "a",
1371
+ __spreadProps(__spreadValues({
1372
+ style: { color: "blue", textDecoration: "underline" }
1373
+ }, props), {
1374
+ target: "_blank",
1375
+ rel: "noopener noreferrer",
1376
+ children
1377
+ })
1378
+ );
1379
+ },
1380
+ code(_c) {
1381
+ var _d = _c, { children, className, inline } = _d, props = __objRest(_d, ["children", "className", "inline"]);
1382
+ if (children.length) {
1383
+ if (children[0] == "\u258D") {
1384
+ return /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(
1385
+ "span",
1386
+ {
1387
+ style: {
1388
+ animation: "pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite",
1389
+ marginTop: "0.25rem"
1390
+ },
1391
+ children: "\u258D"
1392
+ }
1393
+ );
1394
+ }
1395
+ children[0] = children[0].replace("`\u258D`", "\u258D");
1396
+ }
1397
+ const match = /language-(\w+)/.exec(className || "");
1398
+ if (inline) {
1399
+ return /* @__PURE__ */ (0, import_jsx_runtime11.jsx)("code", __spreadProps(__spreadValues({ className }, props), { children }));
1400
+ }
1401
+ return /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(
1402
+ CodeBlock,
1403
+ __spreadValues({
1404
+ language: match && match[1] || "",
1405
+ value: String(children).replace(/\n$/, "")
1406
+ }, props),
1407
+ Math.random()
1408
+ );
1409
+ }
1410
+ };
1411
+
1412
+ // src/components/chat/messages/RenderTextMessage.tsx
1413
+ var import_jsx_runtime12 = require("react/jsx-runtime");
1414
+ function RenderTextMessage(props) {
1415
+ const { message, inProgress, index, isCurrentMessage } = props;
1416
+ const { icons } = useChatContext();
1417
+ if (message.isTextMessage()) {
1418
+ if (message.role === "user") {
1419
+ return /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(
1420
+ "div",
1421
+ {
1422
+ "data-message-role": "user",
1423
+ className: "copilotKitMessage copilotKitUserMessage",
1424
+ children: message.content
1425
+ },
1426
+ index
1427
+ );
1428
+ } else if (message.role == "assistant") {
1429
+ return /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(
1430
+ "div",
1431
+ {
1432
+ "data-message-role": "assistant",
1433
+ className: `copilotKitMessage copilotKitAssistantMessage`,
1434
+ children: isCurrentMessage && inProgress && !message.content ? icons.spinnerIcon : /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(Markdown, { content: message.content })
1435
+ },
1436
+ index
1437
+ );
1438
+ }
1439
+ }
1440
+ }
1441
+
1442
+ // src/components/chat/messages/RenderActionExecutionMessage.tsx
1443
+ var import_runtime_client_gql2 = require("@copilotkit/runtime-client-gql");
1444
+ var import_react_core3 = require("@copilotkit/react-core");
1445
+ var import_jsx_runtime13 = require("react/jsx-runtime");
1446
+ function RenderActionExecutionMessage(props) {
1447
+ const { message, inProgress, index, isCurrentMessage, actionResult } = props;
1448
+ const { chatComponentsCache } = (0, import_react_core3.useCopilotContext)();
1449
+ const { icons } = useChatContext();
1450
+ if (message.isActionExecutionMessage()) {
1451
+ if (chatComponentsCache.current !== null && (chatComponentsCache.current.actions[message.name] || chatComponentsCache.current.actions["*"])) {
1452
+ const render = chatComponentsCache.current.actions[message.name] || chatComponentsCache.current.actions["*"];
1453
+ if (typeof render === "string") {
1454
+ if (isCurrentMessage && inProgress) {
1455
+ return /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)("div", { className: `copilotKitMessage copilotKitAssistantMessage`, children: [
1456
+ icons.spinnerIcon,
1457
+ " ",
1458
+ /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("span", { className: "inProgressLabel", children: render })
1459
+ ] }, index);
1460
+ } else {
1461
+ return null;
1462
+ }
1463
+ } else {
1464
+ const args = message.arguments;
1465
+ let status = "inProgress";
1466
+ if (actionResult !== void 0) {
1467
+ status = "complete";
1468
+ } else if (message.status.code !== import_runtime_client_gql2.MessageStatusCode.Pending) {
1469
+ status = "executing";
1470
+ }
1471
+ try {
1472
+ const toRender = render({
1473
+ status,
1474
+ args,
1475
+ result: actionResult,
1476
+ name: message.name
1477
+ });
1478
+ if (!toRender && status === "complete") {
1479
+ return null;
1480
+ }
1481
+ if (typeof toRender === "string") {
1482
+ return /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)("div", { className: `copilotKitMessage copilotKitAssistantMessage`, children: [
1483
+ isCurrentMessage && inProgress && icons.spinnerIcon,
1484
+ " ",
1485
+ toRender
1486
+ ] }, index);
1487
+ } else {
1488
+ return /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
1489
+ "div",
1490
+ {
1491
+ "data-message-type": "action-render",
1492
+ className: "copilotKitCustomAssistantMessage",
1493
+ children: toRender
1494
+ },
1495
+ index
1496
+ );
1497
+ }
1498
+ } catch (e) {
1499
+ console.error(`Error executing render function for action ${message.name}: ${e}`);
1500
+ return /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)("div", { className: `copilotKitMessage copilotKitAssistantMessage`, children: [
1501
+ isCurrentMessage && inProgress && icons.spinnerIcon,
1502
+ /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)("b", { children: [
1503
+ "\u274C Error executing render: ",
1504
+ message.name
1505
+ ] }),
1506
+ /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("br", {}),
1507
+ e instanceof Error ? e.message : String(e)
1508
+ ] }, index);
1509
+ }
1510
+ }
1511
+ } else if (!inProgress || !isCurrentMessage) {
1512
+ return null;
1513
+ } else {
1514
+ return /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("div", { className: `copilotKitMessage copilotKitAssistantMessage`, children: icons.spinnerIcon }, index);
1515
+ }
1516
+ }
1517
+ }
1518
+
1519
+ // src/components/chat/messages/RenderResultMessage.tsx
1520
+ var import_jsx_runtime14 = require("react/jsx-runtime");
1521
+ function RenderResultMessage(props) {
1522
+ const { message, inProgress, index, isCurrentMessage } = props;
1523
+ const { icons } = useChatContext();
1524
+ if (message.isResultMessage() && inProgress && isCurrentMessage) {
1525
+ return /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("div", { className: `copilotKitMessage copilotKitAssistantMessage`, children: icons.spinnerIcon }, index);
1526
+ }
1527
+ }
1528
+
1529
+ // src/components/chat/messages/RenderAgentStateMessage.tsx
1530
+ var import_react_core4 = require("@copilotkit/react-core");
1531
+ var import_jsx_runtime15 = require("react/jsx-runtime");
1532
+ function RenderAgentStateMessage(props) {
1533
+ const { message, inProgress, index, isCurrentMessage } = props;
1534
+ const { chatComponentsCache } = (0, import_react_core4.useCopilotContext)();
1535
+ const { icons } = useChatContext();
1536
+ if (message.isAgentStateMessage()) {
1537
+ let render;
1538
+ if (chatComponentsCache.current !== null) {
1539
+ render = chatComponentsCache.current.coAgentStateRenders[`${message.agentName}-${message.nodeName}`] || chatComponentsCache.current.coAgentStateRenders[`${message.agentName}-global`];
1540
+ }
1541
+ if (render) {
1542
+ if (typeof render === "string") {
1543
+ if (isCurrentMessage && inProgress) {
1544
+ return /* @__PURE__ */ (0, import_jsx_runtime15.jsxs)("div", { className: `copilotKitMessage copilotKitAssistantMessage`, children: [
1545
+ icons.spinnerIcon,
1546
+ " ",
1547
+ /* @__PURE__ */ (0, import_jsx_runtime15.jsx)("span", { className: "inProgressLabel", children: render })
1548
+ ] }, index);
1549
+ } else {
1550
+ return null;
1551
+ }
1552
+ } else {
1553
+ const state = message.state;
1554
+ let status = message.active ? "inProgress" : "complete";
1555
+ const toRender = render({
1556
+ status,
1557
+ state,
1558
+ nodeName: message.nodeName
1559
+ });
1560
+ if (!toRender && status === "complete") {
1561
+ return null;
1562
+ }
1563
+ if (!toRender && isCurrentMessage && inProgress) {
1564
+ return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)("div", { className: `copilotKitMessage copilotKitAssistantMessage`, children: icons.spinnerIcon }, index);
1565
+ } else if (!toRender) {
1566
+ return null;
1567
+ }
1568
+ if (typeof toRender === "string") {
1569
+ return /* @__PURE__ */ (0, import_jsx_runtime15.jsxs)("div", { className: `copilotKitMessage copilotKitAssistantMessage`, children: [
1570
+ isCurrentMessage && inProgress && icons.spinnerIcon,
1571
+ " ",
1572
+ toRender
1573
+ ] }, index);
1574
+ } else {
1575
+ return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)("div", { className: "copilotKitCustomAssistantMessage", children: toRender }, index);
1576
+ }
1577
+ }
1578
+ } else if (!inProgress || !isCurrentMessage) {
1579
+ return null;
1580
+ } else {
1581
+ return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)("div", { className: `copilotKitMessage copilotKitAssistantMessage`, children: icons.spinnerIcon }, index);
1582
+ }
1583
+ }
1584
+ }
1585
+
1586
+ // src/components/chat/Suggestion.tsx
1587
+ var import_react_core5 = require("@copilotkit/react-core");
1588
+ var import_shared = require("@copilotkit/shared");
1589
+ var import_runtime_client_gql3 = require("@copilotkit/runtime-client-gql");
1590
+ var import_jsx_runtime16 = require("react/jsx-runtime");
1591
+ function Suggestion({ title, message, onClick, partial, className }) {
1592
+ return /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)(
1593
+ "button",
1594
+ {
1595
+ disabled: partial,
1596
+ onClick: (e) => {
1597
+ e.preventDefault();
1598
+ onClick(message);
1599
+ },
1600
+ className: className || "suggestion",
1601
+ children: [
1602
+ partial && SmallSpinnerIcon,
1603
+ /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("span", { children: title })
1604
+ ]
1605
+ }
1606
+ );
1607
+ }
1608
+ var reloadSuggestions = (context, chatSuggestionConfiguration, setCurrentSuggestions, abortControllerRef) => __async(void 0, null, function* () {
1609
+ const abortController = abortControllerRef.current;
1610
+ const tools = JSON.stringify(
1611
+ Object.values(context.actions).map((action) => ({
1612
+ name: action.name,
1613
+ description: action.description,
1614
+ jsonSchema: JSON.stringify((0, import_shared.actionParametersToJsonSchema)(action.parameters))
1615
+ }))
1616
+ );
1617
+ const allSuggestions = [];
1618
+ for (const config of Object.values(chatSuggestionConfiguration)) {
1619
+ try {
1620
+ const numOfSuggestionsInstructions = config.minSuggestions === 0 ? `Produce up to ${config.maxSuggestions} suggestions. If there are no highly relevant suggestions you can think of, provide an empty array.` : `Produce between ${config.minSuggestions} and ${config.maxSuggestions} suggestions.`;
1621
+ const result = yield (0, import_react_core5.extract)({
1622
+ context,
1623
+ instructions: "Suggest what the user could say next. Provide clear, highly relevant suggestions. Do not literally suggest function calls. ",
1624
+ data: config.instructions + "\n\n" + numOfSuggestionsInstructions + "\n\nAvailable tools: " + tools + "\n\n",
1625
+ requestType: import_runtime_client_gql3.CopilotRequestType.Task,
1626
+ parameters: [
1627
+ {
1628
+ name: "suggestions",
1629
+ type: "object[]",
1630
+ attributes: [
1631
+ {
1632
+ name: "title",
1633
+ description: "The title of the suggestion. This is shown as a button and should be short.",
1634
+ type: "string"
1635
+ },
1636
+ {
1637
+ name: "message",
1638
+ description: "The message to send when the suggestion is clicked. This should be a clear, complete sentence and will be sent as an instruction to the AI.",
1639
+ type: "string"
1640
+ }
1641
+ ]
1642
+ }
1643
+ ],
1644
+ include: {
1645
+ messages: true,
1646
+ readable: true
1647
+ },
1648
+ abortSignal: abortController == null ? void 0 : abortController.signal,
1649
+ stream: ({ status, args }) => {
1650
+ const suggestions = args.suggestions || [];
1651
+ const newSuggestions = [];
1652
+ for (let i = 0; i < suggestions.length; i++) {
1653
+ if (config.maxSuggestions !== void 0 && i >= config.maxSuggestions) {
1654
+ break;
1655
+ }
1656
+ const { title, message } = suggestions[i];
1657
+ const partial = i == suggestions.length - 1 && status !== "complete";
1658
+ newSuggestions.push({
1659
+ title,
1660
+ message,
1661
+ partial,
1662
+ className: config.className
1663
+ });
1664
+ }
1665
+ setCurrentSuggestions([...allSuggestions, ...newSuggestions]);
1666
+ }
1667
+ });
1668
+ allSuggestions.push(...result.suggestions);
1669
+ } catch (error) {
1670
+ console.error("Error loading suggestions", error);
1671
+ }
1672
+ }
1673
+ if (abortControllerRef.current === abortController) {
1674
+ abortControllerRef.current = null;
1675
+ }
1676
+ });
1677
+
1678
+ // src/components/chat/Chat.tsx
1679
+ var import_react12 = __toESM(require("react"));
1680
+ var import_react_core8 = require("@copilotkit/react-core");
1681
+ var import_runtime_client_gql4 = require("@copilotkit/runtime-client-gql");
1682
+ var import_shared3 = require("@copilotkit/shared");
1683
+
1684
+ // src/components/dev-console/utils.ts
1685
+ var import_react_core6 = require("@copilotkit/react-core");
1686
+ function shouldShowDevConsole(showDevConsole) {
1687
+ if (typeof showDevConsole === "boolean") {
1688
+ return showDevConsole;
1689
+ }
1690
+ return getHostname() === "localhost" || getHostname() === "127.0.0.1" || getHostname() === "0.0.0.0" || getHostname() === "::1";
1691
+ }
1692
+ function getHostname() {
1693
+ if (typeof window !== "undefined" && window.location) {
1694
+ return window.location.hostname;
1695
+ }
1696
+ return "";
1697
+ }
1698
+ function getPublishedCopilotKitVersion(current, forceCheck = false) {
1699
+ return __async(this, null, function* () {
1700
+ const LOCAL_STORAGE_KEY = "__copilotkit_version_check__";
1701
+ const serializedVersion = localStorage.getItem(LOCAL_STORAGE_KEY);
1702
+ if (serializedVersion && !forceCheck) {
1703
+ try {
1704
+ const parsedVersion = JSON.parse(serializedVersion);
1705
+ const oneHour = 60 * 60 * 1e3;
1706
+ const now = (/* @__PURE__ */ new Date()).getTime();
1707
+ if (parsedVersion.current === current && now - new Date(parsedVersion.lastChecked).getTime() < oneHour) {
1708
+ return parsedVersion;
1709
+ }
1710
+ } catch (error) {
1711
+ console.error("Failed to parse CopilotKitVersion from localStorage", error);
1712
+ }
1713
+ }
1714
+ try {
1715
+ const response = yield fetch("https://api.cloud.stagingcopilotkit.ai/check-for-updates", {
1716
+ method: "POST",
1717
+ headers: {
1718
+ "Content-Type": "application/json"
1719
+ },
1720
+ body: JSON.stringify({
1721
+ packages: [
1722
+ {
1723
+ packageName: "@copilotkit/shared",
1724
+ packageVersion: current
1725
+ }
1726
+ ]
1727
+ })
1728
+ });
1729
+ const data = yield response.json();
1730
+ const version = {
1731
+ current,
1732
+ lastChecked: (/* @__PURE__ */ new Date()).getTime(),
1733
+ latest: data.packages[0].latestVersion,
1734
+ severity: data.packages[0].severity,
1735
+ advisory: data.packages[0].advisory || null
1736
+ };
1737
+ localStorage.setItem(LOCAL_STORAGE_KEY, JSON.stringify(version));
1738
+ return version;
1739
+ } catch (error) {
1740
+ console.error("Failed to check for updates", error);
1741
+ throw error;
1742
+ }
1743
+ });
1744
+ }
1745
+ function logReadables(context) {
1746
+ console.log("%cCurrent Readables:", "font-size: 16px; font-weight: bold;");
1747
+ const readables = context.getContextString([], import_react_core6.defaultCopilotContextCategories).trim();
1748
+ if (readables.length === 0) {
1749
+ console.log("No readables found");
1750
+ return;
1751
+ }
1752
+ console.log(readables);
1753
+ }
1754
+ function logActions(context) {
1755
+ console.log("%cCurrent Actions:", "font-size: 16px; font-weight: bold;");
1756
+ if (Object.values(context.actions).length === 0) {
1757
+ console.log("No actions found");
1758
+ return;
1759
+ }
1760
+ for (const action of Object.values(context.actions)) {
1761
+ console.group(action.name);
1762
+ console.log("name", action.name);
1763
+ console.log("description", action.description);
1764
+ console.log("parameters", action.parameters);
1765
+ console.groupEnd();
1766
+ }
1767
+ }
1768
+ function logMessages(context) {
1769
+ console.log("%cCurrent Messages:", "font-size: 16px; font-weight: bold;");
1770
+ if (context.messages.length === 0) {
1771
+ console.log("No messages found");
1772
+ return;
1773
+ }
1774
+ const tableData = context.messages.map((message) => {
1775
+ if (message.isTextMessage()) {
1776
+ return {
1777
+ id: message.id,
1778
+ type: "TextMessage",
1779
+ role: message.role,
1780
+ name: void 0,
1781
+ scope: void 0,
1782
+ content: message.content
1783
+ };
1784
+ } else if (message.isActionExecutionMessage()) {
1785
+ return {
1786
+ id: message.id,
1787
+ type: "ActionExecutionMessage",
1788
+ role: void 0,
1789
+ name: message.name,
1790
+ scope: message.parentMessageId,
1791
+ content: message.arguments
1792
+ };
1793
+ } else if (message.isResultMessage()) {
1794
+ return {
1795
+ id: message.id,
1796
+ type: "ResultMessage",
1797
+ role: void 0,
1798
+ name: message.actionName,
1799
+ scope: message.actionExecutionId,
1800
+ content: message.result
1801
+ };
1802
+ } else if (message.isAgentStateMessage()) {
1803
+ return {
1804
+ id: message.id,
1805
+ type: `AgentStateMessage (running: ${message.running})`,
1806
+ role: message.role,
1807
+ name: void 0,
1808
+ scope: message.threadId,
1809
+ content: message.state
1810
+ };
1811
+ }
1812
+ });
1813
+ console.table(tableData);
1814
+ }
1815
+
1816
+ // src/components/dev-console/console.tsx
1817
+ var import_react_core7 = require("@copilotkit/react-core");
1818
+ var import_react10 = require("react");
1819
+
1820
+ // src/components/dev-console/icons.tsx
1821
+ var import_jsx_runtime17 = require("react/jsx-runtime");
1822
+ var ExclamationMarkTriangleIcon = /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
1823
+ "svg",
1824
+ {
1825
+ width: "13.3967723px",
1826
+ height: "12px",
1827
+ viewBox: "0 0 13.3967723 12",
1828
+ version: "1.1",
1829
+ xmlns: "http://www.w3.org/2000/svg",
1830
+ children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("g", { id: "exclamation-triangle", fill: "#CD2121", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
1831
+ "path",
1832
+ {
1833
+ d: "M5.39935802,0.75 C5.97670802,-0.25 7.42007802,-0.25 7.99742802,0.75 L13.193588,9.75 C13.770888,10.75 13.049288,12 11.894588,12 L1.50223802,12 C0.34753802,12 -0.37414898,10.75 0.20319802,9.75 L5.39935802,0.75 Z M6.69838802,2.5 C7.11260802,2.5 7.44838802,2.83579 7.44838802,3.25 L7.44838802,6.25 C7.44838802,6.66421 7.11260802,7 6.69838802,7 C6.28417802,7 5.94838802,6.66421 5.94838802,6.25 L5.94838802,3.25 C5.94838802,2.83579 6.28417802,2.5 6.69838802,2.5 Z M6.69838802,10.5 C7.25067802,10.5 7.69838802,10.0523 7.69838802,9.5 C7.69838802,8.9477 7.25067802,8.5 6.69838802,8.5 C6.14610802,8.5 5.69838802,8.9477 5.69838802,9.5 C5.69838802,10.0523 6.14610802,10.5 6.69838802,10.5 Z",
1834
+ id: "Shape"
1835
+ }
1836
+ ) }) })
1837
+ }
1838
+ );
1839
+ var ExclamationMarkIcon = /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
1840
+ "svg",
1841
+ {
1842
+ width: "14px",
1843
+ height: "14px",
1844
+ viewBox: "0 0 14 14",
1845
+ version: "1.1",
1846
+ xmlns: "http://www.w3.org/2000/svg",
1847
+ children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("g", { id: "exclamation-circle", fill: "#EC662C", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
1848
+ "path",
1849
+ {
1850
+ d: "M7,14 C10.866,14 14,10.866 14,7 C14,3.13401 10.866,0 7,0 C3.13401,0 0,3.13401 0,7 C0,10.866 3.13401,14 7,14 Z M7,3 C7.41421,3 7.75,3.33579 7.75,3.75 L7.75,6.75 C7.75,7.16421 7.41421,7.5 7,7.5 C6.58579,7.5 6.25,7.16421 6.25,6.75 L6.25,3.75 C6.25,3.33579 6.58579,3 7,3 Z M7,11 C7.55228,11 8,10.5523 8,10 C8,9.4477 7.55228,9 7,9 C6.44772,9 6,9.4477 6,10 C6,10.5523 6.44772,11 7,11 Z",
1851
+ id: "Shape"
1852
+ }
1853
+ ) }) })
1854
+ }
1855
+ );
1856
+ var ChevronDownIcon = /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("svg", { width: "7px", height: "4px", viewBox: "0 0 7 4", version: "1.1", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("g", { id: "Group", fill: "#000000", fillRule: "nonzero", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
1857
+ "path",
1858
+ {
1859
+ d: "M3.71690723,3.90271086 C3.59268176,4.03242971 3.39143629,4.03242971 3.26721082,3.90271086 L0.0853966595,0.57605615 C-0.0314221035,0.444981627 -0.0279751448,0.240725043 0.0931934622,0.114040675 C0.214362069,-0.0126436935 0.409725445,-0.0162475626 0.535093061,0.105888951 L3.49205902,3.19746006 L6.44902499,0.105888951 C6.52834574,0.0168884389 6.64780588,-0.0197473458 6.7605411,0.0103538404 C6.87327633,0.0404550266 6.96130636,0.132492308 6.99009696,0.250359396 C7.01888756,0.368226483 6.98384687,0.493124608 6.89872139,0.57605615 L3.71690723,3.90271086 Z",
1860
+ id: "Path"
1861
+ }
1862
+ ) }) }) });
1863
+ var CheckIcon2 = /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
1864
+ "svg",
1865
+ {
1866
+ width: "14px",
1867
+ height: "14px",
1868
+ viewBox: "0 0 14 14",
1869
+ version: "1.1",
1870
+ xmlns: "http://www.w3.org/2000/svg",
1871
+ children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("g", { id: "Group-2", transform: "translate(-118, 0)", fill: "#1BC030", fillRule: "nonzero", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("g", { id: "Group", transform: "translate(118, 0)", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
1872
+ "path",
1873
+ {
1874
+ d: "M0,7 C0,3.13384615 3.13384615,0 7,0 C10.8661538,0 14,3.13384615 14,7 C14,10.8661538 10.8661538,14 7,14 C3.13384615,14 0,10.8661538 0,7 Z M9.59179487,5.69764103 C9.70905818,5.54139023 9.73249341,5.33388318 9.65303227,5.15541491 C9.57357113,4.97694665 9.40367989,4.85551619 9.20909814,4.83811118 C9.01451638,4.82070616 8.82577109,4.91005717 8.71589744,5.07158974 L6.39261538,8.32389744 L5.22666667,7.15794872 C5.01450582,6.96025518 4.68389046,6.9660885 4.47883563,7.17114332 C4.27378081,7.37619815 4.26794748,7.70681351 4.46564103,7.91897436 L6.08102564,9.53435897 C6.19289944,9.64614839 6.3482622,9.70310251 6.50588106,9.69010587 C6.66349993,9.67710922 6.80743532,9.59547613 6.89948718,9.46687179 L9.59179487,5.69764103 L9.59179487,5.69764103 Z",
1875
+ id: "Shape"
1876
+ }
1877
+ ) }) }) })
1878
+ }
1879
+ );
1880
+ var CopilotKitIcon = /* @__PURE__ */ (0, import_jsx_runtime17.jsxs)(
1881
+ "svg",
1882
+ {
1883
+ width: "33px",
1884
+ height: "35px",
1885
+ viewBox: "0 0 33 35",
1886
+ version: "1.1",
1887
+ xmlns: "http://www.w3.org/2000/svg",
1888
+ children: [
1889
+ /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("title", { children: "bd5c9079-929b-4d55-bdc9-16d1c8181b71" }),
1890
+ /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
1891
+ "image",
1892
+ {
1893
+ x: "0",
1894
+ y: "0",
1895
+ width: "33",
1896
+ height: "35",
1897
+ xlinkHref: ""
1898
+ }
1899
+ ) })
1900
+ ]
1901
+ }
1902
+ );
1903
+
1904
+ // src/components/dev-console/console.tsx
1905
+ var import_react11 = require("@headlessui/react");
1906
+ var import_shared2 = require("@copilotkit/shared");
1907
+
1908
+ // src/components/help-modal/modal.tsx
1909
+ var import_react9 = require("react");
1910
+
1911
+ // src/components/help-modal/icons.tsx
1912
+ var import_jsx_runtime18 = require("react/jsx-runtime");
1913
+ var CloseIcon2 = () => /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
1914
+ "svg",
1915
+ {
1916
+ xmlns: "http://www.w3.org/2000/svg",
1917
+ fill: "none",
1918
+ viewBox: "0 0 24 24",
1919
+ strokeWidth: "1.5",
1920
+ stroke: "currentColor",
1921
+ width: "20",
1922
+ height: "20",
1923
+ children: /* @__PURE__ */ (0, import_jsx_runtime18.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M6 18L18 6M6 6l12 12" })
1924
+ }
1925
+ );
1926
+ var LoadingSpinnerIcon = ({ color = "rgb(107 114 128)" }) => /* @__PURE__ */ (0, import_jsx_runtime18.jsxs)(
1927
+ "svg",
1928
+ {
1929
+ style: {
1930
+ animation: "copilotKitSpinAnimation 1s linear infinite",
1931
+ color
1932
+ },
1933
+ width: "24",
1934
+ height: "24",
1935
+ xmlns: "http://www.w3.org/2000/svg",
1936
+ fill: "none",
1937
+ viewBox: "0 0 24 24",
1938
+ children: [
1939
+ /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
1940
+ "circle",
1941
+ {
1942
+ style: { opacity: 0.25 },
1943
+ cx: "12",
1944
+ cy: "12",
1945
+ r: "10",
1946
+ stroke: "currentColor",
1947
+ strokeWidth: "4"
1948
+ }
1949
+ ),
1950
+ /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
1951
+ "path",
1952
+ {
1953
+ style: { opacity: 0.75 },
1954
+ fill: "currentColor",
1955
+ d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
1956
+ }
1957
+ )
1958
+ ]
1959
+ }
1960
+ );
1961
+
1962
+ // src/components/help-modal/modal.tsx
1963
+ var import_jsx_runtime19 = require("react/jsx-runtime");
1964
+ function CopilotKitHelpModal() {
1965
+ const [showHelpModal, setShowHelpModal] = (0, import_react9.useState)(false);
1966
+ const [issueDescription, setIssueDescription] = (0, import_react9.useState)("");
1967
+ const [email, setEmail] = (0, import_react9.useState)("");
1968
+ const [emailError, setEmailError] = (0, import_react9.useState)("");
1969
+ const [submitting, setSubmitting] = (0, import_react9.useState)(false);
1970
+ const validateEmail = (email2) => {
1971
+ const re = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/;
1972
+ return re.test(email2);
1973
+ };
1974
+ const handleSubmit = (e) => __async(this, null, function* () {
1975
+ e.preventDefault();
1976
+ if ((email == null ? void 0 : email.length) > 0 && !validateEmail(email)) {
1977
+ setEmailError("Please enter a valid email address");
1978
+ return;
1979
+ }
1980
+ setSubmitting(true);
1981
+ yield fetch("https://api.segment.io/v1/track", {
1982
+ method: "POST",
1983
+ headers: {
1984
+ "Content-Type": "application/json"
1985
+ },
1986
+ body: JSON.stringify({
1987
+ event: "oss.dev-console.help",
1988
+ anonymousId: window.crypto.randomUUID(),
1989
+ properties: { email, text: issueDescription },
1990
+ writeKey: "q0gQqvGYyw9pNyhIocNzefSYKGO1aiwW"
1991
+ })
1992
+ });
1993
+ setEmailError("");
1994
+ setEmail("");
1995
+ setIssueDescription("");
1996
+ setSubmitting(false);
1997
+ setShowHelpModal(false);
1998
+ });
1999
+ const HelpButton = () => /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
2000
+ "button",
2001
+ {
2002
+ onClick: () => setShowHelpModal(true),
2003
+ style: { width: "50px", height: "30px", marginRight: "0.25rem" },
2004
+ className: "text-sm p-0 bg-transparent rounded border border-blue-500",
2005
+ "aria-label": "Open Help",
2006
+ children: "Help"
2007
+ }
2008
+ );
2009
+ const submitButtonDisabled = (0, import_react9.useMemo)(
2010
+ () => submitting || !!emailError || issueDescription == null || (issueDescription == null ? void 0 : issueDescription.length) == 0,
2011
+ [submitting, emailError, issueDescription]
2012
+ );
2013
+ return /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)(import_jsx_runtime19.Fragment, { children: [
2014
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(HelpButton, {}),
2015
+ showHelpModal && /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
2016
+ "div",
2017
+ {
2018
+ className: "fixed inset-0 flex items-center justify-center p-4",
2019
+ style: { backgroundColor: "rgba(11, 15, 26, 0.5)", zIndex: 99 },
2020
+ children: /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)("div", { className: "bg-white rounded-lg shadow-xl max-w-md w-full p-4 flex-col relative", children: [
2021
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
2022
+ "button",
2023
+ {
2024
+ className: "absolute text-gray-400 hover:text-gray-600 focus:outline-none",
2025
+ style: { top: "10px", right: "10px" },
2026
+ onClick: () => setShowHelpModal(false),
2027
+ "aria-label": "Close",
2028
+ children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(CloseIcon2, {})
2029
+ }
2030
+ ),
2031
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("div", { className: "w-full flex mb-6 justify-center", children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("h2", { className: "text-2xl font-bold", children: "Help Options" }) }),
2032
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)("div", { className: "space-y-4 mb-4", children: [
2033
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("div", { className: "block w-full text-center py-2 px-4 bg-blue-500 text-white rounded hover:bg-blue-600 transition duration-150 text-sm", children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
2034
+ "a",
2035
+ {
2036
+ href: "https://docs.copilotkit.ai/coagents/troubleshooting/common-issues",
2037
+ target: "_blank",
2038
+ rel: "noopener noreferrer",
2039
+ children: "Visit the Troubleshooting and FAQ section in the docs"
2040
+ }
2041
+ ) }),
2042
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("div", { className: "block w-full text-center py-2 px-4 bg-blue-500 text-white rounded hover:bg-blue-600 transition duration-150 text-sm", children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
2043
+ "a",
2044
+ {
2045
+ href: "https://go.copilotkit.ai/dev-console-support-discord",
2046
+ target: "_blank",
2047
+ rel: "noopener noreferrer",
2048
+ children: "Go to Discord Support Channel (Community Support)"
2049
+ }
2050
+ ) }),
2051
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("div", { className: "block w-full text-center py-2 px-4 bg-blue-500 text-white rounded hover:bg-blue-600 transition duration-150 text-sm", children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
2052
+ "a",
2053
+ {
2054
+ href: "https://go.copilotkit.ai/dev-console-support-slack",
2055
+ target: "_blank",
2056
+ rel: "noopener noreferrer",
2057
+ children: "Apply for Priority Direct Slack Support"
2058
+ }
2059
+ ) })
2060
+ ] }),
2061
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)("form", { onSubmit: handleSubmit, className: "flex flex-col space-y-2", children: [
2062
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)("div", { children: [
2063
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("label", { htmlFor: "feedback", className: "block text-sm font-medium text-gray-700 mb-1", children: "Let us know what your issue is:" }),
2064
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
2065
+ "textarea",
2066
+ {
2067
+ id: "feedback",
2068
+ rows: 4,
2069
+ className: "w-full px-3 py-2 text-gray-700 border rounded-lg focus:outline-none focus:border-blue-500",
2070
+ placeholder: "A Loom link / screen recording is always great!",
2071
+ onChange: (e) => setIssueDescription(e.target.value),
2072
+ value: issueDescription,
2073
+ required: true
2074
+ }
2075
+ )
2076
+ ] }),
2077
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)("div", { children: [
2078
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("label", { htmlFor: "email", className: "block text-sm font-medium text-gray-700 mb-1", children: "Email (optional):" }),
2079
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
2080
+ "input",
2081
+ {
2082
+ type: "email",
2083
+ id: "email",
2084
+ className: `w-full px-3 py-2 text-gray-700 border rounded-lg focus:outline-none focus:border-blue-500 ${emailError ? "border-red-500" : ""}`,
2085
+ placeholder: "Enter your email for follow-up",
2086
+ onChange: (e) => {
2087
+ setEmail(e.target.value);
2088
+ setEmailError("");
2089
+ },
2090
+ value: email
2091
+ }
2092
+ ),
2093
+ emailError && /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("p", { className: "text-red-500 text-sm mt-1", children: emailError })
2094
+ ] }),
2095
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("div", { className: "bg-gray-50 px-4 py-4 sm:px-6 sm:flex sm:flex-row-reverse rounded-b-lg", children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
2096
+ "button",
2097
+ {
2098
+ type: "submit",
2099
+ onClick: handleSubmit,
2100
+ disabled: submitButtonDisabled,
2101
+ style: submitButtonDisabled ? { backgroundColor: "rgb(216, 216, 216)", color: "rgb(129, 129, 129)" } : void 0,
2102
+ className: "w-full inline-flex justify-center rounded-md border border-transparent shadow-sm px-4 py-2 bg-blue-500 text-base font-medium text-white hover:bg-blue-600 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500 sm:ml-3 sm:w-auto sm:text-sm disabled:shadow-none",
2103
+ children: submitting ? /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(LoadingSpinnerIcon, { color: "white" }) : "Submit"
2104
+ }
2105
+ ) })
2106
+ ] })
2107
+ ] })
2108
+ }
2109
+ )
2110
+ ] });
2111
+ }
2112
+
2113
+ // src/components/dev-console/console.tsx
2114
+ var import_jsx_runtime20 = require("react/jsx-runtime");
2115
+ function CopilotDevConsole() {
2116
+ const currentVersion = import_shared2.COPILOTKIT_VERSION;
2117
+ const context = (0, import_react_core7.useCopilotContext)();
2118
+ const [showDevConsole, setShowDevConsole] = (0, import_react10.useState)(false);
2119
+ (0, import_react10.useEffect)(() => {
2120
+ setShowDevConsole(shouldShowDevConsole(context.showDevConsole));
2121
+ }, [context.showDevConsole]);
2122
+ const dontRunTwiceInDevMode = (0, import_react10.useRef)(false);
2123
+ const [versionStatus, setVersionStatus] = (0, import_react10.useState)("unknown");
2124
+ const [latestVersion, setLatestVersion] = (0, import_react10.useState)("");
2125
+ const consoleRef = (0, import_react10.useRef)(null);
2126
+ const [debugButtonMode, setDebugButtonMode] = (0, import_react10.useState)("full");
2127
+ const checkForUpdates = (force = false) => {
2128
+ setVersionStatus("checking");
2129
+ getPublishedCopilotKitVersion(currentVersion, force).then((v) => {
2130
+ setLatestVersion(v.latest);
2131
+ let versionOk = false;
2132
+ if (v.current === v.latest) {
2133
+ versionOk = true;
2134
+ } else if (/[a-zA-Z]/.test(v.current)) {
2135
+ versionOk = true;
2136
+ }
2137
+ if (versionOk) {
2138
+ setVersionStatus("latest");
2139
+ } else if (v.severity !== "low") {
2140
+ setVersionStatus("outdated");
2141
+ } else {
2142
+ setVersionStatus("update-available");
2143
+ }
2144
+ }).catch((e) => {
2145
+ console.error(e);
2146
+ setVersionStatus("unknown");
2147
+ });
2148
+ };
2149
+ (0, import_react10.useEffect)(() => {
2150
+ if (dontRunTwiceInDevMode.current === true) {
2151
+ return;
2152
+ }
2153
+ dontRunTwiceInDevMode.current = true;
2154
+ checkForUpdates();
2155
+ }, []);
2156
+ (0, import_react10.useEffect)(() => {
2157
+ const handleResize = (entries) => {
2158
+ for (let entry of entries) {
2159
+ if (entry.target === consoleRef.current) {
2160
+ const width = entry.contentRect.width;
2161
+ if (width < 400) {
2162
+ setDebugButtonMode("compact");
2163
+ } else {
2164
+ setDebugButtonMode("full");
2165
+ }
2166
+ }
2167
+ }
2168
+ };
2169
+ const observer = new ResizeObserver(handleResize);
2170
+ if (consoleRef.current) {
2171
+ observer.observe(consoleRef.current);
2172
+ const initialWidth = consoleRef.current.getBoundingClientRect().width;
2173
+ if (initialWidth < 400) {
2174
+ setDebugButtonMode("compact");
2175
+ } else {
2176
+ setDebugButtonMode("full");
2177
+ }
2178
+ }
2179
+ return () => {
2180
+ if (consoleRef.current) {
2181
+ observer.unobserve(consoleRef.current);
2182
+ }
2183
+ };
2184
+ }, [consoleRef.current]);
2185
+ if (!showDevConsole) {
2186
+ return null;
2187
+ }
2188
+ return /* @__PURE__ */ (0, import_jsx_runtime20.jsxs)(
2189
+ "div",
2190
+ {
2191
+ ref: consoleRef,
2192
+ className: "copilotKitDevConsole " + (versionStatus === "update-available" ? "copilotKitDevConsoleUpgrade" : "") + (versionStatus === "outdated" ? "copilotKitDevConsoleWarnOutdated" : ""),
2193
+ children: [
2194
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsx)("div", { className: "copilotKitDevConsoleLogo", children: /* @__PURE__ */ (0, import_jsx_runtime20.jsx)("a", { href: "https://copilotkit.ai", target: "_blank", children: CopilotKitIcon }) }),
2195
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(
2196
+ VersionInfo,
2197
+ {
2198
+ showDevConsole: context.showDevConsole,
2199
+ versionStatus,
2200
+ currentVersion,
2201
+ latestVersion
2202
+ }
2203
+ ),
2204
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(CopilotKitHelpModal, {}),
2205
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(
2206
+ DebugMenuButton,
2207
+ {
2208
+ setShowDevConsole,
2209
+ checkForUpdates,
2210
+ mode: debugButtonMode
2211
+ }
2212
+ )
2213
+ ]
2214
+ }
2215
+ );
2216
+ }
2217
+ function VersionInfo({
2218
+ showDevConsole,
2219
+ versionStatus,
2220
+ currentVersion,
2221
+ latestVersion
2222
+ }) {
2223
+ const [copyStatus, setCopyStatus] = (0, import_react10.useState)("");
2224
+ let versionLabel = "";
2225
+ let versionIcon = "";
2226
+ let currentVersionLabel = currentVersion;
2227
+ if (versionStatus === "latest") {
2228
+ versionLabel = "latest";
2229
+ versionIcon = CheckIcon2;
2230
+ } else if (versionStatus === "checking") {
2231
+ versionLabel = "checking";
2232
+ versionIcon = SmallSpinnerIcon;
2233
+ } else if (versionStatus === "update-available") {
2234
+ versionLabel = "update available";
2235
+ versionIcon = ExclamationMarkIcon;
2236
+ currentVersionLabel = `${currentVersion} \u2192 ${latestVersion}`;
2237
+ } else if (versionStatus === "outdated") {
2238
+ versionLabel = "outdated";
2239
+ versionIcon = ExclamationMarkTriangleIcon;
2240
+ currentVersionLabel = `${currentVersion} \u2192 ${latestVersion}`;
2241
+ }
2242
+ let asideLabel = "";
2243
+ if (showDevConsole === "auto") {
2244
+ asideLabel = "(localhost only)";
2245
+ } else if (showDevConsole === true) {
2246
+ asideLabel = "(always on)";
2247
+ }
2248
+ const installCommand = [
2249
+ `npm install`,
2250
+ `@copilotkit/react-core@${latestVersion}`,
2251
+ `@copilotkit/react-ui@${latestVersion}`,
2252
+ `@copilotkit/react-textarea@${latestVersion}`
2253
+ ].join(" ");
2254
+ const handleCopyClick = () => {
2255
+ navigator.clipboard.writeText(installCommand.trim()).then(() => {
2256
+ setCopyStatus("Command copied to clipboard!");
2257
+ setTimeout(() => setCopyStatus(""), 1e3);
2258
+ });
2259
+ };
2260
+ return /* @__PURE__ */ (0, import_jsx_runtime20.jsxs)("div", { className: "copilotKitVersionInfo", children: [
2261
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsxs)("header", { children: [
2262
+ "COPILOTKIT DEV CONSOLE",
2263
+ showDevConsole === "auto" && /* @__PURE__ */ (0, import_jsx_runtime20.jsx)("aside", { children: asideLabel })
2264
+ ] }),
2265
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsxs)("section", { children: [
2266
+ "Version: ",
2267
+ versionLabel,
2268
+ " (",
2269
+ currentVersionLabel,
2270
+ ") ",
2271
+ versionIcon
2272
+ ] }),
2273
+ (versionStatus === "update-available" || versionStatus === "outdated") && /* @__PURE__ */ (0, import_jsx_runtime20.jsx)("footer", { children: /* @__PURE__ */ (0, import_jsx_runtime20.jsx)("button", { onClick: handleCopyClick, children: copyStatus || installCommand }) })
2274
+ ] });
2275
+ }
2276
+ function DebugMenuButton({
2277
+ setShowDevConsole,
2278
+ checkForUpdates,
2279
+ mode
2280
+ }) {
2281
+ const context = (0, import_react_core7.useCopilotContext)();
2282
+ const messagesContext = (0, import_react_core7.useCopilotMessagesContext)();
2283
+ return /* @__PURE__ */ (0, import_jsx_runtime20.jsx)("div", { className: "bg-black top-24 w-52 text-right", children: /* @__PURE__ */ (0, import_jsx_runtime20.jsxs)(import_react11.Menu, { children: [
2284
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(import_react11.MenuButton, { className: `copilotKitDebugMenuButton ${mode === "compact" ? "compact" : ""}`, children: mode == "compact" ? "Debug" : /* @__PURE__ */ (0, import_jsx_runtime20.jsxs)(import_jsx_runtime20.Fragment, { children: [
2285
+ "Debug ",
2286
+ ChevronDownIcon
2287
+ ] }) }),
2288
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsxs)(
2289
+ import_react11.MenuItems,
2290
+ {
2291
+ transition: true,
2292
+ anchor: "bottom end",
2293
+ className: "copilotKitDebugMenu",
2294
+ style: { zIndex: 40 },
2295
+ children: [
2296
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(import_react11.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime20.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => logReadables(context), children: "Log Readables" }) }),
2297
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(import_react11.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime20.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => logActions(context), children: "Log Actions" }) }),
2298
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(import_react11.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(
2299
+ "button",
2300
+ {
2301
+ className: "copilotKitDebugMenuItem",
2302
+ onClick: () => logMessages(messagesContext),
2303
+ children: "Log Messages"
2304
+ }
2305
+ ) }),
2306
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(import_react11.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime20.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => checkForUpdates(true), children: "Check for Updates" }) }),
2307
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsx)("hr", {}),
2308
+ /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(import_react11.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime20.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => setShowDevConsole(false), children: "Hide Dev Console" }) })
2309
+ ]
2310
+ }
2311
+ )
2312
+ ] }) });
2313
+ }
2314
+
2315
+ // src/components/chat/Chat.tsx
2316
+ var import_react_core9 = require("@copilotkit/react-core");
2317
+ var import_jsx_runtime21 = require("react/jsx-runtime");
2318
+ function CopilotChat({
2319
+ instructions,
2320
+ onSubmitMessage,
2321
+ makeSystemMessage,
2322
+ showResponseButton = true,
2323
+ onInProgress,
2324
+ onStopGeneration,
2325
+ onReloadMessages,
2326
+ Messages: Messages2 = Messages,
2327
+ RenderTextMessage: RenderTextMessage2 = RenderTextMessage,
2328
+ RenderActionExecutionMessage: RenderActionExecutionMessage2 = RenderActionExecutionMessage,
2329
+ RenderAgentStateMessage: RenderAgentStateMessage2 = RenderAgentStateMessage,
2330
+ RenderResultMessage: RenderResultMessage2 = RenderResultMessage,
2331
+ Input: Input2 = Input,
2332
+ ResponseButton: ResponseButton2 = ResponseButton,
2333
+ className,
2334
+ icons,
2335
+ labels
2336
+ }) {
2337
+ const context = (0, import_react_core8.useCopilotContext)();
2338
+ (0, import_react12.useEffect)(() => {
2339
+ context.setChatInstructions(instructions || "");
2340
+ }, [instructions]);
2341
+ const {
2342
+ visibleMessages,
2343
+ isLoading,
2344
+ currentSuggestions,
2345
+ sendMessage,
2346
+ stopGeneration,
2347
+ reloadMessages
2348
+ } = useCopilotChatLogic(
2349
+ makeSystemMessage,
2350
+ onInProgress,
2351
+ onSubmitMessage,
2352
+ onStopGeneration,
2353
+ onReloadMessages
2354
+ );
2355
+ const chatContext = import_react12.default.useContext(ChatContext);
2356
+ const isVisible = chatContext ? chatContext.open : true;
2357
+ return /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)(WrappedCopilotChat, { icons, labels, className, children: [
2358
+ /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(CopilotDevConsole, {}),
2359
+ /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)(
2360
+ Messages2,
2361
+ {
2362
+ RenderTextMessage: RenderTextMessage2,
2363
+ RenderActionExecutionMessage: RenderActionExecutionMessage2,
2364
+ RenderAgentStateMessage: RenderAgentStateMessage2,
2365
+ RenderResultMessage: RenderResultMessage2,
2366
+ messages: visibleMessages,
2367
+ inProgress: isLoading,
2368
+ children: [
2369
+ currentSuggestions.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)("div", { children: [
2370
+ /* @__PURE__ */ (0, import_jsx_runtime21.jsx)("h6", { children: "Suggested:" }),
2371
+ /* @__PURE__ */ (0, import_jsx_runtime21.jsx)("div", { className: "suggestions", children: currentSuggestions.map((suggestion, index) => /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(
2372
+ Suggestion,
2373
+ {
2374
+ title: suggestion.title,
2375
+ message: suggestion.message,
2376
+ partial: suggestion.partial,
2377
+ className: suggestion.className,
2378
+ onClick: (message) => sendMessage(message)
2379
+ },
2380
+ index
2381
+ )) })
2382
+ ] }),
2383
+ showResponseButton && visibleMessages.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(
2384
+ ResponseButton2,
2385
+ {
2386
+ onClick: isLoading ? stopGeneration : reloadMessages,
2387
+ inProgress: isLoading
2388
+ }
2389
+ )
2390
+ ]
2391
+ }
2392
+ ),
2393
+ /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(Input2, { inProgress: isLoading, onSend: sendMessage, isVisible })
2394
+ ] });
2395
+ }
2396
+ function WrappedCopilotChat({
2397
+ children,
2398
+ icons,
2399
+ labels,
2400
+ className
2401
+ }) {
2402
+ const chatContext = import_react12.default.useContext(ChatContext);
2403
+ if (!chatContext) {
2404
+ return /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(ChatContextProvider, { icons, labels, open: true, setOpen: () => {
2405
+ }, children: /* @__PURE__ */ (0, import_jsx_runtime21.jsx)("div", { className: `copilotKitChat ${className}`, children }) });
2406
+ }
2407
+ return /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(import_jsx_runtime21.Fragment, { children });
2408
+ }
2409
+ var SUGGESTIONS_DEBOUNCE_TIMEOUT = 1e3;
2410
+ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onStopGeneration, onReloadMessages) => {
2411
+ var _a;
2412
+ const {
2413
+ visibleMessages,
2414
+ appendMessage,
2415
+ reloadMessages: defaultReloadMessages,
2416
+ stopGeneration: defaultStopGeneration,
2417
+ runChatCompletion,
2418
+ isLoading
2419
+ } = (0, import_react_core8.useCopilotChat)({
2420
+ id: (0, import_shared3.randomId)(),
2421
+ makeSystemMessage
2422
+ });
2423
+ const [currentSuggestions, setCurrentSuggestions] = (0, import_react12.useState)([]);
2424
+ const suggestionsAbortControllerRef = (0, import_react12.useRef)(null);
2425
+ const debounceTimerRef = (0, import_react12.useRef)();
2426
+ const abortSuggestions = () => {
2427
+ var _a2;
2428
+ (_a2 = suggestionsAbortControllerRef.current) == null ? void 0 : _a2.abort();
2429
+ suggestionsAbortControllerRef.current = null;
2430
+ };
2431
+ const generalContext = (0, import_react_core8.useCopilotContext)();
2432
+ const messagesContext = (0, import_react_core8.useCopilotMessagesContext)();
2433
+ const context = __spreadValues(__spreadValues({}, generalContext), messagesContext);
2434
+ (0, import_react12.useEffect)(() => {
2435
+ onInProgress == null ? void 0 : onInProgress(isLoading);
2436
+ abortSuggestions();
2437
+ debounceTimerRef.current = setTimeout(
2438
+ () => {
2439
+ if (!isLoading && Object.keys(context.chatSuggestionConfiguration).length !== 0) {
2440
+ suggestionsAbortControllerRef.current = new AbortController();
2441
+ reloadSuggestions(
2442
+ context,
2443
+ context.chatSuggestionConfiguration,
2444
+ setCurrentSuggestions,
2445
+ suggestionsAbortControllerRef
2446
+ );
2447
+ }
2448
+ },
2449
+ currentSuggestions.length == 0 ? 0 : SUGGESTIONS_DEBOUNCE_TIMEOUT
2450
+ );
2451
+ return () => {
2452
+ clearTimeout(debounceTimerRef.current);
2453
+ };
2454
+ }, [
2455
+ isLoading,
2456
+ context.chatSuggestionConfiguration,
2457
+ // hackish way to trigger suggestions reload on reset, but better than moving suggestions to the
2458
+ // global context
2459
+ visibleMessages.length == 0
2460
+ ]);
2461
+ const sendMessage = (messageContent) => __async(void 0, null, function* () {
2462
+ abortSuggestions();
2463
+ setCurrentSuggestions([]);
2464
+ const message = new import_runtime_client_gql4.TextMessage({
2465
+ content: messageContent,
2466
+ role: import_runtime_client_gql4.Role.User
2467
+ });
2468
+ if (onSubmitMessage) {
2469
+ try {
2470
+ yield onSubmitMessage(messageContent);
2471
+ } catch (error) {
2472
+ console.error("Error in onSubmitMessage:", error);
2473
+ }
2474
+ }
2475
+ appendMessage(message);
2476
+ return message;
2477
+ });
2478
+ const messages = visibleMessages;
2479
+ const { setMessages } = messagesContext;
2480
+ const currentAgentName = (_a = generalContext.agentSession) == null ? void 0 : _a.agentName;
2481
+ const restartCurrentAgent = (hint) => __async(void 0, null, function* () {
2482
+ if (generalContext.agentSession) {
2483
+ generalContext.setAgentSession(__spreadProps(__spreadValues({}, generalContext.agentSession), {
2484
+ nodeName: void 0,
2485
+ threadId: void 0
2486
+ }));
2487
+ generalContext.setCoagentStates((prevAgentStates) => {
2488
+ return __spreadProps(__spreadValues({}, prevAgentStates), {
2489
+ [generalContext.agentSession.agentName]: __spreadProps(__spreadValues({}, prevAgentStates[generalContext.agentSession.agentName]), {
2490
+ threadId: void 0,
2491
+ nodeName: void 0,
2492
+ runId: void 0
2493
+ })
2494
+ });
2495
+ });
2496
+ }
2497
+ });
2498
+ const runCurrentAgent = (hint) => __async(void 0, null, function* () {
2499
+ if (generalContext.agentSession) {
2500
+ yield (0, import_react_core9.runAgent)(
2501
+ generalContext.agentSession.agentName,
2502
+ context,
2503
+ appendMessage,
2504
+ runChatCompletion,
2505
+ hint
2506
+ );
2507
+ }
2508
+ });
2509
+ const stopCurrentAgent = () => {
2510
+ if (generalContext.agentSession) {
2511
+ (0, import_react_core9.stopAgent)(generalContext.agentSession.agentName, context);
2512
+ }
2513
+ };
2514
+ const setCurrentAgentState = (state) => {
2515
+ if (generalContext.agentSession) {
2516
+ generalContext.setCoagentStates((prevAgentStates) => {
2517
+ return __spreadProps(__spreadValues({}, prevAgentStates), {
2518
+ [generalContext.agentSession.agentName]: {
2519
+ state
2520
+ }
2521
+ });
2522
+ });
2523
+ }
2524
+ };
2525
+ function stopGeneration() {
2526
+ if (onStopGeneration) {
2527
+ onStopGeneration({
2528
+ messages,
2529
+ setMessages,
2530
+ stopGeneration: defaultStopGeneration,
2531
+ currentAgentName,
2532
+ restartCurrentAgent,
2533
+ stopCurrentAgent,
2534
+ runCurrentAgent,
2535
+ setCurrentAgentState
2536
+ });
2537
+ } else {
2538
+ defaultStopGeneration();
2539
+ }
2540
+ }
2541
+ function reloadMessages() {
2542
+ if (onReloadMessages) {
2543
+ onReloadMessages({
2544
+ messages,
2545
+ setMessages,
2546
+ stopGeneration: defaultStopGeneration,
2547
+ currentAgentName,
2548
+ restartCurrentAgent,
2549
+ stopCurrentAgent,
2550
+ runCurrentAgent,
2551
+ setCurrentAgentState
2552
+ });
2553
+ } else {
2554
+ defaultReloadMessages();
2555
+ }
2556
+ }
2557
+ return {
2558
+ visibleMessages,
2559
+ isLoading,
2560
+ currentSuggestions,
2561
+ sendMessage,
2562
+ stopGeneration,
2563
+ reloadMessages
2564
+ };
2565
+ };
2566
+
2567
+ // src/components/chat/Modal.tsx
2568
+ var import_jsx_runtime22 = require("react/jsx-runtime");
2569
+ var CopilotModal = ({
2570
+ instructions,
2571
+ defaultOpen = false,
2572
+ clickOutsideToClose = true,
2573
+ hitEscapeToClose = true,
2574
+ onSetOpen,
2575
+ onSubmitMessage,
2576
+ onStopGeneration,
2577
+ onReloadMessages,
2578
+ shortcut = "/",
2579
+ icons,
2580
+ labels,
2581
+ makeSystemMessage,
2582
+ showResponseButton = true,
2583
+ onInProgress,
2584
+ Window: Window2 = Window,
2585
+ Button: Button2 = Button,
2586
+ Header: Header2 = Header,
2587
+ Messages: Messages2 = Messages,
2588
+ Input: Input2 = Input,
2589
+ ResponseButton: ResponseButton2 = ResponseButton,
2590
+ className,
2591
+ children
2592
+ }) => {
2593
+ const [openState, setOpenState] = import_react13.default.useState(defaultOpen);
2594
+ const setOpen = (open) => {
2595
+ onSetOpen == null ? void 0 : onSetOpen(open);
2596
+ setOpenState(open);
2597
+ };
2598
+ return /* @__PURE__ */ (0, import_jsx_runtime22.jsxs)(ChatContextProvider, { icons, labels, open: openState, setOpen, children: [
2599
+ children,
2600
+ /* @__PURE__ */ (0, import_jsx_runtime22.jsxs)("div", { className, children: [
2601
+ /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(Button2, {}),
2602
+ /* @__PURE__ */ (0, import_jsx_runtime22.jsxs)(
2603
+ Window2,
2604
+ {
2605
+ clickOutsideToClose,
2606
+ shortcut,
2607
+ hitEscapeToClose,
2608
+ children: [
2609
+ /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(Header2, {}),
2610
+ /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(
2611
+ CopilotChat,
2612
+ {
2613
+ instructions,
2614
+ onSubmitMessage,
2615
+ onStopGeneration,
2616
+ onReloadMessages,
2617
+ makeSystemMessage,
2618
+ showResponseButton,
2619
+ onInProgress,
2620
+ Messages: Messages2,
2621
+ Input: Input2,
2622
+ ResponseButton: ResponseButton2
2623
+ }
2624
+ )
2625
+ ]
2626
+ }
2627
+ )
2628
+ ] })
2629
+ ] });
2630
+ };
2631
+
2632
+ // src/components/chat/Popup.tsx
2633
+ var import_jsx_runtime23 = require("react/jsx-runtime");
2634
+ function CopilotPopup(props) {
2635
+ props = __spreadProps(__spreadValues({}, props), {
2636
+ className: props.className ? props.className + " copilotKitPopup" : "copilotKitPopup"
2637
+ });
2638
+ return /* @__PURE__ */ (0, import_jsx_runtime23.jsx)(CopilotModal, __spreadProps(__spreadValues({}, props), { children: props.children }));
2639
+ }
2640
+
2641
+ // src/components/chat/Sidebar.tsx
2642
+ var import_react14 = require("react");
2643
+ var import_jsx_runtime24 = require("react/jsx-runtime");
2644
+ function CopilotSidebar(props) {
2645
+ props = __spreadProps(__spreadValues({}, props), {
2646
+ className: props.className ? props.className + " copilotKitSidebar" : "copilotKitSidebar"
2647
+ });
2648
+ const [expandedClassName, setExpandedClassName] = (0, import_react14.useState)(
2649
+ props.defaultOpen ? "sidebarExpanded" : ""
2650
+ );
2651
+ const onSetOpen = (open) => {
2652
+ var _a;
2653
+ (_a = props.onSetOpen) == null ? void 0 : _a.call(props, open);
2654
+ setExpandedClassName(open ? "sidebarExpanded" : "");
2655
+ };
2656
+ return /* @__PURE__ */ (0, import_jsx_runtime24.jsx)("div", { className: `copilotKitSidebarContentWrapper ${expandedClassName}`, children: /* @__PURE__ */ (0, import_jsx_runtime24.jsx)(CopilotModal, __spreadProps(__spreadValues(__spreadValues({}, props), { onSetOpen }), { children: props.children })) });
2657
+ }
2658
+
2659
+ // src/hooks/use-copilot-chat-suggestions.tsx
2660
+ var import_react15 = require("react");
2661
+ var import_react_core10 = require("@copilotkit/react-core");
2662
+ var import_shared4 = require("@copilotkit/shared");
2663
+ function useCopilotChatSuggestions({
2664
+ instructions,
2665
+ className,
2666
+ minSuggestions = 1,
2667
+ maxSuggestions = 3
2668
+ }, dependencies = []) {
2669
+ const context = (0, import_react_core10.useCopilotContext)();
2670
+ (0, import_react15.useEffect)(() => {
2671
+ const id = (0, import_shared4.randomId)();
2672
+ context.addChatSuggestionConfiguration(id, {
2673
+ instructions,
2674
+ minSuggestions,
2675
+ maxSuggestions,
2676
+ className
2677
+ });
2678
+ return () => {
2679
+ context.removeChatSuggestionConfiguration(id);
2680
+ };
2681
+ }, [...dependencies, instructions, minSuggestions, maxSuggestions, className]);
2682
+ }
2683
+ // Annotate the CommonJS export names for ESM import in node:
2684
+ 0 && (module.exports = {
2685
+ CopilotChat,
2686
+ CopilotDevConsole,
2687
+ CopilotPopup,
2688
+ CopilotSidebar,
2689
+ shouldShowDevConsole,
2690
+ useChatContext,
2691
+ useCopilotChatSuggestions
2692
+ });
2693
+ //# sourceMappingURL=index.js.map