@copilotkit/react-core 1.10.0-next.9 → 1.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (118) hide show
  1. package/CHANGELOG.md +104 -0
  2. package/dist/{chunk-VH45SC6Z.mjs → chunk-2GRWTU7W.mjs} +2 -2
  3. package/dist/chunk-3BASANUO.mjs +170 -0
  4. package/dist/chunk-3BASANUO.mjs.map +1 -0
  5. package/dist/{chunk-PHIMGB3K.mjs → chunk-5P46WS5M.mjs} +25 -19
  6. package/dist/chunk-5P46WS5M.mjs.map +1 -0
  7. package/dist/{chunk-AWFAFFO5.mjs → chunk-6ZLPNY7X.mjs} +7 -3
  8. package/dist/chunk-6ZLPNY7X.mjs.map +1 -0
  9. package/dist/{chunk-TTI4Z6GK.mjs → chunk-BEFEBKKI.mjs} +7 -7
  10. package/dist/chunk-BEFEBKKI.mjs.map +1 -0
  11. package/dist/{chunk-VSH4JSN3.mjs → chunk-F26O2HTO.mjs} +13 -7
  12. package/dist/chunk-F26O2HTO.mjs.map +1 -0
  13. package/dist/{chunk-GRCHDHC4.mjs → chunk-JY3STRON.mjs} +22 -4
  14. package/dist/chunk-JY3STRON.mjs.map +1 -0
  15. package/dist/{chunk-ZTZJIDRJ.mjs → chunk-N4VN2B5S.mjs} +2 -2
  16. package/dist/{chunk-FTP6FDYS.mjs → chunk-NTH42BY5.mjs} +2 -2
  17. package/dist/chunk-PIF5KJYI.mjs +103 -0
  18. package/dist/chunk-PIF5KJYI.mjs.map +1 -0
  19. package/dist/chunk-WSXTUD36.mjs +759 -0
  20. package/dist/chunk-WSXTUD36.mjs.map +1 -0
  21. package/dist/chunk-YIBUNEBN.mjs +34 -0
  22. package/dist/chunk-YIBUNEBN.mjs.map +1 -0
  23. package/dist/components/copilot-provider/copilotkit-props.d.ts +9 -1
  24. package/dist/components/copilot-provider/copilotkit-props.js.map +1 -1
  25. package/dist/components/copilot-provider/copilotkit.js +1052 -72
  26. package/dist/components/copilot-provider/copilotkit.js.map +1 -1
  27. package/dist/components/copilot-provider/copilotkit.mjs +6 -3
  28. package/dist/components/copilot-provider/index.js +1052 -72
  29. package/dist/components/copilot-provider/index.js.map +1 -1
  30. package/dist/components/copilot-provider/index.mjs +6 -3
  31. package/dist/components/dev-console/console-trigger.d.ts +8 -0
  32. package/dist/components/dev-console/console-trigger.js +1131 -0
  33. package/dist/components/dev-console/console-trigger.js.map +1 -0
  34. package/dist/components/dev-console/console-trigger.mjs +13 -0
  35. package/dist/components/dev-console/developer-console-modal.d.ts +10 -0
  36. package/dist/components/dev-console/developer-console-modal.js +977 -0
  37. package/dist/components/dev-console/developer-console-modal.js.map +1 -0
  38. package/dist/components/dev-console/developer-console-modal.mjs +12 -0
  39. package/dist/components/dev-console/developer-console-modal.mjs.map +1 -0
  40. package/dist/components/dev-console/icons.d.ts +9 -0
  41. package/dist/components/dev-console/icons.js +131 -0
  42. package/dist/components/dev-console/icons.js.map +1 -0
  43. package/dist/components/dev-console/icons.mjs +16 -0
  44. package/dist/components/dev-console/icons.mjs.map +1 -0
  45. package/dist/components/error-boundary/error-boundary.js +6 -2
  46. package/dist/components/error-boundary/error-boundary.js.map +1 -1
  47. package/dist/components/error-boundary/error-boundary.mjs +2 -2
  48. package/dist/components/index.js +1052 -72
  49. package/dist/components/index.js.map +1 -1
  50. package/dist/components/index.mjs +6 -3
  51. package/dist/components/usage-banner.d.ts +2 -1
  52. package/dist/components/usage-banner.js +6 -2
  53. package/dist/components/usage-banner.js.map +1 -1
  54. package/dist/components/usage-banner.mjs +1 -1
  55. package/dist/hooks/index.d.ts +5 -5
  56. package/dist/hooks/index.js +58 -26
  57. package/dist/hooks/index.js.map +1 -1
  58. package/dist/hooks/index.mjs +13 -10
  59. package/dist/hooks/use-coagent.d.ts +1 -1
  60. package/dist/hooks/use-coagent.js +18 -6
  61. package/dist/hooks/use-coagent.js.map +1 -1
  62. package/dist/hooks/use-coagent.mjs +8 -5
  63. package/dist/hooks/use-copilot-chat-headless_c.d.ts +33 -0
  64. package/dist/hooks/{use-copilot-chat-light.js → use-copilot-chat-headless_c.js} +88 -19
  65. package/dist/hooks/use-copilot-chat-headless_c.js.map +1 -0
  66. package/dist/hooks/{use-copilot-chat-light.mjs → use-copilot-chat-headless_c.mjs} +14 -8
  67. package/dist/hooks/use-copilot-chat-headless_c.mjs.map +1 -0
  68. package/dist/hooks/use-copilot-chat.d.ts +85 -4
  69. package/dist/hooks/use-copilot-chat.js +38 -61
  70. package/dist/hooks/use-copilot-chat.js.map +1 -1
  71. package/dist/hooks/use-copilot-chat.mjs +8 -8
  72. package/dist/hooks/use-copilot-chat_internal.d.ts +98 -12
  73. package/dist/hooks/use-copilot-chat_internal.js +13 -1
  74. package/dist/hooks/use-copilot-chat_internal.js.map +1 -1
  75. package/dist/hooks/use-copilot-chat_internal.mjs +7 -4
  76. package/dist/hooks/use-langgraph-interrupt.js +13 -1
  77. package/dist/hooks/use-langgraph-interrupt.js.map +1 -1
  78. package/dist/hooks/use-langgraph-interrupt.mjs +8 -5
  79. package/dist/index.d.ts +3 -3
  80. package/dist/index.js +1203 -200
  81. package/dist/index.js.map +1 -1
  82. package/dist/index.mjs +14 -11
  83. package/dist/lib/copilot-task.js.map +1 -1
  84. package/dist/lib/copilot-task.mjs +7 -4
  85. package/dist/lib/index.js.map +1 -1
  86. package/dist/lib/index.mjs +7 -4
  87. package/dist/utils/extract.js.map +1 -1
  88. package/dist/utils/extract.mjs +6 -3
  89. package/dist/utils/index.js.map +1 -1
  90. package/dist/utils/index.mjs +6 -3
  91. package/dist/utils/suggestions.js.map +1 -1
  92. package/dist/utils/suggestions.mjs +6 -3
  93. package/package.json +3 -3
  94. package/src/components/copilot-provider/copilotkit-props.tsx +10 -1
  95. package/src/components/copilot-provider/copilotkit.tsx +25 -16
  96. package/src/components/dev-console/console-trigger.tsx +190 -0
  97. package/src/components/dev-console/developer-console-modal.tsx +866 -0
  98. package/src/components/dev-console/icons.tsx +101 -0
  99. package/src/components/usage-banner.tsx +8 -3
  100. package/src/hooks/index.ts +6 -7
  101. package/src/hooks/use-coagent.ts +6 -11
  102. package/src/hooks/use-copilot-chat-headless_c.ts +257 -0
  103. package/src/hooks/use-copilot-chat.ts +103 -154
  104. package/src/hooks/use-copilot-chat_internal.ts +122 -15
  105. package/dist/chunk-AWFAFFO5.mjs.map +0 -1
  106. package/dist/chunk-GRCHDHC4.mjs.map +0 -1
  107. package/dist/chunk-MWHILKQH.mjs +0 -18
  108. package/dist/chunk-MWHILKQH.mjs.map +0 -1
  109. package/dist/chunk-PHIMGB3K.mjs.map +0 -1
  110. package/dist/chunk-TTI4Z6GK.mjs.map +0 -1
  111. package/dist/chunk-VSH4JSN3.mjs.map +0 -1
  112. package/dist/hooks/use-copilot-chat-light.d.ts +0 -211
  113. package/dist/hooks/use-copilot-chat-light.js.map +0 -1
  114. package/src/hooks/use-copilot-chat-light.ts +0 -219
  115. /package/dist/{chunk-VH45SC6Z.mjs.map → chunk-2GRWTU7W.mjs.map} +0 -0
  116. /package/dist/{chunk-ZTZJIDRJ.mjs.map → chunk-N4VN2B5S.mjs.map} +0 -0
  117. /package/dist/{chunk-FTP6FDYS.mjs.map → chunk-NTH42BY5.mjs.map} +0 -0
  118. /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: "Get Free API Key",
223
+ label: "Show me how",
223
224
  onClick: () =>
224
- window.open("https://cloud.copilotkit.ai", "_blank", "noopener,noreferrer"),
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:
@@ -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 { useCopilotChatLight } from "./use-copilot-chat-light";
6
- export type {
7
- UseCopilotChatLightOptions,
8
- UseCopilotChatLightReturn,
9
- } from "./use-copilot-chat-light";
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";
@@ -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 { appendMessage, runChatCompletion } = useCopilotChat();
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(), appendMessage, runChatCompletion, hint);
349
+ await runAgent(name, context, getMessagesFromTap(), sendMessage, runChatCompletion, hint);
355
350
  },
356
- [name, context, appendMessage, runChatCompletion],
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
- appendMessage: (message: Message) => Promise<void>,
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 appendMessage(hintMessage);
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
+ };