@copilotkit/react-ui 1.7.2-next.2 → 1.8.0-next.4

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 (162) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/dist/{chunk-CBBFRI3Q.mjs → chunk-5JY5QJ2W.mjs} +9 -5
  3. package/dist/chunk-5JY5QJ2W.mjs.map +1 -0
  4. package/dist/{chunk-OFYI4UU4.mjs → chunk-7RIBDD4K.mjs} +19 -3
  5. package/dist/chunk-7RIBDD4K.mjs.map +1 -0
  6. package/dist/{chunk-AELKLZSG.mjs → chunk-AIR3MXUU.mjs} +12 -12
  7. package/dist/{chunk-YAGE7RCE.mjs → chunk-CGVOCLHN.mjs} +2 -2
  8. package/dist/{chunk-DLG7BZTA.mjs → chunk-CZUP2N4J.mjs} +2 -2
  9. package/dist/chunk-FBYETUFL.mjs +118 -0
  10. package/dist/chunk-FBYETUFL.mjs.map +1 -0
  11. package/dist/chunk-GIPO7UB2.mjs +24 -0
  12. package/dist/chunk-GIPO7UB2.mjs.map +1 -0
  13. package/dist/{chunk-6FTRYYR5.mjs → chunk-GJME6MK4.mjs} +72 -62
  14. package/dist/chunk-GJME6MK4.mjs.map +1 -0
  15. package/dist/{chunk-QXQDIFOC.mjs → chunk-H24B7QWO.mjs} +49 -38
  16. package/dist/chunk-H24B7QWO.mjs.map +1 -0
  17. package/dist/{chunk-QXTRFMPM.mjs → chunk-LYHZXHTJ.mjs} +15 -12
  18. package/dist/chunk-LYHZXHTJ.mjs.map +1 -0
  19. package/dist/chunk-ORSMX3SE.mjs +244 -0
  20. package/dist/chunk-ORSMX3SE.mjs.map +1 -0
  21. package/dist/{chunk-UPTB2MVO.mjs → chunk-PCTCOQK2.mjs} +4 -10
  22. package/dist/chunk-PCTCOQK2.mjs.map +1 -0
  23. package/dist/{chunk-ZIF5JJCH.mjs → chunk-QQ4FBIGN.mjs} +30 -59
  24. package/dist/chunk-QQ4FBIGN.mjs.map +1 -0
  25. package/dist/{chunk-R2O33F44.mjs → chunk-TFIQA2P5.mjs} +2 -2
  26. package/dist/{chunk-WGAZXTUA.mjs → chunk-TOQ7P4DO.mjs} +6 -9
  27. package/dist/chunk-TOQ7P4DO.mjs.map +1 -0
  28. package/dist/{chunk-3XAXY2Z3.mjs → chunk-UZTZXMYS.mjs} +2 -2
  29. package/dist/{chunk-RQNJNK2W.mjs → chunk-VC4NO5QZ.mjs} +2 -2
  30. package/dist/{chunk-YQ3D5IQV.mjs → chunk-XNQO5AZZ.mjs} +2 -5
  31. package/dist/chunk-XNQO5AZZ.mjs.map +1 -0
  32. package/dist/chunk-YC4NBUGE.mjs +97 -0
  33. package/dist/chunk-YC4NBUGE.mjs.map +1 -0
  34. package/dist/components/chat/Button.js.map +1 -1
  35. package/dist/components/chat/Button.mjs +3 -3
  36. package/dist/components/chat/Chat.d.ts +17 -1
  37. package/dist/components/chat/Chat.js +380 -906
  38. package/dist/components/chat/Chat.js.map +1 -1
  39. package/dist/components/chat/Chat.mjs +11 -18
  40. package/dist/components/chat/ChatContext.d.ts +20 -0
  41. package/dist/components/chat/ChatContext.js +44 -74
  42. package/dist/components/chat/ChatContext.js.map +1 -1
  43. package/dist/components/chat/ChatContext.mjs +2 -2
  44. package/dist/components/chat/CodeBlock.js +58 -82
  45. package/dist/components/chat/CodeBlock.js.map +1 -1
  46. package/dist/components/chat/CodeBlock.mjs +2 -2
  47. package/dist/components/chat/Header.js +516 -4
  48. package/dist/components/chat/Header.js.map +1 -1
  49. package/dist/components/chat/Header.mjs +10 -3
  50. package/dist/components/chat/Icons.d.ts +10 -9
  51. package/dist/components/chat/Icons.js +125 -164
  52. package/dist/components/chat/Icons.js.map +1 -1
  53. package/dist/components/chat/Icons.mjs +9 -5
  54. package/dist/components/chat/Input.d.ts +1 -1
  55. package/dist/components/chat/Input.js +13 -10
  56. package/dist/components/chat/Input.js.map +1 -1
  57. package/dist/components/chat/Input.mjs +3 -3
  58. package/dist/components/chat/Markdown.js +58 -56
  59. package/dist/components/chat/Markdown.js.map +1 -1
  60. package/dist/components/chat/Markdown.mjs +3 -3
  61. package/dist/components/chat/Messages.d.ts +1 -1
  62. package/dist/components/chat/Messages.js +70 -60
  63. package/dist/components/chat/Messages.js.map +1 -1
  64. package/dist/components/chat/Messages.mjs +3 -3
  65. package/dist/components/chat/Modal.js +1709 -1749
  66. package/dist/components/chat/Modal.js.map +1 -1
  67. package/dist/components/chat/Modal.mjs +20 -20
  68. package/dist/components/chat/Popup.js +1709 -1749
  69. package/dist/components/chat/Popup.js.map +1 -1
  70. package/dist/components/chat/Popup.mjs +21 -21
  71. package/dist/components/chat/Response.js.map +1 -1
  72. package/dist/components/chat/Response.mjs +3 -3
  73. package/dist/components/chat/Sidebar.js +1711 -1751
  74. package/dist/components/chat/Sidebar.js.map +1 -1
  75. package/dist/components/chat/Sidebar.mjs +21 -21
  76. package/dist/components/chat/Suggestion.js +4 -40
  77. package/dist/components/chat/Suggestion.js.map +1 -1
  78. package/dist/components/chat/Suggestion.mjs +2 -2
  79. package/dist/components/chat/Window.js.map +1 -1
  80. package/dist/components/chat/Window.mjs +3 -3
  81. package/dist/components/chat/index.js +1711 -1751
  82. package/dist/components/chat/index.js.map +1 -1
  83. package/dist/components/chat/index.mjs +24 -24
  84. package/dist/components/chat/messages/AssistantMessage.js +211 -59
  85. package/dist/components/chat/messages/AssistantMessage.js.map +1 -1
  86. package/dist/components/chat/messages/AssistantMessage.mjs +5 -5
  87. package/dist/components/chat/messages/RenderTextMessage.js +18 -2
  88. package/dist/components/chat/messages/RenderTextMessage.js.map +1 -1
  89. package/dist/components/chat/messages/RenderTextMessage.mjs +1 -1
  90. package/dist/components/chat/props.d.ts +53 -0
  91. package/dist/components/chat/props.js.map +1 -1
  92. package/dist/components/crew/index.mjs +1 -1
  93. package/dist/components/dev-console/console.js +51 -233
  94. package/dist/components/dev-console/console.js.map +1 -1
  95. package/dist/components/dev-console/console.mjs +5 -5
  96. package/dist/components/dev-console/index.js +51 -233
  97. package/dist/components/dev-console/index.js.map +1 -1
  98. package/dist/components/dev-console/index.mjs +5 -5
  99. package/dist/components/help-modal/index.js +29 -147
  100. package/dist/components/help-modal/index.js.map +1 -1
  101. package/dist/components/help-modal/index.mjs +1 -1
  102. package/dist/components/help-modal/modal.js +29 -147
  103. package/dist/components/help-modal/modal.js.map +1 -1
  104. package/dist/components/help-modal/modal.mjs +1 -1
  105. package/dist/components/index.js +1685 -1725
  106. package/dist/components/index.js.map +1 -1
  107. package/dist/components/index.mjs +30 -30
  108. package/dist/index.css +266 -98
  109. package/dist/index.css.map +1 -1
  110. package/dist/index.js +1694 -1734
  111. package/dist/index.js.map +1 -1
  112. package/dist/index.mjs +30 -30
  113. package/dist/types/css.d.ts +6 -5
  114. package/dist/types/css.js.map +1 -1
  115. package/package.json +4 -4
  116. package/src/components/chat/Chat.tsx +59 -22
  117. package/src/components/chat/ChatContext.tsx +29 -1
  118. package/src/components/chat/CodeBlock.tsx +2 -4
  119. package/src/components/chat/Header.tsx +8 -3
  120. package/src/components/chat/Icons.tsx +108 -108
  121. package/src/components/chat/Input.tsx +47 -38
  122. package/src/components/chat/Markdown.tsx +0 -3
  123. package/src/components/chat/Messages.tsx +68 -56
  124. package/src/components/chat/Suggestion.tsx +2 -3
  125. package/src/components/chat/messages/AssistantMessage.tsx +95 -3
  126. package/src/components/chat/messages/RenderTextMessage.tsx +17 -1
  127. package/src/components/chat/props.ts +66 -0
  128. package/src/components/dev-console/console.tsx +16 -54
  129. package/src/components/help-modal/modal.tsx +38 -101
  130. package/src/css/button.css +15 -4
  131. package/src/css/colors.css +56 -10
  132. package/src/css/console.css +46 -39
  133. package/src/css/header.css +23 -6
  134. package/src/css/input.css +35 -19
  135. package/src/css/markdown.css +2 -1
  136. package/src/css/messages.css +126 -16
  137. package/src/css/panel.css +1 -0
  138. package/src/css/suggestions.css +14 -6
  139. package/src/types/css.ts +6 -5
  140. package/dist/chunk-3VNMQWGT.mjs +0 -25
  141. package/dist/chunk-3VNMQWGT.mjs.map +0 -1
  142. package/dist/chunk-6FTRYYR5.mjs.map +0 -1
  143. package/dist/chunk-CBBFRI3Q.mjs.map +0 -1
  144. package/dist/chunk-FZC7X5PK.mjs +0 -262
  145. package/dist/chunk-FZC7X5PK.mjs.map +0 -1
  146. package/dist/chunk-OFYI4UU4.mjs.map +0 -1
  147. package/dist/chunk-QXQDIFOC.mjs.map +0 -1
  148. package/dist/chunk-QXTRFMPM.mjs.map +0 -1
  149. package/dist/chunk-TI7SY2RI.mjs +0 -164
  150. package/dist/chunk-TI7SY2RI.mjs.map +0 -1
  151. package/dist/chunk-UPTB2MVO.mjs.map +0 -1
  152. package/dist/chunk-VEC45H6Q.mjs +0 -18
  153. package/dist/chunk-VEC45H6Q.mjs.map +0 -1
  154. package/dist/chunk-WGAZXTUA.mjs.map +0 -1
  155. package/dist/chunk-YQ3D5IQV.mjs.map +0 -1
  156. package/dist/chunk-ZIF5JJCH.mjs.map +0 -1
  157. /package/dist/{chunk-AELKLZSG.mjs.map → chunk-AIR3MXUU.mjs.map} +0 -0
  158. /package/dist/{chunk-YAGE7RCE.mjs.map → chunk-CGVOCLHN.mjs.map} +0 -0
  159. /package/dist/{chunk-DLG7BZTA.mjs.map → chunk-CZUP2N4J.mjs.map} +0 -0
  160. /package/dist/{chunk-R2O33F44.mjs.map → chunk-TFIQA2P5.mjs.map} +0 -0
  161. /package/dist/{chunk-3XAXY2Z3.mjs.map → chunk-UZTZXMYS.mjs.map} +0 -0
  162. /package/dist/{chunk-RQNJNK2W.mjs.map → chunk-VC4NO5QZ.mjs.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/chat/messages/RenderTextMessage.tsx"],"sourcesContent":["import { RenderMessageProps } from \"../props\";\n\nexport function RenderTextMessage(props: RenderMessageProps) {\n const { message, inProgress, index, isCurrentMessage, UserMessage, AssistantMessage } = props;\n\n if (message.isTextMessage()) {\n if (message.role === \"user\") {\n return (\n <UserMessage\n key={index}\n data-message-role=\"user\"\n message={message.content}\n rawData={message}\n />\n );\n } else if (message.role == \"assistant\") {\n return (\n <AssistantMessage\n key={index}\n data-message-role=\"assistant\"\n message={message.content}\n rawData={message}\n isLoading={inProgress && isCurrentMessage && !message.content}\n isGenerating={inProgress && isCurrentMessage && !!message.content}\n />\n );\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAQQ;AAND,SAAS,kBAAkB,OAA2B;AAC3D,QAAM,EAAE,SAAS,YAAY,OAAO,kBAAkB,aAAa,iBAAiB,IAAI;AAExF,MAAI,QAAQ,cAAc,GAAG;AAC3B,QAAI,QAAQ,SAAS,QAAQ;AAC3B,aACE;AAAA,QAAC;AAAA;AAAA,UAEC,qBAAkB;AAAA,UAClB,SAAS,QAAQ;AAAA,UACjB,SAAS;AAAA;AAAA,QAHJ;AAAA,MAIP;AAAA,IAEJ,WAAW,QAAQ,QAAQ,aAAa;AACtC,aACE;AAAA,QAAC;AAAA;AAAA,UAEC,qBAAkB;AAAA,UAClB,SAAS,QAAQ;AAAA,UACjB,SAAS;AAAA,UACT,WAAW,cAAc,oBAAoB,CAAC,QAAQ;AAAA,UACtD,cAAc,cAAc,oBAAoB,CAAC,CAAC,QAAQ;AAAA;AAAA,QALrD;AAAA,MAMP;AAAA,IAEJ;AAAA,EACF;AACF;","names":[]}
