@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.
- package/.turbo/turbo-build.log +143 -147
- package/CHANGELOG.md +3 -14
- package/dist/{chunk-KZNQLITJ.mjs → chunk-AVLJ3AWG.mjs} +2 -2
- package/dist/{chunk-ABXVFQLN.mjs → chunk-NW27C3BV.mjs} +39 -7
- package/dist/chunk-NW27C3BV.mjs.map +1 -0
- package/dist/components/copilot-provider/copilotkit.mjs +8 -439
- package/dist/components/copilot-provider/copilotkit.mjs.map +1 -1
- package/dist/components/copilot-provider/index.mjs +9 -439
- package/dist/components/copilot-provider/index.mjs.map +1 -1
- package/dist/components/copilot-provider/standard-copilot-api-config.mjs +4 -9
- package/dist/components/copilot-provider/standard-copilot-api-config.mjs.map +1 -1
- package/dist/components/index.mjs +10 -439
- package/dist/components/index.mjs.map +1 -1
- package/dist/context/copilot-context.mjs +5 -63
- package/dist/context/copilot-context.mjs.map +1 -1
- package/dist/context/index.mjs +6 -63
- package/dist/context/index.mjs.map +1 -1
- package/dist/hooks/index.js +39 -7
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/index.mjs +21 -392
- package/dist/hooks/index.mjs.map +1 -1
- package/dist/hooks/use-chat.js +38 -6
- package/dist/hooks/use-chat.js.map +1 -1
- package/dist/hooks/use-chat.mjs +4 -204
- package/dist/hooks/use-chat.mjs.map +1 -1
- package/dist/hooks/use-copilot-chat.js +39 -7
- package/dist/hooks/use-copilot-chat.js.map +1 -1
- package/dist/hooks/use-copilot-chat.mjs +13 -340
- package/dist/hooks/use-copilot-chat.mjs.map +1 -1
- package/dist/hooks/use-flat-category-store.mjs +4 -65
- package/dist/hooks/use-flat-category-store.mjs.map +1 -1
- package/dist/hooks/use-make-copilot-actionable.mjs +5 -85
- package/dist/hooks/use-make-copilot-actionable.mjs.map +1 -1
- package/dist/hooks/use-make-copilot-document-readable.mjs +5 -77
- package/dist/hooks/use-make-copilot-document-readable.mjs.map +1 -1
- package/dist/hooks/use-make-copilot-readable.mjs +5 -77
- package/dist/hooks/use-make-copilot-readable.mjs.map +1 -1
- package/dist/hooks/use-tree.mjs +4 -150
- package/dist/hooks/use-tree.mjs.map +1 -1
- package/dist/index.js +40 -8
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +46 -979
- package/dist/index.mjs.map +1 -1
- package/dist/lib/copilot-task.mjs +11 -183
- package/dist/lib/copilot-task.mjs.map +1 -1
- package/dist/lib/index.mjs +12 -183
- package/dist/lib/index.mjs.map +1 -1
- package/dist/openai-assistants/hooks/index.mjs +14 -228
- package/dist/openai-assistants/hooks/index.mjs.map +1 -1
- package/dist/openai-assistants/hooks/use-assistants.mjs +7 -45
- package/dist/openai-assistants/hooks/use-assistants.mjs.map +1 -1
- package/dist/openai-assistants/hooks/use-copilot-chat-v2.mjs +14 -228
- package/dist/openai-assistants/hooks/use-copilot-chat-v2.mjs.map +1 -1
- package/dist/openai-assistants/index.mjs +17 -228
- package/dist/openai-assistants/index.mjs.map +1 -1
- package/dist/openai-assistants/utils/index.mjs +5 -43
- package/dist/openai-assistants/utils/index.mjs.map +1 -1
- package/dist/openai-assistants/utils/process-message-stream.mjs +4 -43
- package/dist/openai-assistants/utils/process-message-stream.mjs.map +1 -1
- package/dist/types/index.mjs +1 -0
- package/dist/utils/fetch-chat-completion.mjs +5 -99
- package/dist/utils/fetch-chat-completion.mjs.map +1 -1
- package/package.json +4 -4
- package/src/hooks/use-chat.ts +57 -6
- package/dist/chunk-ABXVFQLN.mjs.map +0 -1
- /package/dist/{chunk-KZNQLITJ.mjs.map → chunk-AVLJ3AWG.mjs.map} +0 -0
package/src/hooks/use-chat.ts
CHANGED
|
@@ -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
|
-
|
|
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 (
|
|
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
|
-
|
|
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":"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","names":["messages"]}
|
|
File without changes
|