@vkontakte/vkui 6.1.2 → 6.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1986) hide show
  1. package/dist/cjs/components/Accordion/Accordion.js.map +1 -1
  2. package/dist/cjs/components/Accordion/AccordionContent.d.ts.map +1 -1
  3. package/dist/cjs/components/Accordion/AccordionContent.js +35 -39
  4. package/dist/cjs/components/Accordion/AccordionContent.js.map +1 -1
  5. package/dist/cjs/components/Accordion/AccordionContext.js.map +1 -1
  6. package/dist/cjs/components/Accordion/AccordionSummary.js.map +1 -1
  7. package/dist/cjs/components/ActionSheet/ActionSheet.d.ts +1 -1
  8. package/dist/cjs/components/ActionSheet/ActionSheet.d.ts.map +1 -1
  9. package/dist/cjs/components/ActionSheet/ActionSheet.js +24 -32
  10. package/dist/cjs/components/ActionSheet/ActionSheet.js.map +1 -1
  11. package/dist/cjs/components/ActionSheet/ActionSheetContext.js.map +1 -1
  12. package/dist/cjs/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -1
  13. package/dist/cjs/components/ActionSheet/ActionSheetDropdownMenu.d.ts +1 -1
  14. package/dist/cjs/components/ActionSheet/ActionSheetDropdownMenu.d.ts.map +1 -1
  15. package/dist/cjs/components/ActionSheet/ActionSheetDropdownMenu.js +7 -3
  16. package/dist/cjs/components/ActionSheet/ActionSheetDropdownMenu.js.map +1 -1
  17. package/dist/cjs/components/ActionSheet/ActionSheetDropdownSheet.js +1 -1
  18. package/dist/cjs/components/ActionSheet/ActionSheetDropdownSheet.js.map +1 -1
  19. package/dist/cjs/components/ActionSheet/types.js.map +1 -1
  20. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  21. package/dist/cjs/components/ActionSheetItem/subcomponents/Radio/Radio.js.map +1 -1
  22. package/dist/cjs/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -1
  23. package/dist/cjs/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  24. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  25. package/dist/cjs/components/Alert/Alert.d.ts.map +1 -1
  26. package/dist/cjs/components/Alert/Alert.js +22 -33
  27. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  28. package/dist/cjs/components/Alert/AlertAction.js.map +1 -1
  29. package/dist/cjs/components/Alert/AlertActions.js.map +1 -1
  30. package/dist/cjs/components/Alert/AlertTypography.js.map +1 -1
  31. package/dist/cjs/components/AppRoot/AppRoot.d.ts +14 -2
  32. package/dist/cjs/components/AppRoot/AppRoot.d.ts.map +1 -1
  33. package/dist/cjs/components/AppRoot/AppRoot.js +11 -3
  34. package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
  35. package/dist/cjs/components/AppRoot/AppRootContext.js.map +1 -1
  36. package/dist/cjs/components/AppRoot/AppRootPortal.js.map +1 -1
  37. package/dist/cjs/components/AppRoot/ScrollContext.d.ts.map +1 -1
  38. package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
  39. package/dist/cjs/components/AppRoot/helpers.d.ts +6 -1
  40. package/dist/cjs/components/AppRoot/helpers.d.ts.map +1 -1
  41. package/dist/cjs/components/AppRoot/helpers.js +24 -0
  42. package/dist/cjs/components/AppRoot/helpers.js.map +1 -1
  43. package/dist/cjs/components/AppRoot/types.d.ts +1 -0
  44. package/dist/cjs/components/AppRoot/types.d.ts.map +1 -1
  45. package/dist/cjs/components/AppRoot/types.js.map +1 -1
  46. package/dist/cjs/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  47. package/dist/cjs/components/AspectRatio/AspectRatio.js.map +1 -1
  48. package/dist/cjs/components/Avatar/Avatar.d.ts +1 -1
  49. package/dist/cjs/components/Avatar/Avatar.js.map +1 -1
  50. package/dist/cjs/components/Avatar/AvatarBadge/AvatarBadge.js.map +1 -1
  51. package/dist/cjs/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  52. package/dist/cjs/components/Avatar/AvatarBadge/icons.d.ts.map +1 -1
  53. package/dist/cjs/components/Avatar/AvatarBadge/icons.js.map +1 -1
  54. package/dist/cjs/components/Avatar/helpers.js.map +1 -1
  55. package/dist/cjs/components/Badge/Badge.js.map +1 -1
  56. package/dist/cjs/components/Banner/Banner.js.map +1 -1
  57. package/dist/cjs/components/BaseGallery/BaseGallery.js.map +1 -1
  58. package/dist/cjs/components/BaseGallery/CarouselBase/CarouselBase.js.map +1 -1
  59. package/dist/cjs/components/BaseGallery/CarouselBase/constants.js.map +1 -1
  60. package/dist/cjs/components/BaseGallery/CarouselBase/helpers.js.map +1 -1
  61. package/dist/cjs/components/BaseGallery/CarouselBase/hooks.js.map +1 -1
  62. package/dist/cjs/components/BaseGallery/CarouselBase/types.js.map +1 -1
  63. package/dist/cjs/components/BaseGallery/helpers.js.map +1 -1
  64. package/dist/cjs/components/BaseGallery/types.js.map +1 -1
  65. package/dist/cjs/components/Button/Button.js.map +1 -1
  66. package/dist/cjs/components/ButtonGroup/ButtonGroup.js.map +1 -1
  67. package/dist/cjs/components/Calendar/Calendar.d.ts.map +1 -1
  68. package/dist/cjs/components/Calendar/Calendar.js +4 -2
  69. package/dist/cjs/components/Calendar/Calendar.js.map +1 -1
  70. package/dist/cjs/components/CalendarDay/CalendarDay.js.map +1 -1
  71. package/dist/cjs/components/CalendarDays/CalendarDays.js.map +1 -1
  72. package/dist/cjs/components/CalendarHeader/CalendarHeader.d.ts +3 -1
  73. package/dist/cjs/components/CalendarHeader/CalendarHeader.d.ts.map +1 -1
  74. package/dist/cjs/components/CalendarHeader/CalendarHeader.js +23 -10
  75. package/dist/cjs/components/CalendarHeader/CalendarHeader.js.map +1 -1
  76. package/dist/cjs/components/CalendarRange/CalendarRange.d.ts.map +1 -1
  77. package/dist/cjs/components/CalendarRange/CalendarRange.js +11 -4
  78. package/dist/cjs/components/CalendarRange/CalendarRange.js.map +1 -1
  79. package/dist/cjs/components/CalendarTime/CalendarTime.js.map +1 -1
  80. package/dist/cjs/components/Card/Card.js.map +1 -1
  81. package/dist/cjs/components/CardGrid/CardGrid.js.map +1 -1
  82. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  83. package/dist/cjs/components/Cell/Cell.js.map +1 -1
  84. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  85. package/dist/cjs/components/Cell/CellDragger/CellDragger.js.map +1 -1
  86. package/dist/cjs/components/Cell/constants.js.map +1 -1
  87. package/dist/cjs/components/CellButton/CellButton.js.map +1 -1
  88. package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
  89. package/dist/cjs/components/ChipsInput/ChipsInput.d.ts.map +1 -1
  90. package/dist/cjs/components/ChipsInput/ChipsInput.js.map +1 -1
  91. package/dist/cjs/components/ChipsInput/useChipsInput.d.ts.map +1 -1
  92. package/dist/cjs/components/ChipsInput/useChipsInput.js.map +1 -1
  93. package/dist/cjs/components/ChipsInputBase/Chip/Chip.js.map +1 -1
  94. package/dist/cjs/components/ChipsInputBase/ChipsInputBase.d.ts.map +1 -1
  95. package/dist/cjs/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
  96. package/dist/cjs/components/ChipsInputBase/constants.js.map +1 -1
  97. package/dist/cjs/components/ChipsInputBase/helpers.d.ts.map +1 -1
  98. package/dist/cjs/components/ChipsInputBase/helpers.js.map +1 -1
  99. package/dist/cjs/components/ChipsInputBase/types.js.map +1 -1
  100. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts +5 -1
  101. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts.map +1 -1
  102. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +15 -8
  103. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  104. package/dist/cjs/components/ChipsSelect/constants.d.ts.map +1 -1
  105. package/dist/cjs/components/ChipsSelect/constants.js.map +1 -1
  106. package/dist/cjs/components/ChipsSelect/types.js.map +1 -1
  107. package/dist/cjs/components/ChipsSelect/useChipsSelect.d.ts +10 -2
  108. package/dist/cjs/components/ChipsSelect/useChipsSelect.d.ts.map +1 -1
  109. package/dist/cjs/components/ChipsSelect/useChipsSelect.js +12 -4
  110. package/dist/cjs/components/ChipsSelect/useChipsSelect.js.map +1 -1
  111. package/dist/cjs/components/Clickable/Clickable.d.ts.map +1 -1
  112. package/dist/cjs/components/Clickable/Clickable.js.map +1 -1
  113. package/dist/cjs/components/Clickable/useKeyboard.d.ts.map +1 -1
  114. package/dist/cjs/components/Clickable/useKeyboard.js.map +1 -1
  115. package/dist/cjs/components/Clickable/useState.d.ts.map +1 -1
  116. package/dist/cjs/components/Clickable/useState.js.map +1 -1
  117. package/dist/cjs/components/Clickable/useStateWithDelay.js.map +1 -1
  118. package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
  119. package/dist/cjs/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  120. package/dist/cjs/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  121. package/dist/cjs/components/ContentBadge/ContentBadge.js.map +1 -1
  122. package/dist/cjs/components/ContentBadge/ContentBadgeContext.js.map +1 -1
  123. package/dist/cjs/components/ContentBadge/ContentBadgeSlotIcon.js.map +1 -1
  124. package/dist/cjs/components/ContentBadge/types.js.map +1 -1
  125. package/dist/cjs/components/ContentCard/ContentCard.js.map +1 -1
  126. package/dist/cjs/components/Counter/Counter.js.map +1 -1
  127. package/dist/cjs/components/CustomScrollView/CustomScrollView.js.map +1 -1
  128. package/dist/cjs/components/CustomScrollView/useTrackerVisibility.d.ts.map +1 -1
  129. package/dist/cjs/components/CustomScrollView/useTrackerVisibility.js +31 -37
  130. package/dist/cjs/components/CustomScrollView/useTrackerVisibility.js.map +1 -1
  131. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +5 -2
  132. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts.map +1 -1
  133. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  134. package/dist/cjs/components/CustomSelect/CustomSelectClearButton.js.map +1 -1
  135. package/dist/cjs/components/CustomSelect/CustomSelectInput.js.map +1 -1
  136. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  137. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  138. package/dist/cjs/components/DateInput/DateInput.js.map +1 -1
  139. package/dist/cjs/components/DatePicker/DatePicker.d.ts +6 -0
  140. package/dist/cjs/components/DatePicker/DatePicker.d.ts.map +1 -1
  141. package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
  142. package/dist/cjs/components/DateRangeInput/DateRangeInput.js.map +1 -1
  143. package/dist/cjs/components/Div/Div.js.map +1 -1
  144. package/dist/cjs/components/DropZone/DropZone.js.map +1 -1
  145. package/dist/cjs/components/DropZone/components/DropZoneGrid.js.map +1 -1
  146. package/dist/cjs/components/DropdownIcon/DropdownIcon.js.map +1 -1
  147. package/dist/cjs/components/Epic/Epic.js.map +1 -1
  148. package/dist/cjs/components/Epic/ScrollSaver.js.map +1 -1
  149. package/dist/cjs/components/File/File.js.map +1 -1
  150. package/dist/cjs/components/FixedLayout/FixedLayout.d.ts.map +1 -1
  151. package/dist/cjs/components/FixedLayout/FixedLayout.js +18 -6
  152. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  153. package/dist/cjs/components/Flex/Flex.d.ts +42 -0
  154. package/dist/cjs/components/Flex/Flex.d.ts.map +1 -0
  155. package/dist/cjs/components/Flex/Flex.js +60 -0
  156. package/dist/cjs/components/Flex/Flex.js.map +1 -0
  157. package/dist/cjs/components/Flex/FlexItem/FlexItem.d.ts +20 -0
  158. package/dist/cjs/components/Flex/FlexItem/FlexItem.d.ts.map +1 -0
  159. package/dist/cjs/components/Flex/FlexItem/FlexItem.js +47 -0
  160. package/dist/cjs/components/Flex/FlexItem/FlexItem.js.map +1 -0
  161. package/dist/cjs/components/FloatingArrow/DefaultIcon.d.ts.map +1 -1
  162. package/dist/cjs/components/FloatingArrow/DefaultIcon.js.map +1 -1
  163. package/dist/cjs/components/FloatingArrow/FloatingArrow.js +14 -4
  164. package/dist/cjs/components/FloatingArrow/FloatingArrow.js.map +1 -1
  165. package/dist/cjs/components/FocusTrap/FocusTrap.d.ts +6 -1
  166. package/dist/cjs/components/FocusTrap/FocusTrap.d.ts.map +1 -1
  167. package/dist/cjs/components/FocusTrap/FocusTrap.js +44 -19
  168. package/dist/cjs/components/FocusTrap/FocusTrap.js.map +1 -1
  169. package/dist/cjs/components/Footer/Footer.js.map +1 -1
  170. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  171. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  172. package/dist/cjs/components/FormItem/FormItemTop/FormItemTop.js.map +1 -1
  173. package/dist/cjs/components/FormItem/FormItemTop/FormItemTopAside.js.map +1 -1
  174. package/dist/cjs/components/FormItem/FormItemTop/FormItemTopLabel.js.map +1 -1
  175. package/dist/cjs/components/FormItem/context.js.map +1 -1
  176. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  177. package/dist/cjs/components/FormStatus/FormStatus.js.map +1 -1
  178. package/dist/cjs/components/Gallery/Gallery.js.map +1 -1
  179. package/dist/cjs/components/Gallery/hooks.d.ts +1 -1
  180. package/dist/cjs/components/Gallery/hooks.d.ts.map +1 -1
  181. package/dist/cjs/components/Gallery/hooks.js +24 -21
  182. package/dist/cjs/components/Gallery/hooks.js.map +1 -1
  183. package/dist/cjs/components/Gradient/Gradient.js.map +1 -1
  184. package/dist/cjs/components/GridAvatar/GridAvatar.d.ts +1 -1
  185. package/dist/cjs/components/GridAvatar/GridAvatar.js.map +1 -1
  186. package/dist/cjs/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.js.map +1 -1
  187. package/dist/cjs/components/Group/Group.js.map +1 -1
  188. package/dist/cjs/components/Header/Header.js.map +1 -1
  189. package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
  190. package/dist/cjs/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.js.map +1 -1
  191. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  192. package/dist/cjs/components/IconButton/IconButton.js.map +1 -1
  193. package/dist/cjs/components/Image/Image.d.ts +1 -1
  194. package/dist/cjs/components/Image/Image.js.map +1 -1
  195. package/dist/cjs/components/Image/ImageBadge/ImageBadge.js.map +1 -1
  196. package/dist/cjs/components/ImageBase/ImageBase.js.map +1 -1
  197. package/dist/cjs/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
  198. package/dist/cjs/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  199. package/dist/cjs/components/ImageBase/context.js.map +1 -1
  200. package/dist/cjs/components/ImageBase/helpers.js.map +1 -1
  201. package/dist/cjs/components/ImageBase/types.js.map +1 -1
  202. package/dist/cjs/components/ImageBase/validators.js.map +1 -1
  203. package/dist/cjs/components/InfoRow/InfoRow.js.map +1 -1
  204. package/dist/cjs/components/Input/Input.js.map +1 -1
  205. package/dist/cjs/components/InputLike/InputLike.js.map +1 -1
  206. package/dist/cjs/components/InputLike/InputLikeDivider.d.ts.map +1 -1
  207. package/dist/cjs/components/InputLike/InputLikeDivider.js.map +1 -1
  208. package/dist/cjs/components/Link/Link.d.ts.map +1 -1
  209. package/dist/cjs/components/Link/Link.js +1 -0
  210. package/dist/cjs/components/Link/Link.js.map +1 -1
  211. package/dist/cjs/components/List/List.js.map +1 -1
  212. package/dist/cjs/components/LocaleProvider/LocaleProvider.js.map +1 -1
  213. package/dist/cjs/components/Mark/Mark.js.map +1 -1
  214. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  215. package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
  216. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  217. package/dist/cjs/components/ModalCardBase/ModalCardBaseCloseButton.js.map +1 -1
  218. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  219. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  220. package/dist/cjs/components/ModalPage/ModalPageContext.js.map +1 -1
  221. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  222. package/dist/cjs/components/ModalRoot/ModalRoot.d.ts.map +1 -1
  223. package/dist/cjs/components/ModalRoot/ModalRoot.js +6 -9
  224. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  225. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  226. package/dist/cjs/components/ModalRoot/ModalRootContext.js.map +1 -1
  227. package/dist/cjs/components/ModalRoot/ModalRootDesktop.d.ts.map +1 -1
  228. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +2 -1
  229. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  230. package/dist/cjs/components/ModalRoot/constants.js.map +1 -1
  231. package/dist/cjs/components/ModalRoot/types.d.ts +0 -1
  232. package/dist/cjs/components/ModalRoot/types.d.ts.map +1 -1
  233. package/dist/cjs/components/ModalRoot/types.js.map +1 -1
  234. package/dist/cjs/components/ModalRoot/useModalManager.d.ts.map +1 -1
  235. package/dist/cjs/components/ModalRoot/useModalManager.js.map +1 -1
  236. package/dist/cjs/components/ModalRoot/useModalRootContext.js.map +1 -1
  237. package/dist/cjs/components/ModalRoot/withModalRootContext.js.map +1 -1
  238. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  239. package/dist/cjs/components/NavIdContext/NavIdContext.js.map +1 -1
  240. package/dist/cjs/components/NavIdContext/useNavId.js.map +1 -1
  241. package/dist/cjs/components/NavTransitionContext/NavTransitionContext.d.ts.map +1 -1
  242. package/dist/cjs/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  243. package/dist/cjs/components/NavTransitionDirectionContext/NavTransitionDirectionContext.d.ts.map +1 -1
  244. package/dist/cjs/components/NavTransitionDirectionContext/NavTransitionDirectionContext.js.map +1 -1
  245. package/dist/cjs/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  246. package/dist/cjs/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts +1 -1
  247. package/dist/cjs/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts.map +1 -1
  248. package/dist/cjs/components/OnboardingTooltip/OnboardingTooltipContainer.js.map +1 -1
  249. package/dist/cjs/components/Pagination/Pagination.js.map +1 -1
  250. package/dist/cjs/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.d.ts.map +1 -1
  251. package/dist/cjs/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.js.map +1 -1
  252. package/dist/cjs/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -1
  253. package/dist/cjs/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -1
  254. package/dist/cjs/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -1
  255. package/dist/cjs/components/Pagination/utils.js.map +1 -1
  256. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  257. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  258. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  259. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  260. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  261. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  262. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.d.ts +2 -2
  263. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.d.ts.map +1 -1
  264. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js +27 -37
  265. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  266. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  267. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  268. package/dist/cjs/components/PanelSpinner/PanelSpinner.js.map +1 -1
  269. package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
  270. package/dist/cjs/components/PlatformProvider/PlatformProvider.js.map +1 -1
  271. package/dist/cjs/components/PopoutRoot/PopoutRoot.d.ts.map +1 -1
  272. package/dist/cjs/components/PopoutRoot/PopoutRoot.js +0 -8
  273. package/dist/cjs/components/PopoutRoot/PopoutRoot.js.map +1 -1
  274. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.d.ts.map +1 -1
  275. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js +1 -20
  276. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  277. package/dist/cjs/components/Popover/Popover.d.ts +5 -1
  278. package/dist/cjs/components/Popover/Popover.d.ts.map +1 -1
  279. package/dist/cjs/components/Popover/Popover.js +11 -5
  280. package/dist/cjs/components/Popover/Popover.js.map +1 -1
  281. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  282. package/dist/cjs/components/Progress/Progress.js.map +1 -1
  283. package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
  284. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  285. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  286. package/dist/cjs/components/RadioGroup/RadioGroup.js.map +1 -1
  287. package/dist/cjs/components/Removable/Removable.js.map +1 -1
  288. package/dist/cjs/components/RichCell/RichCell.js.map +1 -1
  289. package/dist/cjs/components/RichCell/RichCellIcon/RichCellIcon.js.map +1 -1
  290. package/dist/cjs/components/Root/Root.d.ts.map +1 -1
  291. package/dist/cjs/components/Root/Root.js +8 -18
  292. package/dist/cjs/components/Root/Root.js.map +1 -1
  293. package/dist/cjs/components/RootComponent/RootComponent.d.ts.map +1 -1
  294. package/dist/cjs/components/RootComponent/RootComponent.js.map +1 -1
  295. package/dist/cjs/components/ScreenSpinner/Icon48CancelCircle.d.ts.map +1 -1
  296. package/dist/cjs/components/ScreenSpinner/Icon48CancelCircle.js.map +1 -1
  297. package/dist/cjs/components/ScreenSpinner/Icon48DoneOutline.d.ts.map +1 -1
  298. package/dist/cjs/components/ScreenSpinner/Icon48DoneOutline.js.map +1 -1
  299. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  300. package/dist/cjs/components/ScrollArrow/ScrollArrow.js.map +1 -1
  301. package/dist/cjs/components/Search/Search.js.map +1 -1
  302. package/dist/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
  303. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  304. package/dist/cjs/components/Select/Select.d.ts.map +1 -1
  305. package/dist/cjs/components/Select/Select.js.map +1 -1
  306. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  307. package/dist/cjs/components/SelectTypography/SelectTypography.js.map +1 -1
  308. package/dist/cjs/components/Separator/Separator.js.map +1 -1
  309. package/dist/cjs/components/SimpleCell/Chevron/Chevron.js.map +1 -1
  310. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  311. package/dist/cjs/components/Skeleton/Skeleton.js.map +1 -1
  312. package/dist/cjs/components/Slider/Slider.d.ts.map +1 -1
  313. package/dist/cjs/components/Slider/Slider.js +7 -2
  314. package/dist/cjs/components/Slider/Slider.js.map +1 -1
  315. package/dist/cjs/components/Slider/SliderThumb/SliderThumb.d.ts +2 -1
  316. package/dist/cjs/components/Slider/SliderThumb/SliderThumb.d.ts.map +1 -1
  317. package/dist/cjs/components/Slider/SliderThumb/SliderThumb.js +6 -5
  318. package/dist/cjs/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
  319. package/dist/cjs/components/Slider/helpers.d.ts.map +1 -1
  320. package/dist/cjs/components/Slider/helpers.js.map +1 -1
  321. package/dist/cjs/components/Slider/types.js.map +1 -1
  322. package/dist/cjs/components/Snackbar/Snackbar.d.ts +1 -1
  323. package/dist/cjs/components/Snackbar/Snackbar.d.ts.map +1 -1
  324. package/dist/cjs/components/Snackbar/Snackbar.js +11 -10
  325. package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
  326. package/dist/cjs/components/Snackbar/subcomponents/Basic/Basic.js.map +1 -1
  327. package/dist/cjs/components/Snackbar/types.js.map +1 -1
  328. package/dist/cjs/components/Snackbar/utils.d.ts +0 -1
  329. package/dist/cjs/components/Snackbar/utils.d.ts.map +1 -1
  330. package/dist/cjs/components/Snackbar/utils.js.map +1 -1
  331. package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
  332. package/dist/cjs/components/Spinner/Spinner.d.ts.map +1 -1
  333. package/dist/cjs/components/Spinner/Spinner.js +37 -18
  334. package/dist/cjs/components/Spinner/Spinner.js.map +1 -1
  335. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  336. package/dist/cjs/components/SplitCol/SplitColContext.js.map +1 -1
  337. package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
  338. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  339. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  340. package/dist/cjs/components/Switch/Switch.d.ts +1 -1
  341. package/dist/cjs/components/Switch/Switch.d.ts.map +1 -1
  342. package/dist/cjs/components/Switch/Switch.js +41 -19
  343. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  344. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  345. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  346. package/dist/cjs/components/Tabs/Tabs.js.map +1 -1
  347. package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
  348. package/dist/cjs/components/Tappable/Ripple.d.ts.map +1 -1
  349. package/dist/cjs/components/Tappable/Ripple.js +10 -3
  350. package/dist/cjs/components/Tappable/Ripple.js.map +1 -1
  351. package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
  352. package/dist/cjs/components/Tappable/state.js.map +1 -1
  353. package/dist/cjs/components/Textarea/Textarea.d.ts.map +1 -1
  354. package/dist/cjs/components/Textarea/Textarea.js +7 -19
  355. package/dist/cjs/components/Textarea/Textarea.js.map +1 -1
  356. package/dist/cjs/components/Textarea/useResizeTextarea.d.ts +3 -0
  357. package/dist/cjs/components/Textarea/useResizeTextarea.d.ts.map +1 -0
  358. package/dist/cjs/components/Textarea/useResizeTextarea.js +45 -0
  359. package/dist/cjs/components/Textarea/useResizeTextarea.js.map +1 -0
  360. package/dist/cjs/components/ToolButton/ToolButton.js.map +1 -1
  361. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  362. package/dist/cjs/components/TooltipBase/TooltipBase.js.map +1 -1
  363. package/dist/cjs/components/Touch/Touch.js.map +1 -1
  364. package/dist/cjs/components/Touch/TouchContext.js.map +1 -1
  365. package/dist/cjs/components/Typography/Caption/Caption.d.ts +1 -1
  366. package/dist/cjs/components/Typography/Caption/Caption.d.ts.map +1 -1
  367. package/dist/cjs/components/Typography/Caption/Caption.js +4 -2
  368. package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
  369. package/dist/cjs/components/Typography/DisplayTitle/DisplayTitle.d.ts +11 -0
  370. package/dist/cjs/components/Typography/DisplayTitle/DisplayTitle.d.ts.map +1 -0
  371. package/dist/cjs/components/Typography/DisplayTitle/DisplayTitle.js +38 -0
  372. package/dist/cjs/components/Typography/DisplayTitle/DisplayTitle.js.map +1 -0
  373. package/dist/cjs/components/Typography/EllipsisText/EllipsisText.js.map +1 -1
  374. package/dist/cjs/components/Typography/Footnote/Footnote.d.ts +1 -1
  375. package/dist/cjs/components/Typography/Footnote/Footnote.d.ts.map +1 -1
  376. package/dist/cjs/components/Typography/Footnote/Footnote.js +4 -2
  377. package/dist/cjs/components/Typography/Footnote/Footnote.js.map +1 -1
  378. package/dist/cjs/components/Typography/Headline/Headline.d.ts +1 -1
  379. package/dist/cjs/components/Typography/Headline/Headline.d.ts.map +1 -1
  380. package/dist/cjs/components/Typography/Headline/Headline.js +4 -2
  381. package/dist/cjs/components/Typography/Headline/Headline.js.map +1 -1
  382. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts +1 -1
  383. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts.map +1 -1
  384. package/dist/cjs/components/Typography/Paragraph/Paragraph.js +4 -2
  385. package/dist/cjs/components/Typography/Paragraph/Paragraph.js.map +1 -1
  386. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts +1 -1
  387. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts.map +1 -1
  388. package/dist/cjs/components/Typography/Subhead/Subhead.js +4 -2
  389. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  390. package/dist/cjs/components/Typography/Text/Text.d.ts +1 -1
  391. package/dist/cjs/components/Typography/Text/Text.d.ts.map +1 -1
  392. package/dist/cjs/components/Typography/Text/Text.js +4 -2
  393. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  394. package/dist/cjs/components/Typography/Title/Title.d.ts +1 -1
  395. package/dist/cjs/components/Typography/Title/Title.d.ts.map +1 -1
  396. package/dist/cjs/components/Typography/Title/Title.js +4 -2
  397. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  398. package/dist/cjs/components/Typography/Typography.d.ts +5 -1
  399. package/dist/cjs/components/Typography/Typography.d.ts.map +1 -1
  400. package/dist/cjs/components/Typography/Typography.js +4 -3
  401. package/dist/cjs/components/Typography/Typography.js.map +1 -1
  402. package/dist/cjs/components/UnstyledTextField/UnstyledTextField.js.map +1 -1
  403. package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
  404. package/dist/cjs/components/View/View.d.ts.map +1 -1
  405. package/dist/cjs/components/View/View.js +36 -50
  406. package/dist/cjs/components/View/View.js.map +1 -1
  407. package/dist/cjs/components/View/ViewInfinite.d.ts.map +1 -1
  408. package/dist/cjs/components/View/ViewInfinite.js +16 -18
  409. package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
  410. package/dist/cjs/components/View/utils.js.map +1 -1
  411. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.d.ts.map +1 -1
  412. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.js.map +1 -1
  413. package/dist/cjs/components/WriteBar/WriteBar.d.ts.map +1 -1
  414. package/dist/cjs/components/WriteBar/WriteBar.js +3 -19
  415. package/dist/cjs/components/WriteBar/WriteBar.js.map +1 -1
  416. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  417. package/dist/cjs/helpers/avatar.js.map +1 -1
  418. package/dist/cjs/helpers/getMergedSameEventsByProps.d.ts +1 -1
  419. package/dist/cjs/helpers/getMergedSameEventsByProps.d.ts.map +1 -1
  420. package/dist/cjs/helpers/getMergedSameEventsByProps.js.map +1 -1
  421. package/dist/cjs/helpers/getOrDefault.js.map +1 -1
  422. package/dist/cjs/helpers/math.js.map +1 -1
  423. package/dist/cjs/helpers/range.js.map +1 -1
  424. package/dist/cjs/hoc/withContext.js.map +1 -1
  425. package/dist/cjs/hoc/withPlatform.js.map +1 -1
  426. package/dist/cjs/hooks/useAdaptivity.js.map +1 -1
  427. package/dist/cjs/hooks/useAdaptivityConditionalRender/constants.js.map +1 -1
  428. package/dist/cjs/hooks/useAdaptivityConditionalRender/helpers.d.ts +3 -3
  429. package/dist/cjs/hooks/useAdaptivityConditionalRender/helpers.d.ts.map +1 -1
  430. package/dist/cjs/hooks/useAdaptivityConditionalRender/helpers.js.map +1 -1
  431. package/dist/cjs/hooks/useAdaptivityConditionalRender/index.js.map +1 -1
  432. package/dist/cjs/hooks/useAdaptivityConditionalRender/types.js.map +1 -1
  433. package/dist/cjs/hooks/useAdaptivityConditionalRender/useAdaptivityConditionalRender.js.map +1 -1
  434. package/dist/cjs/hooks/useAdaptivityHasPointer.js.map +1 -1
  435. package/dist/cjs/hooks/useAdaptivityWithJSMediaQueries.js.map +1 -1
  436. package/dist/cjs/hooks/useAppearance.js.map +1 -1
  437. package/dist/cjs/hooks/useAutoDetectAppearance.js.map +1 -1
  438. package/dist/cjs/hooks/useAutoFocus.js.map +1 -1
  439. package/dist/cjs/hooks/useBooleanState.js.map +1 -1
  440. package/dist/cjs/hooks/useCalendar.d.ts +2 -0
  441. package/dist/cjs/hooks/useCalendar.d.ts.map +1 -1
  442. package/dist/cjs/hooks/useCalendar.js +43 -1
  443. package/dist/cjs/hooks/useCalendar.js.map +1 -1
  444. package/dist/cjs/hooks/useDateInput.d.ts.map +1 -1
  445. package/dist/cjs/hooks/useDateInput.js.map +1 -1
  446. package/dist/cjs/hooks/useDirection.js.map +1 -1
  447. package/dist/cjs/hooks/useDraggableWithDomApi/autoScroll.js.map +1 -1
  448. package/dist/cjs/hooks/useDraggableWithDomApi/constants.js.map +1 -1
  449. package/dist/cjs/hooks/useDraggableWithDomApi/index.js.map +1 -1
  450. package/dist/cjs/hooks/useDraggableWithDomApi/types.js.map +1 -1
  451. package/dist/cjs/hooks/useDraggableWithDomApi/useDraggableWithDomApi.d.ts.map +1 -1
  452. package/dist/cjs/hooks/useDraggableWithDomApi/useDraggableWithDomApi.js.map +1 -1
  453. package/dist/cjs/hooks/useDraggableWithDomApi/utils.d.ts +2 -2
  454. package/dist/cjs/hooks/useDraggableWithDomApi/utils.d.ts.map +1 -1
  455. package/dist/cjs/hooks/useDraggableWithDomApi/utils.js.map +1 -1
  456. package/dist/cjs/hooks/useEffectDev.js.map +1 -1
  457. package/dist/cjs/hooks/useEnsuredControl.js.map +1 -1
  458. package/dist/cjs/hooks/useEventListener.js.map +1 -1
  459. package/dist/cjs/hooks/useExternRef.js.map +1 -1
  460. package/dist/cjs/hooks/useFocusVisible.d.ts.map +1 -1
  461. package/dist/cjs/hooks/useFocusVisible.js.map +1 -1
  462. package/dist/cjs/hooks/useFocusVisibleClassName.js.map +1 -1
  463. package/dist/cjs/hooks/useFocusWithin.js.map +1 -1
  464. package/dist/cjs/hooks/useGlobalEscKeyDown.js.map +1 -1
  465. package/dist/cjs/hooks/useGlobalEventListener.js.map +1 -1
  466. package/dist/cjs/hooks/useGlobalOnClickOutside.d.ts +1 -1
  467. package/dist/cjs/hooks/useGlobalOnClickOutside.d.ts.map +1 -1
  468. package/dist/cjs/hooks/useGlobalOnClickOutside.js.map +1 -1
  469. package/dist/cjs/hooks/useIsClient.js.map +1 -1
  470. package/dist/cjs/hooks/useKeyboard.js.map +1 -1
  471. package/dist/cjs/hooks/useKeyboardInputTracker.js.map +1 -1
  472. package/dist/cjs/hooks/useMediaQueries.d.ts.map +1 -1
  473. package/dist/cjs/hooks/useMediaQueries.js +21 -18
  474. package/dist/cjs/hooks/useMediaQueries.js.map +1 -1
  475. package/dist/cjs/hooks/useNativeFormResetListener.d.ts.map +1 -1
  476. package/dist/cjs/hooks/useNativeFormResetListener.js.map +1 -1
  477. package/dist/cjs/hooks/useObjectMemo.js.map +1 -1
  478. package/dist/cjs/hooks/useOrientationChange.js.map +1 -1
  479. package/dist/cjs/hooks/usePagination.d.ts.map +1 -1
  480. package/dist/cjs/hooks/usePagination.js.map +1 -1
  481. package/dist/cjs/hooks/usePatchChildren.d.ts.map +1 -1
  482. package/dist/cjs/hooks/usePatchChildren.js.map +1 -1
  483. package/dist/cjs/hooks/usePlatform.js.map +1 -1
  484. package/dist/cjs/hooks/usePrevious.js.map +1 -1
  485. package/dist/cjs/hooks/useResizeObserver.d.ts +1 -1
  486. package/dist/cjs/hooks/useResizeObserver.d.ts.map +1 -1
  487. package/dist/cjs/hooks/useResizeObserver.js +4 -4
  488. package/dist/cjs/hooks/useResizeObserver.js.map +1 -1
  489. package/dist/cjs/hooks/useStableCallback.js.map +1 -1
  490. package/dist/cjs/hooks/useTodayDate.js.map +1 -1
  491. package/dist/cjs/hooks/useWaitTransitionFinish.d.ts +1 -3
  492. package/dist/cjs/hooks/useWaitTransitionFinish.d.ts.map +1 -1
  493. package/dist/cjs/hooks/useWaitTransitionFinish.js +4 -9
  494. package/dist/cjs/hooks/useWaitTransitionFinish.js.map +1 -1
  495. package/dist/cjs/index.d.ts +7 -1
  496. package/dist/cjs/index.d.ts.map +1 -1
  497. package/dist/cjs/index.js +8 -0
  498. package/dist/cjs/index.js.map +1 -1
  499. package/dist/cjs/lib/SSR.js.map +1 -1
  500. package/dist/cjs/lib/accessibility.d.ts +1 -1
  501. package/dist/cjs/lib/accessibility.d.ts.map +1 -1
  502. package/dist/cjs/lib/accessibility.js +1 -0
  503. package/dist/cjs/lib/accessibility.js.map +1 -1
  504. package/dist/cjs/lib/adaptivity/constants.js.map +1 -1
  505. package/dist/cjs/lib/adaptivity/functions.js.map +1 -1
  506. package/dist/cjs/lib/adaptivity/index.js.map +1 -1
  507. package/dist/cjs/lib/adaptivity/types.js.map +1 -1
  508. package/dist/cjs/lib/animate.js.map +1 -1
  509. package/dist/cjs/lib/animation/fades.js.map +1 -1
  510. package/dist/cjs/lib/animation/index.d.ts +1 -0
  511. package/dist/cjs/lib/animation/index.d.ts.map +1 -1
  512. package/dist/cjs/lib/animation/index.js +7 -0
  513. package/dist/cjs/lib/animation/index.js.map +1 -1
  514. package/dist/cjs/lib/animation/rubberbandIfOutOfBounds.js.map +1 -1
  515. package/dist/cjs/lib/animation/transformOrigin.js.map +1 -1
  516. package/dist/cjs/lib/animation/useCSSKeyframesAnimationController.d.ts +1 -1
  517. package/dist/cjs/lib/animation/useCSSKeyframesAnimationController.d.ts.map +1 -1
  518. package/dist/cjs/lib/animation/useCSSKeyframesAnimationController.js +5 -6
  519. package/dist/cjs/lib/animation/useCSSKeyframesAnimationController.js.map +1 -1
  520. package/dist/cjs/lib/animation/useReducedMotion.js.map +1 -1
  521. package/dist/cjs/lib/appearance/index.js.map +1 -1
  522. package/dist/cjs/lib/appearance/types.js.map +1 -1
  523. package/dist/cjs/lib/browser.js.map +1 -1
  524. package/dist/cjs/lib/calendar.js.map +1 -1
  525. package/dist/cjs/lib/callMultiple.js.map +1 -1
  526. package/dist/cjs/lib/children.d.ts.map +1 -1
  527. package/dist/cjs/lib/children.js.map +1 -1
  528. package/dist/cjs/lib/comparing.js.map +1 -1
  529. package/dist/cjs/lib/createPortal.d.ts.map +1 -1
  530. package/dist/cjs/lib/createPortal.js.map +1 -1
  531. package/dist/cjs/lib/date.js.map +1 -1
  532. package/dist/cjs/lib/dom.d.ts +0 -1
  533. package/dist/cjs/lib/dom.d.ts.map +1 -1
  534. package/dist/cjs/lib/dom.js.map +1 -1
  535. package/dist/cjs/lib/floating/adapters.js.map +1 -1
  536. package/dist/cjs/lib/floating/customResizeObserver.js.map +1 -1
  537. package/dist/cjs/lib/floating/functions.d.ts +1 -1
  538. package/dist/cjs/lib/floating/functions.js.map +1 -1
  539. package/dist/cjs/lib/floating/index.js.map +1 -1
  540. package/dist/cjs/lib/floating/types/common.js.map +1 -1
  541. package/dist/cjs/lib/floating/types/component.js.map +1 -1
  542. package/dist/cjs/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts +1 -11
  543. package/dist/cjs/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts.map +1 -1
  544. package/dist/cjs/lib/floating/useFloatingMiddlewaresBootstrap/index.js.map +1 -1
  545. package/dist/cjs/lib/floating/useFloatingWithInteractions/constants.js.map +1 -1
  546. package/dist/cjs/lib/floating/useFloatingWithInteractions/index.js.map +1 -1
  547. package/dist/cjs/lib/floating/useFloatingWithInteractions/types.d.ts +0 -1
  548. package/dist/cjs/lib/floating/useFloatingWithInteractions/types.d.ts.map +1 -1
  549. package/dist/cjs/lib/floating/useFloatingWithInteractions/types.js.map +1 -1
  550. package/dist/cjs/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.d.ts.map +1 -1
  551. package/dist/cjs/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
  552. package/dist/cjs/lib/floating/useFloatingWithInteractions/useResolveTriggerType.js.map +1 -1
  553. package/dist/cjs/lib/floating/usePlacementChangeCallback.js.map +1 -1
  554. package/dist/cjs/lib/fx.js.map +1 -1
  555. package/dist/cjs/lib/getNavId.js.map +1 -1
  556. package/dist/cjs/lib/isRefObject.d.ts.map +1 -1
  557. package/dist/cjs/lib/isRefObject.js.map +1 -1
  558. package/dist/cjs/lib/layouts/gaps.d.ts +32 -0
  559. package/dist/cjs/lib/layouts/gaps.d.ts.map +1 -0
  560. package/dist/cjs/lib/layouts/gaps.js +60 -0
  561. package/dist/cjs/lib/layouts/gaps.js.map +1 -0
  562. package/dist/cjs/lib/layouts/index.d.ts +2 -0
  563. package/dist/cjs/lib/layouts/index.d.ts.map +1 -0
  564. package/dist/cjs/lib/layouts/index.js +24 -0
  565. package/dist/cjs/lib/layouts/index.js.map +1 -0
  566. package/dist/cjs/lib/matchMedia.js.map +1 -1
  567. package/dist/cjs/lib/mergeCalls.js.map +1 -1
  568. package/dist/cjs/lib/offset.js.map +1 -1
  569. package/dist/cjs/lib/platform.js.map +1 -1
  570. package/dist/cjs/lib/rafSchd.d.ts.map +1 -1
  571. package/dist/cjs/lib/rafSchd.js.map +1 -1
  572. package/dist/cjs/lib/react/index.js.map +1 -1
  573. package/dist/cjs/lib/react/simulateReactInput.js.map +1 -1
  574. package/dist/cjs/lib/removeObjectKeys.js.map +1 -1
  575. package/dist/cjs/lib/select.js.map +1 -1
  576. package/dist/cjs/lib/styles.js.map +1 -1
  577. package/dist/cjs/lib/testing.js.map +1 -1
  578. package/dist/cjs/lib/tokens/TokensClassProvider.js.map +1 -1
  579. package/dist/cjs/lib/tokens/constants.js.map +1 -1
  580. package/dist/cjs/lib/tokens/index.js.map +1 -1
  581. package/dist/cjs/lib/tokens/types.js.map +1 -1
  582. package/dist/cjs/lib/tokens/useTokenClassName.js.map +1 -1
  583. package/dist/cjs/lib/touch/UIPanGestureRecognizer.js.map +1 -1
  584. package/dist/cjs/lib/touch/functions.js.map +1 -1
  585. package/dist/cjs/lib/touch/index.js.map +1 -1
  586. package/dist/cjs/lib/useIsomorphicLayoutEffect.js.map +1 -1
  587. package/dist/cjs/lib/utils.d.ts +1 -1
  588. package/dist/cjs/lib/utils.d.ts.map +1 -1
  589. package/dist/cjs/lib/utils.js.map +1 -1
  590. package/dist/cjs/lib/warnOnce.js.map +1 -1
  591. package/dist/cjs/shared/breakpoints.d.js +8 -0
  592. package/dist/cjs/shared/breakpoints.d.js.map +1 -0
  593. package/dist/cjs/shared/breakpoints.js.map +1 -1
  594. package/dist/cjs/types.d.ts +1 -0
  595. package/dist/cjs/types.d.ts.map +1 -1
  596. package/dist/cjs/types.js.map +1 -1
  597. package/dist/cjs/vkui.js.map +1 -1
  598. package/dist/components/Accordion/Accordion.js.map +1 -1
  599. package/dist/components/Accordion/AccordionContent.d.ts.map +1 -1
  600. package/dist/components/Accordion/AccordionContent.js +35 -39
  601. package/dist/components/Accordion/AccordionContent.js.map +1 -1
  602. package/dist/components/Accordion/AccordionContext.js.map +1 -1
  603. package/dist/components/Accordion/AccordionSummary.js.map +1 -1
  604. package/dist/components/ActionSheet/ActionSheet.d.ts +1 -1
  605. package/dist/components/ActionSheet/ActionSheet.d.ts.map +1 -1
  606. package/dist/components/ActionSheet/ActionSheet.js +24 -32
  607. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  608. package/dist/components/ActionSheet/ActionSheetContext.js.map +1 -1
  609. package/dist/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -1
  610. package/dist/components/ActionSheet/ActionSheetDropdownMenu.d.ts +1 -1
  611. package/dist/components/ActionSheet/ActionSheetDropdownMenu.d.ts.map +1 -1
  612. package/dist/components/ActionSheet/ActionSheetDropdownMenu.js +7 -3
  613. package/dist/components/ActionSheet/ActionSheetDropdownMenu.js.map +1 -1
  614. package/dist/components/ActionSheet/ActionSheetDropdownSheet.js +1 -1
  615. package/dist/components/ActionSheet/ActionSheetDropdownSheet.js.map +1 -1
  616. package/dist/components/ActionSheet/types.js.map +1 -1
  617. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  618. package/dist/components/ActionSheetItem/subcomponents/Radio/Radio.js.map +1 -1
  619. package/dist/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -1
  620. package/dist/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  621. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  622. package/dist/components/Alert/Alert.d.ts.map +1 -1
  623. package/dist/components/Alert/Alert.js +23 -34
  624. package/dist/components/Alert/Alert.js.map +1 -1
  625. package/dist/components/Alert/AlertAction.js.map +1 -1
  626. package/dist/components/Alert/AlertActions.js.map +1 -1
  627. package/dist/components/Alert/AlertTypography.js.map +1 -1
  628. package/dist/components/AppRoot/AppRoot.d.ts +14 -2
  629. package/dist/components/AppRoot/AppRoot.d.ts.map +1 -1
  630. package/dist/components/AppRoot/AppRoot.js +12 -4
  631. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  632. package/dist/components/AppRoot/AppRootContext.js.map +1 -1
  633. package/dist/components/AppRoot/AppRootPortal.js.map +1 -1
  634. package/dist/components/AppRoot/ScrollContext.d.ts.map +1 -1
  635. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  636. package/dist/components/AppRoot/helpers.d.ts +6 -1
  637. package/dist/components/AppRoot/helpers.d.ts.map +1 -1
  638. package/dist/components/AppRoot/helpers.js +21 -0
  639. package/dist/components/AppRoot/helpers.js.map +1 -1
  640. package/dist/components/AppRoot/types.d.ts +1 -0
  641. package/dist/components/AppRoot/types.d.ts.map +1 -1
  642. package/dist/components/AppRoot/types.js.map +1 -1
  643. package/dist/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  644. package/dist/components/AspectRatio/AspectRatio.js.map +1 -1
  645. package/dist/components/Avatar/Avatar.d.ts +1 -1
  646. package/dist/components/Avatar/Avatar.js.map +1 -1
  647. package/dist/components/Avatar/AvatarBadge/AvatarBadge.js.map +1 -1
  648. package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  649. package/dist/components/Avatar/AvatarBadge/icons.d.ts.map +1 -1
  650. package/dist/components/Avatar/AvatarBadge/icons.js.map +1 -1
  651. package/dist/components/Avatar/helpers.js.map +1 -1
  652. package/dist/components/Badge/Badge.js.map +1 -1
  653. package/dist/components/Banner/Banner.js.map +1 -1
  654. package/dist/components/BaseGallery/BaseGallery.js.map +1 -1
  655. package/dist/components/BaseGallery/CarouselBase/CarouselBase.js.map +1 -1
  656. package/dist/components/BaseGallery/CarouselBase/constants.js.map +1 -1
  657. package/dist/components/BaseGallery/CarouselBase/helpers.js.map +1 -1
  658. package/dist/components/BaseGallery/CarouselBase/hooks.js.map +1 -1
  659. package/dist/components/BaseGallery/CarouselBase/types.js.map +1 -1
  660. package/dist/components/BaseGallery/helpers.js.map +1 -1
  661. package/dist/components/BaseGallery/types.js.map +1 -1
  662. package/dist/components/Button/Button.js.map +1 -1
  663. package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -1
  664. package/dist/components/Calendar/Calendar.d.ts.map +1 -1
  665. package/dist/components/Calendar/Calendar.js +4 -2
  666. package/dist/components/Calendar/Calendar.js.map +1 -1
  667. package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
  668. package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
  669. package/dist/components/CalendarHeader/CalendarHeader.d.ts +3 -1
  670. package/dist/components/CalendarHeader/CalendarHeader.d.ts.map +1 -1
  671. package/dist/components/CalendarHeader/CalendarHeader.js +23 -10
  672. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
  673. package/dist/components/CalendarRange/CalendarRange.d.ts.map +1 -1
  674. package/dist/components/CalendarRange/CalendarRange.js +12 -5
  675. package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
  676. package/dist/components/CalendarTime/CalendarTime.js.map +1 -1
  677. package/dist/components/Card/Card.js.map +1 -1
  678. package/dist/components/CardGrid/CardGrid.js.map +1 -1
  679. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  680. package/dist/components/Cell/Cell.js.map +1 -1
  681. package/dist/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  682. package/dist/components/Cell/CellDragger/CellDragger.js.map +1 -1
  683. package/dist/components/Cell/constants.js.map +1 -1
  684. package/dist/components/CellButton/CellButton.js.map +1 -1
  685. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  686. package/dist/components/ChipsInput/ChipsInput.d.ts.map +1 -1
  687. package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
  688. package/dist/components/ChipsInput/useChipsInput.d.ts.map +1 -1
  689. package/dist/components/ChipsInput/useChipsInput.js.map +1 -1
  690. package/dist/components/ChipsInputBase/Chip/Chip.js.map +1 -1
  691. package/dist/components/ChipsInputBase/ChipsInputBase.d.ts.map +1 -1
  692. package/dist/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
  693. package/dist/components/ChipsInputBase/constants.js.map +1 -1
  694. package/dist/components/ChipsInputBase/helpers.d.ts.map +1 -1
  695. package/dist/components/ChipsInputBase/helpers.js.map +1 -1
  696. package/dist/components/ChipsInputBase/types.js.map +1 -1
  697. package/dist/components/ChipsSelect/ChipsSelect.d.ts +5 -1
  698. package/dist/components/ChipsSelect/ChipsSelect.d.ts.map +1 -1
  699. package/dist/components/ChipsSelect/ChipsSelect.js +15 -8
  700. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  701. package/dist/components/ChipsSelect/constants.d.ts.map +1 -1
  702. package/dist/components/ChipsSelect/constants.js.map +1 -1
  703. package/dist/components/ChipsSelect/types.js.map +1 -1
  704. package/dist/components/ChipsSelect/useChipsSelect.d.ts +10 -2
  705. package/dist/components/ChipsSelect/useChipsSelect.d.ts.map +1 -1
  706. package/dist/components/ChipsSelect/useChipsSelect.js +12 -4
  707. package/dist/components/ChipsSelect/useChipsSelect.js.map +1 -1
  708. package/dist/components/Clickable/Clickable.d.ts.map +1 -1
  709. package/dist/components/Clickable/Clickable.js.map +1 -1
  710. package/dist/components/Clickable/useKeyboard.d.ts.map +1 -1
  711. package/dist/components/Clickable/useKeyboard.js.map +1 -1
  712. package/dist/components/Clickable/useState.d.ts.map +1 -1
  713. package/dist/components/Clickable/useState.js.map +1 -1
  714. package/dist/components/Clickable/useStateWithDelay.js.map +1 -1
  715. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  716. package/dist/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  717. package/dist/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  718. package/dist/components/ContentBadge/ContentBadge.js.map +1 -1
  719. package/dist/components/ContentBadge/ContentBadgeContext.js.map +1 -1
  720. package/dist/components/ContentBadge/ContentBadgeSlotIcon.js.map +1 -1
  721. package/dist/components/ContentBadge/types.js.map +1 -1
  722. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  723. package/dist/components/Counter/Counter.js.map +1 -1
  724. package/dist/components/CustomScrollView/CustomScrollView.js.map +1 -1
  725. package/dist/components/CustomScrollView/useTrackerVisibility.d.ts.map +1 -1
  726. package/dist/components/CustomScrollView/useTrackerVisibility.js +31 -37
  727. package/dist/components/CustomScrollView/useTrackerVisibility.js.map +1 -1
  728. package/dist/components/CustomSelect/CustomSelect.d.ts +5 -2
  729. package/dist/components/CustomSelect/CustomSelect.d.ts.map +1 -1
  730. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  731. package/dist/components/CustomSelect/CustomSelectClearButton.js.map +1 -1
  732. package/dist/components/CustomSelect/CustomSelectInput.js.map +1 -1
  733. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  734. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  735. package/dist/components/DateInput/DateInput.js.map +1 -1
  736. package/dist/components/DatePicker/DatePicker.d.ts +6 -0
  737. package/dist/components/DatePicker/DatePicker.d.ts.map +1 -1
  738. package/dist/components/DatePicker/DatePicker.js +6 -0
  739. package/dist/components/DatePicker/DatePicker.js.map +1 -1
  740. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  741. package/dist/components/Div/Div.js.map +1 -1
  742. package/dist/components/DropZone/DropZone.js.map +1 -1
  743. package/dist/components/DropZone/components/DropZoneGrid.js.map +1 -1
  744. package/dist/components/DropdownIcon/DropdownIcon.js.map +1 -1
  745. package/dist/components/Epic/Epic.js.map +1 -1
  746. package/dist/components/Epic/ScrollSaver.js.map +1 -1
  747. package/dist/components/File/File.js.map +1 -1
  748. package/dist/components/FixedLayout/FixedLayout.d.ts.map +1 -1
  749. package/dist/components/FixedLayout/FixedLayout.js +19 -6
  750. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  751. package/dist/components/Flex/Flex.d.ts +42 -0
  752. package/dist/components/Flex/Flex.d.ts.map +1 -0
  753. package/dist/components/Flex/Flex.js +50 -0
  754. package/dist/components/Flex/Flex.js.map +1 -0
  755. package/dist/components/Flex/FlexItem/FlexItem.d.ts +20 -0
  756. package/dist/components/Flex/FlexItem/FlexItem.d.ts.map +1 -0
  757. package/dist/components/Flex/FlexItem/FlexItem.js +37 -0
  758. package/dist/components/Flex/FlexItem/FlexItem.js.map +1 -0
  759. package/dist/components/FloatingArrow/DefaultIcon.d.ts.map +1 -1
  760. package/dist/components/FloatingArrow/DefaultIcon.js.map +1 -1
  761. package/dist/components/FloatingArrow/FloatingArrow.js +14 -4
  762. package/dist/components/FloatingArrow/FloatingArrow.js.map +1 -1
  763. package/dist/components/FocusTrap/FocusTrap.d.ts +6 -1
  764. package/dist/components/FocusTrap/FocusTrap.d.ts.map +1 -1
  765. package/dist/components/FocusTrap/FocusTrap.js +45 -20
  766. package/dist/components/FocusTrap/FocusTrap.js.map +1 -1
  767. package/dist/components/Footer/Footer.js.map +1 -1
  768. package/dist/components/FormField/FormField.js.map +1 -1
  769. package/dist/components/FormItem/FormItem.js.map +1 -1
  770. package/dist/components/FormItem/FormItemTop/FormItemTop.js.map +1 -1
  771. package/dist/components/FormItem/FormItemTop/FormItemTopAside.js.map +1 -1
  772. package/dist/components/FormItem/FormItemTop/FormItemTopLabel.js.map +1 -1
  773. package/dist/components/FormItem/context.js.map +1 -1
  774. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  775. package/dist/components/FormStatus/FormStatus.js.map +1 -1
  776. package/dist/components/Gallery/Gallery.js.map +1 -1
  777. package/dist/components/Gallery/hooks.d.ts +1 -1
  778. package/dist/components/Gallery/hooks.d.ts.map +1 -1
  779. package/dist/components/Gallery/hooks.js +24 -21
  780. package/dist/components/Gallery/hooks.js.map +1 -1
  781. package/dist/components/Gradient/Gradient.js.map +1 -1
  782. package/dist/components/GridAvatar/GridAvatar.d.ts +1 -1
  783. package/dist/components/GridAvatar/GridAvatar.js.map +1 -1
  784. package/dist/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.js.map +1 -1
  785. package/dist/components/Group/Group.js.map +1 -1
  786. package/dist/components/Header/Header.js.map +1 -1
  787. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  788. package/dist/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.js.map +1 -1
  789. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  790. package/dist/components/IconButton/IconButton.js.map +1 -1
  791. package/dist/components/Image/Image.d.ts +1 -1
  792. package/dist/components/Image/Image.js.map +1 -1
  793. package/dist/components/Image/ImageBadge/ImageBadge.js.map +1 -1
  794. package/dist/components/ImageBase/ImageBase.js.map +1 -1
  795. package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
  796. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  797. package/dist/components/ImageBase/context.js.map +1 -1
  798. package/dist/components/ImageBase/helpers.js.map +1 -1
  799. package/dist/components/ImageBase/types.js.map +1 -1
  800. package/dist/components/ImageBase/validators.js.map +1 -1
  801. package/dist/components/InfoRow/InfoRow.js.map +1 -1
  802. package/dist/components/Input/Input.js.map +1 -1
  803. package/dist/components/InputLike/InputLike.js.map +1 -1
  804. package/dist/components/InputLike/InputLikeDivider.d.ts.map +1 -1
  805. package/dist/components/InputLike/InputLikeDivider.js.map +1 -1
  806. package/dist/components/Link/Link.d.ts.map +1 -1
  807. package/dist/components/Link/Link.js +1 -0
  808. package/dist/components/Link/Link.js.map +1 -1
  809. package/dist/components/List/List.js.map +1 -1
  810. package/dist/components/LocaleProvider/LocaleProvider.js.map +1 -1
  811. package/dist/components/Mark/Mark.js.map +1 -1
  812. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  813. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  814. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  815. package/dist/components/ModalCardBase/ModalCardBaseCloseButton.js.map +1 -1
  816. package/dist/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  817. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  818. package/dist/components/ModalPage/ModalPageContext.js.map +1 -1
  819. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  820. package/dist/components/ModalRoot/ModalRoot.d.ts.map +1 -1
  821. package/dist/components/ModalRoot/ModalRoot.js +6 -9
  822. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  823. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  824. package/dist/components/ModalRoot/ModalRootContext.js.map +1 -1
  825. package/dist/components/ModalRoot/ModalRootDesktop.d.ts.map +1 -1
  826. package/dist/components/ModalRoot/ModalRootDesktop.js +2 -1
  827. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  828. package/dist/components/ModalRoot/constants.js.map +1 -1
  829. package/dist/components/ModalRoot/types.d.ts +0 -1
  830. package/dist/components/ModalRoot/types.d.ts.map +1 -1
  831. package/dist/components/ModalRoot/types.js.map +1 -1
  832. package/dist/components/ModalRoot/useModalManager.d.ts.map +1 -1
  833. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  834. package/dist/components/ModalRoot/useModalRootContext.js.map +1 -1
  835. package/dist/components/ModalRoot/withModalRootContext.js.map +1 -1
  836. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  837. package/dist/components/NavIdContext/NavIdContext.js.map +1 -1
  838. package/dist/components/NavIdContext/useNavId.js.map +1 -1
  839. package/dist/components/NavTransitionContext/NavTransitionContext.d.ts.map +1 -1
  840. package/dist/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  841. package/dist/components/NavTransitionDirectionContext/NavTransitionDirectionContext.d.ts.map +1 -1
  842. package/dist/components/NavTransitionDirectionContext/NavTransitionDirectionContext.js.map +1 -1
  843. package/dist/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  844. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts +1 -1
  845. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts.map +1 -1
  846. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.js.map +1 -1
  847. package/dist/components/Pagination/Pagination.js.map +1 -1
  848. package/dist/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.d.ts.map +1 -1
  849. package/dist/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.js.map +1 -1
  850. package/dist/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -1
  851. package/dist/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -1
  852. package/dist/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -1
  853. package/dist/components/Pagination/utils.js.map +1 -1
  854. package/dist/components/Panel/Panel.js.map +1 -1
  855. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  856. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  857. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  858. package/dist/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  859. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  860. package/dist/components/PanelHeaderContext/PanelHeaderContext.d.ts +2 -2
  861. package/dist/components/PanelHeaderContext/PanelHeaderContext.d.ts.map +1 -1
  862. package/dist/components/PanelHeaderContext/PanelHeaderContext.js +27 -37
  863. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  864. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  865. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  866. package/dist/components/PanelSpinner/PanelSpinner.js.map +1 -1
  867. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  868. package/dist/components/PlatformProvider/PlatformProvider.js.map +1 -1
  869. package/dist/components/PopoutRoot/PopoutRoot.d.ts.map +1 -1
  870. package/dist/components/PopoutRoot/PopoutRoot.js +0 -8
  871. package/dist/components/PopoutRoot/PopoutRoot.js.map +1 -1
  872. package/dist/components/PopoutWrapper/PopoutWrapper.d.ts.map +1 -1
  873. package/dist/components/PopoutWrapper/PopoutWrapper.js +1 -19
  874. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  875. package/dist/components/Popover/Popover.d.ts +5 -1
  876. package/dist/components/Popover/Popover.d.ts.map +1 -1
  877. package/dist/components/Popover/Popover.js +11 -5
  878. package/dist/components/Popover/Popover.js.map +1 -1
  879. package/dist/components/Popper/Popper.js.map +1 -1
  880. package/dist/components/Progress/Progress.js.map +1 -1
  881. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  882. package/dist/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  883. package/dist/components/Radio/Radio.js.map +1 -1
  884. package/dist/components/RadioGroup/RadioGroup.js.map +1 -1
  885. package/dist/components/Removable/Removable.js.map +1 -1
  886. package/dist/components/RichCell/RichCell.js.map +1 -1
  887. package/dist/components/RichCell/RichCellIcon/RichCellIcon.js.map +1 -1
  888. package/dist/components/Root/Root.d.ts.map +1 -1
  889. package/dist/components/Root/Root.js +8 -18
  890. package/dist/components/Root/Root.js.map +1 -1
  891. package/dist/components/RootComponent/RootComponent.d.ts.map +1 -1
  892. package/dist/components/RootComponent/RootComponent.js.map +1 -1
  893. package/dist/components/ScreenSpinner/Icon48CancelCircle.d.ts.map +1 -1
  894. package/dist/components/ScreenSpinner/Icon48CancelCircle.js.map +1 -1
  895. package/dist/components/ScreenSpinner/Icon48DoneOutline.d.ts.map +1 -1
  896. package/dist/components/ScreenSpinner/Icon48DoneOutline.js.map +1 -1
  897. package/dist/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  898. package/dist/components/ScrollArrow/ScrollArrow.js.map +1 -1
  899. package/dist/components/Search/Search.js.map +1 -1
  900. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  901. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  902. package/dist/components/Select/Select.d.ts.map +1 -1
  903. package/dist/components/Select/Select.js.map +1 -1
  904. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  905. package/dist/components/SelectTypography/SelectTypography.js.map +1 -1
  906. package/dist/components/Separator/Separator.js.map +1 -1
  907. package/dist/components/SimpleCell/Chevron/Chevron.js.map +1 -1
  908. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  909. package/dist/components/Skeleton/Skeleton.js.map +1 -1
  910. package/dist/components/Slider/Slider.d.ts.map +1 -1
  911. package/dist/components/Slider/Slider.js +7 -2
  912. package/dist/components/Slider/Slider.js.map +1 -1
  913. package/dist/components/Slider/SliderThumb/SliderThumb.d.ts +2 -1
  914. package/dist/components/Slider/SliderThumb/SliderThumb.d.ts.map +1 -1
  915. package/dist/components/Slider/SliderThumb/SliderThumb.js +6 -5
  916. package/dist/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
  917. package/dist/components/Slider/helpers.d.ts.map +1 -1
  918. package/dist/components/Slider/helpers.js.map +1 -1
  919. package/dist/components/Slider/types.js.map +1 -1
  920. package/dist/components/Snackbar/Snackbar.d.ts +1 -1
  921. package/dist/components/Snackbar/Snackbar.d.ts.map +1 -1
  922. package/dist/components/Snackbar/Snackbar.js +11 -10
  923. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  924. package/dist/components/Snackbar/subcomponents/Basic/Basic.js.map +1 -1
  925. package/dist/components/Snackbar/types.js.map +1 -1
  926. package/dist/components/Snackbar/utils.d.ts +0 -1
  927. package/dist/components/Snackbar/utils.d.ts.map +1 -1
  928. package/dist/components/Snackbar/utils.js.map +1 -1
  929. package/dist/components/Spacing/Spacing.js.map +1 -1
  930. package/dist/components/Spinner/Spinner.d.ts.map +1 -1
  931. package/dist/components/Spinner/Spinner.js +37 -18
  932. package/dist/components/Spinner/Spinner.js.map +1 -1
  933. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  934. package/dist/components/SplitCol/SplitColContext.js.map +1 -1
  935. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  936. package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  937. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  938. package/dist/components/Switch/Switch.d.ts +1 -1
  939. package/dist/components/Switch/Switch.d.ts.map +1 -1
  940. package/dist/components/Switch/Switch.js +41 -19
  941. package/dist/components/Switch/Switch.js.map +1 -1
  942. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  943. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  944. package/dist/components/Tabs/Tabs.js.map +1 -1
  945. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  946. package/dist/components/Tappable/Ripple.d.ts.map +1 -1
  947. package/dist/components/Tappable/Ripple.js +10 -3
  948. package/dist/components/Tappable/Ripple.js.map +1 -1
  949. package/dist/components/Tappable/Tappable.js.map +1 -1
  950. package/dist/components/Tappable/state.js.map +1 -1
  951. package/dist/components/Textarea/Textarea.d.ts.map +1 -1
  952. package/dist/components/Textarea/Textarea.js +7 -19
  953. package/dist/components/Textarea/Textarea.js.map +1 -1
  954. package/dist/components/Textarea/useResizeTextarea.d.ts +3 -0
  955. package/dist/components/Textarea/useResizeTextarea.d.ts.map +1 -0
  956. package/dist/components/Textarea/useResizeTextarea.js +34 -0
  957. package/dist/components/Textarea/useResizeTextarea.js.map +1 -0
  958. package/dist/components/ToolButton/ToolButton.js.map +1 -1
  959. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  960. package/dist/components/TooltipBase/TooltipBase.js.map +1 -1
  961. package/dist/components/Touch/Touch.js.map +1 -1
  962. package/dist/components/Touch/TouchContext.js.map +1 -1
  963. package/dist/components/Typography/Caption/Caption.d.ts +1 -1
  964. package/dist/components/Typography/Caption/Caption.d.ts.map +1 -1
  965. package/dist/components/Typography/Caption/Caption.js +4 -2
  966. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  967. package/dist/components/Typography/DisplayTitle/DisplayTitle.d.ts +11 -0
  968. package/dist/components/Typography/DisplayTitle/DisplayTitle.d.ts.map +1 -0
  969. package/dist/components/Typography/DisplayTitle/DisplayTitle.js +32 -0
  970. package/dist/components/Typography/DisplayTitle/DisplayTitle.js.map +1 -0
  971. package/dist/components/Typography/EllipsisText/EllipsisText.js.map +1 -1
  972. package/dist/components/Typography/Footnote/Footnote.d.ts +1 -1
  973. package/dist/components/Typography/Footnote/Footnote.d.ts.map +1 -1
  974. package/dist/components/Typography/Footnote/Footnote.js +4 -2
  975. package/dist/components/Typography/Footnote/Footnote.js.map +1 -1
  976. package/dist/components/Typography/Headline/Headline.d.ts +1 -1
  977. package/dist/components/Typography/Headline/Headline.d.ts.map +1 -1
  978. package/dist/components/Typography/Headline/Headline.js +4 -2
  979. package/dist/components/Typography/Headline/Headline.js.map +1 -1
  980. package/dist/components/Typography/Paragraph/Paragraph.d.ts +1 -1
  981. package/dist/components/Typography/Paragraph/Paragraph.d.ts.map +1 -1
  982. package/dist/components/Typography/Paragraph/Paragraph.js +4 -2
  983. package/dist/components/Typography/Paragraph/Paragraph.js.map +1 -1
  984. package/dist/components/Typography/Subhead/Subhead.d.ts +1 -1
  985. package/dist/components/Typography/Subhead/Subhead.d.ts.map +1 -1
  986. package/dist/components/Typography/Subhead/Subhead.js +4 -2
  987. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  988. package/dist/components/Typography/Text/Text.d.ts +1 -1
  989. package/dist/components/Typography/Text/Text.d.ts.map +1 -1
  990. package/dist/components/Typography/Text/Text.js +4 -2
  991. package/dist/components/Typography/Text/Text.js.map +1 -1
  992. package/dist/components/Typography/Title/Title.d.ts +1 -1
  993. package/dist/components/Typography/Title/Title.d.ts.map +1 -1
  994. package/dist/components/Typography/Title/Title.js +4 -2
  995. package/dist/components/Typography/Title/Title.js.map +1 -1
  996. package/dist/components/Typography/Typography.d.ts +5 -1
  997. package/dist/components/Typography/Typography.d.ts.map +1 -1
  998. package/dist/components/Typography/Typography.js +4 -3
  999. package/dist/components/Typography/Typography.js.map +1 -1
  1000. package/dist/components/UnstyledTextField/UnstyledTextField.js.map +1 -1
  1001. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  1002. package/dist/components/View/View.d.ts.map +1 -1
  1003. package/dist/components/View/View.js +36 -50
  1004. package/dist/components/View/View.js.map +1 -1
  1005. package/dist/components/View/ViewInfinite.d.ts.map +1 -1
  1006. package/dist/components/View/ViewInfinite.js +17 -19
  1007. package/dist/components/View/ViewInfinite.js.map +1 -1
  1008. package/dist/components/View/utils.js.map +1 -1
  1009. package/dist/components/VisuallyHidden/VisuallyHidden.d.ts.map +1 -1
  1010. package/dist/components/VisuallyHidden/VisuallyHidden.js.map +1 -1
  1011. package/dist/components/WriteBar/WriteBar.d.ts.map +1 -1
  1012. package/dist/components/WriteBar/WriteBar.js +3 -19
  1013. package/dist/components/WriteBar/WriteBar.js.map +1 -1
  1014. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1015. package/dist/components.css +3 -153
  1016. package/dist/components.css.map +1 -1
  1017. package/dist/components.js.tmp +25127 -69149
  1018. package/dist/cssm/components/Accordion/Accordion.js.map +1 -1
  1019. package/dist/cssm/components/Accordion/Accordion.module.css +94 -2
  1020. package/dist/cssm/components/Accordion/AccordionContent.d.ts.map +1 -1
  1021. package/dist/cssm/components/Accordion/AccordionContent.js +33 -37
  1022. package/dist/cssm/components/Accordion/AccordionContent.js.map +1 -1
  1023. package/dist/cssm/components/Accordion/AccordionContext.js.map +1 -1
  1024. package/dist/cssm/components/Accordion/AccordionSummary.js.map +1 -1
  1025. package/dist/cssm/components/ActionSheet/ActionSheet.d.ts +1 -1
  1026. package/dist/cssm/components/ActionSheet/ActionSheet.d.ts.map +1 -1
  1027. package/dist/cssm/components/ActionSheet/ActionSheet.js +22 -30
  1028. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  1029. package/dist/cssm/components/ActionSheet/ActionSheet.module.css +42 -11
  1030. package/dist/cssm/components/ActionSheet/ActionSheetContext.js.map +1 -1
  1031. package/dist/cssm/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -1
  1032. package/dist/cssm/components/ActionSheet/ActionSheetDropdownMenu.d.ts +1 -1
  1033. package/dist/cssm/components/ActionSheet/ActionSheetDropdownMenu.d.ts.map +1 -1
  1034. package/dist/cssm/components/ActionSheet/ActionSheetDropdownMenu.js +4 -2
  1035. package/dist/cssm/components/ActionSheet/ActionSheetDropdownMenu.js.map +1 -1
  1036. package/dist/cssm/components/ActionSheet/ActionSheetDropdownSheet.js +1 -1
  1037. package/dist/cssm/components/ActionSheet/ActionSheetDropdownSheet.js.map +1 -1
  1038. package/dist/cssm/components/ActionSheet/types.js.map +1 -1
  1039. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  1040. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.module.css +3 -1
  1041. package/dist/cssm/components/ActionSheetItem/subcomponents/Radio/Radio.js.map +1 -1
  1042. package/dist/cssm/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -1
  1043. package/dist/cssm/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  1044. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  1045. package/dist/cssm/components/Alert/Alert.d.ts.map +1 -1
  1046. package/dist/cssm/components/Alert/Alert.js +23 -33
  1047. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  1048. package/dist/cssm/components/Alert/Alert.module.css +31 -19
  1049. package/dist/cssm/components/Alert/AlertAction.js.map +1 -1
  1050. package/dist/cssm/components/Alert/AlertActions.js.map +1 -1
  1051. package/dist/cssm/components/Alert/AlertTypography.js.map +1 -1
  1052. package/dist/cssm/components/AppRoot/AppRoot.d.ts +14 -2
  1053. package/dist/cssm/components/AppRoot/AppRoot.d.ts.map +1 -1
  1054. package/dist/cssm/components/AppRoot/AppRoot.js +10 -3
  1055. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  1056. package/dist/cssm/components/AppRoot/AppRoot.module.css +5 -5
  1057. package/dist/cssm/components/AppRoot/AppRootContext.js.map +1 -1
  1058. package/dist/cssm/components/AppRoot/AppRootPortal.js.map +1 -1
  1059. package/dist/cssm/components/AppRoot/ScrollContext.d.ts.map +1 -1
  1060. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  1061. package/dist/cssm/components/AppRoot/helpers.d.ts +6 -1
  1062. package/dist/cssm/components/AppRoot/helpers.d.ts.map +1 -1
  1063. package/dist/cssm/components/AppRoot/helpers.js +22 -0
  1064. package/dist/cssm/components/AppRoot/helpers.js.map +1 -1
  1065. package/dist/cssm/components/AppRoot/types.d.ts +1 -0
  1066. package/dist/cssm/components/AppRoot/types.d.ts.map +1 -1
  1067. package/dist/cssm/components/AppRoot/types.js.map +1 -1
  1068. package/dist/cssm/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  1069. package/dist/cssm/components/AspectRatio/AspectRatio.js.map +1 -1
  1070. package/dist/cssm/components/Avatar/Avatar.d.ts +1 -1
  1071. package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
  1072. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadge.js.map +1 -1
  1073. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  1074. package/dist/cssm/components/Avatar/AvatarBadge/icons.d.ts.map +1 -1
  1075. package/dist/cssm/components/Avatar/AvatarBadge/icons.js.map +1 -1
  1076. package/dist/cssm/components/Avatar/helpers.js.map +1 -1
  1077. package/dist/cssm/components/Badge/Badge.js.map +1 -1
  1078. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  1079. package/dist/cssm/components/BaseGallery/BaseGallery.js.map +1 -1
  1080. package/dist/cssm/components/BaseGallery/CarouselBase/CarouselBase.js.map +1 -1
  1081. package/dist/cssm/components/BaseGallery/CarouselBase/constants.js.map +1 -1
  1082. package/dist/cssm/components/BaseGallery/CarouselBase/helpers.js.map +1 -1
  1083. package/dist/cssm/components/BaseGallery/CarouselBase/hooks.js.map +1 -1
  1084. package/dist/cssm/components/BaseGallery/CarouselBase/types.js.map +1 -1
  1085. package/dist/cssm/components/BaseGallery/helpers.js.map +1 -1
  1086. package/dist/cssm/components/BaseGallery/types.js.map +1 -1
  1087. package/dist/cssm/components/Button/Button.js.map +1 -1
  1088. package/dist/cssm/components/Button/Button.module.css +3 -6
  1089. package/dist/cssm/components/ButtonGroup/ButtonGroup.js.map +1 -1
  1090. package/dist/cssm/components/Calendar/Calendar.d.ts.map +1 -1
  1091. package/dist/cssm/components/Calendar/Calendar.js +4 -2
  1092. package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
  1093. package/dist/cssm/components/Calendar/Calendar.module.css +1 -1
  1094. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
  1095. package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
  1096. package/dist/cssm/components/CalendarHeader/CalendarHeader.d.ts +3 -1
  1097. package/dist/cssm/components/CalendarHeader/CalendarHeader.d.ts.map +1 -1
  1098. package/dist/cssm/components/CalendarHeader/CalendarHeader.js +21 -9
  1099. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
  1100. package/dist/cssm/components/CalendarRange/CalendarRange.d.ts.map +1 -1
  1101. package/dist/cssm/components/CalendarRange/CalendarRange.js +12 -5
  1102. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
  1103. package/dist/cssm/components/CalendarRange/CalendarRange.module.css +1 -1
  1104. package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -1
  1105. package/dist/cssm/components/Card/Card.js.map +1 -1
  1106. package/dist/cssm/components/Card/Card.module.css +2 -2
  1107. package/dist/cssm/components/CardGrid/CardGrid.js.map +1 -1
  1108. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  1109. package/dist/cssm/components/Cell/Cell.js.map +1 -1
  1110. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  1111. package/dist/cssm/components/Cell/CellDragger/CellDragger.js.map +1 -1
  1112. package/dist/cssm/components/Cell/constants.js.map +1 -1
  1113. package/dist/cssm/components/CellButton/CellButton.js.map +1 -1
  1114. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  1115. package/dist/cssm/components/ChipsInput/ChipsInput.d.ts.map +1 -1
  1116. package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
  1117. package/dist/cssm/components/ChipsInput/useChipsInput.d.ts.map +1 -1
  1118. package/dist/cssm/components/ChipsInput/useChipsInput.js.map +1 -1
  1119. package/dist/cssm/components/ChipsInputBase/Chip/Chip.js.map +1 -1
  1120. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.d.ts.map +1 -1
  1121. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
  1122. package/dist/cssm/components/ChipsInputBase/constants.js.map +1 -1
  1123. package/dist/cssm/components/ChipsInputBase/helpers.d.ts.map +1 -1
  1124. package/dist/cssm/components/ChipsInputBase/helpers.js.map +1 -1
  1125. package/dist/cssm/components/ChipsInputBase/types.js.map +1 -1
  1126. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts +5 -1
  1127. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts.map +1 -1
  1128. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +11 -7
  1129. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  1130. package/dist/cssm/components/ChipsSelect/constants.d.ts.map +1 -1
  1131. package/dist/cssm/components/ChipsSelect/constants.js.map +1 -1
  1132. package/dist/cssm/components/ChipsSelect/types.js.map +1 -1
  1133. package/dist/cssm/components/ChipsSelect/useChipsSelect.d.ts +10 -2
  1134. package/dist/cssm/components/ChipsSelect/useChipsSelect.d.ts.map +1 -1
  1135. package/dist/cssm/components/ChipsSelect/useChipsSelect.js +12 -4
  1136. package/dist/cssm/components/ChipsSelect/useChipsSelect.js.map +1 -1
  1137. package/dist/cssm/components/Clickable/Clickable.d.ts.map +1 -1
  1138. package/dist/cssm/components/Clickable/Clickable.js.map +1 -1
  1139. package/dist/cssm/components/Clickable/useKeyboard.d.ts.map +1 -1
  1140. package/dist/cssm/components/Clickable/useKeyboard.js.map +1 -1
  1141. package/dist/cssm/components/Clickable/useState.d.ts.map +1 -1
  1142. package/dist/cssm/components/Clickable/useState.js.map +1 -1
  1143. package/dist/cssm/components/Clickable/useStateWithDelay.js.map +1 -1
  1144. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  1145. package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  1146. package/dist/cssm/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  1147. package/dist/cssm/components/ContentBadge/ContentBadge.js.map +1 -1
  1148. package/dist/cssm/components/ContentBadge/ContentBadgeContext.js.map +1 -1
  1149. package/dist/cssm/components/ContentBadge/ContentBadgeSlotIcon.js.map +1 -1
  1150. package/dist/cssm/components/ContentBadge/types.js.map +1 -1
  1151. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  1152. package/dist/cssm/components/Counter/Counter.js.map +1 -1
  1153. package/dist/cssm/components/CustomScrollView/CustomScrollView.js.map +1 -1
  1154. package/dist/cssm/components/CustomScrollView/CustomScrollView.module.css +3 -1
  1155. package/dist/cssm/components/CustomScrollView/useTrackerVisibility.d.ts.map +1 -1
  1156. package/dist/cssm/components/CustomScrollView/useTrackerVisibility.js +31 -37
  1157. package/dist/cssm/components/CustomScrollView/useTrackerVisibility.js.map +1 -1
  1158. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +5 -2
  1159. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts.map +1 -1
  1160. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  1161. package/dist/cssm/components/CustomSelect/CustomSelectClearButton.js.map +1 -1
  1162. package/dist/cssm/components/CustomSelect/CustomSelectInput.js.map +1 -1
  1163. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  1164. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.module.css +1 -1
  1165. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  1166. package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
  1167. package/dist/cssm/components/DatePicker/DatePicker.d.ts +6 -0
  1168. package/dist/cssm/components/DatePicker/DatePicker.d.ts.map +1 -1
  1169. package/dist/cssm/components/DatePicker/DatePicker.js +6 -0
  1170. package/dist/cssm/components/DatePicker/DatePicker.js.map +1 -1
  1171. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  1172. package/dist/cssm/components/Div/Div.js.map +1 -1
  1173. package/dist/cssm/components/DropZone/DropZone.js.map +1 -1
  1174. package/dist/cssm/components/DropZone/components/DropZoneGrid.js.map +1 -1
  1175. package/dist/cssm/components/DropdownIcon/DropdownIcon.js.map +1 -1
  1176. package/dist/cssm/components/Epic/Epic.js.map +1 -1
  1177. package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
  1178. package/dist/cssm/components/File/File.js.map +1 -1
  1179. package/dist/cssm/components/FixedLayout/FixedLayout.d.ts.map +1 -1
  1180. package/dist/cssm/components/FixedLayout/FixedLayout.js +19 -5
  1181. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  1182. package/dist/cssm/components/Flex/Flex.d.ts +42 -0
  1183. package/dist/cssm/components/Flex/Flex.d.ts.map +1 -0
  1184. package/dist/cssm/components/Flex/Flex.js +42 -0
  1185. package/dist/cssm/components/Flex/Flex.js.map +1 -0
  1186. package/dist/cssm/components/Flex/Flex.module.css +90 -0
  1187. package/dist/cssm/components/Flex/FlexItem/FlexItem.d.ts +20 -0
  1188. package/dist/cssm/components/Flex/FlexItem/FlexItem.d.ts.map +1 -0
  1189. package/dist/cssm/components/Flex/FlexItem/FlexItem.js +30 -0
  1190. package/dist/cssm/components/Flex/FlexItem/FlexItem.js.map +1 -0
  1191. package/dist/cssm/components/Flex/FlexItem/FlexItem.module.css +43 -0
  1192. package/dist/cssm/components/FloatingArrow/DefaultIcon.d.ts.map +1 -1
  1193. package/dist/cssm/components/FloatingArrow/DefaultIcon.js.map +1 -1
  1194. package/dist/cssm/components/FloatingArrow/FloatingArrow.js +14 -4
  1195. package/dist/cssm/components/FloatingArrow/FloatingArrow.js.map +1 -1
  1196. package/dist/cssm/components/FocusTrap/FocusTrap.d.ts +6 -1
  1197. package/dist/cssm/components/FocusTrap/FocusTrap.d.ts.map +1 -1
  1198. package/dist/cssm/components/FocusTrap/FocusTrap.js +43 -20
  1199. package/dist/cssm/components/FocusTrap/FocusTrap.js.map +1 -1
  1200. package/dist/cssm/components/Footer/Footer.js.map +1 -1
  1201. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  1202. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  1203. package/dist/cssm/components/FormItem/FormItemTop/FormItemTop.js.map +1 -1
  1204. package/dist/cssm/components/FormItem/FormItemTop/FormItemTopAside.js.map +1 -1
  1205. package/dist/cssm/components/FormItem/FormItemTop/FormItemTopLabel.js.map +1 -1
  1206. package/dist/cssm/components/FormItem/context.js.map +1 -1
  1207. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  1208. package/dist/cssm/components/FormStatus/FormStatus.js.map +1 -1
  1209. package/dist/cssm/components/Gallery/Gallery.js.map +1 -1
  1210. package/dist/cssm/components/Gallery/hooks.d.ts +1 -1
  1211. package/dist/cssm/components/Gallery/hooks.d.ts.map +1 -1
  1212. package/dist/cssm/components/Gallery/hooks.js +24 -21
  1213. package/dist/cssm/components/Gallery/hooks.js.map +1 -1
  1214. package/dist/cssm/components/Gradient/Gradient.js.map +1 -1
  1215. package/dist/cssm/components/GridAvatar/GridAvatar.d.ts +1 -1
  1216. package/dist/cssm/components/GridAvatar/GridAvatar.js.map +1 -1
  1217. package/dist/cssm/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.js.map +1 -1
  1218. package/dist/cssm/components/Group/Group.js.map +1 -1
  1219. package/dist/cssm/components/Header/Header.js.map +1 -1
  1220. package/dist/cssm/components/Header/Header.module.css +0 -4
  1221. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  1222. package/dist/cssm/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.js.map +1 -1
  1223. package/dist/cssm/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.module.css +2 -2
  1224. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  1225. package/dist/cssm/components/IconButton/IconButton.js.map +1 -1
  1226. package/dist/cssm/components/Image/Image.d.ts +1 -1
  1227. package/dist/cssm/components/Image/Image.js.map +1 -1
  1228. package/dist/cssm/components/Image/ImageBadge/ImageBadge.js.map +1 -1
  1229. package/dist/cssm/components/ImageBase/ImageBase.js.map +1 -1
  1230. package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
  1231. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  1232. package/dist/cssm/components/ImageBase/context.js.map +1 -1
  1233. package/dist/cssm/components/ImageBase/helpers.js.map +1 -1
  1234. package/dist/cssm/components/ImageBase/types.js.map +1 -1
  1235. package/dist/cssm/components/ImageBase/validators.js.map +1 -1
  1236. package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
  1237. package/dist/cssm/components/Input/Input.js.map +1 -1
  1238. package/dist/cssm/components/InputLike/InputLike.js.map +1 -1
  1239. package/dist/cssm/components/InputLike/InputLikeDivider.d.ts.map +1 -1
  1240. package/dist/cssm/components/InputLike/InputLikeDivider.js.map +1 -1
  1241. package/dist/cssm/components/Link/Link.d.ts.map +1 -1
  1242. package/dist/cssm/components/Link/Link.js +1 -0
  1243. package/dist/cssm/components/Link/Link.js.map +1 -1
  1244. package/dist/cssm/components/Link/Link.module.css +0 -2
  1245. package/dist/cssm/components/List/List.js.map +1 -1
  1246. package/dist/cssm/components/LocaleProvider/LocaleProvider.js.map +1 -1
  1247. package/dist/cssm/components/Mark/Mark.js.map +1 -1
  1248. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  1249. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  1250. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  1251. package/dist/cssm/components/ModalCardBase/ModalCardBaseCloseButton.js.map +1 -1
  1252. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  1253. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  1254. package/dist/cssm/components/ModalPage/ModalPageContext.js.map +1 -1
  1255. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  1256. package/dist/cssm/components/ModalRoot/ModalRoot.d.ts.map +1 -1
  1257. package/dist/cssm/components/ModalRoot/ModalRoot.js +6 -7
  1258. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  1259. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  1260. package/dist/cssm/components/ModalRoot/ModalRootContext.js.map +1 -1
  1261. package/dist/cssm/components/ModalRoot/ModalRootDesktop.d.ts.map +1 -1
  1262. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +2 -1
  1263. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  1264. package/dist/cssm/components/ModalRoot/constants.js.map +1 -1
  1265. package/dist/cssm/components/ModalRoot/types.d.ts +0 -1
  1266. package/dist/cssm/components/ModalRoot/types.d.ts.map +1 -1
  1267. package/dist/cssm/components/ModalRoot/types.js.map +1 -1
  1268. package/dist/cssm/components/ModalRoot/useModalManager.d.ts.map +1 -1
  1269. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  1270. package/dist/cssm/components/ModalRoot/useModalRootContext.js.map +1 -1
  1271. package/dist/cssm/components/ModalRoot/withModalRootContext.js.map +1 -1
  1272. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  1273. package/dist/cssm/components/NavIdContext/NavIdContext.js.map +1 -1
  1274. package/dist/cssm/components/NavIdContext/useNavId.js.map +1 -1
  1275. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.d.ts.map +1 -1
  1276. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  1277. package/dist/cssm/components/NavTransitionDirectionContext/NavTransitionDirectionContext.d.ts.map +1 -1
  1278. package/dist/cssm/components/NavTransitionDirectionContext/NavTransitionDirectionContext.js.map +1 -1
  1279. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  1280. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts +1 -1
  1281. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts.map +1 -1
  1282. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContainer.js.map +1 -1
  1283. package/dist/cssm/components/Pagination/Pagination.js.map +1 -1
  1284. package/dist/cssm/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.d.ts.map +1 -1
  1285. package/dist/cssm/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.js.map +1 -1
  1286. package/dist/cssm/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -1
  1287. package/dist/cssm/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -1
  1288. package/dist/cssm/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -1
  1289. package/dist/cssm/components/Pagination/utils.js.map +1 -1
  1290. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  1291. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  1292. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  1293. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  1294. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  1295. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  1296. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.d.ts +2 -2
  1297. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.d.ts.map +1 -1
  1298. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js +22 -32
  1299. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  1300. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.module.css +34 -30
  1301. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  1302. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  1303. package/dist/cssm/components/PanelSpinner/PanelSpinner.js.map +1 -1
  1304. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  1305. package/dist/cssm/components/PlatformProvider/PlatformProvider.js.map +1 -1
  1306. package/dist/cssm/components/PopoutRoot/PopoutRoot.d.ts.map +1 -1
  1307. package/dist/cssm/components/PopoutRoot/PopoutRoot.js +0 -8
  1308. package/dist/cssm/components/PopoutRoot/PopoutRoot.js.map +1 -1
  1309. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.d.ts.map +1 -1
  1310. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +1 -19
  1311. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  1312. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.module.css +16 -2
  1313. package/dist/cssm/components/Popover/Popover.d.ts +5 -1
  1314. package/dist/cssm/components/Popover/Popover.d.ts.map +1 -1
  1315. package/dist/cssm/components/Popover/Popover.js +10 -5
  1316. package/dist/cssm/components/Popover/Popover.js.map +1 -1
  1317. package/dist/cssm/components/Popover/Popover.module.css +6 -2
  1318. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  1319. package/dist/cssm/components/Progress/Progress.js.map +1 -1
  1320. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  1321. package/dist/cssm/components/PullToRefresh/PullToRefresh.module.css +3 -1
  1322. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  1323. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  1324. package/dist/cssm/components/RadioGroup/RadioGroup.js.map +1 -1
  1325. package/dist/cssm/components/Removable/Removable.js.map +1 -1
  1326. package/dist/cssm/components/Removable/Removable.module.css +1 -6
  1327. package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
  1328. package/dist/cssm/components/RichCell/RichCellIcon/RichCellIcon.js.map +1 -1
  1329. package/dist/cssm/components/Root/Root.d.ts.map +1 -1
  1330. package/dist/cssm/components/Root/Root.js +8 -18
  1331. package/dist/cssm/components/Root/Root.js.map +1 -1
  1332. package/dist/cssm/components/Root/Root.module.css +44 -51
  1333. package/dist/cssm/components/RootComponent/RootComponent.d.ts.map +1 -1
  1334. package/dist/cssm/components/RootComponent/RootComponent.js.map +1 -1
  1335. package/dist/cssm/components/ScreenSpinner/Icon48CancelCircle.d.ts.map +1 -1
  1336. package/dist/cssm/components/ScreenSpinner/Icon48CancelCircle.js.map +1 -1
  1337. package/dist/cssm/components/ScreenSpinner/Icon48DoneOutline.d.ts.map +1 -1
  1338. package/dist/cssm/components/ScreenSpinner/Icon48DoneOutline.js.map +1 -1
  1339. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  1340. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.module.css +1 -1
  1341. package/dist/cssm/components/ScrollArrow/ScrollArrow.js.map +1 -1
  1342. package/dist/cssm/components/ScrollArrow/ScrollArrow.module.css +1 -1
  1343. package/dist/cssm/components/Search/Search.js.map +1 -1
  1344. package/dist/cssm/components/Search/Search.module.css +4 -1
  1345. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  1346. package/dist/cssm/components/SegmentedControl/SegmentedControl.module.css +3 -1
  1347. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  1348. package/dist/cssm/components/Select/Select.d.ts.map +1 -1
  1349. package/dist/cssm/components/Select/Select.js.map +1 -1
  1350. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  1351. package/dist/cssm/components/SelectTypography/SelectTypography.js.map +1 -1
  1352. package/dist/cssm/components/Separator/Separator.js.map +1 -1
  1353. package/dist/cssm/components/SimpleCell/Chevron/Chevron.js.map +1 -1
  1354. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  1355. package/dist/cssm/components/Skeleton/Skeleton.js.map +1 -1
  1356. package/dist/cssm/components/Skeleton/Skeleton.module.css +7 -0
  1357. package/dist/cssm/components/Slider/Slider.d.ts.map +1 -1
  1358. package/dist/cssm/components/Slider/Slider.js +7 -2
  1359. package/dist/cssm/components/Slider/Slider.js.map +1 -1
  1360. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.d.ts +2 -1
  1361. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.d.ts.map +1 -1
  1362. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.js +4 -4
  1363. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
  1364. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.module.css +10 -2
  1365. package/dist/cssm/components/Slider/helpers.d.ts.map +1 -1
  1366. package/dist/cssm/components/Slider/helpers.js.map +1 -1
  1367. package/dist/cssm/components/Slider/types.js.map +1 -1
  1368. package/dist/cssm/components/Snackbar/Snackbar.d.ts +1 -1
  1369. package/dist/cssm/components/Snackbar/Snackbar.d.ts.map +1 -1
  1370. package/dist/cssm/components/Snackbar/Snackbar.js +11 -10
  1371. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  1372. package/dist/cssm/components/Snackbar/Snackbar.module.css +72 -112
  1373. package/dist/cssm/components/Snackbar/subcomponents/Basic/Basic.js.map +1 -1
  1374. package/dist/cssm/components/Snackbar/types.js.map +1 -1
  1375. package/dist/cssm/components/Snackbar/utils.d.ts +0 -1
  1376. package/dist/cssm/components/Snackbar/utils.d.ts.map +1 -1
  1377. package/dist/cssm/components/Snackbar/utils.js.map +1 -1
  1378. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  1379. package/dist/cssm/components/Spacing/Spacing.module.css +1 -0
  1380. package/dist/cssm/components/Spinner/Spinner.d.ts.map +1 -1
  1381. package/dist/cssm/components/Spinner/Spinner.js +37 -18
  1382. package/dist/cssm/components/Spinner/Spinner.js.map +1 -1
  1383. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  1384. package/dist/cssm/components/SplitCol/SplitColContext.js.map +1 -1
  1385. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  1386. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  1387. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  1388. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.module.css +1 -1
  1389. package/dist/cssm/components/Switch/Switch.d.ts +1 -1
  1390. package/dist/cssm/components/Switch/Switch.d.ts.map +1 -1
  1391. package/dist/cssm/components/Switch/Switch.js +37 -19
  1392. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  1393. package/dist/cssm/components/Switch/Switch.module.css +198 -142
  1394. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  1395. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  1396. package/dist/cssm/components/Tabs/Tabs.js.map +1 -1
  1397. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  1398. package/dist/cssm/components/TabsItem/TabsItem.module.css +4 -2
  1399. package/dist/cssm/components/Tappable/Ripple.d.ts.map +1 -1
  1400. package/dist/cssm/components/Tappable/Ripple.js +10 -3
  1401. package/dist/cssm/components/Tappable/Ripple.js.map +1 -1
  1402. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  1403. package/dist/cssm/components/Tappable/Tappable.module.css +0 -2
  1404. package/dist/cssm/components/Tappable/state.js.map +1 -1
  1405. package/dist/cssm/components/Textarea/Textarea.d.ts.map +1 -1
  1406. package/dist/cssm/components/Textarea/Textarea.js +7 -19
  1407. package/dist/cssm/components/Textarea/Textarea.js.map +1 -1
  1408. package/dist/cssm/components/Textarea/useResizeTextarea.d.ts +3 -0
  1409. package/dist/cssm/components/Textarea/useResizeTextarea.d.ts.map +1 -0
  1410. package/dist/cssm/components/Textarea/useResizeTextarea.js +34 -0
  1411. package/dist/cssm/components/Textarea/useResizeTextarea.js.map +1 -0
  1412. package/dist/cssm/components/ToolButton/ToolButton.js.map +1 -1
  1413. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  1414. package/dist/cssm/components/TooltipBase/TooltipBase.js.map +1 -1
  1415. package/dist/cssm/components/TooltipBase/TooltipBase.module.css +2 -2
  1416. package/dist/cssm/components/Touch/Touch.js.map +1 -1
  1417. package/dist/cssm/components/Touch/TouchContext.js.map +1 -1
  1418. package/dist/cssm/components/Typography/Caption/Caption.d.ts +1 -1
  1419. package/dist/cssm/components/Typography/Caption/Caption.d.ts.map +1 -1
  1420. package/dist/cssm/components/Typography/Caption/Caption.js +2 -1
  1421. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  1422. package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.d.ts +11 -0
  1423. package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.d.ts.map +1 -0
  1424. package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.js +25 -0
  1425. package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.js.map +1 -0
  1426. package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.module.css +27 -0
  1427. package/dist/cssm/components/Typography/EllipsisText/EllipsisText.js.map +1 -1
  1428. package/dist/cssm/components/Typography/Footnote/Footnote.d.ts +1 -1
  1429. package/dist/cssm/components/Typography/Footnote/Footnote.d.ts.map +1 -1
  1430. package/dist/cssm/components/Typography/Footnote/Footnote.js +2 -1
  1431. package/dist/cssm/components/Typography/Footnote/Footnote.js.map +1 -1
  1432. package/dist/cssm/components/Typography/Headline/Headline.d.ts +1 -1
  1433. package/dist/cssm/components/Typography/Headline/Headline.d.ts.map +1 -1
  1434. package/dist/cssm/components/Typography/Headline/Headline.js +2 -1
  1435. package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
  1436. package/dist/cssm/components/Typography/Paragraph/Paragraph.d.ts +1 -1
  1437. package/dist/cssm/components/Typography/Paragraph/Paragraph.d.ts.map +1 -1
  1438. package/dist/cssm/components/Typography/Paragraph/Paragraph.js +2 -1
  1439. package/dist/cssm/components/Typography/Paragraph/Paragraph.js.map +1 -1
  1440. package/dist/cssm/components/Typography/Subhead/Subhead.d.ts +1 -1
  1441. package/dist/cssm/components/Typography/Subhead/Subhead.d.ts.map +1 -1
  1442. package/dist/cssm/components/Typography/Subhead/Subhead.js +2 -1
  1443. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  1444. package/dist/cssm/components/Typography/Text/Text.d.ts +1 -1
  1445. package/dist/cssm/components/Typography/Text/Text.d.ts.map +1 -1
  1446. package/dist/cssm/components/Typography/Text/Text.js +2 -1
  1447. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  1448. package/dist/cssm/components/Typography/Title/Title.d.ts +1 -1
  1449. package/dist/cssm/components/Typography/Title/Title.d.ts.map +1 -1
  1450. package/dist/cssm/components/Typography/Title/Title.js +2 -1
  1451. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  1452. package/dist/cssm/components/Typography/Typography.d.ts +5 -1
  1453. package/dist/cssm/components/Typography/Typography.d.ts.map +1 -1
  1454. package/dist/cssm/components/Typography/Typography.js +2 -2
  1455. package/dist/cssm/components/Typography/Typography.js.map +1 -1
  1456. package/dist/cssm/components/Typography/Typography.module.css +4 -0
  1457. package/dist/cssm/components/UnstyledTextField/UnstyledTextField.js.map +1 -1
  1458. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  1459. package/dist/cssm/components/View/View.d.ts.map +1 -1
  1460. package/dist/cssm/components/View/View.js +36 -49
  1461. package/dist/cssm/components/View/View.js.map +1 -1
  1462. package/dist/cssm/components/View/View.module.css +105 -83
  1463. package/dist/cssm/components/View/ViewInfinite.d.ts.map +1 -1
  1464. package/dist/cssm/components/View/ViewInfinite.js +17 -19
  1465. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  1466. package/dist/cssm/components/View/utils.js.map +1 -1
  1467. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.d.ts.map +1 -1
  1468. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.js.map +1 -1
  1469. package/dist/cssm/components/WriteBar/WriteBar.d.ts.map +1 -1
  1470. package/dist/cssm/components/WriteBar/WriteBar.js +3 -19
  1471. package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
  1472. package/dist/cssm/components/WriteBar/WriteBar.module.css +1 -1
  1473. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1474. package/dist/cssm/helpers/avatar.js.map +1 -1
  1475. package/dist/cssm/helpers/getMergedSameEventsByProps.d.ts +1 -1
  1476. package/dist/cssm/helpers/getMergedSameEventsByProps.d.ts.map +1 -1
  1477. package/dist/cssm/helpers/getMergedSameEventsByProps.js.map +1 -1
  1478. package/dist/cssm/helpers/getOrDefault.js.map +1 -1
  1479. package/dist/cssm/helpers/math.js.map +1 -1
  1480. package/dist/cssm/helpers/range.js.map +1 -1
  1481. package/dist/cssm/hoc/withContext.js.map +1 -1
  1482. package/dist/cssm/hoc/withPlatform.js.map +1 -1
  1483. package/dist/cssm/hooks/useAdaptivity.js.map +1 -1
  1484. package/dist/cssm/hooks/useAdaptivityConditionalRender/constants.js.map +1 -1
  1485. package/dist/cssm/hooks/useAdaptivityConditionalRender/helpers.d.ts +3 -3
  1486. package/dist/cssm/hooks/useAdaptivityConditionalRender/helpers.d.ts.map +1 -1
  1487. package/dist/cssm/hooks/useAdaptivityConditionalRender/helpers.js.map +1 -1
  1488. package/dist/cssm/hooks/useAdaptivityConditionalRender/index.js.map +1 -1
  1489. package/dist/cssm/hooks/useAdaptivityConditionalRender/types.js.map +1 -1
  1490. package/dist/cssm/hooks/useAdaptivityConditionalRender/useAdaptivityConditionalRender.js.map +1 -1
  1491. package/dist/cssm/hooks/useAdaptivityHasPointer.js.map +1 -1
  1492. package/dist/cssm/hooks/useAdaptivityWithJSMediaQueries.js.map +1 -1
  1493. package/dist/cssm/hooks/useAppearance.js.map +1 -1
  1494. package/dist/cssm/hooks/useAutoDetectAppearance.js.map +1 -1
  1495. package/dist/cssm/hooks/useAutoFocus.js.map +1 -1
  1496. package/dist/cssm/hooks/useBooleanState.js.map +1 -1
  1497. package/dist/cssm/hooks/useCalendar.d.ts +2 -0
  1498. package/dist/cssm/hooks/useCalendar.d.ts.map +1 -1
  1499. package/dist/cssm/hooks/useCalendar.js +44 -2
  1500. package/dist/cssm/hooks/useCalendar.js.map +1 -1
  1501. package/dist/cssm/hooks/useDateInput.d.ts.map +1 -1
  1502. package/dist/cssm/hooks/useDateInput.js.map +1 -1
  1503. package/dist/cssm/hooks/useDirection.js.map +1 -1
  1504. package/dist/cssm/hooks/useDraggableWithDomApi/autoScroll.js.map +1 -1
  1505. package/dist/cssm/hooks/useDraggableWithDomApi/constants.js.map +1 -1
  1506. package/dist/cssm/hooks/useDraggableWithDomApi/index.js.map +1 -1
  1507. package/dist/cssm/hooks/useDraggableWithDomApi/types.js.map +1 -1
  1508. package/dist/cssm/hooks/useDraggableWithDomApi/useDraggableWithDomApi.d.ts.map +1 -1
  1509. package/dist/cssm/hooks/useDraggableWithDomApi/useDraggableWithDomApi.js.map +1 -1
  1510. package/dist/cssm/hooks/useDraggableWithDomApi/utils.d.ts +2 -2
  1511. package/dist/cssm/hooks/useDraggableWithDomApi/utils.d.ts.map +1 -1
  1512. package/dist/cssm/hooks/useDraggableWithDomApi/utils.js.map +1 -1
  1513. package/dist/cssm/hooks/useEffectDev.js.map +1 -1
  1514. package/dist/cssm/hooks/useEnsuredControl.js.map +1 -1
  1515. package/dist/cssm/hooks/useEventListener.js.map +1 -1
  1516. package/dist/cssm/hooks/useExternRef.js.map +1 -1
  1517. package/dist/cssm/hooks/useFocusVisible.d.ts.map +1 -1
  1518. package/dist/cssm/hooks/useFocusVisible.js.map +1 -1
  1519. package/dist/cssm/hooks/useFocusVisibleClassName.js.map +1 -1
  1520. package/dist/cssm/hooks/useFocusWithin.js.map +1 -1
  1521. package/dist/cssm/hooks/useGlobalEscKeyDown.js.map +1 -1
  1522. package/dist/cssm/hooks/useGlobalEventListener.js.map +1 -1
  1523. package/dist/cssm/hooks/useGlobalOnClickOutside.d.ts +1 -1
  1524. package/dist/cssm/hooks/useGlobalOnClickOutside.d.ts.map +1 -1
  1525. package/dist/cssm/hooks/useGlobalOnClickOutside.js.map +1 -1
  1526. package/dist/cssm/hooks/useIsClient.js.map +1 -1
  1527. package/dist/cssm/hooks/useKeyboard.js.map +1 -1
  1528. package/dist/cssm/hooks/useKeyboardInputTracker.js.map +1 -1
  1529. package/dist/cssm/hooks/useMediaQueries.d.ts.map +1 -1
  1530. package/dist/cssm/hooks/useMediaQueries.js +21 -18
  1531. package/dist/cssm/hooks/useMediaQueries.js.map +1 -1
  1532. package/dist/cssm/hooks/useNativeFormResetListener.d.ts.map +1 -1
  1533. package/dist/cssm/hooks/useNativeFormResetListener.js.map +1 -1
  1534. package/dist/cssm/hooks/useObjectMemo.js.map +1 -1
  1535. package/dist/cssm/hooks/useOrientationChange.js.map +1 -1
  1536. package/dist/cssm/hooks/usePagination.d.ts.map +1 -1
  1537. package/dist/cssm/hooks/usePagination.js.map +1 -1
  1538. package/dist/cssm/hooks/usePatchChildren.d.ts.map +1 -1
  1539. package/dist/cssm/hooks/usePatchChildren.js.map +1 -1
  1540. package/dist/cssm/hooks/usePlatform.js.map +1 -1
  1541. package/dist/cssm/hooks/usePrevious.js.map +1 -1
  1542. package/dist/cssm/hooks/useResizeObserver.d.ts +1 -1
  1543. package/dist/cssm/hooks/useResizeObserver.d.ts.map +1 -1
  1544. package/dist/cssm/hooks/useResizeObserver.js +5 -4
  1545. package/dist/cssm/hooks/useResizeObserver.js.map +1 -1
  1546. package/dist/cssm/hooks/useStableCallback.js.map +1 -1
  1547. package/dist/cssm/hooks/useTodayDate.js.map +1 -1
  1548. package/dist/cssm/hooks/useWaitTransitionFinish.d.ts +1 -3
  1549. package/dist/cssm/hooks/useWaitTransitionFinish.d.ts.map +1 -1
  1550. package/dist/cssm/hooks/useWaitTransitionFinish.js +4 -9
  1551. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  1552. package/dist/cssm/index.d.ts +7 -1
  1553. package/dist/cssm/index.d.ts.map +1 -1
  1554. package/dist/cssm/index.js +3 -0
  1555. package/dist/cssm/index.js.map +1 -1
  1556. package/dist/cssm/lib/SSR.js.map +1 -1
  1557. package/dist/cssm/lib/accessibility.d.ts +1 -1
  1558. package/dist/cssm/lib/accessibility.d.ts.map +1 -1
  1559. package/dist/cssm/lib/accessibility.js +1 -0
  1560. package/dist/cssm/lib/accessibility.js.map +1 -1
  1561. package/dist/cssm/lib/adaptivity/constants.js.map +1 -1
  1562. package/dist/cssm/lib/adaptivity/functions.js.map +1 -1
  1563. package/dist/cssm/lib/adaptivity/index.js.map +1 -1
  1564. package/dist/cssm/lib/adaptivity/types.js.map +1 -1
  1565. package/dist/cssm/lib/animate.js.map +1 -1
  1566. package/dist/cssm/lib/animation/fades.js.map +1 -1
  1567. package/dist/cssm/lib/animation/index.d.ts +1 -0
  1568. package/dist/cssm/lib/animation/index.d.ts.map +1 -1
  1569. package/dist/cssm/lib/animation/index.js +1 -0
  1570. package/dist/cssm/lib/animation/index.js.map +1 -1
  1571. package/dist/cssm/lib/animation/rubberbandIfOutOfBounds.js.map +1 -1
  1572. package/dist/cssm/lib/animation/transformOrigin.js.map +1 -1
  1573. package/dist/cssm/lib/animation/useCSSKeyframesAnimationController.d.ts +1 -1
  1574. package/dist/cssm/lib/animation/useCSSKeyframesAnimationController.d.ts.map +1 -1
  1575. package/dist/cssm/lib/animation/useCSSKeyframesAnimationController.js +5 -6
  1576. package/dist/cssm/lib/animation/useCSSKeyframesAnimationController.js.map +1 -1
  1577. package/dist/cssm/lib/animation/useReducedMotion.js.map +1 -1
  1578. package/dist/cssm/lib/appearance/index.js.map +1 -1
  1579. package/dist/cssm/lib/appearance/types.js.map +1 -1
  1580. package/dist/cssm/lib/browser.js.map +1 -1
  1581. package/dist/cssm/lib/calendar.js.map +1 -1
  1582. package/dist/cssm/lib/callMultiple.js.map +1 -1
  1583. package/dist/cssm/lib/children.d.ts.map +1 -1
  1584. package/dist/cssm/lib/children.js.map +1 -1
  1585. package/dist/cssm/lib/comparing.js.map +1 -1
  1586. package/dist/cssm/lib/createPortal.d.ts.map +1 -1
  1587. package/dist/cssm/lib/createPortal.js.map +1 -1
  1588. package/dist/cssm/lib/date.js.map +1 -1
  1589. package/dist/cssm/lib/dom.d.ts +0 -1
  1590. package/dist/cssm/lib/dom.d.ts.map +1 -1
  1591. package/dist/cssm/lib/dom.js.map +1 -1
  1592. package/dist/cssm/lib/floating/adapters.js.map +1 -1
  1593. package/dist/cssm/lib/floating/customResizeObserver.js.map +1 -1
  1594. package/dist/cssm/lib/floating/functions.d.ts +1 -1
  1595. package/dist/cssm/lib/floating/functions.js.map +1 -1
  1596. package/dist/cssm/lib/floating/index.js.map +1 -1
  1597. package/dist/cssm/lib/floating/types/common.js.map +1 -1
  1598. package/dist/cssm/lib/floating/types/component.js.map +1 -1
  1599. package/dist/cssm/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts +1 -11
  1600. package/dist/cssm/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts.map +1 -1
  1601. package/dist/cssm/lib/floating/useFloatingMiddlewaresBootstrap/index.js.map +1 -1
  1602. package/dist/cssm/lib/floating/useFloatingWithInteractions/constants.js.map +1 -1
  1603. package/dist/cssm/lib/floating/useFloatingWithInteractions/index.js.map +1 -1
  1604. package/dist/cssm/lib/floating/useFloatingWithInteractions/types.d.ts +0 -1
  1605. package/dist/cssm/lib/floating/useFloatingWithInteractions/types.d.ts.map +1 -1
  1606. package/dist/cssm/lib/floating/useFloatingWithInteractions/types.js.map +1 -1
  1607. package/dist/cssm/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.d.ts.map +1 -1
  1608. package/dist/cssm/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
  1609. package/dist/cssm/lib/floating/useFloatingWithInteractions/useResolveTriggerType.js.map +1 -1
  1610. package/dist/cssm/lib/floating/usePlacementChangeCallback.js.map +1 -1
  1611. package/dist/cssm/lib/fx.js.map +1 -1
  1612. package/dist/cssm/lib/getNavId.js.map +1 -1
  1613. package/dist/cssm/lib/isRefObject.d.ts.map +1 -1
  1614. package/dist/cssm/lib/isRefObject.js.map +1 -1
  1615. package/dist/cssm/lib/layouts/gaps.d.ts +32 -0
  1616. package/dist/cssm/lib/layouts/gaps.d.ts.map +1 -0
  1617. package/dist/cssm/lib/layouts/gaps.js +42 -0
  1618. package/dist/cssm/lib/layouts/gaps.js.map +1 -0
  1619. package/dist/cssm/lib/layouts/index.d.ts +2 -0
  1620. package/dist/cssm/lib/layouts/index.d.ts.map +1 -0
  1621. package/dist/cssm/lib/layouts/index.js +3 -0
  1622. package/dist/cssm/lib/layouts/index.js.map +1 -0
  1623. package/dist/cssm/lib/matchMedia.js.map +1 -1
  1624. package/dist/cssm/lib/mergeCalls.js.map +1 -1
  1625. package/dist/cssm/lib/offset.js.map +1 -1
  1626. package/dist/cssm/lib/platform.js.map +1 -1
  1627. package/dist/cssm/lib/rafSchd.d.ts.map +1 -1
  1628. package/dist/cssm/lib/rafSchd.js.map +1 -1
  1629. package/dist/cssm/lib/react/index.js.map +1 -1
  1630. package/dist/cssm/lib/react/simulateReactInput.js.map +1 -1
  1631. package/dist/cssm/lib/removeObjectKeys.js.map +1 -1
  1632. package/dist/cssm/lib/select.js.map +1 -1
  1633. package/dist/cssm/lib/styles.js.map +1 -1
  1634. package/dist/cssm/lib/testing.js.map +1 -1
  1635. package/dist/cssm/lib/tokens/TokensClassProvider.js.map +1 -1
  1636. package/dist/cssm/lib/tokens/constants.js.map +1 -1
  1637. package/dist/cssm/lib/tokens/index.js.map +1 -1
  1638. package/dist/cssm/lib/tokens/types.js.map +1 -1
  1639. package/dist/cssm/lib/tokens/useTokenClassName.js.map +1 -1
  1640. package/dist/cssm/lib/touch/UIPanGestureRecognizer.js.map +1 -1
  1641. package/dist/cssm/lib/touch/functions.js.map +1 -1
  1642. package/dist/cssm/lib/touch/index.js.map +1 -1
  1643. package/dist/cssm/lib/useIsomorphicLayoutEffect.js.map +1 -1
  1644. package/dist/cssm/lib/utils.d.ts +1 -1
  1645. package/dist/cssm/lib/utils.d.ts.map +1 -1
  1646. package/dist/cssm/lib/utils.js.map +1 -1
  1647. package/dist/cssm/lib/warnOnce.js.map +1 -1
  1648. package/dist/cssm/shared/breakpoints.d.js +5 -0
  1649. package/dist/cssm/shared/breakpoints.d.js.map +1 -0
  1650. package/dist/cssm/shared/breakpoints.js.map +1 -1
  1651. package/dist/cssm/styles/animationFades.module.css +7 -13
  1652. package/dist/cssm/styles/constants.css +4 -0
  1653. package/dist/cssm/styles/customMedias.generated.css +1 -0
  1654. package/dist/cssm/styles/focusVisible.module.css +10 -26
  1655. package/dist/cssm/styles/gaps.module.css +75 -0
  1656. package/dist/cssm/styles/themes.css +45 -31
  1657. package/dist/cssm/types.d.ts +1 -0
  1658. package/dist/cssm/types.d.ts.map +1 -1
  1659. package/dist/cssm/types.js.map +1 -1
  1660. package/dist/cssm/vkui.js.map +1 -1
  1661. package/dist/helpers/avatar.js.map +1 -1
  1662. package/dist/helpers/getMergedSameEventsByProps.d.ts +1 -1
  1663. package/dist/helpers/getMergedSameEventsByProps.d.ts.map +1 -1
  1664. package/dist/helpers/getMergedSameEventsByProps.js.map +1 -1
  1665. package/dist/helpers/getOrDefault.js.map +1 -1
  1666. package/dist/helpers/math.js.map +1 -1
  1667. package/dist/helpers/range.js.map +1 -1
  1668. package/dist/hoc/withContext.js.map +1 -1
  1669. package/dist/hoc/withPlatform.js.map +1 -1
  1670. package/dist/hooks/useAdaptivity.js.map +1 -1
  1671. package/dist/hooks/useAdaptivityConditionalRender/constants.js.map +1 -1
  1672. package/dist/hooks/useAdaptivityConditionalRender/helpers.d.ts +3 -3
  1673. package/dist/hooks/useAdaptivityConditionalRender/helpers.d.ts.map +1 -1
  1674. package/dist/hooks/useAdaptivityConditionalRender/helpers.js.map +1 -1
  1675. package/dist/hooks/useAdaptivityConditionalRender/index.js.map +1 -1
  1676. package/dist/hooks/useAdaptivityConditionalRender/types.js.map +1 -1
  1677. package/dist/hooks/useAdaptivityConditionalRender/useAdaptivityConditionalRender.js.map +1 -1
  1678. package/dist/hooks/useAdaptivityHasPointer.js.map +1 -1
  1679. package/dist/hooks/useAdaptivityWithJSMediaQueries.js.map +1 -1
  1680. package/dist/hooks/useAppearance.js.map +1 -1
  1681. package/dist/hooks/useAutoDetectAppearance.js.map +1 -1
  1682. package/dist/hooks/useAutoFocus.js.map +1 -1
  1683. package/dist/hooks/useBooleanState.js.map +1 -1
  1684. package/dist/hooks/useCalendar.d.ts +2 -0
  1685. package/dist/hooks/useCalendar.d.ts.map +1 -1
  1686. package/dist/hooks/useCalendar.js +44 -2
  1687. package/dist/hooks/useCalendar.js.map +1 -1
  1688. package/dist/hooks/useDateInput.d.ts.map +1 -1
  1689. package/dist/hooks/useDateInput.js.map +1 -1
  1690. package/dist/hooks/useDirection.js.map +1 -1
  1691. package/dist/hooks/useDraggableWithDomApi/autoScroll.js.map +1 -1
  1692. package/dist/hooks/useDraggableWithDomApi/constants.js.map +1 -1
  1693. package/dist/hooks/useDraggableWithDomApi/index.js.map +1 -1
  1694. package/dist/hooks/useDraggableWithDomApi/types.js.map +1 -1
  1695. package/dist/hooks/useDraggableWithDomApi/useDraggableWithDomApi.d.ts.map +1 -1
  1696. package/dist/hooks/useDraggableWithDomApi/useDraggableWithDomApi.js.map +1 -1
  1697. package/dist/hooks/useDraggableWithDomApi/utils.d.ts +2 -2
  1698. package/dist/hooks/useDraggableWithDomApi/utils.d.ts.map +1 -1
  1699. package/dist/hooks/useDraggableWithDomApi/utils.js.map +1 -1
  1700. package/dist/hooks/useEffectDev.js.map +1 -1
  1701. package/dist/hooks/useEnsuredControl.js.map +1 -1
  1702. package/dist/hooks/useEventListener.js.map +1 -1
  1703. package/dist/hooks/useExternRef.js.map +1 -1
  1704. package/dist/hooks/useFocusVisible.d.ts.map +1 -1
  1705. package/dist/hooks/useFocusVisible.js.map +1 -1
  1706. package/dist/hooks/useFocusVisibleClassName.js.map +1 -1
  1707. package/dist/hooks/useFocusWithin.js.map +1 -1
  1708. package/dist/hooks/useGlobalEscKeyDown.js.map +1 -1
  1709. package/dist/hooks/useGlobalEventListener.js.map +1 -1
  1710. package/dist/hooks/useGlobalOnClickOutside.d.ts +1 -1
  1711. package/dist/hooks/useGlobalOnClickOutside.d.ts.map +1 -1
  1712. package/dist/hooks/useGlobalOnClickOutside.js.map +1 -1
  1713. package/dist/hooks/useIsClient.js.map +1 -1
  1714. package/dist/hooks/useKeyboard.js.map +1 -1
  1715. package/dist/hooks/useKeyboardInputTracker.js.map +1 -1
  1716. package/dist/hooks/useMediaQueries.d.ts.map +1 -1
  1717. package/dist/hooks/useMediaQueries.js +21 -18
  1718. package/dist/hooks/useMediaQueries.js.map +1 -1
  1719. package/dist/hooks/useNativeFormResetListener.d.ts.map +1 -1
  1720. package/dist/hooks/useNativeFormResetListener.js.map +1 -1
  1721. package/dist/hooks/useObjectMemo.js.map +1 -1
  1722. package/dist/hooks/useOrientationChange.js.map +1 -1
  1723. package/dist/hooks/usePagination.d.ts.map +1 -1
  1724. package/dist/hooks/usePagination.js.map +1 -1
  1725. package/dist/hooks/usePatchChildren.d.ts.map +1 -1
  1726. package/dist/hooks/usePatchChildren.js.map +1 -1
  1727. package/dist/hooks/usePlatform.js.map +1 -1
  1728. package/dist/hooks/usePrevious.js.map +1 -1
  1729. package/dist/hooks/useResizeObserver.d.ts +1 -1
  1730. package/dist/hooks/useResizeObserver.d.ts.map +1 -1
  1731. package/dist/hooks/useResizeObserver.js +5 -4
  1732. package/dist/hooks/useResizeObserver.js.map +1 -1
  1733. package/dist/hooks/useStableCallback.js.map +1 -1
  1734. package/dist/hooks/useTodayDate.js.map +1 -1
  1735. package/dist/hooks/useWaitTransitionFinish.d.ts +1 -3
  1736. package/dist/hooks/useWaitTransitionFinish.d.ts.map +1 -1
  1737. package/dist/hooks/useWaitTransitionFinish.js +4 -9
  1738. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  1739. package/dist/index.d.ts +7 -1
  1740. package/dist/index.d.ts.map +1 -1
  1741. package/dist/index.js +2 -0
  1742. package/dist/index.js.map +1 -1
  1743. package/dist/lib/SSR.js.map +1 -1
  1744. package/dist/lib/accessibility.d.ts +1 -1
  1745. package/dist/lib/accessibility.d.ts.map +1 -1
  1746. package/dist/lib/accessibility.js +1 -0
  1747. package/dist/lib/accessibility.js.map +1 -1
  1748. package/dist/lib/adaptivity/constants.js.map +1 -1
  1749. package/dist/lib/adaptivity/functions.js.map +1 -1
  1750. package/dist/lib/adaptivity/index.js.map +1 -1
  1751. package/dist/lib/adaptivity/types.js.map +1 -1
  1752. package/dist/lib/animate.js.map +1 -1
  1753. package/dist/lib/animation/fades.js.map +1 -1
  1754. package/dist/lib/animation/index.d.ts +1 -0
  1755. package/dist/lib/animation/index.d.ts.map +1 -1
  1756. package/dist/lib/animation/index.js +1 -0
  1757. package/dist/lib/animation/index.js.map +1 -1
  1758. package/dist/lib/animation/rubberbandIfOutOfBounds.js.map +1 -1
  1759. package/dist/lib/animation/transformOrigin.js.map +1 -1
  1760. package/dist/lib/animation/useCSSKeyframesAnimationController.d.ts +1 -1
  1761. package/dist/lib/animation/useCSSKeyframesAnimationController.d.ts.map +1 -1
  1762. package/dist/lib/animation/useCSSKeyframesAnimationController.js +5 -6
  1763. package/dist/lib/animation/useCSSKeyframesAnimationController.js.map +1 -1
  1764. package/dist/lib/animation/useReducedMotion.js.map +1 -1
  1765. package/dist/lib/appearance/index.js.map +1 -1
  1766. package/dist/lib/appearance/types.js.map +1 -1
  1767. package/dist/lib/browser.js.map +1 -1
  1768. package/dist/lib/calendar.js.map +1 -1
  1769. package/dist/lib/callMultiple.js.map +1 -1
  1770. package/dist/lib/children.d.ts.map +1 -1
  1771. package/dist/lib/children.js.map +1 -1
  1772. package/dist/lib/comparing.js.map +1 -1
  1773. package/dist/lib/createPortal.d.ts.map +1 -1
  1774. package/dist/lib/createPortal.js.map +1 -1
  1775. package/dist/lib/date.js.map +1 -1
  1776. package/dist/lib/dom.d.ts +0 -1
  1777. package/dist/lib/dom.d.ts.map +1 -1
  1778. package/dist/lib/dom.js.map +1 -1
  1779. package/dist/lib/floating/adapters.js.map +1 -1
  1780. package/dist/lib/floating/customResizeObserver.js.map +1 -1
  1781. package/dist/lib/floating/functions.d.ts +1 -1
  1782. package/dist/lib/floating/functions.js.map +1 -1
  1783. package/dist/lib/floating/index.js.map +1 -1
  1784. package/dist/lib/floating/types/common.js.map +1 -1
  1785. package/dist/lib/floating/types/component.js.map +1 -1
  1786. package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts +1 -11
  1787. package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts.map +1 -1
  1788. package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.js.map +1 -1
  1789. package/dist/lib/floating/useFloatingWithInteractions/constants.js.map +1 -1
  1790. package/dist/lib/floating/useFloatingWithInteractions/index.js.map +1 -1
  1791. package/dist/lib/floating/useFloatingWithInteractions/types.d.ts +0 -1
  1792. package/dist/lib/floating/useFloatingWithInteractions/types.d.ts.map +1 -1
  1793. package/dist/lib/floating/useFloatingWithInteractions/types.js.map +1 -1
  1794. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.d.ts.map +1 -1
  1795. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
  1796. package/dist/lib/floating/useFloatingWithInteractions/useResolveTriggerType.js.map +1 -1
  1797. package/dist/lib/floating/usePlacementChangeCallback.js.map +1 -1
  1798. package/dist/lib/fx.js.map +1 -1
  1799. package/dist/lib/getNavId.js.map +1 -1
  1800. package/dist/lib/isRefObject.d.ts.map +1 -1
  1801. package/dist/lib/isRefObject.js.map +1 -1
  1802. package/dist/lib/layouts/gaps.d.ts +32 -0
  1803. package/dist/lib/layouts/gaps.d.ts.map +1 -0
  1804. package/dist/lib/layouts/gaps.js +41 -0
  1805. package/dist/lib/layouts/gaps.js.map +1 -0
  1806. package/dist/lib/layouts/index.d.ts +2 -0
  1807. package/dist/lib/layouts/index.d.ts.map +1 -0
  1808. package/dist/lib/layouts/index.js +3 -0
  1809. package/dist/lib/layouts/index.js.map +1 -0
  1810. package/dist/lib/matchMedia.js.map +1 -1
  1811. package/dist/lib/mergeCalls.js.map +1 -1
  1812. package/dist/lib/offset.js.map +1 -1
  1813. package/dist/lib/platform.js.map +1 -1
  1814. package/dist/lib/rafSchd.d.ts.map +1 -1
  1815. package/dist/lib/rafSchd.js.map +1 -1
  1816. package/dist/lib/react/index.js.map +1 -1
  1817. package/dist/lib/react/simulateReactInput.js.map +1 -1
  1818. package/dist/lib/removeObjectKeys.js.map +1 -1
  1819. package/dist/lib/select.js.map +1 -1
  1820. package/dist/lib/styles.js.map +1 -1
  1821. package/dist/lib/testing.js.map +1 -1
  1822. package/dist/lib/tokens/TokensClassProvider.js.map +1 -1
  1823. package/dist/lib/tokens/constants.js.map +1 -1
  1824. package/dist/lib/tokens/index.js.map +1 -1
  1825. package/dist/lib/tokens/types.js.map +1 -1
  1826. package/dist/lib/tokens/useTokenClassName.js.map +1 -1
  1827. package/dist/lib/touch/UIPanGestureRecognizer.js.map +1 -1
  1828. package/dist/lib/touch/functions.js.map +1 -1
  1829. package/dist/lib/touch/index.js.map +1 -1
  1830. package/dist/lib/useIsomorphicLayoutEffect.js.map +1 -1
  1831. package/dist/lib/utils.d.ts +1 -1
  1832. package/dist/lib/utils.d.ts.map +1 -1
  1833. package/dist/lib/utils.js.map +1 -1
  1834. package/dist/lib/warnOnce.js.map +1 -1
  1835. package/dist/shared/breakpoints.d.js +5 -0
  1836. package/dist/shared/breakpoints.d.js.map +1 -0
  1837. package/dist/shared/breakpoints.js.map +1 -1
  1838. package/dist/types.d.ts +1 -0
  1839. package/dist/types.d.ts.map +1 -1
  1840. package/dist/types.js.map +1 -1
  1841. package/dist/vkui.css +3 -154
  1842. package/dist/vkui.css.map +1 -1
  1843. package/dist/vkui.js.map +1 -1
  1844. package/dist/vkui.js.tmp +25851 -69791
  1845. package/package.json +3 -3
  1846. package/src/components/Accordion/Accordion.module.css +91 -2
  1847. package/src/components/Accordion/AccordionContent.tsx +41 -46
  1848. package/src/components/ActionSheet/ActionSheet.module.css +42 -11
  1849. package/src/components/ActionSheet/ActionSheet.tsx +23 -27
  1850. package/src/components/ActionSheet/ActionSheetDropdownMenu.tsx +5 -0
  1851. package/src/components/ActionSheet/ActionSheetDropdownSheet.tsx +1 -1
  1852. package/src/components/ActionSheetItem/ActionSheetItem.module.css +3 -1
  1853. package/src/components/Alert/Alert.module.css +29 -19
  1854. package/src/components/Alert/Alert.tsx +25 -33
  1855. package/src/components/AppRoot/AppRoot.module.css +5 -5
  1856. package/src/components/AppRoot/AppRoot.tsx +30 -8
  1857. package/src/components/AppRoot/helpers.ts +33 -1
  1858. package/src/components/AppRoot/types.ts +2 -0
  1859. package/src/components/Button/Button.module.css +3 -6
  1860. package/src/components/Calendar/Calendar.module.css +1 -1
  1861. package/src/components/Calendar/Calendar.tsx +4 -0
  1862. package/src/components/CalendarHeader/CalendarHeader.tsx +32 -7
  1863. package/src/components/CalendarRange/CalendarRange.module.css +1 -1
  1864. package/src/components/CalendarRange/CalendarRange.tsx +13 -1
  1865. package/src/components/Card/Card.module.css +2 -2
  1866. package/src/components/ChipsSelect/ChipsSelect.tsx +23 -12
  1867. package/src/components/ChipsSelect/useChipsSelect.ts +21 -3
  1868. package/src/components/CustomScrollView/CustomScrollView.module.css +3 -1
  1869. package/src/components/CustomScrollView/useTrackerVisibility.ts +45 -32
  1870. package/src/components/CustomSelect/CustomSelect.tsx +9 -1
  1871. package/src/components/CustomSelectDropdown/CustomSelectDropdown.module.css +1 -1
  1872. package/src/components/DatePicker/DatePicker.tsx +6 -0
  1873. package/src/components/FixedLayout/FixedLayout.tsx +23 -5
  1874. package/src/components/Flex/Flex.module.css +89 -0
  1875. package/src/components/Flex/Flex.tsx +113 -0
  1876. package/src/components/Flex/FlexItem/FlexItem.module.css +43 -0
  1877. package/src/components/Flex/FlexItem/FlexItem.tsx +60 -0
  1878. package/src/components/FloatingArrow/FloatingArrow.tsx +16 -4
  1879. package/src/components/FocusTrap/FocusTrap.tsx +52 -24
  1880. package/src/components/Gallery/hooks.ts +27 -19
  1881. package/src/components/Header/Header.module.css +0 -1
  1882. package/src/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.module.css +2 -2
  1883. package/src/components/Link/Link.module.css +1 -2
  1884. package/src/components/Link/Link.tsx +1 -0
  1885. package/src/components/ModalRoot/ModalRoot.tsx +4 -8
  1886. package/src/components/ModalRoot/ModalRootDesktop.tsx +2 -1
  1887. package/src/components/PanelHeaderContext/PanelHeaderContext.module.css +34 -30
  1888. package/src/components/PanelHeaderContext/PanelHeaderContext.tsx +35 -49
  1889. package/src/components/PopoutRoot/PopoutRoot.tsx +0 -7
  1890. package/src/components/PopoutWrapper/PopoutWrapper.module.css +15 -2
  1891. package/src/components/PopoutWrapper/PopoutWrapper.tsx +1 -19
  1892. package/src/components/Popover/Popover.module.css +6 -2
  1893. package/src/components/Popover/Popover.tsx +18 -4
  1894. package/src/components/PullToRefresh/PullToRefresh.module.css +3 -1
  1895. package/src/components/Removable/Removable.module.css +1 -6
  1896. package/src/components/Root/Root.module.css +44 -50
  1897. package/src/components/Root/Root.tsx +10 -20
  1898. package/src/components/ScreenSpinner/ScreenSpinner.module.css +1 -1
  1899. package/src/components/ScrollArrow/ScrollArrow.module.css +1 -1
  1900. package/src/components/Search/Search.module.css +3 -1
  1901. package/src/components/SegmentedControl/SegmentedControl.module.css +3 -1
  1902. package/src/components/Skeleton/Skeleton.module.css +7 -0
  1903. package/src/components/Slider/Slider.tsx +6 -1
  1904. package/src/components/Slider/SliderThumb/SliderThumb.module.css +10 -2
  1905. package/src/components/Slider/SliderThumb/SliderThumb.tsx +11 -3
  1906. package/src/components/Snackbar/Snackbar.module.css +73 -75
  1907. package/src/components/Snackbar/Snackbar.tsx +12 -10
  1908. package/src/components/Spacing/Spacing.module.css +1 -0
  1909. package/src/components/Spinner/Spinner.tsx +40 -22
  1910. package/src/components/SubnavigationButton/SubnavigationButton.module.css +1 -1
  1911. package/src/components/Switch/Switch.module.css +200 -141
  1912. package/src/components/Switch/Switch.tsx +43 -17
  1913. package/src/components/TabsItem/TabsItem.module.css +4 -2
  1914. package/src/components/Tappable/Ripple.tsx +11 -3
  1915. package/src/components/Tappable/Tappable.module.css +0 -2
  1916. package/src/components/Textarea/Textarea.tsx +5 -17
  1917. package/src/components/Textarea/useResizeTextarea.ts +35 -0
  1918. package/src/components/TooltipBase/TooltipBase.module.css +2 -2
  1919. package/src/components/Typography/Caption/Caption.tsx +2 -0
  1920. package/src/components/Typography/DisplayTitle/DisplayTitle.module.css +27 -0
  1921. package/src/components/Typography/DisplayTitle/DisplayTitle.tsx +38 -0
  1922. package/src/components/Typography/Footnote/Footnote.tsx +2 -0
  1923. package/src/components/Typography/Headline/Headline.tsx +2 -0
  1924. package/src/components/Typography/Paragraph/Paragraph.tsx +2 -0
  1925. package/src/components/Typography/Subhead/Subhead.tsx +2 -0
  1926. package/src/components/Typography/Text/Text.tsx +2 -0
  1927. package/src/components/Typography/Title/Title.tsx +2 -0
  1928. package/src/components/Typography/Typography.module.css +4 -0
  1929. package/src/components/Typography/Typography.tsx +6 -0
  1930. package/src/components/View/View.module.css +104 -82
  1931. package/src/components/View/View.tsx +51 -83
  1932. package/src/components/View/ViewInfinite.tsx +22 -37
  1933. package/src/components/WriteBar/WriteBar.module.css +1 -1
  1934. package/src/components/WriteBar/WriteBar.tsx +3 -19
  1935. package/src/hooks/useAdaptivityConditionalRender/helpers.ts +8 -8
  1936. package/src/hooks/useCalendar.ts +52 -1
  1937. package/src/hooks/useMediaQueries.ts +23 -39
  1938. package/src/hooks/usePatchChildren.ts +2 -2
  1939. package/src/hooks/useResizeObserver.ts +5 -5
  1940. package/src/hooks/useWaitTransitionFinish.ts +4 -9
  1941. package/src/index.ts +7 -0
  1942. package/src/lib/accessibility.ts +1 -0
  1943. package/src/lib/animation/index.ts +1 -0
  1944. package/src/lib/animation/useCSSKeyframesAnimationController.ts +7 -5
  1945. package/src/lib/dom.tsx +2 -2
  1946. package/src/lib/layouts/gaps.ts +48 -0
  1947. package/src/lib/layouts/index.ts +7 -0
  1948. package/src/styles/animationFades.module.css +5 -13
  1949. package/src/styles/constants.css +4 -0
  1950. package/src/styles/customMedias.generated.css +3 -1
  1951. package/src/styles/focusVisible.module.css +10 -26
  1952. package/src/styles/gaps.module.css +75 -0
  1953. package/src/types.ts +2 -0
  1954. package/dist/cjs/hooks/useTimeout.d.ts +0 -5
  1955. package/dist/cjs/hooks/useTimeout.d.ts.map +0 -1
  1956. package/dist/cjs/hooks/useTimeout.js +0 -51
  1957. package/dist/cjs/hooks/useTimeout.js.map +0 -1
  1958. package/dist/cjs/lib/supportEvents.d.ts +0 -10
  1959. package/dist/cjs/lib/supportEvents.d.ts.map +0 -1
  1960. package/dist/cjs/lib/supportEvents.js +0 -43
  1961. package/dist/cjs/lib/supportEvents.js.map +0 -1
  1962. package/dist/cjs/shared/breakpoints.d.ts +0 -74
  1963. package/dist/cjs/shared/breakpoints.d.ts.map +0 -1
  1964. package/dist/cssm/hooks/useTimeout.d.ts +0 -5
  1965. package/dist/cssm/hooks/useTimeout.d.ts.map +0 -1
  1966. package/dist/cssm/hooks/useTimeout.js +0 -40
  1967. package/dist/cssm/hooks/useTimeout.js.map +0 -1
  1968. package/dist/cssm/lib/supportEvents.d.ts +0 -10
  1969. package/dist/cssm/lib/supportEvents.d.ts.map +0 -1
  1970. package/dist/cssm/lib/supportEvents.js +0 -26
  1971. package/dist/cssm/lib/supportEvents.js.map +0 -1
  1972. package/dist/cssm/shared/breakpoints.d.ts +0 -74
  1973. package/dist/cssm/shared/breakpoints.d.ts.map +0 -1
  1974. package/dist/hooks/useTimeout.d.ts +0 -5
  1975. package/dist/hooks/useTimeout.d.ts.map +0 -1
  1976. package/dist/hooks/useTimeout.js +0 -40
  1977. package/dist/hooks/useTimeout.js.map +0 -1
  1978. package/dist/lib/supportEvents.d.ts +0 -10
  1979. package/dist/lib/supportEvents.d.ts.map +0 -1
  1980. package/dist/lib/supportEvents.js +0 -26
  1981. package/dist/lib/supportEvents.js.map +0 -1
  1982. package/dist/shared/breakpoints.d.ts +0 -74
  1983. package/dist/shared/breakpoints.d.ts.map +0 -1
  1984. package/dist/stable.js.tmp +0 -180
  1985. package/src/hooks/useTimeout.ts +0 -33
  1986. package/src/lib/supportEvents.ts +0 -38