1
+ {"version":3,"sources":["../../../../src/components/chat/messages/RenderTextMessage.tsx"],"sourcesContent":["import { RenderMessageProps } from \"../props\";\n\nexport function RenderTextMessage(props: RenderMessageProps) {\n const {\n message,\n inProgress,\n index,\n isCurrentMessage,\n UserMessage,\n AssistantMessage,\n onRegenerate,\n onCopy,\n onThumbsUp,\n onThumbsDown,\n } = props;\n\n if (message.isTextMessage()) {\n if (message.role === \"user\") {\n return (\n <UserMessage\n key={index}\n data-message-role=\"user\"\n message={message.content}\n rawData={message}\n />\n );\n } else if (message.role == \"assistant\") {\n return (\n <AssistantMessage\n key={index}\n data-message-role=\"assistant\"\n message={message.content}\n rawData={message}\n isLoading={inProgress && isCurrentMessage && !message.content}\n isGenerating={inProgress && isCurrentMessage && !!message.content}\n isCurrentMessage={isCurrentMessage}\n onRegenerate={onRegenerate}\n onCopy={onCopy}\n onThumbsUp={onThumbsUp}\n onThumbsDown={onThumbsDown}\n />\n );\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAmBQ;AAjBD,SAAS,kBAAkB,OAA2B;AAC3D,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI;AAEJ,MAAI,QAAQ,cAAc,GAAG;AAC3B,QAAI,QAAQ,SAAS,QAAQ;AAC3B,aACE;AAAA,QAAC;AAAA;AAAA,UAEC,qBAAkB;AAAA,UAClB,SAAS,QAAQ;AAAA,UACjB,SAAS;AAAA;AAAA,QAHJ;AAAA,MAIP;AAAA,IAEJ,WAAW,QAAQ,QAAQ,aAAa;AACtC,aACE;AAAA,QAAC;AAAA;AAAA,UAEC,qBAAkB;AAAA,UAClB,SAAS,QAAQ;AAAA,UACjB,SAAS;AAAA,UACT,WAAW,cAAc,oBAAoB,CAAC,QAAQ;AAAA,UACtD,cAAc,cAAc,oBAAoB,CAAC,CAAC,QAAQ;AAAA,UAC1D;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA;AAAA,QAVK;AAAA,MAWP;AAAA,IAEJ;AAAA,EACF;AACF;","names":[]}
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  RenderTextMessage
3
- } from "../../../chunk-OFYI4UU4.mjs";
3
+ } from "../../../chunk-7RIBDD4K.mjs";
4
4
  import "../../../chunk-MRXNTQOX.mjs";
