@copilotkit/react-core 1.10.0-next.11 → 1.10.0-next.13

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 (114) hide show
  1. package/CHANGELOG.md +15 -0
  2. package/dist/{chunk-ADZDXHVC.mjs → chunk-2GRWTU7W.mjs} +4 -4
  3. package/dist/chunk-3BASANUO.mjs +170 -0
  4. package/dist/chunk-3BASANUO.mjs.map +1 -0
  5. package/dist/{chunk-LVWV62JZ.mjs → chunk-5P46WS5M.mjs} +32 -26
  6. package/dist/chunk-5P46WS5M.mjs.map +1 -0
  7. package/dist/{chunk-OKRZF3DD.mjs → chunk-6ZLPNY7X.mjs} +2 -2
  8. package/dist/{chunk-OKRZF3DD.mjs.map → chunk-6ZLPNY7X.mjs.map} +1 -1
  9. package/dist/{chunk-COEUPDRL.mjs → chunk-BEFEBKKI.mjs} +8 -8
  10. package/dist/{chunk-QGE7U4NV.mjs → chunk-F26O2HTO.mjs} +3 -3
  11. package/dist/chunk-F26O2HTO.mjs.map +1 -0
  12. package/dist/{chunk-DLEXVOQE.mjs → chunk-GEKWHETN.mjs} +4 -4
  13. package/dist/{chunk-L6HQIJ74.mjs → chunk-JY3STRON.mjs} +8 -8
  14. package/dist/{chunk-JJDXTTEN.mjs → chunk-K4HXT453.mjs} +2 -2
  15. package/dist/{chunk-JBLMXZ3O.mjs → chunk-KH27ZS4Y.mjs} +6 -6
  16. package/dist/{chunk-TWYUYC4F.mjs → chunk-MUDXTKXE.mjs} +6 -6
  17. package/dist/{chunk-Q42NJFXR.mjs → chunk-N4VN2B5S.mjs} +5 -5
  18. package/dist/{chunk-2TSNHEIS.mjs → chunk-NTH42BY5.mjs} +5 -5
  19. package/dist/{chunk-X2DNXTME.mjs → chunk-OPRDTF4S.mjs} +4 -4
  20. package/dist/chunk-PIF5KJYI.mjs +103 -0
  21. package/dist/chunk-PIF5KJYI.mjs.map +1 -0
  22. package/dist/chunk-WSXTUD36.mjs +759 -0
  23. package/dist/chunk-WSXTUD36.mjs.map +1 -0
  24. package/dist/{chunk-IHAZJF3V.mjs → chunk-YIBUNEBN.mjs} +2 -2
  25. package/dist/chunk-YIBUNEBN.mjs.map +1 -0
  26. package/dist/components/copilot-provider/copilot-messages.mjs +3 -3
  27. package/dist/components/copilot-provider/copilotkit-props.d.ts +9 -1
  28. package/dist/components/copilot-provider/copilotkit-props.js.map +1 -1
  29. package/dist/components/copilot-provider/copilotkit.js +1047 -71
  30. package/dist/components/copilot-provider/copilotkit.js.map +1 -1
  31. package/dist/components/copilot-provider/copilotkit.mjs +11 -8
  32. package/dist/components/copilot-provider/index.js +1047 -71
  33. package/dist/components/copilot-provider/index.js.map +1 -1
  34. package/dist/components/copilot-provider/index.mjs +11 -8
  35. package/dist/components/dev-console/console-trigger.d.ts +8 -0
  36. package/dist/components/dev-console/console-trigger.js +1131 -0
  37. package/dist/components/dev-console/console-trigger.js.map +1 -0
  38. package/dist/components/dev-console/console-trigger.mjs +13 -0
  39. package/dist/components/dev-console/console-trigger.mjs.map +1 -0
  40. package/dist/components/dev-console/developer-console-modal.d.ts +10 -0
  41. package/dist/components/dev-console/developer-console-modal.js +977 -0
  42. package/dist/components/dev-console/developer-console-modal.js.map +1 -0
  43. package/dist/components/dev-console/developer-console-modal.mjs +12 -0
  44. package/dist/components/dev-console/developer-console-modal.mjs.map +1 -0
  45. package/dist/components/dev-console/icons.d.ts +9 -0
  46. package/dist/components/dev-console/icons.js +131 -0
  47. package/dist/components/dev-console/icons.js.map +1 -0
  48. package/dist/components/dev-console/icons.mjs +16 -0
  49. package/dist/components/dev-console/icons.mjs.map +1 -0
  50. package/dist/components/error-boundary/error-boundary.js +1 -1
  51. package/dist/components/error-boundary/error-boundary.js.map +1 -1
  52. package/dist/components/error-boundary/error-boundary.mjs +2 -2
  53. package/dist/components/index.js +1047 -71
  54. package/dist/components/index.js.map +1 -1
  55. package/dist/components/index.mjs +11 -8
  56. package/dist/components/usage-banner.js +1 -1
  57. package/dist/components/usage-banner.js.map +1 -1
  58. package/dist/components/usage-banner.mjs +1 -1
  59. package/dist/context/index.mjs +4 -4
  60. package/dist/hooks/index.js +1 -1
  61. package/dist/hooks/index.js.map +1 -1
  62. package/dist/hooks/index.mjs +32 -29
  63. package/dist/hooks/use-chat.mjs +4 -4
  64. package/dist/hooks/use-coagent-state-render.mjs +2 -2
  65. package/dist/hooks/use-coagent.js.map +1 -1
  66. package/dist/hooks/use-coagent.mjs +16 -13
  67. package/dist/hooks/use-copilot-action.mjs +2 -2
  68. package/dist/hooks/use-copilot-authenticated-action.mjs +3 -3
  69. package/dist/hooks/use-copilot-chat-headless_c.js +1 -1
  70. package/dist/hooks/use-copilot-chat-headless_c.js.map +1 -1
  71. package/dist/hooks/use-copilot-chat-headless_c.mjs +16 -13
  72. package/dist/hooks/use-copilot-chat.d.ts +42 -3
  73. package/dist/hooks/use-copilot-chat.js.map +1 -1
  74. package/dist/hooks/use-copilot-chat.mjs +16 -13
  75. package/dist/hooks/use-copilot-chat_internal.js.map +1 -1
  76. package/dist/hooks/use-copilot-chat_internal.mjs +15 -12
  77. package/dist/hooks/use-langgraph-interrupt-render.mjs +1 -1
  78. package/dist/hooks/use-langgraph-interrupt.js.map +1 -1
  79. package/dist/hooks/use-langgraph-interrupt.mjs +16 -13
  80. package/dist/index.js +1145 -178
  81. package/dist/index.js.map +1 -1
  82. package/dist/index.mjs +36 -33
  83. package/dist/lib/copilot-task.js.map +1 -1
  84. package/dist/lib/copilot-task.mjs +13 -10
  85. package/dist/lib/index.js.map +1 -1
  86. package/dist/lib/index.mjs +13 -10
  87. package/dist/utils/extract.js.map +1 -1
  88. package/dist/utils/extract.mjs +11 -8
  89. package/dist/utils/index.js.map +1 -1
  90. package/dist/utils/index.mjs +11 -8
  91. package/dist/utils/suggestions.js.map +1 -1
  92. package/dist/utils/suggestions.mjs +11 -8
  93. package/package.json +3 -3
  94. package/src/components/copilot-provider/copilotkit-props.tsx +10 -1
  95. package/src/components/copilot-provider/copilotkit.tsx +25 -16
  96. package/src/components/dev-console/console-trigger.tsx +190 -0
  97. package/src/components/dev-console/developer-console-modal.tsx +866 -0
  98. package/src/components/dev-console/icons.tsx +101 -0
  99. package/src/components/usage-banner.tsx +1 -1
  100. package/src/hooks/use-copilot-chat-headless_c.ts +79 -9
  101. package/src/hooks/use-copilot-chat.ts +42 -3
  102. package/dist/chunk-IHAZJF3V.mjs.map +0 -1
  103. package/dist/chunk-LVWV62JZ.mjs.map +0 -1
  104. package/dist/chunk-QGE7U4NV.mjs.map +0 -1
  105. /package/dist/{chunk-ADZDXHVC.mjs.map → chunk-2GRWTU7W.mjs.map} +0 -0
  106. /package/dist/{chunk-COEUPDRL.mjs.map → chunk-BEFEBKKI.mjs.map} +0 -0
  107. /package/dist/{chunk-DLEXVOQE.mjs.map → chunk-GEKWHETN.mjs.map} +0 -0
  108. /package/dist/{chunk-L6HQIJ74.mjs.map → chunk-JY3STRON.mjs.map} +0 -0
  109. /package/dist/{chunk-JJDXTTEN.mjs.map → chunk-K4HXT453.mjs.map} +0 -0
  110. /package/dist/{chunk-JBLMXZ3O.mjs.map → chunk-KH27ZS4Y.mjs.map} +0 -0
  111. /package/dist/{chunk-TWYUYC4F.mjs.map → chunk-MUDXTKXE.mjs.map} +0 -0
  112. /package/dist/{chunk-Q42NJFXR.mjs.map → chunk-N4VN2B5S.mjs.map} +0 -0
  113. /package/dist/{chunk-2TSNHEIS.mjs.map → chunk-NTH42BY5.mjs.map} +0 -0
  114. /package/dist/{chunk-X2DNXTME.mjs.map → chunk-OPRDTF4S.mjs.map} +0 -0
