@copilotkit/react-core 1.10.0-next.8 → 1.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +111 -0
- package/dist/{chunk-VH45SC6Z.mjs → chunk-2GRWTU7W.mjs} +2 -2
- package/dist/chunk-3BASANUO.mjs +170 -0
- package/dist/chunk-3BASANUO.mjs.map +1 -0
- package/dist/{chunk-PHIMGB3K.mjs → chunk-5P46WS5M.mjs} +25 -19
- package/dist/chunk-5P46WS5M.mjs.map +1 -0
- package/dist/{chunk-AWFAFFO5.mjs → chunk-6ZLPNY7X.mjs} +7 -3
- package/dist/chunk-6ZLPNY7X.mjs.map +1 -0
- package/dist/{chunk-TTI4Z6GK.mjs → chunk-BEFEBKKI.mjs} +7 -7
- package/dist/chunk-BEFEBKKI.mjs.map +1 -0
- package/dist/{chunk-VSH4JSN3.mjs → chunk-F26O2HTO.mjs} +13 -7
- package/dist/chunk-F26O2HTO.mjs.map +1 -0
- package/dist/{chunk-GRCHDHC4.mjs → chunk-JY3STRON.mjs} +22 -4
- package/dist/chunk-JY3STRON.mjs.map +1 -0
- package/dist/{chunk-ZTZJIDRJ.mjs → chunk-N4VN2B5S.mjs} +2 -2
- package/dist/{chunk-FTP6FDYS.mjs → chunk-NTH42BY5.mjs} +2 -2
- package/dist/chunk-PIF5KJYI.mjs +103 -0
- package/dist/chunk-PIF5KJYI.mjs.map +1 -0
- package/dist/chunk-WSXTUD36.mjs +759 -0
- package/dist/chunk-WSXTUD36.mjs.map +1 -0
- package/dist/chunk-YIBUNEBN.mjs +34 -0
- package/dist/chunk-YIBUNEBN.mjs.map +1 -0
- package/dist/components/copilot-provider/copilotkit-props.d.ts +9 -1
- package/dist/components/copilot-provider/copilotkit-props.js.map +1 -1
- package/dist/components/copilot-provider/copilotkit.js +1052 -72
- package/dist/components/copilot-provider/copilotkit.js.map +1 -1
- package/dist/components/copilot-provider/copilotkit.mjs +6 -3
- package/dist/components/copilot-provider/index.js +1052 -72
- package/dist/components/copilot-provider/index.js.map +1 -1
- package/dist/components/copilot-provider/index.mjs +6 -3
- package/dist/components/dev-console/console-trigger.d.ts +8 -0
- package/dist/components/dev-console/console-trigger.js +1131 -0
- package/dist/components/dev-console/console-trigger.js.map +1 -0
- package/dist/components/dev-console/console-trigger.mjs +13 -0
- package/dist/components/dev-console/developer-console-modal.d.ts +10 -0
- package/dist/components/dev-console/developer-console-modal.js +977 -0
- package/dist/components/dev-console/developer-console-modal.js.map +1 -0
- package/dist/components/dev-console/developer-console-modal.mjs +12 -0
- package/dist/components/dev-console/developer-console-modal.mjs.map +1 -0
- package/dist/components/dev-console/icons.d.ts +9 -0
- package/dist/components/dev-console/icons.js +131 -0
- package/dist/components/dev-console/icons.js.map +1 -0
- package/dist/components/dev-console/icons.mjs +16 -0
- package/dist/components/dev-console/icons.mjs.map +1 -0
- package/dist/components/error-boundary/error-boundary.js +6 -2
- package/dist/components/error-boundary/error-boundary.js.map +1 -1
- package/dist/components/error-boundary/error-boundary.mjs +2 -2
- package/dist/components/index.js +1052 -72
- package/dist/components/index.js.map +1 -1
- package/dist/components/index.mjs +6 -3
- package/dist/components/usage-banner.d.ts +2 -1
- package/dist/components/usage-banner.js +6 -2
- package/dist/components/usage-banner.js.map +1 -1
- package/dist/components/usage-banner.mjs +1 -1
- package/dist/hooks/index.d.ts +5 -5
- package/dist/hooks/index.js +58 -26
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/index.mjs +13 -10
- package/dist/hooks/use-coagent.d.ts +1 -1
- package/dist/hooks/use-coagent.js +18 -6
- package/dist/hooks/use-coagent.js.map +1 -1
- package/dist/hooks/use-coagent.mjs +8 -5
- package/dist/hooks/use-copilot-chat-headless_c.d.ts +33 -0
- package/dist/hooks/{use-copilot-chat-light.js → use-copilot-chat-headless_c.js} +88 -19
- package/dist/hooks/use-copilot-chat-headless_c.js.map +1 -0
- package/dist/hooks/{use-copilot-chat-light.mjs → use-copilot-chat-headless_c.mjs} +14 -8
- package/dist/hooks/use-copilot-chat-headless_c.mjs.map +1 -0
- package/dist/hooks/use-copilot-chat.d.ts +85 -4
- package/dist/hooks/use-copilot-chat.js +38 -61
- package/dist/hooks/use-copilot-chat.js.map +1 -1
- package/dist/hooks/use-copilot-chat.mjs +8 -8
- package/dist/hooks/use-copilot-chat_internal.d.ts +98 -12
- package/dist/hooks/use-copilot-chat_internal.js +13 -1
- package/dist/hooks/use-copilot-chat_internal.js.map +1 -1
- package/dist/hooks/use-copilot-chat_internal.mjs +7 -4
- package/dist/hooks/use-langgraph-interrupt.js +13 -1
- package/dist/hooks/use-langgraph-interrupt.js.map +1 -1
- package/dist/hooks/use-langgraph-interrupt.mjs +8 -5
- package/dist/index.d.ts +3 -3
- package/dist/index.js +1203 -200
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +14 -11
- package/dist/lib/copilot-task.js.map +1 -1
- package/dist/lib/copilot-task.mjs +7 -4
- package/dist/lib/index.js.map +1 -1
- package/dist/lib/index.mjs +7 -4
- package/dist/utils/extract.js.map +1 -1
- package/dist/utils/extract.mjs +6 -3
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/index.mjs +6 -3
- package/dist/utils/suggestions.js.map +1 -1
- package/dist/utils/suggestions.mjs +6 -3
- package/package.json +3 -3
- package/src/components/copilot-provider/copilotkit-props.tsx +10 -1
- package/src/components/copilot-provider/copilotkit.tsx +25 -16
- package/src/components/dev-console/console-trigger.tsx +190 -0
- package/src/components/dev-console/developer-console-modal.tsx +866 -0
- package/src/components/dev-console/icons.tsx +101 -0
- package/src/components/usage-banner.tsx +8 -3
- package/src/hooks/index.ts +6 -7
- package/src/hooks/use-coagent.ts +6 -11
- package/src/hooks/use-copilot-chat-headless_c.ts +257 -0
- package/src/hooks/use-copilot-chat.ts +103 -154
- package/src/hooks/use-copilot-chat_internal.ts +122 -15
- package/dist/chunk-AWFAFFO5.mjs.map +0 -1
- package/dist/chunk-GRCHDHC4.mjs.map +0 -1
- package/dist/chunk-MWHILKQH.mjs +0 -18
- package/dist/chunk-MWHILKQH.mjs.map +0 -1
- package/dist/chunk-PHIMGB3K.mjs.map +0 -1
- package/dist/chunk-TTI4Z6GK.mjs.map +0 -1
- package/dist/chunk-VSH4JSN3.mjs.map +0 -1
- package/dist/hooks/use-copilot-chat-light.d.ts +0 -211
- package/dist/hooks/use-copilot-chat-light.js.map +0 -1
- package/src/hooks/use-copilot-chat-light.ts +0 -219
- /package/dist/{chunk-VH45SC6Z.mjs.map → chunk-2GRWTU7W.mjs.map} +0 -0
- /package/dist/{chunk-ZTZJIDRJ.mjs.map → chunk-N4VN2B5S.mjs.map} +0 -0
- /package/dist/{chunk-FTP6FDYS.mjs.map → chunk-NTH42BY5.mjs.map} +0 -0
- /package/dist/{hooks/use-copilot-chat-light.mjs.map → components/dev-console/console-trigger.mjs.map} +0 -0
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
|
|
3
|
+
export const ExclamationMarkTriangleIcon = () => (
|
|
4
|
+
<svg
|
|
5
|
+
width="13.3967723px"
|
|
6
|
+
height="12px"
|
|
7
|
+
viewBox="0 0 13.3967723 12"
|
|
8
|
+
version="1.1"
|
|
9
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
10
|
+
>
|
|
11
|
+
<g id="Page-1" stroke="none" strokeWidth="1" fill="none" fillRule="evenodd">
|
|
12
|
+
<g id="exclamation-triangle" fill="#CD2121">
|
|
13
|
+
<path
|
|
14
|
+
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"
|
|
15
|
+
id="Shape"
|
|
16
|
+
></path>
|
|
17
|
+
</g>
|
|
18
|
+
</g>
|
|
19
|
+
</svg>
|
|
20
|
+
);
|
|
21
|
+
|
|
22
|
+
export const ExclamationMarkIcon = () => (
|
|
23
|
+
<svg
|
|
24
|
+
width="14px"
|
|
25
|
+
height="14px"
|
|
26
|
+
viewBox="0 0 14 14"
|
|
27
|
+
version="1.1"
|
|
28
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
29
|
+
>
|
|
30
|
+
<g id="Page-1" stroke="none" strokeWidth="1" fill="none" fillRule="evenodd">
|
|
31
|
+
<g id="exclamation-circle" fill="#EC662C">
|
|
32
|
+
<path
|
|
33
|
+
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"
|
|
34
|
+
id="Shape"
|
|
35
|
+
></path>
|
|
36
|
+
</g>
|
|
37
|
+
</g>
|
|
38
|
+
</svg>
|
|
39
|
+
);
|
|
40
|
+
|
|
41
|
+
export const ChevronDownIcon = () => (
|
|
42
|
+
<svg
|
|
43
|
+
width="7px"
|
|
44
|
+
height="4px"
|
|
45
|
+
viewBox="0 0 7 4"
|
|
46
|
+
version="1.1"
|
|
47
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
48
|
+
fill="currentColor"
|
|
49
|
+
>
|
|
50
|
+
<g id="Page-1" stroke="none" strokeWidth="1" fill="none" fillRule="evenodd">
|
|
51
|
+
<g id="Group" fill="currentColor" fillRule="nonzero">
|
|
52
|
+
<path
|
|
53
|
+
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"
|
|
54
|
+
id="Path"
|
|
55
|
+
></path>
|
|
56
|
+
</g>
|
|
57
|
+
</g>
|
|
58
|
+
</svg>
|
|
59
|
+
);
|
|
60
|
+
|
|
61
|
+
export const CheckIcon = () => (
|
|
62
|
+
<svg
|
|
63
|
+
width="14px"
|
|
64
|
+
height="14px"
|
|
65
|
+
viewBox="0 0 14 14"
|
|
66
|
+
version="1.1"
|
|
67
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
68
|
+
>
|
|
69
|
+
<g id="Page-1" stroke="none" strokeWidth="1" fill="none" fillRule="evenodd">
|
|
70
|
+
<g id="Group-2" transform="translate(-118, 0)" fill="#1BC030" fillRule="nonzero">
|
|
71
|
+
<g id="Group" transform="translate(118, 0)">
|
|
72
|
+
<path
|
|
73
|
+
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"
|
|
74
|
+
id="Shape"
|
|
75
|
+
></path>
|
|
76
|
+
</g>
|
|
77
|
+
</g>
|
|
78
|
+
</g>
|
|
79
|
+
</svg>
|
|
80
|
+
);
|
|
81
|
+
|
|
82
|
+
export const CopilotKitIcon = () => (
|
|
83
|
+
<svg
|
|
84
|
+
width="33px"
|
|
85
|
+
height="35px"
|
|
86
|
+
viewBox="0 0 33 35"
|
|
87
|
+
version="1.1"
|
|
88
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
89
|
+
>
|
|
90
|
+
<title>bd5c9079-929b-4d55-bdc9-16d1c8181b71</title>
|
|
91
|
+
<g id="Page-1" stroke="none" strokeWidth="1" fill="none" fillRule="evenodd">
|
|
92
|
+
<image
|
|
93
|
+
x="0"
|
|
94
|
+
y="0"
|
|
95
|
+
width="33"
|
|
96
|
+
height="35"
|
|
97
|
+
xlinkHref=""
|
|
98
|
+
></image>
|
|
99
|
+
</g>
|
|
100
|
+
</svg>
|
|
101
|
+
);
|
|
@@ -4,10 +4,11 @@ import {
|
|
|
4
4
|
ErrorVisibility,
|
|
5
5
|
CopilotKitErrorCode,
|
|
6
6
|
} from "@copilotkit/shared";
|
|
7
|
+
import React from "react";
|
|
7
8
|
|
|
8
9
|
interface UsageBannerProps {
|
|
9
10
|
severity?: Severity;
|
|
10
|
-
message?: string;
|
|
11
|
+
message?: string | React.ReactNode;
|
|
11
12
|
onClose?: () => void;
|
|
12
13
|
actions?: {
|
|
13
14
|
primary?: {
|
|
@@ -219,9 +220,13 @@ export const getErrorActions = (error: CopilotKitError) => {
|
|
|
219
220
|
case CopilotKitErrorCode.MISSING_PUBLIC_API_KEY_ERROR:
|
|
220
221
|
return {
|
|
221
222
|
primary: {
|
|
222
|
-
label: "
|
|
223
|
+
label: "Show me how",
|
|
223
224
|
onClick: () =>
|
|
224
|
-
window.open(
|
|
225
|
+
window.open(
|
|
226
|
+
"https://docs.copilotkit.ai/premium#how-do-i-get-access-to-premium-features",
|
|
227
|
+
"_blank",
|
|
228
|
+
"noopener,noreferrer",
|
|
229
|
+
),
|
|
225
230
|
},
|
|
226
231
|
};
|
|
227
232
|
case CopilotKitErrorCode.UPGRADE_REQUIRED_ERROR:
|
package/src/hooks/index.ts
CHANGED
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
export { useCopilotChat } from "./use-copilot-chat";
|
|
2
|
-
export type { UseCopilotChatOptions } from "./use-copilot-chat";
|
|
3
2
|
export type { UseCopilotChatReturn } from "./use-copilot-chat";
|
|
4
|
-
|
|
5
|
-
export {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
} from "./use-copilot-chat-
|
|
3
|
+
export type { UseCopilotChatOptions } from "./use-copilot-chat_internal";
|
|
4
|
+
export {
|
|
5
|
+
type UseCopilotChatReturn_c,
|
|
6
|
+
type UseCopilotChatOptions_c,
|
|
7
|
+
useCopilotChatHeadless_c,
|
|
8
|
+
} from "./use-copilot-chat-headless_c";
|
|
10
9
|
export { useCopilotChat as useCopilotChatInternal } from "./use-copilot-chat_internal";
|
|
11
10
|
export { useCopilotAction } from "./use-copilot-action";
|
|
12
11
|
export { useCoAgentStateRender } from "./use-coagent-state-render";
|
package/src/hooks/use-coagent.ts
CHANGED
|
@@ -89,12 +89,7 @@
|
|
|
89
89
|
*/
|
|
90
90
|
|
|
91
91
|
import { useCallback, useEffect, useMemo, useRef } from "react";
|
|
92
|
-
import {
|
|
93
|
-
CopilotContextParams,
|
|
94
|
-
CopilotMessagesContextParams,
|
|
95
|
-
useCopilotContext,
|
|
96
|
-
useCopilotMessagesContext,
|
|
97
|
-
} from "../context";
|
|
92
|
+
import { CopilotContextParams, useCopilotContext } from "../context";
|
|
98
93
|
import { CoagentState } from "../types/coagent-state";
|
|
99
94
|
import { useCopilotChat } from "./use-copilot-chat_internal";
|
|
100
95
|
import { Message } from "@copilotkit/shared";
|
|
@@ -239,7 +234,7 @@ export function useCoAgent<T = any>(options: UseCoagentOptions<T>): UseCoagentRe
|
|
|
239
234
|
|
|
240
235
|
const { coagentStates, coagentStatesRef, setCoagentStatesWithRef, threadId, copilotApiConfig } =
|
|
241
236
|
context;
|
|
242
|
-
const {
|
|
237
|
+
const { sendMessage, runChatCompletion } = useCopilotChat();
|
|
243
238
|
const headers = {
|
|
244
239
|
...(copilotApiConfig.headers || {}),
|
|
245
240
|
};
|
|
@@ -351,9 +346,9 @@ export function useCoAgent<T = any>(options: UseCoagentOptions<T>): UseCoagentRe
|
|
|
351
346
|
|
|
352
347
|
const runAgentCallback = useAsyncCallback(
|
|
353
348
|
async (hint?: HintFunction) => {
|
|
354
|
-
await runAgent(name, context, getMessagesFromTap(),
|
|
349
|
+
await runAgent(name, context, getMessagesFromTap(), sendMessage, runChatCompletion, hint);
|
|
355
350
|
},
|
|
356
|
-
[name, context,
|
|
351
|
+
[name, context, sendMessage, runChatCompletion],
|
|
357
352
|
);
|
|
358
353
|
|
|
359
354
|
// Return the state and setState function
|
|
@@ -406,7 +401,7 @@ export async function runAgent(
|
|
|
406
401
|
name: string,
|
|
407
402
|
context: CopilotContextParams,
|
|
408
403
|
messages: GqlMessage[],
|
|
409
|
-
|
|
404
|
+
sendMessage: (message: Message) => Promise<void>,
|
|
410
405
|
runChatCompletion: () => Promise<Message[]>,
|
|
411
406
|
hint?: HintFunction,
|
|
412
407
|
) {
|
|
@@ -430,7 +425,7 @@ export async function runAgent(
|
|
|
430
425
|
if (hint) {
|
|
431
426
|
const hintMessage = hint({ previousState, currentState: state });
|
|
432
427
|
if (hintMessage) {
|
|
433
|
-
await
|
|
428
|
+
await sendMessage(hintMessage);
|
|
434
429
|
} else {
|
|
435
430
|
await runChatCompletion();
|
|
436
431
|
}
|
|
@@ -0,0 +1,257 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `useCopilotChatHeadless_c` is for building fully custom UI (headless UI) implementations.
|
|
3
|
+
*
|
|
4
|
+
* <Callout title="This is a premium-only feature">
|
|
5
|
+
* Sign up for free on [Copilot Cloud](https://cloud.copilotkit.ai) to get your public license key or read more about [premium features](/premium).
|
|
6
|
+
*
|
|
7
|
+
* Usage is generous, **free** to get started, and works with **either self-hosted or Copilot Cloud** environments.
|
|
8
|
+
* </Callout>
|
|
9
|
+
*
|
|
10
|
+
* ## Key Features
|
|
11
|
+
*
|
|
12
|
+
* - **Fully headless**: Build your own fully custom UI's for your agentic applications.
|
|
13
|
+
* - **Advanced Suggestions**: Direct access to suggestions array with full control
|
|
14
|
+
* - **Interrupt Handling**: Support for advanced interrupt functionality
|
|
15
|
+
* - **MCP Server Support**: Model Context Protocol server configurations
|
|
16
|
+
* - **Chat Controls**: Complete set of chat management functions
|
|
17
|
+
* - **Loading States**: Comprehensive loading state management
|
|
18
|
+
*
|
|
19
|
+
*
|
|
20
|
+
* ## Usage
|
|
21
|
+
*
|
|
22
|
+
* ### Basic Setup
|
|
23
|
+
*
|
|
24
|
+
* ```tsx
|
|
25
|
+
* import { CopilotKit } from "@copilotkit/react-core";
|
|
26
|
+
* import { useCopilotChatHeadless_c } from "@copilotkit/react-core";
|
|
27
|
+
*
|
|
28
|
+
* export function App() {
|
|
29
|
+
* return (
|
|
30
|
+
* <CopilotKit publicApiKey="your-free-public-license-key">
|
|
31
|
+
* <YourComponent />
|
|
32
|
+
* </CopilotKit>
|
|
33
|
+
* );
|
|
34
|
+
* }
|
|
35
|
+
*
|
|
36
|
+
* export function YourComponent() {
|
|
37
|
+
* const { messages, sendMessage, isLoading } = useCopilotChatHeadless_c();
|
|
38
|
+
*
|
|
39
|
+
* const handleSendMessage = async () => {
|
|
40
|
+
* await sendMessage({
|
|
41
|
+
* id: "123",
|
|
42
|
+
* role: "user",
|
|
43
|
+
* content: "Hello World",
|
|
44
|
+
* });
|
|
45
|
+
* };
|
|
46
|
+
*
|
|
47
|
+
* return (
|
|
48
|
+
* <div>
|
|
49
|
+
* {messages.map(msg => <div key={msg.id}>{msg.content}</div>)}
|
|
50
|
+
* <button onClick={handleSendMessage} disabled={isLoading}>
|
|
51
|
+
* Send Message
|
|
52
|
+
* </button>
|
|
53
|
+
* </div>
|
|
54
|
+
* );
|
|
55
|
+
* }
|
|
56
|
+
* ```
|
|
57
|
+
*
|
|
58
|
+
* ### Working with Suggestions
|
|
59
|
+
*
|
|
60
|
+
* ```tsx
|
|
61
|
+
* import { useCopilotChatHeadless_c, useCopilotChatSuggestions } from "@copilotkit/react-core";
|
|
62
|
+
*
|
|
63
|
+
* export function SuggestionExample() {
|
|
64
|
+
* const {
|
|
65
|
+
* suggestions,
|
|
66
|
+
* setSuggestions,
|
|
67
|
+
* generateSuggestions,
|
|
68
|
+
* isLoadingSuggestions
|
|
69
|
+
* } = useCopilotChatHeadless_c();
|
|
70
|
+
*
|
|
71
|
+
* // Configure AI suggestion generation
|
|
72
|
+
* useCopilotChatSuggestions({
|
|
73
|
+
* instructions: "Suggest helpful actions based on the current context",
|
|
74
|
+
* maxSuggestions: 3
|
|
75
|
+
* });
|
|
76
|
+
*
|
|
77
|
+
* return (
|
|
78
|
+
* <div>
|
|
79
|
+
* {suggestions.map(suggestion => (
|
|
80
|
+
* <button key={suggestion.title}>{suggestion.title}</button>
|
|
81
|
+
* ))}
|
|
82
|
+
* <button onClick={generateSuggestions} disabled={isLoadingSuggestions}>
|
|
83
|
+
* Generate Suggestions
|
|
84
|
+
* </button>
|
|
85
|
+
* </div>
|
|
86
|
+
* );
|
|
87
|
+
* }
|
|
88
|
+
* ```
|
|
89
|
+
*
|
|
90
|
+
* ## Return Values
|
|
91
|
+
* The following properties are returned from the hook:
|
|
92
|
+
*
|
|
93
|
+
* <PropertyReference name="messages" type="Message[]">
|
|
94
|
+
* The messages currently in the chat in AG-UI format
|
|
95
|
+
* </PropertyReference>
|
|
96
|
+
*
|
|
97
|
+
* <PropertyReference name="sendMessage" type="(message: Message, options?) => Promise<void>">
|
|
98
|
+
* Send a new message to the chat and trigger AI response
|
|
99
|
+
* </PropertyReference>
|
|
100
|
+
*
|
|
101
|
+
* <PropertyReference name="setMessages" type="(messages: Message[] | DeprecatedGqlMessage[]) => void">
|
|
102
|
+
* Replace all messages in the chat with new array
|
|
103
|
+
* </PropertyReference>
|
|
104
|
+
*
|
|
105
|
+
* <PropertyReference name="deleteMessage" type="(messageId: string) => void">
|
|
106
|
+
* Remove a specific message by ID from the chat
|
|
107
|
+
* </PropertyReference>
|
|
108
|
+
*
|
|
109
|
+
* <PropertyReference name="reloadMessages" type="(messageId: string) => Promise<void>">
|
|
110
|
+
* Regenerate the response for a specific message by ID
|
|
111
|
+
* </PropertyReference>
|
|
112
|
+
*
|
|
113
|
+
* <PropertyReference name="stopGeneration" type="() => void">
|
|
114
|
+
* Stop the current message generation process
|
|
115
|
+
* </PropertyReference>
|
|
116
|
+
*
|
|
117
|
+
* <PropertyReference name="reset" type="() => void">
|
|
118
|
+
* Clear all messages and reset chat state completely
|
|
119
|
+
* </PropertyReference>
|
|
120
|
+
*
|
|
121
|
+
* <PropertyReference name="isLoading" type="boolean">
|
|
122
|
+
* Whether the chat is currently generating a response
|
|
123
|
+
* </PropertyReference>
|
|
124
|
+
*
|
|
125
|
+
* <PropertyReference name="runChatCompletion" type="() => Promise<Message[]>">
|
|
126
|
+
* Manually trigger chat completion for advanced usage
|
|
127
|
+
* </PropertyReference>
|
|
128
|
+
*
|
|
129
|
+
* <PropertyReference name="mcpServers" type="MCPServerConfig[]">
|
|
130
|
+
* Array of Model Context Protocol server configurations
|
|
131
|
+
* </PropertyReference>
|
|
132
|
+
*
|
|
133
|
+
* <PropertyReference name="setMcpServers" type="(servers: MCPServerConfig[]) => void">
|
|
134
|
+
* Update MCP server configurations for enhanced context
|
|
135
|
+
* </PropertyReference>
|
|
136
|
+
*
|
|
137
|
+
* <PropertyReference name="suggestions" type="SuggestionItem[]">
|
|
138
|
+
* Current suggestions array for reading or manual control
|
|
139
|
+
* </PropertyReference>
|
|
140
|
+
*
|
|
141
|
+
* <PropertyReference name="setSuggestions" type="(suggestions: SuggestionItem[]) => void">
|
|
142
|
+
* Manually set suggestions for custom workflows
|
|
143
|
+
* </PropertyReference>
|
|
144
|
+
*
|
|
145
|
+
* <PropertyReference name="generateSuggestions" type="() => Promise<void>">
|
|
146
|
+
* Trigger AI-powered suggestion generation using configured settings
|
|
147
|
+
* </PropertyReference>
|
|
148
|
+
*
|
|
149
|
+
* <PropertyReference name="resetSuggestions" type="() => void">
|
|
150
|
+
* Clear all current suggestions and reset generation state
|
|
151
|
+
* </PropertyReference>
|
|
152
|
+
*
|
|
153
|
+
* <PropertyReference name="isLoadingSuggestions" type="boolean">
|
|
154
|
+
* Whether suggestions are currently being generated
|
|
155
|
+
* </PropertyReference>
|
|
156
|
+
*
|
|
157
|
+
* <PropertyReference name="interrupt" type="string | React.ReactElement | null">
|
|
158
|
+
* Interrupt content for human-in-the-loop workflows
|
|
159
|
+
* </PropertyReference>
|
|
160
|
+
*/
|
|
161
|
+
import { useEffect } from "react";
|
|
162
|
+
import { useCopilotContext } from "../context/copilot-context";
|
|
163
|
+
import {
|
|
164
|
+
useCopilotChat as useCopilotChatInternal,
|
|
165
|
+
defaultSystemMessage,
|
|
166
|
+
UseCopilotChatOptions as UseCopilotChatOptions_c,
|
|
167
|
+
UseCopilotChatReturn as UseCopilotChatReturn_c,
|
|
168
|
+
MCPServerConfig,
|
|
169
|
+
} from "./use-copilot-chat_internal";
|
|
170
|
+
|
|
171
|
+
import {
|
|
172
|
+
ErrorVisibility,
|
|
173
|
+
Severity,
|
|
174
|
+
CopilotKitError,
|
|
175
|
+
CopilotKitErrorCode,
|
|
176
|
+
styledConsole,
|
|
177
|
+
} from "@copilotkit/shared";
|
|
178
|
+
|
|
179
|
+
// Non-functional fallback implementation
|
|
180
|
+
const createNonFunctionalReturn = (): UseCopilotChatReturn_c => ({
|
|
181
|
+
visibleMessages: [],
|
|
182
|
+
messages: [],
|
|
183
|
+
sendMessage: async () => {},
|
|
184
|
+
appendMessage: async () => {},
|
|
185
|
+
setMessages: () => {},
|
|
186
|
+
deleteMessage: () => {},
|
|
187
|
+
reloadMessages: async () => {},
|
|
188
|
+
stopGeneration: () => {},
|
|
189
|
+
reset: () => {},
|
|
190
|
+
isLoading: false,
|
|
191
|
+
runChatCompletion: async () => [],
|
|
192
|
+
mcpServers: [],
|
|
193
|
+
setMcpServers: () => {},
|
|
194
|
+
suggestions: [],
|
|
195
|
+
setSuggestions: () => {},
|
|
196
|
+
generateSuggestions: async () => {},
|
|
197
|
+
resetSuggestions: () => {},
|
|
198
|
+
isLoadingSuggestions: false,
|
|
199
|
+
interrupt: null,
|
|
200
|
+
});
|
|
201
|
+
/**
|
|
202
|
+
* Enterprise React hook that provides complete chat functionality for fully custom UI implementations.
|
|
203
|
+
* Includes all advanced features like direct message access, suggestions array, interrupt handling, and MCP support.
|
|
204
|
+
*
|
|
205
|
+
* **Requires a publicApiKey** - Sign up for free at https://cloud.copilotkit.ai/
|
|
206
|
+
*
|
|
207
|
+
* @param options - Configuration options for the chat
|
|
208
|
+
* @returns Complete chat interface with all enterprise features
|
|
209
|
+
*
|
|
210
|
+
* @example
|
|
211
|
+
* ```tsx
|
|
212
|
+
* const { messages, sendMessage, suggestions, interrupt } = useCopilotChatHeadless_c();
|
|
213
|
+
* ```
|
|
214
|
+
*/
|
|
215
|
+
function useCopilotChatHeadless_c(options: UseCopilotChatOptions_c = {}): UseCopilotChatReturn_c {
|
|
216
|
+
const { copilotApiConfig, setBannerError } = useCopilotContext();
|
|
217
|
+
|
|
218
|
+
// Check if publicApiKey is available
|
|
219
|
+
const hasPublicApiKey = Boolean(copilotApiConfig.publicApiKey);
|
|
220
|
+
|
|
221
|
+
// Always call the internal hook (follows rules of hooks)
|
|
222
|
+
const internalResult = useCopilotChatInternal(options);
|
|
223
|
+
|
|
224
|
+
// Set banner error when no public API key is provided
|
|
225
|
+
useEffect(() => {
|
|
226
|
+
if (!hasPublicApiKey) {
|
|
227
|
+
setBannerError(
|
|
228
|
+
new CopilotKitError({
|
|
229
|
+
message:
|
|
230
|
+
// add link to documentation here
|
|
231
|
+
"You're using useCopilotChatHeadless_c, a premium-only feature, which offers extensive headless chat capabilities. To continue, you'll need to provide a free public license key.",
|
|
232
|
+
code: CopilotKitErrorCode.MISSING_PUBLIC_API_KEY_ERROR,
|
|
233
|
+
severity: Severity.WARNING,
|
|
234
|
+
visibility: ErrorVisibility.BANNER,
|
|
235
|
+
}),
|
|
236
|
+
);
|
|
237
|
+
styledConsole.logCopilotKitPlatformMessage();
|
|
238
|
+
} else {
|
|
239
|
+
setBannerError(null); // Clear banner when API key is provided
|
|
240
|
+
}
|
|
241
|
+
}, [hasPublicApiKey]); // Removed setBannerError dependency
|
|
242
|
+
|
|
243
|
+
// Return internal result if publicApiKey is available, otherwise return fallback
|
|
244
|
+
if (hasPublicApiKey) {
|
|
245
|
+
return internalResult;
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
// Return non-functional fallback when no publicApiKey
|
|
249
|
+
return createNonFunctionalReturn();
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
export { defaultSystemMessage, useCopilotChatHeadless_c };
|
|
253
|
+
export type { UseCopilotChatOptions_c, UseCopilotChatReturn_c, MCPServerConfig };
|
|
254
|
+
|
|
255
|
+
const noKeyWarning = () => {
|
|
256
|
+
styledConsole.logCopilotKitPlatformMessage();
|
|
257
|
+
};
|