5
5
  export {
6
6
  RenderTextMessage
@@ -27,6 +27,22 @@ interface MessagesProps {
27
27
  RenderActionExecutionMessage: React.ComponentType<RenderMessageProps>;
28
28
  RenderAgentStateMessage: React.ComponentType<RenderMessageProps>;
29
29
  RenderResultMessage: React.ComponentType<RenderMessageProps>;
30
+ /**
31
+ * Callback function to regenerate the assistant's response
32
+ */
33
+ onRegenerate?: () => void;
34
+ /**
35
+ * Callback function when the message is copied
36
+ */
37
+ onCopy?: (message: string) => void;
38
+ /**
39
+ * Callback function for thumbs up feedback
40
+ */
41
+ onThumbsUp?: (message: string) => void;
42
+ /**
43
+ * Callback function for thumbs down feedback
44
+ */
45
+ onThumbsDown?: (message: string) => void;
30
46
  }
31
47
  interface Renderer {
32
48
  content: string;
@@ -40,6 +56,10 @@ interface AssistantMessageProps {
40
56
  * The message content from the assistant
41
57
  */
42
58
  message?: string;
59
+ /**
60
+ * Indicates if this is the last message
61
+ */
62
+ isCurrentMessage?: boolean;
43
63
  /**
44
64
  * The raw data from the assistant's response
45
65
  */
@@ -58,6 +78,22 @@ interface AssistantMessageProps {
58
78
  * Whether a response is generating, this is when the LLM is actively generating and streaming content.
59
79
  */
60
80
  isGenerating: boolean;
81
+ /**
82
+ * Callback function to regenerate the assistant's response
83
+ */
84
+ onRegenerate?: () => void;
85
+ /**
86
+ * Callback function when the message is copied
87
+ */
88
+ onCopy?: (message: string) => void;
89
+ /**
90
+ * Callback function for thumbs up feedback
91
+ */
92
+ onThumbsUp?: (message: string) => void;
93
+ /**
94
+ * Callback function for thumbs down feedback
95
+ */
96
+ onThumbsDown?: (message: string) => void;
61
97
  }
62
98
  interface RenderMessageProps {
63
99
  message: Message;
@@ -67,11 +103,28 @@ interface RenderMessageProps {
67
103
  actionResult?: string;
68
104
  AssistantMessage: React.ComponentType<AssistantMessageProps>;
69
105
  UserMessage: React.ComponentType<UserMessageProps>;
106
+ /**
107
+ * Callback function to regenerate the assistant's response
108
+ */
109
+ onRegenerate?: () => void;
110
+ /**
111
+ * Callback function when the message is copied
112
+ */
113
+ onCopy?: (message: string) => void;
114
+ /**
115
+ * Callback function for thumbs up feedback
116
+ */
117
+ onThumbsUp?: (message: string) => void;
118
+ /**
119
+ * Callback function for thumbs down feedback
120
+ */
121
+ onThumbsDown?: (message: string) => void;
70
122
  }
71
123
  interface InputProps {
72
124
  inProgress: boolean;
73
125
  onSend: (text: string) => Promise<Message>;
74
126
  isVisible?: boolean;
127
+ onStop?: () => void;
75
128
  }
76
129
  interface ResponseButtonProps {
77
130
  onClick: () => void;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/chat/props.ts"],"sourcesContent":["import { Message } from \"@copilotkit/runtime-client-gql\";\n\nexport interface ButtonProps {}\n\nexport interface WindowProps {\n clickOutsideToClose: boolean;\n hitEscapeToClose: boolean;\n shortcut: string;\n children?: React.ReactNode;\n}\n\nexport interface HeaderProps {}\n\nexport interface SuggestionsProps {\n title: string;\n message: string;\n partial?: boolean;\n className?: string;\n onClick: (message: string) => void;\n}\n\nexport interface MessagesProps {\n messages: Message[];\n inProgress: boolean;\n children?: React.ReactNode;\n AssistantMessage: React.ComponentType<AssistantMessageProps>;\n UserMessage: React.ComponentType<UserMessageProps>;\n RenderTextMessage: React.ComponentType<RenderMessageProps>;\n RenderActionExecutionMessage: React.ComponentType<RenderMessageProps>;\n RenderAgentStateMessage: React.ComponentType<RenderMessageProps>;\n RenderResultMessage: React.ComponentType<RenderMessageProps>;\n}\n\nexport interface Renderer {\n content: string;\n}\n\nexport interface UserMessageProps {\n message?: string;\n rawData: any;\n}\n\nexport interface AssistantMessageProps {\n /**\n * The message content from the assistant\n */\n\n message?: string;\n\n /**\n * The raw data from the assistant's response\n */\n rawData: any;\n\n /**\n * A component that was decided to render by the LLM.\n * When working with useCopilotActions and useCoAgentStateRender, this will be\n * the render component that was specified.\n */\n subComponent?: React.JSX.Element;\n\n /**\n * Whether a response is loading, this is when the LLM is thinking of a response but hasn't finished yet.\n */\n isLoading: boolean;\n\n /**\n * Whether a response is generating, this is when the LLM is actively generating and streaming content.\n */\n isGenerating: boolean;\n}\n\nexport interface RenderMessageProps {\n message: Message;\n inProgress: boolean;\n index: number;\n isCurrentMessage: boolean;\n actionResult?: string;\n AssistantMessage: React.ComponentType<AssistantMessageProps>;\n UserMessage: React.ComponentType<UserMessageProps>;\n}\n\nexport interface InputProps {\n inProgress: boolean;\n onSend: (text: string) => Promise<Message>;\n isVisible?: boolean;\n}\n\nexport interface ResponseButtonProps {\n onClick: () => void;\n inProgress: boolean;\n}\n"],"mappings":";;;;;;;;;;;;;;;;AAAA;AAAA;","names":[]}
1
+ {"version":3,"sources":["../../../src/components/chat/props.ts"],"sourcesContent":["import { Message } from \"@copilotkit/runtime-client-gql\";\n\nexport interface ButtonProps {}\n\nexport interface WindowProps {\n clickOutsideToClose: boolean;\n hitEscapeToClose: boolean;\n shortcut: string;\n children?: React.ReactNode;\n}\n\nexport interface HeaderProps {}\n\nexport interface SuggestionsProps {\n title: string;\n message: string;\n partial?: boolean;\n className?: string;\n onClick: (message: string) => void;\n}\n\nexport interface MessagesProps {\n messages: Message[];\n inProgress: boolean;\n children?: React.ReactNode;\n AssistantMessage: React.ComponentType<AssistantMessageProps>;\n UserMessage: React.ComponentType<UserMessageProps>;\n RenderTextMessage: React.ComponentType<RenderMessageProps>;\n RenderActionExecutionMessage: React.ComponentType<RenderMessageProps>;\n RenderAgentStateMessage: React.ComponentType<RenderMessageProps>;\n RenderResultMessage: React.ComponentType<RenderMessageProps>;\n\n /**\n * Callback function to regenerate the assistant's response\n */\n onRegenerate?: () => void;\n\n /**\n * Callback function when the message is copied\n */\n onCopy?: (message: string) => void;\n\n /**\n * Callback function for thumbs up feedback\n */\n onThumbsUp?: (message: string) => void;\n\n /**\n * Callback function for thumbs down feedback\n */\n onThumbsDown?: (message: string) => void;\n}\n\nexport interface Renderer {\n content: string;\n}\n\nexport interface UserMessageProps {\n message?: string;\n rawData: any;\n}\n\nexport interface AssistantMessageProps {\n /**\n * The message content from the assistant\n */\n\n message?: string;\n\n /**\n * Indicates if this is the last message\n */\n isCurrentMessage?: boolean;\n\n /**\n * The raw data from the assistant's response\n */\n rawData: any;\n\n /**\n * A component that was decided to render by the LLM.\n * When working with useCopilotActions and useCoAgentStateRender, this will be\n * the render component that was specified.\n */\n subComponent?: React.JSX.Element;\n\n /**\n * Whether a response is loading, this is when the LLM is thinking of a response but hasn't finished yet.\n */\n isLoading: boolean;\n\n /**\n * Whether a response is generating, this is when the LLM is actively generating and streaming content.\n */\n isGenerating: boolean;\n\n /**\n * Callback function to regenerate the assistant's response\n */\n onRegenerate?: () => void;\n\n /**\n * Callback function when the message is copied\n */\n onCopy?: (message: string) => void;\n\n /**\n * Callback function for thumbs up feedback\n */\n onThumbsUp?: (message: string) => void;\n\n /**\n * Callback function for thumbs down feedback\n */\n onThumbsDown?: (message: string) => void;\n}\n\nexport interface RenderMessageProps {\n message: Message;\n inProgress: boolean;\n index: number;\n isCurrentMessage: boolean;\n actionResult?: string;\n AssistantMessage: React.ComponentType<AssistantMessageProps>;\n UserMessage: React.ComponentType<UserMessageProps>;\n\n /**\n * Callback function to regenerate the assistant's response\n */\n onRegenerate?: () => void;\n\n /**\n * Callback function when the message is copied\n */\n onCopy?: (message: string) => void;\n\n /**\n * Callback function for thumbs up feedback\n */\n onThumbsUp?: (message: string) => void;\n\n /**\n * Callback function for thumbs down feedback\n */\n onThumbsDown?: (message: string) => void;\n}\n\nexport interface InputProps {\n inProgress: boolean;\n onSend: (text: string) => Promise<Message>;\n isVisible?: boolean;\n onStop?: () => void;\n}\n\nexport interface ResponseButtonProps {\n onClick: () => void;\n inProgress: boolean;\n}\n"],"mappings":";;;;;;;;;;;;;;;;AAAA;AAAA;","names":[]}
@@ -1,5 +1,4 @@
1
1
  import "../../chunk-UCVCAGU7.mjs";
2
- import "../../chunk-N7LTE54T.mjs";
3
2
  import {
4
3
  DefaultResponseRenderer,
5
4
  createResponseCache
@@ -7,6 +6,7 @@ import {
7
6
  import {
8
7
  DefaultStateRenderer
9
8
  } from "../../chunk-MCO235PS.mjs";
9
+ import "../../chunk-N7LTE54T.mjs";
10
10
  import "../../chunk-MRXNTQOX.mjs";
11
11
  export {
12
12
  DefaultResponseRenderer,
@@ -242,29 +242,6 @@ var CheckIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
242
242
  ) }) }) })
