@copilotkit/react-ui 1.8.5-next.1 → 1.8.5-next.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (79) hide show
  1. package/CHANGELOG.md +18 -0
  2. package/dist/{chunk-Q2YY2NX3.mjs → chunk-COZFHP6Y.mjs} +2 -2
  3. package/dist/{chunk-MYUOPOIL.mjs → chunk-DRAM4KIH.mjs} +13 -13
  4. package/dist/{chunk-PCTCOQK2.mjs → chunk-DYUT4CVD.mjs} +4 -4
  5. package/dist/{chunk-4TWPMWD4.mjs → chunk-GULJZORG.mjs} +8 -8
  6. package/dist/chunk-JGMFJZMG.mjs +11 -0
  7. package/dist/chunk-JGMFJZMG.mjs.map +1 -0
  8. package/dist/{chunk-XNQO5AZZ.mjs → chunk-KSW7FVYG.mjs} +2 -2
  9. package/dist/{chunk-5M7ODWKH.mjs → chunk-N7ZQXCKF.mjs} +2 -2
  10. package/dist/{chunk-6QV7AIIG.mjs → chunk-P53JYD5X.mjs} +2 -2
  11. package/dist/{chunk-D5XIJNXQ.mjs → chunk-Q6XB5B2M.mjs} +7 -7
  12. package/dist/{chunk-2OTVZXDX.mjs → chunk-QDC2Q7XX.mjs} +2 -2
  13. package/dist/{chunk-NMNC4ROZ.mjs → chunk-QMW2LYI3.mjs} +2 -2
  14. package/dist/{chunk-P7S3E5UW.mjs → chunk-QSUC3MKT.mjs} +35 -7
  15. package/dist/chunk-QSUC3MKT.mjs.map +1 -0
  16. package/dist/{chunk-QJKMOGWN.mjs → chunk-RXBEZZ5I.mjs} +4 -4
  17. package/dist/{chunk-U6ISBBRF.mjs → chunk-TYAYVE3X.mjs} +2 -2
  18. package/dist/{chunk-62QMTKMJ.mjs → chunk-USR5CBYD.mjs} +4 -4
  19. package/dist/{chunk-WNC6OCIB.mjs → chunk-YIQTTJAT.mjs} +2 -2
  20. package/dist/components/chat/Chat.mjs +11 -11
  21. package/dist/components/chat/CodeBlock.mjs +2 -2
  22. package/dist/components/chat/Header.mjs +3 -3
  23. package/dist/components/chat/Input.mjs +2 -2
  24. package/dist/components/chat/Markdown.mjs +3 -3
  25. package/dist/components/chat/Modal.js +66 -32
  26. package/dist/components/chat/Modal.js.map +1 -1
  27. package/dist/components/chat/Modal.mjs +17 -16
  28. package/dist/components/chat/Popup.js +66 -32
  29. package/dist/components/chat/Popup.js.map +1 -1
  30. package/dist/components/chat/Popup.mjs +18 -17
  31. package/dist/components/chat/Sidebar.js +66 -32
  32. package/dist/components/chat/Sidebar.js.map +1 -1
  33. package/dist/components/chat/Sidebar.mjs +18 -17
  34. package/dist/components/chat/Window.js +39 -5
  35. package/dist/components/chat/Window.js.map +1 -1
  36. package/dist/components/chat/Window.mjs +2 -1
  37. package/dist/components/chat/index.js +66 -32
  38. package/dist/components/chat/index.js.map +1 -1
  39. package/dist/components/chat/index.mjs +22 -21
  40. package/dist/components/chat/messages/AssistantMessage.mjs +4 -4
  41. package/dist/components/chat/messages/RenderActionExecutionMessage.mjs +5 -5
  42. package/dist/components/chat/messages/RenderAgentStateMessage.mjs +5 -5
  43. package/dist/components/chat/messages/RenderResultMessage.mjs +5 -5
  44. package/dist/components/chat/messages/RenderTextMessage.mjs +5 -5
  45. package/dist/components/dev-console/console.mjs +2 -2
  46. package/dist/components/dev-console/index.mjs +2 -2
  47. package/dist/components/index.js +66 -32
  48. package/dist/components/index.js.map +1 -1
  49. package/dist/components/index.mjs +22 -21
  50. package/dist/hooks/use-dark-mode.d.ts +3 -0
  51. package/dist/hooks/use-dark-mode.js +35 -0
  52. package/dist/hooks/use-dark-mode.js.map +1 -0
  53. package/dist/hooks/use-dark-mode.mjs +8 -0
  54. package/dist/hooks/use-dark-mode.mjs.map +1 -0
  55. package/dist/index.css +25 -1
  56. package/dist/index.css.map +1 -1
  57. package/dist/index.js +68 -34
  58. package/dist/index.js.map +1 -1
  59. package/dist/index.mjs +28 -27
  60. package/package.json +4 -4
  61. package/src/components/chat/Window.tsx +26 -1
  62. package/src/css/input.css +1 -1
  63. package/src/css/window.css +27 -0
  64. package/src/hooks/use-dark-mode.ts +10 -0
  65. package/dist/chunk-P7S3E5UW.mjs.map +0 -1
  66. /package/dist/{chunk-Q2YY2NX3.mjs.map → chunk-COZFHP6Y.mjs.map} +0 -0
  67. /package/dist/{chunk-MYUOPOIL.mjs.map → chunk-DRAM4KIH.mjs.map} +0 -0
  68. /package/dist/{chunk-PCTCOQK2.mjs.map → chunk-DYUT4CVD.mjs.map} +0 -0
  69. /package/dist/{chunk-4TWPMWD4.mjs.map → chunk-GULJZORG.mjs.map} +0 -0
  70. /package/dist/{chunk-XNQO5AZZ.mjs.map → chunk-KSW7FVYG.mjs.map} +0 -0
  71. /package/dist/{chunk-5M7ODWKH.mjs.map → chunk-N7ZQXCKF.mjs.map} +0 -0
  72. /package/dist/{chunk-6QV7AIIG.mjs.map → chunk-P53JYD5X.mjs.map} +0 -0
  73. /package/dist/{chunk-D5XIJNXQ.mjs.map → chunk-Q6XB5B2M.mjs.map} +0 -0
  74. /package/dist/{chunk-2OTVZXDX.mjs.map → chunk-QDC2Q7XX.mjs.map} +0 -0
  75. /package/dist/{chunk-NMNC4ROZ.mjs.map → chunk-QMW2LYI3.mjs.map} +0 -0
  76. /package/dist/{chunk-QJKMOGWN.mjs.map → chunk-RXBEZZ5I.mjs.map} +0 -0
  77. /package/dist/{chunk-U6ISBBRF.mjs.map → chunk-TYAYVE3X.mjs.map} +0 -0
  78. /package/dist/{chunk-62QMTKMJ.mjs.map → chunk-USR5CBYD.mjs.map} +0 -0
  79. /package/dist/{chunk-WNC6OCIB.mjs.map → chunk-YIQTTJAT.mjs.map} +0 -0
