@stack-spot/portal-components 0.0.17 → 1.0.0-dev.1768482754546

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 (613) hide show
  1. package/CHANGELOG.md +670 -0
  2. package/dist/components/AnimatedHeight.d.ts +58 -0
  3. package/dist/components/AnimatedHeight.d.ts.map +1 -0
  4. package/dist/components/AnimatedHeight.js +105 -0
  5. package/dist/components/AnimatedHeight.js.map +1 -0
  6. package/dist/components/AsyncContent.d.ts +46 -0
  7. package/dist/components/AsyncContent.d.ts.map +1 -0
  8. package/dist/components/AsyncContent.js +34 -0
  9. package/dist/components/AsyncContent.js.map +1 -0
  10. package/dist/components/BannerWarning.d.ts +11 -2
  11. package/dist/components/BannerWarning.d.ts.map +1 -1
  12. package/dist/components/BannerWarning.js +45 -3
  13. package/dist/components/BannerWarning.js.map +1 -1
  14. package/dist/components/Breadcrumb/index.d.ts +10 -2
  15. package/dist/components/Breadcrumb/index.d.ts.map +1 -1
  16. package/dist/components/Breadcrumb/index.js +7 -5
  17. package/dist/components/Breadcrumb/index.js.map +1 -1
  18. package/dist/components/Breadcrumb/styled.d.ts +1 -2
  19. package/dist/components/Breadcrumb/styled.d.ts.map +1 -1
  20. package/dist/components/Breadcrumb/styled.js +1 -0
  21. package/dist/components/Breadcrumb/styled.js.map +1 -1
  22. package/dist/components/ButtonLoading.d.ts +11 -0
  23. package/dist/components/ButtonLoading.d.ts.map +1 -0
  24. package/dist/components/ButtonLoading.js +5 -0
  25. package/dist/components/ButtonLoading.js.map +1 -0
  26. package/dist/components/ChatBot.d.ts +5 -0
  27. package/dist/components/ChatBot.d.ts.map +1 -1
  28. package/dist/components/ChatBot.js +11 -6
  29. package/dist/components/ChatBot.js.map +1 -1
  30. package/dist/components/ContentValidateFilter.d.ts +6 -0
  31. package/dist/components/ContentValidateFilter.d.ts.map +1 -0
  32. package/dist/components/ContentValidateFilter.js +8 -0
  33. package/dist/components/ContentValidateFilter.js.map +1 -0
  34. package/dist/components/FadingOverflow.d.ts +37 -0
  35. package/dist/components/FadingOverflow.d.ts.map +1 -0
  36. package/dist/components/FadingOverflow.js +228 -0
  37. package/dist/components/FadingOverflow.js.map +1 -0
  38. package/dist/components/FileTreeView/More.d.ts +23 -0
  39. package/dist/components/FileTreeView/More.d.ts.map +1 -0
  40. package/dist/components/FileTreeView/More.js +55 -0
  41. package/dist/components/FileTreeView/More.js.map +1 -0
  42. package/dist/components/FileTreeView/index.d.ts +32 -0
  43. package/dist/components/FileTreeView/index.d.ts.map +1 -0
  44. package/dist/components/FileTreeView/index.js +91 -0
  45. package/dist/components/FileTreeView/index.js.map +1 -0
  46. package/dist/components/InfiniteScroll.d.ts +11 -0
  47. package/dist/components/InfiniteScroll.d.ts.map +1 -0
  48. package/dist/components/InfiniteScroll.js +14 -0
  49. package/dist/components/InfiniteScroll.js.map +1 -0
  50. package/dist/components/InfoMaintenanceBanner.d.ts +8 -0
  51. package/dist/components/InfoMaintenanceBanner.d.ts.map +1 -0
  52. package/dist/components/InfoMaintenanceBanner.js +19 -0
  53. package/dist/components/InfoMaintenanceBanner.js.map +1 -0
  54. package/dist/components/LazyMarkdown/BlockquoteMd.d.ts +11 -0
  55. package/dist/components/LazyMarkdown/BlockquoteMd.d.ts.map +1 -0
  56. package/dist/components/LazyMarkdown/BlockquoteMd.js +77 -0
  57. package/dist/components/LazyMarkdown/BlockquoteMd.js.map +1 -0
  58. package/dist/components/LazyMarkdown/CodeViewer.d.ts +24 -0
  59. package/dist/components/LazyMarkdown/CodeViewer.d.ts.map +1 -0
  60. package/dist/components/LazyMarkdown/CodeViewer.js +122 -0
  61. package/dist/components/LazyMarkdown/CodeViewer.js.map +1 -0
  62. package/dist/components/LazyMarkdown/Markdown.d.ts +19 -0
  63. package/dist/components/LazyMarkdown/Markdown.d.ts.map +1 -0
  64. package/dist/components/LazyMarkdown/Markdown.js +96 -0
  65. package/dist/components/LazyMarkdown/Markdown.js.map +1 -0
  66. package/dist/components/LazyMarkdown/MarkdownButton.d.ts +19 -0
  67. package/dist/components/LazyMarkdown/MarkdownButton.d.ts.map +1 -0
  68. package/dist/components/LazyMarkdown/MarkdownButton.js +9 -0
  69. package/dist/components/LazyMarkdown/MarkdownButton.js.map +1 -0
  70. package/dist/components/LazyMarkdown/Video.d.ts +11 -0
  71. package/dist/components/LazyMarkdown/Video.d.ts.map +1 -0
  72. package/dist/components/LazyMarkdown/Video.js +10 -0
  73. package/dist/components/LazyMarkdown/Video.js.map +1 -0
  74. package/dist/components/LazyMarkdown/index.d.ts +10 -0
  75. package/dist/components/LazyMarkdown/index.d.ts.map +1 -0
  76. package/dist/components/LazyMarkdown/index.js +8 -0
  77. package/dist/components/LazyMarkdown/index.js.map +1 -0
  78. package/dist/components/Placeholder.d.ts +28 -0
  79. package/dist/components/Placeholder.d.ts.map +1 -0
  80. package/dist/components/Placeholder.js +32 -0
  81. package/dist/components/Placeholder.js.map +1 -0
  82. package/dist/components/ScrollView.d.ts +31 -0
  83. package/dist/components/ScrollView.d.ts.map +1 -0
  84. package/dist/components/ScrollView.js +30 -0
  85. package/dist/components/ScrollView.js.map +1 -0
  86. package/dist/components/Select/BadgeItem.d.ts +4 -0
  87. package/dist/components/Select/BadgeItem.d.ts.map +1 -0
  88. package/dist/components/Select/BadgeItem.js +28 -0
  89. package/dist/components/Select/BadgeItem.js.map +1 -0
  90. package/dist/components/Select/ClearInput.d.ts +3 -0
  91. package/dist/components/Select/ClearInput.d.ts.map +1 -0
  92. package/dist/components/Select/ClearInput.js +18 -0
  93. package/dist/components/Select/ClearInput.js.map +1 -0
  94. package/dist/components/Select/CloseItem.d.ts +3 -0
  95. package/dist/components/Select/CloseItem.d.ts.map +1 -0
  96. package/dist/components/Select/CloseItem.js +26 -0
  97. package/dist/components/Select/CloseItem.js.map +1 -0
  98. package/dist/components/Select/CreatableSelect.d.ts +16 -0
  99. package/dist/components/Select/CreatableSelect.d.ts.map +1 -0
  100. package/dist/components/Select/CreatableSelect.js +114 -0
  101. package/dist/components/Select/CreatableSelect.js.map +1 -0
  102. package/dist/components/Select/CustomMenu.d.ts +8 -0
  103. package/dist/components/Select/CustomMenu.d.ts.map +1 -0
  104. package/dist/components/Select/CustomMenu.js +4 -0
  105. package/dist/components/Select/CustomMenu.js.map +1 -0
  106. package/dist/components/Select/LabelItem.d.ts +3 -0
  107. package/dist/components/Select/LabelItem.d.ts.map +1 -0
  108. package/dist/components/Select/LabelItem.js +4 -0
  109. package/dist/components/Select/LabelItem.js.map +1 -0
  110. package/dist/components/Select/MultiValue.d.ts +3 -0
  111. package/dist/components/Select/MultiValue.d.ts.map +1 -0
  112. package/dist/components/Select/MultiValue.js +27 -0
  113. package/dist/components/Select/MultiValue.js.map +1 -0
  114. package/dist/components/Select/SelectInfiniteScroll.d.ts +14 -0
  115. package/dist/components/Select/SelectInfiniteScroll.d.ts.map +1 -0
  116. package/dist/components/Select/SelectInfiniteScroll.js +31 -0
  117. package/dist/components/Select/SelectInfiniteScroll.js.map +1 -0
  118. package/dist/components/Select/SelectSearch.d.ts +11 -0
  119. package/dist/components/Select/SelectSearch.d.ts.map +1 -0
  120. package/dist/components/Select/SelectSearch.js +156 -0
  121. package/dist/components/Select/SelectSearch.js.map +1 -0
  122. package/dist/components/Select/index.d.ts +6 -0
  123. package/dist/components/Select/index.d.ts.map +1 -0
  124. package/dist/components/Select/index.js +6 -0
  125. package/dist/components/Select/index.js.map +1 -0
  126. package/dist/components/Select/types.d.ts +7 -0
  127. package/dist/components/Select/types.d.ts.map +1 -0
  128. package/dist/components/Select/types.js +2 -0
  129. package/dist/components/Select/types.js.map +1 -0
  130. package/dist/components/SelectionList.d.ts +151 -0
  131. package/dist/components/SelectionList.d.ts.map +1 -0
  132. package/dist/components/SelectionList.js +180 -0
  133. package/dist/components/SelectionList.js.map +1 -0
  134. package/dist/components/StatusCircle.d.ts +24 -0
  135. package/dist/components/StatusCircle.d.ts.map +1 -0
  136. package/dist/components/StatusCircle.js +44 -0
  137. package/dist/components/StatusCircle.js.map +1 -0
  138. package/dist/components/Stepper/Navigation.d.ts +35 -0
  139. package/dist/components/Stepper/Navigation.d.ts.map +1 -0
  140. package/dist/components/Stepper/Navigation.js +41 -0
  141. package/dist/components/Stepper/Navigation.js.map +1 -0
  142. package/dist/components/Stepper/Step.d.ts +18 -0
  143. package/dist/components/Stepper/Step.d.ts.map +1 -0
  144. package/dist/components/Stepper/Step.js +13 -0
  145. package/dist/components/Stepper/Step.js.map +1 -0
  146. package/dist/components/Stepper/Stepper.d.ts +45 -0
  147. package/dist/components/Stepper/Stepper.d.ts.map +1 -0
  148. package/dist/components/Stepper/Stepper.js +57 -0
  149. package/dist/components/Stepper/Stepper.js.map +1 -0
  150. package/dist/components/Stepper/headers.d.ts +19 -0
  151. package/dist/components/Stepper/headers.d.ts.map +1 -0
  152. package/dist/components/Stepper/headers.js +40 -0
  153. package/dist/components/Stepper/headers.js.map +1 -0
  154. package/dist/components/Stepper/index.d.ts +4 -0
  155. package/dist/components/Stepper/index.d.ts.map +1 -0
  156. package/dist/components/Stepper/index.js +4 -0
  157. package/dist/components/Stepper/index.js.map +1 -0
  158. package/dist/components/Table/HeaderItem.d.ts +18 -0
  159. package/dist/components/Table/HeaderItem.d.ts.map +1 -0
  160. package/dist/components/Table/HeaderItem.js +14 -0
  161. package/dist/components/Table/HeaderItem.js.map +1 -0
  162. package/dist/components/Table/SettingsVerticalMenu.d.ts +14 -0
  163. package/dist/components/Table/SettingsVerticalMenu.d.ts.map +1 -0
  164. package/dist/components/Table/SettingsVerticalMenu.js +14 -0
  165. package/dist/components/Table/SettingsVerticalMenu.js.map +1 -0
  166. package/dist/components/Table/StyledLinkTable.d.ts +5 -0
  167. package/dist/components/Table/StyledLinkTable.d.ts.map +1 -0
  168. package/dist/components/Table/StyledLinkTable.js +13 -0
  169. package/dist/components/Table/StyledLinkTable.js.map +1 -0
  170. package/dist/components/Table/TableData.d.ts +37 -0
  171. package/dist/components/Table/TableData.d.ts.map +1 -0
  172. package/dist/components/Table/TableData.js +84 -0
  173. package/dist/components/Table/TableData.js.map +1 -0
  174. package/dist/components/Table/index.d.ts +3 -0
  175. package/dist/components/Table/index.d.ts.map +1 -0
  176. package/dist/components/Table/index.js +3 -0
  177. package/dist/components/Table/index.js.map +1 -0
  178. package/dist/components/TimelineSection.d.ts +24 -0
  179. package/dist/components/TimelineSection.d.ts.map +1 -0
  180. package/dist/components/TimelineSection.js +37 -0
  181. package/dist/components/TimelineSection.js.map +1 -0
  182. package/dist/components/error/ErrorFeedback.d.ts +58 -0
  183. package/dist/components/error/ErrorFeedback.d.ts.map +1 -0
  184. package/dist/components/error/ErrorFeedback.js +110 -0
  185. package/dist/components/error/ErrorFeedback.js.map +1 -0
  186. package/dist/components/error/NotFound.d.ts +4 -0
  187. package/dist/components/error/NotFound.d.ts.map +1 -0
  188. package/dist/components/error/NotFound.js +19 -0
  189. package/dist/components/error/NotFound.js.map +1 -0
  190. package/dist/components/error/UnderMaintenance.d.ts +4 -0
  191. package/dist/components/error/UnderMaintenance.d.ts.map +1 -0
  192. package/dist/components/error/UnderMaintenance.js +25 -0
  193. package/dist/components/error/UnderMaintenance.js.map +1 -0
  194. package/dist/components/error/index.d.ts +4 -0
  195. package/dist/components/error/index.d.ts.map +1 -0
  196. package/dist/components/error/index.js +4 -0
  197. package/dist/components/error/index.js.map +1 -0
  198. package/dist/components/form/Form/Form.d.ts +15 -0
  199. package/dist/components/form/Form/Form.d.ts.map +1 -0
  200. package/dist/components/form/Form/Form.js +48 -0
  201. package/dist/components/form/Form/Form.js.map +1 -0
  202. package/dist/components/form/Form/FormGroup.d.ts +37 -0
  203. package/dist/components/form/Form/FormGroup.d.ts.map +1 -0
  204. package/dist/components/form/Form/FormGroup.js +72 -0
  205. package/dist/components/form/Form/FormGroup.js.map +1 -0
  206. package/dist/components/form/Form/index.d.ts +3 -0
  207. package/dist/components/form/Form/index.d.ts.map +1 -0
  208. package/dist/components/form/Form/index.js +3 -0
  209. package/dist/components/form/Form/index.js.map +1 -0
  210. package/dist/components/form/SearchInput.d.ts +9 -0
  211. package/dist/components/form/SearchInput.d.ts.map +1 -0
  212. package/dist/components/form/SearchInput.js +28 -0
  213. package/dist/components/form/SearchInput.js.map +1 -0
  214. package/dist/components/form/Select/CustomSelect.d.ts +81 -0
  215. package/dist/components/form/Select/CustomSelect.d.ts.map +1 -0
  216. package/dist/components/form/Select/CustomSelect.js +178 -0
  217. package/dist/components/form/Select/CustomSelect.js.map +1 -0
  218. package/dist/components/form/Select/DetailedSelect.d.ts +65 -0
  219. package/dist/components/form/Select/DetailedSelect.d.ts.map +1 -0
  220. package/dist/components/form/Select/DetailedSelect.js +80 -0
  221. package/dist/components/form/Select/DetailedSelect.js.map +1 -0
  222. package/dist/components/form/Select/Select.d.ts +47 -0
  223. package/dist/components/form/Select/Select.d.ts.map +1 -0
  224. package/dist/components/form/Select/Select.js +62 -0
  225. package/dist/components/form/Select/Select.js.map +1 -0
  226. package/dist/components/form/Select/index.d.ts +5 -0
  227. package/dist/components/form/Select/index.d.ts.map +1 -0
  228. package/dist/components/form/Select/index.js +5 -0
  229. package/dist/components/form/Select/index.js.map +1 -0
  230. package/dist/components/form/Select/styled.d.ts +5 -0
  231. package/dist/components/form/Select/styled.d.ts.map +1 -0
  232. package/dist/components/form/Select/styled.js +165 -0
  233. package/dist/components/form/Select/styled.js.map +1 -0
  234. package/dist/components/form/Select/types.d.ts +103 -0
  235. package/dist/components/form/Select/types.d.ts.map +1 -0
  236. package/dist/components/form/Select/types.js +2 -0
  237. package/dist/components/form/Select/types.js.map +1 -0
  238. package/dist/components/form/Select/utils.d.ts +3 -0
  239. package/dist/components/form/Select/utils.d.ts.map +1 -0
  240. package/dist/components/form/Select/utils.js +20 -0
  241. package/dist/components/form/Select/utils.js.map +1 -0
  242. package/dist/components/notification/NotificationComponent.d.ts +31 -0
  243. package/dist/components/notification/NotificationComponent.d.ts.map +1 -0
  244. package/dist/components/notification/NotificationComponent.js +176 -0
  245. package/dist/components/notification/NotificationComponent.js.map +1 -0
  246. package/dist/components/notification/NotificationItem.d.ts +51 -0
  247. package/dist/components/notification/NotificationItem.d.ts.map +1 -0
  248. package/dist/components/notification/NotificationItem.js +165 -0
  249. package/dist/components/notification/NotificationItem.js.map +1 -0
  250. package/dist/components/notification/NotificationList.d.ts +47 -0
  251. package/dist/components/notification/NotificationList.d.ts.map +1 -0
  252. package/dist/components/notification/NotificationList.js +82 -0
  253. package/dist/components/notification/NotificationList.js.map +1 -0
  254. package/dist/components/notification/NotificationPlaceholder.d.ts +13 -0
  255. package/dist/components/notification/NotificationPlaceholder.d.ts.map +1 -0
  256. package/dist/components/notification/NotificationPlaceholder.js +34 -0
  257. package/dist/components/notification/NotificationPlaceholder.js.map +1 -0
  258. package/dist/components/notification/types.d.ts +60 -0
  259. package/dist/components/notification/types.d.ts.map +1 -0
  260. package/dist/components/notification/types.js +7 -0
  261. package/dist/components/notification/types.js.map +1 -0
  262. package/dist/containers/NotificationsPage.d.ts +2 -0
  263. package/dist/containers/NotificationsPage.d.ts.map +1 -0
  264. package/dist/containers/NotificationsPage.js +71 -0
  265. package/dist/containers/NotificationsPage.js.map +1 -0
  266. package/dist/context/anchor.d.ts +27 -0
  267. package/dist/context/anchor.d.ts.map +1 -0
  268. package/dist/context/anchor.js +23 -0
  269. package/dist/context/anchor.js.map +1 -0
  270. package/dist/context/loading.d.ts +27 -0
  271. package/dist/context/loading.d.ts.map +1 -0
  272. package/dist/context/loading.js +24 -0
  273. package/dist/context/loading.js.map +1 -0
  274. package/dist/context/notification/LazyNotificationList.d.ts +28 -0
  275. package/dist/context/notification/LazyNotificationList.d.ts.map +1 -0
  276. package/dist/context/notification/LazyNotificationList.js +136 -0
  277. package/dist/context/notification/LazyNotificationList.js.map +1 -0
  278. package/dist/context/notification/NotificationController.d.ts +25 -0
  279. package/dist/context/notification/NotificationController.d.ts.map +1 -0
  280. package/dist/context/notification/NotificationController.js +153 -0
  281. package/dist/context/notification/NotificationController.js.map +1 -0
  282. package/dist/context/notification/context.d.ts +8 -0
  283. package/dist/context/notification/context.d.ts.map +1 -0
  284. package/dist/context/notification/context.js +12 -0
  285. package/dist/context/notification/context.js.map +1 -0
  286. package/dist/context/notification/hooks.d.ts +18 -0
  287. package/dist/context/notification/hooks.d.ts.map +1 -0
  288. package/dist/context/notification/hooks.js +92 -0
  289. package/dist/context/notification/hooks.js.map +1 -0
  290. package/dist/context/notification/types.d.ts +65 -0
  291. package/dist/context/notification/types.d.ts.map +1 -0
  292. package/dist/context/notification/types.js +2 -0
  293. package/dist/context/notification/types.js.map +1 -0
  294. package/dist/hooks/date.d.ts +18 -0
  295. package/dist/hooks/date.d.ts.map +1 -0
  296. package/dist/hooks/date.js +68 -0
  297. package/dist/hooks/date.js.map +1 -0
  298. package/dist/hooks/keyboard.d.ts +64 -0
  299. package/dist/hooks/keyboard.d.ts.map +1 -0
  300. package/dist/hooks/keyboard.js +84 -0
  301. package/dist/hooks/keyboard.js.map +1 -0
  302. package/dist/hooks/manual-render.d.ts +8 -0
  303. package/dist/hooks/manual-render.d.ts.map +1 -0
  304. package/dist/hooks/manual-render.js +10 -0
  305. package/dist/hooks/manual-render.js.map +1 -0
  306. package/dist/hooks/service-now.d.ts +32 -1
  307. package/dist/hooks/service-now.d.ts.map +1 -1
  308. package/dist/hooks/service-now.js +58 -18
  309. package/dist/hooks/service-now.js.map +1 -1
  310. package/dist/hooks/text.d.ts +9 -0
  311. package/dist/hooks/text.d.ts.map +1 -0
  312. package/dist/hooks/text.js +24 -0
  313. package/dist/hooks/text.js.map +1 -0
  314. package/dist/hooks/title.d.ts +13 -0
  315. package/dist/hooks/title.d.ts.map +1 -1
  316. package/dist/hooks/title.js +13 -0
  317. package/dist/hooks/title.js.map +1 -1
  318. package/dist/hooks/use-effect-once.d.ts.map +1 -1
  319. package/dist/hooks/use-effect-once.js.map +1 -1
  320. package/dist/index.d.ts +14 -4
  321. package/dist/index.d.ts.map +1 -1
  322. package/dist/index.js +14 -4
  323. package/dist/index.js.map +1 -1
  324. package/dist/notifications.d.ts +11 -0
  325. package/dist/notifications.d.ts.map +1 -0
  326. package/dist/notifications.js +10 -0
  327. package/dist/notifications.js.map +1 -0
  328. package/dist/svg/AI.d.ts +8 -0
  329. package/dist/svg/AI.d.ts.map +1 -0
  330. package/dist/svg/AI.js +15 -0
  331. package/dist/svg/AI.js.map +1 -0
  332. package/dist/svg/CS.d.ts +8 -0
  333. package/dist/svg/CS.d.ts.map +1 -0
  334. package/dist/svg/CS.js +15 -0
  335. package/dist/svg/CS.js.map +1 -0
  336. package/dist/svg/EDP.d.ts +8 -0
  337. package/dist/svg/EDP.d.ts.map +1 -0
  338. package/dist/svg/EDP.js +15 -0
  339. package/dist/svg/EDP.js.map +1 -0
  340. package/dist/svg/Forbidden.d.ts +5 -0
  341. package/dist/svg/Forbidden.d.ts.map +1 -0
  342. package/dist/svg/Forbidden.js +4 -0
  343. package/dist/svg/Forbidden.js.map +1 -0
  344. package/dist/svg/GenericPlaceholder.d.ts +7 -0
  345. package/dist/svg/GenericPlaceholder.d.ts.map +1 -0
  346. package/dist/svg/GenericPlaceholder.js +4 -0
  347. package/dist/svg/GenericPlaceholder.js.map +1 -0
  348. package/dist/svg/HUB.d.ts +8 -0
  349. package/dist/svg/HUB.d.ts.map +1 -0
  350. package/dist/svg/HUB.js +15 -0
  351. package/dist/svg/HUB.js.map +1 -0
  352. package/dist/svg/Logo.d.ts +5 -0
  353. package/dist/svg/Logo.d.ts.map +1 -0
  354. package/dist/svg/Logo.js +8 -0
  355. package/dist/svg/Logo.js.map +1 -0
  356. package/dist/svg/MiniLogo.d.ts +8 -0
  357. package/dist/svg/MiniLogo.d.ts.map +1 -0
  358. package/dist/svg/MiniLogo.js +6 -0
  359. package/dist/svg/MiniLogo.js.map +1 -0
  360. package/dist/svg/NotFound.d.ts +5 -0
  361. package/dist/svg/NotFound.d.ts.map +1 -0
  362. package/dist/svg/NotFound.js +4 -0
  363. package/dist/svg/NotFound.js.map +1 -0
  364. package/dist/svg/ServerError.d.ts +5 -0
  365. package/dist/svg/ServerError.d.ts.map +1 -0
  366. package/dist/svg/ServerError.js +4 -0
  367. package/dist/svg/ServerError.js.map +1 -0
  368. package/dist/svg/Unauthenticated.d.ts +5 -0
  369. package/dist/svg/Unauthenticated.d.ts.map +1 -0
  370. package/dist/svg/Unauthenticated.js +4 -0
  371. package/dist/svg/Unauthenticated.js.map +1 -0
  372. package/dist/svg/index.d.ts +12 -0
  373. package/dist/svg/index.d.ts.map +1 -0
  374. package/dist/svg/index.js +12 -0
  375. package/dist/svg/index.js.map +1 -0
  376. package/dist/utils/accessibility.d.ts +75 -0
  377. package/dist/utils/accessibility.d.ts.map +1 -0
  378. package/dist/utils/accessibility.js +123 -0
  379. package/dist/utils/accessibility.js.map +1 -0
  380. package/dist/utils/cookie.d.ts +34 -0
  381. package/dist/utils/cookie.d.ts.map +1 -0
  382. package/dist/utils/cookie.js +69 -0
  383. package/dist/utils/cookie.js.map +1 -0
  384. package/dist/utils/promise.d.ts +2 -0
  385. package/dist/utils/promise.d.ts.map +1 -0
  386. package/dist/utils/promise.js +6 -0
  387. package/dist/utils/promise.js.map +1 -0
  388. package/dist/utils/read-file.d.ts +2 -0
  389. package/dist/utils/read-file.d.ts.map +1 -0
  390. package/dist/utils/read-file.js +14 -0
  391. package/dist/utils/read-file.js.map +1 -0
  392. package/package.dev.json +3 -0
  393. package/package.json +53 -14
  394. package/package.stg.json +3 -0
  395. package/readme.md +55 -13
  396. package/src/components/AnimatedHeight.tsx +174 -0
  397. package/src/components/AsyncContent.tsx +78 -0
  398. package/src/components/BannerWarning.tsx +89 -19
  399. package/src/components/Breadcrumb/index.tsx +20 -5
  400. package/src/components/Breadcrumb/styled.ts +2 -1
  401. package/src/components/ButtonLoading.tsx +29 -0
  402. package/src/components/ChatBot.tsx +12 -7
  403. package/src/components/ContentValidateFilter.tsx +15 -0
  404. package/src/components/FadingOverflow.tsx +265 -0
  405. package/src/components/FileTreeView/More.tsx +114 -0
  406. package/src/components/FileTreeView/index.tsx +186 -0
  407. package/src/components/InfiniteScroll.tsx +24 -0
  408. package/src/components/InfoMaintenanceBanner.tsx +25 -0
  409. package/src/components/LazyMarkdown/BlockquoteMd.tsx +107 -0
  410. package/src/components/LazyMarkdown/CodeViewer.tsx +161 -0
  411. package/src/components/LazyMarkdown/Markdown.tsx +122 -0
  412. package/src/components/LazyMarkdown/MarkdownButton.tsx +24 -0
  413. package/src/components/LazyMarkdown/Video.tsx +13 -0
  414. package/src/components/LazyMarkdown/index.tsx +21 -0
  415. package/src/components/Placeholder.tsx +124 -0
  416. package/src/components/ScrollView.tsx +57 -0
  417. package/src/components/Select/BadgeItem.tsx +58 -0
  418. package/src/components/Select/ClearInput.tsx +24 -0
  419. package/src/components/Select/CloseItem.tsx +38 -0
  420. package/src/components/Select/CreatableSelect.tsx +155 -0
  421. package/src/components/Select/CustomMenu.tsx +16 -0
  422. package/src/components/Select/LabelItem.tsx +8 -0
  423. package/src/components/Select/MultiValue.tsx +49 -0
  424. package/src/components/Select/SelectInfiniteScroll.tsx +82 -0
  425. package/src/components/Select/SelectSearch.tsx +195 -0
  426. package/src/components/Select/index.tsx +7 -0
  427. package/src/components/Select/types.ts +8 -0
  428. package/src/components/SelectionList.tsx +427 -0
  429. package/src/components/StatusCircle.tsx +67 -0
  430. package/src/components/Stepper/Navigation.tsx +97 -0
  431. package/src/components/Stepper/Step.tsx +30 -0
  432. package/src/components/Stepper/Stepper.tsx +113 -0
  433. package/src/components/Stepper/headers.tsx +64 -0
  434. package/src/components/Stepper/index.ts +3 -0
  435. package/src/components/Table/HeaderItem.tsx +52 -0
  436. package/src/components/Table/SettingsVerticalMenu.tsx +50 -0
  437. package/src/components/Table/StyledLinkTable.tsx +22 -0
  438. package/src/components/Table/TableData.tsx +251 -0
  439. package/src/components/Table/index.tsx +2 -0
  440. package/src/components/TimelineSection.tsx +66 -0
  441. package/src/components/error/ErrorFeedback.tsx +217 -0
  442. package/src/components/error/NotFound.tsx +24 -0
  443. package/src/components/error/UnderMaintenance.tsx +30 -0
  444. package/src/components/error/index.ts +4 -0
  445. package/src/components/form/Form/Form.tsx +101 -0
  446. package/src/components/form/Form/FormGroup.tsx +221 -0
  447. package/src/components/form/Form/index.ts +2 -0
  448. package/src/components/form/SearchInput.tsx +69 -0
  449. package/src/components/form/Select/CustomSelect.tsx +232 -0
  450. package/src/components/form/Select/DetailedSelect.tsx +85 -0
  451. package/src/components/form/Select/Select.tsx +67 -0
  452. package/src/components/form/Select/index.ts +4 -0
  453. package/src/components/form/Select/styled.ts +165 -0
  454. package/src/components/form/Select/types.ts +112 -0
  455. package/src/components/form/Select/utils.tsx +28 -0
  456. package/src/components/notification/NotificationComponent.tsx +340 -0
  457. package/src/components/notification/NotificationItem.tsx +353 -0
  458. package/src/components/notification/NotificationList.tsx +185 -0
  459. package/src/components/notification/NotificationPlaceholder.tsx +60 -0
  460. package/src/components/notification/types.ts +72 -0
  461. package/src/containers/NotificationsPage.tsx +120 -0
  462. package/src/context/anchor.tsx +37 -0
  463. package/src/context/loading.tsx +36 -0
  464. package/src/context/notification/LazyNotificationList.ts +103 -0
  465. package/src/context/notification/NotificationController.ts +119 -0
  466. package/src/context/notification/context.tsx +23 -0
  467. package/src/context/notification/hooks.ts +98 -0
  468. package/src/context/notification/types.ts +71 -0
  469. package/src/hooks/date.ts +68 -0
  470. package/src/hooks/keyboard.tsx +128 -0
  471. package/src/hooks/manual-render.tsx +10 -0
  472. package/src/hooks/service-now.tsx +64 -19
  473. package/src/hooks/text.tsx +30 -0
  474. package/src/hooks/title.tsx +13 -0
  475. package/src/index.ts +14 -6
  476. package/src/notifications.ts +11 -0
  477. package/src/svg/AI.tsx +41 -0
  478. package/src/svg/CS.tsx +48 -0
  479. package/src/svg/EDP.tsx +31 -0
  480. package/src/svg/Forbidden.tsx +22 -0
  481. package/src/svg/GenericPlaceholder.tsx +16 -0
  482. package/src/svg/HUB.tsx +48 -0
  483. package/src/svg/Logo.tsx +16 -0
  484. package/src/svg/MiniLogo.tsx +12 -0
  485. package/src/svg/NotFound.tsx +16 -0
  486. package/src/svg/ServerError.tsx +33 -0
  487. package/src/svg/Unauthenticated.tsx +16 -0
  488. package/src/svg/index.ts +11 -0
  489. package/src/utils/accessibility.ts +135 -0
  490. package/src/utils/cookie.ts +73 -0
  491. package/src/utils/promise.ts +5 -0
  492. package/src/utils/read-file.ts +16 -0
  493. package/tsconfig.json +1 -0
  494. package/dist/BannerWarning.d.ts +0 -4
  495. package/dist/BannerWarning.d.ts.map +0 -1
  496. package/dist/BannerWarning.js +0 -6
  497. package/dist/BannerWarning.js.map +0 -1
  498. package/dist/Login.d.ts +0 -25
  499. package/dist/Login.d.ts.map +0 -1
  500. package/dist/Login.js +0 -104
  501. package/dist/Login.js.map +0 -1
  502. package/dist/MiniLogo.d.ts +0 -6
  503. package/dist/MiniLogo.d.ts.map +0 -1
  504. package/dist/MiniLogo.js +0 -4
  505. package/dist/MiniLogo.js.map +0 -1
  506. package/dist/components/Login.d.ts +0 -26
  507. package/dist/components/Login.d.ts.map +0 -1
  508. package/dist/components/Login.js +0 -100
  509. package/dist/components/Login.js.map +0 -1
  510. package/dist/components/MiniLogo.d.ts +0 -6
  511. package/dist/components/MiniLogo.d.ts.map +0 -1
  512. package/dist/components/MiniLogo.js +0 -4
  513. package/dist/components/MiniLogo.js.map +0 -1
  514. package/dist/components/src/components/BannerWarning.d.ts +0 -4
  515. package/dist/components/src/components/BannerWarning.d.ts.map +0 -1
  516. package/dist/components/src/components/BannerWarning.js +0 -6
  517. package/dist/components/src/components/BannerWarning.js.map +0 -1
  518. package/dist/components/src/components/Breadcrumb/index.d.ts +0 -42
  519. package/dist/components/src/components/Breadcrumb/index.d.ts.map +0 -1
  520. package/dist/components/src/components/Breadcrumb/index.js +0 -27
  521. package/dist/components/src/components/Breadcrumb/index.js.map +0 -1
  522. package/dist/components/src/components/Breadcrumb/styled.d.ts +0 -3
  523. package/dist/components/src/components/Breadcrumb/styled.d.ts.map +0 -1
  524. package/dist/components/src/components/Breadcrumb/styled.js +0 -36
  525. package/dist/components/src/components/Breadcrumb/styled.js.map +0 -1
  526. package/dist/components/src/components/ChatBot.d.ts +0 -2
  527. package/dist/components/src/components/ChatBot.d.ts.map +0 -1
  528. package/dist/components/src/components/ChatBot.js +0 -61
  529. package/dist/components/src/components/ChatBot.js.map +0 -1
  530. package/dist/components/src/components/Login.d.ts +0 -26
  531. package/dist/components/src/components/Login.d.ts.map +0 -1
  532. package/dist/components/src/components/Login.js +0 -100
  533. package/dist/components/src/components/Login.js.map +0 -1
  534. package/dist/components/src/components/MiniLogo.d.ts +0 -6
  535. package/dist/components/src/components/MiniLogo.d.ts.map +0 -1
  536. package/dist/components/src/components/MiniLogo.js +0 -4
  537. package/dist/components/src/components/MiniLogo.js.map +0 -1
  538. package/dist/components/src/components/tour/StepContainer.d.ts +0 -13
  539. package/dist/components/src/components/tour/StepContainer.d.ts.map +0 -1
  540. package/dist/components/src/components/tour/StepContainer.js +0 -48
  541. package/dist/components/src/components/tour/StepContainer.js.map +0 -1
  542. package/dist/components/src/components/tour/StepNavigation.d.ts +0 -13
  543. package/dist/components/src/components/tour/StepNavigation.d.ts.map +0 -1
  544. package/dist/components/src/components/tour/StepNavigation.js +0 -20
  545. package/dist/components/src/components/tour/StepNavigation.js.map +0 -1
  546. package/dist/components/src/components/tour/StepTitle.d.ts +0 -7
  547. package/dist/components/src/components/tour/StepTitle.d.ts.map +0 -1
  548. package/dist/components/src/components/tour/StepTitle.js +0 -5
  549. package/dist/components/src/components/tour/StepTitle.js.map +0 -1
  550. package/dist/components/src/components/tour/context.d.ts +0 -17
  551. package/dist/components/src/components/tour/context.d.ts.map +0 -1
  552. package/dist/components/src/components/tour/context.js +0 -48
  553. package/dist/components/src/components/tour/context.js.map +0 -1
  554. package/dist/components/src/components/tour/index.d.ts +0 -4
  555. package/dist/components/src/components/tour/index.d.ts.map +0 -1
  556. package/dist/components/src/components/tour/index.js +0 -4
  557. package/dist/components/src/components/tour/index.js.map +0 -1
  558. package/dist/components/src/components/tour/utils.d.ts +0 -13
  559. package/dist/components/src/components/tour/utils.d.ts.map +0 -1
  560. package/dist/components/src/components/tour/utils.js +0 -43
  561. package/dist/components/src/components/tour/utils.js.map +0 -1
  562. package/dist/components/src/hooks/service-now.d.ts +0 -24
  563. package/dist/components/src/hooks/service-now.d.ts.map +0 -1
  564. package/dist/components/src/hooks/service-now.js +0 -161
  565. package/dist/components/src/hooks/service-now.js.map +0 -1
  566. package/dist/components/src/hooks/title.d.ts +0 -3
  567. package/dist/components/src/hooks/title.d.ts.map +0 -1
  568. package/dist/components/src/hooks/title.js +0 -13
  569. package/dist/components/src/hooks/title.js.map +0 -1
  570. package/dist/components/src/hooks/use-effect-once.d.ts +0 -12
  571. package/dist/components/src/hooks/use-effect-once.d.ts.map +0 -1
  572. package/dist/components/src/hooks/use-effect-once.js +0 -40
  573. package/dist/components/src/hooks/use-effect-once.js.map +0 -1
  574. package/dist/components/src/index.d.ts +0 -9
  575. package/dist/components/src/index.d.ts.map +0 -1
  576. package/dist/components/src/index.js +0 -9
  577. package/dist/components/src/index.js.map +0 -1
  578. package/dist/components/tour/StepContainer.d.ts +0 -13
  579. package/dist/components/tour/StepContainer.d.ts.map +0 -1
  580. package/dist/components/tour/StepContainer.js +0 -48
  581. package/dist/components/tour/StepContainer.js.map +0 -1
  582. package/dist/components/tour/StepNavigation.d.ts +0 -13
  583. package/dist/components/tour/StepNavigation.d.ts.map +0 -1
  584. package/dist/components/tour/StepNavigation.js +0 -20
  585. package/dist/components/tour/StepNavigation.js.map +0 -1
  586. package/dist/components/tour/StepTitle.d.ts +0 -7
  587. package/dist/components/tour/StepTitle.d.ts.map +0 -1
  588. package/dist/components/tour/StepTitle.js +0 -5
  589. package/dist/components/tour/StepTitle.js.map +0 -1
  590. package/dist/components/tour/context.d.ts +0 -17
  591. package/dist/components/tour/context.d.ts.map +0 -1
  592. package/dist/components/tour/context.js +0 -48
  593. package/dist/components/tour/context.js.map +0 -1
  594. package/dist/components/tour/index.d.ts +0 -9
  595. package/dist/components/tour/index.d.ts.map +0 -1
  596. package/dist/components/tour/index.js +0 -4
  597. package/dist/components/tour/index.js.map +0 -1
  598. package/dist/components/tour/utils.d.ts +0 -13
  599. package/dist/components/tour/utils.d.ts.map +0 -1
  600. package/dist/components/tour/utils.js +0 -43
  601. package/dist/components/tour/utils.js.map +0 -1
  602. package/dist/layout/src/components/tour/PortalSwitcherStep.d.ts +0 -2
  603. package/dist/layout/src/components/tour/PortalSwitcherStep.d.ts.map +0 -1
  604. package/dist/layout/src/components/tour/PortalSwitcherStep.js +0 -30
  605. package/dist/layout/src/components/tour/PortalSwitcherStep.js.map +0 -1
  606. package/src/components/Login.tsx +0 -157
  607. package/src/components/MiniLogo.tsx +0 -32
  608. package/src/components/tour/StepContainer.tsx +0 -67
  609. package/src/components/tour/StepNavigation.tsx +0 -32
  610. package/src/components/tour/StepTitle.tsx +0 -17
  611. package/src/components/tour/context.tsx +0 -56
  612. package/src/components/tour/index.ts +0 -7
  613. package/src/components/tour/utils.tsx +0 -65