243
243
  }
244
244
  );
245
- var CopilotKitIcon = /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
246
- "svg",
247
- {
248
- width: "33px",
249
- height: "35px",
250
- viewBox: "0 0 33 35",
251
- version: "1.1",
252
- xmlns: "http://www.w3.org/2000/svg",
253
- children: [
254
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("title", { children: "bd5c9079-929b-4d55-bdc9-16d1c8181b71" }),
255
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { id: "Page-1", stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
256
- "image",
257
- {
258
- x: "0",
259
- y: "0",
260
- width: "33",
261
- height: "35",
262
- xlinkHref: ""
263
- }
264
- ) })
265
- ]
266
- }
267
- );
268
245
 
269
246
  // src/components/dev-console/console.tsx
270
247
  var import_react3 = require("@headlessui/react");
@@ -272,40 +249,7 @@ var import_shared = require("@copilotkit/shared");
272
249
 
273
250
  // src/components/chat/Icons.tsx
274
251
  var import_jsx_runtime2 = require("react/jsx-runtime");
275
- var SmallSpinnerIcon = /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
276
- "svg",
277
- {
278
- style: {
279
- animation: "copilotKitSpinAnimation 1s linear infinite"
280
- },
281
- width: "13",
282
- height: "13",
283
- xmlns: "http://www.w3.org/2000/svg",
284
- fill: "none",
285
- viewBox: "0 0 24 24",
286
- children: [
287
- /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
288
- "circle",
289
- {
290
- style: { opacity: 0.25 },
291
- cx: "12",
292
- cy: "12",
293
- r: "10",
294
- stroke: "currentColor",
295
- strokeWidth: "4"
296
- }
297
- ),
298
- /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
299
- "path",
300
- {
301
- style: { opacity: 0.75 },
302
- fill: "currentColor",
303
- d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
304
- }
305
- )
306
- ]
307
- }
308
- );
252
+ var SmallSpinnerIcon = /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("span", { className: "copilotKitSpinner", style: { width: "13px", height: "13px" } });
309
253
 
