@ultraviolet/ui 1.51.1 → 1.51.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (435) hide show
  1. package/dist/components/ActionBar/index.d.ts +20 -0
  2. package/dist/components/ActionBar/index.js +30 -0
  3. package/dist/components/Alert/index.d.ts +27 -0
  4. package/dist/components/Alert/index.js +115 -0
  5. package/dist/components/Avatar/index.d.ts +43 -0
  6. package/dist/components/Avatar/index.js +57 -0
  7. package/dist/components/Badge/index.d.ts +31 -0
  8. package/dist/components/Badge/index.js +99 -0
  9. package/dist/components/Banner/assets/default-image-small.svg.js +4 -0
  10. package/dist/components/Banner/assets/default-image.svg.js +4 -0
  11. package/dist/components/Banner/index.d.ts +24 -0
  12. package/dist/components/Banner/index.js +116 -0
  13. package/dist/components/BarChart/Tooltip.d.ts +9 -0
  14. package/dist/components/BarChart/Tooltip.js +41 -0
  15. package/dist/components/BarChart/index.d.ts +27 -0
  16. package/dist/components/BarChart/index.js +69 -0
  17. package/dist/components/BarStack/index.d.ts +36 -0
  18. package/dist/components/BarStack/index.js +114 -0
  19. package/dist/components/Breadcrumbs/index.d.ts +30 -0
  20. package/dist/components/Breadcrumbs/index.js +73 -0
  21. package/dist/components/Bullet/index.d.ts +39 -0
  22. package/dist/components/Bullet/index.js +84 -0
  23. package/dist/components/Button/index.d.ts +120 -0
  24. package/dist/components/Button/index.js +249 -0
  25. package/dist/components/Card/index.d.ts +20 -0
  26. package/dist/components/Card/index.js +52 -0
  27. package/dist/components/Carousel/index.d.ts +19 -0
  28. package/dist/components/Carousel/index.js +123 -0
  29. package/dist/components/Checkbox/index.d.ts +36 -0
  30. package/dist/components/Checkbox/index.js +262 -0
  31. package/dist/components/CheckboxGroup/index.d.ts +24 -0
  32. package/dist/components/CheckboxGroup/index.js +116 -0
  33. package/dist/components/CopyButton/index.d.ts +19 -0
  34. package/dist/components/CopyButton/index.js +23 -0
  35. package/dist/components/DateInput/datepicker.css.js +4 -0
  36. package/dist/components/DateInput/index.d.ts +38 -0
  37. package/dist/components/DateInput/index.js +182 -0
  38. package/dist/components/Dialog/Context.d.ts +7 -0
  39. package/dist/components/Dialog/Context.js +13 -0
  40. package/dist/components/Dialog/constants.d.ts +2 -0
  41. package/dist/components/Dialog/index.d.ts +87 -0
  42. package/dist/components/Dialog/index.js +66 -0
  43. package/dist/components/Dialog/subComponents/Button.d.ts +7 -0
  44. package/dist/components/Dialog/subComponents/Button.js +15 -0
  45. package/dist/components/Dialog/subComponents/Buttons.d.ts +7 -0
  46. package/dist/components/Dialog/subComponents/Buttons.js +12 -0
  47. package/dist/components/Dialog/subComponents/CancelButton.d.ts +8 -0
  48. package/dist/components/Dialog/subComponents/CancelButton.js +9 -0
  49. package/dist/components/Dialog/subComponents/Stack.d.ts +6 -0
  50. package/dist/components/Dialog/subComponents/Stack.js +8 -0
  51. package/dist/components/Dialog/subComponents/Text.d.ts +6 -0
  52. package/dist/components/Dialog/subComponents/Text.js +8 -0
  53. package/dist/components/EmptyState/index.d.ts +38 -0
  54. package/dist/components/EmptyState/index.js +90 -0
  55. package/dist/components/Expandable/index.d.ts +33 -0
  56. package/dist/components/Expandable/index.js +75 -0
  57. package/dist/components/GlobalAlert/GlobalAlertLink.d.ts +3 -0
  58. package/dist/components/GlobalAlert/GlobalAlertLink.js +23 -0
  59. package/dist/components/GlobalAlert/index.d.ts +40 -0
  60. package/dist/components/GlobalAlert/index.js +59 -0
  61. package/dist/components/LineChart/CustomLegend.d.ts +13 -0
  62. package/dist/components/LineChart/CustomLegend.js +113 -0
  63. package/dist/components/LineChart/Tooltip.d.ts +6 -0
  64. package/dist/components/LineChart/Tooltip.js +35 -0
  65. package/dist/components/LineChart/helpers.d.ts +8 -0
  66. package/dist/{src/components → components}/LineChart/helpers.js +22 -10
  67. package/dist/components/LineChart/index.d.ts +25 -0
  68. package/dist/components/LineChart/index.js +101 -0
  69. package/dist/components/Link/index.d.ts +33 -0
  70. package/dist/components/Link/index.js +128 -0
  71. package/dist/components/List/Body.d.ts +6 -0
  72. package/dist/components/List/Body.js +16 -0
  73. package/dist/components/List/Cell.d.ts +12 -0
  74. package/dist/components/List/Cell.js +41 -0
  75. package/dist/components/List/HeaderCell.d.ts +11 -0
  76. package/dist/components/List/HeaderCell.js +82 -0
  77. package/dist/components/List/HeaderRow.d.ts +7 -0
  78. package/dist/components/List/HeaderRow.js +36 -0
  79. package/dist/components/List/ListContext.d.ts +34 -0
  80. package/dist/{src/components → components}/List/ListContext.js +27 -29
  81. package/dist/components/List/Row.d.ts +23 -0
  82. package/dist/components/List/Row.js +161 -0
  83. package/dist/components/List/SelectBar.d.ts +15 -0
  84. package/dist/components/List/SelectBar.js +52 -0
  85. package/dist/components/List/SkeletonRows.d.ts +7 -0
  86. package/dist/components/List/SkeletonRows.js +55 -0
  87. package/dist/components/List/constants.d.ts +2 -0
  88. package/dist/{src/components → components}/List/constants.js +4 -2
  89. package/dist/components/List/index.d.ts +68 -0
  90. package/dist/components/List/index.js +60 -0
  91. package/dist/components/Loader/index.d.ts +22 -0
  92. package/dist/components/Loader/index.js +77 -0
  93. package/dist/components/Menu/Item.d.ts +15 -0
  94. package/dist/components/Menu/Item.js +91 -0
  95. package/dist/components/Menu/index.d.ts +49 -0
  96. package/dist/components/Menu/index.js +116 -0
  97. package/dist/components/MenuV2/Group.d.ts +7 -0
  98. package/dist/components/MenuV2/Group.js +21 -0
  99. package/dist/components/MenuV2/Item.d.ts +16 -0
  100. package/dist/components/MenuV2/Item.js +113 -0
  101. package/dist/components/MenuV2/index.d.ts +90 -0
  102. package/dist/components/MenuV2/index.js +90 -0
  103. package/dist/components/Meter/index.d.ts +26 -0
  104. package/dist/components/Meter/index.js +63 -0
  105. package/dist/components/Modal/Dialog.d.ts +3 -0
  106. package/dist/components/Modal/Dialog.js +141 -0
  107. package/dist/components/Modal/Disclosure.d.ts +3 -0
  108. package/dist/{src/components → components}/Modal/Disclosure.js +12 -12
  109. package/dist/components/Modal/constants.d.ts +3 -0
  110. package/dist/{src/components → components}/Modal/constants.js +8 -6
  111. package/dist/components/Modal/index.d.ts +42 -0
  112. package/dist/components/Modal/index.js +79 -0
  113. package/dist/components/Modal/types.d.ts +48 -0
  114. package/dist/components/Notice/index.d.ts +11 -0
  115. package/dist/components/Notice/index.js +23 -0
  116. package/dist/components/Notification/index.d.ts +36 -0
  117. package/dist/components/Notification/index.js +49 -0
  118. package/dist/components/Notification/react-toastify.css.js +4 -0
  119. package/dist/components/NumberInput/helpers.d.ts +4 -0
  120. package/dist/{src/components → components}/NumberInput/helpers.js +6 -2
  121. package/dist/components/NumberInput/index.d.ts +41 -0
  122. package/dist/components/NumberInput/index.js +262 -0
  123. package/dist/components/NumberInputV2/index.d.ts +27 -0
  124. package/dist/components/NumberInputV2/index.js +221 -0
  125. package/dist/components/Pagination/getPageNumbers.d.ts +8 -0
  126. package/dist/{src/components → components}/Pagination/getPageNumbers.js +3 -9
  127. package/dist/components/Pagination/index.d.ts +30 -0
  128. package/dist/components/Pagination/index.js +88 -0
  129. package/dist/components/PasswordCheck/index.d.ts +20 -0
  130. package/dist/components/PasswordCheck/index.js +24 -0
  131. package/dist/components/PasswordStrengthMeter/index.d.ts +39 -0
  132. package/dist/components/PasswordStrengthMeter/index.js +96 -0
  133. package/dist/components/PieChart/Legends.d.ts +9 -0
  134. package/dist/components/PieChart/Legends.js +142 -0
  135. package/dist/components/PieChart/Tooltip.d.ts +12 -0
  136. package/dist/components/PieChart/Tooltip.js +49 -0
  137. package/dist/components/PieChart/index.d.ts +20 -0
  138. package/dist/components/PieChart/index.js +101 -0
  139. package/dist/components/PieChart/types.d.ts +7 -0
  140. package/dist/components/Popover/index.d.ts +55 -0
  141. package/dist/components/Popover/index.js +100 -0
  142. package/dist/components/Popup/animations.d.ts +11 -0
  143. package/dist/{src/components → components}/Popup/animations.js +7 -6
  144. package/dist/components/Popup/helpers.d.ts +31 -0
  145. package/dist/components/Popup/helpers.js +216 -0
  146. package/dist/components/Popup/index.d.ts +72 -0
  147. package/dist/components/Popup/index.js +297 -0
  148. package/dist/components/ProgressBar/index.d.ts +14 -0
  149. package/dist/components/ProgressBar/index.js +53 -0
  150. package/dist/components/Radio/index.d.ts +21 -0
  151. package/dist/components/Radio/index.js +133 -0
  152. package/dist/components/RadioGroup/index.d.ts +25 -0
  153. package/dist/components/RadioGroup/index.js +99 -0
  154. package/dist/components/Row/index.d.ts +22 -0
  155. package/dist/components/Row/index.js +34 -0
  156. package/dist/components/SelectInput/index.d.ts +75 -0
  157. package/dist/components/SelectInput/index.js +516 -0
  158. package/dist/components/SelectInputV2/Dropdown.d.ts +23 -0
  159. package/dist/components/SelectInputV2/Dropdown.js +429 -0
  160. package/dist/components/SelectInputV2/DropdownOption.d.ts +8 -0
  161. package/dist/components/SelectInputV2/DropdownOption.js +62 -0
  162. package/dist/components/SelectInputV2/SearchBarDropdown.d.ts +9 -0
  163. package/dist/components/SelectInputV2/SearchBarDropdown.js +107 -0
  164. package/dist/components/SelectInputV2/SelectBar.d.ts +14 -0
  165. package/dist/components/SelectInputV2/SelectBar.js +224 -0
  166. package/dist/components/SelectInputV2/SelectInputProvider.d.ts +41 -0
  167. package/dist/{src/components → components}/SelectInputV2/SelectInputProvider.js +38 -36
  168. package/dist/components/SelectInputV2/findOptionInOptions.d.ts +2 -0
  169. package/dist/components/SelectInputV2/findOptionInOptions.js +12 -0
  170. package/dist/components/SelectInputV2/index.d.ts +115 -0
  171. package/dist/components/SelectInputV2/index.js +87 -0
  172. package/dist/components/SelectInputV2/types.d.ts +38 -0
  173. package/dist/{src/components → components}/SelectInputV2/types.js +4 -2
  174. package/dist/components/SelectableCard/index.d.ts +25 -0
  175. package/dist/components/SelectableCard/index.js +137 -0
  176. package/dist/components/SelectableCardGroup/index.d.ts +23 -0
  177. package/dist/components/SelectableCardGroup/index.js +107 -0
  178. package/dist/components/Separator/index.d.ts +17 -0
  179. package/dist/components/Separator/index.js +56 -0
  180. package/dist/components/Skeleton/Block.d.ts +3 -0
  181. package/dist/components/Skeleton/Block.js +38 -0
  182. package/dist/components/Skeleton/Blocks.d.ts +4 -0
  183. package/dist/components/Skeleton/Blocks.js +38 -0
  184. package/dist/components/Skeleton/BoxWithIcon.d.ts +4 -0
  185. package/dist/components/Skeleton/BoxWithIcon.js +36 -0
  186. package/dist/components/Skeleton/Donut.d.ts +1 -0
  187. package/dist/components/Skeleton/Donut.js +61 -0
  188. package/dist/components/Skeleton/IconSkeleton.d.ts +5 -0
  189. package/dist/components/Skeleton/IconSkeleton.js +22 -0
  190. package/dist/components/Skeleton/Line.d.ts +5 -0
  191. package/dist/components/Skeleton/Line.js +16 -0
  192. package/dist/components/Skeleton/List.d.ts +4 -0
  193. package/dist/components/Skeleton/List.js +56 -0
  194. package/dist/components/Skeleton/Slider.d.ts +3 -0
  195. package/dist/components/Skeleton/Slider.js +40 -0
  196. package/dist/components/Skeleton/Square.d.ts +5 -0
  197. package/dist/components/Skeleton/Square.js +12 -0
  198. package/dist/components/Skeleton/index.d.ts +47 -0
  199. package/dist/components/Skeleton/index.js +79 -0
  200. package/dist/components/Snippet/index.d.ts +23 -0
  201. package/dist/components/Snippet/index.js +182 -0
  202. package/dist/components/Stack/index.d.ts +23 -0
  203. package/dist/components/Stack/index.js +29 -0
  204. package/dist/components/Status/index.d.ts +32 -0
  205. package/dist/components/Status/index.js +72 -0
  206. package/dist/components/StepList/index.d.ts +33 -0
  207. package/dist/components/StepList/index.js +58 -0
  208. package/dist/components/Stepper/index.d.ts +15 -0
  209. package/dist/components/Stepper/index.js +145 -0
  210. package/dist/components/SwitchButton/FocusOverlay.d.ts +8 -0
  211. package/dist/components/SwitchButton/FocusOverlay.js +38 -0
  212. package/dist/components/SwitchButton/index.d.ts +26 -0
  213. package/dist/components/SwitchButton/index.js +76 -0
  214. package/dist/components/Table/Body.d.ts +6 -0
  215. package/dist/components/Table/Body.js +7 -0
  216. package/dist/components/Table/Cell.d.ts +9 -0
  217. package/dist/components/Table/Cell.js +19 -0
  218. package/dist/components/Table/Header.d.ts +6 -0
  219. package/dist/components/Table/Header.js +16 -0
  220. package/dist/components/Table/HeaderCell.d.ts +14 -0
  221. package/dist/components/Table/HeaderCell.js +80 -0
  222. package/dist/components/Table/HeaderRow.d.ts +7 -0
  223. package/dist/components/Table/HeaderRow.js +23 -0
  224. package/dist/components/Table/Row.d.ts +14 -0
  225. package/dist/components/Table/Row.js +80 -0
  226. package/dist/components/Table/SelectBar.d.ts +15 -0
  227. package/dist/components/Table/SelectBar.js +52 -0
  228. package/dist/components/Table/SkeletonRows.d.ts +7 -0
  229. package/dist/components/Table/SkeletonRows.js +54 -0
  230. package/dist/components/Table/TableContext.d.ts +27 -0
  231. package/dist/{src/components → components}/Table/TableContext.js +19 -21
  232. package/dist/components/Table/index.d.ts +60 -0
  233. package/dist/components/Table/index.js +67 -0
  234. package/dist/components/Tabs/Tab.d.ts +20 -0
  235. package/dist/components/Tabs/Tab.js +120 -0
  236. package/dist/components/Tabs/TabMenu.d.ts +8 -0
  237. package/dist/components/Tabs/TabMenu.js +62 -0
  238. package/dist/components/Tabs/TabMenuItem.d.ts +20 -0
  239. package/dist/components/Tabs/TabMenuItem.js +34 -0
  240. package/dist/components/Tabs/TabsContext.d.ts +8 -0
  241. package/dist/components/Tabs/TabsContext.js +7 -0
  242. package/dist/components/Tabs/index.d.ts +50 -0
  243. package/dist/components/Tabs/index.js +102 -0
  244. package/dist/components/Tag/index.d.ts +26 -0
  245. package/dist/components/Tag/index.js +144 -0
  246. package/dist/components/TagInput/index.d.ts +55 -0
  247. package/dist/components/TagInput/index.js +253 -0
  248. package/dist/components/TagList/index.d.ts +37 -0
  249. package/dist/components/TagList/index.js +98 -0
  250. package/dist/components/Text/index.d.ts +40 -0
  251. package/dist/components/Text/index.js +82 -0
  252. package/dist/components/TextArea/index.d.ts +50 -0
  253. package/dist/components/TextArea/index.js +158 -0
  254. package/dist/components/TextInput/index.d.ts +75 -0
  255. package/dist/components/TextInput/index.js +387 -0
  256. package/dist/components/TextInputV2/index.d.ts +30 -0
  257. package/dist/components/TextInputV2/index.js +190 -0
  258. package/dist/components/TimeInput/index.d.ts +25 -0
  259. package/dist/components/TimeInput/index.js +28 -0
  260. package/dist/components/Toaster/index.d.ts +46 -0
  261. package/dist/components/Toaster/index.js +83 -0
  262. package/dist/components/Toaster/react-toastify.css.js +4 -0
  263. package/dist/components/Toggle/index.d.ts +34 -0
  264. package/dist/components/Toggle/index.js +136 -0
  265. package/dist/components/ToggleGroup/index.d.ts +24 -0
  266. package/dist/components/ToggleGroup/index.js +96 -0
  267. package/dist/components/Tooltip/index.d.ts +9 -0
  268. package/dist/components/Tooltip/index.js +40 -0
  269. package/dist/components/VerificationCode/index.d.ts +36 -0
  270. package/dist/components/VerificationCode/index.js +217 -0
  271. package/dist/components/index.d.ts +75 -0
  272. package/dist/helpers/isJSON.d.ts +2 -0
  273. package/dist/{src/helpers → helpers}/isJSON.js +4 -3
  274. package/dist/helpers/jestMockMatchMedia.d.ts +6 -0
  275. package/dist/helpers/keycode.d.ts +3 -0
  276. package/dist/helpers/legend.d.ts +2 -0
  277. package/dist/helpers/legend.js +14 -0
  278. package/dist/helpers/numbers.d.ts +2 -0
  279. package/dist/helpers/recursivelyGetChildrenString.d.ts +3 -0
  280. package/dist/helpers/recursivelyGetChildrenString.js +15 -0
  281. package/dist/hooks/useIsOverflowing.d.ts +5 -0
  282. package/dist/hooks/useIsOverflowing.js +23 -0
  283. package/dist/index.d.ts +4 -3723
  284. package/dist/index.js +187 -0
  285. package/dist/mocks/list.d.ts +12 -0
  286. package/dist/theme/index.d.ts +1573 -0
  287. package/dist/theme/index.js +27 -0
  288. package/dist/types.d.ts +6 -0
  289. package/dist/utils/animations.d.ts +27 -0
  290. package/dist/{src/utils → utils}/animations.js +30 -4
  291. package/dist/utils/capitalize.d.ts +2 -0
  292. package/dist/utils/capitalize.js +4 -0
  293. package/dist/utils/ids.d.ts +1 -0
  294. package/dist/{src/utils → utils}/ids.js +5 -4
  295. package/dist/utils/index.d.ts +6 -0
  296. package/dist/utils/normalize.d.ts +2 -0
  297. package/dist/{src/utils → utils}/normalize.js +4 -3
  298. package/dist/utils/orderBy.d.ts +2 -0
  299. package/dist/utils/responsive/Breakpoint.d.ts +9 -0
  300. package/dist/utils/responsive/Breakpoint.js +15 -0
  301. package/dist/utils/responsive/index.d.ts +2 -0
  302. package/dist/utils/responsive/utilities.d.ts +3 -0
  303. package/dist/{src/utils → utils}/responsive/utilities.js +9 -6
  304. package/package.json +18 -8
  305. package/dist/react-datepicker/dist/react-datepicker.min.css.js +0 -3
  306. package/dist/react-toastify/dist/ReactToastify.min.css.js +0 -3
  307. package/dist/src/components/ActionBar/index.js +0 -40
  308. package/dist/src/components/Alert/index.js +0 -133
  309. package/dist/src/components/Avatar/index.js +0 -74
  310. package/dist/src/components/Badge/index.js +0 -116
  311. package/dist/src/components/Banner/assets/default-image-small.svg.js +0 -5
  312. package/dist/src/components/Banner/assets/default-image.svg.js +0 -5
  313. package/dist/src/components/Banner/index.js +0 -159
  314. package/dist/src/components/BarChart/Tooltip.js +0 -48
  315. package/dist/src/components/BarChart/index.js +0 -95
  316. package/dist/src/components/BarStack/index.js +0 -136
  317. package/dist/src/components/Breadcrumbs/index.js +0 -82
  318. package/dist/src/components/Bullet/index.js +0 -98
  319. package/dist/src/components/Button/index.js +0 -311
  320. package/dist/src/components/Card/index.js +0 -67
  321. package/dist/src/components/Carousel/index.js +0 -128
  322. package/dist/src/components/Checkbox/index.js +0 -316
  323. package/dist/src/components/CheckboxGroup/index.js +0 -143
  324. package/dist/src/components/CopyButton/index.js +0 -37
  325. package/dist/src/components/DateInput/index.js +0 -242
  326. package/dist/src/components/Dialog/Context.js +0 -12
  327. package/dist/src/components/Dialog/index.js +0 -88
  328. package/dist/src/components/Dialog/subComponents/Button.js +0 -21
  329. package/dist/src/components/Dialog/subComponents/Buttons.js +0 -14
  330. package/dist/src/components/Dialog/subComponents/CancelButton.js +0 -14
  331. package/dist/src/components/Dialog/subComponents/Stack.js +0 -11
  332. package/dist/src/components/Dialog/subComponents/Text.js +0 -12
  333. package/dist/src/components/EmptyState/index.js +0 -112
  334. package/dist/src/components/Expandable/index.js +0 -96
  335. package/dist/src/components/GlobalAlert/GlobalAlertLink.js +0 -38
  336. package/dist/src/components/GlobalAlert/index.js +0 -82
  337. package/dist/src/components/LineChart/CustomLegend.js +0 -138
  338. package/dist/src/components/LineChart/Tooltip.js +0 -43
  339. package/dist/src/components/LineChart/index.js +0 -131
  340. package/dist/src/components/Link/index.js +0 -147
  341. package/dist/src/components/List/Body.js +0 -16
  342. package/dist/src/components/List/Cell.js +0 -43
  343. package/dist/src/components/List/HeaderCell.js +0 -90
  344. package/dist/src/components/List/HeaderRow.js +0 -43
  345. package/dist/src/components/List/Row.js +0 -185
  346. package/dist/src/components/List/SelectBar.js +0 -48
  347. package/dist/src/components/List/SkeletonRows.js +0 -53
  348. package/dist/src/components/List/index.js +0 -75
  349. package/dist/src/components/Loader/index.js +0 -100
  350. package/dist/src/components/Menu/Item.js +0 -112
  351. package/dist/src/components/Menu/index.js +0 -129
  352. package/dist/src/components/MenuV2/Group.js +0 -25
  353. package/dist/src/components/MenuV2/Item.js +0 -139
  354. package/dist/src/components/MenuV2/index.js +0 -118
  355. package/dist/src/components/Meter/index.js +0 -76
  356. package/dist/src/components/Modal/Dialog.js +0 -182
  357. package/dist/src/components/Modal/index.js +0 -113
  358. package/dist/src/components/Notice/index.js +0 -34
  359. package/dist/src/components/Notification/index.js +0 -77
  360. package/dist/src/components/NumberInput/index.js +0 -299
  361. package/dist/src/components/NumberInputV2/index.js +0 -284
  362. package/dist/src/components/Pagination/index.js +0 -117
  363. package/dist/src/components/PasswordCheck/index.js +0 -41
  364. package/dist/src/components/PasswordStrengthMeter/index.js +0 -102
  365. package/dist/src/components/PieChart/Legends.js +0 -138
  366. package/dist/src/components/PieChart/Tooltip.js +0 -61
  367. package/dist/src/components/PieChart/index.js +0 -125
  368. package/dist/src/components/Popover/index.js +0 -146
  369. package/dist/src/components/Popup/helpers.js +0 -252
  370. package/dist/src/components/Popup/index.js +0 -383
  371. package/dist/src/components/ProgressBar/index.js +0 -57
  372. package/dist/src/components/Radio/index.js +0 -157
  373. package/dist/src/components/RadioGroup/index.js +0 -131
  374. package/dist/src/components/Row/index.js +0 -41
  375. package/dist/src/components/SelectInput/index.js +0 -610
  376. package/dist/src/components/SelectInputV2/Dropdown.js +0 -594
  377. package/dist/src/components/SelectInputV2/DropdownOption.js +0 -130
  378. package/dist/src/components/SelectInputV2/SearchBarDropdown.js +0 -122
  379. package/dist/src/components/SelectInputV2/SelectBar.js +0 -282
  380. package/dist/src/components/SelectInputV2/findOptionInOptions.js +0 -11
  381. package/dist/src/components/SelectInputV2/index.js +0 -137
  382. package/dist/src/components/SelectableCard/index.js +0 -175
  383. package/dist/src/components/SelectableCardGroup/index.js +0 -141
  384. package/dist/src/components/Separator/index.js +0 -73
  385. package/dist/src/components/Skeleton/Block.js +0 -35
  386. package/dist/src/components/Skeleton/Blocks.js +0 -34
  387. package/dist/src/components/Skeleton/BoxWithIcon.js +0 -32
  388. package/dist/src/components/Skeleton/Donut.js +0 -55
  389. package/dist/src/components/Skeleton/IconSkeleton.js +0 -19
  390. package/dist/src/components/Skeleton/Line.js +0 -13
  391. package/dist/src/components/Skeleton/List.js +0 -51
  392. package/dist/src/components/Skeleton/Slider.js +0 -36
  393. package/dist/src/components/Skeleton/Square.js +0 -9
  394. package/dist/src/components/Skeleton/index.js +0 -82
  395. package/dist/src/components/Snippet/index.js +0 -200
  396. package/dist/src/components/Stack/index.js +0 -29
  397. package/dist/src/components/Status/index.js +0 -74
  398. package/dist/src/components/StepList/index.js +0 -69
  399. package/dist/src/components/Stepper/index.js +0 -150
  400. package/dist/src/components/SwitchButton/FocusOverlay.js +0 -37
  401. package/dist/src/components/SwitchButton/index.js +0 -108
  402. package/dist/src/components/Table/Body.js +0 -9
  403. package/dist/src/components/Table/Cell.js +0 -21
  404. package/dist/src/components/Table/Header.js +0 -15
  405. package/dist/src/components/Table/HeaderCell.js +0 -103
  406. package/dist/src/components/Table/HeaderRow.js +0 -32
  407. package/dist/src/components/Table/Row.js +0 -89
  408. package/dist/src/components/Table/SelectBar.js +0 -48
  409. package/dist/src/components/Table/SkeletonRows.js +0 -51
  410. package/dist/src/components/Table/index.js +0 -82
  411. package/dist/src/components/Tabs/Tab.js +0 -138
  412. package/dist/src/components/Tabs/TabMenu.js +0 -59
  413. package/dist/src/components/Tabs/TabMenuItem.js +0 -36
  414. package/dist/src/components/Tabs/TabsContext.js +0 -6
  415. package/dist/src/components/Tabs/index.js +0 -117
  416. package/dist/src/components/Tag/index.js +0 -169
  417. package/dist/src/components/TagInput/index.js +0 -309
  418. package/dist/src/components/TagList/index.js +0 -106
  419. package/dist/src/components/Text/index.js +0 -107
  420. package/dist/src/components/TextArea/index.js +0 -210
  421. package/dist/src/components/TextInput/index.js +0 -451
  422. package/dist/src/components/TextInputV2/index.js +0 -289
  423. package/dist/src/components/TimeInput/index.js +0 -37
  424. package/dist/src/components/Toaster/index.js +0 -131
  425. package/dist/src/components/Toggle/index.js +0 -160
  426. package/dist/src/components/ToggleGroup/index.js +0 -122
  427. package/dist/src/components/Tooltip/index.js +0 -55
  428. package/dist/src/components/VerificationCode/index.js +0 -222
  429. package/dist/src/helpers/legend.js +0 -13
  430. package/dist/src/helpers/recursivelyGetChildrenString.js +0 -11
  431. package/dist/src/hooks/useIsOverflowing.js +0 -34
  432. package/dist/src/index.js +0 -77
  433. package/dist/src/theme/index.js +0 -29
  434. package/dist/src/utils/capitalize.js +0 -3
  435. package/dist/src/utils/responsive/Breakpoint.js +0 -12