@@ -0,0 +1,427 @@
1
+ import { Flex, IconBox, Text } from '@citric/core'
2
+ import { ArrowLeft, Check, ChevronRight } from '@citric/icons'
3
+ import { IconButton } from '@citric/ui'
4
+ import { WithStyle, listToClass, theme } from '@stack-spot/portal-theme'
5
+ import { Dictionary, useTranslate } from '@stack-spot/portal-translate'
6
+ import { ReactElement, useCallback, useEffect, useMemo, useState } from 'react'
7
+ import { styled } from 'styled-components'
8
+ import { AnchorComponent, useAnchorTag } from '../context/anchor'
9
+ import { useKeyboardControls } from '../hooks/keyboard'
10
+
11
+ interface CustomLabel {
12
+ /**
13
+ * A unique identifier for this label. This is also used to read this label to screen readers.
14
+ */
15
+ id: string,
16
+ /**
17
+ * A custom label that can be made up of any React component.
18
+ */
19
+ element: React.ReactNode,
20
+ }
21
+
22
+ export interface Action {
23
+ /**
24
+ * The label of the action.
25
+ */
26
+ label: string | CustomLabel,
27
+ /**
28
+ * Function to run on a click.
29
+ */
30
+ onClick?: (event?: React.MouseEvent) => void,
31
+ /**
32
+ * URL to open on a click.
33
+ */
34
+ href?: string,
35
+ /**
36
+ * Target of the URL to open.
37
+ */
38
+ target?: React.AnchorHTMLAttributes<HTMLAnchorElement>['target'],
39
+ /**
40
+ * Language of the linked document.
41
+ */
42
+ lang?: React.AnchorHTMLAttributes<HTMLAnchorElement>['lang'],
43
+ /**
44
+ * Language of the destination URL.
45
+ */
46
+ hrefLang?: React.AnchorHTMLAttributes<HTMLAnchorElement>['hrefLang'],
47
+ /**
48
+ * The title of the action.
49
+ */
50
+ title?: string,
51
+ }
52
+
53
+ interface ItemWithIcon {
54
+ /**
55
+ * An Icon to appear at the left of the item.
56
+ */
57
+ icon?: React.ReactElement,
58
+ /**
59
+ * An Icon to appear at the right of the item.
60
+ */
61
+ iconRight?: React.ReactElement,
62
+ }
63
+
64
+ export interface ListAction extends ItemWithIcon, Action {
65
+ /**
66
+ * Whether or not this option is currently active.
67
+ */
68
+ active?: boolean,
69
+ /**
70
+ * Icon to render when this option is active.
71
+ */
72
+ iconActive?: React.ReactElement,
73
+ /**
74
+ * A class to be added to this item.
75
+ */
76
+ className?: string,
77
+ /**
78
+ * Defines the ARIA role of the element for accessibility purposes. Example: "button", "dialog", etc.
79
+ */
80
+ role?: string,
81
+ }
82
+
83
+ interface ListGroup {
84
+ /**
85
+ * If this group is rendered as a section with its items right below it or a collapsible, which requires a click to open a submenu.
86
+ */
87
+ type?: 'section' | 'collapsible',
88
+ /**
89
+ * The items of this group.
90
+ */
91
+ children: ListItem[],
92
+ /**
93
+ * A class to be added to this item.
94
+ */
95
+ className?: string,
96
+ }
97
+
98
+ interface ListSection extends ListGroup {
99
+ type: 'section',
100
+ /**
101
+ * The section's title.
102
+ */
103
+ label?: string,
104
+ }
105
+
106
+ interface ListCollapsible extends ListGroup, ItemWithIcon {
107
+ type?: 'collapsible',
108
+ /**
109
+ * The title of the collapsible menu.
110
+ */
111
+ label: string,
112
+ }
113
+
114
+ type ListItem = ListSection | ListCollapsible | ListAction
115
+
116
+ interface CurrentItemList {
117
+ items: ListItem[],
118
+ label?: string,
119
+ parent?: CurrentItemList,
120
+ }
121
+
122
+ const ANIMATION_DURATION_MS = 300
123
+ const MAX_HEIGHT_TRANSITION = `max-height ease-in ${ANIMATION_DURATION_MS / 1000}s`
124
+
125
+ export interface SelectionListProps extends WithStyle {
126
+ /**
127
+ * The id of this selection list. This is important for accessibility. Be sure to link it to the aria-controls tag of the element who
128
+ * controls the visibility of this selection list.
129
+ */
130
+ id: string,
131
+ /**
132
+ * Whether or not the selection list is visible.
133
+ */
134
+ visible?: boolean,
135
+ /**
136
+ * The options in the selection list.
137
+ */
138
+ items: ListItem[],
139
+ /**
140
+ * Function to run when the selection list is hidden/closed.
141
+ */
142
+ onHide?: () => void,
143
+ /**
144
+ * The maximum height for the selection list.
145
+ * @default "300px"
146
+ */
147
+ maxHeight?: string,
148
+ /**
149
+ * A React element to render right before the items.
150
+ */
151
+ before?: ReactElement,
152
+ /**
153
+ * A React element to render right after the items.
154
+ */
155
+ after?: ReactElement,
156
+ /**
157
+ * Whether or not this list should be scrollable.
158
+ */
159
+ scroll?: boolean,
160
+ /**
161
+ * Show list as card
162
+ */
163
+ showListAsCard?: boolean,
164
+ }
165
+
166
+ interface RenderOptions {
167
+ setCurrent: (current: CurrentItemList) => void,
168
+ controllerId?: string,
169
+ onClose?: () => void,
170
+ Link: AnchorComponent,
171
+ }
172
+
173
+ const SelectionBox = styled.div<{ $maxHeight: string, $scroll?: boolean, $showListAsCard?: boolean }>`
174
+ max-height: 0;
175
+ overflow-y: ${({ $scroll }) => $scroll ? 'auto' : 'hidden'};
176
+ overflow-x: hidden;
177
+ transition: ${MAX_HEIGHT_TRANSITION}, visibility 0s ${ANIMATION_DURATION_MS / 1000}s;
178
+ z-index: 1;
179
+ box-shadow: 4px 4px 48px #000;
180
+ border-radius: 0.5rem;
181
+ visibility: hidden;
182
+
183
+ .selection-list-content {
184
+ display: flex;
185
+ flex-direction: column;
186
+ border-radius: 0.5rem;
187
+ background-color: ${theme.color.light['300']};
188
+ padding-inline: ${({ $showListAsCard }) => $showListAsCard ? '8px' : '0'};
189
+ }
190
+
191
+ .section-title, li > a {
192
+ height: 40px;
193
+ padding: 0 8px;
194
+ display: flex;
195
+ flex-direction: row;
196
+ align-items: center;
197
+ }
198
+
199
+ li > a {
200
+ gap: 4px;
201
+ transition: background-color 0.2s;
202
+ &:hover, &:focus {
203
+ background: ${theme.color.light['400']};
204
+ }
205
+ .label {
206
+ flex: 1;
207
+ white-space: nowrap;
208
+ overflow: hidden;
209
+ text-overflow: ellipsis;
210
+ }
211
+ }
212
+
213
+ li.action {
214
+ background-color: ${({ $showListAsCard }) => $showListAsCard ? theme.color.light['400'] : ''};
215
+ border: ${({ $showListAsCard }) => '1px solid' + $showListAsCard ? theme.color.light['500'] : 'transparent'};
216
+ border-radius: ${({ $showListAsCard }) => $showListAsCard ? '4px' : '0'};
217
+ margin-bottom: ${({ $showListAsCard }) => $showListAsCard ? '8px' : '0'};
218
+ }
219
+
220
+ li.section {
221
+ border-bottom: 2px solid;
222
+ border-bottom-color: ${({ $showListAsCard }) => $showListAsCard ? 'transparent' : theme.color.light['600']};
223
+ &:last-child {
224
+ border-bottom: none;
225
+ }
226
+ }
227
+
228
+ &.visible {
229
+ max-height: ${({ $maxHeight }) => $maxHeight};
230
+ visibility: visible;
231
+ transition: ${MAX_HEIGHT_TRANSITION};
232
+ }
233
+ `
234
+
235
+ function renderAction({
236
+ label, href, onClick, icon, iconRight, active, target, iconActive = <Check />,
237
+ className = '', lang, hrefLang, title, role = 'link',
238
+ }: ListAction, { onClose, Link }: RenderOptions) {
239
+ function handleClick(event: React.MouseEvent) {
240
+ onClick?.(event)
241
+ onClose?.()
242
+ }
243
+
244
+ const isTextLabel = typeof label === 'string'
245
+
246
+ return (
247
+ <li key={isTextLabel ? label : label.id} className="action" title={title}>
248
+ <Link href={href} onClick={handleClick} target={target} tabIndex={0} aria-current={active && 'page'}
249
+ className={className} lang={lang} hrefLang={hrefLang} role={role}>
250
+ {icon && <IconBox>{icon}</IconBox>}
251
+ {isTextLabel ? <Text appearance="body2" className="label">{label}</Text> : label.element}
252
+ {iconRight && <IconBox>{iconRight}</IconBox>}
253
+ {active && <IconBox>{iconActive}</IconBox>}
254
+ </Link>
255
+ </li>
256
+ )
257
+ }
258
+
259
+ function renderCollapsible({ label, icon, iconRight, className = '', children }:
260
+ ListCollapsible, { setCurrent, controllerId, Link }: RenderOptions) {
261
+ function handleClick(ev: React.MouseEvent) {
262
+ //accessibility: this will tell the screen reader the section was expanded before this link is removed from the DOM.
263
+ (ev.target as HTMLElement)?.setAttribute?.('aria-expanded', 'true')
264
+ setCurrent({ items: children, label })
265
+ }
266
+ return (
267
+ <li key={label} className="collapsible">
268
+ <Link onClick={handleClick} tabIndex={0} className={className} aria-expanded={false} aria-controls={controllerId}>
269
+ {icon && <IconBox>{icon}</IconBox>}
270
+ <Text appearance="body2" className="label">{label}</Text>
271
+ {iconRight && <IconBox>{iconRight}</IconBox>}
272
+ <IconBox><ChevronRight /></IconBox>
273
+ </Link>
274
+ </li>
275
+ )
276
+ }
277
+
278
+ function renderSection({ label, className = '', children }: ListSection, options: RenderOptions) {
279
+ return (
280
+ <li key={label ?? children.map(c => c.label).join('-')} className={`${className} section`}>
281
+ {label && <Text appearance="overheader2" colorScheme="light.700" className="section-title">{label}</Text>}
282
+ <ul>{children.map(i => renderItem(i, options))}</ul>
283
+ </li>
284
+ )
285
+ }
286
+
287
+ function renderItem(item: ListItem, options: RenderOptions) {
288
+ if ('children' in item) {
289
+ return item.type === 'section' ? renderSection(item, options) : renderCollapsible(item, options)
290
+ }
291
+ return renderAction(item, options)
292
+ }
293
+
294
+ /**
295
+ * Renders a component that allows the selection of one item. The list is show/hidden according to the prop `visible`.
296
+ *
297
+ * The items in this list can be grouped into multiple sections. Sections may be displayed on a column (section) or might replace the
298
+ * current list of options with another list of options (collapsible).
299
+ *
300
+ * This component implements keyboard controls and accessibility features.
301
+ * @param props the component's props {@link SelectionListProps}.
302
+ */
303
+ export const SelectionList = ({
304
+ id, items, className, style, visible = true, maxHeight = '300px', onHide, before, after, scroll, showListAsCard,
305
+ }: SelectionListProps) => {
306
+ const Link = useAnchorTag()
307
+ const t = useTranslate(dictionary)
308
+ const [current, setCurrent] = useState<CurrentItemList>({ items })
309
+ const { keyboardControlledElement: wrapper, attachKeyboardListeners, detachKeyboardListeners } = useKeyboardControls(
310
+ { onPressEscape: onHide, querySelectors: 'li.action a, li.collapsible a, button' },
311
+ )
312
+
313
+ const listItems = useMemo(
314
+ () => current.items.map(i => renderItem(
315
+ i,
316
+ {
317
+ setCurrent: (next: CurrentItemList) => setCurrent({ ...next, parent: current }),
318
+ onClose: onHide,
319
+ controllerId: id,
320
+ Link,
321
+ },
322
+ )),
323
+ [current],
324
+ )
325
+
326
+ useEffect(() => {
327
+ const selectionBox = wrapper.current
328
+ if (!selectionBox) return
329
+
330
+ const handleTransitionEnd = () => {
331
+ selectionBox.style.overflow = 'auto'
332
+ }
333
+
334
+ selectionBox.addEventListener('transitionend', handleTransitionEnd)
335
+
336
+ return () => {
337
+ selectionBox.removeEventListener('transitionend', handleTransitionEnd)
338
+ }
339
+ }, [])
340
+
341
+ const handleExpand = () => {
342
+ const selectionBox = wrapper.current
343
+ if (selectionBox) {
344
+ selectionBox.style.overflow = 'hidden'
345
+ }
346
+ }
347
+
348
+ const hide = useCallback((event: Event) => {
349
+ const target = (event.target as HTMLElement | null)
350
+ // if the element is not in the DOM anymore, we'll consider the click was inside the selection list
351
+ const isClickInsideSelectionList = !target?.isConnected || wrapper.current?.contains(target)
352
+ const isAction = target?.classList?.contains('action') || !!target?.closest('.action')
353
+ const isInsideTour = !!target?.closest('#___reactour')
354
+ if (!isInsideTour && (!isClickInsideSelectionList || isAction)) onHide?.()
355
+ }, [])
356
+
357
+ useEffect(() => {
358
+ handleExpand()
359
+ function removeListeners() {
360
+ detachKeyboardListeners()
361
+ document.removeEventListener('click', hide)
362
+ }
363
+ if (visible) {
364
+ setCurrent({ items })
365
+ attachKeyboardListeners()
366
+ if (onHide) setTimeout(() => document.addEventListener('click', hide), 50)
367
+ } else {
368
+ removeListeners()
369
+ }
370
+ return () => removeListeners()
371
+ }, [visible, items])
372
+
373
+ return (
374
+ <SelectionBox
375
+ id={id}
376
+ ref={wrapper}
377
+ $maxHeight={maxHeight}
378
+ style={style}
379
+ className={listToClass(['selection-list', visible ? 'visible' : undefined, className])}
380
+ $scroll={scroll}
381
+ aria-hidden={!visible}
382
+ $showListAsCard={showListAsCard}
383
+ >
384
+ <div className="selection-list-content">
385
+ {before}
386
+ {current.parent
387
+ ? (
388
+ <Flex mt={5} mb={1} alignItems="center">
389
+ <IconButton
390
+ onClick={(ev) => {
391
+ // accessibility: this will tell the screen reader the section was collapsed before this button is removed from the DOM.
392
+ (ev.target as HTMLElement)?.setAttribute?.('aria-expanded', 'false')
393
+ setCurrent(current.parent ?? { items })
394
+ }}
395
+ sx={{ mr: 3 }}
396
+ title={t.back}
397
+ aria-controls={id}
398
+ aria-expanded={true}
399
+ >
400
+ <ArrowLeft />
401
+ </IconButton>
402
+ <Text appearance="microtext1">{current.label}</Text>
403
+ </Flex>
404
+ )
405
+ : undefined
406
+ }
407
+ <ul>
408
+ {listItems}
409
+ {after &&
410
+ <li className="action">
411
+ {after}
412
+ </li>
413
+ }
414
+ </ul>
415
+ </div>
416
+ </SelectionBox>
417
+ )
418
+ }
419
+
420
+ const dictionary = {
421
+ en: {
422
+ back: 'Go back',
423
+ },
424
+ pt: {
425
+ back: 'Voltar',
426
+ },
427
+ } satisfies Dictionary
@@ -0,0 +1,67 @@
1
+ import { OneOfColorSchemesWithVariants, OneOfPalettesWithVariants, Theme } from '@citric/core'
2
+ import { getColor } from '@citric/core/dist/utils/theme'
3
+ import { Tooltip } from '@citric/ui'
4
+ import styled from 'styled-components'
5
+
6
+ type Color = OneOfColorSchemesWithVariants | OneOfPalettesWithVariants
7
+
8
+ export type Status = 'success' | 'warning' | 'danger' | 'unknown' | 'progress'
9
+
10
+ interface Props {
11
+ /** The status of the component which determines its color */
12
+ status?: Status,
13
+ /** Tooltip text to be displayed on hover */
14
+ tooltip?: string,
15
+ }
16
+
17
+ const statusToColor: Record<Status, Color> = {
18
+ success: 'success.500',
19
+ warning: 'warning.500',
20
+ danger: 'danger.500',
21
+ progress: 'secondary.500',
22
+ unknown: 'light.contrastText',
23
+ }
24
+
25
+ /**
26
+ * Get the color corresponding to the status.
27
+ *
28
+ * @param {Theme} theme - The theme object.
29
+ * @param {Status} [status] - The status of the component.
30
+ * @returns {string} The color corresponding to the status.
31
+ */
32
+ function getColorFromStatus(theme: Theme, status?: Status) {
33
+ const colorName = status && status in statusToColor ? statusToColor[status] : statusToColor.unknown
34
+ return getColor(theme, colorName)
35
+ }
36
+
37
+ interface WithTooltip {
38
+ /** Tooltip text to be displayed on hover */
39
+ tooltip?: string,
40
+ /** Additional class names for the component */
41
+ className?: string,
42
+ /** Inline styles for the component */
43
+ style?: React.CSSProperties,
44
+ }
45
+
46
+ /**
47
+ * CircleWithTooltip component that displays a circle with an optional tooltip.
48
+ *
49
+ * @param props the component's props {@link WithTooltip}.
50
+ */
51
+ const CircleWithTooltip = ({ tooltip, className, style }: WithTooltip) => {
52
+ const circle = <div style={style} className={className}></div>
53
+ return tooltip && tooltip.length ? <Tooltip text={tooltip}>{circle}</Tooltip> : circle
54
+ }
55
+
56
+ /**
57
+ * Renders a component that displays a colored circle based on the status.
58
+ * It also supports an optional tooltip.
59
+ *
60
+ * @param props the component's props {@link Props}.
61
+ */
62
+ export const StatusCircle = styled(CircleWithTooltip)<Props>`
63
+ background-color: ${({ status, theme }) => getColorFromStatus(theme as any, status)};
64
+ width: 12px;
65
+ height: 12px;
66
+ border-radius: 50%;
67
+ `
@@ -0,0 +1,97 @@
1
+ import { Button, Flex, Text } from '@citric/core'
2
+ import { Dictionary, useTranslate } from '@stack-spot/portal-translate'
3
+ import { FC, useContext } from 'react'
4
+ import { styled } from 'styled-components'
5
+ import { ButtonProps } from '@citric/core/dist/Button'
6
+ import { useLoadingComponent } from '../../context/loading'
7
+ import { StepperContext } from './Stepper'
8
+
9
+ export interface StepperNavigationProps extends ButtonProps{
10
+ /**
11
+ * Prop used to pass specific text to the next button.
12
+ */
13
+ nextButtonText?: string,
14
+ /**
15
+ * Function that is rendered when pressing the skip button.
16
+ */
17
+ onSkip?: () => void,
18
+ /**
19
+ * Boolean that is used as a conditional to appear the skip button.
20
+ */
21
+ canSkip?: boolean,
22
+ /**
23
+ * Boolean that is used as a conditional to appear the loading icon in next button.
24
+ */
25
+ isLoading?: boolean,
26
+ /**
27
+ * Function that is rendered when pressing the back button.
28
+ */
29
+ onGoBack?: () => void,
30
+ /**
31
+ * Function that is rendered when pressing the next button.
32
+ */
33
+ onSubmit?: () => void,
34
+ }
35
+
36
+ const Wrapper = styled(Flex)`
37
+ width: 100%;
38
+ justify-content: space-between;
39
+ `
40
+
41
+ /**
42
+ * Renders a component that represents the stepper component's navigation buttons, containing the button options (back, skip, and next).
43
+ *
44
+ * The component stepper wraps this component.
45
+ */
46
+
47
+ export const StepperNavigation: FC<Omit<StepperNavigationProps, 'children'>> = (
48
+ { nextButtonText, onSkip, onGoBack, canSkip = false, isLoading, disabled, onSubmit }) => {
49
+ const t = useTranslate(dictionary)
50
+ const { goToNextStep, goToPreviousStep } = useContext(StepperContext)
51
+ const Loading = useLoadingComponent()
52
+
53
+ return (
54
+ <Wrapper>
55
+ <Button
56
+ appearance="contained"
57
+ colorScheme="inverse"
58
+ onClick={() => {
59
+ onGoBack && onGoBack()
60
+ goToPreviousStep()
61
+ }}
62
+ >
63
+ {t.back}
64
+ </Button>
65
+ <Flex>
66
+ {canSkip && (
67
+ <Button
68
+ appearance="text"
69
+ colorScheme="inverse"
70
+ onClick={() => {
71
+ onSkip && onSkip()
72
+ goToNextStep()
73
+ }}
74
+ >
75
+ {t.skip}
76
+ </Button>
77
+ )}
78
+ <Button type="submit" onClick={onSubmit} sx={{ position: 'relative' }} disabled={isLoading || disabled}>
79
+ <Text as="span" sx={{ visibility: isLoading ? 'hidden' : 'visible' }}>{nextButtonText ?? t.next}</Text>
80
+ {isLoading && Loading}
81
+ </Button>
82
+ </Flex>
83
+ </Wrapper>
84
+ )}
85
+
86
+ const dictionary = {
87
+ en: {
88
+ back: 'Back',
89
+ skip: 'Skip',
90
+ next: 'Next',
91
+ },
92
+ pt: {
93
+ back: 'Voltar',
94
+ skip: 'Pular',
95
+ next: 'Próximo',
96
+ },
97
+ } satisfies Dictionary
@@ -0,0 +1,30 @@
1
+ import { Box } from '@citric/core'
2
+ import { FC, PropsWithChildren } from 'react'
3
+ import { styled } from 'styled-components'
4
+
5
+ export interface StepProps extends PropsWithChildren {
6
+ /**
7
+ * Name given to the step.
8
+ */
9
+ name: string,
10
+ /**
11
+ * Title given to the step.
12
+ */
13
+ title: string,
14
+ }
15
+
16
+ const Wrapper = styled(Box)`
17
+ width: 100%;
18
+ `
19
+
20
+ /**
21
+ * Renders a component that represents the body of a step within the stepper component.
22
+ *
23
+ * The component stepper wraps this component.
24
+ */
25
+
26
+ export const Step: FC<StepProps> = ({ children }) => (
27
+ <Wrapper>
28
+ {children}
29
+ </Wrapper>
30
+ )