310
254
  // src/components/help-modal/modal.tsx
311
255
  var import_react = require("react");
@@ -325,101 +269,49 @@ var CloseIcon = () => /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
325
269
  children: /* @__PURE__ */ (0, import_jsx_runtime3.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M6 18L18 6M6 6l12 12" })
326
270
  }
327
271
  );
328
- var LoadingSpinnerIcon = ({ color = "rgb(107 114 128)" }) => /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(
329
- "svg",
330
- {
331
- style: {
332
- animation: "copilotKitSpinAnimation 1s linear infinite",
333
- color
334
- },
335
- width: "24",
336
- height: "24",
337
- xmlns: "http://www.w3.org/2000/svg",
338
- fill: "none",
339
- viewBox: "0 0 24 24",
340
- children: [
341
- /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
342
- "circle",
343
- {
344
- style: { opacity: 0.25 },
345
- cx: "12",
346
- cy: "12",
347
- r: "10",
348
- stroke: "currentColor",
349
- strokeWidth: "4"
350
- }
351
- ),
352
- /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
353
- "path",
354
- {
355
- style: { opacity: 0.75 },
356
- fill: "currentColor",
357
- d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
358
- }
359
- )
360
- ]
361
- }
362
- );
363
272
 
364
273
  // src/components/help-modal/modal.tsx
