@copilotkit/react-ui 1.0.7 → 1.0.8-mme-pre-dev-console.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (76) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/dist/{chunk-DYHXNV2B.mjs → chunk-2CFQIOJA.mjs} +2 -2
  3. package/dist/{chunk-5BL3YDGU.mjs → chunk-BBZDFB4Y.mjs} +5 -1
  4. package/dist/chunk-BBZDFB4Y.mjs.map +1 -0
  5. package/dist/{chunk-QHAVUMXM.mjs → chunk-EU75TDHP.mjs} +2 -2
  6. package/dist/{chunk-OLL5TU65.mjs → chunk-JCRSTTLF.mjs} +2 -2
  7. package/dist/chunk-O4AM2PCW.mjs +212 -0
  8. package/dist/chunk-O4AM2PCW.mjs.map +1 -0
  9. package/dist/chunk-OTPAZXVR.mjs +92 -0
  10. package/dist/chunk-OTPAZXVR.mjs.map +1 -0
  11. package/dist/chunk-RT2BA4MP.mjs +85 -0
  12. package/dist/chunk-RT2BA4MP.mjs.map +1 -0
  13. package/dist/chunk-V7W6IM2V.mjs +1 -0
  14. package/dist/chunk-V7W6IM2V.mjs.map +1 -0
  15. package/dist/components/chat/Chat.js +377 -24
  16. package/dist/components/chat/Chat.js.map +1 -1
  17. package/dist/components/chat/Chat.mjs +5 -1
  18. package/dist/components/chat/Modal.js +386 -33
  19. package/dist/components/chat/Modal.js.map +1 -1
  20. package/dist/components/chat/Modal.mjs +6 -2
  21. package/dist/components/chat/Popup.js +388 -35
  22. package/dist/components/chat/Popup.js.map +1 -1
  23. package/dist/components/chat/Popup.mjs +7 -3
  24. package/dist/components/chat/Sidebar.js +390 -37
  25. package/dist/components/chat/Sidebar.js.map +1 -1
  26. package/dist/components/chat/Sidebar.mjs +7 -3
  27. package/dist/components/chat/index.js +392 -39
  28. package/dist/components/chat/index.js.map +1 -1
  29. package/dist/components/chat/index.mjs +8 -4
  30. package/dist/components/dev-console/console.d.ts +8 -0
  31. package/dist/components/dev-console/console.js +441 -0
  32. package/dist/components/dev-console/console.js.map +1 -0
  33. package/dist/components/dev-console/console.mjs +14 -0
  34. package/dist/components/dev-console/console.mjs.map +1 -0
  35. package/dist/components/dev-console/icons.d.ts +7 -0
  36. package/dist/components/dev-console/icons.js +120 -0
  37. package/dist/components/dev-console/icons.js.map +1 -0
  38. package/dist/components/dev-console/icons.mjs +16 -0
  39. package/dist/components/dev-console/icons.mjs.map +1 -0
  40. package/dist/components/dev-console/index.d.ts +4 -0
  41. package/dist/components/dev-console/index.js +441 -0
  42. package/dist/components/dev-console/index.js.map +1 -0
  43. package/dist/components/dev-console/index.mjs +15 -0
  44. package/dist/components/dev-console/index.mjs.map +1 -0
  45. package/dist/components/dev-console/types.d.ts +9 -0
  46. package/dist/components/dev-console/types.js +19 -0
  47. package/dist/components/dev-console/types.js.map +1 -0
  48. package/dist/components/dev-console/types.mjs +1 -0
  49. package/dist/components/dev-console/types.mjs.map +1 -0
  50. package/dist/components/dev-console/utils.d.ts +9 -0
  51. package/dist/components/dev-console/utils.js +128 -0
  52. package/dist/components/dev-console/utils.js.map +1 -0
  53. package/dist/components/dev-console/utils.mjs +14 -0
  54. package/dist/components/dev-console/utils.mjs.map +1 -0
  55. package/dist/components/index.js +392 -39
  56. package/dist/components/index.js.map +1 -1
  57. package/dist/components/index.mjs +8 -4
  58. package/dist/index.css +115 -0
  59. package/dist/index.css.map +1 -1
  60. package/dist/index.js +398 -45
  61. package/dist/index.js.map +1 -1
  62. package/dist/index.mjs +8 -4
  63. package/package.json +8 -7
  64. package/src/components/chat/Chat.tsx +3 -0
  65. package/src/components/dev-console/console.tsx +258 -0
  66. package/src/components/dev-console/icons.tsx +92 -0
  67. package/src/components/dev-console/index.tsx +2 -0
  68. package/src/components/dev-console/types.ts +7 -0
  69. package/src/components/dev-console/utils.ts +93 -0
  70. package/src/css/console.css +130 -0
  71. package/src/styles.css +1 -0
  72. package/.turbo/turbo-build.log +0 -222
  73. package/dist/chunk-5BL3YDGU.mjs.map +0 -1
  74. /package/dist/{chunk-DYHXNV2B.mjs.map → chunk-2CFQIOJA.mjs.map} +0 -0
  75. /package/dist/{chunk-QHAVUMXM.mjs.map → chunk-EU75TDHP.mjs.map} +0 -0
  76. /package/dist/{chunk-OLL5TU65.mjs.map → chunk-JCRSTTLF.mjs.map} +0 -0
