@copilotkit/react-ui 1.9.3 → 1.10.0-next.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (198) hide show
  1. package/CHANGELOG.md +38 -0
  2. package/dist/{chunk-GVKA7RQQ.mjs → chunk-7CAK2CNK.mjs} +2 -2
  3. package/dist/{chunk-KN2GCKBE.mjs → chunk-7RNOT3GM.mjs} +9 -9
  4. package/dist/{chunk-KENCH7RN.mjs → chunk-B5IFB5YJ.mjs} +1 -1
  5. package/dist/chunk-B5IFB5YJ.mjs.map +1 -0
  6. package/dist/chunk-DBKRAOH7.mjs +34 -0
  7. package/dist/chunk-DBKRAOH7.mjs.map +1 -0
  8. package/dist/{chunk-4HUXYD3B.mjs → chunk-DTRPPNSA.mjs} +2 -2
  9. package/dist/{chunk-YTXEWDNC.mjs → chunk-E6MQUIZW.mjs} +15 -4
  10. package/dist/chunk-E6MQUIZW.mjs.map +1 -0
  11. package/dist/{chunk-Z4XPPVZT.mjs → chunk-EYRKZDP5.mjs} +1 -1
  12. package/dist/chunk-EYRKZDP5.mjs.map +1 -0
  13. package/dist/{chunk-SGFUVPDB.mjs → chunk-FOSKS7AI.mjs} +4 -4
  14. package/dist/{chunk-L3GZ7TXC.mjs → chunk-GCKKSSBU.mjs} +21 -24
  15. package/dist/chunk-GCKKSSBU.mjs.map +1 -0
  16. package/dist/{chunk-S5MBUNGN.mjs → chunk-O72ZB5V3.mjs} +4 -4
  17. package/dist/chunk-O72ZB5V3.mjs.map +1 -0
  18. package/dist/{chunk-QGSPTXOV.mjs → chunk-O7KTFUAN.mjs} +2 -2
  19. package/dist/chunk-O7KTFUAN.mjs.map +1 -0
  20. package/dist/{chunk-HKTWKCPS.mjs → chunk-O7PYQO73.mjs} +127 -92
  21. package/dist/chunk-O7PYQO73.mjs.map +1 -0
  22. package/dist/{chunk-32MUWKL3.mjs → chunk-OQM7D3Z3.mjs} +22 -18
  23. package/dist/chunk-OQM7D3Z3.mjs.map +1 -0
  24. package/dist/chunk-Q2467VHZ.mjs +30 -0
  25. package/dist/chunk-Q2467VHZ.mjs.map +1 -0
  26. package/dist/{chunk-ALIBUJML.mjs → chunk-QELAC6XJ.mjs} +2 -2
  27. package/dist/chunk-QELAC6XJ.mjs.map +1 -0
  28. package/dist/{chunk-H3EM63WS.mjs → chunk-TCIZDWPC.mjs} +2 -2
  29. package/dist/chunk-TCIZDWPC.mjs.map +1 -0
  30. package/dist/chunk-VVL6JFCJ.mjs +16 -0
  31. package/dist/chunk-VVL6JFCJ.mjs.map +1 -0
  32. package/dist/chunk-WHDNKXMP.mjs +135 -0
  33. package/dist/chunk-WHDNKXMP.mjs.map +1 -0
  34. package/dist/components/chat/Button.d.ts +1 -1
  35. package/dist/components/chat/Chat.d.ts +119 -28
  36. package/dist/components/chat/Chat.js +298 -658
  37. package/dist/components/chat/Chat.js.map +1 -1
  38. package/dist/components/chat/Chat.mjs +12 -15
  39. package/dist/components/chat/CodeBlock.js.map +1 -1
  40. package/dist/components/chat/CodeBlock.mjs +1 -1
  41. package/dist/components/chat/Header.d.ts +1 -1
  42. package/dist/components/chat/Header.mjs +4 -4
  43. package/dist/components/chat/Input.d.ts +1 -1
  44. package/dist/components/chat/Input.js +3 -3
  45. package/dist/components/chat/Input.js.map +1 -1
  46. package/dist/components/chat/Input.mjs +2 -2
  47. package/dist/components/chat/Markdown.js +13 -2
  48. package/dist/components/chat/Markdown.js.map +1 -1
  49. package/dist/components/chat/Markdown.mjs +2 -2
  50. package/dist/components/chat/Messages.d.ts +3 -3
  51. package/dist/components/chat/Messages.js +40 -116
  52. package/dist/components/chat/Messages.js.map +1 -1
  53. package/dist/components/chat/Messages.mjs +1 -1
  54. package/dist/components/chat/Modal.d.ts +7 -2
  55. package/dist/components/chat/Modal.js +308 -668
  56. package/dist/components/chat/Modal.js.map +1 -1
  57. package/dist/components/chat/Modal.mjs +17 -20
  58. package/dist/components/chat/Popup.d.ts +7 -2
  59. package/dist/components/chat/Popup.js +310 -670
  60. package/dist/components/chat/Popup.js.map +1 -1
  61. package/dist/components/chat/Popup.mjs +18 -21
  62. package/dist/components/chat/Sidebar.d.ts +7 -2
  63. package/dist/components/chat/Sidebar.js +312 -672
  64. package/dist/components/chat/Sidebar.js.map +1 -1
  65. package/dist/components/chat/Sidebar.mjs +18 -21
  66. package/dist/components/chat/Suggestion.d.ts +2 -9
  67. package/dist/components/chat/Suggestion.js +6 -96
  68. package/dist/components/chat/Suggestion.js.map +1 -1
  69. package/dist/components/chat/Suggestion.mjs +3 -5
  70. package/dist/components/chat/Suggestions.d.ts +1 -1
  71. package/dist/components/chat/Suggestions.js +4 -3
  72. package/dist/components/chat/Suggestions.js.map +1 -1
  73. package/dist/components/chat/Suggestions.mjs +2 -2
  74. package/dist/components/chat/Window.d.ts +1 -1
  75. package/dist/components/chat/index.d.ts +8 -3
  76. package/dist/components/chat/index.js +316 -676
  77. package/dist/components/chat/index.js.map +1 -1
  78. package/dist/components/chat/index.mjs +22 -25
  79. package/dist/components/chat/messages/AssistantMessage.d.ts +1 -1
  80. package/dist/components/chat/messages/AssistantMessage.js +32 -24
  81. package/dist/components/chat/messages/AssistantMessage.js.map +1 -1
  82. package/dist/components/chat/messages/AssistantMessage.mjs +3 -3
  83. package/dist/components/chat/messages/ImageRenderer.d.ts +12 -0
  84. package/dist/components/chat/messages/ImageRenderer.js +58 -0
  85. package/dist/components/chat/messages/ImageRenderer.js.map +1 -0
  86. package/dist/components/chat/messages/ImageRenderer.mjs +8 -0
  87. package/dist/components/chat/messages/RenderMessage.d.ts +9 -0
  88. package/dist/components/chat/messages/{RenderTextMessage.js → RenderMessage.js} +92 -47
  89. package/dist/components/chat/messages/RenderMessage.js.map +1 -0
  90. package/dist/components/chat/messages/RenderMessage.mjs +16 -0
  91. package/dist/components/chat/messages/UserMessage.d.ts +1 -1
  92. package/dist/components/chat/messages/UserMessage.js +7 -1
  93. package/dist/components/chat/messages/UserMessage.js.map +1 -1
  94. package/dist/components/chat/messages/UserMessage.mjs +1 -1
  95. package/dist/components/chat/props.d.ts +32 -27
  96. package/dist/components/chat/props.js.map +1 -1
  97. package/dist/components/dev-console/console.mjs +3 -3
  98. package/dist/components/dev-console/index.mjs +4 -4
  99. package/dist/components/index.d.ts +8 -3
  100. package/dist/components/index.js +316 -676
  101. package/dist/components/index.js.map +1 -1
  102. package/dist/components/index.mjs +23 -26
  103. package/dist/hooks/index.js.map +1 -1
  104. package/dist/hooks/index.mjs +1 -1
  105. package/dist/hooks/use-copilot-chat-suggestions.d.ts +1 -1
  106. package/dist/hooks/use-copilot-chat-suggestions.js.map +1 -1
  107. package/dist/hooks/use-copilot-chat-suggestions.mjs +1 -1
  108. package/dist/hooks/use-push-to-talk.d.ts +1 -1
  109. package/dist/hooks/use-push-to-talk.js +3 -3
  110. package/dist/hooks/use-push-to-talk.js.map +1 -1
  111. package/dist/hooks/use-push-to-talk.mjs +1 -1
  112. package/dist/index.css +59 -3
  113. package/dist/index.css.map +1 -1
  114. package/dist/index.d.ts +8 -3
  115. package/dist/index.js +322 -682
  116. package/dist/index.js.map +1 -1
  117. package/dist/index.mjs +24 -27
  118. package/dist/types/css.d.ts +3 -0
  119. package/dist/types/css.js.map +1 -1
  120. package/package.json +4 -4
  121. package/src/components/chat/Chat.tsx +194 -106
  122. package/src/components/chat/CodeBlock.tsx +1 -1
  123. package/src/components/chat/Markdown.tsx +12 -2
  124. package/src/components/chat/Messages.tsx +43 -122
  125. package/src/components/chat/Popup.tsx +1 -1
  126. package/src/components/chat/Sidebar.tsx +1 -1
  127. package/src/components/chat/Suggestion.tsx +5 -108
  128. package/src/components/chat/Suggestions.tsx +0 -1
  129. package/src/components/chat/index.tsx +1 -1
  130. package/src/components/chat/messages/AssistantMessage.tsx +15 -23
  131. package/src/components/chat/messages/ImageRenderer.tsx +37 -0
  132. package/src/components/chat/messages/{RenderTextMessage.tsx → RenderMessage.tsx} +10 -9
  133. package/src/components/chat/messages/UserMessage.tsx +16 -5
  134. package/src/components/chat/props.ts +36 -28
  135. package/src/css/colors.css +10 -0
  136. package/src/css/markdown.css +8 -0
  137. package/src/css/messages.css +54 -5
  138. package/src/css/suggestions.css +1 -1
  139. package/src/hooks/use-copilot-chat-suggestions.tsx +1 -1
  140. package/src/hooks/use-push-to-talk.tsx +6 -5
  141. package/src/styles.css +1 -1
  142. package/src/types/css.ts +3 -0
  143. package/dist/chunk-2II3Q27P.mjs +0 -112
  144. package/dist/chunk-2II3Q27P.mjs.map +0 -1
  145. package/dist/chunk-32MUWKL3.mjs.map +0 -1
  146. package/dist/chunk-53CVDVS5.mjs +0 -127
  147. package/dist/chunk-53CVDVS5.mjs.map +0 -1
  148. package/dist/chunk-ALIBUJML.mjs.map +0 -1
  149. package/dist/chunk-B3D7U7TJ.mjs +0 -211
  150. package/dist/chunk-B3D7U7TJ.mjs.map +0 -1
  151. package/dist/chunk-C7OB63U5.mjs +0 -36
  152. package/dist/chunk-C7OB63U5.mjs.map +0 -1
  153. package/dist/chunk-H3EM63WS.mjs.map +0 -1
  154. package/dist/chunk-HKTWKCPS.mjs.map +0 -1
  155. package/dist/chunk-HWMFMBJC.mjs +0 -10
  156. package/dist/chunk-HWMFMBJC.mjs.map +0 -1
  157. package/dist/chunk-IMBPSLL4.mjs +0 -104
  158. package/dist/chunk-IMBPSLL4.mjs.map +0 -1
  159. package/dist/chunk-KENCH7RN.mjs.map +0 -1
  160. package/dist/chunk-L3GZ7TXC.mjs.map +0 -1
  161. package/dist/chunk-QGSPTXOV.mjs.map +0 -1
  162. package/dist/chunk-S5MBUNGN.mjs.map +0 -1
  163. package/dist/chunk-ULDQXCED.mjs +0 -78
  164. package/dist/chunk-ULDQXCED.mjs.map +0 -1
  165. package/dist/chunk-YTXEWDNC.mjs.map +0 -1
  166. package/dist/chunk-Z4XPPVZT.mjs.map +0 -1
  167. package/dist/components/chat/messages/RenderActionExecutionMessage.d.ts +0 -9
  168. package/dist/components/chat/messages/RenderActionExecutionMessage.js +0 -869
  169. package/dist/components/chat/messages/RenderActionExecutionMessage.js.map +0 -1
  170. package/dist/components/chat/messages/RenderActionExecutionMessage.mjs +0 -14
  171. package/dist/components/chat/messages/RenderAgentStateMessage.d.ts +0 -9
  172. package/dist/components/chat/messages/RenderAgentStateMessage.js +0 -854
  173. package/dist/components/chat/messages/RenderAgentStateMessage.js.map +0 -1
  174. package/dist/components/chat/messages/RenderAgentStateMessage.mjs +0 -14
  175. package/dist/components/chat/messages/RenderImageMessage.d.ts +0 -9
  176. package/dist/components/chat/messages/RenderImageMessage.js +0 -823
  177. package/dist/components/chat/messages/RenderImageMessage.js.map +0 -1
  178. package/dist/components/chat/messages/RenderImageMessage.mjs +0 -15
  179. package/dist/components/chat/messages/RenderImageMessage.mjs.map +0 -1
  180. package/dist/components/chat/messages/RenderResultMessage.d.ts +0 -9
  181. package/dist/components/chat/messages/RenderResultMessage.js +0 -778
  182. package/dist/components/chat/messages/RenderResultMessage.js.map +0 -1
  183. package/dist/components/chat/messages/RenderResultMessage.mjs +0 -14
  184. package/dist/components/chat/messages/RenderResultMessage.mjs.map +0 -1
  185. package/dist/components/chat/messages/RenderTextMessage.d.ts +0 -9
  186. package/dist/components/chat/messages/RenderTextMessage.js.map +0 -1
  187. package/dist/components/chat/messages/RenderTextMessage.mjs +0 -15
  188. package/dist/components/chat/messages/RenderTextMessage.mjs.map +0 -1
  189. package/src/components/chat/messages/RenderActionExecutionMessage.tsx +0 -127
  190. package/src/components/chat/messages/RenderAgentStateMessage.tsx +0 -116
  191. package/src/components/chat/messages/RenderImageMessage.tsx +0 -64
  192. package/src/components/chat/messages/RenderResultMessage.tsx +0 -26
  193. /package/dist/{chunk-GVKA7RQQ.mjs.map → chunk-7CAK2CNK.mjs.map} +0 -0
  194. /package/dist/{chunk-KN2GCKBE.mjs.map → chunk-7RNOT3GM.mjs.map} +0 -0
  195. /package/dist/{chunk-4HUXYD3B.mjs.map → chunk-DTRPPNSA.mjs.map} +0 -0
  196. /package/dist/{chunk-SGFUVPDB.mjs.map → chunk-FOSKS7AI.mjs.map} +0 -0
  197. /package/dist/components/chat/messages/{RenderActionExecutionMessage.mjs.map → ImageRenderer.mjs.map} +0 -0
  198. /package/dist/components/chat/messages/{RenderAgentStateMessage.mjs.map → RenderMessage.mjs.map} +0 -0