365
274
  var import_jsx_runtime4 = require("react/jsx-runtime");
366
275
  function CopilotKitHelpModal() {
367
276
  const [showHelpModal, setShowHelpModal] = (0, import_react.useState)(false);
368
- const [issueDescription, setIssueDescription] = (0, import_react.useState)("");
369
- const [email, setEmail] = (0, import_react.useState)("");
370
- const [emailError, setEmailError] = (0, import_react.useState)("");
371
- const [submitting, setSubmitting] = (0, import_react.useState)(false);
372
- const validateEmail = (email2) => {
373
- const re = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/;
374
- return re.test(email2);
375
- };
376
- const handleSubmit = (e) => __async(this, null, function* () {
377
- e.preventDefault();
378
- if ((email == null ? void 0 : email.length) > 0 && !validateEmail(email)) {
379
- setEmailError("Please enter a valid email address");
380
- return;
277
+ const buttonRef = (0, import_react.useRef)(null);
278
+ const popoverRef = (0, import_react.useRef)(null);
279
+ (0, import_react.useEffect)(() => {
280
+ const handleClickOutside = (event) => {
281
+ if (popoverRef.current && !popoverRef.current.contains(event.target) && buttonRef.current && !buttonRef.current.contains(event.target)) {
282
+ setShowHelpModal(false);
283
+ }
284
+ };
285
+ if (showHelpModal) {
286
+ document.addEventListener("mousedown", handleClickOutside);
381
287
  }
382
- setSubmitting(true);
383
- yield fetch("https://api.segment.io/v1/track", {
384
- method: "POST",
385
- headers: {
386
- "Content-Type": "application/json"
387
- },
388
- body: JSON.stringify({
389
- event: "oss.dev-console.help",
390
- anonymousId: window.crypto.randomUUID(),
391
- properties: { email, text: issueDescription },
392
- writeKey: "q0gQqvGYyw9pNyhIocNzefSYKGO1aiwW"
393
- })
394
- });
395
- setEmailError("");
396
- setEmail("");
397
- setIssueDescription("");
398
- setSubmitting(false);
399
- setShowHelpModal(false);
400
- });
288
+ return () => {
289
+ document.removeEventListener("mousedown", handleClickOutside);
290
+ };
291
+ }, [showHelpModal]);
401
292
  const HelpButton = () => /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
402
293
  "button",
403
294
  {
404
- onClick: () => setShowHelpModal(true),
405
- style: { width: "50px", height: "30px", marginRight: "0.25rem" },
406
- className: "text-sm p-0 bg-transparent rounded border border-blue-500",
295
+ ref: buttonRef,
296
+ onClick: () => setShowHelpModal(!showHelpModal),
297
+ className: "copilotKitDebugMenuTriggerButton relative",
407
298
  "aria-label": "Open Help",
408
299
  children: "Help"
409
300
  }
410
301
  );
411
- const submitButtonDisabled = (0, import_react.useMemo)(
412
- () => submitting || !!emailError || issueDescription == null || (issueDescription == null ? void 0 : issueDescription.length) == 0,
413
- [submitting, emailError, issueDescription]
414
- );
415
- return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)(import_jsx_runtime4.Fragment, { children: [
302
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "relative", children: [
416
303
  /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(HelpButton, {}),
417
304
  showHelpModal && /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
418
305
  "div",
419
306
  {
420
- className: "fixed inset-0 flex items-center justify-center p-4",
421
- style: { backgroundColor: "rgba(11, 15, 26, 0.5)", zIndex: 99 },
422
- children: /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "bg-white rounded-lg shadow-xl max-w-md w-full p-4 flex-col relative", children: [
307
+ ref: popoverRef,
308
+ className: "absolute mt-2 z-50",
309
+ style: {
310
+ top: "100%",
311
+ right: "-120px",
312
+ width: "380px"
313
+ },
314
+ children: /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "bg-white rounded-lg shadow-xl w-full p-4 flex-col relative", children: [
423
315
  /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
424
316
  "button",
425
317
  {
@@ -432,7 +324,7 @@ function CopilotKitHelpModal() {
432
324
  ),
433
325
  /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { className: "w-full flex mb-6 justify-center", children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("h2", { className: "text-2xl font-bold", children: "Help Options" }) }),
434
326
  /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "space-y-4 mb-4", children: [
435
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { className: "block w-full text-center py-2 px-4 bg-blue-500 text-white rounded hover:bg-blue-600 transition duration-150 text-sm", children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
327
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { className: "copilotKitHelpItemButton", children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
436
328
  "a",
437
329
  {
438
330
  href: "https://docs.copilotkit.ai/coagents/troubleshooting/common-issues",
@@ -441,7 +333,7 @@ function CopilotKitHelpModal() {
441
333
  children: "Visit the Troubleshooting and FAQ section in the docs"
442
334
  }
443
335
  ) }),
444
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { className: "block w-full text-center py-2 px-4 bg-blue-500 text-white rounded hover:bg-blue-600 transition duration-150 text-sm", children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
336
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { className: "copilotKitHelpItemButton", children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
445
337
  "a",
446
338
  {
447
339
  href: "https://go.copilotkit.ai/dev-console-support-discord",
@@ -450,7 +342,7 @@ function CopilotKitHelpModal() {
450
342
  children: "Go to Discord Support Channel (Community Support)"
451
343
  }
452
344
  ) }),
453
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { className: "block w-full text-center py-2 px-4 bg-blue-500 text-white rounded hover:bg-blue-600 transition duration-150 text-sm", children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
345
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { className: "copilotKitHelpItemButton", children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
454
346
  "a",
455
347
  {
456
348
  href: "https://go.copilotkit.ai/dev-console-support-slack",
@@ -459,52 +351,6 @@ function CopilotKitHelpModal() {
459
351
  children: "Apply for Priority Direct Slack Support"
460
352
  }
461
353
  ) })
462
- ] }),
463
- /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("form", { onSubmit: handleSubmit, className: "flex flex-col space-y-2", children: [
464
- /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { children: [
465
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("label", { htmlFor: "feedback", className: "block text-sm font-medium text-gray-700 mb-1", children: "Let us know what your issue is:" }),
466
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
467
- "textarea",
468
- {
469
- id: "feedback",
470
- rows: 4,
471
- className: "w-full px-3 py-2 text-gray-700 border rounded-lg focus:outline-none focus:border-blue-500",
472
- placeholder: "A Loom link / screen recording is always great!",
473
- onChange: (e) => setIssueDescription(e.target.value),
474
- value: issueDescription,
475
- required: true
476
- }
477
- )
478
- ] }),
479
- /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { children: [
480
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("label", { htmlFor: "email", className: "block text-sm font-medium text-gray-700 mb-1", children: "Email (optional):" }),
481
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
482
- "input",
483
- {
484
- type: "email",
485
- id: "email",
486
- className: `w-full px-3 py-2 text-gray-700 border rounded-lg focus:outline-none focus:border-blue-500 ${emailError ? "border-red-500" : ""}`,
487
- placeholder: "Enter your email for follow-up",
488
- onChange: (e) => {
489
- setEmail(e.target.value);
490
- setEmailError("");
491
- },
492
- value: email
493
- }
494
- ),
495
- emailError && /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("p", { className: "text-red-500 text-sm mt-1", children: emailError })
496
- ] }),
497
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { className: "bg-gray-50 px-4 py-4 sm:px-6 sm:flex sm:flex-row-reverse rounded-b-lg", children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
498
- "button",
499
- {
500
- type: "submit",
501
- onClick: handleSubmit,
502
- disabled: submitButtonDisabled,
503
- style: submitButtonDisabled ? { backgroundColor: "rgb(216, 216, 216)", color: "rgb(129, 129, 129)" } : void 0,
504
- className: "w-full inline-flex justify-center rounded-md border border-transparent shadow-sm px-4 py-2 bg-blue-500 text-base font-medium text-white hover:bg-blue-600 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500 sm:ml-3 sm:w-auto sm:text-sm disabled:shadow-none",
505
- children: submitting ? /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(LoadingSpinnerIcon, { color: "white" }) : "Submit"
506
- }
507
- ) })
508
354
  ] })
