@copilotkit/react-ui 1.3.16-mme-reset-chat.10 → 1.3.16-mme-revert-rxjs-changes.10

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 (45) hide show
  1. package/CHANGELOG.md +9 -53
  2. package/dist/{chunk-H7LLXN6X.mjs → chunk-H5CXJBR5.mjs} +3 -7
  3. package/dist/chunk-H5CXJBR5.mjs.map +1 -0
  4. package/dist/{chunk-P54DK2TL.mjs → chunk-M2NVAJQA.mjs} +2 -2
  5. package/dist/{chunk-3QOICFXX.mjs → chunk-ORHE7FYT.mjs} +8 -104
  6. package/dist/chunk-ORHE7FYT.mjs.map +1 -0
  7. package/dist/{chunk-SEY3XSCD.mjs → chunk-PY7YBFPA.mjs} +2 -2
  8. package/dist/{chunk-CPMIEVKK.mjs → chunk-RKPANT3F.mjs} +65 -15
  9. package/dist/chunk-RKPANT3F.mjs.map +1 -0
  10. package/dist/components/chat/Chat.d.ts +5 -50
  11. package/dist/components/chat/Chat.js +68 -114
  12. package/dist/components/chat/Chat.js.map +1 -1
  13. package/dist/components/chat/Chat.mjs +2 -2
  14. package/dist/components/chat/Messages.d.ts +6 -1
  15. package/dist/components/chat/Messages.js +66 -15
  16. package/dist/components/chat/Messages.js.map +1 -1
  17. package/dist/components/chat/Messages.mjs +5 -3
  18. package/dist/components/chat/Modal.d.ts +1 -1
  19. package/dist/components/chat/Modal.js +68 -118
  20. package/dist/components/chat/Modal.js.map +1 -1
  21. package/dist/components/chat/Modal.mjs +3 -3
  22. package/dist/components/chat/Popup.js +68 -118
  23. package/dist/components/chat/Popup.js.map +1 -1
  24. package/dist/components/chat/Popup.mjs +4 -4
  25. package/dist/components/chat/Sidebar.js +68 -118
  26. package/dist/components/chat/Sidebar.js.map +1 -1
  27. package/dist/components/chat/Sidebar.mjs +4 -4
  28. package/dist/components/chat/index.js +68 -118
  29. package/dist/components/chat/index.js.map +1 -1
  30. package/dist/components/chat/index.mjs +5 -5
  31. package/dist/components/index.js +68 -118
  32. package/dist/components/index.js.map +1 -1
  33. package/dist/components/index.mjs +5 -5
  34. package/dist/index.js +70 -120
  35. package/dist/index.js.map +1 -1
  36. package/dist/index.mjs +5 -5
  37. package/package.json +7 -7
  38. package/src/components/chat/Chat.tsx +7 -166
  39. package/src/components/chat/Messages.tsx +72 -15
  40. package/src/components/chat/Modal.tsx +0 -4
  41. package/dist/chunk-3QOICFXX.mjs.map +0 -1
  42. package/dist/chunk-CPMIEVKK.mjs.map +0 -1
  43. package/dist/chunk-H7LLXN6X.mjs.map +0 -1
  44. /package/dist/{chunk-P54DK2TL.mjs.map → chunk-M2NVAJQA.mjs.map} +0 -0
  45. /package/dist/{chunk-SEY3XSCD.mjs.map → chunk-PY7YBFPA.mjs.map} +0 -0
@@ -2,7 +2,7 @@ import {
2
2
  CopilotChat,
3
3
  WrappedCopilotChat,
4
4
  useCopilotChatLogic
5
- } from "../../chunk-3QOICFXX.mjs";
5
+ } from "../../chunk-ORHE7FYT.mjs";
6
6
  import "../../chunk-V7W6IM2V.mjs";
7
7
  import "../../chunk-OMTPWC7T.mjs";
8
8
  import "../../chunk-ZABXREBH.mjs";
