@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
@@ -0,0 +1,720 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var __async = (__this, __arguments, generator) => {
20
+ return new Promise((resolve, reject) => {
21
+ var fulfilled = (value) => {
22
+ try {
23
+ step(generator.next(value));
24
+ } catch (e) {
25
+ reject(e);
26
+ }
27
+ };
28
+ var rejected = (value) => {
29
+ try {
30
+ step(generator.throw(value));
31
+ } catch (e) {
32
+ reject(e);
33
+ }
34
+ };
35
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
36
+ step((generator = generator.apply(__this, __arguments)).next());
37
+ });
38
+ };
39
+
40
+ // src/components/dev-console/index.tsx
41
+ var dev_console_exports = {};
42
+ __export(dev_console_exports, {
43
+ CopilotDevConsole: () => CopilotDevConsole,
44
+ shouldShowDevConsole: () => shouldShowDevConsole
45
+ });
46
+ module.exports = __toCommonJS(dev_console_exports);
47
+
48
+ // src/components/dev-console/utils.ts
49
+ var import_react_core = require("@copilotkit/react-core");
50
+ function shouldShowDevConsole(showDevConsole) {
51
+ if (typeof showDevConsole === "boolean") {
52
+ return showDevConsole;
53
+ }
54
+ return getHostname() === "localhost" || getHostname() === "127.0.0.1" || getHostname() === "0.0.0.0" || getHostname() === "::1";
55
+ }
56
+ function getHostname() {
57
+ if (typeof window !== "undefined" && window.location) {
58
+ return window.location.hostname;
59
+ }
60
+ return "";
61
+ }
62
+ function getPublishedCopilotKitVersion(current, forceCheck = false) {
63
+ return __async(this, null, function* () {
64
+ const LOCAL_STORAGE_KEY = "__copilotkit_version_check__";
65
+ const serializedVersion = localStorage.getItem(LOCAL_STORAGE_KEY);
66
+ if (serializedVersion && !forceCheck) {
67
+ try {
68
+ const parsedVersion = JSON.parse(serializedVersion);
69
+ const oneHour = 60 * 60 * 1e3;
70
+ const now = (/* @__PURE__ */ new Date()).getTime();
71
+ if (parsedVersion.current === current && now - new Date(parsedVersion.lastChecked).getTime() < oneHour) {
72
+ return parsedVersion;
73
+ }
74
+ } catch (error) {
75
+ console.error("Failed to parse CopilotKitVersion from localStorage", error);
76
+ }
77
+ }
78
+ try {
79
+ const response = yield fetch("https://api.cloud.stagingcopilotkit.ai/check-for-updates", {
80
+ method: "POST",
81
+ headers: {
82
+ "Content-Type": "application/json"
83
+ },
84
+ body: JSON.stringify({
85
+ packages: [
86
+ {
87
+ packageName: "@copilotkit/shared",
88
+ packageVersion: current
89
+ }
90
+ ]
91
+ })
92
+ });
93
+ const data = yield response.json();
94
+ const version = {
95
+ current,
96
+ lastChecked: (/* @__PURE__ */ new Date()).getTime(),
97
+ latest: data.packages[0].latestVersion,
98
+ severity: data.packages[0].severity,
99
+ advisory: data.packages[0].advisory || null
100
+ };
101
+ localStorage.setItem(LOCAL_STORAGE_KEY, JSON.stringify(version));
102
+ return version;
103
+ } catch (error) {
104
+ console.error("Failed to check for updates", error);
105
+ throw error;
106
+ }
107
+ });
108
+ }
109
+ function logReadables(context) {
110
+ console.log("%cCurrent Readables:", "font-size: 16px; font-weight: bold;");
111
+ const readables = context.getContextString([], import_react_core.defaultCopilotContextCategories).trim();
112
+ if (readables.length === 0) {
113
+ console.log("No readables found");
114
+ return;
115
+ }
116
+ console.log(readables);
117
+ }
118
+ function logActions(context) {
119
+ console.log("%cCurrent Actions:", "font-size: 16px; font-weight: bold;");
120
+ if (Object.values(context.actions).length === 0) {
121
+ console.log("No actions found");
122
+ return;
123
+ }
124
+ for (const action of Object.values(context.actions)) {
125
+ console.group(action.name);
126
+ console.log("name", action.name);
127
+ console.log("description", action.description);
128
+ console.log("parameters", action.parameters);
129
+ console.groupEnd();
130
+ }
131
+ }
132
+ function logMessages(context) {
133
+ console.log("%cCurrent Messages:", "font-size: 16px; font-weight: bold;");
134
+ if (context.messages.length === 0) {
135
+ console.log("No messages found");
136
+ return;
137
+ }
138
+ const tableData = context.messages.map((message) => {
139
+ if (message.isTextMessage()) {
140
+ return {
141
+ id: message.id,
142
+ type: "TextMessage",
143
+ role: message.role,
144
+ name: void 0,
145
+ scope: void 0,
146
+ content: message.content
147
+ };
148
+ } else if (message.isActionExecutionMessage()) {
149
+ return {
150
+ id: message.id,
151
+ type: "ActionExecutionMessage",
152
+ role: void 0,
153
+ name: message.name,
154
+ scope: message.parentMessageId,
155
+ content: message.arguments
156
+ };
157
+ } else if (message.isResultMessage()) {
158
+ return {
159
+ id: message.id,
160
+ type: "ResultMessage",
161
+ role: void 0,
162
+ name: message.actionName,
163
+ scope: message.actionExecutionId,
164
+ content: message.result
165
+ };
166
+ } else if (message.isAgentStateMessage()) {
167
+ return {
168
+ id: message.id,
169
+ type: `AgentStateMessage (running: ${message.running})`,
170
+ role: message.role,
171
+ name: void 0,
172
+ scope: message.threadId,
173
+ content: message.state
174
+ };
175
+ }
176
+ });
177
+ console.table(tableData);
178
+ }
179
+
180
+ // src/components/dev-console/console.tsx
181
+ var import_react_core2 = require("@copilotkit/react-core");
182
+ var import_react2 = require("react");
183
+
184
+ // src/components/dev-console/icons.tsx
185
+ var import_jsx_runtime = require("react/jsx-runtime");
186
+ var ExclamationMarkTriangleIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
187
+ "svg",
188
+ {
189
+ width: "13.3967723px",
190
+ height: "12px",
191
+ viewBox: "0 0 13.3967723 12",
192
+ version: "1.1",
193
+ xmlns: "http://www.w3.org/2000/svg",
194
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { id: "exclamation-triangle", fill: "#CD2121", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
195
+ "path",
196
+ {
197
+ 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",
198
+ id: "Shape"
199
+ }
200
+ ) }) })
201
+ }
202
+ );
203
+ var ExclamationMarkIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
204
+ "svg",
205
+ {
206
+ width: "14px",
207
+ height: "14px",
208
+ viewBox: "0 0 14 14",
209
+ version: "1.1",
210
+ xmlns: "http://www.w3.org/2000/svg",
211
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { id: "exclamation-circle", fill: "#EC662C", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
212
+ "path",
213
+ {
214
+ 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",
215
+ id: "Shape"
216
+ }
217
+ ) }) })
218
+ }
219
+ );
220
+ var ChevronDownIcon = /* @__PURE__ */ (0, import_jsx_runtime.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_runtime.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { id: "Group", fill: "#000000", fillRule: "nonzero", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
221
+ "path",
222
+ {
223
+ 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",
224
+ id: "Path"
225
+ }
226
+ ) }) }) });
227
+ var CheckIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
228
+ "svg",
229
+ {
230
+ width: "14px",
231
+ height: "14px",
232
+ viewBox: "0 0 14 14",
233
+ version: "1.1",
234
+ xmlns: "http://www.w3.org/2000/svg",
235
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { id: "Group-2", transform: "translate(-118, 0)", fill: "#1BC030", fillRule: "nonzero", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { id: "Group", transform: "translate(118, 0)", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
236
+ "path",
237
+ {
238
+ 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",
239
+ id: "Shape"
240
+ }
241
+ ) }) }) })
242
+ }
243
+ );
244
+ var CopilotKitIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
245
+ "svg",
246
+ {
247
+ width: "33px",
248
+ height: "35px",
249
+ viewBox: "0 0 33 35",
250
+ version: "1.1",
251
+ xmlns: "http://www.w3.org/2000/svg",
252
+ children: [
253
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("title", { children: "bd5c9079-929b-4d55-bdc9-16d1c8181b71" }),
254
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
255
+ "image",
256
+ {
257
+ x: "0",
258
+ y: "0",
259
+ width: "33",
260
+ height: "35",
261
+ xlinkHref: ""
262
+ }
263
+ ) })
264
+ ]
265
+ }
266
+ );
267
+
268
+ // src/components/dev-console/console.tsx
269
+ var import_react3 = require("@headlessui/react");
270
+ var import_shared = require("@copilotkit/shared");
271
+
272
+ // src/components/chat/Icons.tsx
273
+ var import_jsx_runtime2 = require("react/jsx-runtime");
274
+ var SmallSpinnerIcon = /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
275
+ "svg",
276
+ {
277
+ style: {
278
+ animation: "copilotKitSpinAnimation 1s linear infinite"
279
+ },
280
+ width: "13",
281
+ height: "13",
282
+ xmlns: "http://www.w3.org/2000/svg",
283
+ fill: "none",
284
+ viewBox: "0 0 24 24",
285
+ children: [
286
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
287
+ "circle",
288
+ {
289
+ style: { opacity: 0.25 },
290
+ cx: "12",
291
+ cy: "12",
292
+ r: "10",
293
+ stroke: "currentColor",
294
+ strokeWidth: "4"
295
+ }
296
+ ),
297
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
298
+ "path",
299
+ {
300
+ style: { opacity: 0.75 },
301
+ fill: "currentColor",
302
+ 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"
303
+ }
304
+ )
305
+ ]
306
+ }
307
+ );
308
+
309
+ // src/components/help-modal/modal.tsx
310
+ var import_react = require("react");
311
+
312
+ // src/components/help-modal/icons.tsx
313
+ var import_jsx_runtime3 = require("react/jsx-runtime");
314
+ var CloseIcon = () => /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
315
+ "svg",
316
+ {
317
+ xmlns: "http://www.w3.org/2000/svg",
318
+ fill: "none",
319
+ viewBox: "0 0 24 24",
320
+ strokeWidth: "1.5",
321
+ stroke: "currentColor",
322
+ width: "20",
323
+ height: "20",
324
+ children: /* @__PURE__ */ (0, import_jsx_runtime3.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M6 18L18 6M6 6l12 12" })
325
+ }
326
+ );
327
+ var LoadingSpinnerIcon = ({ color = "rgb(107 114 128)" }) => /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(
328
+ "svg",
329
+ {
330
+ style: {
331
+ animation: "copilotKitSpinAnimation 1s linear infinite",
332
+ color
333
+ },
334
+ width: "24",
335
+ height: "24",
336
+ xmlns: "http://www.w3.org/2000/svg",
337
+ fill: "none",
338
+ viewBox: "0 0 24 24",
339
+ children: [
340
+ /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
341
+ "circle",
342
+ {
343
+ style: { opacity: 0.25 },
344
+ cx: "12",
345
+ cy: "12",
346
+ r: "10",
347
+ stroke: "currentColor",
348
+ strokeWidth: "4"
349
+ }
350
+ ),
351
+ /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
352
+ "path",
353
+ {
354
+ style: { opacity: 0.75 },
355
+ fill: "currentColor",
356
+ 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"
357
+ }
358
+ )
359
+ ]
360
+ }
361
+ );
362
+
363
+ // src/components/help-modal/modal.tsx
364
+ var import_jsx_runtime4 = require("react/jsx-runtime");
365
+ function CopilotKitHelpModal() {
366
+ const [showHelpModal, setShowHelpModal] = (0, import_react.useState)(false);
367
+ const [issueDescription, setIssueDescription] = (0, import_react.useState)("");
368
+ const [email, setEmail] = (0, import_react.useState)("");
369
+ const [emailError, setEmailError] = (0, import_react.useState)("");
370
+ const [submitting, setSubmitting] = (0, import_react.useState)(false);
371
+ const validateEmail = (email2) => {
372
+ const re = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/;
373
+ return re.test(email2);
374
+ };
375
+ const handleSubmit = (e) => __async(this, null, function* () {
376
+ e.preventDefault();
377
+ if ((email == null ? void 0 : email.length) > 0 && !validateEmail(email)) {
378
+ setEmailError("Please enter a valid email address");
379
+ return;
380
+ }
381
+ setSubmitting(true);
382
+ yield fetch("https://api.segment.io/v1/track", {
383
+ method: "POST",
384
+ headers: {
385
+ "Content-Type": "application/json"
386
+ },
387
+ body: JSON.stringify({
388
+ event: "oss.dev-console.help",
389
+ anonymousId: window.crypto.randomUUID(),
390
+ properties: { email, text: issueDescription },
391
+ writeKey: "q0gQqvGYyw9pNyhIocNzefSYKGO1aiwW"
392
+ })
393
+ });
394
+ setEmailError("");
395
+ setEmail("");
396
+ setIssueDescription("");
397
+ setSubmitting(false);
398
+ setShowHelpModal(false);
399
+ });
400
+ const HelpButton = () => /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
401
+ "button",
402
+ {
403
+ onClick: () => setShowHelpModal(true),
404
+ style: { width: "50px", height: "30px", marginRight: "0.25rem" },
405
+ className: "text-sm p-0 bg-transparent rounded border border-blue-500",
406
+ "aria-label": "Open Help",
407
+ children: "Help"
408
+ }
409
+ );
410
+ const submitButtonDisabled = (0, import_react.useMemo)(
411
+ () => submitting || !!emailError || issueDescription == null || (issueDescription == null ? void 0 : issueDescription.length) == 0,
412
+ [submitting, emailError, issueDescription]
413
+ );
414
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)(import_jsx_runtime4.Fragment, { children: [
415
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(HelpButton, {}),
416
+ showHelpModal && /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
417
+ "div",
418
+ {
419
+ className: "fixed inset-0 flex items-center justify-center p-4",
420
+ style: { backgroundColor: "rgba(11, 15, 26, 0.5)", zIndex: 99 },
421
+ children: /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "bg-white rounded-lg shadow-xl max-w-md w-full p-4 flex-col relative", children: [
422
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
423
+ "button",
424
+ {
425
+ className: "absolute text-gray-400 hover:text-gray-600 focus:outline-none",
426
+ style: { top: "10px", right: "10px" },
427
+ onClick: () => setShowHelpModal(false),
428
+ "aria-label": "Close",
429
+ children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(CloseIcon, {})
430
+ }
431
+ ),
432
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { className: "w-full flex mb-6 justify-center", children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("h2", { className: "text-2xl font-bold", children: "Help Options" }) }),
433
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "space-y-4 mb-4", children: [
434
+ /* @__PURE__ */ (0, import_jsx_runtime4.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_runtime4.jsx)(
435
+ "a",
436
+ {
437
+ href: "https://docs.copilotkit.ai/coagents/troubleshooting/common-issues",
438
+ target: "_blank",
439
+ rel: "noopener noreferrer",
440
+ children: "Visit the Troubleshooting and FAQ section in the docs"
441
+ }
442
+ ) }),
443
+ /* @__PURE__ */ (0, import_jsx_runtime4.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_runtime4.jsx)(
444
+ "a",
445
+ {
446
+ href: "https://go.copilotkit.ai/dev-console-support-discord",
447
+ target: "_blank",
448
+ rel: "noopener noreferrer",
449
+ children: "Go to Discord Support Channel (Community Support)"
450
+ }
451
+ ) }),
452
+ /* @__PURE__ */ (0, import_jsx_runtime4.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_runtime4.jsx)(
453
+ "a",
454
+ {
455
+ href: "https://go.copilotkit.ai/dev-console-support-slack",
456
+ target: "_blank",
457
+ rel: "noopener noreferrer",
458
+ children: "Apply for Priority Direct Slack Support"
459
+ }
460
+ ) })
461
+ ] }),
462
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("form", { onSubmit: handleSubmit, className: "flex flex-col space-y-2", children: [
463
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { children: [
464
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("label", { htmlFor: "feedback", className: "block text-sm font-medium text-gray-700 mb-1", children: "Let us know what your issue is:" }),
465
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
466
+ "textarea",
467
+ {
468
+ id: "feedback",
469
+ rows: 4,
470
+ className: "w-full px-3 py-2 text-gray-700 border rounded-lg focus:outline-none focus:border-blue-500",
471
+ placeholder: "A Loom link / screen recording is always great!",
472
+ onChange: (e) => setIssueDescription(e.target.value),
473
+ value: issueDescription,
474
+ required: true
475
+ }
476
+ )
477
+ ] }),
478
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { children: [
479
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("label", { htmlFor: "email", className: "block text-sm font-medium text-gray-700 mb-1", children: "Email (optional):" }),
480
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
481
+ "input",
482
+ {
483
+ type: "email",
484
+ id: "email",
485
+ className: `w-full px-3 py-2 text-gray-700 border rounded-lg focus:outline-none focus:border-blue-500 ${emailError ? "border-red-500" : ""}`,
486
+ placeholder: "Enter your email for follow-up",
487
+ onChange: (e) => {
488
+ setEmail(e.target.value);
489
+ setEmailError("");
490
+ },
491
+ value: email
492
+ }
493
+ ),
494
+ emailError && /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("p", { className: "text-red-500 text-sm mt-1", children: emailError })
495
+ ] }),
496
+ /* @__PURE__ */ (0, import_jsx_runtime4.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_runtime4.jsx)(
497
+ "button",
498
+ {
499
+ type: "submit",
500
+ onClick: handleSubmit,
501
+ disabled: submitButtonDisabled,
502
+ style: submitButtonDisabled ? { backgroundColor: "rgb(216, 216, 216)", color: "rgb(129, 129, 129)" } : void 0,
503
+ 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",
504
+ children: submitting ? /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(LoadingSpinnerIcon, { color: "white" }) : "Submit"
505
+ }
506
+ ) })
507
+ ] })
508
+ ] })
509
+ }
510
+ )
511
+ ] });
512
+ }
513
+
514
+ // src/components/dev-console/console.tsx
515
+ var import_jsx_runtime5 = require("react/jsx-runtime");
516
+ function CopilotDevConsole() {
517
+ const currentVersion = import_shared.COPILOTKIT_VERSION;
518
+ const context = (0, import_react_core2.useCopilotContext)();
519
+ const [showDevConsole, setShowDevConsole] = (0, import_react2.useState)(false);
520
+ (0, import_react2.useEffect)(() => {
521
+ setShowDevConsole(shouldShowDevConsole(context.showDevConsole));
522
+ }, [context.showDevConsole]);
523
+ const dontRunTwiceInDevMode = (0, import_react2.useRef)(false);
524
+ const [versionStatus, setVersionStatus] = (0, import_react2.useState)("unknown");
525
+ const [latestVersion, setLatestVersion] = (0, import_react2.useState)("");
526
+ const consoleRef = (0, import_react2.useRef)(null);
527
+ const [debugButtonMode, setDebugButtonMode] = (0, import_react2.useState)("full");
528
+ const checkForUpdates = (force = false) => {
529
+ setVersionStatus("checking");
530
+ getPublishedCopilotKitVersion(currentVersion, force).then((v) => {
531
+ setLatestVersion(v.latest);
532
+ let versionOk = false;
533
+ if (v.current === v.latest) {
534
+ versionOk = true;
535
+ } else if (/[a-zA-Z]/.test(v.current)) {
536
+ versionOk = true;
537
+ }
538
+ if (versionOk) {
539
+ setVersionStatus("latest");
540
+ } else if (v.severity !== "low") {
541
+ setVersionStatus("outdated");
542
+ } else {
543
+ setVersionStatus("update-available");
544
+ }
545
+ }).catch((e) => {
546
+ console.error(e);
547
+ setVersionStatus("unknown");
548
+ });
549
+ };
550
+ (0, import_react2.useEffect)(() => {
551
+ if (dontRunTwiceInDevMode.current === true) {
552
+ return;
553
+ }
554
+ dontRunTwiceInDevMode.current = true;
555
+ checkForUpdates();
556
+ }, []);
557
+ (0, import_react2.useEffect)(() => {
558
+ const handleResize = (entries) => {
559
+ for (let entry of entries) {
560
+ if (entry.target === consoleRef.current) {
561
+ const width = entry.contentRect.width;
562
+ if (width < 400) {
563
+ setDebugButtonMode("compact");
564
+ } else {
565
+ setDebugButtonMode("full");
566
+ }
567
+ }
568
+ }
569
+ };
570
+ const observer = new ResizeObserver(handleResize);
571
+ if (consoleRef.current) {
572
+ observer.observe(consoleRef.current);
573
+ const initialWidth = consoleRef.current.getBoundingClientRect().width;
574
+ if (initialWidth < 400) {
575
+ setDebugButtonMode("compact");
576
+ } else {
577
+ setDebugButtonMode("full");
578
+ }
579
+ }
580
+ return () => {
581
+ if (consoleRef.current) {
582
+ observer.unobserve(consoleRef.current);
583
+ }
584
+ };
585
+ }, [consoleRef.current]);
586
+ if (!showDevConsole) {
587
+ return null;
588
+ }
589
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(
590
+ "div",
591
+ {
592
+ ref: consoleRef,
593
+ className: "copilotKitDevConsole " + (versionStatus === "update-available" ? "copilotKitDevConsoleUpgrade" : "") + (versionStatus === "outdated" ? "copilotKitDevConsoleWarnOutdated" : ""),
594
+ children: [
595
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("div", { className: "copilotKitDevConsoleLogo", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("a", { href: "https://copilotkit.ai", target: "_blank", children: CopilotKitIcon }) }),
596
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
597
+ VersionInfo,
598
+ {
599
+ showDevConsole: context.showDevConsole,
600
+ versionStatus,
601
+ currentVersion,
602
+ latestVersion
603
+ }
604
+ ),
605
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(CopilotKitHelpModal, {}),
606
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
607
+ DebugMenuButton,
608
+ {
609
+ setShowDevConsole,
610
+ checkForUpdates,
611
+ mode: debugButtonMode
612
+ }
613
+ )
614
+ ]
615
+ }
616
+ );
617
+ }
618
+ function VersionInfo({
619
+ showDevConsole,
620
+ versionStatus,
621
+ currentVersion,
622
+ latestVersion
623
+ }) {
624
+ const [copyStatus, setCopyStatus] = (0, import_react2.useState)("");
625
+ let versionLabel = "";
626
+ let versionIcon = "";
627
+ let currentVersionLabel = currentVersion;
628
+ if (versionStatus === "latest") {
629
+ versionLabel = "latest";
630
+ versionIcon = CheckIcon;
631
+ } else if (versionStatus === "checking") {
632
+ versionLabel = "checking";
633
+ versionIcon = SmallSpinnerIcon;
634
+ } else if (versionStatus === "update-available") {
635
+ versionLabel = "update available";
636
+ versionIcon = ExclamationMarkIcon;
637
+ currentVersionLabel = `${currentVersion} \u2192 ${latestVersion}`;
638
+ } else if (versionStatus === "outdated") {
639
+ versionLabel = "outdated";
640
+ versionIcon = ExclamationMarkTriangleIcon;
641
+ currentVersionLabel = `${currentVersion} \u2192 ${latestVersion}`;
642
+ }
643
+ let asideLabel = "";
644
+ if (showDevConsole === "auto") {
645
+ asideLabel = "(localhost only)";
646
+ } else if (showDevConsole === true) {
647
+ asideLabel = "(always on)";
648
+ }
649
+ const installCommand = [
650
+ `npm install`,
651
+ `@copilotkit/react-core@${latestVersion}`,
652
+ `@copilotkit/react-ui@${latestVersion}`,
653
+ `@copilotkit/react-textarea@${latestVersion}`
654
+ ].join(" ");
655
+ const handleCopyClick = () => {
656
+ navigator.clipboard.writeText(installCommand.trim()).then(() => {
657
+ setCopyStatus("Command copied to clipboard!");
658
+ setTimeout(() => setCopyStatus(""), 1e3);
659
+ });
660
+ };
661
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "copilotKitVersionInfo", children: [
662
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("header", { children: [
663
+ "COPILOTKIT DEV CONSOLE",
664
+ showDevConsole === "auto" && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("aside", { children: asideLabel })
665
+ ] }),
666
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("section", { children: [
667
+ "Version: ",
668
+ versionLabel,
669
+ " (",
670
+ currentVersionLabel,
671
+ ") ",
672
+ versionIcon
673
+ ] }),
674
+ (versionStatus === "update-available" || versionStatus === "outdated") && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("footer", { children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("button", { onClick: handleCopyClick, children: copyStatus || installCommand }) })
675
+ ] });
676
+ }
677
+ function DebugMenuButton({
678
+ setShowDevConsole,
679
+ checkForUpdates,
680
+ mode
681
+ }) {
682
+ const context = (0, import_react_core2.useCopilotContext)();
683
+ const messagesContext = (0, import_react_core2.useCopilotMessagesContext)();
684
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("div", { className: "bg-black top-24 w-52 text-right", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_react3.Menu, { children: [
685
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_react3.MenuButton, { className: `copilotKitDebugMenuButton ${mode === "compact" ? "compact" : ""}`, children: mode == "compact" ? "Debug" : /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_jsx_runtime5.Fragment, { children: [
686
+ "Debug ",
687
+ ChevronDownIcon
688
+ ] }) }),
689
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(
690
+ import_react3.MenuItems,
691
+ {
692
+ transition: true,
693
+ anchor: "bottom end",
694
+ className: "copilotKitDebugMenu",
695
+ style: { zIndex: 40 },
696
+ children: [
697
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_react3.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => logReadables(context), children: "Log Readables" }) }),
698
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_react3.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => logActions(context), children: "Log Actions" }) }),
699
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_react3.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
700
+ "button",
701
+ {
702
+ className: "copilotKitDebugMenuItem",
703
+ onClick: () => logMessages(messagesContext),
704
+ children: "Log Messages"
705
+ }
706
+ ) }),
707
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_react3.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => checkForUpdates(true), children: "Check for Updates" }) }),
708
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("hr", {}),
709
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_react3.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => setShowDevConsole(false), children: "Hide Dev Console" }) })
710
+ ]
711
+ }
712
+ )
713
+ ] }) });
714
+ }
715
+ // Annotate the CommonJS export names for ESM import in node:
716
+ 0 && (module.exports = {
717
+ CopilotDevConsole,
718
+ shouldShowDevConsole
719
+ });
720
+ //# sourceMappingURL=index.js.map