509
355
  ] })
510
356
  }
@@ -555,35 +401,6 @@ function CopilotDevConsole() {
555
401
  dontRunTwiceInDevMode.current = true;
556
402
  checkForUpdates();
557
403
  }, []);
558
- (0, import_react2.useEffect)(() => {
559
- const handleResize = (entries) => {
560
- for (let entry of entries) {
561
- if (entry.target === consoleRef.current) {
562
- const width = entry.contentRect.width;
563
- if (width < 400) {
564
- setDebugButtonMode("compact");
565
- } else {
566
- setDebugButtonMode("full");
567
- }
568
- }
569
- }
570
- };
571
- const observer = new ResizeObserver(handleResize);
572
- if (consoleRef.current) {
573
- observer.observe(consoleRef.current);
574
- const initialWidth = consoleRef.current.getBoundingClientRect().width;
575
- if (initialWidth < 400) {
576
- setDebugButtonMode("compact");
577
- } else {
578
- setDebugButtonMode("full");
579
- }
580
- }
581
- return () => {
582
- if (consoleRef.current) {
583
- observer.unobserve(consoleRef.current);
584
- }
585
- };
586
- }, [consoleRef.current]);
587
404
  if (!showDevConsole) {
588
405
  return null;
589
406
  }
@@ -593,7 +410,6 @@ function CopilotDevConsole() {
593
410
  ref: consoleRef,
594
411
  className: "copilotKitDevConsole " + (versionStatus === "update-available" ? "copilotKitDevConsoleUpgrade" : "") + (versionStatus === "outdated" ? "copilotKitDevConsoleWarnOutdated" : ""),
595
412
  children: [
596
- /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("div", { className: "copilotKitDevConsoleLogo", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("a", { href: "https://copilotkit.ai", target: "_blank", children: CopilotKitIcon }) }),
597
413
  /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
598
414
  VersionInfo,
599
415
  {
@@ -660,21 +476,17 @@ function VersionInfo({
660
476
  setTimeout(() => setCopyStatus(""), 1e3);
661
477
  });
662
478
  };
663
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "copilotKitVersionInfo", children: [
664
- /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("header", { children: [
665
- "COPILOTKIT DEV CONSOLE",
666
- showDevConsole === "auto" && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("aside", { children: asideLabel })
667
- ] }),
668
- /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("section", { children: [
669
- "Version: ",
670
- versionLabel,
671
- " (",
672
- currentVersionLabel,
673
- ") ",
674
- versionIcon
675
- ] }),
676
- (versionStatus === "update-available" || versionStatus === "outdated") && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("footer", { children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("button", { onClick: handleCopyClick, children: copyStatus || installCommand }) })
677
- ] });
479
+ if (versionStatus === "update-available" || versionStatus === "outdated") {
480
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "copilotKitVersionInfo", children: [
481
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("p", { children: [
482
+ currentVersionLabel,
483
+ " ",
484
+ versionIcon
485
+ ] }),
486
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("button", { onClick: handleCopyClick, children: copyStatus || installCommand })
487
+ ] });
488
+ }
489
+ return null;
678
490
  }
679
491
  function DebugMenuButton({
680
492
  setShowDevConsole,
@@ -684,10 +496,16 @@ function DebugMenuButton({
684
496
  const context = (0, import_react_core2.useCopilotContext)();
685
497
  const messagesContext = (0, import_react_core2.useCopilotMessagesContext)();
686
498
  return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("div", { className: "bg-black top-24 w-52 text-right", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_react3.Menu, { children: [
687
- /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_react3.MenuButton, { className: `copilotKitDebugMenuButton ${mode === "compact" ? "compact" : ""}`, children: mode == "compact" ? "Debug" : /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_jsx_runtime5.Fragment, { children: [
688
- "Debug ",
689
- ChevronDownIcon
690
- ] }) }),
499
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
500
+ import_react3.MenuButton,
501
+ {
502
+ className: `copilotKitDebugMenuTriggerButton ${mode === "compact" ? "compact" : ""}`,
503
+ children: mode == "compact" ? "Debug" : /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_jsx_runtime5.Fragment, { children: [
504
+ "Debug ",
505
+ ChevronDownIcon
506
+ ] })
507
+ }
508
+ ),
691
509
  /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(
692
510
  import_react3.MenuItems,
693
511
  {