package/dist/index.mjs CHANGED
@@ -1,61 +1,62 @@
1
1
  "use client";
2
- import "./chunk-EFZPSZWO.mjs";
2
+ import "./chunk-T26KLXLH.mjs";
3
+ import {
4
+ useCopilotChatSuggestions
5
+ } from "./chunk-Z4XPPVZT.mjs";
6
+ import "./chunk-IU3WTXLQ.mjs";
3
7
  import "./chunk-MMVDU6DF.mjs";
4
8
  import "./chunk-SQMEPWVT.mjs";
5
- import "./chunk-WB3YULQ4.mjs";
6
9
  import {
7
10
  CopilotPopup
8
- } from "./chunk-6QV7AIIG.mjs";
11
+ } from "./chunk-P53JYD5X.mjs";
9
12
  import {
10
13
  CopilotSidebar
11
- } from "./chunk-U6ISBBRF.mjs";
12
- import "./chunk-4TWPMWD4.mjs";
13
- import "./chunk-P7S3E5UW.mjs";
14
- import "./chunk-2OTVZXDX.mjs";
14
+ } from "./chunk-TYAYVE3X.mjs";
15
+ import "./chunk-WB3YULQ4.mjs";
16
+ import "./chunk-GULJZORG.mjs";
17
+ import "./chunk-QSUC3MKT.mjs";
18
+ import "./chunk-JGMFJZMG.mjs";
19
+ import "./chunk-QDC2Q7XX.mjs";
15
20
  import "./chunk-V7W6IM2V.mjs";
