@vkontakte/vkui 7.1.3 → 7.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 (1131) hide show
  1. package/dist/components/Accordion/Accordion.d.ts +2 -2
  2. package/dist/components/Accordion/Accordion.d.ts.map +1 -1
  3. package/dist/components/Accordion/Accordion.js.map +1 -1
  4. package/dist/components/ActionSheet/ActionSheet.d.ts +1 -1
  5. package/dist/components/ActionSheet/ActionSheet.d.ts.map +1 -1
  6. package/dist/components/ActionSheet/ActionSheet.js +1 -1
  7. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  8. package/dist/components/ActionSheet/ActionSheetDefaultIosCloseItem.d.ts.map +1 -1
  9. package/dist/components/ActionSheet/ActionSheetDropdownMenu.d.ts +1 -1
  10. package/dist/components/ActionSheet/ActionSheetDropdownMenu.d.ts.map +1 -1
  11. package/dist/components/ActionSheet/ActionSheetDropdownMenu.js +10 -4
  12. package/dist/components/ActionSheet/ActionSheetDropdownMenu.js.map +1 -1
  13. package/dist/components/ActionSheet/ActionSheetDropdownSheet.d.ts +1 -1
  14. package/dist/components/ActionSheet/ActionSheetDropdownSheet.d.ts.map +1 -1
  15. package/dist/components/ActionSheet/ActionSheetDropdownSheet.js +10 -4
  16. package/dist/components/ActionSheet/ActionSheetDropdownSheet.js.map +1 -1
  17. package/dist/components/ActionSheet/types.d.ts +4 -0
  18. package/dist/components/ActionSheet/types.d.ts.map +1 -1
  19. package/dist/components/ActionSheet/types.js.map +1 -1
  20. package/dist/components/ActionSheetItem/ActionSheetItem.d.ts.map +1 -1
  21. package/dist/components/ActionSheetItem/helpers.d.ts.map +1 -1
  22. package/dist/components/ActionSheetItem/subcomponents/Radio/Radio.d.ts.map +1 -1
  23. package/dist/components/AdaptiveIconRenderer/AdaptiveIconRenderer.d.ts.map +1 -1
  24. package/dist/components/AdaptivityProvider/AdaptivityProvider.d.ts.map +1 -1
  25. package/dist/components/Alert/Alert.d.ts +14 -2
  26. package/dist/components/Alert/Alert.d.ts.map +1 -1
  27. package/dist/components/Alert/Alert.js +15 -104
  28. package/dist/components/Alert/Alert.js.map +1 -1
  29. package/dist/components/Alert/AlertAction.d.ts.map +1 -1
  30. package/dist/components/Alert/AlertActions.d.ts.map +1 -1
  31. package/dist/components/Alert/AlertBase.d.ts +7 -0
  32. package/dist/components/Alert/AlertBase.d.ts.map +1 -0
  33. package/dist/components/Alert/AlertBase.js +131 -0
  34. package/dist/components/Alert/AlertBase.js.map +1 -0
  35. package/dist/components/Alert/AlertTypography.d.ts +2 -1
  36. package/dist/components/Alert/AlertTypography.d.ts.map +1 -1
  37. package/dist/components/Alert/AlertTypography.js.map +1 -1
  38. package/dist/components/AppRoot/AppRoot.d.ts.map +1 -1
  39. package/dist/components/AppRoot/AppRootPortal.d.ts.map +1 -1
  40. package/dist/components/AppRoot/AppRootStyleContainer/AppRootStyleContainer.js +1 -1
  41. package/dist/components/AppRoot/AppRootStyleContainer/AppRootStyleContainer.js.map +1 -1
  42. package/dist/components/AppRoot/ScrollContext.d.ts +1 -0
  43. package/dist/components/AppRoot/ScrollContext.d.ts.map +1 -1
  44. package/dist/components/AppRoot/ScrollContext.js +127 -39
  45. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  46. package/dist/components/AppRoot/helpers.d.ts.map +1 -1
  47. package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.d.ts.map +1 -1
  48. package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js +4 -1
  49. package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  50. package/dist/components/Avatar/AvatarBadge/icons.d.ts.map +1 -1
  51. package/dist/components/Badge/Badge.d.ts.map +1 -1
  52. package/dist/components/Banner/Banner.d.ts.map +1 -1
  53. package/dist/components/Button/Button.d.ts.map +1 -1
  54. package/dist/components/ButtonGroup/ButtonGroup.d.ts +4 -1
  55. package/dist/components/ButtonGroup/ButtonGroup.d.ts.map +1 -1
  56. package/dist/components/ButtonGroup/ButtonGroup.js +1 -0
  57. package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -1
  58. package/dist/components/Calendar/Calendar.d.ts +7 -2
  59. package/dist/components/Calendar/Calendar.d.ts.map +1 -1
  60. package/dist/components/Calendar/Calendar.js +98 -92
  61. package/dist/components/Calendar/Calendar.js.map +1 -1
  62. package/dist/components/CalendarDay/CalendarDay.d.ts.map +1 -1
  63. package/dist/components/CalendarDay/CalendarDay.js +1 -3
  64. package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
  65. package/dist/components/CalendarDays/CalendarDays.d.ts.map +1 -1
  66. package/dist/components/CalendarHeader/CalendarHeader.d.ts.map +1 -1
  67. package/dist/components/CalendarHeader/CalendarHeader.js +1 -3
  68. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
  69. package/dist/components/CalendarRange/CalendarRange.d.ts +3 -2
  70. package/dist/components/CalendarRange/CalendarRange.d.ts.map +1 -1
  71. package/dist/components/CalendarRange/CalendarRange.js +102 -108
  72. package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
  73. package/dist/components/CalendarTime/CalendarTime.d.ts.map +1 -1
  74. package/dist/components/Card/Card.d.ts.map +1 -1
  75. package/dist/components/CardGrid/CardGrid.d.ts.map +1 -1
  76. package/dist/components/CardScroll/CardScroll.d.ts +5 -1
  77. package/dist/components/CardScroll/CardScroll.d.ts.map +1 -1
  78. package/dist/components/CardScroll/CardScroll.js +32 -29
  79. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  80. package/dist/components/CarouselBase/CarouselBase.d.ts.map +1 -1
  81. package/dist/components/CarouselBase/CarouselBase.js +71 -46
  82. package/dist/components/CarouselBase/CarouselBase.js.map +1 -1
  83. package/dist/components/CarouselBase/ScrollArrows.d.ts.map +1 -1
  84. package/dist/components/CarouselBase/helpers.d.ts +20 -5
  85. package/dist/components/CarouselBase/helpers.d.ts.map +1 -1
  86. package/dist/components/CarouselBase/helpers.js +70 -44
  87. package/dist/components/CarouselBase/helpers.js.map +1 -1
  88. package/dist/components/Cell/CellCheckbox/CellCheckbox.d.ts.map +1 -1
  89. package/dist/components/Cell/CellDragger/CellDragger.d.ts.map +1 -1
  90. package/dist/components/CellButton/CellButton.d.ts.map +1 -1
  91. package/dist/components/CellButtonGroup/CellButtonGroup.d.ts +300 -0
  92. package/dist/components/CellButtonGroup/CellButtonGroup.d.ts.map +1 -0
  93. package/dist/components/CellButtonGroup/CellButtonGroup.js +20 -0
  94. package/dist/components/CellButtonGroup/CellButtonGroup.js.map +1 -0
  95. package/dist/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.d.ts +8 -0
  96. package/dist/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.d.ts.map +1 -0
  97. package/dist/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.js +20 -0
  98. package/dist/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.js.map +1 -0
  99. package/dist/components/ChipsInput/ChipsInput.d.ts.map +1 -1
  100. package/dist/components/ChipsInput/useChipsInput.d.ts.map +1 -1
  101. package/dist/components/ChipsInputBase/Chip/Chip.d.ts.map +1 -1
  102. package/dist/components/ChipsInputBase/ChipsInputBase.d.ts.map +1 -1
  103. package/dist/components/ChipsInputBase/helpers.d.ts.map +1 -1
  104. package/dist/components/ChipsSelect/ChipsSelect.d.ts +1 -1
  105. package/dist/components/ChipsSelect/ChipsSelect.d.ts.map +1 -1
  106. package/dist/components/ChipsSelect/ChipsSelect.js +3 -1
  107. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  108. package/dist/components/ChipsSelect/constants.d.ts.map +1 -1
  109. package/dist/components/ChipsSelect/useChipsSelect.d.ts +3 -2
  110. package/dist/components/ChipsSelect/useChipsSelect.d.ts.map +1 -1
  111. package/dist/components/ChipsSelect/useChipsSelect.js +9 -3
  112. package/dist/components/ChipsSelect/useChipsSelect.js.map +1 -1
  113. package/dist/components/Clickable/Clickable.d.ts +1 -1
  114. package/dist/components/Clickable/Clickable.d.ts.map +1 -1
  115. package/dist/components/Clickable/Clickable.js +28 -28
  116. package/dist/components/Clickable/Clickable.js.map +1 -1
  117. package/dist/components/Clickable/RealClickable.d.ts.map +1 -1
  118. package/dist/components/ColorSchemeProvider/ColorSchemeProvider.d.ts.map +1 -1
  119. package/dist/components/ColorSchemeProvider/ColorSchemeProvider.js +1 -1
  120. package/dist/components/ColorSchemeProvider/ColorSchemeProvider.js.map +1 -1
  121. package/dist/components/ConfigProvider/ConfigProvider.d.ts.map +1 -1
  122. package/dist/components/ConfigProvider/ConfigProvider.js +5 -2
  123. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  124. package/dist/components/ConfigProvider/ConfigProviderContext.d.ts +11 -1
  125. package/dist/components/ConfigProvider/ConfigProviderContext.d.ts.map +1 -1
  126. package/dist/components/ConfigProvider/ConfigProviderContext.js +12 -7
  127. package/dist/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  128. package/dist/components/ContentCard/ContentCard.d.ts +6 -1
  129. package/dist/components/ContentCard/ContentCard.d.ts.map +1 -1
  130. package/dist/components/ContentCard/ContentCard.js +6 -4
  131. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  132. package/dist/components/Counter/Counter.d.ts.map +1 -1
  133. package/dist/components/CustomScrollView/CustomScrollView.d.ts.map +1 -1
  134. package/dist/components/CustomSelect/CustomSelect.d.ts.map +1 -1
  135. package/dist/components/CustomSelect/CustomSelect.js +105 -69
  136. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  137. package/dist/components/CustomSelect/CustomSelectClearButton.d.ts.map +1 -1
  138. package/dist/components/CustomSelect/CustomSelectInput/CustomSelectInput.d.ts.map +1 -1
  139. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts.map +1 -1
  140. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js +2 -1
  141. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  142. package/dist/components/CustomSelectOption/CustomSelectOption.d.ts.map +1 -1
  143. package/dist/components/DateInput/DateInput.d.ts +11 -2
  144. package/dist/components/DateInput/DateInput.d.ts.map +1 -1
  145. package/dist/components/DateInput/DateInput.js +108 -82
  146. package/dist/components/DateInput/DateInput.js.map +1 -1
  147. package/dist/components/DateInput/hooks.d.ts +15 -0
  148. package/dist/components/DateInput/hooks.d.ts.map +1 -0
  149. package/dist/components/DateInput/hooks.js +54 -0
  150. package/dist/components/DateInput/hooks.js.map +1 -0
  151. package/dist/components/DateRangeInput/DateRangeInput.d.ts +2 -2
  152. package/dist/components/DateRangeInput/DateRangeInput.d.ts.map +1 -1
  153. package/dist/components/DateRangeInput/DateRangeInput.js +100 -82
  154. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  155. package/dist/components/DirectionProvider/DirectionProvider.d.ts +13 -0
  156. package/dist/components/DirectionProvider/DirectionProvider.d.ts.map +1 -0
  157. package/dist/components/DirectionProvider/DirectionProvider.js +15 -0
  158. package/dist/components/DirectionProvider/DirectionProvider.js.map +1 -0
  159. package/dist/components/Div/Div.d.ts.map +1 -1
  160. package/dist/components/DropdownIcon/DropdownIcon.d.ts.map +1 -1
  161. package/dist/components/Epic/Epic.d.ts.map +1 -1
  162. package/dist/components/Epic/ScrollSaver.d.ts.map +1 -1
  163. package/dist/components/File/File.d.ts.map +1 -1
  164. package/dist/components/FixedLayout/FixedLayout.d.ts.map +1 -1
  165. package/dist/components/Flex/Flex.d.ts.map +1 -1
  166. package/dist/components/Flex/Flex.js +3 -5
  167. package/dist/components/Flex/Flex.js.map +1 -1
  168. package/dist/components/Flex/FlexItem/FlexItem.d.ts.map +1 -1
  169. package/dist/components/FloatingArrow/DefaultIcon.d.ts.map +1 -1
  170. package/dist/components/FloatingArrow/FloatingArrow.d.ts.map +1 -1
  171. package/dist/components/FocusTrap/FocusTrap.d.ts.map +1 -1
  172. package/dist/components/Footer/Footer.d.ts.map +1 -1
  173. package/dist/components/FormField/FormField.d.ts.map +1 -1
  174. package/dist/components/FormFieldClearButton/FormFieldClearButton.d.ts.map +1 -1
  175. package/dist/components/FormLayoutGroup/FormLayoutGroup.d.ts.map +1 -1
  176. package/dist/components/FormStatus/FormStatus.d.ts.map +1 -1
  177. package/dist/components/Gallery/Gallery.d.ts.map +1 -1
  178. package/dist/components/Gradient/Gradient.d.ts.map +1 -1
  179. package/dist/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.d.ts.map +1 -1
  180. package/dist/components/Header/Header.d.ts.map +1 -1
  181. package/dist/components/HorizontalCell/HorizontalCell.d.ts.map +1 -1
  182. package/dist/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.d.ts.map +1 -1
  183. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +13 -1
  184. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts.map +1 -1
  185. package/dist/components/HorizontalScroll/HorizontalScroll.js +32 -24
  186. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  187. package/dist/components/IconButton/IconButton.d.ts.map +1 -1
  188. package/dist/components/ImageBase/ImageBase.d.ts +5 -0
  189. package/dist/components/ImageBase/ImageBase.d.ts.map +1 -1
  190. package/dist/components/ImageBase/ImageBase.js +6 -4
  191. package/dist/components/ImageBase/ImageBase.js.map +1 -1
  192. package/dist/components/ImageBase/ImageBaseFloatElement/helpers.d.ts.map +1 -1
  193. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.d.ts.map +1 -1
  194. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js +3 -4
  195. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  196. package/dist/components/ImageBase/ImageBaseOverlay/hooks.d.ts +1 -0
  197. package/dist/components/ImageBase/ImageBaseOverlay/hooks.d.ts.map +1 -1
  198. package/dist/components/ImageBase/ImageBaseOverlay/hooks.js +25 -0
  199. package/dist/components/ImageBase/ImageBaseOverlay/hooks.js.map +1 -1
  200. package/dist/components/ImageBase/ImageBaseOverlay/types.d.ts +4 -0
  201. package/dist/components/ImageBase/ImageBaseOverlay/types.d.ts.map +1 -1
  202. package/dist/components/ImageBase/ImageBaseOverlay/types.js.map +1 -1
  203. package/dist/components/InfoRow/InfoRow.d.ts.map +1 -1
  204. package/dist/components/Input/Input.d.ts.map +1 -1
  205. package/dist/components/InputLike/InputLikeDivider.d.ts.map +1 -1
  206. package/dist/components/Link/Link.d.ts.map +1 -1
  207. package/dist/components/List/List.d.ts.map +1 -1
  208. package/dist/components/Mark/Mark.d.ts.map +1 -1
  209. package/dist/components/MiniInfoCell/MiniInfoCell.d.ts.map +1 -1
  210. package/dist/components/ModalCard/ModalCard.d.ts.map +1 -1
  211. package/dist/components/ModalCard/ModalCard.js +2 -1
  212. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  213. package/dist/components/ModalCard/ModalCardInternal.d.ts +1 -1
  214. package/dist/components/ModalCard/ModalCardInternal.d.ts.map +1 -1
  215. package/dist/components/ModalCard/ModalCardInternal.js +4 -2
  216. package/dist/components/ModalCard/ModalCardInternal.js.map +1 -1
  217. package/dist/components/ModalCard/types.d.ts +1 -1
  218. package/dist/components/ModalCard/types.d.ts.map +1 -1
  219. package/dist/components/ModalCard/types.js.map +1 -1
  220. package/dist/components/ModalCardBase/ModalCardBase.d.ts +9 -1
  221. package/dist/components/ModalCardBase/ModalCardBase.d.ts.map +1 -1
  222. package/dist/components/ModalCardBase/ModalCardBase.js +33 -8
  223. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  224. package/dist/components/ModalDismissButton/ModalDismissButton.d.ts +5 -3
  225. package/dist/components/ModalDismissButton/ModalDismissButton.d.ts.map +1 -1
  226. package/dist/components/ModalDismissButton/ModalDismissButton.js +7 -7
  227. package/dist/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  228. package/dist/components/ModalOutlet/ModalOutlet.d.ts.map +1 -1
  229. package/dist/components/ModalOutsideButton/ModalOutsideButton.d.ts +17 -0
  230. package/dist/components/ModalOutsideButton/ModalOutsideButton.d.ts.map +1 -0
  231. package/dist/components/ModalOutsideButton/ModalOutsideButton.js +30 -0
  232. package/dist/components/ModalOutsideButton/ModalOutsideButton.js.map +1 -0
  233. package/dist/components/ModalOutsideButtons/ModalOutsideButtons.d.ts +6 -0
  234. package/dist/components/ModalOutsideButtons/ModalOutsideButtons.d.ts.map +1 -0
  235. package/dist/components/ModalOutsideButtons/ModalOutsideButtons.js +22 -0
  236. package/dist/components/ModalOutsideButtons/ModalOutsideButtons.js.map +1 -0
  237. package/dist/components/ModalOverlay/ModalOverlay.d.ts.map +1 -1
  238. package/dist/components/ModalPage/ModalPage.d.ts.map +1 -1
  239. package/dist/components/ModalPage/ModalPageBase.d.ts +8 -0
  240. package/dist/components/ModalPage/ModalPageBase.d.ts.map +1 -0
  241. package/dist/components/ModalPage/ModalPageBase.js +66 -0
  242. package/dist/components/ModalPage/ModalPageBase.js.map +1 -0
  243. package/dist/components/ModalPage/ModalPageInternal.d.ts +1 -1
  244. package/dist/components/ModalPage/ModalPageInternal.d.ts.map +1 -1
  245. package/dist/components/ModalPage/ModalPageInternal.js +24 -32
  246. package/dist/components/ModalPage/ModalPageInternal.js.map +1 -1
  247. package/dist/components/ModalPage/types.d.ts +12 -1
  248. package/dist/components/ModalPage/types.d.ts.map +1 -1
  249. package/dist/components/ModalPage/types.js.map +1 -1
  250. package/dist/components/ModalPageContent/ModalPageContent.d.ts.map +1 -1
  251. package/dist/components/ModalPageFooter/ModalPageFooter.d.ts.map +1 -1
  252. package/dist/components/ModalPageHeader/ModalPageHeader.d.ts.map +1 -1
  253. package/dist/components/ModalRoot/ModalRoot.d.ts.map +1 -1
  254. package/dist/components/ModalRoot/VisuallyHiddenModalOverlay/VisuallyHiddenModalOverlay.d.ts.map +1 -1
  255. package/dist/components/ModalRoot/useModalManager.d.ts.map +1 -1
  256. package/dist/components/NativeSelect/NativeSelect.d.ts.map +1 -1
  257. package/dist/components/NavTransitionContext/NavTransitionContext.d.ts.map +1 -1
  258. package/dist/components/NavTransitionDirectionContext/NavTransitionDirectionContext.d.ts.map +1 -1
  259. package/dist/components/OnboardingTooltip/OnboardingTooltip.d.ts +2 -2
  260. package/dist/components/OnboardingTooltip/OnboardingTooltip.d.ts.map +1 -1
  261. package/dist/components/OnboardingTooltip/OnboardingTooltip.js +22 -8
  262. package/dist/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  263. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts.map +1 -1
  264. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.js +12 -3
  265. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.js.map +1 -1
  266. package/dist/components/OnboardingTooltip/OnboardingTooltipContext.d.ts +7 -0
  267. package/dist/components/OnboardingTooltip/OnboardingTooltipContext.d.ts.map +1 -0
  268. package/dist/components/OnboardingTooltip/OnboardingTooltipContext.js +9 -0
  269. package/dist/components/OnboardingTooltip/OnboardingTooltipContext.js.map +1 -0
  270. package/dist/components/Pagination/Pagination.d.ts.map +1 -1
  271. package/dist/components/Pagination/Pagination.js +5 -2
  272. package/dist/components/Pagination/Pagination.js.map +1 -1
  273. package/dist/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.d.ts.map +1 -1
  274. package/dist/components/Pagination/PaginationPage/PaginationPageButton.d.ts.map +1 -1
  275. package/dist/components/Pagination/PaginationPage/PaginationPageEllipsis.d.ts.map +1 -1
  276. package/dist/components/Pagination/PaginationPage/usePaginationPageClasses.d.ts.map +1 -1
  277. package/dist/components/Panel/Panel.d.ts.map +1 -1
  278. package/dist/components/PanelHeader/PanelHeader.d.ts.map +1 -1
  279. package/dist/components/PanelHeaderBack/PanelHeaderBack.d.ts.map +1 -1
  280. package/dist/components/PanelHeaderBack/PanelHeaderBack.js +3 -1
  281. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  282. package/dist/components/PanelHeaderButton/PanelHeaderButton.d.ts.map +1 -1
  283. package/dist/components/PanelHeaderClose/PanelHeaderClose.d.ts.map +1 -1
  284. package/dist/components/PanelHeaderContent/PanelHeaderContent.d.ts.map +1 -1
  285. package/dist/components/PanelHeaderContext/PanelHeaderContext.d.ts.map +1 -1
  286. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.d.ts.map +1 -1
  287. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts.map +1 -1
  288. package/dist/components/Placeholder/Placeholder.d.ts.map +1 -1
  289. package/dist/components/PlatformProvider/PlatformProvider.js +1 -1
  290. package/dist/components/PlatformProvider/PlatformProvider.js.map +1 -1
  291. package/dist/components/PopoutWrapper/PopoutWrapper.d.ts +15 -2
  292. package/dist/components/PopoutWrapper/PopoutWrapper.d.ts.map +1 -1
  293. package/dist/components/PopoutWrapper/PopoutWrapper.js +10 -2
  294. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  295. package/dist/components/Popover/Popover.d.ts +1 -1
  296. package/dist/components/Popover/Popover.d.ts.map +1 -1
  297. package/dist/components/Popover/Popover.js +4 -4
  298. package/dist/components/Popover/Popover.js.map +1 -1
  299. package/dist/components/Popover/usePopover.d.ts +1 -1
  300. package/dist/components/Popover/usePopover.d.ts.map +1 -1
  301. package/dist/components/Popover/usePopover.js +69 -44
  302. package/dist/components/Popover/usePopover.js.map +1 -1
  303. package/dist/components/Popper/Popper.d.ts +2 -2
  304. package/dist/components/Popper/Popper.d.ts.map +1 -1
  305. package/dist/components/Popper/Popper.js +18 -5
  306. package/dist/components/Popper/Popper.js.map +1 -1
  307. package/dist/components/Progress/Progress.d.ts +7 -3
  308. package/dist/components/Progress/Progress.d.ts.map +1 -1
  309. package/dist/components/Progress/Progress.js +30 -11
  310. package/dist/components/Progress/Progress.js.map +1 -1
  311. package/dist/components/PullToRefresh/PullToRefresh.d.ts.map +1 -1
  312. package/dist/components/PullToRefresh/PullToRefreshSpinner.d.ts.map +1 -1
  313. package/dist/components/RadioGroup/RadioGroup.d.ts.map +1 -1
  314. package/dist/components/Removable/Removable.d.ts.map +1 -1
  315. package/dist/components/Removable/Removable.js +8 -4
  316. package/dist/components/Removable/Removable.js.map +1 -1
  317. package/dist/components/RichCell/RichCellIcon/RichCellIcon.d.ts.map +1 -1
  318. package/dist/components/Root/Root.d.ts.map +1 -1
  319. package/dist/components/RootComponent/RootComponent.d.ts.map +1 -1
  320. package/dist/components/ScreenSpinner/Icon48CancelCircle.d.ts.map +1 -1
  321. package/dist/components/ScreenSpinner/Icon48DoneOutline.d.ts.map +1 -1
  322. package/dist/components/ScreenSpinner/ScreenSpinner.js +1 -0
  323. package/dist/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  324. package/dist/components/ScrollArrow/ScrollArrow.d.ts.map +1 -1
  325. package/dist/components/ScrollArrow/ScrollArrow.js +4 -1
  326. package/dist/components/ScrollArrow/ScrollArrow.js.map +1 -1
  327. package/dist/components/Search/Search.d.ts +9 -1
  328. package/dist/components/Search/Search.d.ts.map +1 -1
  329. package/dist/components/Search/Search.js +9 -2
  330. package/dist/components/Search/Search.js.map +1 -1
  331. package/dist/components/SegmentedControl/SegmentedControl.d.ts.map +1 -1
  332. package/dist/components/SegmentedControl/SegmentedControl.js +10 -7
  333. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  334. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts.map +1 -1
  335. package/dist/components/Select/Select.d.ts.map +1 -1
  336. package/dist/components/SelectMimicry/SelectMimicry.d.ts.map +1 -1
  337. package/dist/components/SelectTypography/SelectTypography.d.ts.map +1 -1
  338. package/dist/components/Separator/Separator.d.ts.map +1 -1
  339. package/dist/components/SimpleCell/Chevron/Chevron.d.ts.map +1 -1
  340. package/dist/components/SimpleCell/SimpleCell.d.ts.map +1 -1
  341. package/dist/components/SimpleGrid/SimpleGrid.d.ts.map +1 -1
  342. package/dist/components/Skeleton/Skeleton.d.ts.map +1 -1
  343. package/dist/components/Slider/Slider.d.ts +1 -1
  344. package/dist/components/Slider/Slider.d.ts.map +1 -1
  345. package/dist/components/Slider/Slider.js +22 -18
  346. package/dist/components/Slider/Slider.js.map +1 -1
  347. package/dist/components/Slider/SliderThumb/SliderThumb.d.ts.map +1 -1
  348. package/dist/components/Slider/SliderThumb/SliderThumb.js +5 -1
  349. package/dist/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
  350. package/dist/components/Slider/helpers.d.ts.map +1 -1
  351. package/dist/components/Snackbar/Snackbar.d.ts.map +1 -1
  352. package/dist/components/Snackbar/Snackbar.js +6 -3
  353. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  354. package/dist/components/Snackbar/utils.d.ts +3 -2
  355. package/dist/components/Snackbar/utils.d.ts.map +1 -1
  356. package/dist/components/Snackbar/utils.js +11 -8
  357. package/dist/components/Snackbar/utils.js.map +1 -1
  358. package/dist/components/Spacing/Spacing.d.ts.map +1 -1
  359. package/dist/components/SplitCol/SplitCol.d.ts.map +1 -1
  360. package/dist/components/SplitLayout/SplitLayout.d.ts.map +1 -1
  361. package/dist/components/SubnavigationBar/SubnavigationBar.d.ts.map +1 -1
  362. package/dist/components/SubnavigationButton/SubnavigationButton.d.ts.map +1 -1
  363. package/dist/components/SubnavigationButton/SubnavigationButton.js +1 -1
  364. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  365. package/dist/components/Switch/Switch.d.ts.map +1 -1
  366. package/dist/components/Switch/Switch.js +4 -1
  367. package/dist/components/Switch/Switch.js.map +1 -1
  368. package/dist/components/Tabbar/Tabbar.d.ts.map +1 -1
  369. package/dist/components/TabbarItem/TabbarItem.d.ts.map +1 -1
  370. package/dist/components/Tabs/Tabs.d.ts.map +1 -1
  371. package/dist/components/Tabs/Tabs.js +3 -1
  372. package/dist/components/Tabs/Tabs.js.map +1 -1
  373. package/dist/components/TabsItem/TabsItem.d.ts.map +1 -1
  374. package/dist/components/Tappable/Ripple.d.ts.map +1 -1
  375. package/dist/components/Tappable/Tappable.d.ts.map +1 -1
  376. package/dist/components/Textarea/Textarea.d.ts.map +1 -1
  377. package/dist/components/ToolButton/ToolButton.d.ts.map +1 -1
  378. package/dist/components/Tooltip/Tooltip.d.ts +2 -2
  379. package/dist/components/Tooltip/Tooltip.d.ts.map +1 -1
  380. package/dist/components/Tooltip/Tooltip.js +8 -101
  381. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  382. package/dist/components/Tooltip/useTooltip.d.ts +14 -0
  383. package/dist/components/Tooltip/useTooltip.d.ts.map +1 -0
  384. package/dist/components/Tooltip/useTooltip.js +126 -0
  385. package/dist/components/Tooltip/useTooltip.js.map +1 -0
  386. package/dist/components/TooltipBase/TooltipBase.d.ts.map +1 -1
  387. package/dist/components/Touch/Touch.d.ts.map +1 -1
  388. package/dist/components/Typography/Caption/Caption.d.ts.map +1 -1
  389. package/dist/components/Typography/DisplayTitle/DisplayTitle.d.ts.map +1 -1
  390. package/dist/components/Typography/EllipsisText/EllipsisText.d.ts.map +1 -1
  391. package/dist/components/Typography/Footnote/Footnote.d.ts.map +1 -1
  392. package/dist/components/Typography/Headline/Headline.d.ts.map +1 -1
  393. package/dist/components/Typography/Paragraph/Paragraph.d.ts.map +1 -1
  394. package/dist/components/Typography/Subhead/Subhead.d.ts.map +1 -1
  395. package/dist/components/Typography/Text/Text.d.ts.map +1 -1
  396. package/dist/components/Typography/Title/Title.d.ts.map +1 -1
  397. package/dist/components/Typography/Typography.d.ts.map +1 -1
  398. package/dist/components/UnstyledTextField/UnstyledTextField.d.ts.map +1 -1
  399. package/dist/components/UsersStack/UsersStack.d.ts +1 -1
  400. package/dist/components/UsersStack/UsersStack.d.ts.map +1 -1
  401. package/dist/components/UsersStack/UsersStack.js +5 -9
  402. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  403. package/dist/components/View/View.d.ts.map +1 -1
  404. package/dist/components/View/utils.d.ts.map +1 -1
  405. package/dist/components/VisuallyHidden/VisuallyHidden.d.ts.map +1 -1
  406. package/dist/components/WriteBar/WriteBar.d.ts.map +1 -1
  407. package/dist/components/WriteBarIcon/WriteBarIcon.d.ts.map +1 -1
  408. package/dist/components.css +1 -1
  409. package/dist/components.css.map +1 -1
  410. package/dist/context/CalendarDirectionContext.d.ts +1 -1
  411. package/dist/context/CalendarDirectionContext.d.ts.map +1 -1
  412. package/dist/context/CalendarDirectionContext.js.map +1 -1
  413. package/dist/cssm/components/Accordion/Accordion.js.map +1 -1
  414. package/dist/cssm/components/Accordion/Accordion.module.css +6 -6
  415. package/dist/cssm/components/ActionSheet/ActionSheet.js +1 -1
  416. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  417. package/dist/cssm/components/ActionSheet/ActionSheet.module.css +9 -9
  418. package/dist/cssm/components/ActionSheet/ActionSheetDropdownMenu.js +7 -3
  419. package/dist/cssm/components/ActionSheet/ActionSheetDropdownMenu.js.map +1 -1
  420. package/dist/cssm/components/ActionSheet/ActionSheetDropdownSheet.js +7 -3
  421. package/dist/cssm/components/ActionSheet/ActionSheetDropdownSheet.js.map +1 -1
  422. package/dist/cssm/components/ActionSheet/types.js.map +1 -1
  423. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.module.css +18 -18
  424. package/dist/cssm/components/Alert/Alert.js +12 -92
  425. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  426. package/dist/cssm/components/Alert/Alert.module.css +27 -29
  427. package/dist/cssm/components/Alert/AlertBase.js +111 -0
  428. package/dist/cssm/components/Alert/AlertBase.js.map +1 -0
  429. package/dist/cssm/components/Alert/AlertTypography.js.map +1 -1
  430. package/dist/cssm/components/AppRoot/AppRoot.module.css +2 -2
  431. package/dist/cssm/components/AppRoot/AppRootStyleContainer/AppRootStyleContainer.js +1 -1
  432. package/dist/cssm/components/AppRoot/AppRootStyleContainer/AppRootStyleContainer.js.map +1 -1
  433. package/dist/cssm/components/AppRoot/ScrollContext.js +129 -37
  434. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  435. package/dist/cssm/components/AspectRatio/AspectRatio.module.css +2 -2
  436. package/dist/cssm/components/Avatar/Avatar.module.css +1 -1
  437. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadge.module.css +8 -3
  438. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js +4 -1
  439. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  440. package/dist/cssm/components/Banner/Banner.module.css +19 -19
  441. package/dist/cssm/components/Button/Button.module.css +11 -11
  442. package/dist/cssm/components/ButtonGroup/ButtonGroup.js +1 -0
  443. package/dist/cssm/components/ButtonGroup/ButtonGroup.js.map +1 -1
  444. package/dist/cssm/components/Calendar/Calendar.js +96 -92
  445. package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
  446. package/dist/cssm/components/Calendar/Calendar.module.css +8 -8
  447. package/dist/cssm/components/CalendarDay/CalendarDay.js +1 -3
  448. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
  449. package/dist/cssm/components/CalendarDay/CalendarDay.module.css +11 -11
  450. package/dist/cssm/components/CalendarDays/CalendarDays.module.css +7 -7
  451. package/dist/cssm/components/CalendarHeader/CalendarHeader.js +1 -3
  452. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
  453. package/dist/cssm/components/CalendarHeader/CalendarHeader.module.css +4 -4
  454. package/dist/cssm/components/CalendarRange/CalendarRange.js +103 -110
  455. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
  456. package/dist/cssm/components/CalendarRange/CalendarRange.module.css +5 -5
  457. package/dist/cssm/components/CalendarTime/CalendarTime.module.css +1 -1
  458. package/dist/cssm/components/Card/Card.module.css +7 -7
  459. package/dist/cssm/components/CardGrid/CardGrid.module.css +3 -3
  460. package/dist/cssm/components/CardScroll/CardScroll.js +30 -28
  461. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  462. package/dist/cssm/components/CardScroll/CardScroll.module.css +16 -16
  463. package/dist/cssm/components/CarouselBase/CarouselBase.js +71 -44
  464. package/dist/cssm/components/CarouselBase/CarouselBase.js.map +1 -1
  465. package/dist/cssm/components/CarouselBase/CarouselBase.module.css +11 -11
  466. package/dist/cssm/components/CarouselBase/helpers.js +70 -44
  467. package/dist/cssm/components/CarouselBase/helpers.js.map +1 -1
  468. package/dist/cssm/components/Cell/Cell.module.css +18 -2
  469. package/dist/cssm/components/Cell/CellDragger/CellDragger.module.css +2 -2
  470. package/dist/cssm/components/CellButton/CellButton.module.css +8 -8
  471. package/dist/cssm/components/CellButtonGroup/CellButtonGroup.js +20 -0
  472. package/dist/cssm/components/CellButtonGroup/CellButtonGroup.js.map +1 -0
  473. package/dist/cssm/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.js +15 -0
  474. package/dist/cssm/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.js.map +1 -0
  475. package/dist/cssm/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.module.css +5 -0
  476. package/dist/cssm/components/Checkbox/CheckboxSimple/CheckboxSimple.module.css +2 -2
  477. package/dist/cssm/components/ChipsInputBase/Chip/Chip.module.css +16 -16
  478. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.module.css +12 -12
  479. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +2 -1
  480. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  481. package/dist/cssm/components/ChipsSelect/ChipsSelect.module.css +1 -1
  482. package/dist/cssm/components/ChipsSelect/useChipsSelect.js +9 -3
  483. package/dist/cssm/components/ChipsSelect/useChipsSelect.js.map +1 -1
  484. package/dist/cssm/components/Clickable/Clickable.js +29 -22
  485. package/dist/cssm/components/Clickable/Clickable.js.map +1 -1
  486. package/dist/cssm/components/Clickable/Clickable.module.css +1 -1
  487. package/dist/cssm/components/ColorSchemeProvider/ColorSchemeProvider.js +1 -1
  488. package/dist/cssm/components/ColorSchemeProvider/ColorSchemeProvider.js.map +1 -1
  489. package/dist/cssm/components/ConfigProvider/ConfigProvider.js +5 -2
  490. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  491. package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js +12 -7
  492. package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  493. package/dist/cssm/components/ContentBadge/ContentBadge.module.css +7 -7
  494. package/dist/cssm/components/ContentCard/ContentCard.js +5 -4
  495. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  496. package/dist/cssm/components/ContentCard/ContentCard.module.css +6 -6
  497. package/dist/cssm/components/Counter/Counter.module.css +4 -4
  498. package/dist/cssm/components/CustomScrollView/CustomScrollView.module.css +2 -2
  499. package/dist/cssm/components/CustomSelect/CustomSelect.js +105 -69
  500. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  501. package/dist/cssm/components/CustomSelect/CustomSelect.module.css +2 -2
  502. package/dist/cssm/components/CustomSelect/CustomSelectInput/CustomSelectInput.module.css +13 -13
  503. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js +1 -0
  504. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  505. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.module.css +2 -2
  506. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.module.css +9 -9
  507. package/dist/cssm/components/DateInput/DateInput.js +104 -81
  508. package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
  509. package/dist/cssm/components/DateInput/DateInput.module.css +40 -6
  510. package/dist/cssm/components/DateInput/hooks.js +54 -0
  511. package/dist/cssm/components/DateInput/hooks.js.map +1 -0
  512. package/dist/cssm/components/DateRangeInput/DateRangeInput.js +99 -82
  513. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  514. package/dist/cssm/components/DateRangeInput/DateRangeInput.module.css +3 -3
  515. package/dist/cssm/components/DirectionProvider/DirectionProvider.js +15 -0
  516. package/dist/cssm/components/DirectionProvider/DirectionProvider.js.map +1 -0
  517. package/dist/cssm/components/DropZone/DropZone.module.css +2 -2
  518. package/dist/cssm/components/FixedLayout/FixedLayout.module.css +3 -3
  519. package/dist/cssm/components/Flex/Flex.js +3 -5
  520. package/dist/cssm/components/Flex/Flex.js.map +1 -1
  521. package/dist/cssm/components/Flex/Flex.module.css +40 -23
  522. package/dist/cssm/components/FloatingArrow/FloatingArrow.module.css +1 -1
  523. package/dist/cssm/components/Footer/Footer.module.css +1 -1
  524. package/dist/cssm/components/FormField/FormField.module.css +24 -24
  525. package/dist/cssm/components/FormItem/FormItem.module.css +10 -10
  526. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.module.css +5 -5
  527. package/dist/cssm/components/GridAvatar/GridAvatar.module.css +2 -2
  528. package/dist/cssm/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.module.css +2 -2
  529. package/dist/cssm/components/Group/Group.module.css +16 -16
  530. package/dist/cssm/components/Header/Header.module.css +6 -6
  531. package/dist/cssm/components/HorizontalCell/HorizontalCell.module.css +3 -3
  532. package/dist/cssm/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.module.css +2 -2
  533. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +28 -23
  534. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  535. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.module.css +10 -4
  536. package/dist/cssm/components/IconButton/IconButton.module.css +11 -11
  537. package/dist/cssm/components/ImageBase/ImageBase.js +5 -4
  538. package/dist/cssm/components/ImageBase/ImageBase.js.map +1 -1
  539. package/dist/cssm/components/ImageBase/ImageBase.module.css +15 -6
  540. package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.module.css +5 -5
  541. package/dist/cssm/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.module.css +8 -8
  542. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js +3 -4
  543. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  544. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.module.css +2 -2
  545. package/dist/cssm/components/ImageBase/ImageBaseOverlay/hooks.js +25 -0
  546. package/dist/cssm/components/ImageBase/ImageBaseOverlay/hooks.js.map +1 -1
  547. package/dist/cssm/components/ImageBase/ImageBaseOverlay/types.js.map +1 -1
  548. package/dist/cssm/components/InfoRow/InfoRow.module.css +3 -3
  549. package/dist/cssm/components/Input/Input.module.css +5 -5
  550. package/dist/cssm/components/InputLike/InputLike.module.css +3 -3
  551. package/dist/cssm/components/Link/Link.module.css +6 -6
  552. package/dist/cssm/components/Mark/Mark.module.css +2 -2
  553. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.module.css +5 -5
  554. package/dist/cssm/components/ModalCard/ModalCard.js +1 -0
  555. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  556. package/dist/cssm/components/ModalCard/ModalCard.module.css +4 -4
  557. package/dist/cssm/components/ModalCard/ModalCardInternal.js +3 -2
  558. package/dist/cssm/components/ModalCard/ModalCardInternal.js.map +1 -1
  559. package/dist/cssm/components/ModalCard/types.js.map +1 -1
  560. package/dist/cssm/components/ModalCardBase/ModalCardBase.js +30 -7
  561. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  562. package/dist/cssm/components/ModalCardBase/ModalCardBase.module.css +7 -7
  563. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js +5 -6
  564. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  565. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.module.css +0 -29
  566. package/dist/cssm/components/ModalOutlet/ModalOutlet.module.css +1 -1
  567. package/dist/cssm/components/ModalOutsideButton/ModalOutsideButton.js +24 -0
  568. package/dist/cssm/components/ModalOutsideButton/ModalOutsideButton.js.map +1 -0
  569. package/dist/cssm/components/ModalOutsideButton/ModalOutsideButton.module.css +31 -0
  570. package/dist/cssm/components/ModalOutsideButtons/ModalOutsideButtons.js +16 -0
  571. package/dist/cssm/components/ModalOutsideButtons/ModalOutsideButtons.js.map +1 -0
  572. package/dist/cssm/components/ModalOutsideButtons/ModalOutsideButtons.module.css +6 -0
  573. package/dist/cssm/components/ModalOverlay/ModalOverlay.module.css +2 -2
  574. package/dist/cssm/components/ModalPage/ModalPage.module.css +15 -16
  575. package/dist/cssm/components/ModalPage/ModalPageBase.js +49 -0
  576. package/dist/cssm/components/ModalPage/ModalPageBase.js.map +1 -0
  577. package/dist/cssm/components/ModalPage/ModalPageInternal.js +21 -32
  578. package/dist/cssm/components/ModalPage/ModalPageInternal.js.map +1 -1
  579. package/dist/cssm/components/ModalPage/types.js.map +1 -1
  580. package/dist/cssm/components/ModalPageFooter/ModalPageFooter.module.css +4 -4
  581. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.module.css +2 -3
  582. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js +20 -7
  583. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  584. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.module.css +1 -1
  585. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContainer.js +13 -4
  586. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContainer.js.map +1 -1
  587. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContext.js +9 -0
  588. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContext.js.map +1 -0
  589. package/dist/cssm/components/Pagination/Pagination.js +5 -2
  590. package/dist/cssm/components/Pagination/Pagination.js.map +1 -1
  591. package/dist/cssm/components/Pagination/Pagination.module.css +1 -1
  592. package/dist/cssm/components/Pagination/PaginationPage/PaginationPage.module.css +9 -9
  593. package/dist/cssm/components/Panel/Panel.module.css +3 -3
  594. package/dist/cssm/components/PanelHeader/PanelHeader.module.css +30 -30
  595. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js +3 -1
  596. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  597. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.module.css +16 -8
  598. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.module.css +10 -10
  599. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.module.css +7 -7
  600. package/dist/cssm/components/Placeholder/Placeholder.module.css +3 -3
  601. package/dist/cssm/components/PlatformProvider/PlatformProvider.js +1 -1
  602. package/dist/cssm/components/PlatformProvider/PlatformProvider.js.map +1 -1
  603. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +9 -2
  604. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  605. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.module.css +14 -9
  606. package/dist/cssm/components/Popover/Popover.js +4 -4
  607. package/dist/cssm/components/Popover/Popover.js.map +1 -1
  608. package/dist/cssm/components/Popover/Popover.module.css +1 -1
  609. package/dist/cssm/components/Popover/usePopover.js +62 -44
  610. package/dist/cssm/components/Popover/usePopover.js.map +1 -1
  611. package/dist/cssm/components/Popper/Popper.js +15 -5
  612. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  613. package/dist/cssm/components/Progress/Progress.js +29 -9
  614. package/dist/cssm/components/Progress/Progress.js.map +1 -1
  615. package/dist/cssm/components/Progress/Progress.module.css +20 -9
  616. package/dist/cssm/components/PullToRefresh/PullToRefresh.module.css +14 -14
  617. package/dist/cssm/components/Radio/Radio.module.css +1 -1
  618. package/dist/cssm/components/Radio/RadioInput/RadioInput.module.css +1 -1
  619. package/dist/cssm/components/RadioGroup/RadioGroup.module.css +1 -1
  620. package/dist/cssm/components/Removable/Removable.js +8 -4
  621. package/dist/cssm/components/Removable/Removable.js.map +1 -1
  622. package/dist/cssm/components/Removable/Removable.module.css +19 -6
  623. package/dist/cssm/components/RichCell/RichCell.module.css +10 -10
  624. package/dist/cssm/components/RichCell/RichCellIcon/RichCellIcon.module.css +4 -4
  625. package/dist/cssm/components/Root/Root.module.css +10 -10
  626. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js +1 -0
  627. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  628. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.module.css +12 -12
  629. package/dist/cssm/components/ScrollArrow/ScrollArrow.js +4 -1
  630. package/dist/cssm/components/ScrollArrow/ScrollArrow.js.map +1 -1
  631. package/dist/cssm/components/ScrollArrow/ScrollArrow.module.css +15 -14
  632. package/dist/cssm/components/Search/Search.js +7 -2
  633. package/dist/cssm/components/Search/Search.js.map +1 -1
  634. package/dist/cssm/components/Search/Search.module.css +44 -32
  635. package/dist/cssm/components/SegmentedControl/SegmentedControl.js +10 -7
  636. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  637. package/dist/cssm/components/SegmentedControl/SegmentedControl.module.css +16 -7
  638. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.module.css +14 -14
  639. package/dist/cssm/components/Select/Select.module.css +15 -15
  640. package/dist/cssm/components/SelectionControl/SelectionControl.module.css +2 -2
  641. package/dist/cssm/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.module.css +5 -5
  642. package/dist/cssm/components/Separator/Separator.module.css +3 -3
  643. package/dist/cssm/components/SimpleCell/SimpleCell.module.css +18 -16
  644. package/dist/cssm/components/SimpleGrid/SimpleGrid.module.css +2 -2
  645. package/dist/cssm/components/Skeleton/Skeleton.module.css +8 -8
  646. package/dist/cssm/components/Slider/Slider.js +20 -17
  647. package/dist/cssm/components/Slider/Slider.js.map +1 -1
  648. package/dist/cssm/components/Slider/Slider.module.css +25 -4
  649. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.js +5 -1
  650. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
  651. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.module.css +8 -8
  652. package/dist/cssm/components/Snackbar/Snackbar.js +6 -3
  653. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  654. package/dist/cssm/components/Snackbar/Snackbar.module.css +23 -6
  655. package/dist/cssm/components/Snackbar/subcomponents/Basic/Basic.module.css +9 -8
  656. package/dist/cssm/components/Snackbar/utils.js +11 -8
  657. package/dist/cssm/components/Snackbar/utils.js.map +1 -1
  658. package/dist/cssm/components/Spacing/Spacing.module.css +1 -1
  659. package/dist/cssm/components/Spinner/Spinner.module.css +2 -2
  660. package/dist/cssm/components/SplitCol/SplitCol.module.css +9 -9
  661. package/dist/cssm/components/SplitLayout/SplitLayout.module.css +2 -2
  662. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.module.css +4 -4
  663. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +1 -1
  664. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  665. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.module.css +10 -6
  666. package/dist/cssm/components/Switch/Switch.js +4 -1
  667. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  668. package/dist/cssm/components/Switch/Switch.module.css +25 -17
  669. package/dist/cssm/components/Tabbar/Tabbar.module.css +5 -5
  670. package/dist/cssm/components/TabbarItem/TabbarItem.module.css +16 -16
  671. package/dist/cssm/components/Tabs/Tabs.js +3 -1
  672. package/dist/cssm/components/Tabs/Tabs.js.map +1 -1
  673. package/dist/cssm/components/Tabs/Tabs.module.css +1 -1
  674. package/dist/cssm/components/TabsItem/TabsItem.module.css +21 -20
  675. package/dist/cssm/components/Tappable/Tappable.module.css +6 -6
  676. package/dist/cssm/components/Textarea/Textarea.module.css +7 -3
  677. package/dist/cssm/components/ToolButton/ToolButton.module.css +7 -7
  678. package/dist/cssm/components/Tooltip/Tooltip.js +7 -80
  679. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  680. package/dist/cssm/components/Tooltip/useTooltip.js +97 -0
  681. package/dist/cssm/components/Tooltip/useTooltip.js.map +1 -0
  682. package/dist/cssm/components/TooltipBase/TooltipBase.module.css +9 -9
  683. package/dist/cssm/components/Typography/Caption/Caption.module.css +96 -96
  684. package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.module.css +64 -64
  685. package/dist/cssm/components/Typography/EllipsisText/EllipsisText.module.css +3 -3
  686. package/dist/cssm/components/Typography/Footnote/Footnote.module.css +32 -32
  687. package/dist/cssm/components/Typography/Headline/Headline.module.css +20 -20
  688. package/dist/cssm/components/Typography/Paragraph/Paragraph.module.css +16 -16
  689. package/dist/cssm/components/Typography/Subhead/Subhead.module.css +16 -16
  690. package/dist/cssm/components/Typography/Text/Text.module.css +16 -16
  691. package/dist/cssm/components/Typography/Title/Title.module.css +48 -48
  692. package/dist/cssm/components/Typography/Typography.module.css +1 -1
  693. package/dist/cssm/components/UnstyledTextField/UnstyledTextField.module.css +5 -5
  694. package/dist/cssm/components/UsersStack/UsersStack.js +4 -7
  695. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  696. package/dist/cssm/components/UsersStack/UsersStack.module.css +4 -4
  697. package/dist/cssm/components/View/View.module.css +8 -8
  698. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.module.css +10 -10
  699. package/dist/cssm/components/WriteBar/WriteBar.module.css +10 -11
  700. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.module.css +9 -9
  701. package/dist/cssm/context/CalendarDirectionContext.js.map +1 -1
  702. package/dist/cssm/helpers/getValueByKey.js +17 -0
  703. package/dist/cssm/helpers/getValueByKey.js.map +1 -0
  704. package/dist/cssm/hooks/useAutoDetectDirection.js +21 -0
  705. package/dist/cssm/hooks/useAutoDetectDirection.js.map +1 -0
  706. package/dist/cssm/hooks/useConfigDirection.js +7 -0
  707. package/dist/cssm/hooks/useConfigDirection.js.map +1 -0
  708. package/dist/cssm/hooks/useFloatingElement.js +70 -0
  709. package/dist/cssm/hooks/useFloatingElement.js.map +1 -0
  710. package/dist/cssm/hooks/useFocusVisible.js +10 -1
  711. package/dist/cssm/hooks/useFocusVisible.js.map +1 -1
  712. package/dist/cssm/hooks/useReferenceElement.js +13 -0
  713. package/dist/cssm/hooks/useReferenceElement.js.map +1 -0
  714. package/dist/cssm/hooks/useTabsNavigation.js +3 -3
  715. package/dist/cssm/hooks/useTabsNavigation.js.map +1 -1
  716. package/dist/cssm/hooks/useTodayDate.js +4 -4
  717. package/dist/cssm/hooks/useTodayDate.js.map +1 -1
  718. package/dist/cssm/index.js +6 -1
  719. package/dist/cssm/index.js.map +1 -1
  720. package/dist/cssm/lib/SSR.js +2 -1
  721. package/dist/cssm/lib/SSR.js.map +1 -1
  722. package/dist/cssm/lib/date.js +15 -0
  723. package/dist/cssm/lib/date.js.map +1 -1
  724. package/dist/cssm/lib/direction/index.js +3 -0
  725. package/dist/cssm/lib/direction/index.js.map +1 -0
  726. package/dist/cssm/lib/floating/adapters.js.map +1 -1
  727. package/dist/cssm/lib/floating/customResizeObserver.js +2 -5
  728. package/dist/cssm/lib/floating/customResizeObserver.js.map +1 -1
  729. package/dist/cssm/lib/floating/functions.js +1 -1
  730. package/dist/cssm/lib/floating/functions.js.map +1 -1
  731. package/dist/cssm/lib/floating/types/component.js.map +1 -1
  732. package/dist/cssm/lib/floating/useFloatingMiddlewaresBootstrap/index.js +4 -2
  733. package/dist/cssm/lib/floating/useFloatingMiddlewaresBootstrap/index.js.map +1 -1
  734. package/dist/cssm/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js +6 -1
  735. package/dist/cssm/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
  736. package/dist/cssm/lib/floating/useReferenceHiddenChangeCallback.js +21 -0
  737. package/dist/cssm/lib/floating/useReferenceHiddenChangeCallback.js.map +1 -0
  738. package/dist/cssm/lib/object.js +9 -0
  739. package/dist/cssm/lib/object.js.map +1 -0
  740. package/dist/cssm/lib/select.js.map +1 -1
  741. package/dist/cssm/lib/sheet/controllers/BottomSheetController.js +13 -23
  742. package/dist/cssm/lib/sheet/controllers/BottomSheetController.js.map +1 -1
  743. package/dist/cssm/lib/sheet/controllers/CSSTransitionController.js +4 -5
  744. package/dist/cssm/lib/sheet/controllers/CSSTransitionController.js.map +1 -1
  745. package/dist/cssm/lib/tokens/TokensClassProvider.module.css +1 -1
  746. package/dist/cssm/styles/common.css +2 -2
  747. package/dist/cssm/styles/themes.css +22 -5
  748. package/dist/helpers/getMergedSameEventsByProps.d.ts.map +1 -1
  749. package/dist/helpers/getValueByKey.d.ts +5 -0
  750. package/dist/helpers/getValueByKey.d.ts.map +1 -0
  751. package/dist/helpers/getValueByKey.js +17 -0
  752. package/dist/helpers/getValueByKey.js.map +1 -0
  753. package/dist/helpers/math.d.ts.map +1 -1
  754. package/dist/hooks/useAdaptivityConditionalRender/helpers.d.ts.map +1 -1
  755. package/dist/hooks/useAutoDetectColorScheme.d.ts.map +1 -1
  756. package/dist/hooks/useAutoDetectDirection.d.ts +3 -0
  757. package/dist/hooks/useAutoDetectDirection.d.ts.map +1 -0
  758. package/dist/hooks/useAutoDetectDirection.js +21 -0
  759. package/dist/hooks/useAutoDetectDirection.js.map +1 -0
  760. package/dist/hooks/useBooleanState.d.ts.map +1 -1
  761. package/dist/hooks/useConfigDirection.d.ts +3 -0
  762. package/dist/hooks/useConfigDirection.d.ts.map +1 -0
  763. package/dist/hooks/useConfigDirection.js +7 -0
  764. package/dist/hooks/useConfigDirection.js.map +1 -0
  765. package/dist/hooks/useDraggableWithDomApi/autoScroll.d.ts.map +1 -1
  766. package/dist/hooks/useDraggableWithDomApi/useDraggableWithDomApi.d.ts.map +1 -1
  767. package/dist/hooks/useDraggableWithDomApi/utils.d.ts.map +1 -1
  768. package/dist/hooks/useFloatingElement.d.ts +26 -0
  769. package/dist/hooks/useFloatingElement.d.ts.map +1 -0
  770. package/dist/hooks/useFloatingElement.js +71 -0
  771. package/dist/hooks/useFloatingElement.js.map +1 -0
  772. package/dist/hooks/useFocusTrap.d.ts.map +1 -1
  773. package/dist/hooks/useFocusVisible.d.ts +9 -1
  774. package/dist/hooks/useFocusVisible.d.ts.map +1 -1
  775. package/dist/hooks/useFocusVisible.js +10 -1
  776. package/dist/hooks/useFocusVisible.js.map +1 -1
  777. package/dist/hooks/useGlobalEscKeyDown.d.ts.map +1 -1
  778. package/dist/hooks/useGlobalOnClickOutside.d.ts.map +1 -1
  779. package/dist/hooks/useMutationObserver.d.ts.map +1 -1
  780. package/dist/hooks/useNativeFormResetListener.d.ts.map +1 -1
  781. package/dist/hooks/usePagination.d.ts.map +1 -1
  782. package/dist/hooks/usePatchChildren.d.ts.map +1 -1
  783. package/dist/hooks/useReferenceElement.d.ts +3 -0
  784. package/dist/hooks/useReferenceElement.d.ts.map +1 -0
  785. package/dist/hooks/useReferenceElement.js +13 -0
  786. package/dist/hooks/useReferenceElement.js.map +1 -0
  787. package/dist/hooks/useTabsNavigation.d.ts +1 -1
  788. package/dist/hooks/useTabsNavigation.d.ts.map +1 -1
  789. package/dist/hooks/useTabsNavigation.js +3 -3
  790. package/dist/hooks/useTabsNavigation.js.map +1 -1
  791. package/dist/hooks/useTodayDate.d.ts.map +1 -1
  792. package/dist/hooks/useTodayDate.js +4 -4
  793. package/dist/hooks/useTodayDate.js.map +1 -1
  794. package/dist/index.d.ts +9 -2
  795. package/dist/index.d.ts.map +1 -1
  796. package/dist/index.js +6 -1
  797. package/dist/index.js.map +1 -1
  798. package/dist/lib/SSR.d.ts +2 -0
  799. package/dist/lib/SSR.d.ts.map +1 -1
  800. package/dist/lib/SSR.js +2 -1
  801. package/dist/lib/SSR.js.map +1 -1
  802. package/dist/lib/accessibility.d.ts.map +1 -1
  803. package/dist/lib/animation/useCSSKeyframesAnimationController.d.ts.map +1 -1
  804. package/dist/lib/animation/useCSSTransition.d.ts.map +1 -1
  805. package/dist/lib/calendar.d.ts.map +1 -1
  806. package/dist/lib/callMultiple.d.ts.map +1 -1
  807. package/dist/lib/children.d.ts.map +1 -1
  808. package/dist/lib/createPortal.d.ts.map +1 -1
  809. package/dist/lib/date.d.ts +2 -0
  810. package/dist/lib/date.d.ts.map +1 -1
  811. package/dist/lib/date.js +15 -0
  812. package/dist/lib/date.js.map +1 -1
  813. package/dist/lib/direction/index.d.ts +2 -0
  814. package/dist/lib/direction/index.d.ts.map +1 -0
  815. package/dist/lib/direction/index.js +3 -0
  816. package/dist/lib/direction/index.js.map +1 -0
  817. package/dist/lib/dom.d.ts.map +1 -1
  818. package/dist/lib/floating/adapters.d.ts +1 -0
  819. package/dist/lib/floating/adapters.d.ts.map +1 -1
  820. package/dist/lib/floating/adapters.js.map +1 -1
  821. package/dist/lib/floating/customResizeObserver.d.ts +1 -1
  822. package/dist/lib/floating/customResizeObserver.d.ts.map +1 -1
  823. package/dist/lib/floating/customResizeObserver.js +2 -5
  824. package/dist/lib/floating/customResizeObserver.js.map +1 -1
  825. package/dist/lib/floating/functions.d.ts +8 -1
  826. package/dist/lib/floating/functions.d.ts.map +1 -1
  827. package/dist/lib/floating/functions.js +1 -1
  828. package/dist/lib/floating/functions.js.map +1 -1
  829. package/dist/lib/floating/types/component.d.ts +10 -0
  830. package/dist/lib/floating/types/component.d.ts.map +1 -1
  831. package/dist/lib/floating/types/component.js.map +1 -1
  832. package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts +3 -1
  833. package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts.map +1 -1
  834. package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.js +4 -2
  835. package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.js.map +1 -1
  836. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.d.ts.map +1 -1
  837. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js +6 -1
  838. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
  839. package/dist/lib/floating/useFloatingWithInteractions/useResolveTriggerType.d.ts.map +1 -1
  840. package/dist/lib/floating/useReferenceHiddenChangeCallback.d.ts +4 -0
  841. package/dist/lib/floating/useReferenceHiddenChangeCallback.d.ts.map +1 -0
  842. package/dist/lib/floating/useReferenceHiddenChangeCallback.js +21 -0
  843. package/dist/lib/floating/useReferenceHiddenChangeCallback.js.map +1 -0
  844. package/dist/lib/fx.d.ts.map +1 -1
  845. package/dist/lib/isRefObject.d.ts.map +1 -1
  846. package/dist/lib/object.d.ts +2 -0
  847. package/dist/lib/object.d.ts.map +1 -0
  848. package/dist/lib/object.js +9 -0
  849. package/dist/lib/object.js.map +1 -0
  850. package/dist/lib/rafSchd.d.ts.map +1 -1
  851. package/dist/lib/react/simulateReactInput.d.ts.map +1 -1
  852. package/dist/lib/select.d.ts +1 -0
  853. package/dist/lib/select.d.ts.map +1 -1
  854. package/dist/lib/select.js.map +1 -1
  855. package/dist/lib/sheet/controllers/BottomSheetController.d.ts.map +1 -1
  856. package/dist/lib/sheet/controllers/BottomSheetController.js +13 -23
  857. package/dist/lib/sheet/controllers/BottomSheetController.js.map +1 -1
  858. package/dist/lib/sheet/controllers/CSSTransitionController.d.ts.map +1 -1
  859. package/dist/lib/sheet/controllers/CSSTransitionController.js +4 -5
  860. package/dist/lib/sheet/controllers/CSSTransitionController.js.map +1 -1
  861. package/dist/lib/sheet/useBottomSheet.d.ts.map +1 -1
  862. package/dist/lib/touch/functions.d.ts.map +1 -1
  863. package/dist/lib/utils.d.ts.map +1 -1
  864. package/dist/vkui.css +1 -1
  865. package/dist/vkui.css.map +1 -1
  866. package/package.json +5 -4
  867. package/src/components/Accordion/Accordion.module.css +6 -6
  868. package/src/components/Accordion/Accordion.tsx +2 -2
  869. package/src/components/ActionSheet/ActionSheet.module.css +9 -9
  870. package/src/components/ActionSheet/ActionSheet.tsx +5 -2
  871. package/src/components/ActionSheet/ActionSheetDropdownMenu.tsx +11 -3
  872. package/src/components/ActionSheet/ActionSheetDropdownSheet.tsx +11 -3
  873. package/src/components/ActionSheet/types.ts +4 -0
  874. package/src/components/ActionSheetItem/ActionSheetItem.module.css +17 -17
  875. package/src/components/Alert/Alert.module.css +25 -25
  876. package/src/components/Alert/Alert.tsx +33 -118
  877. package/src/components/Alert/AlertBase.tsx +156 -0
  878. package/src/components/Alert/AlertTypography.tsx +2 -1
  879. package/src/components/AppRoot/AppRoot.module.css +2 -2
  880. package/src/components/AppRoot/AppRootStyleContainer/AppRootStyleContainer.tsx +1 -1
  881. package/src/components/AppRoot/ScrollContext.tsx +162 -50
  882. package/src/components/AspectRatio/AspectRatio.module.css +2 -2
  883. package/src/components/Avatar/Avatar.module.css +1 -1
  884. package/src/components/Avatar/AvatarBadge/AvatarBadge.module.css +8 -3
  885. package/src/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.tsx +4 -1
  886. package/src/components/Banner/Banner.module.css +17 -17
  887. package/src/components/Button/Button.module.css +11 -11
  888. package/src/components/ButtonGroup/ButtonGroup.tsx +2 -0
  889. package/src/components/Calendar/Calendar.module.css +7 -7
  890. package/src/components/Calendar/Calendar.tsx +108 -98
  891. package/src/components/CalendarDay/CalendarDay.module.css +11 -11
  892. package/src/components/CalendarDay/CalendarDay.tsx +1 -3
  893. package/src/components/CalendarDays/CalendarDays.module.css +7 -7
  894. package/src/components/CalendarHeader/CalendarHeader.module.css +4 -4
  895. package/src/components/CalendarHeader/CalendarHeader.tsx +1 -3
  896. package/src/components/CalendarRange/CalendarRange.module.css +5 -5
  897. package/src/components/CalendarRange/CalendarRange.tsx +97 -106
  898. package/src/components/CalendarTime/CalendarTime.module.css +1 -1
  899. package/src/components/Card/Card.module.css +7 -7
  900. package/src/components/CardGrid/CardGrid.module.css +3 -3
  901. package/src/components/CardScroll/CardScroll.module.css +16 -16
  902. package/src/components/CardScroll/CardScroll.tsx +49 -29
  903. package/src/components/CarouselBase/CarouselBase.module.css +11 -11
  904. package/src/components/CarouselBase/CarouselBase.tsx +107 -44
  905. package/src/components/CarouselBase/helpers.ts +108 -46
  906. package/src/components/Cell/Cell.module.css +16 -2
  907. package/src/components/Cell/CellDragger/CellDragger.module.css +2 -2
  908. package/src/components/CellButton/CellButton.module.css +7 -7
  909. package/src/components/CellButtonGroup/CellButtonGroup.tsx +20 -0
  910. package/src/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.module.css +5 -0
  911. package/src/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.tsx +21 -0
  912. package/src/components/Checkbox/CheckboxSimple/CheckboxSimple.module.css +2 -2
  913. package/src/components/ChipsInputBase/Chip/Chip.module.css +16 -16
  914. package/src/components/ChipsInputBase/ChipsInputBase.module.css +10 -10
  915. package/src/components/ChipsSelect/ChipsSelect.module.css +1 -1
  916. package/src/components/ChipsSelect/ChipsSelect.tsx +2 -0
  917. package/src/components/ChipsSelect/useChipsSelect.ts +12 -1
  918. package/src/components/Clickable/Clickable.module.css +1 -1
  919. package/src/components/Clickable/Clickable.tsx +37 -25
  920. package/src/components/ColorSchemeProvider/ColorSchemeProvider.tsx +1 -1
  921. package/src/components/ConfigProvider/ConfigProvider.tsx +4 -1
  922. package/src/components/ConfigProvider/ConfigProviderContext.tsx +29 -15
  923. package/src/components/ContentBadge/ContentBadge.module.css +7 -7
  924. package/src/components/ContentCard/ContentCard.module.css +6 -6
  925. package/src/components/ContentCard/ContentCard.tsx +9 -3
  926. package/src/components/Counter/Counter.module.css +4 -4
  927. package/src/components/CustomScrollView/CustomScrollView.module.css +2 -2
  928. package/src/components/CustomSelect/CustomSelect.module.css +2 -2
  929. package/src/components/CustomSelect/CustomSelect.tsx +151 -93
  930. package/src/components/CustomSelect/CustomSelectInput/CustomSelectInput.module.css +12 -12
  931. package/src/components/CustomSelectDropdown/CustomSelectDropdown.module.css +2 -2
  932. package/src/components/CustomSelectDropdown/CustomSelectDropdown.tsx +1 -0
  933. package/src/components/CustomSelectOption/CustomSelectOption.module.css +8 -8
  934. package/src/components/DateInput/DateInput.module.css +38 -5
  935. package/src/components/DateInput/DateInput.tsx +123 -87
  936. package/src/components/DateInput/hooks.ts +84 -0
  937. package/src/components/DateRangeInput/DateRangeInput.module.css +3 -3
  938. package/src/components/DateRangeInput/DateRangeInput.tsx +104 -81
  939. package/src/components/DirectionProvider/DirectionProvider.tsx +17 -0
  940. package/src/components/DropZone/DropZone.module.css +2 -2
  941. package/src/components/FixedLayout/FixedLayout.module.css +3 -3
  942. package/src/components/Flex/Flex.module.css +26 -14
  943. package/src/components/Flex/Flex.tsx +3 -6
  944. package/src/components/FloatingArrow/FloatingArrow.module.css +1 -1
  945. package/src/components/Footer/Footer.module.css +1 -1
  946. package/src/components/FormField/FormField.module.css +24 -24
  947. package/src/components/FormItem/FormItem.module.css +10 -10
  948. package/src/components/FormLayoutGroup/FormLayoutGroup.module.css +5 -5
  949. package/src/components/GridAvatar/GridAvatar.module.css +2 -2
  950. package/src/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.module.css +2 -2
  951. package/src/components/Group/Group.module.css +16 -16
  952. package/src/components/Header/Header.module.css +5 -5
  953. package/src/components/HorizontalCell/HorizontalCell.module.css +3 -3
  954. package/src/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.module.css +2 -2
  955. package/src/components/HorizontalScroll/HorizontalScroll.module.css +10 -4
  956. package/src/components/HorizontalScroll/HorizontalScroll.tsx +47 -19
  957. package/src/components/IconButton/IconButton.module.css +9 -9
  958. package/src/components/ImageBase/ImageBase.module.css +15 -6
  959. package/src/components/ImageBase/ImageBase.tsx +16 -5
  960. package/src/components/ImageBase/ImageBaseBadge/ImageBaseBadge.module.css +5 -5
  961. package/src/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.module.css +8 -8
  962. package/src/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.module.css +2 -2
  963. package/src/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.tsx +5 -4
  964. package/src/components/ImageBase/ImageBaseOverlay/hooks.ts +31 -0
  965. package/src/components/ImageBase/ImageBaseOverlay/types.ts +4 -0
  966. package/src/components/InfoRow/InfoRow.module.css +3 -3
  967. package/src/components/Input/Input.module.css +5 -5
  968. package/src/components/InputLike/InputLike.module.css +3 -3
  969. package/src/components/Link/Link.module.css +6 -6
  970. package/src/components/Mark/Mark.module.css +2 -2
  971. package/src/components/MiniInfoCell/MiniInfoCell.module.css +5 -5
  972. package/src/components/ModalCard/ModalCard.module.css +4 -4
  973. package/src/components/ModalCard/ModalCard.tsx +1 -0
  974. package/src/components/ModalCard/ModalCardInternal.tsx +2 -0
  975. package/src/components/ModalCard/types.ts +2 -1
  976. package/src/components/ModalCardBase/ModalCardBase.module.css +7 -7
  977. package/src/components/ModalCardBase/ModalCardBase.tsx +50 -10
  978. package/src/components/ModalDismissButton/ModalDismissButton.module.css +0 -28
  979. package/src/components/ModalDismissButton/ModalDismissButton.tsx +11 -9
  980. package/src/components/ModalOutlet/ModalOutlet.module.css +1 -1
  981. package/src/components/ModalOutsideButton/ModalOutsideButton.module.css +30 -0
  982. package/src/components/ModalOutsideButton/ModalOutsideButton.tsx +38 -0
  983. package/src/components/ModalOutsideButtons/ModalOutsideButtons.module.css +6 -0
  984. package/src/components/ModalOutsideButtons/ModalOutsideButtons.tsx +14 -0
  985. package/src/components/ModalOverlay/ModalOverlay.module.css +2 -2
  986. package/src/components/ModalPage/ModalPage.module.css +15 -16
  987. package/src/components/ModalPage/ModalPageBase.tsx +92 -0
  988. package/src/components/ModalPage/ModalPageInternal.tsx +23 -42
  989. package/src/components/ModalPage/types.ts +12 -0
  990. package/src/components/ModalPageFooter/ModalPageFooter.module.css +4 -4
  991. package/src/components/ModalPageHeader/ModalPageHeader.module.css +2 -3
  992. package/src/components/OnboardingTooltip/OnboardingTooltip.module.css +1 -1
  993. package/src/components/OnboardingTooltip/OnboardingTooltip.tsx +21 -12
  994. package/src/components/OnboardingTooltip/OnboardingTooltipContainer.tsx +10 -1
  995. package/src/components/OnboardingTooltip/OnboardingTooltipContext.tsx +11 -0
  996. package/src/components/Pagination/Pagination.module.css +1 -1
  997. package/src/components/Pagination/Pagination.tsx +5 -2
  998. package/src/components/Pagination/PaginationPage/PaginationPage.module.css +8 -8
  999. package/src/components/Panel/Panel.module.css +3 -3
  1000. package/src/components/PanelHeader/PanelHeader.module.css +27 -27
  1001. package/src/components/PanelHeaderBack/PanelHeaderBack.tsx +3 -0
  1002. package/src/components/PanelHeaderButton/PanelHeaderButton.module.css +14 -8
  1003. package/src/components/PanelHeaderContent/PanelHeaderContent.module.css +10 -10
  1004. package/src/components/PanelHeaderContext/PanelHeaderContext.module.css +7 -7
  1005. package/src/components/Placeholder/Placeholder.module.css +3 -3
  1006. package/src/components/PlatformProvider/PlatformProvider.tsx +1 -1
  1007. package/src/components/PopoutWrapper/PopoutWrapper.module.css +14 -9
  1008. package/src/components/PopoutWrapper/PopoutWrapper.tsx +25 -2
  1009. package/src/components/Popover/Popover.module.css +1 -1
  1010. package/src/components/Popover/Popover.tsx +6 -4
  1011. package/src/components/Popover/usePopover.tsx +106 -85
  1012. package/src/components/Popper/Popper.tsx +17 -6
  1013. package/src/components/Progress/Progress.module.css +20 -9
  1014. package/src/components/Progress/Progress.tsx +38 -9
  1015. package/src/components/PullToRefresh/PullToRefresh.module.css +14 -14
  1016. package/src/components/Radio/Radio.module.css +1 -1
  1017. package/src/components/Radio/RadioInput/RadioInput.module.css +1 -1
  1018. package/src/components/RadioGroup/RadioGroup.module.css +1 -1
  1019. package/src/components/Removable/Removable.module.css +19 -6
  1020. package/src/components/Removable/Removable.tsx +10 -3
  1021. package/src/components/RichCell/RichCell.module.css +10 -10
  1022. package/src/components/RichCell/RichCellIcon/RichCellIcon.module.css +4 -4
  1023. package/src/components/Root/Root.module.css +10 -10
  1024. package/src/components/ScreenSpinner/ScreenSpinner.module.css +11 -11
  1025. package/src/components/ScreenSpinner/ScreenSpinner.tsx +1 -1
  1026. package/src/components/ScrollArrow/ScrollArrow.module.css +15 -14
  1027. package/src/components/ScrollArrow/ScrollArrow.tsx +10 -1
  1028. package/src/components/Search/Search.module.css +40 -28
  1029. package/src/components/Search/Search.tsx +16 -0
  1030. package/src/components/SegmentedControl/SegmentedControl.module.css +16 -7
  1031. package/src/components/SegmentedControl/SegmentedControl.tsx +11 -13
  1032. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.module.css +11 -11
  1033. package/src/components/Select/Select.module.css +14 -14
  1034. package/src/components/SelectionControl/SelectionControl.module.css +2 -2
  1035. package/src/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.module.css +5 -5
  1036. package/src/components/Separator/Separator.module.css +3 -3
  1037. package/src/components/SimpleCell/SimpleCell.module.css +18 -16
  1038. package/src/components/SimpleGrid/SimpleGrid.module.css +2 -2
  1039. package/src/components/Skeleton/Skeleton.module.css +8 -8
  1040. package/src/components/Slider/Slider.module.css +25 -4
  1041. package/src/components/Slider/Slider.tsx +23 -15
  1042. package/src/components/Slider/SliderThumb/SliderThumb.module.css +7 -7
  1043. package/src/components/Slider/SliderThumb/SliderThumb.tsx +5 -5
  1044. package/src/components/Snackbar/Snackbar.module.css +23 -6
  1045. package/src/components/Snackbar/Snackbar.tsx +7 -0
  1046. package/src/components/Snackbar/subcomponents/Basic/Basic.module.css +9 -8
  1047. package/src/components/Snackbar/utils.ts +24 -6
  1048. package/src/components/Spacing/Spacing.module.css +1 -1
  1049. package/src/components/Spinner/Spinner.module.css +2 -2
  1050. package/src/components/SplitCol/SplitCol.module.css +9 -9
  1051. package/src/components/SplitLayout/SplitLayout.module.css +2 -2
  1052. package/src/components/SubnavigationBar/SubnavigationBar.module.css +4 -4
  1053. package/src/components/SubnavigationButton/SubnavigationButton.module.css +9 -5
  1054. package/src/components/SubnavigationButton/SubnavigationButton.tsx +1 -0
  1055. package/src/components/Switch/Switch.module.css +25 -17
  1056. package/src/components/Switch/Switch.tsx +4 -0
  1057. package/src/components/Tabbar/Tabbar.module.css +5 -5
  1058. package/src/components/TabbarItem/TabbarItem.module.css +16 -16
  1059. package/src/components/Tabs/Tabs.module.css +1 -1
  1060. package/src/components/Tabs/Tabs.tsx +3 -1
  1061. package/src/components/TabsItem/TabsItem.module.css +21 -20
  1062. package/src/components/Tappable/Tappable.module.css +6 -6
  1063. package/src/components/Textarea/Textarea.module.css +7 -3
  1064. package/src/components/ToolButton/ToolButton.module.css +7 -7
  1065. package/src/components/Tooltip/Tooltip.tsx +9 -142
  1066. package/src/components/Tooltip/useTooltip.tsx +168 -0
  1067. package/src/components/TooltipBase/TooltipBase.module.css +9 -9
  1068. package/src/components/Typography/Caption/Caption.module.css +96 -96
  1069. package/src/components/Typography/DisplayTitle/DisplayTitle.module.css +64 -64
  1070. package/src/components/Typography/EllipsisText/EllipsisText.module.css +3 -3
  1071. package/src/components/Typography/Footnote/Footnote.module.css +32 -32
  1072. package/src/components/Typography/Headline/Headline.module.css +20 -20
  1073. package/src/components/Typography/Paragraph/Paragraph.module.css +16 -16
  1074. package/src/components/Typography/Subhead/Subhead.module.css +16 -16
  1075. package/src/components/Typography/Text/Text.module.css +16 -16
  1076. package/src/components/Typography/Title/Title.module.css +48 -48
  1077. package/src/components/Typography/Typography.module.css +1 -1
  1078. package/src/components/UnstyledTextField/UnstyledTextField.module.css +4 -4
  1079. package/src/components/UsersStack/UsersStack.module.css +4 -4
  1080. package/src/components/UsersStack/UsersStack.tsx +3 -7
  1081. package/src/components/View/View.module.css +8 -8
  1082. package/src/components/VisuallyHidden/VisuallyHidden.module.css +8 -8
  1083. package/src/components/WriteBar/WriteBar.module.css +10 -10
  1084. package/src/components/WriteBarIcon/WriteBarIcon.module.css +9 -9
  1085. package/src/context/CalendarDirectionContext.ts +1 -1
  1086. package/src/helpers/getValueByKey.ts +25 -0
  1087. package/src/hooks/useAutoDetectDirection.ts +18 -0
  1088. package/src/hooks/useConfigDirection.ts +8 -0
  1089. package/src/hooks/useFloatingElement.tsx +172 -0
  1090. package/src/hooks/useFocusVisible.ts +12 -1
  1091. package/src/hooks/useReferenceElement.tsx +13 -0
  1092. package/src/hooks/useTabsNavigation.ts +5 -3
  1093. package/src/hooks/useTodayDate.ts +34 -31
  1094. package/src/index.ts +9 -2
  1095. package/src/lib/SSR.tsx +11 -2
  1096. package/src/lib/date.ts +23 -0
  1097. package/src/lib/direction/index.ts +1 -0
  1098. package/src/lib/floating/adapters.ts +2 -0
  1099. package/src/lib/floating/customResizeObserver.ts +2 -1
  1100. package/src/lib/floating/functions.ts +15 -7
  1101. package/src/lib/floating/types/component.ts +10 -0
  1102. package/src/lib/floating/useFloatingMiddlewaresBootstrap/index.ts +6 -1
  1103. package/src/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.ts +2 -3
  1104. package/src/lib/floating/useReferenceHiddenChangeCallback.ts +26 -0
  1105. package/src/lib/object.ts +14 -0
  1106. package/src/lib/select.ts +2 -0
  1107. package/src/lib/sheet/controllers/BottomSheetController.ts +4 -1
  1108. package/src/lib/sheet/controllers/CSSTransitionController.ts +7 -4
  1109. package/src/lib/tokens/TokensClassProvider.module.css +1 -1
  1110. package/src/styles/common.css +2 -2
  1111. package/dist/components/ModalCardBase/ModalCardBaseCloseButton.d.ts +0 -10
  1112. package/dist/components/ModalCardBase/ModalCardBaseCloseButton.d.ts.map +0 -1
  1113. package/dist/components/ModalCardBase/ModalCardBaseCloseButton.js +0 -38
  1114. package/dist/components/ModalCardBase/ModalCardBaseCloseButton.js.map +0 -1
  1115. package/dist/cssm/components/ModalCardBase/ModalCardBaseCloseButton.js +0 -39
  1116. package/dist/cssm/components/ModalCardBase/ModalCardBaseCloseButton.js.map +0 -1
  1117. package/dist/cssm/hooks/useDirection.js +0 -55
  1118. package/dist/cssm/hooks/useDirection.js.map +0 -1
  1119. package/dist/cssm/lib/tokens/index.js +0 -5
  1120. package/dist/cssm/lib/tokens/index.js.map +0 -1
  1121. package/dist/hooks/useDirection.d.ts +0 -39
  1122. package/dist/hooks/useDirection.d.ts.map +0 -1
  1123. package/dist/hooks/useDirection.js +0 -55
  1124. package/dist/hooks/useDirection.js.map +0 -1
  1125. package/dist/lib/tokens/index.d.ts +0 -5
  1126. package/dist/lib/tokens/index.d.ts.map +0 -1
  1127. package/dist/lib/tokens/index.js +0 -5
  1128. package/dist/lib/tokens/index.js.map +0 -1
  1129. package/src/components/ModalCardBase/ModalCardBaseCloseButton.tsx +0 -51
  1130. package/src/hooks/useDirection.ts +0 -63
  1131. package/src/lib/tokens/index.ts +0 -11
