@stack-spot/ai-chat-widget 0.11.0 → 1.1.0

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 (347) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/dist/StackspotAIWidget.d.ts +20 -0
  3. package/dist/StackspotAIWidget.d.ts.map +1 -1
  4. package/dist/StackspotAIWidget.js +7 -3
  5. package/dist/StackspotAIWidget.js.map +1 -1
  6. package/dist/chat-interceptors/CustomInputs.d.ts +4 -1
  7. package/dist/chat-interceptors/CustomInputs.d.ts.map +1 -1
  8. package/dist/chat-interceptors/CustomInputs.js +10 -1
  9. package/dist/chat-interceptors/CustomInputs.js.map +1 -1
  10. package/dist/chat-interceptors/quick-command-questions.d.ts +10 -0
  11. package/dist/chat-interceptors/quick-command-questions.d.ts.map +1 -1
  12. package/dist/chat-interceptors/quick-command-questions.js +12 -2
  13. package/dist/chat-interceptors/quick-command-questions.js.map +1 -1
  14. package/dist/chat-interceptors/quick-commands.d.ts +11 -0
  15. package/dist/chat-interceptors/quick-commands.d.ts.map +1 -1
  16. package/dist/chat-interceptors/quick-commands.js +65 -25
  17. package/dist/chat-interceptors/quick-commands.js.map +1 -1
  18. package/dist/chat-interceptors/send-message.d.ts +10 -0
  19. package/dist/chat-interceptors/send-message.d.ts.map +1 -1
  20. package/dist/chat-interceptors/send-message.js +32 -10
  21. package/dist/chat-interceptors/send-message.js.map +1 -1
  22. package/dist/components/Accordion.d.ts +10 -0
  23. package/dist/components/Accordion.d.ts.map +1 -1
  24. package/dist/components/Accordion.js +3 -0
  25. package/dist/components/Accordion.js.map +1 -1
  26. package/dist/components/AdaptiveTextArea.d.ts +13 -1
  27. package/dist/components/AdaptiveTextArea.d.ts.map +1 -1
  28. package/dist/components/AdaptiveTextArea.js +9 -4
  29. package/dist/components/AdaptiveTextArea.js.map +1 -1
  30. package/dist/components/AutoFocus.d.ts +23 -0
  31. package/dist/components/AutoFocus.d.ts.map +1 -0
  32. package/dist/components/AutoFocus.js +16 -0
  33. package/dist/components/AutoFocus.js.map +1 -0
  34. package/dist/components/Fading.d.ts +32 -0
  35. package/dist/components/Fading.d.ts.map +1 -0
  36. package/dist/components/Fading.js +33 -0
  37. package/dist/components/Fading.js.map +1 -0
  38. package/dist/components/FadingOverflow.d.ts +25 -0
  39. package/dist/components/FadingOverflow.d.ts.map +1 -1
  40. package/dist/components/FadingOverflow.js +11 -2
  41. package/dist/components/FadingOverflow.js.map +1 -1
  42. package/dist/components/FallbackBoundary/ErrorBoundary.d.ts +3 -0
  43. package/dist/components/FallbackBoundary/ErrorBoundary.d.ts.map +1 -1
  44. package/dist/components/FallbackBoundary/ErrorBoundary.js +18 -4
  45. package/dist/components/FallbackBoundary/ErrorBoundary.js.map +1 -1
  46. package/dist/components/FallbackBoundary/Loading.js +1 -1
  47. package/dist/components/FallbackBoundary/Loading.js.map +1 -1
  48. package/dist/components/FallbackBoundary/index.d.ts +12 -1
  49. package/dist/components/FallbackBoundary/index.d.ts.map +1 -1
  50. package/dist/components/FallbackBoundary/index.js +1 -1
  51. package/dist/components/FallbackBoundary/index.js.map +1 -1
  52. package/dist/components/HistoryList.d.ts +15 -0
  53. package/dist/components/HistoryList.d.ts.map +1 -1
  54. package/dist/components/HistoryList.js +3 -1
  55. package/dist/components/HistoryList.js.map +1 -1
  56. package/dist/components/IconInput.d.ts +3 -0
  57. package/dist/components/IconInput.d.ts.map +1 -1
  58. package/dist/components/IconInput.js +3 -0
  59. package/dist/components/IconInput.js.map +1 -1
  60. package/dist/components/OverlayMenu.d.ts +12 -1
  61. package/dist/components/OverlayMenu.d.ts.map +1 -1
  62. package/dist/components/OverlayMenu.js +31 -10
  63. package/dist/components/OverlayMenu.js.map +1 -1
  64. package/dist/components/ProgressBar.d.ts +22 -0
  65. package/dist/components/ProgressBar.d.ts.map +1 -1
  66. package/dist/components/ProgressBar.js +5 -0
  67. package/dist/components/ProgressBar.js.map +1 -1
  68. package/dist/components/QuickStartButton.d.ts.map +1 -1
  69. package/dist/components/QuickStartButton.js +3 -0
  70. package/dist/components/QuickStartButton.js.map +1 -1
  71. package/dist/components/RightPanelForm.d.ts +3 -0
  72. package/dist/components/RightPanelForm.d.ts.map +1 -1
  73. package/dist/components/RightPanelForm.js +8 -4
  74. package/dist/components/RightPanelForm.js.map +1 -1
  75. package/dist/components/RightPanelTabs.d.ts +3 -0
  76. package/dist/components/RightPanelTabs.d.ts.map +1 -1
  77. package/dist/components/RightPanelTabs.js +3 -0
  78. package/dist/components/RightPanelTabs.js.map +1 -1
  79. package/dist/components/TabManager.d.ts +6 -0
  80. package/dist/components/TabManager.d.ts.map +1 -1
  81. package/dist/components/TabManager.js +8 -0
  82. package/dist/components/TabManager.js.map +1 -1
  83. package/dist/components/Tooltip/Tooltip.d.ts +26 -1
  84. package/dist/components/Tooltip/Tooltip.d.ts.map +1 -1
  85. package/dist/components/Tooltip/Tooltip.js +18 -5
  86. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  87. package/dist/components/Tooltip/TooltipAPI.d.ts +18 -2
  88. package/dist/components/Tooltip/TooltipAPI.d.ts.map +1 -1
  89. package/dist/components/Tooltip/TooltipAPI.js +68 -51
  90. package/dist/components/Tooltip/TooltipAPI.js.map +1 -1
  91. package/dist/components/Tooltip/types.d.ts +13 -0
  92. package/dist/components/Tooltip/types.d.ts.map +1 -1
  93. package/dist/components/form/DescribedCheckboxGroup.d.ts +4 -0
  94. package/dist/components/form/DescribedCheckboxGroup.d.ts.map +1 -1
  95. package/dist/components/form/DescribedCheckboxGroup.js +4 -0
  96. package/dist/components/form/DescribedCheckboxGroup.js.map +1 -1
  97. package/dist/components/form/DescribedRadioGroup.d.ts +4 -0
  98. package/dist/components/form/DescribedRadioGroup.d.ts.map +1 -1
  99. package/dist/components/form/DescribedRadioGroup.js +4 -0
  100. package/dist/components/form/DescribedRadioGroup.js.map +1 -1
  101. package/dist/components/form/types.d.ts +34 -0
  102. package/dist/components/form/types.d.ts.map +1 -1
  103. package/dist/context/AIWidgetProvider.d.ts +19 -0
  104. package/dist/context/AIWidgetProvider.d.ts.map +1 -1
  105. package/dist/context/AIWidgetProvider.js +19 -0
  106. package/dist/context/AIWidgetProvider.js.map +1 -1
  107. package/dist/context/hooks.d.ts +56 -0
  108. package/dist/context/hooks.d.ts.map +1 -1
  109. package/dist/context/hooks.js +56 -1
  110. package/dist/context/hooks.js.map +1 -1
  111. package/dist/features.d.ts +28 -0
  112. package/dist/features.d.ts.map +1 -1
  113. package/dist/features.js +1 -0
  114. package/dist/features.js.map +1 -1
  115. package/dist/layout.css +5 -0
  116. package/dist/regex.d.ts +2 -0
  117. package/dist/regex.d.ts.map +1 -0
  118. package/dist/regex.js +2 -0
  119. package/dist/regex.js.map +1 -0
  120. package/dist/right-panel/DefaultPanel.d.ts +3 -0
  121. package/dist/right-panel/DefaultPanel.d.ts.map +1 -1
  122. package/dist/right-panel/DefaultPanel.js +3 -0
  123. package/dist/right-panel/DefaultPanel.js.map +1 -1
  124. package/dist/right-panel/RightPanel.d.ts +3 -0
  125. package/dist/right-panel/RightPanel.d.ts.map +1 -1
  126. package/dist/right-panel/RightPanel.js +3 -0
  127. package/dist/right-panel/RightPanel.js.map +1 -1
  128. package/dist/right-panel/RightPanelProvider.d.ts +15 -0
  129. package/dist/right-panel/RightPanelProvider.d.ts.map +1 -1
  130. package/dist/right-panel/RightPanelProvider.js.map +1 -1
  131. package/dist/right-panel/constants.d.ts +2 -0
  132. package/dist/right-panel/constants.d.ts.map +1 -0
  133. package/dist/right-panel/constants.js +2 -0
  134. package/dist/right-panel/constants.js.map +1 -0
  135. package/dist/right-panel/hooks.d.ts +6 -0
  136. package/dist/right-panel/hooks.d.ts.map +1 -1
  137. package/dist/right-panel/hooks.js +8 -1
  138. package/dist/right-panel/hooks.js.map +1 -1
  139. package/dist/state/ChatEntry.d.ts +58 -2
  140. package/dist/state/ChatEntry.d.ts.map +1 -1
  141. package/dist/state/ChatEntry.js +20 -1
  142. package/dist/state/ChatEntry.js.map +1 -1
  143. package/dist/state/ChatState.d.ts +73 -8
  144. package/dist/state/ChatState.d.ts.map +1 -1
  145. package/dist/state/ChatState.js +24 -7
  146. package/dist/state/ChatState.js.map +1 -1
  147. package/dist/state/ChatTabsController.d.ts +31 -0
  148. package/dist/state/ChatTabsController.d.ts.map +1 -1
  149. package/dist/state/ChatTabsController.js +31 -0
  150. package/dist/state/ChatTabsController.js.map +1 -1
  151. package/dist/state/ObservableState.d.ts +14 -0
  152. package/dist/state/ObservableState.d.ts.map +1 -1
  153. package/dist/state/ObservableState.js +14 -0
  154. package/dist/state/ObservableState.js.map +1 -1
  155. package/dist/state/WidgetState.d.ts +5 -0
  156. package/dist/state/WidgetState.d.ts.map +1 -1
  157. package/dist/state/WidgetState.js +5 -0
  158. package/dist/state/WidgetState.js.map +1 -1
  159. package/dist/types.d.ts +10 -0
  160. package/dist/types.d.ts.map +1 -1
  161. package/dist/utils/chat.d.ts +13 -0
  162. package/dist/utils/chat.d.ts.map +1 -1
  163. package/dist/utils/chat.js +15 -1
  164. package/dist/utils/chat.js.map +1 -1
  165. package/dist/utils/date.d.ts +25 -0
  166. package/dist/utils/date.d.ts.map +1 -1
  167. package/dist/utils/date.js +25 -0
  168. package/dist/utils/date.js.map +1 -1
  169. package/dist/utils/download.d.ts +5 -0
  170. package/dist/utils/download.d.ts.map +1 -1
  171. package/dist/utils/download.js +5 -0
  172. package/dist/utils/download.js.map +1 -1
  173. package/dist/utils/knowledge-source.d.ts +10 -0
  174. package/dist/utils/knowledge-source.d.ts.map +1 -1
  175. package/dist/utils/knowledge-source.js +16 -0
  176. package/dist/utils/knowledge-source.js.map +1 -1
  177. package/dist/utils/string.d.ts +5 -0
  178. package/dist/utils/string.d.ts.map +1 -1
  179. package/dist/utils/string.js +5 -1
  180. package/dist/utils/string.js.map +1 -1
  181. package/dist/utils/url.d.ts +2 -0
  182. package/dist/utils/url.d.ts.map +1 -0
  183. package/dist/utils/url.js +8 -0
  184. package/dist/utils/url.js.map +1 -0
  185. package/dist/views/Agents.js +3 -0
  186. package/dist/views/Agents.js.map +1 -1
  187. package/dist/views/Chat/AgentInfo.d.ts +3 -0
  188. package/dist/views/Chat/AgentInfo.d.ts.map +1 -1
  189. package/dist/views/Chat/AgentInfo.js +3 -0
  190. package/dist/views/Chat/AgentInfo.js.map +1 -1
  191. package/dist/views/Chat/ChatMessage.d.ts +17 -2
  192. package/dist/views/Chat/ChatMessage.d.ts.map +1 -1
  193. package/dist/views/Chat/ChatMessage.js +9 -13
  194. package/dist/views/Chat/ChatMessage.js.map +1 -1
  195. package/dist/views/Chat/ChatMessages.d.ts +3 -0
  196. package/dist/views/Chat/ChatMessages.d.ts.map +1 -1
  197. package/dist/views/Chat/ChatMessages.js +3 -0
  198. package/dist/views/Chat/ChatMessages.js.map +1 -1
  199. package/dist/views/Chat/chat-scroll.d.ts +1 -1
  200. package/dist/views/Chat/chat-scroll.js +1 -1
  201. package/dist/views/Chat/events.d.ts +22 -0
  202. package/dist/views/Chat/events.d.ts.map +1 -0
  203. package/dist/views/Chat/events.js +66 -0
  204. package/dist/views/Chat/events.js.map +1 -0
  205. package/dist/views/Chat/index.d.ts +6 -0
  206. package/dist/views/Chat/index.d.ts.map +1 -1
  207. package/dist/views/Chat/index.js +3 -0
  208. package/dist/views/Chat/index.js.map +1 -1
  209. package/dist/views/ChatHistory/ChatHistoryPanel.d.ts +3 -0
  210. package/dist/views/ChatHistory/ChatHistoryPanel.d.ts.map +1 -1
  211. package/dist/views/ChatHistory/ChatHistoryPanel.js +5 -1
  212. package/dist/views/ChatHistory/ChatHistoryPanel.js.map +1 -1
  213. package/dist/views/ChatHistory/HistoryItem.d.ts +3 -0
  214. package/dist/views/ChatHistory/HistoryItem.d.ts.map +1 -1
  215. package/dist/views/ChatHistory/HistoryItem.js +13 -1
  216. package/dist/views/ChatHistory/HistoryItem.js.map +1 -1
  217. package/dist/views/ChatHistory/index.d.ts +10 -2
  218. package/dist/views/ChatHistory/index.d.ts.map +1 -1
  219. package/dist/views/ChatHistory/index.js +3 -0
  220. package/dist/views/ChatHistory/index.js.map +1 -1
  221. package/dist/views/ChatHistory/utils.d.ts +14 -0
  222. package/dist/views/ChatHistory/utils.d.ts.map +1 -1
  223. package/dist/views/ChatHistory/utils.js +14 -0
  224. package/dist/views/ChatHistory/utils.js.map +1 -1
  225. package/dist/views/ChatTabSelection.d.ts +3 -0
  226. package/dist/views/ChatTabSelection.d.ts.map +1 -1
  227. package/dist/views/ChatTabSelection.js +3 -0
  228. package/dist/views/ChatTabSelection.js.map +1 -1
  229. package/dist/views/Editor.d.ts +3 -0
  230. package/dist/views/Editor.d.ts.map +1 -1
  231. package/dist/views/Editor.js +4 -0
  232. package/dist/views/Editor.js.map +1 -1
  233. package/dist/views/Home.d.ts +8 -0
  234. package/dist/views/Home.d.ts.map +1 -1
  235. package/dist/views/Home.js +5 -0
  236. package/dist/views/Home.js.map +1 -1
  237. package/dist/views/KSDocument.d.ts +3 -0
  238. package/dist/views/KSDocument.d.ts.map +1 -1
  239. package/dist/views/KSDocument.js +3 -0
  240. package/dist/views/KSDocument.js.map +1 -1
  241. package/dist/views/KnowledgeSources.js +3 -0
  242. package/dist/views/KnowledgeSources.js.map +1 -1
  243. package/dist/views/MessageInput/ButtonGroup.d.ts +22 -0
  244. package/dist/views/MessageInput/ButtonGroup.d.ts.map +1 -1
  245. package/dist/views/MessageInput/ButtonGroup.js +4 -0
  246. package/dist/views/MessageInput/ButtonGroup.js.map +1 -1
  247. package/dist/views/MessageInput/InfoBar.d.ts +7 -0
  248. package/dist/views/MessageInput/InfoBar.d.ts.map +1 -1
  249. package/dist/views/MessageInput/InfoBar.js +7 -0
  250. package/dist/views/MessageInput/InfoBar.js.map +1 -1
  251. package/dist/views/MessageInput/QuickCommandSelector.d.ts +13 -0
  252. package/dist/views/MessageInput/QuickCommandSelector.d.ts.map +1 -0
  253. package/dist/views/MessageInput/QuickCommandSelector.js +141 -0
  254. package/dist/views/MessageInput/QuickCommandSelector.js.map +1 -0
  255. package/dist/views/MessageInput/index.d.ts +8 -0
  256. package/dist/views/MessageInput/index.d.ts.map +1 -1
  257. package/dist/views/MessageInput/index.js +11 -4
  258. package/dist/views/MessageInput/index.js.map +1 -1
  259. package/dist/views/MessageInput/styled.d.ts.map +1 -1
  260. package/dist/views/MessageInput/styled.js +137 -0
  261. package/dist/views/MessageInput/styled.js.map +1 -1
  262. package/dist/views/MinimizedHeader.d.ts +4 -0
  263. package/dist/views/MinimizedHeader.d.ts.map +1 -1
  264. package/dist/views/MinimizedHeader.js +4 -0
  265. package/dist/views/MinimizedHeader.js.map +1 -1
  266. package/dist/views/Stacks.d.ts +3 -0
  267. package/dist/views/Stacks.d.ts.map +1 -1
  268. package/dist/views/Stacks.js +3 -0
  269. package/dist/views/Stacks.js.map +1 -1
  270. package/dist/views/Workspaces.d.ts +3 -0
  271. package/dist/views/Workspaces.d.ts.map +1 -1
  272. package/dist/views/Workspaces.js +3 -0
  273. package/dist/views/Workspaces.js.map +1 -1
  274. package/package.json +6 -6
  275. package/src/StackspotAIWidget.tsx +23 -2
  276. package/src/chat-interceptors/CustomInputs.ts +14 -1
  277. package/src/chat-interceptors/quick-command-questions.ts +12 -2
  278. package/src/chat-interceptors/quick-commands.ts +66 -26
  279. package/src/chat-interceptors/send-message.ts +41 -11
  280. package/src/components/Accordion.tsx +10 -0
  281. package/src/components/AdaptiveTextArea.tsx +21 -4
  282. package/src/components/AutoFocus.tsx +34 -0
  283. package/src/components/Fading.tsx +66 -0
  284. package/src/components/FadingOverflow.tsx +31 -3
  285. package/src/components/FallbackBoundary/ErrorBoundary.tsx +26 -3
  286. package/src/components/FallbackBoundary/Loading.tsx +1 -1
  287. package/src/components/FallbackBoundary/index.tsx +13 -2
  288. package/src/components/HistoryList.tsx +15 -1
  289. package/src/components/IconInput.tsx +3 -0
  290. package/src/components/OverlayMenu.tsx +76 -20
  291. package/src/components/ProgressBar.tsx +23 -0
  292. package/src/components/QuickStartButton.tsx +3 -0
  293. package/src/components/RightPanelForm.tsx +15 -9
  294. package/src/components/RightPanelTabs.tsx +3 -0
  295. package/src/components/TabManager.tsx +8 -0
  296. package/src/components/Tooltip/Tooltip.tsx +47 -5
  297. package/src/components/Tooltip/TooltipAPI.ts +59 -42
  298. package/src/components/Tooltip/types.ts +13 -0
  299. package/src/components/form/DescribedCheckboxGroup.tsx +4 -0
  300. package/src/components/form/DescribedRadioGroup.tsx +4 -0
  301. package/src/components/form/types.ts +34 -0
  302. package/src/context/AIWidgetProvider.tsx +19 -0
  303. package/src/context/hooks.ts +56 -1
  304. package/src/features.ts +29 -0
  305. package/src/layout.css +5 -0
  306. package/src/regex.ts +1 -0
  307. package/src/right-panel/DefaultPanel.tsx +4 -0
  308. package/src/right-panel/RightPanel.tsx +3 -0
  309. package/src/right-panel/RightPanelProvider.tsx +15 -0
  310. package/src/right-panel/constants.ts +1 -0
  311. package/src/right-panel/hooks.tsx +8 -1
  312. package/src/state/ChatEntry.ts +60 -2
  313. package/src/state/ChatState.ts +74 -9
  314. package/src/state/ChatTabsController.ts +31 -0
  315. package/src/state/ObservableState.ts +14 -0
  316. package/src/state/WidgetState.ts +5 -0
  317. package/src/types.ts +10 -0
  318. package/src/utils/chat.ts +15 -1
  319. package/src/utils/date.ts +25 -1
  320. package/src/utils/download.ts +5 -0
  321. package/src/utils/knowledge-source.ts +16 -0
  322. package/src/utils/string.ts +5 -1
  323. package/src/utils/url.ts +8 -0
  324. package/src/views/Agents.tsx +3 -0
  325. package/src/views/Chat/AgentInfo.tsx +3 -0
  326. package/src/views/Chat/ChatMessage.tsx +31 -18
  327. package/src/views/Chat/ChatMessages.tsx +3 -0
  328. package/src/views/Chat/chat-scroll.ts +1 -1
  329. package/src/views/Chat/events.ts +69 -0
  330. package/src/views/Chat/index.tsx +6 -0
  331. package/src/views/ChatHistory/ChatHistoryPanel.tsx +6 -2
  332. package/src/views/ChatHistory/HistoryItem.tsx +14 -2
  333. package/src/views/ChatHistory/index.tsx +11 -1
  334. package/src/views/ChatHistory/utils.ts +14 -0
  335. package/src/views/ChatTabSelection.tsx +3 -0
  336. package/src/views/Editor.tsx +4 -0
  337. package/src/views/Home.tsx +8 -0
  338. package/src/views/KSDocument.tsx +3 -0
  339. package/src/views/KnowledgeSources.tsx +3 -0
  340. package/src/views/MessageInput/ButtonGroup.tsx +22 -0
  341. package/src/views/MessageInput/InfoBar.tsx +7 -0
  342. package/src/views/MessageInput/QuickCommandSelector.tsx +217 -0
  343. package/src/views/MessageInput/index.tsx +16 -4
  344. package/src/views/MessageInput/styled.ts +137 -0
  345. package/src/views/MinimizedHeader.tsx +4 -0
  346. package/src/views/Stacks.tsx +3 -0
  347. package/src/views/Workspaces.tsx +3 -0
