@stack-spot/ai-chat-widget 0.11.0 → 1.0.0-dev.1768324407795

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 (779) hide show
  1. package/CHANGELOG.md +972 -0
  2. package/README.md +1 -0
  3. package/dist/StackspotAIWidget.d.ts +48 -7
  4. package/dist/StackspotAIWidget.d.ts.map +1 -1
  5. package/dist/StackspotAIWidget.js +22 -23
  6. package/dist/StackspotAIWidget.js.map +1 -1
  7. package/dist/app-metadata.json +175 -0
  8. package/dist/assets/placeholder.png +0 -0
  9. package/dist/chat-interceptors/CustomInputs.d.ts +4 -1
  10. package/dist/chat-interceptors/CustomInputs.d.ts.map +1 -1
  11. package/dist/chat-interceptors/CustomInputs.js +10 -1
  12. package/dist/chat-interceptors/CustomInputs.js.map +1 -1
  13. package/dist/chat-interceptors/quick-command-questions.d.ts +10 -0
  14. package/dist/chat-interceptors/quick-command-questions.d.ts.map +1 -1
  15. package/dist/chat-interceptors/quick-command-questions.js +12 -2
  16. package/dist/chat-interceptors/quick-command-questions.js.map +1 -1
  17. package/dist/chat-interceptors/quick-commands.d.ts +11 -0
  18. package/dist/chat-interceptors/quick-commands.d.ts.map +1 -1
  19. package/dist/chat-interceptors/quick-commands.js +241 -48
  20. package/dist/chat-interceptors/quick-commands.js.map +1 -1
  21. package/dist/chat-interceptors/send-message.d.ts +26 -1
  22. package/dist/chat-interceptors/send-message.d.ts.map +1 -1
  23. package/dist/chat-interceptors/send-message.js +227 -26
  24. package/dist/chat-interceptors/send-message.js.map +1 -1
  25. package/dist/components/AdaptiveTextArea.d.ts +15 -3
  26. package/dist/components/AdaptiveTextArea.d.ts.map +1 -1
  27. package/dist/components/AdaptiveTextArea.js +22 -10
  28. package/dist/components/AdaptiveTextArea.js.map +1 -1
  29. package/dist/components/AgentCard/AgentCardCreate.d.ts +4 -0
  30. package/dist/components/AgentCard/AgentCardCreate.d.ts.map +1 -0
  31. package/dist/components/AgentCard/AgentCardCreate.js +33 -0
  32. package/dist/components/AgentCard/AgentCardCreate.js.map +1 -0
  33. package/dist/components/AgentCard/dictionary.d.ts +23 -0
  34. package/dist/components/AgentCard/dictionary.d.ts.map +1 -0
  35. package/dist/components/AgentCard/dictionary.js +23 -0
  36. package/dist/components/AgentCard/dictionary.js.map +1 -0
  37. package/dist/components/AgentCard/index.d.ts +5 -0
  38. package/dist/components/AgentCard/index.d.ts.map +1 -0
  39. package/dist/components/AgentCard/index.js +55 -0
  40. package/dist/components/AgentCard/index.js.map +1 -0
  41. package/dist/components/AnimatedOpacity.d.ts +8 -0
  42. package/dist/components/AnimatedOpacity.d.ts.map +1 -0
  43. package/dist/components/AnimatedOpacity.js +46 -0
  44. package/dist/components/AnimatedOpacity.js.map +1 -0
  45. package/dist/components/AutoFocus.d.ts +23 -0
  46. package/dist/components/AutoFocus.d.ts.map +1 -0
  47. package/dist/components/AutoFocus.js +23 -0
  48. package/dist/components/AutoFocus.js.map +1 -0
  49. package/dist/components/ButtonFavorite.d.ts +40 -0
  50. package/dist/components/ButtonFavorite.d.ts.map +1 -0
  51. package/dist/components/ButtonFavorite.js +25 -0
  52. package/dist/components/ButtonFavorite.js.map +1 -0
  53. package/dist/components/Code.d.ts +2 -1
  54. package/dist/components/Code.d.ts.map +1 -1
  55. package/dist/components/Code.js +52 -24
  56. package/dist/components/Code.js.map +1 -1
  57. package/dist/components/ComponentNavigator.d.ts +38 -0
  58. package/dist/components/ComponentNavigator.d.ts.map +1 -0
  59. package/dist/components/ComponentNavigator.js +31 -0
  60. package/dist/components/ComponentNavigator.js.map +1 -0
  61. package/dist/components/Fading.d.ts +32 -0
  62. package/dist/components/Fading.d.ts.map +1 -0
  63. package/dist/components/Fading.js +33 -0
  64. package/dist/components/Fading.js.map +1 -0
  65. package/dist/components/FadingOverflow.d.ts +25 -0
  66. package/dist/components/FadingOverflow.d.ts.map +1 -1
  67. package/dist/components/FadingOverflow.js +16 -8
  68. package/dist/components/FadingOverflow.js.map +1 -1
  69. package/dist/components/FileDescription.d.ts +10 -0
  70. package/dist/components/FileDescription.d.ts.map +1 -0
  71. package/dist/components/FileDescription.js +84 -0
  72. package/dist/components/FileDescription.js.map +1 -0
  73. package/dist/components/HistoryList.d.ts +15 -0
  74. package/dist/components/HistoryList.d.ts.map +1 -1
  75. package/dist/components/HistoryList.js +6 -2
  76. package/dist/components/HistoryList.js.map +1 -1
  77. package/dist/components/ListResource.d.ts +29 -0
  78. package/dist/components/ListResource.d.ts.map +1 -0
  79. package/dist/components/ListResource.js +17 -0
  80. package/dist/components/ListResource.js.map +1 -0
  81. package/dist/components/Markdown.d.ts.map +1 -1
  82. package/dist/components/Markdown.js +2 -2
  83. package/dist/components/Markdown.js.map +1 -1
  84. package/dist/components/Modal.d.ts +9 -0
  85. package/dist/components/Modal.d.ts.map +1 -0
  86. package/dist/components/Modal.js +56 -0
  87. package/dist/components/Modal.js.map +1 -0
  88. package/dist/components/QuickStartButton.d.ts +2 -4
  89. package/dist/components/QuickStartButton.d.ts.map +1 -1
  90. package/dist/components/QuickStartButton.js +7 -39
  91. package/dist/components/QuickStartButton.js.map +1 -1
  92. package/dist/components/RightPanelContentList.d.ts +10 -0
  93. package/dist/components/RightPanelContentList.d.ts.map +1 -0
  94. package/dist/components/RightPanelContentList.js +7 -0
  95. package/dist/components/RightPanelContentList.js.map +1 -0
  96. package/dist/components/RightPanelForm.d.ts +3 -0
  97. package/dist/components/RightPanelForm.d.ts.map +1 -1
  98. package/dist/components/RightPanelForm.js +57 -17
  99. package/dist/components/RightPanelForm.js.map +1 -1
  100. package/dist/components/RightPanelTabs.d.ts +4 -4
  101. package/dist/components/RightPanelTabs.d.ts.map +1 -1
  102. package/dist/components/RightPanelTabs.js +7 -16
  103. package/dist/components/RightPanelTabs.js.map +1 -1
  104. package/dist/components/Selector/index.d.ts +54 -0
  105. package/dist/components/Selector/index.d.ts.map +1 -0
  106. package/dist/components/Selector/index.js +143 -0
  107. package/dist/components/Selector/index.js.map +1 -0
  108. package/dist/components/Selector/styled.d.ts +4 -0
  109. package/dist/components/Selector/styled.d.ts.map +1 -0
  110. package/dist/components/Selector/styled.js +157 -0
  111. package/dist/components/Selector/styled.js.map +1 -0
  112. package/dist/components/StackedBadge.d.ts +14 -0
  113. package/dist/components/StackedBadge.d.ts.map +1 -0
  114. package/dist/components/StackedBadge.js +56 -0
  115. package/dist/components/StackedBadge.js.map +1 -0
  116. package/dist/components/TabManager.d.ts +6 -0
  117. package/dist/components/TabManager.d.ts.map +1 -1
  118. package/dist/components/TabManager.js +16 -28
  119. package/dist/components/TabManager.js.map +1 -1
  120. package/dist/components/ToolBadge.d.ts +9 -0
  121. package/dist/components/ToolBadge.d.ts.map +1 -0
  122. package/dist/components/ToolBadge.js +34 -0
  123. package/dist/components/ToolBadge.js.map +1 -0
  124. package/dist/components/WorkspaceTabNavigator.d.ts +17 -0
  125. package/dist/components/WorkspaceTabNavigator.d.ts.map +1 -0
  126. package/dist/components/WorkspaceTabNavigator.js +93 -0
  127. package/dist/components/WorkspaceTabNavigator.js.map +1 -0
  128. package/dist/components/form/DescribedCheckboxGroup.d.ts +30 -2
  129. package/dist/components/form/DescribedCheckboxGroup.d.ts.map +1 -1
  130. package/dist/components/form/DescribedCheckboxGroup.js +75 -21
  131. package/dist/components/form/DescribedCheckboxGroup.js.map +1 -1
  132. package/dist/components/form/DescribedRadioGroup.d.ts +31 -2
  133. package/dist/components/form/DescribedRadioGroup.d.ts.map +1 -1
  134. package/dist/components/form/DescribedRadioGroup.js +65 -16
  135. package/dist/components/form/DescribedRadioGroup.js.map +1 -1
  136. package/dist/components/form/dictionary.d.ts +19 -0
  137. package/dist/components/form/dictionary.d.ts.map +1 -0
  138. package/dist/components/form/dictionary.js +19 -0
  139. package/dist/components/form/dictionary.js.map +1 -0
  140. package/dist/components/form/styled.d.ts.map +1 -1
  141. package/dist/components/form/styled.js +1 -2
  142. package/dist/components/form/styled.js.map +1 -1
  143. package/dist/components/form/types.d.ts +42 -0
  144. package/dist/components/form/types.d.ts.map +1 -1
  145. package/dist/context/AIWidgetProvider.d.ts +19 -0
  146. package/dist/context/AIWidgetProvider.d.ts.map +1 -1
  147. package/dist/context/AIWidgetProvider.js +19 -0
  148. package/dist/context/AIWidgetProvider.js.map +1 -1
  149. package/dist/context/hooks.d.ts +61 -4
  150. package/dist/context/hooks.d.ts.map +1 -1
  151. package/dist/context/hooks.js +83 -13
  152. package/dist/context/hooks.js.map +1 -1
  153. package/dist/features.d.ts +72 -10
  154. package/dist/features.d.ts.map +1 -1
  155. package/dist/features.js +23 -8
  156. package/dist/features.js.map +1 -1
  157. package/dist/hooks/midnight-update-view.d.ts +5 -0
  158. package/dist/hooks/midnight-update-view.d.ts.map +1 -0
  159. package/dist/hooks/midnight-update-view.js +30 -0
  160. package/dist/hooks/midnight-update-view.js.map +1 -0
  161. package/dist/index.d.ts +12 -0
  162. package/dist/index.d.ts.map +1 -1
  163. package/dist/index.js +7 -0
  164. package/dist/index.js.map +1 -1
  165. package/dist/layout.css +95 -28
  166. package/dist/regex.d.ts +3 -0
  167. package/dist/regex.d.ts.map +1 -0
  168. package/dist/regex.js +3 -0
  169. package/dist/regex.js.map +1 -0
  170. package/dist/right-panel/DefaultPanel.d.ts +3 -0
  171. package/dist/right-panel/DefaultPanel.d.ts.map +1 -1
  172. package/dist/right-panel/DefaultPanel.js +5 -4
  173. package/dist/right-panel/DefaultPanel.js.map +1 -1
  174. package/dist/right-panel/RightPanel.d.ts +3 -0
  175. package/dist/right-panel/RightPanel.d.ts.map +1 -1
  176. package/dist/right-panel/RightPanel.js +3 -0
  177. package/dist/right-panel/RightPanel.js.map +1 -1
  178. package/dist/right-panel/RightPanelProvider.d.ts +15 -0
  179. package/dist/right-panel/RightPanelProvider.d.ts.map +1 -1
  180. package/dist/right-panel/RightPanelProvider.js.map +1 -1
  181. package/dist/right-panel/constants.d.ts +2 -0
  182. package/dist/right-panel/constants.d.ts.map +1 -0
  183. package/dist/right-panel/constants.js +2 -0
  184. package/dist/right-panel/constants.js.map +1 -0
  185. package/dist/right-panel/hooks.d.ts +6 -0
  186. package/dist/right-panel/hooks.d.ts.map +1 -1
  187. package/dist/right-panel/hooks.js +8 -1
  188. package/dist/right-panel/hooks.js.map +1 -1
  189. package/dist/state/ChatEntry.d.ts +182 -8
  190. package/dist/state/ChatEntry.d.ts.map +1 -1
  191. package/dist/state/ChatEntry.js +26 -3
  192. package/dist/state/ChatEntry.js.map +1 -1
  193. package/dist/state/ChatState.d.ts +116 -14
  194. package/dist/state/ChatState.d.ts.map +1 -1
  195. package/dist/state/ChatState.js +49 -8
  196. package/dist/state/ChatState.js.map +1 -1
  197. package/dist/state/ChatTabsController.d.ts +50 -1
  198. package/dist/state/ChatTabsController.d.ts.map +1 -1
  199. package/dist/state/ChatTabsController.js +77 -8
  200. package/dist/state/ChatTabsController.js.map +1 -1
  201. package/dist/state/ObservableState.d.ts +14 -0
  202. package/dist/state/ObservableState.d.ts.map +1 -1
  203. package/dist/state/ObservableState.js +14 -0
  204. package/dist/state/ObservableState.js.map +1 -1
  205. package/dist/state/WidgetState.d.ts +62 -2
  206. package/dist/state/WidgetState.d.ts.map +1 -1
  207. package/dist/state/WidgetState.js +49 -2
  208. package/dist/state/WidgetState.js.map +1 -1
  209. package/dist/state/constants.d.ts +5 -0
  210. package/dist/state/constants.d.ts.map +1 -0
  211. package/dist/state/constants.js +10 -0
  212. package/dist/state/constants.js.map +1 -0
  213. package/dist/state/types.d.ts +10 -1
  214. package/dist/state/types.d.ts.map +1 -1
  215. package/dist/types.d.ts +20 -4
  216. package/dist/types.d.ts.map +1 -1
  217. package/dist/utils/chat.d.ts +11 -4
  218. package/dist/utils/chat.d.ts.map +1 -1
  219. package/dist/utils/chat.js +13 -11
  220. package/dist/utils/chat.js.map +1 -1
  221. package/dist/utils/check-is-trial.d.ts +2 -0
  222. package/dist/utils/check-is-trial.d.ts.map +1 -0
  223. package/dist/utils/check-is-trial.js +6 -0
  224. package/dist/utils/check-is-trial.js.map +1 -0
  225. package/dist/utils/copy-to-clipboard.d.ts +6 -0
  226. package/dist/utils/copy-to-clipboard.d.ts.map +1 -0
  227. package/dist/utils/copy-to-clipboard.js +30 -0
  228. package/dist/utils/copy-to-clipboard.js.map +1 -0
  229. package/dist/utils/date.d.ts +26 -2
  230. package/dist/utils/date.d.ts.map +1 -1
  231. package/dist/utils/date.js +28 -3
  232. package/dist/utils/date.js.map +1 -1
  233. package/dist/utils/download.d.ts +5 -0
  234. package/dist/utils/download.d.ts.map +1 -1
  235. package/dist/utils/download.js +5 -0
  236. package/dist/utils/download.js.map +1 -1
  237. package/dist/utils/error.d.ts +2 -0
  238. package/dist/utils/error.d.ts.map +1 -0
  239. package/dist/utils/error.js +54 -0
  240. package/dist/utils/error.js.map +1 -0
  241. package/dist/utils/knowledge-source.d.ts +12 -2
  242. package/dist/utils/knowledge-source.d.ts.map +1 -1
  243. package/dist/utils/knowledge-source.js +16 -0
  244. package/dist/utils/knowledge-source.js.map +1 -1
  245. package/dist/utils/planning-tool.d.ts +17 -0
  246. package/dist/utils/planning-tool.d.ts.map +1 -0
  247. package/dist/utils/planning-tool.js +32 -0
  248. package/dist/utils/planning-tool.js.map +1 -0
  249. package/dist/utils/programming-languages.d.ts.map +1 -1
  250. package/dist/utils/programming-languages.js +10 -0
  251. package/dist/utils/programming-languages.js.map +1 -1
  252. package/dist/utils/string.d.ts +5 -0
  253. package/dist/utils/string.d.ts.map +1 -1
  254. package/dist/utils/string.js +5 -1
  255. package/dist/utils/string.js.map +1 -1
  256. package/dist/utils/tools.d.ts +23 -0
  257. package/dist/utils/tools.d.ts.map +1 -0
  258. package/dist/utils/tools.js +23 -0
  259. package/dist/utils/tools.js.map +1 -0
  260. package/dist/utils/update-tool-step.d.ts +3 -0
  261. package/dist/utils/update-tool-step.d.ts.map +1 -0
  262. package/dist/utils/update-tool-step.js +23 -0
  263. package/dist/utils/update-tool-step.js.map +1 -0
  264. package/dist/utils/upload/FileUpload.d.ts +21 -0
  265. package/dist/utils/upload/FileUpload.d.ts.map +1 -0
  266. package/dist/utils/upload/FileUpload.js +54 -0
  267. package/dist/utils/upload/FileUpload.js.map +1 -0
  268. package/dist/utils/upload/UploadManager.d.ts +42 -0
  269. package/dist/utils/upload/UploadManager.d.ts.map +1 -0
  270. package/dist/utils/upload/UploadManager.js +138 -0
  271. package/dist/utils/upload/UploadManager.js.map +1 -0
  272. package/dist/utils/upload/context.d.ts +15 -0
  273. package/dist/utils/upload/context.d.ts.map +1 -0
  274. package/dist/utils/upload/context.js +37 -0
  275. package/dist/utils/upload/context.js.map +1 -0
  276. package/dist/utils/upload/errors.d.ts +17 -0
  277. package/dist/utils/upload/errors.d.ts.map +1 -0
  278. package/dist/utils/upload/errors.js +27 -0
  279. package/dist/utils/upload/errors.js.map +1 -0
  280. package/dist/utils/upload/types.d.ts +7 -0
  281. package/dist/utils/upload/types.d.ts.map +1 -0
  282. package/dist/{components/Tooltip → utils/upload}/types.js.map +1 -1
  283. package/dist/utils/upload/use-paste-upload.d.ts +8 -0
  284. package/dist/utils/upload/use-paste-upload.d.ts.map +1 -0
  285. package/dist/utils/upload/use-paste-upload.js +19 -0
  286. package/dist/utils/upload/use-paste-upload.js.map +1 -0
  287. package/dist/utils/upload/utils.d.ts +4 -0
  288. package/dist/utils/upload/utils.d.ts.map +1 -0
  289. package/dist/utils/upload/utils.js +10 -0
  290. package/dist/utils/upload/utils.js.map +1 -0
  291. package/dist/utils/url.d.ts +2 -0
  292. package/dist/utils/url.d.ts.map +1 -0
  293. package/dist/utils/url.js +8 -0
  294. package/dist/utils/url.js.map +1 -0
  295. package/dist/views/Agents/AgentDescription.d.ts +4 -0
  296. package/dist/views/Agents/AgentDescription.d.ts.map +1 -0
  297. package/dist/views/Agents/AgentDescription.js +38 -0
  298. package/dist/views/Agents/AgentDescription.js.map +1 -0
  299. package/dist/views/Agents/AgentsPanel.d.ts +5 -0
  300. package/dist/views/Agents/AgentsPanel.d.ts.map +1 -0
  301. package/dist/views/Agents/AgentsPanel.js +45 -0
  302. package/dist/views/Agents/AgentsPanel.js.map +1 -0
  303. package/dist/views/Agents/AgentsTab.d.ts +11 -0
  304. package/dist/views/Agents/AgentsTab.d.ts.map +1 -0
  305. package/dist/views/Agents/AgentsTab.js +82 -0
  306. package/dist/views/Agents/AgentsTab.js.map +1 -0
  307. package/dist/views/Agents/dictionary.d.ts +2 -0
  308. package/dist/views/Agents/dictionary.d.ts.map +1 -0
  309. package/dist/views/Agents/dictionary.js +43 -0
  310. package/dist/views/Agents/dictionary.js.map +1 -0
  311. package/dist/views/Agents/index.d.ts +5 -0
  312. package/dist/views/Agents/index.d.ts.map +1 -0
  313. package/dist/views/Agents/index.js +21 -0
  314. package/dist/views/Agents/index.js.map +1 -0
  315. package/dist/views/Agents/styled.d.ts +3 -0
  316. package/dist/views/Agents/styled.d.ts.map +1 -0
  317. package/dist/views/Agents/styled.js +68 -0
  318. package/dist/views/Agents/styled.js.map +1 -0
  319. package/dist/views/Agents/useAgentFavorites.d.ts +8 -0
  320. package/dist/views/Agents/useAgentFavorites.d.ts.map +1 -0
  321. package/dist/views/Agents/useAgentFavorites.js +59 -0
  322. package/dist/views/Agents/useAgentFavorites.js.map +1 -0
  323. package/dist/views/Chat/AgentInfo.d.ts +5 -1
  324. package/dist/views/Chat/AgentInfo.d.ts.map +1 -1
  325. package/dist/views/Chat/AgentInfo.js +6 -5
  326. package/dist/views/Chat/AgentInfo.js.map +1 -1
  327. package/dist/views/Chat/ButtonExecutionDetail.d.ts +5 -0
  328. package/dist/views/Chat/ButtonExecutionDetail.d.ts.map +1 -0
  329. package/dist/views/Chat/ButtonExecutionDetail.js +34 -0
  330. package/dist/views/Chat/ButtonExecutionDetail.js.map +1 -0
  331. package/dist/views/Chat/ChatMessage.d.ts +56 -4
  332. package/dist/views/Chat/ChatMessage.d.ts.map +1 -1
  333. package/dist/views/Chat/ChatMessage.js +160 -24
  334. package/dist/views/Chat/ChatMessage.js.map +1 -1
  335. package/dist/views/Chat/ChatMessages.d.ts +6 -2
  336. package/dist/views/Chat/ChatMessages.d.ts.map +1 -1
  337. package/dist/views/Chat/ChatMessages.js +5 -2
  338. package/dist/views/Chat/ChatMessages.js.map +1 -1
  339. package/dist/views/Chat/StepsList.d.ts +14 -0
  340. package/dist/views/Chat/StepsList.d.ts.map +1 -0
  341. package/dist/views/Chat/StepsList.js +192 -0
  342. package/dist/views/Chat/StepsList.js.map +1 -0
  343. package/dist/views/Chat/chat-scroll.d.ts +1 -1
  344. package/dist/views/Chat/chat-scroll.js +1 -1
  345. package/dist/views/Chat/events.d.ts +22 -0
  346. package/dist/views/Chat/events.d.ts.map +1 -0
  347. package/dist/views/Chat/events.js +67 -0
  348. package/dist/views/Chat/events.js.map +1 -0
  349. package/dist/views/Chat/index.d.ts +9 -2
  350. package/dist/views/Chat/index.d.ts.map +1 -1
  351. package/dist/views/Chat/index.js +5 -2
  352. package/dist/views/Chat/index.js.map +1 -1
  353. package/dist/views/Chat/styled.d.ts +3 -1
  354. package/dist/views/Chat/styled.d.ts.map +1 -1
  355. package/dist/views/Chat/styled.js +152 -31
  356. package/dist/views/Chat/styled.js.map +1 -1
  357. package/dist/views/ChatHistory/ChatHistoryPanel.d.ts +4 -4
  358. package/dist/views/ChatHistory/ChatHistoryPanel.d.ts.map +1 -1
  359. package/dist/views/ChatHistory/ChatHistoryPanel.js +6 -2
  360. package/dist/views/ChatHistory/ChatHistoryPanel.js.map +1 -1
  361. package/dist/views/ChatHistory/HistoryItem.d.ts +4 -3
  362. package/dist/views/ChatHistory/HistoryItem.d.ts.map +1 -1
  363. package/dist/views/ChatHistory/HistoryItem.js +16 -37
  364. package/dist/views/ChatHistory/HistoryItem.js.map +1 -1
  365. package/dist/views/ChatHistory/dictionary.d.ts +1 -1
  366. package/dist/views/ChatHistory/index.d.ts +4 -4
  367. package/dist/views/ChatHistory/index.d.ts.map +1 -1
  368. package/dist/views/ChatHistory/index.js +6 -3
  369. package/dist/views/ChatHistory/index.js.map +1 -1
  370. package/dist/views/ChatHistory/styled.d.ts.map +1 -1
  371. package/dist/views/ChatHistory/styled.js +3 -5
  372. package/dist/views/ChatHistory/styled.js.map +1 -1
  373. package/dist/views/ChatHistory/utils.d.ts +17 -2
  374. package/dist/views/ChatHistory/utils.d.ts.map +1 -1
  375. package/dist/views/ChatHistory/utils.js +140 -9
  376. package/dist/views/ChatHistory/utils.js.map +1 -1
  377. package/dist/views/ChatTabSelection.d.ts +6 -4
  378. package/dist/views/ChatTabSelection.d.ts.map +1 -1
  379. package/dist/views/ChatTabSelection.js +40 -15
  380. package/dist/views/ChatTabSelection.js.map +1 -1
  381. package/dist/views/Editor.d.ts +3 -0
  382. package/dist/views/Editor.d.ts.map +1 -1
  383. package/dist/views/Editor.js +23 -16
  384. package/dist/views/Editor.js.map +1 -1
  385. package/dist/views/Home/BuiltInAgent.d.ts +6 -0
  386. package/dist/views/Home/BuiltInAgent.d.ts.map +1 -0
  387. package/dist/views/Home/BuiltInAgent.js +37 -0
  388. package/dist/views/Home/BuiltInAgent.js.map +1 -0
  389. package/dist/views/Home/CustomAgent.d.ts +5 -0
  390. package/dist/views/Home/CustomAgent.d.ts.map +1 -0
  391. package/dist/views/Home/CustomAgent.js +23 -0
  392. package/dist/views/Home/CustomAgent.js.map +1 -0
  393. package/dist/views/Home/index.d.ts +8 -0
  394. package/dist/views/Home/index.d.ts.map +1 -0
  395. package/dist/views/Home/index.js +34 -0
  396. package/dist/views/Home/index.js.map +1 -0
  397. package/dist/views/Home/styled.d.ts +2 -0
  398. package/dist/views/Home/styled.d.ts.map +1 -0
  399. package/dist/views/Home/styled.js +74 -0
  400. package/dist/views/Home/styled.js.map +1 -0
  401. package/dist/views/Home/types.d.ts +16 -0
  402. package/dist/views/Home/types.d.ts.map +1 -0
  403. package/dist/views/Home/types.js +2 -0
  404. package/dist/views/Home/types.js.map +1 -0
  405. package/dist/views/KSDocument.d.ts +3 -0
  406. package/dist/views/KSDocument.d.ts.map +1 -1
  407. package/dist/views/KSDocument.js +7 -4
  408. package/dist/views/KSDocument.js.map +1 -1
  409. package/dist/views/KnowledgeSources.d.ts +12 -0
  410. package/dist/views/KnowledgeSources.d.ts.map +1 -1
  411. package/dist/views/KnowledgeSources.js +123 -33
  412. package/dist/views/KnowledgeSources.js.map +1 -1
  413. package/dist/views/MessageInput/AgentSelector.d.ts +5 -0
  414. package/dist/views/MessageInput/AgentSelector.d.ts.map +1 -0
  415. package/dist/views/MessageInput/AgentSelector.js +66 -0
  416. package/dist/views/MessageInput/AgentSelector.js.map +1 -0
  417. package/dist/views/MessageInput/ButtonAgent.d.ts +2 -0
  418. package/dist/views/MessageInput/ButtonAgent.d.ts.map +1 -0
  419. package/dist/views/MessageInput/ButtonAgent.js +35 -0
  420. package/dist/views/MessageInput/ButtonAgent.js.map +1 -0
  421. package/dist/views/MessageInput/ButtonBar.d.ts +13 -0
  422. package/dist/views/MessageInput/ButtonBar.d.ts.map +1 -0
  423. package/dist/views/MessageInput/ButtonBar.js +15 -0
  424. package/dist/views/MessageInput/ButtonBar.js.map +1 -0
  425. package/dist/views/MessageInput/ContextBar.d.ts +9 -0
  426. package/dist/views/MessageInput/ContextBar.d.ts.map +1 -0
  427. package/dist/views/MessageInput/ContextBar.js +51 -0
  428. package/dist/views/MessageInput/ContextBar.js.map +1 -0
  429. package/dist/views/MessageInput/ModelSwitcher/index.d.ts +2 -0
  430. package/dist/views/MessageInput/ModelSwitcher/index.d.ts.map +1 -0
  431. package/dist/views/MessageInput/ModelSwitcher/index.js +25 -0
  432. package/dist/views/MessageInput/ModelSwitcher/index.js.map +1 -0
  433. package/dist/views/MessageInput/ModelSwitcher/utils.d.ts +30 -0
  434. package/dist/views/MessageInput/ModelSwitcher/utils.d.ts.map +1 -0
  435. package/dist/views/MessageInput/ModelSwitcher/utils.js +91 -0
  436. package/dist/views/MessageInput/ModelSwitcher/utils.js.map +1 -0
  437. package/dist/views/MessageInput/QuickCommandSelector.d.ts +5 -0
  438. package/dist/views/MessageInput/QuickCommandSelector.d.ts.map +1 -0
  439. package/dist/views/MessageInput/QuickCommandSelector.js +104 -0
  440. package/dist/views/MessageInput/QuickCommandSelector.js.map +1 -0
  441. package/dist/views/MessageInput/SelectContent.d.ts +2 -0
  442. package/dist/views/MessageInput/SelectContent.d.ts.map +1 -0
  443. package/dist/views/MessageInput/SelectContent.js +84 -0
  444. package/dist/views/MessageInput/SelectContent.js.map +1 -0
  445. package/dist/views/MessageInput/UploadBar.d.ts +2 -0
  446. package/dist/views/MessageInput/UploadBar.d.ts.map +1 -0
  447. package/dist/views/MessageInput/UploadBar.js +74 -0
  448. package/dist/views/MessageInput/UploadBar.js.map +1 -0
  449. package/dist/views/MessageInput/UploadDragNDrop.d.ts +14 -0
  450. package/dist/views/MessageInput/UploadDragNDrop.d.ts.map +1 -0
  451. package/dist/views/MessageInput/UploadDragNDrop.js +51 -0
  452. package/dist/views/MessageInput/UploadDragNDrop.js.map +1 -0
  453. package/dist/views/MessageInput/chat-entry-history.d.ts +11 -0
  454. package/dist/views/MessageInput/chat-entry-history.d.ts.map +1 -0
  455. package/dist/views/MessageInput/chat-entry-history.js +78 -0
  456. package/dist/views/MessageInput/chat-entry-history.js.map +1 -0
  457. package/dist/views/MessageInput/dictionary.d.ts +1 -1
  458. package/dist/views/MessageInput/dictionary.d.ts.map +1 -1
  459. package/dist/views/MessageInput/dictionary.js +52 -10
  460. package/dist/views/MessageInput/dictionary.js.map +1 -1
  461. package/dist/views/MessageInput/index.d.ts +9 -6
  462. package/dist/views/MessageInput/index.d.ts.map +1 -1
  463. package/dist/views/MessageInput/index.js +112 -20
  464. package/dist/views/MessageInput/index.js.map +1 -1
  465. package/dist/views/MessageInput/styled.d.ts +13 -1
  466. package/dist/views/MessageInput/styled.d.ts.map +1 -1
  467. package/dist/views/MessageInput/styled.js +223 -85
  468. package/dist/views/MessageInput/styled.js.map +1 -1
  469. package/dist/views/MinimizedHeader.d.ts +4 -0
  470. package/dist/views/MinimizedHeader.d.ts.map +1 -1
  471. package/dist/views/MinimizedHeader.js +9 -7
  472. package/dist/views/MinimizedHeader.js.map +1 -1
  473. package/dist/views/Resources.d.ts +2 -0
  474. package/dist/views/Resources.d.ts.map +1 -0
  475. package/dist/views/Resources.js +69 -0
  476. package/dist/views/Resources.js.map +1 -0
  477. package/dist/views/Stacks.d.ts +12 -0
  478. package/dist/views/Stacks.d.ts.map +1 -1
  479. package/dist/views/Stacks.js +117 -21
  480. package/dist/views/Stacks.js.map +1 -1
  481. package/dist/views/Steps/FlowChart/HandleGroup.d.ts +10 -0
  482. package/dist/views/Steps/FlowChart/HandleGroup.d.ts.map +1 -0
  483. package/dist/views/Steps/FlowChart/HandleGroup.js +4 -0
  484. package/dist/views/Steps/FlowChart/HandleGroup.js.map +1 -0
  485. package/dist/views/Steps/FlowChart/NodeDynamic.d.ts +15 -0
  486. package/dist/views/Steps/FlowChart/NodeDynamic.d.ts.map +1 -0
  487. package/dist/views/Steps/FlowChart/NodeDynamic.js +41 -0
  488. package/dist/views/Steps/FlowChart/NodeDynamic.js.map +1 -0
  489. package/dist/views/Steps/FlowChart/NodeStep.d.ts +10 -0
  490. package/dist/views/Steps/FlowChart/NodeStep.d.ts.map +1 -0
  491. package/dist/views/Steps/FlowChart/NodeStep.js +13 -0
  492. package/dist/views/Steps/FlowChart/NodeStep.js.map +1 -0
  493. package/dist/views/Steps/FlowChart/hooks.d.ts +7 -0
  494. package/dist/views/Steps/FlowChart/hooks.d.ts.map +1 -0
  495. package/dist/views/Steps/FlowChart/hooks.js +31 -0
  496. package/dist/views/Steps/FlowChart/hooks.js.map +1 -0
  497. package/dist/views/Steps/FlowChart/index.d.ts +12 -0
  498. package/dist/views/Steps/FlowChart/index.d.ts.map +1 -0
  499. package/dist/views/Steps/FlowChart/index.js +78 -0
  500. package/dist/views/Steps/FlowChart/index.js.map +1 -0
  501. package/dist/views/Steps/FlowChart/layout.d.ts +8 -0
  502. package/dist/views/Steps/FlowChart/layout.d.ts.map +1 -0
  503. package/dist/views/Steps/FlowChart/layout.js +59 -0
  504. package/dist/views/Steps/FlowChart/layout.js.map +1 -0
  505. package/dist/views/Steps/FlowChart/styled.d.ts +14 -0
  506. package/dist/views/Steps/FlowChart/styled.d.ts.map +1 -0
  507. package/dist/views/Steps/FlowChart/styled.js +156 -0
  508. package/dist/views/Steps/FlowChart/styled.js.map +1 -0
  509. package/dist/views/Steps/FlowChart/types.d.ts +25 -0
  510. package/dist/views/Steps/FlowChart/types.d.ts.map +1 -0
  511. package/dist/views/Steps/FlowChart/types.js +2 -0
  512. package/dist/views/Steps/FlowChart/types.js.map +1 -0
  513. package/dist/views/Steps/StepModal.d.ts +10 -0
  514. package/dist/views/Steps/StepModal.d.ts.map +1 -0
  515. package/dist/views/Steps/StepModal.js +139 -0
  516. package/dist/views/Steps/StepModal.js.map +1 -0
  517. package/dist/views/Steps/StepsPanel.d.ts +6 -0
  518. package/dist/views/Steps/StepsPanel.d.ts.map +1 -0
  519. package/dist/views/Steps/StepsPanel.js +18 -0
  520. package/dist/views/Steps/StepsPanel.js.map +1 -0
  521. package/dist/views/Steps/dictionary.d.ts +43 -0
  522. package/dist/views/Steps/dictionary.d.ts.map +1 -0
  523. package/dist/views/Steps/dictionary.js +45 -0
  524. package/dist/views/Steps/dictionary.js.map +1 -0
  525. package/dist/views/Steps/index.d.ts +5 -0
  526. package/dist/views/Steps/index.d.ts.map +1 -0
  527. package/dist/views/Steps/index.js +30 -0
  528. package/dist/views/Steps/index.js.map +1 -0
  529. package/dist/views/Steps/utils.d.ts +7 -0
  530. package/dist/views/Steps/utils.d.ts.map +1 -0
  531. package/dist/views/Steps/utils.js +32 -0
  532. package/dist/views/Steps/utils.js.map +1 -0
  533. package/dist/views/Tools.d.ts +2 -0
  534. package/dist/views/Tools.d.ts.map +1 -0
  535. package/dist/views/Tools.js +53 -0
  536. package/dist/views/Tools.js.map +1 -0
  537. package/dist/views/Workspaces/WorkspacesTab.d.ts +20 -0
  538. package/dist/views/Workspaces/WorkspacesTab.d.ts.map +1 -0
  539. package/dist/views/Workspaces/WorkspacesTab.js +61 -0
  540. package/dist/views/Workspaces/WorkspacesTab.js.map +1 -0
  541. package/dist/views/Workspaces/index.d.ts +5 -0
  542. package/dist/views/Workspaces/index.d.ts.map +1 -0
  543. package/dist/views/Workspaces/index.js +69 -0
  544. package/dist/views/Workspaces/index.js.map +1 -0
  545. package/package.dev.json +3 -0
  546. package/package.json +21 -13
  547. package/package.stg.json +4 -0
  548. package/src/StackspotAIWidget.tsx +96 -37
  549. package/src/app-metadata.json +175 -0
  550. package/src/assets/placeholder.png +0 -0
  551. package/src/chat-interceptors/CustomInputs.ts +14 -1
  552. package/src/chat-interceptors/quick-command-questions.ts +12 -2
  553. package/src/chat-interceptors/quick-commands.ts +286 -52
  554. package/src/chat-interceptors/send-message.ts +253 -25
  555. package/src/components/AdaptiveTextArea.tsx +36 -11
  556. package/src/components/AgentCard/AgentCardCreate.tsx +42 -0
  557. package/src/components/AgentCard/dictionary.ts +25 -0
  558. package/src/components/AgentCard/index.tsx +82 -0
  559. package/src/components/AnimatedOpacity.tsx +55 -0
  560. package/src/components/AutoFocus.tsx +42 -0
  561. package/src/components/ButtonFavorite.tsx +78 -0
  562. package/src/components/Code.tsx +94 -59
  563. package/src/components/ComponentNavigator.tsx +99 -0
  564. package/src/components/Fading.tsx +66 -0
  565. package/src/components/FadingOverflow.tsx +39 -12
  566. package/src/components/FileDescription.tsx +118 -0
  567. package/src/components/HistoryList.tsx +19 -2
  568. package/src/components/ListResource.tsx +60 -0
  569. package/src/components/Markdown.tsx +2 -1
  570. package/src/components/Modal.tsx +85 -0
  571. package/src/components/QuickStartButton.tsx +15 -47
  572. package/src/components/RightPanelContentList.tsx +15 -0
  573. package/src/components/RightPanelForm.tsx +64 -22
  574. package/src/components/RightPanelTabs.tsx +7 -32
  575. package/src/components/Selector/index.tsx +312 -0
  576. package/src/components/Selector/styled.ts +158 -0
  577. package/src/components/StackedBadge.tsx +77 -0
  578. package/src/components/TabManager.tsx +36 -36
  579. package/src/components/ToolBadge.tsx +67 -0
  580. package/src/components/WorkspaceTabNavigator.tsx +172 -0
  581. package/src/components/form/DescribedCheckboxGroup.tsx +135 -33
  582. package/src/components/form/DescribedRadioGroup.tsx +136 -32
  583. package/src/components/form/dictionary.ts +18 -0
  584. package/src/components/form/styled.ts +1 -2
  585. package/src/components/form/types.ts +45 -1
  586. package/src/context/AIWidgetProvider.tsx +19 -0
  587. package/src/context/hooks.ts +86 -16
  588. package/src/features.ts +90 -16
  589. package/src/hooks/midnight-update-view.ts +36 -0
  590. package/src/images.d.ts +5 -0
  591. package/src/index.ts +16 -0
  592. package/src/layout.css +95 -28
  593. package/src/regex.ts +2 -0
  594. package/src/right-panel/DefaultPanel.tsx +7 -7
  595. package/src/right-panel/RightPanel.tsx +3 -0
  596. package/src/right-panel/RightPanelProvider.tsx +15 -0
  597. package/src/right-panel/constants.ts +1 -0
  598. package/src/right-panel/hooks.tsx +8 -1
  599. package/src/state/ChatEntry.ts +189 -9
  600. package/src/state/ChatState.ts +131 -14
  601. package/src/state/ChatTabsController.ts +78 -8
  602. package/src/state/ObservableState.ts +14 -0
  603. package/src/state/WidgetState.ts +86 -3
  604. package/src/state/constants.ts +13 -0
  605. package/src/state/types.ts +12 -1
  606. package/src/types.ts +21 -4
  607. package/src/utils/chat.ts +15 -14
  608. package/src/utils/check-is-trial.ts +6 -0
  609. package/src/utils/copy-to-clipboard.ts +29 -0
  610. package/src/utils/date.ts +28 -4
  611. package/src/utils/download.ts +5 -0
  612. package/src/utils/error.ts +56 -0
  613. package/src/utils/knowledge-source.ts +18 -2
  614. package/src/utils/planning-tool.ts +41 -0
  615. package/src/utils/programming-languages.ts +10 -0
  616. package/src/utils/string.ts +5 -1
  617. package/src/utils/tools.ts +32 -0
  618. package/src/utils/update-tool-step.tsx +27 -0
  619. package/src/utils/upload/FileUpload.ts +63 -0
  620. package/src/utils/upload/UploadManager.ts +156 -0
  621. package/src/utils/upload/context.tsx +44 -0
  622. package/src/utils/upload/errors.ts +34 -0
  623. package/src/utils/upload/types.ts +7 -0
  624. package/src/utils/upload/use-paste-upload.tsx +30 -0
  625. package/src/utils/upload/utils.ts +12 -0
  626. package/src/utils/url.ts +8 -0
  627. package/src/views/Agents/AgentDescription.tsx +107 -0
  628. package/src/views/Agents/AgentsPanel.tsx +57 -0
  629. package/src/views/Agents/AgentsTab.tsx +126 -0
  630. package/src/views/Agents/dictionary.ts +45 -0
  631. package/src/views/Agents/index.tsx +26 -0
  632. package/src/views/Agents/styled.ts +69 -0
  633. package/src/views/Agents/useAgentFavorites.ts +63 -0
  634. package/src/views/Chat/AgentInfo.tsx +13 -8
  635. package/src/views/Chat/ButtonExecutionDetail.tsx +46 -0
  636. package/src/views/Chat/ChatMessage.tsx +465 -79
  637. package/src/views/Chat/ChatMessages.tsx +15 -4
  638. package/src/views/Chat/StepsList.tsx +394 -0
  639. package/src/views/Chat/chat-scroll.ts +1 -1
  640. package/src/views/Chat/events.ts +71 -0
  641. package/src/views/Chat/index.tsx +17 -3
  642. package/src/views/Chat/styled.ts +158 -32
  643. package/src/views/ChatHistory/ChatHistoryPanel.tsx +8 -5
  644. package/src/views/ChatHistory/HistoryItem.tsx +23 -44
  645. package/src/views/ChatHistory/index.tsx +6 -4
  646. package/src/views/ChatHistory/styled.ts +3 -5
  647. package/src/views/ChatHistory/utils.ts +144 -11
  648. package/src/views/ChatTabSelection.tsx +47 -20
  649. package/src/views/Editor.tsx +28 -18
  650. package/src/views/Home/BuiltInAgent.tsx +67 -0
  651. package/src/views/Home/CustomAgent.tsx +36 -0
  652. package/src/views/Home/index.tsx +48 -0
  653. package/src/views/Home/styled.ts +74 -0
  654. package/src/views/Home/types.ts +16 -0
  655. package/src/views/KSDocument.tsx +11 -8
  656. package/src/views/KnowledgeSources.tsx +169 -62
  657. package/src/views/MessageInput/AgentSelector.tsx +92 -0
  658. package/src/views/MessageInput/ButtonAgent.tsx +73 -0
  659. package/src/views/MessageInput/ButtonBar.tsx +57 -0
  660. package/src/views/MessageInput/ContextBar.tsx +117 -0
  661. package/src/views/MessageInput/ModelSwitcher/index.tsx +69 -0
  662. package/src/views/MessageInput/ModelSwitcher/utils.tsx +143 -0
  663. package/src/views/MessageInput/QuickCommandSelector.tsx +137 -0
  664. package/src/views/MessageInput/SelectContent.tsx +99 -0
  665. package/src/views/MessageInput/UploadBar.tsx +107 -0
  666. package/src/views/MessageInput/UploadDragNDrop.tsx +79 -0
  667. package/src/views/MessageInput/chat-entry-history.ts +97 -0
  668. package/src/views/MessageInput/dictionary.ts +52 -10
  669. package/src/views/MessageInput/index.tsx +154 -51
  670. package/src/views/MessageInput/styled.ts +226 -85
  671. package/src/views/MinimizedHeader.tsx +11 -10
  672. package/src/views/Resources.tsx +108 -0
  673. package/src/views/Stacks.tsx +152 -39
  674. package/src/views/Steps/FlowChart/HandleGroup.tsx +14 -0
  675. package/src/views/Steps/FlowChart/NodeDynamic.tsx +97 -0
  676. package/src/views/Steps/FlowChart/NodeStep.tsx +49 -0
  677. package/src/views/Steps/FlowChart/hooks.ts +41 -0
  678. package/src/views/Steps/FlowChart/index.tsx +111 -0
  679. package/src/views/Steps/FlowChart/layout.ts +73 -0
  680. package/src/views/Steps/FlowChart/styled.ts +157 -0
  681. package/src/views/Steps/FlowChart/types.ts +28 -0
  682. package/src/views/Steps/StepModal.tsx +233 -0
  683. package/src/views/Steps/StepsPanel.tsx +31 -0
  684. package/src/views/Steps/dictionary.ts +48 -0
  685. package/src/views/Steps/index.tsx +36 -0
  686. package/src/views/Steps/utils.tsx +34 -0
  687. package/src/views/Tools.tsx +77 -0
  688. package/src/views/Workspaces/WorkspacesTab.tsx +116 -0
  689. package/src/views/Workspaces/index.tsx +78 -0
  690. package/tsconfig.json +8 -3
  691. package/dist/components/Accordion.d.ts +0 -10
  692. package/dist/components/Accordion.d.ts.map +0 -1
  693. package/dist/components/Accordion.js +0 -46
  694. package/dist/components/Accordion.js.map +0 -1
  695. package/dist/components/FallbackBoundary/ErrorBoundary.d.ts +0 -30
  696. package/dist/components/FallbackBoundary/ErrorBoundary.d.ts.map +0 -1
  697. package/dist/components/FallbackBoundary/ErrorBoundary.js +0 -38
  698. package/dist/components/FallbackBoundary/ErrorBoundary.js.map +0 -1
  699. package/dist/components/FallbackBoundary/Loading.d.ts +0 -2
  700. package/dist/components/FallbackBoundary/Loading.d.ts.map +0 -1
  701. package/dist/components/FallbackBoundary/Loading.js +0 -12
  702. package/dist/components/FallbackBoundary/Loading.js.map +0 -1
  703. package/dist/components/FallbackBoundary/index.d.ts +0 -6
  704. package/dist/components/FallbackBoundary/index.d.ts.map +0 -1
  705. package/dist/components/FallbackBoundary/index.js +0 -9
  706. package/dist/components/FallbackBoundary/index.js.map +0 -1
  707. package/dist/components/IconInput.d.ts +0 -7
  708. package/dist/components/IconInput.d.ts.map +0 -1
  709. package/dist/components/IconInput.js +0 -58
  710. package/dist/components/IconInput.js.map +0 -1
  711. package/dist/components/OverlayMenu.d.ts +0 -10
  712. package/dist/components/OverlayMenu.d.ts.map +0 -1
  713. package/dist/components/OverlayMenu.js +0 -58
  714. package/dist/components/OverlayMenu.js.map +0 -1
  715. package/dist/components/ProgressBar.d.ts +0 -11
  716. package/dist/components/ProgressBar.d.ts.map +0 -1
  717. package/dist/components/ProgressBar.js +0 -126
  718. package/dist/components/ProgressBar.js.map +0 -1
  719. package/dist/components/Tooltip/Tooltip.d.ts +0 -12
  720. package/dist/components/Tooltip/Tooltip.d.ts.map +0 -1
  721. package/dist/components/Tooltip/Tooltip.js +0 -17
  722. package/dist/components/Tooltip/Tooltip.js.map +0 -1
  723. package/dist/components/Tooltip/TooltipAPI.d.ts +0 -13
  724. package/dist/components/Tooltip/TooltipAPI.d.ts.map +0 -1
  725. package/dist/components/Tooltip/TooltipAPI.js +0 -90
  726. package/dist/components/Tooltip/TooltipAPI.js.map +0 -1
  727. package/dist/components/Tooltip/context.d.ts +0 -5
  728. package/dist/components/Tooltip/context.d.ts.map +0 -1
  729. package/dist/components/Tooltip/context.js +0 -18
  730. package/dist/components/Tooltip/context.js.map +0 -1
  731. package/dist/components/Tooltip/index.d.ts +0 -3
  732. package/dist/components/Tooltip/index.d.ts.map +0 -1
  733. package/dist/components/Tooltip/index.js +0 -3
  734. package/dist/components/Tooltip/index.js.map +0 -1
  735. package/dist/components/Tooltip/style.d.ts +0 -4
  736. package/dist/components/Tooltip/style.d.ts.map +0 -1
  737. package/dist/components/Tooltip/style.js +0 -22
  738. package/dist/components/Tooltip/style.js.map +0 -1
  739. package/dist/components/Tooltip/types.d.ts +0 -14
  740. package/dist/components/Tooltip/types.d.ts.map +0 -1
  741. package/dist/views/Agents.d.ts +0 -2
  742. package/dist/views/Agents.d.ts.map +0 -1
  743. package/dist/views/Agents.js +0 -143
  744. package/dist/views/Agents.js.map +0 -1
  745. package/dist/views/Home.d.ts +0 -6
  746. package/dist/views/Home.d.ts.map +0 -1
  747. package/dist/views/Home.js +0 -68
  748. package/dist/views/Home.js.map +0 -1
  749. package/dist/views/MessageInput/ButtonGroup.d.ts +0 -12
  750. package/dist/views/MessageInput/ButtonGroup.d.ts.map +0 -1
  751. package/dist/views/MessageInput/ButtonGroup.js +0 -24
  752. package/dist/views/MessageInput/ButtonGroup.js.map +0 -1
  753. package/dist/views/MessageInput/InfoBar.d.ts +0 -2
  754. package/dist/views/MessageInput/InfoBar.d.ts.map +0 -1
  755. package/dist/views/MessageInput/InfoBar.js +0 -35
  756. package/dist/views/MessageInput/InfoBar.js.map +0 -1
  757. package/dist/views/Workspaces.d.ts +0 -2
  758. package/dist/views/Workspaces.d.ts.map +0 -1
  759. package/dist/views/Workspaces.js +0 -62
  760. package/dist/views/Workspaces.js.map +0 -1
  761. package/src/components/Accordion.tsx +0 -64
  762. package/src/components/FallbackBoundary/ErrorBoundary.tsx +0 -48
  763. package/src/components/FallbackBoundary/Loading.tsx +0 -14
  764. package/src/components/FallbackBoundary/index.tsx +0 -15
  765. package/src/components/IconInput.tsx +0 -70
  766. package/src/components/OverlayMenu.tsx +0 -77
  767. package/src/components/ProgressBar.tsx +0 -153
  768. package/src/components/Tooltip/Tooltip.tsx +0 -36
  769. package/src/components/Tooltip/TooltipAPI.ts +0 -84
  770. package/src/components/Tooltip/context.tsx +0 -24
  771. package/src/components/Tooltip/index.ts +0 -2
  772. package/src/components/Tooltip/style.tsx +0 -24
  773. package/src/components/Tooltip/types.ts +0 -15
  774. package/src/views/Agents.tsx +0 -200
  775. package/src/views/Home.tsx +0 -109
  776. package/src/views/MessageInput/ButtonGroup.tsx +0 -91
  777. package/src/views/MessageInput/InfoBar.tsx +0 -82
  778. package/src/views/Workspaces.tsx +0 -92
  779. /package/dist/{components/Tooltip → utils/upload}/types.js +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AnimatedOpacity.js","sourceRoot":"","sources":["../../src/components/AnimatedOpacity.tsx"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAA;AACtD,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAC/D,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAQ1C,MAAM,MAAM,GAAG,MAAM,CAAC,GAAG,CAAyB;;wBAE1B,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,WAAW,GAAG,IAAI;;;;CAI9D,CAAA;AAED,MAAM,CAAC,MAAM,eAAe,GAAG,UAAU,CAAwB,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE;IAChH,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;IACjE,MAAM,SAAS,GAAG,MAAM,EAAsB,CAAA;IAC9C,MAAM,eAAe,GAAG,MAAM,EAAuB,CAAA;IAErD,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,aAAa,GAAG,eAAe,KAAK,SAAS,CAAA;QACnD,MAAM,oBAAoB,GAAG,OAAO,KAAK,eAAe,CAAC,OAAO,CAAA;QAChE,eAAe,CAAC,OAAO,GAAG,OAAO,CAAA;QACjC,IAAI,aAAa;YAAE,OAAM;QACzB,IAAI,oBAAoB,EAAE,CAAC;YACzB,IAAI,SAAS,CAAC,OAAO,EAAE,CAAC;gBACtB,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,OAAO,CAAC,CAAA;gBACtC,SAAS,CAAC,OAAO,GAAG,SAAS,CAAA;gBAC7B,OAAO,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;YAC9C,CAAC;YACD,IAAI,OAAO;gBAAE,UAAU,CAAC,QAAQ,CAAC,CAAA;YACjC,SAAS,CAAC,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;gBACzC,IAAI,CAAC,OAAO;oBAAE,UAAU,CAAC,IAAI,CAAC,CAAA;gBAC9B,SAAS,CAAC,OAAO,GAAG,SAAS,CAAA;YAC/B,CAAC,EAAE,UAAU,CAAC,CAAA;QAChB,CAAC;aAAM,IAAI,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;YACzC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;QACvC,CAAC;QAED,OAAO,GAAG,EAAE;YACV,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,OAAO,CAAC,CAAA;QACxC,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAA;IAEvB,OAAO,CACL,KAAC,MAAM,IAAC,GAAG,EAAE,GAAG,iBAAe,UAAU,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC,gBAAgB,EAAE,OAAO,IAAI,SAAS,CAAC,CAAC,YACxG,OAAO,GACD,CACV,CAAA;AACH,CAAC,CAAC,CAAA"}