@@ -1,823 +0,0 @@
1
- "use strict";
2
- var __create = Object.create;
3
- var __defProp = Object.defineProperty;
4
- var __defProps = Object.defineProperties;
5
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
7
- var __getOwnPropNames = Object.getOwnPropertyNames;
8
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
9
- var __getProtoOf = Object.getPrototypeOf;
10
- var __hasOwnProp = Object.prototype.hasOwnProperty;
11
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
12
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
13
- var __spreadValues = (a, b) => {
14
- for (var prop in b || (b = {}))
15
- if (__hasOwnProp.call(b, prop))
16
- __defNormalProp(a, prop, b[prop]);
17
- if (__getOwnPropSymbols)
18
- for (var prop of __getOwnPropSymbols(b)) {
19
- if (__propIsEnum.call(b, prop))
20
- __defNormalProp(a, prop, b[prop]);
21
- }
22
- return a;
23
- };
24
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
25
- var __objRest = (source, exclude) => {
26
- var target = {};
27
- for (var prop in source)
28
- if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
29
- target[prop] = source[prop];
30
- if (source != null && __getOwnPropSymbols)
31
- for (var prop of __getOwnPropSymbols(source)) {
32
- if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
33
- target[prop] = source[prop];
34
- }
35
- return target;
36
- };
37
- var __export = (target, all) => {
38
- for (var name in all)
39
- __defProp(target, name, { get: all[name], enumerable: true });
40
- };
41
- var __copyProps = (to, from, except, desc) => {
42
- if (from && typeof from === "object" || typeof from === "function") {
43
- for (let key of __getOwnPropNames(from))
44
- if (!__hasOwnProp.call(to, key) && key !== except)
45
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
46
- }
47
- return to;
48
- };
49
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
50
- // If the importer is in node compatibility mode or this is not an ESM
51
- // file that has been converted to a CommonJS file using a Babel-
52
- // compatible transform (i.e. "__esModule" has not been set), then set
53
- // "default" to the CommonJS "module.exports" for node compatibility.
54
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
55
- mod
56
- ));
57
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
58
-
59
- // src/components/chat/messages/RenderImageMessage.tsx
60
- var RenderImageMessage_exports = {};
61
- __export(RenderImageMessage_exports, {
62
- RenderImageMessage: () => RenderImageMessage
63
- });
64
- module.exports = __toCommonJS(RenderImageMessage_exports);
65
-
66
- // src/components/chat/messages/UserMessage.tsx
67
- var import_jsx_runtime = require("react/jsx-runtime");
68
- var UserMessage = (props) => {
69
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: "copilotKitMessage copilotKitUserMessage", children: props.subComponent || props.message });
70
- };
71
-
72
- // src/components/chat/ChatContext.tsx
73
- var import_react = __toESM(require("react"));
74
-
75
- // src/components/chat/Icons.tsx
76
- var import_jsx_runtime2 = require("react/jsx-runtime");
77
- var CopyIcon = /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
78
- "svg",
79
- {
80
- xmlns: "http://www.w3.org/2000/svg",
81
- fill: "none",
82
- viewBox: "0 0 24 24",
83
- strokeWidth: "2",
84
- stroke: "currentColor",
85
- width: "16",
86
- height: "16",
87
- style: { minWidth: "16px", minHeight: "16px" },
88
- children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
89
- "path",
90
- {
91
- strokeLinecap: "round",
92
- strokeLinejoin: "round",
93
- d: "M15.75 17.25v3.375c0 .621-.504 1.125-1.125 1.125h-9.75a1.125 1.125 0 01-1.125-1.125V7.875c0-.621.504-1.125 1.125-1.125H6.75a9.06 9.06 0 011.5.124m7.5 10.376h3.375c.621 0 1.125-.504 1.125-1.125V11.25c0-4.46-3.243-8.161-7.5-8.876a9.06 9.06 0 00-1.5-.124H9.375c-.621 0-1.125.504-1.125 1.125v3.5m7.5 10.375H9.375a1.125 1.125 0 01-1.125-1.125v-9.25m12 6.625v-1.875a3.375 3.375 0 00-3.375-3.375h-1.5a1.125 1.125 0 01-1.125-1.125v-1.5a3.375 3.375 0 00-3.375-3.375H9.75"
94
- }
95
- )
96
- }
97
- );
98
- var DownloadIcon = /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
99
- "svg",
100
- {
101
- xmlns: "http://www.w3.org/2000/svg",
102
- fill: "none",
103
- viewBox: "0 0 24 24",
104
- strokeWidth: "2",
105
- stroke: "currentColor",
106
- width: "16",
107
- height: "16",
108
- style: { minWidth: "16px", minHeight: "16px" },
109
- children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
110
- "path",
111
- {
112
- strokeLinecap: "round",
113
- strokeLinejoin: "round",
114
- d: "M3 16.5v2.25A2.25 2.25 0 005.25 21h13.5A2.25 2.25 0 0021 18.75V16.5M16.5 12L12 16.5m0 0L7.5 12m4.5 4.5V3"
115
- }
116
- )
117
- }
118
- );
119
- var CheckIcon = /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
120
- "svg",
121
- {
122
- xmlns: "http://www.w3.org/2000/svg",
123
- fill: "none",
124
- viewBox: "0 0 24 24",
125
- strokeWidth: "2",
126
- stroke: "currentColor",
127
- width: "16",
128
- height: "16",
129
- style: { minWidth: "16px", minHeight: "16px" },
130
- children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M4.5 12.75l6 6 9-13.5" })
131
- }
132
- );
133
-
134
- // src/components/chat/ChatContext.tsx
135
- var import_jsx_runtime3 = require("react/jsx-runtime");
136
- var ChatContext = import_react.default.createContext(void 0);
137
- function useChatContext() {
138
- const context = import_react.default.useContext(ChatContext);
139
- if (context === void 0) {
140
- throw new Error(
141
- "Context not found. Did you forget to wrap your app in a <ChatContextProvider> component?"
142
- );
143
- }
144
- return context;
145
- }
146
-
147
- // src/components/chat/Markdown.tsx
148
- var import_react3 = require("react");
149
- var import_react_markdown = __toESM(require("react-markdown"));
150
-
151
- // src/components/chat/CodeBlock.tsx
152
- var import_react2 = require("react");
153
- var import_react_syntax_highlighter = require("react-syntax-highlighter");
154
-
155
- // src/hooks/use-copy-to-clipboard.tsx
156
- var React2 = __toESM(require("react"));
157
- function useCopyToClipboard({ timeout = 2e3 }) {
158
- const [isCopied, setIsCopied] = React2.useState(false);
159
- const copyToClipboard = (value) => {
160
- var _a;
161
- if (typeof window === "undefined" || !((_a = navigator.clipboard) == null ? void 0 : _a.writeText)) {
162
- return;
163
- }
164
- if (!value) {
165
- return;
166
- }
167
- navigator.clipboard.writeText(value).then(() => {
168
- setIsCopied(true);
169
- setTimeout(() => {
170
- setIsCopied(false);
171
- }, timeout);
172
- });
173
- };
174
- return { isCopied, copyToClipboard };
175
- }
176
-
177
- // src/components/chat/CodeBlock.tsx
178
- var import_jsx_runtime4 = require("react/jsx-runtime");
179
- var programmingLanguages = {
180
- javascript: ".js",
181
- python: ".py",
182
- java: ".java",
183
- c: ".c",
184
- cpp: ".cpp",
185
- "c++": ".cpp",
186
- "c#": ".cs",
187
- ruby: ".rb",
188
- php: ".php",
189
- swift: ".swift",
190
- "objective-c": ".m",
191
- kotlin: ".kt",
192
- typescript: ".ts",
193
- go: ".go",
194
- perl: ".pl",
195
- rust: ".rs",
196
- scala: ".scala",
197
- haskell: ".hs",
198
- lua: ".lua",
199
- shell: ".sh",
200
- sql: ".sql",
201
- html: ".html",
202
- css: ".css"
203
- // add more file extensions here, make sure the key is same as language prop in CodeBlock.tsx component
204
- };
205
- var generateRandomString = (length, lowercase = false) => {
206
- const chars = "ABCDEFGHJKLMNPQRSTUVWXY3456789";
207
- let result = "";
208
- for (let i = 0; i < length; i++) {
209
- result += chars.charAt(Math.floor(Math.random() * chars.length));
210
- }
211
- return lowercase ? result.toLowerCase() : result;
212
- };
213
- var CodeBlock = (0, import_react2.memo)(({ language, value }) => {
214
- const { isCopied, copyToClipboard } = useCopyToClipboard({ timeout: 2e3 });
215
- const downloadAsFile = () => {
216
- if (typeof window === "undefined") {
217
- return;
218
- }
219
- const fileExtension = programmingLanguages[language] || ".file";
220
- const suggestedFileName = `file-${generateRandomString(3, true)}${fileExtension}`;
221
- const fileName = window.prompt("Enter file name", suggestedFileName);
222
- if (!fileName) {
223
- return;
224
- }
225
- const blob = new Blob([value], { type: "text/plain" });
226
- const url = URL.createObjectURL(blob);
227
- const link = document.createElement("a");
228
- link.download = fileName;
229
- link.href = url;
230
- link.style.display = "none";
231
- document.body.appendChild(link);
232
- link.click();
233
- document.body.removeChild(link);
234
- URL.revokeObjectURL(url);
235
- };
236
- const onCopy = () => {
237
- if (isCopied)
238
- return;
239
- copyToClipboard(value);
240
- };
241
- return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "copilotKitCodeBlock", children: [
242
- /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "copilotKitCodeBlockToolbar", children: [
243
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("span", { className: "copilotKitCodeBlockToolbarLanguage", children: language }),
244
- /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "copilotKitCodeBlockToolbarButtons", children: [
245
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("button", { className: "copilotKitCodeBlockToolbarButton", onClick: downloadAsFile, children: DownloadIcon }),
246
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("button", { className: "copilotKitCodeBlockToolbarButton", onClick: onCopy, children: isCopied ? CheckIcon : CopyIcon })
247
- ] })
248
- ] }),
249
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
250
- import_react_syntax_highlighter.Prism,
251
- {
252
- language,
253
- style: highlightStyle,
254
- PreTag: "div",
255
- customStyle: {
256
- margin: 0,
257
- borderBottomLeftRadius: "0.375rem",
258
- borderBottomRightRadius: "0.375rem"
259
- },
260
- children: value
261
- }
262
- )
263
- ] });
264
- });
265
- CodeBlock.displayName = "CodeBlock";
266
- var highlightStyle = {
267
- 'pre[class*="language-"]': {
268
- color: "#d4d4d4",
269
- fontSize: "13px",
270
- textShadow: "none",
271
- fontFamily: 'Menlo, Monaco, Consolas, "Andale Mono", "Ubuntu Mono", "Courier New", monospace',
272
- direction: "ltr",
273
- textAlign: "left",
274
- whiteSpace: "pre",
275
- wordSpacing: "normal",
276
- wordBreak: "normal",
277
- lineHeight: "1.5",
278
- MozTabSize: "4",
279
- OTabSize: "4",
280
- tabSize: "4",
281
- WebkitHyphens: "none",
282
- MozHyphens: "none",
283
- msHyphens: "none",
284
- hyphens: "none",
285
- padding: "1em",
286
- margin: ".5em 0",
287
- overflow: "auto",
288
- background: "#1e1e1e"
289
- },
290
- 'code[class*="language-"]': {
291
- color: "#d4d4d4",
292
- fontSize: "13px",
293
- textShadow: "none",
294
- fontFamily: 'Menlo, Monaco, Consolas, "Andale Mono", "Ubuntu Mono", "Courier New", monospace',
295
- direction: "ltr",
296
- textAlign: "left",
297
- whiteSpace: "pre",
298
- wordSpacing: "normal",
299
- wordBreak: "normal",
300
- lineHeight: "1.5",
301
- MozTabSize: "4",
302
- OTabSize: "4",
303
- tabSize: "4",
304
- WebkitHyphens: "none",
305
- MozHyphens: "none",
306
- msHyphens: "none",
307
- hyphens: "none"
308
- },
309
- 'pre[class*="language-"]::selection': {
310
- textShadow: "none",
311
- background: "#264F78"
312
- },
313
- 'code[class*="language-"]::selection': {
314
- textShadow: "none",
315
- background: "#264F78"
316
- },
317
- 'pre[class*="language-"] *::selection': {
318
- textShadow: "none",
319
- background: "#264F78"
320
- },
321
- 'code[class*="language-"] *::selection': {
322
- textShadow: "none",
323
- background: "#264F78"
324
- },
325
- ':not(pre) > code[class*="language-"]': {
326
- padding: ".1em .3em",
327
- borderRadius: ".3em",
328
- color: "#db4c69",
329
- background: "#1e1e1e"
330
- },
331
- ".namespace": {
332
- Opacity: ".7"
333
- },
334
- "doctype.doctype-tag": {
335
- color: "#569CD6"
336
- },
337
- "doctype.name": {
338
- color: "#9cdcfe"
339
- },
340
- comment: {
341
- color: "#6a9955"
342
- },
343
- prolog: {
344
- color: "#6a9955"
345
- },
346
- punctuation: {
347
- color: "#d4d4d4"
348
- },
349
- ".language-html .language-css .token.punctuation": {
350
- color: "#d4d4d4"
351
- },
352
- ".language-html .language-javascript .token.punctuation": {
353
- color: "#d4d4d4"
354
- },
355
- property: {
356
- color: "#9cdcfe"
357
- },
358
- tag: {
359
- color: "#569cd6"
360
- },
361
- boolean: {
362
- color: "#569cd6"
363
- },
364
- number: {
365
- color: "#b5cea8"
366
- },
367
- constant: {
368
- color: "#9cdcfe"
369
- },
370
- symbol: {
371
- color: "#b5cea8"
372
- },
373
- inserted: {
374
- color: "#b5cea8"
375
- },
376
- unit: {
377
- color: "#b5cea8"
378
- },
379
- selector: {
380
- color: "#d7ba7d"
381
- },
382
- "attr-name": {
383
- color: "#9cdcfe"
384
- },
385
- string: {
386
- color: "#ce9178"
387
- },
388
- char: {
389
- color: "#ce9178"
390
- },
391
- builtin: {
392
- color: "#ce9178"
393
- },
394
- deleted: {
395
- color: "#ce9178"
396
- },
397
- ".language-css .token.string.url": {
398
- textDecoration: "underline"
399
- },
400
- operator: {
401
- color: "#d4d4d4"
402
- },
403
- entity: {
404
- color: "#569cd6"
405
- },
406
- "operator.arrow": {
407
- color: "#569CD6"
408
- },
409
- atrule: {
410
- color: "#ce9178"
411
- },
412
- "atrule.rule": {
413
- color: "#c586c0"
414
- },
415
- "atrule.url": {
416
- color: "#9cdcfe"
417
- },
418
- "atrule.url.function": {
419
- color: "#dcdcaa"
420
- },
421
- "atrule.url.punctuation": {
422
- color: "#d4d4d4"
423
- },
424
- keyword: {
425
- color: "#569CD6"
426
- },
427
- "keyword.module": {
428
- color: "#c586c0"
429
- },
430
- "keyword.control-flow": {
431
- color: "#c586c0"
432
- },
433
- function: {
434
- color: "#dcdcaa"
435
- },
436
- "function.maybe-class-name": {
437
- color: "#dcdcaa"
438
- },
439
- regex: {
440
- color: "#d16969"
441
- },
442
- important: {
443
- color: "#569cd6"
444
- },
445
- italic: {
446
- fontStyle: "italic"
447
- },
448
- "class-name": {
449
- color: "#4ec9b0"
450
- },
451
- "maybe-class-name": {
452
- color: "#4ec9b0"
453
- },
454
- console: {
455
- color: "#9cdcfe"
456
- },
457
- parameter: {
458
- color: "#9cdcfe"
459
- },
460
- interpolation: {
461
- color: "#9cdcfe"
462
- },
463
- "punctuation.interpolation-punctuation": {
464
- color: "#569cd6"
465
- },
466
- variable: {
467
- color: "#9cdcfe"
468
- },
469
- "imports.maybe-class-name": {
470
- color: "#9cdcfe"
471
- },
472
- "exports.maybe-class-name": {
473
- color: "#9cdcfe"
474
- },
475
- escape: {
476
- color: "#d7ba7d"
477
- },
478
- "tag.punctuation": {
479
- color: "#808080"
480
- },
481
- cdata: {
482
- color: "#808080"
483
- },
484
- "attr-value": {
485
- color: "#ce9178"
486
- },
487
- "attr-value.punctuation": {
488
- color: "#ce9178"
489
- },
490
- "attr-value.punctuation.attr-equals": {
491
- color: "#d4d4d4"
492
- },
493
- namespace: {
494
- color: "#4ec9b0"
495
- },
496
- 'pre[class*="language-javascript"]': {
497
- color: "#9cdcfe"
498
- },
499
- 'code[class*="language-javascript"]': {
500
- color: "#9cdcfe"
501
- },
502
- 'pre[class*="language-jsx"]': {
503
- color: "#9cdcfe"
504
- },
505
- 'code[class*="language-jsx"]': {
506
- color: "#9cdcfe"
507
- },
508
- 'pre[class*="language-typescript"]': {
509
- color: "#9cdcfe"
510
- },
511
- 'code[class*="language-typescript"]': {
512
- color: "#9cdcfe"
513
- },
514
- 'pre[class*="language-tsx"]': {
515
- color: "#9cdcfe"
516
- },
517
- 'code[class*="language-tsx"]': {
518
- color: "#9cdcfe"
519
- },
520
- 'pre[class*="language-css"]': {
521
- color: "#ce9178"
522
- },
523
- 'code[class*="language-css"]': {
524
- color: "#ce9178"
525
- },
526
- 'pre[class*="language-html"]': {
527
- color: "#d4d4d4"
528
- },
529
- 'code[class*="language-html"]': {
530
- color: "#d4d4d4"
531
- },
532
- ".language-regex .token.anchor": {
533
- color: "#dcdcaa"
534
- },
535
- ".language-html .token.punctuation": {
536
- color: "#808080"
537
- },
538
- 'pre[class*="language-"] > code[class*="language-"]': {
539
- position: "relative",
540
- zIndex: "1"
541
- },
542
- ".line-highlight.line-highlight": {
543
- background: "#f7ebc6",
544
- boxShadow: "inset 5px 0 0 #f7d87c",
545
- zIndex: "0"
546
- }
547
- };
548
-
549
- // src/components/chat/Markdown.tsx
550
- var import_remark_gfm = __toESM(require("remark-gfm"));
551
- var import_remark_math = __toESM(require("remark-math"));
552
- var import_rehype_raw = __toESM(require("rehype-raw"));
553
- var import_jsx_runtime5 = require("react/jsx-runtime");
554
- var defaultComponents = {
555
- a(_a) {
556
- var _b = _a, { children } = _b, props = __objRest(_b, ["children"]);
557
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("a", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { target: "_blank", rel: "noopener noreferrer", children }));
558
- },
559
- // @ts-expect-error -- inline
560
- code(_c) {
561
- var _d = _c, { children, className, inline } = _d, props = __objRest(_d, ["children", "className", "inline"]);
562
- if (Array.isArray(children) && children.length) {
563
- if (children[0] == "\u258D") {
564
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
565
- "span",
566
- {
567
- style: {
568
- animation: "pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite",
569
- marginTop: "0.25rem"
570
- },
571
- children: "\u258D"
572
- }
573
- );
574
- }
575
- children[0] = (children == null ? void 0 : children[0]).replace("`\u258D`", "\u258D");
576
- }
577
- const match = /language-(\w+)/.exec(className || "");
578
- if (inline) {
579
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("code", __spreadProps(__spreadValues({ className }, props), { children }));
580
- }
581
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
582
- CodeBlock,
583
- __spreadValues({
584
- language: match && match[1] || "",
585
- value: String(children).replace(/\n$/, "")
586
- }, props),
587
- Math.random()
588
- );
589
- },
590
- h1: (_e) => {
591
- var _f = _e, { children } = _f, props = __objRest(_f, ["children"]);
592
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("h1", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
593
- },
594
- h2: (_g) => {
595
- var _h = _g, { children } = _h, props = __objRest(_h, ["children"]);
596
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("h2", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
597
- },
598
- h3: (_i) => {
599
- var _j = _i, { children } = _j, props = __objRest(_j, ["children"]);
600
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("h3", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
601
- },
602
- h4: (_k) => {
603
- var _l = _k, { children } = _l, props = __objRest(_l, ["children"]);
604
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("h4", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
605
- },
606
- h5: (_m) => {
607
- var _n = _m, { children } = _n, props = __objRest(_n, ["children"]);
608
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("h5", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
609
- },
610
- h6: (_o) => {
611
- var _p = _o, { children } = _p, props = __objRest(_p, ["children"]);
612
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("h6", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
613
- },
614
- p: (_q) => {
615
- var _r = _q, { children } = _r, props = __objRest(_r, ["children"]);
616
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("p", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
617
- },
618
- pre: (_s) => {
619
- var _t = _s, { children } = _t, props = __objRest(_t, ["children"]);
620
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("pre", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
621
- },
622
- blockquote: (_u) => {
623
- var _v = _u, { children } = _v, props = __objRest(_v, ["children"]);
624
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("blockquote", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
625
- },
626
- ul: (_w) => {
627
- var _x = _w, { children } = _x, props = __objRest(_x, ["children"]);
628
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("ul", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
629
- },
630
- li: (_y) => {
631
- var _z = _y, { children } = _z, props = __objRest(_z, ["children"]);
632
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("li", __spreadProps(__spreadValues({ className: "copilotKitMarkdownElement" }, props), { children }));
633
- }
634
- };
635
- var MemoizedReactMarkdown = (0, import_react3.memo)(
636
- import_react_markdown.default,
637
- (prevProps, nextProps) => prevProps.children === nextProps.children && prevProps.components === nextProps.components
638
- );
639
- var Markdown = ({ content, components }) => {
640
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("div", { className: "copilotKitMarkdown", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
641
- MemoizedReactMarkdown,
642
- {
643
- components: __spreadValues(__spreadValues({}, defaultComponents), components),
644
- remarkPlugins: [import_remark_gfm.default, import_remark_math.default],
645
- rehypePlugins: [import_rehype_raw.default],
646
- children: content
647
- }
648
- ) });
649
- };
650
-
651
- // src/components/chat/messages/AssistantMessage.tsx
652
- var import_react4 = require("react");
653
- var import_jsx_runtime6 = require("react/jsx-runtime");
654
- var AssistantMessage = (props) => {
655
- const { icons, labels } = useChatContext();
656
- const {
657
- message,
658
- isLoading,
659
- subComponent,
660
- onRegenerate,
661
- onCopy,
662
- onThumbsUp,
663
- onThumbsDown,
664
- isCurrentMessage,
665
- rawData,
666
- markdownTagRenderers
667
- } = props;
668
- const [copied, setCopied] = (0, import_react4.useState)(false);
669
- const handleCopy = () => {
670
- if (message && onCopy) {
671
- navigator.clipboard.writeText(message);
672
- setCopied(true);
673
- onCopy(message);
674
- setTimeout(() => setCopied(false), 2e3);
675
- } else if (message) {
676
- navigator.clipboard.writeText(message);
677
- setCopied(true);
678
- setTimeout(() => setCopied(false), 2e3);
679
- }
680
- };
681
- const handleRegenerate = () => {
682
- if (onRegenerate) {
683
- onRegenerate();
684
- }
685
- };
686
- const handleThumbsUp = () => {
687
- const fullMessage = rawData;
688
- if (onThumbsUp && fullMessage) {
689
- onThumbsUp(fullMessage);
690
- }
691
- };
692
- const handleThumbsDown = () => {
693
- const fullMessage = rawData;
694
- if (onThumbsDown && fullMessage) {
695
- onThumbsDown(fullMessage);
696
- }
697
- };
698
- const LoadingIcon = () => /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("span", { children: icons.activityIcon });
699
- return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(import_jsx_runtime6.Fragment, { children: [
700
- (message || isLoading) && /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { className: "copilotKitMessage copilotKitAssistantMessage", children: [
701
- message && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(Markdown, { content: message || "", components: markdownTagRenderers }),
702
- isLoading && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(LoadingIcon, {}),
703
- message && !isLoading && /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
704
- "div",
705
- {
706
- className: `copilotKitMessageControls ${isCurrentMessage ? "currentMessage" : ""}`,
707
- children: [
708
- /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
709
- "button",
710
- {
711
- className: "copilotKitMessageControlButton",
712
- onClick: handleRegenerate,
713
- "aria-label": labels.regenerateResponse,
714
- title: labels.regenerateResponse,
715
- children: icons.regenerateIcon
716
- }
717
- ),
718
- /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
719
- "button",
720
- {
721
- className: "copilotKitMessageControlButton",
722
- onClick: handleCopy,
723
- "aria-label": labels.copyToClipboard,
724
- title: labels.copyToClipboard,
725
- children: copied ? /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("span", { style: { fontSize: "10px", fontWeight: "bold" }, children: "\u2713" }) : icons.copyIcon
726
- }
727
- ),
728
- onThumbsUp && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
729
- "button",
730
- {
731
- className: "copilotKitMessageControlButton",
732
- onClick: handleThumbsUp,
733
- "aria-label": labels.thumbsUp,
734
- title: labels.thumbsUp,
735
- children: icons.thumbsUpIcon
736
- }
737
- ),
738
- onThumbsDown && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
739
- "button",
740
- {
741
- className: "copilotKitMessageControlButton",
742
- onClick: handleThumbsDown,
743
- "aria-label": labels.thumbsDown,
744
- title: labels.thumbsDown,
745
- children: icons.thumbsDownIcon
746
- }
747
- )
748
- ]
749
- }
750
- )
751
- ] }),
752
- /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { style: { marginBottom: "0.5rem" }, children: subComponent })
753
- ] });
754
- };
755
-
756
- // src/components/chat/messages/RenderImageMessage.tsx
757
- var import_jsx_runtime7 = require("react/jsx-runtime");
758
- function RenderImageMessage(_a) {
759
- var _b = _a, {
760
- UserMessage: UserMessage2 = UserMessage,
761
- AssistantMessage: AssistantMessage2 = AssistantMessage
762
- } = _b, props = __objRest(_b, [
763
- "UserMessage",
764
- "AssistantMessage"
765
- ]);
766
- const {
767
- message,
768
- inProgress,
769
- index,
770
- isCurrentMessage,
771
- onRegenerate,
772
- onCopy,
773
- onThumbsUp,
774
- onThumbsDown
775
- } = props;
776
- if (message.isImageMessage()) {
777
- const imageData = `data:${message.format};base64,${message.bytes}`;
778
- const imageComponent = /* @__PURE__ */ (0, import_jsx_runtime7.jsx)("div", { className: "copilotKitImage", children: /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
779
- "img",
780
- {
781
- src: imageData,
782
- alt: "User uploaded image",
783
- style: { maxWidth: "100%", maxHeight: "300px", borderRadius: "8px" }
784
- }
785
- ) });
786
- if (message.role === "user") {
787
- return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
788
- UserMessage2,
789
- {
790
- "data-message-role": "user",
791
- message: "",
792
- rawData: message,
793
- subComponent: imageComponent
794
- },
795
- index
796
- );
797
- } else if (message.role === "assistant") {
798
- return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
799
- AssistantMessage2,
800
- {
801
- "data-message-role": "assistant",
802
- message: "",
803
- rawData: message,
804
- subComponent: imageComponent,
805
- isLoading: inProgress && isCurrentMessage && !message.bytes,
806
- isGenerating: inProgress && isCurrentMessage && !!message.bytes,
807
- isCurrentMessage,
808
- onRegenerate: () => onRegenerate == null ? void 0 : onRegenerate(message.id),
809
- onCopy,
810
- onThumbsUp,
811
- onThumbsDown
812
- },
813
- index
814
- );
815
- }
816
- }
817
- return null;
818
- }
819
- // Annotate the CommonJS export names for ESM import in node:
820
- 0 && (module.exports = {
821
- RenderImageMessage
822
- });
823
- //# sourceMappingURL=RenderImageMessage.js.map