@@ -1,8 +1,9 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- /* eslint-disable no-empty-pattern */
2
+ /* eslint-disable react/display-name */
3
3
  import { IconBox, Text } from '@citric/core';
4
+ import { useKeyboardControls } from '@stack-spot/portal-components';
4
5
  import { theme } from '@stack-spot/portal-theme';
5
- import { useMemo } from 'react';
6
+ import { forwardRef, useCallback, useRef } from 'react';
6
7
  import { styled } from 'styled-components';
7
8
  import { Tooltip } from './Tooltip/index.js';
8
9
  import { useTooltip } from './Tooltip/context.js';
@@ -30,8 +31,9 @@ const MenuList = styled.ul `
30
31
  gap: 8px;
31
32
  background-color: transparent;
32
33
  border: none;
34
+ outline: none;
33
35
 
34
- &:hover {
36
+ &:hover, &:focus {
35
37
  background-color: ${theme.color.light[500]};
36
38
  }
37
39
  }
@@ -44,15 +46,34 @@ const StyledButton = styled.button `
44
46
  fill: ${({ $color }) => $color || theme.color.light.contrastText};
45
47
  }
46
48
  `;
47
- export const OverlayMenu = ({ actions, children, className, position, style }) => {
49
+ const Menu = ({ actions, trigger }) => {
48
50
  const tooltip = useTooltip();
49
- const menu = useMemo(() => {
50
- const items = actions.map(({ label, onClick, className, color, icon, style }) => (_jsx("li", { className: className, style: style, children: _jsxs(StyledButton, { "$color": color, onClick: () => {
51
+ const ref = useRef(null);
52
+ useKeyboardControls({
53
+ querySelectors: 'button',
54
+ onPressEscape: () => {
55
+ tooltip.hide();
56
+ trigger.current?.focus();
57
+ },
58
+ ref,
59
+ }, []);
60
+ return (_jsx(MenuList, { ref: ref, children: actions.map(({ label, onClick, className, color, icon, style }) => (_jsx("li", { className: className, style: style, children: _jsxs(StyledButton, { "$color": color, onClick: () => {
51
61
  onClick();
52
62
  tooltip.hide();
53
- }, children: [_jsx(IconBox, { children: icon }), _jsx(Text, { children: label })] }) }, label)));
54
- return _jsx(MenuList, { children: items });
55
- }, [actions]);
56
- return (_jsx(Tooltip, { content: menu, custom: true, position: position, className: className, style: style, triggeredBy: "click", children: children }));
63
+ }, children: [_jsx(IconBox, { children: icon }), _jsx(Text, { children: label })] }) }, label))) }));
57
64
  };
65
+ /**
66
+ * A floating menu that shows up when the user clicks the children.
67
+ *
68
+ * This uses the tooltip component to build the menu.
69
+ */
70
+ export const OverlayMenu = forwardRef(({ actions, children, className, position, style }, externalRef) => {
71
+ const localRef = useRef(null);
72
+ const ref = externalRef ?? localRef;
73
+ const tooltip = useTooltip();
74
+ const onShow = useCallback(() => {
75
+ tooltip.tooltipRef.current?.querySelector('button')?.focus();
76
+ }, []);
77
+ return (_jsx(Tooltip, { content: _jsx(Menu, { actions: actions, trigger: ref }), custom: true, position: position, className: className, style: style, triggeredBy: "click", onShow: onShow, ref: ref, children: children }));
78
+ });
58
79
  //# sourceMappingURL=OverlayMenu.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"OverlayMenu.js","sourceRoot":"","sources":["../../src/components/OverlayMenu.tsx"],"names":[],"mappings":";AAAA,qCAAqC;AACrC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAa,MAAM,0BAA0B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAC/B,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAE1C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAQ9C,MAAM,QAAQ,GAAG,MAAM,CAAC,EAAE,CAAA;;;;;sBAKJ,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;;4BAqBhB,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;CAIjD,CAAA;AAED,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAgC;WACvD,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,IAAI,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;;YAGvD,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,IAAI,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;CAEnE,CAAA;AAED,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAS,EAAE,EAAE;IACtF,MAAM,OAAO,GAAG,UAAU,EAAE,CAAA;IAC5B,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,EAAE;QACxB,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAC/E,aAAgB,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,YAChD,MAAC,YAAY,cAAS,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE;oBACzC,OAAO,EAAE,CAAA;oBACT,OAAO,CAAC,IAAI,EAAE,CAAA;gBAChB,CAAC,aACC,KAAC,OAAO,cAAE,IAAI,GAAW,EACzB,KAAC,IAAI,cAAE,KAAK,GAAQ,IACP,IAPR,KAAK,CAQT,CACN,CAAC,CAAA;QACF,OAAO,KAAC,QAAQ,cAAE,KAAK,GAAY,CAAA;IACrC,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAA;IACb,OAAO,CACL,KAAC,OAAO,IAAC,OAAO,EAAE,IAAI,EAAE,MAAM,QAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,EAAC,OAAO,YACvG,QAAQ,GACD,CACX,CAAA;AACH,CAAC,CAAA"}
1
+ {"version":3,"file":"OverlayMenu.js","sourceRoot":"","sources":["../../src/components/OverlayMenu.tsx"],"names":[],"mappings":"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"}
@@ -1,11 +1,33 @@
1
1
  import { WithStyle } from '@stack-spot/portal-theme';
2
2
  interface Props extends WithStyle {
3
+ /**
4
+ * Whether or not the progress bar is visible.
5
+ */
3
6
  visible?: boolean;
7
+ /**
8
+ * When true, the progress bar becomes very colorful and bright.
9
+ */
4
10
  shimmer?: boolean;
11
+ /**
12
+ * Color to use in the progress bar that appears in the foreground. Arrays create linear gradients.
13
+ * @default primary.500 if shimmer is false, white otherwise.
14
+ */
5
15
  foregroundColor?: string | string[];
16
+ /**
17
+ * Color to use in the progress bar that appears in the background. Arrays create linear gradients.
18
+ * @default light.500 if shimmer is false, a transparent white otherwise.
19
+ */
6
20
  backgroundColor?: string | string[];
21
+ /**
22
+ * Only useful if `shimmer` is true. This allows to customize the colors in the shimmering effect. Arrays create linear gradients.
23
+ * @default ['#ff6633', '#d668cd', '#ff6633', '#FFF8', '#299cf4']
24
+ */
7
25
  shimmerColor?: string | string[];
8
26
  }
27
+ /**
28
+ * A progress bar with indefinite progress report. This renders a narrower bar on top of larger one that animates from the left to the
29
+ * right.
30
+ */
9
31
  export declare const ProgressBar: ({ visible, shimmer, backgroundColor, foregroundColor, shimmerColor, className, style, }: Props) => import("react/jsx-runtime").JSX.Element;
10
32
  export {};
11
33
  //# sourceMappingURL=ProgressBar.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"ProgressBar.d.ts","sourceRoot":"","sources":["../../src/components/ProgressBar.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAsB,SAAS,EAAE,MAAM,0BAA0B,CAAA;AAGxE,UAAU,KAAM,SAAQ,SAAS;IAC/B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,eAAe,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IACpC,eAAe,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IACpC,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;CAClC;AAoHD,eAAO,MAAM,WAAW,4FAQrB,KAAK,4CAmBP,CAAA"}
1
+ {"version":3,"file":"ProgressBar.d.ts","sourceRoot":"","sources":["../../src/components/ProgressBar.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAsB,SAAS,EAAE,MAAM,0BAA0B,CAAA;AAGxE,UAAU,KAAM,SAAQ,SAAS;IAC/B;;OAEG;IACH,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB;;OAEG;IACH,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB;;;OAGG;IACH,eAAe,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IACpC;;;OAGG;IACH,eAAe,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IACpC;;;OAGG;IACH,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;CAClC;AAqHD;;;GAGG;AACH,eAAO,MAAM,WAAW,4FAQrB,KAAK,4CAmBP,CAAA"}
@@ -13,6 +13,7 @@ function gradientFromColorArray(colors) {
13
13
  }
14
14
  return `linear-gradient(to right, ${partials.join(', ')})`;
15
15
  }
16
+ // the shimmering effect requires more space
16
17
  const SHIMMER_PADDING = '10px';
17
18
  const Styled = styled.div `
