@copilotkit/react-core 0.20.0-demofixes.2 → 0.20.0-tools.1

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 (66) hide show
  1. package/.turbo/turbo-build.log +143 -147
  2. package/CHANGELOG.md +3 -14
  3. package/dist/{chunk-KZNQLITJ.mjs → chunk-AVLJ3AWG.mjs} +2 -2
  4. package/dist/{chunk-ABXVFQLN.mjs → chunk-NW27C3BV.mjs} +39 -7
  5. package/dist/chunk-NW27C3BV.mjs.map +1 -0
  6. package/dist/components/copilot-provider/copilotkit.mjs +8 -439
  7. package/dist/components/copilot-provider/copilotkit.mjs.map +1 -1
  8. package/dist/components/copilot-provider/index.mjs +9 -439
  9. package/dist/components/copilot-provider/index.mjs.map +1 -1
  10. package/dist/components/copilot-provider/standard-copilot-api-config.mjs +4 -9
  11. package/dist/components/copilot-provider/standard-copilot-api-config.mjs.map +1 -1
  12. package/dist/components/index.mjs +10 -439
  13. package/dist/components/index.mjs.map +1 -1
  14. package/dist/context/copilot-context.mjs +5 -63
  15. package/dist/context/copilot-context.mjs.map +1 -1
  16. package/dist/context/index.mjs +6 -63
  17. package/dist/context/index.mjs.map +1 -1
  18. package/dist/hooks/index.js +39 -7
  19. package/dist/hooks/index.js.map +1 -1
  20. package/dist/hooks/index.mjs +21 -392
  21. package/dist/hooks/index.mjs.map +1 -1
  22. package/dist/hooks/use-chat.js +38 -6
  23. package/dist/hooks/use-chat.js.map +1 -1
  24. package/dist/hooks/use-chat.mjs +4 -204
  25. package/dist/hooks/use-chat.mjs.map +1 -1
  26. package/dist/hooks/use-copilot-chat.js +39 -7
  27. package/dist/hooks/use-copilot-chat.js.map +1 -1
  28. package/dist/hooks/use-copilot-chat.mjs +13 -340
  29. package/dist/hooks/use-copilot-chat.mjs.map +1 -1
  30. package/dist/hooks/use-flat-category-store.mjs +4 -65
  31. package/dist/hooks/use-flat-category-store.mjs.map +1 -1
  32. package/dist/hooks/use-make-copilot-actionable.mjs +5 -85
  33. package/dist/hooks/use-make-copilot-actionable.mjs.map +1 -1
  34. package/dist/hooks/use-make-copilot-document-readable.mjs +5 -77
  35. package/dist/hooks/use-make-copilot-document-readable.mjs.map +1 -1
  36. package/dist/hooks/use-make-copilot-readable.mjs +5 -77
  37. package/dist/hooks/use-make-copilot-readable.mjs.map +1 -1
  38. package/dist/hooks/use-tree.mjs +4 -150
  39. package/dist/hooks/use-tree.mjs.map +1 -1
  40. package/dist/index.js +40 -8
  41. package/dist/index.js.map +1 -1
  42. package/dist/index.mjs +46 -979
  43. package/dist/index.mjs.map +1 -1
  44. package/dist/lib/copilot-task.mjs +11 -183
  45. package/dist/lib/copilot-task.mjs.map +1 -1
  46. package/dist/lib/index.mjs +12 -183
  47. package/dist/lib/index.mjs.map +1 -1
  48. package/dist/openai-assistants/hooks/index.mjs +14 -228
  49. package/dist/openai-assistants/hooks/index.mjs.map +1 -1
  50. package/dist/openai-assistants/hooks/use-assistants.mjs +7 -45
  51. package/dist/openai-assistants/hooks/use-assistants.mjs.map +1 -1
  52. package/dist/openai-assistants/hooks/use-copilot-chat-v2.mjs +14 -228
  53. package/dist/openai-assistants/hooks/use-copilot-chat-v2.mjs.map +1 -1
  54. package/dist/openai-assistants/index.mjs +17 -228
  55. package/dist/openai-assistants/index.mjs.map +1 -1
  56. package/dist/openai-assistants/utils/index.mjs +5 -43
  57. package/dist/openai-assistants/utils/index.mjs.map +1 -1
  58. package/dist/openai-assistants/utils/process-message-stream.mjs +4 -43
  59. package/dist/openai-assistants/utils/process-message-stream.mjs.map +1 -1
  60. package/dist/types/index.mjs +1 -0
  61. package/dist/utils/fetch-chat-completion.mjs +5 -99
  62. package/dist/utils/fetch-chat-completion.mjs.map +1 -1
  63. package/package.json +4 -4
  64. package/src/hooks/use-chat.ts +57 -6
  65. package/dist/chunk-ABXVFQLN.mjs.map +0 -1
  66. /package/dist/{chunk-KZNQLITJ.mjs.map → chunk-AVLJ3AWG.mjs.map} +0 -0
