@copilotkit/react-ui 1.8.5-next.1 → 1.8.5-next.2
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 +9 -0
- package/dist/{chunk-4TWPMWD4.mjs → chunk-GOAED4H6.mjs} +3 -3
- package/dist/{chunk-P7S3E5UW.mjs → chunk-HIORSNVD.mjs} +35 -7
- package/dist/chunk-HIORSNVD.mjs.map +1 -0
- package/dist/chunk-JGMFJZMG.mjs +11 -0
- package/dist/chunk-JGMFJZMG.mjs.map +1 -0
- package/dist/{chunk-6QV7AIIG.mjs → chunk-SMJ3QQCE.mjs} +2 -2
- package/dist/{chunk-U6ISBBRF.mjs → chunk-X6EFGEBJ.mjs} +2 -2
- package/dist/{chunk-MYUOPOIL.mjs → chunk-ZLRUNNS7.mjs} +4 -4
- package/dist/components/chat/Chat.mjs +3 -3
- package/dist/components/chat/Modal.js +66 -32
- package/dist/components/chat/Modal.js.map +1 -1
- package/dist/components/chat/Modal.mjs +6 -5
- package/dist/components/chat/Popup.js +66 -32
- package/dist/components/chat/Popup.js.map +1 -1
- package/dist/components/chat/Popup.mjs +7 -6
- package/dist/components/chat/Sidebar.js +66 -32
- package/dist/components/chat/Sidebar.js.map +1 -1
- package/dist/components/chat/Sidebar.mjs +7 -6
- package/dist/components/chat/Window.js +39 -5
- package/dist/components/chat/Window.js.map +1 -1
- package/dist/components/chat/Window.mjs +2 -1
- package/dist/components/chat/index.js +66 -32
- package/dist/components/chat/index.js.map +1 -1
- package/dist/components/chat/index.mjs +10 -9
- package/dist/components/chat/messages/AssistantMessage.mjs +1 -1
- package/dist/components/chat/messages/RenderActionExecutionMessage.mjs +1 -1
- package/dist/components/chat/messages/RenderAgentStateMessage.mjs +1 -1
- package/dist/components/chat/messages/RenderResultMessage.mjs +1 -1
- package/dist/components/chat/messages/RenderTextMessage.mjs +1 -1
- package/dist/components/index.js +66 -32
- package/dist/components/index.js.map +1 -1
- package/dist/components/index.mjs +10 -9
- package/dist/hooks/use-dark-mode.d.ts +3 -0
- package/dist/hooks/use-dark-mode.js +35 -0
- package/dist/hooks/use-dark-mode.js.map +1 -0
- package/dist/hooks/use-dark-mode.mjs +8 -0
- package/dist/hooks/use-dark-mode.mjs.map +1 -0
- package/dist/index.css +25 -1
- package/dist/index.css.map +1 -1
- package/dist/index.js +68 -34
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +10 -9
- package/package.json +4 -4
- package/src/components/chat/Window.tsx +26 -1
- package/src/css/input.css +1 -1
- package/src/css/window.css +27 -0
- package/src/hooks/use-dark-mode.ts +10 -0
- package/dist/chunk-P7S3E5UW.mjs.map +0 -1
- /package/dist/{chunk-4TWPMWD4.mjs.map → chunk-GOAED4H6.mjs.map} +0 -0
- /package/dist/{chunk-6QV7AIIG.mjs.map → chunk-SMJ3QQCE.mjs.map} +0 -0
- /package/dist/{chunk-U6ISBBRF.mjs.map → chunk-X6EFGEBJ.mjs.map} +0 -0
- /package/dist/{chunk-MYUOPOIL.mjs.map → chunk-ZLRUNNS7.mjs.map} +0 -0
package/dist/index.mjs
CHANGED
|
@@ -2,15 +2,15 @@
|
|
|
2
2
|
import "./chunk-EFZPSZWO.mjs";
|
|
3
3
|
import "./chunk-MMVDU6DF.mjs";
|
|
4
4
|
import "./chunk-SQMEPWVT.mjs";
|
|
5
|
+
import {
|
|
6
|
+
CopilotSidebar
|
|
7
|
+
} from "./chunk-X6EFGEBJ.mjs";
|
|
5
8
|
import "./chunk-WB3YULQ4.mjs";
|
|
6
9
|
import {
|
|
7
10
|
CopilotPopup
|
|
8
|
-
} from "./chunk-
|
|
9
|
-
import
|
|
10
|
-
|
|
11
|
-
} from "./chunk-U6ISBBRF.mjs";
|
|
12
|
-
import "./chunk-4TWPMWD4.mjs";
|
|
13
|
-
import "./chunk-P7S3E5UW.mjs";
|
|
11
|
+
} from "./chunk-SMJ3QQCE.mjs";
|
|
12
|
+
import "./chunk-GOAED4H6.mjs";
|
|
13
|
+
import "./chunk-HIORSNVD.mjs";
|
|
14
14
|
import "./chunk-2OTVZXDX.mjs";
|
|
15
15
|
import "./chunk-V7W6IM2V.mjs";
|
|
16
16
|
import {
|
|
@@ -26,14 +26,14 @@ import "./chunk-Q5V6S67N.mjs";
|
|
|
26
26
|
import "./chunk-YOEL33HG.mjs";
|
|
27
27
|
import {
|
|
28
28
|
CopilotChat
|
|
29
|
-
} from "./chunk-
|
|
29
|
+
} from "./chunk-ZLRUNNS7.mjs";
|
|
30
|
+
import "./chunk-Q2YY2NX3.mjs";
|
|
30
31
|
import "./chunk-WNC6OCIB.mjs";
|
|
31
32
|
import "./chunk-62QMTKMJ.mjs";
|
|
32
33
|
import {
|
|
33
34
|
UserMessage
|
|
34
35
|
} from "./chunk-HEIDCT7I.mjs";
|
|
35
36
|
import "./chunk-NMNC4ROZ.mjs";
|
|
36
|
-
import "./chunk-Q2YY2NX3.mjs";
|
|
37
37
|
import {
|
|
38
38
|
AssistantMessage
|
|
39
39
|
} from "./chunk-5M7ODWKH.mjs";
|
|
@@ -43,11 +43,11 @@ import "./chunk-YQFVRDNC.mjs";
|
|
|
43
43
|
import {
|
|
44
44
|
Markdown
|
|
45
45
|
} from "./chunk-XNQO5AZZ.mjs";
|
|
46
|
+
import "./chunk-PCTCOQK2.mjs";
|
|
46
47
|
import "./chunk-ZY25LVYR.mjs";
|
|
47
48
|
import {
|
|
48
49
|
useChatContext
|
|
49
50
|
} from "./chunk-UN2E3HCK.mjs";
|
|
50
|
-
import "./chunk-PCTCOQK2.mjs";
|
|
51
51
|
import "./chunk-ORSMX3SE.mjs";
|
|
52
52
|
import "./chunk-IU3WTXLQ.mjs";
|
|
53
53
|
import "./chunk-T26KLXLH.mjs";
|
|
@@ -55,6 +55,7 @@ import {
|
|
|
55
55
|
useCopilotChatSuggestions
|
|
56
56
|
} from "./chunk-Z4XPPVZT.mjs";
|
|
57
57
|
import "./chunk-54JAUBUJ.mjs";
|
|
58
|
+
import "./chunk-JGMFJZMG.mjs";
|
|
58
59
|
import "./chunk-S5MBUNGN.mjs";
|
|
59
60
|
import "./chunk-MRXNTQOX.mjs";
|
|
60
61
|
export {
|
package/package.json
CHANGED
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
"publishConfig": {
|
|
10
10
|
"access": "public"
|
|
11
11
|
},
|
|
12
|
-
"version": "1.8.5-next.
|
|
12
|
+
"version": "1.8.5-next.2",
|
|
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.5-next.
|
|
54
|
-
"@copilotkit/runtime-client-gql": "1.8.5-next.
|
|
55
|
-
"@copilotkit/shared": "1.8.5-next.
|
|
53
|
+
"@copilotkit/react-core": "1.8.5-next.2",
|
|
54
|
+
"@copilotkit/runtime-client-gql": "1.8.5-next.2",
|
|
55
|
+
"@copilotkit/shared": "1.8.5-next.2"
|
|
56
56
|
},
|
|
57
57
|
"keywords": [
|
|
58
58
|
"copilotkit",
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import React, { useCallback, useEffect } from "react";
|
|
2
2
|
import { WindowProps } from "./props";
|
|
3
3
|
import { useChatContext } from "./ChatContext";
|
|
4
|
+
import { useCopilotContext } from "@copilotkit/react-core";
|
|
5
|
+
import { useDarkMode } from "../../hooks/use-dark-mode";
|
|
4
6
|
|
|
5
7
|
export const Window = ({
|
|
6
8
|
children,
|
|
@@ -9,6 +11,7 @@ export const Window = ({
|
|
|
9
11
|
hitEscapeToClose,
|
|
10
12
|
}: WindowProps) => {
|
|
11
13
|
const windowRef = React.useRef<HTMLDivElement>(null);
|
|
14
|
+
const context = useCopilotContext();
|
|
12
15
|
|
|
13
16
|
const { open, setOpen } = useChatContext();
|
|
14
17
|
|
|
@@ -121,9 +124,31 @@ export const Window = ({
|
|
|
121
124
|
};
|
|
122
125
|
}, [adjustForMobile, handleClickOutside, handleKeyDown]);
|
|
123
126
|
|
|
127
|
+
const isDark = useDarkMode();
|
|
128
|
+
|
|
129
|
+
const showPoweredBy = !context.copilotApiConfig?.publicApiKey;
|
|
130
|
+
const poweredByStyle = {
|
|
131
|
+
visibility: "visible",
|
|
132
|
+
display: "block",
|
|
133
|
+
position: "static",
|
|
134
|
+
textAlign: "center",
|
|
135
|
+
fontSize: "12px",
|
|
136
|
+
padding: "3px 0",
|
|
137
|
+
color: isDark ? "rgb(69, 69, 69)" : "rgb(214, 214, 214)",
|
|
138
|
+
};
|
|
139
|
+
|
|
124
140
|
return (
|
|
125
|
-
<div
|
|
141
|
+
<div
|
|
142
|
+
className={`copilotKitWindow ${showPoweredBy ? " poweredByContainer" : ""} ${open ? " open" : ""}`}
|
|
143
|
+
ref={windowRef}
|
|
144
|
+
>
|
|
126
145
|
{children}
|
|
146
|
+
{showPoweredBy && (
|
|
147
|
+
// @ts-expect-error -- expecting position not to be a string, but it can be.
|
|
148
|
+
<p className="poweredBy" style={poweredByStyle}>
|
|
149
|
+
Powered by CopilotKit
|
|
150
|
+
</p>
|
|
151
|
+
)}
|
|
127
152
|
</div>
|
|
128
153
|
);
|
|
129
154
|
};
|
package/src/css/input.css
CHANGED
package/src/css/window.css
CHANGED
|
@@ -14,6 +14,33 @@
|
|
|
14
14
|
transform: scale(0.95) translateY(20px);
|
|
15
15
|
display: flex;
|
|
16
16
|
pointer-events: none;
|
|
17
|
+
padding-bottom: 15px;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
.poweredByContainer {
|
|
21
|
+
padding: 0;
|
|
22
|
+
visibility: visible !important;
|
|
23
|
+
display: flex !important;
|
|
24
|
+
position: fixed !important;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
.poweredBy {
|
|
28
|
+
visibility: visible !important;
|
|
29
|
+
display: block !important;
|
|
30
|
+
position: static !important;
|
|
31
|
+
text-align: center !important;
|
|
32
|
+
font-size: 12px !important;
|
|
33
|
+
padding: 3px 0 !important;
|
|
34
|
+
color: rgb(214, 214, 214) !important;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
.dark,
|
|
38
|
+
html.dark,
|
|
39
|
+
body.dark,
|
|
40
|
+
[data-theme="dark"],
|
|
41
|
+
html[style*="color-scheme: dark"],
|
|
42
|
+
body[style*="color-scheme: dark"] .poweredBy {
|
|
43
|
+
color: rgb(69, 69, 69) !important;
|
|
17
44
|
}
|
|
18
45
|
|
|
19
46
|
.copilotKitSidebar .copilotKitWindow {
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export const useDarkMode = () => {
|
|
2
|
+
if (typeof window === "undefined") return false;
|
|
3
|
+
return (
|
|
4
|
+
document.documentElement.classList.contains("dark") ||
|
|
5
|
+
document.body.classList.contains("dark") ||
|
|
6
|
+
document.documentElement.getAttribute("data-theme") === "dark" ||
|
|
7
|
+
document.body.getAttribute("data-theme") === "dark" ||
|
|
8
|
+
window.matchMedia("(prefers-color-scheme: dark)").matches
|
|
9
|
+
);
|
|
10
|
+
};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/components/chat/Window.tsx"],"sourcesContent":["import React, { useCallback, useEffect } from \"react\";\nimport { WindowProps } from \"./props\";\nimport { useChatContext } from \"./ChatContext\";\n\nexport const Window = ({\n children,\n clickOutsideToClose,\n shortcut,\n hitEscapeToClose,\n}: WindowProps) => {\n const windowRef = React.useRef<HTMLDivElement>(null);\n\n const { open, setOpen } = useChatContext();\n\n const handleClickOutside = useCallback(\n (event: MouseEvent) => {\n if (!clickOutsideToClose) {\n return;\n }\n\n const parentElement = windowRef.current?.parentElement;\n\n let className = \"\";\n if (event.target instanceof HTMLElement) {\n className = event.target.className;\n }\n\n if (\n open &&\n parentElement &&\n !parentElement.contains(event.target as any) &&\n // prevent closing the window when clicking on the debug menu\n !className.includes(\"copilotKitDebugMenu\")\n ) {\n setOpen(false);\n }\n },\n [clickOutsideToClose, open, setOpen],\n );\n\n const handleKeyDown = useCallback(\n (event: KeyboardEvent) => {\n const target = event.target as HTMLElement;\n const isInput =\n target.tagName === \"INPUT\" ||\n target.tagName === \"SELECT\" ||\n target.tagName === \"TEXTAREA\" ||\n target.isContentEditable;\n\n const isDescendantOfWrapper = windowRef.current?.contains(target);\n\n if (\n open &&\n event.key === \"Escape\" &&\n (!isInput || isDescendantOfWrapper) &&\n hitEscapeToClose\n ) {\n setOpen(false);\n } else if (\n event.key === shortcut &&\n ((isMacOS() && event.metaKey) || (!isMacOS() && event.ctrlKey)) &&\n (!isInput || isDescendantOfWrapper)\n ) {\n setOpen(!open);\n }\n },\n [hitEscapeToClose, shortcut, open, setOpen],\n );\n\n const adjustForMobile = useCallback(() => {\n const copilotKitWindow = windowRef.current;\n const vv = window.visualViewport;\n if (!copilotKitWindow || !vv) {\n return;\n }\n\n if (window.innerWidth < 640 && open) {\n copilotKitWindow.style.height = `${vv.height}px`;\n copilotKitWindow.style.left = `${vv.offsetLeft}px`;\n copilotKitWindow.style.top = `${vv.offsetTop}px`;\n\n document.body.style.position = \"fixed\";\n document.body.style.width = \"100%\";\n document.body.style.height = `${window.innerHeight}px`;\n document.body.style.overflow = \"hidden\";\n document.body.style.touchAction = \"none\";\n\n // Prevent scrolling on iOS\n document.body.addEventListener(\"touchmove\", preventScroll, {\n passive: false,\n });\n } else {\n copilotKitWindow.style.height = \"\";\n copilotKitWindow.style.left = \"\";\n copilotKitWindow.style.top = \"\";\n document.body.style.position = \"\";\n document.body.style.height = \"\";\n document.body.style.width = \"\";\n document.body.style.overflow = \"\";\n document.body.style.top = \"\";\n document.body.style.touchAction = \"\";\n\n document.body.removeEventListener(\"touchmove\", preventScroll);\n }\n }, [open]);\n\n useEffect(() => {\n document.addEventListener(\"mousedown\", handleClickOutside);\n document.addEventListener(\"keydown\", handleKeyDown);\n if (window.visualViewport) {\n window.visualViewport.addEventListener(\"resize\", adjustForMobile);\n adjustForMobile();\n }\n\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n document.removeEventListener(\"keydown\", handleKeyDown);\n if (window.visualViewport) {\n window.visualViewport.removeEventListener(\"resize\", adjustForMobile);\n }\n };\n }, [adjustForMobile, handleClickOutside, handleKeyDown]);\n\n return (\n <div className={`copilotKitWindow${open ? \" open\" : \"\"}`} ref={windowRef}>\n {children}\n </div>\n );\n};\n\nconst preventScroll = (event: TouchEvent): void => {\n let targetElement = event.target as Element;\n\n // Function to check if the target has the parent with a given class\n const hasParentWithClass = (element: Element, className: string): boolean => {\n while (element && element !== document.body) {\n if (element.classList.contains(className)) {\n return true;\n }\n element = element.parentElement!;\n }\n return false;\n };\n\n // Check if the target of the touch event is inside an element with the 'copilotKitMessages' class\n if (!hasParentWithClass(targetElement, \"copilotKitMessages\")) {\n event.preventDefault();\n }\n};\n\nfunction isMacOS() {\n return /Mac|iMac|Macintosh/i.test(navigator.userAgent);\n}\n"],"mappings":"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","names":[]}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|