@@ -15,7 +15,7 @@ import "../../chunk-OTPAZXVR.mjs";
15
15
  import "../../chunk-4LUMV4YO.mjs";
16
16
  import "../../chunk-YQFVRDNC.mjs";
17
17
  import "../../chunk-YQ3D5IQV.mjs";
18
- import "../../chunk-CPMIEVKK.mjs";
18
+ import "../../chunk-RKPANT3F.mjs";
19
19
  import "../../chunk-3XAXY2Z3.mjs";
20
20
  import "../../chunk-CBBFRI3Q.mjs";
21
21
  import "../../chunk-UPTB2MVO.mjs";
@@ -1,7 +1,12 @@
1
1
  import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import React__default from 'react';
2
3
  import { MessagesProps } from './props.js';
3
4
  import '@copilotkit/runtime-client-gql';
4
5
 
5
6
  declare const Messages: ({ messages, inProgress, children, RenderTextMessage, RenderActionExecutionMessage, RenderAgentStateMessage, RenderResultMessage, }: MessagesProps) => react_jsx_runtime.JSX.Element;
7
+ declare function useScrollToBottom(messages: any[]): {
8
+ messagesEndRef: React__default.RefObject<HTMLDivElement>;
9
+ messagesContainerRef: React__default.MutableRefObject<HTMLDivElement | null>;
10
+ };
6
11
 
7
- export { Messages };
12
+ export { Messages, useScrollToBottom };
@@ -30,10 +30,11 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
30
30
  // src/components/chat/Messages.tsx
31
31
  var Messages_exports = {};
32
32
  __export(Messages_exports, {
33
- Messages: () => Messages
33
+ Messages: () => Messages,
34
+ useScrollToBottom: () => useScrollToBottom
34
35
  });
35
36
  module.exports = __toCommonJS(Messages_exports);
36
- var import_react2 = __toESM(require("react"));
37
+ var import_react2 = require("react");
37
38
 
38
39
  // src/components/chat/ChatContext.tsx
39
40
  var import_react = __toESM(require("react"));
@@ -79,18 +80,8 @@ var Messages = ({
79
80
  }
80
81
  }
81
82
  }
