@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
package/dist/index.mjs CHANGED
@@ -4,19 +4,23 @@ import "./chunk-JD7BAH7U.mjs";
4
4
  import "./chunk-MRFF7GSQ.mjs";
5
5
  import {
6
6
  CopilotSidebar
7
- } from "./chunk-QHAVUMXM.mjs";
7
+ } from "./chunk-EU75TDHP.mjs";
8
8
  import "./chunk-WB3YULQ4.mjs";
9
9
  import {
10
10
  CopilotPopup
11
- } from "./chunk-DYHXNV2B.mjs";
12
- import "./chunk-OLL5TU65.mjs";
11
+ } from "./chunk-2CFQIOJA.mjs";
12
+ import "./chunk-JCRSTTLF.mjs";
13
13
  import "./chunk-B7DNOYVQ.mjs";
14
14
  import "./chunk-SE6DAYSX.mjs";
15
15
  import "./chunk-UC3Y7MWX.mjs";
16
16
  import {
17
17
  CopilotChat
18
- } from "./chunk-5BL3YDGU.mjs";
18
+ } from "./chunk-BBZDFB4Y.mjs";
19
+ import "./chunk-V7W6IM2V.mjs";
19
20
  import "./chunk-KSCXPA74.mjs";
21
+ import "./chunk-O4AM2PCW.mjs";
22
+ import "./chunk-RT2BA4MP.mjs";
23
+ import "./chunk-OTPAZXVR.mjs";
20
24
  import "./chunk-U6J5DGOE.mjs";
21
25
  import "./chunk-YQFVRDNC.mjs";
22
26
  import "./chunk-4Z2WDXSK.mjs";
package/package.json CHANGED
@@ -9,7 +9,7 @@
9
9
  "publishConfig": {
10
10
  "access": "public"
11
11
  },
12
- "version": "1.0.7",
12
+ "version": "1.0.8-mme-pre-dev-console.0",
13
13
  "sideEffects": [
14
14
  "**/*.css"
15
15
  ],
@@ -40,18 +40,19 @@
40
40
  "ts-jest": "^29.1.1",
41
41
  "tsup": "^6.7.0",
42
42
  "typescript": "^5.2.3",
43
- "eslint-config-custom": "1.0.2",
44
- "tailwind-config": "1.0.2",
45
- "tsconfig": "1.0.2"
43
+ "eslint-config-custom": "1.0.3-mme-pre-dev-console.0",
44
+ "tailwind-config": "1.0.3-mme-pre-dev-console.0",
45
+ "tsconfig": "1.0.3-mme-pre-dev-console.0"
46
46
  },
47
47
  "dependencies": {
48
+ "@headlessui/react": "^2.1.2",
48
49
  "react-markdown": "^8.0.7",
49
50
  "react-syntax-highlighter": "^15.5.0",
50
51
  "remark-gfm": "^3.0.1",
51
52
  "remark-math": "^5.1.1",
52
- "@copilotkit/react-core": "1.0.7",
53
- "@copilotkit/runtime-client-gql": "1.0.7",
54
- "@copilotkit/shared": "1.0.7"
53
+ "@copilotkit/react-core": "1.0.8-mme-pre-dev-console.0",
54
+ "@copilotkit/runtime-client-gql": "1.0.8-mme-pre-dev-console.0",
55
+ "@copilotkit/shared": "1.0.8-mme-pre-dev-console.0"
55
56
  },