@@ -1 +1 @@
1
- {"version":3,"file":"useCalendar.d.ts","sourceRoot":"","sources":["../../src/hooks/useCalendar.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAYhE,MAAM,WAAW,uBACf,SAAQ,IAAI,CACV,aAAa,EACX,gBAAgB,GAChB,aAAa,GACb,aAAa,GACb,aAAa,GACb,aAAa,GACb,mBAAmB,GACnB,eAAe,GACf,aAAa,CAChB;IACD,KAAK,CAAC,EAAE,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC;CACnC;AAED,wBAAgB,WAAW,CAAC,EAC1B,KAAK,EACL,WAAW,EACX,aAAa,EACb,iBAAiB,EACjB,cAAc,EACd,WAAW,EACX,WAAW,EACX,WAAW,EACX,WAAW,GACZ,EAAE,uBAAuB;;yBAgBd,IAAI;;;;;wBAQN,IAAI;yBAKJ,IAAI,aAAa,OAAO;;EAmCjC"}
1
+ {"version":3,"file":"useCalendar.d.ts","sourceRoot":"","sources":["../../src/hooks/useCalendar.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAYhE,MAAM,WAAW,uBACf,SAAQ,IAAI,CACV,aAAa,EACX,gBAAgB,GAChB,aAAa,GACb,aAAa,GACb,aAAa,GACb,aAAa,GACb,mBAAmB,GACnB,eAAe,GACf,aAAa,CAChB;IACD,KAAK,CAAC,EAAE,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC;CACnC;AAED,wBAAgB,WAAW,CAAC,EAC1B,KAAK,EACL,WAAW,EACX,aAAa,EACb,iBAAiB,EACjB,cAAc,EACd,WAAW,EACX,WAAW,EACX,WAAW,EACX,WAAW,GACZ,EAAE,uBAAuB;;yBAgBd,IAAI;;;;;wBAQN,IAAI;yBAKJ,IAAI,aAAa,OAAO;;6BAqBtB,MAAM,SAAS,MAAM,KAAG,OAAO;2BA8BhC,MAAM,KAAG,OAAO;EAmC1B"}
@@ -1,5 +1,5 @@
1
1
  import * as React from 'react';
2
- import { isDayMinMaxRestricted } from '../lib/calendar';
2
+ import { DEFAULT_MAX_YEAR, DEFAULT_MIN_YEAR, isDayMinMaxRestricted } from '../lib/calendar';
3
3
  import { addMonths, endOfDay, isAfter, isBefore, isSameDay, startOfDay, subMonths } from '../lib/date';
4
4
  export function useCalendar({ value, disablePast, disableFuture, shouldDisableDate, onHeaderChange, onNextMonth, onPrevMonth, minDateTime, maxDateTime }) {
5
5
  var _ref;
@@ -54,6 +54,46 @@ export function useCalendar({ value, disablePast, disableFuture, shouldDisableDa
54
54
  minDateTime,
55
55
  maxDateTime
56
56
  ]);
57
+ const isMonthDisabled = React.useCallback((month, year)=>{
58
+ const now = new Date();
59
+ year = year || viewDate.getFullYear();
60
+ const minMonth = minDateTime ? minDateTime.getMonth() : 0;
61
+ const maxMonth = maxDateTime ? maxDateTime.getMonth() : 11;
62
+ const minYear = (minDateTime === null || minDateTime === void 0 ? void 0 : minDateTime.getFullYear()) || DEFAULT_MIN_YEAR;
63
+ const maxYear = (maxDateTime === null || maxDateTime === void 0 ? void 0 : maxDateTime.getFullYear()) || DEFAULT_MAX_YEAR;
64
+ let isDisabled = year >= minYear && year <= maxYear ? year === minYear && minMonth > month || year === maxYear && month > maxMonth : true;
65
+ if (disableFuture) {
66
+ isDisabled = isDisabled || (year === now.getFullYear() ? month > now.getMonth() : year > now.getFullYear());
67
+ }
68
+ if (disablePast) {
69
+ isDisabled = isDisabled || (year === now.getFullYear() ? month < now.getMonth() : year < now.getFullYear());
70
+ }
71
+ return isDisabled;
72
+ }, [
73
+ disableFuture,
74
+ disablePast,
75
+ viewDate,
76
+ minDateTime,
77
+ maxDateTime
78
+ ]);
79
+ const isYearDisabled = React.useCallback((year)=>{
80
+ const now = new Date();
81
+ const minYear = (minDateTime === null || minDateTime === void 0 ? void 0 : minDateTime.getFullYear()) || DEFAULT_MIN_YEAR;
82
+ const maxYear = (maxDateTime === null || maxDateTime === void 0 ? void 0 : maxDateTime.getFullYear()) || DEFAULT_MAX_YEAR;
83
+ let isDisabled = minYear > year || year > maxYear;
84
+ if (disableFuture) {
85
+ isDisabled = isDisabled || year > now.getFullYear();
86
+ }
87
+ if (disablePast) {
88
+ isDisabled = isDisabled || year < now.getFullYear();
89
+ }
90
+ return isDisabled;
91
+ }, [
92
+ disableFuture,
93
+ disablePast,
94
+ minDateTime,
95
+ maxDateTime
96
+ ]);
57
97
  const resetSelectedDay = React.useCallback(()=>{
58
98
  setFocusedDay(undefined);
59
99
  }, [
@@ -68,7 +108,9 @@ export function useCalendar({ value, disablePast, disableFuture, shouldDisableDa
68
108
  setFocusedDay,
69
109
  isDayFocused,
70
110
  isDayDisabled,
71
- resetSelectedDay
111
+ resetSelectedDay,
112
+ isMonthDisabled,
113
+ isYearDisabled
72
114
  };
73
115
  }
74
116
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useCalendar.ts"],"sourcesContent":["import * as React from 'react';\nimport { CalendarProps } from '../components/Calendar/Calendar';\nimport { isDayMinMaxRestricted } from '../lib/calendar';\nimport {\n addMonths,\n endOfDay,\n isAfter,\n isBefore,\n isSameDay,\n startOfDay,\n subMonths,\n} from '../lib/date';\n\nexport interface UseCalendarDependencies\n extends Pick<\n CalendarProps,\n | 'onHeaderChange'\n | 'onNextMonth'\n | 'onPrevMonth'\n | 'minDateTime'\n | 'maxDateTime'\n | 'shouldDisableDate'\n | 'disableFuture'\n | 'disablePast'\n > {\n value?: Array<Date | null> | Date;\n}\n\nexport function useCalendar({\n value,\n disablePast,\n disableFuture,\n shouldDisableDate,\n onHeaderChange,\n onNextMonth,\n onPrevMonth,\n minDateTime,\n maxDateTime,\n}: UseCalendarDependencies) {\n const [viewDate, setViewDate] = React.useState(\n (Array.isArray(value) ? value[0] : value) ?? new Date(),\n );\n const [focusedDay, setFocusedDay] = React.useState<Date>();\n\n const setPrevMonth = React.useCallback(() => {\n onPrevMonth?.();\n setViewDate(subMonths(viewDate, 1));\n }, [viewDate, onPrevMonth]);\n const setNextMonth = React.useCallback(() => {\n onNextMonth?.();\n setViewDate(addMonths(viewDate, 1));\n }, [viewDate, onNextMonth]);\n\n const handleSetViewDate = React.useCallback(\n (value: Date) => {\n onHeaderChange?.(value);\n setViewDate(value);\n },\n [onHeaderChange],\n );\n\n const isDayFocused = React.useCallback(\n (day: Date) => Boolean(focusedDay && isSameDay(day, focusedDay)),\n [focusedDay],\n );\n\n const isDayDisabled = React.useCallback(\n (day: Date, withTime?: boolean) => {\n const now = new Date();\n if (shouldDisableDate) {\n return shouldDisableDate(day);\n }\n if (disableFuture) {\n return isAfter(startOfDay(day), now);\n }\n if (disablePast) {\n return isBefore(endOfDay(day), now);\n }\n if (minDateTime || maxDateTime) {\n return isDayMinMaxRestricted(day, { min: minDateTime, max: maxDateTime, withTime });\n }\n\n return false;\n },\n [disableFuture, disablePast, shouldDisableDate, minDateTime, maxDateTime],\n );\n\n const resetSelectedDay = React.useCallback(() => {\n setFocusedDay(undefined);\n }, [setFocusedDay]);\n\n return {\n viewDate,\n setViewDate: handleSetViewDate,\n setPrevMonth,\n setNextMonth,\n focusedDay,\n setFocusedDay,\n isDayFocused,\n isDayDisabled,\n resetSelectedDay,\n };\n}\n"],"names":["React","isDayMinMaxRestricted","addMonths","endOfDay","isAfter","isBefore","isSameDay","startOfDay","subMonths","useCalendar","value","disablePast","disableFuture","shouldDisableDate","onHeaderChange","onNextMonth","onPrevMonth","minDateTime","maxDateTime","Array","viewDate","setViewDate","useState","isArray","Date","focusedDay","setFocusedDay","setPrevMonth","useCallback","setNextMonth","handleSetViewDate","isDayFocused","day","Boolean","isDayDisabled","withTime","now","min","max","resetSelectedDay","undefined"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,YAAYA,WAAW,QAAQ;AAE/B,SAASC,qBAAqB,QAAQ,kBAAkB;AACxD,SACEC,SAAS,EACTC,QAAQ,EACRC,OAAO,EACPC,QAAQ,EACRC,SAAS,EACTC,UAAU,EACVC,SAAS,QACJ,cAAc;AAiBrB,OAAO,SAASC,YAAY,EAC1BC,KAAK,EACLC,WAAW,EACXC,aAAa,EACbC,iBAAiB,EACjBC,cAAc,EACdC,WAAW,EACXC,WAAW,EACXC,WAAW,EACXC,WAAW,EACa;QAErBC;IADH,MAAM,CAACC,UAAUC,YAAY,GAAGrB,MAAMsB,QAAQ,CAC5C,CAACH,OAAAA,MAAMI,OAAO,CAACb,SAASA,KAAK,CAAC,EAAE,GAAGA,mBAAlCS,kBAAAA,OAA4C,IAAIK;IAEnD,MAAM,CAACC,YAAYC,cAAc,GAAG1B,MAAMsB,QAAQ;IAElD,MAAMK,eAAe3B,MAAM4B,WAAW,CAAC;QACrCZ,wBAAAA,kCAAAA;QACAK,YAAYb,UAAUY,UAAU;IAClC,GAAG;QAACA;QAAUJ;KAAY;IAC1B,MAAMa,eAAe7B,MAAM4B,WAAW,CAAC;QACrCb,wBAAAA,kCAAAA;QACAM,YAAYnB,UAAUkB,UAAU;IAClC,GAAG;QAACA;QAAUL;KAAY;IAE1B,MAAMe,oBAAoB9B,MAAM4B,WAAW,CACzC,CAAClB;QACCI,2BAAAA,qCAAAA,eAAiBJ;QACjBW,YAAYX;IACd,GACA;QAACI;KAAe;IAGlB,MAAMiB,eAAe/B,MAAM4B,WAAW,CACpC,CAACI,MAAcC,QAAQR,cAAcnB,UAAU0B,KAAKP,cACpD;QAACA;KAAW;IAGd,MAAMS,gBAAgBlC,MAAM4B,WAAW,CACrC,CAACI,KAAWG;QACV,MAAMC,MAAM,IAAIZ;QAChB,IAAIX,mBAAmB;YACrB,OAAOA,kBAAkBmB;QAC3B;QACA,IAAIpB,eAAe;YACjB,OAAOR,QAAQG,WAAWyB,MAAMI;QAClC;QACA,IAAIzB,aAAa;YACf,OAAON,SAASF,SAAS6B,MAAMI;QACjC;QACA,IAAInB,eAAeC,aAAa;YAC9B,OAAOjB,sBAAsB+B,KAAK;gBAAEK,KAAKpB;gBAAaqB,KAAKpB;gBAAaiB;YAAS;QACnF;QAEA,OAAO;IACT,GACA;QAACvB;QAAeD;QAAaE;QAAmBI;QAAaC;KAAY;IAG3E,MAAMqB,mBAAmBvC,MAAM4B,WAAW,CAAC;QACzCF,cAAcc;IAChB,GAAG;QAACd;KAAc;IAElB,OAAO;QACLN;QACAC,aAAaS;QACbH;QACAE;QACAJ;QACAC;QACAK;QACAG;QACAK;IACF;AACF"}
1
+ {"version":3,"sources":["../../src/hooks/useCalendar.ts"],"sourcesContent":["import * as React from 'react';\nimport { CalendarProps } from '../components/Calendar/Calendar';\nimport { DEFAULT_MAX_YEAR, DEFAULT_MIN_YEAR, isDayMinMaxRestricted } from '../lib/calendar';\nimport {\n addMonths,\n endOfDay,\n isAfter,\n isBefore,\n isSameDay,\n startOfDay,\n subMonths,\n} from '../lib/date';\n\nexport interface UseCalendarDependencies\n extends Pick<\n CalendarProps,\n | 'onHeaderChange'\n | 'onNextMonth'\n | 'onPrevMonth'\n | 'minDateTime'\n | 'maxDateTime'\n | 'shouldDisableDate'\n | 'disableFuture'\n | 'disablePast'\n > {\n value?: Array<Date | null> | Date;\n}\n\nexport function useCalendar({\n value,\n disablePast,\n disableFuture,\n shouldDisableDate,\n onHeaderChange,\n onNextMonth,\n onPrevMonth,\n minDateTime,\n maxDateTime,\n}: UseCalendarDependencies) {\n const [viewDate, setViewDate] = React.useState(\n (Array.isArray(value) ? value[0] : value) ?? new Date(),\n );\n const [focusedDay, setFocusedDay] = React.useState<Date>();\n\n const setPrevMonth = React.useCallback(() => {\n onPrevMonth?.();\n setViewDate(subMonths(viewDate, 1));\n }, [viewDate, onPrevMonth]);\n const setNextMonth = React.useCallback(() => {\n onNextMonth?.();\n setViewDate(addMonths(viewDate, 1));\n }, [viewDate, onNextMonth]);\n\n const handleSetViewDate = React.useCallback(\n (value: Date) => {\n onHeaderChange?.(value);\n setViewDate(value);\n },\n [onHeaderChange],\n );\n\n const isDayFocused = React.useCallback(\n (day: Date) => Boolean(focusedDay && isSameDay(day, focusedDay)),\n [focusedDay],\n );\n\n const isDayDisabled = React.useCallback(\n (day: Date, withTime?: boolean) => {\n const now = new Date();\n if (shouldDisableDate) {\n return shouldDisableDate(day);\n }\n if (disableFuture) {\n return isAfter(startOfDay(day), now);\n }\n if (disablePast) {\n return isBefore(endOfDay(day), now);\n }\n if (minDateTime || maxDateTime) {\n return isDayMinMaxRestricted(day, { min: minDateTime, max: maxDateTime, withTime });\n }\n\n return false;\n },\n [disableFuture, disablePast, shouldDisableDate, minDateTime, maxDateTime],\n );\n\n const isMonthDisabled = React.useCallback(\n (month: number, year?: number): boolean => {\n const now = new Date();\n year = year || viewDate.getFullYear();\n const minMonth = minDateTime ? minDateTime.getMonth() : 0;\n const maxMonth = maxDateTime ? maxDateTime.getMonth() : 11;\n const minYear = minDateTime?.getFullYear() || DEFAULT_MIN_YEAR;\n const maxYear = maxDateTime?.getFullYear() || DEFAULT_MAX_YEAR;\n\n let isDisabled =\n year >= minYear && year <= maxYear\n ? (year === minYear && minMonth > month) || (year === maxYear && month > maxMonth)\n : true;\n\n if (disableFuture) {\n isDisabled =\n isDisabled ||\n (year === now.getFullYear() ? month > now.getMonth() : year > now.getFullYear());\n }\n if (disablePast) {\n isDisabled =\n isDisabled ||\n (year === now.getFullYear() ? month < now.getMonth() : year < now.getFullYear());\n }\n\n return isDisabled;\n },\n [disableFuture, disablePast, viewDate, minDateTime, maxDateTime],\n );\n\n const isYearDisabled = React.useCallback(\n (year: number): boolean => {\n const now = new Date();\n const minYear = minDateTime?.getFullYear() || DEFAULT_MIN_YEAR;\n const maxYear = maxDateTime?.getFullYear() || DEFAULT_MAX_YEAR;\n\n let isDisabled = minYear > year || year > maxYear;\n if (disableFuture) {\n isDisabled = isDisabled || year > now.getFullYear();\n }\n if (disablePast) {\n isDisabled = isDisabled || year < now.getFullYear();\n }\n\n return isDisabled;\n },\n [disableFuture, disablePast, minDateTime, maxDateTime],\n );\n\n const resetSelectedDay = React.useCallback(() => {\n setFocusedDay(undefined);\n }, [setFocusedDay]);\n\n return {\n viewDate,\n setViewDate: handleSetViewDate,\n setPrevMonth,\n setNextMonth,\n focusedDay,\n setFocusedDay,\n isDayFocused,\n isDayDisabled,\n resetSelectedDay,\n isMonthDisabled,\n isYearDisabled,\n };\n}\n"],"names":["React","DEFAULT_MAX_YEAR","DEFAULT_MIN_YEAR","isDayMinMaxRestricted","addMonths","endOfDay","isAfter","isBefore","isSameDay","startOfDay","subMonths","useCalendar","value","disablePast","disableFuture","shouldDisableDate","onHeaderChange","onNextMonth","onPrevMonth","minDateTime","maxDateTime","Array","viewDate","setViewDate","useState","isArray","Date","focusedDay","setFocusedDay","setPrevMonth","useCallback","setNextMonth","handleSetViewDate","isDayFocused","day","Boolean","isDayDisabled","withTime","now","min","max","isMonthDisabled","month","year","getFullYear","minMonth","getMonth","maxMonth","minYear","maxYear","isDisabled","isYearDisabled","resetSelectedDay","undefined"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"useDateInput.d.ts","sourceRoot":"","sources":["../../src/hooks/useDateInput.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAK/B,MAAM,WAAW,wBAAwB,CAAC,CAAC,EAAE,CAAC;IAC5C,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IAChC,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,CAAC,CAAC;IACV,cAAc,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK;QACjC,MAAM,EAAE,MAAM,CAAC;QACf,GAAG,EAAE,MAAM,CAAC;QACZ,GAAG,EAAE,MAAM,CAAC;KACb,CAAC;IACF,qBAAqB,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;IACjD,gBAAgB,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,SAAS,KAAK,MAAM,EAAE,CAAC;IACtD,QAAQ,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,SAAS,KAAK,IAAI,CAAC;CAC5C;AAED,wBAAgB,YAAY,CAAC,CAAC,SAAS,WAAW,EAAE,CAAC,EAAE,EACrD,UAAU,EACV,IAAI,EACJ,SAAS,EACT,QAAQ,EACR,cAAc,EACd,QAAQ,EACR,qBAAqB,EACrB,gBAAgB,EAChB,KAAK,GACN,EAAE,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAAC;;;;;;;;;uBAgFzB,mBAAmB,CAAC,eAAe,CAAC;;;;EA8E3C"}
1
+ {"version":3,"file":"useDateInput.d.ts","sourceRoot":"","sources":["../../src/hooks/useDateInput.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAK/B,MAAM,WAAW,wBAAwB,CAAC,CAAC,EAAE,CAAC;IAC5C,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IAChC,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,CAAC,CAAC;IACV,cAAc,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK;QACjC,MAAM,EAAE,MAAM,CAAC;QACf,GAAG,EAAE,MAAM,CAAC;QACZ,GAAG,EAAE,MAAM,CAAC;KACb,CAAC;IACF,qBAAqB,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;IACjD,gBAAgB,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,SAAS,KAAK,MAAM,EAAE,CAAC;IACtD,QAAQ,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,SAAS,KAAK,IAAI,CAAC;CAC5C;AAED,wBAAgB,YAAY,CAAC,CAAC,SAAS,WAAW,EAAE,CAAC,EAAE,EACrD,UAAU,EACV,IAAI,EACJ,SAAS,EACT,QAAQ,EACR,cAAc,EACd,QAAQ,EACR,qBAAqB,EACrB,gBAAgB,EAChB,KAAK,GACN,EAAE,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAAC;;;;;;;;;uBAgFzB,KAAK,CAAC,aAAa,CAAC,eAAe,CAAC;;;;EA8E3C"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useDateInput.ts"],"sourcesContent":["import * as React from 'react';\nimport { useDOM } from '../lib/dom';\nimport { useBooleanState } from './useBooleanState';\nimport { useGlobalEventListener } from './useGlobalEventListener';\n\nexport interface UseDateInputDependencies<T, D> {\n maxElement: number;\n refs: Array<React.RefObject<T>>;\n autoFocus?: boolean;\n disabled?: boolean;\n value?: D;\n elementsConfig: (index: number) => {\n length: number;\n min: number;\n max: number;\n };\n onInternalValueChange: (value: string[]) => void;\n getInternalValue: (value?: D | undefined) => string[];\n onChange?: (value?: D | undefined) => void;\n}\n\nexport function useDateInput<T extends HTMLElement, D>({\n maxElement,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange,\n onInternalValueChange,\n getInternalValue,\n value,\n}: UseDateInputDependencies<T, D>) {\n const { document } = useDOM();\n const { value: open, setTrue: openCalendar, setFalse: closeCalendar } = useBooleanState(false);\n const rootRef = React.useRef<HTMLDivElement>(null);\n const calendarRef = React.useRef<HTMLDivElement>(null);\n const [internalValue, setInternalValue] = React.useState<string[]>([]);\n const [focusedElement, setFocusedElement] = React.useState<number | null>(null);\n const { window } = useDOM();\n\n const removeFocusFromField = React.useCallback(() => {\n if (focusedElement !== null) {\n setFocusedElement(null);\n closeCalendar();\n window!.getSelection()?.removeAllRanges();\n setInternalValue(getInternalValue(value));\n }\n }, [focusedElement, closeCalendar, getInternalValue, value, window]);\n\n const handleClickOutside = React.useCallback(\n (e: MouseEvent) => {\n if (\n !rootRef.current?.contains(e.target as Node | null) &&\n !calendarRef.current?.contains(e.target as Node | null)\n ) {\n removeFocusFromField();\n }\n },\n [removeFocusFromField],\n );\n\n const selectFirst = React.useCallback(() => {\n setFocusedElement(0);\n }, []);\n\n useGlobalEventListener(document, 'click', handleClickOutside, {\n capture: true,\n });\n\n React.useEffect(() => {\n setInternalValue(getInternalValue(value));\n }, [getInternalValue, value]);\n\n React.useEffect(() => {\n if (autoFocus) {\n selectFirst();\n }\n }, [autoFocus, selectFirst]);\n\n React.useEffect(() => {\n if (disabled || focusedElement === null) {\n return;\n }\n\n const range = window!.document.createRange();\n\n let element = refs[focusedElement].current;\n\n if (element) {\n element.focus();\n openCalendar();\n range.selectNodeContents(element as Node);\n\n const selection = window!.getSelection();\n selection?.removeAllRanges();\n selection?.addRange(range);\n }\n }, [disabled, focusedElement, openCalendar, refs, window]);\n\n const clear = React.useCallback(() => {\n onChange?.(undefined);\n selectFirst();\n }, [onChange, selectFirst]);\n\n const handleFieldEnter = React.useCallback(() => {\n if (!open) {\n selectFirst();\n }\n }, [open, selectFirst]);\n\n const handleKeyDown = React.useCallback(\n (e: React.KeyboardEvent<HTMLSpanElement>) => {\n if (focusedElement === null) {\n return;\n }\n\n const _value = [...internalValue];\n const config = elementsConfig(focusedElement);\n\n if (/^\\d+$/.test(e.key)) {\n if (_value[focusedElement].length >= config.length) {\n _value[focusedElement] = e.key;\n } else {\n _value[focusedElement] += e.key;\n if (_value[focusedElement].length >= config.length && focusedElement < maxElement) {\n setFocusedElement(focusedElement + 1);\n }\n }\n } else if (e.key === 'Backspace') {\n if (!_value[focusedElement]) {\n setFocusedElement(focusedElement <= 0 ? maxElement : focusedElement - 1);\n } else {\n _value[focusedElement] = _value[focusedElement].slice(0, -1);\n }\n } else if (e.key === 'ArrowDown' || e.key === 'Down') {\n let currentValue = Number(_value[focusedElement]);\n _value[focusedElement] = String(\n currentValue <= config.min ? config.max : currentValue - 1,\n ).padStart(config.length, '0');\n } else if (e.key === 'ArrowUp' || e.key === 'Up') {\n let currentValue = Number(_value[focusedElement]);\n _value[focusedElement] = String(\n currentValue >= config.max ? config.min : currentValue + 1,\n ).padStart(config.length, '0');\n } else if (\n e.key === 'Enter' ||\n (e.key === 'Tab' && focusedElement === maxElement) ||\n (e.key === 'Tab' && e.shiftKey && focusedElement === 0)\n ) {\n removeFocusFromField();\n return;\n } else if (e.key === 'ArrowLeft' || e.key === 'Left' || (e.key === 'Tab' && e.shiftKey)) {\n setFocusedElement(focusedElement <= 0 ? maxElement : focusedElement - 1);\n } else if (e.key === 'ArrowRight' || e.key === 'Right' || e.key === 'Tab') {\n setFocusedElement(focusedElement >= maxElement ? 0 : focusedElement + 1);\n } else if (e.key === 'Delete' || e.key === 'Del') {\n _value[focusedElement] = '';\n } else {\n return;\n }\n\n e.preventDefault();\n setInternalValue(_value);\n onInternalValueChange(_value);\n },\n [\n elementsConfig,\n focusedElement,\n internalValue,\n maxElement,\n onInternalValueChange,\n removeFocusFromField,\n ],\n );\n\n return {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n closeCalendar,\n internalValue,\n focusedElement,\n setFocusedElement,\n handleKeyDown,\n clear,\n handleFieldEnter,\n removeFocusFromField,\n };\n}\n"],"names":["React","useDOM","useBooleanState","useGlobalEventListener","useDateInput","maxElement","refs","autoFocus","disabled","elementsConfig","onChange","onInternalValueChange","getInternalValue","value","document","open","setTrue","openCalendar","setFalse","closeCalendar","rootRef","useRef","calendarRef","internalValue","setInternalValue","useState","focusedElement","setFocusedElement","window","removeFocusFromField","useCallback","getSelection","removeAllRanges","handleClickOutside","e","current","contains","target","selectFirst","capture","useEffect","range","createRange","element","focus","selectNodeContents","selection","addRange","clear","undefined","handleFieldEnter","handleKeyDown","_value","config","test","key","length","slice","currentValue","Number","String","min","max","padStart","shiftKey","preventDefault"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["../../src/hooks/useDateInput.ts"],"sourcesContent":["import * as React from 'react';\nimport { useDOM } from '../lib/dom';\nimport { useBooleanState } from './useBooleanState';\nimport { useGlobalEventListener } from './useGlobalEventListener';\n\nexport interface UseDateInputDependencies<T, D> {\n maxElement: number;\n refs: Array<React.RefObject<T>>;\n autoFocus?: boolean;\n disabled?: boolean;\n value?: D;\n elementsConfig: (index: number) => {\n length: number;\n min: number;\n max: number;\n };\n onInternalValueChange: (value: string[]) => void;\n getInternalValue: (value?: D | undefined) => string[];\n onChange?: (value?: D | undefined) => void;\n}\n\nexport function useDateInput<T extends HTMLElement, D>({\n maxElement,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange,\n onInternalValueChange,\n getInternalValue,\n value,\n}: UseDateInputDependencies<T, D>) {\n const { document } = useDOM();\n const { value: open, setTrue: openCalendar, setFalse: closeCalendar } = useBooleanState(false);\n const rootRef = React.useRef<HTMLDivElement>(null);\n const calendarRef = React.useRef<HTMLDivElement>(null);\n const [internalValue, setInternalValue] = React.useState<string[]>([]);\n const [focusedElement, setFocusedElement] = React.useState<number | null>(null);\n const { window } = useDOM();\n\n const removeFocusFromField = React.useCallback(() => {\n if (focusedElement !== null) {\n setFocusedElement(null);\n closeCalendar();\n window!.getSelection()?.removeAllRanges();\n setInternalValue(getInternalValue(value));\n }\n }, [focusedElement, closeCalendar, getInternalValue, value, window]);\n\n const handleClickOutside = React.useCallback(\n (e: MouseEvent) => {\n if (\n !rootRef.current?.contains(e.target as Node | null) &&\n !calendarRef.current?.contains(e.target as Node | null)\n ) {\n removeFocusFromField();\n }\n },\n [removeFocusFromField],\n );\n\n const selectFirst = React.useCallback(() => {\n setFocusedElement(0);\n }, []);\n\n useGlobalEventListener(document, 'click', handleClickOutside, {\n capture: true,\n });\n\n React.useEffect(() => {\n setInternalValue(getInternalValue(value));\n }, [getInternalValue, value]);\n\n React.useEffect(() => {\n if (autoFocus) {\n selectFirst();\n }\n }, [autoFocus, selectFirst]);\n\n React.useEffect(() => {\n if (disabled || focusedElement === null) {\n return;\n }\n\n const range = window!.document.createRange();\n\n let element = refs[focusedElement].current;\n\n if (element) {\n element.focus();\n openCalendar();\n range.selectNodeContents(element as Node);\n\n const selection = window!.getSelection();\n selection?.removeAllRanges();\n selection?.addRange(range);\n }\n }, [disabled, focusedElement, openCalendar, refs, window]);\n\n const clear = React.useCallback(() => {\n onChange?.(undefined);\n selectFirst();\n }, [onChange, selectFirst]);\n\n const handleFieldEnter = React.useCallback(() => {\n if (!open) {\n selectFirst();\n }\n }, [open, selectFirst]);\n\n const handleKeyDown = React.useCallback(\n (e: React.KeyboardEvent<HTMLSpanElement>) => {\n if (focusedElement === null) {\n return;\n }\n\n const _value = [...internalValue];\n const config = elementsConfig(focusedElement);\n\n if (/^\\d+$/.test(e.key)) {\n if (_value[focusedElement].length >= config.length) {\n _value[focusedElement] = e.key;\n } else {\n _value[focusedElement] += e.key;\n if (_value[focusedElement].length >= config.length && focusedElement < maxElement) {\n setFocusedElement(focusedElement + 1);\n }\n }\n } else if (e.key === 'Backspace') {\n if (!_value[focusedElement]) {\n setFocusedElement(focusedElement <= 0 ? maxElement : focusedElement - 1);\n } else {\n _value[focusedElement] = _value[focusedElement].slice(0, -1);\n }\n } else if (e.key === 'ArrowDown' || e.key === 'Down') {\n let currentValue = Number(_value[focusedElement]);\n _value[focusedElement] = String(\n currentValue <= config.min ? config.max : currentValue - 1,\n ).padStart(config.length, '0');\n } else if (e.key === 'ArrowUp' || e.key === 'Up') {\n let currentValue = Number(_value[focusedElement]);\n _value[focusedElement] = String(\n currentValue >= config.max ? config.min : currentValue + 1,\n ).padStart(config.length, '0');\n } else if (\n e.key === 'Enter' ||\n (e.key === 'Tab' && focusedElement === maxElement) ||\n (e.key === 'Tab' && e.shiftKey && focusedElement === 0)\n ) {\n removeFocusFromField();\n return;\n } else if (e.key === 'ArrowLeft' || e.key === 'Left' || (e.key === 'Tab' && e.shiftKey)) {\n setFocusedElement(focusedElement <= 0 ? maxElement : focusedElement - 1);\n } else if (e.key === 'ArrowRight' || e.key === 'Right' || e.key === 'Tab') {\n setFocusedElement(focusedElement >= maxElement ? 0 : focusedElement + 1);\n } else if (e.key === 'Delete' || e.key === 'Del') {\n _value[focusedElement] = '';\n } else {\n return;\n }\n\n e.preventDefault();\n setInternalValue(_value);\n onInternalValueChange(_value);\n },\n [\n elementsConfig,\n focusedElement,\n internalValue,\n maxElement,\n onInternalValueChange,\n removeFocusFromField,\n ],\n );\n\n return {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n closeCalendar,\n internalValue,\n focusedElement,\n setFocusedElement,\n handleKeyDown,\n clear,\n handleFieldEnter,\n removeFocusFromField,\n };\n}\n"],"names":["React","useDOM","useBooleanState","useGlobalEventListener","useDateInput","maxElement","refs","autoFocus","disabled","elementsConfig","onChange","onInternalValueChange","getInternalValue","value","document","open","setTrue","openCalendar","setFalse","closeCalendar","rootRef","useRef","calendarRef","internalValue","setInternalValue","useState","focusedElement","setFocusedElement","window","removeFocusFromField","useCallback","getSelection","removeAllRanges","handleClickOutside","e","current","contains","target","selectFirst","capture","useEffect","range","createRange","element","focus","selectNodeContents","selection","addRange","clear","undefined","handleFieldEnter","handleKeyDown","_value","config","test","key","length","slice","currentValue","Number","String","min","max","padStart","shiftKey","preventDefault"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useDirection.ts"],"sourcesContent":["import * as React from 'react';\nimport { useDOM } from '../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\n\ntype Direction = 'ltr' | 'rtl';\ntype WritingMode = 'horizontal-tb' | 'vertical-rl' | 'vertical-lr';\n\n/**\n * Определяет направление текста элемента.\n *\n * ## Ограничения\n *\n * - Не следит за изменением направлением.\n * - Определяется только на второй рендер.\n *\n * ## Пример\n *\n * ```jsx\n * import { strict as assert } from 'node:assert';\n *\n * const Component = () => {\n * const [ref, direction, writingMode] = useDirection();\n *\n * React.useEffect(()=>{\n * if (!direction || !writingMode) {\n * return\n * }\n *\n * assert.equal(direction, 'ltr')\n * assert.equal(writingMode, 'vertical-rl')\n * }, [direction, writingMode])\n *\n * return <div ref={ref} style={{writingMode: 'vertical-rl'}}>我家没有电脑。</div>\n * }\n * ```\n */\nexport function useDirection<T extends HTMLElement>(): [\n React.RefObject<T>,\n Direction | undefined,\n WritingMode | undefined,\n] {\n const ref = React.useRef<T>(null);\n\n const [direction, setDirection] = React.useState<Direction | undefined>(undefined);\n const [writingMode, setWritingMode] = React.useState<WritingMode | undefined>(undefined);\n\n const { window } = useDOM();\n\n const update = () => {\n if (!window || !ref.current) {\n return;\n }\n\n const styleDeclaration = window.getComputedStyle(ref.current);\n\n setDirection(styleDeclaration.direction as Direction);\n setWritingMode(styleDeclaration.writingMode as WritingMode);\n };\n\n useIsomorphicLayoutEffect(update, [window]);\n\n return [ref, direction, writingMode];\n}\n"],"names":["React","useDOM","useIsomorphicLayoutEffect","useDirection","ref","useRef","direction","setDirection","useState","undefined","writingMode","setWritingMode","window","update","current","styleDeclaration","getComputedStyle"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,MAAM,QAAQ,aAAa;AACpC,SAASC,yBAAyB,QAAQ,mCAAmC;AAK7E;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4BC,GACD,OAAO,SAASC;IAKd,MAAMC,MAAMJ,MAAMK,MAAM,CAAI;IAE5B,MAAM,CAACC,WAAWC,aAAa,GAAGP,MAAMQ,QAAQ,CAAwBC;IACxE,MAAM,CAACC,aAAaC,eAAe,GAAGX,MAAMQ,QAAQ,CAA0BC;IAE9E,MAAM,EAAEG,MAAM,EAAE,GAAGX;IAEnB,MAAMY,SAAS;QACb,IAAI,CAACD,UAAU,CAACR,IAAIU,OAAO,EAAE;YAC3B;QACF;QAEA,MAAMC,mBAAmBH,OAAOI,gBAAgB,CAACZ,IAAIU,OAAO;QAE5DP,aAAaQ,iBAAiBT,SAAS;QACvCK,eAAeI,iBAAiBL,WAAW;IAC7C;IAEAR,0BAA0BW,QAAQ;QAACD;KAAO;IAE1C,OAAO;QAACR;QAAKE;QAAWI;KAAY;AACtC"}
1
+ {"version":3,"sources":["../../src/hooks/useDirection.ts"],"sourcesContent":["import * as React from 'react';\nimport { useDOM } from '../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\n\ntype Direction = 'ltr' | 'rtl';\ntype WritingMode = 'horizontal-tb' | 'vertical-rl' | 'vertical-lr';\n\n/**\n * Определяет направление текста элемента.\n *\n * ## Ограничения\n *\n * - Не следит за изменением направлением.\n * - Определяется только на второй рендер.\n *\n * ## Пример\n *\n * ```jsx\n * import { strict as assert } from 'node:assert';\n *\n * const Component = () => {\n * const [ref, direction, writingMode] = useDirection();\n *\n * React.useEffect(()=>{\n * if (!direction || !writingMode) {\n * return\n * }\n *\n * assert.equal(direction, 'ltr')\n * assert.equal(writingMode, 'vertical-rl')\n * }, [direction, writingMode])\n *\n * return <div ref={ref} style={{writingMode: 'vertical-rl'}}>我家没有电脑。</div>\n * }\n * ```\n */\nexport function useDirection<T extends HTMLElement>(): [\n React.RefObject<T>,\n Direction | undefined,\n WritingMode | undefined,\n] {\n const ref = React.useRef<T>(null);\n\n const [direction, setDirection] = React.useState<Direction | undefined>(undefined);\n const [writingMode, setWritingMode] = React.useState<WritingMode | undefined>(undefined);\n\n const { window } = useDOM();\n\n const update = () => {\n if (!window || !ref.current) {\n return;\n }\n\n const styleDeclaration = window.getComputedStyle(ref.current);\n\n setDirection(styleDeclaration.direction as Direction);\n setWritingMode(styleDeclaration.writingMode as WritingMode);\n };\n\n useIsomorphicLayoutEffect(update, [window]);\n\n return [ref, direction, writingMode];\n}\n"],"names":["React","useDOM","useIsomorphicLayoutEffect","useDirection","ref","useRef","direction","setDirection","useState","undefined","writingMode","setWritingMode","window","update","current","styleDeclaration","getComputedStyle"],"mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,MAAM,QAAQ,aAAa;AACpC,SAASC,yBAAyB,QAAQ,mCAAmC;AAK7E;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4BC,GACD,OAAO,SAASC;IAKd,MAAMC,MAAMJ,MAAMK,MAAM,CAAI;IAE5B,MAAM,CAACC,WAAWC,aAAa,GAAGP,MAAMQ,QAAQ,CAAwBC;IACxE,MAAM,CAACC,aAAaC,eAAe,GAAGX,MAAMQ,QAAQ,CAA0BC;IAE9E,MAAM,EAAEG,MAAM,EAAE,GAAGX;IAEnB,MAAMY,SAAS;QACb,IAAI,CAACD,UAAU,CAACR,IAAIU,OAAO,EAAE;YAC3B;QACF;QAEA,MAAMC,mBAAmBH,OAAOI,gBAAgB,CAACZ,IAAIU,OAAO;QAE5DP,aAAaQ,iBAAiBT,SAAS;QACvCK,eAAeI,iBAAiBL,WAAW;IAC7C;IAEAR,0BAA0BW,QAAQ;QAACD;KAAO;IAE1C,OAAO;QAACR;QAAKE;QAAWI;KAAY;AACtC"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/hooks/useDraggableWithDomApi/autoScroll.ts"],"sourcesContent":["import { getNodeScroll, getScrollHeight, getScrollRect } from '../../lib/dom';\nimport { rafSchd } from '../../lib/rafSchd';\n\nconst SCROLL_SPEED = 10;\nexport const EDGE_SIZE = 50;\n\nexport const getAutoScrollingData = (clientY: number, scrollEl: Element | Window) => {\n const scrollTop = Math.floor(getNodeScroll(scrollEl).scrollTop);\n\n const { relative, edges } = getScrollRect(scrollEl);\n const viewportHeight = relative.height;\n const documentHeight = getScrollHeight(scrollEl);\n const maxScrollY = documentHeight - viewportHeight;\n const canScrollUp = scrollTop > 0;\n const canScrollDown = scrollTop < maxScrollY;\n\n const [edgeTop, edgeBottom] = edges.y;\n const topDistance = clientY - edgeTop;\n const bottomDistance = edgeBottom - clientY;\n const isInTopEdge = topDistance <= EDGE_SIZE;\n const isInBottomEdge = bottomDistance <= EDGE_SIZE;\n\n const result = {\n shouldScrolling: (canScrollUp && isInTopEdge) || (canScrollDown && isInBottomEdge),\n y: 0,\n };\n\n // Inspired by https://github.com/SortableJS/Sortable/issues/1907#issuecomment-1495403785\n if (isInTopEdge) {\n result.y = -1 * ((EDGE_SIZE - topDistance) / EDGE_SIZE) * SCROLL_SPEED;\n } else if (isInBottomEdge) {\n result.y = ((EDGE_SIZE - bottomDistance) / EDGE_SIZE) * SCROLL_SPEED;\n }\n\n return result;\n};\n\nexport type AutoScrollingDataFn = () => { shouldScrolling: boolean; y: number };\n\nexport const createAutoScrollController = (scrollEl: Element | Window) => {\n let isRunning = false;\n const scheduledScroll = rafSchd(scroll);\n\n function scroll(fn: AutoScrollingDataFn) {\n const { shouldScrolling, y } = fn();\n if (shouldScrolling) {\n isRunning = true;\n scrollEl.scrollBy(0, y);\n scheduledScroll(fn);\n } else {\n isRunning = false;\n scheduledScroll.cancel();\n }\n }\n\n const tryAutoScroll = (fn: AutoScrollingDataFn) => {\n scheduledScroll(fn);\n };\n\n const stop = () => {\n isRunning = false;\n scheduledScroll.cancel();\n };\n\n return {\n tryAutoScroll,\n stop,\n get isRunning() {\n return isRunning;\n },\n };\n};\n"],"names":["getNodeScroll","getScrollHeight","getScrollRect","rafSchd","SCROLL_SPEED","EDGE_SIZE","getAutoScrollingData","clientY","scrollEl","scrollTop","Math","floor","relative","edges","viewportHeight","height","documentHeight","maxScrollY","canScrollUp","canScrollDown","edgeTop","edgeBottom","y","topDistance","bottomDistance","isInTopEdge","isInBottomEdge","result","shouldScrolling","createAutoScrollController","isRunning","scheduledScroll","scroll","fn","scrollBy","cancel","tryAutoScroll","stop"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,SAASA,aAAa,EAAEC,eAAe,EAAEC,aAAa,QAAQ,gBAAgB;AAC9E,SAASC,OAAO,QAAQ,oBAAoB;AAE5C,MAAMC,eAAe;AACrB,OAAO,MAAMC,YAAY,GAAG;AAE5B,OAAO,MAAMC,uBAAuB,CAACC,SAAiBC;IACpD,MAAMC,YAAYC,KAAKC,KAAK,CAACX,cAAcQ,UAAUC,SAAS;IAE9D,MAAM,EAAEG,QAAQ,EAAEC,KAAK,EAAE,GAAGX,cAAcM;IAC1C,MAAMM,iBAAiBF,SAASG,MAAM;IACtC,MAAMC,iBAAiBf,gBAAgBO;IACvC,MAAMS,aAAaD,iBAAiBF;IACpC,MAAMI,cAAcT,YAAY;IAChC,MAAMU,gBAAgBV,YAAYQ;IAElC,MAAM,CAACG,SAASC,WAAW,GAAGR,MAAMS,CAAC;IACrC,MAAMC,cAAchB,UAAUa;IAC9B,MAAMI,iBAAiBH,aAAad;IACpC,MAAMkB,cAAcF,eAAelB;IACnC,MAAMqB,iBAAiBF,kBAAkBnB;IAEzC,MAAMsB,SAAS;QACbC,iBAAiB,AAACV,eAAeO,eAAiBN,iBAAiBO;QACnEJ,GAAG;IACL;IAEA,yFAAyF;IACzF,IAAIG,aAAa;QACfE,OAAOL,CAAC,GAAG,CAAC,IAAK,CAAA,AAACjB,CAAAA,YAAYkB,WAAU,IAAKlB,SAAQ,IAAKD;IAC5D,OAAO,IAAIsB,gBAAgB;QACzBC,OAAOL,CAAC,GAAG,AAAEjB,CAAAA,YAAYmB,cAAa,IAAKnB,YAAaD;IAC1D;IAEA,OAAOuB;AACT,EAAE;AAIF,OAAO,MAAME,6BAA6B,CAACrB;IACzC,IAAIsB,YAAY;IAChB,MAAMC,kBAAkB5B,QAAQ6B;IAEhC,SAASA,OAAOC,EAAuB;QACrC,MAAM,EAAEL,eAAe,EAAEN,CAAC,EAAE,GAAGW;QAC/B,IAAIL,iBAAiB;YACnBE,YAAY;YACZtB,SAAS0B,QAAQ,CAAC,GAAGZ;YACrBS,gBAAgBE;QAClB,OAAO;YACLH,YAAY;YACZC,gBAAgBI,MAAM;QACxB;IACF;IAEA,MAAMC,gBAAgB,CAACH;QACrBF,gBAAgBE;IAClB;IAEA,MAAMI,OAAO;QACXP,YAAY;QACZC,gBAAgBI,MAAM;IACxB;IAEA,OAAO;QACLC;QACAC;QACA,IAAIP,aAAY;YACd,OAAOA;QACT;IACF;AACF,EAAE"}
1
+ {"version":3,"sources":["../../../src/hooks/useDraggableWithDomApi/autoScroll.ts"],"sourcesContent":["import { getNodeScroll, getScrollHeight, getScrollRect } from '../../lib/dom';\nimport { rafSchd } from '../../lib/rafSchd';\n\nconst SCROLL_SPEED = 10;\nexport const EDGE_SIZE = 50;\n\nexport const getAutoScrollingData = (clientY: number, scrollEl: Element | Window) => {\n const scrollTop = Math.floor(getNodeScroll(scrollEl).scrollTop);\n\n const { relative, edges } = getScrollRect(scrollEl);\n const viewportHeight = relative.height;\n const documentHeight = getScrollHeight(scrollEl);\n const maxScrollY = documentHeight - viewportHeight;\n const canScrollUp = scrollTop > 0;\n const canScrollDown = scrollTop < maxScrollY;\n\n const [edgeTop, edgeBottom] = edges.y;\n const topDistance = clientY - edgeTop;\n const bottomDistance = edgeBottom - clientY;\n const isInTopEdge = topDistance <= EDGE_SIZE;\n const isInBottomEdge = bottomDistance <= EDGE_SIZE;\n\n const result = {\n shouldScrolling: (canScrollUp && isInTopEdge) || (canScrollDown && isInBottomEdge),\n y: 0,\n };\n\n // Inspired by https://github.com/SortableJS/Sortable/issues/1907#issuecomment-1495403785\n if (isInTopEdge) {\n result.y = -1 * ((EDGE_SIZE - topDistance) / EDGE_SIZE) * SCROLL_SPEED;\n } else if (isInBottomEdge) {\n result.y = ((EDGE_SIZE - bottomDistance) / EDGE_SIZE) * SCROLL_SPEED;\n }\n\n return result;\n};\n\nexport type AutoScrollingDataFn = () => { shouldScrolling: boolean; y: number };\n\nexport const createAutoScrollController = (scrollEl: Element | Window) => {\n let isRunning = false;\n const scheduledScroll = rafSchd(scroll);\n\n function scroll(fn: AutoScrollingDataFn) {\n const { shouldScrolling, y } = fn();\n if (shouldScrolling) {\n isRunning = true;\n scrollEl.scrollBy(0, y);\n scheduledScroll(fn);\n } else {\n isRunning = false;\n scheduledScroll.cancel();\n }\n }\n\n const tryAutoScroll = (fn: AutoScrollingDataFn) => {\n scheduledScroll(fn);\n };\n\n const stop = () => {\n isRunning = false;\n scheduledScroll.cancel();\n };\n\n return {\n tryAutoScroll,\n stop,\n get isRunning() {\n return isRunning;\n },\n };\n};\n"],"names":["getNodeScroll","getScrollHeight","getScrollRect","rafSchd","SCROLL_SPEED","EDGE_SIZE","getAutoScrollingData","clientY","scrollEl","scrollTop","Math","floor","relative","edges","viewportHeight","height","documentHeight","maxScrollY","canScrollUp","canScrollDown","edgeTop","edgeBottom","y","topDistance","bottomDistance","isInTopEdge","isInBottomEdge","result","shouldScrolling","createAutoScrollController","isRunning","scheduledScroll","scroll","fn","scrollBy","cancel","tryAutoScroll","stop"],"mappings":"AAAA,SAASA,aAAa,EAAEC,eAAe,EAAEC,aAAa,QAAQ,gBAAgB;AAC9E,SAASC,OAAO,QAAQ,oBAAoB;AAE5C,MAAMC,eAAe;AACrB,OAAO,MAAMC,YAAY,GAAG;AAE5B,OAAO,MAAMC,uBAAuB,CAACC,SAAiBC;IACpD,MAAMC,YAAYC,KAAKC,KAAK,CAACX,cAAcQ,UAAUC,SAAS;IAE9D,MAAM,EAAEG,QAAQ,EAAEC,KAAK,EAAE,GAAGX,cAAcM;IAC1C,MAAMM,iBAAiBF,SAASG,MAAM;IACtC,MAAMC,iBAAiBf,gBAAgBO;IACvC,MAAMS,aAAaD,iBAAiBF;IACpC,MAAMI,cAAcT,YAAY;IAChC,MAAMU,gBAAgBV,YAAYQ;IAElC,MAAM,CAACG,SAASC,WAAW,GAAGR,MAAMS,CAAC;IACrC,MAAMC,cAAchB,UAAUa;IAC9B,MAAMI,iBAAiBH,aAAad;IACpC,MAAMkB,cAAcF,eAAelB;IACnC,MAAMqB,iBAAiBF,kBAAkBnB;IAEzC,MAAMsB,SAAS;QACbC,iBAAiB,AAACV,eAAeO,eAAiBN,iBAAiBO;QACnEJ,GAAG;IACL;IAEA,yFAAyF;IACzF,IAAIG,aAAa;QACfE,OAAOL,CAAC,GAAG,CAAC,IAAK,CAAA,AAACjB,CAAAA,YAAYkB,WAAU,IAAKlB,SAAQ,IAAKD;IAC5D,OAAO,IAAIsB,gBAAgB;QACzBC,OAAOL,CAAC,GAAG,AAAEjB,CAAAA,YAAYmB,cAAa,IAAKnB,YAAaD;IAC1D;IAEA,OAAOuB;AACT,EAAE;AAIF,OAAO,MAAME,6BAA6B,CAACrB;IACzC,IAAIsB,YAAY;IAChB,MAAMC,kBAAkB5B,QAAQ6B;IAEhC,SAASA,OAAOC,EAAuB;QACrC,MAAM,EAAEL,eAAe,EAAEN,CAAC,EAAE,GAAGW;QAC/B,IAAIL,iBAAiB;YACnBE,YAAY;YACZtB,SAAS0B,QAAQ,CAAC,GAAGZ;YACrBS,gBAAgBE;QAClB,OAAO;YACLH,YAAY;YACZC,gBAAgBI,MAAM;QACxB;IACF;IAEA,MAAMC,gBAAgB,CAACH;QACrBF,gBAAgBE;IAClB;IAEA,MAAMI,OAAO;QACXP,YAAY;QACZC,gBAAgBI,MAAM;IACxB;IAEA,OAAO;QACLC;QACAC;QACA,IAAIP,aAAY;YACd,OAAOA;QACT;IACF;AACF,EAAE"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/hooks/useDraggableWithDomApi/constants.ts"],"sourcesContent":["export const AUTO_SCROLL_START_DELAY = 300;\n\nexport const ITEM_INITIAL_INDEX = -1;\n\nexport const DATA_DRAGGABLE_PLACEHOLDER_KEY = 'data-draggable-placeholder';\n\nexport const DATA_DRAGGABLE_PLACEHOLDER_REACT_PROP = { [DATA_DRAGGABLE_PLACEHOLDER_KEY]: 'true' };\n"],"names":["AUTO_SCROLL_START_DELAY","ITEM_INITIAL_INDEX","DATA_DRAGGABLE_PLACEHOLDER_KEY","DATA_DRAGGABLE_PLACEHOLDER_REACT_PROP"],"rangeMappings":";;;;;","mappings":"AAAA,OAAO,MAAMA,0BAA0B,IAAI;AAE3C,OAAO,MAAMC,qBAAqB,CAAC,EAAE;AAErC,OAAO,MAAMC,iCAAiC,6BAA6B;AAE3E,OAAO,MAAMC,wCAAwC;IAAE,CAACD,+BAA+B,EAAE;AAAO,EAAE"}
1
+ {"version":3,"sources":["../../../src/hooks/useDraggableWithDomApi/constants.ts"],"sourcesContent":["export const AUTO_SCROLL_START_DELAY = 300;\n\nexport const ITEM_INITIAL_INDEX = -1;\n\nexport const DATA_DRAGGABLE_PLACEHOLDER_KEY = 'data-draggable-placeholder';\n\nexport const DATA_DRAGGABLE_PLACEHOLDER_REACT_PROP = { [DATA_DRAGGABLE_PLACEHOLDER_KEY]: 'true' };\n"],"names":["AUTO_SCROLL_START_DELAY","ITEM_INITIAL_INDEX","DATA_DRAGGABLE_PLACEHOLDER_KEY","DATA_DRAGGABLE_PLACEHOLDER_REACT_PROP"],"mappings":"AAAA,OAAO,MAAMA,0BAA0B,IAAI;AAE3C,OAAO,MAAMC,qBAAqB,CAAC,EAAE;AAErC,OAAO,MAAMC,iCAAiC,6BAA6B;AAE3E,OAAO,MAAMC,wCAAwC;IAAE,CAACD,+BAA+B,EAAE;AAAO,EAAE"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/hooks/useDraggableWithDomApi/index.tsx"],"sourcesContent":["export type * from './types';\n\nexport { DATA_DRAGGABLE_PLACEHOLDER_REACT_PROP } from './constants';\n\nexport { useDraggableWithDomApi } from './useDraggableWithDomApi';\n"],"names":["DATA_DRAGGABLE_PLACEHOLDER_REACT_PROP","useDraggableWithDomApi"],"rangeMappings":";","mappings":"AAEA,SAASA,qCAAqC,QAAQ,cAAc;AAEpE,SAASC,sBAAsB,QAAQ,2BAA2B"}
1
+ {"version":3,"sources":["../../../src/hooks/useDraggableWithDomApi/index.tsx"],"sourcesContent":["export type * from './types';\n\nexport { DATA_DRAGGABLE_PLACEHOLDER_REACT_PROP } from './constants';\n\nexport { useDraggableWithDomApi } from './useDraggableWithDomApi';\n"],"names":["DATA_DRAGGABLE_PLACEHOLDER_REACT_PROP","useDraggableWithDomApi"],"mappings":"AAEA,SAASA,qCAAqC,QAAQ,cAAc;AAEpE,SAASC,sBAAsB,QAAQ,2BAA2B"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/hooks/useDraggableWithDomApi/types.ts"],"sourcesContent":["import * as React from 'react';\nimport type { TouchEvent } from '../../components/Touch/Touch';\n\nexport type Direction = 'up' | 'down';\n\nexport type DraggingItem = {\n index: number;\n el: HTMLElement;\n draggingElRect: DOMRect;\n};\n\nexport type PlaceholderItem = {\n index: number;\n el: HTMLElement;\n draggingElRect: DOMRect;\n};\n\nexport type SiblingItem = {\n index: number;\n el: HTMLElement;\n shifted: boolean;\n draggingElRect: DOMRect;\n};\n\nexport type SwappedItemRange = { from: number; to: number };\n\nexport interface UseDraggableProps<T extends HTMLElement = HTMLElement> {\n elRef: React.MutableRefObject<T | null>;\n onDragFinish?: (value: SwappedItemRange) => void;\n}\n\nexport interface DraggableProps {\n onDragStart: (this: void, event: TouchEvent) => void;\n onDragEnd: (this: void, event: TouchEvent) => void;\n onDragMove: (this: void, event: TouchEvent) => void;\n}\n\nexport interface UseDraggable extends DraggableProps {\n dragging: boolean;\n}\n"],"names":["React"],"rangeMappings":"","mappings":"AAAA,YAAYA,WAAW,QAAQ"}
1
+ {"version":3,"sources":["../../../src/hooks/useDraggableWithDomApi/types.ts"],"sourcesContent":["import * as React from 'react';\nimport type { TouchEvent } from '../../components/Touch/Touch';\n\nexport type Direction = 'up' | 'down';\n\nexport type DraggingItem = {\n index: number;\n el: HTMLElement;\n draggingElRect: DOMRect;\n};\n\nexport type PlaceholderItem = {\n index: number;\n el: HTMLElement;\n draggingElRect: DOMRect;\n};\n\nexport type SiblingItem = {\n index: number;\n el: HTMLElement;\n shifted: boolean;\n draggingElRect: DOMRect;\n};\n\nexport type SwappedItemRange = { from: number; to: number };\n\nexport interface UseDraggableProps<T extends HTMLElement = HTMLElement> {\n elRef: React.MutableRefObject<T | null>;\n onDragFinish?: (value: SwappedItemRange) => void;\n}\n\nexport interface DraggableProps {\n onDragStart: (this: void, event: TouchEvent) => void;\n onDragEnd: (this: void, event: TouchEvent) => void;\n onDragMove: (this: void, event: TouchEvent) => void;\n}\n\nexport interface UseDraggable extends DraggableProps {\n dragging: boolean;\n}\n"],"names":["React"],"mappings":"AAAA,YAAYA,WAAW,QAAQ"}
@@ -1 +1 @@
1
- {"version":3,"file":"useDraggableWithDomApi.d.ts","sourceRoot":"","sources":["../../../src/hooks/useDraggableWithDomApi/useDraggableWithDomApi.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAKV,YAAY,EACZ,iBAAiB,EAClB,MAAM,SAAS,CAAC;AAajB,eAAO,MAAM,sBAAsB,mEAGhC,kBAAkB,CAAC,CAAC,KAAG,YAqQzB,CAAC"}
1
+ {"version":3,"file":"useDraggableWithDomApi.d.ts","sourceRoot":"","sources":["../../../src/hooks/useDraggableWithDomApi/useDraggableWithDomApi.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAKV,YAAY,EACZ,iBAAiB,EAClB,MAAM,SAAS,CAAC;AAajB,eAAO,MAAM,sBAAsB,GAAI,CAAC,SAAS,WAAW,2CAGzD,iBAAiB,CAAC,CAAC,CAAC,KAAG,YAqQzB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/hooks/useDraggableWithDomApi/useDraggableWithDomApi.ts"],"sourcesContent":["import * as React from 'react';\nimport type { TouchEvent } from '../../components/Touch/Touch';\nimport { getBoundingClientRect, getNearestOverflowAncestor, getNodeScroll } from '../../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { createAutoScrollController, getAutoScrollingData } from './autoScroll';\nimport {\n AUTO_SCROLL_START_DELAY,\n DATA_DRAGGABLE_PLACEHOLDER_KEY,\n ITEM_INITIAL_INDEX,\n} from './constants';\nimport type {\n Direction,\n DraggingItem,\n PlaceholderItem,\n SiblingItem,\n UseDraggable,\n UseDraggableProps,\n} from './types';\nimport {\n getTargetIsOverOrUnderElData,\n setDraggingItemShiftStyles,\n setInitialDraggingItemStyles,\n setInitialPlaceholderItemStyles,\n setInitialSiblingItemStyles,\n setSiblingItemsShiftStyles,\n unsetInitialDraggingItemStyles,\n unsetInitialPlaceholderItemStyles,\n unsetInitialSiblingItemStyles,\n} from './utils';\n\nexport const useDraggableWithDomApi = <T extends HTMLElement>({\n elRef: draggingElRef,\n onDragFinish,\n}: UseDraggableProps<T>): UseDraggable => {\n const [dragging, setDragging] = React.useState(false);\n const lastClientYRef = React.useRef(0);\n const lastDragShiftYRef = React.useRef(0);\n\n const scrollElRef = React.useRef<Element | Window | null>(null);\n const lastScrollTopRef = React.useRef<number>(0);\n const scrollControllerRef = React.useRef<ReturnType<typeof createAutoScrollController> | null>(\n null,\n );\n const initializeScrollRefs = (draggableEl: HTMLElement) => {\n const node = getNearestOverflowAncestor(draggableEl);\n if (node) {\n scrollElRef.current = node;\n lastScrollTopRef.current = getNodeScroll(node).scrollTop;\n scrollControllerRef.current = createAutoScrollController(scrollElRef.current);\n }\n };\n const cleanupScrollRefs = () => {\n lastScrollTopRef.current = 0;\n scrollControllerRef.current?.stop();\n scrollElRef.current = scrollControllerRef.current = null;\n };\n\n const lastDragDirectionRef = React.useRef<Direction | undefined>(undefined);\n const toggleDragDirection = (prevShiftY: number, nextShiftY: number) => {\n const shiftYDiff = prevShiftY - nextShiftY;\n if (shiftYDiff < 0) {\n return 'down';\n }\n if (shiftYDiff > 0) {\n return 'up';\n }\n return lastDragDirectionRef.current;\n };\n\n const itemStartIndexRef = React.useRef<number>(ITEM_INITIAL_INDEX);\n const itemEndIndexRef = React.useRef<number>(ITEM_INITIAL_INDEX);\n const draggingItemRef = React.useRef<DraggingItem | null>(null);\n const placeholderItemRef = React.useRef<PlaceholderItem | null>(null);\n const siblingItemsRef = React.useRef<SiblingItem[]>([]);\n const initializeItems = (draggingEl: HTMLElement) => {\n const draggingElRect = getBoundingClientRect(draggingEl, true);\n const { children } = draggingEl.parentElement || { children: [] };\n Array.prototype.forEach.call(children, (el: HTMLElement, index) => {\n if (el === draggingEl) {\n itemStartIndexRef.current = itemEndIndexRef.current = index;\n draggingItemRef.current = { index, el, draggingElRect };\n } else if (el.getAttribute(DATA_DRAGGABLE_PLACEHOLDER_KEY) !== null) {\n placeholderItemRef.current = { index, el, draggingElRect };\n } else {\n siblingItemsRef.current.push({ index, el, shifted: itemStartIndexRef.current !== ITEM_INITIAL_INDEX && itemStartIndexRef.current < index, draggingElRect }); // prettier-ignore\n }\n });\n if (placeholderItemRef.current) {\n setInitialPlaceholderItemStyles(placeholderItemRef.current); // 1. reflow\n }\n if (draggingItemRef.current) {\n setInitialDraggingItemStyles(draggingItemRef.current); // 2. repaint\n }\n siblingItemsRef.current.forEach(setInitialSiblingItemStyles); // 2. repaint\n };\n const cleanupItems = () => {\n if (placeholderItemRef.current) {\n unsetInitialPlaceholderItemStyles(placeholderItemRef.current); // 1. reflow\n }\n if (draggingItemRef.current) {\n unsetInitialDraggingItemStyles(draggingItemRef.current); // 2. repaint\n }\n siblingItemsRef.current.forEach(unsetInitialSiblingItemStyles); // 2. repaint\n siblingItemsRef.current = [];\n placeholderItemRef.current = draggingItemRef.current = null;\n\n const swappedItemIndexRange = { from: itemStartIndexRef.current, to: itemEndIndexRef.current };\n itemStartIndexRef.current = itemEndIndexRef.current = ITEM_INITIAL_INDEX;\n return swappedItemIndexRange;\n };\n const getShiftAndUnshiftItemsPreparedData = (\n clientY: number,\n ): [Array<[SiblingItem, Direction]>, Array<[SiblingItem, Direction]>] => {\n const shiftItemEls: Array<[SiblingItem, Direction]> = [];\n const unshiftItemEls: Array<[SiblingItem, Direction]> = [];\n itemEndIndexRef.current = itemStartIndexRef.current;\n siblingItemsRef.current.forEach((siblingItem) => {\n const { isOverEl, isUnderEl } = getTargetIsOverOrUnderElData(\n clientY,\n getBoundingClientRect(siblingItem.el),\n );\n if (itemStartIndexRef.current < siblingItem.index) {\n if (isOverEl) {\n itemEndIndexRef.current = itemEndIndexRef.current + 1;\n if (lastDragDirectionRef.current === 'down' && siblingItem.shifted) {\n siblingItem.shifted = false;\n shiftItemEls.push([siblingItem, 'up']);\n }\n }\n if (isUnderEl) {\n if (lastDragDirectionRef.current === 'up' && !siblingItem.shifted) {\n siblingItem.shifted = true;\n unshiftItemEls.push([siblingItem, 'down']);\n }\n }\n } else if (itemStartIndexRef.current > siblingItem.index) {\n if (isUnderEl) {\n itemEndIndexRef.current = itemEndIndexRef.current - 1;\n if (lastDragDirectionRef.current === 'up' && !siblingItem.shifted) {\n siblingItem.shifted = true;\n shiftItemEls.push([siblingItem, 'down']);\n }\n }\n if (isOverEl) {\n if (lastDragDirectionRef.current === 'down' && siblingItem.shifted) {\n siblingItem.shifted = false;\n unshiftItemEls.push([siblingItem, 'up']);\n }\n }\n }\n });\n return [shiftItemEls, unshiftItemEls];\n };\n const setShiftAndUnshiftItemStyles = (\n shiftItemEls: Array<[SiblingItem, Direction]>,\n unshiftItemEls: Array<[SiblingItem, Direction]>,\n ) => {\n shiftItemEls.forEach(setSiblingItemsShiftStyles);\n unshiftItemEls.forEach(setSiblingItemsShiftStyles);\n };\n\n const schedulingAutoScrollTimeoutIdRef = React.useRef<ReturnType<typeof setTimeout> | null>(null);\n const clearSchedulingAutoScrollTimeout = () => {\n if (schedulingAutoScrollTimeoutIdRef.current) {\n clearTimeout(schedulingAutoScrollTimeoutIdRef.current);\n schedulingAutoScrollTimeoutIdRef.current = null;\n }\n };\n const tryAutoScroll = () => {\n if (scrollControllerRef.current) {\n scrollControllerRef.current.tryAutoScroll(() => {\n return scrollElRef.current\n ? getAutoScrollingData(lastClientYRef.current, scrollElRef.current)\n : {\n shouldScrolling: false,\n y: 0,\n };\n });\n }\n };\n const schedulingAutoScroll = () => {\n clearSchedulingAutoScrollTimeout();\n schedulingAutoScrollTimeoutIdRef.current = setTimeout(() => {\n schedulingAutoScrollTimeoutIdRef.current = null;\n tryAutoScroll();\n }, AUTO_SCROLL_START_DELAY);\n };\n\n const onDragStart = (event: TouchEvent) => {\n event.originalEvent.stopPropagation();\n event.originalEvent.preventDefault();\n };\n\n const onDragMove = (event: TouchEvent) => {\n event.originalEvent.stopPropagation();\n event.originalEvent.preventDefault();\n\n const draggingEl = draggingElRef.current;\n\n if (!draggingEl) {\n return;\n }\n\n if (dragging) {\n lastDragDirectionRef.current = toggleDragDirection(lastDragShiftYRef.current, event.shiftY);\n lastDragShiftYRef.current = event.shiftY;\n lastClientYRef.current = event.clientY;\n\n if (scrollControllerRef.current && scrollControllerRef.current.isRunning) {\n setDraggingItemShiftStyles(draggingEl, lastDragShiftYRef.current);\n } else {\n const [shiftItemEls, unshiftItemEls] = getShiftAndUnshiftItemsPreparedData(\n lastClientYRef.current,\n );\n setDraggingItemShiftStyles(draggingEl, lastDragShiftYRef.current);\n setShiftAndUnshiftItemStyles(shiftItemEls, unshiftItemEls);\n schedulingAutoScroll();\n }\n } else {\n setDragging((prevDragging) => {\n // На случай, если onDragMove успеет вызваться ещё раз до того, как `dragging` выставится в\n // `true`\n if (prevDragging) {\n return prevDragging;\n }\n initializeScrollRefs(draggingEl);\n initializeItems(draggingEl);\n return true;\n });\n }\n };\n\n const onDragEnd = (event: TouchEvent) => {\n event.originalEvent.stopPropagation();\n event.originalEvent.preventDefault();\n\n clearSchedulingAutoScrollTimeout();\n cleanupScrollRefs();\n\n lastClientYRef.current = lastDragShiftYRef.current = 0;\n lastDragDirectionRef.current = undefined;\n\n if (dragging) {\n const swappedItemRange = cleanupItems();\n if (onDragFinish) {\n onDragFinish(swappedItemRange);\n }\n setDragging(false);\n }\n };\n\n const handleScroll = React.useCallback(() => {\n if (!draggingElRef.current || !scrollElRef.current) {\n return;\n }\n\n const nextScrollTop = getNodeScroll(scrollElRef.current).scrollTop;\n lastDragDirectionRef.current = toggleDragDirection(lastScrollTopRef.current, nextScrollTop);\n const scrollDiff = lastScrollTopRef.current - nextScrollTop;\n const clientYWithScrollOffset = lastClientYRef.current + scrollDiff;\n lastScrollTopRef.current = nextScrollTop;\n\n const [shiftItemEls, unshiftItemEls] =\n getShiftAndUnshiftItemsPreparedData(clientYWithScrollOffset);\n setShiftAndUnshiftItemStyles(shiftItemEls, unshiftItemEls);\n }, [draggingElRef]);\n\n useIsomorphicLayoutEffect(\n function recalculateOnScroll() {\n const scrollEl = scrollElRef.current;\n if (!dragging || !scrollEl) {\n return;\n }\n scrollEl.addEventListener('scroll', handleScroll);\n return () => {\n if (scrollEl) {\n scrollEl.removeEventListener('scroll', handleScroll);\n }\n };\n },\n [dragging, handleScroll],\n );\n\n useIsomorphicLayoutEffect(\n () =>\n function componentWillUnmount() {\n if (placeholderItemRef.current) {\n unsetInitialPlaceholderItemStyles(placeholderItemRef.current);\n }\n },\n [],\n );\n\n return { dragging, onDragStart, onDragMove, onDragEnd };\n};\n"],"names":["React","getBoundingClientRect","getNearestOverflowAncestor","getNodeScroll","useIsomorphicLayoutEffect","createAutoScrollController","getAutoScrollingData","AUTO_SCROLL_START_DELAY","DATA_DRAGGABLE_PLACEHOLDER_KEY","ITEM_INITIAL_INDEX","getTargetIsOverOrUnderElData","setDraggingItemShiftStyles","setInitialDraggingItemStyles","setInitialPlaceholderItemStyles","setInitialSiblingItemStyles","setSiblingItemsShiftStyles","unsetInitialDraggingItemStyles","unsetInitialPlaceholderItemStyles","unsetInitialSiblingItemStyles","useDraggableWithDomApi","elRef","draggingElRef","onDragFinish","dragging","setDragging","useState","lastClientYRef","useRef","lastDragShiftYRef","scrollElRef","lastScrollTopRef","scrollControllerRef","initializeScrollRefs","draggableEl","node","current","scrollTop","cleanupScrollRefs","stop","lastDragDirectionRef","undefined","toggleDragDirection","prevShiftY","nextShiftY","shiftYDiff","itemStartIndexRef","itemEndIndexRef","draggingItemRef","placeholderItemRef","siblingItemsRef","initializeItems","draggingEl","draggingElRect","children","parentElement","Array","prototype","forEach","call","el","index","getAttribute","push","shifted","cleanupItems","swappedItemIndexRange","from","to","getShiftAndUnshiftItemsPreparedData","clientY","shiftItemEls","unshiftItemEls","siblingItem","isOverEl","isUnderEl","setShiftAndUnshiftItemStyles","schedulingAutoScrollTimeoutIdRef","clearSchedulingAutoScrollTimeout","clearTimeout","tryAutoScroll","shouldScrolling","y","schedulingAutoScroll","setTimeout","onDragStart","event","originalEvent","stopPropagation","preventDefault","onDragMove","shiftY","isRunning","prevDragging","onDragEnd","swappedItemRange","handleScroll","useCallback","nextScrollTop","scrollDiff","clientYWithScrollOffset","recalculateOnScroll","scrollEl","addEventListener","removeEventListener","componentWillUnmount"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["../../../src/hooks/useDraggableWithDomApi/useDraggableWithDomApi.ts"],"sourcesContent":["import * as React from 'react';\nimport type { TouchEvent } from '../../components/Touch/Touch';\nimport { getBoundingClientRect, getNearestOverflowAncestor, getNodeScroll } from '../../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { createAutoScrollController, getAutoScrollingData } from './autoScroll';\nimport {\n AUTO_SCROLL_START_DELAY,\n DATA_DRAGGABLE_PLACEHOLDER_KEY,\n ITEM_INITIAL_INDEX,\n} from './constants';\nimport type {\n Direction,\n DraggingItem,\n PlaceholderItem,\n SiblingItem,\n UseDraggable,\n UseDraggableProps,\n} from './types';\nimport {\n getTargetIsOverOrUnderElData,\n setDraggingItemShiftStyles,\n setInitialDraggingItemStyles,\n setInitialPlaceholderItemStyles,\n setInitialSiblingItemStyles,\n setSiblingItemsShiftStyles,\n unsetInitialDraggingItemStyles,\n unsetInitialPlaceholderItemStyles,\n unsetInitialSiblingItemStyles,\n} from './utils';\n\nexport const useDraggableWithDomApi = <T extends HTMLElement>({\n elRef: draggingElRef,\n onDragFinish,\n}: UseDraggableProps<T>): UseDraggable => {\n const [dragging, setDragging] = React.useState(false);\n const lastClientYRef = React.useRef(0);\n const lastDragShiftYRef = React.useRef(0);\n\n const scrollElRef = React.useRef<Element | Window | null>(null);\n const lastScrollTopRef = React.useRef<number>(0);\n const scrollControllerRef = React.useRef<ReturnType<typeof createAutoScrollController> | null>(\n null,\n );\n const initializeScrollRefs = (draggableEl: HTMLElement) => {\n const node = getNearestOverflowAncestor(draggableEl);\n if (node) {\n scrollElRef.current = node;\n lastScrollTopRef.current = getNodeScroll(node).scrollTop;\n scrollControllerRef.current = createAutoScrollController(scrollElRef.current);\n }\n };\n const cleanupScrollRefs = () => {\n lastScrollTopRef.current = 0;\n scrollControllerRef.current?.stop();\n scrollElRef.current = scrollControllerRef.current = null;\n };\n\n const lastDragDirectionRef = React.useRef<Direction | undefined>(undefined);\n const toggleDragDirection = (prevShiftY: number, nextShiftY: number) => {\n const shiftYDiff = prevShiftY - nextShiftY;\n if (shiftYDiff < 0) {\n return 'down';\n }\n if (shiftYDiff > 0) {\n return 'up';\n }\n return lastDragDirectionRef.current;\n };\n\n const itemStartIndexRef = React.useRef<number>(ITEM_INITIAL_INDEX);\n const itemEndIndexRef = React.useRef<number>(ITEM_INITIAL_INDEX);\n const draggingItemRef = React.useRef<DraggingItem | null>(null);\n const placeholderItemRef = React.useRef<PlaceholderItem | null>(null);\n const siblingItemsRef = React.useRef<SiblingItem[]>([]);\n const initializeItems = (draggingEl: HTMLElement) => {\n const draggingElRect = getBoundingClientRect(draggingEl, true);\n const { children } = draggingEl.parentElement || { children: [] };\n Array.prototype.forEach.call(children, (el: HTMLElement, index) => {\n if (el === draggingEl) {\n itemStartIndexRef.current = itemEndIndexRef.current = index;\n draggingItemRef.current = { index, el, draggingElRect };\n } else if (el.getAttribute(DATA_DRAGGABLE_PLACEHOLDER_KEY) !== null) {\n placeholderItemRef.current = { index, el, draggingElRect };\n } else {\n siblingItemsRef.current.push({ index, el, shifted: itemStartIndexRef.current !== ITEM_INITIAL_INDEX && itemStartIndexRef.current < index, draggingElRect }); // prettier-ignore\n }\n });\n if (placeholderItemRef.current) {\n setInitialPlaceholderItemStyles(placeholderItemRef.current); // 1. reflow\n }\n if (draggingItemRef.current) {\n setInitialDraggingItemStyles(draggingItemRef.current); // 2. repaint\n }\n siblingItemsRef.current.forEach(setInitialSiblingItemStyles); // 2. repaint\n };\n const cleanupItems = () => {\n if (placeholderItemRef.current) {\n unsetInitialPlaceholderItemStyles(placeholderItemRef.current); // 1. reflow\n }\n if (draggingItemRef.current) {\n unsetInitialDraggingItemStyles(draggingItemRef.current); // 2. repaint\n }\n siblingItemsRef.current.forEach(unsetInitialSiblingItemStyles); // 2. repaint\n siblingItemsRef.current = [];\n placeholderItemRef.current = draggingItemRef.current = null;\n\n const swappedItemIndexRange = { from: itemStartIndexRef.current, to: itemEndIndexRef.current };\n itemStartIndexRef.current = itemEndIndexRef.current = ITEM_INITIAL_INDEX;\n return swappedItemIndexRange;\n };\n const getShiftAndUnshiftItemsPreparedData = (\n clientY: number,\n ): [Array<[SiblingItem, Direction]>, Array<[SiblingItem, Direction]>] => {\n const shiftItemEls: Array<[SiblingItem, Direction]> = [];\n const unshiftItemEls: Array<[SiblingItem, Direction]> = [];\n itemEndIndexRef.current = itemStartIndexRef.current;\n siblingItemsRef.current.forEach((siblingItem) => {\n const { isOverEl, isUnderEl } = getTargetIsOverOrUnderElData(\n clientY,\n getBoundingClientRect(siblingItem.el),\n );\n if (itemStartIndexRef.current < siblingItem.index) {\n if (isOverEl) {\n itemEndIndexRef.current = itemEndIndexRef.current + 1;\n if (lastDragDirectionRef.current === 'down' && siblingItem.shifted) {\n siblingItem.shifted = false;\n shiftItemEls.push([siblingItem, 'up']);\n }\n }\n if (isUnderEl) {\n if (lastDragDirectionRef.current === 'up' && !siblingItem.shifted) {\n siblingItem.shifted = true;\n unshiftItemEls.push([siblingItem, 'down']);\n }\n }\n } else if (itemStartIndexRef.current > siblingItem.index) {\n if (isUnderEl) {\n itemEndIndexRef.current = itemEndIndexRef.current - 1;\n if (lastDragDirectionRef.current === 'up' && !siblingItem.shifted) {\n siblingItem.shifted = true;\n shiftItemEls.push([siblingItem, 'down']);\n }\n }\n if (isOverEl) {\n if (lastDragDirectionRef.current === 'down' && siblingItem.shifted) {\n siblingItem.shifted = false;\n unshiftItemEls.push([siblingItem, 'up']);\n }\n }\n }\n });\n return [shiftItemEls, unshiftItemEls];\n };\n const setShiftAndUnshiftItemStyles = (\n shiftItemEls: Array<[SiblingItem, Direction]>,\n unshiftItemEls: Array<[SiblingItem, Direction]>,\n ) => {\n shiftItemEls.forEach(setSiblingItemsShiftStyles);\n unshiftItemEls.forEach(setSiblingItemsShiftStyles);\n };\n\n const schedulingAutoScrollTimeoutIdRef = React.useRef<ReturnType<typeof setTimeout> | null>(null);\n const clearSchedulingAutoScrollTimeout = () => {\n if (schedulingAutoScrollTimeoutIdRef.current) {\n clearTimeout(schedulingAutoScrollTimeoutIdRef.current);\n schedulingAutoScrollTimeoutIdRef.current = null;\n }\n };\n const tryAutoScroll = () => {\n if (scrollControllerRef.current) {\n scrollControllerRef.current.tryAutoScroll(() => {\n return scrollElRef.current\n ? getAutoScrollingData(lastClientYRef.current, scrollElRef.current)\n : {\n shouldScrolling: false,\n y: 0,\n };\n });\n }\n };\n const schedulingAutoScroll = () => {\n clearSchedulingAutoScrollTimeout();\n schedulingAutoScrollTimeoutIdRef.current = setTimeout(() => {\n schedulingAutoScrollTimeoutIdRef.current = null;\n tryAutoScroll();\n }, AUTO_SCROLL_START_DELAY);\n };\n\n const onDragStart = (event: TouchEvent) => {\n event.originalEvent.stopPropagation();\n event.originalEvent.preventDefault();\n };\n\n const onDragMove = (event: TouchEvent) => {\n event.originalEvent.stopPropagation();\n event.originalEvent.preventDefault();\n\n const draggingEl = draggingElRef.current;\n\n if (!draggingEl) {\n return;\n }\n\n if (dragging) {\n lastDragDirectionRef.current = toggleDragDirection(lastDragShiftYRef.current, event.shiftY);\n lastDragShiftYRef.current = event.shiftY;\n lastClientYRef.current = event.clientY;\n\n if (scrollControllerRef.current && scrollControllerRef.current.isRunning) {\n setDraggingItemShiftStyles(draggingEl, lastDragShiftYRef.current);\n } else {\n const [shiftItemEls, unshiftItemEls] = getShiftAndUnshiftItemsPreparedData(\n lastClientYRef.current,\n );\n setDraggingItemShiftStyles(draggingEl, lastDragShiftYRef.current);\n setShiftAndUnshiftItemStyles(shiftItemEls, unshiftItemEls);\n schedulingAutoScroll();\n }\n } else {\n setDragging((prevDragging) => {\n // На случай, если onDragMove успеет вызваться ещё раз до того, как `dragging` выставится в\n // `true`\n if (prevDragging) {\n return prevDragging;\n }\n initializeScrollRefs(draggingEl);\n initializeItems(draggingEl);\n return true;\n });\n }\n };\n\n const onDragEnd = (event: TouchEvent) => {\n event.originalEvent.stopPropagation();\n event.originalEvent.preventDefault();\n\n clearSchedulingAutoScrollTimeout();\n cleanupScrollRefs();\n\n lastClientYRef.current = lastDragShiftYRef.current = 0;\n lastDragDirectionRef.current = undefined;\n\n if (dragging) {\n const swappedItemRange = cleanupItems();\n if (onDragFinish) {\n onDragFinish(swappedItemRange);\n }\n setDragging(false);\n }\n };\n\n const handleScroll = React.useCallback(() => {\n if (!draggingElRef.current || !scrollElRef.current) {\n return;\n }\n\n const nextScrollTop = getNodeScroll(scrollElRef.current).scrollTop;\n lastDragDirectionRef.current = toggleDragDirection(lastScrollTopRef.current, nextScrollTop);\n const scrollDiff = lastScrollTopRef.current - nextScrollTop;\n const clientYWithScrollOffset = lastClientYRef.current + scrollDiff;\n lastScrollTopRef.current = nextScrollTop;\n\n const [shiftItemEls, unshiftItemEls] =\n getShiftAndUnshiftItemsPreparedData(clientYWithScrollOffset);\n setShiftAndUnshiftItemStyles(shiftItemEls, unshiftItemEls);\n }, [draggingElRef]);\n\n useIsomorphicLayoutEffect(\n function recalculateOnScroll() {\n const scrollEl = scrollElRef.current;\n if (!dragging || !scrollEl) {\n return;\n }\n scrollEl.addEventListener('scroll', handleScroll);\n return () => {\n if (scrollEl) {\n scrollEl.removeEventListener('scroll', handleScroll);\n }\n };\n },\n [dragging, handleScroll],\n );\n\n useIsomorphicLayoutEffect(\n () =>\n function componentWillUnmount() {\n if (placeholderItemRef.current) {\n unsetInitialPlaceholderItemStyles(placeholderItemRef.current);\n }\n },\n [],\n );\n\n return { dragging, onDragStart, onDragMove, onDragEnd };\n};\n"],"names":["React","getBoundingClientRect","getNearestOverflowAncestor","getNodeScroll","useIsomorphicLayoutEffect","createAutoScrollController","getAutoScrollingData","AUTO_SCROLL_START_DELAY","DATA_DRAGGABLE_PLACEHOLDER_KEY","ITEM_INITIAL_INDEX","getTargetIsOverOrUnderElData","setDraggingItemShiftStyles","setInitialDraggingItemStyles","setInitialPlaceholderItemStyles","setInitialSiblingItemStyles","setSiblingItemsShiftStyles","unsetInitialDraggingItemStyles","unsetInitialPlaceholderItemStyles","unsetInitialSiblingItemStyles","useDraggableWithDomApi","elRef","draggingElRef","onDragFinish","dragging","setDragging","useState","lastClientYRef","useRef","lastDragShiftYRef","scrollElRef","lastScrollTopRef","scrollControllerRef","initializeScrollRefs","draggableEl","node","current","scrollTop","cleanupScrollRefs","stop","lastDragDirectionRef","undefined","toggleDragDirection","prevShiftY","nextShiftY","shiftYDiff","itemStartIndexRef","itemEndIndexRef","draggingItemRef","placeholderItemRef","siblingItemsRef","initializeItems","draggingEl","draggingElRect","children","parentElement","Array","prototype","forEach","call","el","index","getAttribute","push","shifted","cleanupItems","swappedItemIndexRange","from","to","getShiftAndUnshiftItemsPreparedData","clientY","shiftItemEls","unshiftItemEls","siblingItem","isOverEl","isUnderEl","setShiftAndUnshiftItemStyles","schedulingAutoScrollTimeoutIdRef","clearSchedulingAutoScrollTimeout","clearTimeout","tryAutoScroll","shouldScrolling","y","schedulingAutoScroll","setTimeout","onDragStart","event","originalEvent","stopPropagation","preventDefault","onDragMove","shiftY","isRunning","prevDragging","onDragEnd","swappedItemRange","handleScroll","useCallback","nextScrollTop","scrollDiff","clientYWithScrollOffset","recalculateOnScroll","scrollEl","addEventListener","removeEventListener","componentWillUnmount"],"mappings":"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"}
@@ -4,11 +4,11 @@ export declare const getTargetIsOverOrUnderElData: (clientY: number, elRect: DOM
4
4
  isOverEl: boolean;
5
5
  };
6
6
  export declare const setDraggingItemShiftStyles: (draggingEl: HTMLElement, nextShiftY: number) => void;
7
- export declare const setSiblingItemsShiftStyles: ([{ el, draggingElRect: { height }, }, direction,]: [Omit<SiblingItem, 'shifted'>, Direction]) => void;
7
+ export declare const setSiblingItemsShiftStyles: ([{ el, draggingElRect: { height }, }, direction,]: [Omit<SiblingItem, "shifted">, Direction]) => void;
8
8
  export declare const setInitialDraggingItemStyles: ({ el, draggingElRect }: DraggingItem) => void;
9
9
  export declare const unsetInitialDraggingItemStyles: ({ el }: DraggingItem) => void;
10
10
  export declare const setInitialPlaceholderItemStyles: ({ el, draggingElRect }: PlaceholderItem) => void;
11
11
  export declare const unsetInitialPlaceholderItemStyles: ({ el }: PlaceholderItem) => void;
12
12
  export declare const setInitialSiblingItemStyles: ({ el, shifted, draggingElRect }: SiblingItem) => void;
13
- export declare const unsetInitialSiblingItemStyles: ({ el }: Omit<SiblingItem, 'shifted'>) => void;
13
+ export declare const unsetInitialSiblingItemStyles: ({ el }: Omit<SiblingItem, "shifted">) => void;
14
14
  //# sourceMappingURL=utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/hooks/useDraggableWithDomApi/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAErF,eAAO,MAAM,4BAA4B,YAAa,MAAM,UAAU,OAAO;;;CAM5E,CAAC;AAEF,eAAO,MAAM,0BAA0B,eAAgB,WAAW,cAAc,MAAM,SAIrF,CAAC;AAEF,eAAO,MAAM,0BAA0B,sDAMpC,CAAC,KAAK,WAAW,EAAE,SAAS,CAAC,EAAE,SAAS,CAAC,SAU3C,CAAC;AAEF,eAAO,MAAM,4BAA4B,2BAA4B,YAAY,SAchF,CAAC;AAEF,eAAO,MAAM,8BAA8B,WAAY,YAAY,SAYlE,CAAC;AAEF,eAAO,MAAM,+BAA+B,2BAA4B,eAAe,SAWtF,CAAC;AAEF,eAAO,MAAM,iCAAiC,WAAY,eAAe,SAIxE,CAAC;AAEF,eAAO,MAAM,2BAA2B,oCAAqC,WAAW,SAUvF,CAAC;AAEF,eAAO,MAAM,6BAA6B,WAAY,KAAK,WAAW,EAAE,SAAS,CAAC,SAMjF,CAAC"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/hooks/useDraggableWithDomApi/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAErF,eAAO,MAAM,4BAA4B,YAAa,MAAM,UAAU,OAAO;;;CAM5E,CAAC;AAEF,eAAO,MAAM,0BAA0B,eAAgB,WAAW,cAAc,MAAM,SAIrF,CAAC;AAEF,eAAO,MAAM,0BAA0B,sDAMpC,CAAC,IAAI,CAAC,WAAW,EAAE,SAAS,CAAC,EAAE,SAAS,CAAC,SAU3C,CAAC;AAEF,eAAO,MAAM,4BAA4B,2BAA4B,YAAY,SAchF,CAAC;AAEF,eAAO,MAAM,8BAA8B,WAAY,YAAY,SAYlE,CAAC;AAEF,eAAO,MAAM,+BAA+B,2BAA4B,eAAe,SAWtF,CAAC;AAEF,eAAO,MAAM,iCAAiC,WAAY,eAAe,SAIxE,CAAC;AAEF,eAAO,MAAM,2BAA2B,oCAAqC,WAAW,SAUvF,CAAC;AAEF,eAAO,MAAM,6BAA6B,WAAY,IAAI,CAAC,WAAW,EAAE,SAAS,CAAC,SAMjF,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/hooks/useDraggableWithDomApi/utils.ts"],"sourcesContent":["import type { Direction, DraggingItem, PlaceholderItem, SiblingItem } from './types';\n\nexport const getTargetIsOverOrUnderElData = (clientY: number, elRect: DOMRect) => {\n const elRectHalfHeight = elRect.height / 2;\n return {\n isUnderEl: clientY <= elRect.bottom - elRectHalfHeight,\n isOverEl: clientY >= elRect.top + elRectHalfHeight,\n };\n};\n\nexport const setDraggingItemShiftStyles = (draggingEl: HTMLElement, nextShiftY: number) => {\n requestAnimationFrame(() => {\n draggingEl.style.transform = `translateY(${nextShiftY}px)`;\n });\n};\n\nexport const setSiblingItemsShiftStyles = ([\n {\n el,\n draggingElRect: { height },\n },\n direction,\n]: [Omit<SiblingItem, 'shifted'>, Direction]) => {\n requestAnimationFrame(() => {\n if (direction === 'up') {\n el.style.setProperty('transition', 'transform 0.3s ease-in 0s');\n el.style.removeProperty('transform');\n } else {\n el.style.setProperty('transition', 'transform 0.3s ease-out 0s');\n el.style.setProperty('transform', `translateY(${height}px)`);\n }\n });\n};\n\nexport const setInitialDraggingItemStyles = ({ el, draggingElRect }: DraggingItem) => {\n const { top, left, width, height } = draggingElRect;\n requestAnimationFrame(() => {\n // Inspired by https://github.com/hello-pangea/dnd\n el.style.setProperty('pointer-events', 'none');\n el.style.setProperty('position', 'fixed');\n el.style.setProperty('top', `${top}px`);\n el.style.setProperty('left', `${left}px`);\n el.style.setProperty('width', `${width}px`);\n el.style.setProperty('height', `${height}px`);\n el.style.setProperty('z-index', 'var(--vkui_internal--z_index_cell_dragging)');\n el.style.setProperty('box-sizing', 'border-box');\n el.style.setProperty('transform', 'translateY(0)');\n });\n};\n\nexport const unsetInitialDraggingItemStyles = ({ el }: DraggingItem) => {\n requestAnimationFrame(() => {\n el.style.removeProperty('pointer-events');\n el.style.removeProperty('position');\n el.style.removeProperty('top');\n el.style.removeProperty('left');\n el.style.removeProperty('width');\n el.style.removeProperty('height');\n el.style.removeProperty('z-index');\n el.style.removeProperty('box-sizing');\n el.style.removeProperty('transform');\n });\n};\n\nexport const setInitialPlaceholderItemStyles = ({ el, draggingElRect }: PlaceholderItem) => {\n if (el.firstElementChild) {\n return;\n }\n const { width, height } = draggingElRect;\n const node = el.cloneNode() as HTMLElement;\n node.style.setProperty('display', 'block');\n node.style.setProperty('width', `${width}px`);\n node.style.setProperty('height', `${height}px`);\n node.style.setProperty('pointer-events', 'none');\n el.appendChild(node);\n};\n\nexport const unsetInitialPlaceholderItemStyles = ({ el }: PlaceholderItem) => {\n if (el.firstElementChild) {\n el.firstElementChild.remove();\n }\n};\n\nexport const setInitialSiblingItemStyles = ({ el, shifted, draggingElRect }: SiblingItem) => {\n const { height } = draggingElRect;\n requestAnimationFrame(() => {\n el.style.setProperty('pointer-events', 'none');\n el.style.setProperty('transition', 'none 0s ease 0s');\n\n if (shifted) {\n el.style.setProperty('transform', `translateY(${height}px)`);\n }\n });\n};\n\nexport const unsetInitialSiblingItemStyles = ({ el }: Omit<SiblingItem, 'shifted'>) => {\n requestAnimationFrame(() => {\n el.style.removeProperty('pointer-events');\n el.style.removeProperty('transition');\n el.style.removeProperty('transform');\n });\n};\n"],"names":["getTargetIsOverOrUnderElData","clientY","elRect","elRectHalfHeight","height","isUnderEl","bottom","isOverEl","top","setDraggingItemShiftStyles","draggingEl","nextShiftY","requestAnimationFrame","style","transform","setSiblingItemsShiftStyles","el","draggingElRect","direction","setProperty","removeProperty","setInitialDraggingItemStyles","left","width","unsetInitialDraggingItemStyles","setInitialPlaceholderItemStyles","firstElementChild","node","cloneNode","appendChild","unsetInitialPlaceholderItemStyles","remove","setInitialSiblingItemStyles","shifted","unsetInitialSiblingItemStyles"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["../../../src/hooks/useDraggableWithDomApi/utils.ts"],"sourcesContent":["import type { Direction, DraggingItem, PlaceholderItem, SiblingItem } from './types';\n\nexport const getTargetIsOverOrUnderElData = (clientY: number, elRect: DOMRect) => {\n const elRectHalfHeight = elRect.height / 2;\n return {\n isUnderEl: clientY <= elRect.bottom - elRectHalfHeight,\n isOverEl: clientY >= elRect.top + elRectHalfHeight,\n };\n};\n\nexport const setDraggingItemShiftStyles = (draggingEl: HTMLElement, nextShiftY: number) => {\n requestAnimationFrame(() => {\n draggingEl.style.transform = `translateY(${nextShiftY}px)`;\n });\n};\n\nexport const setSiblingItemsShiftStyles = ([\n {\n el,\n draggingElRect: { height },\n },\n direction,\n]: [Omit<SiblingItem, 'shifted'>, Direction]) => {\n requestAnimationFrame(() => {\n if (direction === 'up') {\n el.style.setProperty('transition', 'transform 0.3s ease-in 0s');\n el.style.removeProperty('transform');\n } else {\n el.style.setProperty('transition', 'transform 0.3s ease-out 0s');\n el.style.setProperty('transform', `translateY(${height}px)`);\n }\n });\n};\n\nexport const setInitialDraggingItemStyles = ({ el, draggingElRect }: DraggingItem) => {\n const { top, left, width, height } = draggingElRect;\n requestAnimationFrame(() => {\n // Inspired by https://github.com/hello-pangea/dnd\n el.style.setProperty('pointer-events', 'none');\n el.style.setProperty('position', 'fixed');\n el.style.setProperty('top', `${top}px`);\n el.style.setProperty('left', `${left}px`);\n el.style.setProperty('width', `${width}px`);\n el.style.setProperty('height', `${height}px`);\n el.style.setProperty('z-index', 'var(--vkui_internal--z_index_cell_dragging)');\n el.style.setProperty('box-sizing', 'border-box');\n el.style.setProperty('transform', 'translateY(0)');\n });\n};\n\nexport const unsetInitialDraggingItemStyles = ({ el }: DraggingItem) => {\n requestAnimationFrame(() => {\n el.style.removeProperty('pointer-events');\n el.style.removeProperty('position');\n el.style.removeProperty('top');\n el.style.removeProperty('left');\n el.style.removeProperty('width');\n el.style.removeProperty('height');\n el.style.removeProperty('z-index');\n el.style.removeProperty('box-sizing');\n el.style.removeProperty('transform');\n });\n};\n\nexport const setInitialPlaceholderItemStyles = ({ el, draggingElRect }: PlaceholderItem) => {\n if (el.firstElementChild) {\n return;\n }\n const { width, height } = draggingElRect;\n const node = el.cloneNode() as HTMLElement;\n node.style.setProperty('display', 'block');\n node.style.setProperty('width', `${width}px`);\n node.style.setProperty('height', `${height}px`);\n node.style.setProperty('pointer-events', 'none');\n el.appendChild(node);\n};\n\nexport const unsetInitialPlaceholderItemStyles = ({ el }: PlaceholderItem) => {\n if (el.firstElementChild) {\n el.firstElementChild.remove();\n }\n};\n\nexport const setInitialSiblingItemStyles = ({ el, shifted, draggingElRect }: SiblingItem) => {\n const { height } = draggingElRect;\n requestAnimationFrame(() => {\n el.style.setProperty('pointer-events', 'none');\n el.style.setProperty('transition', 'none 0s ease 0s');\n\n if (shifted) {\n el.style.setProperty('transform', `translateY(${height}px)`);\n }\n });\n};\n\nexport const unsetInitialSiblingItemStyles = ({ el }: Omit<SiblingItem, 'shifted'>) => {\n requestAnimationFrame(() => {\n el.style.removeProperty('pointer-events');\n el.style.removeProperty('transition');\n el.style.removeProperty('transform');\n });\n};\n"],"names":["getTargetIsOverOrUnderElData","clientY","elRect","elRectHalfHeight","height","isUnderEl","bottom","isOverEl","top","setDraggingItemShiftStyles","draggingEl","nextShiftY","requestAnimationFrame","style","transform","setSiblingItemsShiftStyles","el","draggingElRect","direction","setProperty","removeProperty","setInitialDraggingItemStyles","left","width","unsetInitialDraggingItemStyles","setInitialPlaceholderItemStyles","firstElementChild","node","cloneNode","appendChild","unsetInitialPlaceholderItemStyles","remove","setInitialSiblingItemStyles","shifted","unsetInitialSiblingItemStyles"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useEffectDev.ts"],"sourcesContent":["import { useEffect } from 'react';\nimport { noop } from '@vkontakte/vkjs';\n\nexport const useEffectDev = process.env.NODE_ENV === 'development' ? useEffect : noop;\n"],"names":["useEffect","noop","useEffectDev","process","env","NODE_ENV"],"rangeMappings":";;","mappings":"AAAA,SAASA,SAAS,QAAQ,QAAQ;AAClC,SAASC,IAAI,QAAQ,kBAAkB;AAEvC,OAAO,MAAMC,eAAeC,QAAQC,GAAG,CAACC,QAAQ,KAAK,gBAAgBL,YAAYC,KAAK"}
1
+ {"version":3,"sources":["../../src/hooks/useEffectDev.ts"],"sourcesContent":["import { useEffect } from 'react';\nimport { noop } from '@vkontakte/vkjs';\n\nexport const useEffectDev = process.env.NODE_ENV === 'development' ? useEffect : noop;\n"],"names":["useEffect","noop","useEffectDev","process","env","NODE_ENV"],"mappings":"AAAA,SAASA,SAAS,QAAQ,QAAQ;AAClC,SAASC,IAAI,QAAQ,kBAAkB;AAEvC,OAAO,MAAMC,eAAeC,QAAQC,GAAG,CAACC,QAAQ,KAAK,gBAAgBL,YAAYC,KAAK"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useEnsuredControl.ts"],"sourcesContent":["import * as React from 'react';\nimport { isFunction } from '@vkontakte/vkjs';\nimport { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\n\nexport interface UseEnsuredControlProps<V, E extends React.ChangeEvent<any>> {\n value?: V;\n defaultValue: V;\n disabled?: boolean | undefined;\n onChange?: (this: void, e: E) => any;\n}\n\nexport function useEnsuredControl<V, E extends React.ChangeEvent<any>>({\n onChange: onChangeProp,\n disabled,\n ...props\n}: UseEnsuredControlProps<V, E>): [V, (e: E) => any] {\n const [value, onChangeValue] = useCustomEnsuredControl(props);\n\n const onChange = React.useCallback(\n (e: E) => {\n if (disabled) {\n return;\n }\n\n onChangeValue(e.target.value);\n onChangeProp && onChangeProp(e);\n },\n [onChangeValue, onChangeProp, disabled],\n );\n\n return [value, onChange];\n}\n\nexport interface UseCustomEnsuredControlProps<V> {\n value?: V;\n defaultValue: V;\n disabled?: boolean | undefined;\n onChange?: (this: void, v: V) => any;\n}\n\nexport function useCustomEnsuredControl<V = any>({\n value,\n defaultValue,\n disabled,\n onChange: onChangeProp,\n}: UseCustomEnsuredControlProps<V>): [V, React.Dispatch<React.SetStateAction<V>>] {\n const isControlled = value !== undefined;\n const [localValue, setLocalValue] = React.useState(defaultValue);\n const preservedControlledValueRef = React.useRef<V>();\n\n useIsomorphicLayoutEffect(() => {\n preservedControlledValueRef.current = value;\n });\n\n const onChange = React.useCallback(\n (nextValue: V | ((prevValue: any) => V)) => {\n if (disabled) {\n return;\n }\n\n if (isFunction(nextValue)) {\n if (!isControlled) {\n setLocalValue((prevValue) => {\n const resolvedValue = nextValue(prevValue);\n if (onChangeProp) {\n onChangeProp(resolvedValue);\n }\n return resolvedValue;\n });\n } else if (onChangeProp) {\n const resolvedValue = nextValue(preservedControlledValueRef.current);\n onChangeProp(resolvedValue);\n }\n } else {\n if (onChangeProp) {\n onChangeProp(nextValue);\n }\n if (!isControlled) {\n setLocalValue(nextValue);\n }\n }\n },\n [disabled, isControlled, onChangeProp],\n );\n\n return [isControlled ? value : localValue, onChange];\n}\n"],"names":["React","isFunction","useIsomorphicLayoutEffect","useEnsuredControl","onChange","onChangeProp","disabled","props","value","onChangeValue","useCustomEnsuredControl","useCallback","e","target","defaultValue","isControlled","undefined","localValue","setLocalValue","useState","preservedControlledValueRef","useRef","current","nextValue","prevValue","resolvedValue"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,yBAAyB,QAAQ,mCAAmC;AAS7E,OAAO,SAASC,kBAAuD;QAAA,EACrEC,UAAUC,YAAY,EACtBC,QAAQ,EAEqB,GAJwC,QAGlEC,mCAHkE;QACrEH;QACAE;;IAGA,MAAM,CAACE,OAAOC,cAAc,GAAGC,wBAAwBH;IAEvD,MAAMH,WAAWJ,MAAMW,WAAW,CAChC,CAACC;QACC,IAAIN,UAAU;YACZ;QACF;QAEAG,cAAcG,EAAEC,MAAM,CAACL,KAAK;QAC5BH,gBAAgBA,aAAaO;IAC/B,GACA;QAACH;QAAeJ;QAAcC;KAAS;IAGzC,OAAO;QAACE;QAAOJ;KAAS;AAC1B;AASA,OAAO,SAASM,wBAAiC,EAC/CF,KAAK,EACLM,YAAY,EACZR,QAAQ,EACRF,UAAUC,YAAY,EACU;IAChC,MAAMU,eAAeP,UAAUQ;IAC/B,MAAM,CAACC,YAAYC,cAAc,GAAGlB,MAAMmB,QAAQ,CAACL;IACnD,MAAMM,8BAA8BpB,MAAMqB,MAAM;IAEhDnB,0BAA0B;QACxBkB,4BAA4BE,OAAO,GAAGd;IACxC;IAEA,MAAMJ,WAAWJ,MAAMW,WAAW,CAChC,CAACY;QACC,IAAIjB,UAAU;YACZ;QACF;QAEA,IAAIL,WAAWsB,YAAY;YACzB,IAAI,CAACR,cAAc;gBACjBG,cAAc,CAACM;oBACb,MAAMC,gBAAgBF,UAAUC;oBAChC,IAAInB,cAAc;wBAChBA,aAAaoB;oBACf;oBACA,OAAOA;gBACT;YACF,OAAO,IAAIpB,cAAc;gBACvB,MAAMoB,gBAAgBF,UAAUH,4BAA4BE,OAAO;gBACnEjB,aAAaoB;YACf;QACF,OAAO;YACL,IAAIpB,cAAc;gBAChBA,aAAakB;YACf;YACA,IAAI,CAACR,cAAc;gBACjBG,cAAcK;YAChB;QACF;IACF,GACA;QAACjB;QAAUS;QAAcV;KAAa;IAGxC,OAAO;QAACU,eAAeP,QAAQS;QAAYb;KAAS;AACtD"}
1
+ {"version":3,"sources":["../../src/hooks/useEnsuredControl.ts"],"sourcesContent":["import * as React from 'react';\nimport { isFunction } from '@vkontakte/vkjs';\nimport { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\n\nexport interface UseEnsuredControlProps<V, E extends React.ChangeEvent<any>> {\n value?: V;\n defaultValue: V;\n disabled?: boolean | undefined;\n onChange?: (this: void, e: E) => any;\n}\n\nexport function useEnsuredControl<V, E extends React.ChangeEvent<any>>({\n onChange: onChangeProp,\n disabled,\n ...props\n}: UseEnsuredControlProps<V, E>): [V, (e: E) => any] {\n const [value, onChangeValue] = useCustomEnsuredControl(props);\n\n const onChange = React.useCallback(\n (e: E) => {\n if (disabled) {\n return;\n }\n\n onChangeValue(e.target.value);\n onChangeProp && onChangeProp(e);\n },\n [onChangeValue, onChangeProp, disabled],\n );\n\n return [value, onChange];\n}\n\nexport interface UseCustomEnsuredControlProps<V> {\n value?: V;\n defaultValue: V;\n disabled?: boolean | undefined;\n onChange?: (this: void, v: V) => any;\n}\n\nexport function useCustomEnsuredControl<V = any>({\n value,\n defaultValue,\n disabled,\n onChange: onChangeProp,\n}: UseCustomEnsuredControlProps<V>): [V, React.Dispatch<React.SetStateAction<V>>] {\n const isControlled = value !== undefined;\n const [localValue, setLocalValue] = React.useState(defaultValue);\n const preservedControlledValueRef = React.useRef<V>();\n\n useIsomorphicLayoutEffect(() => {\n preservedControlledValueRef.current = value;\n });\n\n const onChange = React.useCallback(\n (nextValue: V | ((prevValue: any) => V)) => {\n if (disabled) {\n return;\n }\n\n if (isFunction(nextValue)) {\n if (!isControlled) {\n setLocalValue((prevValue) => {\n const resolvedValue = nextValue(prevValue);\n if (onChangeProp) {\n onChangeProp(resolvedValue);\n }\n return resolvedValue;\n });\n } else if (onChangeProp) {\n const resolvedValue = nextValue(preservedControlledValueRef.current);\n onChangeProp(resolvedValue);\n }\n } else {\n if (onChangeProp) {\n onChangeProp(nextValue);\n }\n if (!isControlled) {\n setLocalValue(nextValue);\n }\n }\n },\n [disabled, isControlled, onChangeProp],\n );\n\n return [isControlled ? value : localValue, onChange];\n}\n"],"names":["React","isFunction","useIsomorphicLayoutEffect","useEnsuredControl","onChange","onChangeProp","disabled","props","value","onChangeValue","useCustomEnsuredControl","useCallback","e","target","defaultValue","isControlled","undefined","localValue","setLocalValue","useState","preservedControlledValueRef","useRef","current","nextValue","prevValue","resolvedValue"],"mappings":";AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,yBAAyB,QAAQ,mCAAmC;AAS7E,OAAO,SAASC,kBAAuD;QAAA,EACrEC,UAAUC,YAAY,EACtBC,QAAQ,EAEqB,GAJwC,QAGlEC,mCAHkE;QACrEH;QACAE;;IAGA,MAAM,CAACE,OAAOC,cAAc,GAAGC,wBAAwBH;IAEvD,MAAMH,WAAWJ,MAAMW,WAAW,CAChC,CAACC;QACC,IAAIN,UAAU;YACZ;QACF;QAEAG,cAAcG,EAAEC,MAAM,CAACL,KAAK;QAC5BH,gBAAgBA,aAAaO;IAC/B,GACA;QAACH;QAAeJ;QAAcC;KAAS;IAGzC,OAAO;QAACE;QAAOJ;KAAS;AAC1B;AASA,OAAO,SAASM,wBAAiC,EAC/CF,KAAK,EACLM,YAAY,EACZR,QAAQ,EACRF,UAAUC,YAAY,EACU;IAChC,MAAMU,eAAeP,UAAUQ;IAC/B,MAAM,CAACC,YAAYC,cAAc,GAAGlB,MAAMmB,QAAQ,CAACL;IACnD,MAAMM,8BAA8BpB,MAAMqB,MAAM;IAEhDnB,0BAA0B;QACxBkB,4BAA4BE,OAAO,GAAGd;IACxC;IAEA,MAAMJ,WAAWJ,MAAMW,WAAW,CAChC,CAACY;QACC,IAAIjB,UAAU;YACZ;QACF;QAEA,IAAIL,WAAWsB,YAAY;YACzB,IAAI,CAACR,cAAc;gBACjBG,cAAc,CAACM;oBACb,MAAMC,gBAAgBF,UAAUC;oBAChC,IAAInB,cAAc;wBAChBA,aAAaoB;oBACf;oBACA,OAAOA;gBACT;YACF,OAAO,IAAIpB,cAAc;gBACvB,MAAMoB,gBAAgBF,UAAUH,4BAA4BE,OAAO;gBACnEjB,aAAaoB;YACf;QACF,OAAO;YACL,IAAIpB,cAAc;gBAChBA,aAAakB;YACf;YACA,IAAI,CAACR,cAAc;gBACjBG,cAAcK;YAChB;QACF;IACF,GACA;QAACjB;QAAUS;QAAcV;KAAa;IAGxC,OAAO;QAACU,eAAeP,QAAQS;QAAYb;KAAS;AACtD"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useEventListener.ts"],"sourcesContent":["import * as React from 'react';\nimport { noop } from '@vkontakte/vkjs';\nimport { canUseDOM } from '../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\n\ninterface EventListenerHandle {\n add: (el: HTMLElement | Document | Window) => void;\n remove: () => void;\n}\n\nexport function useEventListener<K extends keyof GlobalEventHandlersEventMap>(\n event: K,\n _cb: false | null | undefined | ((ev: GlobalEventHandlersEventMap[K]) => void),\n _options?: AddEventListenerOptions,\n): EventListenerHandle;\nexport function useEventListener<E extends Event>(\n event: string,\n _cb: false | null | undefined | ((ev: E) => void),\n _options?: AddEventListenerOptions,\n): EventListenerHandle;\nexport function useEventListener<E extends Event, K extends keyof GlobalEventHandlersEventMap>(\n event: string | K,\n _cb: false | null | undefined | ((ev: E) => void),\n _options?: AddEventListenerOptions,\n): EventListenerHandle {\n const cbRef = React.useRef(_cb);\n useIsomorphicLayoutEffect(() => {\n cbRef.current = _cb;\n }, [_cb]);\n const cb = React.useCallback((e: any) => cbRef.current && cbRef.current(e), []);\n\n const detach = React.useRef(noop);\n const remove = React.useCallback(() => {\n detach.current();\n detach.current = noop;\n }, []);\n const add = React.useCallback(\n (el: HTMLElement | Document | Window) => {\n if (!canUseDOM) {\n return;\n }\n remove();\n if (!el) {\n return;\n }\n const options = { ..._options };\n el.addEventListener(event, cb, options);\n detach.current = () => el.removeEventListener(event, cb, options);\n },\n [_options, cb, event, remove],\n );\n React.useEffect(() => remove, [remove]);\n\n return React.useMemo(() => ({ add, remove }), [add, remove]);\n}\n"],"names":["React","noop","canUseDOM","useIsomorphicLayoutEffect","useEventListener","event","_cb","_options","cbRef","useRef","current","cb","useCallback","e","detach","remove","add","el","options","addEventListener","removeEventListener","useEffect","useMemo"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,IAAI,QAAQ,kBAAkB;AACvC,SAASC,SAAS,QAAQ,aAAa;AACvC,SAASC,yBAAyB,QAAQ,mCAAmC;AAiB7E,OAAO,SAASC,iBACdC,KAAiB,EACjBC,GAAiD,EACjDC,QAAkC;IAElC,MAAMC,QAAQR,MAAMS,MAAM,CAACH;IAC3BH,0BAA0B;QACxBK,MAAME,OAAO,GAAGJ;IAClB,GAAG;QAACA;KAAI;IACR,MAAMK,KAAKX,MAAMY,WAAW,CAAC,CAACC,IAAWL,MAAME,OAAO,IAAIF,MAAME,OAAO,CAACG,IAAI,EAAE;IAE9E,MAAMC,SAASd,MAAMS,MAAM,CAACR;IAC5B,MAAMc,SAASf,MAAMY,WAAW,CAAC;QAC/BE,OAAOJ,OAAO;QACdI,OAAOJ,OAAO,GAAGT;IACnB,GAAG,EAAE;IACL,MAAMe,MAAMhB,MAAMY,WAAW,CAC3B,CAACK;QACC,IAAI,CAACf,WAAW;YACd;QACF;QACAa;QACA,IAAI,CAACE,IAAI;YACP;QACF;QACA,MAAMC,UAAU,mBAAKX;QACrBU,GAAGE,gBAAgB,CAACd,OAAOM,IAAIO;QAC/BJ,OAAOJ,OAAO,GAAG,IAAMO,GAAGG,mBAAmB,CAACf,OAAOM,IAAIO;IAC3D,GACA;QAACX;QAAUI;QAAIN;QAAOU;KAAO;IAE/Bf,MAAMqB,SAAS,CAAC,IAAMN,QAAQ;QAACA;KAAO;IAEtC,OAAOf,MAAMsB,OAAO,CAAC,IAAO,CAAA;YAAEN;YAAKD;QAAO,CAAA,GAAI;QAACC;QAAKD;KAAO;AAC7D"}
1
+ {"version":3,"sources":["../../src/hooks/useEventListener.ts"],"sourcesContent":["import * as React from 'react';\nimport { noop } from '@vkontakte/vkjs';\nimport { canUseDOM } from '../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\n\ninterface EventListenerHandle {\n add: (el: HTMLElement | Document | Window) => void;\n remove: () => void;\n}\n\nexport function useEventListener<K extends keyof GlobalEventHandlersEventMap>(\n event: K,\n _cb: false | null | undefined | ((ev: GlobalEventHandlersEventMap[K]) => void),\n _options?: AddEventListenerOptions,\n): EventListenerHandle;\nexport function useEventListener<E extends Event>(\n event: string,\n _cb: false | null | undefined | ((ev: E) => void),\n _options?: AddEventListenerOptions,\n): EventListenerHandle;\nexport function useEventListener<E extends Event, K extends keyof GlobalEventHandlersEventMap>(\n event: string | K,\n _cb: false | null | undefined | ((ev: E) => void),\n _options?: AddEventListenerOptions,\n): EventListenerHandle {\n const cbRef = React.useRef(_cb);\n useIsomorphicLayoutEffect(() => {\n cbRef.current = _cb;\n }, [_cb]);\n const cb = React.useCallback((e: any) => cbRef.current && cbRef.current(e), []);\n\n const detach = React.useRef(noop);\n const remove = React.useCallback(() => {\n detach.current();\n detach.current = noop;\n }, []);\n const add = React.useCallback(\n (el: HTMLElement | Document | Window) => {\n if (!canUseDOM) {\n return;\n }\n remove();\n if (!el) {\n return;\n }\n const options = { ..._options };\n el.addEventListener(event, cb, options);\n detach.current = () => el.removeEventListener(event, cb, options);\n },\n [_options, cb, event, remove],\n );\n React.useEffect(() => remove, [remove]);\n\n return React.useMemo(() => ({ add, remove }), [add, remove]);\n}\n"],"names":["React","noop","canUseDOM","useIsomorphicLayoutEffect","useEventListener","event","_cb","_options","cbRef","useRef","current","cb","useCallback","e","detach","remove","add","el","options","addEventListener","removeEventListener","useEffect","useMemo"],"mappings":";AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,IAAI,QAAQ,kBAAkB;AACvC,SAASC,SAAS,QAAQ,aAAa;AACvC,SAASC,yBAAyB,QAAQ,mCAAmC;AAiB7E,OAAO,SAASC,iBACdC,KAAiB,EACjBC,GAAiD,EACjDC,QAAkC;IAElC,MAAMC,QAAQR,MAAMS,MAAM,CAACH;IAC3BH,0BAA0B;QACxBK,MAAME,OAAO,GAAGJ;IAClB,GAAG;QAACA;KAAI;IACR,MAAMK,KAAKX,MAAMY,WAAW,CAAC,CAACC,IAAWL,MAAME,OAAO,IAAIF,MAAME,OAAO,CAACG,IAAI,EAAE;IAE9E,MAAMC,SAASd,MAAMS,MAAM,CAACR;IAC5B,MAAMc,SAASf,MAAMY,WAAW,CAAC;QAC/BE,OAAOJ,OAAO;QACdI,OAAOJ,OAAO,GAAGT;IACnB,GAAG,EAAE;IACL,MAAMe,MAAMhB,MAAMY,WAAW,CAC3B,CAACK;QACC,IAAI,CAACf,WAAW;YACd;QACF;QACAa;QACA,IAAI,CAACE,IAAI;YACP;QACF;QACA,MAAMC,UAAU,mBAAKX;QACrBU,GAAGE,gBAAgB,CAACd,OAAOM,IAAIO;QAC/BJ,OAAOJ,OAAO,GAAG,IAAMO,GAAGG,mBAAmB,CAACf,OAAOM,IAAIO;IAC3D,GACA;QAACX;QAAUI;QAAIN;QAAOU;KAAO;IAE/Bf,MAAMqB,SAAS,CAAC,IAAMN,QAAQ;QAACA;KAAO;IAEtC,OAAOf,MAAMsB,OAAO,CAAC,IAAO,CAAA;YAAEN;YAAKD;QAAO,CAAA,GAAI;QAACC;QAAKD;KAAO;AAC7D"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useExternRef.ts"],"sourcesContent":["import * as React from 'react';\nimport { setRef } from '../lib/utils';\n\nexport function useExternRef<T>(\n ...externRefs: Array<React.Ref<T> | undefined | false>\n): React.MutableRefObject<T | null> {\n const stableRef = React.useRef<T | null>(null);\n\n return React.useMemo(\n () => ({\n get current() {\n return stableRef.current;\n },\n set current(el) {\n stableRef.current = el;\n externRefs.forEach((ref) => {\n if (ref) {\n setRef(el, ref);\n }\n });\n },\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n externRefs,\n );\n}\n"],"names":["React","setRef","useExternRef","externRefs","stableRef","useRef","useMemo","current","el","forEach","ref"],"rangeMappings":";;;;;;;;;;;;;;;;;;","mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,MAAM,QAAQ,eAAe;AAEtC,OAAO,SAASC,aACd,GAAGC,UAAmD;IAEtD,MAAMC,YAAYJ,MAAMK,MAAM,CAAW;IAEzC,OAAOL,MAAMM,OAAO,CAClB,IAAO,CAAA;YACL,IAAIC,WAAU;gBACZ,OAAOH,UAAUG,OAAO;YAC1B;YACA,IAAIA,SAAQC,GAAI;gBACdJ,UAAUG,OAAO,GAAGC;gBACpBL,WAAWM,OAAO,CAAC,CAACC;oBAClB,IAAIA,KAAK;wBACPT,OAAOO,IAAIE;oBACb;gBACF;YACF;QACF,CAAA,GACA,uDAAuD;IACvDP;AAEJ"}
1
+ {"version":3,"sources":["../../src/hooks/useExternRef.ts"],"sourcesContent":["import * as React from 'react';\nimport { setRef } from '../lib/utils';\n\nexport function useExternRef<T>(\n ...externRefs: Array<React.Ref<T> | undefined | false>\n): React.MutableRefObject<T | null> {\n const stableRef = React.useRef<T | null>(null);\n\n return React.useMemo(\n () => ({\n get current() {\n return stableRef.current;\n },\n set current(el) {\n stableRef.current = el;\n externRefs.forEach((ref) => {\n if (ref) {\n setRef(el, ref);\n }\n });\n },\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n externRefs,\n );\n}\n"],"names":["React","setRef","useExternRef","externRefs","stableRef","useRef","useMemo","current","el","forEach","ref"],"mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,MAAM,QAAQ,eAAe;AAEtC,OAAO,SAASC,aACd,GAAGC,UAAmD;IAEtD,MAAMC,YAAYJ,MAAMK,MAAM,CAAW;IAEzC,OAAOL,MAAMM,OAAO,CAClB,IAAO,CAAA;YACL,IAAIC,WAAU;gBACZ,OAAOH,UAAUG,OAAO;YAC1B;YACA,IAAIA,SAAQC,GAAI;gBACdJ,UAAUG,OAAO,GAAGC;gBACpBL,WAAWM,OAAO,CAAC,CAACC;oBAClB,IAAIA,KAAK;wBACPT,OAAOO,IAAIE;oBACb;gBACF;YACF;QACF,CAAA,GACA,uDAAuD;IACvDP;AAEJ"}
@@ -1 +1 @@
1
- {"version":3,"file":"useFocusVisible.d.ts","sourceRoot":"","sources":["../../src/hooks/useFocusVisible.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAqC,MAAM,OAAO,CAAC;AAGtE,wBAAgB,eAAe,CAAC,sBAAsB,UAAO;;qBAKjD,WAAW,WAAW,CAAC;oBAQvB,WAAW,WAAW,CAAC;EAclC"}
1
+ {"version":3,"file":"useFocusVisible.d.ts","sourceRoot":"","sources":["../../src/hooks/useFocusVisible.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAqC,MAAM,OAAO,CAAC;AAGtE,wBAAgB,eAAe,CAAC,sBAAsB,UAAO;;qBAKjD,UAAU,CAAC,WAAW,CAAC;oBAQvB,UAAU,CAAC,WAAW,CAAC;EAclC"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useFocusVisible.ts"],"sourcesContent":["import { FocusEvent, useCallback, useContext, useState } from 'react';\nimport { AppRootContext } from '../components/AppRoot/AppRootContext';\n\nexport function useFocusVisible(withKeyboardInputCheck = true) {\n const [isFocused, setIsFocused] = useState(false);\n const { keyboardInput } = useContext(AppRootContext);\n\n const onFocus = useCallback(\n (event: FocusEvent<HTMLElement>) => {\n event.stopPropagation();\n setIsFocused(true);\n },\n [setIsFocused],\n );\n\n const onBlur = useCallback(\n (event: FocusEvent<HTMLElement>) => {\n event.stopPropagation();\n setIsFocused(false);\n },\n [setIsFocused],\n );\n\n const focusVisible = withKeyboardInputCheck ? keyboardInput && isFocused : isFocused;\n\n return {\n focusVisible,\n onFocus,\n onBlur,\n };\n}\n"],"names":["useCallback","useContext","useState","AppRootContext","useFocusVisible","withKeyboardInputCheck","isFocused","setIsFocused","keyboardInput","onFocus","event","stopPropagation","onBlur","focusVisible"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,SAAqBA,WAAW,EAAEC,UAAU,EAAEC,QAAQ,QAAQ,QAAQ;AACtE,SAASC,cAAc,QAAQ,uCAAuC;AAEtE,OAAO,SAASC,gBAAgBC,yBAAyB,IAAI;IAC3D,MAAM,CAACC,WAAWC,aAAa,GAAGL,SAAS;IAC3C,MAAM,EAAEM,aAAa,EAAE,GAAGP,WAAWE;IAErC,MAAMM,UAAUT,YACd,CAACU;QACCA,MAAMC,eAAe;QACrBJ,aAAa;IACf,GACA;QAACA;KAAa;IAGhB,MAAMK,SAASZ,YACb,CAACU;QACCA,MAAMC,eAAe;QACrBJ,aAAa;IACf,GACA;QAACA;KAAa;IAGhB,MAAMM,eAAeR,yBAAyBG,iBAAiBF,YAAYA;IAE3E,OAAO;QACLO;QACAJ;QACAG;IACF;AACF"}
1
+ {"version":3,"sources":["../../src/hooks/useFocusVisible.ts"],"sourcesContent":["import { FocusEvent, useCallback, useContext, useState } from 'react';\nimport { AppRootContext } from '../components/AppRoot/AppRootContext';\n\nexport function useFocusVisible(withKeyboardInputCheck = true) {\n const [isFocused, setIsFocused] = useState(false);\n const { keyboardInput } = useContext(AppRootContext);\n\n const onFocus = useCallback(\n (event: FocusEvent<HTMLElement>) => {\n event.stopPropagation();\n setIsFocused(true);\n },\n [setIsFocused],\n );\n\n const onBlur = useCallback(\n (event: FocusEvent<HTMLElement>) => {\n event.stopPropagation();\n setIsFocused(false);\n },\n [setIsFocused],\n );\n\n const focusVisible = withKeyboardInputCheck ? keyboardInput && isFocused : isFocused;\n\n return {\n focusVisible,\n onFocus,\n onBlur,\n };\n}\n"],"names":["useCallback","useContext","useState","AppRootContext","useFocusVisible","withKeyboardInputCheck","isFocused","setIsFocused","keyboardInput","onFocus","event","stopPropagation","onBlur","focusVisible"],"mappings":"AAAA,SAAqBA,WAAW,EAAEC,UAAU,EAAEC,QAAQ,QAAQ,QAAQ;AACtE,SAASC,cAAc,QAAQ,uCAAuC;AAEtE,OAAO,SAASC,gBAAgBC,yBAAyB,IAAI;IAC3D,MAAM,CAACC,WAAWC,aAAa,GAAGL,SAAS;IAC3C,MAAM,EAAEM,aAAa,EAAE,GAAGP,WAAWE;IAErC,MAAMM,UAAUT,YACd,CAACU;QACCA,MAAMC,eAAe;QACrBJ,aAAa;IACf,GACA;QAACA;KAAa;IAGhB,MAAMK,SAASZ,YACb,CAACU;QACCA,MAAMC,eAAe;QACrBJ,aAAa;IACf,GACA;QAACA;KAAa;IAGhB,MAAMM,eAAeR,yBAAyBG,iBAAiBF,YAAYA;IAE3E,OAAO;QACLO;QACAJ;QACAG;IACF;AACF"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useFocusVisibleClassName.ts"],"sourcesContent":["import { classNames } from '@vkontakte/vkjs';\nimport { LiteralUnion } from '../types';\nimport styles from '../styles/focusVisible.module.css';\n\nexport const focusVisiblePresetModeClassNames = {\n inside: styles['-focus-visible--mode-inside'],\n outside: styles['-focus-visible--mode-outside'],\n};\n\ntype FocusVisiblePresetMode = keyof typeof focusVisiblePresetModeClassNames;\n\nexport type FocusVisibleMode = LiteralUnion<FocusVisiblePresetMode, string>;\n\nconst isPresetMode = (mode: FocusVisibleMode): mode is FocusVisiblePresetMode =>\n mode === 'inside' || mode === 'outside';\n\nexport interface FocusVisibleModeProps {\n /**\n * Стиль аутлайна focus visible. Если передать произвольную строку, она добавится как css-класс при :focus-visible\n */\n focusVisibleMode?: FocusVisibleMode;\n}\n\nexport interface UseFocusVisibleClassNameProps {\n focusVisible?: boolean;\n mode?: FocusVisibleMode;\n}\n\n/**\n * Используется для проброса классов состояния :focus-visible в компонент.\n *\n * Рулит исключительно классами. Чтобы определить, есть ли фокусное состояние,\n * используйте хуки `useFocusVisible()` и `useFocusWithin()`.\n */\nexport function useFocusVisibleClassName({\n focusVisible = false,\n mode = 'inside',\n}: UseFocusVisibleClassNameProps) {\n const modeClassName = isPresetMode(mode) ? focusVisiblePresetModeClassNames[mode] : mode;\n\n const focusVisibleClassNames = classNames(\n styles['-focus-visible'],\n focusVisible && styles['-focus-visible--focused'],\n focusVisible && modeClassName,\n );\n\n return focusVisibleClassNames;\n}\n"],"names":["classNames","focusVisiblePresetModeClassNames","inside","outside","isPresetMode","mode","useFocusVisibleClassName","focusVisible","modeClassName","focusVisibleClassNames"],"rangeMappings":";;;;;;;;;;;;;;;","mappings":"AAAA,SAASA,UAAU,QAAQ,kBAAkB;AAI7C,OAAO,MAAMC,mCAAmC;IAC9CC,MAAM;IACNC,OAAO;AACT,EAAE;AAMF,MAAMC,eAAe,CAACC,OACpBA,SAAS,YAAYA,SAAS;AAchC;;;;;CAKC,GACD,OAAO,SAASC,yBAAyB,EACvCC,eAAe,KAAK,EACpBF,OAAO,QAAQ,EACe;IAC9B,MAAMG,gBAAgBJ,aAAaC,QAAQJ,gCAAgC,CAACI,KAAK,GAAGA;IAEpF,MAAMI,yBAAyBT,iCAE7BO,+CACAA,gBAAgBC;IAGlB,OAAOC;AACT"}
1
+ {"version":3,"sources":["../../src/hooks/useFocusVisibleClassName.ts"],"sourcesContent":["import { classNames } from '@vkontakte/vkjs';\nimport { LiteralUnion } from '../types';\nimport styles from '../styles/focusVisible.module.css';\n\nexport const focusVisiblePresetModeClassNames = {\n inside: styles['-focus-visible--mode-inside'],\n outside: styles['-focus-visible--mode-outside'],\n};\n\ntype FocusVisiblePresetMode = keyof typeof focusVisiblePresetModeClassNames;\n\nexport type FocusVisibleMode = LiteralUnion<FocusVisiblePresetMode, string>;\n\nconst isPresetMode = (mode: FocusVisibleMode): mode is FocusVisiblePresetMode =>\n mode === 'inside' || mode === 'outside';\n\nexport interface FocusVisibleModeProps {\n /**\n * Стиль аутлайна focus visible. Если передать произвольную строку, она добавится как css-класс при :focus-visible\n */\n focusVisibleMode?: FocusVisibleMode;\n}\n\nexport interface UseFocusVisibleClassNameProps {\n focusVisible?: boolean;\n mode?: FocusVisibleMode;\n}\n\n/**\n * Используется для проброса классов состояния :focus-visible в компонент.\n *\n * Рулит исключительно классами. Чтобы определить, есть ли фокусное состояние,\n * используйте хуки `useFocusVisible()` и `useFocusWithin()`.\n */\nexport function useFocusVisibleClassName({\n focusVisible = false,\n mode = 'inside',\n}: UseFocusVisibleClassNameProps) {\n const modeClassName = isPresetMode(mode) ? focusVisiblePresetModeClassNames[mode] : mode;\n\n const focusVisibleClassNames = classNames(\n styles['-focus-visible'],\n focusVisible && styles['-focus-visible--focused'],\n focusVisible && modeClassName,\n );\n\n return focusVisibleClassNames;\n}\n"],"names":["classNames","focusVisiblePresetModeClassNames","inside","outside","isPresetMode","mode","useFocusVisibleClassName","focusVisible","modeClassName","focusVisibleClassNames"],"mappings":"AAAA,SAASA,UAAU,QAAQ,kBAAkB;AAI7C,OAAO,MAAMC,mCAAmC;IAC9CC,MAAM;IACNC,OAAO;AACT,EAAE;AAMF,MAAMC,eAAe,CAACC,OACpBA,SAAS,YAAYA,SAAS;AAchC;;;;;CAKC,GACD,OAAO,SAASC,yBAAyB,EACvCC,eAAe,KAAK,EACpBF,OAAO,QAAQ,EACe;IAC9B,MAAMG,gBAAgBJ,aAAaC,QAAQJ,gCAAgC,CAACI,KAAK,GAAGA;IAEpF,MAAMI,yBAAyBT,iCAE7BO,+CACAA,gBAAgBC;IAGlB,OAAOC;AACT"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useFocusWithin.ts"],"sourcesContent":["import * as React from 'react';\nimport { useDOM } from '../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\n\nconst isFocusWithin = <T extends Element>(ref: T, document: Document) =>\n ref.contains(document.activeElement);\n\nexport function useFocusWithin(ref: React.RefObject<HTMLElement | null>): boolean {\n const { document } = useDOM();\n const [focusWithin, setFocusWithin] = React.useState<boolean>(() =>\n ref.current && document ? isFocusWithin(ref.current, document) : false,\n );\n\n useIsomorphicLayoutEffect(function handleAutoFocus() {\n /* istanbul ignore if: невозможный кейс, т.к. в SSR эффекты не вызываются. Проверка на будущее, если вдруг эффект будет вызываться. */\n if (!document) {\n return;\n }\n\n const handleFocusOrBlurEvents = () => {\n if (ref.current) {\n setFocusWithin(isFocusWithin(ref.current, document));\n }\n };\n\n // Вызываем в начале, чтобы проверить autoFocus\n void handleFocusOrBlurEvents();\n\n document.addEventListener('focus', handleFocusOrBlurEvents, { capture: true });\n document.addEventListener('blur', handleFocusOrBlurEvents, { capture: true });\n return () => {\n document.removeEventListener('focus', handleFocusOrBlurEvents, { capture: true });\n document.removeEventListener('blur', handleFocusOrBlurEvents, { capture: true });\n };\n }, []);\n\n return focusWithin;\n}\n"],"names":["React","useDOM","useIsomorphicLayoutEffect","isFocusWithin","ref","document","contains","activeElement","useFocusWithin","focusWithin","setFocusWithin","useState","current","handleAutoFocus","handleFocusOrBlurEvents","addEventListener","capture","removeEventListener"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,MAAM,QAAQ,aAAa;AACpC,SAASC,yBAAyB,QAAQ,mCAAmC;AAE7E,MAAMC,gBAAgB,CAAoBC,KAAQC,WAChDD,IAAIE,QAAQ,CAACD,SAASE,aAAa;AAErC,OAAO,SAASC,eAAeJ,GAAwC;IACrE,MAAM,EAAEC,QAAQ,EAAE,GAAGJ;IACrB,MAAM,CAACQ,aAAaC,eAAe,GAAGV,MAAMW,QAAQ,CAAU,IAC5DP,IAAIQ,OAAO,IAAIP,WAAWF,cAAcC,IAAIQ,OAAO,EAAEP,YAAY;IAGnEH,0BAA0B,SAASW;QACjC,oIAAoI,GACpI,IAAI,CAACR,UAAU;YACb;QACF;QAEA,MAAMS,0BAA0B;YAC9B,IAAIV,IAAIQ,OAAO,EAAE;gBACfF,eAAeP,cAAcC,IAAIQ,OAAO,EAAEP;YAC5C;QACF;QAEA,+CAA+C;QAC/C,KAAKS;QAELT,SAASU,gBAAgB,CAAC,SAASD,yBAAyB;YAAEE,SAAS;QAAK;QAC5EX,SAASU,gBAAgB,CAAC,QAAQD,yBAAyB;YAAEE,SAAS;QAAK;QAC3E,OAAO;YACLX,SAASY,mBAAmB,CAAC,SAASH,yBAAyB;gBAAEE,SAAS;YAAK;YAC/EX,SAASY,mBAAmB,CAAC,QAAQH,yBAAyB;gBAAEE,SAAS;YAAK;QAChF;IACF,GAAG,EAAE;IAEL,OAAOP;AACT"}
1
+ {"version":3,"sources":["../../src/hooks/useFocusWithin.ts"],"sourcesContent":["import * as React from 'react';\nimport { useDOM } from '../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\n\nconst isFocusWithin = <T extends Element>(ref: T, document: Document) =>\n ref.contains(document.activeElement);\n\nexport function useFocusWithin(ref: React.RefObject<HTMLElement | null>): boolean {\n const { document } = useDOM();\n const [focusWithin, setFocusWithin] = React.useState<boolean>(() =>\n ref.current && document ? isFocusWithin(ref.current, document) : false,\n );\n\n useIsomorphicLayoutEffect(function handleAutoFocus() {\n /* istanbul ignore if: невозможный кейс, т.к. в SSR эффекты не вызываются. Проверка на будущее, если вдруг эффект будет вызываться. */\n if (!document) {\n return;\n }\n\n const handleFocusOrBlurEvents = () => {\n if (ref.current) {\n setFocusWithin(isFocusWithin(ref.current, document));\n }\n };\n\n // Вызываем в начале, чтобы проверить autoFocus\n void handleFocusOrBlurEvents();\n\n document.addEventListener('focus', handleFocusOrBlurEvents, { capture: true });\n document.addEventListener('blur', handleFocusOrBlurEvents, { capture: true });\n return () => {\n document.removeEventListener('focus', handleFocusOrBlurEvents, { capture: true });\n document.removeEventListener('blur', handleFocusOrBlurEvents, { capture: true });\n };\n }, []);\n\n return focusWithin;\n}\n"],"names":["React","useDOM","useIsomorphicLayoutEffect","isFocusWithin","ref","document","contains","activeElement","useFocusWithin","focusWithin","setFocusWithin","useState","current","handleAutoFocus","handleFocusOrBlurEvents","addEventListener","capture","removeEventListener"],"mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,MAAM,QAAQ,aAAa;AACpC,SAASC,yBAAyB,QAAQ,mCAAmC;AAE7E,MAAMC,gBAAgB,CAAoBC,KAAQC,WAChDD,IAAIE,QAAQ,CAACD,SAASE,aAAa;AAErC,OAAO,SAASC,eAAeJ,GAAwC;IACrE,MAAM,EAAEC,QAAQ,EAAE,GAAGJ;IACrB,MAAM,CAACQ,aAAaC,eAAe,GAAGV,MAAMW,QAAQ,CAAU,IAC5DP,IAAIQ,OAAO,IAAIP,WAAWF,cAAcC,IAAIQ,OAAO,EAAEP,YAAY;IAGnEH,0BAA0B,SAASW;QACjC,oIAAoI,GACpI,IAAI,CAACR,UAAU;YACb;QACF;QAEA,MAAMS,0BAA0B;YAC9B,IAAIV,IAAIQ,OAAO,EAAE;gBACfF,eAAeP,cAAcC,IAAIQ,OAAO,EAAEP;YAC5C;QACF;QAEA,+CAA+C;QAC/C,KAAKS;QAELT,SAASU,gBAAgB,CAAC,SAASD,yBAAyB;YAAEE,SAAS;QAAK;QAC5EX,SAASU,gBAAgB,CAAC,QAAQD,yBAAyB;YAAEE,SAAS;QAAK;QAC3E,OAAO;YACLX,SAASY,mBAAmB,CAAC,SAASH,yBAAyB;gBAAEE,SAAS;YAAK;YAC/EX,SAASY,mBAAmB,CAAC,QAAQH,yBAAyB;gBAAEE,SAAS;YAAK;QAChF;IACF,GAAG,EAAE;IAEL,OAAOP;AACT"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useGlobalEscKeyDown.ts"],"sourcesContent":["import { Keys, pressedKey } from '../lib/accessibility';\nimport { useDOM } from '../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\n\nconst EVENT_OPTIONS = {\n passive: true,\n capture: true,\n};\n\n/**\n * Завязывается на document.\n *\n * @private\n */\nexport const useGlobalEscKeyDown = (init: boolean, callback?: (event: KeyboardEvent) => void) => {\n const { document } = useDOM();\n useIsomorphicLayoutEffect(() => {\n if (!document || !init || !callback) {\n return;\n }\n const handleKeyDown = (event: KeyboardEvent) => {\n if (pressedKey(event) === Keys.ESCAPE) {\n callback(event);\n }\n };\n document.addEventListener('keydown', handleKeyDown, EVENT_OPTIONS);\n return () => {\n document.removeEventListener('keydown', handleKeyDown, EVENT_OPTIONS);\n };\n }, [init, document, callback]);\n};\n"],"names":["Keys","pressedKey","useDOM","useIsomorphicLayoutEffect","EVENT_OPTIONS","passive","capture","useGlobalEscKeyDown","init","callback","document","handleKeyDown","event","ESCAPE","addEventListener","removeEventListener"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,SAASA,IAAI,EAAEC,UAAU,QAAQ,uBAAuB;AACxD,SAASC,MAAM,QAAQ,aAAa;AACpC,SAASC,yBAAyB,QAAQ,mCAAmC;AAE7E,MAAMC,gBAAgB;IACpBC,SAAS;IACTC,SAAS;AACX;AAEA;;;;CAIC,GACD,OAAO,MAAMC,sBAAsB,CAACC,MAAeC;IACjD,MAAM,EAAEC,QAAQ,EAAE,GAAGR;IACrBC,0BAA0B;QACxB,IAAI,CAACO,YAAY,CAACF,QAAQ,CAACC,UAAU;YACnC;QACF;QACA,MAAME,gBAAgB,CAACC;YACrB,IAAIX,WAAWW,WAAWZ,KAAKa,MAAM,EAAE;gBACrCJ,SAASG;YACX;QACF;QACAF,SAASI,gBAAgB,CAAC,WAAWH,eAAeP;QACpD,OAAO;YACLM,SAASK,mBAAmB,CAAC,WAAWJ,eAAeP;QACzD;IACF,GAAG;QAACI;QAAME;QAAUD;KAAS;AAC/B,EAAE"}
1
+ {"version":3,"sources":["../../src/hooks/useGlobalEscKeyDown.ts"],"sourcesContent":["import { Keys, pressedKey } from '../lib/accessibility';\nimport { useDOM } from '../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\n\nconst EVENT_OPTIONS = {\n passive: true,\n capture: true,\n};\n\n/**\n * Завязывается на document.\n *\n * @private\n */\nexport const useGlobalEscKeyDown = (init: boolean, callback?: (event: KeyboardEvent) => void) => {\n const { document } = useDOM();\n useIsomorphicLayoutEffect(() => {\n if (!document || !init || !callback) {\n return;\n }\n const handleKeyDown = (event: KeyboardEvent) => {\n if (pressedKey(event) === Keys.ESCAPE) {\n callback(event);\n }\n };\n document.addEventListener('keydown', handleKeyDown, EVENT_OPTIONS);\n return () => {\n document.removeEventListener('keydown', handleKeyDown, EVENT_OPTIONS);\n };\n }, [init, document, callback]);\n};\n"],"names":["Keys","pressedKey","useDOM","useIsomorphicLayoutEffect","EVENT_OPTIONS","passive","capture","useGlobalEscKeyDown","init","callback","document","handleKeyDown","event","ESCAPE","addEventListener","removeEventListener"],"mappings":"AAAA,SAASA,IAAI,EAAEC,UAAU,QAAQ,uBAAuB;AACxD,SAASC,MAAM,QAAQ,aAAa;AACpC,SAASC,yBAAyB,QAAQ,mCAAmC;AAE7E,MAAMC,gBAAgB;IACpBC,SAAS;IACTC,SAAS;AACX;AAEA;;;;CAIC,GACD,OAAO,MAAMC,sBAAsB,CAACC,MAAeC;IACjD,MAAM,EAAEC,QAAQ,EAAE,GAAGR;IACrBC,0BAA0B;QACxB,IAAI,CAACO,YAAY,CAACF,QAAQ,CAACC,UAAU;YACnC;QACF;QACA,MAAME,gBAAgB,CAACC;YACrB,IAAIX,WAAWW,WAAWZ,KAAKa,MAAM,EAAE;gBACrCJ,SAASG;YACX;QACF;QACAF,SAASI,gBAAgB,CAAC,WAAWH,eAAeP;QACpD,OAAO;YACLM,SAASK,mBAAmB,CAAC,WAAWJ,eAAeP;QACzD;IACF,GAAG;QAACI;QAAME;QAAUD;KAAS;AAC/B,EAAE"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useGlobalEventListener.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\nimport { useEventListener } from './useEventListener';\n\nexport function useGlobalEventListener<K extends keyof GlobalEventHandlersEventMap>(\n element: Document | HTMLElement | Window | null | undefined,\n event: K,\n cb: ((ev: GlobalEventHandlersEventMap[K]) => void) | null | false | undefined,\n options?: AddEventListenerOptions,\n): void;\nexport function useGlobalEventListener<E extends Event>(\n element: Document | HTMLElement | Window | null | undefined,\n event: string,\n cb: ((ev: E) => void) | null | false | undefined,\n options?: AddEventListenerOptions,\n): void;\nexport function useGlobalEventListener<\n K extends keyof GlobalEventHandlersEventMap,\n E extends Event,\n>(\n element: Document | HTMLElement | Window | null | undefined,\n event: K | string,\n cb: ((ev: E) => void) | null | false | undefined,\n options?: AddEventListenerOptions,\n) {\n const listener = useEventListener(event, cb, options);\n useIsomorphicLayoutEffect(() => {\n if (cb && element) {\n listener.add(element);\n } else {\n listener.remove();\n }\n }, [Boolean(cb), Boolean(element)]);\n}\n"],"names":["useIsomorphicLayoutEffect","useEventListener","useGlobalEventListener","element","event","cb","options","listener","add","remove","Boolean"],"rangeMappings":";;;;;;;;;;;;;;","mappings":"AAAA,SAASA,yBAAyB,QAAQ,mCAAmC;AAC7E,SAASC,gBAAgB,QAAQ,qBAAqB;AActD,OAAO,SAASC,uBAIdC,OAA2D,EAC3DC,KAAiB,EACjBC,EAAgD,EAChDC,OAAiC;IAEjC,MAAMC,WAAWN,iBAAiBG,OAAOC,IAAIC;IAC7CN,0BAA0B;QACxB,IAAIK,MAAMF,SAAS;YACjBI,SAASC,GAAG,CAACL;QACf,OAAO;YACLI,SAASE,MAAM;QACjB;IACF,GAAG;QAACC,QAAQL;QAAKK,QAAQP;KAAS;AACpC"}
1
+ {"version":3,"sources":["../../src/hooks/useGlobalEventListener.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\nimport { useEventListener } from './useEventListener';\n\nexport function useGlobalEventListener<K extends keyof GlobalEventHandlersEventMap>(\n element: Document | HTMLElement | Window | null | undefined,\n event: K,\n cb: ((ev: GlobalEventHandlersEventMap[K]) => void) | null | false | undefined,\n options?: AddEventListenerOptions,\n): void;\nexport function useGlobalEventListener<E extends Event>(\n element: Document | HTMLElement | Window | null | undefined,\n event: string,\n cb: ((ev: E) => void) | null | false | undefined,\n options?: AddEventListenerOptions,\n): void;\nexport function useGlobalEventListener<\n K extends keyof GlobalEventHandlersEventMap,\n E extends Event,\n>(\n element: Document | HTMLElement | Window | null | undefined,\n event: K | string,\n cb: ((ev: E) => void) | null | false | undefined,\n options?: AddEventListenerOptions,\n) {\n const listener = useEventListener(event, cb, options);\n useIsomorphicLayoutEffect(() => {\n if (cb && element) {\n listener.add(element);\n } else {\n listener.remove();\n }\n }, [Boolean(cb), Boolean(element)]);\n}\n"],"names":["useIsomorphicLayoutEffect","useEventListener","useGlobalEventListener","element","event","cb","options","listener","add","remove","Boolean"],"mappings":"AAAA,SAASA,yBAAyB,QAAQ,mCAAmC;AAC7E,SAASC,gBAAgB,QAAQ,qBAAqB;AActD,OAAO,SAASC,uBAIdC,OAA2D,EAC3DC,KAAiB,EACjBC,EAAgD,EAChDC,OAAiC;IAEjC,MAAMC,WAAWN,iBAAiBG,OAAOC,IAAIC;IAC7CN,0BAA0B;QACxB,IAAIK,MAAMF,SAAS;YACjBI,SAASC,GAAG,CAACL;QACf,OAAO;YACLI,SAASE,MAAM;QACjB;IACF,GAAG;QAACC,QAAQL;QAAKK,QAAQP;KAAS;AACpC"}
@@ -4,5 +4,5 @@ import * as React from 'react';
4
4
  *
5
5
  * @private
6
6
  */
7
- export declare const useGlobalOnClickOutside: <T extends React.RefObject<ElementType> | null | undefined, ElementType extends Element = Element>(callback: (event: MouseEvent) => void, ...refs: T[]) => void;
7
+ export declare const useGlobalOnClickOutside: <T extends React.RefObject<ElementType> | undefined | null, ElementType extends Element = Element>(callback: (event: MouseEvent) => void, ...refs: T[]) => void;
8
8
  //# sourceMappingURL=useGlobalOnClickOutside.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useGlobalOnClickOutside.d.ts","sourceRoot":"","sources":["../../src/hooks/useGlobalOnClickOutside.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B;;;;GAIG;AACH,eAAO,MAAM,uBAAuB,+GAIxB,CAAC,KAAK,EAAE,UAAU,KAAK,IAAI,WAC5B,CAAC,EAAE,SAyBb,CAAC"}
1
+ {"version":3,"file":"useGlobalOnClickOutside.d.ts","sourceRoot":"","sources":["../../src/hooks/useGlobalOnClickOutside.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B;;;;GAIG;AACH,eAAO,MAAM,uBAAuB,GAClC,CAAC,SAAS,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,GAAG,SAAS,GAAG,IAAI,EACzD,WAAW,SAAS,OAAO,sBAEjB,CAAC,KAAK,EAAE,UAAU,KAAK,IAAI,WAC5B,CAAC,EAAE,SAyBb,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useGlobalOnClickOutside.ts"],"sourcesContent":["import * as React from 'react';\nimport { isElement, useDOM } from '../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\n\n/**\n * Завязывается на document.\n *\n * @private\n */\nexport const useGlobalOnClickOutside = <\n T extends React.RefObject<ElementType> | undefined | null,\n ElementType extends Element = Element,\n>(\n callback: (event: MouseEvent) => void,\n ...refs: T[]\n) => {\n const { document } = useDOM();\n useIsomorphicLayoutEffect(() => {\n const someRefNotNull = refs.some((ref) => ref && ref.current !== null);\n if (!document || !someRefNotNull) {\n return;\n }\n const handleClick = (event: MouseEvent) => {\n const targetEl = event.target;\n const someRefHasTargetEl =\n isElement(targetEl) &&\n refs.some((ref) => ref && ref.current && ref.current.contains(targetEl));\n if (!someRefHasTargetEl) {\n callback(event);\n }\n };\n document.addEventListener('click', handleClick, {\n passive: true,\n capture: true,\n });\n return () => {\n document.removeEventListener('click', handleClick, true);\n };\n }, [document, callback, ...refs]);\n};\n"],"names":["React","isElement","useDOM","useIsomorphicLayoutEffect","useGlobalOnClickOutside","callback","refs","document","someRefNotNull","some","ref","current","handleClick","event","targetEl","target","someRefHasTargetEl","contains","addEventListener","passive","capture","removeEventListener"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,SAAS,EAAEC,MAAM,QAAQ,aAAa;AAC/C,SAASC,yBAAyB,QAAQ,mCAAmC;AAE7E;;;;CAIC,GACD,OAAO,MAAMC,0BAA0B,CAIrCC,UACA,GAAGC;IAEH,MAAM,EAAEC,QAAQ,EAAE,GAAGL;IACrBC,0BAA0B;QACxB,MAAMK,iBAAiBF,KAAKG,IAAI,CAAC,CAACC,MAAQA,OAAOA,IAAIC,OAAO,KAAK;QACjE,IAAI,CAACJ,YAAY,CAACC,gBAAgB;YAChC;QACF;QACA,MAAMI,cAAc,CAACC;YACnB,MAAMC,WAAWD,MAAME,MAAM;YAC7B,MAAMC,qBACJf,UAAUa,aACVR,KAAKG,IAAI,CAAC,CAACC,MAAQA,OAAOA,IAAIC,OAAO,IAAID,IAAIC,OAAO,CAACM,QAAQ,CAACH;YAChE,IAAI,CAACE,oBAAoB;gBACvBX,SAASQ;YACX;QACF;QACAN,SAASW,gBAAgB,CAAC,SAASN,aAAa;YAC9CO,SAAS;YACTC,SAAS;QACX;QACA,OAAO;YACLb,SAASc,mBAAmB,CAAC,SAAST,aAAa;QACrD;IACF,GAAG;QAACL;QAAUF;WAAaC;KAAK;AAClC,EAAE"}
1
+ {"version":3,"sources":["../../src/hooks/useGlobalOnClickOutside.ts"],"sourcesContent":["import * as React from 'react';\nimport { isElement, useDOM } from '../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../lib/useIsomorphicLayoutEffect';\n\n/**\n * Завязывается на document.\n *\n * @private\n */\nexport const useGlobalOnClickOutside = <\n T extends React.RefObject<ElementType> | undefined | null,\n ElementType extends Element = Element,\n>(\n callback: (event: MouseEvent) => void,\n ...refs: T[]\n) => {\n const { document } = useDOM();\n useIsomorphicLayoutEffect(() => {\n const someRefNotNull = refs.some((ref) => ref && ref.current !== null);\n if (!document || !someRefNotNull) {\n return;\n }\n const handleClick = (event: MouseEvent) => {\n const targetEl = event.target;\n const someRefHasTargetEl =\n isElement(targetEl) &&\n refs.some((ref) => ref && ref.current && ref.current.contains(targetEl));\n if (!someRefHasTargetEl) {\n callback(event);\n }\n };\n document.addEventListener('click', handleClick, {\n passive: true,\n capture: true,\n });\n return () => {\n document.removeEventListener('click', handleClick, true);\n };\n }, [document, callback, ...refs]);\n};\n"],"names":["React","isElement","useDOM","useIsomorphicLayoutEffect","useGlobalOnClickOutside","callback","refs","document","someRefNotNull","some","ref","current","handleClick","event","targetEl","target","someRefHasTargetEl","contains","addEventListener","passive","capture","removeEventListener"],"mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,SAAS,EAAEC,MAAM,QAAQ,aAAa;AAC/C,SAASC,yBAAyB,QAAQ,mCAAmC;AAE7E;;;;CAIC,GACD,OAAO,MAAMC,0BAA0B,CAIrCC,UACA,GAAGC;IAEH,MAAM,EAAEC,QAAQ,EAAE,GAAGL;IACrBC,0BAA0B;QACxB,MAAMK,iBAAiBF,KAAKG,IAAI,CAAC,CAACC,MAAQA,OAAOA,IAAIC,OAAO,KAAK;QACjE,IAAI,CAACJ,YAAY,CAACC,gBAAgB;YAChC;QACF;QACA,MAAMI,cAAc,CAACC;YACnB,MAAMC,WAAWD,MAAME,MAAM;YAC7B,MAAMC,qBACJf,UAAUa,aACVR,KAAKG,IAAI,CAAC,CAACC,MAAQA,OAAOA,IAAIC,OAAO,IAAID,IAAIC,OAAO,CAACM,QAAQ,CAACH;YAChE,IAAI,CAACE,oBAAoB;gBACvBX,SAASQ;YACX;QACF;QACAN,SAASW,gBAAgB,CAAC,SAASN,aAAa;YAC9CO,SAAS;YACTC,SAAS;QACX;QACA,OAAO;YACLb,SAASc,mBAAmB,CAAC,SAAST,aAAa;QACrD;IACF,GAAG;QAACL;QAAUF;WAAaC;KAAK;AAClC,EAAE"}