16
21
  import {
17
22
  CopilotDevConsole
18
- } from "./chunk-D5XIJNXQ.mjs";
23
+ } from "./chunk-Q6XB5B2M.mjs";
24
+ import "./chunk-Q5V6S67N.mjs";
19
25
  import {
20
26
  shouldShowDevConsole
21
27
  } from "./chunk-6TCUJ3B7.mjs";
22
28
  import "./chunk-KXE2JCUH.mjs";
23
29
  import "./chunk-NRA3CFEE.mjs";
24
30
  import "./chunk-BH6PCAAL.mjs";
25
- import "./chunk-Q5V6S67N.mjs";
31
+ import "./chunk-EFZPSZWO.mjs";
26
32
  import "./chunk-YOEL33HG.mjs";
27
33
  import {
28
34
  CopilotChat
29
- } from "./chunk-MYUOPOIL.mjs";
30
- import "./chunk-WNC6OCIB.mjs";
31
- import "./chunk-62QMTKMJ.mjs";
35
+ } from "./chunk-DRAM4KIH.mjs";
36
+ import "./chunk-QMW2LYI3.mjs";
37
+ import "./chunk-COZFHP6Y.mjs";
38
+ import "./chunk-YIQTTJAT.mjs";
39
+ import "./chunk-USR5CBYD.mjs";
40
+ import {
41
+ AssistantMessage
42
+ } from "./chunk-N7ZQXCKF.mjs";
32
43
  import {
33
44
  UserMessage
34
45
  } from "./chunk-HEIDCT7I.mjs";
35
- import "./chunk-NMNC4ROZ.mjs";
36
- import "./chunk-Q2YY2NX3.mjs";
37
- import {
38
- AssistantMessage
39
- } from "./chunk-5M7ODWKH.mjs";
40
46
  import "./chunk-TOQ7P4DO.mjs";
41
- import "./chunk-QJKMOGWN.mjs";
47
+ import "./chunk-RXBEZZ5I.mjs";
48
+ import "./chunk-S5MBUNGN.mjs";
42
49
  import "./chunk-YQFVRDNC.mjs";
43
50
  import {
44
51
  Markdown
45
- } from "./chunk-XNQO5AZZ.mjs";
52
+ } from "./chunk-KSW7FVYG.mjs";
53
+ import "./chunk-DYUT4CVD.mjs";
54
+ import "./chunk-54JAUBUJ.mjs";
46
55
  import "./chunk-ZY25LVYR.mjs";
47
56
  import {
48
57
  useChatContext
49
58
  } from "./chunk-UN2E3HCK.mjs";
50
- import "./chunk-PCTCOQK2.mjs";
51
59
  import "./chunk-ORSMX3SE.mjs";
52
- import "./chunk-IU3WTXLQ.mjs";
53
- import "./chunk-T26KLXLH.mjs";
54
- import {
55
- useCopilotChatSuggestions
56
- } from "./chunk-Z4XPPVZT.mjs";
57
- import "./chunk-54JAUBUJ.mjs";
58
- import "./chunk-S5MBUNGN.mjs";
59
60
  import "./chunk-MRXNTQOX.mjs";
60
61
  export {
61
62
  AssistantMessage,
package/package.json CHANGED
@@ -9,7 +9,7 @@
9
9
  "publishConfig": {
10
10
  "access": "public"
11
11
  },
12
- "version": "1.8.5-next.1",
12
+ "version": "1.8.5-next.3",
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.1",
54
- "@copilotkit/runtime-client-gql": "1.8.5-next.1",
55
- "@copilotkit/shared": "1.8.5-next.1"
53
+ "@copilotkit/react-core": "1.8.5-next.3",
54
+ "@copilotkit/runtime-client-gql": "1.8.5-next.3",
55
+ "@copilotkit/shared": "1.8.5-next.3"
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 className={`copilotKitWindow${open ? " open" : ""}`} ref={windowRef}>
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
@@ -14,7 +14,7 @@
14
14
 
15
15
  .copilotKitInputContainer {
16
16
  width: 100%;
17
- padding: 0 0 15px 0;
17
+ padding: 0;
18
18
  background: var(--copilot-kit-background-color);
19
19
  border-bottom-left-radius: 0.75rem;
20
20
  border-bottom-right-radius: 0.75rem;
@@ -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":[]}