56
57
  "keywords": [
57
58
  "copilotkit",
@@ -62,6 +62,8 @@ import { Message, Role, TextMessage } from "@copilotkit/runtime-client-gql";
62
62
  import { InputProps, MessagesProps, ResponseButtonProps } from "./props";
63
63
  import { randomId } from "@copilotkit/shared";
64
64
 
65
+ import { CopilotDevConsole } from "../dev-console";
66
+
65
67
  /**
66
68
  * Props for CopilotChat component.
67
69
  */
@@ -169,6 +171,7 @@ export function CopilotChat({
169
171
 
170
172
  return (
171
173
  <WrappedCopilotChat icons={icons} labels={labels} className={className}>
174
+ <CopilotDevConsole />
172
175
  <Messages messages={visibleMessages} inProgress={isLoading}>
173
176
  {currentSuggestions.length > 0 && (
174
177
  <div>
@@ -0,0 +1,258 @@
1
+ "use client";
2
+
3
+ import { useCopilotContext } from "@copilotkit/react-core";
4
+ import {
5
+ getPublishedCopilotKitVersion,
6
+ logActions,
7
+ logReadables,
8
+ shouldShowDevConsole,
9
+ } from "./utils";
10
+ import { useEffect, useRef, useState } from "react";
11
+ import {
12
+ CheckIcon,
13
+ ChevronDownIcon,
14
+ CopilotKitIcon,
15
+ ExclamationMarkIcon,
16
+ ExclamationMarkTriangleIcon,
17
+ } from "./icons";
18
+ import { Menu, MenuButton, MenuItem, MenuItems } from "@headlessui/react";
19
+ import { COPILOTKIT_VERSION } from "@copilotkit/shared";
20
+ import { SmallSpinnerIcon } from "../chat/Icons";
21
+
22
+ type VersionStatus = "unknown" | "checking" | "latest" | "update-available" | "outdated";
23
+
24
+ export function CopilotDevConsole() {
25
+ const currentVersion = COPILOTKIT_VERSION;
26
+ const context = useCopilotContext();
27
+
28
+ // to prevent hydration errors, ensure that the component renders the same content
29
+ // server-side as it does during the initial client-side render to prevent a hydration
30
+ // mismatch
31
+ // see: https://nextjs.org/docs/messages/react-hydration-error#solution-1-using-useeffect-to-run-on-the-client-only
32
+
33
+ const [showDevConsole, setShowDevConsole] = useState(false);
34
+
35
+ useEffect(() => {
36
+ setShowDevConsole(shouldShowDevConsole(context.showDevConsole));
37
+ }, [context.showDevConsole]);
38
+
39
+ const dontRunTwiceInDevMode = useRef(false);
40
+ const [versionStatus, setVersionStatus] = useState<VersionStatus>("unknown");
41
+ const [latestVersion, setLatestVersion] = useState<string>("");
42
+ const consoleRef = useRef<HTMLDivElement>(null);
43
+ const [debugButtonMode, setDebugButtonMode] = useState<"full" | "compact">("full");
44
+
45
+ const checkForUpdates = (force: boolean = false) => {
46
+ setVersionStatus("checking");
47
+ getPublishedCopilotKitVersion(currentVersion, force)
48
+ .then((v) => {
49
+ setLatestVersion(v.latest);
50
+ if (v.current === v.latest) {
51
+ setVersionStatus("latest");
52
+ } else if (v.severity !== "low") {
53
+ setVersionStatus("outdated");
54
+ } else {
55
+ setVersionStatus("update-available");
56
+ }
57
+ })
58
+ .catch((e) => {
59
+ console.error(e);
60
+ setVersionStatus("unknown");
61
+ });
62
+ };
63
+
64
+ useEffect(() => {
65
+ if (dontRunTwiceInDevMode.current === true) {
66
+ return;
67
+ }
68
+ dontRunTwiceInDevMode.current = true;
69
+
70
+ checkForUpdates();
71
+ }, []);
72
+
73
+ useEffect(() => {
74
+ const handleResize = (entries: ResizeObserverEntry[]) => {
75
+ for (let entry of entries) {
76
+ if (entry.target === consoleRef.current) {
77
+ const width = entry.contentRect.width;
78
+ if (width < 400) {
79
+ setDebugButtonMode("compact");
80
+ } else {
81
+ setDebugButtonMode("full");
82
+ }
83
+ }
84
+ }
85
+ };
86
+
87
+ const observer = new ResizeObserver(handleResize);
88
+ if (consoleRef.current) {
89
+ observer.observe(consoleRef.current);
90
+
91
+ const initialWidth = consoleRef.current.getBoundingClientRect().width;
92
+ if (initialWidth < 400) {
93
+ setDebugButtonMode("compact");
94
+ } else {
95
+ setDebugButtonMode("full");
96
+ }
97
+ }
98
+
99
+ return () => {
100
+ if (consoleRef.current) {
101
+ observer.unobserve(consoleRef.current);
102
+ }
103
+ };
104
+ }, [consoleRef.current]);
105
+
106
+ if (!showDevConsole) {
107
+ return null;
108
+ }
109
+ return (
110
+ <div
111
+ ref={consoleRef}
112
+ className={
113
+ "copilotKitDevConsole " +
114
+ (versionStatus === "update-available" ? "copilotKitDevConsoleUpgrade" : "") +
115
+ (versionStatus === "outdated" ? "copilotKitDevConsoleWarnOutdated" : "")
116
+ }
117
+ >
118
+ <div className="copilotKitDevConsoleLogo">
119
+ <a href="https://copilotkit.ai" target="_blank">
120
+ {CopilotKitIcon}
121
+ </a>
122
+ </div>
123
+ <VersionInfo
124
+ showDevConsole={context.showDevConsole}
125
+ versionStatus={versionStatus}
126
+ currentVersion={currentVersion}
127
+ latestVersion={latestVersion}
128
+ />
129
+
130
+ <DebugMenuButton
131
+ setShowDevConsole={setShowDevConsole}
132
+ checkForUpdates={checkForUpdates}
133
+ mode={debugButtonMode}
134
+ />
135
+ </div>
136
+ );
137
+ }
138
+
139
+ function VersionInfo({
140
+ showDevConsole,
141
+ versionStatus,
142
+ currentVersion,
143
+ latestVersion,
144
+ }: {
145
+ showDevConsole: boolean | "auto";
146
+ versionStatus: VersionStatus;
147
+ currentVersion: string;
148
+ latestVersion: string;
149
+ }) {
150
+ const [copyStatus, setCopyStatus] = useState<string>("");
151
+
152
+ let versionLabel = "";
153
+ let versionIcon: any = "";
154
+ let currentVersionLabel = currentVersion;
155
+
156
+ if (versionStatus === "latest") {
157
+ versionLabel = "latest";
158
+ versionIcon = CheckIcon;
159
+ } else if (versionStatus === "checking") {
160
+ versionLabel = "checking";
161
+ versionIcon = SmallSpinnerIcon;
162
+ } else if (versionStatus === "update-available") {
163
+ versionLabel = "update available";
164
+ versionIcon = ExclamationMarkIcon;
165
+ currentVersionLabel = `${currentVersion} → ${latestVersion}`;
166
+ } else if (versionStatus === "outdated") {
167
+ versionLabel = "outdated";
168
+ versionIcon = ExclamationMarkTriangleIcon;
169
+ currentVersionLabel = `${currentVersion} → ${latestVersion}`;
170
+ }
171
+
172
+ let asideLabel = "";
173
+ if (showDevConsole === "auto") {
174
+ asideLabel = "(localhost only)";
175
+ } else if (showDevConsole === true) {
176
+ asideLabel = "(always on)";
177
+ }
178
+
179
+ const installCommand = [
180
+ `npm install`,
181
+ `@copilotkit/react-core@${latestVersion}`,
182
+ `@copilotkit/react-ui@${latestVersion}`,
183
+ `@copilotkit/react-textarea@${latestVersion}`,
184
+ ].join(" ");
185
+
186
+ const handleCopyClick = () => {
187
+ navigator.clipboard.writeText(installCommand.trim()).then(() => {
188
+ setCopyStatus("Command copied to clipboard!");
189
+ setTimeout(() => setCopyStatus(""), 1000);
190
+ });
191
+ };
192
+
193
+ return (
194
+ <div className="copilotKitVersionInfo">
195
+ <header>
196
+ COPILOTKIT DEV CONSOLE{showDevConsole === "auto" && <aside>{asideLabel}</aside>}
197
+ </header>
198
+ <section>
199
+ Version: {versionLabel} ({currentVersionLabel}) {versionIcon}
200
+ </section>
201
+ {(versionStatus === "update-available" || versionStatus === "outdated") && (
202
+ <footer>
203
+ <button onClick={handleCopyClick}>{copyStatus || installCommand}</button>
204
+ </footer>
205
+ )}
206
+ </div>
207
+ );
208
+ }
209
+ export default function DebugMenuButton({
210
+ setShowDevConsole,
211
+ checkForUpdates,
212
+ mode,
213
+ }: {
214
+ setShowDevConsole: (show: boolean) => void;
215
+ checkForUpdates: (force: boolean) => void;
216
+ mode: "full" | "compact";
217
+ }) {
218
+ const context = useCopilotContext();
219
+
220
+ return (
221
+ <div className="bg-black fixed top-24 w-52 text-right">
222
+ <Menu>
223
+ <MenuButton className={`copilotKitDebugMenuButton ${mode === "compact" ? "compact" : ""}`}>
224
+ {mode == "compact" ? "Debug" : <>Debug {ChevronDownIcon}</>}
225
+ </MenuButton>
226
+
227
+ <MenuItems
228
+ transition
229
+ anchor="bottom end"
230
+ className="copilotKitDebugMenu"
231
+ style={{ zIndex: 40 }}
232
+ >
233
+ <MenuItem>
234
+ <button className="copilotKitDebugMenuItem" onClick={() => logReadables(context)}>
235
+ Log Readables
236
+ </button>
237
+ </MenuItem>
238
+ <MenuItem>
239
+ <button className="copilotKitDebugMenuItem" onClick={() => logActions(context)}>
240
+ Log Actions
241
+ </button>
242
+ </MenuItem>
243
+ <MenuItem>
244
+ <button className="copilotKitDebugMenuItem" onClick={() => checkForUpdates(true)}>
245
+ Check for Updates
246
+ </button>
247
+ </MenuItem>
248
+ <hr />
249
+ <MenuItem>
250
+ <button className="copilotKitDebugMenuItem" onClick={() => setShowDevConsole(false)}>
251
+ Hide Dev Console
252
+ </button>
253
+ </MenuItem>
254
+ </MenuItems>
255
+ </Menu>
256
+ </div>
257
+ );
258
+ }
@@ -0,0 +1,92 @@
1
+ export const ExclamationMarkTriangleIcon = (
2
+ <svg
3
+ width="13.3967723px"
4
+ height="12px"
5
+ viewBox="0 0 13.3967723 12"
6
+ version="1.1"
7
+ xmlns="http://www.w3.org/2000/svg"
8
+ >
9
+ <g id="Page-1" stroke="none" strokeWidth="1" fill="none" fillRule="evenodd">
10
+ <g id="exclamation-triangle" fill="#CD2121">
11
+ <path
12
+ 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"
13
+ id="Shape"
14
+ ></path>
15
+ </g>
16
+ </g>
17
+ </svg>
18
+ );
19
+
20
+ export const ExclamationMarkIcon = (
21
+ <svg
22
+ width="14px"
23
+ height="14px"
24
+ viewBox="0 0 14 14"
25
+ version="1.1"
26
+ xmlns="http://www.w3.org/2000/svg"
27
+ >
28
+ <g id="Page-1" stroke="none" strokeWidth="1" fill="none" fillRule="evenodd">
29
+ <g id="exclamation-circle" fill="#EC662C">
30
+ <path
31
+ 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"
32
+ id="Shape"
33
+ ></path>
34
+ </g>
35
+ </g>
36
+ </svg>
37
+ );
38
+
39
+ export const ChevronDownIcon = (
40
+ <svg width="7px" height="4px" viewBox="0 0 7 4" version="1.1" xmlns="http://www.w3.org/2000/svg">
41
+ <g id="Page-1" stroke="none" strokeWidth="1" fill="none" fillRule="evenodd">
42
+ <g id="Group" fill="#000000" fillRule="nonzero">
43
+ <path
44
+ 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"
45
+ id="Path"
46
+ ></path>
47
+ </g>
48
+ </g>
49
+ </svg>
50
+ );
51
+
52
+ export const CheckIcon = (
53
+ <svg
54
+ width="14px"
55
+ height="14px"
56
+ viewBox="0 0 14 14"
57
+ version="1.1"
58
+ xmlns="http://www.w3.org/2000/svg"
59
+ >
60
+ <g id="Page-1" stroke="none" strokeWidth="1" fill="none" fillRule="evenodd">
61
+ <g id="Group-2" transform="translate(-118, 0)" fill="#1BC030" fillRule="nonzero">
62
+ <g id="Group" transform="translate(118, 0)">
63
+ <path
64
+ 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"
65
+ id="Shape"
66
+ ></path>
67
+ </g>
68
+ </g>
69
+ </g>
70
+ </svg>
71
+ );
72
+
73
+ export const CopilotKitIcon = (
74
+ <svg
75
+ width="33px"
76
+ height="35px"
77
+ viewBox="0 0 33 35"
78
+ version="1.1"
79
+ xmlns="http://www.w3.org/2000/svg"
80
+ >
81
+ <title>bd5c9079-929b-4d55-bdc9-16d1c8181b71</title>
82
+ <g id="Page-1" stroke="none" strokeWidth="1" fill="none" fillRule="evenodd">
83
+ <image
84
+ x="0"
85
+ y="0"
86
+ width="33"
87
+ height="35"
88
+ xlinkHref=""
89
+ ></image>
90
+ </g>
91
+ </svg>
92
+ );
@@ -0,0 +1,2 @@
1
+ export { shouldShowDevConsole } from "./utils";
2
+ export { CopilotDevConsole } from "./console";
@@ -0,0 +1,7 @@
1
+ export interface CopilotKitVersion {
2
+ current: string;
3
+ latest: string;
4
+ severity: "low" | "medium" | "high";
5
+ advisory: string | null;
6
+ lastChecked: number;
7
+ }
@@ -0,0 +1,93 @@
1
+ import { CopilotContextParams, defaultCopilotContextCategories } from "@copilotkit/react-core";
2
+ import { CopilotKitVersion } from "./types";
3
+
4
+ export function shouldShowDevConsole(showDevConsole: boolean | "auto"): boolean {
5
+ if (typeof showDevConsole === "boolean") {
6
+ return showDevConsole;
7
+ }
8
+ return (
9
+ getHostname() === "localhost" ||
10
+ getHostname() === "127.0.0.1" ||
11
+ getHostname() === "0.0.0.0" ||
12
+ getHostname() === "::1"
13
+ );
14
+ }
15
+
16
+ function getHostname(): string {
17
+ if (typeof window !== "undefined" && window.location) {
18
+ return window.location.hostname;
19
+ }
20
+ return "";
21
+ }
22
+
23
+ export async function getPublishedCopilotKitVersion(
24
+ current: string,
25
+ forceCheck: boolean = false,
26
+ ): Promise<CopilotKitVersion> {
27
+ const LOCAL_STORAGE_KEY = "__copilotkit_version_check__";
28
+ const serializedVersion = localStorage.getItem(LOCAL_STORAGE_KEY);
29
+ if (serializedVersion && !forceCheck) {
30
+ try {
31
+ const parsedVersion: CopilotKitVersion = JSON.parse(serializedVersion);
32
+ const oneHour = 60 * 60 * 1000;
33
+ const now = new Date().getTime();
34
+
35
+ if (
36
+ parsedVersion.current === current &&
37
+ now - new Date(parsedVersion.lastChecked).getTime() < oneHour
38
+ ) {
39
+ return parsedVersion;
40
+ }
41
+ } catch (error) {
42
+ console.error("Failed to parse CopilotKitVersion from localStorage", error);
43
+ }
44
+ }
45
+
46
+ try {
47
+ const response = await fetch("https://api.cloud.stagingcopilotkit.ai/check-for-updates", {
48
+ method: "POST",
49
+ headers: {
50
+ "Content-Type": "application/json",
51
+ },
52
+ body: JSON.stringify({
53
+ packages: [
54
+ {
55
+ packageName: "@copilotkit/shared",
56
+ packageVersion: current,
57
+ },
58
+ ],
59
+ }),
60
+ });
61
+
62
+ const data = await response.json();
63
+
64
+ const version: CopilotKitVersion = {
65
+ current,
66
+ lastChecked: new Date().getTime(),
67
+ latest: data.packages[0].latestVersion,
68
+ severity: data.packages[0].severity,
69
+ advisory: data.packages[0].advisory || null,
70
+ };
71
+
72
+ localStorage.setItem(LOCAL_STORAGE_KEY, JSON.stringify(version));
73
+ return version;
74
+ } catch (error) {
75
+ console.error("Failed to check for updates", error);
76
+ throw error;
77
+ }
78
+ }
79
+
80
+ export function logReadables(context: CopilotContextParams) {
81
+ console.log(context.getContextString([], defaultCopilotContextCategories));
82
+ }
83
+
84
+ export function logActions(context: CopilotContextParams) {
85
+ for (const action of Object.values(context.actions)) {
86
+ console.group(action.name);
87
+ console.log("name", action.name);
88
+ console.log("description", action.description);
89
+ console.log("parameters", action.parameters);
90
+
91
+ console.groupEnd();
92
+ }
93
+ }