@cube-dev/ui-kit 0.12.6 → 0.13.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (557) hide show
  1. package/CHANGELOG.md +297 -0
  2. package/cjs/_internal/hooks/index.js +1 -1
  3. package/cjs/_internal/hooks/use-chained-callback.js +1 -1
  4. package/cjs/_internal/hooks/use-deprecation-warning.js +1 -1
  5. package/cjs/_internal/hooks/use-event.js +1 -1
  6. package/cjs/_internal/hooks/use-sync-ref.js +1 -1
  7. package/cjs/_internal/hooks/use-timer/index.js +1 -1
  8. package/cjs/_internal/hooks/use-timer/timer.js +1 -1
  9. package/cjs/_internal/hooks/use-timer/use-timer.js +7 -7
  10. package/cjs/_internal/index.js +1 -1
  11. package/cjs/components/Base.js +2 -2
  12. package/cjs/components/Block.js +1 -1
  13. package/cjs/components/GlobalStyles.js +1 -1
  14. package/cjs/components/GridProvider.js +2 -3
  15. package/cjs/components/HiddenInput.js +1 -1
  16. package/cjs/components/OpenTrasition.js +1 -1
  17. package/cjs/components/Root.js +38 -3
  18. package/cjs/components/actions/Action.js +2 -2
  19. package/cjs/components/actions/Button/Button.js +3 -3
  20. package/cjs/components/actions/Button/Submit.js +1 -1
  21. package/cjs/components/actions/Button/index.js +1 -1
  22. package/cjs/components/actions/ButtonGroup/ButtonGroup.js +1 -1
  23. package/cjs/components/actions/index.js +1 -1
  24. package/cjs/components/content/ActiveZone/ActiveZone.js +1 -1
  25. package/cjs/components/content/Alert/Alert.js +1 -1
  26. package/cjs/components/content/Alert/index.js +1 -1
  27. package/cjs/components/content/Alert/types.js +1 -1
  28. package/cjs/components/content/Alert/use-alert.js +2 -3
  29. package/cjs/components/content/Avatar/Avatar.js +1 -1
  30. package/cjs/components/content/Badge/Badge.js +1 -1
  31. package/cjs/components/content/Card/Card.js +1 -1
  32. package/cjs/components/content/Content.js +1 -1
  33. package/cjs/components/content/CopySnippet/CopySnippet.js +1 -1
  34. package/cjs/components/content/CopySnippet/index.js +1 -1
  35. package/cjs/components/content/Divider.js +1 -1
  36. package/cjs/components/content/Footer.js +1 -1
  37. package/cjs/components/content/Header.js +1 -1
  38. package/cjs/components/content/Paragraph.js +1 -1
  39. package/cjs/components/content/Placeholder/Placeholder.js +1 -1
  40. package/cjs/components/content/PrismCode/PrismCode.js +1 -1
  41. package/cjs/components/content/Result/Result.js +2 -2
  42. package/cjs/components/content/Skeleton/Skeleton.js +1 -1
  43. package/cjs/components/content/Tag/Tag.js +1 -1
  44. package/cjs/components/content/Text.js +1 -1
  45. package/cjs/components/content/Title.js +1 -1
  46. package/cjs/components/forms/Checkbox/Checkbox.js +1 -1
  47. package/cjs/components/forms/Checkbox/CheckboxGroup.js +1 -1
  48. package/cjs/components/forms/Checkbox/context.js +1 -1
  49. package/cjs/components/forms/FieldWrapper.js +1 -1
  50. package/cjs/components/forms/FileInput/FileInput.js +6 -7
  51. package/cjs/components/forms/Form/Field.js +5 -5
  52. package/cjs/components/forms/Form/Form.js +19 -19
  53. package/cjs/components/forms/Form/index.js +1 -1
  54. package/cjs/components/forms/Form/types.js +1 -1
  55. package/cjs/components/forms/Form/useForm.js +4 -7
  56. package/cjs/components/forms/Form/validation.js +2 -2
  57. package/cjs/components/forms/Input/Input.js +1 -1
  58. package/cjs/components/forms/Input/index.js +1 -1
  59. package/cjs/components/forms/Label.js +1 -1
  60. package/cjs/components/forms/NumberInput/NumberInput.js +1 -1
  61. package/cjs/components/forms/NumberInput/StepButton.js +1 -1
  62. package/cjs/components/forms/PasswordInput/PasswordInput.js +1 -1
  63. package/cjs/components/forms/RadioGroup/Radio.js +1 -1
  64. package/cjs/components/forms/RadioGroup/RadioGroup.js +1 -1
  65. package/cjs/components/forms/RadioGroup/context.js +1 -1
  66. package/cjs/components/forms/SearchInput/SearchInput.js +1 -1
  67. package/cjs/components/forms/Switch/Switch.js +1 -1
  68. package/cjs/components/forms/TextArea/TextArea.js +1 -1
  69. package/cjs/components/forms/TextInput/TextInput.js +1 -1
  70. package/cjs/components/forms/TextInput/TextInputBase.js +4 -4
  71. package/cjs/components/forms/index.js +1 -1
  72. package/cjs/components/layout/Flex.js +1 -1
  73. package/cjs/components/layout/Flow.js +1 -1
  74. package/cjs/components/layout/Grid.js +1 -1
  75. package/cjs/components/layout/Prefix.js +2 -2
  76. package/cjs/components/layout/Space.js +1 -1
  77. package/cjs/components/layout/Suffix.js +1 -1
  78. package/cjs/components/navigation/LegacyTabs/LegacyTabs.js +1 -1
  79. package/cjs/components/navigation/Link/Link.js +1 -1
  80. package/cjs/components/organisms/FileTabs/FileTabs.js +1 -1
  81. package/cjs/components/organisms/Modal/Modal.js +1 -1
  82. package/cjs/components/organisms/StatsCard/StatsCard.js +1 -1
  83. package/cjs/components/other/Base64Upload/Base64Upload.js +1 -1
  84. package/cjs/components/other/CloudLogo/CloudLogo.js +1 -1
  85. package/cjs/components/overlays/AlertDialog/AlertDialog.js +3 -9
  86. package/cjs/components/overlays/AlertDialog/AlertDialogApiProvider.js +6 -7
  87. package/cjs/components/overlays/AlertDialog/AlertDialogZone.js +2 -2
  88. package/cjs/components/overlays/AlertDialog/index.js +1 -1
  89. package/cjs/components/overlays/AlertDialog/types.js +1 -1
  90. package/cjs/components/overlays/Dialog/Dialog.js +1 -1
  91. package/cjs/components/overlays/Dialog/DialogContainer.js +1 -1
  92. package/cjs/components/overlays/Dialog/DialogForm.js +7 -7
  93. package/cjs/components/overlays/Dialog/DialogTrigger.js +1 -1
  94. package/cjs/components/overlays/Dialog/context.js +1 -1
  95. package/cjs/components/overlays/Dialog/index.js +1 -1
  96. package/cjs/components/overlays/Modal/Modal.js +7 -12
  97. package/cjs/components/overlays/Modal/OpenTransition.js +1 -1
  98. package/cjs/components/overlays/Modal/Overlay.js +3 -3
  99. package/cjs/components/overlays/Modal/Popover.js +1 -1
  100. package/cjs/components/overlays/Modal/Tray.js +3 -34
  101. package/cjs/components/overlays/Modal/Underlay.js +1 -1
  102. package/cjs/components/overlays/Modal/index.js +1 -1
  103. package/cjs/components/overlays/NewNotifications/Bar/FloatingNotification.js +10 -2
  104. package/cjs/components/overlays/NewNotifications/Bar/NotificationsBar.js +30 -13
  105. package/cjs/components/overlays/NewNotifications/Bar/TransitionComponent.js +1 -1
  106. package/cjs/components/overlays/NewNotifications/Bar/index.js +1 -1
  107. package/cjs/components/overlays/NewNotifications/Dialog/NotificationsDialogTrigger.js +2 -2
  108. package/cjs/components/overlays/NewNotifications/Dialog/index.js +1 -1
  109. package/cjs/components/overlays/NewNotifications/Notification.js +6 -3
  110. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationAction.js +6 -3
  111. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationCloseButton.js +9 -20
  112. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationDescription.js +4 -1
  113. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationFooter.js +5 -3
  114. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationHeader.js +4 -1
  115. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationIcon.js +4 -1
  116. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationProvider.js +4 -1
  117. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationView.js +14 -11
  118. package/cjs/components/overlays/NewNotifications/NotificationView/index.js +1 -1
  119. package/cjs/components/overlays/NewNotifications/NotificationView/types.js +1 -1
  120. package/cjs/components/overlays/NewNotifications/NotificationsContext/NotificationsProvider.js +3 -3
  121. package/cjs/components/overlays/NewNotifications/NotificationsContext/index.js +1 -1
  122. package/cjs/components/overlays/NewNotifications/NotificationsContext/use-notifications.js +18 -16
  123. package/cjs/components/overlays/NewNotifications/NotificationsList/NotificationsList.js +48 -0
  124. package/cjs/components/overlays/NewNotifications/NotificationsList/NotificationsListItem.js +33 -0
  125. package/cjs/components/overlays/NewNotifications/NotificationsList/index.js +22 -0
  126. package/cjs/components/overlays/NewNotifications/NotificationsList/types.js +11 -0
  127. package/cjs/components/overlays/NewNotifications/hooks/index.js +1 -1
  128. package/cjs/components/overlays/NewNotifications/hooks/types.js +1 -1
  129. package/cjs/components/overlays/NewNotifications/hooks/use-notification-list-item.js +1 -1
  130. package/cjs/components/overlays/NewNotifications/hooks/use-notifications-api.js +1 -1
  131. package/cjs/components/overlays/NewNotifications/hooks/use-notifications-list.js +1 -1
  132. package/cjs/components/overlays/NewNotifications/hooks/use-notifications-observer.js +3 -4
  133. package/cjs/components/overlays/NewNotifications/index.js +1 -1
  134. package/cjs/components/overlays/NewNotifications/types.js +1 -1
  135. package/cjs/components/overlays/Notification/Notification.js +1 -1
  136. package/cjs/components/overlays/OverlayWrapper.js +1 -1
  137. package/cjs/components/overlays/Toasts/Toast.js +2 -2
  138. package/cjs/components/overlays/Toasts/index.js +1 -1
  139. package/cjs/components/overlays/Toasts/types.js +1 -1
  140. package/cjs/components/overlays/Toasts/use-toasts-api.js +1 -1
  141. package/cjs/components/overlays/Tooltip/Tooltip.js +5 -5
  142. package/cjs/components/overlays/Tooltip/TooltipProvider.js +1 -1
  143. package/cjs/components/overlays/Tooltip/TooltipTrigger.js +2 -3
  144. package/cjs/components/overlays/Tooltip/context.js +1 -1
  145. package/cjs/components/pickers/ComboBox/ComboBox.js +2 -3
  146. package/cjs/components/pickers/Menu/Menu.js +1 -1
  147. package/cjs/components/pickers/Menu/MenuButton.js +9 -5
  148. package/cjs/components/pickers/Menu/MenuItem.js +18 -9
  149. package/cjs/components/pickers/Menu/MenuSection.js +1 -1
  150. package/cjs/components/pickers/Menu/MenuTrigger.js +1 -1
  151. package/cjs/components/pickers/Menu/context.js +1 -1
  152. package/cjs/components/pickers/Menu/styled.js +1 -1
  153. package/cjs/components/pickers/Select/Select.js +5 -6
  154. package/cjs/components/portal/Portal.js +1 -1
  155. package/cjs/components/portal/PortalProvider.js +1 -1
  156. package/cjs/components/portal/index.js +1 -1
  157. package/cjs/components/portal/storybook/templates/CustomRoot.js +1 -1
  158. package/cjs/components/portal/storybook/templates/PortalOrder.js +1 -1
  159. package/cjs/components/portal/storybook/templates/basic.js +1 -1
  160. package/cjs/components/portal/storybook/templates/index.js +1 -1
  161. package/cjs/components/portal/types.js +1 -1
  162. package/cjs/components/portal/usePortal.js +5 -7
  163. package/cjs/components/status/LoadingAnimation/LoadingAnimation.js +1 -1
  164. package/cjs/components/status/LoadingAnimation/index.js +1 -1
  165. package/cjs/components/status/Spin/Cube.js +1 -1
  166. package/cjs/components/status/Spin/InternalSpinner.js +1 -1
  167. package/cjs/components/status/Spin/Spin.js +1 -1
  168. package/cjs/components/status/Spin/SpinsContainer.js +1 -1
  169. package/cjs/components/status/Spin/index.js +1 -1
  170. package/cjs/components/status/Spin/types.js +1 -1
  171. package/cjs/components/status/index.js +1 -1
  172. package/cjs/data/themes.js +1 -1
  173. package/cjs/icons/Attention.js +1 -1
  174. package/cjs/icons/Cross.js +1 -1
  175. package/cjs/icons/Danger.js +1 -1
  176. package/cjs/icons/Success.js +1 -1
  177. package/cjs/icons/index.js +1 -1
  178. package/cjs/index.js +1 -1
  179. package/cjs/provider.js +1 -1
  180. package/cjs/providers/StyleProvider.js +1 -1
  181. package/cjs/services/notification.js +1 -1
  182. package/cjs/shared/form.js +1 -1
  183. package/cjs/shared/index.js +1 -1
  184. package/cjs/stories/FormFieldArgs.js +1 -1
  185. package/cjs/stories/components/ConfirmDeletionDialogForm.js +1 -1
  186. package/cjs/stories/components/DialogFormApp.js +1 -1
  187. package/cjs/stories/components/StyledButton.js +1 -1
  188. package/cjs/stories/lists/baseProps.js +1 -1
  189. package/cjs/styled/index.js +1 -1
  190. package/cjs/styled/styled.js +11 -12
  191. package/cjs/tasty/index.js +1 -1
  192. package/cjs/tasty/providers/BreakpointsProvider.js +1 -1
  193. package/cjs/tasty/styles/align.js +1 -1
  194. package/cjs/tasty/styles/border.js +1 -1
  195. package/cjs/tasty/styles/boxShadow.combinator.js +1 -1
  196. package/cjs/tasty/styles/color.js +1 -1
  197. package/cjs/tasty/styles/createStyle.js +2 -2
  198. package/cjs/tasty/styles/dimension.js +1 -1
  199. package/cjs/tasty/styles/display.js +1 -1
  200. package/cjs/tasty/styles/fill.js +1 -1
  201. package/cjs/tasty/styles/flow.js +1 -1
  202. package/cjs/tasty/styles/font.js +1 -1
  203. package/cjs/tasty/styles/fontStyle.js +1 -1
  204. package/cjs/tasty/styles/gap.js +1 -1
  205. package/cjs/tasty/styles/groupRadius.js +1 -1
  206. package/cjs/tasty/styles/height.js +1 -1
  207. package/cjs/tasty/styles/index.js +1 -1
  208. package/cjs/tasty/styles/justify.js +1 -1
  209. package/cjs/tasty/styles/list.js +1 -1
  210. package/cjs/tasty/styles/margin.js +1 -1
  211. package/cjs/tasty/styles/marginBlock.js +1 -1
  212. package/cjs/tasty/styles/marginInline.js +1 -1
  213. package/cjs/tasty/styles/outline.js +1 -1
  214. package/cjs/tasty/styles/padding.js +1 -1
  215. package/cjs/tasty/styles/paddingBlock.js +1 -1
  216. package/cjs/tasty/styles/paddingInline.js +1 -1
  217. package/cjs/tasty/styles/predefined.js +1 -1
  218. package/cjs/tasty/styles/preset.js +1 -1
  219. package/cjs/tasty/styles/radius.js +1 -1
  220. package/cjs/tasty/styles/reset.js +1 -1
  221. package/cjs/tasty/styles/shadow.js +1 -1
  222. package/cjs/tasty/styles/styledScrollbar.js +1 -1
  223. package/cjs/tasty/styles/transition.js +1 -1
  224. package/cjs/tasty/styles/types.js +1 -1
  225. package/cjs/tasty/styles/width.js +1 -1
  226. package/cjs/tasty/tasty.js +8 -9
  227. package/cjs/tasty/types.js +1 -1
  228. package/cjs/tasty/utils/colors.js +1 -1
  229. package/cjs/tasty/utils/dotize.js +1 -1
  230. package/cjs/tasty/utils/filterBaseProps.js +2 -2
  231. package/cjs/tasty/utils/get-display-name.js +2 -3
  232. package/cjs/tasty/utils/index.js +1 -1
  233. package/cjs/tasty/utils/mergeStyles.js +3 -3
  234. package/cjs/tasty/utils/modAttrs.js +1 -1
  235. package/cjs/tasty/utils/renderStyles.js +1 -1
  236. package/cjs/tasty/utils/responsive.js +1 -1
  237. package/cjs/tasty/utils/string.js +1 -1
  238. package/cjs/tasty/utils/styles.js +6 -3
  239. package/cjs/tasty/utils/warnings.js +1 -1
  240. package/cjs/test/index.js +1 -1
  241. package/cjs/test/render.js +1 -1
  242. package/cjs/test/setup.js +1 -1
  243. package/cjs/test/utils/index.js +1 -1
  244. package/cjs/test/utils/wait.js +1 -1
  245. package/cjs/tokens.js +1 -1
  246. package/cjs/type-checks.js +1 -1
  247. package/cjs/utils/ResizeSensor.js +19 -19
  248. package/cjs/utils/modules.js +1 -1
  249. package/cjs/utils/promise.js +1 -1
  250. package/cjs/utils/random.js +18 -0
  251. package/cjs/utils/range.js +16 -0
  252. package/cjs/utils/react/Slots.js +7 -12
  253. package/cjs/utils/react/chain.js +1 -1
  254. package/cjs/utils/react/index.js +1 -1
  255. package/cjs/utils/react/interactions.js +1 -1
  256. package/cjs/utils/react/isTextOnly.js +1 -1
  257. package/cjs/utils/react/mapProps.js +1 -1
  258. package/cjs/utils/react/mergeProps.js +3 -3
  259. package/cjs/utils/react/nullableValue.js +1 -1
  260. package/cjs/utils/react/useCombinedRefs.js +1 -1
  261. package/cjs/utils/react/useId.js +1 -1
  262. package/cjs/utils/react/useLayoutEffect.js +2 -2
  263. package/cjs/utils/react/wrapNodeIfPlain.js +1 -1
  264. package/cjs/utils/transitions.js +1 -1
  265. package/cjs/utils/tree.js +1 -1
  266. package/cjs/utils/warnings.js +1 -1
  267. package/es/_internal/hooks/index.js +1 -1
  268. package/es/_internal/hooks/use-chained-callback.js +1 -1
  269. package/es/_internal/hooks/use-deprecation-warning.js +1 -1
  270. package/es/_internal/hooks/use-event.js +1 -1
  271. package/es/_internal/hooks/use-sync-ref.js +1 -1
  272. package/es/_internal/hooks/use-timer/index.js +1 -1
  273. package/es/_internal/hooks/use-timer/timer.js +1 -1
  274. package/es/_internal/hooks/use-timer/use-timer.js +7 -7
  275. package/es/_internal/index.js +1 -1
  276. package/es/components/Base.js +2 -2
  277. package/es/components/Block.js +1 -1
  278. package/es/components/GlobalStyles.js +1 -1
  279. package/es/components/GridProvider.js +2 -3
  280. package/es/components/HiddenInput.js +1 -1
  281. package/es/components/OpenTrasition.js +1 -1
  282. package/es/components/Root.js +38 -3
  283. package/es/components/actions/Action.js +2 -2
  284. package/es/components/actions/Button/Button.js +3 -3
  285. package/es/components/actions/Button/Submit.js +1 -1
  286. package/es/components/actions/Button/index.js +1 -1
  287. package/es/components/actions/ButtonGroup/ButtonGroup.js +1 -1
  288. package/es/components/actions/index.js +1 -1
  289. package/es/components/content/ActiveZone/ActiveZone.js +1 -1
  290. package/es/components/content/Alert/Alert.js +1 -1
  291. package/es/components/content/Alert/index.js +1 -1
  292. package/es/components/content/Alert/types.js +1 -1
  293. package/es/components/content/Alert/use-alert.js +2 -3
  294. package/es/components/content/Avatar/Avatar.js +1 -1
  295. package/es/components/content/Badge/Badge.js +1 -1
  296. package/es/components/content/Card/Card.js +1 -1
  297. package/es/components/content/Content.js +1 -1
  298. package/es/components/content/CopySnippet/CopySnippet.js +1 -1
  299. package/es/components/content/CopySnippet/index.js +1 -1
  300. package/es/components/content/Divider.js +1 -1
  301. package/es/components/content/Footer.js +1 -1
  302. package/es/components/content/Header.js +1 -1
  303. package/es/components/content/Paragraph.js +1 -1
  304. package/es/components/content/Placeholder/Placeholder.js +1 -1
  305. package/es/components/content/PrismCode/PrismCode.js +1 -1
  306. package/es/components/content/Result/Result.js +2 -2
  307. package/es/components/content/Skeleton/Skeleton.js +1 -1
  308. package/es/components/content/Tag/Tag.js +1 -1
  309. package/es/components/content/Text.js +1 -1
  310. package/es/components/content/Title.js +1 -1
  311. package/es/components/forms/Checkbox/Checkbox.js +1 -1
  312. package/es/components/forms/Checkbox/CheckboxGroup.js +1 -1
  313. package/es/components/forms/Checkbox/context.js +1 -1
  314. package/es/components/forms/FieldWrapper.js +1 -1
  315. package/es/components/forms/FileInput/FileInput.js +6 -7
  316. package/es/components/forms/Form/Field.js +5 -5
  317. package/es/components/forms/Form/Form.js +19 -19
  318. package/es/components/forms/Form/index.js +1 -1
  319. package/es/components/forms/Form/types.js +1 -1
  320. package/es/components/forms/Form/useForm.js +4 -7
  321. package/es/components/forms/Form/validation.js +2 -2
  322. package/es/components/forms/Input/Input.js +1 -1
  323. package/es/components/forms/Input/index.js +1 -1
  324. package/es/components/forms/Label.js +1 -1
  325. package/es/components/forms/NumberInput/NumberInput.js +1 -1
  326. package/es/components/forms/NumberInput/StepButton.js +1 -1
  327. package/es/components/forms/PasswordInput/PasswordInput.js +1 -1
  328. package/es/components/forms/RadioGroup/Radio.js +1 -1
  329. package/es/components/forms/RadioGroup/RadioGroup.js +1 -1
  330. package/es/components/forms/RadioGroup/context.js +1 -1
  331. package/es/components/forms/SearchInput/SearchInput.js +1 -1
  332. package/es/components/forms/Switch/Switch.js +1 -1
  333. package/es/components/forms/TextArea/TextArea.js +1 -1
  334. package/es/components/forms/TextInput/TextInput.js +1 -1
  335. package/es/components/forms/TextInput/TextInputBase.js +4 -4
  336. package/es/components/forms/index.js +1 -1
  337. package/es/components/layout/Flex.js +1 -1
  338. package/es/components/layout/Flow.js +1 -1
  339. package/es/components/layout/Grid.js +1 -1
  340. package/es/components/layout/Prefix.js +2 -2
  341. package/es/components/layout/Space.js +1 -1
  342. package/es/components/layout/Suffix.js +1 -1
  343. package/es/components/navigation/LegacyTabs/LegacyTabs.js +1 -1
  344. package/es/components/navigation/Link/Link.js +1 -1
  345. package/es/components/organisms/FileTabs/FileTabs.js +1 -1
  346. package/es/components/organisms/Modal/Modal.js +1 -1
  347. package/es/components/organisms/StatsCard/StatsCard.js +1 -1
  348. package/es/components/other/Base64Upload/Base64Upload.js +1 -1
  349. package/es/components/other/CloudLogo/CloudLogo.js +1 -1
  350. package/es/components/overlays/AlertDialog/AlertDialog.js +3 -9
  351. package/es/components/overlays/AlertDialog/AlertDialogApiProvider.js +6 -7
  352. package/es/components/overlays/AlertDialog/AlertDialogZone.js +2 -2
  353. package/es/components/overlays/AlertDialog/index.js +1 -1
  354. package/es/components/overlays/AlertDialog/types.js +1 -1
  355. package/es/components/overlays/Dialog/Dialog.js +1 -1
  356. package/es/components/overlays/Dialog/DialogContainer.js +1 -1
  357. package/es/components/overlays/Dialog/DialogForm.js +7 -7
  358. package/es/components/overlays/Dialog/DialogTrigger.js +1 -1
  359. package/es/components/overlays/Dialog/context.js +1 -1
  360. package/es/components/overlays/Dialog/index.js +1 -1
  361. package/es/components/overlays/Modal/Modal.js +7 -12
  362. package/es/components/overlays/Modal/OpenTransition.js +1 -1
  363. package/es/components/overlays/Modal/Overlay.js +3 -3
  364. package/es/components/overlays/Modal/Popover.js +1 -1
  365. package/es/components/overlays/Modal/Tray.js +4 -35
  366. package/es/components/overlays/Modal/Underlay.js +1 -1
  367. package/es/components/overlays/Modal/index.js +1 -1
  368. package/es/components/overlays/NewNotifications/Bar/FloatingNotification.js +10 -2
  369. package/es/components/overlays/NewNotifications/Bar/NotificationsBar.js +32 -15
  370. package/es/components/overlays/NewNotifications/Bar/TransitionComponent.js +1 -1
  371. package/es/components/overlays/NewNotifications/Bar/index.js +1 -1
  372. package/es/components/overlays/NewNotifications/Dialog/NotificationsDialogTrigger.js +2 -2
  373. package/es/components/overlays/NewNotifications/Dialog/index.js +1 -1
  374. package/es/components/overlays/NewNotifications/Notification.js +6 -3
  375. package/es/components/overlays/NewNotifications/NotificationView/NotificationAction.js +6 -3
  376. package/es/components/overlays/NewNotifications/NotificationView/NotificationCloseButton.js +9 -20
  377. package/es/components/overlays/NewNotifications/NotificationView/NotificationDescription.js +4 -1
  378. package/es/components/overlays/NewNotifications/NotificationView/NotificationFooter.js +5 -3
  379. package/es/components/overlays/NewNotifications/NotificationView/NotificationHeader.js +4 -1
  380. package/es/components/overlays/NewNotifications/NotificationView/NotificationIcon.js +4 -1
  381. package/es/components/overlays/NewNotifications/NotificationView/NotificationProvider.js +4 -1
  382. package/es/components/overlays/NewNotifications/NotificationView/NotificationView.js +14 -11
  383. package/es/components/overlays/NewNotifications/NotificationView/index.js +1 -1
  384. package/es/components/overlays/NewNotifications/NotificationView/types.js +1 -1
  385. package/es/components/overlays/NewNotifications/NotificationsContext/NotificationsProvider.js +3 -3
  386. package/es/components/overlays/NewNotifications/NotificationsContext/index.js +1 -1
  387. package/es/components/overlays/NewNotifications/NotificationsContext/use-notifications.js +18 -16
  388. package/es/components/overlays/NewNotifications/NotificationsList/NotificationsList.js +44 -0
  389. package/es/components/overlays/NewNotifications/NotificationsList/NotificationsListItem.js +29 -0
  390. package/es/components/overlays/NewNotifications/NotificationsList/index.js +10 -0
  391. package/es/components/overlays/NewNotifications/NotificationsList/types.js +10 -0
  392. package/es/components/overlays/NewNotifications/hooks/index.js +1 -1
  393. package/es/components/overlays/NewNotifications/hooks/types.js +1 -1
  394. package/es/components/overlays/NewNotifications/hooks/use-notification-list-item.js +1 -1
  395. package/es/components/overlays/NewNotifications/hooks/use-notifications-api.js +1 -1
  396. package/es/components/overlays/NewNotifications/hooks/use-notifications-list.js +1 -1
  397. package/es/components/overlays/NewNotifications/hooks/use-notifications-observer.js +3 -4
  398. package/es/components/overlays/NewNotifications/index.js +1 -1
  399. package/es/components/overlays/NewNotifications/types.js +1 -1
  400. package/es/components/overlays/Notification/Notification.js +1 -1
  401. package/es/components/overlays/OverlayWrapper.js +1 -1
  402. package/es/components/overlays/Toasts/Toast.js +2 -2
  403. package/es/components/overlays/Toasts/index.js +1 -1
  404. package/es/components/overlays/Toasts/types.js +1 -1
  405. package/es/components/overlays/Toasts/use-toasts-api.js +1 -1
  406. package/es/components/overlays/Tooltip/Tooltip.js +5 -5
  407. package/es/components/overlays/Tooltip/TooltipProvider.js +1 -1
  408. package/es/components/overlays/Tooltip/TooltipTrigger.js +2 -3
  409. package/es/components/overlays/Tooltip/context.js +1 -1
  410. package/es/components/pickers/ComboBox/ComboBox.js +2 -3
  411. package/es/components/pickers/Menu/Menu.js +1 -1
  412. package/es/components/pickers/Menu/MenuButton.js +9 -5
  413. package/es/components/pickers/Menu/MenuItem.js +18 -9
  414. package/es/components/pickers/Menu/MenuSection.js +1 -1
  415. package/es/components/pickers/Menu/MenuTrigger.js +1 -1
  416. package/es/components/pickers/Menu/context.js +1 -1
  417. package/es/components/pickers/Menu/styled.js +1 -1
  418. package/es/components/pickers/Select/Select.js +5 -6
  419. package/es/components/portal/Portal.js +1 -1
  420. package/es/components/portal/PortalProvider.js +1 -1
  421. package/es/components/portal/index.js +1 -1
  422. package/es/components/portal/storybook/templates/CustomRoot.js +1 -1
  423. package/es/components/portal/storybook/templates/PortalOrder.js +1 -1
  424. package/es/components/portal/storybook/templates/basic.js +1 -1
  425. package/es/components/portal/storybook/templates/index.js +1 -1
  426. package/es/components/portal/types.js +1 -1
  427. package/es/components/portal/usePortal.js +5 -7
  428. package/es/components/status/LoadingAnimation/LoadingAnimation.js +1 -1
  429. package/es/components/status/LoadingAnimation/index.js +1 -1
  430. package/es/components/status/Spin/Cube.js +1 -1
  431. package/es/components/status/Spin/InternalSpinner.js +1 -1
  432. package/es/components/status/Spin/Spin.js +1 -1
  433. package/es/components/status/Spin/SpinsContainer.js +1 -1
  434. package/es/components/status/Spin/index.js +1 -1
  435. package/es/components/status/Spin/types.js +1 -1
  436. package/es/components/status/index.js +1 -1
  437. package/es/data/themes.js +1 -1
  438. package/es/icons/Attention.js +1 -1
  439. package/es/icons/Cross.js +1 -1
  440. package/es/icons/Danger.js +1 -1
  441. package/es/icons/Success.js +1 -1
  442. package/es/icons/index.js +1 -1
  443. package/es/index.js +1 -1
  444. package/es/provider.js +1 -1
  445. package/es/providers/StyleProvider.js +1 -1
  446. package/es/services/notification.js +1 -1
  447. package/es/shared/form.js +1 -1
  448. package/es/shared/index.js +1 -1
  449. package/es/stories/FormFieldArgs.js +1 -1
  450. package/es/stories/components/ConfirmDeletionDialogForm.js +1 -1
  451. package/es/stories/components/DialogFormApp.js +1 -1
  452. package/es/stories/components/StyledButton.js +1 -1
  453. package/es/stories/lists/baseProps.js +1 -1
  454. package/es/styled/index.js +1 -1
  455. package/es/styled/styled.js +11 -12
  456. package/es/tasty/index.js +1 -1
  457. package/es/tasty/providers/BreakpointsProvider.js +1 -1
  458. package/es/tasty/styles/align.js +1 -1
  459. package/es/tasty/styles/border.js +1 -1
  460. package/es/tasty/styles/boxShadow.combinator.js +1 -1
  461. package/es/tasty/styles/color.js +1 -1
  462. package/es/tasty/styles/createStyle.js +2 -2
  463. package/es/tasty/styles/dimension.js +1 -1
  464. package/es/tasty/styles/display.js +1 -1
  465. package/es/tasty/styles/fill.js +1 -1
  466. package/es/tasty/styles/flow.js +1 -1
  467. package/es/tasty/styles/font.js +1 -1
  468. package/es/tasty/styles/fontStyle.js +1 -1
  469. package/es/tasty/styles/gap.js +1 -1
  470. package/es/tasty/styles/groupRadius.js +1 -1
  471. package/es/tasty/styles/height.js +1 -1
  472. package/es/tasty/styles/index.js +1 -1
  473. package/es/tasty/styles/justify.js +1 -1
  474. package/es/tasty/styles/list.js +1 -1
  475. package/es/tasty/styles/margin.js +1 -1
  476. package/es/tasty/styles/marginBlock.js +1 -1
  477. package/es/tasty/styles/marginInline.js +1 -1
  478. package/es/tasty/styles/outline.js +1 -1
  479. package/es/tasty/styles/padding.js +1 -1
  480. package/es/tasty/styles/paddingBlock.js +1 -1
  481. package/es/tasty/styles/paddingInline.js +1 -1
  482. package/es/tasty/styles/predefined.js +1 -1
  483. package/es/tasty/styles/preset.js +1 -1
  484. package/es/tasty/styles/radius.js +1 -1
  485. package/es/tasty/styles/reset.js +1 -1
  486. package/es/tasty/styles/shadow.js +1 -1
  487. package/es/tasty/styles/styledScrollbar.js +1 -1
  488. package/es/tasty/styles/transition.js +1 -1
  489. package/es/tasty/styles/types.js +1 -1
  490. package/es/tasty/styles/width.js +1 -1
  491. package/es/tasty/tasty.js +8 -9
  492. package/es/tasty/types.js +1 -1
  493. package/es/tasty/utils/colors.js +1 -1
  494. package/es/tasty/utils/dotize.js +1 -1
  495. package/es/tasty/utils/filterBaseProps.js +2 -2
  496. package/es/tasty/utils/get-display-name.js +2 -3
  497. package/es/tasty/utils/index.js +1 -1
  498. package/es/tasty/utils/mergeStyles.js +3 -3
  499. package/es/tasty/utils/modAttrs.js +1 -1
  500. package/es/tasty/utils/renderStyles.js +1 -1
  501. package/es/tasty/utils/responsive.js +1 -1
  502. package/es/tasty/utils/string.js +1 -1
  503. package/es/tasty/utils/styles.js +6 -3
  504. package/es/tasty/utils/warnings.js +1 -1
  505. package/es/test/index.js +1 -1
  506. package/es/test/render.js +1 -1
  507. package/es/test/setup.js +1 -1
  508. package/es/test/utils/index.js +1 -1
  509. package/es/test/utils/wait.js +1 -1
  510. package/es/tokens.js +1 -1
  511. package/es/type-checks.js +1 -1
  512. package/es/utils/ResizeSensor.js +19 -19
  513. package/es/utils/modules.js +1 -1
  514. package/es/utils/promise.js +1 -1
  515. package/es/utils/random.js +14 -0
  516. package/es/utils/range.js +12 -0
  517. package/es/utils/react/Slots.js +7 -12
  518. package/es/utils/react/chain.js +1 -1
  519. package/es/utils/react/index.js +1 -1
  520. package/es/utils/react/interactions.js +1 -1
  521. package/es/utils/react/isTextOnly.js +1 -1
  522. package/es/utils/react/mapProps.js +1 -1
  523. package/es/utils/react/mergeProps.js +3 -3
  524. package/es/utils/react/nullableValue.js +1 -1
  525. package/es/utils/react/useCombinedRefs.js +1 -1
  526. package/es/utils/react/useId.js +1 -1
  527. package/es/utils/react/useLayoutEffect.js +2 -2
  528. package/es/utils/react/wrapNodeIfPlain.js +1 -1
  529. package/es/utils/transitions.js +1 -1
  530. package/es/utils/tree.js +1 -1
  531. package/es/utils/warnings.js +1 -1
  532. package/package.json +4 -4
  533. package/types/components/forms/Form/Form.d.ts +3 -5
  534. package/types/components/overlays/NewNotifications/Bar/FloatingNotification.d.ts +3 -0
  535. package/types/components/overlays/NewNotifications/Bar/NotificationsBar.d.ts +8 -0
  536. package/types/components/overlays/NewNotifications/Notification.d.ts +3 -0
  537. package/types/components/overlays/NewNotifications/NotificationView/NotificationAction.d.ts +3 -0
  538. package/types/components/overlays/NewNotifications/NotificationView/NotificationCloseButton.d.ts +0 -2
  539. package/types/components/overlays/NewNotifications/NotificationView/NotificationDescription.d.ts +3 -0
  540. package/types/components/overlays/NewNotifications/NotificationView/NotificationFooter.d.ts +3 -0
  541. package/types/components/overlays/NewNotifications/NotificationView/NotificationHeader.d.ts +3 -0
  542. package/types/components/overlays/NewNotifications/NotificationView/NotificationIcon.d.ts +3 -0
  543. package/types/components/overlays/NewNotifications/NotificationView/NotificationProvider.d.ts +3 -0
  544. package/types/components/overlays/NewNotifications/NotificationView/NotificationView.d.ts +3 -0
  545. package/types/components/overlays/NewNotifications/NotificationsContext/use-notifications.d.ts +1 -1
  546. package/types/components/overlays/NewNotifications/NotificationsList/NotificationsList.d.ts +21 -0
  547. package/types/components/overlays/NewNotifications/NotificationsList/NotificationsListItem.d.ts +6 -0
  548. package/types/components/overlays/NewNotifications/NotificationsList/index.d.ts +2 -0
  549. package/types/components/overlays/NewNotifications/{NotificationsList.d.ts → NotificationsList/types.d.ts} +9 -7
  550. package/types/components/pickers/Menu/MenuItem.d.ts +1 -0
  551. package/types/stories/components/StyledButton.d.ts +3 -3
  552. package/types/tasty/utils/styles.d.ts +1 -1
  553. package/types/utils/random.d.ts +1 -0
  554. package/types/utils/range.d.ts +1 -0
  555. package/types/utils/react/interactions.d.ts +1 -2
  556. package/cjs/components/overlays/NewNotifications/NotificationsList.js +0 -43
  557. package/es/components/overlays/NewNotifications/NotificationsList.js +0 -39
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -25,22 +25,21 @@ export function AlertDialogApiProvider(props) {
25
25
  meta: { id: currentId, isClosed: false, isVisible: true },
26
26
  };