@@ -0,0 +1,23 @@
1
+ import { TagPriorityElement } from '@stack-spot/portal-components';
2
+ interface Props extends React.HTMLAttributes<HTMLDivElement> {
3
+ /**
4
+ * A delay in ms to focus the first focusable element.
5
+ */
6
+ delay?: number;
7
+ /**
8
+ * Instead of focusing the first element overall, focus the first according to this list of priorities.
9
+ *
10
+ * 'other' means elements that are normally not focusable, but have positive tabIndex values.
11
+ */
12
+ priority?: TagPriorityElement[];
13
+ /**
14
+ * Ignores any element that matches this query selector.
15
+ */
16
+ ignore?: string;
17
+ }
18
+ /**
19
+ * Focus the first focusable child as soon as the component mounts.
20
+ */
21
+ export declare const AutoFocus: import("react").ForwardRefExoticComponent<Props & import("react").RefAttributes<HTMLDivElement>>;
22
+ export {};
23
+ //# sourceMappingURL=AutoFocus.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AutoFocus.d.ts","sourceRoot":"","sources":["../../src/components/AutoFocus.tsx"],"names":[],"mappings":"AACA,OAAO,EAAmB,kBAAkB,EAAE,MAAM,+BAA+B,CAAA;AAInF,UAAU,KAAM,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC1D;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IACf;;;;OAIG;IACH,QAAQ,CAAC,EAAE,kBAAkB,EAAE,CAAC;IAChC;;OAEG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AASD;;GAEG;AACH,eAAO,MAAM,SAAS,kGASpB,CAAA"}
@@ -0,0 +1,23 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ /* eslint-disable react/display-name */
3
+ import { focusFirstChild } from '@stack-spot/portal-components';
4
+ import { forwardRef, useEffect, useRef } from 'react';
5
+ import { styled } from 'styled-components';
6
+ const FlexibleDiv = styled.div `
7
+ overflow: hidden;
8
+ flex: 1;
9
+ display: flex;
10
+ flex-direction: column;
11
+ `;
12
+ /**
13
+ * Focus the first focusable child as soon as the component mounts.
14
+ */
15
+ export const AutoFocus = forwardRef(({ children, delay = 0, priority, ignore, ...props }, externalRef) => {
16
+ const localRef = useRef(null);
17
+ const ref = externalRef ?? localRef;
18
+ useEffect(() => {
19
+ setTimeout(() => focusFirstChild(ref.current, { priority, ignore }), delay);
20
+ }, []);
21
+ return _jsx(FlexibleDiv, { ref: ref, ...props, children: children });
22
+ });
23
+ //# sourceMappingURL=AutoFocus.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AutoFocus.js","sourceRoot":"","sources":["../../src/components/AutoFocus.tsx"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,OAAO,EAAE,eAAe,EAAsB,MAAM,+BAA+B,CAAA;AACnF,OAAO,EAAE,UAAU,EAAa,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AAChE,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAmB1C,MAAM,WAAW,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;CAK7B,CAAA;AAED;;GAEG;AACH,MAAM,CAAC,MAAM,SAAS,GAAG,UAAU,CAAwB,CAAC,EAAE,QAAQ,EAAE,KAAK,GAAG,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,KAAK,EAAE,EAAE,WAAW,EAAE,EAAE;IAC9H,MAAM,QAAQ,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAA;IAC7C,MAAM,GAAG,GAAG,WAAwC,IAAI,QAAQ,CAAA;IAEhE,SAAS,CAAC,GAAG,EAAE;QACb,UAAU,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC,GAAG,CAAC,OAAO,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,EAAE,KAAK,CAAC,CAAA;IAC7E,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,KAAC,WAAW,IAAC,GAAG,EAAE,GAAG,KAAM,KAAK,YAAG,QAAQ,GAAe,CAAA;AACnE,CAAC,CAAC,CAAA"}
@@ -0,0 +1,40 @@
1
+ import { BaseFavoriteProps } from '@stack-spot/citric-react';
2
+ export interface ItemFavorite {
3
+ id?: string;
4
+ slug?: string;
5
+ }
6
+ export interface Favorite<T extends ItemFavorite> {
7
+ /**
8
+ * id or slug to be used on functions
9
+ */
10
+ idOrSlug: string;
11
+ /**
12
+ * Array containing the list of favorite items.
13
+ */
14
+ listFavorites?: T[];
15
+ /**
16
+ * Function to add an item to the list of favorites.
17
+ * @param idOrSlug - The ID or slug of the content to be added to the favorites list.
18
+ * @returns void
19
+ */
20
+ onAddFavorite?: (idOrSlug: string) => Promise<boolean>;
21
+ /**
22
+ * Function to remove an item from the list of favorites.
23
+ * @param idOrSlug - The ID or slug of the content to be removed from the favorites list.
24
+ * @returns void
25
+ */
26
+ onRemoveFavorite?: (idOrSlug: string) => Promise<boolean>;
27
+ }
28
+ interface Props<T extends ItemFavorite> {
29
+ /**
30
+ * An object containing favorite items and related operations.
31
+ */
32
+ favorite: Favorite<T>;
33
+ /**
34
+ * @default 'square'
35
+ */
36
+ appearance?: BaseFavoriteProps['appearance'];
37
+ }
38
+ export declare const ButtonFavorite: <T extends ItemFavorite>({ favorite, appearance }: Props<T>) => import("react/jsx-runtime").JSX.Element;
39
+ export {};
40
+ //# sourceMappingURL=ButtonFavorite.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ButtonFavorite.d.ts","sourceRoot":"","sources":["../../src/components/ButtonFavorite.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAY,MAAM,0BAA0B,CAAA;AAKtE,MAAM,WAAW,YAAY;IAC3B,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,QAAQ,CAAC,CAAC,SAAS,YAAY;IAC9C;;OAEG;IACH,QAAQ,EAAE,MAAM,CAAC;IACjB;;OAEG;IACH,aAAa,CAAC,EAAE,CAAC,EAAE,CAAC;IACpB;;;;OAIG;IACH,aAAa,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;IACvD;;;;OAIG;IACH,gBAAgB,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;CAC3D;AAED,UAAU,KAAK,CAAC,CAAC,SAAS,YAAY;IACpC;;MAEE;IACH,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;IACtB;;OAEG;IACH,UAAU,CAAC,EAAE,iBAAiB,CAAC,YAAY,CAAC,CAAC;CAC7C;AAED,eAAO,MAAM,cAAc,GAAI,CAAC,SAAS,YAAY,4BAAuC,KAAK,CAAC,CAAC,CAAC,4CAWnG,CAAA"}
@@ -0,0 +1,25 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Favorite } from '@stack-spot/citric-react';
3
+ import { useTranslate } from '@stack-spot/portal-translate';
4
+ import { useEffect, useState } from 'react';
5
+ import { dictionaryFavorites } from './form/dictionary.js';
6
+ export const ButtonFavorite = ({ favorite, appearance = 'square' }) => {
7
+ const [isFavorite, setIsFavorite] = useState(false);
8
+ const { idOrSlug, listFavorites } = favorite || {};
9
+ useEffect(() => {
10
+ setIsFavorite(!!listFavorites?.some((fav) => fav.slug === idOrSlug || fav.id === idOrSlug));
11
+ }, [listFavorites]);
12
+ return (_jsx(ButtonWrapper, { isFavorite: isFavorite, favorite: favorite, appearance: appearance }));
13
+ };
14
+ const ButtonWrapper = ({ isFavorite, favorite, appearance }) => {
15
+ const t = useTranslate(dictionaryFavorites);
16
+ const { idOrSlug, onAddFavorite, onRemoveFavorite } = favorite;
17
+ const [loading, setLoading] = useState(false);
18
+ const handleAction = async (idOrSlug, action) => {
19
+ setLoading(true);
20
+ await action?.(idOrSlug);
21
+ setLoading(false);
22
+ };
23
+ return _jsx(Favorite, { loading: loading, appearance: appearance, "aria-label": `${t[isFavorite ? 'remove' : 'become']} ${t.favorite}`, title: `${t[isFavorite ? 'remove' : 'become']} ${t.favorite}`, value: isFavorite, onChange: checked => handleAction(idOrSlug, checked ? onAddFavorite : onRemoveFavorite) });
24
+ };
25
+ //# sourceMappingURL=ButtonFavorite.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ButtonFavorite.js","sourceRoot":"","sources":["../../src/components/ButtonFavorite.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAqB,QAAQ,EAAE,MAAM,0BAA0B,CAAA;AACtE,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAA;AAC3D,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAC3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;AAyCvD,MAAM,CAAC,MAAM,cAAc,GAAG,CAAyB,EAAE,QAAQ,EAAE,UAAU,GAAG,QAAQ,EAAY,EAAE,EAAE;IACtG,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACnD,MAAM,EAAE,QAAQ,EAAE,aAAa,EAAE,GAAG,QAAQ,IAAI,EAAE,CAAA;IAElD,SAAS,CAAC,GAAG,EAAE;QACb,aAAa,CAAC,CAAC,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,QAAQ,IAAI,GAAG,CAAC,EAAE,KAAK,QAAQ,CAAC,CAAC,CAAA;IAC7F,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC,CAAA;IAEnB,OAAO,CACL,KAAC,aAAa,IAAC,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,GAAI,CACtF,CAAA;AACH,CAAC,CAAA;AAED,MAAM,aAAa,GAAG,CAAyB,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,EACY,EAAE,EAAE;IAC/F,MAAM,CAAC,GAAG,YAAY,CAAC,mBAAmB,CAAC,CAAA;IAC3C,MAAM,EAAE,QAAQ,EAAE,aAAa,EAAE,gBAAgB,EAAE,GAAG,QAAQ,CAAA;IAC9D,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAE7C,MAAM,YAAY,GAAG,KAAK,EAAE,QAAgB,EAAE,MAA+C,EAAE,EAAE;QAC/F,UAAU,CAAC,IAAI,CAAC,CAAA;QAChB,MAAM,MAAM,EAAE,CAAC,QAAQ,CAAC,CAAA;QACxB,UAAU,CAAC,KAAK,CAAC,CAAA;IACnB,CAAC,CAAA;IAED,OAAO,KAAC,QAAQ,IACd,OAAO,EAAE,OAAO,EAChB,UAAU,EAAE,UAAU,gBACV,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAClE,KAAK,EAAE,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAC7D,KAAK,EAAE,UAAU,EACjB,QAAQ,EAAE,OAAO,CAAC,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,gBAAgB,CAAC,GACvF,CAAA;AACJ,CAAC,CAAA"}
@@ -13,7 +13,8 @@ export interface Props extends WithChildren {
13
13
  onNewFile?: CodeAction;
14
14
  onCopyCode?: CodeAction;
15
15
  language?: string;
16
+ showLineNumbers?: boolean;
16
17
  }