@@ -82,7 +82,7 @@ __export(Modal_exports, {
82
82
  CopilotModal: () => CopilotModal
83
83
  });
84
84
  module.exports = __toCommonJS(Modal_exports);
85
- var import_react10 = __toESM(require("react"));
85
+ var import_react12 = __toESM(require("react"));
86
86
 
87
87
  // src/components/chat/ChatContext.tsx
88
88
  var import_react = __toESM(require("react"));
@@ -1413,11 +1413,363 @@ var reloadSuggestions = (context, chatSuggestionConfiguration, setCurrentSuggest
1413
1413
  });
1414
1414
 
1415
1415
  // src/components/chat/Chat.tsx
1416
- var import_react9 = __toESM(require("react"));
1417
- var import_react_core5 = require("@copilotkit/react-core");
1416
+ var import_react11 = __toESM(require("react"));
1417
+ var import_react_core7 = require("@copilotkit/react-core");
1418
1418
  var import_runtime_client_gql4 = require("@copilotkit/runtime-client-gql");
1419
- var import_shared2 = require("@copilotkit/shared");
1419
+ var import_shared3 = require("@copilotkit/shared");
1420
+
1421
+ // src/components/dev-console/utils.ts
1422
+ var import_react_core5 = require("@copilotkit/react-core");
1423
+ function shouldShowDevConsole(showDevConsole) {
1424
+ if (typeof showDevConsole === "boolean") {
1425
+ return showDevConsole;
1426
+ }
1427
+ return getHostname() === "localhost" || getHostname() === "127.0.0.1" || getHostname() === "0.0.0.0" || getHostname() === "::1";
1428
+ }
1429
+ function getHostname() {
1430
+ if (typeof window !== "undefined" && window.location) {
1431
+ return window.location.hostname;
1432
+ }
1433
+ return "";
1434
+ }
1435
+ function getPublishedCopilotKitVersion(current, forceCheck = false) {
1436
+ return __async(this, null, function* () {
1437
+ const LOCAL_STORAGE_KEY = "__copilotkit_version_check__";
1438
+ const serializedVersion = localStorage.getItem(LOCAL_STORAGE_KEY);
1439
+ if (serializedVersion && !forceCheck) {
1440
+ try {
1441
+ const parsedVersion = JSON.parse(serializedVersion);
1442
+ const oneHour = 60 * 60 * 1e3;
1443
+ const now = (/* @__PURE__ */ new Date()).getTime();
1444
+ if (parsedVersion.current === current && now - new Date(parsedVersion.lastChecked).getTime() < oneHour) {
1445
+ return parsedVersion;
1446
+ }
1447
+ } catch (error) {
1448
+ console.error("Failed to parse CopilotKitVersion from localStorage", error);
1449
+ }
1450
+ }
1451
+ try {
1452
+ const response = yield fetch("https://api.cloud.stagingcopilotkit.ai/check-for-updates", {
1453
+ method: "POST",
1454
+ headers: {
1455
+ "Content-Type": "application/json"
1456
+ },
1457
+ body: JSON.stringify({
1458
+ packages: [
1459
+ {
1460
+ packageName: "@copilotkit/shared",
1461
+ packageVersion: current
1462
+ }
1463
+ ]
1464
+ })
1465
+ });
1466
+ const data = yield response.json();
1467
+ const version = {
1468
+ current,
1469
+ lastChecked: (/* @__PURE__ */ new Date()).getTime(),
1470
+ latest: data.packages[0].latestVersion,
1471
+ severity: data.packages[0].severity,
1472
+ advisory: data.packages[0].advisory || null
1473
+ };
1474
+ localStorage.setItem(LOCAL_STORAGE_KEY, JSON.stringify(version));
1475
+ return version;
1476
+ } catch (error) {
1477
+ console.error("Failed to check for updates", error);
1478
+ throw error;
1479
+ }
1480
+ });
1481
+ }
1482
+ function logReadables(context) {
1483
+ console.log(context.getContextString([], import_react_core5.defaultCopilotContextCategories));
1484
+ }
1485
+ function logActions(context) {
1486
+ for (const action of Object.values(context.actions)) {
1487
+ console.group(action.name);
1488
+ console.log("name", action.name);
1489
+ console.log("description", action.description);
1490
+ console.log("parameters", action.parameters);
1491
+ console.groupEnd();
1492
+ }
1493
+ }
1494
+
1495
+ // src/components/dev-console/console.tsx
1496
+ var import_react_core6 = require("@copilotkit/react-core");
1497
+ var import_react9 = require("react");
1498
+
1499
+ // src/components/dev-console/icons.tsx
1420
1500
  var import_jsx_runtime13 = require("react/jsx-runtime");
