@stack-spot/ai-chat-widget 1.8.1 → 1.8.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (404) hide show
  1. package/dist/AbortedError.d.ts +5 -0
  2. package/dist/AbortedError.d.ts.map +1 -0
  3. package/dist/AbortedError.js +7 -0
  4. package/dist/AbortedError.js.map +1 -0
  5. package/dist/StackspotAIWidget.d.ts +23 -0
  6. package/dist/StackspotAIWidget.d.ts.map +1 -0
  7. package/dist/StackspotAIWidget.js +35 -0
  8. package/dist/StackspotAIWidget.js.map +1 -0
  9. package/dist/app-metadata.json +151 -0
  10. package/dist/chat-interceptors/CustomInputs.d.ts +22 -0
  11. package/dist/chat-interceptors/CustomInputs.d.ts.map +1 -0
  12. package/dist/chat-interceptors/CustomInputs.js +71 -0
  13. package/dist/chat-interceptors/CustomInputs.js.map +1 -0
  14. package/dist/chat-interceptors/quick-command-questions.d.ts +14 -0
  15. package/dist/chat-interceptors/quick-command-questions.d.ts.map +1 -0
  16. package/dist/chat-interceptors/quick-command-questions.js +28 -0
  17. package/dist/chat-interceptors/quick-command-questions.js.map +1 -0
  18. package/dist/chat-interceptors/quick-commands.d.ts +17 -0
  19. package/dist/chat-interceptors/quick-commands.d.ts.map +1 -0
  20. package/dist/chat-interceptors/quick-commands.js +292 -0
  21. package/dist/chat-interceptors/quick-commands.js.map +1 -0
  22. package/dist/chat-interceptors/send-message.d.ts +14 -0
  23. package/dist/chat-interceptors/send-message.d.ts.map +1 -0
  24. package/dist/chat-interceptors/send-message.js +96 -0
  25. package/dist/chat-interceptors/send-message.js.map +1 -0
  26. package/dist/components/Accordion.d.ts +20 -0
  27. package/dist/components/Accordion.d.ts.map +1 -0
  28. package/dist/components/Accordion.js +49 -0
  29. package/dist/components/Accordion.js.map +1 -0
  30. package/dist/components/AdaptiveTextArea.d.ts +22 -0
  31. package/dist/components/AdaptiveTextArea.d.ts.map +1 -0
  32. package/dist/components/AdaptiveTextArea.js +39 -0
  33. package/dist/components/AdaptiveTextArea.js.map +1 -0
  34. package/dist/components/AutoFocus.d.ts +23 -0
  35. package/dist/components/AutoFocus.d.ts.map +1 -0
  36. package/dist/components/AutoFocus.js +23 -0
  37. package/dist/components/AutoFocus.js.map +1 -0
  38. package/dist/components/Code.d.ts +19 -0
  39. package/dist/components/Code.d.ts.map +1 -0
  40. package/dist/components/Code.js +118 -0
  41. package/dist/components/Code.js.map +1 -0
  42. package/dist/components/Fading.d.ts +32 -0
  43. package/dist/components/Fading.d.ts.map +1 -0
  44. package/dist/components/Fading.js +33 -0
  45. package/dist/components/Fading.js.map +1 -0
  46. package/dist/components/FadingOverflow.d.ts +37 -0
  47. package/dist/components/FadingOverflow.d.ts.map +1 -0
  48. package/dist/components/FadingOverflow.js +225 -0
  49. package/dist/components/FadingOverflow.js.map +1 -0
  50. package/dist/components/FallbackBoundary/ErrorBoundary.d.ts +33 -0
  51. package/dist/components/FallbackBoundary/ErrorBoundary.d.ts.map +1 -0
  52. package/dist/components/FallbackBoundary/ErrorBoundary.js +52 -0
  53. package/dist/components/FallbackBoundary/ErrorBoundary.js.map +1 -0
  54. package/dist/components/FallbackBoundary/Loading.d.ts +2 -0
  55. package/dist/components/FallbackBoundary/Loading.d.ts.map +1 -0
  56. package/dist/components/FallbackBoundary/Loading.js +12 -0
  57. package/dist/components/FallbackBoundary/Loading.js.map +1 -0
  58. package/dist/components/FallbackBoundary/index.d.ts +17 -0
  59. package/dist/components/FallbackBoundary/index.d.ts.map +1 -0
  60. package/dist/components/FallbackBoundary/index.js +9 -0
  61. package/dist/components/FallbackBoundary/index.js.map +1 -0
  62. package/dist/components/HistoryList.d.ts +25 -0
  63. package/dist/components/HistoryList.d.ts.map +1 -0
  64. package/dist/components/HistoryList.js +74 -0
  65. package/dist/components/HistoryList.js.map +1 -0
  66. package/dist/components/IconInput.d.ts +10 -0
  67. package/dist/components/IconInput.d.ts.map +1 -0
  68. package/dist/components/IconInput.js +61 -0
  69. package/dist/components/IconInput.js.map +1 -0
  70. package/dist/components/Markdown.d.ts +9 -0
  71. package/dist/components/Markdown.d.ts.map +1 -0
  72. package/dist/components/Markdown.js +17 -0
  73. package/dist/components/Markdown.js.map +1 -0
  74. package/dist/components/OverlayMenu.d.ts +21 -0
  75. package/dist/components/OverlayMenu.d.ts.map +1 -0
  76. package/dist/components/OverlayMenu.js +79 -0
  77. package/dist/components/OverlayMenu.js.map +1 -0
  78. package/dist/components/ProgressBar.d.ts +33 -0
  79. package/dist/components/ProgressBar.d.ts.map +1 -0
  80. package/dist/components/ProgressBar.js +131 -0
  81. package/dist/components/ProgressBar.js.map +1 -0
  82. package/dist/components/QuickStartButton.d.ts +13 -0
  83. package/dist/components/QuickStartButton.d.ts.map +1 -0
  84. package/dist/components/QuickStartButton.js +47 -0
  85. package/dist/components/QuickStartButton.js.map +1 -0
  86. package/dist/components/RightPanelForm.d.ts +8 -0
  87. package/dist/components/RightPanelForm.d.ts.map +1 -0
  88. package/dist/components/RightPanelForm.js +50 -0
  89. package/dist/components/RightPanelForm.js.map +1 -0
  90. package/dist/components/RightPanelTabs.d.ts +13 -0
  91. package/dist/components/RightPanelTabs.d.ts.map +1 -0
  92. package/dist/components/RightPanelTabs.js +24 -0
  93. package/dist/components/RightPanelTabs.js.map +1 -0
  94. package/dist/components/Selector/index.d.ts +24 -0
  95. package/dist/components/Selector/index.d.ts.map +1 -0
  96. package/dist/components/Selector/index.js +134 -0
  97. package/dist/components/Selector/index.js.map +1 -0
  98. package/dist/components/Selector/styled.d.ts +2 -0
  99. package/dist/components/Selector/styled.d.ts.map +1 -0
  100. package/dist/components/Selector/styled.js +153 -0
  101. package/dist/components/Selector/styled.js.map +1 -0
  102. package/dist/components/TabManager.d.ts +40 -0
  103. package/dist/components/TabManager.d.ts.map +1 -0
  104. package/dist/components/TabManager.js +166 -0
  105. package/dist/components/TabManager.js.map +1 -0
  106. package/dist/components/Tooltip/Tooltip.d.ts +37 -0
  107. package/dist/components/Tooltip/Tooltip.d.ts.map +1 -0
  108. package/dist/components/Tooltip/Tooltip.js +30 -0
  109. package/dist/components/Tooltip/Tooltip.js.map +1 -0
  110. package/dist/components/Tooltip/TooltipAPI.d.ts +29 -0
  111. package/dist/components/Tooltip/TooltipAPI.d.ts.map +1 -0
  112. package/dist/components/Tooltip/TooltipAPI.js +107 -0
  113. package/dist/components/Tooltip/TooltipAPI.js.map +1 -0
  114. package/dist/components/Tooltip/context.d.ts +5 -0
  115. package/dist/components/Tooltip/context.d.ts.map +1 -0
  116. package/dist/components/Tooltip/context.js +18 -0
  117. package/dist/components/Tooltip/context.js.map +1 -0
  118. package/dist/components/Tooltip/index.d.ts +3 -0
  119. package/dist/components/Tooltip/index.d.ts.map +1 -0
  120. package/dist/components/Tooltip/index.js +3 -0
  121. package/dist/components/Tooltip/index.js.map +1 -0
  122. package/dist/components/Tooltip/style.d.ts +4 -0
  123. package/dist/components/Tooltip/style.d.ts.map +1 -0
  124. package/dist/components/Tooltip/style.js +22 -0
  125. package/dist/components/Tooltip/style.js.map +1 -0
  126. package/dist/components/Tooltip/types.d.ts +27 -0
  127. package/dist/components/Tooltip/types.d.ts.map +1 -0
  128. package/dist/components/Tooltip/types.js +2 -0
  129. package/dist/components/Tooltip/types.js.map +1 -0
  130. package/dist/components/form/DescribedCheckboxGroup.d.ts +7 -0
  131. package/dist/components/form/DescribedCheckboxGroup.d.ts.map +1 -0
  132. package/dist/components/form/DescribedCheckboxGroup.js +27 -0
  133. package/dist/components/form/DescribedCheckboxGroup.js.map +1 -0
  134. package/dist/components/form/DescribedRadioGroup.d.ts +7 -0
  135. package/dist/components/form/DescribedRadioGroup.d.ts.map +1 -0
  136. package/dist/components/form/DescribedRadioGroup.js +22 -0
  137. package/dist/components/form/DescribedRadioGroup.js.map +1 -0
  138. package/dist/components/form/styled.d.ts +2 -0
  139. package/dist/components/form/styled.d.ts.map +1 -0
  140. package/dist/components/form/styled.js +42 -0
  141. package/dist/components/form/styled.js.map +1 -0
  142. package/dist/components/form/types.d.ts +53 -0
  143. package/dist/components/form/types.d.ts.map +1 -0
  144. package/dist/components/form/types.js +2 -0
  145. package/dist/components/form/types.js.map +1 -0
  146. package/dist/context/AIWidgetProvider.d.ts +23 -0
  147. package/dist/context/AIWidgetProvider.d.ts.map +1 -0
  148. package/dist/context/AIWidgetProvider.js +23 -0
  149. package/dist/context/AIWidgetProvider.js.map +1 -0
  150. package/dist/context/hooks.d.ts +69 -0
  151. package/dist/context/hooks.d.ts.map +1 -0
  152. package/dist/context/hooks.js +121 -0
  153. package/dist/context/hooks.js.map +1 -0
  154. package/dist/features.d.ts +40 -0
  155. package/dist/features.d.ts.map +1 -0
  156. package/dist/features.js +18 -0
  157. package/dist/features.js.map +1 -0
  158. package/dist/index.d.ts +14 -0
  159. package/dist/index.d.ts.map +1 -0
  160. package/dist/index.js +12 -0
  161. package/dist/index.js.map +1 -0
  162. package/dist/layout.css +137 -0
  163. package/dist/regex.d.ts +3 -0
  164. package/dist/regex.d.ts.map +1 -0
  165. package/dist/regex.js +3 -0
  166. package/dist/regex.js.map +1 -0
  167. package/dist/right-panel/DefaultPanel.d.ts +12 -0
  168. package/dist/right-panel/DefaultPanel.d.ts.map +1 -0
  169. package/dist/right-panel/DefaultPanel.js +50 -0
  170. package/dist/right-panel/DefaultPanel.js.map +1 -0
  171. package/dist/right-panel/RightPanel.d.ts +5 -0
  172. package/dist/right-panel/RightPanel.d.ts.map +1 -0
  173. package/dist/right-panel/RightPanel.js +9 -0
  174. package/dist/right-panel/RightPanel.js.map +1 -0
  175. package/dist/right-panel/RightPanelProvider.d.ts +28 -0
  176. package/dist/right-panel/RightPanelProvider.d.ts.map +1 -0
  177. package/dist/right-panel/RightPanelProvider.js +10 -0
  178. package/dist/right-panel/RightPanelProvider.js.map +1 -0
  179. package/dist/right-panel/constants.d.ts +2 -0
  180. package/dist/right-panel/constants.d.ts.map +1 -0
  181. package/dist/right-panel/constants.js +2 -0
  182. package/dist/right-panel/constants.js.map +1 -0
  183. package/dist/right-panel/hooks.d.ts +19 -0
  184. package/dist/right-panel/hooks.d.ts.map +1 -0
  185. package/dist/right-panel/hooks.js +46 -0
  186. package/dist/right-panel/hooks.js.map +1 -0
  187. package/dist/state/ChatEntry.d.ts +112 -0
  188. package/dist/state/ChatEntry.d.ts.map +1 -0
  189. package/dist/state/ChatEntry.js +59 -0
  190. package/dist/state/ChatEntry.js.map +1 -0
  191. package/dist/state/ChatState.d.ts +154 -0
  192. package/dist/state/ChatState.d.ts.map +1 -0
  193. package/dist/state/ChatState.js +108 -0
  194. package/dist/state/ChatState.js.map +1 -0
  195. package/dist/state/ChatTabsController.d.ts +66 -0
  196. package/dist/state/ChatTabsController.d.ts.map +1 -0
  197. package/dist/state/ChatTabsController.js +116 -0
  198. package/dist/state/ChatTabsController.js.map +1 -0
  199. package/dist/state/ObservableState.d.ts +24 -0
  200. package/dist/state/ObservableState.d.ts.map +1 -0
  201. package/dist/state/ObservableState.js +39 -0
  202. package/dist/state/ObservableState.js.map +1 -0
  203. package/dist/state/WidgetState.d.ts +80 -0
  204. package/dist/state/WidgetState.d.ts.map +1 -0
  205. package/dist/state/WidgetState.js +68 -0
  206. package/dist/state/WidgetState.js.map +1 -0
  207. package/dist/state/types.d.ts +8 -0
  208. package/dist/state/types.d.ts.map +1 -0
  209. package/dist/state/types.js +2 -0
  210. package/dist/state/types.js.map +1 -0
  211. package/dist/types.d.ts +27 -0
  212. package/dist/types.d.ts.map +1 -0
  213. package/dist/types.js +2 -0
  214. package/dist/types.js.map +1 -0
  215. package/dist/utils/chat.d.ts +12 -0
  216. package/dist/utils/chat.d.ts.map +1 -0
  217. package/dist/utils/chat.js +26 -0
  218. package/dist/utils/chat.js.map +1 -0
  219. package/dist/utils/date.d.ts +32 -0
  220. package/dist/utils/date.d.ts.map +1 -0
  221. package/dist/utils/date.js +66 -0
  222. package/dist/utils/date.js.map +1 -0
  223. package/dist/utils/download.d.ts +7 -0
  224. package/dist/utils/download.d.ts.map +1 -0
  225. package/dist/utils/download.js +15 -0
  226. package/dist/utils/download.js.map +1 -0
  227. package/dist/utils/knowledge-source.d.ts +19 -0
  228. package/dist/utils/knowledge-source.d.ts.map +1 -0
  229. package/dist/utils/knowledge-source.js +60 -0
  230. package/dist/utils/knowledge-source.js.map +1 -0
  231. package/dist/utils/programming-languages.d.ts +7 -0
  232. package/dist/utils/programming-languages.d.ts.map +1 -0
  233. package/dist/utils/programming-languages.js +464 -0
  234. package/dist/utils/programming-languages.js.map +1 -0
  235. package/dist/utils/string.d.ts +7 -0
  236. package/dist/utils/string.d.ts.map +1 -0
  237. package/dist/utils/string.js +11 -0
  238. package/dist/utils/string.js.map +1 -0
  239. package/dist/utils/url.d.ts +2 -0
  240. package/dist/utils/url.d.ts.map +1 -0
  241. package/dist/utils/url.js +8 -0
  242. package/dist/utils/url.js.map +1 -0
  243. package/dist/views/Agents/AgentDescription.d.ts +9 -0
  244. package/dist/views/Agents/AgentDescription.d.ts.map +1 -0
  245. package/dist/views/Agents/AgentDescription.js +21 -0
  246. package/dist/views/Agents/AgentDescription.js.map +1 -0
  247. package/dist/views/Agents/AgentsPanel.d.ts +5 -0
  248. package/dist/views/Agents/AgentsPanel.d.ts.map +1 -0
  249. package/dist/views/Agents/AgentsPanel.js +19 -0
  250. package/dist/views/Agents/AgentsPanel.js.map +1 -0
  251. package/dist/views/Agents/AgentsTab.d.ts +5 -0
  252. package/dist/views/Agents/AgentsTab.d.ts.map +1 -0
  253. package/dist/views/Agents/AgentsTab.js +43 -0
  254. package/dist/views/Agents/AgentsTab.js.map +1 -0
  255. package/dist/views/Agents/dictionary.d.ts +2 -0
  256. package/dist/views/Agents/dictionary.d.ts.map +1 -0
  257. package/dist/views/Agents/dictionary.js +35 -0
  258. package/dist/views/Agents/dictionary.js.map +1 -0
  259. package/dist/views/Agents/index.d.ts +5 -0
  260. package/dist/views/Agents/index.d.ts.map +1 -0
  261. package/dist/views/Agents/index.js +21 -0
  262. package/dist/views/Agents/index.js.map +1 -0
  263. package/dist/views/Agents/styled.d.ts +3 -0
  264. package/dist/views/Agents/styled.d.ts.map +1 -0
  265. package/dist/views/Agents/styled.js +58 -0
  266. package/dist/views/Agents/styled.js.map +1 -0
  267. package/dist/views/Chat/AgentInfo.d.ts +10 -0
  268. package/dist/views/Chat/AgentInfo.d.ts.map +1 -0
  269. package/dist/views/Chat/AgentInfo.js +10 -0
  270. package/dist/views/Chat/AgentInfo.js.map +1 -0
  271. package/dist/views/Chat/ChatMessage.d.ts +22 -0
  272. package/dist/views/Chat/ChatMessage.d.ts.map +1 -0
  273. package/dist/views/Chat/ChatMessage.js +82 -0
  274. package/dist/views/Chat/ChatMessage.js.map +1 -0
  275. package/dist/views/Chat/ChatMessages.d.ts +10 -0
  276. package/dist/views/Chat/ChatMessages.d.ts.map +1 -0
  277. package/dist/views/Chat/ChatMessages.js +15 -0
  278. package/dist/views/Chat/ChatMessages.js.map +1 -0
  279. package/dist/views/Chat/chat-scroll.d.ts +7 -0
  280. package/dist/views/Chat/chat-scroll.d.ts.map +1 -0
  281. package/dist/views/Chat/chat-scroll.js +17 -0
  282. package/dist/views/Chat/chat-scroll.js.map +1 -0
  283. package/dist/views/Chat/events.d.ts +22 -0
  284. package/dist/views/Chat/events.d.ts.map +1 -0
  285. package/dist/views/Chat/events.js +66 -0
  286. package/dist/views/Chat/events.js.map +1 -0
  287. package/dist/views/Chat/index.d.ts +12 -0
  288. package/dist/views/Chat/index.d.ts.map +1 -0
  289. package/dist/views/Chat/index.js +11 -0
  290. package/dist/views/Chat/index.js.map +1 -0
  291. package/dist/views/Chat/styled.d.ts +2 -0
  292. package/dist/views/Chat/styled.d.ts.map +1 -0
  293. package/dist/views/Chat/styled.js +186 -0
  294. package/dist/views/Chat/styled.js.map +1 -0
  295. package/dist/views/ChatHistory/ChatHistoryPanel.d.ts +5 -0
  296. package/dist/views/ChatHistory/ChatHistoryPanel.d.ts.map +1 -0
  297. package/dist/views/ChatHistory/ChatHistoryPanel.js +14 -0
  298. package/dist/views/ChatHistory/ChatHistoryPanel.js.map +1 -0
  299. package/dist/views/ChatHistory/HistoryItem.d.ts +8 -0
  300. package/dist/views/ChatHistory/HistoryItem.d.ts.map +1 -0
  301. package/dist/views/ChatHistory/HistoryItem.js +130 -0
  302. package/dist/views/ChatHistory/HistoryItem.js.map +1 -0
  303. package/dist/views/ChatHistory/dictionary.d.ts +2 -0
  304. package/dist/views/ChatHistory/dictionary.d.ts.map +1 -0
  305. package/dist/views/ChatHistory/dictionary.js +19 -0
  306. package/dist/views/ChatHistory/dictionary.js.map +1 -0
  307. package/dist/views/ChatHistory/index.d.ts +5 -0
  308. package/dist/views/ChatHistory/index.d.ts.map +1 -0
  309. package/dist/views/ChatHistory/index.js +26 -0
  310. package/dist/views/ChatHistory/index.js.map +1 -0
  311. package/dist/views/ChatHistory/styled.d.ts +2 -0
  312. package/dist/views/ChatHistory/styled.d.ts.map +1 -0
  313. package/dist/views/ChatHistory/styled.js +60 -0
  314. package/dist/views/ChatHistory/styled.js.map +1 -0
  315. package/dist/views/ChatHistory/utils.d.ts +20 -0
  316. package/dist/views/ChatHistory/utils.d.ts.map +1 -0
  317. package/dist/views/ChatHistory/utils.js +53 -0
  318. package/dist/views/ChatHistory/utils.js.map +1 -0
  319. package/dist/views/ChatTabSelection.d.ts +5 -0
  320. package/dist/views/ChatTabSelection.d.ts.map +1 -0
  321. package/dist/views/ChatTabSelection.js +48 -0
  322. package/dist/views/ChatTabSelection.js.map +1 -0
  323. package/dist/views/Editor.d.ts +5 -0
  324. package/dist/views/Editor.d.ts.map +1 -0
  325. package/dist/views/Editor.js +96 -0
  326. package/dist/views/Editor.js.map +1 -0
  327. package/dist/views/Home/BuiltInAgent.d.ts +6 -0
  328. package/dist/views/Home/BuiltInAgent.d.ts.map +1 -0
  329. package/dist/views/Home/BuiltInAgent.js +39 -0
  330. package/dist/views/Home/BuiltInAgent.js.map +1 -0
  331. package/dist/views/Home/CustomAgent.d.ts +5 -0
  332. package/dist/views/Home/CustomAgent.d.ts.map +1 -0
  333. package/dist/views/Home/CustomAgent.js +24 -0
  334. package/dist/views/Home/CustomAgent.js.map +1 -0
  335. package/dist/views/Home/index.d.ts +8 -0
  336. package/dist/views/Home/index.d.ts.map +1 -0
  337. package/dist/views/Home/index.js +15 -0
  338. package/dist/views/Home/index.js.map +1 -0
  339. package/dist/views/Home/styled.d.ts +2 -0
  340. package/dist/views/Home/styled.d.ts.map +1 -0
  341. package/dist/views/Home/styled.js +59 -0
  342. package/dist/views/Home/styled.js.map +1 -0
  343. package/dist/views/Home/types.d.ts +7 -0
  344. package/dist/views/Home/types.d.ts.map +1 -0
  345. package/dist/views/Home/types.js +2 -0
  346. package/dist/views/Home/types.js.map +1 -0
  347. package/dist/views/KSDocument.d.ts +5 -0
  348. package/dist/views/KSDocument.d.ts.map +1 -0
  349. package/dist/views/KSDocument.js +43 -0
  350. package/dist/views/KSDocument.js.map +1 -0
  351. package/dist/views/KnowledgeSources.d.ts +2 -0
  352. package/dist/views/KnowledgeSources.d.ts.map +1 -0
  353. package/dist/views/KnowledgeSources.js +96 -0
  354. package/dist/views/KnowledgeSources.js.map +1 -0
  355. package/dist/views/MessageInput/AgentSelector.d.ts +4 -0
  356. package/dist/views/MessageInput/AgentSelector.d.ts.map +1 -0
  357. package/dist/views/MessageInput/AgentSelector.js +58 -0
  358. package/dist/views/MessageInput/AgentSelector.js.map +1 -0
  359. package/dist/views/MessageInput/ButtonAgent.d.ts +2 -0
  360. package/dist/views/MessageInput/ButtonAgent.d.ts.map +1 -0
  361. package/dist/views/MessageInput/ButtonAgent.js +17 -0
  362. package/dist/views/MessageInput/ButtonAgent.js.map +1 -0
  363. package/dist/views/MessageInput/ButtonGroup.d.ts +29 -0
  364. package/dist/views/MessageInput/ButtonGroup.d.ts.map +1 -0
  365. package/dist/views/MessageInput/ButtonGroup.js +34 -0
  366. package/dist/views/MessageInput/ButtonGroup.js.map +1 -0
  367. package/dist/views/MessageInput/InfoBar.d.ts +9 -0
  368. package/dist/views/MessageInput/InfoBar.d.ts.map +1 -0
  369. package/dist/views/MessageInput/InfoBar.js +52 -0
  370. package/dist/views/MessageInput/InfoBar.js.map +1 -0
  371. package/dist/views/MessageInput/QuickCommandSelector.d.ts +4 -0
  372. package/dist/views/MessageInput/QuickCommandSelector.d.ts.map +1 -0
  373. package/dist/views/MessageInput/QuickCommandSelector.js +34 -0
  374. package/dist/views/MessageInput/QuickCommandSelector.js.map +1 -0
  375. package/dist/views/MessageInput/chat-entry-history.d.ts +11 -0
  376. package/dist/views/MessageInput/chat-entry-history.d.ts.map +1 -0
  377. package/dist/views/MessageInput/chat-entry-history.js +78 -0
  378. package/dist/views/MessageInput/chat-entry-history.js.map +1 -0
  379. package/dist/views/MessageInput/dictionary.d.ts +2 -0
  380. package/dist/views/MessageInput/dictionary.d.ts.map +1 -0
  381. package/dist/views/MessageInput/dictionary.js +43 -0
  382. package/dist/views/MessageInput/dictionary.js.map +1 -0
  383. package/dist/views/MessageInput/index.d.ts +7 -0
  384. package/dist/views/MessageInput/index.d.ts.map +1 -0
  385. package/dist/views/MessageInput/index.js +62 -0
  386. package/dist/views/MessageInput/index.js.map +1 -0
  387. package/dist/views/MessageInput/styled.d.ts +4 -0
  388. package/dist/views/MessageInput/styled.d.ts.map +1 -0
  389. package/dist/views/MessageInput/styled.js +257 -0
  390. package/dist/views/MessageInput/styled.js.map +1 -0
  391. package/dist/views/MinimizedHeader.d.ts +7 -0
  392. package/dist/views/MinimizedHeader.d.ts.map +1 -0
  393. package/dist/views/MinimizedHeader.js +79 -0
  394. package/dist/views/MinimizedHeader.js.map +1 -0
  395. package/dist/views/Stacks.d.ts +5 -0
  396. package/dist/views/Stacks.d.ts.map +1 -0
  397. package/dist/views/Stacks.js +80 -0
  398. package/dist/views/Stacks.js.map +1 -0
  399. package/dist/views/Workspaces.d.ts +5 -0
  400. package/dist/views/Workspaces.d.ts.map +1 -0
  401. package/dist/views/Workspaces.js +66 -0
  402. package/dist/views/Workspaces.js.map +1 -0
  403. package/package.json +1 -1
  404. package/src/app-metadata.json +2 -2