@@ -0,0 +1,90 @@
1
+ import type { ButtonHTMLAttributes, ReactElement, ReactNode, Ref } from 'react';
2
+ export type DisclosureProps = {
3
+ visible: boolean;
4
+ };
5
+ type DisclosureElement = ((disclosure: DisclosureProps) => ReactElement<ButtonHTMLAttributes<HTMLButtonElement>>) | (ReactElement<ButtonHTMLAttributes<HTMLButtonElement>> & {
6
+ ref?: Ref<HTMLButtonElement>;
7
+ });
8
+ type ChildMenuProps = {
9
+ toggle: () => void;
10
+ };
11
+ /**
12
+ * A menu is a widget that offers a list of choices to the user, such as a set of actions or functions.
13
+ * A menu is usually opened, or made visible, by activating a menu button, choosing an item in a menu that opens a
14
+ * sub menu, or by invoking a command, such as `Shift + F10` on Windows, that opens a context specific menu.
15
+ * When a user activates a choice in a menu, the menu usually closes unless the choice opened a submenu.
16
+ */
17
+ export declare const MenuV2: import("react").ForwardRefExoticComponent<{
18
+ id?: string | undefined;
19
+ ariaLabel?: string | undefined;
20
+ children?: ReactNode | (({ toggle }: ChildMenuProps) => ReactNode);
21
+ className?: string | undefined;
22
+ disclosure: DisclosureElement;
23
+ hasArrow?: boolean | undefined;
24
+ visible?: boolean | undefined;
25
+ 'data-testid'?: string | undefined;
26
+ maxHeight?: string | undefined;
27
+ /**
28
+ * @deprecated: use `size` instead
29
+ */
30
+ maxWidth?: string | undefined;
31
+ /**
32
+ * By default, the portal target is children container or document.body if children is a function. You can override this
33
+ * behavior by setting a portalTarget prop.
34
+ */
35
+ portalTarget?: HTMLElement | undefined;
36
+ size?: "large" | "small" | "medium" | undefined;
37
+ /**
38
+ * The behavior of the menu when it is opened. If set to `click`, the menu will open when the user clicks on the disclosure.
39
+ * If set to `hover`, the menu will open when the user hovers over the disclosure.
40
+ */
41
+ triggerMethod?: "click" | "hover" | undefined;
42
+ } & Pick<{
43
+ id?: string | undefined;
44
+ children: ReactNode | ((renderProps: {
45
+ className?: string | undefined;
46
+ onBlur: () => void;
47
+ onFocus: () => void;
48
+ onPointerEnter: () => void;
49
+ onPointerLeave: () => void;
50
+ ref: import("react").RefObject<HTMLDivElement>;
51
+ }) => ReactNode);
52
+ maxWidth?: string | number | undefined;
53
+ placement?: import("../Popup/helpers").PopupPlacement | undefined;
54
+ text?: ReactNode;
55
+ className?: string | undefined;
56
+ containerFullWidth?: boolean | undefined;
57
+ visible?: boolean | undefined;
58
+ innerRef?: Ref<HTMLDivElement | null> | undefined;
59
+ role?: string | undefined;
60
+ 'data-testid'?: string | undefined;
61
+ hasArrow?: boolean | undefined;
62
+ onClose?: (() => void) | undefined;
63
+ tabIndex?: number | undefined;
64
+ onKeyDown?: import("react").KeyboardEventHandler | undefined;
65
+ 'aria-haspopup'?: boolean | "menu" | "dialog" | "grid" | "listbox" | "tree" | "false" | "true" | undefined;
66
+ hideOnClickOutside?: boolean | undefined;
67
+ debounceDelay?: number | undefined;
68
+ maxHeight?: string | number | undefined;
69
+ disableAnimation?: boolean | undefined;
70
+ portalTarget?: HTMLElement | undefined;
71
+ dynamicDomRendering?: boolean | undefined;
72
+ } & import("react").RefAttributes<HTMLDivElement>, "placement" | "dynamicDomRendering"> & import("react").RefAttributes<HTMLButtonElement>> & {
73
+ Item: import("react").ForwardRefExoticComponent<{
74
+ href?: string | undefined;
75
+ disabled?: boolean | undefined;
76
+ tooltip?: string | undefined;
77
+ className?: string | undefined;
78
+ children: ReactNode;
79
+ onClick?: import("react").MouseEventHandler<HTMLElement> | undefined;
80
+ borderless?: boolean | undefined;
81
+ sentiment?: ("primary" | "neutral" | "danger") | undefined;
82
+ active?: boolean | undefined;
83
+ 'data-testid'?: string | undefined;
84
+ } & import("react").RefAttributes<HTMLElement>>;
85
+ Group: ({ label, children }: {
86
+ label: string;
87
+ children: ReactNode;
88
+ }) => import("@emotion/react/jsx-runtime").JSX.Element;
89
+ };
90
+ export {};
@@ -0,0 +1,90 @@
1
+ import { jsx } from "@emotion/react/jsx-runtime";
2
+ import _styled from "@emotion/styled/base";
3
+ import { forwardRef, useState, useRef, useId, isValidElement, useImperativeHandle, cloneElement } from "react";
4
+ import { Popup } from "../Popup/index.js";
5
+ import { Stack } from "../Stack/index.js";
6
+ import { Group } from "./Group.js";
7
+ import Item from "./Item.js";
8
+ const SIZES = {
9
+ small: "180px",
10
+ medium: "280px",
11
+ large: "380px"
12
+ };
13
+ const StyledPopup = /* @__PURE__ */ _styled(Popup, process.env.NODE_ENV === "production" ? {
14
+ shouldForwardProp: (prop) => !["size"].includes(prop),
15
+ target: "e1jn11gg1"
16
+ } : {
17
+ shouldForwardProp: (prop) => !["size"].includes(prop),
18
+ target: "e1jn11gg1",
19
+ label: "StyledPopup"
20
+ })("background-color:", ({
21
+ theme
22
+ }) => theme.colors.neutral.background, ";box-shadow:", ({
23
+ theme
24
+ }) => theme.shadows.menu, ";padding:0;&[data-has-arrow='true']{&::after{border-color:", ({
25
+ theme
26
+ }) => theme.colors.neutral.background, " transparent transparent transparent;}}width:", ({
27
+ size
28
+ }) => SIZES[size], ";max-width:none;padding:", ({
29
+ theme
30
+ }) => `${theme.space["0.25"]} 0`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01lbnVWMi9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUNnQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9NZW51VjIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7XG4gIEJ1dHRvbkhUTUxBdHRyaWJ1dGVzLFxuICBDb21wb25lbnRQcm9wcyxcbiAgTW91c2VFdmVudCxcbiAgUmVhY3RFbGVtZW50LFxuICBSZWFjdE5vZGUsXG4gIFJlZixcbn0gZnJvbSAncmVhY3QnXG5pbXBvcnQge1xuICBjbG9uZUVsZW1lbnQsXG4gIGZvcndhcmRSZWYsXG4gIGlzVmFsaWRFbGVtZW50LFxuICB1c2VJZCxcbiAgdXNlSW1wZXJhdGl2ZUhhbmRsZSxcbiAgdXNlUmVmLFxuICB1c2VTdGF0ZSxcbn0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBQb3B1cCB9IGZyb20gJy4uL1BvcHVwJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IEdyb3VwIH0gZnJvbSAnLi9Hcm91cCdcbmltcG9ydCBJdGVtIGZyb20gJy4vSXRlbSdcblxuY29uc3QgU0laRVMgPSB7XG4gIHNtYWxsOiAnMTgwcHgnLFxuICBtZWRpdW06ICcyODBweCcsXG4gIGxhcmdlOiAnMzgwcHgnLFxufVxuXG5leHBvcnQgdHlwZSBEaXNjbG9zdXJlUHJvcHMgPSB7IHZpc2libGU6IGJvb2xlYW4gfVxuXG50eXBlIERpc2Nsb3N1cmVFbGVtZW50ID1cbiAgfCAoKFxuICAgICAgZGlzY2xvc3VyZTogRGlzY2xvc3VyZVByb3BzLFxuICAgICkgPT4gUmVhY3RFbGVtZW50PEJ1dHRvbkhUTUxBdHRyaWJ1dGVzPEhUTUxCdXR0b25FbGVtZW50Pj4pXG4gIHwgKFJlYWN0RWxlbWVudDxCdXR0b25IVE1MQXR0cmlidXRlczxIVE1MQnV0dG9uRWxlbWVudD4+ICYge1xuICAgICAgcmVmPzogUmVmPEhUTUxCdXR0b25FbGVtZW50PlxuICAgIH0pXG5cbmNvbnN0IFN0eWxlZFBvcHVwID0gc3R5bGVkKFBvcHVwLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZToga2V5b2YgdHlwZW9mIFNJWkVTIH0+YFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9O1xuICBib3gtc2hhZG93OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNoYWRvd3MubWVudX07XG4gIHBhZGRpbmc6IDA7XG5cbiAgJltkYXRhLWhhcy1hcnJvdz0ndHJ1ZSddIHtcbiAgICAmOjphZnRlciB7XG4gICAgICBib3JkZXItY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZH1cbiAgICAgICAgdHJhbnNwYXJlbnQgdHJhbnNwYXJlbnQgdHJhbnNwYXJlbnQ7XG4gICAgfVxuICB9XG5cbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiBTSVpFU1tzaXplXX07XG4gIG1heC13aWR0aDogbm9uZTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiBgJHt0aGVtZS5zcGFjZVsnMC4yNSddfSAwYH07XG5gXG5cbmNvbnN0IE1lbnVMaXN0ID0gc3R5bGVkKFN0YWNrKWBcbiAgb3ZlcmZsb3cteTogYXV0bztcbiAgb3ZlcmZsb3cteDogaGlkZGVuO1xuICAmOmFmdGVyLFxuICAmOmJlZm9yZSB7XG4gICAgYm9yZGVyOiBzb2xpZCB0cmFuc3BhcmVudDtcbiAgICBib3JkZXItd2lkdGg6IDlweDtcbiAgICBjb250ZW50OiAnICc7XG4gICAgaGVpZ2h0OiAwO1xuICAgIHdpZHRoOiAwO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgfVxuXG4gICY6YWZ0ZXIge1xuICAgIGJvcmRlci1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIH1cbiAgJjpiZWZvcmUge1xuICAgIGJvcmRlci1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIH1cbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PlxuICAgIHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmRXZWFrRWxldmF0ZWR9O1xuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0fTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYFxuXG50eXBlIENoaWxkTWVudVByb3BzID0ge1xuICB0b2dnbGU6ICgpID0+IHZvaWRcbn1cblxudHlwZSBNZW51UHJvcHMgPSB7XG4gIGlkPzogc3RyaW5nXG4gIGFyaWFMYWJlbD86IHN0cmluZ1xuICBjaGlsZHJlbj86IFJlYWN0Tm9kZSB8ICgoeyB0b2dnbGUgfTogQ2hpbGRNZW51UHJvcHMpID0+IFJlYWN0Tm9kZSlcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGRpc2Nsb3N1cmU6IERpc2Nsb3N1cmVFbGVtZW50XG4gIGhhc0Fycm93PzogYm9vbGVhblxuICB2aXNpYmxlPzogYm9vbGVhblxuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG4gIG1heEhlaWdodD86IHN0cmluZ1xuICAvKipcbiAgICogQGRlcHJlY2F0ZWQ6IHVzZSBgc2l6ZWAgaW5zdGVhZFxuICAgKi9cbiAgbWF4V2lkdGg/OiBzdHJpbmdcbiAgLyoqXG4gICAqIEJ5IGRlZmF1bHQsIHRoZSBwb3J0YWwgdGFyZ2V0IGlzIGNoaWxkcmVuIGNvbnRhaW5lciBvciBkb2N1bWVudC5ib2R5IGlmIGNoaWxkcmVuIGlzIGEgZnVuY3Rpb24uIFlvdSBjYW4gb3ZlcnJpZGUgdGhpc1xuICAgKiBiZWhhdmlvciBieSBzZXR0aW5nIGEgcG9ydGFsVGFyZ2V0IHByb3AuXG4gICAqL1xuICBwb3J0YWxUYXJnZXQ/OiBIVE1MRWxlbWVudFxuICBzaXplPzoga2V5b2YgdHlwZW9mIFNJWkVTXG4gIC8qKlxuICAgKiBUaGUgYmVoYXZpb3Igb2YgdGhlIG1lbnUgd2hlbiBpdCBpcyBvcGVuZWQuIElmIHNldCB0byBgY2xpY2tgLCB0aGUgbWVudSB3aWxsIG9wZW4gd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhlIGRpc2Nsb3N1cmUuXG4gICAqIElmIHNldCB0byBgaG92ZXJgLCB0aGUgbWVudSB3aWxsIG9wZW4gd2hlbiB0aGUgdXNlciBob3ZlcnMgb3ZlciB0aGUgZGlzY2xvc3VyZS5cbiAgICovXG4gIHRyaWdnZXJNZXRob2Q/OiAnY2xpY2snIHwgJ2hvdmVyJ1xufSAmIFBpY2s8Q29tcG9uZW50UHJvcHM8dHlwZW9mIFBvcHVwPiwgJ3BsYWNlbWVudCcgfCAnZHluYW1pY0RvbVJlbmRlcmluZyc+XG5cbmNvbnN0IEZ3ZE1lbnUgPSBmb3J3YXJkUmVmKFxuICAoXG4gICAge1xuICAgICAgaWQsXG4gICAgICBhcmlhTGFiZWwgPSAnTWVudScsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIGRpc2Nsb3N1cmUsXG4gICAgICBoYXNBcnJvdyA9IGZhbHNlLFxuICAgICAgcGxhY2VtZW50ID0gJ2JvdHRvbScsXG4gICAgICB2aXNpYmxlID0gZmFsc2UsXG4gICAgICBjbGFzc05hbWUsXG4gICAgICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICAgICAgbWF4SGVpZ2h0LFxuICAgICAgbWF4V2lkdGgsXG4gICAgICBwb3J0YWxUYXJnZXQsXG4gICAgICBzaXplID0gJ3NtYWxsJyxcbiAgICAgIHRyaWdnZXJNZXRob2QgPSAnY2xpY2snLFxuICAgICAgZHluYW1pY0RvbVJlbmRlcmluZyxcbiAgICB9OiBNZW51UHJvcHMsXG4gICAgcmVmOiBSZWY8SFRNTEJ1dHRvbkVsZW1lbnQgfCBudWxsPixcbiAgKSA9PiB7XG4gICAgY29uc3QgW2lzVmlzaWJsZSwgc2V0SXNWaXNpYmxlXSA9IHVzZVN0YXRlKHZpc2libGUpXG4gICAgY29uc3QgcG9wdXBSZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpXG4gICAgY29uc3QgZGlzY2xvc3VyZVJlZiA9IHVzZVJlZjxIVE1MQnV0dG9uRWxlbWVudD4obnVsbClcbiAgICBjb25zdCB0ZW1wSWQgPSB1c2VJZCgpXG4gICAgY29uc3QgZmluYWxJZCA9IGBtZW51LSR7aWQgPz8gdGVtcElkfWBcblxuICAgIC8vIGlmIHlvdSBuZWVkIGRpYWxvZyBpbnNpZGUgeW91ciBjb21wb25lbnQsIHVzZSBmdW5jdGlvbiwgb3RoZXJ3aXNlIGNvbXBvbmVudCBpcyBmaW5lXG4gICAgY29uc3QgdGFyZ2V0ID0gaXNWYWxpZEVsZW1lbnQ8QnV0dG9uSFRNTEF0dHJpYnV0ZXM8SFRNTEJ1dHRvbkVsZW1lbnQ+PihcbiAgICAgIGRpc2Nsb3N1cmUsXG4gICAgKVxuICAgICAgPyBkaXNjbG9zdXJlXG4gICAgICA6IGRpc2Nsb3N1cmUoeyB2aXNpYmxlOiBpc1Zpc2libGUgfSlcbiAgICBjb25zdCBpbm5lclJlZiA9IHVzZVJlZih0YXJnZXQgYXMgdW5rbm93biBhcyBIVE1MQnV0dG9uRWxlbWVudClcbiAgICB1c2VJbXBlcmF0aXZlSGFuZGxlKHJlZiwgKCkgPT4gaW5uZXJSZWYuY3VycmVudClcblxuICAgIGNvbnN0IGZpbmFsRGlzY2xvc3VyZSA9IGNsb25lRWxlbWVudCh0YXJnZXQsIHtcbiAgICAgIG9uQ2xpY2s6IChldmVudDogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHtcbiAgICAgICAgdGFyZ2V0LnByb3BzLm9uQ2xpY2s/LihldmVudClcbiAgICAgICAgc2V0SXNWaXNpYmxlKCFpc1Zpc2libGUpXG4gICAgICB9LFxuICAgICAgJ2FyaWEtaGFzcG9wdXAnOiAnZGlhbG9nJyxcbiAgICAgICdhcmlhLWV4cGFuZGVkJzogaXNWaXNpYmxlLFxuICAgICAgLy8gQHRzLWV4cGVjdC1lcnJvciBub3Qgc3VyZSBob3cgdG8gZml4IHRoaXNcbiAgICAgIHJlZjogZGlzY2xvc3VyZVJlZixcbiAgICB9KVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRQb3B1cFxuICAgICAgICBkZWJvdW5jZURlbGF5PXt0cmlnZ2VyTWV0aG9kID09PSAnaG92ZXInID8gMjUwIDogMH1cbiAgICAgICAgaGlkZU9uQ2xpY2tPdXRzaWRlXG4gICAgICAgIGFyaWEtbGFiZWw9e2FyaWFMYWJlbH1cbiAgICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICAgIHZpc2libGU9e3RyaWdnZXJNZXRob2QgPT09ICdjbGljaycgPyBpc1Zpc2libGUgOiB1bmRlZmluZWR9XG4gICAgICAgIHBsYWNlbWVudD17cGxhY2VtZW50fVxuICAgICAgICBoYXNBcnJvdz17aGFzQXJyb3d9XG4gICAgICAgIGRhdGEtaGFzLWFycm93PXtoYXNBcnJvd31cbiAgICAgICAgcm9sZT1cImRpYWxvZ1wiXG4gICAgICAgIGlkPXtmaW5hbElkfVxuICAgICAgICByZWY9e3BvcHVwUmVmfVxuICAgICAgICBvbkNsb3NlPXsoKSA9PiBzZXRJc1Zpc2libGUoZmFsc2UpfVxuICAgICAgICB0YWJJbmRleD17LTF9XG4gICAgICAgIG1heEhlaWdodD17bWF4SGVpZ2h0ID8/ICc0ODBweCd9XG4gICAgICAgIG1heFdpZHRoPXttYXhXaWR0aH1cbiAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgdGV4dD17XG4gICAgICAgICAgPE1lbnVMaXN0IGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfSBjbGFzc05hbWU9e2NsYXNzTmFtZX0gcm9sZT1cIm1lbnVcIj5cbiAgICAgICAgICAgIHt0eXBlb2YgY2hpbGRyZW4gPT09ICdmdW5jdGlvbidcbiAgICAgICAgICAgICAgPyBjaGlsZHJlbih7IHRvZ2dsZTogKCkgPT4gc2V0SXNWaXNpYmxlKCFpc1Zpc2libGUpIH0pXG4gICAgICAgICAgICAgIDogY2hpbGRyZW59XG4gICAgICAgICAgPC9NZW51TGlzdD5cbiAgICAgICAgfVxuICAgICAgICBwb3J0YWxUYXJnZXQ9e3BvcnRhbFRhcmdldH1cbiAgICAgICAgZHluYW1pY0RvbVJlbmRlcmluZz17ZHluYW1pY0RvbVJlbmRlcmluZ31cbiAgICAgID5cbiAgICAgICAge2ZpbmFsRGlzY2xvc3VyZX1cbiAgICAgIDwvU3R5bGVkUG9wdXA+XG4gICAgKVxuICB9LFxuKVxuXG4vKipcbiAqIEEgbWVudSBpcyBhIHdpZGdldCB0aGF0IG9mZmVycyBhIGxpc3Qgb2YgY2hvaWNlcyB0byB0aGUgdXNlciwgc3VjaCBhcyBhIHNldCBvZiBhY3Rpb25zIG9yIGZ1bmN0aW9ucy5cbiAqIEEgbWVudSBpcyB1c3VhbGx5IG9wZW5lZCwgb3IgbWFkZSB2aXNpYmxlLCBieSBhY3RpdmF0aW5nIGEgbWVudSBidXR0b24sIGNob29zaW5nIGFuIGl0ZW0gaW4gYSBtZW51IHRoYXQgb3BlbnMgYVxuICogc3ViIG1lbnUsIG9yIGJ5IGludm9raW5nIGEgY29tbWFuZCwgc3VjaCBhcyBgU2hpZnQgKyBGMTBgIG9uIFdpbmRvd3MsIHRoYXQgb3BlbnMgYSBjb250ZXh0IHNwZWNpZmljIG1lbnUuXG4gKiBXaGVuIGEgdXNlciBhY3RpdmF0ZXMgYSBjaG9pY2UgaW4gYSBtZW51LCB0aGUgbWVudSB1c3VhbGx5IGNsb3NlcyB1bmxlc3MgdGhlIGNob2ljZSBvcGVuZWQgYSBzdWJtZW51LlxuICovXG5leHBvcnQgY29uc3QgTWVudVYyID0gT2JqZWN0LmFzc2lnbihGd2RNZW51LCB7IEl0ZW0sIEdyb3VwIH0pXG4iXX0= */"));
31
+ const MenuList = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
32
+ target: "e1jn11gg0"
33
+ } : {
34
+ target: "e1jn11gg0",
35
+ label: "MenuList"
36
+ })("overflow-y:auto;overflow-x:hidden;&:after,&:before{border:solid transparent;border-width:9px;content:' ';height:0;width:0;position:absolute;pointer-events:none;}&:after{border-color:transparent;}&:before{border-color:transparent;}background-color:", ({
37
+ theme
38
+ }) => theme.colors.neutral.backgroundWeakElevated, ";color:", ({
39
+ theme
40
+ }) => theme.colors.neutral.text, ";border-radius:", ({
41
+ theme
42
+ }) => theme.radii.default, ";position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01lbnVWMi9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEQ4QiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9NZW51VjIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7XG4gIEJ1dHRvbkhUTUxBdHRyaWJ1dGVzLFxuICBDb21wb25lbnRQcm9wcyxcbiAgTW91c2VFdmVudCxcbiAgUmVhY3RFbGVtZW50LFxuICBSZWFjdE5vZGUsXG4gIFJlZixcbn0gZnJvbSAncmVhY3QnXG5pbXBvcnQge1xuICBjbG9uZUVsZW1lbnQsXG4gIGZvcndhcmRSZWYsXG4gIGlzVmFsaWRFbGVtZW50LFxuICB1c2VJZCxcbiAgdXNlSW1wZXJhdGl2ZUhhbmRsZSxcbiAgdXNlUmVmLFxuICB1c2VTdGF0ZSxcbn0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBQb3B1cCB9IGZyb20gJy4uL1BvcHVwJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IEdyb3VwIH0gZnJvbSAnLi9Hcm91cCdcbmltcG9ydCBJdGVtIGZyb20gJy4vSXRlbSdcblxuY29uc3QgU0laRVMgPSB7XG4gIHNtYWxsOiAnMTgwcHgnLFxuICBtZWRpdW06ICcyODBweCcsXG4gIGxhcmdlOiAnMzgwcHgnLFxufVxuXG5leHBvcnQgdHlwZSBEaXNjbG9zdXJlUHJvcHMgPSB7IHZpc2libGU6IGJvb2xlYW4gfVxuXG50eXBlIERpc2Nsb3N1cmVFbGVtZW50ID1cbiAgfCAoKFxuICAgICAgZGlzY2xvc3VyZTogRGlzY2xvc3VyZVByb3BzLFxuICAgICkgPT4gUmVhY3RFbGVtZW50PEJ1dHRvbkhUTUxBdHRyaWJ1dGVzPEhUTUxCdXR0b25FbGVtZW50Pj4pXG4gIHwgKFJlYWN0RWxlbWVudDxCdXR0b25IVE1MQXR0cmlidXRlczxIVE1MQnV0dG9uRWxlbWVudD4+ICYge1xuICAgICAgcmVmPzogUmVmPEhUTUxCdXR0b25FbGVtZW50PlxuICAgIH0pXG5cbmNvbnN0IFN0eWxlZFBvcHVwID0gc3R5bGVkKFBvcHVwLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZToga2V5b2YgdHlwZW9mIFNJWkVTIH0+YFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9O1xuICBib3gtc2hhZG93OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNoYWRvd3MubWVudX07XG4gIHBhZGRpbmc6IDA7XG5cbiAgJltkYXRhLWhhcy1hcnJvdz0ndHJ1ZSddIHtcbiAgICAmOjphZnRlciB7XG4gICAgICBib3JkZXItY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZH1cbiAgICAgICAgdHJhbnNwYXJlbnQgdHJhbnNwYXJlbnQgdHJhbnNwYXJlbnQ7XG4gICAgfVxuICB9XG5cbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiBTSVpFU1tzaXplXX07XG4gIG1heC13aWR0aDogbm9uZTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiBgJHt0aGVtZS5zcGFjZVsnMC4yNSddfSAwYH07XG5gXG5cbmNvbnN0IE1lbnVMaXN0ID0gc3R5bGVkKFN0YWNrKWBcbiAgb3ZlcmZsb3cteTogYXV0bztcbiAgb3ZlcmZsb3cteDogaGlkZGVuO1xuICAmOmFmdGVyLFxuICAmOmJlZm9yZSB7XG4gICAgYm9yZGVyOiBzb2xpZCB0cmFuc3BhcmVudDtcbiAgICBib3JkZXItd2lkdGg6IDlweDtcbiAgICBjb250ZW50OiAnICc7XG4gICAgaGVpZ2h0OiAwO1xuICAgIHdpZHRoOiAwO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgfVxuXG4gICY6YWZ0ZXIge1xuICAgIGJvcmRlci1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIH1cbiAgJjpiZWZvcmUge1xuICAgIGJvcmRlci1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIH1cbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PlxuICAgIHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmRXZWFrRWxldmF0ZWR9O1xuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0fTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYFxuXG50eXBlIENoaWxkTWVudVByb3BzID0ge1xuICB0b2dnbGU6ICgpID0+IHZvaWRcbn1cblxudHlwZSBNZW51UHJvcHMgPSB7XG4gIGlkPzogc3RyaW5nXG4gIGFyaWFMYWJlbD86IHN0cmluZ1xuICBjaGlsZHJlbj86IFJlYWN0Tm9kZSB8ICgoeyB0b2dnbGUgfTogQ2hpbGRNZW51UHJvcHMpID0+IFJlYWN0Tm9kZSlcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGRpc2Nsb3N1cmU6IERpc2Nsb3N1cmVFbGVtZW50XG4gIGhhc0Fycm93PzogYm9vbGVhblxuICB2aXNpYmxlPzogYm9vbGVhblxuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG4gIG1heEhlaWdodD86IHN0cmluZ1xuICAvKipcbiAgICogQGRlcHJlY2F0ZWQ6IHVzZSBgc2l6ZWAgaW5zdGVhZFxuICAgKi9cbiAgbWF4V2lkdGg/OiBzdHJpbmdcbiAgLyoqXG4gICAqIEJ5IGRlZmF1bHQsIHRoZSBwb3J0YWwgdGFyZ2V0IGlzIGNoaWxkcmVuIGNvbnRhaW5lciBvciBkb2N1bWVudC5ib2R5IGlmIGNoaWxkcmVuIGlzIGEgZnVuY3Rpb24uIFlvdSBjYW4gb3ZlcnJpZGUgdGhpc1xuICAgKiBiZWhhdmlvciBieSBzZXR0aW5nIGEgcG9ydGFsVGFyZ2V0IHByb3AuXG4gICAqL1xuICBwb3J0YWxUYXJnZXQ/OiBIVE1MRWxlbWVudFxuICBzaXplPzoga2V5b2YgdHlwZW9mIFNJWkVTXG4gIC8qKlxuICAgKiBUaGUgYmVoYXZpb3Igb2YgdGhlIG1lbnUgd2hlbiBpdCBpcyBvcGVuZWQuIElmIHNldCB0byBgY2xpY2tgLCB0aGUgbWVudSB3aWxsIG9wZW4gd2hlbiB0aGUgdXNlciBjbGlja3Mgb24gdGhlIGRpc2Nsb3N1cmUuXG4gICAqIElmIHNldCB0byBgaG92ZXJgLCB0aGUgbWVudSB3aWxsIG9wZW4gd2hlbiB0aGUgdXNlciBob3ZlcnMgb3ZlciB0aGUgZGlzY2xvc3VyZS5cbiAgICovXG4gIHRyaWdnZXJNZXRob2Q/OiAnY2xpY2snIHwgJ2hvdmVyJ1xufSAmIFBpY2s8Q29tcG9uZW50UHJvcHM8dHlwZW9mIFBvcHVwPiwgJ3BsYWNlbWVudCcgfCAnZHluYW1pY0RvbVJlbmRlcmluZyc+XG5cbmNvbnN0IEZ3ZE1lbnUgPSBmb3J3YXJkUmVmKFxuICAoXG4gICAge1xuICAgICAgaWQsXG4gICAgICBhcmlhTGFiZWwgPSAnTWVudScsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIGRpc2Nsb3N1cmUsXG4gICAgICBoYXNBcnJvdyA9IGZhbHNlLFxuICAgICAgcGxhY2VtZW50ID0gJ2JvdHRvbScsXG4gICAgICB2aXNpYmxlID0gZmFsc2UsXG4gICAgICBjbGFzc05hbWUsXG4gICAgICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICAgICAgbWF4SGVpZ2h0LFxuICAgICAgbWF4V2lkdGgsXG4gICAgICBwb3J0YWxUYXJnZXQsXG4gICAgICBzaXplID0gJ3NtYWxsJyxcbiAgICAgIHRyaWdnZXJNZXRob2QgPSAnY2xpY2snLFxuICAgICAgZHluYW1pY0RvbVJlbmRlcmluZyxcbiAgICB9OiBNZW51UHJvcHMsXG4gICAgcmVmOiBSZWY8SFRNTEJ1dHRvbkVsZW1lbnQgfCBudWxsPixcbiAgKSA9PiB7XG4gICAgY29uc3QgW2lzVmlzaWJsZSwgc2V0SXNWaXNpYmxlXSA9IHVzZVN0YXRlKHZpc2libGUpXG4gICAgY29uc3QgcG9wdXBSZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpXG4gICAgY29uc3QgZGlzY2xvc3VyZVJlZiA9IHVzZVJlZjxIVE1MQnV0dG9uRWxlbWVudD4obnVsbClcbiAgICBjb25zdCB0ZW1wSWQgPSB1c2VJZCgpXG4gICAgY29uc3QgZmluYWxJZCA9IGBtZW51LSR7aWQgPz8gdGVtcElkfWBcblxuICAgIC8vIGlmIHlvdSBuZWVkIGRpYWxvZyBpbnNpZGUgeW91ciBjb21wb25lbnQsIHVzZSBmdW5jdGlvbiwgb3RoZXJ3aXNlIGNvbXBvbmVudCBpcyBmaW5lXG4gICAgY29uc3QgdGFyZ2V0ID0gaXNWYWxpZEVsZW1lbnQ8QnV0dG9uSFRNTEF0dHJpYnV0ZXM8SFRNTEJ1dHRvbkVsZW1lbnQ+PihcbiAgICAgIGRpc2Nsb3N1cmUsXG4gICAgKVxuICAgICAgPyBkaXNjbG9zdXJlXG4gICAgICA6IGRpc2Nsb3N1cmUoeyB2aXNpYmxlOiBpc1Zpc2libGUgfSlcbiAgICBjb25zdCBpbm5lclJlZiA9IHVzZVJlZih0YXJnZXQgYXMgdW5rbm93biBhcyBIVE1MQnV0dG9uRWxlbWVudClcbiAgICB1c2VJbXBlcmF0aXZlSGFuZGxlKHJlZiwgKCkgPT4gaW5uZXJSZWYuY3VycmVudClcblxuICAgIGNvbnN0IGZpbmFsRGlzY2xvc3VyZSA9IGNsb25lRWxlbWVudCh0YXJnZXQsIHtcbiAgICAgIG9uQ2xpY2s6IChldmVudDogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHtcbiAgICAgICAgdGFyZ2V0LnByb3BzLm9uQ2xpY2s/LihldmVudClcbiAgICAgICAgc2V0SXNWaXNpYmxlKCFpc1Zpc2libGUpXG4gICAgICB9LFxuICAgICAgJ2FyaWEtaGFzcG9wdXAnOiAnZGlhbG9nJyxcbiAgICAgICdhcmlhLWV4cGFuZGVkJzogaXNWaXNpYmxlLFxuICAgICAgLy8gQHRzLWV4cGVjdC1lcnJvciBub3Qgc3VyZSBob3cgdG8gZml4IHRoaXNcbiAgICAgIHJlZjogZGlzY2xvc3VyZVJlZixcbiAgICB9KVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRQb3B1cFxuICAgICAgICBkZWJvdW5jZURlbGF5PXt0cmlnZ2VyTWV0aG9kID09PSAnaG92ZXInID8gMjUwIDogMH1cbiAgICAgICAgaGlkZU9uQ2xpY2tPdXRzaWRlXG4gICAgICAgIGFyaWEtbGFiZWw9e2FyaWFMYWJlbH1cbiAgICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICAgIHZpc2libGU9e3RyaWdnZXJNZXRob2QgPT09ICdjbGljaycgPyBpc1Zpc2libGUgOiB1bmRlZmluZWR9XG4gICAgICAgIHBsYWNlbWVudD17cGxhY2VtZW50fVxuICAgICAgICBoYXNBcnJvdz17aGFzQXJyb3d9XG4gICAgICAgIGRhdGEtaGFzLWFycm93PXtoYXNBcnJvd31cbiAgICAgICAgcm9sZT1cImRpYWxvZ1wiXG4gICAgICAgIGlkPXtmaW5hbElkfVxuICAgICAgICByZWY9e3BvcHVwUmVmfVxuICAgICAgICBvbkNsb3NlPXsoKSA9PiBzZXRJc1Zpc2libGUoZmFsc2UpfVxuICAgICAgICB0YWJJbmRleD17LTF9XG4gICAgICAgIG1heEhlaWdodD17bWF4SGVpZ2h0ID8/ICc0ODBweCd9XG4gICAgICAgIG1heFdpZHRoPXttYXhXaWR0aH1cbiAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgdGV4dD17XG4gICAgICAgICAgPE1lbnVMaXN0IGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfSBjbGFzc05hbWU9e2NsYXNzTmFtZX0gcm9sZT1cIm1lbnVcIj5cbiAgICAgICAgICAgIHt0eXBlb2YgY2hpbGRyZW4gPT09ICdmdW5jdGlvbidcbiAgICAgICAgICAgICAgPyBjaGlsZHJlbih7IHRvZ2dsZTogKCkgPT4gc2V0SXNWaXNpYmxlKCFpc1Zpc2libGUpIH0pXG4gICAgICAgICAgICAgIDogY2hpbGRyZW59XG4gICAgICAgICAgPC9NZW51TGlzdD5cbiAgICAgICAgfVxuICAgICAgICBwb3J0YWxUYXJnZXQ9e3BvcnRhbFRhcmdldH1cbiAgICAgICAgZHluYW1pY0RvbVJlbmRlcmluZz17ZHluYW1pY0RvbVJlbmRlcmluZ31cbiAgICAgID5cbiAgICAgICAge2ZpbmFsRGlzY2xvc3VyZX1cbiAgICAgIDwvU3R5bGVkUG9wdXA+XG4gICAgKVxuICB9LFxuKVxuXG4vKipcbiAqIEEgbWVudSBpcyBhIHdpZGdldCB0aGF0IG9mZmVycyBhIGxpc3Qgb2YgY2hvaWNlcyB0byB0aGUgdXNlciwgc3VjaCBhcyBhIHNldCBvZiBhY3Rpb25zIG9yIGZ1bmN0aW9ucy5cbiAqIEEgbWVudSBpcyB1c3VhbGx5IG9wZW5lZCwgb3IgbWFkZSB2aXNpYmxlLCBieSBhY3RpdmF0aW5nIGEgbWVudSBidXR0b24sIGNob29zaW5nIGFuIGl0ZW0gaW4gYSBtZW51IHRoYXQgb3BlbnMgYVxuICogc3ViIG1lbnUsIG9yIGJ5IGludm9raW5nIGEgY29tbWFuZCwgc3VjaCBhcyBgU2hpZnQgKyBGMTBgIG9uIFdpbmRvd3MsIHRoYXQgb3BlbnMgYSBjb250ZXh0IHNwZWNpZmljIG1lbnUuXG4gKiBXaGVuIGEgdXNlciBhY3RpdmF0ZXMgYSBjaG9pY2UgaW4gYSBtZW51LCB0aGUgbWVudSB1c3VhbGx5IGNsb3NlcyB1bmxlc3MgdGhlIGNob2ljZSBvcGVuZWQgYSBzdWJtZW51LlxuICovXG5leHBvcnQgY29uc3QgTWVudVYyID0gT2JqZWN0LmFzc2lnbihGd2RNZW51LCB7IEl0ZW0sIEdyb3VwIH0pXG4iXX0= */"));
43
+ const FwdMenu = forwardRef(({
44
+ id,
45
+ ariaLabel = "Menu",
46
+ children,
47
+ disclosure,
48
+ hasArrow = false,
49
+ placement = "bottom",
50
+ visible = false,
51
+ className,
52
+ "data-testid": dataTestId,
53
+ maxHeight,
54
+ maxWidth,
55
+ portalTarget,
56
+ size = "small",
57
+ triggerMethod = "click",
58
+ dynamicDomRendering
59
+ }, ref) => {
60
+ const [isVisible, setIsVisible] = useState(visible);
61
+ const popupRef = useRef(null);
62
+ const disclosureRef = useRef(null);
63
+ const tempId = useId();
64
+ const finalId = `menu-${id ?? tempId}`;
65
+ const target = isValidElement(disclosure) ? disclosure : disclosure({
66
+ visible: isVisible
67
+ });
68
+ const innerRef = useRef(target);
69
+ useImperativeHandle(ref, () => innerRef.current);
70
+ const finalDisclosure = cloneElement(target, {
71
+ onClick: (event) => {
72
+ target.props.onClick?.(event);
73
+ setIsVisible(!isVisible);
74
+ },
75
+ "aria-haspopup": "dialog",
76
+ "aria-expanded": isVisible,
77
+ // @ts-expect-error not sure how to fix this
78
+ ref: disclosureRef
79
+ });
80
+ return /* @__PURE__ */ jsx(StyledPopup, { debounceDelay: triggerMethod === "hover" ? 250 : 0, hideOnClickOutside: true, "aria-label": ariaLabel, className, visible: triggerMethod === "click" ? isVisible : void 0, placement, hasArrow, "data-has-arrow": hasArrow, role: "dialog", id: finalId, ref: popupRef, onClose: () => setIsVisible(false), tabIndex: -1, maxHeight: maxHeight ?? "480px", maxWidth, size, text: /* @__PURE__ */ jsx(MenuList, { "data-testid": dataTestId, className, role: "menu", children: typeof children === "function" ? children({
81
+ toggle: () => setIsVisible(!isVisible)
82
+ }) : children }), portalTarget, dynamicDomRendering, children: finalDisclosure });
83
+ });
84
+ const MenuV2 = Object.assign(FwdMenu, {
85
+ Item,
86
+ Group
87
+ });
88
+ export {
89
+ MenuV2
90
+ };
@@ -0,0 +1,26 @@
1
+ type Strength = {
2
+ /**
3
+ * Color to display
4
+ */
5
+ color: string;
6
+ /**
7
+ * Text to display
8
+ */
9
+ text: string;
10
+ };
11
+ type PasswordStrengthMeterProps = {
12
+ /**
13
+ * Strength is used for defining different color and text associated with it.
14
+ */
15
+ strength: Strength[];
16
+ title: string;
17
+ value: number;
18
+ className?: string;
19
+ 'data-testid'?: string;
20
+ id?: string;
21
+ };
22
+ /**
23
+ * Show strength of a password based on different criteria.
24
+ */
25
+ export declare const Meter: ({ strength, title, value, className, "data-testid": dataTestId, id, }: PasswordStrengthMeterProps) => import("@emotion/react/jsx-runtime").JSX.Element;
26
+ export {};
@@ -0,0 +1,63 @@
1
+ import { jsxs, jsx } from "@emotion/react/jsx-runtime";
2
+ import _styled from "@emotion/styled/base";
3
+ import { Text } from "../Text/index.js";
4
+ const StyledStrength = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
5
+ shouldForwardProp: (prop) => !["color"].includes(prop),
6
+ target: "e157fc5l2"
7
+ } : {
8
+ shouldForwardProp: (prop) => !["color"].includes(prop),
9
+ target: "e157fc5l2",
10
+ label: "StyledStrength"
11
+ })("float:right;vertical-align:top;color:", ({
12
+ strength
13
+ }) => strength.color, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01ldGVyL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLMEIiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTWV0ZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcblxuY29uc3QgU3R5bGVkU3RyZW5ndGggPSBzdHlsZWQoVGV4dCwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydjb2xvciddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBzdHJlbmd0aDogU3RyZW5ndGggfT5gXG4gIGZsb2F0OiByaWdodDtcbiAgdmVydGljYWwtYWxpZ246IHRvcDtcbiAgY29sb3I6ICR7KHsgc3RyZW5ndGggfSkgPT4gc3RyZW5ndGguY29sb3J9O1xuYFxuXG5jb25zdCBTdHlsZWRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kRGlzYWJsZWR9O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICBoZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIG1hcmdpbi10b3A6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIG1hcmdpbi1ib3R0b206ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG5gXG5cbmNvbnN0IFN0eWxlZE1ldGVyID0gc3R5bGVkLmRpdmBcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgaGVpZ2h0OiAxMDAlO1xuICB0cmFuc2l0aW9uOiBhbGwgMC41cztcbmBcblxudHlwZSBTdHJlbmd0aCA9IHtcbiAgLyoqXG4gICAqIENvbG9yIHRvIGRpc3BsYXlcbiAgICovXG4gIGNvbG9yOiBzdHJpbmdcbiAgLyoqXG4gICAqIFRleHQgdG8gZGlzcGxheVxuICAgKi9cbiAgdGV4dDogc3RyaW5nXG59XG5cbnR5cGUgUGFzc3dvcmRTdHJlbmd0aE1ldGVyUHJvcHMgPSB7XG4gIC8qKlxuICAgKiBTdHJlbmd0aCBpcyB1c2VkIGZvciBkZWZpbmluZyBkaWZmZXJlbnQgY29sb3IgYW5kIHRleHQgYXNzb2NpYXRlZCB3aXRoIGl0LlxuICAgKi9cbiAgc3RyZW5ndGg6IFN0cmVuZ3RoW11cbiAgdGl0bGU6IHN0cmluZ1xuICB2YWx1ZTogbnVtYmVyXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG4gIGlkPzogc3RyaW5nXG59XG5cbi8qKlxuICogU2hvdyBzdHJlbmd0aCBvZiBhIHBhc3N3b3JkIGJhc2VkIG9uIGRpZmZlcmVudCBjcml0ZXJpYS5cbiAqL1xuZXhwb3J0IGNvbnN0IE1ldGVyID0gKHtcbiAgc3RyZW5ndGgsXG4gIHRpdGxlLFxuICB2YWx1ZSxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICBpZCxcbn06IFBhc3N3b3JkU3RyZW5ndGhNZXRlclByb3BzKSA9PiB7XG4gIGNvbnN0IHRvVmFsdWUgPSAoKHZhbHVlICsgMSkgLyBzdHJlbmd0aC5sZW5ndGgpICogMTAwXG4gIGNvbnN0IHdpZHRoID0gYCR7dG9WYWx1ZX0lYFxuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9IHN0cmVuZ3RoW3ZhbHVlXT8uY29sb3IgPz8gc3RyZW5ndGhbMF0uY29sb3JcbiAgY29uc3QgdGV4dCA9IHN0cmVuZ3RoW3ZhbHVlXT8udGV4dCA/PyBzdHJlbmd0aFswXS50ZXh0XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBhcmlhLWxpdmU9XCJwb2xpdGVcIlxuICAgICAgYXJpYS12YWx1ZW1heD17c3RyZW5ndGgubGVuZ3RoID8/IDB9XG4gICAgICBhcmlhLXZhbHVlbWluPXswfVxuICAgICAgYXJpYS12YWx1ZW5vdz17dmFsdWV9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgaWQ9e2lkfVxuICAgICAgcm9sZT1cIm1ldGVyXCJcbiAgICAgIHRpdGxlPXt0aXRsZX1cbiAgICAgIGFyaWEtbGFiZWxsZWRieT1cIm1ldGVyLWxhYmVsXCJcbiAgICA+XG4gICAgICA8VGV4dCBpZD1cIm1ldGVyLWxhYmVsXCIgdmFyaWFudD1cImJvZHlTbWFsbFN0cm9uZ1wiIGFzPVwicFwiPlxuICAgICAgICB7dGl0bGV9XG4gICAgICAgIDxTdHlsZWRTdHJlbmd0aFxuICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgc3RyZW5ndGg9e3N0cmVuZ3RoW3ZhbHVlXX1cbiAgICAgICAgPlxuICAgICAgICAgIHt0ZXh0fVxuICAgICAgICA8L1N0eWxlZFN0cmVuZ3RoPlxuICAgICAgPC9UZXh0PlxuXG4gICAgICA8U3R5bGVkV3JhcHBlcj5cbiAgICAgICAgPFN0eWxlZE1ldGVyXG4gICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgIGJhY2tncm91bmRDb2xvcixcbiAgICAgICAgICAgIHdpZHRoLFxuICAgICAgICAgIH19XG4gICAgICAgIC8+XG4gICAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICAgPC9kaXY+XG4gIClcbn1cbiJdfQ== */"));
14
+ const StyledWrapper = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
15
+ target: "e157fc5l1"
16
+ } : {
17
+ target: "e157fc5l1",
18
+ label: "StyledWrapper"
19
+ })("background-color:", ({
20
+ theme
21
+ }) => theme.colors.neutral.backgroundDisabled, ";border-radius:", ({
22
+ theme
23
+ }) => theme.radii.default, ";height:", ({
24
+ theme
25
+ }) => theme.space["1"], ";margin-top:", ({
26
+ theme
27
+ }) => theme.space["1"], ";margin-bottom:", ({
28
+ theme
29
+ }) => theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01ldGVyL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXZ0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTWV0ZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcblxuY29uc3QgU3R5bGVkU3RyZW5ndGggPSBzdHlsZWQoVGV4dCwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydjb2xvciddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBzdHJlbmd0aDogU3RyZW5ndGggfT5gXG4gIGZsb2F0OiByaWdodDtcbiAgdmVydGljYWwtYWxpZ246IHRvcDtcbiAgY29sb3I6ICR7KHsgc3RyZW5ndGggfSkgPT4gc3RyZW5ndGguY29sb3J9O1xuYFxuXG5jb25zdCBTdHlsZWRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kRGlzYWJsZWR9O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICBoZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIG1hcmdpbi10b3A6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIG1hcmdpbi1ib3R0b206ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG5gXG5cbmNvbnN0IFN0eWxlZE1ldGVyID0gc3R5bGVkLmRpdmBcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgaGVpZ2h0OiAxMDAlO1xuICB0cmFuc2l0aW9uOiBhbGwgMC41cztcbmBcblxudHlwZSBTdHJlbmd0aCA9IHtcbiAgLyoqXG4gICAqIENvbG9yIHRvIGRpc3BsYXlcbiAgICovXG4gIGNvbG9yOiBzdHJpbmdcbiAgLyoqXG4gICAqIFRleHQgdG8gZGlzcGxheVxuICAgKi9cbiAgdGV4dDogc3RyaW5nXG59XG5cbnR5cGUgUGFzc3dvcmRTdHJlbmd0aE1ldGVyUHJvcHMgPSB7XG4gIC8qKlxuICAgKiBTdHJlbmd0aCBpcyB1c2VkIGZvciBkZWZpbmluZyBkaWZmZXJlbnQgY29sb3IgYW5kIHRleHQgYXNzb2NpYXRlZCB3aXRoIGl0LlxuICAgKi9cbiAgc3RyZW5ndGg6IFN0cmVuZ3RoW11cbiAgdGl0bGU6IHN0cmluZ1xuICB2YWx1ZTogbnVtYmVyXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG4gIGlkPzogc3RyaW5nXG59XG5cbi8qKlxuICogU2hvdyBzdHJlbmd0aCBvZiBhIHBhc3N3b3JkIGJhc2VkIG9uIGRpZmZlcmVudCBjcml0ZXJpYS5cbiAqL1xuZXhwb3J0IGNvbnN0IE1ldGVyID0gKHtcbiAgc3RyZW5ndGgsXG4gIHRpdGxlLFxuICB2YWx1ZSxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICBpZCxcbn06IFBhc3N3b3JkU3RyZW5ndGhNZXRlclByb3BzKSA9PiB7XG4gIGNvbnN0IHRvVmFsdWUgPSAoKHZhbHVlICsgMSkgLyBzdHJlbmd0aC5sZW5ndGgpICogMTAwXG4gIGNvbnN0IHdpZHRoID0gYCR7dG9WYWx1ZX0lYFxuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9IHN0cmVuZ3RoW3ZhbHVlXT8uY29sb3IgPz8gc3RyZW5ndGhbMF0uY29sb3JcbiAgY29uc3QgdGV4dCA9IHN0cmVuZ3RoW3ZhbHVlXT8udGV4dCA/PyBzdHJlbmd0aFswXS50ZXh0XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBhcmlhLWxpdmU9XCJwb2xpdGVcIlxuICAgICAgYXJpYS12YWx1ZW1heD17c3RyZW5ndGgubGVuZ3RoID8/IDB9XG4gICAgICBhcmlhLXZhbHVlbWluPXswfVxuICAgICAgYXJpYS12YWx1ZW5vdz17dmFsdWV9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgaWQ9e2lkfVxuICAgICAgcm9sZT1cIm1ldGVyXCJcbiAgICAgIHRpdGxlPXt0aXRsZX1cbiAgICAgIGFyaWEtbGFiZWxsZWRieT1cIm1ldGVyLWxhYmVsXCJcbiAgICA+XG4gICAgICA8VGV4dCBpZD1cIm1ldGVyLWxhYmVsXCIgdmFyaWFudD1cImJvZHlTbWFsbFN0cm9uZ1wiIGFzPVwicFwiPlxuICAgICAgICB7dGl0bGV9XG4gICAgICAgIDxTdHlsZWRTdHJlbmd0aFxuICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgc3RyZW5ndGg9e3N0cmVuZ3RoW3ZhbHVlXX1cbiAgICAgICAgPlxuICAgICAgICAgIHt0ZXh0fVxuICAgICAgICA8L1N0eWxlZFN0cmVuZ3RoPlxuICAgICAgPC9UZXh0PlxuXG4gICAgICA8U3R5bGVkV3JhcHBlcj5cbiAgICAgICAgPFN0eWxlZE1ldGVyXG4gICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgIGJhY2tncm91bmRDb2xvcixcbiAgICAgICAgICAgIHdpZHRoLFxuICAgICAgICAgIH19XG4gICAgICAgIC8+XG4gICAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICAgPC9kaXY+XG4gIClcbn1cbiJdfQ== */"));
30
+ const StyledMeter = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
31
+ target: "e157fc5l0"
32
+ } : {
33
+ target: "e157fc5l0",
34
+ label: "StyledMeter"
35
+ })("border-radius:", ({
36
+ theme
37
+ }) => theme.radii.default, ";height:100%;transition:all 0.5s;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01ldGVyL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQjhCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01ldGVyL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5cbmNvbnN0IFN0eWxlZFN0cmVuZ3RoID0gc3R5bGVkKFRleHQsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnY29sb3InXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc3RyZW5ndGg6IFN0cmVuZ3RoIH0+YFxuICBmbG9hdDogcmlnaHQ7XG4gIHZlcnRpY2FsLWFsaWduOiB0b3A7XG4gIGNvbG9yOiAkeyh7IHN0cmVuZ3RoIH0pID0+IHN0cmVuZ3RoLmNvbG9yfTtcbmBcblxuY29uc3QgU3R5bGVkV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZERpc2FibGVkfTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBtYXJnaW4tdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBtYXJnaW4tYm90dG9tOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuYFxuXG5jb25zdCBTdHlsZWRNZXRlciA9IHN0eWxlZC5kaXZgXG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG4gIGhlaWdodDogMTAwJTtcbiAgdHJhbnNpdGlvbjogYWxsIDAuNXM7XG5gXG5cbnR5cGUgU3RyZW5ndGggPSB7XG4gIC8qKlxuICAgKiBDb2xvciB0byBkaXNwbGF5XG4gICAqL1xuICBjb2xvcjogc3RyaW5nXG4gIC8qKlxuICAgKiBUZXh0IHRvIGRpc3BsYXlcbiAgICovXG4gIHRleHQ6IHN0cmluZ1xufVxuXG50eXBlIFBhc3N3b3JkU3RyZW5ndGhNZXRlclByb3BzID0ge1xuICAvKipcbiAgICogU3RyZW5ndGggaXMgdXNlZCBmb3IgZGVmaW5pbmcgZGlmZmVyZW50IGNvbG9yIGFuZCB0ZXh0IGFzc29jaWF0ZWQgd2l0aCBpdC5cbiAgICovXG4gIHN0cmVuZ3RoOiBTdHJlbmd0aFtdXG4gIHRpdGxlOiBzdHJpbmdcbiAgdmFsdWU6IG51bWJlclxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBpZD86IHN0cmluZ1xufVxuXG4vKipcbiAqIFNob3cgc3RyZW5ndGggb2YgYSBwYXNzd29yZCBiYXNlZCBvbiBkaWZmZXJlbnQgY3JpdGVyaWEuXG4gKi9cbmV4cG9ydCBjb25zdCBNZXRlciA9ICh7XG4gIHN0cmVuZ3RoLFxuICB0aXRsZSxcbiAgdmFsdWUsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgaWQsXG59OiBQYXNzd29yZFN0cmVuZ3RoTWV0ZXJQcm9wcykgPT4ge1xuICBjb25zdCB0b1ZhbHVlID0gKCh2YWx1ZSArIDEpIC8gc3RyZW5ndGgubGVuZ3RoKSAqIDEwMFxuICBjb25zdCB3aWR0aCA9IGAke3RvVmFsdWV9JWBcblxuICBjb25zdCBiYWNrZ3JvdW5kQ29sb3IgPSBzdHJlbmd0aFt2YWx1ZV0/LmNvbG9yID8/IHN0cmVuZ3RoWzBdLmNvbG9yXG4gIGNvbnN0IHRleHQgPSBzdHJlbmd0aFt2YWx1ZV0/LnRleHQgPz8gc3RyZW5ndGhbMF0udGV4dFxuXG4gIHJldHVybiAoXG4gICAgPGRpdlxuICAgICAgYXJpYS1saXZlPVwicG9saXRlXCJcbiAgICAgIGFyaWEtdmFsdWVtYXg9e3N0cmVuZ3RoLmxlbmd0aCA/PyAwfVxuICAgICAgYXJpYS12YWx1ZW1pbj17MH1cbiAgICAgIGFyaWEtdmFsdWVub3c9e3ZhbHVlfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgIGlkPXtpZH1cbiAgICAgIHJvbGU9XCJtZXRlclwiXG4gICAgICB0aXRsZT17dGl0bGV9XG4gICAgICBhcmlhLWxhYmVsbGVkYnk9XCJtZXRlci1sYWJlbFwiXG4gICAgPlxuICAgICAgPFRleHQgaWQ9XCJtZXRlci1sYWJlbFwiIHZhcmlhbnQ9XCJib2R5U21hbGxTdHJvbmdcIiBhcz1cInBcIj5cbiAgICAgICAge3RpdGxlfVxuICAgICAgICA8U3R5bGVkU3RyZW5ndGhcbiAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxTdHJvbmdcIlxuICAgICAgICAgIHN0cmVuZ3RoPXtzdHJlbmd0aFt2YWx1ZV19XG4gICAgICAgID5cbiAgICAgICAgICB7dGV4dH1cbiAgICAgICAgPC9TdHlsZWRTdHJlbmd0aD5cbiAgICAgIDwvVGV4dD5cblxuICAgICAgPFN0eWxlZFdyYXBwZXI+XG4gICAgICAgIDxTdHlsZWRNZXRlclxuICAgICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgICAgICB3aWR0aCxcbiAgICAgICAgICB9fVxuICAgICAgICAvPlxuICAgICAgPC9TdHlsZWRXcmFwcGVyPlxuICAgIDwvZGl2PlxuICApXG59XG4iXX0= */"));
38
+ const Meter = ({
39
+ strength,
40
+ title,
41
+ value,
42
+ className,
43
+ "data-testid": dataTestId,
44
+ id
45
+ }) => {
46
+ const toValue = (value + 1) / strength.length * 100;
47
+ const width = `${toValue}%`;
48
+ const backgroundColor = strength[value]?.color ?? strength[0].color;
49
+ const text = strength[value]?.text ?? strength[0].text;
50
+ return /* @__PURE__ */ jsxs("div", { "aria-live": "polite", "aria-valuemax": strength.length ?? 0, "aria-valuemin": 0, "aria-valuenow": value, className, "data-testid": dataTestId, id, role: "meter", title, "aria-labelledby": "meter-label", children: [
51
+ /* @__PURE__ */ jsxs(Text, { id: "meter-label", variant: "bodySmallStrong", as: "p", children: [
52
+ title,
53
+ /* @__PURE__ */ jsx(StyledStrength, { as: "span", variant: "bodySmallStrong", strength: strength[value], children: text })
54
+ ] }),
55
+ /* @__PURE__ */ jsx(StyledWrapper, { children: /* @__PURE__ */ jsx(StyledMeter, { style: {
56
+ backgroundColor,
57
+ width
58
+ } }) })
59
+ ] });
60
+ };
61
+ export {
62
+ Meter
63
+ };
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import type { DialogProps } from './types';
3
+ export declare const Dialog: ({ children, open, placement, onClose, hideOnClickOutside, size, id, ariaLabel, className, "data-testid": dataTestId, preventBodyScroll, hideOnEsc, backdropClassName, dialogCss, backdropCss, }: DialogProps) => import("react").ReactPortal | null;
@@ -0,0 +1,141 @@
1
+ import { jsx } from "@emotion/react/jsx-runtime";
2
+ import _styled from "@emotion/styled/base";
3
+ import { useRef, useEffect, useCallback } from "react";
4
+ import { createPortal } from "react-dom";
5
+ import { MODAL_WIDTH, MODAL_PLACEMENT } from "./constants.js";
6
+ const StyledBackdrop = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
7
+ target: "e1cqen9h1"
8
+ } : {
9
+ target: "e1cqen9h1",
10
+ label: "StyledBackdrop"
11
+ })("position:fixed;top:0;right:0;height:0;width:0;overflow:hidden;background-color:", ({
12
+ theme
13
+ }) => theme.colors.overlay, ";z-index:1;&[data-open='true']{padding:", ({
14
+ theme
15
+ }) => theme.space["2"], ";overflow:auto;display:flex;bottom:0;left:0;height:100%;width:100%;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL0RpYWxvZy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWTJEIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL0RpYWxvZy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHtcbiAgRm9jdXNFdmVudEhhbmRsZXIsXG4gIEtleWJvYXJkRXZlbnRIYW5kbGVyLFxuICBNb3VzZUV2ZW50SGFuZGxlcixcbiAgUmVhY3RFdmVudEhhbmRsZXIsXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBjcmVhdGVQb3J0YWwgfSBmcm9tICdyZWFjdC1kb20nXG5pbXBvcnQgeyBNT0RBTF9QTEFDRU1FTlQsIE1PREFMX1dJRFRIIH0gZnJvbSAnLi9jb25zdGFudHMnXG5pbXBvcnQgdHlwZSB7IERpYWxvZ1Byb3BzLCBNb2RhbFBsYWNlbWVudCwgTW9kYWxTaXplIH0gZnJvbSAnLi90eXBlcydcblxuY29uc3QgU3R5bGVkQmFja2Ryb3AgPSBzdHlsZWQuZGl2PHsgJ2RhdGEtb3Blbic6IGJvb2xlYW4gfT5gXG4gIHBvc2l0aW9uOiBmaXhlZDtcbiAgdG9wOiAwO1xuICByaWdodDogMDtcbiAgaGVpZ2h0OiAwO1xuICB3aWR0aDogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMub3ZlcmxheX07XG4gIHotaW5kZXg6IDE7XG5cbiAgJltkYXRhLW9wZW49J3RydWUnXSB7XG4gICAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgICBvdmVyZmxvdzogYXV0bztcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGJvdHRvbTogMDtcbiAgICBsZWZ0OiAwO1xuICAgIGhlaWdodDogMTAwJTtcbiAgICB3aWR0aDogMTAwJTtcbiAgfVxuYFxuXG50eXBlIFN0eWxlZERpYWxvZ1Byb3BzID0ge1xuICAnZGF0YS1zaXplJzogTW9kYWxTaXplXG4gICdkYXRhLXBsYWNlbWVudCc6IE1vZGFsUGxhY2VtZW50XG59XG5cbmNvbnN0IFN0eWxlZERpYWxvZyA9IHN0eWxlZC5kaWFsb2c8U3R5bGVkRGlhbG9nUHJvcHM+YFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+XG4gICAgdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFdlYWtFbGV2YXRlZH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgYm9yZGVyOiAwO1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWyczJ119O1xuICB3aWR0aDogJHtNT0RBTF9XSURUSC5tZWRpdW19cHg7XG4gIGJveC1zaGFkb3c6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc2hhZG93cy5tb2RhbH07XG5cbiAgJHtPYmplY3QuZW50cmllcyhNT0RBTF9XSURUSCkubWFwKFxuICAgIChbc2l6ZSwgdmFsdWVdKSA9PiBgXG4gICAgICAmW2RhdGEtc2l6ZT1cIiR7c2l6ZX1cIl0ge1xuICAgICAgICB3aWR0aDogJHt2YWx1ZX1weDtcbiAgICAgIH1cbiAgICAgIGAsXG4gICl9XG5cbiAgJHtPYmplY3QuZW50cmllcyhNT0RBTF9QTEFDRU1FTlQpLm1hcChcbiAgICAoW3BsYWNlbWVudCwgdmFsdWVdKSA9PiBgXG4gICAgICAgICZbZGF0YS1wbGFjZW1lbnQ9XCIke3BsYWNlbWVudH1cIl0ge1xuICAgICAgICAgICR7dmFsdWV9XG4gICAgICAgIH1cbiAgICAgICAgYCxcbiAgKX1cbmBcblxuZXhwb3J0IGNvbnN0IERpYWxvZyA9ICh7XG4gIGNoaWxkcmVuLFxuICBvcGVuLFxuICBwbGFjZW1lbnQsXG4gIG9uQ2xvc2UsXG4gIGhpZGVPbkNsaWNrT3V0c2lkZSxcbiAgc2l6ZSxcbiAgaWQsXG4gIGFyaWFMYWJlbCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICBwcmV2ZW50Qm9keVNjcm9sbCxcbiAgaGlkZU9uRXNjLFxuICBiYWNrZHJvcENsYXNzTmFtZSxcbiAgZGlhbG9nQ3NzLFxuICBiYWNrZHJvcENzcyxcbn06IERpYWxvZ1Byb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRhaW5lclJlZiA9IHVzZVJlZihkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdkaXYnKSlcbiAgY29uc3QgZGlhbG9nUmVmID0gdXNlUmVmPEhUTUxEaWFsb2dFbGVtZW50PihudWxsKVxuICBjb25zdCBvbkNsb3NlUmVmID0gdXNlUmVmKG9uQ2xvc2UpXG5cbiAgLy8gUG9ydGFsIHRvIHB1dCB0aGUgbW9kYWwgaW5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBlbGVtZW50ID0gY29udGFpbmVyUmVmLmN1cnJlbnRcbiAgICBpZiAob3Blbikge1xuICAgICAgZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZChlbGVtZW50KVxuICAgIH1cblxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBpZiAoZG9jdW1lbnQuYm9keS5jb250YWlucyhlbGVtZW50KSkge1xuICAgICAgICBkb2N1bWVudC5ib2R5LnJlbW92ZUNoaWxkKGVsZW1lbnQpXG4gICAgICB9XG4gICAgfVxuICB9LCBbb3Blbl0pXG5cbiAgLy8gU2F2ZSB0aGUgcmVhc3NpZ25tZW50IG9mIGV2ZW50SGFuZGxlciBpbiB0aGUgdXNlRWZmZWN0IGJlbG93XG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgb25DbG9zZVJlZi5jdXJyZW50ID0gb25DbG9zZVxuICB9LCBbb25DbG9zZV0pXG5cbiAgLy8gT24gb3BlbiBmb2N1cyB0aGUgbW9kYWxcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAob3Blbikge1xuICAgICAgZGlhbG9nUmVmLmN1cnJlbnQ/LmZvY3VzKClcbiAgICB9XG4gIH0sIFtvcGVuXSlcblxuICAvLyBIYW5kbGUgYm9keSBzY3JvbGxcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBwcmV2aW91c092ZXJmbG93ID0gZG9jdW1lbnQuYm9keS5zdHlsZS5vdmVyZmxvd1xuXG4gICAgaWYgKG9wZW4gJiYgcHJldmVudEJvZHlTY3JvbGwpIHtcbiAgICAgIGRvY3VtZW50LmJvZHkuc3R5bGUub3ZlcmZsb3cgPSAnaGlkZGVuJ1xuICAgIH1cblxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBkb2N1bWVudC5ib2R5LnN0eWxlLm92ZXJmbG93ID0gcHJldmlvdXNPdmVyZmxvd1xuICAgIH1cbiAgfSwgW3ByZXZlbnRCb2R5U2Nyb2xsLCBvcGVuXSlcblxuICAvLyBTdG9wIGZvY3VzIHRvIHByZXZlbnQgdW5leHBlY3RlZCBib2R5IGxvb3NlIGZvY3VzXG4gIGNvbnN0IHN0b3BGb2N1czogRm9jdXNFdmVudEhhbmRsZXIgPSB1c2VDYWxsYmFjayhldmVudCA9PiB7XG4gICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcbiAgfSwgW10pXG5cbiAgLy8gU3RvcCBjbGljayB0byBwcmV2ZW50IHVuZXhwZWN0ZWQgZGlhbG9nIGNsb3NlXG4gIGNvbnN0IHN0b3BDbGljazogTW91c2VFdmVudEhhbmRsZXIgPSB1c2VDYWxsYmFjayhldmVudCA9PiB7XG4gICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcbiAgfSwgW10pXG5cbiAgLy8gaGFuZGxlIGtleSB1cCA6IHVzZWQgd2hlbiBoYXZpbmcgaW5wdXRzIGluIG1vZGFscyAtIHVzZWZ1bCBmb3IgaGlkZU9uRXNjXG4gIGNvbnN0IGhhbmRsZUtleVVwOiBLZXlib2FyZEV2ZW50SGFuZGxlciA9IHVzZUNhbGxiYWNrKFxuICAgIGV2ZW50ID0+IHtcbiAgICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXG4gICAgICBpZiAoZXZlbnQua2V5ID09PSAnRXNjYXBlJyAmJiBoaWRlT25Fc2MpIHtcbiAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKVxuICAgICAgICBvbkNsb3NlUmVmLmN1cnJlbnQoKVxuICAgICAgfVxuICAgIH0sXG4gICAgW2hpZGVPbkVzY10sXG4gIClcblxuICBjb25zdCBoYW5kbGVDbG9zZTogTW91c2VFdmVudEhhbmRsZXIgPSB1c2VDYWxsYmFjayhcbiAgICBldmVudCA9PiB7XG4gICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKVxuICAgICAgaWYgKGhpZGVPbkNsaWNrT3V0c2lkZSkge1xuICAgICAgICBvbkNsb3NlUmVmLmN1cnJlbnQoKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8gQmVjYXVzZSBvdmVybGF5IGlzIG5vdCBmb2N1c2FibGUgd2UgY2FuJ3QgaGFuZGxlIGhpZGVPbkVzYyBwcm9wZXJseVxuICAgICAgICBkaWFsb2dSZWYuY3VycmVudD8uZm9jdXMoKVxuICAgICAgfVxuICAgIH0sXG4gICAgW2hpZGVPbkNsaWNrT3V0c2lkZV0sXG4gIClcblxuICAvLyBFbmFibGUgZm9jdXMgdHJhcCBpbnNpZGUgdGhlIG1vZGFsXG4gIGNvbnN0IGhhbmRsZUZvY3VzVHJhcDogS2V5Ym9hcmRFdmVudEhhbmRsZXIgPSB1c2VDYWxsYmFjayhldmVudCA9PiB7XG4gICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcbiAgICBpZiAoZXZlbnQua2V5ID09PSAnRXNjYXBlJykge1xuICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKVxuXG4gICAgICByZXR1cm5cbiAgICB9XG4gICAgY29uc3QgaXNUYWJQcmVzc2VkID0gZXZlbnQua2V5ID09PSAnVGFiJ1xuXG4gICAgaWYgKCFpc1RhYlByZXNzZWQpIHtcbiAgICAgIHJldHVyblxuICAgIH1cblxuICAgIGNvbnN0IGZvY3VzYWJsZUVscyA9XG4gICAgICBkaWFsb2dSZWYuY3VycmVudD8ucXVlcnlTZWxlY3RvckFsbChcbiAgICAgICAgJ2FbaHJlZl06bm90KFtkaXNhYmxlZF0pLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCB0ZXh0YXJlYTpub3QoW2Rpc2FibGVkXSksIGlucHV0Om5vdChbZGlzYWJsZWRdKSwgc2VsZWN0Om5vdChbZGlzYWJsZWRdKScsXG4gICAgICApID8/IFtdXG5cbiAgICAvLyBIYW5kbGUgY2FzZSB3aGVuIG5vIGludGVyYWN0aXZlIGVsZW1lbnQgYXJlIHdpdGhpbiB0aGUgbW9kYWwgKGluY2x1ZGluZyBjbG9zZSBpY29uKVxuICAgIGlmIChmb2N1c2FibGVFbHMubGVuZ3RoID09PSAwKSB7XG4gICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpXG4gICAgfVxuXG4gICAgY29uc3QgZmlyc3RGb2N1c2FibGVFbCA9IGZvY3VzYWJsZUVsc1swXSBhcyBIVE1MRWxlbWVudFxuICAgIGNvbnN0IGxhc3RGb2N1c2FibGVFbCA9IGZvY3VzYWJsZUVsc1tmb2N1c2FibGVFbHMubGVuZ3RoIC0gMV0gYXMgSFRNTEVsZW1lbnRcblxuICAgIGlmIChldmVudC5zaGlmdEtleSkge1xuICAgICAgaWYgKFxuICAgICAgICBkb2N1bWVudC5hY3RpdmVFbGVtZW50ID09PSBmaXJzdEZvY3VzYWJsZUVsIHx8XG4gICAgICAgIGRvY3VtZW50LmFjdGl2ZUVsZW1lbnQgPT09IGRpYWxvZ1JlZi5jdXJyZW50XG4gICAgICApIHtcbiAgICAgICAgbGFzdEZvY3VzYWJsZUVsLmZvY3VzKClcbiAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKVxuICAgICAgfVxuICAgIH0gZWxzZSBpZiAoXG4gICAgICBkb2N1bWVudC5hY3RpdmVFbGVtZW50ID09PSBsYXN0Rm9jdXNhYmxlRWwgfHxcbiAgICAgIGRvY3VtZW50LmFjdGl2ZUVsZW1lbnQgPT09IGRpYWxvZ1JlZi5jdXJyZW50XG4gICAgKSB7XG4gICAgICBmaXJzdEZvY3VzYWJsZUVsLmZvY3VzKClcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICB9XG4gIH0sIFtdKVxuXG4gIC8vIFByZXZlbnQgZGVmYXVsdCBiZWhhdmlvdXIgb24gRXNjYXBlXG4gIGNvbnN0IHN0b3BDYW5jZWw6IFJlYWN0RXZlbnRIYW5kbGVyID0gZXZlbnQgPT4ge1xuICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKVxuICB9XG5cbiAgcmV0dXJuIG9wZW5cbiAgICA/IGNyZWF0ZVBvcnRhbChcbiAgICAgICAgPFN0eWxlZEJhY2tkcm9wXG4gICAgICAgICAgZGF0YS1vcGVuPXtvcGVufVxuICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZUNsb3NlfVxuICAgICAgICAgIGNsYXNzTmFtZT17YmFja2Ryb3BDbGFzc05hbWV9XG4gICAgICAgICAgY3NzPXtiYWNrZHJvcENzc31cbiAgICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9LWJhY2tkcm9wYCA6IHVuZGVmaW5lZH1cbiAgICAgICAgICBvbkZvY3VzPXtzdG9wRm9jdXN9XG4gICAgICAgID5cbiAgICAgICAgICA8U3R5bGVkRGlhbG9nXG4gICAgICAgICAgICBjc3M9e2RpYWxvZ0Nzc31cbiAgICAgICAgICAgIG9uS2V5VXA9e2hhbmRsZUtleVVwfVxuICAgICAgICAgICAgb25LZXlEb3duPXtoYW5kbGVGb2N1c1RyYXB9XG4gICAgICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgICAgIGlkPXtpZH1cbiAgICAgICAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgICAgICAgYXJpYS1sYWJlbD17YXJpYUxhYmVsfVxuICAgICAgICAgICAgZGF0YS1wbGFjZW1lbnQ9e3BsYWNlbWVudH1cbiAgICAgICAgICAgIGRhdGEtc2l6ZT17c2l6ZX1cbiAgICAgICAgICAgIG9wZW49e29wZW59XG4gICAgICAgICAgICBvbkNsaWNrPXtzdG9wQ2xpY2t9XG4gICAgICAgICAgICBvbkNhbmNlbD17c3RvcENhbmNlbH1cbiAgICAgICAgICAgIG9uQ2xvc2U9e3N0b3BDYW5jZWx9XG4gICAgICAgICAgICBhcmlhLW1vZGFsXG4gICAgICAgICAgICByZWY9e2RpYWxvZ1JlZn1cbiAgICAgICAgICAgIHRhYkluZGV4PXswfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtvcGVuID8gY2hpbGRyZW4gOiBudWxsfVxuICAgICAgICAgIDwvU3R5bGVkRGlhbG9nPlxuICAgICAgICA8L1N0eWxlZEJhY2tkcm9wPixcbiAgICAgICAgY29udGFpbmVyUmVmLmN1cnJlbnQsXG4gICAgICApXG4gICAgOiBudWxsXG59XG4iXX0= */"));
16
+ const StyledDialog = /* @__PURE__ */ _styled("dialog", process.env.NODE_ENV === "production" ? {
17
+ target: "e1cqen9h0"
18
+ } : {
19
+ target: "e1cqen9h0",
20
+ label: "StyledDialog"
21
+ })("background-color:", ({
22
+ theme
23
+ }) => theme.colors.neutral.backgroundWeakElevated, ";position:relative;border-radius:", ({
24
+ theme
25
+ }) => theme.radii.default, ";border:0;padding:", ({
26
+ theme
27
+ }) => theme.space["3"], ";width:", MODAL_WIDTH.medium, "px;box-shadow:", ({
28
+ theme
29
+ }) => theme.shadows.modal, ";", Object.entries(MODAL_WIDTH).map(([size, value]) => `
30
+ &[data-size="${size}"] {
31
+ width: ${value}px;
32
+ }
33
+ `), " ", Object.entries(MODAL_PLACEMENT).map(([placement, value]) => `
34
+ &[data-placement="${placement}"] {
35
+ ${value}
36
+ }
37
+ `), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL0RpYWxvZy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0NxRCIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9Nb2RhbC9EaWFsb2cudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7XG4gIEZvY3VzRXZlbnRIYW5kbGVyLFxuICBLZXlib2FyZEV2ZW50SGFuZGxlcixcbiAgTW91c2VFdmVudEhhbmRsZXIsXG4gIFJlYWN0RXZlbnRIYW5kbGVyLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZUNhbGxiYWNrLCB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgY3JlYXRlUG9ydGFsIH0gZnJvbSAncmVhY3QtZG9tJ1xuaW1wb3J0IHsgTU9EQUxfUExBQ0VNRU5ULCBNT0RBTF9XSURUSCB9IGZyb20gJy4vY29uc3RhbnRzJ1xuaW1wb3J0IHR5cGUgeyBEaWFsb2dQcm9wcywgTW9kYWxQbGFjZW1lbnQsIE1vZGFsU2l6ZSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IFN0eWxlZEJhY2tkcm9wID0gc3R5bGVkLmRpdjx7ICdkYXRhLW9wZW4nOiBib29sZWFuIH0+YFxuICBwb3NpdGlvbjogZml4ZWQ7XG4gIHRvcDogMDtcbiAgcmlnaHQ6IDA7XG4gIGhlaWdodDogMDtcbiAgd2lkdGg6IDA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm92ZXJsYXl9O1xuICB6LWluZGV4OiAxO1xuXG4gICZbZGF0YS1vcGVuPSd0cnVlJ10ge1xuICAgIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICAgb3ZlcmZsb3c6IGF1dG87XG4gICAgZGlzcGxheTogZmxleDtcbiAgICBib3R0b206IDA7XG4gICAgbGVmdDogMDtcbiAgICBoZWlnaHQ6IDEwMCU7XG4gICAgd2lkdGg6IDEwMCU7XG4gIH1cbmBcblxudHlwZSBTdHlsZWREaWFsb2dQcm9wcyA9IHtcbiAgJ2RhdGEtc2l6ZSc6IE1vZGFsU2l6ZVxuICAnZGF0YS1wbGFjZW1lbnQnOiBNb2RhbFBsYWNlbWVudFxufVxuXG5jb25zdCBTdHlsZWREaWFsb2cgPSBzdHlsZWQuZGlhbG9nPFN0eWxlZERpYWxvZ1Byb3BzPmBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PlxuICAgIHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmRXZWFrRWxldmF0ZWR9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG4gIGJvcmRlcjogMDtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMyddfTtcbiAgd2lkdGg6ICR7TU9EQUxfV0lEVEgubWVkaXVtfXB4O1xuICBib3gtc2hhZG93OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNoYWRvd3MubW9kYWx9O1xuXG4gICR7T2JqZWN0LmVudHJpZXMoTU9EQUxfV0lEVEgpLm1hcChcbiAgICAoW3NpemUsIHZhbHVlXSkgPT4gYFxuICAgICAgJltkYXRhLXNpemU9XCIke3NpemV9XCJdIHtcbiAgICAgICAgd2lkdGg6ICR7dmFsdWV9cHg7XG4gICAgICB9XG4gICAgICBgLFxuICApfVxuXG4gICR7T2JqZWN0LmVudHJpZXMoTU9EQUxfUExBQ0VNRU5UKS5tYXAoXG4gICAgKFtwbGFjZW1lbnQsIHZhbHVlXSkgPT4gYFxuICAgICAgICAmW2RhdGEtcGxhY2VtZW50PVwiJHtwbGFjZW1lbnR9XCJdIHtcbiAgICAgICAgICAke3ZhbHVlfVxuICAgICAgICB9XG4gICAgICAgIGAsXG4gICl9XG5gXG5cbmV4cG9ydCBjb25zdCBEaWFsb2cgPSAoe1xuICBjaGlsZHJlbixcbiAgb3BlbixcbiAgcGxhY2VtZW50LFxuICBvbkNsb3NlLFxuICBoaWRlT25DbGlja091dHNpZGUsXG4gIHNpemUsXG4gIGlkLFxuICBhcmlhTGFiZWwsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgcHJldmVudEJvZHlTY3JvbGwsXG4gIGhpZGVPbkVzYyxcbiAgYmFja2Ryb3BDbGFzc05hbWUsXG4gIGRpYWxvZ0NzcyxcbiAgYmFja2Ryb3BDc3MsXG59OiBEaWFsb2dQcm9wcykgPT4ge1xuICBjb25zdCBjb250YWluZXJSZWYgPSB1c2VSZWYoZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnZGl2JykpXG4gIGNvbnN0IGRpYWxvZ1JlZiA9IHVzZVJlZjxIVE1MRGlhbG9nRWxlbWVudD4obnVsbClcbiAgY29uc3Qgb25DbG9zZVJlZiA9IHVzZVJlZihvbkNsb3NlKVxuXG4gIC8vIFBvcnRhbCB0byBwdXQgdGhlIG1vZGFsIGluXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgZWxlbWVudCA9IGNvbnRhaW5lclJlZi5jdXJyZW50XG4gICAgaWYgKG9wZW4pIHtcbiAgICAgIGRvY3VtZW50LmJvZHkuYXBwZW5kQ2hpbGQoZWxlbWVudClcbiAgICB9XG5cbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaWYgKGRvY3VtZW50LmJvZHkuY29udGFpbnMoZWxlbWVudCkpIHtcbiAgICAgICAgZG9jdW1lbnQuYm9keS5yZW1vdmVDaGlsZChlbGVtZW50KVxuICAgICAgfVxuICAgIH1cbiAgfSwgW29wZW5dKVxuXG4gIC8vIFNhdmUgdGhlIHJlYXNzaWdubWVudCBvZiBldmVudEhhbmRsZXIgaW4gdGhlIHVzZUVmZmVjdCBiZWxvd1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIG9uQ2xvc2VSZWYuY3VycmVudCA9IG9uQ2xvc2VcbiAgfSwgW29uQ2xvc2VdKVxuXG4gIC8vIE9uIG9wZW4gZm9jdXMgdGhlIG1vZGFsXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKG9wZW4pIHtcbiAgICAgIGRpYWxvZ1JlZi5jdXJyZW50Py5mb2N1cygpXG4gICAgfVxuICB9LCBbb3Blbl0pXG5cbiAgLy8gSGFuZGxlIGJvZHkgc2Nyb2xsXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgcHJldmlvdXNPdmVyZmxvdyA9IGRvY3VtZW50LmJvZHkuc3R5bGUub3ZlcmZsb3dcblxuICAgIGlmIChvcGVuICYmIHByZXZlbnRCb2R5U2Nyb2xsKSB7XG4gICAgICBkb2N1bWVudC5ib2R5LnN0eWxlLm92ZXJmbG93ID0gJ2hpZGRlbidcbiAgICB9XG5cbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgZG9jdW1lbnQuYm9keS5zdHlsZS5vdmVyZmxvdyA9IHByZXZpb3VzT3ZlcmZsb3dcbiAgICB9XG4gIH0sIFtwcmV2ZW50Qm9keVNjcm9sbCwgb3Blbl0pXG5cbiAgLy8gU3RvcCBmb2N1cyB0byBwcmV2ZW50IHVuZXhwZWN0ZWQgYm9keSBsb29zZSBmb2N1c1xuICBjb25zdCBzdG9wRm9jdXM6IEZvY3VzRXZlbnRIYW5kbGVyID0gdXNlQ2FsbGJhY2soZXZlbnQgPT4ge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXG4gIH0sIFtdKVxuXG4gIC8vIFN0b3AgY2xpY2sgdG8gcHJldmVudCB1bmV4cGVjdGVkIGRpYWxvZyBjbG9zZVxuICBjb25zdCBzdG9wQ2xpY2s6IE1vdXNlRXZlbnRIYW5kbGVyID0gdXNlQ2FsbGJhY2soZXZlbnQgPT4ge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXG4gIH0sIFtdKVxuXG4gIC8vIGhhbmRsZSBrZXkgdXAgOiB1c2VkIHdoZW4gaGF2aW5nIGlucHV0cyBpbiBtb2RhbHMgLSB1c2VmdWwgZm9yIGhpZGVPbkVzY1xuICBjb25zdCBoYW5kbGVLZXlVcDogS2V5Ym9hcmRFdmVudEhhbmRsZXIgPSB1c2VDYWxsYmFjayhcbiAgICBldmVudCA9PiB7XG4gICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKVxuICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJ0VzY2FwZScgJiYgaGlkZU9uRXNjKSB7XG4gICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICAgICAgb25DbG9zZVJlZi5jdXJyZW50KClcbiAgICAgIH1cbiAgICB9LFxuICAgIFtoaWRlT25Fc2NdLFxuICApXG5cbiAgY29uc3QgaGFuZGxlQ2xvc2U6IE1vdXNlRXZlbnRIYW5kbGVyID0gdXNlQ2FsbGJhY2soXG4gICAgZXZlbnQgPT4ge1xuICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcbiAgICAgIGlmIChoaWRlT25DbGlja091dHNpZGUpIHtcbiAgICAgICAgb25DbG9zZVJlZi5jdXJyZW50KClcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIC8vIEJlY2F1c2Ugb3ZlcmxheSBpcyBub3QgZm9jdXNhYmxlIHdlIGNhbid0IGhhbmRsZSBoaWRlT25Fc2MgcHJvcGVybHlcbiAgICAgICAgZGlhbG9nUmVmLmN1cnJlbnQ/LmZvY3VzKClcbiAgICAgIH1cbiAgICB9LFxuICAgIFtoaWRlT25DbGlja091dHNpZGVdLFxuICApXG5cbiAgLy8gRW5hYmxlIGZvY3VzIHRyYXAgaW5zaWRlIHRoZSBtb2RhbFxuICBjb25zdCBoYW5kbGVGb2N1c1RyYXA6IEtleWJvYXJkRXZlbnRIYW5kbGVyID0gdXNlQ2FsbGJhY2soZXZlbnQgPT4ge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXG4gICAgaWYgKGV2ZW50LmtleSA9PT0gJ0VzY2FwZScpIHtcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcblxuICAgICAgcmV0dXJuXG4gICAgfVxuICAgIGNvbnN0IGlzVGFiUHJlc3NlZCA9IGV2ZW50LmtleSA9PT0gJ1RhYidcblxuICAgIGlmICghaXNUYWJQcmVzc2VkKSB7XG4gICAgICByZXR1cm5cbiAgICB9XG5cbiAgICBjb25zdCBmb2N1c2FibGVFbHMgPVxuICAgICAgZGlhbG9nUmVmLmN1cnJlbnQ/LnF1ZXJ5U2VsZWN0b3JBbGwoXG4gICAgICAgICdhW2hyZWZdOm5vdChbZGlzYWJsZWRdKSwgYnV0dG9uOm5vdChbZGlzYWJsZWRdKSwgdGV4dGFyZWE6bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSknLFxuICAgICAgKSA/PyBbXVxuXG4gICAgLy8gSGFuZGxlIGNhc2Ugd2hlbiBubyBpbnRlcmFjdGl2ZSBlbGVtZW50IGFyZSB3aXRoaW4gdGhlIG1vZGFsIChpbmNsdWRpbmcgY2xvc2UgaWNvbilcbiAgICBpZiAoZm9jdXNhYmxlRWxzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKVxuICAgIH1cblxuICAgIGNvbnN0IGZpcnN0Rm9jdXNhYmxlRWwgPSBmb2N1c2FibGVFbHNbMF0gYXMgSFRNTEVsZW1lbnRcbiAgICBjb25zdCBsYXN0Rm9jdXNhYmxlRWwgPSBmb2N1c2FibGVFbHNbZm9jdXNhYmxlRWxzLmxlbmd0aCAtIDFdIGFzIEhUTUxFbGVtZW50XG5cbiAgICBpZiAoZXZlbnQuc2hpZnRLZXkpIHtcbiAgICAgIGlmIChcbiAgICAgICAgZG9jdW1lbnQuYWN0aXZlRWxlbWVudCA9PT0gZmlyc3RGb2N1c2FibGVFbCB8fFxuICAgICAgICBkb2N1bWVudC5hY3RpdmVFbGVtZW50ID09PSBkaWFsb2dSZWYuY3VycmVudFxuICAgICAgKSB7XG4gICAgICAgIGxhc3RGb2N1c2FibGVFbC5mb2N1cygpXG4gICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICAgIH1cbiAgICB9IGVsc2UgaWYgKFxuICAgICAgZG9jdW1lbnQuYWN0aXZlRWxlbWVudCA9PT0gbGFzdEZvY3VzYWJsZUVsIHx8XG4gICAgICBkb2N1bWVudC5hY3RpdmVFbGVtZW50ID09PSBkaWFsb2dSZWYuY3VycmVudFxuICAgICkge1xuICAgICAgZmlyc3RGb2N1c2FibGVFbC5mb2N1cygpXG4gICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpXG4gICAgfVxuICB9LCBbXSlcblxuICAvLyBQcmV2ZW50IGRlZmF1bHQgYmVoYXZpb3VyIG9uIEVzY2FwZVxuICBjb25zdCBzdG9wQ2FuY2VsOiBSZWFjdEV2ZW50SGFuZGxlciA9IGV2ZW50ID0+IHtcbiAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpXG4gICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcbiAgfVxuXG4gIHJldHVybiBvcGVuXG4gICAgPyBjcmVhdGVQb3J0YWwoXG4gICAgICAgIDxTdHlsZWRCYWNrZHJvcFxuICAgICAgICAgIGRhdGEtb3Blbj17b3Blbn1cbiAgICAgICAgICBvbkNsaWNrPXtoYW5kbGVDbG9zZX1cbiAgICAgICAgICBjbGFzc05hbWU9e2JhY2tkcm9wQ2xhc3NOYW1lfVxuICAgICAgICAgIGNzcz17YmFja2Ryb3BDc3N9XG4gICAgICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWQgPyBgJHtkYXRhVGVzdElkfS1iYWNrZHJvcGAgOiB1bmRlZmluZWR9XG4gICAgICAgICAgb25Gb2N1cz17c3RvcEZvY3VzfVxuICAgICAgICA+XG4gICAgICAgICAgPFN0eWxlZERpYWxvZ1xuICAgICAgICAgICAgY3NzPXtkaWFsb2dDc3N9XG4gICAgICAgICAgICBvbktleVVwPXtoYW5kbGVLZXlVcH1cbiAgICAgICAgICAgIG9uS2V5RG93bj17aGFuZGxlRm9jdXNUcmFwfVxuICAgICAgICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICAgICAgICBpZD17aWR9XG4gICAgICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgICAgIGFyaWEtbGFiZWw9e2FyaWFMYWJlbH1cbiAgICAgICAgICAgIGRhdGEtcGxhY2VtZW50PXtwbGFjZW1lbnR9XG4gICAgICAgICAgICBkYXRhLXNpemU9e3NpemV9XG4gICAgICAgICAgICBvcGVuPXtvcGVufVxuICAgICAgICAgICAgb25DbGljaz17c3RvcENsaWNrfVxuICAgICAgICAgICAgb25DYW5jZWw9e3N0b3BDYW5jZWx9XG4gICAgICAgICAgICBvbkNsb3NlPXtzdG9wQ2FuY2VsfVxuICAgICAgICAgICAgYXJpYS1tb2RhbFxuICAgICAgICAgICAgcmVmPXtkaWFsb2dSZWZ9XG4gICAgICAgICAgICB0YWJJbmRleD17MH1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7b3BlbiA/IGNoaWxkcmVuIDogbnVsbH1cbiAgICAgICAgICA8L1N0eWxlZERpYWxvZz5cbiAgICAgICAgPC9TdHlsZWRCYWNrZHJvcD4sXG4gICAgICAgIGNvbnRhaW5lclJlZi5jdXJyZW50LFxuICAgICAgKVxuICAgIDogbnVsbFxufVxuIl19 */"));
38
+ const Dialog = ({
39
+ children,
40
+ open,
41
+ placement,
42
+ onClose,
43
+ hideOnClickOutside,
44
+ size,
45
+ id,
46
+ ariaLabel,
47
+ className,
48
+ "data-testid": dataTestId,
49
+ preventBodyScroll,
50
+ hideOnEsc,
51
+ backdropClassName,
52
+ dialogCss,
53
+ backdropCss
54
+ }) => {
55
+ const containerRef = useRef(document.createElement("div"));
56
+ const dialogRef = useRef(null);
57
+ const onCloseRef = useRef(onClose);
58
+ useEffect(() => {
59
+ const element = containerRef.current;
60
+ if (open) {
61
+ document.body.appendChild(element);
62
+ }
63
+ return () => {
64
+ if (document.body.contains(element)) {
65
+ document.body.removeChild(element);
66
+ }
67
+ };
68
+ }, [open]);
69
+ useEffect(() => {
70
+ onCloseRef.current = onClose;
71
+ }, [onClose]);
72
+ useEffect(() => {
73
+ if (open) {
74
+ dialogRef.current?.focus();
75
+ }
76
+ }, [open]);
77
+ useEffect(() => {
78
+ const previousOverflow = document.body.style.overflow;
79
+ if (open && preventBodyScroll) {
80
+ document.body.style.overflow = "hidden";
81
+ }
82
+ return () => {
83
+ document.body.style.overflow = previousOverflow;
84
+ };
85
+ }, [preventBodyScroll, open]);
86
+ const stopFocus = useCallback((event) => {
87
+ event.stopPropagation();
88
+ }, []);
89
+ const stopClick = useCallback((event) => {
90
+ event.stopPropagation();
91
+ }, []);
92
+ const handleKeyUp = useCallback((event) => {
93
+ event.stopPropagation();
94
+ if (event.key === "Escape" && hideOnEsc) {
95
+ event.preventDefault();
96
+ onCloseRef.current();
97
+ }
98
+ }, [hideOnEsc]);
99
+ const handleClose = useCallback((event) => {
100
+ event.stopPropagation();
101
+ if (hideOnClickOutside) {
102
+ onCloseRef.current();
103
+ } else {
104
+ dialogRef.current?.focus();
105
+ }
106
+ }, [hideOnClickOutside]);
107
+ const handleFocusTrap = useCallback((event) => {
108
+ event.stopPropagation();
109
+ if (event.key === "Escape") {
110
+ event.preventDefault();
111
+ return;
112
+ }
113
+ const isTabPressed = event.key === "Tab";
114
+ if (!isTabPressed) {
115
+ return;
116
+ }
117
+ const focusableEls = dialogRef.current?.querySelectorAll("a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled])") ?? [];
118
+ if (focusableEls.length === 0) {
119
+ event.preventDefault();
120
+ }
121
+ const firstFocusableEl = focusableEls[0];
122
+ const lastFocusableEl = focusableEls[focusableEls.length - 1];
123
+ if (event.shiftKey) {
124
+ if (document.activeElement === firstFocusableEl || document.activeElement === dialogRef.current) {
125
+ lastFocusableEl.focus();
126
+ event.preventDefault();
127
+ }
128
+ } else if (document.activeElement === lastFocusableEl || document.activeElement === dialogRef.current) {
129
+ firstFocusableEl.focus();
130
+ event.preventDefault();
131
+ }
132
+ }, []);
133
+ const stopCancel = (event) => {
134
+ event.preventDefault();
135
+ event.stopPropagation();
136
+ };
137
+ return open ? createPortal(/* @__PURE__ */ jsx(StyledBackdrop, { "data-open": open, onClick: handleClose, className: backdropClassName, css: backdropCss, "data-testid": dataTestId ? `${dataTestId}-backdrop` : void 0, onFocus: stopFocus, children: /* @__PURE__ */ jsx(StyledDialog, { css: dialogCss, onKeyUp: handleKeyUp, onKeyDown: handleFocusTrap, className, id, "data-testid": dataTestId, "aria-label": ariaLabel, "data-placement": placement, "data-size": size, open, onClick: stopClick, onCancel: stopCancel, onClose: stopCancel, "aria-modal": true, ref: dialogRef, tabIndex: 0, children: open ? children : null }) }), containerRef.current) : null;
138
+ };
139
+ export {
140
+ Dialog
141
+ };
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import type { DisclosureProps } from './types';
3
+ export declare const Disclosure: ({ disclosure, handleOpen, visible, handleClose, toggle, id, }: DisclosureProps) => import("react").ReactElement<unknown, string | import("react").JSXElementConstructor<any>> | null;
@@ -1,5 +1,4 @@
1
- import { useEffect, useMemo, isValidElement, cloneElement, createRef } from 'react';
2
-
1
+ import { createRef, useEffect, useMemo, isValidElement, cloneElement } from "react";
3
2
  const Disclosure = ({
4
3
  disclosure,
5
4
  handleOpen,
@@ -8,16 +7,16 @@ const Disclosure = ({
8
7
  toggle,
9
8
  id
10
9
  }) => {
11
- const disclosureRef = /*#__PURE__*/createRef();
10
+ const disclosureRef = createRef();
12
11
  useEffect(() => {
13
12
  const element = disclosureRef.current;
14
- element?.addEventListener('click', handleOpen);
13
+ element?.addEventListener("click", handleOpen);
15
14
  return () => {
16
- element?.removeEventListener('click', handleOpen);
15
+ element?.removeEventListener("click", handleOpen);
17
16
  };
18
17
  }, [handleOpen, disclosureRef]);
19
18
  const finalDisclosure = useMemo(() => {
20
- if (typeof disclosure === 'function') {
19
+ if (typeof disclosure === "function") {
21
20
  return disclosure({
22
21
  visible,
23
22
  onClose: handleClose,
@@ -31,14 +30,15 @@ const Disclosure = ({
31
30
  }
32
31
  return disclosure;
33
32
  }, [disclosure, handleOpen, handleClose, id, toggle, visible]);
34
- if (! /*#__PURE__*/isValidElement(finalDisclosure)) {
33
+ if (!isValidElement(finalDisclosure)) {
35
34
  return null;
36
35
  }
37
- return /*#__PURE__*/cloneElement(finalDisclosure, {
36
+ return cloneElement(finalDisclosure, {
38
37
  ref: disclosureRef,
39
- 'aria-controls': id,
40
- 'aria-haspopup': 'dialog'
38
+ "aria-controls": id,
39
+ "aria-haspopup": "dialog"
41
40
  });
42
41
  };
43
-
44
- export { Disclosure };
42
+ export {
43
+ Disclosure
44
+ };
@@ -0,0 +1,3 @@
1
+ import type { ModalPlacement, ModalSize } from './types';
2
+ export declare const MODAL_WIDTH: Record<ModalSize, number>;
3
+ export declare const MODAL_PLACEMENT: Record<ModalPlacement, string>;
@@ -10,12 +10,12 @@ const MODAL_PLACEMENT = {
10
10
  margin: auto;
11
11
  margin-bottom: 0;
12
12
  `,
13
- 'bottom-left': `
13
+ "bottom-left": `
14
14
  margin: auto;
15
15
  margin-left: 0;
16
16
  margin-bottom: 0;
17
17
  `,
18
- 'bottom-right': `
18
+ "bottom-right": `
19
19
  margin: auto;
20
20
  margin-right: 0;
21
21
  margin-bottom: 0;
@@ -35,16 +35,18 @@ const MODAL_PLACEMENT = {
35
35
  margin: auto;
36
36
  margin-top: 0px;
37
37
  `,
38
- 'top-left': `
38
+ "top-left": `
39
39
  margin: auto;
40
40
  margin-left: 0;
41
41
  margin-top: 0;
42
42
  `,
43
- 'top-right': `
43
+ "top-right": `
44
44
  margin: auto;
45
45
  margin-right: 0;
46
46
  margin-top: 0;
47
47
  `
48
48
  };
49
-
50
- export { MODAL_PLACEMENT, MODAL_WIDTH };
49
+ export {
50
+ MODAL_PLACEMENT,
51
+ MODAL_WIDTH
52
+ };
@@ -0,0 +1,42 @@
1
+ import type { ReactElement, ReactNode } from 'react';
2
+ import type React from 'react';
3
+ import type { ModalPlacement, ModalSize, ModalState } from './types';
4
+ export type ModalProps = {
5
+ id?: string;
6
+ hideOnEsc?: boolean;
7
+ hideOnClickOutside?: boolean;
8
+ preventBodyScroll?: boolean;
9
+ ariaLabel?: string;
10
+ disclosure?: ReactElement | ((state: ModalState) => ReactElement);
11
+ isClosable?: boolean;
12
+ onClose?: () => void;
13
+ onBeforeClose?: () => Promise<void> | void;
14
+ open?: boolean;
15
+ /**
16
+ * @deprecated You should use open prop instead
17
+ */
18
+ opened?: boolean;
19
+ placement?: ModalPlacement;
20
+ size?: ModalSize;
21
+ /**
22
+ * @deprecated You should use size prop instead
23
+ */
24
+ width?: ModalSize;
25
+ children: ReactNode | ((args: ModalState) => ReactNode);
26
+ className?: string;
27
+ 'data-testid'?: string;
28
+ backdropClassName?: string;
29
+ /**
30
+ * @deprecated You should use backdropClassName instead
31
+ */
32
+ customDialogBackdropStyles?: React.JSX.IntrinsicAttributes['css'];
33
+ /**
34
+ * @deprecated You should use className instead
35
+ */
36
+ customDialogStyles?: React.JSX.IntrinsicAttributes['css'];
37
+ };
38
+ /**
39
+ * Modal is a component that allows you to display content on top of other content.
40
+ * It is often used to display a dialog with additional information or to ask for a confirmation.
41
+ */
42
+ export declare const Modal: ({ ariaLabel, id, children, disclosure, hideOnClickOutside, hideOnEsc, isClosable, onClose, onBeforeClose, open, opened, placement, preventBodyScroll, size, className, "data-testid": dataTestId, backdropClassName, width, customDialogStyles, customDialogBackdropStyles, }: ModalProps) => import("@emotion/react/jsx-runtime").JSX.Element;