17
- export declare const Code: ({ className, onInsertCode, onNewFile, onCopyCode, language, children, showActionBar, ...props }: Pick<CodeProps, "className" | "messageId"> & Props) => import("react/jsx-runtime").JSX.Element;
18
+ export declare const Code: ({ className, onInsertCode, onNewFile, onCopyCode, language, children, showActionBar, showLineNumbers, ...props }: Pick<CodeProps, "className" | "messageId"> & Props) => import("react/jsx-runtime").JSX.Element;
18
19
  export {};
19
20
  //# sourceMappingURL=Code.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Code.d.ts","sourceRoot":"","sources":["../../src/components/Code.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAOH,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAI3C,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAEvC,MAAM,MAAM,UAAU,GAAG,CACvB,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,MAAM,KACb,IAAI,CAAA;AAET,KAAK,SAAS,GAAG,KAAK,CAAC,eAAe,CAAC,WAAW,CAAC,GAC/C,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC,GACjC,UAAU,GACV;IAAE,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,CAAA;AAE1B,MAAM,WAAW,KAAM,SAAQ,YAAY;IACzC,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,YAAY,CAAC,EAAE,UAAU,CAAC;IAC1B,SAAS,CAAC,EAAE,UAAU,CAAC;IACvB,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AA6DD,eAAO,MAAM,IAAI,oGASd,IAAI,CAAC,SAAS,EAAE,WAAW,GAAG,WAAW,CAAC,GAAG,KAAK,4CA+FpD,CAAA"}