1501
+ var ExclamationMarkTriangleIcon = /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
1502
+ "svg",
1503
+ {
1504
+ width: "13.3967723px",
1505
+ height: "12px",
1506
+ viewBox: "0 0 13.3967723 12",
1507
+ version: "1.1",
1508
+ xmlns: "http://www.w3.org/2000/svg",
1509
+ children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("g", { id: "exclamation-triangle", fill: "#CD2121", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
1510
+ "path",
1511
+ {
1512
+ 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",
1513
+ id: "Shape"
1514
+ }
1515
+ ) }) })
1516
+ }
1517
+ );
1518
+ var ExclamationMarkIcon = /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
1519
+ "svg",
1520
+ {
1521
+ width: "14px",
1522
+ height: "14px",
1523
+ viewBox: "0 0 14 14",
1524
+ version: "1.1",
1525
+ xmlns: "http://www.w3.org/2000/svg",
1526
+ children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("g", { id: "exclamation-circle", fill: "#EC662C", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
1527
+ "path",
1528
+ {
1529
+ d: "M7,14 C10.866,14 14,10.866 14,7 C14,3.13401 10.866,0 7,0 C3.13401,0 0,3.13401 0,7 C0,10.866 3.13401,14 7,14 Z M7,3 C7.41421,3 7.75,3.33579 7.75,3.75 L7.75,6.75 C7.75,7.16421 7.41421,7.5 7,7.5 C6.58579,7.5 6.25,7.16421 6.25,6.75 L6.25,3.75 C6.25,3.33579 6.58579,3 7,3 Z M7,11 C7.55228,11 8,10.5523 8,10 C8,9.4477 7.55228,9 7,9 C6.44772,9 6,9.4477 6,10 C6,10.5523 6.44772,11 7,11 Z",
1530
+ id: "Shape"
1531
+ }
1532
+ ) }) })
1533
+ }
1534
+ );
1535
+ var ChevronDownIcon = /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("svg", { width: "7px", height: "4px", viewBox: "0 0 7 4", version: "1.1", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("g", { id: "Group", fill: "#000000", fillRule: "nonzero", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
1536
+ "path",
1537
+ {
1538
+ d: "M3.71690723,3.90271086 C3.59268176,4.03242971 3.39143629,4.03242971 3.26721082,3.90271086 L0.0853966595,0.57605615 C-0.0314221035,0.444981627 -0.0279751448,0.240725043 0.0931934622,0.114040675 C0.214362069,-0.0126436935 0.409725445,-0.0162475626 0.535093061,0.105888951 L3.49205902,3.19746006 L6.44902499,0.105888951 C6.52834574,0.0168884389 6.64780588,-0.0197473458 6.7605411,0.0103538404 C6.87327633,0.0404550266 6.96130636,0.132492308 6.99009696,0.250359396 C7.01888756,0.368226483 6.98384687,0.493124608 6.89872139,0.57605615 L3.71690723,3.90271086 Z",
1539
+ id: "Path"
1540
+ }
1541
+ ) }) }) });
1542
+ var CheckIcon2 = /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
1543
+ "svg",
1544
+ {
1545
+ width: "14px",
1546
+ height: "14px",
1547
+ viewBox: "0 0 14 14",
1548
+ version: "1.1",
1549
+ xmlns: "http://www.w3.org/2000/svg",
1550
+ children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("g", { id: "Group-2", transform: "translate(-118, 0)", fill: "#1BC030", fillRule: "nonzero", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("g", { id: "Group", transform: "translate(118, 0)", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
1551
+ "path",
1552
+ {
1553
+ 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",
1554
+ id: "Shape"
1555
+ }
1556
+ ) }) }) })
1557
+ }
1558
+ );
1559
+ var CopilotKitIcon = /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)(
1560
+ "svg",
1561
+ {
1562
+ width: "33px",
1563
+ height: "35px",
1564
+ viewBox: "0 0 33 35",
1565
+ version: "1.1",
1566
+ xmlns: "http://www.w3.org/2000/svg",
1567
+ children: [
1568
+ /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("title", { children: "bd5c9079-929b-4d55-bdc9-16d1c8181b71" }),
1569
+ /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
1570
+ "image",
1571
+ {
1572
+ x: "0",
1573
+ y: "0",
1574
+ width: "33",
1575
+ height: "35",
1576
+ xlinkHref: ""
1577
+ }
1578
+ ) })
1579
+ ]
1580
+ }
1581
+ );
1582
+
1583
+ // src/components/dev-console/console.tsx
1584
+ var import_react10 = require("@headlessui/react");
1585
+ var import_shared2 = require("@copilotkit/shared");
1586
+ var import_jsx_runtime14 = require("react/jsx-runtime");
1587
+ function CopilotDevConsole() {
1588
+ const currentVersion = import_shared2.COPILOTKIT_VERSION;
1589
+ const context = (0, import_react_core6.useCopilotContext)();
1590
+ const [showDevConsole, setShowDevConsole] = (0, import_react9.useState)(false);
1591
+ (0, import_react9.useEffect)(() => {
1592
+ setShowDevConsole(shouldShowDevConsole(context.showDevConsole));
1593
+ }, [context.showDevConsole]);
1594
+ const dontRunTwiceInDevMode = (0, import_react9.useRef)(false);
1595
+ const [versionStatus, setVersionStatus] = (0, import_react9.useState)("unknown");
1596
+ const [latestVersion, setLatestVersion] = (0, import_react9.useState)("");
1597
+ const consoleRef = (0, import_react9.useRef)(null);
1598
+ const [debugButtonMode, setDebugButtonMode] = (0, import_react9.useState)("full");
1599
+ const checkForUpdates = (force = false) => {
1600
+ setVersionStatus("checking");
1601
+ getPublishedCopilotKitVersion(currentVersion, force).then((v) => {
1602
+ setLatestVersion(v.latest);
1603
+ if (v.current === v.latest) {
1604
+ setVersionStatus("latest");
1605
+ } else if (v.severity !== "low") {
1606
+ setVersionStatus("outdated");
1607
+ } else {
1608
+ setVersionStatus("update-available");
1609
+ }
1610
+ }).catch((e) => {
1611
+ console.error(e);
1612
+ setVersionStatus("unknown");
1613
+ });
1614
+ };
1615
+ (0, import_react9.useEffect)(() => {
1616
+ if (dontRunTwiceInDevMode.current === true) {
1617
+ return;
1618
+ }
1619
+ dontRunTwiceInDevMode.current = true;
1620
+ checkForUpdates();
1621
+ }, []);
1622
+ (0, import_react9.useEffect)(() => {
1623
+ const handleResize = (entries) => {
1624
+ for (let entry of entries) {
1625
+ if (entry.target === consoleRef.current) {
1626
+ const width = entry.contentRect.width;
1627
+ if (width < 400) {
1628
+ setDebugButtonMode("compact");
1629
+ } else {
1630
+ setDebugButtonMode("full");
1631
+ }
1632
+ }
1633
+ }
1634
+ };
1635
+ const observer = new ResizeObserver(handleResize);
1636
+ if (consoleRef.current) {
1637
+ observer.observe(consoleRef.current);
1638
+ const initialWidth = consoleRef.current.getBoundingClientRect().width;
1639
+ if (initialWidth < 400) {
1640
+ setDebugButtonMode("compact");
1641
+ } else {
1642
+ setDebugButtonMode("full");
1643
+ }
1644
+ }
1645
+ return () => {
1646
+ if (consoleRef.current) {
1647
+ observer.unobserve(consoleRef.current);
1648
+ }
1649
+ };
1650
+ }, [consoleRef.current]);
1651
+ if (!showDevConsole) {
1652
+ return null;
1653
+ }
1654
+ return /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)(
1655
+ "div",
1656
+ {
1657
+ ref: consoleRef,
1658
+ className: "copilotKitDevConsole " + (versionStatus === "update-available" ? "copilotKitDevConsoleUpgrade" : "") + (versionStatus === "outdated" ? "copilotKitDevConsoleWarnOutdated" : ""),
1659
+ children: [
1660
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("div", { className: "copilotKitDevConsoleLogo", children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("a", { href: "https://copilotkit.ai", target: "_blank", children: CopilotKitIcon }) }),
1661
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(
1662
+ VersionInfo,
1663
+ {
1664
+ showDevConsole: context.showDevConsole,
1665
+ versionStatus,
1666
+ currentVersion,
1667
+ latestVersion
1668
+ }
1669
+ ),
1670
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(
1671
+ DebugMenuButton,
1672
+ {
1673
+ setShowDevConsole,
1674
+ checkForUpdates,
1675
+ mode: debugButtonMode
1676
+ }
1677
+ )
1678
+ ]
1679
+ }
1680
+ );
1681
+ }
1682
+ function VersionInfo({
1683
+ showDevConsole,
1684
+ versionStatus,
1685
+ currentVersion,
1686
+ latestVersion
1687
+ }) {
1688
+ const [copyStatus, setCopyStatus] = (0, import_react9.useState)("");
1689
+ let versionLabel = "";
1690
+ let versionIcon = "";
1691
+ let currentVersionLabel = currentVersion;
1692
+ if (versionStatus === "latest") {
1693
+ versionLabel = "latest";
1694
+ versionIcon = CheckIcon2;
1695
+ } else if (versionStatus === "checking") {
1696
+ versionLabel = "checking";
1697
+ versionIcon = SmallSpinnerIcon;
1698
+ } else if (versionStatus === "update-available") {
1699
+ versionLabel = "update available";
1700
+ versionIcon = ExclamationMarkIcon;
1701
+ currentVersionLabel = `${currentVersion} \u2192 ${latestVersion}`;
1702
+ } else if (versionStatus === "outdated") {
1703
+ versionLabel = "outdated";
1704
+ versionIcon = ExclamationMarkTriangleIcon;
1705
+ currentVersionLabel = `${currentVersion} \u2192 ${latestVersion}`;
1706
+ }
1707
+ let asideLabel = "";
1708
+ if (showDevConsole === "auto") {
1709
+ asideLabel = "(localhost only)";
1710
+ } else if (showDevConsole === true) {
1711
+ asideLabel = "(always on)";
1712
+ }
1713
+ const installCommand = [
1714
+ `npm install`,
1715
+ `@copilotkit/react-core@${latestVersion}`,
1716
+ `@copilotkit/react-ui@${latestVersion}`,
1717
+ `@copilotkit/react-textarea@${latestVersion}`
1718
+ ].join(" ");
1719
+ const handleCopyClick = () => {
1720
+ navigator.clipboard.writeText(installCommand.trim()).then(() => {
1721
+ setCopyStatus("Command copied to clipboard!");
1722
+ setTimeout(() => setCopyStatus(""), 1e3);
1723
+ });
1724
+ };
1725
+ return /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)("div", { className: "copilotKitVersionInfo", children: [
1726
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)("header", { children: [
1727
+ "COPILOTKIT DEV CONSOLE",
1728
+ showDevConsole === "auto" && /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("aside", { children: asideLabel })
1729
+ ] }),
1730
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)("section", { children: [
1731
+ "Version: ",
1732
+ versionLabel,
1733
+ " (",
1734
+ currentVersionLabel,
1735
+ ") ",
1736
+ versionIcon
1737
+ ] }),
1738
+ (versionStatus === "update-available" || versionStatus === "outdated") && /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("footer", { children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("button", { onClick: handleCopyClick, children: copyStatus || installCommand }) })
1739
+ ] });
1740
+ }
1741
+ function DebugMenuButton({
1742
+ setShowDevConsole,
1743
+ checkForUpdates,
1744
+ mode
1745
+ }) {
1746
+ const context = (0, import_react_core6.useCopilotContext)();
1747
+ return /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("div", { className: "bg-black fixed top-24 w-52 text-right", children: /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)(import_react10.Menu, { children: [
1748
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(import_react10.MenuButton, { className: `copilotKitDebugMenuButton ${mode === "compact" ? "compact" : ""}`, children: mode == "compact" ? "Debug" : /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)(import_jsx_runtime14.Fragment, { children: [
1749
+ "Debug ",
1750
+ ChevronDownIcon
1751
+ ] }) }),
1752
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)(
1753
+ import_react10.MenuItems,
1754
+ {
1755
+ transition: true,
1756
+ anchor: "bottom end",
1757
+ className: "copilotKitDebugMenu",
1758
+ style: { zIndex: 40 },
1759
+ children: [
1760
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(import_react10.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => logReadables(context), children: "Log Readables" }) }),
1761
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(import_react10.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => logActions(context), children: "Log Actions" }) }),
1762
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(import_react10.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => checkForUpdates(true), children: "Check for Updates" }) }),
1763
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("hr", {}),
1764
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(import_react10.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => setShowDevConsole(false), children: "Hide Dev Console" }) })
1765
+ ]
1766
+ }
1767
+ )
1768
+ ] }) });
1769
+ }
1770
+
1771
+ // src/components/chat/Chat.tsx
1772
+ var import_jsx_runtime15 = require("react/jsx-runtime");
1421
1773
  function CopilotChat({
1422
1774
  instructions,
1423
1775
  onSubmitMessage,
@@ -1431,8 +1783,8 @@ function CopilotChat({
1431
1783
  icons,
1432
1784
  labels
1433
1785
  }) {
1434
- const context = (0, import_react_core5.useCopilotContext)();
1435
- (0, import_react9.useEffect)(() => {
1786
+ const context = (0, import_react_core7.useCopilotContext)();
1787
+ (0, import_react11.useEffect)(() => {
1436
1788
  context.setChatInstructions(instructions || "");
1437
1789
  }, [instructions]);
1438
1790
  const {
@@ -1443,13 +1795,14 @@ function CopilotChat({
1443
1795
  stopGeneration,
1444
1796
  reloadMessages
1445
1797
  } = useCopilotChatLogic(makeSystemMessage, onInProgress, onSubmitMessage);
1446
- const chatContext = import_react9.default.useContext(ChatContext);
1798
+ const chatContext = import_react11.default.useContext(ChatContext);
1447
1799
  const isVisible = chatContext ? chatContext.open : true;
1448
- return /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)(WrappedCopilotChat, { icons, labels, className, children: [
1449
- /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)(Messages2, { messages: visibleMessages, inProgress: isLoading, children: [
1450
- currentSuggestions.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)("div", { children: [
1451
- /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("h6", { children: "Suggested:" }),
1452
- /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("div", { className: "suggestions", children: currentSuggestions.map((suggestion, index) => /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
1800
+ return /* @__PURE__ */ (0, import_jsx_runtime15.jsxs)(WrappedCopilotChat, { icons, labels, className, children: [
1801
+ /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(CopilotDevConsole, {}),
1802
+ /* @__PURE__ */ (0, import_jsx_runtime15.jsxs)(Messages2, { messages: visibleMessages, inProgress: isLoading, children: [
1803
+ currentSuggestions.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime15.jsxs)("div", { children: [
1804
+ /* @__PURE__ */ (0, import_jsx_runtime15.jsx)("h6", { children: "Suggested:" }),
1805
+ /* @__PURE__ */ (0, import_jsx_runtime15.jsx)("div", { className: "suggestions", children: currentSuggestions.map((suggestion, index) => /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(
1453
1806
  Suggestion,
1454
1807
  {
1455
1808
  title: suggestion.title,
@@ -1461,7 +1814,7 @@ function CopilotChat({
1461
1814
  index
1462
1815
  )) })
1463
1816
  ] }),
1464
- showResponseButton && visibleMessages.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
1817
+ showResponseButton && visibleMessages.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(
1465
1818
  ResponseButton2,
1466
1819
  {
1467
1820
  onClick: isLoading ? stopGeneration : reloadMessages,
@@ -1469,7 +1822,7 @@ function CopilotChat({
1469
1822
  }
1470
1823
  )
1471
1824
  ] }),
1472
- /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(Input2, { inProgress: isLoading, onSend: sendMessage, isVisible })
1825
+ /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(Input2, { inProgress: isLoading, onSend: sendMessage, isVisible })
1473
1826
  ] });
1474
1827
  }
1475
1828
  function WrappedCopilotChat({
@@ -1478,29 +1831,29 @@ function WrappedCopilotChat({
1478
1831
  labels,
1479
1832
  className
1480
1833
  }) {
1481
- const chatContext = import_react9.default.useContext(ChatContext);
1834
+ const chatContext = import_react11.default.useContext(ChatContext);
1482
1835
  if (!chatContext) {
1483
- return /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(ChatContextProvider, { icons, labels, open: true, setOpen: () => {
1484
- }, children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("div", { className: `copilotKitChat ${className}`, children }) });
1836
+ return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(ChatContextProvider, { icons, labels, open: true, setOpen: () => {
1837
+ }, children: /* @__PURE__ */ (0, import_jsx_runtime15.jsx)("div", { className: `copilotKitChat ${className}`, children }) });
1485
1838
  }
1486
- return /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(import_jsx_runtime13.Fragment, { children });
1839
+ return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(import_jsx_runtime15.Fragment, { children });
1487
1840
  }
1488
1841
  var SUGGESTIONS_DEBOUNCE_TIMEOUT = 1e3;
1489
1842
  var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage) => {
1490
- const { visibleMessages, appendMessage, reloadMessages, stopGeneration, isLoading } = (0, import_react_core5.useCopilotChat)({
1491
- id: (0, import_shared2.randomId)(),
1843
+ const { visibleMessages, appendMessage, reloadMessages, stopGeneration, isLoading } = (0, import_react_core7.useCopilotChat)({
1844
+ id: (0, import_shared3.randomId)(),
1492
1845
  makeSystemMessage
1493
1846
  });
1494
- const [currentSuggestions, setCurrentSuggestions] = (0, import_react9.useState)([]);
1495
- const suggestionsAbortControllerRef = (0, import_react9.useRef)(null);
1496
- const debounceTimerRef = (0, import_react9.useRef)();
1847
+ const [currentSuggestions, setCurrentSuggestions] = (0, import_react11.useState)([]);
1848
+ const suggestionsAbortControllerRef = (0, import_react11.useRef)(null);
1849
+ const debounceTimerRef = (0, import_react11.useRef)();
1497
1850
  const abortSuggestions = () => {
1498
1851
  var _a;
1499
1852
  (_a = suggestionsAbortControllerRef.current) == null ? void 0 : _a.abort();
1500
1853
  suggestionsAbortControllerRef.current = null;
1501
1854
  };
1502
- const context = (0, import_react_core5.useCopilotContext)();
1503
- (0, import_react9.useEffect)(() => {
1855
+ const context = (0, import_react_core7.useCopilotContext)();
1856
+ (0, import_react11.useEffect)(() => {
1504
1857
  onInProgress == null ? void 0 : onInProgress(isLoading);
1505
1858
  abortSuggestions();
1506
1859
  debounceTimerRef.current = setTimeout(
@@ -1543,7 +1896,7 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage) =>
1543
1896
  };
1544
1897
 
1545
1898
  // src/components/chat/Modal.tsx
1546
- var import_jsx_runtime14 = require("react/jsx-runtime");
1899
+ var import_jsx_runtime16 = require("react/jsx-runtime");
1547
1900
  var CopilotModal = ({
1548
1901
  instructions,
1549
1902
  defaultOpen = false,
@@ -1566,16 +1919,16 @@ var CopilotModal = ({
1566
1919
  className,
1567
1920
  children
1568
1921
  }) => {
1569
- const [openState, setOpenState] = import_react10.default.useState(defaultOpen);
1922
+ const [openState, setOpenState] = import_react12.default.useState(defaultOpen);
1570
1923
  const setOpen = (open) => {
1571
1924
  onSetOpen == null ? void 0 : onSetOpen(open);
1572
1925
  setOpenState(open);
1573
1926
  };
1574
- return /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)(ChatContextProvider, { icons, labels, open: openState, setOpen: setOpenState, children: [
1927
+ return /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)(ChatContextProvider, { icons, labels, open: openState, setOpen: setOpenState, children: [
1575
1928
  children,
1576
- /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)("div", { className, children: [
1577
- /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(Button2, { open: openState, setOpen }),
1578
- /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)(
1929
+ /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)("div", { className, children: [
1930
+ /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(Button2, { open: openState, setOpen }),
1931
+ /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)(
1579
1932
  Window2,
1580
1933
  {
1581
1934
  open: openState,
@@ -1584,8 +1937,8 @@ var CopilotModal = ({
1584
1937
  shortcut,
1585
1938
  hitEscapeToClose,
1586
1939
  children: [
1587
- /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(Header2, { open: openState, setOpen }),
1588
- /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(
1940
+ /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(Header2, { open: openState, setOpen }),
1941
+ /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
1589
1942
  CopilotChat,
1590
1943
  {
1591
1944
  instructions,