@@ -0,0 +1,58 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Flex, IconBox, Image } from '@citric/core';
3
+ import { Agent } from '@citric/icons';
4
+ import { MiniLogo } from '@stack-spot/portal-components/svg';
5
+ import { agentClient } from '@stack-spot/portal-network';
6
+ import { uniqBy } from 'lodash';
7
+ import { useCallback } from 'react';
8
+ import { Selector } from '../../components/Selector/index.js';
9
+ import { useCurrentChat, useCurrentChatState } from '../../context/hooks.js';
10
+ import { agentRegex } from '../../regex.js';
11
+ const AGENT_DEFAULT_SLUG = 'stackspot_ai';
12
+ const isAgentStackspotAI = (slug) => slug === AGENT_DEFAULT_SLUG;
13
+ const defaultAgent = {
14
+ id: '',
15
+ name: 'StackSpot AI',
16
+ slug: AGENT_DEFAULT_SLUG,
17
+ visibility_level: 'builtIn',
18
+ };
19
+ export const AgentSelector = ({ inputRef }) => {
20
+ const chat = useCurrentChat();
21
+ const isAgentEnabled = useCurrentChatState('features').agent;
22
+ const onSelectItem = useCallback((agent) => {
23
+ const newValue = `@${agent.slug}`;
24
+ chat.set('nextMessage', undefined);
25
+ chat.set('agent', isAgentStackspotAI(agent.slug)
26
+ ? undefined
27
+ : { id: agent.id, label: agent.name, image: agent.avatar, builtIn: agent.visibility_level === 'builtIn' });
28
+ if (!inputRef.current)
29
+ return;
30
+ inputRef.current.value = newValue;
31
+ inputRef.current.focus();
32
+ }, [chat, inputRef]);
33
+ const getAgents = () => {
34
+ const agents = agentClient.agents.useQuery({});
35
+ const publicAgents = agentClient.publicAgents.useQuery({});
36
+ const accountAgents = agentClient.agents.useQuery({ visibility: 'ACCOUNT' });
37
+ const buildIns = [...[defaultAgent], ...publicAgents.map((agent) => ({ ...agent, visibility_level: 'builtIn' }))];
38
+ return uniqBy([...agents, ...buildIns, ...accountAgents], 'id');
39
+ };
40
+ const AgentItem = ({ avatar, name, slug }) => {
41
+ const AvatarComponent = avatar ? _jsx(Image, { width: "32", height: "32", radius: "full", src: avatar }) : _jsx(IconBox, { size: "md", children: _jsx(Agent, {}) });
42
+ return _jsxs(Flex, { flexWrap: "nowrap", alignItems: "center", sx: { gap: '8px' }, children: [isAgentStackspotAI(slug) ? _jsx(MiniLogo, { style: { width: '32px', height: '32px' } }) : AvatarComponent, _jsx("p", { className: "selector-title", children: name })] });
43
+ };
44
+ return _jsx(Selector, { inputRef: inputRef, selectorConfig: {
45
+ resourceName: 'Agent',
46
+ shortcut: '@',
47
+ icon: _jsx(Agent, {}),
48
+ regex: agentRegex,
49
+ urlBuilder: (agent) => `/agents/${agent?.id}`,
50
+ searchProp: 'name',
51
+ sections: ['personal', 'account', 'shared', 'builtIn'],
52
+ renderComponentItem: AgentItem,
53
+ isEnabled: isAgentEnabled,
54
+ onSelect: onSelectItem,
55
+ data: getAgents,
56
+ } });
57
+ };
58
+ //# sourceMappingURL=AgentSelector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AgentSelector.js","sourceRoot":"","sources":["../../../src/views/MessageInput/AgentSelector.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,cAAc,CAAA;AACnD,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AACrC,OAAO,EAAE,QAAQ,EAAE,MAAM,mCAAmC,CAAA;AAC5D,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAA;AAExD,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAC/B,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AACnC,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAA;AACpD,OAAO,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAA;AACzE,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAExC,MAAM,kBAAkB,GAAG,cAAc,CAAA;AAEzC,MAAM,kBAAkB,GAAG,CAAC,IAAY,EAAE,EAAE,CAAC,IAAI,KAAK,kBAAkB,CAAA;AAExE,MAAM,YAAY,GAAG;IACnB,EAAE,EAAE,EAAE;IACN,IAAI,EAAE,cAAc;IACpB,IAAI,EAAE,kBAAkB;IACxB,gBAAgB,EAAE,SAAS;CACX,CAAA;AAElB,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,EAAE,QAAQ,EAAyE,EAAE,EAAE;IACnH,MAAM,IAAI,GAAG,cAAc,EAAE,CAAA;IAC7B,MAAM,cAAc,GAAG,mBAAmB,CAAC,UAAU,CAAC,CAAC,KAAK,CAAA;IAC5D,MAAM,YAAY,GAAG,WAAW,CAAC,CAAC,KAAoB,EAAE,EAAE;QACxD,MAAM,QAAQ,GAAG,IAAI,KAAK,CAAC,IAAI,EAAE,CAAA;QACjC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,SAAS,CAAC,CAAA;QAClC,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,kBAAkB,CAAC,KAAK,CAAC,IAAI,CAAC;YAC9C,CAAC,CAAC,SAAS;YACX,CAAC,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,CAAC,gBAAgB,KAAK,SAAS,EAAE,CAC1G,CAAA;QAED,IAAI,CAAC,QAAQ,CAAC,OAAO;YAAE,OAAM;QAC7B,QAAQ,CAAC,OAAO,CAAC,KAAK,GAAG,QAAQ,CAAA;QACjC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,CAAA;IAC1B,CAAC,EAAE,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAA;IAEpB,MAAM,SAAS,GAAG,GAAG,EAAE;QACrB,MAAM,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;QAC9C,MAAM,YAAY,GAAG,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;QAC1D,MAAM,aAAa,GAAG,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAA;QAC5E,MAAM,QAAQ,GAAG,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,gBAAgB,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,CAAA;QACjH,OAAO,MAAM,CAAC,CAAC,GAAG,MAAM,EAAE,GAAG,QAAQ,EAAE,GAAG,aAAa,CAAC,EAAE,IAAI,CAAC,CAAA;IACjE,CAAC,CAAA;IAED,MAAM,SAAS,GAAG,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAiB,EAAE,EAAE;QAC1D,MAAM,eAAe,GAAG,MAAM,CAAC,CAAC,CAAC,KAAC,KAAK,IAAC,KAAK,EAAC,IAAI,EAAC,MAAM,EAAC,IAAI,EAAC,MAAM,EAAC,MAAM,EAAC,GAAG,EAAE,MAAM,GAAI,CAAC,CAAC,CAAC,KAAC,OAAO,IAAC,IAAI,EAAC,IAAI,YAAC,KAAC,KAAK,KAAG,GAAU,CAAA;QAErI,OAAO,MAAC,IAAI,IAAC,QAAQ,EAAC,QAAQ,EAAC,UAAU,EAAC,QAAQ,EAAC,EAAE,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,aAClE,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAI,CAAC,CAAC,CAAC,eAAe,EACpG,YAAG,SAAS,EAAC,gBAAgB,YAAE,IAAI,GAAK,IACnC,CAAA;IACT,CAAC,CAAA;IAED,OAAO,KAAC,QAAQ,IACd,QAAQ,EAAE,QAAQ,EAClB,cAAc,EAAE;YACd,YAAY,EAAE,OAAO;YACrB,QAAQ,EAAE,GAAG;YACb,IAAI,EAAE,KAAC,KAAK,KAAG;YACf,KAAK,EAAE,UAAU;YACjB,UAAU,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,WAAW,KAAK,EAAE,EAAE,EAAE;YAC7C,UAAU,EAAE,MAAM;YAClB,QAAQ,EAAE,CAAC,UAAU,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS,CAAC;YACtD,mBAAmB,EAAE,SAAS;YAC9B,SAAS,EAAE,cAAc;YACzB,QAAQ,EAAE,YAAY;YACtB,IAAI,EAAE,SAAS;SAChB,GACD,CAAA;AACJ,CAAC,CAAA"}
@@ -0,0 +1,2 @@
1
+ export declare const ButtonAgent: () => import("react/jsx-runtime").JSX.Element;
2
+ //# sourceMappingURL=ButtonAgent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ButtonAgent.d.ts","sourceRoot":"","sources":["../../../src/views/MessageInput/ButtonAgent.tsx"],"names":[],"mappings":"AAOA,eAAO,MAAM,WAAW,+CA4BvB,CAAA"}
@@ -0,0 +1,17 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Flex, IconBox } from '@citric/core';
3
+ import { Agent, TimesMini } from '@citric/icons';
4
+ import { IconButton, Tooltip } from '@citric/ui';
5
+ import { MiniLogo } from '@stack-spot/portal-components/svg';
6
+ import { useCurrentChat, useCurrentChatState, useWidget } from '../../context/hooks.js';
7
+ import { useMessageInputDictionary } from './dictionary.js';
8
+ export const ButtonAgent = () => {
9
+ const t = useMessageInputDictionary();
10
+ const widget = useWidget();
11
+ const chat = useCurrentChat();
12
+ const agent = useCurrentChatState('agent');
13
+ const features = useCurrentChatState('features');
14
+ return (_jsx("div", { className: "button-group", children: features.agent && (_jsxs("div", { className: "group-agent", children: [_jsx(IconButton, { "aria-label": t.agent, title: t.agent, className: "agent", onClick: () => widget.set('panel', 'agent'), children: _jsx(MiniLogo, {}) }), agent?.id &&
15
+ _jsx(Tooltip, { text: t.remove, children: _jsxs(IconButton, { "aria-label": t.remove, className: "agent agent-selected", onClick: () => chat.set('agent', undefined), children: [agent?.image ? _jsx("img", { src: agent.image, className: "image" }) : _jsx(IconBox, { className: "image", size: "xs", children: _jsx(Agent, {}) }), _jsx(Flex, { className: "icon-remove", alignContent: "center", justifyContent: "center", children: _jsx(TimesMini, {}) })] }) })] })) }));
16
+ };
17
+ //# sourceMappingURL=ButtonAgent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ButtonAgent.js","sourceRoot":"","sources":["../../../src/views/MessageInput/ButtonAgent.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AAChD,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,mCAAmC,CAAA;AAC5D,OAAO,EAAE,cAAc,EAAE,mBAAmB,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AACpF,OAAO,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAA;AAExD,MAAM,CAAC,MAAM,WAAW,GAAG,GAAG,EAAE;IAC9B,MAAM,CAAC,GAAG,yBAAyB,EAAE,CAAA;IACrC,MAAM,MAAM,GAAG,SAAS,EAAE,CAAA;IAC1B,MAAM,IAAI,GAAG,cAAc,EAAE,CAAA;IAC7B,MAAM,KAAK,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAA;IAC1C,MAAM,QAAQ,GAAG,mBAAmB,CAAC,UAAU,CAAC,CAAA;IAEhD,OAAO,CACL,cAAK,SAAS,EAAC,cAAc,YAC1B,QAAQ,CAAC,KAAK,IAAI,CACjB,eAAK,SAAS,EAAC,aAAa,aAC1B,KAAC,UAAU,kBAAa,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,SAAS,EAAC,OAAO,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,YAC5G,KAAC,QAAQ,KAAG,GACD,EACZ,KAAK,EAAE,EAAE;oBACR,KAAC,OAAO,IAAC,IAAI,EAAE,CAAC,CAAC,MAAM,YACrB,MAAC,UAAU,kBAAa,CAAC,CAAC,MAAM,EAAE,SAAS,EAAC,sBAAsB,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,SAAS,CAAC,aAC3G,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,cAAK,GAAG,EAAE,KAAK,CAAC,KAAK,EAAE,SAAS,EAAC,OAAO,GAAG,CAAC,CAAC,CAAC,KAAC,OAAO,IAAC,SAAS,EAAC,OAAO,EAAC,IAAI,EAAC,IAAI,YAAC,KAAC,KAAK,KAAG,GAAU,EACtH,KAAC,IAAI,IAAC,SAAS,EAAC,aAAa,EAAC,YAAY,EAAC,QAAQ,EAAC,cAAc,EAAC,QAAQ,YACzE,KAAC,SAAS,KAAG,GACR,IACI,GACL,IAER,CACP,GACG,CACP,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,29 @@
1
+ interface ButtonGroupProps {
2
+ /**
3
+ * Whether or not the button group is expanded.
4
+ */
5
+ expanded: boolean;
6
+ /**
7
+ * A function to set the button group as expanded or collapsed.
8
+ */
9
+ setExpanded: React.Dispatch<React.SetStateAction<boolean>>;
10
+ /**
11
+ * Whether or not the message is currently being sent. This is used to decide which button to show: send or cancel.
12
+ */
13
+ isLoading: boolean;
14
+ /**
15
+ * A function to run when the send button is clicked.
16
+ */
17
+ onSend: () => void;
18
+ /**
19
+ * A function to run when the cancel button is clicked.
20
+ */
21
+ onCancel: () => void;
22
+ }
23
+ /**
24
+ * Renders the button group at right bottom side of the message input. This includes the send button as well as the buttons to open the
25
+ * editor, change the stack, etc.
26
+ */
27
+ export declare const ButtonGroup: ({ onSend, onCancel, expanded, setExpanded, isLoading }: ButtonGroupProps) => import("react/jsx-runtime").JSX.Element;
28
+ export {};
29
+ //# sourceMappingURL=ButtonGroup.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ButtonGroup.d.ts","sourceRoot":"","sources":["../../../src/views/MessageInput/ButtonGroup.tsx"],"names":[],"mappings":"AAOA,UAAU,gBAAgB;IACxB;;OAEG;IACH,QAAQ,EAAE,OAAO,CAAC;IAClB;;OAEG;IACH,WAAW,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC;IAC3D;;OAEG;IACH,SAAS,EAAE,OAAO,CAAC;IACnB;;OAEG;IACH,MAAM,EAAE,MAAM,IAAI,CAAC;IACnB;;OAEG;IACH,QAAQ,EAAE,MAAM,IAAI,CAAC;CACtB;AAED;;;GAGG;AACH,eAAO,MAAM,WAAW,2DAA4D,gBAAgB,4CA0EnG,CAAA"}
@@ -0,0 +1,34 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { ChevronRight, Code, KnowledgeSource, Send, Stack, Times, Workspace } from '@citric/icons';
3
+ import { IconButton } from '@citric/ui';
4
+ import { listToClass } from '@stack-spot/portal-theme';
5
+ import { useEffect, useRef } from 'react';
6
+ import { useCurrentChatState, useWidget } from '../../context/hooks.js';
7
+ import { useMessageInputDictionary } from './dictionary.js';
8
+ /**
9
+ * Renders the button group at right bottom side of the message input. This includes the send button as well as the buttons to open the
10
+ * editor, change the stack, etc.
11
+ */
12
+ export const ButtonGroup = ({ onSend, onCancel, expanded, setExpanded, isLoading }) => {
13
+ const t = useMessageInputDictionary();
14
+ const widget = useWidget();
15
+ const featureButtonsWidth = useRef();
16
+ const featureButtons = useRef(null);
17
+ const features = useCurrentChatState('features');
18
+ const hasFeatureButtons = features.workspace || features.knowledgeSource || features.stack || features.editor;
19
+ useEffect(() => {
20
+ if (!featureButtons.current)
21
+ return;
22
+ const isHidden = featureButtons.current.style.width === '0px';
23
+ featureButtons.current.style.width = 'auto';
24
+ featureButtonsWidth.current = featureButtons.current.clientWidth;
25
+ if (isHidden)
26
+ featureButtons.current.style.width = '0px';
27
+ else
28
+ featureButtons.current.style.width = `${featureButtonsWidth.current}px`;
29
+ },
30
+ // don't use the whole features object here, it would make every chat tab change rerun this effect.
31
+ [features.workspace, features.knowledgeSource, features.stack, features.editor]);
32
+ return (_jsxs("div", { className: "button-group", children: [hasFeatureButtons && _jsxs(_Fragment, { children: [_jsxs("div", { ref: featureButtons, className: listToClass(['feature-buttons', expanded && 'expanded']), style: { width: expanded ? featureButtonsWidth.current : 0 }, children: [features.workspace && (_jsx(IconButton, { "aria-label": t.workspace, title: t.workspace, onClick: () => widget.set('panel', 'workspace'), children: _jsx(Workspace, {}) })), features.knowledgeSource && (_jsx(IconButton, { "aria-label": t.knowledgeSource, title: t.knowledgeSource, onClick: () => widget.set('panel', 'ks'), children: _jsx(KnowledgeSource, {}) })), features.stack && (_jsx(IconButton, { "aria-label": t.stack, title: t.stack, onClick: () => widget.set('panel', 'stack'), children: _jsx(Stack, {}) })), features.editor && (_jsx(IconButton, { "aria-label": t.code, title: t.code, onClick: () => widget.set('panel', 'editor'), children: _jsx(Code, {}) }))] }), _jsx(IconButton, { title: expanded ? t.collapse : t.expand, className: listToClass(['expand', !expanded && 'collapsed']), "aria-label": expanded ? t.collapse : t.expand, onClick: () => setExpanded(v => !v), children: _jsx(ChevronRight, {}) })] }), isLoading ? (_jsx(IconButton, { "aria-label": t.cancel, onClick: onCancel, className: "send", title: t.cancel, children: _jsx(Times, {}) })) : (_jsx(IconButton, { "aria-label": t.send, onClick: onSend, className: "send", title: t.send, children: _jsx(Send, {}) }))] }));
33
+ };
34
+ //# sourceMappingURL=ButtonGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ButtonGroup.js","sourceRoot":"","sources":["../../../src/views/MessageInput/ButtonGroup.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * This renders the bar on top of the textarea to send the message. This tells:
3
+ * - if there's any code selected in the editor;
4
+ * - which workspace is being used;
5
+ * - which stack is being used;
6
+ * - which knowledge sources are being used.
7
+ */
8
+ export declare const InfoBar: () => import("react/jsx-runtime").JSX.Element;
9
+ //# sourceMappingURL=InfoBar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InfoBar.d.ts","sourceRoot":"","sources":["../../../src/views/MessageInput/InfoBar.tsx"],"names":[],"mappings":"AAuBA;;;;;;GAMG;AACH,eAAO,MAAM,OAAO,+CA0EnB,CAAA"}
@@ -0,0 +1,52 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Times, TimesMini } from '@citric/icons';
3
+ import { Badge, IconButton } from '@citric/ui';
4
+ import { loader } from '@monaco-editor/react';
5
+ import { listToClass } from '@stack-spot/portal-theme';
6
+ import { useCallback, useMemo } from 'react';
7
+ import { FadingOverflow } from '../../components/FadingOverflow.js';
8
+ import { useCurrentChat, useCurrentChatState } from '../../context/hooks.js';
9
+ import { useMessageInputDictionary } from './dictionary.js';
10
+ const InfoBadge = ({ label, color, dismiss, onDismiss }) => (_jsxs(Badge, { appearance: "square", palette: color, className: "info-badge", children: [label, onDismiss && _jsx(IconButton, { onClick: onDismiss, title: dismiss, "arial-label": dismiss, children: _jsx(TimesMini, {}) })] }));
11
+ /**
12
+ * This renders the bar on top of the textarea to send the message. This tells:
13
+ * - if there's any code selected in the editor;
14
+ * - which workspace is being used;
15
+ * - which stack is being used;
16
+ * - which knowledge sources are being used.
17
+ */
18
+ export const InfoBar = () => {
19
+ const t = useMessageInputDictionary();
20
+ const chat = useCurrentChat();
21
+ const currentStack = useCurrentChatState('stack');
22
+ const currentWorkspace = useCurrentChatState('workspace');
23
+ const currentKnowledgeSources = useCurrentChatState('knowledgeSources');
24
+ const currentSelection = useCurrentChatState('codeSelection');
25
+ const features = useCurrentChatState('features');
26
+ const visible = !!(currentStack || currentWorkspace || currentKnowledgeSources?.length || currentSelection);
27
+ const ksToRender = useMemo(() => currentKnowledgeSources?.map(ks => {
28
+ const onDismiss = features.knowledgeSource
29
+ ? (() => chat.set('knowledgeSources', currentKnowledgeSources.filter(({ id }) => id !== ks.id)))
30
+ : undefined;
31
+ return _jsx("li", { children: _jsx(InfoBadge, { label: ks.label, dismiss: t.removeKS, color: "teal", onDismiss: onDismiss }) }, ks.id);
32
+ }), [currentKnowledgeSources]);
33
+ const shouldRenderRemoveAllButton = (currentSelection
34
+ || (features.stack && currentStack)
35
+ || (features.workspace && currentWorkspace)
36
+ || (features.knowledgeSource && !!ksToRender?.length));
37
+ const removeAll = useCallback(() => {
38
+ if (features.knowledgeSource)
39
+ chat.set('knowledgeSources', []);
40
+ if (features.stack)
41
+ chat.set('stack', undefined);
42
+ if (features.workspace)
43
+ chat.set('workspace', undefined);
44
+ removeCodeSelection();
45
+ }, []);
46
+ const removeCodeSelection = useCallback(() => {
47
+ const editor = loader.__getMonacoInstance()?.editor;
48
+ editor?.getEditors()[0].setSelection({ startLineNumber: 0, endLineNumber: 0, endColumn: 0, startColumn: 0 });
49
+ }, []);
50
+ return (_jsxs("div", { className: listToClass(['info-bar', visible && 'visible']), children: [_jsx("div", { className: "space" }), _jsxs("div", { className: "content", children: [shouldRenderRemoveAllButton && (_jsx(IconButton, { "aria-label": t.removeConfig, title: t.removeConfig, onClick: removeAll, children: _jsx(Times, {}) })), _jsx(FadingOverflow, { className: "list-overflow", scroll: "arrows", enableHorizontalScrollWithVerticalWheel: true, children: _jsxs("ul", { children: [currentSelection && (_jsx("li", { children: _jsx(InfoBadge, { label: t.selected, dismiss: t.removeSelection, color: "blue", onDismiss: removeCodeSelection }) })), currentStack && (_jsx("li", { children: _jsx(InfoBadge, { label: currentStack.label, dismiss: t.removeStack, color: "cyan", onDismiss: features.stack ? (() => chat.set('stack', undefined)) : undefined }) })), currentWorkspace && (_jsx("li", { children: _jsx(InfoBadge, { label: currentWorkspace.label, dismiss: t.removeWorkspace, color: "pink", onDismiss: features.workspace ? (() => chat.set('workspace', undefined)) : undefined }) })), ksToRender] }) })] })] }));
51
+ };
52
+ //# sourceMappingURL=InfoBar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InfoBar.js","sourceRoot":"","sources":["../../../src/views/MessageInput/InfoBar.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export declare const QuickCommandSelector: ({ inputRef }: {
2
+ inputRef: React.RefObject<HTMLTextAreaElement | HTMLInputElement>;
3
+ }) => import("react/jsx-runtime").JSX.Element;
4
+ //# sourceMappingURL=QuickCommandSelector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QuickCommandSelector.d.ts","sourceRoot":"","sources":["../../../src/views/MessageInput/QuickCommandSelector.tsx"],"names":[],"mappings":"AAQA,eAAO,MAAM,oBAAoB,iBAAkB;IAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,mBAAmB,GAAG,gBAAgB,CAAC,CAAA;CAAE,4CAkCvH,CAAA"}
@@ -0,0 +1,34 @@
1
+ import { jsxs as _jsxs, jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { QuickCommand } from '@citric/icons';
3
+ import { aiClient } from '@stack-spot/portal-network';
4
+ import { useCallback } from 'react';
5
+ import { Selector } from '../../components/Selector/index.js';
6
+ import { useCurrentChat, useCurrentChatState } from '../../context/hooks.js';
7
+ import { quickCommandRegex } from '../../regex.js';
8
+ export const QuickCommandSelector = ({ inputRef }) => {
9
+ const chat = useCurrentChat();
10
+ const isQuickCommandEnabled = useCurrentChatState('features').quickCommands;
11
+ const onSelectItem = useCallback((qc) => {
12
+ const newValue = `/${qc.slug}`;
13
+ chat.set('nextMessage', newValue);
14
+ if (!inputRef.current)
15
+ return;
16
+ inputRef.current.value = newValue;
17
+ inputRef.current.focus();
18
+ }, [chat, inputRef]);
19
+ const QuickCommandItem = ({ slug, description }) => _jsxs(_Fragment, { children: [_jsxs("p", { className: "selector-title", children: ["/", slug.toUpperCase()] }), _jsx("p", { className: "selector-description", children: description })] });
20
+ return _jsx(Selector, { inputRef: inputRef, selectorConfig: {
21
+ resourceName: 'Quick Command',
22
+ shortcut: '/',
23
+ icon: _jsx(QuickCommand, {}),
24
+ searchProp: 'slug',
25
+ urlBuilder: (qc) => `/quick-command/${qc?.slug}`,
26
+ regex: quickCommandRegex,
27
+ sections: ['personal', 'workspace', 'account', 'shared'],
28
+ isEnabled: isQuickCommandEnabled,
29
+ onSelect: onSelectItem,
30
+ renderComponentItem: QuickCommandItem,
31
+ data: () => aiClient.quickCommands.useQuery({ order: 'a-to-z' }),
32
+ } });
33
+ };
34
+ //# sourceMappingURL=QuickCommandSelector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QuickCommandSelector.js","sourceRoot":"","sources":["../../../src/views/MessageInput/QuickCommandSelector.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAA;AAC5C,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAErD,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AACnC,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAA;AACpD,OAAO,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAA;AACzE,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAA;AAE/C,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,EAAE,QAAQ,EAAyE,EAAE,EAAE;IAC1H,MAAM,IAAI,GAAG,cAAc,EAAE,CAAA;IAC7B,MAAM,qBAAqB,GAAI,mBAAmB,CAAC,UAAU,CAAC,CAAC,aAAa,CAAA;IAE5E,MAAM,YAAY,GAAG,WAAW,CAAC,CAAC,EAA4B,EAAE,EAAE;QAChE,MAAM,QAAQ,GAAG,IAAI,EAAE,CAAC,IAAI,EAAE,CAAA;QAC9B,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAA;QAEjC,IAAI,CAAC,QAAQ,CAAC,OAAO;YAAE,OAAM;QAC7B,QAAQ,CAAC,OAAO,CAAC,KAAK,GAAG,QAAQ,CAAA;QACjC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,CAAA;IAC1B,CAAC,EAAE,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAA;IAEpB,MAAM,gBAAgB,GAAG,CAAC,EAAE,IAAI,EAAE,WAAW,EAA4B,EAAE,EAAE,CAAC,8BAC5E,aAAG,SAAS,EAAC,gBAAgB,kBAAG,IAAI,CAAC,WAAW,EAAE,IAAK,EACvD,YAAG,SAAS,EAAC,sBAAsB,YAAE,WAAW,GAAK,IACpD,CAAA;IAEH,OAAO,KAAC,QAAQ,IACd,QAAQ,EAAE,QAAQ,EAClB,cAAc,EAAE;YACd,YAAY,EAAE,eAAe;YAC7B,QAAQ,EAAE,GAAG;YACb,IAAI,EAAE,KAAC,YAAY,KAAG;YACtB,UAAU,EAAE,MAAM;YAClB,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,kBAAkB,EAAE,EAAE,IAAI,EAAE;YAChD,KAAK,EAAE,iBAAiB;YACxB,QAAQ,EAAE,CAAC,UAAU,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,CAAC;YACxD,SAAS,EAAE,qBAAqB;YAChC,QAAQ,EAAE,YAAY;YACtB,mBAAmB,EAAE,gBAAgB;YACrC,IAAI,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;SACjE,GACD,CAAA;AACJ,CAAC,CAAA"}
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Hook to manage keyboard shortcuts for the user's input history.
3
+ *
4
+ * This hook allows the user to navigate through the history of messages sent in a chat
5
+ * using the up arrow (`ArrowUp`) and down arrow (`ArrowDown`) keys.
6
+ */
7
+ export declare const useUserEntryHistoryShortcut: () => {
8
+ handleKeyDown: (event: React.KeyboardEvent<HTMLTextAreaElement>) => void;
9
+ handleKeyUp: (event: React.KeyboardEvent<HTMLTextAreaElement>) => void;
10
+ };
11
+ //# sourceMappingURL=chat-entry-history.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chat-entry-history.d.ts","sourceRoot":"","sources":["../../../src/views/MessageInput/chat-entry-history.ts"],"names":[],"mappings":"AAwCA;;;;;GAKG;AACH,eAAO,MAAM,2BAA2B;2BAiCI,KAAK,CAAC,aAAa,CAAC,mBAAmB,CAAC;yBAU1C,KAAK,CAAC,aAAa,CAAC,mBAAmB,CAAC;CAOjF,CAAA"}
@@ -0,0 +1,78 @@
1
+ import { useCallback, useEffect, useRef } from 'react';
2
+ import { useCurrentChat } from '../../context/hooks.js';
3
+ const DEFAULT_POINTER = -1;
4
+ const useChatEntryHistory = () => {
5
+ const chat = useCurrentChat();
6
+ const historyPointer = useRef(DEFAULT_POINTER);
7
+ const messages = chat.getMessages();
8
+ useEffect(() => {
9
+ historyPointer.current = chat.getMessages().length;
10
+ }, [chat.id, messages]);
11
+ const navigateEntry = useCallback((startIndex, direction, inputValue) => {
12
+ const chatEntries = chat.getMessages() || [];
13
+ let pointer = startIndex + direction;
14
+ while (pointer > DEFAULT_POINTER && pointer < chatEntries.length && chatEntries[pointer]?.getValue().agentType !== 'user') {
15
+ pointer += direction;
16
+ }
17
+ if (pointer >= chatEntries.length + direction) {
18
+ return inputValue;
19
+ }
20
+ if (pointer <= DEFAULT_POINTER) {
21
+ return chatEntries[0]?.getValue().content ?? inputValue;
22
+ }
23
+ historyPointer.current = pointer;
24
+ return chatEntries[pointer]?.getValue().content ?? inputValue;
25
+ }, [chat]);
26
+ const getPreviousUserEntry = useCallback((inputValue) => navigateEntry(historyPointer.current, -1, inputValue), [navigateEntry]);
27
+ const getNextUserEntry = useCallback((inputValue) => navigateEntry(historyPointer.current, +1, inputValue), [navigateEntry]);
28
+ return { getNextUserEntry, getPreviousUserEntry };
29
+ };
30
+ /**
31
+ * Hook to manage keyboard shortcuts for the user's input history.
32
+ *
33
+ * This hook allows the user to navigate through the history of messages sent in a chat
34
+ * using the up arrow (`ArrowUp`) and down arrow (`ArrowDown`) keys.
35
+ */
36
+ export const useUserEntryHistoryShortcut = () => {
37
+ const { getNextUserEntry, getPreviousUserEntry } = useChatEntryHistory();
38
+ const chat = useCurrentChat();
39
+ const userEntryRef = useRef(chat.get('nextMessage') ?? '');
40
+ useEffect(() => {
41
+ userEntryRef.current = chat.get('nextMessage') ?? '';
42
+ chat.onChange('nextMessage', (value) => {
43
+ if (value === '') {
44
+ userEntryRef.current = '';
45
+ }
46
+ });
47
+ }, [chat.id]);
48
+ const setNextMessageFromHistory = useCallback((event, getEntryHistory) => {
49
+ const textarea = event.target;
50
+ if (textarea.selectionStart !== 0)
51
+ return;
52
+ const entryHistory = getEntryHistory(userEntryRef.current);
53
+ if (entryHistory === chat.get('nextMessage'))
54
+ return;
55
+ chat.set('nextMessage', entryHistory);
56
+ requestAnimationFrame(() => {
57
+ textarea.selectionStart = 0;
58
+ textarea.selectionEnd = 0;
59
+ event.preventDefault();
60
+ event.stopPropagation();
61
+ });
62
+ }, [chat]);
63
+ const handleKeyDown = useCallback((event) => {
64
+ if (event.key === 'ArrowUp') {
65
+ setNextMessageFromHistory(event, getPreviousUserEntry);
66
+ }
67
+ if (event.key === 'ArrowDown') {
68
+ setNextMessageFromHistory(event, getNextUserEntry);
69
+ }
70
+ }, [getPreviousUserEntry, getNextUserEntry, setNextMessageFromHistory]);
71
+ const handleKeyUp = useCallback((event) => {
72
+ if (!event.key.startsWith('Arrow')) {
73
+ userEntryRef.current = chat.get('nextMessage') ?? '';
74
+ }
75
+ }, [chat]);
76
+ return { handleKeyDown, handleKeyUp };
77
+ };
78
+ //# sourceMappingURL=chat-entry-history.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chat-entry-history.js","sourceRoot":"","sources":["../../../src/views/MessageInput/chat-entry-history.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare const useMessageInputDictionary: () => Record<"cancel" | "code" | "placeholder" | "selected" | "stack" | "workspace" | "knowledgeSource" | "agent" | "send" | "collapse" | "expand" | "removeConfig" | "removeStack" | "removeWorkspace" | "removeKS" | "removeSelection" | "remove", string>;
2
+ //# sourceMappingURL=dictionary.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dictionary.d.ts","sourceRoot":"","sources":["../../../src/views/MessageInput/dictionary.ts"],"names":[],"mappings":"AA2CA,eAAO,MAAM,yBAAyB,8PAAiC,CAAA"}
@@ -0,0 +1,43 @@
1
+ import { useTranslate } from '@stack-spot/portal-translate';
2
+ const dictionary = {
3
+ en: {
4
+ stack: 'Select stack',
5
+ code: 'Open code editor',
6
+ workspace: 'Select workspace',
7
+ knowledgeSource: 'Select knowledge sources',
8
+ agent: 'Select agent',
9
+ collapse: 'Hide buttons',
10
+ expand: 'Show buttons',
11
+ send: 'Send message',
12
+ placeholder: 'Message to $0',
13
+ cancel: 'Cancel',
14
+ removeConfig: 'Remove all the configuration',
15
+ removeStack: 'Stop using the current stack',
16
+ removeWorkspace: 'Stop using the current workspace',
17
+ removeKS: 'Stop using this knowledge source',
18
+ selected: 'Selected',
19
+ removeSelection: 'Remove current code selection',
20
+ remove: 'Remove',
21
+ },
22
+ pt: {
23
+ stack: 'Selecionar stack',
24
+ code: 'Abrir editor de código',
25
+ workspace: 'Selecionar workspace',
26
+ knowledgeSource: 'Selecionar knowledge sources',
27
+ agent: 'Selecionar agente',
28
+ collapse: 'Esconder botões',
29
+ expand: 'Mostrar botões',
30
+ send: 'Enviar mensagem',
31
+ placeholder: 'Mensagem para $0',
32
+ cancel: 'Cancelar',
33
+ removeConfig: 'Remover todas as configurações',
34
+ removeStack: 'Parar de usar a stack atual',
35
+ removeWorkspace: 'Parar de usar o workspace atual',
36
+ removeKS: 'Parar de usar este knowledge source',
37
+ selected: 'Selecionado',
38
+ removeSelection: 'Desfazer seleção de código',
39
+ remove: 'Remover',
40
+ },
41
+ };
42
+ export const useMessageInputDictionary = () => useTranslate(dictionary);
43
+ //# sourceMappingURL=dictionary.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dictionary.js","sourceRoot":"","sources":["../../../src/views/MessageInput/dictionary.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,YAAY,EAAE,MAAM,8BAA8B,CAAA;AAEvE,MAAM,UAAU,GAAG;IACjB,EAAE,EAAE;QACF,KAAK,EAAE,cAAc;QACrB,IAAI,EAAE,kBAAkB;QACxB,SAAS,EAAE,kBAAkB;QAC7B,eAAe,EAAE,0BAA0B;QAC3C,KAAK,EAAE,cAAc;QACrB,QAAQ,EAAE,cAAc;QACxB,MAAM,EAAE,cAAc;QACtB,IAAI,EAAE,cAAc;QACpB,WAAW,EAAE,eAAe;QAC5B,MAAM,EAAE,QAAQ;QAChB,YAAY,EAAE,8BAA8B;QAC5C,WAAW,EAAE,8BAA8B;QAC3C,eAAe,EAAE,kCAAkC;QACnD,QAAQ,EAAE,kCAAkC;QAC5C,QAAQ,EAAE,UAAU;QACpB,eAAe,EAAE,+BAA+B;QAChD,MAAM,EAAE,QAAQ;KACjB;IACD,EAAE,EAAE;QACF,KAAK,EAAE,kBAAkB;QACzB,IAAI,EAAE,wBAAwB;QAC9B,SAAS,EAAE,sBAAsB;QACjC,eAAe,EAAE,8BAA8B;QAC/C,KAAK,EAAE,mBAAmB;QAC1B,QAAQ,EAAE,iBAAiB;QAC3B,MAAM,EAAE,gBAAgB;QACxB,IAAI,EAAE,iBAAiB;QACvB,WAAW,EAAE,kBAAkB;QAC/B,MAAM,EAAE,UAAU;QAClB,YAAY,EAAE,gCAAgC;QAC9C,WAAW,EAAE,6BAA6B;QAC1C,eAAe,EAAE,iCAAiC;QAClD,QAAQ,EAAE,qCAAqC;QAC/C,QAAQ,EAAE,aAAa;QACvB,eAAe,EAAE,4BAA4B;QAC7C,MAAM,EAAE,SAAS;KAClB;CACmB,CAAA;AAEtB,MAAM,CAAC,MAAM,yBAAyB,GAAG,GAAG,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC,CAAA"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * This renders the MessageInput part of the layout which includes the progress bar, the actual textarea, the badges telling what is
3
+ * going to be used for the question and the buttons to send, cancel, set the workspace, among others. This also includes the Quick
4
+ * Commands panel for auto completing.
5
+ */
6
+ export declare const MessageInput: () => import("react/jsx-runtime").JSX.Element;
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/MessageInput/index.tsx"],"names":[],"mappings":"AAkBA;;;;GAIG;AACH,eAAO,MAAM,YAAY,+CA0ExB,CAAA"}
@@ -0,0 +1,62 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { listToClass } from '@stack-spot/portal-theme';
3
+ import { interpolate } from '@stack-spot/portal-translate';
4
+ import { useCallback, useEffect, useRef, useState } from 'react';
5
+ import { AdaptiveTextArea } from '../../components/AdaptiveTextArea.js';
6
+ import { ProgressBar } from '../../components/ProgressBar.js';
7
+ import { useCurrentChat, useCurrentChatState, useWidgetState } from '../../context/hooks.js';
8
+ import { quickCommandRegex } from '../../regex.js';
9
+ import { ChatEntry } from '../../state/ChatEntry.js';
10
+ import { AgentSelector } from './AgentSelector.js';
11
+ import { ButtonAgent } from './ButtonAgent.js';
12
+ import { ButtonGroup } from './ButtonGroup.js';
13
+ import { useMessageInputDictionary } from './dictionary.js';
14
+ import { InfoBar } from './InfoBar.js';
15
+ import { useUserEntryHistoryShortcut } from './chat-entry-history.js';
16
+ import { QuickCommandSelector } from './QuickCommandSelector.js';
17
+ import { MAX_INPUT_HEIGHT, MessageInputBox, MIN_INPUT_HEIGHT } from './styled.js';
18
+ /**
19
+ * This renders the MessageInput part of the layout which includes the progress bar, the actual textarea, the badges telling what is
20
+ * going to be used for the question and the buttons to send, cancel, set the workspace, among others. This also includes the Quick
21
+ * Commands panel for auto completing.
22
+ */
23
+ export const MessageInput = () => {
24
+ const t = useMessageInputDictionary();
25
+ const [focused, setFocused] = useState(false);
26
+ const [expanded, setExpanded] = useState(true);
27
+ const expansionLocked = useRef(false);
28
+ const chat = useCurrentChat();
29
+ const isLoading = useCurrentChatState('isLoading') ?? false;
30
+ const value = useCurrentChatState('nextMessage') ?? '';
31
+ const isMinimized = useWidgetState('isMinimized');
32
+ const textAreaRef = useRef(null);
33
+ const agentLabel = useCurrentChatState('agent')?.label ?? 'Stackspot AI';
34
+ const { handleKeyDown, handleKeyUp } = useUserEntryHistoryShortcut();
35
+ const onSend = useCallback(async () => {
36
+ const message = chat.get('nextMessage');
37
+ if (!message)
38
+ return;
39
+ const code = chat.get('codeSelection');
40
+ const language = chat.get('codeLanguage');
41
+ const prompt = code && !quickCommandRegex.test(message) ? `${message}\n\`\`\`${language}\n${code}\n\`\`\`` : message;
42
+ chat.pushMessage(ChatEntry.createUserEntry(prompt, true));
43
+ chat.set('nextMessage', '');
44
+ setFocused(false);
45
+ }, [chat]);
46
+ const onKeyDown = useCallback((event) => {
47
+ if (!event.shiftKey && event.key === 'Enter') {
48
+ event.preventDefault();
49
+ onSend();
50
+ }
51
+ handleKeyDown(event);
52
+ }, [onSend, handleKeyDown]);
53
+ useEffect(() => {
54
+ if (!isLoading)
55
+ textAreaRef.current?.focus();
56
+ }, [isLoading]);
57
+ return (_jsxs(MessageInputBox, { "aria-busy": isLoading, className: "message-input", children: [_jsx(ProgressBar, { visible: isLoading, shimmer: true }), _jsx(InfoBar, {}), _jsxs("div", { className: "wrapper-action", children: [_jsx(QuickCommandSelector, { inputRef: textAreaRef }), _jsx(AgentSelector, { inputRef: textAreaRef }), _jsxs("div", { className: listToClass(['action-box', focused && 'focused', isLoading && 'disabled']), children: [_jsx(ButtonAgent, {}), _jsx(AdaptiveTextArea, { ref: textAreaRef, disabled: isLoading, placeholder: interpolate(t.placeholder, agentLabel), onChange: e => chat.set('nextMessage', e.target.value), value: value, onFocus: () => setFocused(true), onBlur: () => setFocused(false), onKeyDown: onKeyDown, onKeyUp: handleKeyUp, onIncreaseSize: () => setExpanded(false), onResetSize: () => !expansionLocked.current && setExpanded(true), maxHeight: isMinimized ? MIN_INPUT_HEIGHT : MAX_INPUT_HEIGHT }), _jsx(ButtonGroup, { onSend: onSend, onCancel: () => chat.abort(), expanded: expanded, isLoading: isLoading, setExpanded: (value) => {
58
+ setExpanded(value);
59
+ expansionLocked.current = expanded;
60
+ } })] })] })] }));
61
+ };
62
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/views/MessageInput/index.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export declare const MAX_INPUT_HEIGHT = 300;
2
+ export declare const MIN_INPUT_HEIGHT = 24;
3
+ export declare const MessageInputBox: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").FastOmit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, never>> & string;
4
+ //# sourceMappingURL=styled.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styled.d.ts","sourceRoot":"","sources":["../../../src/views/MessageInput/styled.ts"],"names":[],"mappings":"AAMA,eAAO,MAAM,gBAAgB,MAAM,CAAA;AACnC,eAAO,MAAM,gBAAgB,KAAK,CAAA;AAElC,eAAO,MAAM,eAAe,wOAwP3B,CAAA"}