82
- const messagesEndRef = import_react2.default.useRef(null);
83
- const scrollToBottom = () => {
84
- if (messagesEndRef.current) {
85
- messagesEndRef.current.scrollIntoView({
86
- behavior: "auto"
87
- });
88
- }
89
- };
90
- (0, import_react2.useEffect)(() => {
91
- scrollToBottom();
92
- }, [messages]);
93
- return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { className: "copilotKitMessages", children: [
83
+ const { messagesEndRef, messagesContainerRef } = useScrollToBottom(messages);
84
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { className: "copilotKitMessages", ref: messagesContainerRef, children: [
94
85
  messages.map((message, index) => {
95
86
  const isCurrentMessage = index === messages.length - 1;
96
87
  if (message.isTextMessage()) {
@@ -159,8 +150,68 @@ function makeInitialMessages(initial) {
159
150
  })
160
151
  );
161
152
  }
153
+ function useScrollToBottom(messages) {
154
+ const messagesEndRef = (0, import_react2.useRef)(null);
155
+ const messagesContainerRef = (0, import_react2.useRef)(null);
156
+ const isProgrammaticScrollRef = (0, import_react2.useRef)(false);
157
+ const isUserScrollUpRef = (0, import_react2.useRef)(false);
158
+ const scrollToBottom = () => {
159
+ if (messagesEndRef.current) {
160
+ isProgrammaticScrollRef.current = true;
161
+ messagesEndRef.current.scrollIntoView({
162
+ behavior: "auto"
163
+ });
164
+ }
165
+ };
166
+ const handleScroll = () => {
167
+ if (isProgrammaticScrollRef.current) {
168
+ isProgrammaticScrollRef.current = false;
169
+ return;
170
+ }
171
+ if (messagesContainerRef.current) {
172
+ const { scrollTop, scrollHeight, clientHeight } = messagesContainerRef.current;
173
+ isUserScrollUpRef.current = scrollTop + clientHeight < scrollHeight;
174
+ }
175
+ };
176
+ (0, import_react2.useEffect)(() => {
177
+ const container = messagesContainerRef.current;
178
+ if (container) {
179
+ container.addEventListener("scroll", handleScroll);
180
+ }
181
+ return () => {
182
+ if (container) {
183
+ container.removeEventListener("scroll", handleScroll);
184
+ }
185
+ };
186
+ }, []);
187
+ (0, import_react2.useEffect)(() => {
188
+ const container = messagesContainerRef.current;
189
+ if (!container) {
190
+ return;
191
+ }
192
+ const mutationObserver = new MutationObserver(() => {
193
+ if (!isUserScrollUpRef.current) {
194
+ scrollToBottom();
195
+ }
196
+ });
197
+ mutationObserver.observe(container, {
198
+ childList: true,
199
+ subtree: true,
200
+ characterData: true
201
+ });
202
+ return () => {
203
+ mutationObserver.disconnect();
204
+ };
205
+ }, []);
206
+ (0, import_react2.useEffect)(() => {
207
+ isUserScrollUpRef.current = false;
208
+ scrollToBottom();
209
+ }, [messages.filter((m) => m.isTextMessage() && m.role === import_runtime_client_gql.Role.User).length]);
210
+ return { messagesEndRef, messagesContainerRef };
211
+ }
162
212
  // Annotate the CommonJS export names for ESM import in node:
163
213
  0 && (module.exports = {
164
- Messages
214
+ Messages,
215
+ useScrollToBottom
165
216
  });
166
217
  //# sourceMappingURL=Messages.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/chat/Messages.tsx","../../../src/components/chat/ChatContext.tsx"],"sourcesContent":["import React, { useEffect, useMemo } from \"react\";\nimport { MessagesProps } from \"./props\";\nimport { useChatContext } from \"./ChatContext\";\nimport {\n ActionExecutionMessage,\n Message,\n ResultMessage,\n TextMessage,\n Role,\n AgentStateMessage,\n} from \"@copilotkit/runtime-client-gql\";\n\nexport const Messages = ({\n messages,\n inProgress,\n children,\n RenderTextMessage,\n RenderActionExecutionMessage,\n RenderAgentStateMessage,\n RenderResultMessage,\n}: MessagesProps) => {\n const context = useChatContext();\n const initialMessages = useMemo(\n () => makeInitialMessages(context.labels.initial),\n [context.labels.initial],\n );\n messages = [...initialMessages, ...messages];\n\n const actionResults: Record<string, string> = {};\n\n for (let i = 0; i < messages.length; i++) {\n if (messages[i].isActionExecutionMessage()) {\n const id = messages[i].id;\n const resultMessage: ResultMessage | undefined = messages.find(\n (message) => message.isResultMessage() && message.actionExecutionId === id,\n ) as ResultMessage | undefined;\n\n if (resultMessage) {\n actionResults[id] = ResultMessage.decodeResult(resultMessage.result || \"\");\n }\n }\n }\n\n const messagesEndRef = React.useRef<HTMLDivElement>(null);\n\n const scrollToBottom = () => {\n if (messagesEndRef.current) {\n messagesEndRef.current.scrollIntoView({\n behavior: \"auto\",\n });\n }\n };\n\n useEffect(() => {\n scrollToBottom();\n }, [messages]);\n\n return (\n <div className=\"copilotKitMessages\">\n {messages.map((message, index) => {\n const isCurrentMessage = index === messages.length - 1;\n\n if (message.isTextMessage()) {\n return (\n <RenderTextMessage\n key={index}\n message={message}\n inProgress={inProgress}\n index={index}\n isCurrentMessage={isCurrentMessage}\n />\n );\n } else if (message.isActionExecutionMessage()) {\n return (\n <RenderActionExecutionMessage\n key={index}\n message={message}\n inProgress={inProgress}\n index={index}\n isCurrentMessage={isCurrentMessage}\n actionResult={actionResults[message.id]}\n />\n );\n } else if (message.isAgentStateMessage()) {\n return (\n <RenderAgentStateMessage\n key={index}\n message={message}\n inProgress={inProgress}\n index={index}\n isCurrentMessage={isCurrentMessage}\n />\n );\n } else if (message.isResultMessage()) {\n return (\n <RenderResultMessage\n key={index}\n message={message}\n inProgress={inProgress}\n index={index}\n isCurrentMessage={isCurrentMessage}\n />\n );\n }\n })}\n <footer ref={messagesEndRef}>{children}</footer>\n </div>\n );\n};\n\nfunction makeInitialMessages(initial?: string | string[]): Message[] {\n let initialArray: string[] = [];\n if (initial) {\n if (Array.isArray(initial)) {\n initialArray.push(...initial);\n } else {\n initialArray.push(initial);\n }\n }\n\n return initialArray.map(\n (message) =>\n new TextMessage({\n role: Role.Assistant,\n content: message,\n }),\n );\n}\n","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\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 },\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.PushToTalkIcon,\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":"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","names":["import_react","React","import_jsx_runtime","React"]}
1
+ {"version":3,"sources":["../../../src/components/chat/Messages.tsx","../../../src/components/chat/ChatContext.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useRef } from \"react\";\nimport { MessagesProps } from \"./props\";\nimport { useChatContext } from \"./ChatContext\";\nimport {\n ActionExecutionMessage,\n Message,\n ResultMessage,\n TextMessage,\n Role,\n AgentStateMessage,\n} from \"@copilotkit/runtime-client-gql\";\n\nexport const Messages = ({\n messages,\n inProgress,\n children,\n RenderTextMessage,\n RenderActionExecutionMessage,\n RenderAgentStateMessage,\n RenderResultMessage,\n}: MessagesProps) => {\n const context = useChatContext();\n const initialMessages = useMemo(\n () => makeInitialMessages(context.labels.initial),\n [context.labels.initial],\n );\n messages = [...initialMessages, ...messages];\n\n const actionResults: Record<string, string> = {};\n\n for (let i = 0; i < messages.length; i++) {\n if (messages[i].isActionExecutionMessage()) {\n const id = messages[i].id;\n const resultMessage: ResultMessage | undefined = messages.find(\n (message) => message.isResultMessage() && message.actionExecutionId === id,\n ) as ResultMessage | undefined;\n\n if (resultMessage) {\n actionResults[id] = ResultMessage.decodeResult(resultMessage.result || \"\");\n }\n }\n }\n\n const { messagesEndRef, messagesContainerRef } = useScrollToBottom(messages);\n\n return (\n <div className=\"copilotKitMessages\" ref={messagesContainerRef}>\n {messages.map((message, index) => {\n const isCurrentMessage = index === messages.length - 1;\n\n if (message.isTextMessage()) {\n return (\n <RenderTextMessage\n key={index}\n message={message}\n inProgress={inProgress}\n index={index}\n isCurrentMessage={isCurrentMessage}\n />\n );\n } else if (message.isActionExecutionMessage()) {\n return (\n <RenderActionExecutionMessage\n key={index}\n message={message}\n inProgress={inProgress}\n index={index}\n isCurrentMessage={isCurrentMessage}\n actionResult={actionResults[message.id]}\n />\n );\n } else if (message.isAgentStateMessage()) {\n return (\n <RenderAgentStateMessage\n key={index}\n message={message}\n inProgress={inProgress}\n index={index}\n isCurrentMessage={isCurrentMessage}\n />\n );\n } else if (message.isResultMessage()) {\n return (\n <RenderResultMessage\n key={index}\n message={message}\n inProgress={inProgress}\n index={index}\n isCurrentMessage={isCurrentMessage}\n />\n );\n }\n })}\n <footer ref={messagesEndRef}>{children}</footer>\n </div>\n );\n};\n\nfunction makeInitialMessages(initial?: string | string[]): Message[] {\n let initialArray: string[] = [];\n if (initial) {\n if (Array.isArray(initial)) {\n initialArray.push(...initial);\n } else {\n initialArray.push(initial);\n }\n }\n\n return initialArray.map(\n (message) =>\n new TextMessage({\n role: Role.Assistant,\n content: message,\n }),\n );\n}\nexport function useScrollToBottom(messages: any[]) {\n const messagesEndRef = useRef<HTMLDivElement>(null);\n const messagesContainerRef = useRef<HTMLDivElement | null>(null);\n const isProgrammaticScrollRef = useRef(false);\n const isUserScrollUpRef = useRef(false);\n\n const scrollToBottom = () => {\n if (messagesEndRef.current) {\n isProgrammaticScrollRef.current = true;\n messagesEndRef.current.scrollIntoView({\n behavior: \"auto\",\n });\n }\n };\n\n const handleScroll = () => {\n if (isProgrammaticScrollRef.current) {\n isProgrammaticScrollRef.current = false;\n return;\n }\n\n if (messagesContainerRef.current) {\n const { scrollTop, scrollHeight, clientHeight } = messagesContainerRef.current;\n isUserScrollUpRef.current = scrollTop + clientHeight < scrollHeight;\n }\n };\n\n useEffect(() => {\n const container = messagesContainerRef.current;\n if (container) {\n container.addEventListener(\"scroll\", handleScroll);\n }\n return () => {\n if (container) {\n container.removeEventListener(\"scroll\", handleScroll);\n }\n };\n }, []);\n\n useEffect(() => {\n const container = messagesContainerRef.current;\n if (!container) {\n return;\n }\n\n const mutationObserver = new MutationObserver(() => {\n if (!isUserScrollUpRef.current) {\n scrollToBottom();\n }\n });\n\n mutationObserver.observe(container, {\n childList: true,\n subtree: true,\n characterData: true,\n });\n\n return () => {\n mutationObserver.disconnect();\n };\n }, []);\n\n useEffect(() => {\n isUserScrollUpRef.current = false;\n scrollToBottom();\n }, [messages.filter((m) => m.isTextMessage() && m.role === Role.User).length]);\n\n return { messagesEndRef, messagesContainerRef };\n}\n","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\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 },\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.PushToTalkIcon,\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":"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","names":["import_react","React","import_jsx_runtime"]}
@@ -1,10 +1,12 @@
1
1
  import {
2
- Messages
3
- } from "../../chunk-CPMIEVKK.mjs";
2
+ Messages,
3
+ useScrollToBottom
4
+ } from "../../chunk-RKPANT3F.mjs";
4
5
  import "../../chunk-CBBFRI3Q.mjs";
5
6
  import "../../chunk-FZC7X5PK.mjs";
6
7
  import "../../chunk-MRXNTQOX.mjs";
7
8
  export {
8
- Messages
9
+ Messages,
10
+ useScrollToBottom
9
11
  };
10
12
  //# sourceMappingURL=Messages.mjs.map
@@ -46,6 +46,6 @@ interface CopilotModalProps extends CopilotChatProps {
46
46
  */
47
47
  Header?: React__default.ComponentType<HeaderProps>;
48
48
  }
49
- declare const CopilotModal: ({ instructions, defaultOpen, clickOutsideToClose, hitEscapeToClose, onSetOpen, onSubmitMessage, onStopGeneration, onReloadMessages, shortcut, icons, labels, makeSystemMessage, showResponseButton, onInProgress, Window, Button, Header, Messages, Input, ResponseButton, className, children, }: CopilotModalProps) => react_jsx_runtime.JSX.Element;
49
+ declare const CopilotModal: ({ instructions, defaultOpen, clickOutsideToClose, hitEscapeToClose, onSetOpen, onSubmitMessage, shortcut, icons, labels, makeSystemMessage, showResponseButton, onInProgress, Window, Button, Header, Messages, Input, ResponseButton, className, children, }: CopilotModalProps) => react_jsx_runtime.JSX.Element;
50
50
 
51
51
  export { CopilotModal, CopilotModalProps };
@@ -524,7 +524,7 @@ var Header = ({}) => {
524
524
  };
525
525
 
526
526
  // src/components/chat/Messages.tsx
527
- var import_react3 = __toESM(require("react"));
527
+ var import_react3 = require("react");
528
528
  var import_runtime_client_gql = require("@copilotkit/runtime-client-gql");
529
529
  var import_jsx_runtime6 = require("react/jsx-runtime");
530
530
  var Messages = ({
@@ -554,18 +554,8 @@ var Messages = ({
554
554
  }
555
555
  }
556
556
  }
557
- const messagesEndRef = import_react3.default.useRef(null);
558
- const scrollToBottom = () => {
559
- if (messagesEndRef.current) {
560
- messagesEndRef.current.scrollIntoView({
561
- behavior: "auto"
562
- });
563
- }
564
- };
565
- (0, import_react3.useEffect)(() => {
566
- scrollToBottom();
567
- }, [messages]);
568
- return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { className: "copilotKitMessages", children: [
557
+ const { messagesEndRef, messagesContainerRef } = useScrollToBottom(messages);
558
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { className: "copilotKitMessages", ref: messagesContainerRef, children: [
569
559
  messages.map((message, index) => {
570
560
  const isCurrentMessage = index === messages.length - 1;
571
561
  if (message.isTextMessage()) {
@@ -634,6 +624,65 @@ function makeInitialMessages(initial) {
634
624
  })
635
625
  );
636
626
  }
627
+ function useScrollToBottom(messages) {
628
+ const messagesEndRef = (0, import_react3.useRef)(null);
629
+ const messagesContainerRef = (0, import_react3.useRef)(null);
630
+ const isProgrammaticScrollRef = (0, import_react3.useRef)(false);
631
+ const isUserScrollUpRef = (0, import_react3.useRef)(false);
632
+ const scrollToBottom = () => {
633
+ if (messagesEndRef.current) {
634
+ isProgrammaticScrollRef.current = true;
635
+ messagesEndRef.current.scrollIntoView({
636
+ behavior: "auto"
637
+ });
638
+ }
639
+ };
640
+ const handleScroll = () => {
641
+ if (isProgrammaticScrollRef.current) {
642
+ isProgrammaticScrollRef.current = false;
643
+ return;
644
+ }
645
+ if (messagesContainerRef.current) {
646
+ const { scrollTop, scrollHeight, clientHeight } = messagesContainerRef.current;
647
+ isUserScrollUpRef.current = scrollTop + clientHeight < scrollHeight;
648
+ }
649
+ };
650
+ (0, import_react3.useEffect)(() => {
651
+ const container = messagesContainerRef.current;
652
+ if (container) {
653
+ container.addEventListener("scroll", handleScroll);
654
+ }
655
+ return () => {
656
+ if (container) {
657
+ container.removeEventListener("scroll", handleScroll);
658
+ }
659
+ };
660
+ }, []);
661
+ (0, import_react3.useEffect)(() => {
662
+ const container = messagesContainerRef.current;
663
+ if (!container) {
664
+ return;
665
+ }
666
+ const mutationObserver = new MutationObserver(() => {
667
+ if (!isUserScrollUpRef.current) {
668
+ scrollToBottom();
669
+ }
670
+ });
671
+ mutationObserver.observe(container, {
672
+ childList: true,
673
+ subtree: true,
674
+ characterData: true
675
+ });
676
+ return () => {
677
+ mutationObserver.disconnect();
678
+ };
679
+ }, []);
680
+ (0, import_react3.useEffect)(() => {
681
+ isUserScrollUpRef.current = false;
682
+ scrollToBottom();
683
+ }, [messages.filter((m) => m.isTextMessage() && m.role === import_runtime_client_gql.Role.User).length]);
684
+ return { messagesEndRef, messagesContainerRef };
685
+ }
637
686
 
638
687
  // src/components/chat/Input.tsx
639
688
  var import_react6 = require("react");
@@ -2041,7 +2090,6 @@ function DebugMenuButton({
2041
2090
  }
2042
2091
 
2043
2092
  // src/components/chat/Chat.tsx
2044
- var import_react_core9 = require("@copilotkit/react-core");
2045
2093
  var import_jsx_runtime19 = require("react/jsx-runtime");
2046
2094
  function CopilotChat({
2047
2095
  instructions,
@@ -2049,8 +2097,6 @@ function CopilotChat({
2049
2097
  makeSystemMessage,
2050
2098
  showResponseButton = true,
2051
2099
  onInProgress,
2052
- onStopGeneration,
2053
- onReloadMessages,
2054
2100
  Messages: Messages2 = Messages,
2055
2101
  RenderTextMessage: RenderTextMessage2 = RenderTextMessage,
2056
2102
  RenderActionExecutionMessage: RenderActionExecutionMessage2 = RenderActionExecutionMessage,
@@ -2073,13 +2119,7 @@ function CopilotChat({
2073
2119
  sendMessage,
2074
2120
  stopGeneration,
2075
2121
  reloadMessages
2076
- } = useCopilotChatLogic(
2077
- makeSystemMessage,
2078
- onInProgress,
2079
- onSubmitMessage,
2080
- onStopGeneration,
2081
- onReloadMessages
2082
- );
2122
+ } = useCopilotChatLogic(makeSystemMessage, onInProgress, onSubmitMessage);
2083
2123
  const chatContext = import_react11.default.useContext(ChatContext);
2084
2124
  const isVisible = chatContext ? chatContext.open : true;
2085
2125
  return /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)(WrappedCopilotChat, { icons, labels, className, children: [
@@ -2135,15 +2175,8 @@ function WrappedCopilotChat({
2135
2175
  return /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(import_jsx_runtime19.Fragment, { children });
2136
2176
  }
2137
2177
  var SUGGESTIONS_DEBOUNCE_TIMEOUT = 1e3;
2138
- var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onStopGeneration, onReloadMessages) => {
2139
- var _a;
2140
- const {
2141
- visibleMessages,
2142
- appendMessage,
2143
- reloadMessages: defaultReloadMessages,
2144
- stopGeneration: defaultStopGeneration,
2145
- isLoading
2146
- } = (0, import_react_core8.useCopilotChat)({
2178
+ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage) => {
2179
+ const { visibleMessages, appendMessage, reloadMessages, stopGeneration, isLoading } = (0, import_react_core8.useCopilotChat)({
2147
2180
  id: (0, import_shared3.randomId)(),
2148
2181
  makeSystemMessage
2149
2182
  });
@@ -2151,8 +2184,8 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onS
2151
2184
  const suggestionsAbortControllerRef = (0, import_react11.useRef)(null);
2152
2185
  const debounceTimerRef = (0, import_react11.useRef)();
2153
2186
  const abortSuggestions = () => {
2154
- var _a2;
2155
- (_a2 = suggestionsAbortControllerRef.current) == null ? void 0 : _a2.abort();
2187
+ var _a;
2188
+ (_a = suggestionsAbortControllerRef.current) == null ? void 0 : _a.abort();
2156
2189
  suggestionsAbortControllerRef.current = null;
2157
2190
  };
2158
2191
  const generalContext = (0, import_react_core8.useCopilotContext)();
@@ -2178,13 +2211,7 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onS
2178
2211
  return () => {
2179
2212
  clearTimeout(debounceTimerRef.current);
2180
2213
  };
2181
- }, [
2182
- isLoading,
2183
- context.chatSuggestionConfiguration,
2184
- // hackish way to trigger suggestions reload on reset, but better than moving suggestions to the
2185
- // global context
2186
- visibleMessages.length == 0
2187
- ]);
2214
+ }, [isLoading, context.chatSuggestionConfiguration]);
2188
2215
  const sendMessage = (messageContent) => __async(void 0, null, function* () {
2189
2216
  abortSuggestions();
2190
2217
  setCurrentSuggestions([]);
@@ -2202,79 +2229,6 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onS
2202
2229
  appendMessage(message);
2203
2230
  return message;
2204
2231
  });
2205
- const messages = visibleMessages;
2206
- const { setMessages } = messagesContext;
2207
- const currentAgentName = (_a = generalContext.agentSession) == null ? void 0 : _a.agentName;
2208
- const restartCurrentAgent = (hint) => __async(void 0, null, function* () {
2209
- if (generalContext.agentSession) {
2210
- generalContext.setAgentSession(__spreadProps(__spreadValues({}, generalContext.agentSession), {
2211
- nodeName: void 0,
2212
- threadId: void 0
2213
- }));
2214
- generalContext.setCoagentStates((prevAgentStates) => {
2215
- return __spreadProps(__spreadValues({}, prevAgentStates), {
2216
- [generalContext.agentSession.agentName]: __spreadProps(__spreadValues({}, prevAgentStates[generalContext.agentSession.agentName]), {
2217
- threadId: void 0,
2218
- nodeName: void 0,
2219
- runId: void 0
2220
- })
2221
- });
2222
- });
2223
- }
2224
- });
2225
- const runCurrentAgent = (hint) => __async(void 0, null, function* () {
2226
- if (generalContext.agentSession) {
2227
- yield (0, import_react_core9.runAgent)(generalContext.agentSession.agentName, context, appendMessage, hint);
2228
- }
2229
- });
2230
- const stopCurrentAgent = () => {
2231
- if (generalContext.agentSession) {
2232
- (0, import_react_core9.stopAgent)(generalContext.agentSession.agentName, context);
2233
- }
2234
- };
2235
- const setCurrentAgentState = (state) => {
2236
- if (generalContext.agentSession) {
2237
- generalContext.setCoagentStates((prevAgentStates) => {
2238
- return __spreadProps(__spreadValues({}, prevAgentStates), {
2239
- [generalContext.agentSession.agentName]: {
2240
- state
2241
- }
2242
- });
2243
- });
2244
- }
2245
- };
2246
- function stopGeneration() {
2247
- if (onStopGeneration) {
2248
- onStopGeneration({
2249
- messages,
2250
- setMessages,
2251
- stopGeneration: defaultStopGeneration,
2252
- currentAgentName,
2253
- restartCurrentAgent,
2254
- stopCurrentAgent,
2255
- runCurrentAgent,
2256
- setCurrentAgentState
2257
- });
2258
- } else {
2259
- defaultStopGeneration();
2260
- }
2261
- }
2262
- function reloadMessages() {
2263
- if (onReloadMessages) {
2264
- onReloadMessages({
2265
- messages,
2266
- setMessages,
2267
- stopGeneration: defaultStopGeneration,
2268
- currentAgentName,
2269
- restartCurrentAgent,
2270
- stopCurrentAgent,
2271
- runCurrentAgent,
2272
- setCurrentAgentState
2273
- });
2274
- } else {
2275
- defaultReloadMessages();
2276
- }
2277
- }
2278
2232
  return {
2279
2233
  visibleMessages,
2280
2234
  isLoading,
@@ -2294,8 +2248,6 @@ var CopilotModal = ({
2294
2248
  hitEscapeToClose = true,
2295
2249
  onSetOpen,
2296
2250
  onSubmitMessage,
2297
- onStopGeneration,
2298
- onReloadMessages,
2299
2251
  shortcut = "/",
2300
2252
  icons,
2301
2253
  labels,
@@ -2333,8 +2285,6 @@ var CopilotModal = ({
2333
2285
  {
2334
2286
  instructions,
2335
2287
  onSubmitMessage,
2336
- onStopGeneration,
2337
- onReloadMessages,
2338
2288
  makeSystemMessage,
2339
2289
  showResponseButton,
2340
2290
  onInProgress,