18
19
  margin: 7px 0;
@@ -113,6 +114,10 @@ const Styled = styled.div `
113
114
  }
114
115
  }
115
116
  `;
117
+ /**
118
+ * A progress bar with indefinite progress report. This renders a narrower bar on top of larger one that animates from the left to the
119
+ * right.
120
+ */
116
121
  export const ProgressBar = ({ visible = true, shimmer, backgroundColor = shimmer ? 'rgba(255, 255, 255, 0.4)' : theme.color.light[500], foregroundColor = shimmer ? ['#FFF0', '#FFF', '#FFF0'] : theme.color.primary[500], shimmerColor = ['#ff6633', '#d668cd', '#ff6633', '#FFF8', '#299cf4'], className, style, }) => {
117
122
  const $bg = Array.isArray(backgroundColor) ? backgroundColor : [backgroundColor];
118
123
  const $fg = Array.isArray(foregroundColor) ? foregroundColor : [...$bg, foregroundColor, ...$bg];
@@ -1 +1 @@
1
- {"version":3,"file":"ProgressBar.js","sourceRoot":"","sources":["../../src/components/ProgressBar.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"ProgressBar.js","sourceRoot":"","sources":["../../src/components/ProgressBar.tsx"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"QuickStartButton.d.ts","sourceRoot":"","sources":["../../src/components/QuickStartButton.tsx"],"names":[],"mappings":"AACA,OAAO,EAAS,SAAS,EAAE,MAAM,0BAA0B,CAAA;AAE3D,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAEvC,UAAU,KAAM,SAAQ,YAAY,EAAE,SAAS;IAC7C,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAsCD,eAAO,MAAM,gBAAgB,kEAAmE,KAAK,4CAKpG,CAAA"}
1
+ {"version":3,"file":"QuickStartButton.d.ts","sourceRoot":"","sources":["../../src/components/QuickStartButton.tsx"],"names":[],"mappings":"AACA,OAAO,EAAS,SAAS,EAAE,MAAM,0BAA0B,CAAA;AAE3D,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAEvC,UAAU,KAAM,SAAQ,YAAY,EAAE,SAAS;IAC7C,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAyCD,eAAO,MAAM,gBAAgB,kEAAmE,KAAK,4CAKpG,CAAA"}
@@ -2,6 +2,9 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { IconBox, Text } from '@citric/core';
3
3
  import { theme } from '@stack-spot/portal-theme';
4
4
  import { styled } from 'styled-components';
5
+ /**
6
+ * A button for quick starting a conversation.
7
+ */
5
8
  const QuickButton = styled.button `
6
9
  display: flex;
7
10
  flex-direction: column;
@@ -1 +1 @@
1
- {"version":3,"file":"QuickStartButton.js","sourceRoot":"","sources":["../../src/components/QuickStartButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAa,MAAM,0BAA0B,CAAA;AAC3D,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAO1C,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,CAAmC;;;;;sBAK9C,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;kBAM1B,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;oBAMpB,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;;;wBAQlB,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,IAAI,aAAa;MACnD,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM;IACxB,CAAC,CAAC;;gBAEU,MAAM;QACd;IACJ,CAAC,CAAC,EACN;;CAEC,CAAA;AAED,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAS,EAAE,EAAE,CAAC,CACxG,MAAC,WAAW,IAAC,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,YAAU,KAAK,SAAO,UAAU,aAC/F,KAAC,OAAO,mCAAc,IAAI,GAAW,EACrC,KAAC,IAAI,cAAE,KAAK,GAAQ,IACR,CACf,CAAA"}
1
+ {"version":3,"file":"QuickStartButton.js","sourceRoot":"","sources":["../../src/components/QuickStartButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAa,MAAM,0BAA0B,CAAA;AAC3D,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAO1C;;GAEG;AACH,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,CAAmC;;;;;sBAK9C,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;kBAM1B,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;oBAMpB,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;;;wBAQlB,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,IAAI,aAAa;MACnD,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM;IACxB,CAAC,CAAC;;gBAEU,MAAM;QACd;IACJ,CAAC,CAAC,EACN;;CAEC,CAAA;AAED,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAS,EAAE,EAAE,CAAC,CACxG,MAAC,WAAW,IAAC,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,YAAU,KAAK,SAAO,UAAU,aAC/F,KAAC,OAAO,mCAAc,IAAI,GAAW,EACrC,KAAC,IAAI,cAAE,KAAK,GAAQ,IACR,CACf,CAAA"}
@@ -1,5 +1,8 @@
1
1
  import { PropsOf } from '../types.js';
2
2
  declare const Form: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").FastOmit<import("react").DetailedHTMLProps<import("react").FormHTMLAttributes<HTMLFormElement>, HTMLFormElement>, never>> & string;
3
+ /**
4
+ * A form that goes into a right panel. This controls style, errors, loading focus and form submission.
5
+ */
3
6
  export declare const RightPanelForm: ({ children, onSubmit, ...props }: PropsOf<typeof Form>) => import("react/jsx-runtime").JSX.Element;
4
7
  export {};
5
8
  //# sourceMappingURL=RightPanelForm.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"RightPanelForm.d.ts","sourceRoot":"","sources":["../../src/components/RightPanelForm.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAA;AAGlC,QAAA,MAAM,IAAI,8OAmCT,CAAA;AAED,eAAO,MAAM,cAAc,qCAAsC,OAAO,CAAC,OAAO,IAAI,CAAC,4CAYpF,CAAA"}
1
+ {"version":3,"file":"RightPanelForm.d.ts","sourceRoot":"","sources":["../../src/components/RightPanelForm.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAA;AAIlC,QAAA,MAAM,IAAI,8OAmCT,CAAA;AAED;;GAEG;AACH,eAAO,MAAM,cAAc,qCAAsC,OAAO,CAAC,OAAO,IAAI,CAAC,4CAcpF,CAAA"}
@@ -1,6 +1,7 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
2
  import { Card } from '@citric/ui';
3
3
  import { styled } from 'styled-components';
4
+ import { AutoFocus } from './AutoFocus.js';
4
5
  import { FallbackBoundary } from './FallbackBoundary/index.js';
5
6
  const Form = styled.form `
6
7
  display: flex;
@@ -38,8 +39,11 @@ const Form = styled.form `
38
39
  fill: transparent;
39
40
  }
40
41
  `;
41
- export const RightPanelForm = ({ children, onSubmit, ...props }) => (_jsx(FallbackBoundary, { children: _jsx(Form, { ...props, onSubmit: (e) => {
42
- e.preventDefault();
43
- onSubmit?.(e);
44
- }, children: children }) }));
42
+ /**
43
+ * A form that goes into a right panel. This controls style, errors, loading focus and form submission.
44
+ */
45
+ export const RightPanelForm = ({ children, onSubmit, ...props }) => (_jsx(FallbackBoundary, { children: _jsx(AutoFocus, { children: _jsx(Form, { ...props, onSubmit: (e) => {
46
+ e.preventDefault();
47
+ onSubmit?.(e);
48
+ }, children: children }) }) }));
45
49
  //# sourceMappingURL=RightPanelForm.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"RightPanelForm.js","sourceRoot":"","sources":["../../src/components/RightPanelForm.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,YAAY,CAAA;AACjC,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAE1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AAErD,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAgCpB,IAAI;;;CAGP,CAAA;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,KAAK,EAAwB,EAAE,EAAE,CAAC,CACxF,KAAC,gBAAgB,cACf,KAAC,IAAI,OACC,KAAK,EACT,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE;YACd,CAAC,CAAC,cAAc,EAAE,CAAA;YAClB,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAA;QACf,CAAC,YAEA,QAAQ,GACJ,GACU,CACpB,CAAA"}
1
+ {"version":3,"file":"RightPanelForm.js","sourceRoot":"","sources":["../../src/components/RightPanelForm.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,YAAY,CAAA;AACjC,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAE1C,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AAErD,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAgCpB,IAAI;;;CAGP,CAAA;AAED;;GAEG;AACH,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,KAAK,EAAwB,EAAE,EAAE,CAAC,CACxF,KAAC,gBAAgB,cACf,KAAC,SAAS,cACR,KAAC,IAAI,OACC,KAAK,EACT,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE;gBACd,CAAC,CAAC,cAAc,EAAE,CAAA;gBAClB,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAA;YACf,CAAC,YAEA,QAAQ,GACJ,GACG,GACK,CACpB,CAAA"}
@@ -5,6 +5,9 @@ interface Tab {
5
5
  interface Props {
6
6
  tabs: Tab[];
7
7
  }
8
+ /**
9
+ * Tabs for the right panel content.
10
+ */
8
11
  export declare const RightPanelTabs: ({ tabs }: Props) => import("react/jsx-runtime").JSX.Element;
9
12
  export {};
10
13
  //# sourceMappingURL=RightPanelTabs.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"RightPanelTabs.d.ts","sourceRoot":"","sources":["../../src/components/RightPanelTabs.tsx"],"names":[],"mappings":"AAKA,UAAU,GAAG;IACX,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;CAC1B;AAED,UAAU,KAAK;IACb,IAAI,EAAE,GAAG,EAAE,CAAC;CACb;AAcD,eAAO,MAAM,cAAc,aAAc,KAAK,4CAa7C,CAAA"}
1
+ {"version":3,"file":"RightPanelTabs.d.ts","sourceRoot":"","sources":["../../src/components/RightPanelTabs.tsx"],"names":[],"mappings":"AAKA,UAAU,GAAG;IACX,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;CAC1B;AAED,UAAU,KAAK;IACb,IAAI,EAAE,GAAG,EAAE,CAAC;CACb;AAcD;;GAEG;AACH,eAAO,MAAM,cAAc,aAAc,KAAK,4CAa7C,CAAA"}
@@ -13,6 +13,9 @@ const StyledTabsItem = styled(TabsItem) `
13
13
  flex: 1;
14
14
  overflow: hidden;
15
15
  `;
16
+ /**
17
+ * Tabs for the right panel content.
18
+ */
16
19
  export const RightPanelTabs = ({ tabs }) => {
17
20
  const [currentTab, setCurrentTab] = useState(0);
18
21
  const tabItems = useMemo(() => tabs.map(({ content, title }) => (_jsx(StyledTabsItem, { title: title, children: _jsx(RightPanelForm, { children: content }) }, title))), [tabs]);
@@ -1 +1 @@
1
- {"version":3,"file":"RightPanelTabs.js","sourceRoot":"","sources":["../../src/components/RightPanelTabs.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAC3C,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,MAAM,MAAM,mBAAmB,CAAA;AACtC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAWjD,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,CAAA;;;;;CAK9B,CAAA;AAED,MAAM,cAAc,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAA;;;CAGtC,CAAA;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAAE,IAAI,EAAS,EAAE,EAAE;IAChD,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IAC/C,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAC9D,KAAC,cAAc,IAAa,KAAK,EAAE,KAAK,YACtC,KAAC,cAAc,cAAE,OAAO,GAAkB,IADvB,KAAK,CAET,CAClB,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAEX,OAAO,CACL,KAAC,UAAU,IAAC,WAAW,EAAE,UAAU,EAAE,QAAQ,EAAE,aAAa,YACzD,QAAQ,GACE,CACd,CAAA;AACH,CAAC,CAAA"}
1
+ {"version":3,"file":"RightPanelTabs.js","sourceRoot":"","sources":["../../src/components/RightPanelTabs.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAC3C,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,MAAM,MAAM,mBAAmB,CAAA;AACtC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAWjD,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,CAAA;;;;;CAK9B,CAAA;AAED,MAAM,cAAc,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAA;;;CAGtC,CAAA;AAED;;GAEG;AACH,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAAE,IAAI,EAAS,EAAE,EAAE;IAChD,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IAC/C,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAC9D,KAAC,cAAc,IAAa,KAAK,EAAE,KAAK,YACtC,KAAC,cAAc,cAAE,OAAO,GAAkB,IADvB,KAAK,CAET,CAClB,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAEX,OAAO,CACL,KAAC,UAAU,IAAC,WAAW,EAAE,UAAU,EAAE,QAAQ,EAAE,aAAa,YACzD,QAAQ,GACE,CACd,CAAA;AACH,CAAC,CAAA"}
@@ -29,6 +29,12 @@ interface Props<T, Key extends React.Key> {
29
29
  */
30
30
  renderLabel: (tab: T) => React.ReactElement;
31
31
  }
32
+ /**
33
+ * Renders and manages a list of tabs. With this, tabs can be selected and removed. Furthermore, extra buttons can be placed after all tabs,
34
+ * e.g. a button to add more tabs.
35
+ *
36
+ * Used for the chat tabs.
37
+ */
32
38
  export declare function TabManager<T, Key extends React.Key>({ active, tabs, keygen, onRemove, onSelect, renderLabel, buttons }: Props<T, Key>): import("react/jsx-runtime").JSX.Element;
33
39
  export {};
34
40
  //# sourceMappingURL=TabManager.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"TabManager.d.ts","sourceRoot":"","sources":["../../src/components/TabManager.tsx"],"names":[],"mappings":"AASA,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAGvC,UAAU,KAAK,CAAC,CAAC,EAAE,GAAG,SAAS,KAAK,CAAC,GAAG;IACtC;;OAEG;IACH,IAAI,EAAE,CAAC,EAAE,CAAC;IACV;;OAEG;IACH,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,GAAG,CAAC;IACxB;;OAEG;IACH,MAAM,EAAE,GAAG,CAAC;IACZ;;OAEG;IACH,QAAQ,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,CAAC;IAC3B;;OAEG;IACH,QAAQ,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,CAAC;IAC3B;;OAEG;IACH,OAAO,CAAC,EAAE,YAAY,EAAE,CAAC;IACzB;;OAEG;IACH,WAAW,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,KAAK,CAAC,YAAY,CAAC;CAC7C;AA0HD,wBAAgB,UAAU,CAAC,CAAC,EAAE,GAAG,SAAS,KAAK,CAAC,GAAG,EACjD,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,WAAW,EAAE,OAAY,EAAE,EAAE,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,2CAgDvF"}
1
+ {"version":3,"file":"TabManager.d.ts","sourceRoot":"","sources":["../../src/components/TabManager.tsx"],"names":[],"mappings":"AASA,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAGvC,UAAU,KAAK,CAAC,CAAC,EAAE,GAAG,SAAS,KAAK,CAAC,GAAG;IACtC;;OAEG;IACH,IAAI,EAAE,CAAC,EAAE,CAAC;IACV;;OAEG;IACH,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,GAAG,CAAC;IACxB;;OAEG;IACH,MAAM,EAAE,GAAG,CAAC;IACZ;;OAEG;IACH,QAAQ,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,CAAC;IAC3B;;OAEG;IACH,QAAQ,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,CAAC;IAC3B;;OAEG;IACH,OAAO,CAAC,EAAE,YAAY,EAAE,CAAC;IACzB;;OAEG;IACH,WAAW,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,KAAK,CAAC,YAAY,CAAC;CAC7C;AA4HD;;;;;GAKG;AACH,wBAAgB,UAAU,CAAC,CAAC,EAAE,GAAG,SAAS,KAAK,CAAC,GAAG,EACjD,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,WAAW,EAAE,OAAY,EAAE,EAAE,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,2CAgDvF"}
@@ -8,7 +8,9 @@ import { last } from 'lodash';
8
8
  import { useCallback, useEffect, useMemo, useRef } from 'react';
9
9
  import { styled } from 'styled-components';
10
10
  import { FadingOverflow } from './FadingOverflow.js';
11
+ // The size of extra buttons placed after the tabs.
11
12
  const EXTRA_BTN_SIZE = 24;
13
+ // The margin of extra buttons placed after the tabs.
12
14
  const EXTRA_BTN_MARGIN = 8;
13
15
  const Tabs = styled.nav `
14
16
  width: 100%;
@@ -126,6 +128,12 @@ const Tabs = styled.nav `
126
128
  }
127
129
  }
128
130
  `;
131
+ /**
132
+ * Renders and manages a list of tabs. With this, tabs can be selected and removed. Furthermore, extra buttons can be placed after all tabs,
133
+ * e.g. a button to add more tabs.
134
+ *
135
+ * Used for the chat tabs.
136
+ */
129
137
  export function TabManager({ active, tabs, keygen, onRemove, onSelect, renderLabel, buttons = [] }) {
130
138
  const t = useTranslate(dictionary);
131
139
  const tabList = useRef(null);
@@ -1 +1 @@
1
- {"version":3,"file":"TabManager.js","sourceRoot":"","sources":["../../src/components/TabManager.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"TabManager.js","sourceRoot":"","sources":["../../src/components/TabManager.tsx"],"names":[],"mappings":"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"}
@@ -2,11 +2,36 @@ import { WithStyle } from '@stack-spot/portal-theme';
2
2
  import { WithChildren } from '../../types.js';
3
3
  import { TooltipPosition } from './types.js';
4
4
  interface Props extends WithChildren, WithStyle {
5
+ /**
6
+ * The content of the tooltip. Can be either a string or a Rect Element.
7
+ */
5
8
  content: React.ReactNode;
9
+ /**
10
+ * Where to position the tooltip relative to the element that triggered it.
11
+ */
6
12
  position?: TooltipPosition;
13
+ /**
14
+ * A tooltip can be triggered either by hovering an element or by clicking it.
15
+ * @default 'hover'
16
+ */
7
17
  triggeredBy?: 'click' | 'hover';
18
+ /**
19
+ * If true, no style is applied to the tooltip, letting you customize it however you want to.
20
+ */
8
21
  custom?: boolean;
22
+ /**
23
+ * Function to run whenever the tooltip is shown.
24
+ */
25
+ onShow?: () => void;
26
+ /**
27
+ * Function to run whenever the tooltip is hidden.
28
+ */
29
+ onHide?: () => void;
9
30
  }
10
- export declare const Tooltip: ({ content, custom, position, triggeredBy, children, className, style }: Props) => import("react/jsx-runtime").JSX.Element;
31
+ /**
32
+ * Shows a tooltip for its children. This tooltip element is always reused and placed at a root level in order to not be cut out by
33
+ * hidden overflows in the children and its ascendants.
34
+ */
35
+ export declare const Tooltip: import("react").ForwardRefExoticComponent<Props & import("react").RefAttributes<HTMLDivElement>>;
11
36
  export {};
12
37
  //# sourceMappingURL=Tooltip.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Tooltip.d.ts","sourceRoot":"","sources":["../../../src/components/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAA;AACpD,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAG1C,OAAO,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAEzC,UAAU,KAAM,SAAQ,YAAY,EAAE,SAAS;IAC7C,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,QAAQ,CAAC,EAAE,eAAe,CAAC;IAC3B,WAAW,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC;IAChC,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,eAAO,MAAM,OAAO,2EAAsF,KAAK,4CAqB9G,CAAA"}
1
+ {"version":3,"file":"Tooltip.d.ts","sourceRoot":"","sources":["../../../src/components/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAA;AAEpD,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAG1C,OAAO,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAEzC,UAAU,KAAM,SAAQ,YAAY,EAAE,SAAS;IAC7C;;OAEG;IACH,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB;;OAEG;IACH,QAAQ,CAAC,EAAE,eAAe,CAAC;IAC3B;;;OAGG;IACH,WAAW,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC;IAChC;;OAEG;IACH,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB;;OAEG;IACH,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB;;OAEG;IACH,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;CACrB;AAED;;;GAGG;AACH,eAAO,MAAM,OAAO,kGAoClB,CAAA"}
@@ -1,17 +1,30 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
+ /* eslint-disable react/display-name */
2
3
  import { Text } from '@citric/core';
4
+ import { forwardRef } from 'react';
3
5
  import { useTooltip } from './context.js';
4
6
  import { DefaultTooltip } from './style.js';
5
- export const Tooltip = ({ content, custom, position, triggeredBy = 'hover', children, className, style }) => {
7
+ /**
8
+ * Shows a tooltip for its children. This tooltip element is always reused and placed at a root level in order to not be cut out by
9
+ * hidden overflows in the children and its ascendants.
10
+ */
11
+ export const Tooltip = forwardRef(({ content, custom, position, triggeredBy = 'hover', onHide, onShow, children, className, style }, ref) => {
6
12
  const api = useTooltip();
7
- function show(e, hideOnClickOutside) {
8
- api.show({
13
+ async function show(e, hideOnClickOutside) {
14
+ await api.show({
9
15
  content: custom ? content : _jsx(DefaultTooltip, { children: _jsx(Text, { appearance: "microtext1", children: content }) }),
10
16
  anchor: e.target,
11
17
  position,
12
18
  hideOnClickOutside,
13
19
  });
20
+ onShow?.();
14
21
  }
15
- return (_jsx("div", { ...(triggeredBy === 'hover' ? { onMouseEnter: show, onMouseLeave: () => api.hide() } : { onClick: (e) => show(e, true) }), className: className, style: style, tabIndex: triggeredBy === 'click' ? 0 : undefined, children: children }));
16
- };
22
+ function hide() {
23
+ api.hide();
24
+ onHide?.();
25
+ }
26
+ return (_jsx("div", { ...(triggeredBy === 'hover'
27
+ ? { onMouseEnter: show, onMouseLeave: hide }
28
+ : { onClick: (e) => show(e, true), onKeyDown: (e) => e.key === 'Enter' && show(e, true) }), className: className, style: style, tabIndex: triggeredBy === 'click' ? 0 : undefined, role: triggeredBy === 'click' ? 'button' : undefined, ref: ref, children: children }));
29
+ });
17
30
  //# sourceMappingURL=Tooltip.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Tooltip.js","sourceRoot":"","sources":["../../../src/components/Tooltip/Tooltip.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AAGnC,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAA;AACtC,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAA;AAUxC,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,GAAG,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,EAAS,EAAE,EAAE;IACjH,MAAM,GAAG,GAAG,UAAU,EAAE,CAAA;IAExB,SAAS,IAAI,CAAC,CAA+C,EAAE,kBAA4B;QACzF,GAAG,CAAC,IAAI,CAAC;YACP,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAC,cAAc,cAAC,KAAC,IAAI,IAAC,UAAU,EAAC,YAAY,YAAE,OAAO,GAAQ,GAAiB;YAC3G,MAAM,EAAE,CAAC,CAAC,MAAqB;YAC/B,QAAQ;YACR,kBAAkB;SACnB,CAAC,CAAA;IACJ,CAAC;IACD,OAAO,CACL,iBACM,CAAC,WAAW,KAAK,OAAO,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,IAAI,EAAE,YAAY,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,EAC1H,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,WAAW,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,YAEhD,QAAQ,GACL,CACP,CAAA;AACH,CAAC,CAAA"}
1
+ {"version":3,"file":"Tooltip.js","sourceRoot":"","sources":["../../../src/components/Tooltip/Tooltip.tsx"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AAEnC,OAAO,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAElC,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAA;AACtC,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAA;AA+BxC;;;GAGG;AACH,MAAM,CAAC,MAAM,OAAO,GAAG,UAAU,CAAwB,CACvD,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,GAAG,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,EAAE,EAChG,GAAG,EACH,EAAE;IACF,MAAM,GAAG,GAAG,UAAU,EAAE,CAAA;IAExB,KAAK,UAAU,IAAI,CAAC,CAAgB,EAAE,kBAA4B;QAChE,MAAM,GAAG,CAAC,IAAI,CAAC;YACb,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAC,cAAc,cAAC,KAAC,IAAI,IAAC,UAAU,EAAC,YAAY,YAAE,OAAO,GAAQ,GAAiB;YAC3G,MAAM,EAAE,CAAC,CAAC,MAAqB;YAC/B,QAAQ;YACR,kBAAkB;SACnB,CAAC,CAAA;QACF,MAAM,EAAE,EAAE,CAAA;IACZ,CAAC;IAED,SAAS,IAAI;QACX,GAAG,CAAC,IAAI,EAAE,CAAA;QACV,MAAM,EAAE,EAAE,CAAA;IACZ,CAAC;IAED,OAAO,CACL,iBACM,CAAC,WAAW,KAAK,OAAO;YAC1B,CAAC,CAAC,EAAE,YAAY,EAAE,IAAI,EAAE,YAAY,EAAE,IAAI,EAAE;YAC5C,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,OAAO,IAAI,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,CAC1F,EACD,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,WAAW,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EACjD,IAAI,EAAE,WAAW,KAAK,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,EACpD,GAAG,EAAE,GAAG,YAEP,QAAQ,GACL,CACP,CAAA;AACH,CAAC,CAAC,CAAA"}
@@ -1,13 +1,29 @@
1
1
  import { ShowOptions } from './types.js';
2
+ /**
3
+ * Allows interaction with the tooltip element.
4
+ *
5
+ * This places the tooltip element at the correct place, shows it, hides it and manages its contents.
6
+ *
7
+ * This also takes into account the screen edges, making adjustments to the tooltip position if it would overflow the screen.
8
+ */
2
9
  export declare class TooltipAPI {
3
- private tooltipRef;
10
+ /**
11
+ * A reference to the tooltip element in the HTML tree.
12
+ */
13
+ tooltipRef: React.RefObject<HTMLDivElement>;
4
14
  private setContent;
5
15
  private hideTimeoutId;
6
16
  private clickListener;
7
17
  private relativeTo;
8
18
  constructor(tooltipRef: React.RefObject<HTMLDivElement>, setContent: React.Dispatch<React.SetStateAction<React.ReactNode>>);
9
19
  private computeRelativeTo;
10
- show({ content, anchor, position, hideOnClickOutside }: ShowOptions): void;
20
+ /**
21
+ * Shows the tooltip with `content`. Its position is based on `position` and the position of the element referred by `anchor`.
22
+ */
23
+ show({ content, anchor, position, hideOnClickOutside }: ShowOptions): Promise<void>;
24
+ /**
25
+ * Hides the tooltip. After the animation, the content is removed.
26
+ */
11
27
  hide(): void;
12
28
  }
13
29
  //# sourceMappingURL=TooltipAPI.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"TooltipAPI.d.ts","sourceRoot":"","sources":["../../../src/components/Tooltip/TooltipAPI.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAQrC,qBAAa,UAAU;IACrB,OAAO,CAAC,UAAU,CAAiC;IACnD,OAAO,CAAC,UAAU,CAAuD;IACzE,OAAO,CAAC,aAAa,CAAoB;IACzC,OAAO,CAAC,aAAa,CAAuC;IAC5D,OAAO,CAAC,UAAU,CAAyB;gBAE/B,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC,cAAc,CAAC,EAAE,UAAU,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IAK1H,OAAO,CAAC,iBAAiB;IAQzB,IAAI,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,QAAmB,EAAE,kBAAkB,EAAE,EAAE,WAAW,GAAG,IAAI;IAgDrF,IAAI,IAAI,IAAI;CAMb"}
1
+ {"version":3,"file":"TooltipAPI.d.ts","sourceRoot":"","sources":["../../../src/components/Tooltip/TooltipAPI.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AASrC;;;;;;GAMG;AACH,qBAAa,UAAU;IACrB;;OAEG;IACH,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC,cAAc,CAAC,CAAA;IAC3C,OAAO,CAAC,UAAU,CAAuD;IACzE,OAAO,CAAC,aAAa,CAAoB;IACzC,OAAO,CAAC,aAAa,CAAuC;IAC5D,OAAO,CAAC,UAAU,CAAyB;gBAE/B,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC,cAAc,CAAC,EAAE,UAAU,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IAK1H,OAAO,CAAC,iBAAiB;IAQzB;;OAEG;IACG,IAAI,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,QAAmB,EAAE,kBAAkB,EAAE,EAAE,WAAW;IA+CpF;;OAEG;IACH,IAAI,IAAI,IAAI;CAMb"}
@@ -1,9 +1,21 @@
1
+ import { delay } from '@stack-spot/portal-components';
1
2
  import { animationTimeMS } from './style.js';
3
+ // the maximum amount of pixels a tooltip can get close to the screen edges.
2
4
  const MARGIN_TO_CORNERS_PX = 10;
3
5
  function isRelative(element) {
4
6
  return ['relative', 'absolute', 'fixed'].includes(element.computedStyleMap().get('position')?.toString() ?? '');
5
7
  }
8
+ /**
9
+ * Allows interaction with the tooltip element.
10
+ *
11
+ * This places the tooltip element at the correct place, shows it, hides it and manages its contents.
12
+ *
13
+ * This also takes into account the screen edges, making adjustments to the tooltip position if it would overflow the screen.
14
+ */
6
15
  export class TooltipAPI {
16
+ /**
17
+ * A reference to the tooltip element in the HTML tree.
18
+ */
7
19
  tooltipRef;
8
20
  setContent;
9
21
  hideTimeoutId;
@@ -21,63 +33,68 @@ export class TooltipAPI {
21
33
  this.relativeTo = this.relativeTo.parentElement;
22
34
  }
23
35
  }
24
- show({ content, anchor, position = 'bottom', hideOnClickOutside }) {
36
+ /**
37
+ * Shows the tooltip with `content`. Its position is based on `position` and the position of the element referred by `anchor`.
38
+ */
39
+ async show({ content, anchor, position = 'bottom', hideOnClickOutside }) {
25
40
  window.clearTimeout(this.hideTimeoutId);
26
41
  this.hideTimeoutId = undefined;
27
42
  if (this.clickListener)
28
43
  document.removeEventListener('click', this.clickListener);
29
44
  this.setContent(content);
30
- setTimeout(() => {
31
- if (!this.tooltipRef.current)
32
- return;
33
- const anchorRect = anchor.getClientRects()[0];
34
- this.tooltipRef.current.classList.add('visible');
35
- const tooltipWidth = this.tooltipRef.current.clientWidth;
36
- const tooltipHeight = this.tooltipRef.current.clientHeight;
37
- let top = 0;
38
- let left = 0;
39
- if (position === 'left' || position === 'right') {
40
- top = anchorRect.top + anchorRect.height / 2 - tooltipHeight / 2;
41
- if (position === 'left')
42
- left = anchorRect.left - tooltipWidth;
43
- else
44
- left = anchorRect.left + anchorRect.width;
45
- }
46
- else {
47
- left = anchorRect.left + anchorRect.width / 2 - tooltipWidth / 2;
48
- if (position === 'top')
49
- top = anchorRect.top - tooltipHeight;
50
- else
51
- top = anchorRect.top + anchorRect.height;
52
- }
53
- // takes the parent the tooltip is positioned relative to into consideration
54
- this.computeRelativeTo();
55
- const relativeRect = this.relativeTo?.getClientRects()[0] ?? { top: 0, left: 0 };
56
- top -= relativeRect.top;
57
- left -= relativeRect.left;
58
- // adjusts positions in order to avoid overflowing the window and leaving a margin to the corners
59
- if (top <= 0)
60
- top += MARGIN_TO_CORNERS_PX;
61
- else if (top + tooltipHeight >= document.body.clientHeight - MARGIN_TO_CORNERS_PX) {
62
- top = document.body.clientHeight - MARGIN_TO_CORNERS_PX + tooltipHeight;
63
- }
64
- if (left <= 0)
65
- left += MARGIN_TO_CORNERS_PX;
66
- else if (left + tooltipWidth >= document.body.clientWidth - MARGIN_TO_CORNERS_PX) {
67
- left = document.body.clientWidth - MARGIN_TO_CORNERS_PX - tooltipWidth;
68
- }
69
- this.tooltipRef.current.style.top = `${top}px`;
70
- this.tooltipRef.current.style.left = `${left}px`;
71
- if (hideOnClickOutside) {
72
- this.clickListener = (e) => {
73
- if (this.tooltipRef.current?.contains(e.target))
74
- return;
75
- this.hide();
76
- };
77
- document.addEventListener('click', this.clickListener);
78
- }
79
- }, 10);
45
+ await delay(10);
46
+ if (!this.tooltipRef.current)
47
+ return;
48
+ const anchorRect = anchor.getClientRects()[0];
49
+ this.tooltipRef.current.classList.add('visible');
50
+ const tooltipWidth = this.tooltipRef.current.clientWidth;
51
+ const tooltipHeight = this.tooltipRef.current.clientHeight;
52
+ let top = 0;
53
+ let left = 0;
54
+ if (position === 'left' || position === 'right') {
55
+ top = anchorRect.top + anchorRect.height / 2 - tooltipHeight / 2;
56
+ if (position === 'left')
57
+ left = anchorRect.left - tooltipWidth;
58
+ else
59
+ left = anchorRect.left + anchorRect.width;
60
+ }
61
+ else {
62
+ left = anchorRect.left + anchorRect.width / 2 - tooltipWidth / 2;
63
+ if (position === 'top')
64
+ top = anchorRect.top - tooltipHeight;
65
+ else
66
+ top = anchorRect.top + anchorRect.height;
67
+ }
68
+ // takes the parent the tooltip is positioned relative to into consideration
69
+ this.computeRelativeTo();
70
+ const relativeRect = this.relativeTo?.getClientRects()[0] ?? { top: 0, left: 0 };
71
+ top -= relativeRect.top;
72
+ left -= relativeRect.left;
73
+ // adjusts positions in order to avoid overflowing the window and leaving a margin to the corners
74
+ if (top <= 0)
75
+ top += MARGIN_TO_CORNERS_PX;
76
+ else if (top + tooltipHeight >= document.body.clientHeight - MARGIN_TO_CORNERS_PX) {
77
+ top = document.body.clientHeight - MARGIN_TO_CORNERS_PX + tooltipHeight;
78
+ }
79
+ if (left <= 0)
80
+ left += MARGIN_TO_CORNERS_PX;
81
+ else if (left + tooltipWidth >= document.body.clientWidth - MARGIN_TO_CORNERS_PX) {
82
+ left = document.body.clientWidth - MARGIN_TO_CORNERS_PX - tooltipWidth;
83
+ }
84
+ this.tooltipRef.current.style.top = `${top}px`;
85
+ this.tooltipRef.current.style.left = `${left}px`;
86
+ if (hideOnClickOutside) {
87
+ this.clickListener = (e) => {
88
+ if (this.tooltipRef.current?.contains(e.target))
89
+ return;
90
+ this.hide();
91
+ };
92
+ document.addEventListener('click', this.clickListener);
93
+ }
80
94
  }
95
+ /**
96
+ * Hides the tooltip. After the animation, the content is removed.
97
+ */
81
98
  hide() {
82
99
  if (!this.tooltipRef.current)
83
100
  return;