1
+ {"version":3,"file":"Code.d.ts","sourceRoot":"","sources":["../../src/components/Code.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAMH,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAI3C,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAIvC,MAAM,MAAM,UAAU,GAAG,CACvB,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,MAAM,KACb,IAAI,CAAA;AAET,KAAK,SAAS,GAAG,KAAK,CAAC,eAAe,CAAC,WAAW,CAAC,GAC/C,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC,GACjC,UAAU,GACV;IAAE,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,CAAA;AAE1B,MAAM,WAAW,KAAM,SAAQ,YAAY;IACzC,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,YAAY,CAAC,EAAE,UAAU,CAAC;IAC1B,SAAS,CAAC,EAAE,UAAU,CAAC;IACvB,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B;AAwED,eAAO,MAAM,IAAI,qHAUd,IAAI,CAAC,SAAS,EAAE,WAAW,GAAG,WAAW,CAAC,GAAG,KAAK,4CA8GpD,CAAA"}
@@ -2,14 +2,15 @@ import { Fragment as _Fragment, jsx as _jsx, jsxs as _jsxs } from "react/jsx-run
2
2
  /**
3
3
  * Copied from the extension's webview.
4
4
  */
5
- import { AddCode, ChevronDoubleDown, Collapse, Copy } from '@citric/icons';
6
- import { IconButton } from '@citric/ui';
5
+ import { IconButton, Text } from '@stack-spot/citric-react';
7
6
  import { theme, useThemeKind } from '@stack-spot/portal-theme';
8
7
  import { useTranslate } from '@stack-spot/portal-translate';
9
8
  import { useState } from 'react';
10
9
  import { Prism as SyntaxHighlighter } from 'react-syntax-highlighter';
11
10
  import { materialDark, vs } from 'react-syntax-highlighter/dist/esm/styles/prism/index.js';
12
11
  import styled from 'styled-components';
12
+ import { copyTextToClipboardWithFallback } from '../utils/copy-to-clipboard.js';
13
+ import { languages } from '../utils/programming-languages.js';
13
14
  const CodeBox = styled.code `
14
15
  background: ${theme.color.light[500]};
15
16
  border-radius: 6px;
@@ -31,23 +32,34 @@ const CodeBox = styled.code `
31
32
  }