@@ -0,0 +1,1131 @@
1
+ "use strict";
2
+ "use client";
3
+ var __create = Object.create;
4
+ var __defProp = Object.defineProperty;
5
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
+ var __getOwnPropNames = Object.getOwnPropertyNames;
7
+ var __getProtoOf = Object.getPrototypeOf;
8
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
9
+ var __export = (target, all) => {
10
+ for (var name in all)
11
+ __defProp(target, name, { get: all[name], enumerable: true });
12
+ };
13
+ var __copyProps = (to, from, except, desc) => {
14
+ if (from && typeof from === "object" || typeof from === "function") {
15
+ for (let key of __getOwnPropNames(from))
16
+ if (!__hasOwnProp.call(to, key) && key !== except)
17
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
18
+ }
19
+ return to;
20
+ };
21
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
22
+ // If the importer is in node compatibility mode or this is not an ESM
23
+ // file that has been converted to a CommonJS file using a Babel-
24
+ // compatible transform (i.e. "__esModule" has not been set), then set
25
+ // "default" to the CommonJS "module.exports" for node compatibility.
26
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
27
+ mod
28
+ ));
29
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
30
+ var __async = (__this, __arguments, generator) => {
31
+ return new Promise((resolve, reject) => {
32
+ var fulfilled = (value) => {
33
+ try {
34
+ step(generator.next(value));
35
+ } catch (e) {
36
+ reject(e);
37
+ }
38
+ };
39
+ var rejected = (value) => {
40
+ try {
41
+ step(generator.throw(value));
42
+ } catch (e) {
43
+ reject(e);
44
+ }
45
+ };
46
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
47
+ step((generator = generator.apply(__this, __arguments)).next());
48
+ });
49
+ };
50
+
51
+ // src/components/dev-console/console-trigger.tsx
52
+ var console_trigger_exports = {};
53
+ __export(console_trigger_exports, {
54
+ ConsoleTrigger: () => ConsoleTrigger
55
+ });
56
+ module.exports = __toCommonJS(console_trigger_exports);
57
+ var import_react4 = require("react");
58
+
59
+ // src/context/copilot-context.tsx
60
+ var import_react = __toESM(require("react"));
61
+ var emptyCopilotContext = {
62
+ actions: {},
63
+ setAction: () => {
64
+ },
65
+ removeAction: () => {
66
+ },
67
+ coAgentStateRenders: {},
68
+ setCoAgentStateRender: () => {
69
+ },
70
+ removeCoAgentStateRender: () => {
71
+ },
72
+ chatComponentsCache: { current: { actions: {}, coAgentStateRenders: {} } },
73
+ getContextString: (documents, categories) => returnAndThrowInDebug(""),
74
+ addContext: () => "",
75
+ removeContext: () => {
76
+ },
77
+ getAllContext: () => [],
78
+ getFunctionCallHandler: () => returnAndThrowInDebug(() => __async(void 0, null, function* () {
79
+ })),
80
+ isLoading: false,
81
+ setIsLoading: () => returnAndThrowInDebug(false),
82
+ chatInstructions: "",
83
+ setChatInstructions: () => returnAndThrowInDebug(""),
84
+ additionalInstructions: [],
85
+ setAdditionalInstructions: () => returnAndThrowInDebug([]),
86
+ getDocumentsContext: (categories) => returnAndThrowInDebug([]),
87
+ addDocumentContext: () => returnAndThrowInDebug(""),
88
+ removeDocumentContext: () => {
89
+ },
90
+ runtimeClient: {},
91
+ copilotApiConfig: new class {
92
+ get chatApiEndpoint() {
93
+ throw new Error("Remember to wrap your app in a `<CopilotKit> {...} </CopilotKit>` !!!");
94
+ }
95
+ get headers() {
96
+ return {};
97
+ }
98
+ get body() {
99
+ return {};
100
+ }
101
+ }(),
102
+ chatSuggestionConfiguration: {},
103
+ addChatSuggestionConfiguration: () => {
104
+ },
105
+ removeChatSuggestionConfiguration: () => {
106
+ },
107
+ showDevConsole: false,
108
+ coagentStates: {},
109
+ setCoagentStates: () => {
110
+ },
111
+ coagentStatesRef: { current: {} },
112
+ setCoagentStatesWithRef: () => {
113
+ },
114
+ agentSession: null,
115
+ setAgentSession: () => {
116
+ },
117
+ forwardedParameters: {},
118
+ agentLock: null,
119
+ threadId: "",
120
+ setThreadId: () => {
121
+ },
122
+ runId: null,
123
+ setRunId: () => {
124
+ },
125
+ chatAbortControllerRef: { current: null },
126
+ availableAgents: [],
127
+ extensions: {},
128
+ setExtensions: () => {
129
+ },
130
+ langGraphInterruptAction: null,
131
+ setLangGraphInterruptAction: () => null,
132
+ removeLangGraphInterruptAction: () => null,
133
+ onError: void 0,
134
+ bannerError: null,
135
+ setBannerError: () => {
136
+ }
137
+ };
138
+ var CopilotContext = import_react.default.createContext(emptyCopilotContext);
139
+ function useCopilotContext() {
140
+ const context = import_react.default.useContext(CopilotContext);
141
+ if (context === emptyCopilotContext) {
142
+ throw new Error("Remember to wrap your app in a `<CopilotKit> {...} </CopilotKit>` !!!");
143
+ }
144
+ return context;
145
+ }
146
+ function returnAndThrowInDebug(_value) {
147
+ throw new Error("Remember to wrap your app in a `<CopilotKit> {...} </CopilotKit>` !!!");
148
+ }
149
+
150
+ // src/components/dev-console/icons.tsx
151
+ var import_jsx_runtime = require("react/jsx-runtime");
152
+ var ExclamationMarkTriangleIcon = () => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
153
+ "svg",
154
+ {
155
+ width: "13.3967723px",
156
+ height: "12px",
157
+ viewBox: "0 0 13.3967723 12",
158
+ version: "1.1",
159
+ xmlns: "http://www.w3.org/2000/svg",
160
+ 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)(
161
+ "path",
162
+ {
163
+ 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",
164
+ id: "Shape"
165
+ }
166
+ ) }) })
167
+ }
168
+ );
169
+ var CheckIcon = () => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
170
+ "svg",
171
+ {
172
+ width: "14px",
173
+ height: "14px",
174
+ viewBox: "0 0 14 14",
175
+ version: "1.1",
176
+ xmlns: "http://www.w3.org/2000/svg",
177
+ 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)(
178
+ "path",
179
+ {
180
+ 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",
181
+ id: "Shape"
182
+ }
183
+ ) }) }) })
184
+ }
185
+ );
186
+ var CopilotKitIcon = () => /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
187
+ "svg",
188
+ {
189
+ width: "33px",
190
+ height: "35px",
191
+ viewBox: "0 0 33 35",
192
+ version: "1.1",
193
+ xmlns: "http://www.w3.org/2000/svg",
194
+ children: [
195
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("title", { children: "bd5c9079-929b-4d55-bdc9-16d1c8181b71" }),
196
+ /* @__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)(
197
+ "image",
198
+ {
199
+ x: "0",
200
+ y: "0",
201
+ width: "33",
202
+ height: "35",
203
+ xlinkHref: ""
204
+ }
205
+ ) })
206
+ ]
207
+ }
208
+ );
209
+
210
+ // src/context/copilot-messages-context.tsx
211
+ var import_react2 = __toESM(require("react"));
212
+ var emptyCopilotContext2 = {
213
+ messages: [],
214
+ setMessages: () => [],
215
+ // suggestions state
216
+ suggestions: [],
217
+ setSuggestions: () => []
218
+ };
219
+ var CopilotMessagesContext = import_react2.default.createContext(emptyCopilotContext2);
220
+ function useCopilotMessagesContext() {
221
+ const context = import_react2.default.useContext(CopilotMessagesContext);
222
+ if (context === emptyCopilotContext2) {
223
+ throw new Error(
224
+ "A messages consuming component was not wrapped with `<CopilotMessages> {...} </CopilotMessages>`"
225
+ );
226
+ }
227
+ return context;
228
+ }
229
+
230
+ // src/components/dev-console/developer-console-modal.tsx
231
+ var import_shared = require("@copilotkit/shared");
232
+ var import_react3 = require("react");
233
+ var import_jsx_runtime2 = require("react/jsx-runtime");
234
+ function DeveloperConsoleModal({ isOpen, onClose, hasApiKey }) {
235
+ const context = useCopilotContext();
236
+ const messagesContext = useCopilotMessagesContext();
237
+ const [activeTab, setActiveTab] = (0, import_react3.useState)("actions");
238
+ (0, import_react3.useEffect)(() => {
239
+ const handleEscape = (e) => {
240
+ if (e.key === "Escape") {
241
+ onClose();
242
+ }
243
+ };
244
+ if (isOpen) {
245
+ document.addEventListener("keydown", handleEscape);
246
+ document.body.style.overflow = "hidden";
247
+ }
248
+ return () => {
249
+ document.removeEventListener("keydown", handleEscape);
250
+ document.body.style.overflow = "unset";
251
+ };
252
+ }, [isOpen, onClose]);
253
+ if (!isOpen)
254
+ return null;
255
+ const displayContext = hasApiKey ? context : {
256
+ actions: {
257
+ search_web: { name: "search_web", description: "Search the web for information" },
258
+ send_email: { name: "send_email", description: "Send an email to a contact" },
259
+ create_document: { name: "create_document", description: "Create a new document" },
260
+ analyze_code: {
261
+ name: "analyze_code",
262
+ description: "Analyze code for issues and improvements"
263
+ },
264
+ generate_tests: {
265
+ name: "generate_tests",
266
+ description: "Generate unit tests for functions"
267
+ }
268
+ },
269
+ getAllContext: () => [
270
+ {
271
+ content: "User preferences: dark mode enabled, TypeScript preferred",
272
+ metadata: { source: "settings" }
273
+ },
274
+ {
275
+ content: "Current project: Building a React application with CopilotKit",
276
+ metadata: { source: "project" }
277
+ },
278
+ {
279
+ content: "Recent activity: Implemented authentication system",
280
+ metadata: { source: "activity" }
281
+ },
282
+ {
283
+ content: "Development environment: VS Code, Node.js 18, React 18",
284
+ metadata: { source: "environment" }
285
+ }
286
+ ],
287
+ coagentStates: {
288
+ "main-agent": { status: "active", lastUpdate: Date.now() },
289
+ "code-assistant": { status: "active", lastUpdate: Date.now() - 15e3 },
290
+ "search-agent": { status: "idle", lastUpdate: Date.now() - 6e4 }
291
+ },
292
+ getDocumentsContext: () => [
293
+ {
294
+ content: "README.md: Project setup and installation instructions",
295
+ metadata: { type: "documentation" }
296
+ },
297
+ {
298
+ content: "API Documentation: CopilotKit integration guide",
299
+ metadata: { type: "documentation" }
300
+ },
301
+ {
302
+ content: "package.json: Project dependencies and scripts",
303
+ metadata: { type: "configuration" }
304
+ }
305
+ ]
306
+ };
307
+ const displayMessagesContext = hasApiKey ? messagesContext : {
308
+ messages: [
309
+ {
310
+ id: "1",
311
+ role: "user",
312
+ content: "Help me implement a todo list with drag and drop functionality"
313
+ },
314
+ {
315
+ id: "2",
316
+ role: "assistant",
317
+ content: "I'll help you create a todo list with drag and drop. Let me start by setting up the basic components and then add the drag and drop functionality using React DnD."
318
+ },
319
+ { id: "3", role: "user", content: "Can you also add priority levels and due dates?" },
320
+ {
321
+ id: "4",
322
+ role: "assistant",
323
+ content: "Absolutely! I'll enhance the todo items with priority levels (high, medium, low) and due date functionality. This will make your todo list much more powerful for task management."
324
+ },
325
+ { id: "5", role: "user", content: "Perfect! How about adding categories or tags?" }
326
+ ]
327
+ };
328
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
329
+ "div",
330
+ {
331
+ style: {
332
+ position: "fixed",
333
+ top: 0,
334
+ left: 0,
335
+ right: 0,
336
+ bottom: 0,
337
+ zIndex: 9999,
338
+ backgroundColor: "rgba(0, 0, 0, 0.3)",
339
+ display: "flex",
340
+ alignItems: "center",
341
+ justifyContent: "center",
342
+ padding: "16px"
343
+ },
344
+ onClick: onClose,
345
+ children: /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
346
+ "div",
347
+ {
348
+ style: {
349
+ width: "1152px",
350
+ maxWidth: "95vw",
351
+ height: "80vh",
352
+ backgroundColor: "white",
353
+ borderRadius: "12px",
354
+ boxShadow: "0 25px 50px -12px rgba(0, 0, 0, 0.25)",
355
+ display: "flex",
356
+ flexDirection: "column",
357
+ overflow: "hidden",
358
+ position: "relative"
359
+ },
360
+ onClick: (e) => e.stopPropagation(),
361
+ children: [
362
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
363
+ "div",
364
+ {
365
+ style: {
366
+ display: "flex",
367
+ alignItems: "center",
368
+ justifyContent: "space-between",
369
+ padding: "24px",
370
+ borderBottom: "1px solid #e5e7eb",
371
+ minHeight: "73px",
372
+ flexShrink: 0,
373
+ filter: !hasApiKey ? "blur(0.3px)" : "none",
374
+ opacity: !hasApiKey ? 0.95 : 1
375
+ },
376
+ children: [
377
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { style: { display: "flex", alignItems: "center", gap: "12px" }, children: [
378
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(CopilotKitIcon, {}),
379
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
380
+ "h1",
381
+ {
382
+ style: {
383
+ fontWeight: "bold",
384
+ fontSize: "20px",
385
+ color: "#1f2937",
386
+ margin: 0
387
+ },
388
+ children: "Developer Console"
389
+ }
390
+ ),
391
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
392
+ "span",
393
+ {
394
+ style: {
395
+ fontSize: "14px",
396
+ color: "#6b7280",
397
+ backgroundColor: "#f3f4f6",
398
+ padding: "4px 8px",
399
+ borderRadius: "4px"
400
+ },
401
+ children: [
402
+ "v",
403
+ import_shared.COPILOTKIT_VERSION
404
+ ]
405
+ }
406
+ )
407
+ ] }),
408
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
409
+ "button",
410
+ {
411
+ onClick: onClose,
412
+ style: {
413
+ color: "#9ca3af",
414
+ fontSize: "24px",
415
+ fontWeight: "300",
416
+ border: "none",
417
+ background: "none",
418
+ cursor: "pointer",
419
+ padding: "4px"
420
+ },
421
+ onMouseEnter: (e) => e.currentTarget.style.color = "#4b5563",
422
+ onMouseLeave: (e) => e.currentTarget.style.color = "#9ca3af",
423
+ children: "\xD7"
424
+ }
425
+ )
426
+ ]
427
+ }
428
+ ),
429
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
430
+ "div",
431
+ {
432
+ style: {
433
+ display: "flex",
434
+ borderBottom: "1px solid #e5e7eb",
435
+ backgroundColor: "#f9fafb",
436
+ minHeight: "50px",
437
+ flexShrink: 0,
438
+ filter: !hasApiKey ? "blur(0.3px)" : "none",
439
+ opacity: !hasApiKey ? 0.9 : 1
440
+ },
441
+ children: [
442
+ { id: "actions", label: "Actions", count: Object.keys(displayContext.actions).length },
443
+ { id: "readables", label: "Readables", count: displayContext.getAllContext().length },
444
+ {
445
+ id: "agent",
446
+ label: "Agent Status",
447
+ count: Object.keys(displayContext.coagentStates).length
448
+ },
449
+ { id: "messages", label: "Messages", count: displayMessagesContext.messages.length },
450
+ {
451
+ id: "context",
452
+ label: "Context",
453
+ count: displayContext.getDocumentsContext([]).length
454
+ }
455
+ ].map((tab) => /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
456
+ "button",
457
+ {
458
+ onClick: () => setActiveTab(tab.id),
459
+ style: {
460
+ padding: "12px 24px",
461
+ fontSize: "14px",
462
+ fontWeight: "500",
463
+ border: "none",
464
+ cursor: "pointer",
465
+ backgroundColor: activeTab === tab.id ? "white" : "transparent",
466
+ color: activeTab === tab.id ? "#2563eb" : "#6b7280",
467
+ borderBottom: activeTab === tab.id ? "2px solid #2563eb" : "none",
468
+ transition: "all 0.2s"
469
+ },
470
+ onMouseEnter: (e) => {
471
+ if (activeTab !== tab.id) {
472
+ e.currentTarget.style.color = "#1f2937";
473
+ e.currentTarget.style.backgroundColor = "#f3f4f6";
474
+ }
475
+ },
476
+ onMouseLeave: (e) => {
477
+ if (activeTab !== tab.id) {
478
+ e.currentTarget.style.color = "#6b7280";
479
+ e.currentTarget.style.backgroundColor = "transparent";
480
+ }
481
+ },
482
+ children: [
483
+ tab.label,
484
+ tab.count > 0 && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
485
+ "span",
486
+ {
487
+ style: {
488
+ marginLeft: "8px",
489
+ backgroundColor: "#e5e7eb",
490
+ color: "#374151",
491
+ padding: "2px 8px",
492
+ borderRadius: "9999px",
493
+ fontSize: "12px"
494
+ },
495
+ children: tab.count
496
+ }
497
+ )
498
+ ]
499
+ },
500
+ tab.id
501
+ ))
502
+ }
503
+ ),
504
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
505
+ "div",
506
+ {
507
+ style: {
508
+ height: "calc(100% - 142px)",
509
+ overflow: "auto",
510
+ padding: "24px",
511
+ backgroundColor: "#f9fafb",
512
+ filter: !hasApiKey ? "blur(0.3px)" : "none",
513
+ opacity: !hasApiKey ? 0.85 : 1
514
+ },
515
+ children: [
516
+ activeTab === "actions" && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(ActionsTab, { context: displayContext }),
517
+ activeTab === "readables" && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(ReadablesTab, { context: displayContext }),
518
+ activeTab === "agent" && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(AgentStatusTab, { context: displayContext }),
519
+ activeTab === "messages" && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(MessagesTab, { messagesContext: displayMessagesContext }),
520
+ activeTab === "context" && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(ContextTab, { context: displayContext })
521
+ ]
522
+ }
523
+ ),
524
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
525
+ "div",
526
+ {
527
+ style: {
528
+ padding: "16px 24px",
529
+ borderTop: "1px solid #e5e7eb",
530
+ backgroundColor: "white",
531
+ display: "flex",
532
+ justifyContent: "space-between",
533
+ alignItems: "center",
534
+ minHeight: "57px",
535
+ flexShrink: 0,
536
+ filter: !hasApiKey ? "blur(0.3px)" : "none",
537
+ opacity: !hasApiKey ? 0.9 : 1
538
+ },
539
+ children: [
540
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { style: { fontSize: "14px", color: "#6b7280" }, children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
541
+ "a",
542
+ {
543
+ href: "https://github.com/CopilotKit/CopilotKit/issues",
544
+ target: "_blank",
545
+ rel: "noopener noreferrer",
546
+ style: { color: "#2563eb", textDecoration: "none" },
547
+ onMouseEnter: (e) => e.currentTarget.style.textDecoration = "underline",
548
+ onMouseLeave: (e) => e.currentTarget.style.textDecoration = "none",
549
+ children: "Report an issue"
550
+ }
551
+ ) }),
552
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { style: { fontSize: "14px", color: "#6b7280" }, children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
553
+ "a",
554
+ {
555
+ href: "https://mcp.copilotkit.ai/",
556
+ target: "_blank",
557
+ rel: "noopener noreferrer",
558
+ style: { color: "#2563eb", textDecoration: "none" },
559
+ onMouseEnter: (e) => e.currentTarget.style.textDecoration = "underline",
560
+ onMouseLeave: (e) => e.currentTarget.style.textDecoration = "none",
561
+ children: "Add MCP Server \u2192"
562
+ }
563
+ ) })
564
+ ]
565
+ }
566
+ ),
567
+ !hasApiKey && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
568
+ "div",
569
+ {
570
+ style: {
571
+ position: "absolute",
572
+ top: 0,
573
+ left: 0,
574
+ right: 0,
575
+ bottom: 0,
576
+ backgroundColor: "rgba(255, 255, 255, 0.2)",
577
+ backdropFilter: "blur(2px)",
578
+ WebkitBackdropFilter: "blur(2px)",
579
+ display: "flex",
580
+ alignItems: "center",
581
+ justifyContent: "center",
582
+ borderRadius: "12px",
583
+ zIndex: 10
584
+ },
585
+ onClick: (e) => e.stopPropagation(),
586
+ children: /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
587
+ "button",
588
+ {
589
+ onClick: () => window.open("https://cloud.copilotkit.ai/sign-in", "_blank"),
590
+ style: {
591
+ // Following button system specifications
592
+ height: "48px",
593
+ padding: "12px 24px",
594
+ backgroundColor: "#030507",
595
+ // textPrimary token
596
+ color: "#FFFFFF",
597
+ borderRadius: "12px",
598
+ // Medium radius token
599
+ border: "none",
600
+ cursor: "pointer",
601
+ fontSize: "14px",
602
+ // Medium Semi Bold typography
603
+ fontWeight: "600",
604
+ fontFamily: "'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif",
605
+ lineHeight: "22px",
606
+ boxShadow: "0 4px 16px rgba(3, 5, 7, 0.2), 0 1px 3px rgba(3, 5, 7, 0.1)",
607
+ transition: "all 200ms ease",
608
+ // 200ms ease as per specs
609
+ display: "inline-flex",
610
+ alignItems: "center",
611
+ gap: "8px",
612
+ textTransform: "uppercase",
613
+ letterSpacing: "0.5px"
614
+ },
615
+ onMouseEnter: (e) => {
616
+ e.currentTarget.style.backgroundColor = "#575758";
617
+ e.currentTarget.style.transform = "translateY(-1px)";
618
+ e.currentTarget.style.boxShadow = "0 6px 20px rgba(3, 5, 7, 0.25), 0 2px 4px rgba(3, 5, 7, 0.15)";
619
+ },
620
+ onMouseLeave: (e) => {
621
+ e.currentTarget.style.backgroundColor = "#030507";
622
+ e.currentTarget.style.transform = "translateY(0)";
623
+ e.currentTarget.style.boxShadow = "0 4px 16px rgba(3, 5, 7, 0.2), 0 1px 3px rgba(3, 5, 7, 0.1)";
624
+ },
625
+ onMouseDown: (e) => {
626
+ e.currentTarget.style.backgroundColor = "#858589";
627
+ e.currentTarget.style.transform = "translateY(0)";
628
+ },
629
+ onMouseUp: (e) => {
630
+ e.currentTarget.style.backgroundColor = "#575758";
631
+ e.currentTarget.style.transform = "translateY(-1px)";
632
+ },
633
+ onFocus: (e) => {
634
+ e.currentTarget.style.outline = "2px solid #BEC9FF";
635
+ e.currentTarget.style.outlineOffset = "2px";
636
+ },
637
+ onBlur: (e) => {
638
+ e.currentTarget.style.outline = "none";
639
+ },
640
+ children: [
641
+ "Get API Key",
642
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("span", { style: { fontSize: "16px", marginLeft: "-4px" }, children: "\u2192" })
643
+ ]
644
+ }
645
+ )
646
+ }
647
+ )
648
+ ]
649
+ }
650
+ )
651
+ }
652
+ );
653
+ }
654
+ function ActionsTab({ context }) {
655
+ const actions = Object.values(context.actions);
656
+ if (actions.length === 0) {
657
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { style: { textAlign: "center", padding: "48px 0", color: "#6b7280" }, children: [
658
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { style: { fontSize: "18px", margin: "0 0 8px 0" }, children: "No actions available" }),
659
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { style: { fontSize: "14px", margin: 0 }, children: "Actions will appear here when registered" })
660
+ ] });
661
+ }
662
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { style: { display: "flex", flexDirection: "column", gap: "16px" }, children: actions.map((action, index) => /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
663
+ "div",
664
+ {
665
+ style: {
666
+ backgroundColor: "white",
667
+ padding: "16px",
668
+ borderRadius: "8px",
669
+ boxShadow: "0 1px 3px 0 rgba(0, 0, 0, 0.1)",
670
+ border: "1px solid #e5e7eb"
671
+ },
672
+ children: /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
673
+ "div",
674
+ {
675
+ style: { display: "flex", alignItems: "flex-start", justifyContent: "space-between" },
676
+ children: [
677
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { style: { flex: 1 }, children: [
678
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("h3", { style: { fontWeight: "600", color: "#1f2937", margin: "0 0 4px 0" }, children: action.name }),
679
+ action.description && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { style: { fontSize: "14px", color: "#4b5563", margin: "0 0 12px 0" }, children: action.description }),
680
+ action.parameters && action.parameters.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { style: { marginTop: "12px" }, children: [
681
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
682
+ "p",
683
+ {
684
+ style: {
685
+ fontSize: "12px",
686
+ fontWeight: "500",
687
+ color: "#6b7280",
688
+ textTransform: "uppercase",
689
+ margin: "0 0 4px 0"
690
+ },
691
+ children: "Parameters:"
692
+ }
693
+ ),
694
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { style: { display: "flex", flexDirection: "column", gap: "4px" }, children: action.parameters.map((param, pIndex) => /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { style: { fontSize: "14px" }, children: [
695
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("span", { style: { fontFamily: "monospace", color: "#374151" }, children: param.name }),
696
+ param.required && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("span", { style: { marginLeft: "4px", fontSize: "12px", color: "#ef4444" }, children: "*required" }),
697
+ param.type && /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("span", { style: { marginLeft: "8px", fontSize: "12px", color: "#6b7280" }, children: [
698
+ "(",
699
+ param.type,
700
+ ")"
701
+ ] })
702
+ ] }, pIndex)) })
703
+ ] })
704
+ ] }),
705
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { style: { marginLeft: "16px" }, children: action.status === "available" ? /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(CheckIcon, {}) : /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(ExclamationMarkTriangleIcon, {}) })
706
+ ]
707
+ }
708
+ )
709
+ },
710
+ index
711
+ )) });
712
+ }
713
+ function ReadablesTab({ context }) {
714
+ const readables = context.getAllContext();
715
+ if (readables.length === 0) {
716
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { style: { textAlign: "center", padding: "48px 0", color: "#6b7280" }, children: [
717
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { style: { fontSize: "18px", margin: "0 0 8px 0" }, children: "No readable context available" }),
718
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { style: { fontSize: "14px", margin: 0 }, children: "Readable context will appear here when provided" })
719
+ ] });
720
+ }
721
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { style: { display: "flex", flexDirection: "column", gap: "16px" }, children: readables.map((readable, index) => /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
722
+ "div",
723
+ {
724
+ style: {
725
+ backgroundColor: "white",
726
+ padding: "16px",
727
+ borderRadius: "8px",
728
+ boxShadow: "0 1px 3px 0 rgba(0, 0, 0, 0.1)",
729
+ border: "1px solid #e5e7eb"
730
+ },
731
+ children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
732
+ "div",
733
+ {
734
+ style: { display: "flex", alignItems: "flex-start", justifyContent: "space-between" },
735
+ children: /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { style: { flex: 1 }, children: [
736
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("h3", { style: { fontWeight: "600", color: "#1f2937", margin: "0 0 4px 0" }, children: readable.name || `Readable ${index + 1}` }),
737
+ readable.description && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { style: { fontSize: "14px", color: "#4b5563", margin: "0 0 12px 0" }, children: readable.description }),
738
+ readable.value && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
739
+ "pre",
740
+ {
741
+ style: {
742
+ marginTop: "12px",
743
+ padding: "8px",
744
+ backgroundColor: "#f9fafb",
745
+ borderRadius: "4px",
746
+ fontSize: "12px",
747
+ overflowX: "auto",
748
+ margin: "12px 0 0 0"
749
+ },
750
+ children: JSON.stringify(readable.value, null, 2)
751
+ }
752
+ )
753
+ ] })
754
+ }
755
+ )
756
+ },
757
+ index
758
+ )) });
759
+ }
760
+ function AgentStatusTab({ context }) {
761
+ const agentStates = context.coagentStates || {};
762
+ const agentStateEntries = Object.entries(agentStates);
763
+ if (agentStateEntries.length === 0) {
764
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { style: { textAlign: "center", padding: "48px 0", color: "#6b7280" }, children: [
765
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { style: { fontSize: "18px", margin: "0 0 8px 0" }, children: "No agent states available" }),
766
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { style: { fontSize: "14px", margin: 0 }, children: "Agent states will appear here when agents are active" })
767
+ ] });
768
+ }
769
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { style: { display: "flex", flexDirection: "column", gap: "24px" }, children: agentStateEntries.map(([agentName, state]) => /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
770
+ "div",
771
+ {
772
+ style: {
773
+ backgroundColor: "white",
774
+ padding: "24px",
775
+ borderRadius: "8px",
776
+ boxShadow: "0 1px 3px 0 rgba(0, 0, 0, 0.1)",
777
+ border: "1px solid #e5e7eb"
778
+ },
779
+ children: [
780
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
781
+ "div",
782
+ {
783
+ style: {
784
+ display: "flex",
785
+ alignItems: "center",
786
+ justifyContent: "space-between",
787
+ marginBottom: "16px"
788
+ },
789
+ children: [
790
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("h3", { style: { fontWeight: "600", fontSize: "18px", color: "#1f2937", margin: 0 }, children: agentName }),
791
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
792
+ "span",
793
+ {
794
+ style: {
795
+ padding: "4px 12px",
796
+ borderRadius: "9999px",
797
+ fontSize: "12px",
798
+ fontWeight: "500",
799
+ backgroundColor: state.status === "running" ? "#dcfce7" : state.status === "complete" ? "#dbeafe" : "#f3f4f6",
800
+ color: state.status === "running" ? "#166534" : state.status === "complete" ? "#1e40af" : "#1f2937"
801
+ },
802
+ children: state.status || "idle"
803
+ }
804
+ )
805
+ ]
806
+ }
807
+ ),
808
+ state.state && /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { style: { marginBottom: "12px" }, children: [
809
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
810
+ "p",
811
+ {
812
+ style: {
813
+ fontSize: "12px",
814
+ fontWeight: "500",
815
+ color: "#6b7280",
816
+ textTransform: "uppercase",
817
+ margin: "0 0 4px 0"
818
+ },
819
+ children: "Current State:"
820
+ }
821
+ ),
822
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
823
+ "pre",
824
+ {
825
+ style: {
826
+ padding: "12px",
827
+ backgroundColor: "#f9fafb",
828
+ borderRadius: "4px",
829
+ fontSize: "12px",
830
+ overflowX: "auto",
831
+ margin: 0
832
+ },
833
+ children: JSON.stringify(state.state, null, 2)
834
+ }
835
+ )
836
+ ] }),
837
+ state.running && /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
838
+ "div",
839
+ {
840
+ style: {
841
+ marginTop: "16px",
842
+ display: "flex",
843
+ alignItems: "center",
844
+ fontSize: "14px",
845
+ color: "#4b5563"
846
+ },
847
+ children: [
848
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { style: { marginRight: "8px" }, children: /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
849
+ "svg",
850
+ {
851
+ width: "16",
852
+ height: "16",
853
+ viewBox: "0 0 16 16",
854
+ style: { animation: "spin 1s linear infinite" },
855
+ children: [
856
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("style", { children: `@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }` }),
857
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
858
+ "circle",
859
+ {
860
+ cx: "8",
861
+ cy: "8",
862
+ r: "6",
863
+ fill: "none",
864
+ stroke: "#4b5563",
865
+ strokeWidth: "2",
866
+ strokeDasharray: "9 3"
867
+ }
868
+ )
869
+ ]
870
+ }
871
+ ) }),
872
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("span", { children: "Agent is currently running..." })
873
+ ]
874
+ }
875
+ )
876
+ ]
877
+ },
878
+ agentName
879
+ )) });
880
+ }
881
+ function MessagesTab({ messagesContext }) {
882
+ const messages = messagesContext.messages || [];
883
+ if (messages.length === 0) {
884
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { style: { textAlign: "center", padding: "48px 0", color: "#6b7280" }, children: [
885
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { style: { fontSize: "18px", margin: "0 0 8px 0" }, children: "No messages yet" }),
886
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { style: { fontSize: "14px", margin: 0 }, children: "Messages will appear here as the conversation progresses" })
887
+ ] });
888
+ }
889
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { style: { display: "flex", flexDirection: "column", gap: "16px" }, children: messages.map((message, index) => /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
890
+ "div",
891
+ {
892
+ style: {
893
+ padding: "16px",
894
+ borderRadius: "8px",
895
+ backgroundColor: message.role === "user" ? "#eff6ff" : message.role === "assistant" ? "#f9fafb" : "#fefce8",
896
+ border: `1px solid ${message.role === "user" ? "#c7d2fe" : message.role === "assistant" ? "#e5e7eb" : "#fde047"}`,
897
+ marginLeft: message.role === "user" ? "48px" : "0",
898
+ marginRight: message.role === "assistant" ? "48px" : "0"
899
+ },
900
+ children: [
901
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
902
+ "div",
903
+ {
904
+ style: {
905
+ display: "flex",
906
+ alignItems: "flex-start",
907
+ justifyContent: "space-between",
908
+ marginBottom: "8px"
909
+ },
910
+ children: [
911
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
912
+ "span",
913
+ {
914
+ style: {
915
+ fontWeight: "500",
916
+ fontSize: "14px",
917
+ color: "#374151",
918
+ textTransform: "capitalize"
919
+ },
920
+ children: message.role || "system"
921
+ }
922
+ ),
923
+ message.timestamp && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("span", { style: { fontSize: "12px", color: "#6b7280" }, children: new Date(message.timestamp).toLocaleTimeString() })
924
+ ]
925
+ }
926
+ ),
927
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { style: { fontSize: "14px", color: "#1f2937", whiteSpace: "pre-wrap" }, children: message.content || "" })
928
+ ]
929
+ },
930
+ index
931
+ )) });
932
+ }
933
+ function ContextTab({ context }) {
934
+ const documents = context.getDocumentsContext([]);
935
+ if (documents.length === 0) {
936
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { style: { textAlign: "center", padding: "48px 0", color: "#6b7280" }, children: [
937
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { style: { fontSize: "18px", margin: "0 0 8px 0" }, children: "No document context available" }),
938
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { style: { fontSize: "14px", margin: 0 }, children: "Document context will appear here when provided" })
939
+ ] });
940
+ }
941
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { style: { display: "flex", flexDirection: "column", gap: "16px" }, children: documents.map((doc, index) => /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
942
+ "div",
943
+ {
944
+ style: {
945
+ backgroundColor: "white",
946
+ padding: "16px",
947
+ borderRadius: "8px",
948
+ boxShadow: "0 1px 3px 0 rgba(0, 0, 0, 0.1)",
949
+ border: "1px solid #e5e7eb"
950
+ },
951
+ children: [
952
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("h3", { style: { fontWeight: "600", color: "#1f2937", margin: "0 0 8px 0" }, children: doc.name || `Document ${index + 1}` }),
953
+ doc.content && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
954
+ "pre",
955
+ {
956
+ style: {
957
+ padding: "12px",
958
+ backgroundColor: "#f9fafb",
959
+ borderRadius: "4px",
960
+ fontSize: "12px",
961
+ overflowX: "auto",
962
+ margin: 0
963
+ },
964
+ children: doc.content
965
+ }
966
+ )
967
+ ]
968
+ },
969
+ index
970
+ )) });
971
+ }
972
+
973
+ // src/components/dev-console/console-trigger.tsx
974
+ var import_jsx_runtime3 = require("react/jsx-runtime");
975
+ function ConsoleTrigger({ position = "bottom-right" }) {
976
+ const context = useCopilotContext();
977
+ const hasApiKey = Boolean(context.copilotApiConfig.publicApiKey);
978
+ const [isModalOpen, setIsModalOpen] = (0, import_react4.useState)(false);
979
+ const [isHovered, setIsHovered] = (0, import_react4.useState)(false);
980
+ const [isDragging, setIsDragging] = (0, import_react4.useState)(false);
981
+ const [buttonPosition, setButtonPosition] = (0, import_react4.useState)(null);
982
+ const [mounted, setMounted] = (0, import_react4.useState)(false);
983
+ const dragRef = (0, import_react4.useRef)(null);
984
+ const buttonRef = (0, import_react4.useRef)(null);
985
+ (0, import_react4.useEffect)(() => {
986
+ setMounted(true);
987
+ if (typeof window !== "undefined" && !buttonPosition) {
988
+ const buttonSize = 60;
989
+ const margin = 24;
990
+ const initialPosition = {
991
+ x: margin,
992
+ y: window.innerHeight - buttonSize - margin
993
+ };
994
+ setButtonPosition(initialPosition);
995
+ }
996
+ }, [position]);
997
+ const handleMouseDown = (e) => {
998
+ e.preventDefault();
999
+ if (!buttonPosition)
1000
+ return;
1001
+ dragRef.current = {
1002
+ startX: e.clientX,
1003
+ startY: e.clientY,
1004
+ buttonX: buttonPosition.x,
1005
+ buttonY: buttonPosition.y
1006
+ };
1007
+ setIsDragging(true);
1008
+ };
1009
+ (0, import_react4.useEffect)(() => {
1010
+ if (!isDragging)
1011
+ return;
1012
+ const handleMouseMove = (e) => {
1013
+ e.preventDefault();
1014
+ e.stopPropagation();
1015
+ if (!dragRef.current)
1016
+ return;
1017
+ const deltaX = e.clientX - dragRef.current.startX;
1018
+ const deltaY = e.clientY - dragRef.current.startY;
1019
+ let newX = dragRef.current.buttonX + deltaX;
1020
+ let newY = dragRef.current.buttonY + deltaY;
1021
+ newX = Math.max(0, Math.min(newX, window.innerWidth - 60));
1022
+ newY = Math.max(0, Math.min(newY, window.innerHeight - 60));
1023
+ setButtonPosition({ x: newX, y: newY });
1024
+ };
1025
+ const handleMouseUp = (e) => {
1026
+ e.preventDefault();
1027
+ e.stopPropagation();
1028
+ setIsDragging(false);
1029
+ dragRef.current = null;
1030
+ };
1031
+ document.addEventListener("mousemove", handleMouseMove, { capture: true, passive: false });
1032
+ document.addEventListener("mouseup", handleMouseUp, { capture: true, passive: false });
1033
+ return () => {
1034
+ document.removeEventListener("mousemove", handleMouseMove, { capture: true });
1035
+ document.removeEventListener("mouseup", handleMouseUp, { capture: true });
1036
+ };
1037
+ }, [isDragging]);
1038
+ if (!mounted || !buttonPosition) {
1039
+ return null;
1040
+ }
1041
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(import_jsx_runtime3.Fragment, { children: [
1042
+ /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(
1043
+ "button",
1044
+ {
1045
+ ref: buttonRef,
1046
+ onClick: () => {
1047
+ if (!isDragging) {
1048
+ setIsModalOpen(true);
1049
+ }
1050
+ },
1051
+ onMouseDown: handleMouseDown,
1052
+ onMouseEnter: () => setIsHovered(true),
1053
+ onMouseLeave: () => setIsHovered(false),
1054
+ style: {
1055
+ position: "fixed",
1056
+ left: `${buttonPosition.x}px`,
1057
+ top: `${buttonPosition.y}px`,
1058
+ zIndex: 2147483647,
1059
+ width: "60px",
1060
+ height: "60px",
1061
+ background: isDragging ? "#000000" : isHovered ? "#111111" : "#000000",
1062
+ color: "white",
1063
+ borderRadius: "50%",
1064
+ boxShadow: isDragging ? "0 8px 32px rgba(0, 0, 0, 0.6), 0 4px 16px rgba(0, 0, 0, 0.4)" : isHovered ? "0 12px 40px rgba(0, 0, 0, 0.7), 0 6px 20px rgba(0, 0, 0, 0.5)" : "0 6px 20px rgba(0, 0, 0, 0.5), 0 3px 10px rgba(0, 0, 0, 0.3)",
1065
+ transition: isDragging ? "none" : "all 0.3s cubic-bezier(0.4, 0, 0.2, 1)",
1066
+ display: "flex",
1067
+ alignItems: "center",
1068
+ justifyContent: "center",
1069
+ border: "none",
1070
+ cursor: isDragging ? "grabbing" : "grab",
1071
+ opacity: 1,
1072
+ userSelect: "none",
1073
+ transform: isDragging ? "scale(1.05)" : isHovered ? "scale(1.1)" : "scale(1)",
1074
+ backdropFilter: "blur(10px)",
1075
+ pointerEvents: "auto",
1076
+ isolation: "isolate"
1077
+ },
1078
+ title: hasApiKey ? "Open Developer Console (Drag to move)" : "Developer Console (API Key Required, Drag to move)",
1079
+ children: [
1080
+ /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
1081
+ "div",
1082
+ {
1083
+ style: {
1084
+ width: "28px",
1085
+ height: "28px",
1086
+ display: "flex",
1087
+ alignItems: "center",
1088
+ justifyContent: "center",
1089
+ filter: "drop-shadow(0 2px 4px rgba(0,0,0,0.2))"
1090
+ },
1091
+ children: /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(CopilotKitIcon, {})
1092
+ }
1093
+ ),
1094
+ !hasApiKey && /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
1095
+ "div",
1096
+ {
1097
+ style: {
1098
+ position: "absolute",
1099
+ top: "-2px",
1100
+ right: "-2px",
1101
+ width: "18px",
1102
+ height: "18px",
1103
+ background: "linear-gradient(135deg, #ff6b6b 0%, #ee5a24 100%)",
1104
+ borderRadius: "50%",
1105
+ display: "flex",
1106
+ alignItems: "center",
1107
+ justifyContent: "center",
1108
+ boxShadow: "0 2px 8px rgba(255, 107, 107, 0.4)",
1109
+ border: "2px solid white"
1110
+ },
1111
+ children: /* @__PURE__ */ (0, import_jsx_runtime3.jsx)("span", { style: { fontSize: "10px", color: "white", fontWeight: "bold" }, children: "!" })
1112
+ }
1113
+ )
1114
+ ]
1115
+ }
1116
+ ),
1117
+ /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
1118
+ DeveloperConsoleModal,
1119
+ {
1120
+ isOpen: isModalOpen,
1121
+ onClose: () => setIsModalOpen(false),
1122
+ hasApiKey
1123
+ }
1124
+ )
1125
+ ] });
1126
+ }
1127
+ // Annotate the CommonJS export names for ESM import in node:
1128
+ 0 && (module.exports = {
1129
+ ConsoleTrigger
1130
+ });
1131
+ //# sourceMappingURL=console-trigger.js.map