@copilotkit/react-ui 1.8.0-next.6 → 1.8.0-next.8
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 +19 -0
- package/dist/{chunk-FBYETUFL.mjs → chunk-5M7ODWKH.mjs} +6 -12
- package/dist/chunk-5M7ODWKH.mjs.map +1 -0
- package/dist/{chunk-GBXUOB6L.mjs → chunk-7BXD65QV.mjs} +3 -3
- package/dist/{chunk-6H7IQRIU.mjs → chunk-DKYAA4DM.mjs} +2 -2
- package/dist/{chunk-DFHFPZQD.mjs → chunk-FGVMRZ5D.mjs} +9 -16
- package/dist/chunk-FGVMRZ5D.mjs.map +1 -0
- package/dist/{chunk-Z6YOBQUJ.mjs → chunk-HGA4N4ME.mjs} +8 -13
- package/dist/chunk-HGA4N4ME.mjs.map +1 -0
- package/dist/{chunk-FFNESJSG.mjs → chunk-N5QWMFFT.mjs} +2 -2
- package/dist/{chunk-YC4NBUGE.mjs → chunk-NRA3CFEE.mjs} +3 -3
- package/dist/chunk-NRA3CFEE.mjs.map +1 -0
- package/dist/{chunk-CGVOCLHN.mjs → chunk-P7S3E5UW.mjs} +2 -2
- package/dist/{chunk-OTPAZXVR.mjs → chunk-Q5V6S67N.mjs} +17 -6
- package/dist/chunk-Q5V6S67N.mjs.map +1 -0
- package/dist/{chunk-LYHZXHTJ.mjs → chunk-SNLHKLW3.mjs} +2 -2
- package/dist/{chunk-5JY5QJ2W.mjs → chunk-UN2E3HCK.mjs} +9 -3
- package/dist/chunk-UN2E3HCK.mjs.map +1 -0
- package/dist/{chunk-QS7UFQFD.mjs → chunk-Y5RNSFAD.mjs} +3 -3
- package/dist/{chunk-VC4NO5QZ.mjs → chunk-YOEL33HG.mjs} +2 -2
- package/dist/{chunk-GJME6MK4.mjs → chunk-ZY25LVYR.mjs} +2 -2
- package/dist/components/chat/Button.js.map +1 -1
- package/dist/components/chat/Button.mjs +2 -2
- package/dist/components/chat/Chat.d.ts +2 -11
- package/dist/components/chat/Chat.js +67 -76
- package/dist/components/chat/Chat.js.map +1 -1
- package/dist/components/chat/Chat.mjs +6 -7
- package/dist/components/chat/ChatContext.d.ts +15 -0
- package/dist/components/chat/ChatContext.js +67 -1
- package/dist/components/chat/ChatContext.js.map +1 -1
- package/dist/components/chat/ChatContext.mjs +1 -1
- package/dist/components/chat/Header.js +18 -7
- package/dist/components/chat/Header.js.map +1 -1
- package/dist/components/chat/Header.mjs +5 -5
- package/dist/components/chat/Input.js.map +1 -1
- package/dist/components/chat/Input.mjs +2 -2
- package/dist/components/chat/Messages.js.map +1 -1
- package/dist/components/chat/Messages.mjs +2 -2
- package/dist/components/chat/Modal.d.ts +1 -1
- package/dist/components/chat/Modal.js +92 -94
- package/dist/components/chat/Modal.js.map +1 -1
- package/dist/components/chat/Modal.mjs +13 -14
- package/dist/components/chat/Popup.js +94 -96
- package/dist/components/chat/Popup.js.map +1 -1
- package/dist/components/chat/Popup.mjs +14 -15
- package/dist/components/chat/Sidebar.js +94 -96
- package/dist/components/chat/Sidebar.js.map +1 -1
- package/dist/components/chat/Sidebar.mjs +14 -15
- package/dist/components/chat/Window.js.map +1 -1
- package/dist/components/chat/Window.mjs +2 -2
- package/dist/components/chat/index.d.ts +1 -1
- package/dist/components/chat/index.js +96 -98
- package/dist/components/chat/index.js.map +1 -1
- package/dist/components/chat/index.mjs +17 -18
- package/dist/components/chat/messages/AssistantMessage.js +4 -67
- package/dist/components/chat/messages/AssistantMessage.js.map +1 -1
- package/dist/components/chat/messages/AssistantMessage.mjs +2 -2
- package/dist/components/chat/props.d.ts +1 -5
- package/dist/components/chat/props.js.map +1 -1
- package/dist/components/dev-console/console.js +18 -7
- package/dist/components/dev-console/console.js.map +1 -1
- package/dist/components/dev-console/console.mjs +3 -3
- package/dist/components/dev-console/icons.js +16 -5
- package/dist/components/dev-console/icons.js.map +1 -1
- package/dist/components/dev-console/icons.mjs +1 -1
- package/dist/components/dev-console/index.js +18 -7
- package/dist/components/dev-console/index.js.map +1 -1
- package/dist/components/dev-console/index.mjs +3 -3
- package/dist/components/help-modal/index.js +2 -2
- package/dist/components/help-modal/index.js.map +1 -1
- package/dist/components/help-modal/index.mjs +1 -1
- package/dist/components/help-modal/modal.js +2 -2
- package/dist/components/help-modal/modal.js.map +1 -1
- package/dist/components/help-modal/modal.mjs +1 -1
- package/dist/components/index.d.ts +1 -1
- package/dist/components/index.js +96 -98
- package/dist/components/index.js.map +1 -1
- package/dist/components/index.mjs +17 -18
- package/dist/index.css +39 -34
- package/dist/index.css.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +96 -98
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +18 -19
- package/dist/types/css.d.ts +2 -0
- package/dist/types/css.js.map +1 -1
- package/package.json +4 -4
- package/src/components/chat/Chat.tsx +0 -16
- package/src/components/chat/ChatContext.tsx +25 -0
- package/src/components/chat/Modal.tsx +0 -6
- package/src/components/chat/messages/AssistantMessage.tsx +4 -5
- package/src/components/chat/props.ts +0 -5
- package/src/components/dev-console/icons.tsx +9 -2
- package/src/components/help-modal/modal.tsx +2 -2
- package/src/css/colors.css +3 -0
- package/src/css/console.css +44 -9
- package/src/styles.css +0 -1
- package/src/types/css.ts +2 -0
- package/dist/chunk-5JY5QJ2W.mjs.map +0 -1
- package/dist/chunk-DFHFPZQD.mjs.map +0 -1
- package/dist/chunk-FBYETUFL.mjs.map +0 -1
- package/dist/chunk-OTPAZXVR.mjs.map +0 -1
- package/dist/chunk-UZTZXMYS.mjs +0 -18
- package/dist/chunk-UZTZXMYS.mjs.map +0 -1
- package/dist/chunk-YC4NBUGE.mjs.map +0 -1
- package/dist/chunk-Z6YOBQUJ.mjs.map +0 -1
- package/dist/components/chat/Response.d.ts +0 -7
- package/dist/components/chat/Response.js +0 -64
- package/dist/components/chat/Response.js.map +0 -1
- package/dist/components/chat/Response.mjs +0 -10
- package/dist/components/chat/Response.mjs.map +0 -1
- package/src/components/chat/Response.tsx +0 -12
- package/src/css/response.css +0 -26
- /package/dist/{chunk-GBXUOB6L.mjs.map → chunk-7BXD65QV.mjs.map} +0 -0
- /package/dist/{chunk-6H7IQRIU.mjs.map → chunk-DKYAA4DM.mjs.map} +0 -0
- /package/dist/{chunk-FFNESJSG.mjs.map → chunk-N5QWMFFT.mjs.map} +0 -0
- /package/dist/{chunk-CGVOCLHN.mjs.map → chunk-P7S3E5UW.mjs.map} +0 -0
- /package/dist/{chunk-LYHZXHTJ.mjs.map → chunk-SNLHKLW3.mjs.map} +0 -0
- /package/dist/{chunk-QS7UFQFD.mjs.map → chunk-Y5RNSFAD.mjs.map} +0 -0
- /package/dist/{chunk-VC4NO5QZ.mjs.map → chunk-YOEL33HG.mjs.map} +0 -0
- /package/dist/{chunk-GJME6MK4.mjs.map → chunk-ZY25LVYR.mjs.map} +0 -0
package/dist/index.mjs
CHANGED
|
@@ -1,34 +1,32 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import "./chunk-EFZPSZWO.mjs";
|
|
3
|
-
import "./chunk-IU3WTXLQ.mjs";
|
|
4
3
|
import "./chunk-MMVDU6DF.mjs";
|
|
5
4
|
import "./chunk-SQMEPWVT.mjs";
|
|
6
|
-
import {
|
|
7
|
-
CopilotSidebar
|
|
8
|
-
} from "./chunk-FFNESJSG.mjs";
|
|
9
5
|
import "./chunk-WB3YULQ4.mjs";
|
|
10
6
|
import {
|
|
11
7
|
CopilotPopup
|
|
12
|
-
} from "./chunk-
|
|
13
|
-
import
|
|
14
|
-
|
|
15
|
-
|
|
8
|
+
} from "./chunk-DKYAA4DM.mjs";
|
|
9
|
+
import {
|
|
10
|
+
CopilotSidebar
|
|
11
|
+
} from "./chunk-N5QWMFFT.mjs";
|
|
12
|
+
import "./chunk-FGVMRZ5D.mjs";
|
|
13
|
+
import "./chunk-P7S3E5UW.mjs";
|
|
14
|
+
import "./chunk-Y5RNSFAD.mjs";
|
|
16
15
|
import "./chunk-V7W6IM2V.mjs";
|
|
17
16
|
import {
|
|
18
17
|
CopilotDevConsole
|
|
19
|
-
} from "./chunk-
|
|
18
|
+
} from "./chunk-7BXD65QV.mjs";
|
|
20
19
|
import {
|
|
21
20
|
shouldShowDevConsole
|
|
22
21
|
} from "./chunk-6TCUJ3B7.mjs";
|
|
23
22
|
import "./chunk-KXE2JCUH.mjs";
|
|
24
|
-
import "./chunk-
|
|
23
|
+
import "./chunk-NRA3CFEE.mjs";
|
|
25
24
|
import "./chunk-BH6PCAAL.mjs";
|
|
26
|
-
import "./chunk-
|
|
27
|
-
import "./chunk-
|
|
25
|
+
import "./chunk-Q5V6S67N.mjs";
|
|
26
|
+
import "./chunk-YOEL33HG.mjs";
|
|
28
27
|
import {
|
|
29
28
|
CopilotChat
|
|
30
|
-
} from "./chunk-
|
|
31
|
-
import "./chunk-UWWMAJ7R.mjs";
|
|
29
|
+
} from "./chunk-HGA4N4ME.mjs";
|
|
32
30
|
import "./chunk-WEYDZBT7.mjs";
|
|
33
31
|
import "./chunk-7RIBDD4K.mjs";
|
|
34
32
|
import {
|
|
@@ -36,21 +34,22 @@ import {
|
|
|
36
34
|
} from "./chunk-HEIDCT7I.mjs";
|
|
37
35
|
import {
|
|
38
36
|
AssistantMessage
|
|
39
|
-
} from "./chunk-
|
|
37
|
+
} from "./chunk-5M7ODWKH.mjs";
|
|
40
38
|
import "./chunk-XB6QCUPB.mjs";
|
|
39
|
+
import "./chunk-UWWMAJ7R.mjs";
|
|
41
40
|
import "./chunk-TOQ7P4DO.mjs";
|
|
42
|
-
import "./chunk-
|
|
41
|
+
import "./chunk-SNLHKLW3.mjs";
|
|
43
42
|
import "./chunk-YQFVRDNC.mjs";
|
|
44
43
|
import {
|
|
45
44
|
Markdown
|
|
46
45
|
} from "./chunk-XNQO5AZZ.mjs";
|
|
47
|
-
import "./chunk-
|
|
48
|
-
import "./chunk-UZTZXMYS.mjs";
|
|
46
|
+
import "./chunk-ZY25LVYR.mjs";
|
|
49
47
|
import {
|
|
50
48
|
useChatContext
|
|
51
|
-
} from "./chunk-
|
|
49
|
+
} from "./chunk-UN2E3HCK.mjs";
|
|
52
50
|
import "./chunk-PCTCOQK2.mjs";
|
|
53
51
|
import "./chunk-ORSMX3SE.mjs";
|
|
52
|
+
import "./chunk-IU3WTXLQ.mjs";
|
|
54
53
|
import "./chunk-T26KLXLH.mjs";
|
|
55
54
|
import {
|
|
56
55
|
useCopilotChatSuggestions
|
package/dist/types/css.d.ts
CHANGED
|
@@ -12,6 +12,8 @@ interface CopilotKitCSSProperties extends CSSProperties {
|
|
|
12
12
|
"--copilot-kit-shadow-sm"?: string;
|
|
13
13
|
"--copilot-kit-shadow-md"?: string;
|
|
14
14
|
"--copilot-kit-shadow-lg"?: string;
|
|
15
|
+
"--copilot-kit-dev-console-bg"?: string;
|
|
16
|
+
"--copilot-kit-dev-console-text"?: string;
|
|
15
17
|
}
|
|
16
18
|
|
|
17
19
|
export { CopilotKitCSSProperties };
|
package/dist/types/css.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/types/css.ts"],"sourcesContent":["// autogenerated (see postcss.config.js) - do not edit\nimport { CSSProperties } from \"react\";\n\nexport interface CopilotKitCSSProperties extends CSSProperties {\n \"--copilot-kit-primary-color\"?: string;\n \"--copilot-kit-contrast-color\"?: string;\n \"--copilot-kit-background-color\"?: string;\n \"--copilot-kit-input-background-color\"?: string;\n \"--copilot-kit-secondary-color\"?: string;\n \"--copilot-kit-secondary-contrast-color\"?: string;\n \"--copilot-kit-separator-color\"?: string;\n \"--copilot-kit-muted-color\"?: string;\n \"--copilot-kit-shadow-sm\"?: string;\n \"--copilot-kit-shadow-md\"?: string;\n \"--copilot-kit-shadow-lg\"?: string;\n}\n"],"mappings":";;;;;;;;;;;;;;;;AAAA;AAAA;","names":[]}
|
|
1
|
+
{"version":3,"sources":["../../src/types/css.ts"],"sourcesContent":["// autogenerated (see postcss.config.js) - do not edit\nimport { CSSProperties } from \"react\";\n\nexport interface CopilotKitCSSProperties extends CSSProperties {\n \"--copilot-kit-primary-color\"?: string;\n \"--copilot-kit-contrast-color\"?: string;\n \"--copilot-kit-background-color\"?: string;\n \"--copilot-kit-input-background-color\"?: string;\n \"--copilot-kit-secondary-color\"?: string;\n \"--copilot-kit-secondary-contrast-color\"?: string;\n \"--copilot-kit-separator-color\"?: string;\n \"--copilot-kit-muted-color\"?: string;\n \"--copilot-kit-shadow-sm\"?: string;\n \"--copilot-kit-shadow-md\"?: string;\n \"--copilot-kit-shadow-lg\"?: string;\n \"--copilot-kit-dev-console-bg\"?: string;\n \"--copilot-kit-dev-console-text\"?: string;\n}\n"],"mappings":";;;;;;;;;;;;;;;;AAAA;AAAA;","names":[]}
|
package/package.json
CHANGED
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
"publishConfig": {
|
|
10
10
|
"access": "public"
|
|
11
11
|
},
|
|
12
|
-
"version": "1.8.0-next.
|
|
12
|
+
"version": "1.8.0-next.8",
|
|
13
13
|
"sideEffects": [
|
|
14
14
|
"**/*.css"
|
|
15
15
|
],
|
|
@@ -50,9 +50,9 @@
|
|
|
50
50
|
"react-syntax-highlighter": "^15.5.0",
|
|
51
51
|
"remark-gfm": "^3.0.1",
|
|
52
52
|
"remark-math": "^5.1.1",
|
|
53
|
-
"@copilotkit/react-core": "1.8.0-next.
|
|
54
|
-
"@copilotkit/runtime-client-gql": "1.8.0-next.
|
|
55
|
-
"@copilotkit/shared": "1.8.0-next.
|
|
53
|
+
"@copilotkit/react-core": "1.8.0-next.8",
|
|
54
|
+
"@copilotkit/runtime-client-gql": "1.8.0-next.8",
|
|
55
|
+
"@copilotkit/shared": "1.8.0-next.8"
|
|
56
56
|
},
|
|
57
57
|
"keywords": [
|
|
58
58
|
"copilotkit",
|
|
@@ -53,7 +53,6 @@ import {
|
|
|
53
53
|
} from "./ChatContext";
|
|
54
54
|
import { Messages as DefaultMessages } from "./Messages";
|
|
55
55
|
import { Input as DefaultInput } from "./Input";
|
|
56
|
-
import { ResponseButton as DefaultResponseButton } from "./Response";
|
|
57
56
|
import { RenderTextMessage as DefaultRenderTextMessage } from "./messages/RenderTextMessage";
|
|
58
57
|
import { RenderActionExecutionMessage as DefaultRenderActionExecutionMessage } from "./messages/RenderActionExecutionMessage";
|
|
59
58
|
import { RenderResultMessage as DefaultRenderResultMessage } from "./messages/RenderResultMessage";
|
|
@@ -77,11 +76,9 @@ import {
|
|
|
77
76
|
InputProps,
|
|
78
77
|
MessagesProps,
|
|
79
78
|
RenderMessageProps,
|
|
80
|
-
ResponseButtonProps,
|
|
81
79
|
UserMessageProps,
|
|
82
80
|
} from "./props";
|
|
83
81
|
|
|
84
|
-
import { CopilotDevConsole } from "../dev-console";
|
|
85
82
|
import { HintFunction, runAgent, stopAgent } from "@copilotkit/react-core";
|
|
86
83
|
|
|
87
84
|
/**
|
|
@@ -156,12 +153,6 @@ export interface CopilotChatProps {
|
|
|
156
153
|
*/
|
|
157
154
|
makeSystemMessage?: SystemMessageFunction;
|
|
158
155
|
|
|
159
|
-
/**
|
|
160
|
-
* Whether to show the response button.
|
|
161
|
-
* @default true
|
|
162
|
-
*/
|
|
163
|
-
showResponseButton?: boolean;
|
|
164
|
-
|
|
165
156
|
/**
|
|
166
157
|
* A custom assistant message component to use instead of the default.
|
|
167
158
|
*/
|
|
@@ -202,11 +193,6 @@ export interface CopilotChatProps {
|
|
|
202
193
|
*/
|
|
203
194
|
Input?: React.ComponentType<InputProps>;
|
|
204
195
|
|
|
205
|
-
/**
|
|
206
|
-
* A custom ResponseButton component to use instead of the default.
|
|
207
|
-
*/
|
|
208
|
-
ResponseButton?: React.ComponentType<ResponseButtonProps>;
|
|
209
|
-
|
|
210
196
|
/**
|
|
211
197
|
* A class name to apply to the root element.
|
|
212
198
|
*/
|
|
@@ -270,7 +256,6 @@ export function CopilotChat({
|
|
|
270
256
|
instructions,
|
|
271
257
|
onSubmitMessage,
|
|
272
258
|
makeSystemMessage,
|
|
273
|
-
showResponseButton = true,
|
|
274
259
|
onInProgress,
|
|
275
260
|
onStopGeneration,
|
|
276
261
|
onReloadMessages,
|
|
@@ -284,7 +269,6 @@ export function CopilotChat({
|
|
|
284
269
|
RenderAgentStateMessage = DefaultRenderAgentStateMessage,
|
|
285
270
|
RenderResultMessage = DefaultRenderResultMessage,
|
|
286
271
|
Input = DefaultInput,
|
|
287
|
-
ResponseButton = DefaultResponseButton,
|
|
288
272
|
className,
|
|
289
273
|
icons,
|
|
290
274
|
labels,
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import React, { useMemo, useState } from "react";
|
|
2
2
|
import * as DefaultIcons from "./Icons";
|
|
3
|
+
import { ThumbsDownIcon, ThumbsUpIcon } from "./Icons";
|
|
3
4
|
|
|
4
5
|
/**
|
|
5
6
|
* Icons for CopilotChat component.
|
|
@@ -59,6 +60,27 @@ export interface CopilotChatIcons {
|
|
|
59
60
|
*/
|
|
60
61
|
|
|
61
62
|
pushToTalkIcon?: React.ReactNode;
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* The icons to use for copy assistant response
|
|
66
|
+
* @default <CopyIcon />
|
|
67
|
+
*/
|
|
68
|
+
|
|
69
|
+
copyIcon?: React.ReactNode;
|
|
70
|
+
|
|
71
|
+
/**
|
|
72
|
+
* The icon to use for thumbs up/response approval.
|
|
73
|
+
* @default <ThumbsUpIcon />
|
|
74
|
+
*/
|
|
75
|
+
|
|
76
|
+
thumbsUpIcon?: React.ReactNode;
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* The icon to use for thumbs down/response rejection.
|
|
80
|
+
* @default <ThumbsDownIcon />
|
|
81
|
+
*/
|
|
82
|
+
|
|
83
|
+
thumbsDownIcon?: React.ReactNode;
|
|
62
84
|
}
|
|
63
85
|
|
|
64
86
|
/**
|
|
@@ -196,6 +218,9 @@ export const ChatContextProvider = ({
|
|
|
196
218
|
stopIcon: DefaultIcons.StopIcon,
|
|
197
219
|
regenerateIcon: DefaultIcons.RegenerateIcon,
|
|
198
220
|
pushToTalkIcon: DefaultIcons.MicrophoneIcon,
|
|
221
|
+
copyIcon: DefaultIcons.CopyIcon,
|
|
222
|
+
thumbsUpIcon: DefaultIcons.ThumbsUpIcon,
|
|
223
|
+
thumbsDownIcon: DefaultIcons.ThumbsDownIcon,
|
|
199
224
|
},
|
|
200
225
|
...icons,
|
|
201
226
|
}),
|
|
@@ -6,9 +6,7 @@ import { Button as DefaultButton } from "./Button";
|
|
|
6
6
|
import { Header as DefaultHeader } from "./Header";
|
|
7
7
|
import { Messages as DefaultMessages } from "./Messages";
|
|
8
8
|
import { Input as DefaultInput } from "./Input";
|
|
9
|
-
import { ResponseButton as DefaultResponseButton } from "./Response";
|
|
10
9
|
import { CopilotChat, CopilotChatProps } from "./Chat";
|
|
11
|
-
import { Markdown as DefaultRenderer } from "./Markdown";
|
|
12
10
|
import { AssistantMessage as DefaultAssistantMessage } from "./messages/AssistantMessage";
|
|
13
11
|
import { UserMessage as DefaultUserMessage } from "./messages/UserMessage";
|
|
14
12
|
|
|
@@ -72,14 +70,12 @@ export const CopilotModal = ({
|
|
|
72
70
|
icons,
|
|
73
71
|
labels,
|
|
74
72
|
makeSystemMessage,
|
|
75
|
-
showResponseButton = true,
|
|
76
73
|
onInProgress,
|
|
77
74
|
Window = DefaultWindow,
|
|
78
75
|
Button = DefaultButton,
|
|
79
76
|
Header = DefaultHeader,
|
|
80
77
|
Messages = DefaultMessages,
|
|
81
78
|
Input = DefaultInput,
|
|
82
|
-
ResponseButton = DefaultResponseButton,
|
|
83
79
|
AssistantMessage = DefaultAssistantMessage,
|
|
84
80
|
UserMessage = DefaultUserMessage,
|
|
85
81
|
className,
|
|
@@ -109,11 +105,9 @@ export const CopilotModal = ({
|
|
|
109
105
|
onStopGeneration={onStopGeneration}
|
|
110
106
|
onReloadMessages={onReloadMessages}
|
|
111
107
|
makeSystemMessage={makeSystemMessage}
|
|
112
|
-
showResponseButton={showResponseButton}
|
|
113
108
|
onInProgress={onInProgress}
|
|
114
109
|
Messages={Messages}
|
|
115
110
|
Input={Input}
|
|
116
|
-
ResponseButton={ResponseButton}
|
|
117
111
|
AssistantMessage={AssistantMessage}
|
|
118
112
|
UserMessage={UserMessage}
|
|
119
113
|
/>
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { AssistantMessageProps } from "../props";
|
|
2
2
|
import { useChatContext } from "../ChatContext";
|
|
3
3
|
import { Markdown } from "../Markdown";
|
|
4
|
-
import { RegenerateIcon, CopyIcon, ThumbsUpIcon, ThumbsDownIcon } from "../Icons";
|
|
5
4
|
import { useState } from "react";
|
|
6
5
|
|
|
7
6
|
export const AssistantMessage = (props: AssistantMessageProps) => {
|
|
@@ -68,7 +67,7 @@ export const AssistantMessage = (props: AssistantMessageProps) => {
|
|
|
68
67
|
aria-label={labels.regenerateResponse}
|
|
69
68
|
title={labels.regenerateResponse}
|
|
70
69
|
>
|
|
71
|
-
{
|
|
70
|
+
{icons.regenerateIcon}
|
|
72
71
|
</button>
|
|
73
72
|
<button
|
|
74
73
|
className="copilotKitMessageControlButton"
|
|
@@ -79,7 +78,7 @@ export const AssistantMessage = (props: AssistantMessageProps) => {
|
|
|
79
78
|
{copied ? (
|
|
80
79
|
<span style={{ fontSize: "10px", fontWeight: "bold" }}>✓</span>
|
|
81
80
|
) : (
|
|
82
|
-
|
|
81
|
+
icons.copyIcon
|
|
83
82
|
)}
|
|
84
83
|
</button>
|
|
85
84
|
{onThumbsUp && (
|
|
@@ -89,7 +88,7 @@ export const AssistantMessage = (props: AssistantMessageProps) => {
|
|
|
89
88
|
aria-label={labels.thumbsUp}
|
|
90
89
|
title={labels.thumbsUp}
|
|
91
90
|
>
|
|
92
|
-
{
|
|
91
|
+
{icons.thumbsUpIcon}
|
|
93
92
|
</button>
|
|
94
93
|
)}
|
|
95
94
|
{onThumbsDown && (
|
|
@@ -99,7 +98,7 @@ export const AssistantMessage = (props: AssistantMessageProps) => {
|
|
|
99
98
|
aria-label={labels.thumbsDown}
|
|
100
99
|
title={labels.thumbsDown}
|
|
101
100
|
>
|
|
102
|
-
{
|
|
101
|
+
{icons.thumbsDownIcon}
|
|
103
102
|
</button>
|
|
104
103
|
)}
|
|
105
104
|
</div>
|
|
@@ -37,9 +37,16 @@ export const ExclamationMarkIcon = (
|
|
|
37
37
|
);
|
|
38
38
|
|
|
39
39
|
export const ChevronDownIcon = (
|
|
40
|
-
<svg
|
|
40
|
+
<svg
|
|
41
|
+
width="7px"
|
|
42
|
+
height="4px"
|
|
43
|
+
viewBox="0 0 7 4"
|
|
44
|
+
version="1.1"
|
|
45
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
46
|
+
fill="currentColor"
|
|
47
|
+
>
|
|
41
48
|
<g id="Page-1" stroke="none" strokeWidth="1" fill="none" fillRule="evenodd">
|
|
42
|
-
<g id="Group" fill="
|
|
49
|
+
<g id="Group" fill="currentColor" fillRule="nonzero">
|
|
43
50
|
<path
|
|
44
51
|
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"
|
|
45
52
|
id="Path"
|
|
@@ -52,9 +52,9 @@ export function CopilotKitHelpModal() {
|
|
|
52
52
|
width: "380px",
|
|
53
53
|
}}
|
|
54
54
|
>
|
|
55
|
-
<div className="
|
|
55
|
+
<div className="copilotKitHelpModal rounded-lg shadow-xl w-full p-4 flex-col relative">
|
|
56
56
|
<button
|
|
57
|
-
className="absolute text-gray-400 hover:text-gray-600 focus:outline-none"
|
|
57
|
+
className="copilotKitHelpModalCloseButton absolute text-gray-400 hover:text-gray-600 focus:outline-none"
|
|
58
58
|
style={{ top: "10px", right: "10px" }}
|
|
59
59
|
onClick={() => setShowHelpModal(false)}
|
|
60
60
|
aria-label="Close"
|
package/src/css/colors.css
CHANGED
|
@@ -25,6 +25,9 @@
|
|
|
25
25
|
--copilot-kit-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
|
|
26
26
|
/* Large shadow for modals */
|
|
27
27
|
--copilot-kit-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
|
|
28
|
+
|
|
29
|
+
--copilot-kit-dev-console-bg: #f8f8fa;
|
|
30
|
+
--copilot-kit-dev-console-text: black;
|
|
28
31
|
}
|
|
29
32
|
|
|
30
33
|
/* Dark theme - based on system preference */
|
package/src/css/console.css
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
}
|
|
7
7
|
|
|
8
8
|
.copilotKitDevConsole.copilotKitDevConsoleWarnOutdated {
|
|
9
|
-
background-color:
|
|
9
|
+
background-color: var(--copilot-kit-dev-console-bg);
|
|
10
10
|
}
|
|
11
11
|
|
|
12
12
|
.copilotKitDevConsole .copilotKitVersionInfo {
|
|
@@ -27,7 +27,7 @@
|
|
|
27
27
|
font-size: 11px;
|
|
28
28
|
font-weight: normal;
|
|
29
29
|
font-family: monospace;
|
|
30
|
-
background-color:
|
|
30
|
+
background-color: var(--copilot-kit-dev-console-bg);
|
|
31
31
|
border: 1px solid #979797;
|
|
32
32
|
padding: 1px 12px;
|
|
33
33
|
padding-left: 5px;
|
|
@@ -64,18 +64,47 @@
|
|
|
64
64
|
align-items: center;
|
|
65
65
|
justify-content: center;
|
|
66
66
|
outline: none;
|
|
67
|
+
color: var(--copilot-kit-dev-console-text);
|
|
67
68
|
}
|
|
68
69
|
|
|
69
70
|
.copilotKitDebugMenuTriggerButton.compact {
|
|
70
71
|
width: 35px;
|
|
71
|
-
color:
|
|
72
|
+
color: var(--copilot-kit-dev-console-bg);
|
|
72
73
|
justify-content: center;
|
|
73
74
|
outline: none;
|
|
74
75
|
font-size: 8px;
|
|
75
76
|
}
|
|
76
77
|
|
|
77
78
|
.copilotKitDevConsole .copilotKitDebugMenuTriggerButton:hover {
|
|
78
|
-
background-color: color-mix(in srgb, var(--copilot-kit-dev-console-bg)
|
|
79
|
+
background-color: color-mix(in srgb, var(--copilot-kit-dev-console-bg) 85%, black);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
@media (prefers-color-scheme: dark) {
|
|
83
|
+
.copilotKitDevConsole .copilotKitDebugMenuTriggerButton {
|
|
84
|
+
color: white;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
.copilotKitDevConsole .copilotKitDebugMenuTriggerButton:hover {
|
|
88
|
+
background-color: color-mix(in srgb, var(--copilot-kit-dev-console-bg) 20%, black);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
.dark,
|
|
93
|
+
html.dark,
|
|
94
|
+
body.dark,
|
|
95
|
+
[data-theme="dark"],
|
|
96
|
+
html[style*="color-scheme: dark"],
|
|
97
|
+
body[style*="color-scheme: dark"] .copilotKitDevConsole .copilotKitDebugMenuTriggerButton {
|
|
98
|
+
color: white;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
.dark,
|
|
102
|
+
html.dark,
|
|
103
|
+
body.dark,
|
|
104
|
+
[data-theme="dark"],
|
|
105
|
+
html[style*="color-scheme: dark"],
|
|
106
|
+
body[style*="color-scheme: dark"] .copilotKitDevConsole .copilotKitDebugMenuTriggerButton:hover {
|
|
107
|
+
background-color: color-mix(in srgb, var(--copilot-kit-dev-console-bg) 20%, black);
|
|
79
108
|
}
|
|
80
109
|
|
|
81
110
|
.copilotKitDevConsole .copilotKitDebugMenuTriggerButton > svg {
|
|
@@ -83,7 +112,6 @@
|
|
|
83
112
|
}
|
|
84
113
|
|
|
85
114
|
.copilotKitDebugMenu {
|
|
86
|
-
--copilot-kit-dev-console-bg: #f8f8fa;
|
|
87
115
|
--copilot-kit-dev-console-border: color-mix(in srgb, var(--copilot-kit-dev-console-bg) 80%, black);
|
|
88
116
|
margin-top: 2px;
|
|
89
117
|
border-radius: 6px;
|
|
@@ -105,10 +133,11 @@
|
|
|
105
133
|
background: none;
|
|
106
134
|
border: none;
|
|
107
135
|
cursor: pointer;
|
|
136
|
+
color: var(--copilot-kit-dev-console-text);
|
|
108
137
|
}
|
|
109
138
|
|
|
110
139
|
.copilotKitDebugMenuItem:hover {
|
|
111
|
-
background-color: color-mix(in srgb, var(--copilot-kit-dev-console-bg)
|
|
140
|
+
background-color: color-mix(in srgb, var(--copilot-kit-dev-console-bg) 95%, black);
|
|
112
141
|
border-radius: 4px;
|
|
113
142
|
}
|
|
114
143
|
|
|
@@ -124,6 +153,11 @@
|
|
|
124
153
|
margin: 0.25rem;
|
|
125
154
|
}
|
|
126
155
|
|
|
156
|
+
.copilotKitHelpModal {
|
|
157
|
+
background-color: var(--copilot-kit-dev-console-bg);
|
|
158
|
+
color: var(--copilot-kit-dev-console-text);
|
|
159
|
+
}
|
|
160
|
+
|
|
127
161
|
.copilotKitHelpItemButton {
|
|
128
162
|
display: block;
|
|
129
163
|
text-align: center;
|
|
@@ -132,10 +166,11 @@
|
|
|
132
166
|
border-radius: 15px;
|
|
133
167
|
font-size: 0.8rem;
|
|
134
168
|
border: 1px solid var(--copilot-kit-muted-color);
|
|
135
|
-
color: var(--copilot-kit-
|
|
169
|
+
color: var(--copilot-kit-dev-console-text);
|
|
136
170
|
box-shadow: 0 5px 5px 0px rgba(0,0,0,.01),0 2px 3px 0px rgba(0,0,0,.02);
|
|
137
171
|
background-color: var(--copilot-kit-dev-console-bg);
|
|
138
172
|
}
|
|
139
173
|
.copilotKitHelpItemButton:hover {
|
|
140
|
-
background-color:
|
|
141
|
-
}
|
|
174
|
+
background-color: color-mix(in srgb, var(--copilot-kit-dev-console-bg) 95%, black);
|
|
175
|
+
}
|
|
176
|
+
|
package/src/styles.css
CHANGED
package/src/types/css.ts
CHANGED
|
@@ -13,4 +13,6 @@ export interface CopilotKitCSSProperties extends CSSProperties {
|
|
|
13
13
|
"--copilot-kit-shadow-sm"?: string;
|
|
14
14
|
"--copilot-kit-shadow-md"?: string;
|
|
15
15
|
"--copilot-kit-shadow-lg"?: string;
|
|
16
|
+
"--copilot-kit-dev-console-bg"?: string;
|
|
17
|
+
"--copilot-kit-dev-console-text"?: string;
|
|
16
18
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/components/chat/ChatContext.tsx"],"sourcesContent":["import React, { useMemo, useState } from \"react\";\nimport * as DefaultIcons from \"./Icons\";\n\n/**\n * Icons for CopilotChat component.\n */\nexport interface CopilotChatIcons {\n /**\n * The icon to use for the open chat button.\n * @default <OpenIcon />\n */\n openIcon?: React.ReactNode;\n\n /**\n * The icon to use for the close chat button.\n * @default <CloseIcon />\n */\n closeIcon?: React.ReactNode;\n\n /**\n * The icon to use for the close chat button in the header.\n * @default <HeaderCloseIcon />\n */\n headerCloseIcon?: React.ReactNode;\n\n /**\n * The icon to use for the send button.\n * @default <SendIcon />\n */\n sendIcon?: React.ReactNode;\n\n /**\n * The icon to use for the activity indicator.\n * @default <ActivityIcon />\n */\n activityIcon?: React.ReactNode;\n\n /**\n * The icon to use for the spinner.\n * @default <SpinnerIcon />\n */\n spinnerIcon?: React.ReactNode;\n\n /**\n * The icon to use for the stop button.\n * @default <StopIcon />\n */\n stopIcon?: React.ReactNode;\n\n /**\n * The icon to use for the regenerate button.\n * @default <RegenerateIcon />\n */\n regenerateIcon?: React.ReactNode;\n\n /**\n * The icons to use for push to talk.\n * @default <PushToTalkIcon />\n */\n\n pushToTalkIcon?: React.ReactNode;\n}\n\n/**\n * Labels for CopilotChat component.\n */\nexport interface CopilotChatLabels {\n /**\n * The initial message(s) to display in the chat window.\n */\n initial?: string | string[];\n\n /**\n * The title to display in the header.\n * @default \"CopilotKit\"\n */\n title?: string;\n\n /**\n * The placeholder to display in the input.\n * @default \"Type a message...\"\n */\n placeholder?: string;\n\n /**\n * The message to display when an error occurs.\n * @default \"❌ An error occurred. Please try again.\"\n */\n error?: string;\n\n /**\n * The label to display on the stop button.\n * @default \"Stop generating\"\n */\n stopGenerating?: string;\n\n /**\n * The label to display on the regenerate button.\n * @default \"Regenerate response\"\n */\n regenerateResponse?: string;\n\n /**\n * The label for the copy button.\n * @default \"Copy to clipboard\"\n */\n copyToClipboard?: string;\n\n /**\n * The label for the thumbs up button.\n * @default \"Thumbs up\"\n */\n thumbsUp?: string;\n\n /**\n * The label for the thumbs down button.\n * @default \"Thumbs down\"\n */\n thumbsDown?: string;\n\n /**\n * The text to display when content is copied.\n * @default \"Copied!\"\n */\n copied?: string;\n}\n\ninterface ChatContext {\n labels: Required<CopilotChatLabels>;\n icons: Required<CopilotChatIcons>;\n open: boolean;\n setOpen: (open: boolean) => void;\n}\n\nexport const ChatContext = React.createContext<ChatContext | undefined>(undefined);\n\nexport function useChatContext(): ChatContext {\n const context = React.useContext(ChatContext);\n if (context === undefined) {\n throw new Error(\n \"Context not found. Did you forget to wrap your app in a <ChatContextProvider> component?\",\n );\n }\n return context;\n}\n\ninterface ChatContextProps {\n // temperature?: number;\n // instructions?: string;\n // maxFeedback?: number;\n labels?: CopilotChatLabels;\n icons?: CopilotChatIcons;\n children?: React.ReactNode;\n open: boolean;\n setOpen: (open: boolean) => void;\n}\n\nexport const ChatContextProvider = ({\n // temperature,\n // instructions,\n // maxFeedback,\n labels,\n icons,\n children,\n open,\n setOpen,\n}: ChatContextProps) => {\n const memoizedLabels = useMemo(\n () => ({\n ...{\n initial: \"\",\n title: \"CopilotKit\",\n placeholder: \"Type a message...\",\n error: \"❌ An error occurred. Please try again.\",\n stopGenerating: \"Stop generating\",\n regenerateResponse: \"Regenerate response\",\n copyToClipboard: \"Copy to clipboard\",\n thumbsUp: \"Thumbs up\",\n thumbsDown: \"Thumbs down\",\n copied: \"Copied!\",\n },\n ...labels,\n }),\n [labels],\n );\n\n const memoizedIcons = useMemo(\n () => ({\n ...{\n openIcon: DefaultIcons.OpenIcon,\n closeIcon: DefaultIcons.CloseIcon,\n headerCloseIcon: DefaultIcons.HeaderCloseIcon,\n sendIcon: DefaultIcons.SendIcon,\n activityIcon: DefaultIcons.ActivityIcon,\n spinnerIcon: DefaultIcons.SpinnerIcon,\n stopIcon: DefaultIcons.StopIcon,\n regenerateIcon: DefaultIcons.RegenerateIcon,\n pushToTalkIcon: DefaultIcons.MicrophoneIcon,\n },\n ...icons,\n }),\n [icons],\n );\n\n const context = useMemo(\n () => ({\n labels: memoizedLabels,\n icons: memoizedIcons,\n open,\n setOpen,\n }),\n [memoizedLabels, memoizedIcons, open, setOpen],\n );\n\n return <ChatContext.Provider value={context}>{children}</ChatContext.Provider>;\n};\n"],"mappings":";;;;;;;;;;;;;;;;AAAA,OAAO,SAAS,eAAyB;AAsNhC;AAhFF,IAAM,cAAc,MAAM,cAAuC,MAAS;AAE1E,SAAS,iBAA8B;AAC5C,QAAM,UAAU,MAAM,WAAW,WAAW;AAC5C,MAAI,YAAY,QAAW;AACzB,UAAM,IAAI;AAAA,MACR;AAAA,IACF;AAAA,EACF;AACA,SAAO;AACT;AAaO,IAAM,sBAAsB,CAAC;AAAA;AAAA;AAAA;AAAA,EAIlC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAAwB;AACtB,QAAM,iBAAiB;AAAA,IACrB,MAAO,kCACF;AAAA,MACD,SAAS;AAAA,MACT,OAAO;AAAA,MACP,aAAa;AAAA,MACb,OAAO;AAAA,MACP,gBAAgB;AAAA,MAChB,oBAAoB;AAAA,MACpB,iBAAiB;AAAA,MACjB,UAAU;AAAA,MACV,YAAY;AAAA,MACZ,QAAQ;AAAA,IACV,IACG;AAAA,IAEL,CAAC,MAAM;AAAA,EACT;AAEA,QAAM,gBAAgB;AAAA,IACpB,MAAO,kCACF;AAAA,MACD,UAAuB;AAAA,MACvB,WAAwB;AAAA,MACxB,iBAA8B;AAAA,MAC9B,UAAuB;AAAA,MACvB,cAA2B;AAAA,MAC3B,aAA0B;AAAA,MAC1B,UAAuB;AAAA,MACvB,gBAA6B;AAAA,MAC7B,gBAA6B;AAAA,IAC/B,IACG;AAAA,IAEL,CAAC,KAAK;AAAA,EACR;AAEA,QAAM,UAAU;AAAA,IACd,OAAO;AAAA,MACL,QAAQ;AAAA,MACR,OAAO;AAAA,MACP;AAAA,MACA;AAAA,IACF;AAAA,IACA,CAAC,gBAAgB,eAAe,MAAM,OAAO;AAAA,EAC/C;AAEA,SAAO,oBAAC,YAAY,UAAZ,EAAqB,OAAO,SAAU,UAAS;AACzD;","names":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/components/chat/Modal.tsx"],"sourcesContent":["import React from \"react\";\nimport { ChatContextProvider } from \"./ChatContext\";\nimport { ButtonProps, HeaderProps, WindowProps } from \"./props\";\nimport { Window as DefaultWindow } from \"./Window\";\nimport { Button as DefaultButton } from \"./Button\";\nimport { Header as DefaultHeader } from \"./Header\";\nimport { Messages as DefaultMessages } from \"./Messages\";\nimport { Input as DefaultInput } from \"./Input\";\nimport { ResponseButton as DefaultResponseButton } from \"./Response\";\nimport { CopilotChat, CopilotChatProps } from \"./Chat\";\nimport { Markdown as DefaultRenderer } from \"./Markdown\";\nimport { AssistantMessage as DefaultAssistantMessage } from \"./messages/AssistantMessage\";\nimport { UserMessage as DefaultUserMessage } from \"./messages/UserMessage\";\n\nexport interface CopilotModalProps extends CopilotChatProps {\n /**\n * Whether the chat window should be open by default.\n * @default false\n */\n defaultOpen?: boolean;\n\n /**\n * If the chat window should close when the user clicks outside of it.\n * @default true\n */\n clickOutsideToClose?: boolean;\n\n /**\n * If the chat window should close when the user hits the Escape key.\n * @default true\n */\n hitEscapeToClose?: boolean;\n\n /**\n * The shortcut key to open the chat window.\n * Uses Command-[shortcut] on a Mac and Ctrl-[shortcut] on Windows.\n * @default '/'\n */\n shortcut?: string;\n\n /**\n * A callback that gets called when the chat window opens or closes.\n */\n onSetOpen?: (open: boolean) => void;\n\n /**\n * A custom Window component to use instead of the default.\n */\n Window?: React.ComponentType<WindowProps>;\n\n /**\n * A custom Button component to use instead of the default.\n */\n Button?: React.ComponentType<ButtonProps>;\n\n /**\n * A custom Header component to use instead of the default.\n */\n Header?: React.ComponentType<HeaderProps>;\n}\n\nexport const CopilotModal = ({\n instructions,\n defaultOpen = false,\n clickOutsideToClose = true,\n hitEscapeToClose = true,\n onSetOpen,\n onSubmitMessage,\n onStopGeneration,\n onReloadMessages,\n shortcut = \"/\",\n icons,\n labels,\n makeSystemMessage,\n showResponseButton = true,\n onInProgress,\n Window = DefaultWindow,\n Button = DefaultButton,\n Header = DefaultHeader,\n Messages = DefaultMessages,\n Input = DefaultInput,\n ResponseButton = DefaultResponseButton,\n AssistantMessage = DefaultAssistantMessage,\n UserMessage = DefaultUserMessage,\n className,\n children,\n}: CopilotModalProps) => {\n const [openState, setOpenState] = React.useState(defaultOpen);\n\n const setOpen = (open: boolean) => {\n onSetOpen?.(open);\n setOpenState(open);\n };\n\n return (\n <ChatContextProvider icons={icons} labels={labels} open={openState} setOpen={setOpen}>\n {children}\n <div className={className}>\n <Button></Button>\n <Window\n clickOutsideToClose={clickOutsideToClose}\n shortcut={shortcut}\n hitEscapeToClose={hitEscapeToClose}\n >\n <Header />\n <CopilotChat\n instructions={instructions}\n onSubmitMessage={onSubmitMessage}\n onStopGeneration={onStopGeneration}\n onReloadMessages={onReloadMessages}\n makeSystemMessage={makeSystemMessage}\n showResponseButton={showResponseButton}\n onInProgress={onInProgress}\n Messages={Messages}\n Input={Input}\n ResponseButton={ResponseButton}\n AssistantMessage={AssistantMessage}\n UserMessage={UserMessage}\n />\n </Window>\n </div>\n </ChatContextProvider>\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,WAAW;AAkGV,cACA,YADA;AArCD,IAAM,eAAe,CAAC;AAAA,EAC3B;AAAA,EACA,cAAc;AAAA,EACd,sBAAsB;AAAA,EACtB,mBAAmB;AAAA,EACnB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,WAAW;AAAA,EACX;AAAA,EACA;AAAA,EACA;AAAA,EACA,qBAAqB;AAAA,EACrB;AAAA,EACA,QAAAA,UAAS;AAAA,EACT,QAAAC,UAAS;AAAA,EACT,QAAAC,UAAS;AAAA,EACT,UAAAC,YAAW;AAAA,EACX,OAAAC,SAAQ;AAAA,EACR,gBAAAC,kBAAiB;AAAA,EACjB,kBAAAC,oBAAmB;AAAA,EACnB,aAAAC,eAAc;AAAA,EACd;AAAA,EACA;AACF,MAAyB;AACvB,QAAM,CAAC,WAAW,YAAY,IAAI,MAAM,SAAS,WAAW;AAE5D,QAAM,UAAU,CAAC,SAAkB;AACjC,2CAAY;AACZ,iBAAa,IAAI;AAAA,EACnB;AAEA,SACE,qBAAC,uBAAoB,OAAc,QAAgB,MAAM,WAAW,SACjE;AAAA;AAAA,IACD,qBAAC,SAAI,WACH;AAAA,0BAACN,SAAA,EAAO;AAAA,MACR;AAAA,QAACD;AAAA,QAAA;AAAA,UACC;AAAA,UACA;AAAA,UACA;AAAA,UAEA;AAAA,gCAACE,SAAA,EAAO;AAAA,YACR;AAAA,cAAC;AAAA;AAAA,gBACC;AAAA,gBACA;AAAA,gBACA;AAAA,gBACA;AAAA,gBACA;AAAA,gBACA;AAAA,gBACA;AAAA,gBACA,UAAUC;AAAA,gBACV,OAAOC;AAAA,gBACP,gBAAgBC;AAAA,gBAChB,kBAAkBC;AAAA,gBAClB,aAAaC;AAAA;AAAA,YACf;AAAA;AAAA;AAAA,MACF;AAAA,OACF;AAAA,KACF;AAEJ;","names":["Window","Button","Header","Messages","Input","ResponseButton","AssistantMessage","UserMessage"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/components/chat/messages/AssistantMessage.tsx"],"sourcesContent":["import { AssistantMessageProps } from \"../props\";\nimport { useChatContext } from \"../ChatContext\";\nimport { Markdown } from \"../Markdown\";\nimport { RegenerateIcon, CopyIcon, ThumbsUpIcon, ThumbsDownIcon } from \"../Icons\";\nimport { useState } from \"react\";\n\nexport const AssistantMessage = (props: AssistantMessageProps) => {\n const { icons, labels } = useChatContext();\n const {\n message,\n isLoading,\n subComponent,\n onRegenerate,\n onCopy,\n onThumbsUp,\n onThumbsDown,\n isCurrentMessage,\n } = props;\n const [copied, setCopied] = useState(false);\n\n const handleCopy = () => {\n if (message && onCopy) {\n navigator.clipboard.writeText(message);\n setCopied(true);\n onCopy(message);\n setTimeout(() => setCopied(false), 2000);\n } else if (message) {\n navigator.clipboard.writeText(message);\n setCopied(true);\n setTimeout(() => setCopied(false), 2000);\n }\n };\n\n const handleRegenerate = () => {\n if (onRegenerate) {\n onRegenerate();\n }\n };\n\n const handleThumbsUp = () => {\n if (onThumbsUp && message) {\n onThumbsUp(message);\n }\n };\n\n const handleThumbsDown = () => {\n if (onThumbsDown && message) {\n onThumbsDown(message);\n }\n };\n\n const LoadingIcon = () => <span>{icons.activityIcon}</span>;\n\n return (\n <>\n {(message || isLoading) && (\n <div className=\"copilotKitMessage copilotKitAssistantMessage\">\n {message && <Markdown content={message || \"\"} />}\n {isLoading && <LoadingIcon />}\n\n {message && !isLoading && (\n <div\n className={`copilotKitMessageControls ${isCurrentMessage ? \"currentMessage\" : \"\"}`}\n >\n <button\n className=\"copilotKitMessageControlButton\"\n onClick={handleRegenerate}\n aria-label={labels.regenerateResponse}\n title={labels.regenerateResponse}\n >\n {RegenerateIcon}\n </button>\n <button\n className=\"copilotKitMessageControlButton\"\n onClick={handleCopy}\n aria-label={labels.copyToClipboard}\n title={labels.copyToClipboard}\n >\n {copied ? (\n <span style={{ fontSize: \"10px\", fontWeight: \"bold\" }}>✓</span>\n ) : (\n CopyIcon\n )}\n </button>\n {onThumbsUp && (\n <button\n className=\"copilotKitMessageControlButton\"\n onClick={handleThumbsUp}\n aria-label={labels.thumbsUp}\n title={labels.thumbsUp}\n >\n {ThumbsUpIcon}\n </button>\n )}\n {onThumbsDown && (\n <button\n className=\"copilotKitMessageControlButton\"\n onClick={handleThumbsDown}\n aria-label={labels.thumbsDown}\n title={labels.thumbsDown}\n >\n {ThumbsDownIcon}\n </button>\n )}\n </div>\n )}\n </div>\n )}\n <div style={{ marginBottom: \"0.5rem\" }}>{subComponent}</div>\n </>\n );\n};\n"],"mappings":";;;;;;;;;;;;;;AAIA,SAAS,gBAAgB;AA+CG,SAGxB,UAHwB,KAUhB,YAVgB;AA7CrB,IAAM,mBAAmB,CAAC,UAAiC;AAChE,QAAM,EAAE,OAAO,OAAO,IAAI,eAAe;AACzC,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI;AACJ,QAAM,CAAC,QAAQ,SAAS,IAAI,SAAS,KAAK;AAE1C,QAAM,aAAa,MAAM;AACvB,QAAI,WAAW,QAAQ;AACrB,gBAAU,UAAU,UAAU,OAAO;AACrC,gBAAU,IAAI;AACd,aAAO,OAAO;AACd,iBAAW,MAAM,UAAU,KAAK,GAAG,GAAI;AAAA,IACzC,WAAW,SAAS;AAClB,gBAAU,UAAU,UAAU,OAAO;AACrC,gBAAU,IAAI;AACd,iBAAW,MAAM,UAAU,KAAK,GAAG,GAAI;AAAA,IACzC;AAAA,EACF;AAEA,QAAM,mBAAmB,MAAM;AAC7B,QAAI,cAAc;AAChB,mBAAa;AAAA,IACf;AAAA,EACF;AAEA,QAAM,iBAAiB,MAAM;AAC3B,QAAI,cAAc,SAAS;AACzB,iBAAW,OAAO;AAAA,IACpB;AAAA,EACF;AAEA,QAAM,mBAAmB,MAAM;AAC7B,QAAI,gBAAgB,SAAS;AAC3B,mBAAa,OAAO;AAAA,IACtB;AAAA,EACF;AAEA,QAAM,cAAc,MAAM,oBAAC,UAAM,gBAAM,cAAa;AAEpD,SACE,iCACI;AAAA,gBAAW,cACX,qBAAC,SAAI,WAAU,gDACZ;AAAA,iBAAW,oBAAC,YAAS,SAAS,WAAW,IAAI;AAAA,MAC7C,aAAa,oBAAC,eAAY;AAAA,MAE1B,WAAW,CAAC,aACX;AAAA,QAAC;AAAA;AAAA,UACC,WAAW,6BAA6B,mBAAmB,mBAAmB;AAAA,UAE9E;AAAA;AAAA,cAAC;AAAA;AAAA,gBACC,WAAU;AAAA,gBACV,SAAS;AAAA,gBACT,cAAY,OAAO;AAAA,gBACnB,OAAO,OAAO;AAAA,gBAEb;AAAA;AAAA,YACH;AAAA,YACA;AAAA,cAAC;AAAA;AAAA,gBACC,WAAU;AAAA,gBACV,SAAS;AAAA,gBACT,cAAY,OAAO;AAAA,gBACnB,OAAO,OAAO;AAAA,gBAEb,mBACC,oBAAC,UAAK,OAAO,EAAE,UAAU,QAAQ,YAAY,OAAO,GAAG,oBAAC,IAExD;AAAA;AAAA,YAEJ;AAAA,YACC,cACC;AAAA,cAAC;AAAA;AAAA,gBACC,WAAU;AAAA,gBACV,SAAS;AAAA,gBACT,cAAY,OAAO;AAAA,gBACnB,OAAO,OAAO;AAAA,gBAEb;AAAA;AAAA,YACH;AAAA,YAED,gBACC;AAAA,cAAC;AAAA;AAAA,gBACC,WAAU;AAAA,gBACV,SAAS;AAAA,gBACT,cAAY,OAAO;AAAA,gBACnB,OAAO,OAAO;AAAA,gBAEb;AAAA;AAAA,YACH;AAAA;AAAA;AAAA,MAEJ;AAAA,OAEJ;AAAA,IAEF,oBAAC,SAAI,OAAO,EAAE,cAAc,SAAS,GAAI,wBAAa;AAAA,KACxD;AAEJ;","names":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/components/dev-console/icons.tsx"],"sourcesContent":["export const ExclamationMarkTriangleIcon = (\n <svg\n width=\"13.3967723px\"\n height=\"12px\"\n viewBox=\"0 0 13.3967723 12\"\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <g id=\"Page-1\" stroke=\"none\" strokeWidth=\"1\" fill=\"none\" fillRule=\"evenodd\">\n <g id=\"exclamation-triangle\" fill=\"#CD2121\">\n <path\n 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\"\n id=\"Shape\"\n ></path>\n </g>\n </g>\n </svg>\n);\n\nexport const ExclamationMarkIcon = (\n <svg\n width=\"14px\"\n height=\"14px\"\n viewBox=\"0 0 14 14\"\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <g id=\"Page-1\" stroke=\"none\" strokeWidth=\"1\" fill=\"none\" fillRule=\"evenodd\">\n <g id=\"exclamation-circle\" fill=\"#EC662C\">\n <path\n 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\"\n id=\"Shape\"\n ></path>\n </g>\n </g>\n </svg>\n);\n\nexport const ChevronDownIcon = (\n <svg width=\"7px\" height=\"4px\" viewBox=\"0 0 7 4\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"Page-1\" stroke=\"none\" strokeWidth=\"1\" fill=\"none\" fillRule=\"evenodd\">\n <g id=\"Group\" fill=\"#000000\" fillRule=\"nonzero\">\n <path\n 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\"\n id=\"Path\"\n ></path>\n </g>\n </g>\n </svg>\n);\n\nexport const CheckIcon = (\n <svg\n width=\"14px\"\n height=\"14px\"\n viewBox=\"0 0 14 14\"\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <g id=\"Page-1\" stroke=\"none\" strokeWidth=\"1\" fill=\"none\" fillRule=\"evenodd\">\n <g id=\"Group-2\" transform=\"translate(-118, 0)\" fill=\"#1BC030\" fillRule=\"nonzero\">\n <g id=\"Group\" transform=\"translate(118, 0)\">\n <path\n 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\"\n id=\"Shape\"\n ></path>\n </g>\n </g>\n </g>\n </svg>\n);\n\nexport const CopilotKitIcon = (\n <svg\n width=\"33px\"\n height=\"35px\"\n viewBox=\"0 0 33 35\"\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <title>bd5c9079-929b-4d55-bdc9-16d1c8181b71</title>\n <g id=\"Page-1\" stroke=\"none\" strokeWidth=\"1\" fill=\"none\" fillRule=\"evenodd\">\n <image\n x=\"0\"\n y=\"0\"\n width=\"33\"\n height=\"35\"\n xlinkHref=\"\"\n ></image>\n </g>\n </svg>\n);\n"],"mappings":";AAUQ,cA+DN,YA/DM;AAVD,IAAM,8BACX;AAAA,EAAC;AAAA;AAAA,IACC,OAAM;AAAA,IACN,QAAO;AAAA,IACP,SAAQ;AAAA,IACR,SAAQ;AAAA,IACR,OAAM;AAAA,IAEN,8BAAC,OAAE,IAAG,UAAS,QAAO,QAAO,aAAY,KAAI,MAAK,QAAO,UAAS,WAChE,8BAAC,OAAE,IAAG,wBAAuB,MAAK,WAChC;AAAA,MAAC;AAAA;AAAA,QACC,GAAE;AAAA,QACF,IAAG;AAAA;AAAA,IACJ,GACH,GACF;AAAA;AACF;AAGK,IAAM,sBACX;AAAA,EAAC;AAAA;AAAA,IACC,OAAM;AAAA,IACN,QAAO;AAAA,IACP,SAAQ;AAAA,IACR,SAAQ;AAAA,IACR,OAAM;AAAA,IAEN,8BAAC,OAAE,IAAG,UAAS,QAAO,QAAO,aAAY,KAAI,MAAK,QAAO,UAAS,WAChE,8BAAC,OAAE,IAAG,sBAAqB,MAAK,WAC9B;AAAA,MAAC;AAAA;AAAA,QACC,GAAE;AAAA,QACF,IAAG;AAAA;AAAA,IACJ,GACH,GACF;AAAA;AACF;AAGK,IAAM,kBACX,oBAAC,SAAI,OAAM,OAAM,QAAO,OAAM,SAAQ,WAAU,SAAQ,OAAM,OAAM,8BAClE,8BAAC,OAAE,IAAG,UAAS,QAAO,QAAO,aAAY,KAAI,MAAK,QAAO,UAAS,WAChE,8BAAC,OAAE,IAAG,SAAQ,MAAK,WAAU,UAAS,WACpC;AAAA,EAAC;AAAA;AAAA,IACC,GAAE;AAAA,IACF,IAAG;AAAA;AACJ,GACH,GACF,GACF;AAGK,IAAM,YACX;AAAA,EAAC;AAAA;AAAA,IACC,OAAM;AAAA,IACN,QAAO;AAAA,IACP,SAAQ;AAAA,IACR,SAAQ;AAAA,IACR,OAAM;AAAA,IAEN,8BAAC,OAAE,IAAG,UAAS,QAAO,QAAO,aAAY,KAAI,MAAK,QAAO,UAAS,WAChE,8BAAC,OAAE,IAAG,WAAU,WAAU,sBAAqB,MAAK,WAAU,UAAS,WACrE,8BAAC,OAAE,IAAG,SAAQ,WAAU,qBACtB;AAAA,MAAC;AAAA;AAAA,QACC,GAAE;AAAA,QACF,IAAG;AAAA;AAAA,IACJ,GACH,GACF,GACF;AAAA;AACF;AAGK,IAAM,iBACX;AAAA,EAAC;AAAA;AAAA,IACC,OAAM;AAAA,IACN,QAAO;AAAA,IACP,SAAQ;AAAA,IACR,SAAQ;AAAA,IACR,OAAM;AAAA,IAEN;AAAA,0BAAC,WAAM,kDAAoC;AAAA,MAC3C,oBAAC,OAAE,IAAG,UAAS,QAAO,QAAO,aAAY,KAAI,MAAK,QAAO,UAAS,WAChE;AAAA,QAAC;AAAA;AAAA,UACC,GAAE;AAAA,UACF,GAAE;AAAA,UACF,OAAM;AAAA,UACN,QAAO;AAAA,UACP,WAAU;AAAA;AAAA,MACX,GACH;AAAA;AAAA;AACF;","names":[]}
|
package/dist/chunk-UZTZXMYS.mjs
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
useChatContext
|
|
3
|
-
} from "./chunk-5JY5QJ2W.mjs";
|
|
4
|
-
|
|
5
|
-
// src/components/chat/Response.tsx
|
|
6
|
-
import { jsx, jsxs } from "react/jsx-runtime";
|
|
7
|
-
var ResponseButton = ({ onClick, inProgress }) => {
|
|
8
|
-
const context = useChatContext();
|
|
9
|
-
return /* @__PURE__ */ jsxs("button", { onClick, className: "copilotKitResponseButton", children: [
|
|
10
|
-
/* @__PURE__ */ jsx("span", { children: inProgress ? context.icons.stopIcon : context.icons.regenerateIcon }),
|
|
11
|
-
inProgress ? context.labels.stopGenerating : context.labels.regenerateResponse
|
|
12
|
-
] });
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
export {
|
|
16
|
-
ResponseButton
|
|
17
|
-
};
|
|
18
|
-
//# sourceMappingURL=chunk-UZTZXMYS.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/components/chat/Response.tsx"],"sourcesContent":["import { useChatContext } from \"./ChatContext\";\nimport { ResponseButtonProps } from \"./props\";\n\nexport const ResponseButton = ({ onClick, inProgress }: ResponseButtonProps) => {\n const context = useChatContext();\n return (\n <button onClick={onClick} className=\"copilotKitResponseButton\">\n <span>{inProgress ? context.icons.stopIcon : context.icons.regenerateIcon}</span>\n {inProgress ? context.labels.stopGenerating : context.labels.regenerateResponse}\n </button>\n );\n};\n"],"mappings":";;;;;AAMI,SACE,KADF;AAHG,IAAM,iBAAiB,CAAC,EAAE,SAAS,WAAW,MAA2B;AAC9E,QAAM,UAAU,eAAe;AAC/B,SACE,qBAAC,YAAO,SAAkB,WAAU,4BAClC;AAAA,wBAAC,UAAM,uBAAa,QAAQ,MAAM,WAAW,QAAQ,MAAM,gBAAe;AAAA,IACzE,aAAa,QAAQ,OAAO,iBAAiB,QAAQ,OAAO;AAAA,KAC/D;AAEJ;","names":[]}
|