32
33
  }
33
34
 
34
- .action-bar {
35
+ .header-code {
35
36
  display: flex;
36
37
  flex-direction: row;
37
- justify-content: flex-end;
38
+ justify-content: space-between;
38
39
  background: ${theme.color.light[600]};
39
40
  padding: 4px 6px;
40
41
  border-top-left-radius: 6px;
41
42
  border-top-right-radius: 6px;
42
43
 
43
- button {
44
- background: transparent;
45
- border: none;
46
- opacity: 0.75;
47
- transition: opacity 0.2s;
44
+ .action-bar {
45
+ display: flex;
46
+ flex-direction: row;
47
+
48
+ button {
49
+ background: transparent;
50
+ border: none;
51
+ opacity: 0.75;
52
+ transition: opacity 0.2s;
53
+
54
+ &:hover {
55
+ opacity: 1;
56
+ }
57
+ }
48
58
 
49
- &:hover {
50
- opacity: 1;
59
+ .copy-btn {
60
+ &:after {
61
+ left: -30px; // prevents scrolling in the horizontal axis.
62
+ }
51
63
  }
52
64
  }
53
65
  }
@@ -67,13 +79,14 @@ const CodeBox = styled.code `
67
79
  const lineNumbersStyle = {
68
80
  userSelect: 'none',
69
81
  };
70
- export const Code = ({ className, onInsertCode, onNewFile, onCopyCode, language, children, showActionBar, ...props }) => {
82
+ export const Code = ({ className, onInsertCode, onNewFile, onCopyCode, language, children, showActionBar, showLineNumbers = true, ...props }) => {
71
83
  const t = useTranslate(dictionary);
72
84
  const themeKind = useThemeKind();
73
- const [showLines, setShowLines] = useState(true);
85
+ const [showLines, setShowLines] = useState(showLineNumbers);
74
86
  const match = /language-(\w+)/.exec(className || '');
75
87
  const computedLanguage = language ?? (match ?? [])[1]?.toLowerCase() ?? 'txt';
76
88
  const content = String(children ?? '').replaceAll(/\n\t/g, '\n').trim();
89
+ const languageExtension = languages.find(l => l.value === computedLanguage)?.extensions?.[0] ?? '.txt';
77
90
  function onClickInsert() {
78
91
  onInsertCode?.(content, computedLanguage);
79
92
  }
@@ -82,37 +95,52 @@ export const Code = ({ className, onInsertCode, onNewFile, onCopyCode, language,
82
95
  }
83
96
  function onClickCopy() {
84
97
  onCopyCode?.(content, computedLanguage);
85
- // try-catch because the client may not support `navigator.clipboard`. Example: Chromium Embedded Browser (CEF).
86
- try {
87
- navigator.clipboard.writeText(content);
88
- }
89
- catch { /* empty */ }
98
+ copyTextToClipboardWithFallback(content);
90
99
  }
91
100
  if (children === undefined)
92
101
  return _jsx(_Fragment, {});
93
- if (!(/language-(\w+)/.exec(className || ''))) {
102
+ if (computedLanguage === 'txt') {
94
103
  return (_jsx("code", { ...props, className: className, children: children }));
95
104
  }
96
- return (_jsxs(CodeBox, { className: ['code-box', themeKind].join(' '), children: [showActionBar && (_jsxs("div", { className: "action-bar", role: "toolbar", children: [_jsx(IconButton, { "aria-label": showLines ? t.hideLines : t.showLines, title: showLines ? t.hideLines : t.showLines, onClick: () => setShowLines(v => !v), style: { position: 'relative', transform: showLines ? undefined : 'rotate(180deg)', transition: 'transform 0.2s' }, children: _jsx(Collapse, {}) }), _jsx(IconButton, { "aria-label": t.copy, title: t.copy, onClick: onClickCopy, style: { position: 'relative' }, children: _jsx(Copy, {}) }), onInsertCode
97
- ? (_jsx(IconButton, { "aria-label": t.insert, title: t.insert, onClick: onClickInsert, style: { position: 'relative' }, children: _jsx(ChevronDoubleDown, { style: { transform: 'rotate(90deg)' } }) }))
98
- : null, onNewFile
99
- ? (_jsx(IconButton, { "aria-label": t.newFile, title: t.newFile, onClick: onClickNewFile, style: { position: 'relative' }, children: _jsx(AddCode, {}) }))
100
- : null] })), _jsx("div", { children: _jsx(SyntaxHighlighter, { ...props, className: "highlighter", style: themeKind === 'dark' ? materialDark : vs, language: computedLanguage, PreTag: "div", showLineNumbers: showLines, lineNumberContainerStyle: lineNumbersStyle, lineNumberStyle: lineNumbersStyle, children: content }) })] }));
105
+ return (_jsxs(CodeBox, { className: ['code-box', themeKind, className].join(' '), children: [showActionBar && (_jsxs("div", { className: "header-code", children: [_jsx("div", { children: _jsx(Text, { appearance: "code2", children: computedLanguage ?? '' }) }), _jsxs("div", { className: "action-bar", role: "toolbar", children: [_jsx(IconButton, { icon: "Collapse", "aria-label": showLines ? t.hideLines : t.showLines, title: showLines ? t.hideLines : t.showLines, onClick: () => setShowLines(v => !v), style: { position: 'relative', transform: showLines ? undefined : 'rotate(180deg)', transition: 'transform 0.2s' } }), _jsx(IconButton, { icon: "Download", "aria-label": t.downloadCode, title: t.downloadCode, onClick: () => {
106
+ try {
107
+ const extension = languageExtension;
108
+ const filename = `download${extension}`;
109
+ const blob = new Blob([content], { type: 'text/plain;charset=utf-8' });
110
+ const link = document.createElement('a');
111
+ link.href = URL.createObjectURL(blob);
112
+ link.download = filename;
113
+ document.body.appendChild(link);
114
+ link.click();
115
+ document.body.removeChild(link);
116
+ URL.revokeObjectURL(link.href);
117
+ }
118
+ catch (e) {
119
+ // eslint-disable-next-line no-console
120
+ console.error(t.downloadError, e);
121
+ }
122
+ } }), _jsx(IconButton, { icon: "Copy", "aria-label": t.copy, title: t.copy, onClick: onClickCopy, style: { position: 'relative' }, feedback: t.copied, className: "copy-btn" }), onInsertCode ? _jsx(IconButton, { icon: "ChevronDoubleDown", "aria-label": t.insert, title: t.insert, onClick: onClickInsert, style: { position: 'relative', transform: 'rotate(90deg)' } }) : null, onNewFile ? _jsx(IconButton, { icon: "AddCode", "aria-label": t.newFile, title: t.newFile, onClick: onClickNewFile, style: { position: 'relative' } }) : null] })] })), _jsx("div", { children: _jsx(SyntaxHighlighter, { ...props, className: "highlighter", style: themeKind === 'dark' ? materialDark : vs, language: computedLanguage, PreTag: "div", showLineNumbers: showLines, lineNumberContainerStyle: lineNumbersStyle, lineNumberStyle: lineNumbersStyle, children: content }) })] }));
101
123
  };
102
124
  const dictionary = {
103
125
  en: {
104
126
  copy: 'Copy code to the clipboard',
127
+ copied: 'Copied',
105
128
  insert: 'Inject code into editor',
106
129
  newFile: 'Creates a new file with this code as its content',
107
130
  hideLines: 'Hide line numbers',
108
131
  showLines: 'Show line numbers',
132
+ downloadCode: 'Download the code',
133
+ downloadError: 'Error downloading code',
109
134
  },
110
135
  pt: {
111
136
  copy: 'Copiar código para a área de transferência',
137
+ copied: 'Copiado',
112
138
  insert: 'Inserir código no editor',
113
139
  newFile: 'Criar um novo arquivo com este código como conteúdo',
114
140
  hideLines: 'Esconder números das linhas',
115
141
  showLines: 'Mostrar números das linhas',
142
+ downloadCode: 'Fazer download do código',
143
+ downloadError: 'Erro ao fazer download do código',
116
144
  },
117
145
  };
118
146
  //# sourceMappingURL=Code.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Code.js","sourceRoot":"","sources":["../../src/components/Code.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Code.js","sourceRoot":"","sources":["../../src/components/Code.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,38 @@
1
+ /**
2
+ * Map of string keys to React components.
3
+ */
4
+ export type NavigationMap = Record<string, React.ComponentType<any>>;
5
+ /**
6
+ * Navigation component describing which component to render and its props.
7
+ */
8
+ export type NavigationComponent<T extends NavigationMap, K extends keyof T = keyof T> = {
9
+ /** Component key to render. */
10
+ component: K;
11
+ /** Props for the component. */
12
+ props?: T[K] extends React.ComponentType<infer P> ? P : never;
13
+ /** Render in fullscreen mode. */
14
+ fullScreen?: boolean;
15
+ };
16
+ export interface NavigationContextType<T extends NavigationMap> {
17
+ /** Navigate to a new component. */
18
+ navigate: <K extends keyof T>(item: NavigationComponent<T, K>) => Promise<void>;
19
+ /** Go back to previous component. */
20
+ goBack: () => void;
21
+ /** True if can go back. */
22
+ canGoBack: boolean;
23
+ /** Current component. */
24
+ currentItem: NavigationComponent<T>;
25
+ }
26
+ export interface ComponentNavigatorProps<T extends NavigationMap, K extends keyof T> {
27
+ /** Initial component to render. */
28
+ initialItem: NavigationComponent<T, K>;
29
+ /** Map of available components. */
30
+ components: T;
31
+ /** Optional title renderer. */
32
+ renderTitle?: (item: NavigationComponent<T, keyof T>) => React.ReactNode;
33
+ /** Optional CSS class. */
34
+ className?: string;
35
+ }
36
+ export declare function ComponentNavigator<T extends NavigationMap, K extends keyof T>({ initialItem, components, renderTitle, className, }: ComponentNavigatorProps<T, K>): import("react/jsx-runtime").JSX.Element;
37
+ export declare function useComponentNavigation<T extends NavigationMap>(): NavigationContextType<T>;
38
+ //# sourceMappingURL=ComponentNavigator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ComponentNavigator.d.ts","sourceRoot":"","sources":["../../src/components/ComponentNavigator.tsx"],"names":[],"mappings":"AAGA;;GAEG;AACH,MAAM,MAAM,aAAa,GAAG,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAA;AAEpE;;GAEG;AACH,MAAM,MAAM,mBAAmB,CAAC,CAAC,SAAS,aAAa,EAAE,CAAC,SAAS,MAAM,CAAC,GAAG,MAAM,CAAC,IAAI;IACtF,+BAA+B;IAC/B,SAAS,EAAE,CAAC,CAAC;IAEb,+BAA+B;IAC/B,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IAE9D,iCAAiC;IACjC,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB,CAAA;AAED,MAAM,WAAW,qBAAqB,CAAC,CAAC,SAAS,aAAa;IAC5D,mCAAmC;IACnC,QAAQ,EAAE,CAAC,CAAC,SAAS,MAAM,CAAC,EAAE,IAAI,EAAE,mBAAmB,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAEhF,qCAAqC;IACrC,MAAM,EAAE,MAAM,IAAI,CAAC;IAEnB,2BAA2B;IAC3B,SAAS,EAAE,OAAO,CAAC;IAEnB,yBAAyB;IACzB,WAAW,EAAE,mBAAmB,CAAC,CAAC,CAAC,CAAC;CACrC;AAED,MAAM,WAAW,uBAAuB,CAAC,CAAC,SAAS,aAAa,EAAE,CAAC,SAAS,MAAM,CAAC;IACjF,mCAAmC;IACnC,WAAW,EAAE,mBAAmB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAEtC,mCAAmC;IACpC,UAAU,EAAE,CAAC,CAAC;IAEd,+BAA+B;IAC/B,WAAW,CAAC,EAAE,CAAC,IAAI,EAAE,mBAAmB,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,KAAK,KAAK,CAAC,SAAS,CAAC;IAExE,0BAA0B;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAID,wBAAgB,kBAAkB,CAAC,CAAC,SAAS,aAAa,EAAE,CAAC,SAAS,MAAM,CAAC,EAAE,EAC7E,WAAW,EACX,UAAU,EACV,WAAW,EACX,SAAS,GACV,EAAE,uBAAuB,CAAC,CAAC,EAAE,CAAC,CAAC,2CAiC/B;AAED,wBAAgB,sBAAsB,CAAC,CAAC,SAAS,aAAa,KAAK,qBAAqB,CAAC,CAAC,CAAC,CAM1F"}
@@ -0,0 +1,31 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { IconButton, Row } from '@stack-spot/citric-react';
3
+ import { createContext, useCallback, useContext, useMemo, useState } from 'react';
4
+ const NavigationContext = createContext(null);
5
+ export function ComponentNavigator({ initialItem, components, renderTitle, className, }) {
6
+ const [navigationStack, setNavigationStack] = useState([initialItem]);
7
+ const currentItem = navigationStack[navigationStack.length - 1];
8
+ const navigate = useCallback((item) => { setNavigationStack((prev) => [...prev, item]); }, []);
9
+ const canGoBack = navigationStack.length > 1;
10
+ const goBack = useCallback(() => {
11
+ if (canGoBack) {
12
+ setNavigationStack((prev) => prev.slice(0, -1));
13
+ }
14
+ }, [canGoBack]);
15
+ const navigationContext = useMemo(() => ({ navigate, goBack, canGoBack, currentItem }), [navigate, goBack, canGoBack, currentItem]);
16
+ const Component = components[currentItem.component];
17
+ const isFullScreen = currentItem.fullScreen;
18
+ if (!Component) {
19
+ // eslint-disable-next-line no-console
20
+ console.error(`Componente not found: ${String(currentItem.component)}`);
21
+ }
22
+ return (_jsx(NavigationContext.Provider, { value: navigationContext, children: _jsxs("div", { className: `content-navigator ${className || isFullScreen ? 'full' : ''}`, role: "navigation", children: [canGoBack && (_jsxs(Row, { gap: "12px", style: { alignSelf: 'stretch' }, children: [_jsx(IconButton, { icon: "ArrowLeft", onClick: goBack, className: "back-button", "aria-label": "Back" }), renderTitle?.(currentItem)] })), _jsx(Component, { ...currentItem.props })] }) }));
23
+ }
24
+ export function useComponentNavigation() {
25
+ const context = useContext(NavigationContext);
26
+ if (!context) {
27
+ throw new Error('useComponentNavigation should be used inside ComponentNavigator');
28
+ }
29
+ return context;
30
+ }
31
+ //# sourceMappingURL=ComponentNavigator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ComponentNavigator.js","sourceRoot":"","sources":["../../src/components/ComponentNavigator.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,0BAA0B,CAAA;AAC1D,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAiDjF,MAAM,iBAAiB,GAAG,aAAa,CAA8C,IAAI,CAAC,CAAA;AAE1F,MAAM,UAAU,kBAAkB,CAA6C,EAC7E,WAAW,EACX,UAAU,EACV,WAAW,EACX,SAAS,GACqB;IAC9B,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,QAAQ,CAA2B,CAAC,WAAW,CAAC,CAAC,CAAA;IAC/F,MAAM,WAAW,GAAG,eAAe,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;IAE/D,MAAM,QAAQ,GAAG,WAAW,CAAC,CAAC,IAA4B,EAAE,EAAE,GAAG,kBAAkB,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,GAAG,IAAI,EAAE,IAAI,CAAC,CAAC,CAAA,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA;IACrH,MAAM,SAAS,GAAG,eAAe,CAAC,MAAM,GAAG,CAAC,CAAA;IAC5C,MAAM,MAAM,GAAG,WAAW,CAAC,GAAG,EAAE;QAC9B,IAAI,SAAS,EAAE,CAAC;YACd,kBAAkB,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAA;QACjD,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,MAAM,iBAAiB,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC,CAAA;IACnI,MAAM,SAAS,GAAG,UAAU,CAAC,WAAW,CAAC,SAAS,CAAC,CAAA;IACnD,MAAM,YAAY,GAAG,WAAW,CAAC,UAAU,CAAA;IAE3C,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,sCAAsC;QACtC,OAAO,CAAC,KAAK,CAAC,yBAAyB,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;IACzE,CAAC;IAED,OAAO,CAAC,KAAC,iBAAiB,CAAC,QAAQ,IAAC,KAAK,EAAE,iBAAyD,YAClG,eAAK,SAAS,EAAE,qBAAqB,SAAS,IAAI,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,IAAI,EAAC,YAAY,aAC9F,SAAS,IAAI,CACZ,MAAC,GAAG,IAAC,GAAG,EAAC,MAAM,EAAC,KAAK,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,aAC7C,KAAC,UAAU,IAAC,IAAI,EAAC,WAAW,EAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAC,aAAa,gBAAY,MAAM,GAAG,EACzF,WAAW,EAAE,CAAC,WAAW,CAAC,IACvB,CACP,EACD,KAAC,SAAS,OAAM,WAAW,CAAC,KAAa,GAAI,IACzC,GACqB,CAC5B,CAAA;AACH,CAAC;AAED,MAAM,UAAU,sBAAsB;IACpC,MAAM,OAAO,GAAG,UAAU,CAAC,iBAAiB,CAAC,CAAA;IAC7C,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,iEAAiE,CAAC,CAAA;IACpF,CAAC;IACD,OAAO,OAAO,CAAA;AAChB,CAAC"}
@@ -0,0 +1,32 @@
1
+ import { WithStyle } from '@stack-spot/portal-theme';
2
+ import { WithChildren } from '../types.js';
3
+ interface Props extends WithChildren, WithStyle {
4
+ /**
5
+ * Whether or not the content is visible.
6
+ */
7
+ visible: boolean;
8
+ /**
9
+ * Duration of the animation in ms.
10
+ * @default 300
11
+ */
12
+ duration?: number;
13
+ /**
14
+ * Function to run right before animation to show the content starts.
15
+ */
16
+ beforeFadeIn?: () => void;
17
+ /**
18
+ * Function to run right before animation to hide the content starts.
19
+ */
20
+ beforeFadeOut?: () => void;
21
+ /**
22
+ * Function to run right after the animation to show the content ends.
23
+ */
24
+ afterFadeIn?: () => void;
25
+ /**
26
+ * Function to run right after the animation to hide the content ends.
27
+ */
28
+ afterFadeOut?: () => void;
29
+ }
30
+ export declare const Fading: import("react").ForwardRefExoticComponent<Props & import("react").RefAttributes<HTMLDivElement>>;
31
+ export {};
32
+ //# sourceMappingURL=Fading.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Fading.d.ts","sourceRoot":"","sources":["../../src/components/Fading.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAA;AAEpD,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAEvC,UAAU,KAAM,SAAQ,YAAY,EAAE,SAAS;IAC7C;;OAEG;IACH,OAAO,EAAE,OAAO,CAAC;IACjB;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAC1B;;OAEG;IACH,aAAa,CAAC,EAAE,MAAM,IAAI,CAAC;IAC3B;;OAEG;IACH,WAAW,CAAC,EAAE,MAAM,IAAI,CAAC;IACzB;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;CAC3B;AAED,eAAO,MAAM,MAAM,kGAgCjB,CAAA"}
@@ -0,0 +1,33 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { forwardRef, useEffect, useRef, useState } from 'react';
3
+ export const Fading = forwardRef(({ visible, children, duration = 300, afterFadeIn, afterFadeOut, beforeFadeIn, beforeFadeOut, className, style }, ref) => {
4
+ const [isOpaque, setOpaque] = useState(visible);
5
+ const [isRendered, setRendered] = useState(visible);
6
+ const previous = useRef(visible);
7
+ const timeout = useRef([]);
8
+ const opacity = { transition: `opacity ${duration / 1000}s`, opacity: isOpaque ? 1 : 0 };
9
+ useEffect(() => {
10
+ if (previous.current === visible)
11
+ return;
12
+ timeout.current.forEach(window.clearTimeout);
13
+ timeout.current = [];
14
+ if (visible) {
15
+ setRendered(true);
16
+ if (afterFadeIn)
17
+ timeout.current.push(window.setTimeout(afterFadeIn, duration));
18
+ beforeFadeIn?.();
19
+ timeout.current.push(window.setTimeout(() => setOpaque(true), 0));
20
+ }
21
+ else {
22
+ setOpaque(false);
23
+ beforeFadeOut?.();
24
+ timeout.current.push(window.setTimeout(() => {
25
+ setRendered(false);
26
+ afterFadeOut?.();
27
+ }, duration));
28
+ }
29
+ previous.current = visible;
30
+ }, [visible]);
31
+ return isRendered ? _jsx("div", { ref: ref, className: className, style: { ...style, ...opacity }, children: children }) : null;
32
+ });
33
+ //# sourceMappingURL=Fading.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Fading.js","sourceRoot":"","sources":["../../src/components/Fading.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AA+B/D,MAAM,CAAC,MAAM,MAAM,GAAG,UAAU,CAAwB,CACtD,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,GAAG,GAAG,EAAE,WAAW,EAAE,YAAY,EAAE,YAAY,EAAE,aAAa,EAAE,SAAS,EAAE,KAAK,EAAE,EAC/G,GAAG,EACH,EAAE;IACF,MAAM,CAAC,QAAQ,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAA;IAC/C,MAAM,CAAC,UAAU,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAA;IACnD,MAAM,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,CAAA;IAChC,MAAM,OAAO,GAAG,MAAM,CAAW,EAAE,CAAC,CAAA;IACpC,MAAM,OAAO,GAAwB,EAAE,UAAU,EAAE,WAAW,QAAQ,GAAG,IAAI,GAAG,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA;IAE7G,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,QAAQ,CAAC,OAAO,KAAK,OAAO;YAAE,OAAM;QACxC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,CAAA;QAC5C,OAAO,CAAC,OAAO,GAAG,EAAE,CAAA;QACpB,IAAI,OAAO,EAAE,CAAC;YACZ,WAAW,CAAC,IAAI,CAAC,CAAA;YACjB,IAAI,WAAW;gBAAE,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,CAAA;YAC/E,YAAY,EAAE,EAAE,CAAA;YAChB,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;QAEnE,CAAC;aAAM,CAAC;YACN,SAAS,CAAC,KAAK,CAAC,CAAA;YAChB,aAAa,EAAE,EAAE,CAAA;YACjB,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;gBAC1C,WAAW,CAAC,KAAK,CAAC,CAAA;gBAClB,YAAY,EAAE,EAAE,CAAA;YAClB,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAA;QACf,CAAC;QACD,QAAQ,CAAC,OAAO,GAAG,OAAO,CAAA;IAC5B,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAA;IAEb,OAAO,UAAU,CAAC,CAAC,CAAC,cAAK,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,GAAG,KAAK,EAAE,GAAG,OAAO,EAAE,YAAG,QAAQ,GAAO,CAAC,CAAC,CAAC,IAAI,CAAA;AACnH,CAAC,CAAC,CAAA"}
@@ -3,10 +3,35 @@ import { WithChildren } from '../types.js';
3
3
  type Side = 'top' | 'right' | 'left' | 'bottom';
4
4
  type ScrollType = 'none' | 'wheel' | 'bar' | 'arrows';
5
5
  interface Props extends WithChildren, WithStyle {
6
+ /**
7
+ * How to scroll the content.
8
+ * - none: overflow is hidden. No scrolling.
9
+ * - wheel: the content is solely scrollable through the mouse wheel and keyboard arrows, no scroll bars are rendered.
10
+ * - bar: this is the normal browser scroll. The content will be scrollable through the mouse wheel, keyboard and scrollbar.
11
+ * - arrows: arrows will be placed in the far edges of the sides that must be scrolled. The content is scrolled through the mouse wheel,
12
+ * keyboard and these arrows. Hovering an arrow slowly scrolls the content, clicking the arrow fully scrolls the content in its direction.
13
+ * There are no scrollbars in this scenario.
14
+ * @default 'none'
15
+ */
6
16
  scroll?: ScrollType;
17
+ /**
18
+ * If true, a horizontal scroll can be performed by using the vertical mouse wheel.
19
+ * @default false
20
+ */
7
21
  enableHorizontalScrollWithVerticalWheel?: boolean;
22
+ /**
23
+ * Which sides to fade when the content overflows.
24
+ *
25
+ * Important: it seems the current solution doesn't support mixing vertical and horizontal scrolls. I'm not sure if this is possible, I
26
+ * believed combining linear gradients would work, but it doesn't.
27
+ */
8
28
  sides?: Side[];
9
29
  }
30
+ /**
31
+ * This component applies a fading graphical effect to its content if it overflows in any of the sides specified by the props.
32
+ *
33
+ * This also controls how this overflow is scrolled, introducing a new scrolling technique, which applies arrows to the overflowing side.
34
+ */
10
35
  export declare const FadingOverflow: ({ children, scroll, sides, enableHorizontalScrollWithVerticalWheel, className, ...props }: Props) => import("react/jsx-runtime").JSX.Element;
11
36
  export {};
12
37
  //# sourceMappingURL=FadingOverflow.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"FadingOverflow.d.ts","sourceRoot":"","sources":["../../src/components/FadingOverflow.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAsB,SAAS,EAAE,MAAM,0BAA0B,CAAA;AAIxE,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAEvC,KAAK,IAAI,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,GAAG,QAAQ,CAAA;AAC/C,KAAK,UAAU,GAAG,MAAM,GAAG,OAAO,GAAG,KAAK,GAAG,QAAQ,CAAA;AAErD,UAAU,KAAM,SAAQ,YAAY,EAAE,SAAS;IAC7C,MAAM,CAAC,EAAE,UAAU,CAAC;IACpB,uCAAuC,CAAC,EAAE,OAAO,CAAC;IAClD,KAAK,CAAC,EAAE,IAAI,EAAE,CAAC;CAChB;AAqFD,eAAO,MAAM,cAAc,8FAC2E,KAAK,4CAoI1G,CAAA"}
1
+ {"version":3,"file":"FadingOverflow.d.ts","sourceRoot":"","sources":["../../src/components/FadingOverflow.tsx"],"names":[],"mappings":"AACA,OAAO,EAAsB,SAAS,EAAE,MAAM,0BAA0B,CAAA;AAIxE,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAEvC,KAAK,IAAI,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,GAAG,QAAQ,CAAA;AAC/C,KAAK,UAAU,GAAG,MAAM,GAAG,OAAO,GAAG,KAAK,GAAG,QAAQ,CAAA;AAErD,UAAU,KAAM,SAAQ,YAAY,EAAE,SAAS;IAC7C;;;;;;;;;OASG;IACH,MAAM,CAAC,EAAE,UAAU,CAAC;IACpB;;;OAGG;IACH,uCAAuC,CAAC,EAAE,OAAO,CAAC;IAClD;;;;;OAKG;IACH,KAAK,CAAC,EAAE,IAAI,EAAE,CAAC;CAChB;AAwFD;;;;GAIG;AACH,eAAO,MAAM,cAAc,8FAC2E,KAAK,4CAoI1G,CAAA"}
@@ -1,16 +1,21 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { IconBox } from '@citric/core';
3
- import { ChevronDown, ChevronLeft, ChevronRight, ChevronUp } from '@citric/icons';
2
+ import { Icon } from '@stack-spot/citric-icons';
4
3
  import { listToClass, theme } from '@stack-spot/portal-theme';
5
4
  import { debounce } from 'lodash';
6
5
  import { useEffect, useRef } from 'react';
7
6
  import { styled } from 'styled-components';
7
+ // Scrolling can be very fast, this sets a lower limit for us to run listeners without impacting performance.
8
8
  const MIN_CHECK_INTERVAL_MS = 20;
9
+ // The interval which to scroll the content when a scroll arrow is hovered.
10
+ const SCROLL_INTERVAL_MS = 20;
11
+ // This sets the speed of the scroll when the user hovers a scroll arrow.
12
+ const SCROLL_PX = 4;
13
+ // Fade masks
9
14
  const masks = {
10
15
  right: 'linear-gradient(to left, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgba(0, 0, 0) 100%)',
11
16
  left: 'linear-gradient(to right, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgba(0, 0, 0) 100%)',
12
- top: 'linear-gradient(to bottom, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgba(0, 0, 0) 100%)',
13
- bottom: 'linear-gradient(to top, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgba(0, 0, 0) 100%)',
17
+ top: 'linear-gradient(to top, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgba(0, 0, 0) 100%)',
18
+ bottom: 'linear-gradient(to bottom, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgba(0, 0, 0) 100%)',
14
19
  horizontal: 'linear-gradient(to left, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgb(0, 0, 0) max(70%, calc(100% - 100px)), rgba(0, 0, 0, 0) 100%)',
15
20
  vertical: 'linear-gradient(to top, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgb(0, 0, 0) max(70%, calc(100% - 100px)), rgba(0, 0, 0, 0) 100%)',
16
21
  };
@@ -43,7 +48,7 @@ const OverflowBox = styled.div `
43
48
  pointer-events: none;
44
49
  transition: opacity 0.3s;
45
50
 
46
- ${IconBox} {
51
+ .citric-icon {
47
52
  background-color: ${theme.color.light[300]};
48
53
  border-radius: 50%;
49
54
  width: 16px;
@@ -83,8 +88,11 @@ const OverflowBox = styled.div `
83
88
  width: unset;
84
89
  }
85
90
  `;
86
- const SCROLL_INTERVAL_MS = 20;
87
- const SCROLL_PX = 4;
91
+ /**
92
+ * This component applies a fading graphical effect to its content if it overflows in any of the sides specified by the props.
93
+ *
94
+ * This also controls how this overflow is scrolled, introducing a new scrolling technique, which applies arrows to the overflowing side.
95
+ */
88
96
  export const FadingOverflow = ({ children, scroll = 'none', sides, enableHorizontalScrollWithVerticalWheel, className, ...props }) => {
89
97
  const ref = useRef(null);
90
98
  useEffect(() => {
@@ -211,6 +219,6 @@ export const FadingOverflow = ({ children, scroll = 'none', sides, enableHorizon
211
219
  element.addEventListener('wheel', scrollWithWheel);
212
220
  return () => element.removeEventListener('wheel', scrollWithWheel);
213
221
  }, [ref.current, enableHorizontalScrollWithVerticalWheel]);
214
- return scroll === 'arrows' ? (_jsxs(OverflowBox, { ...props, className: listToClass(['scroll-arrows', className]), children: [_jsx("div", { className: "content", ref: ref, children: children }), _jsx("div", { className: "scroll-to-left", "aria-hidden": true, children: _jsx(IconBox, { size: "xs", children: _jsx(ChevronLeft, {}) }) }), _jsx("div", { className: "scroll-to-right", "aria-hidden": true, children: _jsx(IconBox, { size: "xs", children: _jsx(ChevronRight, {}) }) }), _jsx("div", { className: "scroll-to-top", "aria-hidden": true, children: _jsx(IconBox, { size: "xs", children: _jsx(ChevronUp, {}) }) }), _jsx("div", { className: "scroll-to-bottom", "aria-hidden": true, children: _jsx(IconBox, { size: "xs", children: _jsx(ChevronDown, {}) }) })] })) : _jsx(OverflowBox, { ...props, className: className, ref: ref, children: children });
222
+ return scroll === 'arrows' ? (_jsxs(OverflowBox, { ...props, className: listToClass(['scroll-arrows', className]), children: [_jsx("div", { className: "content", ref: ref, children: children }), _jsx("div", { className: "scroll-to-left", "aria-hidden": true, children: _jsx(Icon, { icon: "ChevronLeft", size: "xs" }) }), _jsx("div", { className: "scroll-to-right", "aria-hidden": true, children: _jsx(Icon, { icon: "ChevronRight", size: "xs" }) }), _jsx("div", { className: "scroll-to-top", "aria-hidden": true, children: _jsx(Icon, { icon: "ChevronUp", size: "xs" }) }), _jsx("div", { className: "scroll-to-bottom", "aria-hidden": true, children: _jsx(Icon, { icon: "ChevronDown", size: "xs" }) })] })) : _jsx(OverflowBox, { ...props, className: className, ref: ref, children: children });
215
223
  };
216
224
  //# sourceMappingURL=FadingOverflow.js.map