27
27
  const close = () => {
28
- var _a;
29
28
  if (currentDialog.meta.isClosed)
30
29
  return;
31
30
  currentDialog.meta.isClosed = true;
32
- (_a = params.cancelToken) === null || _a === void 0 ? void 0 : _a.removeEventListener('abort', close);
33
- setOpenedDialog((currentState) => (currentState === null || currentState === void 0 ? void 0 : currentState.meta.id) !== currentId
31
+ params.cancelToken?.removeEventListener('abort', close);
32
+ setOpenedDialog((currentState) => currentState?.meta.id !== currentId
34
33
  ? currentState
35
34
  : {
36
35
  props: currentState.props,
37
36
  meta: { ...currentState.meta, isVisible: false },
38
37
  });
39
- setTimeout(() => setOpenedDialog((currentState) => (currentState === null || currentState === void 0 ? void 0 : currentState.meta.id) !== currentId ? currentState : null), 300);
38
+ setTimeout(() => setOpenedDialog((currentState) => currentState?.meta.id !== currentId ? currentState : null), 300);
40
39
  };
41
- if (cancelToken === null || cancelToken === void 0 ? void 0 : cancelToken.aborted)
40
+ if (cancelToken?.aborted)
42
41
  return new Promise(() => { });
43
- cancelToken === null || cancelToken === void 0 ? void 0 : cancelToken.addEventListener('abort', close, { once: true });
42
+ cancelToken?.addEventListener('abort', close, { once: true });
44
43
  currentDialog.meta.promise = new Promise((resolve, reject) => {
45
44
  currentDialog.meta.resolve = (status) => {
46
45
  close();
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -33,7 +33,7 @@ export function AlertDialogZone(props) {
33
33
  return {
34
34
  ...action,
35
35
  onPress: (e) => {
36
- onPress === null || onPress === void 0 ? void 0 : onPress(e);
36
+ onPress?.(e);
37
37
  resolve(status);
38
38
  },
39
39
  };
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -24,17 +24,17 @@ export function DialogForm(props) {
24
24
  [form] = useForm(form);
25
25
  const { onClose } = useDialogContext();
26
26
  function onLocalDismiss() {
27
- onClose === null || onClose === void 0 ? void 0 : onClose();
28
- onDismiss === null || onDismiss === void 0 ? void 0 : onDismiss();
27
+ onClose?.();
28
+ onDismiss?.();
29
29
  if (!preserve) {
30
- form === null || form === void 0 ? void 0 : form.resetFields();
30
+ form?.resetFields();
31
31
  }
32
32
  }
33
33
  return (_jsxs(Dialog, { qa: `${qa || ''}Dialog`, size: size, closeIcon: closeIcon, ...dialogProps, children: [_jsx(Header, { children: _jsx(Title, { children: title }, void 0) }, void 0), _jsx(Content, { children: _jsxs(Form, { qa: qa || 'DialogForm', form: form, name: name, defaultValues: defaultValues, labelStyles: labelStyles, labelPosition: labelPosition, requiredMark: requiredMark, isRequired: isRequired, necessityIndicator: necessityIndicator, necessityLabel: necessityLabel, isReadOnly: isReadOnly, validationState: validationState, validateTrigger: validateTrigger, onSubmit: async (data) => {
34
- await (onSubmit === null || onSubmit === void 0 ? void 0 : onSubmit(data));
35
- onClose === null || onClose === void 0 ? void 0 : onClose();
34
+ await onSubmit?.(data);
35
+ onClose?.();
36
36
  if (!preserve) {
37
- form === null || form === void 0 ? void 0 : form.resetFields();
37
+ form?.resetFields();
38
38
  }
39
39
  }, onSubmitFailed: onSubmitFailed, onValuesChange: onValuesChange, children: [typeof children === 'function' ? children(onLocalDismiss) : children, !noActions ? (_jsxs(ButtonGroup, { children: [_jsx(Submit, { qa: `${qa || ''}SubmitButton`, theme: danger ? 'danger' : undefined, label: "Submit", ...(submitProps || {}) }, void 0), _jsx(Button, { qa: `${qa || ''}CancelButton`, label: "Cancel", onPress: onLocalDismiss, ...(cancelProps || {}) }, void 0)] }, void 0)) : undefined] }, void 0) }, void 0)] }, void 0));
40
40
  }
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,13 +1,12 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
8
8
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
9
9
  import { useDOMRef } from '@react-spectrum/utils';
10
- import { useViewportSize } from '@react-aria/utils';
11
10
  import { forwardRef } from 'react';
12
11
  import { useModal, useOverlay, usePreventScroll } from '@react-aria/overlays';
13
12
  import { tasty } from '../../../tasty';
@@ -26,7 +25,7 @@ export const OVERLAY_WRAPPER_STYLES = {
26
25
  },
27
26
  boxSizing: 'border-box',
28
27
  width: '100vw',
29
- height: '@cube-visual-viewport-height',
28
+ height: '100dvh',
30
29
  pointerEvents: 'none',
31
30
  zIndex: 2,
32
31
  transition: 'visibility 0ms linear .13s',
@@ -40,10 +39,10 @@ const ModalElement = tasty({
40
39
  display: 'grid',
41
40
  zIndex: 2,
42
41
  height: {
43
- '': 'max (@cube-visual-viewport-height * .9)',
44
- '[data-type="fullscreenTakeover"] | [data-type="panel"]': '@cube-visual-viewport-height @cube-visual-viewport-height',
45
- '[data-type="fullscreen"]': '(@cube-visual-viewport-height * .9) (@cube-visual-viewport-height * .9)',
46
- '[data-type="fullscreenTakeover"]': '@cube-visual-viewport-height @cube-visual-viewport-height',
42
+ '': 'max 90dvh',
43
+ '[data-type="fullscreenTakeover"] | [data-type="panel"]': '100dvh 100dvh',
44
+ '[data-type="fullscreen"]': '90dvh 90dvh',
45
+ '[data-type="fullscreenTakeover"]': '100dvh 100dvh',
47
46
  },
48
47
  width: {
49
48
  width: '288px 90vw',
@@ -71,11 +70,7 @@ let ModalWrapper = forwardRef(function ModalWrapper(props, ref) {
71
70
  let { qa, children, isOpen, type, placement, styles, overlayProps, ...otherProps } = props;
72
71
  usePreventScroll();
73
72
  let { modalProps } = useModal();
74
- let viewport = useViewportSize();
75
- let style = {
76
- '--cube-visual-viewport-height': viewport.height + 'px',
77
- };
78
- return (_jsx(ModalWrapperElement, { mods: { open: isOpen }, "data-type": type, "data-placement": placement, style: style, children: _jsx(ModalElement, { qa: qa || 'Modal', styles: styles, mods: { open: isOpen }, "data-type": type, "data-placement": placement, ...mergeProps(otherProps, overlayProps, modalProps), ref: ref, children: children }, void 0) }, void 0));
73
+ return (_jsx(ModalWrapperElement, { mods: { open: isOpen }, "data-type": type, "data-placement": placement, children: _jsx(ModalElement, { qa: qa || 'Modal', styles: styles, mods: { open: isOpen }, "data-type": type, "data-placement": placement, ...mergeProps(otherProps, overlayProps, modalProps), ref: ref, children: children }, void 0) }, void 0));
79
74
  });
80
75
  let _Modal = forwardRef(Modal);
81
76
  export { _Modal as Modal };
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -16,11 +16,11 @@ function Overlay(props, ref) {
16
16
  let { root } = useProviderProps({});
17
17
  let handleEntered = useCallback(() => {
18
18
  setExited(false);
19
- onEntered === null || onEntered === void 0 ? void 0 : onEntered();
19
+ onEntered?.();
20
20
  }, [onEntered]);
21
21
  let handleExited = useCallback(() => {
22
22
  setExited(true);
23
- onExited === null || onExited === void 0 ? void 0 : onExited();
23
+ onExited?.();
24
24
  }, [onExited]);
25
25
  // Don't un-render the overlay while it's transitioning out.
26
26
  let mountOverlay = isOpen || !exited;
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,14 +1,13 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
8
8
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
9
9
  import { useDOMRef } from '@react-spectrum/utils';
10
- import { useViewportSize } from '@react-aria/utils';
11
- import { forwardRef, useEffect, useRef, useState } from 'react';
10
+ import { forwardRef } from 'react';
12
11
  import { useModal, useOverlay, usePreventScroll } from '@react-aria/overlays';
13
12
  import { tasty } from '../../../tasty';
14
13
  import { mergeProps } from '../../../utils/react';
@@ -26,7 +25,7 @@ const TrayWrapperElement = tasty({
26
25
  const TrayElement = tasty({
27
26
  styles: {
28
27
  zIndex: 2,
29
- height: 'max (@cube-visual-viewport-height * .9)',
28
+ height: 'max 90dvh',
30
29
  width: '288px 90vw',
31
30
  pointerEvents: 'auto',
32
31
  transition: 'transform .25s ease-in-out, opacity .25s linear, visibility 0ms linear',
@@ -48,40 +47,10 @@ let TrayWrapper = forwardRef(function TrayWrapper(props, ref) {
48
47
  let { modalProps } = useModal({
49
48
  isDisabled: isNonModal,
50
49
  });
51
- // We need to measure the window's height in JS rather than using percentages in CSS
52
- // so that contents (e.g. menu) can inherit the max-height properly. Using percentages
53
- // does not work properly because there is nothing to base the percentage on.
54
- // We cannot use vh units because mobile browsers adjust the window height dynamically
55
- // when the address bar/bottom toolbars show and hide on scroll and vh units are fixed.
56
- // Also, the visual viewport is smaller than the layout viewport when the virtual keyboard
57
- // is up, so use the VisualViewport API to ensure the tray is displayed above the keyboard.
58
- let viewport = useViewportSize();
59
- let [height, setHeight] = useState(viewport.height);
60
- let timeoutRef = useRef();
61
- useEffect(() => {
62
- if (timeoutRef.current) {
63
- clearTimeout(timeoutRef.current);
64
- }
65
- // When the height is decreasing, and the keyboard is visible
66
- // (visual viewport smaller than layout viewport), delay setting
67
- // the new max height until after the animation is complete
68
- // so that there isn't an empty space under the tray briefly.
69
- if (viewport.height < height && viewport.height < window.innerHeight) {
70
- timeoutRef.current = setTimeout(() => {
71
- setHeight(viewport.height);
72
- }, 500);
73
- }
74
- else {
75
- setHeight(viewport.height);
76
- }
77
- }, [height, viewport.height]);
78
- let wrapperStyle = {
79
- '--cube-visual-viewport-height': height + 'px',
80
- };
81
50
  let domProps = mergeProps(otherProps, overlayProps);
82
51
  return (_jsx(TrayWrapperElement, { mods: {
83
52
  open: isOpen,
84
- }, style: wrapperStyle, children: _jsx(TrayElement, { qa: qa || 'Tray', styles: styles, mods: {
53
+ }, children: _jsx(TrayElement, { qa: qa || 'Tray', styles: styles, mods: {
85
54
  open: isOpen,
86
55
  'fixed-height': isFixedHeight,
87
56
  }, ...domProps, ...modalProps, ref: ref, children: children }, void 0) }, void 0));
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -12,8 +12,16 @@ import { tasty } from '../../../../tasty';
12
12
  import { NotificationView } from '../NotificationView';
13
13
  import { useNotificationListItem, } from '../hooks';
14
14
  const NotificationContainer = tasty({
15
- styles: { boxShadow: '0 0.5x 2x #shadow', pointerEvents: 'auto' },
15
+ styles: {
16
+ overflow: 'hidden',
17
+ radius: '0.5x',
18
+ boxShadow: '0 0.5x 2x #shadow',
19
+ pointerEvents: 'auto',
20
+ },
16
21
  });
22
+ /**
23
+ * @internal This component is unstable and must not be used outside of `NotificationsBar`.
24
+ */
17
25
  export const FloatingNotification = memo(function FloatingNotification(props) {
18
26
  const { item, state, onRemoveNotification, id, isDisabledTimer, onDismissNotification, } = props;
19
27
  const { props: notificationProps, key } = item;
@@ -1,12 +1,12 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
8
8
  import { jsx as _jsx } from "react/jsx-runtime";
9
- import { useRef } from 'react';
9
+ import { useLayoutEffect, useRef, useState } from 'react';
10
10
  import { TransitionGroup } from 'react-transition-group';
11
11
  import { Item } from '@react-stately/collections';
12
12
  import { useHover } from '@react-aria/interactions';
@@ -14,7 +14,7 @@ import { useFocusRing, focusSafely } from '@react-aria/focus';
14
14
  import { tasty } from '../../../../tasty';
15
15
  import { useNotificationsList } from '../hooks';
16
16
  import { mergeProps } from '../../../../utils/react';
17
- import { useEvent } from '../../../../_internal';
17
+ import { useChainedCallback, useEvent } from '../../../../_internal';
18
18
  import { FloatingNotification } from './FloatingNotification';
19
19
  import { TransitionComponent } from './TransitionComponent';
20
20
  const NotificationsContainer = tasty({
@@ -26,7 +26,7 @@ const NotificationsContainer = tasty({
26
26
  display: 'flex',
27
27
  flexDirection: 'column-reverse',
28
28
  width: 'auto 100% 50x',
29
- height: '100vh max',
29
+ height: '100dvh max',
30
30
  padding: '2x',
31
31
  gap: '1x',
32
32
  /* to be sure that we're over the legacy modal and any widget as well */
@@ -34,29 +34,46 @@ const NotificationsContainer = tasty({
34
34
  overflow: 'hidden',
35
35
  isolation: 'isolate',
36
36
  pointerEvents: 'none',
37
- '@supports (-webkit-touch-callout: none)': {
38
- height: '-webkit-fill-available max',
39
- },
40
37
  },
41
38
  });
39
+ /**
40
+ * @internal Do not use it
41
+ */
42
42
  export function NotificationsBar(props) {
43
- const { items, children, onRemoveNotification, onDismissNotification } = props;
43
+ const { items, children, onRemoveNotification, onDismissNotification, limit = 5, } = props;
44
44
  const ref = useRef(null);
45
+ const [realLimit, setRealLimit] = useState(limit + 1);
45
46
  const { listProps, state } = useNotificationsList({ items, children, ref });
46
47
  const { hoverProps, isHovered } = useHover({});
47
48
  const { focusProps, isFocusVisible } = useFocusRing({ within: true });
48
49
  const moveFocus = useEvent((key) => {
49
- var _a, _b, _c;
50
- const nextKey = (_b = (_a = state.collection.getKeyBefore(key.toString())) !== null && _a !== void 0 ? _a : state.collection.getKeyAfter(key.toString())) !== null && _b !== void 0 ? _b : state.collection.getLastKey();
51
- const elementToFocus = (_c = ref.current) === null || _c === void 0 ? void 0 : _c.querySelector(`[data-id="${nextKey}"]`);
50
+ const nextKey = state.collection.getKeyBefore(key.toString()) ??
51
+ state.collection.getKeyAfter(key.toString()) ??
52
+ state.collection.getLastKey();
53
+ const elementToFocus = ref.current?.querySelector(`[data-id="${nextKey}"]`);
52
54
  if (elementToFocus) {
53
55
  focusSafely(elementToFocus);
54
56
  }
55
57
  });
56
- return (_jsx(NotificationsContainer, { ref: ref, qa: "NotificationsBar", role: "region", "aria-live": "polite", ...mergeProps(listProps, hoverProps, focusProps), children: _jsx(TransitionGroup, { enter: true, exit: true, component: null, children: [...state.collection].reverse().map((notification) => (_jsx(TransitionComponent, { children: _jsx(FloatingNotification, { isDisabledTimer: isHovered || isFocusVisible, id: notification.props.id, item: notification, state: state, onRemoveNotification: (key) => {
57
- onRemoveNotification(key);
58
- moveFocus(key);
59
- }, onDismissNotification: onDismissNotification }, void 0) }, notification.props.id))) }, void 0) }, void 0));
58
+ const chainedOnRemoveNotification = useChainedCallback(onRemoveNotification, moveFocus);
59
+ const collection = [...state.collection].reverse();
60
+ const collectionLength = collection.length;
61
+ /**
62
+ * Handy hack to improve animations if the limit is reached.
63
+ */
64
+ useLayoutEffect(() => {
65
+ setRealLimit(limit + 1);
66
+ }, [collectionLength]);
67
+ useLayoutEffect(() => {
68
+ if (realLimit > limit) {
69
+ setRealLimit(limit);
70
+ }
71
+ }, [realLimit]);
72
+ // Auto-dismiss all notifications that are off the limit.
73
+ collection
74
+ .slice(realLimit)
75
+ .forEach((notification) => chainedOnRemoveNotification(notification.props.id));
76
+ return (_jsx(NotificationsContainer, { ref: ref, qa: "NotificationsBar", role: "region", "aria-live": "polite", ...mergeProps(listProps, hoverProps, focusProps), children: _jsx(TransitionGroup, { enter: true, exit: true, component: null, children: collection.slice(0, realLimit).map((notification) => (_jsx(TransitionComponent, { children: _jsx(FloatingNotification, { isDisabledTimer: isHovered || isFocusVisible, id: notification.props.id, item: notification, state: state, onRemoveNotification: chainedOnRemoveNotification, onDismissNotification: onDismissNotification }, void 0) }, notification.props.id))) }, void 0) }, void 0));
60
77
  }
61
78
  NotificationsBar.Item = Item;
62
79
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -15,7 +15,7 @@ import { ClearSlots } from '../../../../utils/react';
15
15
  import { useNotificationsObserver } from '../hooks';
16
16
  export function NotificationsDialogTrigger(props) {
17
17
  const { onCloseNotificationInBar, ...dialogTriggerProps } = props;
18
- useNotificationsObserver((args) => onCloseNotificationInBar === null || onCloseNotificationInBar === void 0 ? void 0 : onCloseNotificationInBar(args));
18
+ useNotificationsObserver((args) => onCloseNotificationInBar?.(args));
19
19
  return _jsx(DialogTrigger, { ...dialogTriggerProps, type: "popover" }, void 0);
20
20
  }
21
21
  const StyledDialog = tasty(Dialog, { height: 'auto calc(100vh - 12x)' });
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -10,17 +10,20 @@ import { useEffect } from 'react';
10
10
  import { useEvent, useSyncRef } from '../../../_internal';
11
11
  import { useId } from '../../../utils/react/useId';
12
12
  import { useNotificationsApi } from './hooks';
13
+ /**
14
+ * Declarative wrap over the `useNotificationsApi` hook
15
+ */
13
16
  export function Notification(props) {
14
17
  const { id: propsId, disableRemoveOnUnmount = false } = props;
15
18
  const defaultId = useId();
16
19
  const disableRemoveOnUnmountRef = useSyncRef(disableRemoveOnUnmount);
17
20
  const { notify, update, remove } = useNotificationsApi();
18
- const id = propsId !== null && propsId !== void 0 ? propsId : defaultId;
21
+ const id = propsId ?? defaultId;
19
22
  const removeNotification = useEvent((id) => disableRemoveOnUnmountRef.current ? void 0 : remove(id));
20
23
  useEffect(() => {
21
24
  notify({ id, ...props });
22
25
  }, [id]);
23
- useEffect(() => () => removeNotification(id), [id]);
26
+ useEffect(() => () => removeNotification(id), [id, removeNotification]);
24
27
  useEffect(() => update(id, props));
25
28
  return null;
26
29
  }
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -23,13 +23,16 @@ const Action = tasty(Button, {
23
23
  },
24
24
  },
25
25
  });
26
+ /**
27
+ * @internal This component is unstable and must not be used outside of `NotificationView`.
28
+ */
26
29
  export function NotificationAction(props) {
27
30
  const { children, onPress, type = 'primary', disableCloseOnAction = type !== 'primary', ...buttonProps } = props;
28
31
  const { onClose } = useNotificationContext();
29
32
  const onPressEvent = useEvent((e) => {
30
- onPress === null || onPress === void 0 ? void 0 : onPress(e);
33
+ onPress?.(e);
31
34
  if (!disableCloseOnAction) {
32
- onClose === null || onClose === void 0 ? void 0 : onClose();
35
+ onClose?.();
33
36
  }
34
37
  });
35
38
  return (_jsx(Action, { ...buttonProps, type: "link", size: "small", mods: { primary: type === 'primary', secondary: type === 'secondary' }, onPress: onPressEvent, children: children }, void 0));
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -11,27 +11,16 @@ import { Button } from '../../../actions';
11
11
  import { tasty } from '../../../../tasty';
12
12
  import { Cross } from '../../../../icons';
13
13
  const CloseButton = tasty(Button, {
14
- styles: {
15
- position: 'absolute',
16
- right: '-0.75x',
17
- top: '-0.75x',
18
- display: 'flex',
19
- placeItems: 'center',
20
- padding: '0.625x',
21
- width: '3x',
22
- height: '3x',
23
- fill: '#white',
24
- shadow: '0 0.5x 2x #shadow',
25
- color: { '': '#dark-02', hovered: '#dark-03', pressed: '#dark-02' },
26
- borderRadius: '50%',
27
- visibility: { '': 'hidden', show: 'visible' },
28
- opacity: { '': '0', show: '1' },
29
- transition: 'opacity, visibility 0.2s ease-in-out',
30
- },
14
+ icon: _jsx(Cross, {}, void 0),
15
+ label: 'Close the notification',
16
+ qa: 'NotificationCloseButton',
17
+ type: 'neutral',
18
+ size: 'small',
19
+ styles: { gridArea: 'close', display: 'flex', padding: '1x' },
31
20
  });
32
21
  export const NotificationCloseButton = memo(function NotificationCloseButton(props) {
33
- const { onPress, isHovered, isFocused } = props;
34
- return (_jsx(CloseButton, { qa: "NotificationCloseButton", type: "neutral", mods: { show: isHovered || isFocused }, icon: _jsx(Cross, {}, void 0), label: "Close the notification", onPress: onPress }, void 0));
22
+ const { onPress } = props;
23
+ return _jsx(CloseButton, { onPress: onPress }, void 0);
35
24
  });
36
25
 
37
26
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.12.6
4
+ * @cube-dev/ui-kit v0.13.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -21,6 +21,9 @@ const Description = tasty(Paragraph, {
21
21
  overflow: 'hidden',
22
22
  },
23
23
  });
24
+ /**
25
+ * @internal This component is unstable and must not be used outside of `NotificationView`.
26
+ */
24
27
  export const NotificationDescription = memo(function NotificationDescription(props) {
25
28
  const { description, ...descriptionProps } = props;
26
29
  return (_jsx(Description, { ...mergeProps(descriptionProps, {