@copilotkit/react-core 1.10.0-next.9 → 1.10.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.
- package/CHANGELOG.md +104 -0
- package/dist/{chunk-VH45SC6Z.mjs → chunk-2GRWTU7W.mjs} +2 -2
- package/dist/chunk-3BASANUO.mjs +170 -0
- package/dist/chunk-3BASANUO.mjs.map +1 -0
- package/dist/{chunk-PHIMGB3K.mjs → chunk-5P46WS5M.mjs} +25 -19
- package/dist/chunk-5P46WS5M.mjs.map +1 -0
- package/dist/{chunk-AWFAFFO5.mjs → chunk-6ZLPNY7X.mjs} +7 -3
- package/dist/chunk-6ZLPNY7X.mjs.map +1 -0
- package/dist/{chunk-TTI4Z6GK.mjs → chunk-BEFEBKKI.mjs} +7 -7
- package/dist/chunk-BEFEBKKI.mjs.map +1 -0
- package/dist/{chunk-VSH4JSN3.mjs → chunk-F26O2HTO.mjs} +13 -7
- package/dist/chunk-F26O2HTO.mjs.map +1 -0
- package/dist/{chunk-GRCHDHC4.mjs → chunk-JY3STRON.mjs} +22 -4
- package/dist/chunk-JY3STRON.mjs.map +1 -0
- package/dist/{chunk-ZTZJIDRJ.mjs → chunk-N4VN2B5S.mjs} +2 -2
- package/dist/{chunk-FTP6FDYS.mjs → chunk-NTH42BY5.mjs} +2 -2
- package/dist/chunk-PIF5KJYI.mjs +103 -0
- package/dist/chunk-PIF5KJYI.mjs.map +1 -0
- package/dist/chunk-WSXTUD36.mjs +759 -0
- package/dist/chunk-WSXTUD36.mjs.map +1 -0
- package/dist/chunk-YIBUNEBN.mjs +34 -0
- package/dist/chunk-YIBUNEBN.mjs.map +1 -0
- package/dist/components/copilot-provider/copilotkit-props.d.ts +9 -1
- package/dist/components/copilot-provider/copilotkit-props.js.map +1 -1
- package/dist/components/copilot-provider/copilotkit.js +1052 -72
- package/dist/components/copilot-provider/copilotkit.js.map +1 -1
- package/dist/components/copilot-provider/copilotkit.mjs +6 -3
- package/dist/components/copilot-provider/index.js +1052 -72
- package/dist/components/copilot-provider/index.js.map +1 -1
- package/dist/components/copilot-provider/index.mjs +6 -3
- package/dist/components/dev-console/console-trigger.d.ts +8 -0
- package/dist/components/dev-console/console-trigger.js +1131 -0
- package/dist/components/dev-console/console-trigger.js.map +1 -0
- package/dist/components/dev-console/console-trigger.mjs +13 -0
- package/dist/components/dev-console/developer-console-modal.d.ts +10 -0
- package/dist/components/dev-console/developer-console-modal.js +977 -0
- package/dist/components/dev-console/developer-console-modal.js.map +1 -0
- package/dist/components/dev-console/developer-console-modal.mjs +12 -0
- package/dist/components/dev-console/developer-console-modal.mjs.map +1 -0
- package/dist/components/dev-console/icons.d.ts +9 -0
- package/dist/components/dev-console/icons.js +131 -0
- package/dist/components/dev-console/icons.js.map +1 -0
- package/dist/components/dev-console/icons.mjs +16 -0
- package/dist/components/dev-console/icons.mjs.map +1 -0
- package/dist/components/error-boundary/error-boundary.js +6 -2
- package/dist/components/error-boundary/error-boundary.js.map +1 -1
- package/dist/components/error-boundary/error-boundary.mjs +2 -2
- package/dist/components/index.js +1052 -72
- package/dist/components/index.js.map +1 -1
- package/dist/components/index.mjs +6 -3
- package/dist/components/usage-banner.d.ts +2 -1
- package/dist/components/usage-banner.js +6 -2
- package/dist/components/usage-banner.js.map +1 -1
- package/dist/components/usage-banner.mjs +1 -1
- package/dist/hooks/index.d.ts +5 -5
- package/dist/hooks/index.js +58 -26
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/index.mjs +13 -10
- package/dist/hooks/use-coagent.d.ts +1 -1
- package/dist/hooks/use-coagent.js +18 -6
- package/dist/hooks/use-coagent.js.map +1 -1
- package/dist/hooks/use-coagent.mjs +8 -5
- package/dist/hooks/use-copilot-chat-headless_c.d.ts +33 -0
- package/dist/hooks/{use-copilot-chat-light.js → use-copilot-chat-headless_c.js} +88 -19
- package/dist/hooks/use-copilot-chat-headless_c.js.map +1 -0
- package/dist/hooks/{use-copilot-chat-light.mjs → use-copilot-chat-headless_c.mjs} +14 -8
- package/dist/hooks/use-copilot-chat-headless_c.mjs.map +1 -0
- package/dist/hooks/use-copilot-chat.d.ts +85 -4
- package/dist/hooks/use-copilot-chat.js +38 -61
- package/dist/hooks/use-copilot-chat.js.map +1 -1
- package/dist/hooks/use-copilot-chat.mjs +8 -8
- package/dist/hooks/use-copilot-chat_internal.d.ts +98 -12
- package/dist/hooks/use-copilot-chat_internal.js +13 -1
- package/dist/hooks/use-copilot-chat_internal.js.map +1 -1
- package/dist/hooks/use-copilot-chat_internal.mjs +7 -4
- package/dist/hooks/use-langgraph-interrupt.js +13 -1
- package/dist/hooks/use-langgraph-interrupt.js.map +1 -1
- package/dist/hooks/use-langgraph-interrupt.mjs +8 -5
- package/dist/index.d.ts +3 -3
- package/dist/index.js +1203 -200
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +14 -11
- package/dist/lib/copilot-task.js.map +1 -1
- package/dist/lib/copilot-task.mjs +7 -4
- package/dist/lib/index.js.map +1 -1
- package/dist/lib/index.mjs +7 -4
- package/dist/utils/extract.js.map +1 -1
- package/dist/utils/extract.mjs +6 -3
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/index.mjs +6 -3
- package/dist/utils/suggestions.js.map +1 -1
- package/dist/utils/suggestions.mjs +6 -3
- package/package.json +3 -3
- package/src/components/copilot-provider/copilotkit-props.tsx +10 -1
- package/src/components/copilot-provider/copilotkit.tsx +25 -16
- package/src/components/dev-console/console-trigger.tsx +190 -0
- package/src/components/dev-console/developer-console-modal.tsx +866 -0
- package/src/components/dev-console/icons.tsx +101 -0
- package/src/components/usage-banner.tsx +8 -3
- package/src/hooks/index.ts +6 -7
- package/src/hooks/use-coagent.ts +6 -11
- package/src/hooks/use-copilot-chat-headless_c.ts +257 -0
- package/src/hooks/use-copilot-chat.ts +103 -154
- package/src/hooks/use-copilot-chat_internal.ts +122 -15
- package/dist/chunk-AWFAFFO5.mjs.map +0 -1
- package/dist/chunk-GRCHDHC4.mjs.map +0 -1
- package/dist/chunk-MWHILKQH.mjs +0 -18
- package/dist/chunk-MWHILKQH.mjs.map +0 -1
- package/dist/chunk-PHIMGB3K.mjs.map +0 -1
- package/dist/chunk-TTI4Z6GK.mjs.map +0 -1
- package/dist/chunk-VSH4JSN3.mjs.map +0 -1
- package/dist/hooks/use-copilot-chat-light.d.ts +0 -211
- package/dist/hooks/use-copilot-chat-light.js.map +0 -1
- package/src/hooks/use-copilot-chat-light.ts +0 -219
- /package/dist/{chunk-VH45SC6Z.mjs.map → chunk-2GRWTU7W.mjs.map} +0 -0
- /package/dist/{chunk-ZTZJIDRJ.mjs.map → chunk-N4VN2B5S.mjs.map} +0 -0
- /package/dist/{chunk-FTP6FDYS.mjs.map → chunk-NTH42BY5.mjs.map} +0 -0
- /package/dist/{hooks/use-copilot-chat-light.mjs.map → components/dev-console/console-trigger.mjs.map} +0 -0
|
@@ -86,7 +86,7 @@ __export(copilot_provider_exports, {
|
|
|
86
86
|
module.exports = __toCommonJS(copilot_provider_exports);
|
|
87
87
|
|
|
88
88
|
// src/components/copilot-provider/copilotkit.tsx
|
|
89
|
-
var
|
|
89
|
+
var import_react11 = require("react");
|
|
90
90
|
|
|
91
91
|
// src/context/copilot-context.tsx
|
|
92
92
|
var import_react = __toESM(require("react"));
|
|
@@ -315,7 +315,7 @@ function setsHaveIntersection(setA, setB) {
|
|
|
315
315
|
|
|
316
316
|
// src/components/copilot-provider/copilotkit.tsx
|
|
317
317
|
var import_react_dom = require("react-dom");
|
|
318
|
-
var
|
|
318
|
+
var import_shared10 = require("@copilotkit/shared");
|
|
319
319
|
|
|
320
320
|
// src/hooks/use-flat-category-store.ts
|
|
321
321
|
var import_react3 = require("react");
|
|
@@ -396,6 +396,15 @@ var emptyCopilotContext2 = {
|
|
|
396
396
|
setSuggestions: () => []
|
|
397
397
|
};
|
|
398
398
|
var CopilotMessagesContext = import_react4.default.createContext(emptyCopilotContext2);
|
|
399
|
+
function useCopilotMessagesContext() {
|
|
400
|
+
const context = import_react4.default.useContext(CopilotMessagesContext);
|
|
401
|
+
if (context === emptyCopilotContext2) {
|
|
402
|
+
throw new Error(
|
|
403
|
+
"A messages consuming component was not wrapped with `<CopilotMessages> {...} </CopilotMessages>`"
|
|
404
|
+
);
|
|
405
|
+
}
|
|
406
|
+
return context;
|
|
407
|
+
}
|
|
399
408
|
|
|
400
409
|
// src/components/copilot-provider/copilot-messages.tsx
|
|
401
410
|
var import_runtime_client_gql = require("@copilotkit/runtime-client-gql");
|
|
@@ -1075,8 +1084,12 @@ var getErrorActions = (error) => {
|
|
|
1075
1084
|
case import_shared5.CopilotKitErrorCode.MISSING_PUBLIC_API_KEY_ERROR:
|
|
1076
1085
|
return {
|
|
1077
1086
|
primary: {
|
|
1078
|
-
label: "
|
|
1079
|
-
onClick: () => window.open(
|
|
1087
|
+
label: "Show me how",
|
|
1088
|
+
onClick: () => window.open(
|
|
1089
|
+
"https://docs.copilotkit.ai/premium#how-do-i-get-access-to-premium-features",
|
|
1090
|
+
"_blank",
|
|
1091
|
+
"noopener,noreferrer"
|
|
1092
|
+
)
|
|
1080
1093
|
}
|
|
1081
1094
|
};
|
|
1082
1095
|
case import_shared5.CopilotKitErrorCode.UPGRADE_REQUIRED_ERROR:
|
|
@@ -1326,69 +1339,1030 @@ var CopilotErrorBoundary = class extends import_react8.default.Component {
|
|
|
1326
1339
|
}
|
|
1327
1340
|
};
|
|
1328
1341
|
|
|
1329
|
-
// src/components/
|
|
1342
|
+
// src/components/dev-console/console-trigger.tsx
|
|
1343
|
+
var import_react10 = require("react");
|
|
1344
|
+
|
|
1345
|
+
// src/components/dev-console/icons.tsx
|
|
1330
1346
|
var import_jsx_runtime5 = require("react/jsx-runtime");
|
|
1347
|
+
var ExclamationMarkTriangleIcon = () => /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
|
|
1348
|
+
"svg",
|
|
1349
|
+
{
|
|
1350
|
+
width: "13.3967723px",
|
|
1351
|
+
height: "12px",
|
|
1352
|
+
viewBox: "0 0 13.3967723 12",
|
|
1353
|
+
version: "1.1",
|
|
1354
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
1355
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("g", { id: "exclamation-triangle", fill: "#CD2121", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
|
|
1356
|
+
"path",
|
|
1357
|
+
{
|
|
1358
|
+
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",
|
|
1359
|
+
id: "Shape"
|
|
1360
|
+
}
|
|
1361
|
+
) }) })
|
|
1362
|
+
}
|
|
1363
|
+
);
|
|
1364
|
+
var CheckIcon = () => /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
|
|
1365
|
+
"svg",
|
|
1366
|
+
{
|
|
1367
|
+
width: "14px",
|
|
1368
|
+
height: "14px",
|
|
1369
|
+
viewBox: "0 0 14 14",
|
|
1370
|
+
version: "1.1",
|
|
1371
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
1372
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("g", { id: "Group-2", transform: "translate(-118, 0)", fill: "#1BC030", fillRule: "nonzero", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("g", { id: "Group", transform: "translate(118, 0)", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
|
|
1373
|
+
"path",
|
|
1374
|
+
{
|
|
1375
|
+
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",
|
|
1376
|
+
id: "Shape"
|
|
1377
|
+
}
|
|
1378
|
+
) }) }) })
|
|
1379
|
+
}
|
|
1380
|
+
);
|
|
1381
|
+
var CopilotKitIcon = () => /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(
|
|
1382
|
+
"svg",
|
|
1383
|
+
{
|
|
1384
|
+
width: "33px",
|
|
1385
|
+
height: "35px",
|
|
1386
|
+
viewBox: "0 0 33 35",
|
|
1387
|
+
version: "1.1",
|
|
1388
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
1389
|
+
children: [
|
|
1390
|
+
/* @__PURE__ */ (0, import_jsx_runtime5.jsx)("title", { children: "bd5c9079-929b-4d55-bdc9-16d1c8181b71" }),
|
|
1391
|
+
/* @__PURE__ */ (0, import_jsx_runtime5.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
|
|
1392
|
+
"image",
|
|
1393
|
+
{
|
|
1394
|
+
x: "0",
|
|
1395
|
+
y: "0",
|
|
1396
|
+
width: "33",
|
|
1397
|
+
height: "35",
|
|
1398
|
+
xlinkHref: ""
|
|
1399
|
+
}
|
|
1400
|
+
) })
|
|
1401
|
+
]
|
|
1402
|
+
}
|
|
1403
|
+
);
|
|
1404
|
+
|
|
1405
|
+
// src/components/dev-console/developer-console-modal.tsx
|
|
1406
|
+
var import_shared9 = require("@copilotkit/shared");
|
|
1407
|
+
var import_react9 = require("react");
|
|
1408
|
+
var import_jsx_runtime6 = require("react/jsx-runtime");
|
|
1409
|
+
function DeveloperConsoleModal({ isOpen, onClose, hasApiKey }) {
|
|
1410
|
+
const context = useCopilotContext();
|
|
1411
|
+
const messagesContext = useCopilotMessagesContext();
|
|
1412
|
+
const [activeTab, setActiveTab] = (0, import_react9.useState)("actions");
|
|
1413
|
+
(0, import_react9.useEffect)(() => {
|
|
1414
|
+
const handleEscape = (e) => {
|
|
1415
|
+
if (e.key === "Escape") {
|
|
1416
|
+
onClose();
|
|
1417
|
+
}
|
|
1418
|
+
};
|
|
1419
|
+
if (isOpen) {
|
|
1420
|
+
document.addEventListener("keydown", handleEscape);
|
|
1421
|
+
document.body.style.overflow = "hidden";
|
|
1422
|
+
}
|
|
1423
|
+
return () => {
|
|
1424
|
+
document.removeEventListener("keydown", handleEscape);
|
|
1425
|
+
document.body.style.overflow = "unset";
|
|
1426
|
+
};
|
|
1427
|
+
}, [isOpen, onClose]);
|
|
1428
|
+
if (!isOpen)
|
|
1429
|
+
return null;
|
|
1430
|
+
const displayContext = hasApiKey ? context : {
|
|
1431
|
+
actions: {
|
|
1432
|
+
search_web: { name: "search_web", description: "Search the web for information" },
|
|
1433
|
+
send_email: { name: "send_email", description: "Send an email to a contact" },
|
|
1434
|
+
create_document: { name: "create_document", description: "Create a new document" },
|
|
1435
|
+
analyze_code: {
|
|
1436
|
+
name: "analyze_code",
|
|
1437
|
+
description: "Analyze code for issues and improvements"
|
|
1438
|
+
},
|
|
1439
|
+
generate_tests: {
|
|
1440
|
+
name: "generate_tests",
|
|
1441
|
+
description: "Generate unit tests for functions"
|
|
1442
|
+
}
|
|
1443
|
+
},
|
|
1444
|
+
getAllContext: () => [
|
|
1445
|
+
{
|
|
1446
|
+
content: "User preferences: dark mode enabled, TypeScript preferred",
|
|
1447
|
+
metadata: { source: "settings" }
|
|
1448
|
+
},
|
|
1449
|
+
{
|
|
1450
|
+
content: "Current project: Building a React application with CopilotKit",
|
|
1451
|
+
metadata: { source: "project" }
|
|
1452
|
+
},
|
|
1453
|
+
{
|
|
1454
|
+
content: "Recent activity: Implemented authentication system",
|
|
1455
|
+
metadata: { source: "activity" }
|
|
1456
|
+
},
|
|
1457
|
+
{
|
|
1458
|
+
content: "Development environment: VS Code, Node.js 18, React 18",
|
|
1459
|
+
metadata: { source: "environment" }
|
|
1460
|
+
}
|
|
1461
|
+
],
|
|
1462
|
+
coagentStates: {
|
|
1463
|
+
"main-agent": { status: "active", lastUpdate: Date.now() },
|
|
1464
|
+
"code-assistant": { status: "active", lastUpdate: Date.now() - 15e3 },
|
|
1465
|
+
"search-agent": { status: "idle", lastUpdate: Date.now() - 6e4 }
|
|
1466
|
+
},
|
|
1467
|
+
getDocumentsContext: () => [
|
|
1468
|
+
{
|
|
1469
|
+
content: "README.md: Project setup and installation instructions",
|
|
1470
|
+
metadata: { type: "documentation" }
|
|
1471
|
+
},
|
|
1472
|
+
{
|
|
1473
|
+
content: "API Documentation: CopilotKit integration guide",
|
|
1474
|
+
metadata: { type: "documentation" }
|
|
1475
|
+
},
|
|
1476
|
+
{
|
|
1477
|
+
content: "package.json: Project dependencies and scripts",
|
|
1478
|
+
metadata: { type: "configuration" }
|
|
1479
|
+
}
|
|
1480
|
+
]
|
|
1481
|
+
};
|
|
1482
|
+
const displayMessagesContext = hasApiKey ? messagesContext : {
|
|
1483
|
+
messages: [
|
|
1484
|
+
{
|
|
1485
|
+
id: "1",
|
|
1486
|
+
role: "user",
|
|
1487
|
+
content: "Help me implement a todo list with drag and drop functionality"
|
|
1488
|
+
},
|
|
1489
|
+
{
|
|
1490
|
+
id: "2",
|
|
1491
|
+
role: "assistant",
|
|
1492
|
+
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."
|
|
1493
|
+
},
|
|
1494
|
+
{ id: "3", role: "user", content: "Can you also add priority levels and due dates?" },
|
|
1495
|
+
{
|
|
1496
|
+
id: "4",
|
|
1497
|
+
role: "assistant",
|
|
1498
|
+
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."
|
|
1499
|
+
},
|
|
1500
|
+
{ id: "5", role: "user", content: "Perfect! How about adding categories or tags?" }
|
|
1501
|
+
]
|
|
1502
|
+
};
|
|
1503
|
+
return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1504
|
+
"div",
|
|
1505
|
+
{
|
|
1506
|
+
style: {
|
|
1507
|
+
position: "fixed",
|
|
1508
|
+
top: 0,
|
|
1509
|
+
left: 0,
|
|
1510
|
+
right: 0,
|
|
1511
|
+
bottom: 0,
|
|
1512
|
+
zIndex: 9999,
|
|
1513
|
+
backgroundColor: "rgba(0, 0, 0, 0.3)",
|
|
1514
|
+
display: "flex",
|
|
1515
|
+
alignItems: "center",
|
|
1516
|
+
justifyContent: "center",
|
|
1517
|
+
padding: "16px"
|
|
1518
|
+
},
|
|
1519
|
+
onClick: onClose,
|
|
1520
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
1521
|
+
"div",
|
|
1522
|
+
{
|
|
1523
|
+
style: {
|
|
1524
|
+
width: "1152px",
|
|
1525
|
+
maxWidth: "95vw",
|
|
1526
|
+
height: "80vh",
|
|
1527
|
+
backgroundColor: "white",
|
|
1528
|
+
borderRadius: "12px",
|
|
1529
|
+
boxShadow: "0 25px 50px -12px rgba(0, 0, 0, 0.25)",
|
|
1530
|
+
display: "flex",
|
|
1531
|
+
flexDirection: "column",
|
|
1532
|
+
overflow: "hidden",
|
|
1533
|
+
position: "relative"
|
|
1534
|
+
},
|
|
1535
|
+
onClick: (e) => e.stopPropagation(),
|
|
1536
|
+
children: [
|
|
1537
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
1538
|
+
"div",
|
|
1539
|
+
{
|
|
1540
|
+
style: {
|
|
1541
|
+
display: "flex",
|
|
1542
|
+
alignItems: "center",
|
|
1543
|
+
justifyContent: "space-between",
|
|
1544
|
+
padding: "24px",
|
|
1545
|
+
borderBottom: "1px solid #e5e7eb",
|
|
1546
|
+
minHeight: "73px",
|
|
1547
|
+
flexShrink: 0,
|
|
1548
|
+
filter: !hasApiKey ? "blur(0.3px)" : "none",
|
|
1549
|
+
opacity: !hasApiKey ? 0.95 : 1
|
|
1550
|
+
},
|
|
1551
|
+
children: [
|
|
1552
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { style: { display: "flex", alignItems: "center", gap: "12px" }, children: [
|
|
1553
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)(CopilotKitIcon, {}),
|
|
1554
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1555
|
+
"h1",
|
|
1556
|
+
{
|
|
1557
|
+
style: {
|
|
1558
|
+
fontWeight: "bold",
|
|
1559
|
+
fontSize: "20px",
|
|
1560
|
+
color: "#1f2937",
|
|
1561
|
+
margin: 0
|
|
1562
|
+
},
|
|
1563
|
+
children: "Developer Console"
|
|
1564
|
+
}
|
|
1565
|
+
),
|
|
1566
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
1567
|
+
"span",
|
|
1568
|
+
{
|
|
1569
|
+
style: {
|
|
1570
|
+
fontSize: "14px",
|
|
1571
|
+
color: "#6b7280",
|
|
1572
|
+
backgroundColor: "#f3f4f6",
|
|
1573
|
+
padding: "4px 8px",
|
|
1574
|
+
borderRadius: "4px"
|
|
1575
|
+
},
|
|
1576
|
+
children: [
|
|
1577
|
+
"v",
|
|
1578
|
+
import_shared9.COPILOTKIT_VERSION
|
|
1579
|
+
]
|
|
1580
|
+
}
|
|
1581
|
+
)
|
|
1582
|
+
] }),
|
|
1583
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1584
|
+
"button",
|
|
1585
|
+
{
|
|
1586
|
+
onClick: onClose,
|
|
1587
|
+
style: {
|
|
1588
|
+
color: "#9ca3af",
|
|
1589
|
+
fontSize: "24px",
|
|
1590
|
+
fontWeight: "300",
|
|
1591
|
+
border: "none",
|
|
1592
|
+
background: "none",
|
|
1593
|
+
cursor: "pointer",
|
|
1594
|
+
padding: "4px"
|
|
1595
|
+
},
|
|
1596
|
+
onMouseEnter: (e) => e.currentTarget.style.color = "#4b5563",
|
|
1597
|
+
onMouseLeave: (e) => e.currentTarget.style.color = "#9ca3af",
|
|
1598
|
+
children: "\xD7"
|
|
1599
|
+
}
|
|
1600
|
+
)
|
|
1601
|
+
]
|
|
1602
|
+
}
|
|
1603
|
+
),
|
|
1604
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1605
|
+
"div",
|
|
1606
|
+
{
|
|
1607
|
+
style: {
|
|
1608
|
+
display: "flex",
|
|
1609
|
+
borderBottom: "1px solid #e5e7eb",
|
|
1610
|
+
backgroundColor: "#f9fafb",
|
|
1611
|
+
minHeight: "50px",
|
|
1612
|
+
flexShrink: 0,
|
|
1613
|
+
filter: !hasApiKey ? "blur(0.3px)" : "none",
|
|
1614
|
+
opacity: !hasApiKey ? 0.9 : 1
|
|
1615
|
+
},
|
|
1616
|
+
children: [
|
|
1617
|
+
{ id: "actions", label: "Actions", count: Object.keys(displayContext.actions).length },
|
|
1618
|
+
{ id: "readables", label: "Readables", count: displayContext.getAllContext().length },
|
|
1619
|
+
{
|
|
1620
|
+
id: "agent",
|
|
1621
|
+
label: "Agent Status",
|
|
1622
|
+
count: Object.keys(displayContext.coagentStates).length
|
|
1623
|
+
},
|
|
1624
|
+
{ id: "messages", label: "Messages", count: displayMessagesContext.messages.length },
|
|
1625
|
+
{
|
|
1626
|
+
id: "context",
|
|
1627
|
+
label: "Context",
|
|
1628
|
+
count: displayContext.getDocumentsContext([]).length
|
|
1629
|
+
}
|
|
1630
|
+
].map((tab) => /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
1631
|
+
"button",
|
|
1632
|
+
{
|
|
1633
|
+
onClick: () => setActiveTab(tab.id),
|
|
1634
|
+
style: {
|
|
1635
|
+
padding: "12px 24px",
|
|
1636
|
+
fontSize: "14px",
|
|
1637
|
+
fontWeight: "500",
|
|
1638
|
+
border: "none",
|
|
1639
|
+
cursor: "pointer",
|
|
1640
|
+
backgroundColor: activeTab === tab.id ? "white" : "transparent",
|
|
1641
|
+
color: activeTab === tab.id ? "#2563eb" : "#6b7280",
|
|
1642
|
+
borderBottom: activeTab === tab.id ? "2px solid #2563eb" : "none",
|
|
1643
|
+
transition: "all 0.2s"
|
|
1644
|
+
},
|
|
1645
|
+
onMouseEnter: (e) => {
|
|
1646
|
+
if (activeTab !== tab.id) {
|
|
1647
|
+
e.currentTarget.style.color = "#1f2937";
|
|
1648
|
+
e.currentTarget.style.backgroundColor = "#f3f4f6";
|
|
1649
|
+
}
|
|
1650
|
+
},
|
|
1651
|
+
onMouseLeave: (e) => {
|
|
1652
|
+
if (activeTab !== tab.id) {
|
|
1653
|
+
e.currentTarget.style.color = "#6b7280";
|
|
1654
|
+
e.currentTarget.style.backgroundColor = "transparent";
|
|
1655
|
+
}
|
|
1656
|
+
},
|
|
1657
|
+
children: [
|
|
1658
|
+
tab.label,
|
|
1659
|
+
tab.count > 0 && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1660
|
+
"span",
|
|
1661
|
+
{
|
|
1662
|
+
style: {
|
|
1663
|
+
marginLeft: "8px",
|
|
1664
|
+
backgroundColor: "#e5e7eb",
|
|
1665
|
+
color: "#374151",
|
|
1666
|
+
padding: "2px 8px",
|
|
1667
|
+
borderRadius: "9999px",
|
|
1668
|
+
fontSize: "12px"
|
|
1669
|
+
},
|
|
1670
|
+
children: tab.count
|
|
1671
|
+
}
|
|
1672
|
+
)
|
|
1673
|
+
]
|
|
1674
|
+
},
|
|
1675
|
+
tab.id
|
|
1676
|
+
))
|
|
1677
|
+
}
|
|
1678
|
+
),
|
|
1679
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
1680
|
+
"div",
|
|
1681
|
+
{
|
|
1682
|
+
style: {
|
|
1683
|
+
height: "calc(100% - 142px)",
|
|
1684
|
+
overflow: "auto",
|
|
1685
|
+
padding: "24px",
|
|
1686
|
+
backgroundColor: "#f9fafb",
|
|
1687
|
+
filter: !hasApiKey ? "blur(0.3px)" : "none",
|
|
1688
|
+
opacity: !hasApiKey ? 0.85 : 1
|
|
1689
|
+
},
|
|
1690
|
+
children: [
|
|
1691
|
+
activeTab === "actions" && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(ActionsTab, { context: displayContext }),
|
|
1692
|
+
activeTab === "readables" && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(ReadablesTab, { context: displayContext }),
|
|
1693
|
+
activeTab === "agent" && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(AgentStatusTab, { context: displayContext }),
|
|
1694
|
+
activeTab === "messages" && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(MessagesTab, { messagesContext: displayMessagesContext }),
|
|
1695
|
+
activeTab === "context" && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(ContextTab, { context: displayContext })
|
|
1696
|
+
]
|
|
1697
|
+
}
|
|
1698
|
+
),
|
|
1699
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
1700
|
+
"div",
|
|
1701
|
+
{
|
|
1702
|
+
style: {
|
|
1703
|
+
padding: "16px 24px",
|
|
1704
|
+
borderTop: "1px solid #e5e7eb",
|
|
1705
|
+
backgroundColor: "white",
|
|
1706
|
+
display: "flex",
|
|
1707
|
+
justifyContent: "space-between",
|
|
1708
|
+
alignItems: "center",
|
|
1709
|
+
minHeight: "57px",
|
|
1710
|
+
flexShrink: 0,
|
|
1711
|
+
filter: !hasApiKey ? "blur(0.3px)" : "none",
|
|
1712
|
+
opacity: !hasApiKey ? 0.9 : 1
|
|
1713
|
+
},
|
|
1714
|
+
children: [
|
|
1715
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { fontSize: "14px", color: "#6b7280" }, children: /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1716
|
+
"a",
|
|
1717
|
+
{
|
|
1718
|
+
href: "https://github.com/CopilotKit/CopilotKit/issues",
|
|
1719
|
+
target: "_blank",
|
|
1720
|
+
rel: "noopener noreferrer",
|
|
1721
|
+
style: { color: "#2563eb", textDecoration: "none" },
|
|
1722
|
+
onMouseEnter: (e) => e.currentTarget.style.textDecoration = "underline",
|
|
1723
|
+
onMouseLeave: (e) => e.currentTarget.style.textDecoration = "none",
|
|
1724
|
+
children: "Report an issue"
|
|
1725
|
+
}
|
|
1726
|
+
) }),
|
|
1727
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { fontSize: "14px", color: "#6b7280" }, children: /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1728
|
+
"a",
|
|
1729
|
+
{
|
|
1730
|
+
href: "https://mcp.copilotkit.ai/",
|
|
1731
|
+
target: "_blank",
|
|
1732
|
+
rel: "noopener noreferrer",
|
|
1733
|
+
style: { color: "#2563eb", textDecoration: "none" },
|
|
1734
|
+
onMouseEnter: (e) => e.currentTarget.style.textDecoration = "underline",
|
|
1735
|
+
onMouseLeave: (e) => e.currentTarget.style.textDecoration = "none",
|
|
1736
|
+
children: "Add MCP Server \u2192"
|
|
1737
|
+
}
|
|
1738
|
+
) })
|
|
1739
|
+
]
|
|
1740
|
+
}
|
|
1741
|
+
),
|
|
1742
|
+
!hasApiKey && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1743
|
+
"div",
|
|
1744
|
+
{
|
|
1745
|
+
style: {
|
|
1746
|
+
position: "absolute",
|
|
1747
|
+
top: 0,
|
|
1748
|
+
left: 0,
|
|
1749
|
+
right: 0,
|
|
1750
|
+
bottom: 0,
|
|
1751
|
+
backgroundColor: "rgba(255, 255, 255, 0.2)",
|
|
1752
|
+
backdropFilter: "blur(2px)",
|
|
1753
|
+
WebkitBackdropFilter: "blur(2px)",
|
|
1754
|
+
display: "flex",
|
|
1755
|
+
alignItems: "center",
|
|
1756
|
+
justifyContent: "center",
|
|
1757
|
+
borderRadius: "12px",
|
|
1758
|
+
zIndex: 10
|
|
1759
|
+
},
|
|
1760
|
+
onClick: (e) => e.stopPropagation(),
|
|
1761
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
1762
|
+
"button",
|
|
1763
|
+
{
|
|
1764
|
+
onClick: () => window.open("https://cloud.copilotkit.ai/sign-in", "_blank"),
|
|
1765
|
+
style: {
|
|
1766
|
+
// Following button system specifications
|
|
1767
|
+
height: "48px",
|
|
1768
|
+
padding: "12px 24px",
|
|
1769
|
+
backgroundColor: "#030507",
|
|
1770
|
+
// textPrimary token
|
|
1771
|
+
color: "#FFFFFF",
|
|
1772
|
+
borderRadius: "12px",
|
|
1773
|
+
// Medium radius token
|
|
1774
|
+
border: "none",
|
|
1775
|
+
cursor: "pointer",
|
|
1776
|
+
fontSize: "14px",
|
|
1777
|
+
// Medium Semi Bold typography
|
|
1778
|
+
fontWeight: "600",
|
|
1779
|
+
fontFamily: "'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif",
|
|
1780
|
+
lineHeight: "22px",
|
|
1781
|
+
boxShadow: "0 4px 16px rgba(3, 5, 7, 0.2), 0 1px 3px rgba(3, 5, 7, 0.1)",
|
|
1782
|
+
transition: "all 200ms ease",
|
|
1783
|
+
// 200ms ease as per specs
|
|
1784
|
+
display: "inline-flex",
|
|
1785
|
+
alignItems: "center",
|
|
1786
|
+
gap: "8px",
|
|
1787
|
+
textTransform: "uppercase",
|
|
1788
|
+
letterSpacing: "0.5px"
|
|
1789
|
+
},
|
|
1790
|
+
onMouseEnter: (e) => {
|
|
1791
|
+
e.currentTarget.style.backgroundColor = "#575758";
|
|
1792
|
+
e.currentTarget.style.transform = "translateY(-1px)";
|
|
1793
|
+
e.currentTarget.style.boxShadow = "0 6px 20px rgba(3, 5, 7, 0.25), 0 2px 4px rgba(3, 5, 7, 0.15)";
|
|
1794
|
+
},
|
|
1795
|
+
onMouseLeave: (e) => {
|
|
1796
|
+
e.currentTarget.style.backgroundColor = "#030507";
|
|
1797
|
+
e.currentTarget.style.transform = "translateY(0)";
|
|
1798
|
+
e.currentTarget.style.boxShadow = "0 4px 16px rgba(3, 5, 7, 0.2), 0 1px 3px rgba(3, 5, 7, 0.1)";
|
|
1799
|
+
},
|
|
1800
|
+
onMouseDown: (e) => {
|
|
1801
|
+
e.currentTarget.style.backgroundColor = "#858589";
|
|
1802
|
+
e.currentTarget.style.transform = "translateY(0)";
|
|
1803
|
+
},
|
|
1804
|
+
onMouseUp: (e) => {
|
|
1805
|
+
e.currentTarget.style.backgroundColor = "#575758";
|
|
1806
|
+
e.currentTarget.style.transform = "translateY(-1px)";
|
|
1807
|
+
},
|
|
1808
|
+
onFocus: (e) => {
|
|
1809
|
+
e.currentTarget.style.outline = "2px solid #BEC9FF";
|
|
1810
|
+
e.currentTarget.style.outlineOffset = "2px";
|
|
1811
|
+
},
|
|
1812
|
+
onBlur: (e) => {
|
|
1813
|
+
e.currentTarget.style.outline = "none";
|
|
1814
|
+
},
|
|
1815
|
+
children: [
|
|
1816
|
+
"Get API Key",
|
|
1817
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("span", { style: { fontSize: "16px", marginLeft: "-4px" }, children: "\u2192" })
|
|
1818
|
+
]
|
|
1819
|
+
}
|
|
1820
|
+
)
|
|
1821
|
+
}
|
|
1822
|
+
)
|
|
1823
|
+
]
|
|
1824
|
+
}
|
|
1825
|
+
)
|
|
1826
|
+
}
|
|
1827
|
+
);
|
|
1828
|
+
}
|
|
1829
|
+
function ActionsTab({ context }) {
|
|
1830
|
+
const actions = Object.values(context.actions);
|
|
1831
|
+
if (actions.length === 0) {
|
|
1832
|
+
return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { style: { textAlign: "center", padding: "48px 0", color: "#6b7280" }, children: [
|
|
1833
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("p", { style: { fontSize: "18px", margin: "0 0 8px 0" }, children: "No actions available" }),
|
|
1834
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("p", { style: { fontSize: "14px", margin: 0 }, children: "Actions will appear here when registered" })
|
|
1835
|
+
] });
|
|
1836
|
+
}
|
|
1837
|
+
return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { display: "flex", flexDirection: "column", gap: "16px" }, children: actions.map((action, index) => /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1838
|
+
"div",
|
|
1839
|
+
{
|
|
1840
|
+
style: {
|
|
1841
|
+
backgroundColor: "white",
|
|
1842
|
+
padding: "16px",
|
|
1843
|
+
borderRadius: "8px",
|
|
1844
|
+
boxShadow: "0 1px 3px 0 rgba(0, 0, 0, 0.1)",
|
|
1845
|
+
border: "1px solid #e5e7eb"
|
|
1846
|
+
},
|
|
1847
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
1848
|
+
"div",
|
|
1849
|
+
{
|
|
1850
|
+
style: { display: "flex", alignItems: "flex-start", justifyContent: "space-between" },
|
|
1851
|
+
children: [
|
|
1852
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { style: { flex: 1 }, children: [
|
|
1853
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("h3", { style: { fontWeight: "600", color: "#1f2937", margin: "0 0 4px 0" }, children: action.name }),
|
|
1854
|
+
action.description && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("p", { style: { fontSize: "14px", color: "#4b5563", margin: "0 0 12px 0" }, children: action.description }),
|
|
1855
|
+
action.parameters && action.parameters.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { style: { marginTop: "12px" }, children: [
|
|
1856
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1857
|
+
"p",
|
|
1858
|
+
{
|
|
1859
|
+
style: {
|
|
1860
|
+
fontSize: "12px",
|
|
1861
|
+
fontWeight: "500",
|
|
1862
|
+
color: "#6b7280",
|
|
1863
|
+
textTransform: "uppercase",
|
|
1864
|
+
margin: "0 0 4px 0"
|
|
1865
|
+
},
|
|
1866
|
+
children: "Parameters:"
|
|
1867
|
+
}
|
|
1868
|
+
),
|
|
1869
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { display: "flex", flexDirection: "column", gap: "4px" }, children: action.parameters.map((param, pIndex) => /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { style: { fontSize: "14px" }, children: [
|
|
1870
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("span", { style: { fontFamily: "monospace", color: "#374151" }, children: param.name }),
|
|
1871
|
+
param.required && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("span", { style: { marginLeft: "4px", fontSize: "12px", color: "#ef4444" }, children: "*required" }),
|
|
1872
|
+
param.type && /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("span", { style: { marginLeft: "8px", fontSize: "12px", color: "#6b7280" }, children: [
|
|
1873
|
+
"(",
|
|
1874
|
+
param.type,
|
|
1875
|
+
")"
|
|
1876
|
+
] })
|
|
1877
|
+
] }, pIndex)) })
|
|
1878
|
+
] })
|
|
1879
|
+
] }),
|
|
1880
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { marginLeft: "16px" }, children: action.status === "available" ? /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(CheckIcon, {}) : /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(ExclamationMarkTriangleIcon, {}) })
|
|
1881
|
+
]
|
|
1882
|
+
}
|
|
1883
|
+
)
|
|
1884
|
+
},
|
|
1885
|
+
index
|
|
1886
|
+
)) });
|
|
1887
|
+
}
|
|
1888
|
+
function ReadablesTab({ context }) {
|
|
1889
|
+
const readables = context.getAllContext();
|
|
1890
|
+
if (readables.length === 0) {
|
|
1891
|
+
return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { style: { textAlign: "center", padding: "48px 0", color: "#6b7280" }, children: [
|
|
1892
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("p", { style: { fontSize: "18px", margin: "0 0 8px 0" }, children: "No readable context available" }),
|
|
1893
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("p", { style: { fontSize: "14px", margin: 0 }, children: "Readable context will appear here when provided" })
|
|
1894
|
+
] });
|
|
1895
|
+
}
|
|
1896
|
+
return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { display: "flex", flexDirection: "column", gap: "16px" }, children: readables.map((readable, index) => /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1897
|
+
"div",
|
|
1898
|
+
{
|
|
1899
|
+
style: {
|
|
1900
|
+
backgroundColor: "white",
|
|
1901
|
+
padding: "16px",
|
|
1902
|
+
borderRadius: "8px",
|
|
1903
|
+
boxShadow: "0 1px 3px 0 rgba(0, 0, 0, 0.1)",
|
|
1904
|
+
border: "1px solid #e5e7eb"
|
|
1905
|
+
},
|
|
1906
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1907
|
+
"div",
|
|
1908
|
+
{
|
|
1909
|
+
style: { display: "flex", alignItems: "flex-start", justifyContent: "space-between" },
|
|
1910
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { style: { flex: 1 }, children: [
|
|
1911
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("h3", { style: { fontWeight: "600", color: "#1f2937", margin: "0 0 4px 0" }, children: readable.name || `Readable ${index + 1}` }),
|
|
1912
|
+
readable.description && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("p", { style: { fontSize: "14px", color: "#4b5563", margin: "0 0 12px 0" }, children: readable.description }),
|
|
1913
|
+
readable.value && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1914
|
+
"pre",
|
|
1915
|
+
{
|
|
1916
|
+
style: {
|
|
1917
|
+
marginTop: "12px",
|
|
1918
|
+
padding: "8px",
|
|
1919
|
+
backgroundColor: "#f9fafb",
|
|
1920
|
+
borderRadius: "4px",
|
|
1921
|
+
fontSize: "12px",
|
|
1922
|
+
overflowX: "auto",
|
|
1923
|
+
margin: "12px 0 0 0"
|
|
1924
|
+
},
|
|
1925
|
+
children: JSON.stringify(readable.value, null, 2)
|
|
1926
|
+
}
|
|
1927
|
+
)
|
|
1928
|
+
] })
|
|
1929
|
+
}
|
|
1930
|
+
)
|
|
1931
|
+
},
|
|
1932
|
+
index
|
|
1933
|
+
)) });
|
|
1934
|
+
}
|
|
1935
|
+
function AgentStatusTab({ context }) {
|
|
1936
|
+
const agentStates = context.coagentStates || {};
|
|
1937
|
+
const agentStateEntries = Object.entries(agentStates);
|
|
1938
|
+
if (agentStateEntries.length === 0) {
|
|
1939
|
+
return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { style: { textAlign: "center", padding: "48px 0", color: "#6b7280" }, children: [
|
|
1940
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("p", { style: { fontSize: "18px", margin: "0 0 8px 0" }, children: "No agent states available" }),
|
|
1941
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("p", { style: { fontSize: "14px", margin: 0 }, children: "Agent states will appear here when agents are active" })
|
|
1942
|
+
] });
|
|
1943
|
+
}
|
|
1944
|
+
return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { display: "flex", flexDirection: "column", gap: "24px" }, children: agentStateEntries.map(([agentName, state]) => /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
1945
|
+
"div",
|
|
1946
|
+
{
|
|
1947
|
+
style: {
|
|
1948
|
+
backgroundColor: "white",
|
|
1949
|
+
padding: "24px",
|
|
1950
|
+
borderRadius: "8px",
|
|
1951
|
+
boxShadow: "0 1px 3px 0 rgba(0, 0, 0, 0.1)",
|
|
1952
|
+
border: "1px solid #e5e7eb"
|
|
1953
|
+
},
|
|
1954
|
+
children: [
|
|
1955
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
1956
|
+
"div",
|
|
1957
|
+
{
|
|
1958
|
+
style: {
|
|
1959
|
+
display: "flex",
|
|
1960
|
+
alignItems: "center",
|
|
1961
|
+
justifyContent: "space-between",
|
|
1962
|
+
marginBottom: "16px"
|
|
1963
|
+
},
|
|
1964
|
+
children: [
|
|
1965
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("h3", { style: { fontWeight: "600", fontSize: "18px", color: "#1f2937", margin: 0 }, children: agentName }),
|
|
1966
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1967
|
+
"span",
|
|
1968
|
+
{
|
|
1969
|
+
style: {
|
|
1970
|
+
padding: "4px 12px",
|
|
1971
|
+
borderRadius: "9999px",
|
|
1972
|
+
fontSize: "12px",
|
|
1973
|
+
fontWeight: "500",
|
|
1974
|
+
backgroundColor: state.status === "running" ? "#dcfce7" : state.status === "complete" ? "#dbeafe" : "#f3f4f6",
|
|
1975
|
+
color: state.status === "running" ? "#166534" : state.status === "complete" ? "#1e40af" : "#1f2937"
|
|
1976
|
+
},
|
|
1977
|
+
children: state.status || "idle"
|
|
1978
|
+
}
|
|
1979
|
+
)
|
|
1980
|
+
]
|
|
1981
|
+
}
|
|
1982
|
+
),
|
|
1983
|
+
state.state && /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { style: { marginBottom: "12px" }, children: [
|
|
1984
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1985
|
+
"p",
|
|
1986
|
+
{
|
|
1987
|
+
style: {
|
|
1988
|
+
fontSize: "12px",
|
|
1989
|
+
fontWeight: "500",
|
|
1990
|
+
color: "#6b7280",
|
|
1991
|
+
textTransform: "uppercase",
|
|
1992
|
+
margin: "0 0 4px 0"
|
|
1993
|
+
},
|
|
1994
|
+
children: "Current State:"
|
|
1995
|
+
}
|
|
1996
|
+
),
|
|
1997
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
1998
|
+
"pre",
|
|
1999
|
+
{
|
|
2000
|
+
style: {
|
|
2001
|
+
padding: "12px",
|
|
2002
|
+
backgroundColor: "#f9fafb",
|
|
2003
|
+
borderRadius: "4px",
|
|
2004
|
+
fontSize: "12px",
|
|
2005
|
+
overflowX: "auto",
|
|
2006
|
+
margin: 0
|
|
2007
|
+
},
|
|
2008
|
+
children: JSON.stringify(state.state, null, 2)
|
|
2009
|
+
}
|
|
2010
|
+
)
|
|
2011
|
+
] }),
|
|
2012
|
+
state.running && /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
2013
|
+
"div",
|
|
2014
|
+
{
|
|
2015
|
+
style: {
|
|
2016
|
+
marginTop: "16px",
|
|
2017
|
+
display: "flex",
|
|
2018
|
+
alignItems: "center",
|
|
2019
|
+
fontSize: "14px",
|
|
2020
|
+
color: "#4b5563"
|
|
2021
|
+
},
|
|
2022
|
+
children: [
|
|
2023
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { marginRight: "8px" }, children: /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
2024
|
+
"svg",
|
|
2025
|
+
{
|
|
2026
|
+
width: "16",
|
|
2027
|
+
height: "16",
|
|
2028
|
+
viewBox: "0 0 16 16",
|
|
2029
|
+
style: { animation: "spin 1s linear infinite" },
|
|
2030
|
+
children: [
|
|
2031
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("style", { children: `@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }` }),
|
|
2032
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
2033
|
+
"circle",
|
|
2034
|
+
{
|
|
2035
|
+
cx: "8",
|
|
2036
|
+
cy: "8",
|
|
2037
|
+
r: "6",
|
|
2038
|
+
fill: "none",
|
|
2039
|
+
stroke: "#4b5563",
|
|
2040
|
+
strokeWidth: "2",
|
|
2041
|
+
strokeDasharray: "9 3"
|
|
2042
|
+
}
|
|
2043
|
+
)
|
|
2044
|
+
]
|
|
2045
|
+
}
|
|
2046
|
+
) }),
|
|
2047
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("span", { children: "Agent is currently running..." })
|
|
2048
|
+
]
|
|
2049
|
+
}
|
|
2050
|
+
)
|
|
2051
|
+
]
|
|
2052
|
+
},
|
|
2053
|
+
agentName
|
|
2054
|
+
)) });
|
|
2055
|
+
}
|
|
2056
|
+
function MessagesTab({ messagesContext }) {
|
|
2057
|
+
const messages = messagesContext.messages || [];
|
|
2058
|
+
if (messages.length === 0) {
|
|
2059
|
+
return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { style: { textAlign: "center", padding: "48px 0", color: "#6b7280" }, children: [
|
|
2060
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("p", { style: { fontSize: "18px", margin: "0 0 8px 0" }, children: "No messages yet" }),
|
|
2061
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("p", { style: { fontSize: "14px", margin: 0 }, children: "Messages will appear here as the conversation progresses" })
|
|
2062
|
+
] });
|
|
2063
|
+
}
|
|
2064
|
+
return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { display: "flex", flexDirection: "column", gap: "16px" }, children: messages.map((message, index) => /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
2065
|
+
"div",
|
|
2066
|
+
{
|
|
2067
|
+
style: {
|
|
2068
|
+
padding: "16px",
|
|
2069
|
+
borderRadius: "8px",
|
|
2070
|
+
backgroundColor: message.role === "user" ? "#eff6ff" : message.role === "assistant" ? "#f9fafb" : "#fefce8",
|
|
2071
|
+
border: `1px solid ${message.role === "user" ? "#c7d2fe" : message.role === "assistant" ? "#e5e7eb" : "#fde047"}`,
|
|
2072
|
+
marginLeft: message.role === "user" ? "48px" : "0",
|
|
2073
|
+
marginRight: message.role === "assistant" ? "48px" : "0"
|
|
2074
|
+
},
|
|
2075
|
+
children: [
|
|
2076
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
2077
|
+
"div",
|
|
2078
|
+
{
|
|
2079
|
+
style: {
|
|
2080
|
+
display: "flex",
|
|
2081
|
+
alignItems: "flex-start",
|
|
2082
|
+
justifyContent: "space-between",
|
|
2083
|
+
marginBottom: "8px"
|
|
2084
|
+
},
|
|
2085
|
+
children: [
|
|
2086
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
2087
|
+
"span",
|
|
2088
|
+
{
|
|
2089
|
+
style: {
|
|
2090
|
+
fontWeight: "500",
|
|
2091
|
+
fontSize: "14px",
|
|
2092
|
+
color: "#374151",
|
|
2093
|
+
textTransform: "capitalize"
|
|
2094
|
+
},
|
|
2095
|
+
children: message.role || "system"
|
|
2096
|
+
}
|
|
2097
|
+
),
|
|
2098
|
+
message.timestamp && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("span", { style: { fontSize: "12px", color: "#6b7280" }, children: new Date(message.timestamp).toLocaleTimeString() })
|
|
2099
|
+
]
|
|
2100
|
+
}
|
|
2101
|
+
),
|
|
2102
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { fontSize: "14px", color: "#1f2937", whiteSpace: "pre-wrap" }, children: message.content || "" })
|
|
2103
|
+
]
|
|
2104
|
+
},
|
|
2105
|
+
index
|
|
2106
|
+
)) });
|
|
2107
|
+
}
|
|
2108
|
+
function ContextTab({ context }) {
|
|
2109
|
+
const documents = context.getDocumentsContext([]);
|
|
2110
|
+
if (documents.length === 0) {
|
|
2111
|
+
return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { style: { textAlign: "center", padding: "48px 0", color: "#6b7280" }, children: [
|
|
2112
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("p", { style: { fontSize: "18px", margin: "0 0 8px 0" }, children: "No document context available" }),
|
|
2113
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("p", { style: { fontSize: "14px", margin: 0 }, children: "Document context will appear here when provided" })
|
|
2114
|
+
] });
|
|
2115
|
+
}
|
|
2116
|
+
return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { display: "flex", flexDirection: "column", gap: "16px" }, children: documents.map((doc, index) => /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
|
|
2117
|
+
"div",
|
|
2118
|
+
{
|
|
2119
|
+
style: {
|
|
2120
|
+
backgroundColor: "white",
|
|
2121
|
+
padding: "16px",
|
|
2122
|
+
borderRadius: "8px",
|
|
2123
|
+
boxShadow: "0 1px 3px 0 rgba(0, 0, 0, 0.1)",
|
|
2124
|
+
border: "1px solid #e5e7eb"
|
|
2125
|
+
},
|
|
2126
|
+
children: [
|
|
2127
|
+
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)("h3", { style: { fontWeight: "600", color: "#1f2937", margin: "0 0 8px 0" }, children: doc.name || `Document ${index + 1}` }),
|
|
2128
|
+
doc.content && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
2129
|
+
"pre",
|
|
2130
|
+
{
|
|
2131
|
+
style: {
|
|
2132
|
+
padding: "12px",
|
|
2133
|
+
backgroundColor: "#f9fafb",
|
|
2134
|
+
borderRadius: "4px",
|
|
2135
|
+
fontSize: "12px",
|
|
2136
|
+
overflowX: "auto",
|
|
2137
|
+
margin: 0
|
|
2138
|
+
},
|
|
2139
|
+
children: doc.content
|
|
2140
|
+
}
|
|
2141
|
+
)
|
|
2142
|
+
]
|
|
2143
|
+
},
|
|
2144
|
+
index
|
|
2145
|
+
)) });
|
|
2146
|
+
}
|
|
2147
|
+
|
|
2148
|
+
// src/components/dev-console/console-trigger.tsx
|
|
2149
|
+
var import_jsx_runtime7 = require("react/jsx-runtime");
|
|
2150
|
+
function ConsoleTrigger({ position = "bottom-right" }) {
|
|
2151
|
+
const context = useCopilotContext();
|
|
2152
|
+
const hasApiKey = Boolean(context.copilotApiConfig.publicApiKey);
|
|
2153
|
+
const [isModalOpen, setIsModalOpen] = (0, import_react10.useState)(false);
|
|
2154
|
+
const [isHovered, setIsHovered] = (0, import_react10.useState)(false);
|
|
2155
|
+
const [isDragging, setIsDragging] = (0, import_react10.useState)(false);
|
|
2156
|
+
const [buttonPosition, setButtonPosition] = (0, import_react10.useState)(null);
|
|
2157
|
+
const [mounted, setMounted] = (0, import_react10.useState)(false);
|
|
2158
|
+
const dragRef = (0, import_react10.useRef)(null);
|
|
2159
|
+
const buttonRef = (0, import_react10.useRef)(null);
|
|
2160
|
+
(0, import_react10.useEffect)(() => {
|
|
2161
|
+
setMounted(true);
|
|
2162
|
+
if (typeof window !== "undefined" && !buttonPosition) {
|
|
2163
|
+
const buttonSize = 60;
|
|
2164
|
+
const margin = 24;
|
|
2165
|
+
const initialPosition = {
|
|
2166
|
+
x: margin,
|
|
2167
|
+
y: window.innerHeight - buttonSize - margin
|
|
2168
|
+
};
|
|
2169
|
+
setButtonPosition(initialPosition);
|
|
2170
|
+
}
|
|
2171
|
+
}, [position]);
|
|
2172
|
+
const handleMouseDown = (e) => {
|
|
2173
|
+
e.preventDefault();
|
|
2174
|
+
if (!buttonPosition)
|
|
2175
|
+
return;
|
|
2176
|
+
dragRef.current = {
|
|
2177
|
+
startX: e.clientX,
|
|
2178
|
+
startY: e.clientY,
|
|
2179
|
+
buttonX: buttonPosition.x,
|
|
2180
|
+
buttonY: buttonPosition.y
|
|
2181
|
+
};
|
|
2182
|
+
setIsDragging(true);
|
|
2183
|
+
};
|
|
2184
|
+
(0, import_react10.useEffect)(() => {
|
|
2185
|
+
if (!isDragging)
|
|
2186
|
+
return;
|
|
2187
|
+
const handleMouseMove = (e) => {
|
|
2188
|
+
e.preventDefault();
|
|
2189
|
+
e.stopPropagation();
|
|
2190
|
+
if (!dragRef.current)
|
|
2191
|
+
return;
|
|
2192
|
+
const deltaX = e.clientX - dragRef.current.startX;
|
|
2193
|
+
const deltaY = e.clientY - dragRef.current.startY;
|
|
2194
|
+
let newX = dragRef.current.buttonX + deltaX;
|
|
2195
|
+
let newY = dragRef.current.buttonY + deltaY;
|
|
2196
|
+
newX = Math.max(0, Math.min(newX, window.innerWidth - 60));
|
|
2197
|
+
newY = Math.max(0, Math.min(newY, window.innerHeight - 60));
|
|
2198
|
+
setButtonPosition({ x: newX, y: newY });
|
|
2199
|
+
};
|
|
2200
|
+
const handleMouseUp = (e) => {
|
|
2201
|
+
e.preventDefault();
|
|
2202
|
+
e.stopPropagation();
|
|
2203
|
+
setIsDragging(false);
|
|
2204
|
+
dragRef.current = null;
|
|
2205
|
+
};
|
|
2206
|
+
document.addEventListener("mousemove", handleMouseMove, { capture: true, passive: false });
|
|
2207
|
+
document.addEventListener("mouseup", handleMouseUp, { capture: true, passive: false });
|
|
2208
|
+
return () => {
|
|
2209
|
+
document.removeEventListener("mousemove", handleMouseMove, { capture: true });
|
|
2210
|
+
document.removeEventListener("mouseup", handleMouseUp, { capture: true });
|
|
2211
|
+
};
|
|
2212
|
+
}, [isDragging]);
|
|
2213
|
+
if (!mounted || !buttonPosition) {
|
|
2214
|
+
return null;
|
|
2215
|
+
}
|
|
2216
|
+
return /* @__PURE__ */ (0, import_jsx_runtime7.jsxs)(import_jsx_runtime7.Fragment, { children: [
|
|
2217
|
+
/* @__PURE__ */ (0, import_jsx_runtime7.jsxs)(
|
|
2218
|
+
"button",
|
|
2219
|
+
{
|
|
2220
|
+
ref: buttonRef,
|
|
2221
|
+
onClick: () => {
|
|
2222
|
+
if (!isDragging) {
|
|
2223
|
+
setIsModalOpen(true);
|
|
2224
|
+
}
|
|
2225
|
+
},
|
|
2226
|
+
onMouseDown: handleMouseDown,
|
|
2227
|
+
onMouseEnter: () => setIsHovered(true),
|
|
2228
|
+
onMouseLeave: () => setIsHovered(false),
|
|
2229
|
+
style: {
|
|
2230
|
+
position: "fixed",
|
|
2231
|
+
left: `${buttonPosition.x}px`,
|
|
2232
|
+
top: `${buttonPosition.y}px`,
|
|
2233
|
+
zIndex: 2147483647,
|
|
2234
|
+
width: "60px",
|
|
2235
|
+
height: "60px",
|
|
2236
|
+
background: isDragging ? "#000000" : isHovered ? "#111111" : "#000000",
|
|
2237
|
+
color: "white",
|
|
2238
|
+
borderRadius: "50%",
|
|
2239
|
+
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)",
|
|
2240
|
+
transition: isDragging ? "none" : "all 0.3s cubic-bezier(0.4, 0, 0.2, 1)",
|
|
2241
|
+
display: "flex",
|
|
2242
|
+
alignItems: "center",
|
|
2243
|
+
justifyContent: "center",
|
|
2244
|
+
border: "none",
|
|
2245
|
+
cursor: isDragging ? "grabbing" : "grab",
|
|
2246
|
+
opacity: 1,
|
|
2247
|
+
userSelect: "none",
|
|
2248
|
+
transform: isDragging ? "scale(1.05)" : isHovered ? "scale(1.1)" : "scale(1)",
|
|
2249
|
+
backdropFilter: "blur(10px)",
|
|
2250
|
+
pointerEvents: "auto",
|
|
2251
|
+
isolation: "isolate"
|
|
2252
|
+
},
|
|
2253
|
+
title: hasApiKey ? "Open Developer Console (Drag to move)" : "Developer Console (API Key Required, Drag to move)",
|
|
2254
|
+
children: [
|
|
2255
|
+
/* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
|
|
2256
|
+
"div",
|
|
2257
|
+
{
|
|
2258
|
+
style: {
|
|
2259
|
+
width: "28px",
|
|
2260
|
+
height: "28px",
|
|
2261
|
+
display: "flex",
|
|
2262
|
+
alignItems: "center",
|
|
2263
|
+
justifyContent: "center",
|
|
2264
|
+
filter: "drop-shadow(0 2px 4px rgba(0,0,0,0.2))"
|
|
2265
|
+
},
|
|
2266
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(CopilotKitIcon, {})
|
|
2267
|
+
}
|
|
2268
|
+
),
|
|
2269
|
+
!hasApiKey && /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
|
|
2270
|
+
"div",
|
|
2271
|
+
{
|
|
2272
|
+
style: {
|
|
2273
|
+
position: "absolute",
|
|
2274
|
+
top: "-2px",
|
|
2275
|
+
right: "-2px",
|
|
2276
|
+
width: "18px",
|
|
2277
|
+
height: "18px",
|
|
2278
|
+
background: "linear-gradient(135deg, #ff6b6b 0%, #ee5a24 100%)",
|
|
2279
|
+
borderRadius: "50%",
|
|
2280
|
+
display: "flex",
|
|
2281
|
+
alignItems: "center",
|
|
2282
|
+
justifyContent: "center",
|
|
2283
|
+
boxShadow: "0 2px 8px rgba(255, 107, 107, 0.4)",
|
|
2284
|
+
border: "2px solid white"
|
|
2285
|
+
},
|
|
2286
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime7.jsx)("span", { style: { fontSize: "10px", color: "white", fontWeight: "bold" }, children: "!" })
|
|
2287
|
+
}
|
|
2288
|
+
)
|
|
2289
|
+
]
|
|
2290
|
+
}
|
|
2291
|
+
),
|
|
2292
|
+
/* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
|
|
2293
|
+
DeveloperConsoleModal,
|
|
2294
|
+
{
|
|
2295
|
+
isOpen: isModalOpen,
|
|
2296
|
+
onClose: () => setIsModalOpen(false),
|
|
2297
|
+
hasApiKey
|
|
2298
|
+
}
|
|
2299
|
+
)
|
|
2300
|
+
] });
|
|
2301
|
+
}
|
|
2302
|
+
|
|
2303
|
+
// src/components/copilot-provider/copilotkit.tsx
|
|
2304
|
+
var import_jsx_runtime8 = require("react/jsx-runtime");
|
|
1331
2305
|
function CopilotKit(_a) {
|
|
1332
2306
|
var _b = _a, { children } = _b, props = __objRest(_b, ["children"]);
|
|
1333
2307
|
const enabled = shouldShowDevConsole(props.showDevConsole);
|
|
1334
|
-
|
|
2308
|
+
const publicApiKey = props.publicApiKey || props.publicLicenseKey;
|
|
2309
|
+
return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(ToastProvider, { enabled, children: /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(CopilotErrorBoundary, { publicApiKey, showUsageBanner: enabled, children: /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(CopilotKitInternal, __spreadProps(__spreadValues({}, props), { children })) }) });
|
|
1335
2310
|
}
|
|
1336
2311
|
function CopilotKitInternal(cpkProps) {
|
|
1337
2312
|
const _a = cpkProps, { children } = _a, props = __objRest(_a, ["children"]);
|
|
1338
2313
|
validateProps(cpkProps);
|
|
1339
|
-
const
|
|
1340
|
-
const
|
|
1341
|
-
const [
|
|
1342
|
-
const
|
|
2314
|
+
const publicApiKey = props.publicLicenseKey || props.publicApiKey;
|
|
2315
|
+
const chatApiEndpoint = props.runtimeUrl || import_shared10.COPILOT_CLOUD_CHAT_URL;
|
|
2316
|
+
const [actions, setActions] = (0, import_react11.useState)({});
|
|
2317
|
+
const [coAgentStateRenders, setCoAgentStateRenders] = (0, import_react11.useState)({});
|
|
2318
|
+
const chatComponentsCache = (0, import_react11.useRef)({
|
|
1343
2319
|
actions: {},
|
|
1344
2320
|
coAgentStateRenders: {}
|
|
1345
2321
|
});
|
|
1346
2322
|
const { addElement, removeElement, printTree, getAllElements } = use_tree_default();
|
|
1347
|
-
const [isLoading, setIsLoading] = (0,
|
|
1348
|
-
const [chatInstructions, setChatInstructions] = (0,
|
|
1349
|
-
const [authStates, setAuthStates] = (0,
|
|
1350
|
-
const [extensions, setExtensions] = (0,
|
|
1351
|
-
const [additionalInstructions, setAdditionalInstructions] = (0,
|
|
2323
|
+
const [isLoading, setIsLoading] = (0, import_react11.useState)(false);
|
|
2324
|
+
const [chatInstructions, setChatInstructions] = (0, import_react11.useState)("");
|
|
2325
|
+
const [authStates, setAuthStates] = (0, import_react11.useState)({});
|
|
2326
|
+
const [extensions, setExtensions] = (0, import_react11.useState)({});
|
|
2327
|
+
const [additionalInstructions, setAdditionalInstructions] = (0, import_react11.useState)([]);
|
|
1352
2328
|
const {
|
|
1353
2329
|
addElement: addDocument,
|
|
1354
2330
|
removeElement: removeDocument,
|
|
1355
2331
|
allElements: allDocuments
|
|
1356
2332
|
} = use_flat_category_store_default();
|
|
1357
|
-
const
|
|
1358
|
-
const [usageBannerStatus, setUsageBannerStatus] = (0, import_react9.useState)(null);
|
|
1359
|
-
const setAction = (0, import_react9.useCallback)((id, action) => {
|
|
2333
|
+
const setAction = (0, import_react11.useCallback)((id, action) => {
|
|
1360
2334
|
setActions((prevPoints) => {
|
|
1361
2335
|
return __spreadProps(__spreadValues({}, prevPoints), {
|
|
1362
2336
|
[id]: action
|
|
1363
2337
|
});
|
|
1364
2338
|
});
|
|
1365
2339
|
}, []);
|
|
1366
|
-
const removeAction = (0,
|
|
2340
|
+
const removeAction = (0, import_react11.useCallback)((id) => {
|
|
1367
2341
|
setActions((prevPoints) => {
|
|
1368
2342
|
const newPoints = __spreadValues({}, prevPoints);
|
|
1369
2343
|
delete newPoints[id];
|
|
1370
2344
|
return newPoints;
|
|
1371
2345
|
});
|
|
1372
2346
|
}, []);
|
|
1373
|
-
const setCoAgentStateRender = (0,
|
|
2347
|
+
const setCoAgentStateRender = (0, import_react11.useCallback)((id, stateRender) => {
|
|
1374
2348
|
setCoAgentStateRenders((prevPoints) => {
|
|
1375
2349
|
return __spreadProps(__spreadValues({}, prevPoints), {
|
|
1376
2350
|
[id]: stateRender
|
|
1377
2351
|
});
|
|
1378
2352
|
});
|
|
1379
2353
|
}, []);
|
|
1380
|
-
const removeCoAgentStateRender = (0,
|
|
2354
|
+
const removeCoAgentStateRender = (0, import_react11.useCallback)((id) => {
|
|
1381
2355
|
setCoAgentStateRenders((prevPoints) => {
|
|
1382
2356
|
const newPoints = __spreadValues({}, prevPoints);
|
|
1383
2357
|
delete newPoints[id];
|
|
1384
2358
|
return newPoints;
|
|
1385
2359
|
});
|
|
1386
2360
|
}, []);
|
|
1387
|
-
const getContextString = (0,
|
|
2361
|
+
const getContextString = (0, import_react11.useCallback)(
|
|
1388
2362
|
(documents, categories) => {
|
|
1389
|
-
const documentsString = documents.map((
|
|
1390
|
-
return `${
|
|
1391
|
-
${
|
|
2363
|
+
const documentsString = documents.map((document2) => {
|
|
2364
|
+
return `${document2.name} (${document2.sourceApplication}):
|
|
2365
|
+
${document2.getContents()}`;
|
|
1392
2366
|
}).join("\n\n");
|
|
1393
2367
|
const nonDocumentStrings = printTree(categories);
|
|
1394
2368
|
return `${documentsString}
|
|
@@ -1397,49 +2371,49 @@ ${nonDocumentStrings}`;
|
|
|
1397
2371
|
},
|
|
1398
2372
|
[printTree]
|
|
1399
2373
|
);
|
|
1400
|
-
const addContext = (0,
|
|
2374
|
+
const addContext = (0, import_react11.useCallback)(
|
|
1401
2375
|
(context, parentId, categories = defaultCopilotContextCategories) => {
|
|
1402
2376
|
return addElement(context, categories, parentId);
|
|
1403
2377
|
},
|
|
1404
2378
|
[addElement]
|
|
1405
2379
|
);
|
|
1406
|
-
const removeContext = (0,
|
|
2380
|
+
const removeContext = (0, import_react11.useCallback)(
|
|
1407
2381
|
(id) => {
|
|
1408
2382
|
removeElement(id);
|
|
1409
2383
|
},
|
|
1410
2384
|
[removeElement]
|
|
1411
2385
|
);
|
|
1412
|
-
const getAllContext = (0,
|
|
2386
|
+
const getAllContext = (0, import_react11.useCallback)(() => {
|
|
1413
2387
|
return getAllElements();
|
|
1414
2388
|
}, [getAllElements]);
|
|
1415
|
-
const getFunctionCallHandler = (0,
|
|
2389
|
+
const getFunctionCallHandler = (0, import_react11.useCallback)(
|
|
1416
2390
|
(customEntryPoints) => {
|
|
1417
2391
|
return entryPointsToFunctionCallHandler(Object.values(customEntryPoints || actions));
|
|
1418
2392
|
},
|
|
1419
2393
|
[actions]
|
|
1420
2394
|
);
|
|
1421
|
-
const getDocumentsContext = (0,
|
|
2395
|
+
const getDocumentsContext = (0, import_react11.useCallback)(
|
|
1422
2396
|
(categories) => {
|
|
1423
2397
|
return allDocuments(categories);
|
|
1424
2398
|
},
|
|
1425
2399
|
[allDocuments]
|
|
1426
2400
|
);
|
|
1427
|
-
const addDocumentContext = (0,
|
|
2401
|
+
const addDocumentContext = (0, import_react11.useCallback)(
|
|
1428
2402
|
(documentPointer, categories = defaultCopilotContextCategories) => {
|
|
1429
2403
|
return addDocument(documentPointer, categories);
|
|
1430
2404
|
},
|
|
1431
2405
|
[addDocument]
|
|
1432
2406
|
);
|
|
1433
|
-
const removeDocumentContext = (0,
|
|
2407
|
+
const removeDocumentContext = (0, import_react11.useCallback)(
|
|
1434
2408
|
(documentId) => {
|
|
1435
2409
|
removeDocument(documentId);
|
|
1436
2410
|
},
|
|
1437
2411
|
[removeDocument]
|
|
1438
2412
|
);
|
|
1439
|
-
const copilotApiConfig = (0,
|
|
2413
|
+
const copilotApiConfig = (0, import_react11.useMemo)(() => {
|
|
1440
2414
|
var _a2, _b;
|
|
1441
2415
|
let cloud = void 0;
|
|
1442
|
-
if (
|
|
2416
|
+
if (publicApiKey) {
|
|
1443
2417
|
cloud = {
|
|
1444
2418
|
guardrails: {
|
|
1445
2419
|
input: {
|
|
@@ -1453,7 +2427,7 @@ ${nonDocumentStrings}`;
|
|
|
1453
2427
|
};
|
|
1454
2428
|
}
|
|
1455
2429
|
return __spreadProps(__spreadValues({
|
|
1456
|
-
publicApiKey
|
|
2430
|
+
publicApiKey
|
|
1457
2431
|
}, cloud ? { cloud } : {}), {
|
|
1458
2432
|
chatApiEndpoint,
|
|
1459
2433
|
headers: props.headers || {},
|
|
@@ -1463,7 +2437,7 @@ ${nonDocumentStrings}`;
|
|
|
1463
2437
|
credentials: props.credentials
|
|
1464
2438
|
});
|
|
1465
2439
|
}, [
|
|
1466
|
-
|
|
2440
|
+
publicApiKey,
|
|
1467
2441
|
props.headers,
|
|
1468
2442
|
props.properties,
|
|
1469
2443
|
props.transcribeAudioUrl,
|
|
@@ -1472,7 +2446,7 @@ ${nonDocumentStrings}`;
|
|
|
1472
2446
|
props.cloudRestrictToTopic,
|
|
1473
2447
|
props.guardrails_c
|
|
1474
2448
|
]);
|
|
1475
|
-
const headers = (0,
|
|
2449
|
+
const headers = (0, import_react11.useMemo)(() => {
|
|
1476
2450
|
const authHeaders = Object.values(authStates || {}).reduce((acc, state) => {
|
|
1477
2451
|
if (state.status === "authenticated" && state.authHeaders) {
|
|
1478
2452
|
return __spreadValues(__spreadValues({}, acc), Object.entries(state.authHeaders).reduce(
|
|
@@ -1484,24 +2458,24 @@ ${nonDocumentStrings}`;
|
|
|
1484
2458
|
}
|
|
1485
2459
|
return acc;
|
|
1486
2460
|
}, {});
|
|
1487
|
-
return __spreadValues(__spreadValues(__spreadValues({}, copilotApiConfig.headers || {}), copilotApiConfig.publicApiKey ? { [
|
|
2461
|
+
return __spreadValues(__spreadValues(__spreadValues({}, copilotApiConfig.headers || {}), copilotApiConfig.publicApiKey ? { [import_shared10.COPILOT_CLOUD_PUBLIC_API_KEY_HEADER]: copilotApiConfig.publicApiKey } : {}), authHeaders);
|
|
1488
2462
|
}, [copilotApiConfig.headers, copilotApiConfig.publicApiKey, authStates]);
|
|
1489
2463
|
const runtimeClient = useCopilotRuntimeClient({
|
|
1490
2464
|
url: copilotApiConfig.chatApiEndpoint,
|
|
1491
|
-
publicApiKey
|
|
2465
|
+
publicApiKey,
|
|
1492
2466
|
headers,
|
|
1493
2467
|
credentials: copilotApiConfig.credentials,
|
|
1494
2468
|
showDevConsole: shouldShowDevConsole(props.showDevConsole),
|
|
1495
2469
|
onError: props.onError
|
|
1496
2470
|
});
|
|
1497
|
-
const [chatSuggestionConfiguration, setChatSuggestionConfiguration] = (0,
|
|
1498
|
-
const addChatSuggestionConfiguration = (0,
|
|
2471
|
+
const [chatSuggestionConfiguration, setChatSuggestionConfiguration] = (0, import_react11.useState)({});
|
|
2472
|
+
const addChatSuggestionConfiguration = (0, import_react11.useCallback)(
|
|
1499
2473
|
(id, suggestion) => {
|
|
1500
2474
|
setChatSuggestionConfiguration((prev) => __spreadProps(__spreadValues({}, prev), { [id]: suggestion }));
|
|
1501
2475
|
},
|
|
1502
2476
|
[setChatSuggestionConfiguration]
|
|
1503
2477
|
);
|
|
1504
|
-
const removeChatSuggestionConfiguration = (0,
|
|
2478
|
+
const removeChatSuggestionConfiguration = (0, import_react11.useCallback)(
|
|
1505
2479
|
(id) => {
|
|
1506
2480
|
setChatSuggestionConfiguration((prev) => {
|
|
1507
2481
|
const _a2 = prev, { [id]: _ } = _a2, rest = __objRest(_a2, [__restKey(id)]);
|
|
@@ -1510,10 +2484,10 @@ ${nonDocumentStrings}`;
|
|
|
1510
2484
|
},
|
|
1511
2485
|
[setChatSuggestionConfiguration]
|
|
1512
2486
|
);
|
|
1513
|
-
const [availableAgents, setAvailableAgents] = (0,
|
|
1514
|
-
const [coagentStates, setCoagentStates] = (0,
|
|
1515
|
-
const coagentStatesRef = (0,
|
|
1516
|
-
const setCoagentStatesWithRef = (0,
|
|
2487
|
+
const [availableAgents, setAvailableAgents] = (0, import_react11.useState)([]);
|
|
2488
|
+
const [coagentStates, setCoagentStates] = (0, import_react11.useState)({});
|
|
2489
|
+
const coagentStatesRef = (0, import_react11.useRef)({});
|
|
2490
|
+
const setCoagentStatesWithRef = (0, import_react11.useCallback)(
|
|
1517
2491
|
(value) => {
|
|
1518
2492
|
const newValue = typeof value === "function" ? value(coagentStatesRef.current) : value;
|
|
1519
2493
|
coagentStatesRef.current = newValue;
|
|
@@ -1523,8 +2497,8 @@ ${nonDocumentStrings}`;
|
|
|
1523
2497
|
},
|
|
1524
2498
|
[]
|
|
1525
2499
|
);
|
|
1526
|
-
const hasLoadedAgents = (0,
|
|
1527
|
-
(0,
|
|
2500
|
+
const hasLoadedAgents = (0, import_react11.useRef)(false);
|
|
2501
|
+
(0, import_react11.useEffect)(() => {
|
|
1528
2502
|
if (hasLoadedAgents.current)
|
|
1529
2503
|
return;
|
|
1530
2504
|
const fetchData = () => __async(this, null, function* () {
|
|
@@ -1543,8 +2517,8 @@ ${nonDocumentStrings}`;
|
|
|
1543
2517
|
agentName: props.agent
|
|
1544
2518
|
};
|
|
1545
2519
|
}
|
|
1546
|
-
const [agentSession, setAgentSession] = (0,
|
|
1547
|
-
(0,
|
|
2520
|
+
const [agentSession, setAgentSession] = (0, import_react11.useState)(initialAgentSession);
|
|
2521
|
+
(0, import_react11.useEffect)(() => {
|
|
1548
2522
|
if (props.agent) {
|
|
1549
2523
|
setAgentSession({
|
|
1550
2524
|
agentName: props.agent
|
|
@@ -1553,8 +2527,8 @@ ${nonDocumentStrings}`;
|
|
|
1553
2527
|
setAgentSession(null);
|
|
1554
2528
|
}
|
|
1555
2529
|
}, [props.agent]);
|
|
1556
|
-
const [internalThreadId, setInternalThreadId] = (0,
|
|
1557
|
-
const setThreadId = (0,
|
|
2530
|
+
const [internalThreadId, setInternalThreadId] = (0, import_react11.useState)(props.threadId || (0, import_shared10.randomUUID)());
|
|
2531
|
+
const setThreadId = (0, import_react11.useCallback)(
|
|
1558
2532
|
(value) => {
|
|
1559
2533
|
if (props.threadId) {
|
|
1560
2534
|
throw new Error("Cannot call setThreadId() when threadId is provided via props.");
|
|
@@ -1563,16 +2537,16 @@ ${nonDocumentStrings}`;
|
|
|
1563
2537
|
},
|
|
1564
2538
|
[props.threadId]
|
|
1565
2539
|
);
|
|
1566
|
-
(0,
|
|
2540
|
+
(0, import_react11.useEffect)(() => {
|
|
1567
2541
|
if (props.threadId !== void 0) {
|
|
1568
2542
|
setInternalThreadId(props.threadId);
|
|
1569
2543
|
}
|
|
1570
2544
|
}, [props.threadId]);
|
|
1571
|
-
const [runId, setRunId] = (0,
|
|
1572
|
-
const chatAbortControllerRef = (0,
|
|
2545
|
+
const [runId, setRunId] = (0, import_react11.useState)(null);
|
|
2546
|
+
const chatAbortControllerRef = (0, import_react11.useRef)(null);
|
|
1573
2547
|
const showDevConsole = shouldShowDevConsole(props.showDevConsole);
|
|
1574
|
-
const [langGraphInterruptAction, _setLangGraphInterruptAction] = (0,
|
|
1575
|
-
const setLangGraphInterruptAction = (0,
|
|
2548
|
+
const [langGraphInterruptAction, _setLangGraphInterruptAction] = (0, import_react11.useState)(null);
|
|
2549
|
+
const setLangGraphInterruptAction = (0, import_react11.useCallback)((action) => {
|
|
1576
2550
|
_setLangGraphInterruptAction((prev) => {
|
|
1577
2551
|
if (prev == null)
|
|
1578
2552
|
return action;
|
|
@@ -1585,23 +2559,23 @@ ${nonDocumentStrings}`;
|
|
|
1585
2559
|
return __spreadProps(__spreadValues(__spreadValues({}, prev), action), { event });
|
|
1586
2560
|
});
|
|
1587
2561
|
}, []);
|
|
1588
|
-
const removeLangGraphInterruptAction = (0,
|
|
2562
|
+
const removeLangGraphInterruptAction = (0, import_react11.useCallback)(() => {
|
|
1589
2563
|
setLangGraphInterruptAction(null);
|
|
1590
2564
|
}, []);
|
|
1591
|
-
const memoizedChildren = (0,
|
|
1592
|
-
const [bannerError, setBannerError] = (0,
|
|
1593
|
-
const agentLock = (0,
|
|
2565
|
+
const memoizedChildren = (0, import_react11.useMemo)(() => children, [children]);
|
|
2566
|
+
const [bannerError, setBannerError] = (0, import_react11.useState)(null);
|
|
2567
|
+
const agentLock = (0, import_react11.useMemo)(() => {
|
|
1594
2568
|
var _a2;
|
|
1595
2569
|
return (_a2 = props.agent) != null ? _a2 : null;
|
|
1596
2570
|
}, [props.agent]);
|
|
1597
|
-
const forwardedParameters = (0,
|
|
2571
|
+
const forwardedParameters = (0, import_react11.useMemo)(
|
|
1598
2572
|
() => {
|
|
1599
2573
|
var _a2;
|
|
1600
2574
|
return (_a2 = props.forwardedParameters) != null ? _a2 : {};
|
|
1601
2575
|
},
|
|
1602
2576
|
[props.forwardedParameters]
|
|
1603
2577
|
);
|
|
1604
|
-
const updateExtensions = (0,
|
|
2578
|
+
const updateExtensions = (0, import_react11.useCallback)(
|
|
1605
2579
|
(newExtensions) => {
|
|
1606
2580
|
setExtensions((prev) => {
|
|
1607
2581
|
const resolved = typeof newExtensions === "function" ? newExtensions(prev) : newExtensions;
|
|
@@ -1613,7 +2587,7 @@ ${nonDocumentStrings}`;
|
|
|
1613
2587
|
},
|
|
1614
2588
|
[setExtensions]
|
|
1615
2589
|
);
|
|
1616
|
-
const updateAuthStates = (0,
|
|
2590
|
+
const updateAuthStates = (0, import_react11.useCallback)(
|
|
1617
2591
|
(newAuthStates) => {
|
|
1618
2592
|
setAuthStates((prev) => {
|
|
1619
2593
|
const resolved = typeof newAuthStates === "function" ? newAuthStates(prev) : newAuthStates;
|
|
@@ -1625,7 +2599,7 @@ ${nonDocumentStrings}`;
|
|
|
1625
2599
|
},
|
|
1626
2600
|
[setAuthStates]
|
|
1627
2601
|
);
|
|
1628
|
-
return /* @__PURE__ */ (0,
|
|
2602
|
+
return /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)(
|
|
1629
2603
|
CopilotContext.Provider,
|
|
1630
2604
|
{
|
|
1631
2605
|
value: {
|
|
@@ -1683,8 +2657,11 @@ ${nonDocumentStrings}`;
|
|
|
1683
2657
|
setBannerError
|
|
1684
2658
|
},
|
|
1685
2659
|
children: [
|
|
1686
|
-
/* @__PURE__ */ (0,
|
|
1687
|
-
|
|
2660
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsx)(MessagesTapProvider, { children: /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)(CopilotMessages, { children: [
|
|
2661
|
+
memoizedChildren,
|
|
2662
|
+
showDevConsole && /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(ConsoleTrigger, {})
|
|
2663
|
+
] }) }),
|
|
2664
|
+
bannerError && showDevConsole && /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
|
|
1688
2665
|
UsageBanner,
|
|
1689
2666
|
{
|
|
1690
2667
|
severity: bannerError.severity,
|
|
@@ -1728,12 +2705,15 @@ function formatFeatureName(featureName) {
|
|
|
1728
2705
|
}
|
|
1729
2706
|
function validateProps(props) {
|
|
1730
2707
|
const cloudFeatures = Object.keys(props).filter((key) => key.endsWith("_c"));
|
|
1731
|
-
|
|
1732
|
-
|
|
2708
|
+
const hasApiKey = props.publicApiKey || props.publicLicenseKey;
|
|
2709
|
+
if (!props.runtimeUrl && !hasApiKey) {
|
|
2710
|
+
throw new import_shared10.ConfigurationError(
|
|
2711
|
+
"Missing required prop: 'runtimeUrl' or 'publicApiKey' or 'publicLicenseKey'"
|
|
2712
|
+
);
|
|
1733
2713
|
}
|
|
1734
|
-
if (cloudFeatures.length > 0 && !
|
|
1735
|
-
throw new
|
|
1736
|
-
`Missing required prop: 'publicApiKey' to use cloud features: ${cloudFeatures.map(formatFeatureName).join(", ")}`
|
|
2714
|
+
if (cloudFeatures.length > 0 && !hasApiKey) {
|
|
2715
|
+
throw new import_shared10.MissingPublicApiKeyError(
|
|
2716
|
+
`Missing required prop: 'publicApiKey' or 'publicLicenseKey' to use cloud features: ${cloudFeatures.map(formatFeatureName).join(", ")}`
|
|
1737
2717
|
);
|
|
1738
2718
|
}
|
|
1739
2719
|
}
|