@@ -6,6 +6,7 @@ import { classNames } from "@vkontakte/vkjs";
6
6
  import { isAfter } from "date-fns";
7
7
  import { useAdaptivity } from "../../hooks/useAdaptivity.js";
8
8
  import { useDateInput } from "../../hooks/useDateInput.js";
9
+ import { useCustomEnsuredControl } from "../../hooks/useEnsuredControl.js";
9
10
  import { useExternRef } from "../../hooks/useExternRef.js";
10
11
  import { callMultiple } from "../../lib/callMultiple.js";
11
12
  import { format, isMatch, parse } from "../../lib/date.js";
@@ -72,13 +73,18 @@ const getInternalValue = (value)=>{
72
73
  };
73
74
  /**
74
75
  * @see https://vkcom.github.io/VKUI/#/DateRangeInput
75
- */ export const DateRangeInput = ({ shouldDisableDate, disableFuture, disablePast, value, onChange, calendarPlacement = 'bottom-start', style, className, closeOnChange = true, disablePickers, getRootRef, name, autoFocus, disabled, onClick, onFocus, prevMonthLabel = 'Предыдущий месяц', nextMonthLabel = 'Следующий месяц', changeDayLabel = 'Изменить день', changeMonthLabel = 'Изменить месяц', changeYearLabel = 'Изменить год', changeStartDayLabel = 'Изменить день начала', changeStartMonthLabel = 'Изменить месяц начала', changeStartYearLabel = 'Изменить год начала', changeEndDayLabel = 'Изменить день окончания', changeEndMonthLabel = 'Изменить месяц окончания', changeEndYearLabel = 'Изменить год окончания', clearFieldLabel = 'Очистить поле', showCalendarLabel = 'Показать календарь', prevMonthIcon, nextMonthIcon, disableCalendar = false, onCalendarOpenChanged, renderDayContent, calendarTestsProps, startDateTestsProps, endDateTestsProps, id, ...props })=>{
76
+ */ export const DateRangeInput = ({ shouldDisableDate, disableFuture, disablePast, value: valueProp, defaultValue, onChange, calendarPlacement: calendarPlacementProp = 'bottom-start', style, className, closeOnChange = true, disablePickers, getRootRef, name, autoFocus, disabled, onClick, onFocus, prevMonthLabel = 'Предыдущий месяц', nextMonthLabel = 'Следующий месяц', changeDayLabel = 'Изменить день', changeMonthLabel = 'Изменить месяц', changeYearLabel = 'Изменить год', changeStartDayLabel = 'Изменить день начала', changeStartMonthLabel = 'Изменить месяц начала', changeStartYearLabel = 'Изменить год начала', changeEndDayLabel = 'Изменить день окончания', changeEndMonthLabel = 'Изменить месяц окончания', changeEndYearLabel = 'Изменить год окончания', clearFieldLabel = 'Очистить поле', showCalendarLabel = 'Показать календарь', prevMonthIcon, nextMonthIcon, disableCalendar = false, onCalendarOpenChanged, renderDayContent, calendarTestsProps, startDateTestsProps, endDateTestsProps, id, ...props })=>{
76
77
  const daysStartRef = React.useRef(null);
77
78
  const monthsStartRef = React.useRef(null);
78
79
  const yearsStartRef = React.useRef(null);
79
80
  const daysEndRef = React.useRef(null);
80
81
  const monthsEndRef = React.useRef(null);
81
82
  const yearsEndRef = React.useRef(null);
83
+ const [value, updateValue] = useCustomEnsuredControl({
84
+ value: valueProp,
85
+ defaultValue,
86
+ onChange
87
+ });
82
88
  const onInternalValueChange = React.useCallback((internalValue)=>{
83
89
  let isStartValid = true;
84
90
  let isEndValid = true;
@@ -109,13 +115,13 @@ const getInternalValue = (value)=>{
109
115
  const start = isStartValid ? parse(formattedStartValue, mask, valueExists && value?.[0] || now) : null;
110
116
  const end = isEndValid ? parse(formattedEndValue, mask, valueExists && value?.[1] || now) : null;
111
117
  if (start && end && isAfter(end, start)) {
112
- onChange?.([
118
+ updateValue([
113
119
  start,
114
120
  end
115
121
  ]);
116
122
  }
117
123
  }, [
118
- onChange,
124
+ updateValue,
119
125
  value
120
126
  ]);
121
127
  const refs = React.useMemo(()=>[
@@ -139,7 +145,7 @@ const getInternalValue = (value)=>{
139
145
  autoFocus,
140
146
  disabled,
141
147
  elementsConfig,
142
- onChange,
148
+ onChange: updateValue,
143
149
  onInternalValueChange,
144
150
  getInternalValue,
145
151
  value,
@@ -148,16 +154,21 @@ const getInternalValue = (value)=>{
148
154
  const { sizeY = 'none' } = useAdaptivity();
149
155
  const handleRootRef = useExternRef(rootRef, getRootRef);
150
156
  const onCalendarChange = React.useCallback((newValue)=>{
151
- onChange?.(newValue);
157
+ updateValue(newValue);
152
158
  if (closeOnChange && newValue?.[1] && newValue[1] !== value?.[1]) {
153
159
  removeFocusFromField();
154
160
  }
155
161
  }, [
156
- onChange,
162
+ updateValue,
157
163
  closeOnChange,
158
164
  value,
159
165
  removeFocusFromField
160
166
  ]);
167
+ // при переключении месяцев высота календаря может меняться,
168
+ // чтобы календарь не прыгал при переключении месяцев каждый раз на
169
+ // лучшую позицию мы запоминаем последнюю удачную, чтобы календарь оставался
170
+ // на ней, пока помещается.
171
+ const [calendarPlacement, setCalendarPlacement] = React.useState(calendarPlacementProp);
161
172
  return /*#__PURE__*/ _jsxs(FormField, {
162
173
  style: style,
163
174
  className: classNames(sizeY !== 'regular' && sizeYClassNames[sizeY], className),
@@ -186,84 +197,89 @@ const getInternalValue = (value)=>{
186
197
  onFocus: callMultiple(handleFieldEnter, onFocus),
187
198
  ...props,
188
199
  children: [
189
- /*#__PURE__*/ _jsx(VisuallyHidden, {
190
- id: id,
191
- Component: "input",
192
- name: name,
193
- value: value ? `${value[0] ? format(value[0], 'dd.MM.yyyy') : ''} - ${value[1] ? format(value[1], 'dd.MM.yyyy') : ''}` : ''
194
- }),
195
- /*#__PURE__*/ _jsxs(Text, {
196
- className: dateInputStyles.input,
197
- onKeyDown: handleKeyDown,
200
+ /*#__PURE__*/ _jsxs("div", {
201
+ className: dateInputStyles.wrapper,
198
202
  children: [
199
- /*#__PURE__*/ _jsx(InputLike, {
200
- length: 2,
201
- getRootRef: daysStartRef,
202
- index: 0,
203
- onElementSelect: setFocusedElement,
204
- value: internalValue[0],
205
- label: changeStartDayLabel,
206
- "data-testid": startDateTestsProps?.day
207
- }),
208
- /*#__PURE__*/ _jsx(InputLikeDivider, {
209
- children: "."
210
- }),
211
- /*#__PURE__*/ _jsx(InputLike, {
212
- length: 2,
213
- getRootRef: monthsStartRef,
214
- index: 1,
215
- onElementSelect: setFocusedElement,
216
- value: internalValue[1],
217
- label: changeStartMonthLabel,
218
- "data-testid": startDateTestsProps?.month
219
- }),
220
- /*#__PURE__*/ _jsx(InputLikeDivider, {
221
- children: "."
222
- }),
223
- /*#__PURE__*/ _jsx(InputLike, {
224
- length: 4,
225
- getRootRef: yearsStartRef,
226
- index: 2,
227
- onElementSelect: setFocusedElement,
228
- value: internalValue[2],
229
- label: changeStartYearLabel,
230
- "data-testid": startDateTestsProps?.year
231
- }),
232
- /*#__PURE__*/ _jsx(InputLikeDivider, {
233
- children: ' — '
234
- }),
235
- /*#__PURE__*/ _jsx(InputLike, {
236
- length: 2,
237
- getRootRef: daysEndRef,
238
- index: 3,
239
- onElementSelect: setFocusedElement,
240
- value: internalValue[3],
241
- label: changeEndDayLabel,
242
- "data-testid": endDateTestsProps?.day
243
- }),
244
- /*#__PURE__*/ _jsx(InputLikeDivider, {
245
- children: "."
246
- }),
247
- /*#__PURE__*/ _jsx(InputLike, {
248
- length: 2,
249
- getRootRef: monthsEndRef,
250
- index: 4,
251
- onElementSelect: setFocusedElement,
252
- value: internalValue[4],
253
- label: changeEndMonthLabel,
254
- "data-testid": endDateTestsProps?.month
255
- }),
256
- /*#__PURE__*/ _jsx(InputLikeDivider, {
257
- children: "."
203
+ /*#__PURE__*/ _jsx(VisuallyHidden, {
204
+ id: id,
205
+ Component: "input",
206
+ name: name,
207
+ value: value ? `${value[0] ? format(value[0], 'dd.MM.yyyy') : ''} - ${value[1] ? format(value[1], 'dd.MM.yyyy') : ''}` : ''
258
208
  }),
259
- /*#__PURE__*/ _jsx(InputLike, {
260
- length: 4,
261
- getRootRef: yearsEndRef,
262
- index: 5,
263
- onElementSelect: setFocusedElement,
264
- value: internalValue[5],
265
- label: changeEndYearLabel,
266
- "data-testid": endDateTestsProps?.year
209
+ /*#__PURE__*/ _jsxs(Text, {
210
+ className: dateInputStyles.input,
211
+ onKeyDown: handleKeyDown,
212
+ children: [
213
+ /*#__PURE__*/ _jsx(InputLike, {
214
+ length: 2,
215
+ getRootRef: daysStartRef,
216
+ index: 0,
217
+ onElementSelect: setFocusedElement,
218
+ value: internalValue[0],
219
+ label: changeStartDayLabel,
220
+ "data-testid": startDateTestsProps?.day
221
+ }),
222
+ /*#__PURE__*/ _jsx(InputLikeDivider, {
223
+ children: "."
224
+ }),
225
+ /*#__PURE__*/ _jsx(InputLike, {
226
+ length: 2,
227
+ getRootRef: monthsStartRef,
228
+ index: 1,
229
+ onElementSelect: setFocusedElement,
230
+ value: internalValue[1],
231
+ label: changeStartMonthLabel,
232
+ "data-testid": startDateTestsProps?.month
233
+ }),
234
+ /*#__PURE__*/ _jsx(InputLikeDivider, {
235
+ children: "."
236
+ }),
237
+ /*#__PURE__*/ _jsx(InputLike, {
238
+ length: 4,
239
+ getRootRef: yearsStartRef,
240
+ index: 2,
241
+ onElementSelect: setFocusedElement,
242
+ value: internalValue[2],
243
+ label: changeStartYearLabel,
244
+ "data-testid": startDateTestsProps?.year
245
+ }),
246
+ /*#__PURE__*/ _jsx(InputLikeDivider, {
247
+ children: ' — '
248
+ }),
249
+ /*#__PURE__*/ _jsx(InputLike, {
250
+ length: 2,
251
+ getRootRef: daysEndRef,
252
+ index: 3,
253
+ onElementSelect: setFocusedElement,
254
+ value: internalValue[3],
255
+ label: changeEndDayLabel,
256
+ "data-testid": endDateTestsProps?.day
257
+ }),
258
+ /*#__PURE__*/ _jsx(InputLikeDivider, {
259
+ children: "."
260
+ }),
261
+ /*#__PURE__*/ _jsx(InputLike, {
262
+ length: 2,
263
+ getRootRef: monthsEndRef,
264
+ index: 4,
265
+ onElementSelect: setFocusedElement,
266
+ value: internalValue[4],
267
+ label: changeEndMonthLabel,
268
+ "data-testid": endDateTestsProps?.month
269
+ }),
270
+ /*#__PURE__*/ _jsx(InputLikeDivider, {
271
+ children: "."
272
+ }),
273
+ /*#__PURE__*/ _jsx(InputLike, {
274
+ length: 4,
275
+ getRootRef: yearsEndRef,
276
+ index: 5,
277
+ onElementSelect: setFocusedElement,
278
+ value: internalValue[5],
279
+ label: changeEndYearLabel,
280
+ "data-testid": endDateTestsProps?.year
281
+ })
282
+ ]
267
283
  })
268
284
  ]
269
285
  }),
@@ -271,6 +287,7 @@ const getInternalValue = (value)=>{
271
287
  targetRef: rootRef,
272
288
  offsetByMainAxis: 8,
273
289
  placement: calendarPlacement,
290
+ onPlacementChange: setCalendarPlacement,
274
291
  children: /*#__PURE__*/ _jsx(CalendarRange, {
275
292
  value: value,
276
293
  onChange: onCalendarChange,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/DateRangeInput/DateRangeInput.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { Icon16Clear, Icon20CalendarOutline } from '@vkontakte/icons';\nimport { classNames } from '@vkontakte/vkjs';\nimport { isAfter } from 'date-fns';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useDateInput } from '../../hooks/useDateInput';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { format, isMatch, parse } from '../../lib/date';\nimport type { PlacementWithAuto } from '../../lib/floating';\nimport type { HasRootRef } from '../../types';\nimport {\n CalendarRange,\n type CalendarRangeProps,\n type CalendarRangeTestsProps,\n type DateRangeType,\n} from '../CalendarRange/CalendarRange';\nimport { FormField, type FormFieldProps } from '../FormField/FormField';\nimport { IconButton } from '../IconButton/IconButton';\nimport { InputLike } from '../InputLike/InputLike';\nimport { InputLikeDivider } from '../InputLike/InputLikeDivider';\nimport { Popper } from '../Popper/Popper';\nimport { Text } from '../Typography/Text/Text';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport styles from './DateRangeInput.module.css';\nimport dateInputStyles from '../DateInput/DateInput.module.css';\n\nconst sizeYClassNames = {\n none: styles.sizeYNone,\n compact: styles.sizeYCompact,\n};\n\ntype DateTestsProps = {\n /**\n * Передает атрибут `data-testid` для поля ввода дня\n */\n day?: string;\n /**\n * Передает атрибут `data-testid` для поля ввода месяца\n */\n month?: string;\n /**\n * Передает атрибут `data-testid` для поля ввода года\n */\n year?: string;\n};\n\nexport type DateRangeInputTestsProps = {\n /**\n * Передает атрибуты `data-testid` для полей ввода начальной даты\n */\n startDateTestsProps?: DateTestsProps;\n /**\n * Передает атрибуты `data-testid` для полей ввода конечной даты\n */\n endDateTestsProps?: DateTestsProps;\n};\n\nexport interface DateRangeInputProps\n extends Omit<React.InputHTMLAttributes<HTMLDivElement>, 'value' | 'onChange'>,\n Pick<\n CalendarRangeProps,\n | 'disablePast'\n | 'disableFuture'\n | 'shouldDisableDate'\n | 'onChange'\n | 'value'\n | 'weekStartsOn'\n | 'disablePickers'\n | 'prevMonthLabel'\n | 'nextMonthLabel'\n | 'changeMonthLabel'\n | 'changeYearLabel'\n | 'changeDayLabel'\n | 'prevMonthIcon'\n | 'nextMonthIcon'\n | 'renderDayContent'\n >,\n HasRootRef<HTMLDivElement>,\n Omit<FormFieldProps, 'maxHeight'>,\n DateRangeInputTestsProps {\n /**\n * Передает атрибуты `data-testid` для интерактивных элементов в календаре\n */\n calendarTestsProps?: CalendarRangeTestsProps;\n calendarPlacement?: PlacementWithAuto;\n closeOnChange?: boolean;\n onCalendarOpenChanged?: (opened: boolean) => void;\n clearFieldLabel?: string;\n showCalendarLabel?: string;\n changeStartDayLabel?: string;\n changeStartMonthLabel?: string;\n changeStartYearLabel?: string;\n changeEndDayLabel?: string;\n changeEndMonthLabel?: string;\n changeEndYearLabel?: string;\n disableCalendar?: boolean;\n}\n\nconst elementsConfig = (index: number) => {\n let length = 2;\n let min = 1;\n let max = 0;\n\n switch (index) {\n case 0:\n case 3:\n max = 31;\n break;\n case 1:\n case 4:\n max = 12;\n break;\n case 2:\n case 5:\n max = 2100;\n min = 1900;\n length = 4;\n break;\n }\n\n return { length, min, max };\n};\n\nconst getInternalValue = (value: CalendarRangeProps['value']) => {\n const newValue = ['', '', '', '', '', ''];\n if (value?.[0]) {\n newValue[0] = String(value[0].getDate()).padStart(2, '0');\n newValue[1] = String(value[0].getMonth() + 1).padStart(2, '0');\n newValue[2] = String(value[0].getFullYear()).padStart(4, '0');\n }\n if (value?.[1]) {\n newValue[3] = String(value[1].getDate()).padStart(2, '0');\n newValue[4] = String(value[1].getMonth() + 1).padStart(2, '0');\n newValue[5] = String(value[1].getFullYear()).padStart(4, '0');\n }\n return newValue;\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/DateRangeInput\n */\nexport const DateRangeInput = ({\n shouldDisableDate,\n disableFuture,\n disablePast,\n value,\n onChange,\n calendarPlacement = 'bottom-start',\n style,\n className,\n closeOnChange = true,\n disablePickers,\n getRootRef,\n name,\n autoFocus,\n disabled,\n onClick,\n onFocus,\n prevMonthLabel = 'Предыдущий месяц',\n nextMonthLabel = 'Следующий месяц',\n changeDayLabel = 'Изменить день',\n changeMonthLabel = 'Изменить месяц',\n changeYearLabel = 'Изменить год',\n changeStartDayLabel = 'Изменить день начала',\n changeStartMonthLabel = 'Изменить месяц начала',\n changeStartYearLabel = 'Изменить год начала',\n changeEndDayLabel = 'Изменить день окончания',\n changeEndMonthLabel = 'Изменить месяц окончания',\n changeEndYearLabel = 'Изменить год окончания',\n clearFieldLabel = 'Очистить поле',\n showCalendarLabel = 'Показать календарь',\n prevMonthIcon,\n nextMonthIcon,\n disableCalendar = false,\n onCalendarOpenChanged,\n renderDayContent,\n calendarTestsProps,\n startDateTestsProps,\n endDateTestsProps,\n id,\n ...props\n}: DateRangeInputProps): React.ReactNode => {\n const daysStartRef = React.useRef<HTMLSpanElement>(null);\n const monthsStartRef = React.useRef<HTMLSpanElement>(null);\n const yearsStartRef = React.useRef<HTMLSpanElement>(null);\n const daysEndRef = React.useRef<HTMLSpanElement>(null);\n const monthsEndRef = React.useRef<HTMLSpanElement>(null);\n const yearsEndRef = React.useRef<HTMLSpanElement>(null);\n\n const onInternalValueChange = React.useCallback(\n (internalValue: string[]) => {\n let isStartValid = true;\n let isEndValid = true;\n for (let i = 0; i <= 2; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n isStartValid = false;\n }\n }\n for (let i = 3; i <= 5; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n isEndValid = false;\n }\n }\n const formattedStartValue = `${internalValue[0]}.${internalValue[1]}.${internalValue[2]}`;\n const formattedEndValue = `${internalValue[3]}.${internalValue[4]}.${internalValue[5]}`;\n const mask = 'dd.MM.yyyy';\n\n if (!isMatch(formattedStartValue, mask)) {\n isStartValid = false;\n }\n if (!isMatch(formattedEndValue, mask)) {\n isEndValid = false;\n }\n\n if (!isStartValid && !isEndValid) {\n return;\n }\n\n const valueExists = Array.isArray(value);\n const now = new Date();\n const start = isStartValid\n ? parse(formattedStartValue, mask, (valueExists && value?.[0]) || now)\n : null;\n const end = isEndValid\n ? parse(formattedEndValue, mask, (valueExists && value?.[1]) || now)\n : null;\n if (start && end && isAfter(end, start)) {\n onChange?.([start, end]);\n }\n },\n [onChange, value],\n );\n\n const refs = React.useMemo(\n () => [daysStartRef, monthsStartRef, yearsStartRef, daysEndRef, monthsEndRef, yearsEndRef],\n [daysStartRef, monthsStartRef, yearsStartRef, daysEndRef, monthsEndRef, yearsEndRef],\n );\n\n const {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n closeCalendar,\n internalValue,\n handleKeyDown,\n setFocusedElement,\n handleFieldEnter,\n clear,\n removeFocusFromField,\n } = useDateInput({\n maxElement: 5,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange,\n onInternalValueChange,\n getInternalValue,\n value,\n onCalendarOpenChanged,\n });\n\n const { sizeY = 'none' } = useAdaptivity();\n\n const handleRootRef = useExternRef(rootRef, getRootRef);\n\n const onCalendarChange = React.useCallback(\n (newValue: DateRangeType | undefined) => {\n onChange?.(newValue);\n if (closeOnChange && newValue?.[1] && newValue[1] !== value?.[1]) {\n removeFocusFromField();\n }\n },\n [onChange, closeOnChange, value, removeFocusFromField],\n );\n\n return (\n <FormField\n style={style}\n className={classNames(sizeY !== 'regular' && sizeYClassNames[sizeY], className)}\n getRootRef={handleRootRef}\n after={\n value ? (\n <IconButton hoverMode=\"opacity\" onClick={clear}>\n <VisuallyHidden>{clearFieldLabel}</VisuallyHidden>\n <Icon16Clear />\n </IconButton>\n ) : (\n <IconButton hoverMode=\"opacity\" onClick={openCalendar}>\n <VisuallyHidden>{showCalendarLabel}</VisuallyHidden>\n <Icon20CalendarOutline />\n </IconButton>\n )\n }\n disabled={disabled}\n onClick={callMultiple(handleFieldEnter, onClick)}\n onFocus={callMultiple(handleFieldEnter, onFocus)}\n {...props}\n >\n <VisuallyHidden\n id={id}\n Component=\"input\"\n name={name}\n value={\n value\n ? `${value[0] ? format(value[0], 'dd.MM.yyyy') : ''} - ${\n value[1] ? format(value[1], 'dd.MM.yyyy') : ''\n }`\n : ''\n }\n />\n <Text className={dateInputStyles.input} onKeyDown={handleKeyDown}>\n <InputLike\n length={2}\n getRootRef={daysStartRef}\n index={0}\n onElementSelect={setFocusedElement}\n value={internalValue[0]}\n label={changeStartDayLabel}\n data-testid={startDateTestsProps?.day}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsStartRef}\n index={1}\n onElementSelect={setFocusedElement}\n value={internalValue[1]}\n label={changeStartMonthLabel}\n data-testid={startDateTestsProps?.month}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsStartRef}\n index={2}\n onElementSelect={setFocusedElement}\n value={internalValue[2]}\n label={changeStartYearLabel}\n data-testid={startDateTestsProps?.year}\n />\n <InputLikeDivider>{' — '}</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={daysEndRef}\n index={3}\n onElementSelect={setFocusedElement}\n value={internalValue[3]}\n label={changeEndDayLabel}\n data-testid={endDateTestsProps?.day}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsEndRef}\n index={4}\n onElementSelect={setFocusedElement}\n value={internalValue[4]}\n label={changeEndMonthLabel}\n data-testid={endDateTestsProps?.month}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsEndRef}\n index={5}\n onElementSelect={setFocusedElement}\n value={internalValue[5]}\n label={changeEndYearLabel}\n data-testid={endDateTestsProps?.year}\n />\n </Text>\n {open && !disableCalendar && (\n <Popper targetRef={rootRef} offsetByMainAxis={8} placement={calendarPlacement}>\n <CalendarRange\n value={value}\n onChange={onCalendarChange}\n disablePast={disablePast}\n disableFuture={disableFuture}\n shouldDisableDate={shouldDisableDate}\n onClose={closeCalendar}\n getRootRef={calendarRef}\n disablePickers={disablePickers}\n prevMonthLabel={prevMonthLabel}\n nextMonthLabel={nextMonthLabel}\n changeMonthLabel={changeMonthLabel}\n changeYearLabel={changeYearLabel}\n changeDayLabel={changeDayLabel}\n prevMonthIcon={prevMonthIcon}\n nextMonthIcon={nextMonthIcon}\n renderDayContent={renderDayContent}\n {...calendarTestsProps}\n />\n </Popper>\n )}\n </FormField>\n );\n};\n"],"names":["React","Icon16Clear","Icon20CalendarOutline","classNames","isAfter","useAdaptivity","useDateInput","useExternRef","callMultiple","format","isMatch","parse","CalendarRange","FormField","IconButton","InputLike","InputLikeDivider","Popper","Text","VisuallyHidden","styles","dateInputStyles","sizeYClassNames","none","sizeYNone","compact","sizeYCompact","elementsConfig","index","length","min","max","getInternalValue","value","newValue","String","getDate","padStart","getMonth","getFullYear","DateRangeInput","shouldDisableDate","disableFuture","disablePast","onChange","calendarPlacement","style","className","closeOnChange","disablePickers","getRootRef","name","autoFocus","disabled","onClick","onFocus","prevMonthLabel","nextMonthLabel","changeDayLabel","changeMonthLabel","changeYearLabel","changeStartDayLabel","changeStartMonthLabel","changeStartYearLabel","changeEndDayLabel","changeEndMonthLabel","changeEndYearLabel","clearFieldLabel","showCalendarLabel","prevMonthIcon","nextMonthIcon","disableCalendar","onCalendarOpenChanged","renderDayContent","calendarTestsProps","startDateTestsProps","endDateTestsProps","id","props","daysStartRef","useRef","monthsStartRef","yearsStartRef","daysEndRef","monthsEndRef","yearsEndRef","onInternalValueChange","useCallback","internalValue","isStartValid","isEndValid","i","formattedStartValue","formattedEndValue","mask","valueExists","Array","isArray","now","Date","start","end","refs","useMemo","rootRef","calendarRef","open","openCalendar","closeCalendar","handleKeyDown","setFocusedElement","handleFieldEnter","clear","removeFocusFromField","maxElement","sizeY","handleRootRef","onCalendarChange","after","hoverMode","Component","input","onKeyDown","onElementSelect","label","data-testid","day","month","year","targetRef","offsetByMainAxis","placement","onClose"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/components/DateRangeInput/DateRangeInput.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { Icon16Clear, Icon20CalendarOutline } from '@vkontakte/icons';\nimport { classNames } from '@vkontakte/vkjs';\nimport { isAfter } from 'date-fns';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useDateInput } from '../../hooks/useDateInput';\nimport { useCustomEnsuredControl } from '../../hooks/useEnsuredControl';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { format, isMatch, parse } from '../../lib/date';\nimport type { PlacementWithAuto } from '../../lib/floating';\nimport type { HasRootRef } from '../../types';\nimport {\n CalendarRange,\n type CalendarRangeProps,\n type CalendarRangeTestsProps,\n type DateRangeType,\n} from '../CalendarRange/CalendarRange';\nimport { FormField, type FormFieldProps } from '../FormField/FormField';\nimport { IconButton } from '../IconButton/IconButton';\nimport { InputLike } from '../InputLike/InputLike';\nimport { InputLikeDivider } from '../InputLike/InputLikeDivider';\nimport { Popper } from '../Popper/Popper';\nimport { Text } from '../Typography/Text/Text';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport styles from './DateRangeInput.module.css';\nimport dateInputStyles from '../DateInput/DateInput.module.css';\n\nconst sizeYClassNames = {\n none: styles.sizeYNone,\n compact: styles.sizeYCompact,\n};\n\ntype DateTestsProps = {\n /**\n * Передает атрибут `data-testid` для поля ввода дня\n */\n day?: string;\n /**\n * Передает атрибут `data-testid` для поля ввода месяца\n */\n month?: string;\n /**\n * Передает атрибут `data-testid` для поля ввода года\n */\n year?: string;\n};\n\nexport type DateRangeInputTestsProps = {\n /**\n * Передает атрибуты `data-testid` для полей ввода начальной даты\n */\n startDateTestsProps?: DateTestsProps;\n /**\n * Передает атрибуты `data-testid` для полей ввода конечной даты\n */\n endDateTestsProps?: DateTestsProps;\n};\n\nexport interface DateRangeInputProps\n extends Omit<React.InputHTMLAttributes<HTMLDivElement>, 'value' | 'defaultValue' | 'onChange'>,\n Pick<\n CalendarRangeProps,\n | 'disablePast'\n | 'disableFuture'\n | 'shouldDisableDate'\n | 'onChange'\n | 'value'\n | 'defaultValue'\n | 'weekStartsOn'\n | 'disablePickers'\n | 'prevMonthLabel'\n | 'nextMonthLabel'\n | 'changeMonthLabel'\n | 'changeYearLabel'\n | 'changeDayLabel'\n | 'prevMonthIcon'\n | 'nextMonthIcon'\n | 'renderDayContent'\n >,\n HasRootRef<HTMLDivElement>,\n Omit<FormFieldProps, 'maxHeight'>,\n DateRangeInputTestsProps {\n /**\n * Передает атрибуты `data-testid` для интерактивных элементов в календаре\n */\n calendarTestsProps?: CalendarRangeTestsProps;\n calendarPlacement?: PlacementWithAuto;\n closeOnChange?: boolean;\n onCalendarOpenChanged?: (opened: boolean) => void;\n clearFieldLabel?: string;\n showCalendarLabel?: string;\n changeStartDayLabel?: string;\n changeStartMonthLabel?: string;\n changeStartYearLabel?: string;\n changeEndDayLabel?: string;\n changeEndMonthLabel?: string;\n changeEndYearLabel?: string;\n disableCalendar?: boolean;\n}\n\nconst elementsConfig = (index: number) => {\n let length = 2;\n let min = 1;\n let max = 0;\n\n switch (index) {\n case 0:\n case 3:\n max = 31;\n break;\n case 1:\n case 4:\n max = 12;\n break;\n case 2:\n case 5:\n max = 2100;\n min = 1900;\n length = 4;\n break;\n }\n\n return { length, min, max };\n};\n\nconst getInternalValue = (value: CalendarRangeProps['value']) => {\n const newValue = ['', '', '', '', '', ''];\n if (value?.[0]) {\n newValue[0] = String(value[0].getDate()).padStart(2, '0');\n newValue[1] = String(value[0].getMonth() + 1).padStart(2, '0');\n newValue[2] = String(value[0].getFullYear()).padStart(4, '0');\n }\n if (value?.[1]) {\n newValue[3] = String(value[1].getDate()).padStart(2, '0');\n newValue[4] = String(value[1].getMonth() + 1).padStart(2, '0');\n newValue[5] = String(value[1].getFullYear()).padStart(4, '0');\n }\n return newValue;\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/DateRangeInput\n */\nexport const DateRangeInput = ({\n shouldDisableDate,\n disableFuture,\n disablePast,\n value: valueProp,\n defaultValue,\n onChange,\n calendarPlacement: calendarPlacementProp = 'bottom-start',\n style,\n className,\n closeOnChange = true,\n disablePickers,\n getRootRef,\n name,\n autoFocus,\n disabled,\n onClick,\n onFocus,\n prevMonthLabel = 'Предыдущий месяц',\n nextMonthLabel = 'Следующий месяц',\n changeDayLabel = 'Изменить день',\n changeMonthLabel = 'Изменить месяц',\n changeYearLabel = 'Изменить год',\n changeStartDayLabel = 'Изменить день начала',\n changeStartMonthLabel = 'Изменить месяц начала',\n changeStartYearLabel = 'Изменить год начала',\n changeEndDayLabel = 'Изменить день окончания',\n changeEndMonthLabel = 'Изменить месяц окончания',\n changeEndYearLabel = 'Изменить год окончания',\n clearFieldLabel = 'Очистить поле',\n showCalendarLabel = 'Показать календарь',\n prevMonthIcon,\n nextMonthIcon,\n disableCalendar = false,\n onCalendarOpenChanged,\n renderDayContent,\n calendarTestsProps,\n startDateTestsProps,\n endDateTestsProps,\n id,\n ...props\n}: DateRangeInputProps): React.ReactNode => {\n const daysStartRef = React.useRef<HTMLSpanElement>(null);\n const monthsStartRef = React.useRef<HTMLSpanElement>(null);\n const yearsStartRef = React.useRef<HTMLSpanElement>(null);\n const daysEndRef = React.useRef<HTMLSpanElement>(null);\n const monthsEndRef = React.useRef<HTMLSpanElement>(null);\n const yearsEndRef = React.useRef<HTMLSpanElement>(null);\n\n const [value, updateValue] = useCustomEnsuredControl<DateRangeType | undefined>({\n value: valueProp,\n defaultValue,\n onChange,\n });\n\n const onInternalValueChange = React.useCallback(\n (internalValue: string[]) => {\n let isStartValid = true;\n let isEndValid = true;\n for (let i = 0; i <= 2; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n isStartValid = false;\n }\n }\n for (let i = 3; i <= 5; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n isEndValid = false;\n }\n }\n const formattedStartValue = `${internalValue[0]}.${internalValue[1]}.${internalValue[2]}`;\n const formattedEndValue = `${internalValue[3]}.${internalValue[4]}.${internalValue[5]}`;\n const mask = 'dd.MM.yyyy';\n\n if (!isMatch(formattedStartValue, mask)) {\n isStartValid = false;\n }\n if (!isMatch(formattedEndValue, mask)) {\n isEndValid = false;\n }\n\n if (!isStartValid && !isEndValid) {\n return;\n }\n\n const valueExists = Array.isArray(value);\n const now = new Date();\n const start = isStartValid\n ? parse(formattedStartValue, mask, (valueExists && value?.[0]) || now)\n : null;\n const end = isEndValid\n ? parse(formattedEndValue, mask, (valueExists && value?.[1]) || now)\n : null;\n if (start && end && isAfter(end, start)) {\n updateValue([start, end]);\n }\n },\n [updateValue, value],\n );\n\n const refs = React.useMemo(\n () => [daysStartRef, monthsStartRef, yearsStartRef, daysEndRef, monthsEndRef, yearsEndRef],\n [daysStartRef, monthsStartRef, yearsStartRef, daysEndRef, monthsEndRef, yearsEndRef],\n );\n\n const {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n closeCalendar,\n internalValue,\n handleKeyDown,\n setFocusedElement,\n handleFieldEnter,\n clear,\n removeFocusFromField,\n } = useDateInput({\n maxElement: 5,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange: updateValue,\n onInternalValueChange,\n getInternalValue,\n value,\n onCalendarOpenChanged,\n });\n\n const { sizeY = 'none' } = useAdaptivity();\n\n const handleRootRef = useExternRef(rootRef, getRootRef);\n\n const onCalendarChange = React.useCallback(\n (newValue: DateRangeType | undefined) => {\n updateValue(newValue);\n if (closeOnChange && newValue?.[1] && newValue[1] !== value?.[1]) {\n removeFocusFromField();\n }\n },\n [updateValue, closeOnChange, value, removeFocusFromField],\n );\n\n // при переключении месяцев высота календаря может меняться,\n // чтобы календарь не прыгал при переключении месяцев каждый раз на\n // лучшую позицию мы запоминаем последнюю удачную, чтобы календарь оставался\n // на ней, пока помещается.\n const [calendarPlacement, setCalendarPlacement] =\n React.useState<PlacementWithAuto>(calendarPlacementProp);\n\n return (\n <FormField\n style={style}\n className={classNames(sizeY !== 'regular' && sizeYClassNames[sizeY], className)}\n getRootRef={handleRootRef}\n after={\n value ? (\n <IconButton hoverMode=\"opacity\" onClick={clear}>\n <VisuallyHidden>{clearFieldLabel}</VisuallyHidden>\n <Icon16Clear />\n </IconButton>\n ) : (\n <IconButton hoverMode=\"opacity\" onClick={openCalendar}>\n <VisuallyHidden>{showCalendarLabel}</VisuallyHidden>\n <Icon20CalendarOutline />\n </IconButton>\n )\n }\n disabled={disabled}\n onClick={callMultiple(handleFieldEnter, onClick)}\n onFocus={callMultiple(handleFieldEnter, onFocus)}\n {...props}\n >\n <div className={dateInputStyles.wrapper}>\n <VisuallyHidden\n id={id}\n Component=\"input\"\n name={name}\n value={\n value\n ? `${value[0] ? format(value[0], 'dd.MM.yyyy') : ''} - ${\n value[1] ? format(value[1], 'dd.MM.yyyy') : ''\n }`\n : ''\n }\n />\n <Text className={dateInputStyles.input} onKeyDown={handleKeyDown}>\n <InputLike\n length={2}\n getRootRef={daysStartRef}\n index={0}\n onElementSelect={setFocusedElement}\n value={internalValue[0]}\n label={changeStartDayLabel}\n data-testid={startDateTestsProps?.day}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsStartRef}\n index={1}\n onElementSelect={setFocusedElement}\n value={internalValue[1]}\n label={changeStartMonthLabel}\n data-testid={startDateTestsProps?.month}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsStartRef}\n index={2}\n onElementSelect={setFocusedElement}\n value={internalValue[2]}\n label={changeStartYearLabel}\n data-testid={startDateTestsProps?.year}\n />\n <InputLikeDivider>{' — '}</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={daysEndRef}\n index={3}\n onElementSelect={setFocusedElement}\n value={internalValue[3]}\n label={changeEndDayLabel}\n data-testid={endDateTestsProps?.day}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsEndRef}\n index={4}\n onElementSelect={setFocusedElement}\n value={internalValue[4]}\n label={changeEndMonthLabel}\n data-testid={endDateTestsProps?.month}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsEndRef}\n index={5}\n onElementSelect={setFocusedElement}\n value={internalValue[5]}\n label={changeEndYearLabel}\n data-testid={endDateTestsProps?.year}\n />\n </Text>\n </div>\n {open && !disableCalendar && (\n <Popper\n targetRef={rootRef}\n offsetByMainAxis={8}\n placement={calendarPlacement}\n onPlacementChange={setCalendarPlacement}\n >\n <CalendarRange\n value={value}\n onChange={onCalendarChange}\n disablePast={disablePast}\n disableFuture={disableFuture}\n shouldDisableDate={shouldDisableDate}\n onClose={closeCalendar}\n getRootRef={calendarRef}\n disablePickers={disablePickers}\n prevMonthLabel={prevMonthLabel}\n nextMonthLabel={nextMonthLabel}\n changeMonthLabel={changeMonthLabel}\n changeYearLabel={changeYearLabel}\n changeDayLabel={changeDayLabel}\n prevMonthIcon={prevMonthIcon}\n nextMonthIcon={nextMonthIcon}\n renderDayContent={renderDayContent}\n {...calendarTestsProps}\n />\n </Popper>\n )}\n </FormField>\n );\n};\n"],"names":["React","Icon16Clear","Icon20CalendarOutline","classNames","isAfter","useAdaptivity","useDateInput","useCustomEnsuredControl","useExternRef","callMultiple","format","isMatch","parse","CalendarRange","FormField","IconButton","InputLike","InputLikeDivider","Popper","Text","VisuallyHidden","styles","dateInputStyles","sizeYClassNames","none","sizeYNone","compact","sizeYCompact","elementsConfig","index","length","min","max","getInternalValue","value","newValue","String","getDate","padStart","getMonth","getFullYear","DateRangeInput","shouldDisableDate","disableFuture","disablePast","valueProp","defaultValue","onChange","calendarPlacement","calendarPlacementProp","style","className","closeOnChange","disablePickers","getRootRef","name","autoFocus","disabled","onClick","onFocus","prevMonthLabel","nextMonthLabel","changeDayLabel","changeMonthLabel","changeYearLabel","changeStartDayLabel","changeStartMonthLabel","changeStartYearLabel","changeEndDayLabel","changeEndMonthLabel","changeEndYearLabel","clearFieldLabel","showCalendarLabel","prevMonthIcon","nextMonthIcon","disableCalendar","onCalendarOpenChanged","renderDayContent","calendarTestsProps","startDateTestsProps","endDateTestsProps","id","props","daysStartRef","useRef","monthsStartRef","yearsStartRef","daysEndRef","monthsEndRef","yearsEndRef","updateValue","onInternalValueChange","useCallback","internalValue","isStartValid","isEndValid","i","formattedStartValue","formattedEndValue","mask","valueExists","Array","isArray","now","Date","start","end","refs","useMemo","rootRef","calendarRef","open","openCalendar","closeCalendar","handleKeyDown","setFocusedElement","handleFieldEnter","clear","removeFocusFromField","maxElement","sizeY","handleRootRef","onCalendarChange","setCalendarPlacement","useState","after","hoverMode","div","wrapper","Component","input","onKeyDown","onElementSelect","label","data-testid","day","month","year","targetRef","offsetByMainAxis","placement","onPlacementChange","onClose"],"mappings":"AAAA;;AAEA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,WAAW,EAAEC,qBAAqB,QAAQ,mBAAmB;AACtE,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,OAAO,QAAQ,WAAW;AACnC,SAASC,aAAa,QAAQ,+BAA4B;AAC1D,SAASC,YAAY,QAAQ,8BAA2B;AACxD,SAASC,uBAAuB,QAAQ,mCAAgC;AACxE,SAASC,YAAY,QAAQ,8BAA2B;AACxD,SAASC,YAAY,QAAQ,4BAAyB;AACtD,SAASC,MAAM,EAAEC,OAAO,EAAEC,KAAK,QAAQ,oBAAiB;AAGxD,SACEC,aAAa,QAIR,oCAAiC;AACxC,SAASC,SAAS,QAA6B,4BAAyB;AACxE,SAASC,UAAU,QAAQ,8BAA2B;AACtD,SAASC,SAAS,QAAQ,4BAAyB;AACnD,SAASC,gBAAgB,QAAQ,mCAAgC;AACjE,SAASC,MAAM,QAAQ,sBAAmB;AAC1C,SAASC,IAAI,QAAQ,6BAA0B;AAC/C,SAASC,cAAc,QAAQ,sCAAmC;AAClE,OAAOC,YAAY,8BAA8B;AACjD,OAAOC,qBAAqB,oCAAoC;AAEhE,MAAMC,kBAAkB;IACtBC,MAAMH,OAAOI,SAAS;IACtBC,SAASL,OAAOM,YAAY;AAC9B;AAsEA,MAAMC,iBAAiB,CAACC;IACtB,IAAIC,SAAS;IACb,IAAIC,MAAM;IACV,IAAIC,MAAM;IAEV,OAAQH;QACN,KAAK;QACL,KAAK;YACHG,MAAM;YACN;QACF,KAAK;QACL,KAAK;YACHA,MAAM;YACN;QACF,KAAK;QACL,KAAK;YACHA,MAAM;YACND,MAAM;YACND,SAAS;YACT;IACJ;IAEA,OAAO;QAAEA;QAAQC;QAAKC;IAAI;AAC5B;AAEA,MAAMC,mBAAmB,CAACC;IACxB,MAAMC,WAAW;QAAC;QAAI;QAAI;QAAI;QAAI;QAAI;KAAG;IACzC,IAAID,OAAO,CAAC,EAAE,EAAE;QACdC,QAAQ,CAAC,EAAE,GAAGC,OAAOF,KAAK,CAAC,EAAE,CAACG,OAAO,IAAIC,QAAQ,CAAC,GAAG;QACrDH,QAAQ,CAAC,EAAE,GAAGC,OAAOF,KAAK,CAAC,EAAE,CAACK,QAAQ,KAAK,GAAGD,QAAQ,CAAC,GAAG;QAC1DH,QAAQ,CAAC,EAAE,GAAGC,OAAOF,KAAK,CAAC,EAAE,CAACM,WAAW,IAAIF,QAAQ,CAAC,GAAG;IAC3D;IACA,IAAIJ,OAAO,CAAC,EAAE,EAAE;QACdC,QAAQ,CAAC,EAAE,GAAGC,OAAOF,KAAK,CAAC,EAAE,CAACG,OAAO,IAAIC,QAAQ,CAAC,GAAG;QACrDH,QAAQ,CAAC,EAAE,GAAGC,OAAOF,KAAK,CAAC,EAAE,CAACK,QAAQ,KAAK,GAAGD,QAAQ,CAAC,GAAG;QAC1DH,QAAQ,CAAC,EAAE,GAAGC,OAAOF,KAAK,CAAC,EAAE,CAACM,WAAW,IAAIF,QAAQ,CAAC,GAAG;IAC3D;IACA,OAAOH;AACT;AAEA;;CAEC,GACD,OAAO,MAAMM,iBAAiB,CAAC,EAC7BC,iBAAiB,EACjBC,aAAa,EACbC,WAAW,EACXV,OAAOW,SAAS,EAChBC,YAAY,EACZC,QAAQ,EACRC,mBAAmBC,wBAAwB,cAAc,EACzDC,KAAK,EACLC,SAAS,EACTC,gBAAgB,IAAI,EACpBC,cAAc,EACdC,UAAU,EACVC,IAAI,EACJC,SAAS,EACTC,QAAQ,EACRC,OAAO,EACPC,OAAO,EACPC,iBAAiB,kBAAkB,EACnCC,iBAAiB,iBAAiB,EAClCC,iBAAiB,eAAe,EAChCC,mBAAmB,gBAAgB,EACnCC,kBAAkB,cAAc,EAChCC,sBAAsB,sBAAsB,EAC5CC,wBAAwB,uBAAuB,EAC/CC,uBAAuB,qBAAqB,EAC5CC,oBAAoB,yBAAyB,EAC7CC,sBAAsB,0BAA0B,EAChDC,qBAAqB,wBAAwB,EAC7CC,kBAAkB,eAAe,EACjCC,oBAAoB,oBAAoB,EACxCC,aAAa,EACbC,aAAa,EACbC,kBAAkB,KAAK,EACvBC,qBAAqB,EACrBC,gBAAgB,EAChBC,kBAAkB,EAClBC,mBAAmB,EACnBC,iBAAiB,EACjBC,EAAE,EACF,GAAGC,OACiB;IACpB,MAAMC,eAAenF,MAAMoF,MAAM,CAAkB;IACnD,MAAMC,iBAAiBrF,MAAMoF,MAAM,CAAkB;IACrD,MAAME,gBAAgBtF,MAAMoF,MAAM,CAAkB;IACpD,MAAMG,aAAavF,MAAMoF,MAAM,CAAkB;IACjD,MAAMI,eAAexF,MAAMoF,MAAM,CAAkB;IACnD,MAAMK,cAAczF,MAAMoF,MAAM,CAAkB;IAElD,MAAM,CAAClD,OAAOwD,YAAY,GAAGnF,wBAAmD;QAC9E2B,OAAOW;QACPC;QACAC;IACF;IAEA,MAAM4C,wBAAwB3F,MAAM4F,WAAW,CAC7C,CAACC;QACC,IAAIC,eAAe;QACnB,IAAIC,aAAa;QACjB,IAAK,IAAIC,IAAI,GAAGA,KAAK,GAAGA,KAAK,EAAG;YAC9B,IAAIH,aAAa,CAACG,EAAE,CAAClE,MAAM,GAAGF,eAAeoE,GAAGlE,MAAM,EAAE;gBACtDgE,eAAe;YACjB;QACF;QACA,IAAK,IAAIE,IAAI,GAAGA,KAAK,GAAGA,KAAK,EAAG;YAC9B,IAAIH,aAAa,CAACG,EAAE,CAAClE,MAAM,GAAGF,eAAeoE,GAAGlE,MAAM,EAAE;gBACtDiE,aAAa;YACf;QACF;QACA,MAAME,sBAAsB,GAAGJ,aAAa,CAAC,EAAE,CAAC,CAAC,EAAEA,aAAa,CAAC,EAAE,CAAC,CAAC,EAAEA,aAAa,CAAC,EAAE,EAAE;QACzF,MAAMK,oBAAoB,GAAGL,aAAa,CAAC,EAAE,CAAC,CAAC,EAAEA,aAAa,CAAC,EAAE,CAAC,CAAC,EAAEA,aAAa,CAAC,EAAE,EAAE;QACvF,MAAMM,OAAO;QAEb,IAAI,CAACxF,QAAQsF,qBAAqBE,OAAO;YACvCL,eAAe;QACjB;QACA,IAAI,CAACnF,QAAQuF,mBAAmBC,OAAO;YACrCJ,aAAa;QACf;QAEA,IAAI,CAACD,gBAAgB,CAACC,YAAY;YAChC;QACF;QAEA,MAAMK,cAAcC,MAAMC,OAAO,CAACpE;QAClC,MAAMqE,MAAM,IAAIC;QAChB,MAAMC,QAAQX,eACVlF,MAAMqF,qBAAqBE,MAAM,AAACC,eAAelE,OAAO,CAAC,EAAE,IAAKqE,OAChE;QACJ,MAAMG,MAAMX,aACRnF,MAAMsF,mBAAmBC,MAAM,AAACC,eAAelE,OAAO,CAAC,EAAE,IAAKqE,OAC9D;QACJ,IAAIE,SAASC,OAAOtG,QAAQsG,KAAKD,QAAQ;YACvCf,YAAY;gBAACe;gBAAOC;aAAI;QAC1B;IACF,GACA;QAAChB;QAAaxD;KAAM;IAGtB,MAAMyE,OAAO3G,MAAM4G,OAAO,CACxB,IAAM;YAACzB;YAAcE;YAAgBC;YAAeC;YAAYC;YAAcC;SAAY,EAC1F;QAACN;QAAcE;QAAgBC;QAAeC;QAAYC;QAAcC;KAAY;IAGtF,MAAM,EACJoB,OAAO,EACPC,WAAW,EACXC,IAAI,EACJC,YAAY,EACZC,aAAa,EACbpB,aAAa,EACbqB,aAAa,EACbC,iBAAiB,EACjBC,gBAAgB,EAChBC,KAAK,EACLC,oBAAoB,EACrB,GAAGhH,aAAa;QACfiH,YAAY;QACZZ;QACAnD;QACAC;QACA7B;QACAmB,UAAU2C;QACVC;QACA1D;QACAC;QACA0C;IACF;IAEA,MAAM,EAAE4C,QAAQ,MAAM,EAAE,GAAGnH;IAE3B,MAAMoH,gBAAgBjH,aAAaqG,SAASvD;IAE5C,MAAMoE,mBAAmB1H,MAAM4F,WAAW,CACxC,CAACzD;QACCuD,YAAYvD;QACZ,IAAIiB,iBAAiBjB,UAAU,CAAC,EAAE,IAAIA,QAAQ,CAAC,EAAE,KAAKD,OAAO,CAAC,EAAE,EAAE;YAChEoF;QACF;IACF,GACA;QAAC5B;QAAatC;QAAelB;QAAOoF;KAAqB;IAG3D,4DAA4D;IAC5D,mEAAmE;IACnE,4EAA4E;IAC5E,2BAA2B;IAC3B,MAAM,CAACtE,mBAAmB2E,qBAAqB,GAC7C3H,MAAM4H,QAAQ,CAAoB3E;IAEpC,qBACE,MAACnC;QACCoC,OAAOA;QACPC,WAAWhD,WAAWqH,UAAU,aAAajG,eAAe,CAACiG,MAAM,EAAErE;QACrEG,YAAYmE;QACZI,OACE3F,sBACE,MAACnB;YAAW+G,WAAU;YAAUpE,SAAS2D;;8BACvC,KAACjG;8BAAgBmD;;8BACjB,KAACtE;;2BAGH,MAACc;YAAW+G,WAAU;YAAUpE,SAASsD;;8BACvC,KAAC5F;8BAAgBoD;;8BACjB,KAACtE;;;QAIPuD,UAAUA;QACVC,SAASjD,aAAa2G,kBAAkB1D;QACxCC,SAASlD,aAAa2G,kBAAkBzD;QACvC,GAAGuB,KAAK;;0BAET,MAAC6C;gBAAI5E,WAAW7B,gBAAgB0G,OAAO;;kCACrC,KAAC5G;wBACC6D,IAAIA;wBACJgD,WAAU;wBACV1E,MAAMA;wBACNrB,OACEA,QACI,GAAGA,KAAK,CAAC,EAAE,GAAGxB,OAAOwB,KAAK,CAAC,EAAE,EAAE,gBAAgB,GAAG,GAAG,EACnDA,KAAK,CAAC,EAAE,GAAGxB,OAAOwB,KAAK,CAAC,EAAE,EAAE,gBAAgB,IAC5C,GACF;;kCAGR,MAACf;wBAAKgC,WAAW7B,gBAAgB4G,KAAK;wBAAEC,WAAWjB;;0CACjD,KAAClG;gCACCc,QAAQ;gCACRwB,YAAY6B;gCACZtD,OAAO;gCACPuG,iBAAiBjB;gCACjBjF,OAAO2D,aAAa,CAAC,EAAE;gCACvBwC,OAAOpE;gCACPqE,eAAavD,qBAAqBwD;;0CAEpC,KAACtH;0CAAiB;;0CAClB,KAACD;gCACCc,QAAQ;gCACRwB,YAAY+B;gCACZxD,OAAO;gCACPuG,iBAAiBjB;gCACjBjF,OAAO2D,aAAa,CAAC,EAAE;gCACvBwC,OAAOnE;gCACPoE,eAAavD,qBAAqByD;;0CAEpC,KAACvH;0CAAiB;;0CAClB,KAACD;gCACCc,QAAQ;gCACRwB,YAAYgC;gCACZzD,OAAO;gCACPuG,iBAAiBjB;gCACjBjF,OAAO2D,aAAa,CAAC,EAAE;gCACvBwC,OAAOlE;gCACPmE,eAAavD,qBAAqB0D;;0CAEpC,KAACxH;0CAAkB;;0CACnB,KAACD;gCACCc,QAAQ;gCACRwB,YAAYiC;gCACZ1D,OAAO;gCACPuG,iBAAiBjB;gCACjBjF,OAAO2D,aAAa,CAAC,EAAE;gCACvBwC,OAAOjE;gCACPkE,eAAatD,mBAAmBuD;;0CAElC,KAACtH;0CAAiB;;0CAClB,KAACD;gCACCc,QAAQ;gCACRwB,YAAYkC;gCACZ3D,OAAO;gCACPuG,iBAAiBjB;gCACjBjF,OAAO2D,aAAa,CAAC,EAAE;gCACvBwC,OAAOhE;gCACPiE,eAAatD,mBAAmBwD;;0CAElC,KAACvH;0CAAiB;;0CAClB,KAACD;gCACCc,QAAQ;gCACRwB,YAAYmC;gCACZ5D,OAAO;gCACPuG,iBAAiBjB;gCACjBjF,OAAO2D,aAAa,CAAC,EAAE;gCACvBwC,OAAO/D;gCACPgE,eAAatD,mBAAmByD;;;;;;YAIrC1B,QAAQ,CAACpC,iCACR,KAACzD;gBACCwH,WAAW7B;gBACX8B,kBAAkB;gBAClBC,WAAW5F;gBACX6F,mBAAmBlB;0BAEnB,cAAA,KAAC9G;oBACCqB,OAAOA;oBACPa,UAAU2E;oBACV9E,aAAaA;oBACbD,eAAeA;oBACfD,mBAAmBA;oBACnBoG,SAAS7B;oBACT3D,YAAYwD;oBACZzD,gBAAgBA;oBAChBO,gBAAgBA;oBAChBC,gBAAgBA;oBAChBE,kBAAkBA;oBAClBC,iBAAiBA;oBACjBF,gBAAgBA;oBAChBW,eAAeA;oBACfC,eAAeA;oBACfG,kBAAkBA;oBACjB,GAAGC,kBAAkB;;;;;AAMlC,EAAE"}
@@ -1,14 +1,14 @@
1
1
  .input {
2
+ z-index: var(--vkui_internal--z_index_form_field_element);
2
3
  flex-grow: 1;
3
4
  align-self: center;
4
5
  margin-inline: 10px 14px;
5
- z-index: var(--vkui_internal--z_index_form_field_element);
6
- cursor: text;
6
+ font-variant-numeric: tabular-nums;
7
7
  white-space: nowrap;
8
+ cursor: text;
8
9
  -webkit-user-select: text;
9
10
  -moz-user-select: text;
10
11
  user-select: text;
11
- font-variant-numeric: tabular-nums;
12
12
  }
13
13
 
14
14
  .sizeYCompact .input {
@@ -0,0 +1,15 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import * as React from "react";
3
+ import { ConfigProviderOverride } from "../ConfigProvider/ConfigProviderOverride.js";
4
+ /**
5
+ * Компонент, прокидывающий направление контента
6
+ * @see https://vkcom.github.io/VKUI/#/DirectionProvider
7
+ * @since 7.2.0
8
+ */ export function DirectionProvider({ value, children }) {
9
+ return /*#__PURE__*/ _jsx(ConfigProviderOverride, {
10
+ direction: value,
11
+ children: children
12
+ });
13
+ }
14
+
15
+ //# sourceMappingURL=DirectionProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/components/DirectionProvider/DirectionProvider.tsx"],"sourcesContent":["import * as React from 'react';\nimport { type ConfigProviderContextInterface } from '../ConfigProvider/ConfigProviderContext';\nimport { ConfigProviderOverride } from '../ConfigProvider/ConfigProviderOverride';\n\nexport interface DirectionProviderProps {\n value: ConfigProviderContextInterface['direction'];\n children: React.ReactNode;\n}\n\n/**\n * Компонент, прокидывающий направление контента\n * @see https://vkcom.github.io/VKUI/#/DirectionProvider\n * @since 7.2.0\n */\nexport function DirectionProvider({ value, children }: DirectionProviderProps): React.ReactNode {\n return <ConfigProviderOverride direction={value}>{children}</ConfigProviderOverride>;\n}\n"],"names":["React","ConfigProviderOverride","DirectionProvider","value","children","direction"],"mappings":";AAAA,YAAYA,WAAW,QAAQ;AAE/B,SAASC,sBAAsB,QAAQ,8CAA2C;AAOlF;;;;CAIC,GACD,OAAO,SAASC,kBAAkB,EAAEC,KAAK,EAAEC,QAAQ,EAA0B;IAC3E,qBAAO,KAACH;QAAuBI,WAAWF;kBAAQC;;AACpD"}
@@ -3,11 +3,11 @@
3
3
  }
4
4
 
5
5
  .host::before {
6
- content: '';
7
6
  position: absolute;
8
7
  inset: 0;
9
- border-radius: var(--vkui--size_border_radius--regular);
8
+ content: '';
10
9
  border: 1px dashed var(--vkui--color_separator_primary);
10
+ border-radius: var(--vkui--size_border_radius--regular);
11
11
  }
12
12
 
13
13
  .active::before {
@@ -1,6 +1,5 @@
1
1
  .host {
2
2
  position: fixed;
3
- box-sizing: border-box;
4
3
  /**
5
4
  * ⚠️ WARNING ⚠️
6
5
  * `left: auto` решает следующие задачи:
@@ -13,6 +12,7 @@
13
12
  */
14
13
  inset-inline-start: auto;
15
14
  z-index: var(--vkui_internal--z_index_fixed_layout);
15
+ box-sizing: border-box;
16
16
  padding-inline: var(--vkui_internal--safe_area_inset_left)
17
17
  var(--vkui_internal--safe_area_inset_right);
18
18
  }
@@ -22,13 +22,13 @@
22
22
  }
23
23
 
24
24
  .verticalTop {
25
- inline-size: 100%;
26
25
  inset-block-start: 0;
26
+ inline-size: 100%;
27
27
  }
28
28
 
29
29
  .verticalBottom {
30
- inline-size: 100%;
31
30
  inset-block-end: 0;
31
+ inline-size: 100%;
32
32
  -webkit-padding-after: var(--vkui_internal--safe_area_inset_bottom);
33
33
  padding-block-end: var(--vkui_internal--safe_area_inset_bottom);
34
34
  }
@@ -1,5 +1,4 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
- import { Children } from "react";
3
2
  import { classNames } from "@vkontakte/vkjs";
4
3
  import { calculateGap, columnGapClassNames, rowGapClassNames } from "../../lib/layouts/index.js";
5
4
  import { RootComponent } from "../RootComponent/RootComponent.js";
@@ -20,12 +19,11 @@ const alignClassNames = {
20
19
  stretch: styles.alignStretch,
21
20
  baseline: styles.alignBaseline
22
21
  };
23
- export const Flex = ({ gap, align, justify, margin = 'none', noWrap = false, direction = 'row', reverse = false, children, ...props })=>{
24
- const withGaps = Children.count(children) > 1 && gap;
25
- const [rowGap, columnGap] = calculateGap(withGaps ? gap : undefined);
22
+ export const Flex = ({ gap = 0, align, justify, margin = 'none', noWrap = false, direction = 'row', reverse = false, children, ...props })=>{
23
+ const [rowGap, columnGap] = calculateGap(gap);
26
24
  return /*#__PURE__*/ _jsx(RootComponent, {
27
25
  ...props,
28
- baseClassName: classNames(styles.host, !noWrap && styles.wrap, reverse && styles.reverse, direction !== 'row' && styles.directionColumn, margin !== 'none' && styles.marginAuto, align && alignClassNames[align], justify && justifyClassNames[justify], withGaps && styles.withGaps, withGaps && getGapsPresets(rowGap, columnGap)),
26
+ baseClassName: classNames(styles.host, !noWrap && styles.wrap, reverse && styles.reverse, direction !== 'row' && styles.directionColumn, margin !== 'none' && styles.marginAuto, align && alignClassNames[align], justify && justifyClassNames[justify], getGapsPresets(rowGap, columnGap)),
29
27
  baseStyle: getGapsByUser(rowGap, columnGap),
30
28
  children: children
31
29
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/Flex/Flex.tsx"],"sourcesContent":["import { Children } from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport {\n calculateGap,\n columnGapClassNames,\n type GapProp,\n type GapsProp,\n rowGapClassNames,\n} from '../../lib/layouts';\nimport type { CSSCustomProperties } from '../../types';\nimport { RootComponent } from '../RootComponent/RootComponent';\nimport type { RootComponentProps } from '../RootComponent/RootComponent';\nimport { FlexItem, type FlexItemProps } from './FlexItem/FlexItem';\nimport styles from './Flex.module.css';\n\nexport type { FlexItemProps };\n\nconst justifyClassNames = {\n 'start': styles.justifyStart,\n 'end': styles.justifyEnd,\n 'center': styles.justifyCenter,\n 'space-around': styles.justifySpaceAround,\n 'space-between': styles.justifySpaceBetween,\n 'space-evenly': styles.justifySpaceEvenly,\n};\n\nconst alignClassNames = {\n start: styles.alignStart,\n end: styles.alignEnd,\n center: styles.alignCenter,\n stretch: styles.alignStretch,\n baseline: styles.alignBaseline,\n};\n\ntype FlexContentProps =\n | 'start'\n | 'end'\n | 'center'\n | 'space-around'\n | 'space-between'\n | 'space-evenly';\n\nexport interface FlexProps extends Omit<RootComponentProps<HTMLElement>, 'baseClassName'> {\n /**\n * Направление осей, эквивалентно `flex-direction`.\n */\n direction?: 'row' | 'column';\n /**\n * Отступы между элементами.\n * Значение из списка предопределённых пресетов или число, которое будет приведено к пикселям.\n * Через массив можно задать отступ между столбцами и строками [row, column], если они отличаются.\n */\n gap?: GapsProp;\n /**\n * Отключает перенос контента, эквивалентно `flex-wrap=nowrap`.\n */\n noWrap?: boolean;\n /**\n * Выравнивание элементов по вспомогательной оси, эквивалентно `align-items`.\n */\n align?: 'start' | 'end' | 'center' | 'stretch' | 'baseline';\n /**\n * Выравнивание элементов по главной оси, эквивалентно `justify-content`.\n */\n justify?: FlexContentProps;\n /**\n * Значение `auto` позволяет задать платформенные отступы вокруг контейнера.\n */\n margin?: 'none' | 'auto';\n /**\n * Для инвертирования направления, эквивалентно `row-reverse` `column-reverse`.\n */\n reverse?: boolean;\n}\n\nexport const Flex: React.FC<FlexProps> & {\n Item: typeof FlexItem;\n} = ({\n gap,\n align,\n justify,\n margin = 'none',\n noWrap = false,\n direction = 'row',\n reverse = false,\n children,\n ...props\n}: FlexProps) => {\n const withGaps = Children.count(children) > 1 && gap;\n const [rowGap, columnGap] = calculateGap(withGaps ? gap : undefined);\n\n return (\n <RootComponent\n {...props}\n baseClassName={classNames(\n styles.host,\n !noWrap && styles.wrap,\n reverse && styles.reverse,\n direction !== 'row' && styles.directionColumn,\n margin !== 'none' && styles.marginAuto,\n align && alignClassNames[align],\n justify && justifyClassNames[justify],\n withGaps && styles.withGaps,\n withGaps && getGapsPresets(rowGap, columnGap),\n )}\n baseStyle={getGapsByUser(rowGap, columnGap)}\n >\n {children}\n </RootComponent>\n );\n};\n\nfunction getGapsPresets(rowGap?: GapProp, columnGap?: GapProp) {\n return classNames(\n typeof rowGap === 'string' && rowGapClassNames[rowGap],\n typeof columnGap === 'string' && columnGapClassNames[columnGap],\n );\n}\n\nfunction getGapsByUser(rowGap?: GapProp, columnGap?: GapProp) {\n const style: CSSCustomProperties = {};\n\n if (typeof rowGap === 'number') {\n style['--vkui_internal--row_gap'] = `${rowGap}px`;\n }\n if (typeof columnGap === 'number') {\n style['--vkui_internal--column_gap'] = `${columnGap}px`;\n }\n\n return style;\n}\n\nFlex.Item = FlexItem;\n"],"names":["Children","classNames","calculateGap","columnGapClassNames","rowGapClassNames","RootComponent","FlexItem","styles","justifyClassNames","justifyStart","justifyEnd","justifyCenter","justifySpaceAround","justifySpaceBetween","justifySpaceEvenly","alignClassNames","start","alignStart","end","alignEnd","center","alignCenter","stretch","alignStretch","baseline","alignBaseline","Flex","gap","align","justify","margin","noWrap","direction","reverse","children","props","withGaps","count","rowGap","columnGap","undefined","baseClassName","host","wrap","directionColumn","marginAuto","getGapsPresets","baseStyle","getGapsByUser","style","Item"],"mappings":";AAAA,SAASA,QAAQ,QAAQ,QAAQ;AACjC,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SACEC,YAAY,EACZC,mBAAmB,EAGnBC,gBAAgB,QACX,6BAAoB;AAE3B,SAASC,aAAa,QAAQ,oCAAiC;AAE/D,SAASC,QAAQ,QAA4B,yBAAsB;AACnE,OAAOC,YAAY,oBAAoB;AAIvC,MAAMC,oBAAoB;IACxB,SAASD,OAAOE,YAAY;IAC5B,OAAOF,OAAOG,UAAU;IACxB,UAAUH,OAAOI,aAAa;IAC9B,gBAAgBJ,OAAOK,kBAAkB;IACzC,iBAAiBL,OAAOM,mBAAmB;IAC3C,gBAAgBN,OAAOO,kBAAkB;AAC3C;AAEA,MAAMC,kBAAkB;IACtBC,OAAOT,OAAOU,UAAU;IACxBC,KAAKX,OAAOY,QAAQ;IACpBC,QAAQb,OAAOc,WAAW;IAC1BC,SAASf,OAAOgB,YAAY;IAC5BC,UAAUjB,OAAOkB,aAAa;AAChC;AA2CA,OAAO,MAAMC,OAET,CAAC,EACHC,GAAG,EACHC,KAAK,EACLC,OAAO,EACPC,SAAS,MAAM,EACfC,SAAS,KAAK,EACdC,YAAY,KAAK,EACjBC,UAAU,KAAK,EACfC,QAAQ,EACR,GAAGC,OACO;IACV,MAAMC,WAAWpC,SAASqC,KAAK,CAACH,YAAY,KAAKP;IACjD,MAAM,CAACW,QAAQC,UAAU,GAAGrC,aAAakC,WAAWT,MAAMa;IAE1D,qBACE,KAACnC;QACE,GAAG8B,KAAK;QACTM,eAAexC,WACbM,OAAOmC,IAAI,EACX,CAACX,UAAUxB,OAAOoC,IAAI,EACtBV,WAAW1B,OAAO0B,OAAO,EACzBD,cAAc,SAASzB,OAAOqC,eAAe,EAC7Cd,WAAW,UAAUvB,OAAOsC,UAAU,EACtCjB,SAASb,eAAe,CAACa,MAAM,EAC/BC,WAAWrB,iBAAiB,CAACqB,QAAQ,EACrCO,YAAY7B,OAAO6B,QAAQ,EAC3BA,YAAYU,eAAeR,QAAQC;QAErCQ,WAAWC,cAAcV,QAAQC;kBAEhCL;;AAGP,EAAE;AAEF,SAASY,eAAeR,MAAgB,EAAEC,SAAmB;IAC3D,OAAOtC,WACL,OAAOqC,WAAW,YAAYlC,gBAAgB,CAACkC,OAAO,EACtD,OAAOC,cAAc,YAAYpC,mBAAmB,CAACoC,UAAU;AAEnE;AAEA,SAASS,cAAcV,MAAgB,EAAEC,SAAmB;IAC1D,MAAMU,QAA6B,CAAC;IAEpC,IAAI,OAAOX,WAAW,UAAU;QAC9BW,KAAK,CAAC,2BAA2B,GAAG,GAAGX,OAAO,EAAE,CAAC;IACnD;IACA,IAAI,OAAOC,cAAc,UAAU;QACjCU,KAAK,CAAC,8BAA8B,GAAG,GAAGV,UAAU,EAAE,CAAC;IACzD;IAEA,OAAOU;AACT;AAEAvB,KAAKwB,IAAI,GAAG5C"}
1
+ {"version":3,"sources":["../../../../src/components/Flex/Flex.tsx"],"sourcesContent":["import { classNames } from '@vkontakte/vkjs';\nimport {\n calculateGap,\n columnGapClassNames,\n type GapProp,\n type GapsProp,\n rowGapClassNames,\n} from '../../lib/layouts';\nimport type { CSSCustomProperties } from '../../types';\nimport { RootComponent } from '../RootComponent/RootComponent';\nimport type { RootComponentProps } from '../RootComponent/RootComponent';\nimport { FlexItem, type FlexItemProps } from './FlexItem/FlexItem';\nimport styles from './Flex.module.css';\n\nexport type { FlexItemProps };\n\nconst justifyClassNames = {\n 'start': styles.justifyStart,\n 'end': styles.justifyEnd,\n 'center': styles.justifyCenter,\n 'space-around': styles.justifySpaceAround,\n 'space-between': styles.justifySpaceBetween,\n 'space-evenly': styles.justifySpaceEvenly,\n};\n\nconst alignClassNames = {\n start: styles.alignStart,\n end: styles.alignEnd,\n center: styles.alignCenter,\n stretch: styles.alignStretch,\n baseline: styles.alignBaseline,\n};\n\ntype FlexContentProps =\n | 'start'\n | 'end'\n | 'center'\n | 'space-around'\n | 'space-between'\n | 'space-evenly';\n\nexport interface FlexProps extends Omit<RootComponentProps<HTMLElement>, 'baseClassName'> {\n /**\n * Направление осей, эквивалентно `flex-direction`.\n */\n direction?: 'row' | 'column';\n /**\n * Отступы между элементами.\n * Значение из списка предопределённых пресетов или число, которое будет приведено к пикселям.\n * Через массив можно задать отступ между столбцами и строками [row, column], если они отличаются.\n */\n gap?: GapsProp;\n /**\n * Отключает перенос контента, эквивалентно `flex-wrap=nowrap`.\n */\n noWrap?: boolean;\n /**\n * Выравнивание элементов по вспомогательной оси, эквивалентно `align-items`.\n */\n align?: 'start' | 'end' | 'center' | 'stretch' | 'baseline';\n /**\n * Выравнивание элементов по главной оси, эквивалентно `justify-content`.\n */\n justify?: FlexContentProps;\n /**\n * Значение `auto` позволяет задать платформенные отступы вокруг контейнера.\n */\n margin?: 'none' | 'auto';\n /**\n * Для инвертирования направления, эквивалентно `row-reverse` `column-reverse`.\n */\n reverse?: boolean;\n}\n\nexport const Flex: React.FC<FlexProps> & {\n Item: typeof FlexItem;\n} = ({\n gap = 0,\n align,\n justify,\n margin = 'none',\n noWrap = false,\n direction = 'row',\n reverse = false,\n children,\n ...props\n}: FlexProps) => {\n const [rowGap, columnGap] = calculateGap(gap);\n\n return (\n <RootComponent\n {...props}\n baseClassName={classNames(\n styles.host,\n !noWrap && styles.wrap,\n reverse && styles.reverse,\n direction !== 'row' && styles.directionColumn,\n margin !== 'none' && styles.marginAuto,\n align && alignClassNames[align],\n justify && justifyClassNames[justify],\n getGapsPresets(rowGap, columnGap),\n )}\n baseStyle={getGapsByUser(rowGap, columnGap)}\n >\n {children}\n </RootComponent>\n );\n};\n\nfunction getGapsPresets(rowGap?: GapProp, columnGap?: GapProp) {\n return classNames(\n typeof rowGap === 'string' && rowGapClassNames[rowGap],\n typeof columnGap === 'string' && columnGapClassNames[columnGap],\n );\n}\n\nfunction getGapsByUser(rowGap?: GapProp, columnGap?: GapProp) {\n const style: CSSCustomProperties = {};\n\n if (typeof rowGap === 'number') {\n style['--vkui_internal--row_gap'] = `${rowGap}px`;\n }\n if (typeof columnGap === 'number') {\n style['--vkui_internal--column_gap'] = `${columnGap}px`;\n }\n\n return style;\n}\n\nFlex.Item = FlexItem;\n"],"names":["classNames","calculateGap","columnGapClassNames","rowGapClassNames","RootComponent","FlexItem","styles","justifyClassNames","justifyStart","justifyEnd","justifyCenter","justifySpaceAround","justifySpaceBetween","justifySpaceEvenly","alignClassNames","start","alignStart","end","alignEnd","center","alignCenter","stretch","alignStretch","baseline","alignBaseline","Flex","gap","align","justify","margin","noWrap","direction","reverse","children","props","rowGap","columnGap","baseClassName","host","wrap","directionColumn","marginAuto","getGapsPresets","baseStyle","getGapsByUser","style","Item"],"mappings":";AAAA,SAASA,UAAU,QAAQ,kBAAkB;AAC7C,SACEC,YAAY,EACZC,mBAAmB,EAGnBC,gBAAgB,QACX,6BAAoB;AAE3B,SAASC,aAAa,QAAQ,oCAAiC;AAE/D,SAASC,QAAQ,QAA4B,yBAAsB;AACnE,OAAOC,YAAY,oBAAoB;AAIvC,MAAMC,oBAAoB;IACxB,SAASD,OAAOE,YAAY;IAC5B,OAAOF,OAAOG,UAAU;IACxB,UAAUH,OAAOI,aAAa;IAC9B,gBAAgBJ,OAAOK,kBAAkB;IACzC,iBAAiBL,OAAOM,mBAAmB;IAC3C,gBAAgBN,OAAOO,kBAAkB;AAC3C;AAEA,MAAMC,kBAAkB;IACtBC,OAAOT,OAAOU,UAAU;IACxBC,KAAKX,OAAOY,QAAQ;IACpBC,QAAQb,OAAOc,WAAW;IAC1BC,SAASf,OAAOgB,YAAY;IAC5BC,UAAUjB,OAAOkB,aAAa;AAChC;AA2CA,OAAO,MAAMC,OAET,CAAC,EACHC,MAAM,CAAC,EACPC,KAAK,EACLC,OAAO,EACPC,SAAS,MAAM,EACfC,SAAS,KAAK,EACdC,YAAY,KAAK,EACjBC,UAAU,KAAK,EACfC,QAAQ,EACR,GAAGC,OACO;IACV,MAAM,CAACC,QAAQC,UAAU,GAAGnC,aAAayB;IAEzC,qBACE,KAACtB;QACE,GAAG8B,KAAK;QACTG,eAAerC,WACbM,OAAOgC,IAAI,EACX,CAACR,UAAUxB,OAAOiC,IAAI,EACtBP,WAAW1B,OAAO0B,OAAO,EACzBD,cAAc,SAASzB,OAAOkC,eAAe,EAC7CX,WAAW,UAAUvB,OAAOmC,UAAU,EACtCd,SAASb,eAAe,CAACa,MAAM,EAC/BC,WAAWrB,iBAAiB,CAACqB,QAAQ,EACrCc,eAAeP,QAAQC;QAEzBO,WAAWC,cAAcT,QAAQC;kBAEhCH;;AAGP,EAAE;AAEF,SAASS,eAAeP,MAAgB,EAAEC,SAAmB;IAC3D,OAAOpC,WACL,OAAOmC,WAAW,YAAYhC,gBAAgB,CAACgC,OAAO,EACtD,OAAOC,cAAc,YAAYlC,mBAAmB,CAACkC,UAAU;AAEnE;AAEA,SAASQ,cAAcT,MAAgB,EAAEC,SAAmB;IAC1D,MAAMS,QAA6B,CAAC;IAEpC,IAAI,OAAOV,WAAW,UAAU;QAC9BU,KAAK,CAAC,2BAA2B,GAAG,GAAGV,OAAO,EAAE,CAAC;IACnD;IACA,IAAI,OAAOC,cAAc,UAAU;QACjCS,KAAK,CAAC,8BAA8B,GAAG,GAAGT,UAAU,EAAE,CAAC;IACzD;IAEA,OAAOS;AACT;AAEApB,KAAKqB,IAAI,GAAGzC"}
@@ -9,23 +9,49 @@
9
9
  --vkui_internal--flex_original_margin_inline: var(--vkui--size_base_padding_horizontal--regular);
10
10
  --vkui_internal--flex_original_margin_block: var(--vkui--size_base_padding_vertical--regular);
11
11
 
12
- margin-inline: var(--vkui--size_base_padding_horizontal--regular);
13
12
  margin-block: var(--vkui--size_base_padding_vertical--regular);
13
+ margin-inline: var(--vkui--size_base_padding_horizontal--regular);
14
14
  }
15
15
 
16
- .withGaps {
17
- -webkit-margin-before: calc(
18
- -1 * var(--vkui_internal--row_gap) + var(--vkui_internal--flex_original_margin_block)
19
- );
20
- margin-block-start: calc(
21
- -1 * var(--vkui_internal--row_gap) + var(--vkui_internal--flex_original_margin_block)
22
- );
23
- -webkit-margin-start: calc(
24
- -1 * var(--vkui_internal--column_gap) + var(--vkui_internal--flex_original_margin_inline)
25
- );
26
- margin-inline-start: calc(
27
- -1 * var(--vkui_internal--column_gap) + var(--vkui_internal--flex_original_margin_inline)
28
- );
16
+ /*TODO [>=8]: Проверить браузерную поддержку gap*/
17
+
18
+ /*Данная проверка позволяет максимально близко определить поддерживается ли gap + flex*/
19
+
20
+ /*см. https://github.com/w3c/csswg-drafts/issues/3559#issuecomment-1758459996*/
21
+
22
+ /*Поддержка inset https://developer.mozilla.org/en-US/docs/Web/CSS/inset#browser_compatibility*/
23
+
24
+ /*Поддержка gap https://developer.mozilla.org/en-US/docs/Web/CSS/gap#browser_compatibility*/
25
+
26
+ @supports (inset: 0) {
27
+ .host {
28
+ gap: var(--vkui_internal--row_gap) var(--vkui_internal--column_gap);
29
+ }
30
+ }
31
+
32
+ @supports not (inset: 0) {
33
+ .host {
34
+ -webkit-margin-before: calc(
35
+ -1 * var(--vkui_internal--row_gap) + var(--vkui_internal--flex_original_margin_block)
36
+ );
37
+ margin-block-start: calc(
38
+ -1 * var(--vkui_internal--row_gap) + var(--vkui_internal--flex_original_margin_block)
39
+ );
40
+ -webkit-margin-start: calc(
41
+ -1 * var(--vkui_internal--column_gap) + var(--vkui_internal--flex_original_margin_inline)
42
+ );
43
+ margin-inline-start: calc(
44
+ -1 * var(--vkui_internal--column_gap) + var(--vkui_internal--flex_original_margin_inline)
45
+ );
46
+ }
47
+
48
+ /* stylelint-disable-next-line @project-tools/stylelint-atomic, selector-max-universal */
49
+ .host.host > * {
50
+ -webkit-margin-before: var(--vkui_internal--row_gap);
51
+ margin-block-start: var(--vkui_internal--row_gap);
52
+ -webkit-margin-start: var(--vkui_internal--column_gap);
53
+ margin-inline-start: var(--vkui_internal--column_gap);
54
+ }
29
55
  }
30
56
 
31
57
  .host > .marginAuto {
@@ -96,12 +122,3 @@
96
122
  .alignBaseline {
97
123
  align-items: baseline;
98
124
  }
99
-
100
- /* stylelint-disable-next-line @project-tools/stylelint-atomic, selector-max-universal */
101
-
102
- .withGaps.withGaps > * {
103
- -webkit-margin-before: var(--vkui_internal--row_gap);
104
- margin-block-start: var(--vkui_internal--row_gap);
105
- -webkit-margin-start: var(--vkui_internal--column_gap);
106
- margin-inline-start: var(--vkui_internal--column_gap);
107
- }
@@ -3,8 +3,8 @@
3
3
  }
4
4
 
5
5
  .in {
6
- content: '';
7
6
  display: block;
7
+ content: '';
8
8
 
9
9
  /* см. "Примечание" в DefaultIcon.tsx. */
10
10
  transform: translateY(1px);
@@ -2,6 +2,6 @@
2
2
  display: block;
3
3
  padding-block: 24px;
4
4
  padding-inline: var(--vkui--size_base_padding_horizontal--regular);
5
- text-align: center;
6
5
  color: var(--vkui--color_text_secondary);
6
+ text-align: center;
7
7
  }