@copilotkit/react-ui 1.7.2-next.2 → 1.8.0-next.4
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 +21 -0
- package/dist/{chunk-CBBFRI3Q.mjs → chunk-5JY5QJ2W.mjs} +9 -5
- package/dist/chunk-5JY5QJ2W.mjs.map +1 -0
- package/dist/{chunk-OFYI4UU4.mjs → chunk-7RIBDD4K.mjs} +19 -3
- package/dist/chunk-7RIBDD4K.mjs.map +1 -0
- package/dist/{chunk-AELKLZSG.mjs → chunk-AIR3MXUU.mjs} +12 -12
- package/dist/{chunk-YAGE7RCE.mjs → chunk-CGVOCLHN.mjs} +2 -2
- package/dist/{chunk-DLG7BZTA.mjs → chunk-CZUP2N4J.mjs} +2 -2
- package/dist/chunk-FBYETUFL.mjs +118 -0
- package/dist/chunk-FBYETUFL.mjs.map +1 -0
- package/dist/chunk-GIPO7UB2.mjs +24 -0
- package/dist/chunk-GIPO7UB2.mjs.map +1 -0
- package/dist/{chunk-6FTRYYR5.mjs → chunk-GJME6MK4.mjs} +72 -62
- package/dist/chunk-GJME6MK4.mjs.map +1 -0
- package/dist/{chunk-QXQDIFOC.mjs → chunk-H24B7QWO.mjs} +49 -38
- package/dist/chunk-H24B7QWO.mjs.map +1 -0
- package/dist/{chunk-QXTRFMPM.mjs → chunk-LYHZXHTJ.mjs} +15 -12
- package/dist/chunk-LYHZXHTJ.mjs.map +1 -0
- package/dist/chunk-ORSMX3SE.mjs +244 -0
- package/dist/chunk-ORSMX3SE.mjs.map +1 -0
- package/dist/{chunk-UPTB2MVO.mjs → chunk-PCTCOQK2.mjs} +4 -10
- package/dist/chunk-PCTCOQK2.mjs.map +1 -0
- package/dist/{chunk-ZIF5JJCH.mjs → chunk-QQ4FBIGN.mjs} +30 -59
- package/dist/chunk-QQ4FBIGN.mjs.map +1 -0
- package/dist/{chunk-R2O33F44.mjs → chunk-TFIQA2P5.mjs} +2 -2
- package/dist/{chunk-WGAZXTUA.mjs → chunk-TOQ7P4DO.mjs} +6 -9
- package/dist/chunk-TOQ7P4DO.mjs.map +1 -0
- package/dist/{chunk-3XAXY2Z3.mjs → chunk-UZTZXMYS.mjs} +2 -2
- package/dist/{chunk-RQNJNK2W.mjs → chunk-VC4NO5QZ.mjs} +2 -2
- package/dist/{chunk-YQ3D5IQV.mjs → chunk-XNQO5AZZ.mjs} +2 -5
- package/dist/chunk-XNQO5AZZ.mjs.map +1 -0
- package/dist/chunk-YC4NBUGE.mjs +97 -0
- package/dist/chunk-YC4NBUGE.mjs.map +1 -0
- package/dist/components/chat/Button.js.map +1 -1
- package/dist/components/chat/Button.mjs +3 -3
- package/dist/components/chat/Chat.d.ts +17 -1
- package/dist/components/chat/Chat.js +380 -906
- package/dist/components/chat/Chat.js.map +1 -1
- package/dist/components/chat/Chat.mjs +11 -18
- package/dist/components/chat/ChatContext.d.ts +20 -0
- package/dist/components/chat/ChatContext.js +44 -74
- package/dist/components/chat/ChatContext.js.map +1 -1
- package/dist/components/chat/ChatContext.mjs +2 -2
- package/dist/components/chat/CodeBlock.js +58 -82
- package/dist/components/chat/CodeBlock.js.map +1 -1
- package/dist/components/chat/CodeBlock.mjs +2 -2
- package/dist/components/chat/Header.js +516 -4
- package/dist/components/chat/Header.js.map +1 -1
- package/dist/components/chat/Header.mjs +10 -3
- package/dist/components/chat/Icons.d.ts +10 -9
- package/dist/components/chat/Icons.js +125 -164
- package/dist/components/chat/Icons.js.map +1 -1
- package/dist/components/chat/Icons.mjs +9 -5
- package/dist/components/chat/Input.d.ts +1 -1
- package/dist/components/chat/Input.js +13 -10
- package/dist/components/chat/Input.js.map +1 -1
- package/dist/components/chat/Input.mjs +3 -3
- package/dist/components/chat/Markdown.js +58 -56
- package/dist/components/chat/Markdown.js.map +1 -1
- package/dist/components/chat/Markdown.mjs +3 -3
- package/dist/components/chat/Messages.d.ts +1 -1
- package/dist/components/chat/Messages.js +70 -60
- package/dist/components/chat/Messages.js.map +1 -1
- package/dist/components/chat/Messages.mjs +3 -3
- package/dist/components/chat/Modal.js +1709 -1749
- package/dist/components/chat/Modal.js.map +1 -1
- package/dist/components/chat/Modal.mjs +20 -20
- package/dist/components/chat/Popup.js +1709 -1749
- package/dist/components/chat/Popup.js.map +1 -1
- package/dist/components/chat/Popup.mjs +21 -21
- package/dist/components/chat/Response.js.map +1 -1
- package/dist/components/chat/Response.mjs +3 -3
- package/dist/components/chat/Sidebar.js +1711 -1751
- package/dist/components/chat/Sidebar.js.map +1 -1
- package/dist/components/chat/Sidebar.mjs +21 -21
- package/dist/components/chat/Suggestion.js +4 -40
- package/dist/components/chat/Suggestion.js.map +1 -1
- package/dist/components/chat/Suggestion.mjs +2 -2
- package/dist/components/chat/Window.js.map +1 -1
- package/dist/components/chat/Window.mjs +3 -3
- package/dist/components/chat/index.js +1711 -1751
- package/dist/components/chat/index.js.map +1 -1
- package/dist/components/chat/index.mjs +24 -24
- package/dist/components/chat/messages/AssistantMessage.js +211 -59
- package/dist/components/chat/messages/AssistantMessage.js.map +1 -1
- package/dist/components/chat/messages/AssistantMessage.mjs +5 -5
- package/dist/components/chat/messages/RenderTextMessage.js +18 -2
- package/dist/components/chat/messages/RenderTextMessage.js.map +1 -1
- package/dist/components/chat/messages/RenderTextMessage.mjs +1 -1
- package/dist/components/chat/props.d.ts +53 -0
- package/dist/components/chat/props.js.map +1 -1
- package/dist/components/crew/index.mjs +1 -1
- package/dist/components/dev-console/console.js +51 -233
- package/dist/components/dev-console/console.js.map +1 -1
- package/dist/components/dev-console/console.mjs +5 -5
- package/dist/components/dev-console/index.js +51 -233
- package/dist/components/dev-console/index.js.map +1 -1
- package/dist/components/dev-console/index.mjs +5 -5
- package/dist/components/help-modal/index.js +29 -147
- package/dist/components/help-modal/index.js.map +1 -1
- package/dist/components/help-modal/index.mjs +1 -1
- package/dist/components/help-modal/modal.js +29 -147
- package/dist/components/help-modal/modal.js.map +1 -1
- package/dist/components/help-modal/modal.mjs +1 -1
- package/dist/components/index.js +1685 -1725
- package/dist/components/index.js.map +1 -1
- package/dist/components/index.mjs +30 -30
- package/dist/index.css +266 -98
- package/dist/index.css.map +1 -1
- package/dist/index.js +1694 -1734
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +30 -30
- package/dist/types/css.d.ts +6 -5
- package/dist/types/css.js.map +1 -1
- package/package.json +4 -4
- package/src/components/chat/Chat.tsx +59 -22
- package/src/components/chat/ChatContext.tsx +29 -1
- package/src/components/chat/CodeBlock.tsx +2 -4
- package/src/components/chat/Header.tsx +8 -3
- package/src/components/chat/Icons.tsx +108 -108
- package/src/components/chat/Input.tsx +47 -38
- package/src/components/chat/Markdown.tsx +0 -3
- package/src/components/chat/Messages.tsx +68 -56
- package/src/components/chat/Suggestion.tsx +2 -3
- package/src/components/chat/messages/AssistantMessage.tsx +95 -3
- package/src/components/chat/messages/RenderTextMessage.tsx +17 -1
- package/src/components/chat/props.ts +66 -0
- package/src/components/dev-console/console.tsx +16 -54
- package/src/components/help-modal/modal.tsx +38 -101
- package/src/css/button.css +15 -4
- package/src/css/colors.css +56 -10
- package/src/css/console.css +46 -39
- package/src/css/header.css +23 -6
- package/src/css/input.css +35 -19
- package/src/css/markdown.css +2 -1
- package/src/css/messages.css +126 -16
- package/src/css/panel.css +1 -0
- package/src/css/suggestions.css +14 -6
- package/src/types/css.ts +6 -5
- package/dist/chunk-3VNMQWGT.mjs +0 -25
- package/dist/chunk-3VNMQWGT.mjs.map +0 -1
- package/dist/chunk-6FTRYYR5.mjs.map +0 -1
- package/dist/chunk-CBBFRI3Q.mjs.map +0 -1
- package/dist/chunk-FZC7X5PK.mjs +0 -262
- package/dist/chunk-FZC7X5PK.mjs.map +0 -1
- package/dist/chunk-OFYI4UU4.mjs.map +0 -1
- package/dist/chunk-QXQDIFOC.mjs.map +0 -1
- package/dist/chunk-QXTRFMPM.mjs.map +0 -1
- package/dist/chunk-TI7SY2RI.mjs +0 -164
- package/dist/chunk-TI7SY2RI.mjs.map +0 -1
- package/dist/chunk-UPTB2MVO.mjs.map +0 -1
- package/dist/chunk-VEC45H6Q.mjs +0 -18
- package/dist/chunk-VEC45H6Q.mjs.map +0 -1
- package/dist/chunk-WGAZXTUA.mjs.map +0 -1
- package/dist/chunk-YQ3D5IQV.mjs.map +0 -1
- package/dist/chunk-ZIF5JJCH.mjs.map +0 -1
- /package/dist/{chunk-AELKLZSG.mjs.map → chunk-AIR3MXUU.mjs.map} +0 -0
- /package/dist/{chunk-YAGE7RCE.mjs.map → chunk-CGVOCLHN.mjs.map} +0 -0
- /package/dist/{chunk-DLG7BZTA.mjs.map → chunk-CZUP2N4J.mjs.map} +0 -0
- /package/dist/{chunk-R2O33F44.mjs.map → chunk-TFIQA2P5.mjs.map} +0 -0
- /package/dist/{chunk-3XAXY2Z3.mjs.map → chunk-UZTZXMYS.mjs.map} +0 -0
- /package/dist/{chunk-RQNJNK2W.mjs.map → chunk-VC4NO5QZ.mjs.map} +0 -0
|
@@ -140,7 +140,20 @@ var SendIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
|
140
140
|
xmlns: "http://www.w3.org/2000/svg",
|
|
141
141
|
fill: "none",
|
|
142
142
|
viewBox: "0 0 24 24",
|
|
143
|
-
strokeWidth: 1.5,
|
|
143
|
+
strokeWidth: "1.5",
|
|
144
|
+
stroke: "currentColor",
|
|
145
|
+
width: "24",
|
|
146
|
+
height: "24",
|
|
147
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M12 19V5m0 0l-7 7m7-7l7 7" })
|
|
148
|
+
}
|
|
149
|
+
);
|
|
150
|
+
var MicrophoneIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
151
|
+
"svg",
|
|
152
|
+
{
|
|
153
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
154
|
+
fill: "none",
|
|
155
|
+
viewBox: "0 0 24 24",
|
|
156
|
+
strokeWidth: "1.5",
|
|
144
157
|
stroke: "currentColor",
|
|
145
158
|
width: "24",
|
|
146
159
|
height: "24",
|
|
@@ -149,184 +162,157 @@ var SendIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
|
149
162
|
{
|
|
150
163
|
strokeLinecap: "round",
|
|
151
164
|
strokeLinejoin: "round",
|
|
152
|
-
d: "
|
|
165
|
+
d: "M12 18.75a6 6 0 006-6v-1.5m-6 7.5a6 6 0 01-6-6v-1.5m6 7.5v3.75m-3.75 0h7.5M12 15.75a3 3 0 01-3-3V4.5a3 3 0 116 0v8.25a3 3 0 01-3 3z"
|
|
153
166
|
}
|
|
154
167
|
)
|
|
155
168
|
}
|
|
156
169
|
);
|
|
157
|
-
var
|
|
170
|
+
var StopIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
158
171
|
"svg",
|
|
159
172
|
{
|
|
160
|
-
style: {
|
|
161
|
-
animation: "copilotKitSpinAnimation 1s linear infinite",
|
|
162
|
-
color: "rgb(107 114 128)"
|
|
163
|
-
},
|
|
164
|
-
width: "24",
|
|
165
|
-
height: "24",
|
|
166
173
|
xmlns: "http://www.w3.org/2000/svg",
|
|
167
174
|
fill: "none",
|
|
168
175
|
viewBox: "0 0 24 24",
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
182
|
-
"path",
|
|
183
|
-
{
|
|
184
|
-
style: { opacity: 0.75 },
|
|
185
|
-
fill: "currentColor",
|
|
186
|
-
d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
|
|
187
|
-
}
|
|
188
|
-
)
|
|
189
|
-
]
|
|
176
|
+
strokeWidth: "1.5",
|
|
177
|
+
stroke: "currentColor",
|
|
178
|
+
width: "24",
|
|
179
|
+
height: "24",
|
|
180
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
181
|
+
"path",
|
|
182
|
+
{
|
|
183
|
+
strokeLinecap: "round",
|
|
184
|
+
strokeLinejoin: "round",
|
|
185
|
+
d: "M5.25 7.5A2.25 2.25 0 017.5 5.25h9a2.25 2.25 0 012.25 2.25v9a2.25 2.25 0 01-2.25 2.25h-9a2.25 2.25 0 01-2.25-2.25v-9z"
|
|
186
|
+
}
|
|
187
|
+
)
|
|
190
188
|
}
|
|
191
189
|
);
|
|
192
|
-
var
|
|
190
|
+
var RegenerateIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
193
191
|
"svg",
|
|
194
192
|
{
|
|
195
|
-
style: {
|
|
196
|
-
animation: "copilotKitSpinAnimation 1s linear infinite"
|
|
197
|
-
},
|
|
198
|
-
width: "13",
|
|
199
|
-
height: "13",
|
|
200
193
|
xmlns: "http://www.w3.org/2000/svg",
|
|
201
194
|
fill: "none",
|
|
202
195
|
viewBox: "0 0 24 24",
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
"path",
|
|
217
|
-
{
|
|
218
|
-
style: { opacity: 0.75 },
|
|
219
|
-
fill: "currentColor",
|
|
220
|
-
d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
|
|
221
|
-
}
|
|
222
|
-
)
|
|
223
|
-
]
|
|
196
|
+
strokeWidth: "2",
|
|
197
|
+
stroke: "currentColor",
|
|
198
|
+
width: "16",
|
|
199
|
+
height: "16",
|
|
200
|
+
style: { minWidth: "16px", minHeight: "16px" },
|
|
201
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
202
|
+
"path",
|
|
203
|
+
{
|
|
204
|
+
strokeLinecap: "round",
|
|
205
|
+
strokeLinejoin: "round",
|
|
206
|
+
d: "M16.023 9.348h4.992v-.001M2.985 19.644v-4.992m0 0h4.992m-4.993 0l3.181 3.183a8.25 8.25 0 0013.803-3.7M4.031 9.865a8.25 8.25 0 0113.803-3.7l3.181 3.182m0-4.991v4.99"
|
|
207
|
+
}
|
|
208
|
+
)
|
|
224
209
|
}
|
|
225
210
|
);
|
|
226
|
-
var
|
|
211
|
+
var CopyIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
227
212
|
"svg",
|
|
228
213
|
{
|
|
229
|
-
style: {
|
|
230
|
-
display: "inline-block",
|
|
231
|
-
marginLeft: "0.25rem",
|
|
232
|
-
marginRight: "0.25rem"
|
|
233
|
-
},
|
|
234
|
-
height: "24",
|
|
235
|
-
width: "24",
|
|
236
|
-
viewBox: "0 0 27 27",
|
|
237
214
|
xmlns: "http://www.w3.org/2000/svg",
|
|
238
|
-
fill: "
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
215
|
+
fill: "none",
|
|
216
|
+
viewBox: "0 0 24 24",
|
|
217
|
+
strokeWidth: "2",
|
|
218
|
+
stroke: "currentColor",
|
|
219
|
+
width: "16",
|
|
220
|
+
height: "16",
|
|
221
|
+
style: { minWidth: "16px", minHeight: "16px" },
|
|
222
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
223
|
+
"path",
|
|
224
|
+
{
|
|
225
|
+
strokeLinecap: "round",
|
|
226
|
+
strokeLinejoin: "round",
|
|
227
|
+
d: "M15.75 17.25v3.375c0 .621-.504 1.125-1.125 1.125h-9.75a1.125 1.125 0 01-1.125-1.125V7.875c0-.621.504-1.125 1.125-1.125H6.75a9.06 9.06 0 011.5.124m7.5 10.376h3.375c.621 0 1.125-.504 1.125-1.125V11.25c0-4.46-3.243-8.161-7.5-8.876a9.06 9.06 0 00-1.5-.124H9.375c-.621 0-1.125.504-1.125 1.125v3.5m7.5 10.375H9.375a1.125 1.125 0 01-1.125-1.125v-9.25m12 6.625v-1.875a3.375 3.375 0 00-3.375-3.375h-1.5a1.125 1.125 0 01-1.125-1.125v-1.5a3.375 3.375 0 00-3.375-3.375H9.75"
|
|
228
|
+
}
|
|
229
|
+
)
|
|
244
230
|
}
|
|
245
231
|
);
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
style: { height: "1rem", width: "1rem" },
|
|
255
|
-
className
|
|
256
|
-
}, props), {
|
|
257
|
-
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { d: "m229.66 77.66-128 128a8 8 0 0 1-11.32 0l-56-56a8 8 0 0 1 11.32-11.32L96 188.69 218.34 66.34a8 8 0 0 1 11.32 11.32Z" })
|
|
258
|
-
})
|
|
259
|
-
);
|
|
260
|
-
}
|
|
261
|
-
function DownloadIcon(_a) {
|
|
262
|
-
var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
|
|
263
|
-
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
264
|
-
"svg",
|
|
265
|
-
__spreadProps(__spreadValues({
|
|
266
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
267
|
-
viewBox: "0 0 256 256",
|
|
268
|
-
fill: "currentColor",
|
|
269
|
-
style: { height: "1rem", width: "1rem" },
|
|
270
|
-
className
|
|
271
|
-
}, props), {
|
|
272
|
-
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { d: "M224 152v56a16 16 0 0 1-16 16H48a16 16 0 0 1-16-16v-56a8 8 0 0 1 16 0v56h160v-56a8 8 0 0 1 16 0Zm-101.66 5.66a8 8 0 0 0 11.32 0l40-40a8 8 0 0 0-11.32-11.32L136 132.69V40a8 8 0 0 0-16 0v92.69l-26.34-26.35a8 8 0 0 0-11.32 11.32Z" })
|
|
273
|
-
})
|
|
274
|
-
);
|
|
275
|
-
}
|
|
276
|
-
function CopyIcon(_a) {
|
|
277
|
-
var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
|
|
278
|
-
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
279
|
-
"svg",
|
|
280
|
-
__spreadProps(__spreadValues({
|
|
281
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
282
|
-
viewBox: "0 0 256 256",
|
|
283
|
-
fill: "currentColor",
|
|
284
|
-
style: { height: "1rem", width: "1rem" },
|
|
285
|
-
className
|
|
286
|
-
}, props), {
|
|
287
|
-
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { d: "M216 32H88a8 8 0 0 0-8 8v40H40a8 8 0 0 0-8 8v128a8 8 0 0 0 8 8h128a8 8 0 0 0 8-8v-40h40a8 8 0 0 0 8-8V40a8 8 0 0 0-8-8Zm-56 176H48V96h112Zm48-48h-32V88a8 8 0 0 0-8-8H96V48h112Z" })
|
|
288
|
-
})
|
|
289
|
-
);
|
|
290
|
-
}
|
|
291
|
-
var StopIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
232
|
+
var SmallSpinnerIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { className: "copilotKitSpinner", style: { width: "13px", height: "13px" } });
|
|
233
|
+
var SpinnerIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { className: "copilotKitSpinner", style: { width: "24px", height: "24px" } });
|
|
234
|
+
var ActivityIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { style: { display: "flex", alignItems: "center", gap: "4px" }, children: [
|
|
235
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { className: "copilotKitActivityDot", style: { animationDelay: "0s" } }),
|
|
236
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { className: "copilotKitActivityDot", style: { animationDelay: "0.2s" } }),
|
|
237
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { className: "copilotKitActivityDot", style: { animationDelay: "0.4s" } })
|
|
238
|
+
] });
|
|
239
|
+
var ThumbsUpIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
292
240
|
"svg",
|
|
293
241
|
{
|
|
294
242
|
xmlns: "http://www.w3.org/2000/svg",
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
243
|
+
fill: "none",
|
|
244
|
+
viewBox: "0 0 24 24",
|
|
245
|
+
strokeWidth: "2",
|
|
246
|
+
stroke: "currentColor",
|
|
247
|
+
width: "16",
|
|
248
|
+
height: "16",
|
|
249
|
+
style: { minWidth: "16px", minHeight: "16px" },
|
|
250
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
251
|
+
"path",
|
|
252
|
+
{
|
|
253
|
+
strokeLinecap: "round",
|
|
254
|
+
strokeLinejoin: "round",
|
|
255
|
+
d: "M6.633 10.5c.806 0 1.533-.446 2.031-1.08a9.041 9.041 0 012.861-2.4c.723-.384 1.35-.956 1.653-1.715a4.498 4.498 0 00.322-1.672V3a.75.75 0 01.75-.75A2.25 2.25 0 0116.5 4.5c0 1.152-.26 2.243-.723 3.218-.266.558.107 1.282.725 1.282h3.126c1.026 0 1.945.694 2.054 1.715.045.422.068.85.068 1.285a11.95 11.95 0 01-2.649 7.521c-.388.482-.987.729-1.605.729H13.48c-.483 0-.964-.078-1.423-.23l-3.114-1.04a4.501 4.501 0 00-1.423-.23H5.904M14.25 9h2.25M5.904 18.75c.083.205.173.405.27.602.197.4-.078.898-.523.898h-.908c-.889 0-1.713-.518-1.972-1.368a12 12 0 01-.521-3.507c0-1.553.295-3.036.831-4.398C3.387 10.203 4.167 9.75 5 9.75h1.053c.472 0 .745.556.5.96a8.958 8.958 0 00-1.302 4.665c0 1.194.232 2.333.654 3.375z"
|
|
256
|
+
}
|
|
257
|
+
)
|
|
299
258
|
}
|
|
300
259
|
);
|
|
301
|
-
var
|
|
260
|
+
var ThumbsDownIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
302
261
|
"svg",
|
|
303
262
|
{
|
|
304
263
|
xmlns: "http://www.w3.org/2000/svg",
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
264
|
+
fill: "none",
|
|
265
|
+
viewBox: "0 0 24 24",
|
|
266
|
+
strokeWidth: "2",
|
|
267
|
+
stroke: "currentColor",
|
|
268
|
+
width: "16",
|
|
269
|
+
height: "16",
|
|
270
|
+
style: { minWidth: "16px", minHeight: "16px" },
|
|
271
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
272
|
+
"path",
|
|
273
|
+
{
|
|
274
|
+
strokeLinecap: "round",
|
|
275
|
+
strokeLinejoin: "round",
|
|
276
|
+
d: "M7.5 15h2.25m8.024-9.75c.011.05.028.1.052.148.591 1.2.924 2.55.924 3.977a8.96 8.96 0 01-.999 4.125m.023-8.25c-.076-.365.183-.75.575-.75h.908c.889 0 1.713.518 1.972 1.368.339 1.11.521 2.287.521 3.507 0 1.553-.295 3.036-.831 4.398C20.613 14.547 19.833 15 19 15h-1.053c-.472 0-.745-.556-.5-.96a8.95 8.95 0 00.303-.54m.023-8.25H16.48a4.5 4.5 0 01-1.423-.23l-3.114-1.04a4.5 4.5 0 00-1.423-.23H6.504c-.618 0-1.217.247-1.605.729A11.95 11.95 0 002.25 12c0 .434.023.863.068 1.285C2.427 14.306 3.346 15 4.372 15h3.126c.618 0 .991.724.725 1.282A7.471 7.471 0 007.5 19.5a2.25 2.25 0 002.25 2.25.75.75 0 00.75-.75v-.633c0-.573.11-1.14.322-1.672.304-.76.93-1.33 1.653-1.715a9.04 9.04 0 002.86-2.4c.498-.634 1.226-1.08 2.032-1.08h.384"
|
|
277
|
+
}
|
|
278
|
+
)
|
|
309
279
|
}
|
|
310
280
|
);
|
|
311
|
-
var
|
|
281
|
+
var DownloadIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
312
282
|
"svg",
|
|
313
283
|
{
|
|
314
284
|
xmlns: "http://www.w3.org/2000/svg",
|
|
315
285
|
fill: "none",
|
|
316
286
|
viewBox: "0 0 24 24",
|
|
317
|
-
strokeWidth:
|
|
287
|
+
strokeWidth: "2",
|
|
318
288
|
stroke: "currentColor",
|
|
319
|
-
|
|
289
|
+
width: "16",
|
|
290
|
+
height: "16",
|
|
291
|
+
style: { minWidth: "16px", minHeight: "16px" },
|
|
320
292
|
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
321
293
|
"path",
|
|
322
294
|
{
|
|
323
295
|
strokeLinecap: "round",
|
|
324
296
|
strokeLinejoin: "round",
|
|
325
|
-
d: "
|
|
297
|
+
d: "M3 16.5v2.25A2.25 2.25 0 005.25 21h13.5A2.25 2.25 0 0021 18.75V16.5M16.5 12L12 16.5m0 0L7.5 12m4.5 4.5V3"
|
|
326
298
|
}
|
|
327
299
|
)
|
|
328
300
|
}
|
|
329
301
|
);
|
|
302
|
+
var CheckIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
303
|
+
"svg",
|
|
304
|
+
{
|
|
305
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
306
|
+
fill: "none",
|
|
307
|
+
viewBox: "0 0 24 24",
|
|
308
|
+
strokeWidth: "2",
|
|
309
|
+
stroke: "currentColor",
|
|
310
|
+
width: "16",
|
|
311
|
+
height: "16",
|
|
312
|
+
style: { minWidth: "16px", minHeight: "16px" },
|
|
313
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M4.5 12.75l6 6 9-13.5" })
|
|
314
|
+
}
|
|
315
|
+
);
|
|
330
316
|
|
|
331
317
|
// src/components/chat/ChatContext.tsx
|
|
332
318
|
var import_jsx_runtime2 = require("react/jsx-runtime");
|
|
@@ -357,7 +343,11 @@ var ChatContextProvider = ({
|
|
|
357
343
|
placeholder: "Type a message...",
|
|
358
344
|
error: "\u274C An error occurred. Please try again.",
|
|
359
345
|
stopGenerating: "Stop generating",
|
|
360
|
-
regenerateResponse: "Regenerate response"
|
|
346
|
+
regenerateResponse: "Regenerate response",
|
|
347
|
+
copyToClipboard: "Copy to clipboard",
|
|
348
|
+
thumbsUp: "Thumbs up",
|
|
349
|
+
thumbsDown: "Thumbs down",
|
|
350
|
+
copied: "Copied!"
|
|
361
351
|
}), labels),
|
|
362
352
|
[labels]
|
|
363
353
|
);
|
|
@@ -371,7 +361,7 @@ var ChatContextProvider = ({
|
|
|
371
361
|
spinnerIcon: SpinnerIcon,
|
|
372
362
|
stopIcon: StopIcon,
|
|
373
363
|
regenerateIcon: RegenerateIcon,
|
|
374
|
-
pushToTalkIcon:
|
|
364
|
+
pushToTalkIcon: MicrophoneIcon
|
|
375
365
|
}), icons),
|
|
376
366
|
[icons]
|
|
377
367
|
);
|
|
@@ -401,7 +391,11 @@ var Messages = ({
|
|
|
401
391
|
RenderAgentStateMessage: RenderAgentStateMessage2,
|
|
402
392
|
RenderResultMessage: RenderResultMessage2,
|
|
403
393
|
AssistantMessage: AssistantMessage2,
|
|
404
|
-
UserMessage: UserMessage2
|
|
394
|
+
UserMessage: UserMessage2,
|
|
395
|
+
onRegenerate,
|
|
396
|
+
onCopy,
|
|
397
|
+
onThumbsUp,
|
|
398
|
+
onThumbsDown
|
|
405
399
|
}) => {
|
|
406
400
|
const context = useChatContext();
|
|
407
401
|
const initialMessages = (0, import_react2.useMemo)(
|
|
@@ -424,65 +418,71 @@ var Messages = ({
|
|
|
424
418
|
const { messagesEndRef, messagesContainerRef } = useScrollToBottom(messages);
|
|
425
419
|
const interrupt = (0, import_react_core.useLangGraphInterruptRender)();
|
|
426
420
|
return /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)("div", { className: "copilotKitMessages", ref: messagesContainerRef, children: [
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
421
|
+
/* @__PURE__ */ (0, import_jsx_runtime3.jsxs)("div", { className: "copilotKitMessagesContainer", children: [
|
|
422
|
+
messages.map((message, index) => {
|
|
423
|
+
const isCurrentMessage = index === messages.length - 1;
|
|
424
|
+
if (message.isTextMessage()) {
|
|
425
|
+
return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
|
|
426
|
+
RenderTextMessage2,
|
|
427
|
+
{
|
|
428
|
+
message,
|
|
429
|
+
inProgress,
|
|
430
|
+
index,
|
|
431
|
+
isCurrentMessage,
|
|
432
|
+
AssistantMessage: AssistantMessage2,
|
|
433
|
+
UserMessage: UserMessage2,
|
|
434
|
+
onRegenerate,
|
|
435
|
+
onCopy,
|
|
436
|
+
onThumbsUp,
|
|
437
|
+
onThumbsDown
|
|
438
|
+
},
|
|
439
|
+
index
|
|
440
|
+
);
|
|
441
|
+
} else if (message.isActionExecutionMessage()) {
|
|
442
|
+
return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
|
|
443
|
+
RenderActionExecutionMessage2,
|
|
444
|
+
{
|
|
445
|
+
message,
|
|
446
|
+
inProgress,
|
|
447
|
+
index,
|
|
448
|
+
isCurrentMessage,
|
|
449
|
+
actionResult: actionResults[message.id],
|
|
450
|
+
AssistantMessage: AssistantMessage2,
|
|
451
|
+
UserMessage: UserMessage2
|
|
452
|
+
},
|
|
453
|
+
index
|
|
454
|
+
);
|
|
455
|
+
} else if (message.isAgentStateMessage()) {
|
|
456
|
+
return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
|
|
457
|
+
RenderAgentStateMessage2,
|
|
458
|
+
{
|
|
459
|
+
message,
|
|
460
|
+
inProgress,
|
|
461
|
+
index,
|
|
462
|
+
isCurrentMessage,
|
|
463
|
+
AssistantMessage: AssistantMessage2,
|
|
464
|
+
UserMessage: UserMessage2
|
|
465
|
+
},
|
|
466
|
+
index
|
|
467
|
+
);
|
|
468
|
+
} else if (message.isResultMessage()) {
|
|
469
|
+
return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
|
|
470
|
+
RenderResultMessage2,
|
|
471
|
+
{
|
|
472
|
+
message,
|
|
473
|
+
inProgress,
|
|
474
|
+
index,
|
|
475
|
+
isCurrentMessage,
|
|
476
|
+
AssistantMessage: AssistantMessage2,
|
|
477
|
+
UserMessage: UserMessage2
|
|
478
|
+
},
|
|
479
|
+
index
|
|
480
|
+
);
|
|
481
|
+
}
|
|
482
|
+
}),
|
|
483
|
+
interrupt
|
|
484
|
+
] }),
|
|
485
|
+
/* @__PURE__ */ (0, import_jsx_runtime3.jsx)("footer", { className: "copilotKitMessagesFooter", ref: messagesEndRef, children })
|
|
486
486
|
] });
|
|
487
487
|
};
|
|
488
488
|
function makeInitialMessages(initial) {
|
|
@@ -720,7 +720,7 @@ var usePushToTalk = ({
|
|
|
720
720
|
// src/components/chat/Input.tsx
|
|
721
721
|
var import_react_core3 = require("@copilotkit/react-core");
|
|
722
722
|
var import_jsx_runtime5 = require("react/jsx-runtime");
|
|
723
|
-
var Input = ({ inProgress, onSend, isVisible = false }) => {
|
|
723
|
+
var Input = ({ inProgress, onSend, isVisible = false, onStop }) => {
|
|
724
724
|
const context = useChatContext();
|
|
725
725
|
const copilotContext = (0, import_react_core3.useCopilotContext)();
|
|
726
726
|
const pushToTalkConfigured = copilotContext.copilotApiConfig.textToSpeechUrl !== void 0 && copilotContext.copilotApiConfig.transcribeAudioUrl !== void 0;
|
|
@@ -750,16 +750,17 @@ var Input = ({ inProgress, onSend, isVisible = false }) => {
|
|
|
750
750
|
sendFunction: onSend,
|
|
751
751
|
inProgress
|
|
752
752
|
});
|
|
753
|
-
const
|
|
753
|
+
const isInProgress = inProgress || pushToTalkState === "transcribing";
|
|
754
|
+
const buttonIcon = isInProgress ? context.icons.stopIcon : context.icons.sendIcon;
|
|
754
755
|
const showPushToTalk = pushToTalkConfigured && (pushToTalkState === "idle" || pushToTalkState === "recording") && !inProgress;
|
|
755
756
|
const canSend = () => {
|
|
756
757
|
var _a;
|
|
757
758
|
const interruptEvent = (_a = copilotContext.langGraphInterruptAction) == null ? void 0 : _a.event;
|
|
758
759
|
const interruptInProgress = (interruptEvent == null ? void 0 : interruptEvent.name) === "LangGraphInterruptEvent" && !(interruptEvent == null ? void 0 : interruptEvent.response);
|
|
759
|
-
return !
|
|
760
|
+
return (isInProgress || !isInProgress && text.trim().length > 0) && pushToTalkState === "idle" && !interruptInProgress;
|
|
760
761
|
};
|
|
761
762
|
const sendDisabled = !canSend();
|
|
762
|
-
return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "copilotKitInput", onClick: handleDivClick, children: [
|
|
763
|
+
return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("div", { className: "copilotKitInputContainer", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "copilotKitInput", onClick: handleDivClick, children: [
|
|
763
764
|
/* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
|
|
764
765
|
Textarea_default,
|
|
765
766
|
{
|
|
@@ -780,11 +781,12 @@ var Input = ({ inProgress, onSend, isVisible = false }) => {
|
|
|
780
781
|
}
|
|
781
782
|
),
|
|
782
783
|
/* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "copilotKitInputControls", children: [
|
|
784
|
+
/* @__PURE__ */ (0, import_jsx_runtime5.jsx)("div", { style: { flexGrow: 1 } }),
|
|
783
785
|
showPushToTalk && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
|
|
784
786
|
"button",
|
|
785
787
|
{
|
|
786
788
|
onClick: () => setPushToTalkState(pushToTalkState === "idle" ? "recording" : "transcribing"),
|
|
787
|
-
className: pushToTalkState === "recording" ? "copilotKitPushToTalkRecording" : "",
|
|
789
|
+
className: pushToTalkState === "recording" ? "copilotKitInputControlButton copilotKitPushToTalkRecording" : "copilotKitInputControlButton",
|
|
788
790
|
children: context.icons.pushToTalkIcon
|
|
789
791
|
}
|
|
790
792
|
),
|
|
@@ -792,14 +794,15 @@ var Input = ({ inProgress, onSend, isVisible = false }) => {
|
|
|
792
794
|
"button",
|
|
793
795
|
{
|
|
794
796
|
disabled: sendDisabled,
|
|
795
|
-
onClick: send,
|
|
796
|
-
"data-copilotkit-in-progress":
|
|
797
|
-
"data-
|
|
798
|
-
|
|
797
|
+
onClick: isInProgress ? onStop : send,
|
|
798
|
+
"data-copilotkit-in-progress": inProgress,
|
|
799
|
+
"data-test-id": inProgress ? "copilot-chat-request-in-progress" : "copilot-chat-ready",
|
|
800
|
+
className: "copilotKitInputControlButton",
|
|
801
|
+
children: buttonIcon
|
|
799
802
|
}
|
|
800
803
|
)
|
|
801
804
|
] })
|
|
802
|
-
] });
|
|
805
|
+
] }) });
|
|
803
806
|
};
|
|
804
807
|
|
|
805
808
|
// src/components/chat/Response.tsx
|
|
@@ -815,7 +818,18 @@ var ResponseButton = ({ onClick, inProgress }) => {
|
|
|
815
818
|
// src/components/chat/messages/RenderTextMessage.tsx
|
|
816
819
|
var import_jsx_runtime7 = require("react/jsx-runtime");
|
|
817
820
|
function RenderTextMessage(props) {
|
|
818
|
-
const {
|
|
821
|
+
const {
|
|
822
|
+
message,
|
|
823
|
+
inProgress,
|
|
824
|
+
index,
|
|
825
|
+
isCurrentMessage,
|
|
826
|
+
UserMessage: UserMessage2,
|
|
827
|
+
AssistantMessage: AssistantMessage2,
|
|
828
|
+
onRegenerate,
|
|
829
|
+
onCopy,
|
|
830
|
+
onThumbsUp,
|
|
831
|
+
onThumbsDown
|
|
832
|
+
} = props;
|
|
819
833
|
if (message.isTextMessage()) {
|
|
820
834
|
if (message.role === "user") {
|
|
821
835
|
return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
|
|
@@ -835,7 +849,12 @@ function RenderTextMessage(props) {
|
|
|
835
849
|
message: message.content,
|
|
836
850
|
rawData: message,
|
|
837
851
|
isLoading: inProgress && isCurrentMessage && !message.content,
|
|
838
|
-
isGenerating: inProgress && isCurrentMessage && !!message.content
|
|
852
|
+
isGenerating: inProgress && isCurrentMessage && !!message.content,
|
|
853
|
+
isCurrentMessage,
|
|
854
|
+
onRegenerate,
|
|
855
|
+
onCopy,
|
|
856
|
+
onThumbsUp,
|
|
857
|
+
onThumbsDown
|
|
839
858
|
},
|
|
840
859
|
index
|
|
841
860
|
);
|
|
@@ -1165,14 +1184,8 @@ var CodeBlock = (0, import_react6.memo)(({ language, value }) => {
|
|
|
1165
1184
|
/* @__PURE__ */ (0, import_jsx_runtime11.jsxs)("div", { className: "copilotKitCodeBlockToolbar", children: [
|
|
1166
1185
|
/* @__PURE__ */ (0, import_jsx_runtime11.jsx)("span", { className: "copilotKitCodeBlockToolbarLanguage", children: language }),
|
|
1167
1186
|
/* @__PURE__ */ (0, import_jsx_runtime11.jsxs)("div", { className: "copilotKitCodeBlockToolbarButtons", children: [
|
|
1168
|
-
/* @__PURE__ */ (0, import_jsx_runtime11.
|
|
1169
|
-
|
|
1170
|
-
/* @__PURE__ */ (0, import_jsx_runtime11.jsx)("span", { className: "sr-only", children: "Download" })
|
|
1171
|
-
] }),
|
|
1172
|
-
/* @__PURE__ */ (0, import_jsx_runtime11.jsxs)("button", { className: "copilotKitCodeBlockToolbarButton", onClick: onCopy, children: [
|
|
1173
|
-
isCopied ? /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(CheckIcon, {}) : /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(CopyIcon, {}),
|
|
1174
|
-
/* @__PURE__ */ (0, import_jsx_runtime11.jsx)("span", { className: "sr-only", children: "Copy code" })
|
|
1175
|
-
] })
|
|
1187
|
+
/* @__PURE__ */ (0, import_jsx_runtime11.jsx)("button", { className: "copilotKitCodeBlockToolbarButton", onClick: downloadAsFile, children: DownloadIcon }),
|
|
1188
|
+
/* @__PURE__ */ (0, import_jsx_runtime11.jsx)("button", { className: "copilotKitCodeBlockToolbarButton", onClick: onCopy, children: isCopied ? CheckIcon : CopyIcon })
|
|
1176
1189
|
] })
|
|
1177
1190
|
] }),
|
|
1178
1191
|
/* @__PURE__ */ (0, import_jsx_runtime11.jsx)(
|
|
@@ -1487,9 +1500,6 @@ var Markdown = ({ content }) => {
|
|
|
1487
1500
|
return /* @__PURE__ */ (0, import_jsx_runtime12.jsx)("div", { className: "copilotKitMarkdown", children: /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(MemoizedReactMarkdown, { components, remarkPlugins: [import_remark_gfm.default, import_remark_math.default], children: content }) });
|
|
1488
1501
|
};
|
|
1489
1502
|
var components = {
|
|
1490
|
-
p({ children }) {
|
|
1491
|
-
return /* @__PURE__ */ (0, import_jsx_runtime12.jsx)("p", { children });
|
|
1492
|
-
},
|
|
1493
1503
|
a(_a) {
|
|
1494
1504
|
var _b = _a, { children } = _b, props = __objRest(_b, ["children"]);
|
|
1495
1505
|
return /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(
|
|
@@ -1536,14 +1546,101 @@ var components = {
|
|
|
1536
1546
|
};
|
|
1537
1547
|
|
|
1538
1548
|
// src/components/chat/messages/AssistantMessage.tsx
|
|
1549
|
+
var import_react8 = require("react");
|
|
1539
1550
|
var import_jsx_runtime13 = require("react/jsx-runtime");
|
|
1540
1551
|
var AssistantMessage = (props) => {
|
|
1541
|
-
const { icons } = useChatContext();
|
|
1542
|
-
const {
|
|
1552
|
+
const { icons, labels } = useChatContext();
|
|
1553
|
+
const {
|
|
1554
|
+
message,
|
|
1555
|
+
isLoading,
|
|
1556
|
+
subComponent,
|
|
1557
|
+
onRegenerate,
|
|
1558
|
+
onCopy,
|
|
1559
|
+
onThumbsUp,
|
|
1560
|
+
onThumbsDown,
|
|
1561
|
+
isCurrentMessage
|
|
1562
|
+
} = props;
|
|
1563
|
+
const [copied, setCopied] = (0, import_react8.useState)(false);
|
|
1564
|
+
const handleCopy = () => {
|
|
1565
|
+
if (message && onCopy) {
|
|
1566
|
+
navigator.clipboard.writeText(message);
|
|
1567
|
+
setCopied(true);
|
|
1568
|
+
onCopy(message);
|
|
1569
|
+
setTimeout(() => setCopied(false), 2e3);
|
|
1570
|
+
} else if (message) {
|
|
1571
|
+
navigator.clipboard.writeText(message);
|
|
1572
|
+
setCopied(true);
|
|
1573
|
+
setTimeout(() => setCopied(false), 2e3);
|
|
1574
|
+
}
|
|
1575
|
+
};
|
|
1576
|
+
const handleRegenerate = () => {
|
|
1577
|
+
if (onRegenerate) {
|
|
1578
|
+
onRegenerate();
|
|
1579
|
+
}
|
|
1580
|
+
};
|
|
1581
|
+
const handleThumbsUp = () => {
|
|
1582
|
+
if (onThumbsUp && message) {
|
|
1583
|
+
onThumbsUp(message);
|
|
1584
|
+
}
|
|
1585
|
+
};
|
|
1586
|
+
const handleThumbsDown = () => {
|
|
1587
|
+
if (onThumbsDown && message) {
|
|
1588
|
+
onThumbsDown(message);
|
|
1589
|
+
}
|
|
1590
|
+
};
|
|
1591
|
+
const LoadingIcon = () => /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("span", { children: icons.activityIcon });
|
|
1543
1592
|
return /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)(import_jsx_runtime13.Fragment, { children: [
|
|
1544
1593
|
(message || isLoading) && /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)("div", { className: "copilotKitMessage copilotKitAssistantMessage", children: [
|
|
1545
1594
|
message && /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(Markdown, { content: message || "" }),
|
|
1546
|
-
isLoading &&
|
|
1595
|
+
isLoading && /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(LoadingIcon, {}),
|
|
1596
|
+
message && !isLoading && /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)(
|
|
1597
|
+
"div",
|
|
1598
|
+
{
|
|
1599
|
+
className: `copilotKitMessageControls ${isCurrentMessage ? "currentMessage" : ""}`,
|
|
1600
|
+
children: [
|
|
1601
|
+
/* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
|
|
1602
|
+
"button",
|
|
1603
|
+
{
|
|
1604
|
+
className: "copilotKitMessageControlButton",
|
|
1605
|
+
onClick: handleRegenerate,
|
|
1606
|
+
"aria-label": labels.regenerateResponse,
|
|
1607
|
+
title: labels.regenerateResponse,
|
|
1608
|
+
children: RegenerateIcon
|
|
1609
|
+
}
|
|
1610
|
+
),
|
|
1611
|
+
/* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
|
|
1612
|
+
"button",
|
|
1613
|
+
{
|
|
1614
|
+
className: "copilotKitMessageControlButton",
|
|
1615
|
+
onClick: handleCopy,
|
|
1616
|
+
"aria-label": labels.copyToClipboard,
|
|
1617
|
+
title: labels.copyToClipboard,
|
|
1618
|
+
children: copied ? /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("span", { style: { fontSize: "10px", fontWeight: "bold" }, children: "\u2713" }) : CopyIcon
|
|
1619
|
+
}
|
|
1620
|
+
),
|
|
1621
|
+
onThumbsUp && /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
|
|
1622
|
+
"button",
|
|
1623
|
+
{
|
|
1624
|
+
className: "copilotKitMessageControlButton",
|
|
1625
|
+
onClick: handleThumbsUp,
|
|
1626
|
+
"aria-label": labels.thumbsUp,
|
|
1627
|
+
title: labels.thumbsUp,
|
|
1628
|
+
children: ThumbsUpIcon
|
|
1629
|
+
}
|
|
1630
|
+
),
|
|
1631
|
+
onThumbsDown && /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
|
|
1632
|
+
"button",
|
|
1633
|
+
{
|
|
1634
|
+
className: "copilotKitMessageControlButton",
|
|
1635
|
+
onClick: handleThumbsDown,
|
|
1636
|
+
"aria-label": labels.thumbsDown,
|
|
1637
|
+
title: labels.thumbsDown,
|
|
1638
|
+
children: ThumbsDownIcon
|
|
1639
|
+
}
|
|
1640
|
+
)
|
|
1641
|
+
]
|
|
1642
|
+
}
|
|
1643
|
+
)
|
|
1547
1644
|
] }),
|
|
1548
1645
|
/* @__PURE__ */ (0, import_jsx_runtime13.jsx)("div", { style: { marginBottom: "0.5rem" }, children: subComponent })
|
|
1549
1646
|
] });
|
|
@@ -1561,7 +1658,7 @@ var import_shared = require("@copilotkit/shared");
|
|
|
1561
1658
|
var import_runtime_client_gql3 = require("@copilotkit/runtime-client-gql");
|
|
1562
1659
|
var import_jsx_runtime15 = require("react/jsx-runtime");
|
|
1563
1660
|
function Suggestion({ title, message, onClick, partial, className }) {
|
|
1564
|
-
return /* @__PURE__ */ (0, import_jsx_runtime15.
|
|
1661
|
+
return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(
|
|
1565
1662
|
"button",
|
|
1566
1663
|
{
|
|
1567
1664
|
disabled: partial,
|
|
@@ -1569,12 +1666,9 @@ function Suggestion({ title, message, onClick, partial, className }) {
|
|
|
1569
1666
|
e.preventDefault();
|
|
1570
1667
|
onClick(message);
|
|
1571
1668
|
},
|
|
1572
|
-
className: className || "suggestion",
|
|
1669
|
+
className: className || (partial ? "suggestion loading" : "suggestion"),
|
|
1573
1670
|
"data-test-id": "suggestion",
|
|
1574
|
-
children:
|
|
1575
|
-
partial && SmallSpinnerIcon,
|
|
1576
|
-
/* @__PURE__ */ (0, import_jsx_runtime15.jsx)("span", { children: title })
|
|
1577
|
-
]
|
|
1671
|
+
children: partial ? SmallSpinnerIcon : /* @__PURE__ */ (0, import_jsx_runtime15.jsx)("span", { children: title })
|
|
1578
1672
|
}
|
|
1579
1673
|
);
|
|
1580
1674
|
}
|
|
@@ -1649,646 +1743,12 @@ var reloadSuggestions = (context, chatSuggestionConfiguration, setCurrentSuggest
|
|
|
1649
1743
|
});
|
|
1650
1744
|
|
|
1651
1745
|
// src/components/chat/Chat.tsx
|
|
1652
|
-
var
|
|
1653
|
-
var import_react_core9 = require("@copilotkit/react-core");
|
|
1654
|
-
var import_runtime_client_gql4 = require("@copilotkit/runtime-client-gql");
|
|
1655
|
-
var import_shared3 = require("@copilotkit/shared");
|
|
1656
|
-
|
|
1657
|
-
// src/components/dev-console/utils.ts
|
|
1746
|
+
var import_react9 = __toESM(require("react"));
|
|
1658
1747
|
var import_react_core7 = require("@copilotkit/react-core");
|
|
1659
|
-
|
|
1660
|
-
|
|
1661
|
-
return showDevConsole;
|
|
1662
|
-
}
|
|
1663
|
-
return getHostname() === "localhost" || getHostname() === "127.0.0.1" || getHostname() === "0.0.0.0" || getHostname() === "::1";
|
|
1664
|
-
}
|
|
1665
|
-
function getHostname() {
|
|
1666
|
-
if (typeof window !== "undefined" && window.location) {
|
|
1667
|
-
return window.location.hostname;
|
|
1668
|
-
}
|
|
1669
|
-
return "";
|
|
1670
|
-
}
|
|
1671
|
-
function getPublishedCopilotKitVersion(current, forceCheck = false) {
|
|
1672
|
-
return __async(this, null, function* () {
|
|
1673
|
-
const LOCAL_STORAGE_KEY = "__copilotkit_version_check__";
|
|
1674
|
-
const serializedVersion = localStorage.getItem(LOCAL_STORAGE_KEY);
|
|
1675
|
-
if (serializedVersion && !forceCheck) {
|
|
1676
|
-
try {
|
|
1677
|
-
const parsedVersion = JSON.parse(serializedVersion);
|
|
1678
|
-
const oneHour = 60 * 60 * 1e3;
|
|
1679
|
-
const now = (/* @__PURE__ */ new Date()).getTime();
|
|
1680
|
-
if (parsedVersion.current === current && now - new Date(parsedVersion.lastChecked).getTime() < oneHour) {
|
|
1681
|
-
return parsedVersion;
|
|
1682
|
-
}
|
|
1683
|
-
} catch (error) {
|
|
1684
|
-
console.error("Failed to parse CopilotKitVersion from localStorage", error);
|
|
1685
|
-
}
|
|
1686
|
-
}
|
|
1687
|
-
try {
|
|
1688
|
-
const response = yield fetch("https://api.cloud.copilotkit.ai/check-for-updates", {
|
|
1689
|
-
method: "POST",
|
|
1690
|
-
headers: {
|
|
1691
|
-
"Content-Type": "application/json"
|
|
1692
|
-
},
|
|
1693
|
-
body: JSON.stringify({
|
|
1694
|
-
packages: [
|
|
1695
|
-
{
|
|
1696
|
-
packageName: "@copilotkit/shared",
|
|
1697
|
-
packageVersion: current
|
|
1698
|
-
}
|
|
1699
|
-
]
|
|
1700
|
-
})
|
|
1701
|
-
});
|
|
1702
|
-
const data = yield response.json();
|
|
1703
|
-
const version = {
|
|
1704
|
-
current,
|
|
1705
|
-
lastChecked: (/* @__PURE__ */ new Date()).getTime(),
|
|
1706
|
-
latest: data.packages[0].latestVersion,
|
|
1707
|
-
severity: data.packages[0].severity,
|
|
1708
|
-
advisory: data.packages[0].advisory || null
|
|
1709
|
-
};
|
|
1710
|
-
localStorage.setItem(LOCAL_STORAGE_KEY, JSON.stringify(version));
|
|
1711
|
-
return version;
|
|
1712
|
-
} catch (error) {
|
|
1713
|
-
console.error("Failed to check for updates", error);
|
|
1714
|
-
throw error;
|
|
1715
|
-
}
|
|
1716
|
-
});
|
|
1717
|
-
}
|
|
1718
|
-
function logReadables(context) {
|
|
1719
|
-
console.log("%cCurrent Readables:", "font-size: 16px; font-weight: bold;");
|
|
1720
|
-
const readables = context.getContextString([], import_react_core7.defaultCopilotContextCategories).trim();
|
|
1721
|
-
if (readables.length === 0) {
|
|
1722
|
-
console.log("No readables found");
|
|
1723
|
-
return;
|
|
1724
|
-
}
|
|
1725
|
-
console.log(readables);
|
|
1726
|
-
}
|
|
1727
|
-
function logActions(context) {
|
|
1728
|
-
console.log("%cCurrent Actions:", "font-size: 16px; font-weight: bold;");
|
|
1729
|
-
if (Object.values(context.actions).length === 0) {
|
|
1730
|
-
console.log("No actions found");
|
|
1731
|
-
return;
|
|
1732
|
-
}
|
|
1733
|
-
for (const action of Object.values(context.actions)) {
|
|
1734
|
-
console.group(action.name);
|
|
1735
|
-
console.log("name", action.name);
|
|
1736
|
-
console.log("description", action.description);
|
|
1737
|
-
console.log("parameters", action.parameters);
|
|
1738
|
-
console.groupEnd();
|
|
1739
|
-
}
|
|
1740
|
-
}
|
|
1741
|
-
function logMessages(context) {
|
|
1742
|
-
console.log("%cCurrent Messages:", "font-size: 16px; font-weight: bold;");
|
|
1743
|
-
if (context.messages.length === 0) {
|
|
1744
|
-
console.log("No messages found");
|
|
1745
|
-
return;
|
|
1746
|
-
}
|
|
1747
|
-
const tableData = context.messages.map((message) => {
|
|
1748
|
-
if (message.isTextMessage()) {
|
|
1749
|
-
return {
|
|
1750
|
-
id: message.id,
|
|
1751
|
-
type: "TextMessage",
|
|
1752
|
-
role: message.role,
|
|
1753
|
-
name: void 0,
|
|
1754
|
-
scope: void 0,
|
|
1755
|
-
content: message.content
|
|
1756
|
-
};
|
|
1757
|
-
} else if (message.isActionExecutionMessage()) {
|
|
1758
|
-
return {
|
|
1759
|
-
id: message.id,
|
|
1760
|
-
type: "ActionExecutionMessage",
|
|
1761
|
-
role: void 0,
|
|
1762
|
-
name: message.name,
|
|
1763
|
-
scope: message.parentMessageId,
|
|
1764
|
-
content: message.arguments
|
|
1765
|
-
};
|
|
1766
|
-
} else if (message.isResultMessage()) {
|
|
1767
|
-
return {
|
|
1768
|
-
id: message.id,
|
|
1769
|
-
type: "ResultMessage",
|
|
1770
|
-
role: void 0,
|
|
1771
|
-
name: message.actionName,
|
|
1772
|
-
scope: message.actionExecutionId,
|
|
1773
|
-
content: message.result
|
|
1774
|
-
};
|
|
1775
|
-
} else if (message.isAgentStateMessage()) {
|
|
1776
|
-
return {
|
|
1777
|
-
id: message.id,
|
|
1778
|
-
type: `AgentStateMessage (running: ${message.running})`,
|
|
1779
|
-
role: message.role,
|
|
1780
|
-
name: void 0,
|
|
1781
|
-
scope: message.threadId,
|
|
1782
|
-
content: message.state
|
|
1783
|
-
};
|
|
1784
|
-
}
|
|
1785
|
-
});
|
|
1786
|
-
console.table(tableData);
|
|
1787
|
-
}
|
|
1788
|
-
|
|
1789
|
-
// src/components/dev-console/console.tsx
|
|
1748
|
+
var import_runtime_client_gql4 = require("@copilotkit/runtime-client-gql");
|
|
1749
|
+
var import_shared2 = require("@copilotkit/shared");
|
|
1790
1750
|
var import_react_core8 = require("@copilotkit/react-core");
|
|
1791
|
-
var import_react9 = require("react");
|
|
1792
|
-
|
|
1793
|
-
// src/components/dev-console/icons.tsx
|
|
1794
1751
|
var import_jsx_runtime16 = require("react/jsx-runtime");
|
|
1795
|
-
var ExclamationMarkTriangleIcon = /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
1796
|
-
"svg",
|
|
1797
|
-
{
|
|
1798
|
-
width: "13.3967723px",
|
|
1799
|
-
height: "12px",
|
|
1800
|
-
viewBox: "0 0 13.3967723 12",
|
|
1801
|
-
version: "1.1",
|
|
1802
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
1803
|
-
children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("g", { id: "exclamation-triangle", fill: "#CD2121", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
1804
|
-
"path",
|
|
1805
|
-
{
|
|
1806
|
-
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",
|
|
1807
|
-
id: "Shape"
|
|
1808
|
-
}
|
|
1809
|
-
) }) })
|
|
1810
|
-
}
|
|
1811
|
-
);
|
|
1812
|
-
var ExclamationMarkIcon = /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
1813
|
-
"svg",
|
|
1814
|
-
{
|
|
1815
|
-
width: "14px",
|
|
1816
|
-
height: "14px",
|
|
1817
|
-
viewBox: "0 0 14 14",
|
|
1818
|
-
version: "1.1",
|
|
1819
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
1820
|
-
children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("g", { id: "exclamation-circle", fill: "#EC662C", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
1821
|
-
"path",
|
|
1822
|
-
{
|
|
1823
|
-
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",
|
|
1824
|
-
id: "Shape"
|
|
1825
|
-
}
|
|
1826
|
-
) }) })
|
|
1827
|
-
}
|
|
1828
|
-
);
|
|
1829
|
-
var ChevronDownIcon = /* @__PURE__ */ (0, import_jsx_runtime16.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_runtime16.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("g", { id: "Group", fill: "#000000", fillRule: "nonzero", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
1830
|
-
"path",
|
|
1831
|
-
{
|
|
1832
|
-
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",
|
|
1833
|
-
id: "Path"
|
|
1834
|
-
}
|
|
1835
|
-
) }) }) });
|
|
1836
|
-
var CheckIcon2 = /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
1837
|
-
"svg",
|
|
1838
|
-
{
|
|
1839
|
-
width: "14px",
|
|
1840
|
-
height: "14px",
|
|
1841
|
-
viewBox: "0 0 14 14",
|
|
1842
|
-
version: "1.1",
|
|
1843
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
1844
|
-
children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("g", { id: "Group-2", transform: "translate(-118, 0)", fill: "#1BC030", fillRule: "nonzero", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("g", { id: "Group", transform: "translate(118, 0)", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
1845
|
-
"path",
|
|
1846
|
-
{
|
|
1847
|
-
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",
|
|
1848
|
-
id: "Shape"
|
|
1849
|
-
}
|
|
1850
|
-
) }) }) })
|
|
1851
|
-
}
|
|
1852
|
-
);
|
|
1853
|
-
var CopilotKitIcon = /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)(
|
|
1854
|
-
"svg",
|
|
1855
|
-
{
|
|
1856
|
-
width: "33px",
|
|
1857
|
-
height: "35px",
|
|
1858
|
-
viewBox: "0 0 33 35",
|
|
1859
|
-
version: "1.1",
|
|
1860
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
1861
|
-
children: [
|
|
1862
|
-
/* @__PURE__ */ (0, import_jsx_runtime16.jsx)("title", { children: "bd5c9079-929b-4d55-bdc9-16d1c8181b71" }),
|
|
1863
|
-
/* @__PURE__ */ (0, import_jsx_runtime16.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
1864
|
-
"image",
|
|
1865
|
-
{
|
|
1866
|
-
x: "0",
|
|
1867
|
-
y: "0",
|
|
1868
|
-
width: "33",
|
|
1869
|
-
height: "35",
|
|
1870
|
-
xlinkHref: ""
|
|
1871
|
-
}
|
|
1872
|
-
) })
|
|
1873
|
-
]
|
|
1874
|
-
}
|
|
1875
|
-
);
|
|
1876
|
-
|
|
1877
|
-
// src/components/dev-console/console.tsx
|
|
1878
|
-
var import_react10 = require("@headlessui/react");
|
|
1879
|
-
var import_shared2 = require("@copilotkit/shared");
|
|
1880
|
-
|
|
1881
|
-
// src/components/help-modal/modal.tsx
|
|
1882
|
-
var import_react8 = require("react");
|
|
1883
|
-
|
|
1884
|
-
// src/components/help-modal/icons.tsx
|
|
1885
|
-
var import_jsx_runtime17 = require("react/jsx-runtime");
|
|
1886
|
-
var CloseIcon2 = () => /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
|
|
1887
|
-
"svg",
|
|
1888
|
-
{
|
|
1889
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
1890
|
-
fill: "none",
|
|
1891
|
-
viewBox: "0 0 24 24",
|
|
1892
|
-
strokeWidth: "1.5",
|
|
1893
|
-
stroke: "currentColor",
|
|
1894
|
-
width: "20",
|
|
1895
|
-
height: "20",
|
|
1896
|
-
children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M6 18L18 6M6 6l12 12" })
|
|
1897
|
-
}
|
|
1898
|
-
);
|
|
1899
|
-
var LoadingSpinnerIcon = ({ color = "rgb(107 114 128)" }) => /* @__PURE__ */ (0, import_jsx_runtime17.jsxs)(
|
|
1900
|
-
"svg",
|
|
1901
|
-
{
|
|
1902
|
-
style: {
|
|
1903
|
-
animation: "copilotKitSpinAnimation 1s linear infinite",
|
|
1904
|
-
color
|
|
1905
|
-
},
|
|
1906
|
-
width: "24",
|
|
1907
|
-
height: "24",
|
|
1908
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
1909
|
-
fill: "none",
|
|
1910
|
-
viewBox: "0 0 24 24",
|
|
1911
|
-
children: [
|
|
1912
|
-
/* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
|
|
1913
|
-
"circle",
|
|
1914
|
-
{
|
|
1915
|
-
style: { opacity: 0.25 },
|
|
1916
|
-
cx: "12",
|
|
1917
|
-
cy: "12",
|
|
1918
|
-
r: "10",
|
|
1919
|
-
stroke: "currentColor",
|
|
1920
|
-
strokeWidth: "4"
|
|
1921
|
-
}
|
|
1922
|
-
),
|
|
1923
|
-
/* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
|
|
1924
|
-
"path",
|
|
1925
|
-
{
|
|
1926
|
-
style: { opacity: 0.75 },
|
|
1927
|
-
fill: "currentColor",
|
|
1928
|
-
d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
|
|
1929
|
-
}
|
|
1930
|
-
)
|
|
1931
|
-
]
|
|
1932
|
-
}
|
|
1933
|
-
);
|
|
1934
|
-
|
|
1935
|
-
// src/components/help-modal/modal.tsx
|
|
1936
|
-
var import_jsx_runtime18 = require("react/jsx-runtime");
|
|
1937
|
-
function CopilotKitHelpModal() {
|
|
1938
|
-
const [showHelpModal, setShowHelpModal] = (0, import_react8.useState)(false);
|
|
1939
|
-
const [issueDescription, setIssueDescription] = (0, import_react8.useState)("");
|
|
1940
|
-
const [email, setEmail] = (0, import_react8.useState)("");
|
|
1941
|
-
const [emailError, setEmailError] = (0, import_react8.useState)("");
|
|
1942
|
-
const [submitting, setSubmitting] = (0, import_react8.useState)(false);
|
|
1943
|
-
const validateEmail = (email2) => {
|
|
1944
|
-
const re = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/;
|
|
1945
|
-
return re.test(email2);
|
|
1946
|
-
};
|
|
1947
|
-
const handleSubmit = (e) => __async(this, null, function* () {
|
|
1948
|
-
e.preventDefault();
|
|
1949
|
-
if ((email == null ? void 0 : email.length) > 0 && !validateEmail(email)) {
|
|
1950
|
-
setEmailError("Please enter a valid email address");
|
|
1951
|
-
return;
|
|
1952
|
-
}
|
|
1953
|
-
setSubmitting(true);
|
|
1954
|
-
yield fetch("https://api.segment.io/v1/track", {
|
|
1955
|
-
method: "POST",
|
|
1956
|
-
headers: {
|
|
1957
|
-
"Content-Type": "application/json"
|
|
1958
|
-
},
|
|
1959
|
-
body: JSON.stringify({
|
|
1960
|
-
event: "oss.dev-console.help",
|
|
1961
|
-
anonymousId: window.crypto.randomUUID(),
|
|
1962
|
-
properties: { email, text: issueDescription },
|
|
1963
|
-
writeKey: "q0gQqvGYyw9pNyhIocNzefSYKGO1aiwW"
|
|
1964
|
-
})
|
|
1965
|
-
});
|
|
1966
|
-
setEmailError("");
|
|
1967
|
-
setEmail("");
|
|
1968
|
-
setIssueDescription("");
|
|
1969
|
-
setSubmitting(false);
|
|
1970
|
-
setShowHelpModal(false);
|
|
1971
|
-
});
|
|
1972
|
-
const HelpButton = () => /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
|
|
1973
|
-
"button",
|
|
1974
|
-
{
|
|
1975
|
-
onClick: () => setShowHelpModal(true),
|
|
1976
|
-
style: { width: "50px", height: "30px", marginRight: "0.25rem" },
|
|
1977
|
-
className: "text-sm p-0 bg-transparent rounded border border-blue-500",
|
|
1978
|
-
"aria-label": "Open Help",
|
|
1979
|
-
children: "Help"
|
|
1980
|
-
}
|
|
1981
|
-
);
|
|
1982
|
-
const submitButtonDisabled = (0, import_react8.useMemo)(
|
|
1983
|
-
() => submitting || !!emailError || issueDescription == null || (issueDescription == null ? void 0 : issueDescription.length) == 0,
|
|
1984
|
-
[submitting, emailError, issueDescription]
|
|
1985
|
-
);
|
|
1986
|
-
return /* @__PURE__ */ (0, import_jsx_runtime18.jsxs)(import_jsx_runtime18.Fragment, { children: [
|
|
1987
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsx)(HelpButton, {}),
|
|
1988
|
-
showHelpModal && /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
|
|
1989
|
-
"div",
|
|
1990
|
-
{
|
|
1991
|
-
className: "fixed inset-0 flex items-center justify-center p-4",
|
|
1992
|
-
style: { backgroundColor: "rgba(11, 15, 26, 0.5)", zIndex: 99 },
|
|
1993
|
-
children: /* @__PURE__ */ (0, import_jsx_runtime18.jsxs)("div", { className: "bg-white rounded-lg shadow-xl max-w-md w-full p-4 flex-col relative", children: [
|
|
1994
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
|
|
1995
|
-
"button",
|
|
1996
|
-
{
|
|
1997
|
-
className: "absolute text-gray-400 hover:text-gray-600 focus:outline-none",
|
|
1998
|
-
style: { top: "10px", right: "10px" },
|
|
1999
|
-
onClick: () => setShowHelpModal(false),
|
|
2000
|
-
"aria-label": "Close",
|
|
2001
|
-
children: /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(CloseIcon2, {})
|
|
2002
|
-
}
|
|
2003
|
-
),
|
|
2004
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsx)("div", { className: "w-full flex mb-6 justify-center", children: /* @__PURE__ */ (0, import_jsx_runtime18.jsx)("h2", { className: "text-2xl font-bold", children: "Help Options" }) }),
|
|
2005
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsxs)("div", { className: "space-y-4 mb-4", children: [
|
|
2006
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsx)("div", { className: "block w-full text-center py-2 px-4 bg-blue-500 text-white rounded hover:bg-blue-600 transition duration-150 text-sm", children: /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
|
|
2007
|
-
"a",
|
|
2008
|
-
{
|
|
2009
|
-
href: "https://docs.copilotkit.ai/coagents/troubleshooting/common-issues",
|
|
2010
|
-
target: "_blank",
|
|
2011
|
-
rel: "noopener noreferrer",
|
|
2012
|
-
children: "Visit the Troubleshooting and FAQ section in the docs"
|
|
2013
|
-
}
|
|
2014
|
-
) }),
|
|
2015
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsx)("div", { className: "block w-full text-center py-2 px-4 bg-blue-500 text-white rounded hover:bg-blue-600 transition duration-150 text-sm", children: /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
|
|
2016
|
-
"a",
|
|
2017
|
-
{
|
|
2018
|
-
href: "https://go.copilotkit.ai/dev-console-support-discord",
|
|
2019
|
-
target: "_blank",
|
|
2020
|
-
rel: "noopener noreferrer",
|
|
2021
|
-
children: "Go to Discord Support Channel (Community Support)"
|
|
2022
|
-
}
|
|
2023
|
-
) }),
|
|
2024
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsx)("div", { className: "block w-full text-center py-2 px-4 bg-blue-500 text-white rounded hover:bg-blue-600 transition duration-150 text-sm", children: /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
|
|
2025
|
-
"a",
|
|
2026
|
-
{
|
|
2027
|
-
href: "https://go.copilotkit.ai/dev-console-support-slack",
|
|
2028
|
-
target: "_blank",
|
|
2029
|
-
rel: "noopener noreferrer",
|
|
2030
|
-
children: "Apply for Priority Direct Slack Support"
|
|
2031
|
-
}
|
|
2032
|
-
) })
|
|
2033
|
-
] }),
|
|
2034
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsxs)("form", { onSubmit: handleSubmit, className: "flex flex-col space-y-2", children: [
|
|
2035
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsxs)("div", { children: [
|
|
2036
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsx)("label", { htmlFor: "feedback", className: "block text-sm font-medium text-gray-700 mb-1", children: "Let us know what your issue is:" }),
|
|
2037
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
|
|
2038
|
-
"textarea",
|
|
2039
|
-
{
|
|
2040
|
-
id: "feedback",
|
|
2041
|
-
rows: 4,
|
|
2042
|
-
className: "w-full px-3 py-2 text-gray-700 border rounded-lg focus:outline-none focus:border-blue-500",
|
|
2043
|
-
placeholder: "A Loom link / screen recording is always great!",
|
|
2044
|
-
onChange: (e) => setIssueDescription(e.target.value),
|
|
2045
|
-
value: issueDescription,
|
|
2046
|
-
required: true
|
|
2047
|
-
}
|
|
2048
|
-
)
|
|
2049
|
-
] }),
|
|
2050
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsxs)("div", { children: [
|
|
2051
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsx)("label", { htmlFor: "email", className: "block text-sm font-medium text-gray-700 mb-1", children: "Email (optional):" }),
|
|
2052
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
|
|
2053
|
-
"input",
|
|
2054
|
-
{
|
|
2055
|
-
type: "email",
|
|
2056
|
-
id: "email",
|
|
2057
|
-
className: `w-full px-3 py-2 text-gray-700 border rounded-lg focus:outline-none focus:border-blue-500 ${emailError ? "border-red-500" : ""}`,
|
|
2058
|
-
placeholder: "Enter your email for follow-up",
|
|
2059
|
-
onChange: (e) => {
|
|
2060
|
-
setEmail(e.target.value);
|
|
2061
|
-
setEmailError("");
|
|
2062
|
-
},
|
|
2063
|
-
value: email
|
|
2064
|
-
}
|
|
2065
|
-
),
|
|
2066
|
-
emailError && /* @__PURE__ */ (0, import_jsx_runtime18.jsx)("p", { className: "text-red-500 text-sm mt-1", children: emailError })
|
|
2067
|
-
] }),
|
|
2068
|
-
/* @__PURE__ */ (0, import_jsx_runtime18.jsx)("div", { className: "bg-gray-50 px-4 py-4 sm:px-6 sm:flex sm:flex-row-reverse rounded-b-lg", children: /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
|
|
2069
|
-
"button",
|
|
2070
|
-
{
|
|
2071
|
-
type: "submit",
|
|
2072
|
-
onClick: handleSubmit,
|
|
2073
|
-
disabled: submitButtonDisabled,
|
|
2074
|
-
style: submitButtonDisabled ? { backgroundColor: "rgb(216, 216, 216)", color: "rgb(129, 129, 129)" } : void 0,
|
|
2075
|
-
className: "w-full inline-flex justify-center rounded-md border border-transparent shadow-sm px-4 py-2 bg-blue-500 text-base font-medium text-white hover:bg-blue-600 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500 sm:ml-3 sm:w-auto sm:text-sm disabled:shadow-none",
|
|
2076
|
-
children: submitting ? /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(LoadingSpinnerIcon, { color: "white" }) : "Submit"
|
|
2077
|
-
}
|
|
2078
|
-
) })
|
|
2079
|
-
] })
|
|
2080
|
-
] })
|
|
2081
|
-
}
|
|
2082
|
-
)
|
|
2083
|
-
] });
|
|
2084
|
-
}
|
|
2085
|
-
|
|
2086
|
-
// src/components/dev-console/console.tsx
|
|
2087
|
-
var import_jsx_runtime19 = require("react/jsx-runtime");
|
|
2088
|
-
function CopilotDevConsole() {
|
|
2089
|
-
const currentVersion = import_shared2.COPILOTKIT_VERSION;
|
|
2090
|
-
const context = (0, import_react_core8.useCopilotContext)();
|
|
2091
|
-
const [showDevConsole, setShowDevConsole] = (0, import_react9.useState)(false);
|
|
2092
|
-
(0, import_react9.useEffect)(() => {
|
|
2093
|
-
setShowDevConsole(shouldShowDevConsole(context.showDevConsole));
|
|
2094
|
-
}, [context.showDevConsole]);
|
|
2095
|
-
const dontRunTwiceInDevMode = (0, import_react9.useRef)(false);
|
|
2096
|
-
const [versionStatus, setVersionStatus] = (0, import_react9.useState)("unknown");
|
|
2097
|
-
const [latestVersion, setLatestVersion] = (0, import_react9.useState)("");
|
|
2098
|
-
const consoleRef = (0, import_react9.useRef)(null);
|
|
2099
|
-
const [debugButtonMode, setDebugButtonMode] = (0, import_react9.useState)("full");
|
|
2100
|
-
const checkForUpdates = (force = false) => {
|
|
2101
|
-
setVersionStatus("checking");
|
|
2102
|
-
getPublishedCopilotKitVersion(currentVersion, force).then((v) => {
|
|
2103
|
-
setLatestVersion(v.latest);
|
|
2104
|
-
let versionOk = false;
|
|
2105
|
-
if (v.current === v.latest) {
|
|
2106
|
-
versionOk = true;
|
|
2107
|
-
} else if (/[a-zA-Z]/.test(v.current)) {
|
|
2108
|
-
versionOk = true;
|
|
2109
|
-
}
|
|
2110
|
-
if (versionOk) {
|
|
2111
|
-
setVersionStatus("latest");
|
|
2112
|
-
} else if (v.severity !== "low") {
|
|
2113
|
-
setVersionStatus("outdated");
|
|
2114
|
-
} else {
|
|
2115
|
-
setVersionStatus("update-available");
|
|
2116
|
-
}
|
|
2117
|
-
}).catch((e) => {
|
|
2118
|
-
console.error(e);
|
|
2119
|
-
setVersionStatus("unknown");
|
|
2120
|
-
});
|
|
2121
|
-
};
|
|
2122
|
-
(0, import_react9.useEffect)(() => {
|
|
2123
|
-
if (dontRunTwiceInDevMode.current === true) {
|
|
2124
|
-
return;
|
|
2125
|
-
}
|
|
2126
|
-
dontRunTwiceInDevMode.current = true;
|
|
2127
|
-
checkForUpdates();
|
|
2128
|
-
}, []);
|
|
2129
|
-
(0, import_react9.useEffect)(() => {
|
|
2130
|
-
const handleResize = (entries) => {
|
|
2131
|
-
for (let entry of entries) {
|
|
2132
|
-
if (entry.target === consoleRef.current) {
|
|
2133
|
-
const width = entry.contentRect.width;
|
|
2134
|
-
if (width < 400) {
|
|
2135
|
-
setDebugButtonMode("compact");
|
|
2136
|
-
} else {
|
|
2137
|
-
setDebugButtonMode("full");
|
|
2138
|
-
}
|
|
2139
|
-
}
|
|
2140
|
-
}
|
|
2141
|
-
};
|
|
2142
|
-
const observer = new ResizeObserver(handleResize);
|
|
2143
|
-
if (consoleRef.current) {
|
|
2144
|
-
observer.observe(consoleRef.current);
|
|
2145
|
-
const initialWidth = consoleRef.current.getBoundingClientRect().width;
|
|
2146
|
-
if (initialWidth < 400) {
|
|
2147
|
-
setDebugButtonMode("compact");
|
|
2148
|
-
} else {
|
|
2149
|
-
setDebugButtonMode("full");
|
|
2150
|
-
}
|
|
2151
|
-
}
|
|
2152
|
-
return () => {
|
|
2153
|
-
if (consoleRef.current) {
|
|
2154
|
-
observer.unobserve(consoleRef.current);
|
|
2155
|
-
}
|
|
2156
|
-
};
|
|
2157
|
-
}, [consoleRef.current]);
|
|
2158
|
-
if (!showDevConsole) {
|
|
2159
|
-
return null;
|
|
2160
|
-
}
|
|
2161
|
-
return /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)(
|
|
2162
|
-
"div",
|
|
2163
|
-
{
|
|
2164
|
-
ref: consoleRef,
|
|
2165
|
-
className: "copilotKitDevConsole " + (versionStatus === "update-available" ? "copilotKitDevConsoleUpgrade" : "") + (versionStatus === "outdated" ? "copilotKitDevConsoleWarnOutdated" : ""),
|
|
2166
|
-
children: [
|
|
2167
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsx)("div", { className: "copilotKitDevConsoleLogo", children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("a", { href: "https://copilotkit.ai", target: "_blank", children: CopilotKitIcon }) }),
|
|
2168
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
|
|
2169
|
-
VersionInfo,
|
|
2170
|
-
{
|
|
2171
|
-
showDevConsole: context.showDevConsole,
|
|
2172
|
-
versionStatus,
|
|
2173
|
-
currentVersion,
|
|
2174
|
-
latestVersion
|
|
2175
|
-
}
|
|
2176
|
-
),
|
|
2177
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsx)(CopilotKitHelpModal, {}),
|
|
2178
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
|
|
2179
|
-
DebugMenuButton,
|
|
2180
|
-
{
|
|
2181
|
-
setShowDevConsole,
|
|
2182
|
-
checkForUpdates,
|
|
2183
|
-
mode: debugButtonMode
|
|
2184
|
-
}
|
|
2185
|
-
)
|
|
2186
|
-
]
|
|
2187
|
-
}
|
|
2188
|
-
);
|
|
2189
|
-
}
|
|
2190
|
-
function VersionInfo({
|
|
2191
|
-
showDevConsole,
|
|
2192
|
-
versionStatus,
|
|
2193
|
-
currentVersion,
|
|
2194
|
-
latestVersion
|
|
2195
|
-
}) {
|
|
2196
|
-
const [copyStatus, setCopyStatus] = (0, import_react9.useState)("");
|
|
2197
|
-
let versionLabel = "";
|
|
2198
|
-
let versionIcon = "";
|
|
2199
|
-
let currentVersionLabel = currentVersion;
|
|
2200
|
-
if (versionStatus === "latest") {
|
|
2201
|
-
versionLabel = "latest";
|
|
2202
|
-
versionIcon = CheckIcon2;
|
|
2203
|
-
} else if (versionStatus === "checking") {
|
|
2204
|
-
versionLabel = "checking";
|
|
2205
|
-
versionIcon = SmallSpinnerIcon;
|
|
2206
|
-
} else if (versionStatus === "update-available") {
|
|
2207
|
-
versionLabel = "update available";
|
|
2208
|
-
versionIcon = ExclamationMarkIcon;
|
|
2209
|
-
currentVersionLabel = `${currentVersion} \u2192 ${latestVersion}`;
|
|
2210
|
-
} else if (versionStatus === "outdated") {
|
|
2211
|
-
versionLabel = "outdated";
|
|
2212
|
-
versionIcon = ExclamationMarkTriangleIcon;
|
|
2213
|
-
currentVersionLabel = `${currentVersion} \u2192 ${latestVersion}`;
|
|
2214
|
-
}
|
|
2215
|
-
let asideLabel = "";
|
|
2216
|
-
if (showDevConsole === "auto") {
|
|
2217
|
-
asideLabel = "(localhost only)";
|
|
2218
|
-
} else if (showDevConsole === true) {
|
|
2219
|
-
asideLabel = "(always on)";
|
|
2220
|
-
}
|
|
2221
|
-
const installCommand = [
|
|
2222
|
-
`npm install`,
|
|
2223
|
-
`@copilotkit/react-core@${latestVersion}`,
|
|
2224
|
-
`@copilotkit/react-ui@${latestVersion}`,
|
|
2225
|
-
`@copilotkit/react-textarea@${latestVersion}`,
|
|
2226
|
-
`&& npm install @copilotkit/runtime@${latestVersion}`
|
|
2227
|
-
].join(" ");
|
|
2228
|
-
const handleCopyClick = () => {
|
|
2229
|
-
navigator.clipboard.writeText(installCommand.trim()).then(() => {
|
|
2230
|
-
setCopyStatus("Command copied to clipboard!");
|
|
2231
|
-
setTimeout(() => setCopyStatus(""), 1e3);
|
|
2232
|
-
});
|
|
2233
|
-
};
|
|
2234
|
-
return /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)("div", { className: "copilotKitVersionInfo", children: [
|
|
2235
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsxs)("header", { children: [
|
|
2236
|
-
"COPILOTKIT DEV CONSOLE",
|
|
2237
|
-
showDevConsole === "auto" && /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("aside", { children: asideLabel })
|
|
2238
|
-
] }),
|
|
2239
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsxs)("section", { children: [
|
|
2240
|
-
"Version: ",
|
|
2241
|
-
versionLabel,
|
|
2242
|
-
" (",
|
|
2243
|
-
currentVersionLabel,
|
|
2244
|
-
") ",
|
|
2245
|
-
versionIcon
|
|
2246
|
-
] }),
|
|
2247
|
-
(versionStatus === "update-available" || versionStatus === "outdated") && /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("footer", { children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("button", { onClick: handleCopyClick, children: copyStatus || installCommand }) })
|
|
2248
|
-
] });
|
|
2249
|
-
}
|
|
2250
|
-
function DebugMenuButton({
|
|
2251
|
-
setShowDevConsole,
|
|
2252
|
-
checkForUpdates,
|
|
2253
|
-
mode
|
|
2254
|
-
}) {
|
|
2255
|
-
const context = (0, import_react_core8.useCopilotContext)();
|
|
2256
|
-
const messagesContext = (0, import_react_core8.useCopilotMessagesContext)();
|
|
2257
|
-
return /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("div", { className: "bg-black top-24 w-52 text-right", children: /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)(import_react10.Menu, { children: [
|
|
2258
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsx)(import_react10.MenuButton, { className: `copilotKitDebugMenuButton ${mode === "compact" ? "compact" : ""}`, children: mode == "compact" ? "Debug" : /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)(import_jsx_runtime19.Fragment, { children: [
|
|
2259
|
-
"Debug ",
|
|
2260
|
-
ChevronDownIcon
|
|
2261
|
-
] }) }),
|
|
2262
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsxs)(
|
|
2263
|
-
import_react10.MenuItems,
|
|
2264
|
-
{
|
|
2265
|
-
transition: true,
|
|
2266
|
-
anchor: "bottom end",
|
|
2267
|
-
className: "copilotKitDebugMenu",
|
|
2268
|
-
style: { zIndex: 40 },
|
|
2269
|
-
children: [
|
|
2270
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsx)(import_react10.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => logReadables(context), children: "Log Readables" }) }),
|
|
2271
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsx)(import_react10.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => logActions(context), children: "Log Actions" }) }),
|
|
2272
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsx)(import_react10.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
|
|
2273
|
-
"button",
|
|
2274
|
-
{
|
|
2275
|
-
className: "copilotKitDebugMenuItem",
|
|
2276
|
-
onClick: () => logMessages(messagesContext),
|
|
2277
|
-
children: "Log Messages"
|
|
2278
|
-
}
|
|
2279
|
-
) }),
|
|
2280
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsx)(import_react10.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => checkForUpdates(true), children: "Check for Updates" }) }),
|
|
2281
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsx)("hr", {}),
|
|
2282
|
-
/* @__PURE__ */ (0, import_jsx_runtime19.jsx)(import_react10.MenuItem, { children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("button", { className: "copilotKitDebugMenuItem", onClick: () => setShowDevConsole(false), children: "Hide Dev Console" }) })
|
|
2283
|
-
]
|
|
2284
|
-
}
|
|
2285
|
-
)
|
|
2286
|
-
] }) });
|
|
2287
|
-
}
|
|
2288
|
-
|
|
2289
|
-
// src/components/chat/Chat.tsx
|
|
2290
|
-
var import_react_core10 = require("@copilotkit/react-core");
|
|
2291
|
-
var import_jsx_runtime20 = require("react/jsx-runtime");
|
|
2292
1752
|
function CopilotChat({
|
|
2293
1753
|
instructions,
|
|
2294
1754
|
onSubmitMessage,
|
|
@@ -2297,6 +1757,10 @@ function CopilotChat({
|
|
|
2297
1757
|
onInProgress,
|
|
2298
1758
|
onStopGeneration,
|
|
2299
1759
|
onReloadMessages,
|
|
1760
|
+
onRegenerate,
|
|
1761
|
+
onCopy,
|
|
1762
|
+
onThumbsUp,
|
|
1763
|
+
onThumbsDown,
|
|
2300
1764
|
Messages: Messages2 = Messages,
|
|
2301
1765
|
RenderTextMessage: RenderTextMessage2 = RenderTextMessage,
|
|
2302
1766
|
RenderActionExecutionMessage: RenderActionExecutionMessage2 = RenderActionExecutionMessage,
|
|
@@ -2310,8 +1774,8 @@ function CopilotChat({
|
|
|
2310
1774
|
AssistantMessage: AssistantMessage2 = AssistantMessage,
|
|
2311
1775
|
UserMessage: UserMessage2 = UserMessage
|
|
2312
1776
|
}) {
|
|
2313
|
-
const { additionalInstructions, setChatInstructions } = (0,
|
|
2314
|
-
(0,
|
|
1777
|
+
const { additionalInstructions, setChatInstructions } = (0, import_react_core7.useCopilotContext)();
|
|
1778
|
+
(0, import_react9.useEffect)(() => {
|
|
2315
1779
|
if (!(additionalInstructions == null ? void 0 : additionalInstructions.length)) {
|
|
2316
1780
|
setChatInstructions(instructions || "");
|
|
2317
1781
|
return;
|
|
@@ -2338,11 +1802,21 @@ function CopilotChat({
|
|
|
2338
1802
|
onStopGeneration,
|
|
2339
1803
|
onReloadMessages
|
|
2340
1804
|
);
|
|
2341
|
-
const chatContext =
|
|
1805
|
+
const chatContext = import_react9.default.useContext(ChatContext);
|
|
2342
1806
|
const isVisible = chatContext ? chatContext.open : true;
|
|
2343
|
-
|
|
2344
|
-
|
|
2345
|
-
|
|
1807
|
+
const handleRegenerate = () => {
|
|
1808
|
+
if (onRegenerate) {
|
|
1809
|
+
onRegenerate();
|
|
1810
|
+
}
|
|
1811
|
+
reloadMessages();
|
|
1812
|
+
};
|
|
1813
|
+
const handleCopy = (message) => {
|
|
1814
|
+
if (onCopy) {
|
|
1815
|
+
onCopy(message);
|
|
1816
|
+
}
|
|
1817
|
+
};
|
|
1818
|
+
return /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)(WrappedCopilotChat, { icons, labels, className, children: [
|
|
1819
|
+
/* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
2346
1820
|
Messages2,
|
|
2347
1821
|
{
|
|
2348
1822
|
AssistantMessage: AssistantMessage2,
|
|
@@ -2353,32 +1827,32 @@ function CopilotChat({
|
|
|
2353
1827
|
RenderResultMessage: RenderResultMessage2,
|
|
2354
1828
|
messages: visibleMessages,
|
|
2355
1829
|
inProgress: isLoading,
|
|
2356
|
-
|
|
2357
|
-
|
|
2358
|
-
|
|
2359
|
-
|
|
2360
|
-
|
|
2361
|
-
|
|
2362
|
-
|
|
2363
|
-
|
|
2364
|
-
|
|
2365
|
-
|
|
2366
|
-
|
|
2367
|
-
|
|
2368
|
-
|
|
2369
|
-
|
|
2370
|
-
|
|
2371
|
-
showResponseButton && visibleMessages.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(
|
|
2372
|
-
ResponseButton2,
|
|
2373
|
-
{
|
|
2374
|
-
onClick: isLoading ? stopGeneration : reloadMessages,
|
|
2375
|
-
inProgress: isLoading
|
|
2376
|
-
}
|
|
2377
|
-
)
|
|
2378
|
-
]
|
|
1830
|
+
onRegenerate: handleRegenerate,
|
|
1831
|
+
onCopy: handleCopy,
|
|
1832
|
+
onThumbsUp,
|
|
1833
|
+
onThumbsDown,
|
|
1834
|
+
children: currentSuggestions.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("div", { className: "suggestions", children: currentSuggestions.map((suggestion, index) => /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
1835
|
+
Suggestion,
|
|
1836
|
+
{
|
|
1837
|
+
title: suggestion.title,
|
|
1838
|
+
message: suggestion.message,
|
|
1839
|
+
partial: suggestion.partial,
|
|
1840
|
+
className: suggestion.className,
|
|
1841
|
+
onClick: (message) => sendMessage(message)
|
|
1842
|
+
},
|
|
1843
|
+
index
|
|
1844
|
+
)) })
|
|
2379
1845
|
}
|
|
2380
1846
|
),
|
|
2381
|
-
/* @__PURE__ */ (0,
|
|
1847
|
+
/* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
1848
|
+
Input2,
|
|
1849
|
+
{
|
|
1850
|
+
inProgress: isLoading,
|
|
1851
|
+
onSend: sendMessage,
|
|
1852
|
+
isVisible,
|
|
1853
|
+
onStop: stopGeneration
|
|
1854
|
+
}
|
|
1855
|
+
)
|
|
2382
1856
|
] });
|
|
2383
1857
|
}
|
|
2384
1858
|
function WrappedCopilotChat({
|
|
@@ -2387,12 +1861,12 @@ function WrappedCopilotChat({
|
|
|
2387
1861
|
labels,
|
|
2388
1862
|
className
|
|
2389
1863
|
}) {
|
|
2390
|
-
const chatContext =
|
|
1864
|
+
const chatContext = import_react9.default.useContext(ChatContext);
|
|
2391
1865
|
if (!chatContext) {
|
|
2392
|
-
return /* @__PURE__ */ (0,
|
|
2393
|
-
}, children: /* @__PURE__ */ (0,
|
|
1866
|
+
return /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(ChatContextProvider, { icons, labels, open: true, setOpen: () => {
|
|
1867
|
+
}, children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("div", { className: `copilotKitChat ${className}`, children }) });
|
|
2394
1868
|
}
|
|
2395
|
-
return /* @__PURE__ */ (0,
|
|
1869
|
+
return /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(import_jsx_runtime16.Fragment, { children });
|
|
2396
1870
|
}
|
|
2397
1871
|
var SUGGESTIONS_DEBOUNCE_TIMEOUT = 1e3;
|
|
2398
1872
|
var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onStopGeneration, onReloadMessages) => {
|
|
@@ -2404,22 +1878,22 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onS
|
|
|
2404
1878
|
stopGeneration: defaultStopGeneration,
|
|
2405
1879
|
runChatCompletion,
|
|
2406
1880
|
isLoading
|
|
2407
|
-
} = (0,
|
|
2408
|
-
id: (0,
|
|
1881
|
+
} = (0, import_react_core7.useCopilotChat)({
|
|
1882
|
+
id: (0, import_shared2.randomId)(),
|
|
2409
1883
|
makeSystemMessage
|
|
2410
1884
|
});
|
|
2411
|
-
const [currentSuggestions, setCurrentSuggestions] = (0,
|
|
2412
|
-
const suggestionsAbortControllerRef = (0,
|
|
2413
|
-
const debounceTimerRef = (0,
|
|
1885
|
+
const [currentSuggestions, setCurrentSuggestions] = (0, import_react9.useState)([]);
|
|
1886
|
+
const suggestionsAbortControllerRef = (0, import_react9.useRef)(null);
|
|
1887
|
+
const debounceTimerRef = (0, import_react9.useRef)();
|
|
2414
1888
|
const abortSuggestions = () => {
|
|
2415
1889
|
var _a2;
|
|
2416
1890
|
(_a2 = suggestionsAbortControllerRef.current) == null ? void 0 : _a2.abort();
|
|
2417
1891
|
suggestionsAbortControllerRef.current = null;
|
|
2418
1892
|
};
|
|
2419
|
-
const generalContext = (0,
|
|
2420
|
-
const messagesContext = (0,
|
|
1893
|
+
const generalContext = (0, import_react_core7.useCopilotContext)();
|
|
1894
|
+
const messagesContext = (0, import_react_core7.useCopilotMessagesContext)();
|
|
2421
1895
|
const context = __spreadValues(__spreadValues({}, generalContext), messagesContext);
|
|
2422
|
-
(0,
|
|
1896
|
+
(0, import_react9.useEffect)(() => {
|
|
2423
1897
|
onInProgress == null ? void 0 : onInProgress(isLoading);
|
|
2424
1898
|
abortSuggestions();
|
|
2425
1899
|
debounceTimerRef.current = setTimeout(
|
|
@@ -2485,7 +1959,7 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onS
|
|
|
2485
1959
|
});
|
|
2486
1960
|
const runCurrentAgent = (hint) => __async(void 0, null, function* () {
|
|
2487
1961
|
if (generalContext.agentSession) {
|
|
2488
|
-
yield (0,
|
|
1962
|
+
yield (0, import_react_core8.runAgent)(
|
|
2489
1963
|
generalContext.agentSession.agentName,
|
|
2490
1964
|
context,
|
|
2491
1965
|
appendMessage,
|
|
@@ -2496,7 +1970,7 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onS
|
|
|
2496
1970
|
});
|
|
2497
1971
|
const stopCurrentAgent = () => {
|
|
2498
1972
|
if (generalContext.agentSession) {
|
|
2499
|
-
(0,
|
|
1973
|
+
(0, import_react_core8.stopAgent)(generalContext.agentSession.agentName, context);
|
|
2500
1974
|
}
|
|
2501
1975
|
};
|
|
2502
1976
|
const setCurrentAgentState = (state) => {
|