@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,"sources":["../../../../src/components/ModalCardBase/ModalCardBase.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { useAdaptivityWithJSMediaQueries } from '../../hooks/useAdaptivityWithJSMediaQueries';\nimport { useKeyboard } from '../../hooks/useKeyboard';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { HTMLAttributesWithRootRef } from '../../types';\nimport { AdaptivityContext } from '../AdaptivityProvider/AdaptivityContext';\nimport { RootComponent } from '../RootComponent/RootComponent';\nimport { Spacing } from '../Spacing/Spacing';\nimport { Subhead } from '../Typography/Subhead/Subhead';\nimport { Title } from '../Typography/Title/Title';\nimport { ModalCardBaseCloseButton } from './ModalCardBaseCloseButton';\nimport styles from './ModalCardBase.module.css';\n\nexport interface ModalCardBaseProps extends HTMLAttributesWithRootRef<HTMLDivElement> {\n /**\n * Иконка.\n *\n * Может быть компонентом иконки, например, `<Icon56MoneyTransferOutline />`, или `<Avatar size={72} src=\"\" />`\n */\n icon?: React.ReactNode;\n\n /**\n * Заголовок карточки\n */\n header?: React.ReactNode;\n /* Позволяет поменять тег используемый для заголовка */\n headerComponent?: React.ElementType;\n\n /**\n * Подзаголовок\n */\n subheader?: React.ReactNode;\n /* Позволяет поменять тег используемый для подзаголовка */\n subheaderComponent?: React.ElementType;\n\n /**\n * Кнопки-действия. Принимает [`Button`](https://vkcom.github.io/VKUI/#/Button) с параметрами:\n *\n * - `size=\"l\" mode=\"primary\" stretched`\n * - `size=\"l\" mode=\"secondary\" stretched`\n *\n * Для набора кнопок используйте [`ButtonGroup`](https://vkcom.github.io/VKUI/#/ButtonGroup) с параметрами:\n *\n * - `gap=\"s\" mode=\"horizontal\" stretched`\n * - `gap=\"m\" mode=\"vertical\" stretched`\n */\n actions?: React.ReactNode;\n\n onClose?: VoidFunction;\n\n /**\n * Текст кнопки закрытия. Делает ее доступной для ассистивных технологий\n */\n dismissLabel?: string;\n\n /**\n * Задаёт контенту максимальную ширину для десктопной версии.\n */\n size?: number;\n\n /**\n * `data-testid` для кнопки закрытия\n */\n modalDismissButtonTestId?: string;\n /**\n * Расположение кнопки закрытия (внутри и вне `popout'a`)\n *\n * Доступно только в `compact`-режиме\n *\n * На `iOS` в `regular`-режиме всегда включен `inside`\n *\n * ⚠️ ВНИМАНИЕ: использование `none` скрывает крестик, это негативно сказывается на пользовательском опыте\n */\n dismissButtonMode?: 'inside' | 'outside' | 'none';\n /**\n * Позволяет отключить возможность закрытия модальной страницы (смахивание, клавиша `ESC`, клик по подложке)\n *\n * ⚠️ ВНИМАНИЕ: использование этой опции негативно сказывается на пользовательском опыте\n */\n preventClose?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalCardBase\n */\nexport const ModalCardBase = ({\n icon,\n header,\n headerComponent = 'span',\n subheader,\n subheaderComponent = 'span',\n children,\n actions,\n onClose,\n dismissLabel = 'Скрыть',\n style,\n size: sizeProp,\n modalDismissButtonTestId,\n dismissButtonMode = 'outside',\n preventClose,\n ...restProps\n}: ModalCardBaseProps) => {\n const platform = usePlatform();\n const { isDesktop } = useAdaptivityWithJSMediaQueries();\n const isSoftwareKeyboardOpened = useKeyboard().isOpened;\n\n const size = isDesktop ? sizeProp : undefined;\n const withSafeZone =\n !icon &&\n (dismissButtonMode === 'inside' ||\n (platform === 'ios' && !isDesktop && dismissButtonMode !== 'none'));\n\n const hasHeader = hasReactNode(header);\n const hasSubheader = hasReactNode(subheader);\n return (\n <RootComponent\n {...restProps}\n baseClassName={classNames(\n 'vkuiInternalModalCardBase',\n platform === 'ios' && styles['ModalCardBase--ios'],\n isDesktop && styles['ModalCardBase--desktop'],\n withSafeZone && styles['ModalCardBase--withSafeZone'],\n )}\n style={{\n ...style,\n maxWidth: size,\n }}\n >\n <div\n className={classNames(\n styles['ModalCardBase__container'],\n isSoftwareKeyboardOpened && styles['ModalCardBase__container--softwareKeyboardOpened'],\n )}\n >\n {hasReactNode(icon) && <div className={styles['ModalCardBase__icon']}>{icon}</div>}\n {hasReactNode(header) && (\n <Title\n level=\"2\"\n weight=\"2\"\n className={styles['ModalCardBase__header']}\n Component={headerComponent}\n >\n {header}\n </Title>\n )}\n {hasHeader && hasSubheader && <Spacing size={8} />}\n {hasSubheader && (\n <AdaptivityContext.Provider value={{ sizeY: 'regular' }}>\n <Subhead className={styles['ModalCardBase__subheader']} Component={subheaderComponent}>\n {subheader}\n </Subhead>\n </AdaptivityContext.Provider>\n )}\n\n {children}\n\n {hasReactNode(actions) && <div className={styles['ModalCardBase__actions']}>{actions}</div>}\n\n {dismissButtonMode !== 'none' && (\n <ModalCardBaseCloseButton\n testId={modalDismissButtonTestId}\n onClose={onClose}\n mode={dismissButtonMode}\n >\n {dismissLabel}\n </ModalCardBaseCloseButton>\n )}\n </div>\n </RootComponent>\n );\n};\n"],"names":["React","classNames","hasReactNode","useAdaptivityWithJSMediaQueries","useKeyboard","usePlatform","AdaptivityContext","RootComponent","Spacing","Subhead","Title","ModalCardBaseCloseButton","styles","ModalCardBase","icon","header","headerComponent","subheader","subheaderComponent","children","actions","onClose","dismissLabel","style","size","sizeProp","modalDismissButtonTestId","dismissButtonMode","preventClose","restProps","platform","isDesktop","isSoftwareKeyboardOpened","isOpened","undefined","withSafeZone","hasHeader","hasSubheader","baseClassName","maxWidth","div","className","level","weight","Component","Provider","value","sizeY","testId","mode"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,EAAEC,YAAY,QAAQ,kBAAkB;AAC3D,SAASC,+BAA+B,QAAQ,8CAA8C;AAC9F,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,WAAW,QAAQ,0BAA0B;AAEtD,SAASC,iBAAiB,QAAQ,0CAA0C;AAC5E,SAASC,aAAa,QAAQ,iCAAiC;AAC/D,SAASC,OAAO,QAAQ,qBAAqB;AAC7C,SAASC,OAAO,QAAQ,gCAAgC;AACxD,SAASC,KAAK,QAAQ,4BAA4B;AAClD,SAASC,wBAAwB,QAAQ,6BAA6B;AACtE,OAAOC,YAAY,6BAA6B;AAuEhD;;CAEC,GACD,OAAO,MAAMC,gBAAgB,CAAC,EAC5BC,IAAI,EACJC,MAAM,EACNC,kBAAkB,MAAM,EACxBC,SAAS,EACTC,qBAAqB,MAAM,EAC3BC,QAAQ,EACRC,OAAO,EACPC,OAAO,EACPC,eAAe,QAAQ,EACvBC,KAAK,EACLC,MAAMC,QAAQ,EACdC,wBAAwB,EACxBC,oBAAoB,SAAS,EAC7BC,YAAY,EACZ,GAAGC,WACgB;IACnB,MAAMC,WAAWzB;IACjB,MAAM,EAAE0B,SAAS,EAAE,GAAG5B;IACtB,MAAM6B,2BAA2B5B,cAAc6B,QAAQ;IAEvD,MAAMT,OAAOO,YAAYN,WAAWS;IACpC,MAAMC,eACJ,CAACrB,QACAa,CAAAA,sBAAsB,YACpBG,aAAa,SAAS,CAACC,aAAaJ,sBAAsB,MAAM;IAErE,MAAMS,YAAYlC,aAAaa;IAC/B,MAAMsB,eAAenC,aAAae;IAClC,qBACE,KAACV;QACE,GAAGsB,SAAS;QACbS,eAAerC,WACb,6BACA6B,aAAa,SAASlB,MAAM,CAAC,qBAAqB,EAClDmB,aAAanB,MAAM,CAAC,yBAAyB,EAC7CuB,gBAAgBvB,MAAM,CAAC,8BAA8B;QAEvDW,OAAO;YACL,GAAGA,KAAK;YACRgB,UAAUf;QACZ;kBAEA,cAAA,MAACgB;YACCC,WAAWxC,WACTW,MAAM,CAAC,2BAA2B,EAClCoB,4BAA4BpB,MAAM,CAAC,mDAAmD;;gBAGvFV,aAAaY,uBAAS,KAAC0B;oBAAIC,WAAW7B,MAAM,CAAC,sBAAsB;8BAAGE;;gBACtEZ,aAAaa,yBACZ,KAACL;oBACCgC,OAAM;oBACNC,QAAO;oBACPF,WAAW7B,MAAM,CAAC,wBAAwB;oBAC1CgC,WAAW5B;8BAEVD;;gBAGJqB,aAAaC,8BAAgB,KAAC7B;oBAAQgB,MAAM;;gBAC5Ca,8BACC,KAAC/B,kBAAkBuC,QAAQ;oBAACC,OAAO;wBAAEC,OAAO;oBAAU;8BACpD,cAAA,KAACtC;wBAAQgC,WAAW7B,MAAM,CAAC,2BAA2B;wBAAEgC,WAAW1B;kCAChED;;;gBAKNE;gBAEAjB,aAAakB,0BAAY,KAACoB;oBAAIC,WAAW7B,MAAM,CAAC,yBAAyB;8BAAGQ;;gBAE5EO,sBAAsB,wBACrB,KAAChB;oBACCqC,QAAQtB;oBACRL,SAASA;oBACT4B,MAAMtB;8BAELL;;;;;AAMb,EAAE"}
1
+ {"version":3,"sources":["../../../../src/components/ModalCardBase/ModalCardBase.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { useAdaptivityWithJSMediaQueries } from '../../hooks/useAdaptivityWithJSMediaQueries';\nimport { useKeyboard } from '../../hooks/useKeyboard';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { HTMLAttributesWithRootRef } from '../../types';\nimport { AdaptivityContext } from '../AdaptivityProvider/AdaptivityContext';\nimport { RootComponent } from '../RootComponent/RootComponent';\nimport { Spacing } from '../Spacing/Spacing';\nimport { Subhead } from '../Typography/Subhead/Subhead';\nimport { Title } from '../Typography/Title/Title';\nimport { ModalCardBaseCloseButton } from './ModalCardBaseCloseButton';\nimport styles from './ModalCardBase.module.css';\n\nexport interface ModalCardBaseProps extends HTMLAttributesWithRootRef<HTMLDivElement> {\n /**\n * Иконка.\n *\n * Может быть компонентом иконки, например, `<Icon56MoneyTransferOutline />`, или `<Avatar size={72} src=\"\" />`\n */\n icon?: React.ReactNode;\n\n /**\n * Заголовок карточки\n */\n header?: React.ReactNode;\n /* Позволяет поменять тег используемый для заголовка */\n headerComponent?: React.ElementType;\n\n /**\n * Подзаголовок\n */\n subheader?: React.ReactNode;\n /* Позволяет поменять тег используемый для подзаголовка */\n subheaderComponent?: React.ElementType;\n\n /**\n * Кнопки-действия. Принимает [`Button`](https://vkcom.github.io/VKUI/#/Button) с параметрами:\n *\n * - `size=\"l\" mode=\"primary\" stretched`\n * - `size=\"l\" mode=\"secondary\" stretched`\n *\n * Для набора кнопок используйте [`ButtonGroup`](https://vkcom.github.io/VKUI/#/ButtonGroup) с параметрами:\n *\n * - `gap=\"s\" mode=\"horizontal\" stretched`\n * - `gap=\"m\" mode=\"vertical\" stretched`\n */\n actions?: React.ReactNode;\n\n onClose?: VoidFunction;\n\n /**\n * Текст кнопки закрытия. Делает ее доступной для ассистивных технологий\n */\n dismissLabel?: string;\n\n /**\n * Задаёт контенту максимальную ширину для десктопной версии.\n */\n size?: number;\n\n /**\n * `data-testid` для кнопки закрытия\n */\n modalDismissButtonTestId?: string;\n /**\n * Расположение кнопки закрытия (внутри и вне `popout'a`)\n *\n * Доступно только в `compact`-режиме\n *\n * На `iOS` в `regular`-режиме всегда включен `inside`\n *\n * ⚠️ ВНИМАНИЕ: использование `none` скрывает крестик, это негативно сказывается на пользовательском опыте\n */\n dismissButtonMode?: 'inside' | 'outside' | 'none';\n /**\n * Позволяет отключить возможность закрытия модальной страницы (смахивание, клавиша `ESC`, клик по подложке)\n *\n * ⚠️ ВНИМАНИЕ: использование этой опции негативно сказывается на пользовательском опыте\n */\n preventClose?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalCardBase\n */\nexport const ModalCardBase = ({\n icon,\n header,\n headerComponent = 'span',\n subheader,\n subheaderComponent = 'span',\n children,\n actions,\n onClose,\n dismissLabel = 'Скрыть',\n style,\n size: sizeProp,\n modalDismissButtonTestId,\n dismissButtonMode = 'outside',\n preventClose,\n ...restProps\n}: ModalCardBaseProps) => {\n const platform = usePlatform();\n const { isDesktop } = useAdaptivityWithJSMediaQueries();\n const isSoftwareKeyboardOpened = useKeyboard().isOpened;\n\n const size = isDesktop ? sizeProp : undefined;\n const withSafeZone =\n !icon &&\n (dismissButtonMode === 'inside' ||\n (platform === 'ios' && !isDesktop && dismissButtonMode !== 'none'));\n\n const hasHeader = hasReactNode(header);\n const hasSubheader = hasReactNode(subheader);\n return (\n <RootComponent\n {...restProps}\n baseClassName={classNames(\n 'vkuiInternalModalCardBase',\n platform === 'ios' && styles['ModalCardBase--ios'],\n isDesktop && styles['ModalCardBase--desktop'],\n withSafeZone && styles['ModalCardBase--withSafeZone'],\n )}\n style={{\n ...style,\n maxWidth: size,\n }}\n >\n <div\n className={classNames(\n styles['ModalCardBase__container'],\n isSoftwareKeyboardOpened && styles['ModalCardBase__container--softwareKeyboardOpened'],\n )}\n >\n {hasReactNode(icon) && <div className={styles['ModalCardBase__icon']}>{icon}</div>}\n {hasReactNode(header) && (\n <Title\n level=\"2\"\n weight=\"2\"\n className={styles['ModalCardBase__header']}\n Component={headerComponent}\n >\n {header}\n </Title>\n )}\n {hasHeader && hasSubheader && <Spacing size={8} />}\n {hasSubheader && (\n <AdaptivityContext.Provider value={{ sizeY: 'regular' }}>\n <Subhead className={styles['ModalCardBase__subheader']} Component={subheaderComponent}>\n {subheader}\n </Subhead>\n </AdaptivityContext.Provider>\n )}\n\n {children}\n\n {hasReactNode(actions) && <div className={styles['ModalCardBase__actions']}>{actions}</div>}\n\n {dismissButtonMode !== 'none' && (\n <ModalCardBaseCloseButton\n testId={modalDismissButtonTestId}\n onClose={onClose}\n mode={dismissButtonMode}\n >\n {dismissLabel}\n </ModalCardBaseCloseButton>\n )}\n </div>\n </RootComponent>\n );\n};\n"],"names":["React","classNames","hasReactNode","useAdaptivityWithJSMediaQueries","useKeyboard","usePlatform","AdaptivityContext","RootComponent","Spacing","Subhead","Title","ModalCardBaseCloseButton","styles","ModalCardBase","icon","header","headerComponent","subheader","subheaderComponent","children","actions","onClose","dismissLabel","style","size","sizeProp","modalDismissButtonTestId","dismissButtonMode","preventClose","restProps","platform","isDesktop","isSoftwareKeyboardOpened","isOpened","undefined","withSafeZone","hasHeader","hasSubheader","baseClassName","maxWidth","div","className","level","weight","Component","Provider","value","sizeY","testId","mode"],"mappings":";AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,EAAEC,YAAY,QAAQ,kBAAkB;AAC3D,SAASC,+BAA+B,QAAQ,8CAA8C;AAC9F,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,WAAW,QAAQ,0BAA0B;AAEtD,SAASC,iBAAiB,QAAQ,0CAA0C;AAC5E,SAASC,aAAa,QAAQ,iCAAiC;AAC/D,SAASC,OAAO,QAAQ,qBAAqB;AAC7C,SAASC,OAAO,QAAQ,gCAAgC;AACxD,SAASC,KAAK,QAAQ,4BAA4B;AAClD,SAASC,wBAAwB,QAAQ,6BAA6B;AACtE,OAAOC,YAAY,6BAA6B;AAuEhD;;CAEC,GACD,OAAO,MAAMC,gBAAgB,CAAC,EAC5BC,IAAI,EACJC,MAAM,EACNC,kBAAkB,MAAM,EACxBC,SAAS,EACTC,qBAAqB,MAAM,EAC3BC,QAAQ,EACRC,OAAO,EACPC,OAAO,EACPC,eAAe,QAAQ,EACvBC,KAAK,EACLC,MAAMC,QAAQ,EACdC,wBAAwB,EACxBC,oBAAoB,SAAS,EAC7BC,YAAY,EACZ,GAAGC,WACgB;IACnB,MAAMC,WAAWzB;IACjB,MAAM,EAAE0B,SAAS,EAAE,GAAG5B;IACtB,MAAM6B,2BAA2B5B,cAAc6B,QAAQ;IAEvD,MAAMT,OAAOO,YAAYN,WAAWS;IACpC,MAAMC,eACJ,CAACrB,QACAa,CAAAA,sBAAsB,YACpBG,aAAa,SAAS,CAACC,aAAaJ,sBAAsB,MAAM;IAErE,MAAMS,YAAYlC,aAAaa;IAC/B,MAAMsB,eAAenC,aAAae;IAClC,qBACE,KAACV;QACE,GAAGsB,SAAS;QACbS,eAAerC,WACb,6BACA6B,aAAa,SAASlB,MAAM,CAAC,qBAAqB,EAClDmB,aAAanB,MAAM,CAAC,yBAAyB,EAC7CuB,gBAAgBvB,MAAM,CAAC,8BAA8B;QAEvDW,OAAO;YACL,GAAGA,KAAK;YACRgB,UAAUf;QACZ;kBAEA,cAAA,MAACgB;YACCC,WAAWxC,WACTW,MAAM,CAAC,2BAA2B,EAClCoB,4BAA4BpB,MAAM,CAAC,mDAAmD;;gBAGvFV,aAAaY,uBAAS,KAAC0B;oBAAIC,WAAW7B,MAAM,CAAC,sBAAsB;8BAAGE;;gBACtEZ,aAAaa,yBACZ,KAACL;oBACCgC,OAAM;oBACNC,QAAO;oBACPF,WAAW7B,MAAM,CAAC,wBAAwB;oBAC1CgC,WAAW5B;8BAEVD;;gBAGJqB,aAAaC,8BAAgB,KAAC7B;oBAAQgB,MAAM;;gBAC5Ca,8BACC,KAAC/B,kBAAkBuC,QAAQ;oBAACC,OAAO;wBAAEC,OAAO;oBAAU;8BACpD,cAAA,KAACtC;wBAAQgC,WAAW7B,MAAM,CAAC,2BAA2B;wBAAEgC,WAAW1B;kCAChED;;;gBAKNE;gBAEAjB,aAAakB,0BAAY,KAACoB;oBAAIC,WAAW7B,MAAM,CAAC,yBAAyB;8BAAGQ;;gBAE5EO,sBAAsB,wBACrB,KAAChB;oBACCqC,QAAQtB;oBACRL,SAASA;oBACT4B,MAAMtB;8BAELL;;;;;AAMb,EAAE"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalCardBase/ModalCardBaseCloseButton.tsx"],"sourcesContent":["import { Icon20Cancel, Icon24Dismiss } from '@vkontakte/icons';\nimport { useAdaptivityWithJSMediaQueries } from '../../hooks/useAdaptivityWithJSMediaQueries';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { ModalDismissButton } from '../ModalDismissButton/ModalDismissButton';\nimport { Tappable, TappableProps } from '../Tappable/Tappable';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport styles from './ModalCardBase.module.css';\n\ninterface ModalCardBaseCloseButtonProps extends Omit<TappableProps, 'mode' | 'onClose'> {\n onClose?: VoidFunction;\n testId?: string;\n mode?: 'inside' | 'outside';\n}\n\nexport function ModalCardBaseCloseButton({\n children = 'Закрыть',\n testId,\n mode,\n onClose,\n}: ModalCardBaseCloseButtonProps) {\n const platform = usePlatform();\n const { isDesktop } = useAdaptivityWithJSMediaQueries();\n\n if (isDesktop && mode === 'outside') {\n return (\n <ModalDismissButton data-testid={testId} onClick={onClose}>\n {children}\n </ModalDismissButton>\n );\n }\n\n if (mode === 'inside' || (platform === 'ios' && !isDesktop)) {\n return (\n <Tappable\n className={styles['ModalCardBase__dismiss']}\n onClick={onClose}\n hoverMode=\"opacity\"\n activeMode=\"opacity\"\n data-testid={testId}\n >\n <VisuallyHidden>{children}</VisuallyHidden>\n {platform === 'ios' ? <Icon24Dismiss /> : <Icon20Cancel />}\n </Tappable>\n );\n }\n\n return null;\n}\n"],"names":["Icon20Cancel","Icon24Dismiss","useAdaptivityWithJSMediaQueries","usePlatform","ModalDismissButton","Tappable","VisuallyHidden","styles","ModalCardBaseCloseButton","children","testId","mode","onClose","platform","isDesktop","data-testid","onClick","className","hoverMode","activeMode"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";AAAA,SAASA,YAAY,EAAEC,aAAa,QAAQ,mBAAmB;AAC/D,SAASC,+BAA+B,QAAQ,8CAA8C;AAC9F,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,kBAAkB,QAAQ,2CAA2C;AAC9E,SAASC,QAAQ,QAAuB,uBAAuB;AAC/D,SAASC,cAAc,QAAQ,mCAAmC;AAClE,OAAOC,YAAY,6BAA6B;AAQhD,OAAO,SAASC,yBAAyB,EACvCC,WAAW,SAAS,EACpBC,MAAM,EACNC,IAAI,EACJC,OAAO,EACuB;IAC9B,MAAMC,WAAWV;IACjB,MAAM,EAAEW,SAAS,EAAE,GAAGZ;IAEtB,IAAIY,aAAaH,SAAS,WAAW;QACnC,qBACE,KAACP;YAAmBW,eAAaL;YAAQM,SAASJ;sBAC/CH;;IAGP;IAEA,IAAIE,SAAS,YAAaE,aAAa,SAAS,CAACC,WAAY;QAC3D,qBACE,MAACT;YACCY,WAAWV,MAAM,CAAC,yBAAyB;YAC3CS,SAASJ;YACTM,WAAU;YACVC,YAAW;YACXJ,eAAaL;;8BAEb,KAACJ;8BAAgBG;;gBAChBI,aAAa,sBAAQ,KAACZ,mCAAmB,KAACD;;;IAGjD;IAEA,OAAO;AACT"}
1
+ {"version":3,"sources":["../../../../src/components/ModalCardBase/ModalCardBaseCloseButton.tsx"],"sourcesContent":["import { Icon20Cancel, Icon24Dismiss } from '@vkontakte/icons';\nimport { useAdaptivityWithJSMediaQueries } from '../../hooks/useAdaptivityWithJSMediaQueries';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { ModalDismissButton } from '../ModalDismissButton/ModalDismissButton';\nimport { Tappable, TappableProps } from '../Tappable/Tappable';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport styles from './ModalCardBase.module.css';\n\ninterface ModalCardBaseCloseButtonProps extends Omit<TappableProps, 'mode' | 'onClose'> {\n onClose?: VoidFunction;\n testId?: string;\n mode?: 'inside' | 'outside';\n}\n\nexport function ModalCardBaseCloseButton({\n children = 'Закрыть',\n testId,\n mode,\n onClose,\n}: ModalCardBaseCloseButtonProps) {\n const platform = usePlatform();\n const { isDesktop } = useAdaptivityWithJSMediaQueries();\n\n if (isDesktop && mode === 'outside') {\n return (\n <ModalDismissButton data-testid={testId} onClick={onClose}>\n {children}\n </ModalDismissButton>\n );\n }\n\n if (mode === 'inside' || (platform === 'ios' && !isDesktop)) {\n return (\n <Tappable\n className={styles['ModalCardBase__dismiss']}\n onClick={onClose}\n hoverMode=\"opacity\"\n activeMode=\"opacity\"\n data-testid={testId}\n >\n <VisuallyHidden>{children}</VisuallyHidden>\n {platform === 'ios' ? <Icon24Dismiss /> : <Icon20Cancel />}\n </Tappable>\n );\n }\n\n return null;\n}\n"],"names":["Icon20Cancel","Icon24Dismiss","useAdaptivityWithJSMediaQueries","usePlatform","ModalDismissButton","Tappable","VisuallyHidden","styles","ModalCardBaseCloseButton","children","testId","mode","onClose","platform","isDesktop","data-testid","onClick","className","hoverMode","activeMode"],"mappings":";AAAA,SAASA,YAAY,EAAEC,aAAa,QAAQ,mBAAmB;AAC/D,SAASC,+BAA+B,QAAQ,8CAA8C;AAC9F,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,kBAAkB,QAAQ,2CAA2C;AAC9E,SAASC,QAAQ,QAAuB,uBAAuB;AAC/D,SAASC,cAAc,QAAQ,mCAAmC;AAClE,OAAOC,YAAY,6BAA6B;AAQhD,OAAO,SAASC,yBAAyB,EACvCC,WAAW,SAAS,EACpBC,MAAM,EACNC,IAAI,EACJC,OAAO,EACuB;IAC9B,MAAMC,WAAWV;IACjB,MAAM,EAAEW,SAAS,EAAE,GAAGZ;IAEtB,IAAIY,aAAaH,SAAS,WAAW;QACnC,qBACE,KAACP;YAAmBW,eAAaL;YAAQM,SAASJ;sBAC/CH;;IAGP;IAEA,IAAIE,SAAS,YAAaE,aAAa,SAAS,CAACC,WAAY;QAC3D,qBACE,MAACT;YACCY,WAAWV,MAAM,CAAC,yBAAyB;YAC3CS,SAASJ;YACTM,WAAU;YACVC,YAAW;YACXJ,eAAaL;;8BAEb,KAACJ;8BAAgBG;;gBAChBI,aAAa,sBAAQ,KAACZ,mCAAmB,KAACD;;;IAGjD;IAEA,OAAO;AACT"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalDismissButton/ModalDismissButton.tsx"],"sourcesContent":["import { Icon20Cancel } from '@vkontakte/icons';\nimport { classNames } from '@vkontakte/vkjs';\nimport { Tappable, type TappableProps } from '../Tappable/Tappable';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport styles from './ModalDismissButton.module.css';\n\nexport type ModalDismissButtonProps = Omit<TappableProps, 'mode' | 'onClose'>;\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalDismissButton\n */\nexport const ModalDismissButton = ({\n children = 'Закрыть',\n className,\n ...restProps\n}: ModalDismissButtonProps) => {\n return (\n <Tappable\n className={classNames(styles['ModalDismissButton'], className)}\n {...restProps}\n activeMode={styles['ModalDismissButton--active']}\n hoverMode={styles['ModalDismissButton--hover']}\n >\n {children && <VisuallyHidden>{children}</VisuallyHidden>}\n <Icon20Cancel />\n </Tappable>\n );\n};\n"],"names":["Icon20Cancel","classNames","Tappable","VisuallyHidden","styles","ModalDismissButton","children","className","restProps","activeMode","hoverMode"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;","mappings":";AAAA,SAASA,YAAY,QAAQ,mBAAmB;AAChD,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,QAAQ,QAA4B,uBAAuB;AACpE,SAASC,cAAc,QAAQ,mCAAmC;AAClE,OAAOC,YAAY,kCAAkC;AAIrD;;CAEC,GACD,OAAO,MAAMC,qBAAqB,CAAC,EACjCC,WAAW,SAAS,EACpBC,SAAS,EACT,GAAGC,WACqB;IACxB,qBACE,MAACN;QACCK,WAAWN,WAAWG,MAAM,CAAC,qBAAqB,EAAEG;QACnD,GAAGC,SAAS;QACbC,YAAYL,MAAM,CAAC,6BAA6B;QAChDM,WAAWN,MAAM,CAAC,4BAA4B;;YAE7CE,0BAAY,KAACH;0BAAgBG;;0BAC9B,KAACN;;;AAGP,EAAE"}
1
+ {"version":3,"sources":["../../../../src/components/ModalDismissButton/ModalDismissButton.tsx"],"sourcesContent":["import { Icon20Cancel } from '@vkontakte/icons';\nimport { classNames } from '@vkontakte/vkjs';\nimport { Tappable, type TappableProps } from '../Tappable/Tappable';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport styles from './ModalDismissButton.module.css';\n\nexport type ModalDismissButtonProps = Omit<TappableProps, 'mode' | 'onClose'>;\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalDismissButton\n */\nexport const ModalDismissButton = ({\n children = 'Закрыть',\n className,\n ...restProps\n}: ModalDismissButtonProps) => {\n return (\n <Tappable\n className={classNames(styles['ModalDismissButton'], className)}\n {...restProps}\n activeMode={styles['ModalDismissButton--active']}\n hoverMode={styles['ModalDismissButton--hover']}\n >\n {children && <VisuallyHidden>{children}</VisuallyHidden>}\n <Icon20Cancel />\n </Tappable>\n );\n};\n"],"names":["Icon20Cancel","classNames","Tappable","VisuallyHidden","styles","ModalDismissButton","children","className","restProps","activeMode","hoverMode"],"mappings":";AAAA,SAASA,YAAY,QAAQ,mBAAmB;AAChD,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,QAAQ,QAA4B,uBAAuB;AACpE,SAASC,cAAc,QAAQ,mCAAmC;AAClE,OAAOC,YAAY,kCAAkC;AAIrD;;CAEC,GACD,OAAO,MAAMC,qBAAqB,CAAC,EACjCC,WAAW,SAAS,EACpBC,SAAS,EACT,GAAGC,WACqB;IACxB,qBACE,MAACN;QACCK,WAAWN,WAAWG,MAAM,CAAC,qBAAqB,EAAEG;QACnD,GAAGC,SAAS;QACbC,YAAYL,MAAM,CAAC,6BAA6B;QAChDM,WAAWN,MAAM,CAAC,4BAA4B;;YAE7CE,0BAAY,KAACH;0BAAgBG;;0BAC9B,KAACN;;;AAGP,EAAE"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalPage/ModalPage.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivityWithJSMediaQueries } from '../../hooks/useAdaptivityWithJSMediaQueries';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useOrientationChange } from '../../hooks/useOrientationChange';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { getNavId, NavIdProps } from '../../lib/getNavId';\nimport { multiRef } from '../../lib/utils';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { HTMLAttributesWithRootRef } from '../../types';\nimport { ModalDismissButton } from '../ModalDismissButton/ModalDismissButton';\nimport { ModalRootContext, useModalRegistry } from '../ModalRoot/ModalRootContext';\nimport { RootComponent } from '../RootComponent/RootComponent';\nimport { ModalPageContext } from './ModalPageContext';\nimport styles from './ModalPage.module.css';\n\nconst sizeClassName = {\n s: styles['ModalPage--size-s'],\n m: styles['ModalPage--size-m'],\n l: styles['ModalPage--size-l'],\n};\n\nexport interface ModalPageProps extends HTMLAttributesWithRootRef<HTMLDivElement>, NavIdProps {\n /**\n * Шапка модальной страницы, `<ModalPageHeader />`\n */\n header?: React.ReactNode;\n /**\n * Задаёт контенту максимальную ширину для десктопной версии.\n */\n size?: 's' | 'm' | 'l' | number;\n /**\n * Задаёт модальному окну фиксированную высоту.\n * Можно передать числовое значение в пикселях, а можно строкой, в том числе и в процентах \"50%\".\n * В мобильной версии 'settlingHeight' будет считаться относительно заданного height.\n */\n height?: string | number;\n /**\n * Будет вызвано при начале открытия модалки.\n */\n onOpen?: VoidFunction;\n /**\n * Будет вызвано при окончательном открытии модалки.\n */\n onOpened?: VoidFunction;\n /**\n * Будет вызвано при начале закрытия модалки.\n */\n onClose?: VoidFunction;\n /**\n * Будет вызвано при окончательном закрытии модалки.\n */\n onClosed?: VoidFunction;\n /**\n * Процент, на который изначально будет открыта модальная страница. При `settlingHeight={100}` модальная страница раскрывается на всю высоту.\n */\n settlingHeight?: number;\n /**\n * Если высота контента в модальной странице может поменяться, нужно установить это свойство\n */\n dynamicContentHeight?: boolean;\n getModalContentRef?: React.Ref<HTMLDivElement>;\n /**\n * Скрывает кнопку закрытия (актуально для iOS, т.к. можно отрисовать кнопку закрытия внутри модалки)\n */\n hideCloseButton?: boolean;\n modalContentTestId?: string;\n /**\n * `data-testid` для кнопки закрытия\n */\n modalDismissButtonTestId?: string;\n /**\n * Позволяет отключить возможность закрытия модальной страницы (смахивание, клавиша `ESC`, клик по подложке)\n *\n * ⚠️ ВНИМАНИЕ: использование этой опции негативно сказывается на пользовательском опыте\n */\n preventClose?: boolean;\n}\n\nconst warn = warnOnce('ModalPage');\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalPage\n */\nexport const ModalPage = ({\n children,\n header,\n size: sizeProp = 's',\n onOpen,\n onOpened,\n onClose,\n onClosed,\n settlingHeight, // 75\n dynamicContentHeight,\n getModalContentRef,\n nav,\n id: idProp,\n hideCloseButton = false,\n height,\n modalContentTestId,\n modalDismissButtonTestId,\n getRootRef,\n preventClose,\n ...restProps\n}: ModalPageProps) => {\n const generatingId = React.useId();\n const id = idProp || generatingId;\n\n const { updateModalHeight } = React.useContext(ModalRootContext);\n\n const platform = usePlatform();\n const orientation = useOrientationChange();\n const { sizeX, isDesktop } = useAdaptivityWithJSMediaQueries();\n\n React.useEffect(() => {\n if (dynamicContentHeight) {\n updateModalHeight();\n }\n }, [children, dynamicContentHeight, orientation, updateModalHeight]);\n\n const isCloseButtonShown = !hideCloseButton && isDesktop;\n const size = isDesktop ? sizeProp : 's';\n\n const modalContext = React.useContext(ModalRootContext);\n const { refs } = useModalRegistry(getNavId({ nav, id }, warn), 'page');\n const rootRef = useExternRef(getRootRef, refs.modalElement);\n\n const contextValue = React.useMemo(() => ({ labelId: `${id}-label` }), [id]);\n\n return (\n <ModalPageContext.Provider value={contextValue}>\n <RootComponent\n {...restProps}\n getRootRef={rootRef}\n tabIndex={-1}\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby={contextValue.labelId}\n id={id}\n baseClassName={classNames(\n styles['ModalPage'],\n platform === 'ios' && styles['ModalPage--ios'],\n isDesktop && styles['ModalPage--desktop'],\n sizeX === 'regular' && 'vkuiInternalModalPage--sizeX-regular',\n typeof size === 'string' && sizeClassName[size],\n )}\n >\n <div\n className={styles['ModalPage__in-wrap']}\n style={{\n maxWidth: typeof size === 'number' ? size : undefined,\n height,\n }}\n ref={refs.innerElement}\n >\n <div className={styles['ModalPage__in']}>\n <div className={styles['ModalPage__header']} ref={refs.headerElement}>\n {header}\n </div>\n\n <div className={styles['ModalPage__content-wrap']}>\n <div\n className={styles['ModalPage__content']}\n ref={multiRef<HTMLDivElement>(refs.contentElement, getModalContentRef)}\n {...(modalContentTestId && { 'data-testid': modalContentTestId })}\n >\n <div className={styles['ModalPage__content-in']}>{children}</div>\n </div>\n <div ref={refs.bottomInset} className={styles['ModalPage__bottom-inset']} />\n </div>\n {isCloseButtonShown && (\n <ModalDismissButton\n data-testid={modalDismissButtonTestId}\n onClick={onClose || modalContext.onClose}\n />\n )}\n </div>\n </div>\n </RootComponent>\n </ModalPageContext.Provider>\n );\n};\n"],"names":["React","classNames","useAdaptivityWithJSMediaQueries","useExternRef","useOrientationChange","usePlatform","getNavId","multiRef","warnOnce","ModalDismissButton","ModalRootContext","useModalRegistry","RootComponent","ModalPageContext","styles","sizeClassName","s","m","l","warn","ModalPage","children","header","size","sizeProp","onOpen","onOpened","onClose","onClosed","settlingHeight","dynamicContentHeight","getModalContentRef","nav","id","idProp","hideCloseButton","height","modalContentTestId","modalDismissButtonTestId","getRootRef","preventClose","restProps","generatingId","useId","updateModalHeight","useContext","platform","orientation","sizeX","isDesktop","useEffect","isCloseButtonShown","modalContext","refs","rootRef","modalElement","contextValue","useMemo","labelId","Provider","value","tabIndex","role","aria-modal","aria-labelledby","baseClassName","div","className","style","maxWidth","undefined","ref","innerElement","headerElement","contentElement","bottomInset","data-testid","onClick"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/components/ModalPage/ModalPage.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivityWithJSMediaQueries } from '../../hooks/useAdaptivityWithJSMediaQueries';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useOrientationChange } from '../../hooks/useOrientationChange';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { getNavId, NavIdProps } from '../../lib/getNavId';\nimport { multiRef } from '../../lib/utils';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { HTMLAttributesWithRootRef } from '../../types';\nimport { ModalDismissButton } from '../ModalDismissButton/ModalDismissButton';\nimport { ModalRootContext, useModalRegistry } from '../ModalRoot/ModalRootContext';\nimport { RootComponent } from '../RootComponent/RootComponent';\nimport { ModalPageContext } from './ModalPageContext';\nimport styles from './ModalPage.module.css';\n\nconst sizeClassName = {\n s: styles['ModalPage--size-s'],\n m: styles['ModalPage--size-m'],\n l: styles['ModalPage--size-l'],\n};\n\nexport interface ModalPageProps extends HTMLAttributesWithRootRef<HTMLDivElement>, NavIdProps {\n /**\n * Шапка модальной страницы, `<ModalPageHeader />`\n */\n header?: React.ReactNode;\n /**\n * Задаёт контенту максимальную ширину для десктопной версии.\n */\n size?: 's' | 'm' | 'l' | number;\n /**\n * Задаёт модальному окну фиксированную высоту.\n * Можно передать числовое значение в пикселях, а можно строкой, в том числе и в процентах \"50%\".\n * В мобильной версии 'settlingHeight' будет считаться относительно заданного height.\n */\n height?: string | number;\n /**\n * Будет вызвано при начале открытия модалки.\n */\n onOpen?: VoidFunction;\n /**\n * Будет вызвано при окончательном открытии модалки.\n */\n onOpened?: VoidFunction;\n /**\n * Будет вызвано при начале закрытия модалки.\n */\n onClose?: VoidFunction;\n /**\n * Будет вызвано при окончательном закрытии модалки.\n */\n onClosed?: VoidFunction;\n /**\n * Процент, на который изначально будет открыта модальная страница. При `settlingHeight={100}` модальная страница раскрывается на всю высоту.\n */\n settlingHeight?: number;\n /**\n * Если высота контента в модальной странице может поменяться, нужно установить это свойство\n */\n dynamicContentHeight?: boolean;\n getModalContentRef?: React.Ref<HTMLDivElement>;\n /**\n * Скрывает кнопку закрытия (актуально для iOS, т.к. можно отрисовать кнопку закрытия внутри модалки)\n */\n hideCloseButton?: boolean;\n modalContentTestId?: string;\n /**\n * `data-testid` для кнопки закрытия\n */\n modalDismissButtonTestId?: string;\n /**\n * Позволяет отключить возможность закрытия модальной страницы (смахивание, клавиша `ESC`, клик по подложке)\n *\n * ⚠️ ВНИМАНИЕ: использование этой опции негативно сказывается на пользовательском опыте\n */\n preventClose?: boolean;\n}\n\nconst warn = warnOnce('ModalPage');\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalPage\n */\nexport const ModalPage = ({\n children,\n header,\n size: sizeProp = 's',\n onOpen,\n onOpened,\n onClose,\n onClosed,\n settlingHeight, // 75\n dynamicContentHeight,\n getModalContentRef,\n nav,\n id: idProp,\n hideCloseButton = false,\n height,\n modalContentTestId,\n modalDismissButtonTestId,\n getRootRef,\n preventClose,\n ...restProps\n}: ModalPageProps) => {\n const generatingId = React.useId();\n const id = idProp || generatingId;\n\n const { updateModalHeight } = React.useContext(ModalRootContext);\n\n const platform = usePlatform();\n const orientation = useOrientationChange();\n const { sizeX, isDesktop } = useAdaptivityWithJSMediaQueries();\n\n React.useEffect(() => {\n if (dynamicContentHeight) {\n updateModalHeight();\n }\n }, [children, dynamicContentHeight, orientation, updateModalHeight]);\n\n const isCloseButtonShown = !hideCloseButton && isDesktop;\n const size = isDesktop ? sizeProp : 's';\n\n const modalContext = React.useContext(ModalRootContext);\n const { refs } = useModalRegistry(getNavId({ nav, id }, warn), 'page');\n const rootRef = useExternRef(getRootRef, refs.modalElement);\n\n const contextValue = React.useMemo(() => ({ labelId: `${id}-label` }), [id]);\n\n return (\n <ModalPageContext.Provider value={contextValue}>\n <RootComponent\n {...restProps}\n getRootRef={rootRef}\n tabIndex={-1}\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby={contextValue.labelId}\n id={id}\n baseClassName={classNames(\n styles['ModalPage'],\n platform === 'ios' && styles['ModalPage--ios'],\n isDesktop && styles['ModalPage--desktop'],\n sizeX === 'regular' && 'vkuiInternalModalPage--sizeX-regular',\n typeof size === 'string' && sizeClassName[size],\n )}\n >\n <div\n className={styles['ModalPage__in-wrap']}\n style={{\n maxWidth: typeof size === 'number' ? size : undefined,\n height,\n }}\n ref={refs.innerElement}\n >\n <div className={styles['ModalPage__in']}>\n <div className={styles['ModalPage__header']} ref={refs.headerElement}>\n {header}\n </div>\n\n <div className={styles['ModalPage__content-wrap']}>\n <div\n className={styles['ModalPage__content']}\n ref={multiRef<HTMLDivElement>(refs.contentElement, getModalContentRef)}\n {...(modalContentTestId && { 'data-testid': modalContentTestId })}\n >\n <div className={styles['ModalPage__content-in']}>{children}</div>\n </div>\n <div ref={refs.bottomInset} className={styles['ModalPage__bottom-inset']} />\n </div>\n {isCloseButtonShown && (\n <ModalDismissButton\n data-testid={modalDismissButtonTestId}\n onClick={onClose || modalContext.onClose}\n />\n )}\n </div>\n </div>\n </RootComponent>\n </ModalPageContext.Provider>\n );\n};\n"],"names":["React","classNames","useAdaptivityWithJSMediaQueries","useExternRef","useOrientationChange","usePlatform","getNavId","multiRef","warnOnce","ModalDismissButton","ModalRootContext","useModalRegistry","RootComponent","ModalPageContext","styles","sizeClassName","s","m","l","warn","ModalPage","children","header","size","sizeProp","onOpen","onOpened","onClose","onClosed","settlingHeight","dynamicContentHeight","getModalContentRef","nav","id","idProp","hideCloseButton","height","modalContentTestId","modalDismissButtonTestId","getRootRef","preventClose","restProps","generatingId","useId","updateModalHeight","useContext","platform","orientation","sizeX","isDesktop","useEffect","isCloseButtonShown","modalContext","refs","rootRef","modalElement","contextValue","useMemo","labelId","Provider","value","tabIndex","role","aria-modal","aria-labelledby","baseClassName","div","className","style","maxWidth","undefined","ref","innerElement","headerElement","contentElement","bottomInset","data-testid","onClick"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalPage/ModalPageContext.tsx"],"sourcesContent":["import * as React from 'react';\n\nexport interface ModalPageContextInterface {\n labelId?: string;\n}\n\nexport const ModalPageContext = React.createContext<ModalPageContextInterface>({});\n"],"names":["React","ModalPageContext","createContext"],"rangeMappings":";","mappings":"AAAA,YAAYA,WAAW,QAAQ;AAM/B,OAAO,MAAMC,iCAAmBD,MAAME,aAAa,CAA4B,CAAC,GAAG"}
1
+ {"version":3,"sources":["../../../../src/components/ModalPage/ModalPageContext.tsx"],"sourcesContent":["import * as React from 'react';\n\nexport interface ModalPageContextInterface {\n labelId?: string;\n}\n\nexport const ModalPageContext = React.createContext<ModalPageContextInterface>({});\n"],"names":["React","ModalPageContext","createContext"],"mappings":"AAAA,YAAYA,WAAW,QAAQ;AAM/B,OAAO,MAAMC,iCAAmBD,MAAME,aAAa,CAA4B,CAAC,GAAG"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalPageHeader/ModalPageHeader.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivityWithJSMediaQueries } from '../../hooks/useAdaptivityWithJSMediaQueries';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { HasRef, HasRootRef } from '../../types';\nimport { ModalPageContext } from '../ModalPage/ModalPageContext';\nimport { PanelHeader, PanelHeaderProps } from '../PanelHeader/PanelHeader';\nimport { Separator } from '../Separator/Separator';\nimport styles from './ModalPageHeader.module.css';\n\nexport interface ModalPageHeaderProps\n extends React.HTMLAttributes<HTMLDivElement>,\n Omit<PanelHeaderProps, 'fixed' | 'shadow' | 'delimiter'>,\n HasRef<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n noSeparator?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalPageHeader\n */\nexport const ModalPageHeader = ({\n children,\n noSeparator = false,\n getRootRef,\n className,\n typographyProps,\n ...restProps\n}: ModalPageHeaderProps) => {\n const platform = usePlatform();\n const { isDesktop, sizeX } = useAdaptivityWithJSMediaQueries();\n const { labelId } = React.useContext(ModalPageContext);\n\n return (\n <div\n className={classNames(\n styles['ModalPageHeader'],\n platform !== 'vkcom' && styles['ModalPageHeader--withGaps'],\n isDesktop && styles['ModalPageHeader--desktop'],\n )}\n ref={getRootRef}\n >\n <PanelHeader\n className={classNames('vkuiInternalModalPageHeader__in', className)}\n typographyProps={{\n Component: 'h2',\n id: labelId,\n ...typographyProps,\n }}\n {...restProps}\n fixed={false}\n delimiter=\"none\"\n transparent\n >\n {children}\n </PanelHeader>\n {!noSeparator && <Separator wide={sizeX === 'regular'} />}\n </div>\n );\n};\n"],"names":["React","classNames","useAdaptivityWithJSMediaQueries","usePlatform","ModalPageContext","PanelHeader","Separator","styles","ModalPageHeader","children","noSeparator","getRootRef","className","typographyProps","restProps","platform","isDesktop","sizeX","labelId","useContext","div","ref","Component","id","fixed","delimiter","transparent","wide"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,+BAA+B,QAAQ,8CAA8C;AAC9F,SAASC,WAAW,QAAQ,0BAA0B;AAEtD,SAASC,gBAAgB,QAAQ,gCAAgC;AACjE,SAASC,WAAW,QAA0B,6BAA6B;AAC3E,SAASC,SAAS,QAAQ,yBAAyB;AACnD,OAAOC,YAAY,+BAA+B;AAUlD;;CAEC,GACD,OAAO,MAAMC,kBAAkB,CAAC,EAC9BC,QAAQ,EACRC,cAAc,KAAK,EACnBC,UAAU,EACVC,SAAS,EACTC,eAAe,EACf,GAAGC,WACkB;IACrB,MAAMC,WAAWZ;IACjB,MAAM,EAAEa,SAAS,EAAEC,KAAK,EAAE,GAAGf;IAC7B,MAAM,EAAEgB,OAAO,EAAE,GAAGlB,MAAMmB,UAAU,CAACf;IAErC,qBACE,MAACgB;QACCR,WAAWX,WACTM,MAAM,CAAC,kBAAkB,EACzBQ,aAAa,WAAWR,MAAM,CAAC,4BAA4B,EAC3DS,aAAaT,MAAM,CAAC,2BAA2B;QAEjDc,KAAKV;;0BAEL,KAACN;gBACCO,WAAWX,WAAW,mCAAmCW;gBACzDC,iBAAiB;oBACfS,WAAW;oBACXC,IAAIL;oBACJ,GAAGL,eAAe;gBACpB;gBACC,GAAGC,SAAS;gBACbU,OAAO;gBACPC,WAAU;gBACVC,WAAW;0BAEVjB;;YAEF,CAACC,6BAAe,KAACJ;gBAAUqB,MAAMV,UAAU;;;;AAGlD,EAAE"}
1
+ {"version":3,"sources":["../../../../src/components/ModalPageHeader/ModalPageHeader.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivityWithJSMediaQueries } from '../../hooks/useAdaptivityWithJSMediaQueries';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { HasRef, HasRootRef } from '../../types';\nimport { ModalPageContext } from '../ModalPage/ModalPageContext';\nimport { PanelHeader, PanelHeaderProps } from '../PanelHeader/PanelHeader';\nimport { Separator } from '../Separator/Separator';\nimport styles from './ModalPageHeader.module.css';\n\nexport interface ModalPageHeaderProps\n extends React.HTMLAttributes<HTMLDivElement>,\n Omit<PanelHeaderProps, 'fixed' | 'shadow' | 'delimiter'>,\n HasRef<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n noSeparator?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalPageHeader\n */\nexport const ModalPageHeader = ({\n children,\n noSeparator = false,\n getRootRef,\n className,\n typographyProps,\n ...restProps\n}: ModalPageHeaderProps) => {\n const platform = usePlatform();\n const { isDesktop, sizeX } = useAdaptivityWithJSMediaQueries();\n const { labelId } = React.useContext(ModalPageContext);\n\n return (\n <div\n className={classNames(\n styles['ModalPageHeader'],\n platform !== 'vkcom' && styles['ModalPageHeader--withGaps'],\n isDesktop && styles['ModalPageHeader--desktop'],\n )}\n ref={getRootRef}\n >\n <PanelHeader\n className={classNames('vkuiInternalModalPageHeader__in', className)}\n typographyProps={{\n Component: 'h2',\n id: labelId,\n ...typographyProps,\n }}\n {...restProps}\n fixed={false}\n delimiter=\"none\"\n transparent\n >\n {children}\n </PanelHeader>\n {!noSeparator && <Separator wide={sizeX === 'regular'} />}\n </div>\n );\n};\n"],"names":["React","classNames","useAdaptivityWithJSMediaQueries","usePlatform","ModalPageContext","PanelHeader","Separator","styles","ModalPageHeader","children","noSeparator","getRootRef","className","typographyProps","restProps","platform","isDesktop","sizeX","labelId","useContext","div","ref","Component","id","fixed","delimiter","transparent","wide"],"mappings":";AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,+BAA+B,QAAQ,8CAA8C;AAC9F,SAASC,WAAW,QAAQ,0BAA0B;AAEtD,SAASC,gBAAgB,QAAQ,gCAAgC;AACjE,SAASC,WAAW,QAA0B,6BAA6B;AAC3E,SAASC,SAAS,QAAQ,yBAAyB;AACnD,OAAOC,YAAY,+BAA+B;AAUlD;;CAEC,GACD,OAAO,MAAMC,kBAAkB,CAAC,EAC9BC,QAAQ,EACRC,cAAc,KAAK,EACnBC,UAAU,EACVC,SAAS,EACTC,eAAe,EACf,GAAGC,WACkB;IACrB,MAAMC,WAAWZ;IACjB,MAAM,EAAEa,SAAS,EAAEC,KAAK,EAAE,GAAGf;IAC7B,MAAM,EAAEgB,OAAO,EAAE,GAAGlB,MAAMmB,UAAU,CAACf;IAErC,qBACE,MAACgB;QACCR,WAAWX,WACTM,MAAM,CAAC,kBAAkB,EACzBQ,aAAa,WAAWR,MAAM,CAAC,4BAA4B,EAC3DS,aAAaT,MAAM,CAAC,2BAA2B;QAEjDc,KAAKV;;0BAEL,KAACN;gBACCO,WAAWX,WAAW,mCAAmCW;gBACzDC,iBAAiB;oBACfS,WAAW;oBACXC,IAAIL;oBACJ,GAAGL,eAAe;gBACpB;gBACC,GAAGC,SAAS;gBACbU,OAAO;gBACPC,WAAU;gBACVC,WAAW;0BAEVjB;;YAEF,CAACC,6BAAe,KAACJ;gBAAUqB,MAAMV,UAAU;;;;AAGlD,EAAE"}
@@ -1 +1 @@
1
- {"version":3,"file":"ModalRoot.d.ts","sourceRoot":"","sources":["../../../../src/components/ModalRoot/ModalRoot.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAiB/B,OAAO,EAAE,qBAAqB,EAAoC,MAAM,SAAS,CAAC;AA6mBlF,eAAO,MAAM,cAAc,mDAM1B,CAAC"}
1
+ {"version":3,"file":"ModalRoot.d.ts","sourceRoot":"","sources":["../../../../src/components/ModalRoot/ModalRoot.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAgB/B,OAAO,EAAE,qBAAqB,EAAoC,MAAM,SAAS,CAAC;AA0mBlF,eAAO,MAAM,cAAc,mDAM1B,CAAC"}
@@ -7,7 +7,6 @@ import { withPlatform } from '../../hoc/withPlatform';
7
7
  import { withDOM } from '../../lib/dom';
8
8
  import { getNavId } from '../../lib/getNavId';
9
9
  import { setTransformStyle } from '../../lib/styles';
10
- import { transitionEvent } from '../../lib/supportEvents';
11
10
  import { rubber } from '../../lib/touch';
12
11
  import { warnOnce } from '../../lib/warnOnce';
13
12
  import { ConfigProviderContext } from '../ConfigProvider/ConfigProviderContext';
@@ -410,12 +409,11 @@ class ModalRootTouchComponent extends React.Component {
410
409
  }
411
410
  };
412
411
  waitTransitionFinish(modalState, eventHandler) {
413
- if (transitionEvent.supported) {
414
- const onceHandler = ()=>{
415
- modalState?.innerElement?.removeEventListener(transitionEvent.name, onceHandler);
416
- eventHandler();
417
- };
418
- modalState?.innerElement?.addEventListener(transitionEvent.name, onceHandler);
412
+ const el = modalState ? modalState.innerElement : null;
413
+ if (el) {
414
+ el.addEventListener('transitionend', eventHandler, {
415
+ once: true
416
+ });
419
417
  } else {
420
418
  setTimeout(eventHandler, this.timeout);
421
419
  }
@@ -488,6 +486,7 @@ class ModalRootTouchComponent extends React.Component {
488
486
  onClose: this.props.onExit,
489
487
  timeout: this.timeout,
490
488
  className: classNames(styles['ModalRoot__modal'], dragging && 'vkuiInternalModalRoot__modal--dragging', isPage && modalState.expandable && 'vkuiInternalModalRoot__modal--expandable', isPage && modalState.collapsed && 'vkuiInternalModalRoot__modal--collapsed'),
489
+ autoFocus: false,
491
490
  restoreFocus: false,
492
491
  children: Modal
493
492
  }, key);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRoot.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { clamp } from '../../helpers/math';\nimport { withContext } from '../../hoc/withContext';\nimport { withPlatform } from '../../hoc/withPlatform';\nimport { DOMProps, withDOM } from '../../lib/dom';\nimport { getNavId } from '../../lib/getNavId';\nimport { setTransformStyle } from '../../lib/styles';\nimport { transitionEvent } from '../../lib/supportEvents';\nimport { rubber } from '../../lib/touch';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { ConfigProviderContext } from '../ConfigProvider/ConfigProviderContext';\nimport { FocusTrap } from '../FocusTrap/FocusTrap';\nimport { Touch, TouchEvent } from '../Touch/Touch';\nimport TouchRootContext from '../Touch/TouchContext';\nimport { ModalRootContext, ModalRootContextInterface } from './ModalRootContext';\nimport { MODAL_PAGE_DEFAULT_PERCENT_HEIGHT } from './constants';\nimport { ModalRootWithDOMProps, ModalsStateEntry, TranslateRange } from './types';\nimport { ModalTransitionProps, withModalManager } from './useModalManager';\nimport styles from './ModalRoot.module.css';\n\nconst warn = warnOnce('ModalRoot');\n\nfunction numberInRange(number: number, range: TranslateRange | undefined) {\n if (!range) {\n return false;\n }\n return number >= range[0] && number <= range[1];\n}\n\nfunction rangeTranslate(number: number) {\n return clamp(number, 0, 98);\n}\n\ninterface ModalRootState {\n touchDown?: boolean;\n dragging?: boolean;\n modalOpenedLog: string[];\n}\n\nclass ModalRootTouchComponent extends React.Component<\n ModalRootWithDOMProps & DOMProps & ModalTransitionProps,\n ModalRootState\n> {\n constructor(props: ModalRootWithDOMProps & ModalTransitionProps) {\n super(props);\n this.state = {\n touchDown: false,\n dragging: false,\n modalOpenedLog: [],\n };\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: this.updateModalHeight,\n registerModal: ({ id, ...data }) => Object.assign(this.props.getModalState(id) ?? {}, data),\n onClose: () => this.props.onExit(),\n isInsideModal: true,\n };\n\n this.frameIds = {};\n }\n\n private documentScrolling = false;\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private readonly viewportRef = React.createRef<HTMLDivElement>();\n private maskAnimationFrame: number | undefined = undefined;\n private readonly modalRootContext: ModalRootContextInterface;\n private readonly frameIds: {\n [index: string]: number;\n };\n private restoreFocusTo: HTMLElement | undefined | null = undefined;\n\n get timeout(): number {\n return this.props.platform === 'ios' ? 400 : 320;\n }\n\n get document(): Document {\n return this.props.document as Document;\n }\n\n get window(): Window {\n return this.props.window as Window;\n }\n\n getModals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n componentDidMount() {\n // Отслеживаем изменение размеров viewport\n this.window?.addEventListener('resize', this.updateModalHeight, false);\n }\n\n componentWillUnmount() {\n this.toggleDocumentScrolling(true);\n this.window.removeEventListener('resize', this.updateModalHeight, false);\n }\n\n componentDidUpdate(prevProps: ModalRootWithDOMProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (this.props.exitingModal && this.props.exitingModal !== prevProps.exitingModal) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (this.props.enteringModal && this.props.enteringModal !== prevProps.enteringModal) {\n const enteringState = this.props.getModalState(this.props.enteringModal);\n this.props.onEnter();\n this.waitTransitionFinish(enteringState, () => {\n if (enteringState) {\n if (enteringState.innerElement) {\n enteringState.innerElement.style.transitionDelay = '';\n }\n this.onEntered(enteringState);\n }\n });\n\n if (enteringState?.innerElement) {\n enteringState.innerElement.style.transitionDelay = this.props.delayEnter\n ? `${this.timeout}ms`\n : '';\n this.animateTranslate(enteringState, enteringState.translateY);\n this.setMaskOpacity(enteringState, 1);\n }\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = this.document.activeElement as HTMLElement;\n }\n if (!this.props.activeModal && !this.props.exitingModal && this.restoreFocusTo) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = null;\n }\n\n this.toggleDocumentScrolling(!this.props.activeModal && !this.props.exitingModal);\n }\n\n /* Отключает скролл документа */\n toggleDocumentScrolling(enabled: boolean) {\n if (this.documentScrolling === enabled) {\n return;\n }\n this.documentScrolling = enabled;\n\n if (enabled) {\n // восстанавливаем значение overscroll behavior\n // eslint-disable-next-line no-restricted-properties\n this.document.documentElement.classList.remove('vkui--disable-overscroll-behavior');\n\n // некоторые браузеры на странных вендорах типа Meizu не удаляют обработчик.\n // https://github.com/VKCOM/VKUI/issues/444\n this.window.removeEventListener('touchmove', this.preventTouch, {\n // @ts-expect-error: TS2769 В интерфейсе EventListenerOptions нет поля passive\n passive: false,\n });\n } else {\n // отключаем нативный pull-to-refresh при открытом модальном окне\n // чтобы он не срабатывал при закрытии модалки смахиванием вниз\n // eslint-disable-next-line no-restricted-properties\n this.document.documentElement.classList.add('vkui--disable-overscroll-behavior');\n\n this.window.addEventListener('touchmove', this.preventTouch, {\n passive: false,\n });\n }\n }\n\n preventTouch = (event: any) => {\n if (!event) {\n return false;\n }\n while (event.originalEvent) {\n event = event.originalEvent;\n }\n if (event.preventDefault) {\n event.preventDefault();\n }\n return false;\n };\n\n checkPageContentHeight() {\n const modalState = this.props.getModalState(this.props.activeModal);\n\n if (modalState?.type === 'page' && modalState?.modalElement) {\n const prevModalState = { ...modalState };\n initPageModal(modalState);\n const currentModalState = { ...modalState };\n\n let needAnimate = false;\n\n if (prevModalState.expandable === currentModalState.expandable) {\n if (prevModalState.translateYFrom !== currentModalState.translateYFrom) {\n needAnimate = true;\n }\n } else {\n needAnimate = true;\n }\n\n if (needAnimate) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n }\n }\n\n updateModalHeight = () => {\n const modalState = this.props.getModalState(this.props.activeModal);\n\n if (modalState && modalState.type === 'page') {\n if (this.props.enteringModal) {\n this.waitTransitionFinish(modalState, () => {\n requestAnimationFrame(() => this.checkPageContentHeight());\n });\n } else {\n requestAnimationFrame(() => this.checkPageContentHeight());\n }\n }\n };\n\n onEntered({ id, modalElement }: ModalsStateEntry) {\n if (\n !this.props.noFocusToDialog &&\n modalElement &&\n !modalElement.contains(this.document.activeElement)\n ) {\n modalElement.focus();\n }\n\n this.props.onEntered(id);\n }\n\n closeModal(id: string) {\n // Сбрасываем состояния, которые могут помешать закрытию модального окна\n this.setState({ touchDown: false });\n\n const prevModalState = this.props.getModalState(id);\n\n if (!prevModalState) {\n id && warn(`closeActiveModal: модальное окно (страница) ${id} не существует`, 'error');\n return;\n }\n if (!this.state.modalOpenedLog.length) {\n this.setState((prevState) => ({\n modalOpenedLog: [...prevState.modalOpenedLog, id],\n }));\n }\n const nextModalState = this.props.getModalState(this.props.activeModal);\n const nextIsPage = !!nextModalState && nextModalState.type === 'page';\n\n const prevIsPage = !!prevModalState && prevModalState.type === 'page';\n this.waitTransitionFinish(prevModalState, () => this.props.onExited(id));\n const exitTranslate =\n prevIsPage &&\n nextIsPage &&\n (prevModalState.translateY ?? 0) <= (nextModalState?.translateYFrom ?? 0) &&\n !this.props.isBack\n ? (nextModalState?.translateYFrom ?? 0) + 10\n : 100;\n this.animateTranslate(prevModalState, exitTranslate);\n\n if (!nextModalState) {\n // NOTE: was only for clean exit\n this.setMaskOpacity(prevModalState, 0);\n this.setState({ modalOpenedLog: [] });\n prevModalState.translateY = undefined;\n prevModalState.expandable = undefined;\n } else if (nextModalState.id && !this.state.modalOpenedLog.includes(nextModalState.id)) {\n nextModalState.translateY = undefined;\n this.setState((prevState) => ({\n modalOpenedLog: [...prevState.modalOpenedLog, nextModalState.id!],\n }));\n }\n }\n\n onTouchMove = (e: TouchEvent) => {\n if (this.props.exitingModal) {\n return;\n }\n const modalState = this.props.getModalState(this.props.activeModal);\n if (!modalState) {\n return;\n }\n\n if (modalState.type === 'page') {\n return this.onPageTouchMove(e, modalState);\n }\n\n if (modalState.type === 'card') {\n return this.onCardTouchMove(e, modalState);\n }\n };\n\n onPageTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { shiftY, originalEvent } = event;\n const target = originalEvent.target as HTMLElement;\n\n if (!event.isY) {\n if (this.viewportRef.current?.contains(target)) {\n originalEvent.preventDefault();\n }\n return;\n }\n\n if (!modalState.innerElement?.contains(target)) {\n return originalEvent.preventDefault();\n }\n\n originalEvent.stopPropagation();\n\n const { expandable, contentScrolled, collapsed, expanded } = modalState;\n\n if (!this.state.touchDown) {\n modalState.touchStartContentScrollTop = modalState.contentElement?.scrollTop ?? 0;\n this.setState({ touchDown: true });\n }\n\n if (contentScrolled) {\n return;\n }\n\n if (modalState.touchMovePositive === null) {\n modalState.touchMovePositive = shiftY > 0;\n }\n\n if (\n !modalState.expandable ||\n collapsed ||\n (expanded && modalState.touchMovePositive && modalState.touchStartContentScrollTop === 0) ||\n modalState.headerElement?.contains(target)\n ) {\n originalEvent.preventDefault();\n\n if ((!expandable && shiftY < 0) || !this.window) {\n return;\n }\n\n !this.state.dragging && this.setState({ dragging: true });\n\n const shiftYPercent = (shiftY / this.window.innerHeight) * 100;\n const shiftYCurrent = rubber(shiftYPercent, 72, 0.8, this.props.platform !== 'ios');\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = rangeTranslate((modalState.translateY ?? 0) + shiftYCurrent);\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onCardTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { originalEvent, shiftY } = event;\n const target = originalEvent.target as HTMLElement;\n if (modalState.innerElement?.contains(target)) {\n if (!this.state.touchDown) {\n this.setState({ touchDown: true, dragging: true });\n }\n\n const shiftYPercent = (shiftY / modalState.innerElement.offsetHeight) * 100;\n const shiftYCurrent = rubber(shiftYPercent, 72, 1.2, this.props.platform !== 'ios');\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = Math.max(0, (modalState.translateY ?? 0) + shiftYCurrent);\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onTouchEnd = (e: TouchEvent) => {\n const modalState = this.props.getModalState(this.props.activeModal);\n\n if (modalState?.type === 'page') {\n return this.onPageTouchEnd(e, modalState);\n }\n\n if (modalState?.type === 'card') {\n return this.onCardTouchEnd(e, modalState);\n }\n };\n\n onPageTouchEnd(event: TouchEvent, modalState: ModalsStateEntry) {\n const { startY, shiftY } = event;\n\n modalState.contentScrolled = false;\n modalState.touchMovePositive = null;\n\n let setStateCallback;\n\n if (this.state.dragging && this.window) {\n const shiftYEndPercent = ((startY + shiftY) / this.window.innerHeight) * 100;\n\n let translateY = modalState.translateYCurrent ?? 0;\n const expectTranslateY =\n (translateY / event.duration) *\n 240 *\n 0.6 *\n ((modalState.touchShiftYPercent ?? 0) < 0 ? -1 : 1);\n translateY = rangeTranslate(translateY + expectTranslateY);\n\n if (modalState.settlingHeight !== 100) {\n if (numberInRange(translateY, modalState.expandedRange)) {\n translateY = modalState.expandedRange?.[0] ?? 0;\n } else if (numberInRange(translateY, modalState.collapsedRange)) {\n translateY = modalState.translateYFrom ?? 0;\n } else if (numberInRange(translateY, modalState.hiddenRange)) {\n translateY = modalState.preventClose ? modalState.translateYFrom ?? 0 : 100;\n } else {\n translateY = modalState.translateYFrom ?? 0;\n }\n } else {\n if (numberInRange(translateY, [0, 25])) {\n translateY = 0;\n } else {\n translateY = modalState.preventClose ? modalState.translateYFrom ?? 0 : 100;\n }\n }\n\n if (translateY !== 100 && shiftYEndPercent >= 75 && !modalState.preventClose) {\n translateY = 100;\n }\n\n modalState.translateY = translateY;\n modalState.translateYCurrent = translateY;\n modalState.collapsed = numberInRange(translateY, modalState.collapsedRange);\n modalState.expanded = translateY === 0;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.onExit();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback,\n );\n }\n\n onCardTouchEnd({ duration }: TouchEvent, modalState: ModalsStateEntry) {\n let setStateCallback;\n\n if (this.state.dragging) {\n let translateY = modalState.translateYCurrent ?? 0;\n\n const expectTranslateY =\n (translateY / duration) * 240 * 0.6 * ((modalState.touchShiftYPercent ?? 0) < 0 ? -1 : 1);\n translateY = Math.max(0, translateY + expectTranslateY);\n\n if (translateY >= 30) {\n translateY = 100;\n } else {\n translateY = 0;\n }\n\n modalState.translateY = translateY;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.onExit();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback,\n );\n }\n\n onScroll = (e: React.SyntheticEvent) => {\n const activeModal = this.props.activeModal;\n\n const target = e.target as HTMLElement;\n\n if (!activeModal) {\n return;\n }\n const modalState = this.props.getModalState(activeModal);\n if (modalState?.type === 'page' && modalState?.contentElement?.contains(target)) {\n modalState.contentScrolled = true;\n\n if (modalState.contentScrollStopTimeout) {\n clearTimeout(modalState.contentScrollStopTimeout);\n }\n\n modalState.contentScrollStopTimeout = setTimeout(() => {\n if (modalState.contentScrolled) {\n modalState.contentScrolled = false;\n }\n }, 250);\n }\n };\n\n waitTransitionFinish(modalState: ModalsStateEntry | undefined, eventHandler: () => void) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState?.innerElement?.removeEventListener(transitionEvent.name as string, onceHandler);\n eventHandler();\n };\n\n modalState?.innerElement?.addEventListener(transitionEvent.name as string, onceHandler);\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /**\n * Анимирует сдвиг модалки\n *\n * @param {ModalsStateEntry} modalState\n * @param {number} percent Процент сдвига: 0 – полностью открыта, 100 – полностью закрыта\n */\n animateTranslate(modalState: ModalsStateEntry, percent: number | undefined) {\n const frameId = `animateTranslateFrame${modalState.id}`;\n\n cancelAnimationFrame(this.frameIds[frameId]);\n\n this.frameIds[frameId] = requestAnimationFrame(() => {\n setTransformStyle(modalState.innerElement, `translate3d(0, ${percent}%, 0)`);\n });\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(modalState: ModalsStateEntry, forceOpacity: number | null = null) {\n if (forceOpacity === null && this.props.history?.[0] !== modalState.id) {\n return;\n }\n if (this.maskAnimationFrame) {\n cancelAnimationFrame(this.maskAnimationFrame);\n }\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = clamp(opacity, 0, 100).toString();\n this.maskElementRef.current.style.transitionDelay =\n opacity && this.props.delayEnter ? `${this.timeout}ms` : '';\n }\n });\n }\n\n render() {\n const { activeModal, exitingModal, enteringModal, modalOverlayTestId } = this.props;\n const { touchDown, dragging } = this.state;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <TouchRootContext.Provider value={true}>\n <ModalRootContext.Provider value={this.modalRootContext}>\n <Touch\n className={classNames(\n styles['ModalRoot'],\n this.props.configProvider?.hasCustomPanelHeaderAfter &&\n styles['ModalRoot--hasCustomPanelHeaderAfterSlot'],\n touchDown &&\n classNames(styles['ModalRoot--touched'], 'vkuiInternalModalRoot--touched'),\n !!(enteringModal || exitingModal) &&\n classNames(styles['ModalRoot--switching'], 'vkuiInternalModalRoot--switching'),\n )}\n onMove={this.onTouchMove}\n onEnd={this.onTouchEnd}\n onScroll={this.onScroll}\n >\n <div\n data-testid={modalOverlayTestId}\n className={styles['ModalRoot__mask']}\n onClick={this.props.onExit}\n ref={this.maskElementRef}\n />\n <div className={styles['ModalRoot__viewport']} ref={this.viewportRef}>\n {this.getModals().map((Modal) => {\n const modalId = getNavId(Modal.props, warn);\n const _modalState = this.props.getModalState(modalId);\n if ((modalId !== activeModal && modalId !== exitingModal) || !_modalState) {\n return null;\n }\n const modalState = { ..._modalState };\n\n const isPage = modalState.type === 'page';\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n key={key}\n onClose={this.props.onExit}\n timeout={this.timeout}\n className={classNames(\n styles['ModalRoot__modal'],\n\n dragging && 'vkuiInternalModalRoot__modal--dragging',\n\n isPage && modalState.expandable && 'vkuiInternalModalRoot__modal--expandable',\n isPage && modalState.collapsed && 'vkuiInternalModalRoot__modal--collapsed',\n )}\n restoreFocus={false}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </Touch>\n </ModalRootContext.Provider>\n </TouchRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootTouch = withContext(\n withPlatform(\n withDOM<ModalRootWithDOMProps>(withModalManager(initModal)(ModalRootTouchComponent)),\n ),\n ConfigProviderContext,\n 'configProvider',\n);\n\n/**\n * Инициализирует модалку перед анимацией открытия\n */\nfunction initModal(modalState: ModalsStateEntry) {\n switch (modalState.type) {\n case 'page':\n modalState.settlingHeight = modalState.settlingHeight || MODAL_PAGE_DEFAULT_PERCENT_HEIGHT;\n return initPageModal(modalState);\n case 'card':\n return initCardModal(modalState);\n default:\n process.env.NODE_ENV === 'development' &&\n warn(`initActiveModal: modalState.type=\"${modalState.type}\" не поддерживается`, 'error');\n }\n}\n\nfunction initPageModal(modalState: ModalsStateEntry) {\n const { contentElement, bottomInset } = modalState;\n const contentElementHeight = calculateModalContentHeight(\n contentElement?.firstElementChild as HTMLElement,\n modalState.expandable,\n );\n const bottomInsetHeight = bottomInset?.offsetHeight || 0;\n const contentHeight = contentElementHeight + bottomInsetHeight;\n let prevTranslateY = modalState.translateY;\n let prevExpandable = modalState.expandable;\n\n modalState.expandable =\n contentHeight > (contentElement?.clientHeight ?? 0) || modalState.settlingHeight === 100;\n\n let collapsed = false;\n let expanded = false;\n let translateYFrom;\n let translateY;\n let expandedRange: TranslateRange;\n let collapsedRange: TranslateRange | undefined;\n let hiddenRange: TranslateRange;\n\n const hasCollapsedState = Boolean(modalState.expandable && modalState.settlingHeight !== 100);\n if (modalState.expandable) {\n translateYFrom = 100 - (modalState.settlingHeight ?? 0);\n\n const shiftHalf = translateYFrom / 2;\n const visiblePart = 100 - translateYFrom;\n\n expandedRange = [0, shiftHalf];\n collapsedRange = hasCollapsedState ? [shiftHalf, translateYFrom + visiblePart / 4] : undefined;\n hiddenRange = [translateYFrom + visiblePart / 4, 100];\n\n collapsed = hasCollapsedState && translateYFrom > 0;\n expanded = translateYFrom <= 0;\n translateY = translateYFrom;\n } else {\n const headerHeight = modalState.headerElement?.offsetHeight ?? 0;\n const height = contentHeight + headerHeight;\n\n translateYFrom =\n 100 - (height / (modalState.innerElement?.parentElement?.offsetHeight ?? 0)) * 100;\n translateY = translateYFrom;\n\n expandedRange = [translateY, translateY + 25];\n collapsedRange = undefined;\n hiddenRange = [translateY + 25, translateY + 100];\n }\n\n // Свойство expandable может измениться из-за высоты контента, в таком случае на всю высоту не разворачиваем\n const shouldExpand = prevExpandable && modalState.expandable;\n // Если модалка может открываться на весь экран, и новый сдвиг больше предыдущего, то откроем её на весь экран\n if ((shouldExpand && translateY > (prevTranslateY ?? 100)) || modalState.settlingHeight === 100) {\n translateY = 0;\n }\n\n // Если модалка уже раскрыта обновляем состояния\n if (translateY === 0) {\n expanded = true;\n collapsed = false;\n }\n\n modalState.expandedRange = expandedRange;\n modalState.collapsedRange = collapsedRange;\n modalState.hiddenRange = hiddenRange;\n modalState.translateY = translateY;\n modalState.translateYFrom = translateYFrom;\n modalState.collapsed = collapsed;\n modalState.expanded = expanded;\n}\n\nfunction initCardModal(modalState: ModalsStateEntry) {\n modalState.translateY = 0;\n}\n\nfunction calculateModalContentHeight(\n element: HTMLElement,\n isExpandable: ModalsStateEntry['expandable'],\n) {\n if (!isExpandable) {\n return element.scrollHeight;\n }\n\n /*\n * В режиме expandable мы назначаем контейнеру контента высоту 100%, что не даёт\n * получить реальную высоту контента.\n * Поэтому мы пересчитываем высоту, временно устанавливая height: auto;\n * */\n const currentHeightStyle = element.style.height;\n element.style.height = 'auto';\n\n const elementHeight = element.scrollHeight;\n element.style.height = currentHeightStyle;\n\n return elementHeight;\n}\n"],"names":["React","classNames","clamp","withContext","withPlatform","withDOM","getNavId","setTransformStyle","transitionEvent","rubber","warnOnce","ConfigProviderContext","FocusTrap","Touch","TouchRootContext","ModalRootContext","MODAL_PAGE_DEFAULT_PERCENT_HEIGHT","withModalManager","styles","warn","numberInRange","number","range","rangeTranslate","ModalRootTouchComponent","Component","constructor","props","state","touchDown","dragging","modalOpenedLog","maskElementRef","createRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","getModalState","onClose","onExit","isInsideModal","frameIds","documentScrolling","viewportRef","maskAnimationFrame","undefined","restoreFocusTo","timeout","platform","document","window","getModals","Children","toArray","children","componentDidMount","addEventListener","componentWillUnmount","toggleDocumentScrolling","removeEventListener","componentDidUpdate","prevProps","exitingModal","closeModal","enteringModal","enteringState","onEnter","waitTransitionFinish","innerElement","style","transitionDelay","onEntered","delayEnter","animateTranslate","translateY","setMaskOpacity","activeModal","activeElement","focus","enabled","documentElement","classList","remove","preventTouch","passive","add","event","originalEvent","preventDefault","checkPageContentHeight","modalState","type","modalElement","prevModalState","initPageModal","currentModalState","needAnimate","expandable","translateYFrom","requestAnimationFrame","noFocusToDialog","contains","setState","length","prevState","nextModalState","nextIsPage","prevIsPage","onExited","exitTranslate","isBack","includes","onTouchMove","e","onPageTouchMove","onCardTouchMove","shiftY","target","isY","current","stopPropagation","contentScrolled","collapsed","expanded","touchStartContentScrollTop","contentElement","scrollTop","touchMovePositive","headerElement","shiftYPercent","innerHeight","shiftYCurrent","touchShiftYPercent","translateYCurrent","offsetHeight","Math","max","onTouchEnd","onPageTouchEnd","onCardTouchEnd","startY","setStateCallback","shiftYEndPercent","expectTranslateY","duration","settlingHeight","expandedRange","collapsedRange","hiddenRange","preventClose","hidden","onScroll","contentScrollStopTimeout","clearTimeout","setTimeout","eventHandler","supported","onceHandler","name","percent","frameId","cancelAnimationFrame","forceOpacity","history","opacity","toString","render","modalOverlayTestId","Provider","value","className","configProvider","hasCustomPanelHeaderAfter","onMove","onEnd","div","data-testid","onClick","ref","map","Modal","modalId","_modalState","isPage","key","restoreFocus","ModalRootTouch","initModal","initCardModal","process","env","NODE_ENV","bottomInset","contentElementHeight","calculateModalContentHeight","firstElementChild","bottomInsetHeight","contentHeight","prevTranslateY","prevExpandable","clientHeight","hasCollapsedState","Boolean","shiftHalf","visiblePart","headerHeight","height","parentElement","shouldExpand","element","isExpandable","scrollHeight","currentHeightStyle","elementHeight"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRoot.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { clamp } from '../../helpers/math';\nimport { withContext } from '../../hoc/withContext';\nimport { withPlatform } from '../../hoc/withPlatform';\nimport { DOMProps, withDOM } from '../../lib/dom';\nimport { getNavId } from '../../lib/getNavId';\nimport { setTransformStyle } from '../../lib/styles';\nimport { rubber } from '../../lib/touch';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { ConfigProviderContext } from '../ConfigProvider/ConfigProviderContext';\nimport { FocusTrap } from '../FocusTrap/FocusTrap';\nimport { Touch, TouchEvent } from '../Touch/Touch';\nimport TouchRootContext from '../Touch/TouchContext';\nimport { ModalRootContext, ModalRootContextInterface } from './ModalRootContext';\nimport { MODAL_PAGE_DEFAULT_PERCENT_HEIGHT } from './constants';\nimport { ModalRootWithDOMProps, ModalsStateEntry, TranslateRange } from './types';\nimport { ModalTransitionProps, withModalManager } from './useModalManager';\nimport styles from './ModalRoot.module.css';\n\nconst warn = warnOnce('ModalRoot');\n\nfunction numberInRange(number: number, range: TranslateRange | undefined) {\n if (!range) {\n return false;\n }\n return number >= range[0] && number <= range[1];\n}\n\nfunction rangeTranslate(number: number) {\n return clamp(number, 0, 98);\n}\n\ninterface ModalRootState {\n touchDown?: boolean;\n dragging?: boolean;\n modalOpenedLog: string[];\n}\n\nclass ModalRootTouchComponent extends React.Component<\n ModalRootWithDOMProps & DOMProps & ModalTransitionProps,\n ModalRootState\n> {\n constructor(props: ModalRootWithDOMProps & ModalTransitionProps) {\n super(props);\n this.state = {\n touchDown: false,\n dragging: false,\n modalOpenedLog: [],\n };\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: this.updateModalHeight,\n registerModal: ({ id, ...data }) => Object.assign(this.props.getModalState(id) ?? {}, data),\n onClose: () => this.props.onExit(),\n isInsideModal: true,\n };\n\n this.frameIds = {};\n }\n\n private documentScrolling = false;\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private readonly viewportRef = React.createRef<HTMLDivElement>();\n private maskAnimationFrame: number | undefined = undefined;\n private readonly modalRootContext: ModalRootContextInterface;\n private readonly frameIds: {\n [index: string]: number;\n };\n private restoreFocusTo: HTMLElement | undefined | null = undefined;\n\n get timeout(): number {\n return this.props.platform === 'ios' ? 400 : 320;\n }\n\n get document(): Document {\n return this.props.document as Document;\n }\n\n get window(): Window {\n return this.props.window as Window;\n }\n\n getModals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n componentDidMount() {\n // Отслеживаем изменение размеров viewport\n this.window?.addEventListener('resize', this.updateModalHeight, false);\n }\n\n componentWillUnmount() {\n this.toggleDocumentScrolling(true);\n this.window.removeEventListener('resize', this.updateModalHeight, false);\n }\n\n componentDidUpdate(prevProps: ModalRootWithDOMProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (this.props.exitingModal && this.props.exitingModal !== prevProps.exitingModal) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (this.props.enteringModal && this.props.enteringModal !== prevProps.enteringModal) {\n const enteringState = this.props.getModalState(this.props.enteringModal);\n this.props.onEnter();\n this.waitTransitionFinish(enteringState, () => {\n if (enteringState) {\n if (enteringState.innerElement) {\n enteringState.innerElement.style.transitionDelay = '';\n }\n this.onEntered(enteringState);\n }\n });\n\n if (enteringState?.innerElement) {\n enteringState.innerElement.style.transitionDelay = this.props.delayEnter\n ? `${this.timeout}ms`\n : '';\n this.animateTranslate(enteringState, enteringState.translateY);\n this.setMaskOpacity(enteringState, 1);\n }\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = this.document.activeElement as HTMLElement;\n }\n if (!this.props.activeModal && !this.props.exitingModal && this.restoreFocusTo) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = null;\n }\n\n this.toggleDocumentScrolling(!this.props.activeModal && !this.props.exitingModal);\n }\n\n /* Отключает скролл документа */\n toggleDocumentScrolling(enabled: boolean) {\n if (this.documentScrolling === enabled) {\n return;\n }\n this.documentScrolling = enabled;\n\n if (enabled) {\n // восстанавливаем значение overscroll behavior\n // eslint-disable-next-line no-restricted-properties\n this.document.documentElement.classList.remove('vkui--disable-overscroll-behavior');\n\n // некоторые браузеры на странных вендорах типа Meizu не удаляют обработчик.\n // https://github.com/VKCOM/VKUI/issues/444\n this.window.removeEventListener('touchmove', this.preventTouch, {\n // @ts-expect-error: TS2769 В интерфейсе EventListenerOptions нет поля passive\n passive: false,\n });\n } else {\n // отключаем нативный pull-to-refresh при открытом модальном окне\n // чтобы он не срабатывал при закрытии модалки смахиванием вниз\n // eslint-disable-next-line no-restricted-properties\n this.document.documentElement.classList.add('vkui--disable-overscroll-behavior');\n\n this.window.addEventListener('touchmove', this.preventTouch, {\n passive: false,\n });\n }\n }\n\n preventTouch = (event: any) => {\n if (!event) {\n return false;\n }\n while (event.originalEvent) {\n event = event.originalEvent;\n }\n if (event.preventDefault) {\n event.preventDefault();\n }\n return false;\n };\n\n checkPageContentHeight() {\n const modalState = this.props.getModalState(this.props.activeModal);\n\n if (modalState?.type === 'page' && modalState?.modalElement) {\n const prevModalState = { ...modalState };\n initPageModal(modalState);\n const currentModalState = { ...modalState };\n\n let needAnimate = false;\n\n if (prevModalState.expandable === currentModalState.expandable) {\n if (prevModalState.translateYFrom !== currentModalState.translateYFrom) {\n needAnimate = true;\n }\n } else {\n needAnimate = true;\n }\n\n if (needAnimate) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n }\n }\n\n updateModalHeight = () => {\n const modalState = this.props.getModalState(this.props.activeModal);\n\n if (modalState && modalState.type === 'page') {\n if (this.props.enteringModal) {\n this.waitTransitionFinish(modalState, () => {\n requestAnimationFrame(() => this.checkPageContentHeight());\n });\n } else {\n requestAnimationFrame(() => this.checkPageContentHeight());\n }\n }\n };\n\n onEntered({ id, modalElement }: ModalsStateEntry) {\n if (\n !this.props.noFocusToDialog &&\n modalElement &&\n !modalElement.contains(this.document.activeElement)\n ) {\n modalElement.focus();\n }\n\n this.props.onEntered(id);\n }\n\n closeModal(id: string) {\n // Сбрасываем состояния, которые могут помешать закрытию модального окна\n this.setState({ touchDown: false });\n\n const prevModalState = this.props.getModalState(id);\n\n if (!prevModalState) {\n id && warn(`closeActiveModal: модальное окно (страница) ${id} не существует`, 'error');\n return;\n }\n if (!this.state.modalOpenedLog.length) {\n this.setState((prevState) => ({\n modalOpenedLog: [...prevState.modalOpenedLog, id],\n }));\n }\n const nextModalState = this.props.getModalState(this.props.activeModal);\n const nextIsPage = !!nextModalState && nextModalState.type === 'page';\n\n const prevIsPage = !!prevModalState && prevModalState.type === 'page';\n this.waitTransitionFinish(prevModalState, () => this.props.onExited(id));\n const exitTranslate =\n prevIsPage &&\n nextIsPage &&\n (prevModalState.translateY ?? 0) <= (nextModalState?.translateYFrom ?? 0) &&\n !this.props.isBack\n ? (nextModalState?.translateYFrom ?? 0) + 10\n : 100;\n this.animateTranslate(prevModalState, exitTranslate);\n\n if (!nextModalState) {\n // NOTE: was only for clean exit\n this.setMaskOpacity(prevModalState, 0);\n this.setState({ modalOpenedLog: [] });\n prevModalState.translateY = undefined;\n prevModalState.expandable = undefined;\n } else if (nextModalState.id && !this.state.modalOpenedLog.includes(nextModalState.id)) {\n nextModalState.translateY = undefined;\n this.setState((prevState) => ({\n modalOpenedLog: [...prevState.modalOpenedLog, nextModalState.id!],\n }));\n }\n }\n\n onTouchMove = (e: TouchEvent) => {\n if (this.props.exitingModal) {\n return;\n }\n const modalState = this.props.getModalState(this.props.activeModal);\n if (!modalState) {\n return;\n }\n\n if (modalState.type === 'page') {\n return this.onPageTouchMove(e, modalState);\n }\n\n if (modalState.type === 'card') {\n return this.onCardTouchMove(e, modalState);\n }\n };\n\n onPageTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { shiftY, originalEvent } = event;\n const target = originalEvent.target as HTMLElement;\n\n if (!event.isY) {\n if (this.viewportRef.current?.contains(target)) {\n originalEvent.preventDefault();\n }\n return;\n }\n\n if (!modalState.innerElement?.contains(target)) {\n return originalEvent.preventDefault();\n }\n\n originalEvent.stopPropagation();\n\n const { expandable, contentScrolled, collapsed, expanded } = modalState;\n\n if (!this.state.touchDown) {\n modalState.touchStartContentScrollTop = modalState.contentElement?.scrollTop ?? 0;\n this.setState({ touchDown: true });\n }\n\n if (contentScrolled) {\n return;\n }\n\n if (modalState.touchMovePositive === null) {\n modalState.touchMovePositive = shiftY > 0;\n }\n\n if (\n !modalState.expandable ||\n collapsed ||\n (expanded && modalState.touchMovePositive && modalState.touchStartContentScrollTop === 0) ||\n modalState.headerElement?.contains(target)\n ) {\n originalEvent.preventDefault();\n\n if ((!expandable && shiftY < 0) || !this.window) {\n return;\n }\n\n !this.state.dragging && this.setState({ dragging: true });\n\n const shiftYPercent = (shiftY / this.window.innerHeight) * 100;\n const shiftYCurrent = rubber(shiftYPercent, 72, 0.8, this.props.platform !== 'ios');\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = rangeTranslate((modalState.translateY ?? 0) + shiftYCurrent);\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onCardTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { originalEvent, shiftY } = event;\n const target = originalEvent.target as HTMLElement;\n if (modalState.innerElement?.contains(target)) {\n if (!this.state.touchDown) {\n this.setState({ touchDown: true, dragging: true });\n }\n\n const shiftYPercent = (shiftY / modalState.innerElement.offsetHeight) * 100;\n const shiftYCurrent = rubber(shiftYPercent, 72, 1.2, this.props.platform !== 'ios');\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = Math.max(0, (modalState.translateY ?? 0) + shiftYCurrent);\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onTouchEnd = (e: TouchEvent) => {\n const modalState = this.props.getModalState(this.props.activeModal);\n\n if (modalState?.type === 'page') {\n return this.onPageTouchEnd(e, modalState);\n }\n\n if (modalState?.type === 'card') {\n return this.onCardTouchEnd(e, modalState);\n }\n };\n\n onPageTouchEnd(event: TouchEvent, modalState: ModalsStateEntry) {\n const { startY, shiftY } = event;\n\n modalState.contentScrolled = false;\n modalState.touchMovePositive = null;\n\n let setStateCallback;\n\n if (this.state.dragging && this.window) {\n const shiftYEndPercent = ((startY + shiftY) / this.window.innerHeight) * 100;\n\n let translateY = modalState.translateYCurrent ?? 0;\n const expectTranslateY =\n (translateY / event.duration) *\n 240 *\n 0.6 *\n ((modalState.touchShiftYPercent ?? 0) < 0 ? -1 : 1);\n translateY = rangeTranslate(translateY + expectTranslateY);\n\n if (modalState.settlingHeight !== 100) {\n if (numberInRange(translateY, modalState.expandedRange)) {\n translateY = modalState.expandedRange?.[0] ?? 0;\n } else if (numberInRange(translateY, modalState.collapsedRange)) {\n translateY = modalState.translateYFrom ?? 0;\n } else if (numberInRange(translateY, modalState.hiddenRange)) {\n translateY = modalState.preventClose ? modalState.translateYFrom ?? 0 : 100;\n } else {\n translateY = modalState.translateYFrom ?? 0;\n }\n } else {\n if (numberInRange(translateY, [0, 25])) {\n translateY = 0;\n } else {\n translateY = modalState.preventClose ? modalState.translateYFrom ?? 0 : 100;\n }\n }\n\n if (translateY !== 100 && shiftYEndPercent >= 75 && !modalState.preventClose) {\n translateY = 100;\n }\n\n modalState.translateY = translateY;\n modalState.translateYCurrent = translateY;\n modalState.collapsed = numberInRange(translateY, modalState.collapsedRange);\n modalState.expanded = translateY === 0;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.onExit();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback,\n );\n }\n\n onCardTouchEnd({ duration }: TouchEvent, modalState: ModalsStateEntry) {\n let setStateCallback;\n\n if (this.state.dragging) {\n let translateY = modalState.translateYCurrent ?? 0;\n\n const expectTranslateY =\n (translateY / duration) * 240 * 0.6 * ((modalState.touchShiftYPercent ?? 0) < 0 ? -1 : 1);\n translateY = Math.max(0, translateY + expectTranslateY);\n\n if (translateY >= 30) {\n translateY = 100;\n } else {\n translateY = 0;\n }\n\n modalState.translateY = translateY;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.onExit();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback,\n );\n }\n\n onScroll = (e: React.SyntheticEvent) => {\n const activeModal = this.props.activeModal;\n\n const target = e.target as HTMLElement;\n\n if (!activeModal) {\n return;\n }\n const modalState = this.props.getModalState(activeModal);\n if (modalState?.type === 'page' && modalState?.contentElement?.contains(target)) {\n modalState.contentScrolled = true;\n\n if (modalState.contentScrollStopTimeout) {\n clearTimeout(modalState.contentScrollStopTimeout);\n }\n\n modalState.contentScrollStopTimeout = setTimeout(() => {\n if (modalState.contentScrolled) {\n modalState.contentScrolled = false;\n }\n }, 250);\n }\n };\n\n waitTransitionFinish(modalState: ModalsStateEntry | undefined, eventHandler: () => void) {\n const el = modalState ? modalState.innerElement : null;\n if (el) {\n el.addEventListener('transitionend', eventHandler, { once: true });\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /**\n * Анимирует сдвиг модалки\n *\n * @param {ModalsStateEntry} modalState\n * @param {number} percent Процент сдвига: 0 – полностью открыта, 100 – полностью закрыта\n */\n animateTranslate(modalState: ModalsStateEntry, percent: number | undefined) {\n const frameId = `animateTranslateFrame${modalState.id}`;\n\n cancelAnimationFrame(this.frameIds[frameId]);\n\n this.frameIds[frameId] = requestAnimationFrame(() => {\n setTransformStyle(modalState.innerElement, `translate3d(0, ${percent}%, 0)`);\n });\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(modalState: ModalsStateEntry, forceOpacity: number | null = null) {\n if (forceOpacity === null && this.props.history?.[0] !== modalState.id) {\n return;\n }\n if (this.maskAnimationFrame) {\n cancelAnimationFrame(this.maskAnimationFrame);\n }\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = clamp(opacity, 0, 100).toString();\n this.maskElementRef.current.style.transitionDelay =\n opacity && this.props.delayEnter ? `${this.timeout}ms` : '';\n }\n });\n }\n\n render() {\n const { activeModal, exitingModal, enteringModal, modalOverlayTestId } = this.props;\n const { touchDown, dragging } = this.state;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <TouchRootContext.Provider value={true}>\n <ModalRootContext.Provider value={this.modalRootContext}>\n <Touch\n className={classNames(\n styles['ModalRoot'],\n this.props.configProvider?.hasCustomPanelHeaderAfter &&\n styles['ModalRoot--hasCustomPanelHeaderAfterSlot'],\n touchDown &&\n classNames(styles['ModalRoot--touched'], 'vkuiInternalModalRoot--touched'),\n !!(enteringModal || exitingModal) &&\n classNames(styles['ModalRoot--switching'], 'vkuiInternalModalRoot--switching'),\n )}\n onMove={this.onTouchMove}\n onEnd={this.onTouchEnd}\n onScroll={this.onScroll}\n >\n <div\n data-testid={modalOverlayTestId}\n className={styles['ModalRoot__mask']}\n onClick={this.props.onExit}\n ref={this.maskElementRef}\n />\n <div className={styles['ModalRoot__viewport']} ref={this.viewportRef}>\n {this.getModals().map((Modal) => {\n const modalId = getNavId(Modal.props, warn);\n const _modalState = this.props.getModalState(modalId);\n if ((modalId !== activeModal && modalId !== exitingModal) || !_modalState) {\n return null;\n }\n const modalState = { ..._modalState };\n\n const isPage = modalState.type === 'page';\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n key={key}\n onClose={this.props.onExit}\n timeout={this.timeout}\n className={classNames(\n styles['ModalRoot__modal'],\n\n dragging && 'vkuiInternalModalRoot__modal--dragging',\n\n isPage && modalState.expandable && 'vkuiInternalModalRoot__modal--expandable',\n isPage && modalState.collapsed && 'vkuiInternalModalRoot__modal--collapsed',\n )}\n autoFocus={false}\n restoreFocus={false}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </Touch>\n </ModalRootContext.Provider>\n </TouchRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootTouch = withContext(\n withPlatform(\n withDOM<ModalRootWithDOMProps>(withModalManager(initModal)(ModalRootTouchComponent)),\n ),\n ConfigProviderContext,\n 'configProvider',\n);\n\n/**\n * Инициализирует модалку перед анимацией открытия\n */\nfunction initModal(modalState: ModalsStateEntry) {\n switch (modalState.type) {\n case 'page':\n modalState.settlingHeight = modalState.settlingHeight || MODAL_PAGE_DEFAULT_PERCENT_HEIGHT;\n return initPageModal(modalState);\n case 'card':\n return initCardModal(modalState);\n default:\n process.env.NODE_ENV === 'development' &&\n warn(`initActiveModal: modalState.type=\"${modalState.type}\" не поддерживается`, 'error');\n }\n}\n\nfunction initPageModal(modalState: ModalsStateEntry) {\n const { contentElement, bottomInset } = modalState;\n const contentElementHeight = calculateModalContentHeight(\n contentElement?.firstElementChild as HTMLElement,\n modalState.expandable,\n );\n const bottomInsetHeight = bottomInset?.offsetHeight || 0;\n const contentHeight = contentElementHeight + bottomInsetHeight;\n let prevTranslateY = modalState.translateY;\n let prevExpandable = modalState.expandable;\n\n modalState.expandable =\n contentHeight > (contentElement?.clientHeight ?? 0) || modalState.settlingHeight === 100;\n\n let collapsed = false;\n let expanded = false;\n let translateYFrom;\n let translateY;\n let expandedRange: TranslateRange;\n let collapsedRange: TranslateRange | undefined;\n let hiddenRange: TranslateRange;\n\n const hasCollapsedState = Boolean(modalState.expandable && modalState.settlingHeight !== 100);\n if (modalState.expandable) {\n translateYFrom = 100 - (modalState.settlingHeight ?? 0);\n\n const shiftHalf = translateYFrom / 2;\n const visiblePart = 100 - translateYFrom;\n\n expandedRange = [0, shiftHalf];\n collapsedRange = hasCollapsedState ? [shiftHalf, translateYFrom + visiblePart / 4] : undefined;\n hiddenRange = [translateYFrom + visiblePart / 4, 100];\n\n collapsed = hasCollapsedState && translateYFrom > 0;\n expanded = translateYFrom <= 0;\n translateY = translateYFrom;\n } else {\n const headerHeight = modalState.headerElement?.offsetHeight ?? 0;\n const height = contentHeight + headerHeight;\n\n translateYFrom =\n 100 - (height / (modalState.innerElement?.parentElement?.offsetHeight ?? 0)) * 100;\n translateY = translateYFrom;\n\n expandedRange = [translateY, translateY + 25];\n collapsedRange = undefined;\n hiddenRange = [translateY + 25, translateY + 100];\n }\n\n // Свойство expandable может измениться из-за высоты контента, в таком случае на всю высоту не разворачиваем\n const shouldExpand = prevExpandable && modalState.expandable;\n // Если модалка может открываться на весь экран, и новый сдвиг больше предыдущего, то откроем её на весь экран\n if ((shouldExpand && translateY > (prevTranslateY ?? 100)) || modalState.settlingHeight === 100) {\n translateY = 0;\n }\n\n // Если модалка уже раскрыта обновляем состояния\n if (translateY === 0) {\n expanded = true;\n collapsed = false;\n }\n\n modalState.expandedRange = expandedRange;\n modalState.collapsedRange = collapsedRange;\n modalState.hiddenRange = hiddenRange;\n modalState.translateY = translateY;\n modalState.translateYFrom = translateYFrom;\n modalState.collapsed = collapsed;\n modalState.expanded = expanded;\n}\n\nfunction initCardModal(modalState: ModalsStateEntry) {\n modalState.translateY = 0;\n}\n\nfunction calculateModalContentHeight(\n element: HTMLElement,\n isExpandable: ModalsStateEntry['expandable'],\n) {\n if (!isExpandable) {\n return element.scrollHeight;\n }\n\n /*\n * В режиме expandable мы назначаем контейнеру контента высоту 100%, что не даёт\n * получить реальную высоту контента.\n * Поэтому мы пересчитываем высоту, временно устанавливая height: auto;\n * */\n const currentHeightStyle = element.style.height;\n element.style.height = 'auto';\n\n const elementHeight = element.scrollHeight;\n element.style.height = currentHeightStyle;\n\n return elementHeight;\n}\n"],"names":["React","classNames","clamp","withContext","withPlatform","withDOM","getNavId","setTransformStyle","rubber","warnOnce","ConfigProviderContext","FocusTrap","Touch","TouchRootContext","ModalRootContext","MODAL_PAGE_DEFAULT_PERCENT_HEIGHT","withModalManager","styles","warn","numberInRange","number","range","rangeTranslate","ModalRootTouchComponent","Component","constructor","props","state","touchDown","dragging","modalOpenedLog","maskElementRef","createRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","getModalState","onClose","onExit","isInsideModal","frameIds","documentScrolling","viewportRef","maskAnimationFrame","undefined","restoreFocusTo","timeout","platform","document","window","getModals","Children","toArray","children","componentDidMount","addEventListener","componentWillUnmount","toggleDocumentScrolling","removeEventListener","componentDidUpdate","prevProps","exitingModal","closeModal","enteringModal","enteringState","onEnter","waitTransitionFinish","innerElement","style","transitionDelay","onEntered","delayEnter","animateTranslate","translateY","setMaskOpacity","activeModal","activeElement","focus","enabled","documentElement","classList","remove","preventTouch","passive","add","event","originalEvent","preventDefault","checkPageContentHeight","modalState","type","modalElement","prevModalState","initPageModal","currentModalState","needAnimate","expandable","translateYFrom","requestAnimationFrame","noFocusToDialog","contains","setState","length","prevState","nextModalState","nextIsPage","prevIsPage","onExited","exitTranslate","isBack","includes","onTouchMove","e","onPageTouchMove","onCardTouchMove","shiftY","target","isY","current","stopPropagation","contentScrolled","collapsed","expanded","touchStartContentScrollTop","contentElement","scrollTop","touchMovePositive","headerElement","shiftYPercent","innerHeight","shiftYCurrent","touchShiftYPercent","translateYCurrent","offsetHeight","Math","max","onTouchEnd","onPageTouchEnd","onCardTouchEnd","startY","setStateCallback","shiftYEndPercent","expectTranslateY","duration","settlingHeight","expandedRange","collapsedRange","hiddenRange","preventClose","hidden","onScroll","contentScrollStopTimeout","clearTimeout","setTimeout","eventHandler","el","once","percent","frameId","cancelAnimationFrame","forceOpacity","history","opacity","toString","render","modalOverlayTestId","Provider","value","className","configProvider","hasCustomPanelHeaderAfter","onMove","onEnd","div","data-testid","onClick","ref","map","Modal","modalId","_modalState","isPage","key","autoFocus","restoreFocus","ModalRootTouch","initModal","initCardModal","process","env","NODE_ENV","bottomInset","contentElementHeight","calculateModalContentHeight","firstElementChild","bottomInsetHeight","contentHeight","prevTranslateY","prevExpandable","clientHeight","hasCollapsedState","Boolean","shiftHalf","visiblePart","headerHeight","height","parentElement","shouldExpand","element","isExpandable","scrollHeight","currentHeightStyle","elementHeight"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootAdaptive.tsx"],"sourcesContent":["import { useAdaptivityWithJSMediaQueries } from '../../hooks/useAdaptivityWithJSMediaQueries';\nimport { useScrollLock } from '../AppRoot/ScrollContext';\nimport { ModalRootTouch } from './ModalRoot';\nimport { ModalRootDesktop } from './ModalRootDesktop';\nimport { ModalRootProps } from './types';\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalRoot\n */\nexport const ModalRoot = (props: ModalRootProps) => {\n const { isDesktop } = useAdaptivityWithJSMediaQueries();\n\n useScrollLock(!!props.activeModal);\n\n const RootComponent = isDesktop ? ModalRootDesktop : ModalRootTouch;\n\n return <RootComponent {...props} />;\n};\n"],"names":["useAdaptivityWithJSMediaQueries","useScrollLock","ModalRootTouch","ModalRootDesktop","ModalRoot","props","isDesktop","activeModal","RootComponent"],"rangeMappings":";;;;;;;;;;;;;;","mappings":";AAAA,SAASA,+BAA+B,QAAQ,8CAA8C;AAC9F,SAASC,aAAa,QAAQ,2BAA2B;AACzD,SAASC,cAAc,QAAQ,cAAc;AAC7C,SAASC,gBAAgB,QAAQ,qBAAqB;AAGtD;;CAEC,GACD,OAAO,MAAMC,YAAY,CAACC;IACxB,MAAM,EAAEC,SAAS,EAAE,GAAGN;IAEtBC,cAAc,CAAC,CAACI,MAAME,WAAW;IAEjC,MAAMC,gBAAgBF,YAAYH,mBAAmBD;IAErD,qBAAO,KAACM;QAAe,GAAGH,KAAK;;AACjC,EAAE"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootAdaptive.tsx"],"sourcesContent":["import { useAdaptivityWithJSMediaQueries } from '../../hooks/useAdaptivityWithJSMediaQueries';\nimport { useScrollLock } from '../AppRoot/ScrollContext';\nimport { ModalRootTouch } from './ModalRoot';\nimport { ModalRootDesktop } from './ModalRootDesktop';\nimport { ModalRootProps } from './types';\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalRoot\n */\nexport const ModalRoot = (props: ModalRootProps) => {\n const { isDesktop } = useAdaptivityWithJSMediaQueries();\n\n useScrollLock(!!props.activeModal);\n\n const RootComponent = isDesktop ? ModalRootDesktop : ModalRootTouch;\n\n return <RootComponent {...props} />;\n};\n"],"names":["useAdaptivityWithJSMediaQueries","useScrollLock","ModalRootTouch","ModalRootDesktop","ModalRoot","props","isDesktop","activeModal","RootComponent"],"mappings":";AAAA,SAASA,+BAA+B,QAAQ,8CAA8C;AAC9F,SAASC,aAAa,QAAQ,2BAA2B;AACzD,SAASC,cAAc,QAAQ,cAAc;AAC7C,SAASC,gBAAgB,QAAQ,qBAAqB;AAGtD;;CAEC,GACD,OAAO,MAAMC,YAAY,CAACC;IACxB,MAAM,EAAEC,SAAS,EAAE,GAAGN;IAEtBC,cAAc,CAAC,CAACI,MAAME,WAAW;IAEjC,MAAMC,gBAAgBF,YAAYH,mBAAmBD;IAErD,qBAAO,KAACM;QAAe,GAAGH,KAAK;;AACjC,EAAE"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootContext.tsx"],"sourcesContent":["import * as React from 'react';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { ModalElements, ModalsStateEntry, ModalType } from './types';\n\nexport type ModalRegistryEntry = ModalElements & Required<Pick<ModalsStateEntry, 'type' | 'id'>>;\ntype ModalRefs = { [k in keyof ModalElements]: (e: ModalElements[k]) => void };\n\nexport interface ModalRootContextInterface {\n updateModalHeight: VoidFunction;\n registerModal: (data: ModalRegistryEntry) => void;\n onClose?: VoidFunction;\n isInsideModal: boolean;\n}\n\nexport const ModalRootContext = React.createContext<ModalRootContextInterface>({\n updateModalHeight: () => undefined,\n registerModal: () => undefined,\n isInsideModal: false,\n});\n\n/**\n * All referenced elements must be static\n */\nexport function useModalRegistry(id: string | undefined, type: ModalType) {\n const modalContext = React.useContext(ModalRootContext);\n const elements = React.useRef<ModalElements>({}).current;\n useIsomorphicLayoutEffect(() => {\n if (id !== undefined) {\n modalContext.registerModal({ ...elements, type, id });\n // unset refs on unmount to prevent leak\n const reset = Object.keys(elements).reduce<ModalRegistryEntry>(\n (acc, k) => ({ ...acc, [k]: null }),\n { type, id },\n );\n return () => modalContext.registerModal(reset);\n }\n return undefined;\n }, []);\n\n const refs = React.useRef<Required<ModalRefs>>({\n modalElement: (e) => (elements.modalElement = e),\n innerElement: (e) => (elements.innerElement = e),\n headerElement: (e) => (elements.headerElement = e),\n contentElement: (e) => (elements.contentElement = e),\n bottomInset: (e) => (elements.bottomInset = e),\n }).current;\n return { refs };\n}\n"],"names":["React","useIsomorphicLayoutEffect","ModalRootContext","createContext","updateModalHeight","undefined","registerModal","isInsideModal","useModalRegistry","id","type","modalContext","useContext","elements","useRef","current","reset","Object","keys","reduce","acc","k","refs","modalElement","e","innerElement","headerElement","contentElement","bottomInset"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,yBAAyB,QAAQ,sCAAsC;AAahF,OAAO,MAAMC,iCAAmBF,MAAMG,aAAa,CAA4B;IAC7EC,mBAAmB,IAAMC;IACzBC,eAAe,IAAMD;IACrBE,eAAe;AACjB,GAAG;AAEH;;CAEC,GACD,OAAO,SAASC,iBAAiBC,EAAsB,EAAEC,IAAe;IACtE,MAAMC,eAAeX,MAAMY,UAAU,CAACV;IACtC,MAAMW,WAAWb,MAAMc,MAAM,CAAgB,CAAC,GAAGC,OAAO;IACxDd,0BAA0B;QACxB,IAAIQ,OAAOJ,WAAW;YACpBM,aAAaL,aAAa,CAAC;gBAAE,GAAGO,QAAQ;gBAAEH;gBAAMD;YAAG;YACnD,yCAAyC;YACzC,MAAMO,QAAQC,OAAOC,IAAI,CAACL,UAAUM,MAAM,CACxC,CAACC,KAAKC,IAAO,CAAA;oBAAE,GAAGD,GAAG;oBAAE,CAACC,EAAE,EAAE;gBAAK,CAAA,GACjC;gBAAEX;gBAAMD;YAAG;YAEb,OAAO,IAAME,aAAaL,aAAa,CAACU;QAC1C;QACA,OAAOX;IACT,GAAG,EAAE;IAEL,MAAMiB,OAAOtB,MAAMc,MAAM,CAAsB;QAC7CS,cAAc,CAACC,IAAOX,SAASU,YAAY,GAAGC;QAC9CC,cAAc,CAACD,IAAOX,SAASY,YAAY,GAAGD;QAC9CE,eAAe,CAACF,IAAOX,SAASa,aAAa,GAAGF;QAChDG,gBAAgB,CAACH,IAAOX,SAASc,cAAc,GAAGH;QAClDI,aAAa,CAACJ,IAAOX,SAASe,WAAW,GAAGJ;IAC9C,GAAGT,OAAO;IACV,OAAO;QAAEO;IAAK;AAChB"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootContext.tsx"],"sourcesContent":["import * as React from 'react';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { ModalElements, ModalsStateEntry, ModalType } from './types';\n\nexport type ModalRegistryEntry = ModalElements & Required<Pick<ModalsStateEntry, 'type' | 'id'>>;\ntype ModalRefs = { [k in keyof ModalElements]: (e: ModalElements[k]) => void };\n\nexport interface ModalRootContextInterface {\n updateModalHeight: VoidFunction;\n registerModal: (data: ModalRegistryEntry) => void;\n onClose?: VoidFunction;\n isInsideModal: boolean;\n}\n\nexport const ModalRootContext = React.createContext<ModalRootContextInterface>({\n updateModalHeight: () => undefined,\n registerModal: () => undefined,\n isInsideModal: false,\n});\n\n/**\n * All referenced elements must be static\n */\nexport function useModalRegistry(id: string | undefined, type: ModalType) {\n const modalContext = React.useContext(ModalRootContext);\n const elements = React.useRef<ModalElements>({}).current;\n useIsomorphicLayoutEffect(() => {\n if (id !== undefined) {\n modalContext.registerModal({ ...elements, type, id });\n // unset refs on unmount to prevent leak\n const reset = Object.keys(elements).reduce<ModalRegistryEntry>(\n (acc, k) => ({ ...acc, [k]: null }),\n { type, id },\n );\n return () => modalContext.registerModal(reset);\n }\n return undefined;\n }, []);\n\n const refs = React.useRef<Required<ModalRefs>>({\n modalElement: (e) => (elements.modalElement = e),\n innerElement: (e) => (elements.innerElement = e),\n headerElement: (e) => (elements.headerElement = e),\n contentElement: (e) => (elements.contentElement = e),\n bottomInset: (e) => (elements.bottomInset = e),\n }).current;\n return { refs };\n}\n"],"names":["React","useIsomorphicLayoutEffect","ModalRootContext","createContext","updateModalHeight","undefined","registerModal","isInsideModal","useModalRegistry","id","type","modalContext","useContext","elements","useRef","current","reset","Object","keys","reduce","acc","k","refs","modalElement","e","innerElement","headerElement","contentElement","bottomInset"],"mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,yBAAyB,QAAQ,sCAAsC;AAahF,OAAO,MAAMC,iCAAmBF,MAAMG,aAAa,CAA4B;IAC7EC,mBAAmB,IAAMC;IACzBC,eAAe,IAAMD;IACrBE,eAAe;AACjB,GAAG;AAEH;;CAEC,GACD,OAAO,SAASC,iBAAiBC,EAAsB,EAAEC,IAAe;IACtE,MAAMC,eAAeX,MAAMY,UAAU,CAACV;IACtC,MAAMW,WAAWb,MAAMc,MAAM,CAAgB,CAAC,GAAGC,OAAO;IACxDd,0BAA0B;QACxB,IAAIQ,OAAOJ,WAAW;YACpBM,aAAaL,aAAa,CAAC;gBAAE,GAAGO,QAAQ;gBAAEH;gBAAMD;YAAG;YACnD,yCAAyC;YACzC,MAAMO,QAAQC,OAAOC,IAAI,CAACL,UAAUM,MAAM,CACxC,CAACC,KAAKC,IAAO,CAAA;oBAAE,GAAGD,GAAG;oBAAE,CAACC,EAAE,EAAE;gBAAK,CAAA,GACjC;gBAAEX;gBAAMD;YAAG;YAEb,OAAO,IAAME,aAAaL,aAAa,CAACU;QAC1C;QACA,OAAOX;IACT,GAAG,EAAE;IAEL,MAAMiB,OAAOtB,MAAMc,MAAM,CAAsB;QAC7CS,cAAc,CAACC,IAAOX,SAASU,YAAY,GAAGC;QAC9CC,cAAc,CAACD,IAAOX,SAASY,YAAY,GAAGD;QAC9CE,eAAe,CAACF,IAAOX,SAASa,aAAa,GAAGF;QAChDG,gBAAgB,CAACH,IAAOX,SAASc,cAAc,GAAGH;QAClDI,aAAa,CAACJ,IAAOX,SAASe,WAAW,GAAGJ;IAC9C,GAAGT,OAAO;IACV,OAAO;QAAEO;IAAK;AAChB"}
@@ -1 +1 @@
1
- {"version":3,"file":"ModalRootDesktop.d.ts","sourceRoot":"","sources":["../../../../src/components/ModalRoot/ModalRootDesktop.tsx"],"names":[],"mappings":"AAYA,OAAO,EAAE,qBAAqB,EAAoB,MAAM,SAAS,CAAC;AAMlE,eAAO,MAAM,gBAAgB,0HAS1B,qBAAqB,mDAwMvB,CAAC"}
1
+ {"version":3,"file":"ModalRootDesktop.d.ts","sourceRoot":"","sources":["../../../../src/components/ModalRoot/ModalRootDesktop.tsx"],"names":[],"mappings":"AAYA,OAAO,EAAE,qBAAqB,EAAoB,MAAM,SAAS,CAAC;AAMlE,eAAO,MAAM,gBAAgB,0HAS1B,qBAAqB,mDAyMvB,CAAC"}
@@ -21,7 +21,7 @@ export const ModalRootDesktop = ({ activeModal: activeModalProp, children, noFoc
21
21
  const { document } = useDOM();
22
22
  const { hasCustomPanelHeaderAfter, platform } = useConfigProvider();
23
23
  const { activeModal, exitingModal, onExit, getModalState, enteringModal, onEnter, onEntered: onEnteredProp, onExited, history, delayEnter } = useModalManager(activeModalProp, children, onOpen, onOpened, onClose, onClosed, noop);
24
- const { waitTransitionFinish } = useWaitTransitionFinish();
24
+ const waitTransitionFinish = useWaitTransitionFinish();
25
25
  const prevProps = usePrevious({
26
26
  exitingModal,
27
27
  enteringModal,
@@ -153,6 +153,7 @@ export const ModalRootDesktop = ({ activeModal: activeModalProp, children, noFoc
153
153
  }
154
154
  const key = `modal-${modalId}`;
155
155
  return /*#__PURE__*/ _jsx(FocusTrap, {
156
+ autoFocus: false,
156
157
  restoreFocus: false,
157
158
  onClose: onExit,
158
159
  timeout: timeout,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootDesktop.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, noop } from '@vkontakte/vkjs';\nimport { clamp } from '../../helpers/math';\nimport { useObjectMemo } from '../../hooks/useObjectMemo';\nimport { usePrevious } from '../../hooks/usePrevious';\nimport { useWaitTransitionFinish } from '../../hooks/useWaitTransitionFinish';\nimport { useDOM } from '../../lib/dom';\nimport { getNavId } from '../../lib/getNavId';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { useConfigProvider } from '../ConfigProvider/ConfigProviderContext';\nimport { FocusTrap } from '../FocusTrap/FocusTrap';\nimport { ModalRootContext, ModalRootContextInterface } from './ModalRootContext';\nimport { ModalRootWithDOMProps, ModalsStateEntry } from './types';\nimport { useModalManager } from './useModalManager';\nimport styles from './ModalRoot.module.css';\n\nconst warn = warnOnce('ModalRoot');\n\nexport const ModalRootDesktop = ({\n activeModal: activeModalProp,\n children,\n noFocusToDialog = false,\n onOpen,\n onOpened,\n onClose,\n onClosed,\n modalOverlayTestId,\n}: ModalRootWithDOMProps) => {\n const maskElementRef = React.useRef<HTMLDivElement>(null);\n const maskAnimationFrame = React.useRef<number | undefined>(undefined);\n const restoreFocusTo = React.useRef<HTMLElement | undefined>(undefined);\n\n const { document } = useDOM();\n const { hasCustomPanelHeaderAfter, platform } = useConfigProvider();\n const {\n activeModal,\n exitingModal,\n onExit,\n getModalState,\n enteringModal,\n onEnter,\n onEntered: onEnteredProp,\n onExited,\n history,\n delayEnter,\n } = useModalManager(activeModalProp, children, onOpen, onOpened, onClose, onClosed, noop);\n\n const { waitTransitionFinish } = useWaitTransitionFinish();\n const prevProps = usePrevious({\n exitingModal,\n enteringModal,\n activeModal,\n });\n const modalRootContext: ModalRootContextInterface = useObjectMemo({\n updateModalHeight: () => undefined,\n registerModal: ({ id, ...data }) => Object.assign(getModalState(id) ?? {}, data),\n onClose: onExit,\n isInsideModal: true,\n });\n\n const timeout = platform === 'ios' ? 400 : 320;\n const modals = React.Children.toArray(children) as React.ReactElement[];\n\n /* Анимирует сдвиг модального окна */\n const animateModalOpacity = (modalState: ModalsStateEntry | undefined, display: boolean) => {\n if (modalState?.innerElement) {\n modalState.innerElement.style.transition = '';\n modalState.innerElement.style.transitionDelay = display && delayEnter ? `${timeout}ms` : '';\n modalState.innerElement.style.opacity = display ? '1' : '0';\n }\n };\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n const setMaskOpacity = (modalState: ModalsStateEntry, forceOpacity: number | null = null) => {\n if (forceOpacity === null && history?.[0] !== modalState.id) {\n return;\n }\n\n if (maskAnimationFrame.current) {\n cancelAnimationFrame(maskAnimationFrame.current);\n }\n maskAnimationFrame.current = requestAnimationFrame(() => {\n if (maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n maskElementRef.current.style.opacity = clamp(opacity, 0, 100).toString();\n }\n });\n };\n\n const onEntered = ({ id, modalElement }: ModalsStateEntry) => {\n if (!noFocusToDialog && modalElement && !modalElement.contains(document!.activeElement)) {\n modalElement.focus();\n }\n\n onEnteredProp(id);\n };\n\n const openModal = () => {\n if (!enteringModal || !prevProps) {\n return;\n }\n\n const enteringState = getModalState(enteringModal);\n onEnter();\n\n // Анимация открытия модального окна\n if (!prevProps.exitingModal) {\n requestAnimationFrame(() => {\n if (enteringModal === enteringModal && enteringState) {\n waitTransitionFinish(enteringState.innerElement, () => onEntered(enteringState), timeout);\n animateModalOpacity(enteringState, true);\n setMaskOpacity(enteringState, 1);\n }\n });\n\n return;\n }\n\n // Переход между модальными окнами без анимации\n requestAnimationFrame(() => {\n if (enteringState?.innerElement) {\n enteringState.innerElement.style.transition = 'none';\n enteringState.innerElement.style.opacity = '1';\n setMaskOpacity(enteringState, 1);\n }\n });\n\n if (enteringState) {\n onEntered(enteringState);\n }\n };\n\n const closeModal = (id: string) => {\n const prevModalState = getModalState(id);\n if (!prevModalState) {\n return;\n }\n\n // Анимация закрытия модального окна\n if (!activeModal) {\n requestAnimationFrame(() => {\n waitTransitionFinish(prevModalState?.innerElement, () => onExited(id), timeout);\n animateModalOpacity(prevModalState, false);\n setMaskOpacity(prevModalState, 0);\n });\n\n return;\n }\n\n // Переход между модальными окнами без анимации\n onExited(id);\n };\n\n React.useEffect(() => {\n if (!prevProps) {\n return;\n }\n\n // transition phase 2: animate exiting modal\n if (exitingModal && exitingModal !== prevProps.exitingModal) {\n closeModal(exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (enteringModal && enteringModal !== prevProps.enteringModal) {\n openModal();\n }\n\n // focus restoration\n if (activeModal && !prevProps.activeModal) {\n restoreFocusTo.current = (document?.activeElement ?? undefined) as HTMLElement | undefined;\n }\n if (!activeModal && !exitingModal && restoreFocusTo.current) {\n restoreFocusTo.current.focus();\n restoreFocusTo.current = undefined;\n }\n });\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <ModalRootContext.Provider value={modalRootContext}>\n <div\n className={classNames(\n styles['ModalRoot'],\n hasCustomPanelHeaderAfter && styles['ModalRoot--hasCustomPanelHeaderAfterSlot'],\n styles['ModalRoot--desktop'],\n )}\n >\n <div\n data-testid={modalOverlayTestId}\n className={styles['ModalRoot__mask']}\n ref={maskElementRef}\n onClick={onExit}\n />\n <div className={styles['ModalRoot__viewport']}>\n {modals.map((Modal: React.ReactElement) => {\n const modalId = getNavId(Modal.props, warn);\n if (modalId !== activeModal && modalId !== exitingModal) {\n return null;\n }\n\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n restoreFocus={false}\n onClose={onExit}\n timeout={timeout}\n key={key}\n className={styles['ModalRoot__modal']}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </div>\n </ModalRootContext.Provider>\n );\n};\n"],"names":["React","classNames","noop","clamp","useObjectMemo","usePrevious","useWaitTransitionFinish","useDOM","getNavId","warnOnce","useConfigProvider","FocusTrap","ModalRootContext","useModalManager","styles","warn","ModalRootDesktop","activeModal","activeModalProp","children","noFocusToDialog","onOpen","onOpened","onClose","onClosed","modalOverlayTestId","maskElementRef","useRef","maskAnimationFrame","undefined","restoreFocusTo","document","hasCustomPanelHeaderAfter","platform","exitingModal","onExit","getModalState","enteringModal","onEnter","onEntered","onEnteredProp","onExited","history","delayEnter","waitTransitionFinish","prevProps","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","isInsideModal","timeout","modals","Children","toArray","animateModalOpacity","modalState","display","innerElement","style","transition","transitionDelay","opacity","setMaskOpacity","forceOpacity","current","cancelAnimationFrame","requestAnimationFrame","translateY","translateYCurrent","toString","modalElement","contains","activeElement","focus","openModal","enteringState","closeModal","prevModalState","useEffect","Provider","value","div","className","data-testid","ref","onClick","map","Modal","modalId","props","key","restoreFocus"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootDesktop.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, noop } from '@vkontakte/vkjs';\nimport { clamp } from '../../helpers/math';\nimport { useObjectMemo } from '../../hooks/useObjectMemo';\nimport { usePrevious } from '../../hooks/usePrevious';\nimport { useWaitTransitionFinish } from '../../hooks/useWaitTransitionFinish';\nimport { useDOM } from '../../lib/dom';\nimport { getNavId } from '../../lib/getNavId';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { useConfigProvider } from '../ConfigProvider/ConfigProviderContext';\nimport { FocusTrap } from '../FocusTrap/FocusTrap';\nimport { ModalRootContext, ModalRootContextInterface } from './ModalRootContext';\nimport { ModalRootWithDOMProps, ModalsStateEntry } from './types';\nimport { useModalManager } from './useModalManager';\nimport styles from './ModalRoot.module.css';\n\nconst warn = warnOnce('ModalRoot');\n\nexport const ModalRootDesktop = ({\n activeModal: activeModalProp,\n children,\n noFocusToDialog = false,\n onOpen,\n onOpened,\n onClose,\n onClosed,\n modalOverlayTestId,\n}: ModalRootWithDOMProps) => {\n const maskElementRef = React.useRef<HTMLDivElement>(null);\n const maskAnimationFrame = React.useRef<number | undefined>(undefined);\n const restoreFocusTo = React.useRef<HTMLElement | undefined>(undefined);\n\n const { document } = useDOM();\n const { hasCustomPanelHeaderAfter, platform } = useConfigProvider();\n const {\n activeModal,\n exitingModal,\n onExit,\n getModalState,\n enteringModal,\n onEnter,\n onEntered: onEnteredProp,\n onExited,\n history,\n delayEnter,\n } = useModalManager(activeModalProp, children, onOpen, onOpened, onClose, onClosed, noop);\n\n const waitTransitionFinish = useWaitTransitionFinish();\n const prevProps = usePrevious({\n exitingModal,\n enteringModal,\n activeModal,\n });\n const modalRootContext: ModalRootContextInterface = useObjectMemo({\n updateModalHeight: () => undefined,\n registerModal: ({ id, ...data }) => Object.assign(getModalState(id) ?? {}, data),\n onClose: onExit,\n isInsideModal: true,\n });\n\n const timeout = platform === 'ios' ? 400 : 320;\n const modals = React.Children.toArray(children) as React.ReactElement[];\n\n /* Анимирует сдвиг модального окна */\n const animateModalOpacity = (modalState: ModalsStateEntry | undefined, display: boolean) => {\n if (modalState?.innerElement) {\n modalState.innerElement.style.transition = '';\n modalState.innerElement.style.transitionDelay = display && delayEnter ? `${timeout}ms` : '';\n modalState.innerElement.style.opacity = display ? '1' : '0';\n }\n };\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n const setMaskOpacity = (modalState: ModalsStateEntry, forceOpacity: number | null = null) => {\n if (forceOpacity === null && history?.[0] !== modalState.id) {\n return;\n }\n\n if (maskAnimationFrame.current) {\n cancelAnimationFrame(maskAnimationFrame.current);\n }\n maskAnimationFrame.current = requestAnimationFrame(() => {\n if (maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n maskElementRef.current.style.opacity = clamp(opacity, 0, 100).toString();\n }\n });\n };\n\n const onEntered = ({ id, modalElement }: ModalsStateEntry) => {\n if (!noFocusToDialog && modalElement && !modalElement.contains(document!.activeElement)) {\n modalElement.focus();\n }\n\n onEnteredProp(id);\n };\n\n const openModal = () => {\n if (!enteringModal || !prevProps) {\n return;\n }\n\n const enteringState = getModalState(enteringModal);\n onEnter();\n\n // Анимация открытия модального окна\n if (!prevProps.exitingModal) {\n requestAnimationFrame(() => {\n if (enteringModal === enteringModal && enteringState) {\n waitTransitionFinish(enteringState.innerElement, () => onEntered(enteringState), timeout);\n animateModalOpacity(enteringState, true);\n setMaskOpacity(enteringState, 1);\n }\n });\n\n return;\n }\n\n // Переход между модальными окнами без анимации\n requestAnimationFrame(() => {\n if (enteringState?.innerElement) {\n enteringState.innerElement.style.transition = 'none';\n enteringState.innerElement.style.opacity = '1';\n setMaskOpacity(enteringState, 1);\n }\n });\n\n if (enteringState) {\n onEntered(enteringState);\n }\n };\n\n const closeModal = (id: string) => {\n const prevModalState = getModalState(id);\n if (!prevModalState) {\n return;\n }\n\n // Анимация закрытия модального окна\n if (!activeModal) {\n requestAnimationFrame(() => {\n waitTransitionFinish(prevModalState?.innerElement, () => onExited(id), timeout);\n animateModalOpacity(prevModalState, false);\n setMaskOpacity(prevModalState, 0);\n });\n\n return;\n }\n\n // Переход между модальными окнами без анимации\n onExited(id);\n };\n\n React.useEffect(() => {\n if (!prevProps) {\n return;\n }\n\n // transition phase 2: animate exiting modal\n if (exitingModal && exitingModal !== prevProps.exitingModal) {\n closeModal(exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (enteringModal && enteringModal !== prevProps.enteringModal) {\n openModal();\n }\n\n // focus restoration\n if (activeModal && !prevProps.activeModal) {\n restoreFocusTo.current = (document?.activeElement ?? undefined) as HTMLElement | undefined;\n }\n if (!activeModal && !exitingModal && restoreFocusTo.current) {\n restoreFocusTo.current.focus();\n restoreFocusTo.current = undefined;\n }\n });\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <ModalRootContext.Provider value={modalRootContext}>\n <div\n className={classNames(\n styles['ModalRoot'],\n hasCustomPanelHeaderAfter && styles['ModalRoot--hasCustomPanelHeaderAfterSlot'],\n styles['ModalRoot--desktop'],\n )}\n >\n <div\n data-testid={modalOverlayTestId}\n className={styles['ModalRoot__mask']}\n ref={maskElementRef}\n onClick={onExit}\n />\n <div className={styles['ModalRoot__viewport']}>\n {modals.map((Modal: React.ReactElement) => {\n const modalId = getNavId(Modal.props, warn);\n if (modalId !== activeModal && modalId !== exitingModal) {\n return null;\n }\n\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n autoFocus={false}\n restoreFocus={false}\n onClose={onExit}\n timeout={timeout}\n key={key}\n className={styles['ModalRoot__modal']}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </div>\n </ModalRootContext.Provider>\n );\n};\n"],"names":["React","classNames","noop","clamp","useObjectMemo","usePrevious","useWaitTransitionFinish","useDOM","getNavId","warnOnce","useConfigProvider","FocusTrap","ModalRootContext","useModalManager","styles","warn","ModalRootDesktop","activeModal","activeModalProp","children","noFocusToDialog","onOpen","onOpened","onClose","onClosed","modalOverlayTestId","maskElementRef","useRef","maskAnimationFrame","undefined","restoreFocusTo","document","hasCustomPanelHeaderAfter","platform","exitingModal","onExit","getModalState","enteringModal","onEnter","onEntered","onEnteredProp","onExited","history","delayEnter","waitTransitionFinish","prevProps","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","isInsideModal","timeout","modals","Children","toArray","animateModalOpacity","modalState","display","innerElement","style","transition","transitionDelay","opacity","setMaskOpacity","forceOpacity","current","cancelAnimationFrame","requestAnimationFrame","translateY","translateYCurrent","toString","modalElement","contains","activeElement","focus","openModal","enteringState","closeModal","prevModalState","useEffect","Provider","value","div","className","data-testid","ref","onClick","map","Modal","modalId","props","key","autoFocus","restoreFocus"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/constants.ts"],"sourcesContent":["export const MODAL_PAGE_DEFAULT_PERCENT_HEIGHT = 75;\n\nexport const PERCENT_OPENED = 0;\nexport const PERCENT_CLOSED = 100;\n"],"names":["MODAL_PAGE_DEFAULT_PERCENT_HEIGHT","PERCENT_OPENED","PERCENT_CLOSED"],"rangeMappings":";;","mappings":"AAAA,OAAO,MAAMA,oCAAoC,GAAG;AAEpD,OAAO,MAAMC,iBAAiB,EAAE;AAChC,OAAO,MAAMC,iBAAiB,IAAI"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/constants.ts"],"sourcesContent":["export const MODAL_PAGE_DEFAULT_PERCENT_HEIGHT = 75;\n\nexport const PERCENT_OPENED = 0;\nexport const PERCENT_CLOSED = 100;\n"],"names":["MODAL_PAGE_DEFAULT_PERCENT_HEIGHT","PERCENT_OPENED","PERCENT_CLOSED"],"mappings":"AAAA,OAAO,MAAMA,oCAAoC,GAAG;AAEpD,OAAO,MAAMC,iBAAiB,EAAE;AAChC,OAAO,MAAMC,iBAAiB,IAAI"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import { DOMContextInterface } from '../../lib/dom';
3
2
  import { HasPlatform } from '../../types';
4
3
  import { ConfigProviderContextInterface } from '../ConfigProvider/ConfigProviderContext';