@copilotkit/react-ui 1.5.15-next.3 → 1.5.15-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 +12 -0
- package/dist/{chunk-34FREWVK.mjs → chunk-6FTRYYR5.mjs} +4 -1
- package/dist/chunk-6FTRYYR5.mjs.map +1 -0
- package/dist/{chunk-6ZBXFJHS.mjs → chunk-7D6TIVZ6.mjs} +3 -3
- package/dist/{chunk-I37TTM3T.mjs → chunk-NCM42YQL.mjs} +2 -2
- package/dist/{chunk-R5ZETDHL.mjs → chunk-PGXWPTAW.mjs} +2 -2
- package/dist/{chunk-HBUJWEWY.mjs → chunk-Q77YGF2I.mjs} +2 -2
- package/dist/components/chat/Chat.js +28 -25
- package/dist/components/chat/Chat.js.map +1 -1
- package/dist/components/chat/Chat.mjs +2 -2
- package/dist/components/chat/Messages.js +3 -0
- package/dist/components/chat/Messages.js.map +1 -1
- package/dist/components/chat/Messages.mjs +1 -1
- package/dist/components/chat/Modal.js +28 -25
- package/dist/components/chat/Modal.js.map +1 -1
- package/dist/components/chat/Modal.mjs +3 -3
- package/dist/components/chat/Popup.js +28 -25
- package/dist/components/chat/Popup.js.map +1 -1
- package/dist/components/chat/Popup.mjs +4 -4
- package/dist/components/chat/Sidebar.js +28 -25
- package/dist/components/chat/Sidebar.js.map +1 -1
- package/dist/components/chat/Sidebar.mjs +4 -4
- package/dist/components/chat/index.js +28 -25
- package/dist/components/chat/index.js.map +1 -1
- package/dist/components/chat/index.mjs +5 -5
- package/dist/components/index.js +28 -25
- package/dist/components/index.js.map +1 -1
- package/dist/components/index.mjs +5 -5
- package/dist/index.js +30 -27
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +5 -5
- package/package.json +6 -6
- package/src/components/chat/Messages.tsx +6 -1
- package/dist/chunk-34FREWVK.mjs.map +0 -1
- /package/dist/{chunk-6ZBXFJHS.mjs.map → chunk-7D6TIVZ6.mjs.map} +0 -0
- /package/dist/{chunk-I37TTM3T.mjs.map → chunk-NCM42YQL.mjs.map} +0 -0
- /package/dist/{chunk-R5ZETDHL.mjs.map → chunk-PGXWPTAW.mjs.map} +0 -0
- /package/dist/{chunk-HBUJWEWY.mjs.map → chunk-Q77YGF2I.mjs.map} +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,17 @@
|
|
|
1
1
|
# ui
|
|
2
2
|
|
|
3
|
+
## 1.5.15-next.4
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- 7b3141d: - feat(interrupt): support LG interrupt with useLangGraphInterrupt hook
|
|
8
|
+
- chore(interrupt): add e2e test to interrupt functionality
|
|
9
|
+
- feat(interrupt): add support for multiple interrupts and conditions
|
|
10
|
+
- Updated dependencies [7b3141d]
|
|
11
|
+
- @copilotkit/react-core@1.5.15-next.4
|
|
12
|
+
- @copilotkit/runtime-client-gql@1.5.15-next.4
|
|
13
|
+
- @copilotkit/shared@1.5.15-next.4
|
|
14
|
+
|
|
3
15
|
## 1.5.15-next.3
|
|
4
16
|
|
|
5
17
|
### Patch Changes
|
|
@@ -5,6 +5,7 @@ import {
|
|
|
5
5
|
// src/components/chat/Messages.tsx
|
|
6
6
|
import { useEffect, useMemo, useRef } from "react";
|
|
7
7
|
import { ResultMessage, TextMessage, Role } from "@copilotkit/runtime-client-gql";
|
|
8
|
+
import { useLangGraphInterruptRender } from "@copilotkit/react-core";
|
|
8
9
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
9
10
|
var Messages = ({
|
|
10
11
|
messages,
|
|
@@ -36,6 +37,7 @@ var Messages = ({
|
|
|
36
37
|
}
|
|
37
38
|
}
|
|
38
39
|
const { messagesEndRef, messagesContainerRef } = useScrollToBottom(messages);
|
|
40
|
+
const interrupt = useLangGraphInterruptRender();
|
|
39
41
|
return /* @__PURE__ */ jsxs("div", { className: "copilotKitMessages", ref: messagesContainerRef, children: [
|
|
40
42
|
messages.map((message, index) => {
|
|
41
43
|
const isCurrentMessage = index === messages.length - 1;
|
|
@@ -94,6 +96,7 @@ var Messages = ({
|
|
|
94
96
|
);
|
|
95
97
|
}
|
|
96
98
|
}),
|
|
99
|
+
interrupt,
|
|
97
100
|
/* @__PURE__ */ jsx("footer", { ref: messagesEndRef, children })
|
|
98
101
|
] });
|
|
99
102
|
};
|
|
@@ -177,4 +180,4 @@ export {
|
|
|
177
180
|
Messages,
|
|
178
181
|
useScrollToBottom
|
|
179
182
|
};
|
|
180
|
-
//# sourceMappingURL=chunk-
|
|
183
|
+
//# sourceMappingURL=chunk-6FTRYYR5.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/chat/Messages.tsx"],"sourcesContent":["import { useCallback, useEffect, useMemo, useRef } from \"react\";\nimport { MessagesProps } from \"./props\";\nimport { useChatContext } from \"./ChatContext\";\nimport { Message, ResultMessage, TextMessage, Role } from \"@copilotkit/runtime-client-gql\";\nimport { useLangGraphInterruptRender } from \"@copilotkit/react-core\";\n\nexport const Messages = ({\n messages,\n inProgress,\n children,\n RenderTextMessage,\n RenderActionExecutionMessage,\n RenderAgentStateMessage,\n RenderResultMessage,\n AssistantMessage,\n UserMessage,\n}: MessagesProps) => {\n const context = useChatContext();\n const initialMessages = useMemo(\n () => makeInitialMessages(context.labels.initial),\n [context.labels.initial],\n );\n\n messages = [...initialMessages, ...messages];\n\n const actionResults: Record<string, string> = {};\n\n for (let i = 0; i < messages.length; i++) {\n if (messages[i].isActionExecutionMessage()) {\n const id = messages[i].id;\n const resultMessage: ResultMessage | undefined = messages.find(\n (message) => message.isResultMessage() && message.actionExecutionId === id,\n ) as ResultMessage | undefined;\n\n if (resultMessage) {\n actionResults[id] = ResultMessage.decodeResult(resultMessage.result || \"\");\n }\n }\n }\n\n const { messagesEndRef, messagesContainerRef } = useScrollToBottom(messages);\n\n const interrupt = useLangGraphInterruptRender();\n\n return (\n <div className=\"copilotKitMessages\" ref={messagesContainerRef}>\n {messages.map((message, index) => {\n const isCurrentMessage = index === messages.length - 1;\n\n if (message.isTextMessage()) {\n return (\n <RenderTextMessage\n key={index}\n message={message}\n inProgress={inProgress}\n index={index}\n isCurrentMessage={isCurrentMessage}\n AssistantMessage={AssistantMessage}\n UserMessage={UserMessage}\n />\n );\n } else if (message.isActionExecutionMessage()) {\n return (\n <RenderActionExecutionMessage\n key={index}\n message={message}\n inProgress={inProgress}\n index={index}\n isCurrentMessage={isCurrentMessage}\n actionResult={actionResults[message.id]}\n AssistantMessage={AssistantMessage}\n UserMessage={UserMessage}\n />\n );\n } else if (message.isAgentStateMessage()) {\n return (\n <RenderAgentStateMessage\n key={index}\n message={message}\n inProgress={inProgress}\n index={index}\n isCurrentMessage={isCurrentMessage}\n AssistantMessage={AssistantMessage}\n UserMessage={UserMessage}\n />\n );\n } else if (message.isResultMessage()) {\n return (\n <RenderResultMessage\n key={index}\n message={message}\n inProgress={inProgress}\n index={index}\n isCurrentMessage={isCurrentMessage}\n AssistantMessage={AssistantMessage}\n UserMessage={UserMessage}\n />\n );\n }\n })}\n {interrupt}\n <footer ref={messagesEndRef}>{children}</footer>\n </div>\n );\n};\n\nfunction makeInitialMessages(initial?: string | string[]): Message[] {\n let initialArray: string[] = [];\n if (initial) {\n if (Array.isArray(initial)) {\n initialArray.push(...initial);\n } else {\n initialArray.push(initial);\n }\n }\n\n return initialArray.map(\n (message) =>\n new TextMessage({\n role: Role.Assistant,\n content: message,\n }),\n );\n}\nexport function useScrollToBottom(messages: any[]) {\n const messagesEndRef = useRef<HTMLDivElement>(null);\n const messagesContainerRef = useRef<HTMLDivElement | null>(null);\n const isProgrammaticScrollRef = useRef(false);\n const isUserScrollUpRef = useRef(false);\n\n const scrollToBottom = () => {\n if (messagesEndRef.current) {\n isProgrammaticScrollRef.current = true;\n messagesEndRef.current.scrollIntoView({\n behavior: \"auto\",\n });\n }\n };\n\n const handleScroll = () => {\n if (isProgrammaticScrollRef.current) {\n isProgrammaticScrollRef.current = false;\n return;\n }\n\n if (messagesContainerRef.current) {\n const { scrollTop, scrollHeight, clientHeight } = messagesContainerRef.current;\n isUserScrollUpRef.current = scrollTop + clientHeight < scrollHeight;\n }\n };\n\n useEffect(() => {\n const container = messagesContainerRef.current;\n if (container) {\n container.addEventListener(\"scroll\", handleScroll);\n }\n return () => {\n if (container) {\n container.removeEventListener(\"scroll\", handleScroll);\n }\n };\n }, []);\n\n useEffect(() => {\n const container = messagesContainerRef.current;\n if (!container) {\n return;\n }\n\n const mutationObserver = new MutationObserver(() => {\n if (!isUserScrollUpRef.current) {\n scrollToBottom();\n }\n });\n\n mutationObserver.observe(container, {\n childList: true,\n subtree: true,\n characterData: true,\n });\n\n return () => {\n mutationObserver.disconnect();\n };\n }, []);\n\n useEffect(() => {\n isUserScrollUpRef.current = false;\n scrollToBottom();\n }, [messages.filter((m) => m.isTextMessage() && m.role === Role.User).length]);\n\n return { messagesEndRef, messagesContainerRef };\n}\n"],"mappings":"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","names":[]}
|
|
@@ -9,7 +9,7 @@ import {
|
|
|
9
9
|
} from "./chunk-RQNJNK2W.mjs";
|
|
10
10
|
import {
|
|
11
11
|
CopilotChat
|
|
12
|
-
} from "./chunk-
|
|
12
|
+
} from "./chunk-Q77YGF2I.mjs";
|
|
13
13
|
import {
|
|
14
14
|
UserMessage
|
|
15
15
|
} from "./chunk-HEIDCT7I.mjs";
|
|
@@ -21,7 +21,7 @@ import {
|
|
|
21
21
|
} from "./chunk-EMQEEXUB.mjs";
|
|
22
22
|
import {
|
|
23
23
|
Messages
|
|
24
|
-
} from "./chunk-
|
|
24
|
+
} from "./chunk-6FTRYYR5.mjs";
|
|
25
25
|
import {
|
|
26
26
|
ResponseButton
|
|
27
27
|
} from "./chunk-3XAXY2Z3.mjs";
|
|
@@ -102,4 +102,4 @@ var CopilotModal = ({
|
|
|
102
102
|
export {
|
|
103
103
|
CopilotModal
|
|
104
104
|
};
|
|
105
|
-
//# sourceMappingURL=chunk-
|
|
105
|
+
//# sourceMappingURL=chunk-7D6TIVZ6.mjs.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
CopilotModal
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-7D6TIVZ6.mjs";
|
|
4
4
|
import {
|
|
5
5
|
__spreadProps,
|
|
6
6
|
__spreadValues
|
|
@@ -18,4 +18,4 @@ function CopilotPopup(props) {
|
|
|
18
18
|
export {
|
|
19
19
|
CopilotPopup
|
|
20
20
|
};
|
|
21
|
-
//# sourceMappingURL=chunk-
|
|
21
|
+
//# sourceMappingURL=chunk-NCM42YQL.mjs.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
CopilotModal
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-7D6TIVZ6.mjs";
|
|
4
4
|
import {
|
|
5
5
|
__spreadProps,
|
|
6
6
|
__spreadValues
|
|
@@ -27,4 +27,4 @@ function CopilotSidebar(props) {
|
|
|
27
27
|
export {
|
|
28
28
|
CopilotSidebar
|
|
29
29
|
};
|
|
30
|
-
//# sourceMappingURL=chunk-
|
|
30
|
+
//# sourceMappingURL=chunk-PGXWPTAW.mjs.map
|
|
@@ -28,7 +28,7 @@ import {
|
|
|
28
28
|
} from "./chunk-EMQEEXUB.mjs";
|
|
29
29
|
import {
|
|
30
30
|
Messages
|
|
31
|
-
} from "./chunk-
|
|
31
|
+
} from "./chunk-6FTRYYR5.mjs";
|
|
32
32
|
import {
|
|
33
33
|
ResponseButton
|
|
34
34
|
} from "./chunk-3XAXY2Z3.mjs";
|
|
@@ -311,4 +311,4 @@ export {
|
|
|
311
311
|
WrappedCopilotChat,
|
|
312
312
|
useCopilotChatLogic
|
|
313
313
|
};
|
|
314
|
-
//# sourceMappingURL=chunk-
|
|
314
|
+
//# sourceMappingURL=chunk-Q77YGF2I.mjs.map
|
|
@@ -390,6 +390,7 @@ var ChatContextProvider = ({
|
|
|
390
390
|
// src/components/chat/Messages.tsx
|
|
391
391
|
var import_react2 = require("react");
|
|
392
392
|
var import_runtime_client_gql = require("@copilotkit/runtime-client-gql");
|
|
393
|
+
var import_react_core = require("@copilotkit/react-core");
|
|
393
394
|
var import_jsx_runtime3 = require("react/jsx-runtime");
|
|
394
395
|
var Messages = ({
|
|
395
396
|
messages,
|
|
@@ -421,6 +422,7 @@ var Messages = ({
|
|
|
421
422
|
}
|
|
422
423
|
}
|
|
423
424
|
const { messagesEndRef, messagesContainerRef } = useScrollToBottom(messages);
|
|
425
|
+
const interrupt = (0, import_react_core.useLangGraphInterruptRender)();
|
|
424
426
|
return /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)("div", { className: "copilotKitMessages", ref: messagesContainerRef, children: [
|
|
425
427
|
messages.map((message, index) => {
|
|
426
428
|
const isCurrentMessage = index === messages.length - 1;
|
|
@@ -479,6 +481,7 @@ var Messages = ({
|
|
|
479
481
|
);
|
|
480
482
|
}
|
|
481
483
|
}),
|
|
484
|
+
interrupt,
|
|
482
485
|
/* @__PURE__ */ (0, import_jsx_runtime3.jsx)("footer", { ref: messagesEndRef, children })
|
|
483
486
|
] });
|
|
484
487
|
};
|
|
@@ -611,7 +614,7 @@ var AutoResizingTextarea = (0, import_react3.forwardRef)(
|
|
|
611
614
|
var Textarea_default = AutoResizingTextarea;
|
|
612
615
|
|
|
613
616
|
// src/hooks/use-push-to-talk.tsx
|
|
614
|
-
var
|
|
617
|
+
var import_react_core2 = require("@copilotkit/react-core");
|
|
615
618
|
var import_react4 = require("react");
|
|
616
619
|
var startRecording = (mediaStreamRef, mediaRecorderRef, audioContextRef, recordedChunks, onStop) => __async(void 0, null, function* () {
|
|
617
620
|
if (!mediaStreamRef.current || !audioContextRef.current) {
|
|
@@ -666,8 +669,8 @@ var usePushToTalk = ({
|
|
|
666
669
|
const audioContextRef = (0, import_react4.useRef)(null);
|
|
667
670
|
const mediaRecorderRef = (0, import_react4.useRef)(null);
|
|
668
671
|
const recordedChunks = (0, import_react4.useRef)([]);
|
|
669
|
-
const generalContext = (0,
|
|
670
|
-
const messagesContext = (0,
|
|
672
|
+
const generalContext = (0, import_react_core2.useCopilotContext)();
|
|
673
|
+
const messagesContext = (0, import_react_core2.useCopilotMessagesContext)();
|
|
671
674
|
const context = __spreadValues(__spreadValues({}, generalContext), messagesContext);
|
|
672
675
|
const [startReadingFromMessageId, setStartReadingFromMessageId] = (0, import_react4.useState)(null);
|
|
673
676
|
(0, import_react4.useEffect)(() => {
|
|
@@ -715,11 +718,11 @@ var usePushToTalk = ({
|
|
|
715
718
|
};
|
|
716
719
|
|
|
717
720
|
// src/components/chat/Input.tsx
|
|
718
|
-
var
|
|
721
|
+
var import_react_core3 = require("@copilotkit/react-core");
|
|
719
722
|
var import_jsx_runtime5 = require("react/jsx-runtime");
|
|
720
723
|
var Input = ({ inProgress, onSend, isVisible = false }) => {
|
|
721
724
|
const context = useChatContext();
|
|
722
|
-
const copilotContext = (0,
|
|
725
|
+
const copilotContext = (0, import_react_core3.useCopilotContext)();
|
|
723
726
|
const pushToTalkConfigured = copilotContext.copilotApiConfig.textToSpeechUrl !== void 0 && copilotContext.copilotApiConfig.transcribeAudioUrl !== void 0;
|
|
724
727
|
const textareaRef = (0, import_react5.useRef)(null);
|
|
725
728
|
const handleDivClick = (event) => {
|
|
@@ -839,10 +842,10 @@ function RenderTextMessage(props) {
|
|
|
839
842
|
|
|
840
843
|
// src/components/chat/messages/RenderActionExecutionMessage.tsx
|
|
841
844
|
var import_runtime_client_gql2 = require("@copilotkit/runtime-client-gql");
|
|
842
|
-
var
|
|
845
|
+
var import_react_core4 = require("@copilotkit/react-core");
|
|
843
846
|
var import_jsx_runtime8 = require("react/jsx-runtime");
|
|
844
847
|
function RenderActionExecutionMessage(props) {
|
|
845
|
-
const { chatComponentsCache } = (0,
|
|
848
|
+
const { chatComponentsCache } = (0, import_react_core4.useCopilotContext)();
|
|
846
849
|
const { message, inProgress, index, isCurrentMessage, actionResult, AssistantMessage: AssistantMessage2 } = props;
|
|
847
850
|
if (message.isActionExecutionMessage()) {
|
|
848
851
|
if (chatComponentsCache.current !== null && (chatComponentsCache.current.actions[message.name] || chatComponentsCache.current.actions["*"])) {
|
|
@@ -964,10 +967,10 @@ function RenderResultMessage(props) {
|
|
|
964
967
|
}
|
|
965
968
|
|
|
966
969
|
// src/components/chat/messages/RenderAgentStateMessage.tsx
|
|
967
|
-
var
|
|
970
|
+
var import_react_core5 = require("@copilotkit/react-core");
|
|
968
971
|
var import_jsx_runtime10 = require("react/jsx-runtime");
|
|
969
972
|
function RenderAgentStateMessage(props) {
|
|
970
|
-
const { chatComponentsCache } = (0,
|
|
973
|
+
const { chatComponentsCache } = (0, import_react_core5.useCopilotContext)();
|
|
971
974
|
const { message, inProgress, index, isCurrentMessage, AssistantMessage: AssistantMessage2 } = props;
|
|
972
975
|
if (message.isAgentStateMessage()) {
|
|
973
976
|
let render;
|
|
@@ -1548,7 +1551,7 @@ var UserMessage = (props) => {
|
|
|
1548
1551
|
};
|
|
1549
1552
|
|
|
1550
1553
|
// src/components/chat/Suggestion.tsx
|
|
1551
|
-
var
|
|
1554
|
+
var import_react_core6 = require("@copilotkit/react-core");
|
|
1552
1555
|
var import_shared = require("@copilotkit/shared");
|
|
1553
1556
|
var import_runtime_client_gql3 = require("@copilotkit/runtime-client-gql");
|
|
1554
1557
|
var import_jsx_runtime15 = require("react/jsx-runtime");
|
|
@@ -1583,7 +1586,7 @@ var reloadSuggestions = (context, chatSuggestionConfiguration, setCurrentSuggest
|
|
|
1583
1586
|
for (const config of Object.values(chatSuggestionConfiguration)) {
|
|
1584
1587
|
try {
|
|
1585
1588
|
const numOfSuggestionsInstructions = config.minSuggestions === 0 ? `Produce up to ${config.maxSuggestions} suggestions. If there are no highly relevant suggestions you can think of, provide an empty array.` : `Produce between ${config.minSuggestions} and ${config.maxSuggestions} suggestions.`;
|
|
1586
|
-
const result = yield (0,
|
|
1589
|
+
const result = yield (0, import_react_core6.extract)({
|
|
1587
1590
|
context,
|
|
1588
1591
|
instructions: "Suggest what the user could say next. Provide clear, highly relevant suggestions. Do not literally suggest function calls. ",
|
|
1589
1592
|
data: config.instructions + "\n\n" + numOfSuggestionsInstructions + "\n\nAvailable tools: " + tools + "\n\n",
|
|
@@ -1642,12 +1645,12 @@ var reloadSuggestions = (context, chatSuggestionConfiguration, setCurrentSuggest
|
|
|
1642
1645
|
|
|
1643
1646
|
// src/components/chat/Chat.tsx
|
|
1644
1647
|
var import_react11 = __toESM(require("react"));
|
|
1645
|
-
var
|
|
1648
|
+
var import_react_core9 = require("@copilotkit/react-core");
|
|
1646
1649
|
var import_runtime_client_gql4 = require("@copilotkit/runtime-client-gql");
|
|
1647
1650
|
var import_shared3 = require("@copilotkit/shared");
|
|
1648
1651
|
|
|
1649
1652
|
// src/components/dev-console/utils.ts
|
|
1650
|
-
var
|
|
1653
|
+
var import_react_core7 = require("@copilotkit/react-core");
|
|
1651
1654
|
function shouldShowDevConsole(showDevConsole) {
|
|
1652
1655
|
if (typeof showDevConsole === "boolean") {
|
|
1653
1656
|
return showDevConsole;
|
|
@@ -1709,7 +1712,7 @@ function getPublishedCopilotKitVersion(current, forceCheck = false) {
|
|
|
1709
1712
|
}
|
|
1710
1713
|
function logReadables(context) {
|
|
1711
1714
|
console.log("%cCurrent Readables:", "font-size: 16px; font-weight: bold;");
|
|
1712
|
-
const readables = context.getContextString([],
|
|
1715
|
+
const readables = context.getContextString([], import_react_core7.defaultCopilotContextCategories).trim();
|
|
1713
1716
|
if (readables.length === 0) {
|
|
1714
1717
|
console.log("No readables found");
|
|
1715
1718
|
return;
|
|
@@ -1779,7 +1782,7 @@ function logMessages(context) {
|
|
|
1779
1782
|
}
|
|
1780
1783
|
|
|
1781
1784
|
// src/components/dev-console/console.tsx
|
|
1782
|
-
var
|
|
1785
|
+
var import_react_core8 = require("@copilotkit/react-core");
|
|
1783
1786
|
var import_react9 = require("react");
|
|
1784
1787
|
|
|
1785
1788
|
// src/components/dev-console/icons.tsx
|
|
@@ -2079,7 +2082,7 @@ function CopilotKitHelpModal() {
|
|
|
2079
2082
|
var import_jsx_runtime19 = require("react/jsx-runtime");
|
|
2080
2083
|
function CopilotDevConsole() {
|
|
2081
2084
|
const currentVersion = import_shared2.COPILOTKIT_VERSION;
|
|
2082
|
-
const context = (0,
|
|
2085
|
+
const context = (0, import_react_core8.useCopilotContext)();
|
|
2083
2086
|
const [showDevConsole, setShowDevConsole] = (0, import_react9.useState)(false);
|
|
2084
2087
|
(0, import_react9.useEffect)(() => {
|
|
2085
2088
|
setShowDevConsole(shouldShowDevConsole(context.showDevConsole));
|
|
@@ -2243,8 +2246,8 @@ function DebugMenuButton({
|
|
|
2243
2246
|
checkForUpdates,
|
|
2244
2247
|
mode
|
|
2245
2248
|
}) {
|
|
2246
|
-
const context = (0,
|
|
2247
|
-
const messagesContext = (0,
|
|
2249
|
+
const context = (0, import_react_core8.useCopilotContext)();
|
|
2250
|
+
const messagesContext = (0, import_react_core8.useCopilotMessagesContext)();
|
|
2248
2251
|
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: [
|
|
2249
2252
|
/* @__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: [
|
|
2250
2253
|
"Debug ",
|
|
@@ -2278,7 +2281,7 @@ function DebugMenuButton({
|
|
|
2278
2281
|
}
|
|
2279
2282
|
|
|
2280
2283
|
// src/components/chat/Chat.tsx
|
|
2281
|
-
var
|
|
2284
|
+
var import_react_core10 = require("@copilotkit/react-core");
|
|
2282
2285
|
var import_jsx_runtime20 = require("react/jsx-runtime");
|
|
2283
2286
|
function CopilotChat({
|
|
2284
2287
|
instructions,
|
|
@@ -2301,7 +2304,7 @@ function CopilotChat({
|
|
|
2301
2304
|
AssistantMessage: AssistantMessage2 = AssistantMessage,
|
|
2302
2305
|
UserMessage: UserMessage2 = UserMessage
|
|
2303
2306
|
}) {
|
|
2304
|
-
const context = (0,
|
|
2307
|
+
const context = (0, import_react_core9.useCopilotContext)();
|
|
2305
2308
|
(0, import_react11.useEffect)(() => {
|
|
2306
2309
|
context.setChatInstructions(instructions || "");
|
|
2307
2310
|
}, [instructions]);
|
|
@@ -2385,7 +2388,7 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onS
|
|
|
2385
2388
|
stopGeneration: defaultStopGeneration,
|
|
2386
2389
|
runChatCompletion,
|
|
2387
2390
|
isLoading
|
|
2388
|
-
} = (0,
|
|
2391
|
+
} = (0, import_react_core9.useCopilotChat)({
|
|
2389
2392
|
id: (0, import_shared3.randomId)(),
|
|
2390
2393
|
makeSystemMessage
|
|
2391
2394
|
});
|
|
@@ -2397,8 +2400,8 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onS
|
|
|
2397
2400
|
(_a2 = suggestionsAbortControllerRef.current) == null ? void 0 : _a2.abort();
|
|
2398
2401
|
suggestionsAbortControllerRef.current = null;
|
|
2399
2402
|
};
|
|
2400
|
-
const generalContext = (0,
|
|
2401
|
-
const messagesContext = (0,
|
|
2403
|
+
const generalContext = (0, import_react_core9.useCopilotContext)();
|
|
2404
|
+
const messagesContext = (0, import_react_core9.useCopilotMessagesContext)();
|
|
2402
2405
|
const context = __spreadValues(__spreadValues({}, generalContext), messagesContext);
|
|
2403
2406
|
(0, import_react11.useEffect)(() => {
|
|
2404
2407
|
onInProgress == null ? void 0 : onInProgress(isLoading);
|
|
@@ -2466,7 +2469,7 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onS
|
|
|
2466
2469
|
});
|
|
2467
2470
|
const runCurrentAgent = (hint) => __async(void 0, null, function* () {
|
|
2468
2471
|
if (generalContext.agentSession) {
|
|
2469
|
-
yield (0,
|
|
2472
|
+
yield (0, import_react_core10.runAgent)(
|
|
2470
2473
|
generalContext.agentSession.agentName,
|
|
2471
2474
|
context,
|
|
2472
2475
|
appendMessage,
|
|
@@ -2477,7 +2480,7 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onS
|
|
|
2477
2480
|
});
|
|
2478
2481
|
const stopCurrentAgent = () => {
|
|
2479
2482
|
if (generalContext.agentSession) {
|
|
2480
|
-
(0,
|
|
2483
|
+
(0, import_react_core10.stopAgent)(generalContext.agentSession.agentName, context);
|
|
2481
2484
|
}
|
|
2482
2485
|
};
|
|
2483
2486
|
const setCurrentAgentState = (state) => {
|