@@ -1,5 +1,5 @@
1
1
  import { useRef, useState } from "react";
2
- import { Message, ToolDefinition, FunctionCallHandler } from "@copilotkit/shared";
2
+ import { Message, ToolDefinition, FunctionCallHandler, encodeResult } from "@copilotkit/shared";
3
3
  import { nanoid } from "nanoid";
4
4
  import { fetchAndDecodeChatCompletion } from "../utils/fetch-chat-completion";
5
5
  import { CopilotApiConfig } from "../context";
@@ -116,19 +116,23 @@ export function useChat(options: UseChatOptionsWithCopilotConfig): UseChatHelper
116
116
  }
117
117
 
118
118
  const reader = response.events.getReader();
119
+
120
+ // Whether to feed back the new messages to GPT
121
+ let feedback = false;
122
+
119
123
  try {
120
124
  while (true) {
121
125
  const { done, value } = await reader.read();
122
126
 
123
127
  if (done) {
124
- return newMessages.slice();
128
+ break;
125
129
  }
126
130
 
127
131
  let currentMessage = Object.assign({}, newMessages[newMessages.length - 1]);
128
132
 
129
133
  if (value.type === "content") {
130
- if (currentMessage.function_call) {
131
- // Create a new message if the previous one is a function call
134
+ if (currentMessage.function_call || currentMessage.role === "function") {
135
+ // Create a new message if the previous one is a function call or result
132
136
  currentMessage = {
133
137
  id: nanoid(),
134
138
  createdAt: new Date(),
@@ -140,9 +144,26 @@ export function useChat(options: UseChatOptionsWithCopilotConfig): UseChatHelper
140
144
  currentMessage.content += value.content;
141
145
  newMessages[newMessages.length - 1] = currentMessage;
142
146
  setMessages([...messages, ...newMessages]);
147
+ } else if (value.type === "result") {
148
+ // When we get a result message, it is already complete
149
+ currentMessage = {
150
+ id: nanoid(),
151
+ role: "function",
152
+ content: value.content,
153
+ name: value.name,
154
+ };
155
+ newMessages.push(currentMessage);
156
+ setMessages([...messages, ...newMessages]);
157
+
158
+ // After receiving a result, feed back the new messages to GPT
159
+ feedback = true;
143
160
  } else if (value.type === "function") {
144
161
  // Create a new message if the previous one is not empty
145
- if (currentMessage.content != "" || currentMessage.function_call) {
162
+ if (
163
+ currentMessage.content != "" ||
164
+ currentMessage.function_call ||
165
+ currentMessage.role == "function"
166
+ ) {
146
167
  currentMessage = {
147
168
  id: nanoid(),
148
169
  createdAt: new Date(),
@@ -154,15 +175,45 @@ export function useChat(options: UseChatOptionsWithCopilotConfig): UseChatHelper
154
175
  currentMessage.function_call = {
155
176
  name: value.name,
156
177
  arguments: JSON.stringify(value.arguments),
178
+ scope: value.scope,
157
179
  };
158
180
 
159
181
  newMessages[newMessages.length - 1] = currentMessage;
160
182
  setMessages([...messages, ...newMessages]);
161
183
 
162
184
  // Execute the function call
163
- await options.onFunctionCall?.(messages, currentMessage.function_call);
185
+ try {
186
+ if (options.onFunctionCall && value.scope === "client") {
187
+ const result = await options.onFunctionCall(messages, currentMessage.function_call);
188
+
189
+ currentMessage = {
190
+ id: nanoid(),
191
+ role: "function",
192
+ content: encodeResult(result),
193
+ name: currentMessage.function_call!.name!,
194
+ };
195
+ newMessages.push(currentMessage);
196
+ setMessages([...messages, ...newMessages]);
197
+
198
+ // After a function call, feed back the new messages to GPT
199
+ feedback = true;
200
+ }
201
+ } catch (error) {
202
+ console.error("Failed to execute function call", error);
203
+ // TODO: Handle error
204
+ // this should go to the message itself
205
+ }
164
206
  }
165
207
  }
208
+
209
+ // If we want feedback, run the completion again and return the results
210
+ if (feedback) {
211
+ return await runChatCompletion([...messages, ...newMessages]);
212
+ }
213
+ // otherwise, return the new messages
214
+ else {
215
+ return newMessages.slice();
216
+ }
166
217
  } finally {
167
218
  setIsLoading(false);
168
219
  }
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/hooks/use-chat.ts"],"sourcesContent":["import { useRef, useState } from \"react\";\nimport { Message, ToolDefinition, FunctionCallHandler } from \"@copilotkit/shared\";\nimport { nanoid } from \"nanoid\";\nimport { fetchAndDecodeChatCompletion } from \"../utils/fetch-chat-completion\";\nimport { CopilotApiConfig } from \"../context\";\n\nexport type UseChatOptions = {\n /**\n * The API endpoint that accepts a `{ messages: Message[] }` object and returns\n * a stream of tokens of the AI chat response. Defaults to `/api/chat`.\n */\n api?: string;\n /**\n * A unique identifier for the chat. If not provided, a random one will be\n * generated. When provided, the `useChat` hook with the same `id` will\n * have shared states across components.\n */\n id?: string;\n /**\n * System messages of the chat. Defaults to an empty array.\n */\n initialMessages?: Message[];\n /**\n * Callback function to be called when a function call is received.\n * If the function returns a `ChatRequest` object, the request will be sent\n * automatically to the API and will be used to update the chat.\n */\n onFunctionCall?: FunctionCallHandler;\n /**\n * HTTP headers to be sent with the API request.\n */\n headers?: Record<string, string> | Headers;\n /**\n * Extra body object to be sent with the API request.\n * @example\n * Send a `sessionId` to the API along with the messages.\n * ```js\n * useChat({\n * body: {\n * sessionId: '123',\n * }\n * })\n * ```\n */\n body?: object;\n /**\n * Function definitions to be sent to the API.\n */\n tools?: ToolDefinition[];\n};\n\nexport type UseChatHelpers = {\n /** Current messages in the chat */\n messages: Message[];\n /**\n * Append a user message to the chat list. This triggers the API call to fetch\n * the assistant's response.\n * @param message The message to append\n */\n append: (message: Message) => Promise<void>;\n /**\n * Reload the last AI chat response for the given chat history. If the last\n * message isn't from the assistant, it will request the API to generate a\n * new response.\n */\n reload: () => Promise<void>;\n /**\n * Abort the current request immediately, keep the generated tokens if any.\n */\n stop: () => void;\n /** The current value of the input */\n input: string;\n /** setState-powered method to update the input value */\n setInput: React.Dispatch<React.SetStateAction<string>>;\n /** Whether the API request is in progress */\n isLoading: boolean;\n};\n\nexport type UseChatOptionsWithCopilotConfig = UseChatOptions & {\n copilotConfig: CopilotApiConfig;\n};\n\nexport function useChat(options: UseChatOptionsWithCopilotConfig): UseChatHelpers {\n const [messages, setMessages] = useState<Message[]>([]);\n const [input, setInput] = useState(\"\");\n const [isLoading, setIsLoading] = useState(false);\n const abortControllerRef = useRef<AbortController>();\n\n const runChatCompletion = async (messages: Message[]): Promise<Message[]> => {\n setIsLoading(true);\n\n const newMessages: Message[] = [\n {\n id: nanoid(),\n createdAt: new Date(),\n content: \"\",\n role: \"assistant\",\n },\n ];\n const abortController = new AbortController();\n abortControllerRef.current = abortController;\n\n setMessages([...messages, ...newMessages]);\n\n const messagesWithContext = [...(options.initialMessages || []), ...messages];\n const response = await fetchAndDecodeChatCompletion({\n copilotConfig: options.copilotConfig,\n messages: messagesWithContext,\n tools: options.tools,\n headers: options.headers,\n signal: abortController.signal,\n });\n\n if (!response.events) {\n throw new Error(\"Failed to fetch chat completion\");\n }\n\n const reader = response.events.getReader();\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n return newMessages.slice();\n }\n\n let currentMessage = Object.assign({}, newMessages[newMessages.length - 1]);\n\n if (value.type === \"content\") {\n if (currentMessage.function_call) {\n // Create a new message if the previous one is a function call\n currentMessage = {\n id: nanoid(),\n createdAt: new Date(),\n content: \"\",\n role: \"assistant\",\n };\n newMessages.push(currentMessage);\n }\n currentMessage.content += value.content;\n newMessages[newMessages.length - 1] = currentMessage;\n setMessages([...messages, ...newMessages]);\n } else if (value.type === \"function\") {\n // Create a new message if the previous one is not empty\n if (currentMessage.content != \"\" || currentMessage.function_call) {\n currentMessage = {\n id: nanoid(),\n createdAt: new Date(),\n content: \"\",\n role: \"assistant\",\n };\n newMessages.push(currentMessage);\n }\n currentMessage.function_call = {\n name: value.name,\n arguments: JSON.stringify(value.arguments),\n };\n\n newMessages[newMessages.length - 1] = currentMessage;\n setMessages([...messages, ...newMessages]);\n\n // Execute the function call\n await options.onFunctionCall?.(messages, currentMessage.function_call);\n }\n }\n } finally {\n setIsLoading(false);\n }\n };\n\n const runChatCompletionAndHandleFunctionCall = async (messages: Message[]): Promise<void> => {\n await runChatCompletion(messages);\n };\n\n const append = async (message: Message): Promise<void> => {\n if (isLoading) {\n return;\n }\n const newMessages = [...messages, message];\n setMessages(newMessages);\n return runChatCompletionAndHandleFunctionCall(newMessages);\n };\n\n const reload = async (): Promise<void> => {\n if (isLoading || messages.length === 0) {\n return;\n }\n let newMessages = [...messages];\n const lastMessage = messages[messages.length - 1];\n\n if (lastMessage.role === \"assistant\") {\n newMessages = newMessages.slice(0, -1);\n }\n setMessages(newMessages);\n\n return runChatCompletionAndHandleFunctionCall(newMessages);\n };\n\n const stop = (): void => {\n abortControllerRef.current?.abort();\n };\n\n return {\n messages,\n append,\n reload,\n stop,\n isLoading,\n input,\n setInput,\n };\n}\n"],"mappings":";;;;;;;;AAAA,SAAS,QAAQ,gBAAgB;AAEjC,SAAS,cAAc;AAgFhB,SAAS,QAAQ,SAA0D;AAChF,QAAM,CAAC,UAAU,WAAW,IAAI,SAAoB,CAAC,CAAC;AACtD,QAAM,CAAC,OAAO,QAAQ,IAAI,SAAS,EAAE;AACrC,QAAM,CAAC,WAAW,YAAY,IAAI,SAAS,KAAK;AAChD,QAAM,qBAAqB,OAAwB;AAEnD,QAAM,oBAAoB,CAAOA,cAA4C;AAxF/E;AAyFI,iBAAa,IAAI;AAEjB,UAAM,cAAyB;AAAA,MAC7B;AAAA,QACE,IAAI,OAAO;AAAA,QACX,WAAW,oBAAI,KAAK;AAAA,QACpB,SAAS;AAAA,QACT,MAAM;AAAA,MACR;AAAA,IACF;AACA,UAAM,kBAAkB,IAAI,gBAAgB;AAC5C,uBAAmB,UAAU;AAE7B,gBAAY,CAAC,GAAGA,WAAU,GAAG,WAAW,CAAC;AAEzC,UAAM,sBAAsB,CAAC,GAAI,QAAQ,mBAAmB,CAAC,GAAI,GAAGA,SAAQ;AAC5E,UAAM,WAAW,MAAM,6BAA6B;AAAA,MAClD,eAAe,QAAQ;AAAA,MACvB,UAAU;AAAA,MACV,OAAO,QAAQ;AAAA,MACf,SAAS,QAAQ;AAAA,MACjB,QAAQ,gBAAgB;AAAA,IAC1B,CAAC;AAED,QAAI,CAAC,SAAS,QAAQ;AACpB,YAAM,IAAI,MAAM,iCAAiC;AAAA,IACnD;AAEA,UAAM,SAAS,SAAS,OAAO,UAAU;AACzC,QAAI;AACF,aAAO,MAAM;AACX,cAAM,EAAE,MAAM,MAAM,IAAI,MAAM,OAAO,KAAK;AAE1C,YAAI,MAAM;AACR,iBAAO,YAAY,MAAM;AAAA,QAC3B;AAEA,YAAI,iBAAiB,OAAO,OAAO,CAAC,GAAG,YAAY,YAAY,SAAS,CAAC,CAAC;AAE1E,YAAI,MAAM,SAAS,WAAW;AAC5B,cAAI,eAAe,eAAe;AAEhC,6BAAiB;AAAA,cACf,IAAI,OAAO;AAAA,cACX,WAAW,oBAAI,KAAK;AAAA,cACpB,SAAS;AAAA,cACT,MAAM;AAAA,YACR;AACA,wBAAY,KAAK,cAAc;AAAA,UACjC;AACA,yBAAe,WAAW,MAAM;AAChC,sBAAY,YAAY,SAAS,CAAC,IAAI;AACtC,sBAAY,CAAC,GAAGA,WAAU,GAAG,WAAW,CAAC;AAAA,QAC3C,WAAW,MAAM,SAAS,YAAY;AAEpC,cAAI,eAAe,WAAW,MAAM,eAAe,eAAe;AAChE,6BAAiB;AAAA,cACf,IAAI,OAAO;AAAA,cACX,WAAW,oBAAI,KAAK;AAAA,cACpB,SAAS;AAAA,cACT,MAAM;AAAA,YACR;AACA,wBAAY,KAAK,cAAc;AAAA,UACjC;AACA,yBAAe,gBAAgB;AAAA,YAC7B,MAAM,MAAM;AAAA,YACZ,WAAW,KAAK,UAAU,MAAM,SAAS;AAAA,UAC3C;AAEA,sBAAY,YAAY,SAAS,CAAC,IAAI;AACtC,sBAAY,CAAC,GAAGA,WAAU,GAAG,WAAW,CAAC;AAGzC,iBAAM,aAAQ,mBAAR,iCAAyBA,WAAU,eAAe;AAAA,QAC1D;AAAA,MACF;AAAA,IACF,UAAE;AACA,mBAAa,KAAK;AAAA,IACpB;AAAA,EACF;AAEA,QAAM,yCAAyC,CAAOA,cAAuC;AAC3F,UAAM,kBAAkBA,SAAQ;AAAA,EAClC;AAEA,QAAM,SAAS,CAAO,YAAoC;AACxD,QAAI,WAAW;AACb;AAAA,IACF;AACA,UAAM,cAAc,CAAC,GAAG,UAAU,OAAO;AACzC,gBAAY,WAAW;AACvB,WAAO,uCAAuC,WAAW;AAAA,EAC3D;AAEA,QAAM,SAAS,MAA2B;AACxC,QAAI,aAAa,SAAS,WAAW,GAAG;AACtC;AAAA,IACF;AACA,QAAI,cAAc,CAAC,GAAG,QAAQ;AAC9B,UAAM,cAAc,SAAS,SAAS,SAAS,CAAC;AAEhD,QAAI,YAAY,SAAS,aAAa;AACpC,oBAAc,YAAY,MAAM,GAAG,EAAE;AAAA,IACvC;AACA,gBAAY,WAAW;AAEvB,WAAO,uCAAuC,WAAW;AAAA,EAC3D;AAEA,QAAM,OAAO,MAAY;AAtM3B;AAuMI,6BAAmB,YAAnB,mBAA4B;AAAA,EAC9B;AAEA,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;","names":["messages"]}