@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
@@ -1,11 +1,11 @@
1
1
  .host {
2
2
  flex-grow: 1;
3
- color: var(--vkui--color_text_primary);
4
3
  min-inline-size: 0; /* см. https://github.com/VKCOM/VKUI/issues/5687 */
5
- word-break: break-word;
6
4
  margin-block: var(--vkui--spacing_size_xl);
7
5
  -webkit-margin-start: 12px;
8
6
  margin-inline-start: 12px;
7
+ color: var(--vkui--color_text_primary);
8
+ word-break: break-word;
9
9
  }
10
10
 
11
11
  .host:first-child {
@@ -14,16 +14,16 @@
14
14
  }
15
15
 
16
16
  .description {
17
- color: var(--vkui--color_text_secondary);
18
17
  display: block;
19
18
  -webkit-margin-before: 2px;
20
19
  margin-block-start: 2px;
20
+ color: var(--vkui--color_text_secondary);
21
21
  }
22
22
 
23
23
  .titleLayout {
24
24
  display: flex;
25
- justify-content: space-between;
26
25
  align-items: center;
26
+ justify-content: space-between;
27
27
  }
28
28
 
29
29
  .title {
@@ -31,9 +31,9 @@
31
31
  }
32
32
 
33
33
  .titleAfter {
34
+ flex-shrink: 0;
34
35
  -webkit-margin-start: 4px;
35
36
  margin-inline-start: 4px;
36
- flex-shrink: 0;
37
37
  color: var(--vkui--color_icon_tertiary);
38
38
  }
39
39
 
@@ -25,19 +25,19 @@
25
25
 
26
26
  .sized.directionHorizontal {
27
27
  display: flex;
28
- block-size: var(--vkui_internal--spacing_size);
29
28
  align-items: var(--vkui_internal--separator_align, center);
29
+ block-size: var(--vkui_internal--spacing_size);
30
30
  }
31
31
 
32
32
  .sized.directionVertical {
33
- inline-size: var(--vkui_internal--spacing_size);
34
33
  justify-content: var(--vkui_internal--separator_align, center);
34
+ inline-size: var(--vkui_internal--spacing_size);
35
35
  }
36
36
 
37
37
  .in {
38
38
  margin: 0;
39
- background: currentColor;
40
39
  color: inherit;
40
+ background: currentColor;
41
41
  border: 0;
42
42
  }
43
43
 
@@ -4,10 +4,10 @@
4
4
  display: flex;
5
5
  align-items: center;
6
6
  min-block-size: 48px;
7
+ padding-inline: var(--vkui--size_base_padding_horizontal--regular);
8
+ color: var(--vkui--color_text_primary);
7
9
  white-space: nowrap;
8
10
  text-decoration: none;
9
- color: var(--vkui--color_text_primary);
10
- padding-inline: var(--vkui--size_base_padding_horizontal--regular);
11
11
  }
12
12
 
13
13
  .mult {
@@ -25,6 +25,7 @@
25
25
  .before {
26
26
  display: flex;
27
27
  align-items: center;
28
+ align-self: stretch;
28
29
  padding-block: var(--vkui--spacing_size_s);
29
30
  -webkit-padding-end: var(--vkui_internal--SimpleCell-before-inline-padding-end);
30
31
  padding-inline-end: var(--vkui_internal--SimpleCell-before-inline-padding-end);
@@ -52,12 +53,12 @@
52
53
 
53
54
  .middle {
54
55
  display: flex;
56
+ flex-grow: 1;
55
57
  flex-direction: column;
56
58
  justify-content: center;
57
- padding-block: var(--vkui--spacing_size_l);
58
- max-inline-size: 100%;
59
- flex-grow: 1;
60
59
  min-inline-size: 0;
60
+ max-inline-size: 100%;
61
+ padding-block: var(--vkui--spacing_size_l);
61
62
  overflow: hidden;
62
63
  }
63
64
 
@@ -73,8 +74,8 @@
73
74
  }
74
75
 
75
76
  .text {
76
- text-overflow: ellipsis;
77
77
  overflow: hidden;
78
+ text-overflow: ellipsis;
78
79
  }
79
80
 
80
81
  .subtitle,
@@ -86,15 +87,15 @@
86
87
  display: flex;
87
88
  align-content: flex-start;
88
89
  align-items: center;
89
- max-inline-size: 100%;
90
90
  justify-content: flex-start;
91
+ max-inline-size: 100%;
91
92
  }
92
93
 
93
94
  .children {
94
- color: inherit;
95
- text-overflow: ellipsis;
96
- overflow: hidden;
97
95
  display: block;
96
+ overflow: hidden;
97
+ text-overflow: ellipsis;
98
+ color: inherit;
98
99
  }
99
100
 
100
101
  .mult .children,
@@ -118,19 +119,20 @@
118
119
 
119
120
  .indicator {
120
121
  flex-shrink: 0;
121
- color: var(--vkui--color_text_secondary);
122
122
  min-inline-size: 0;
123
- white-space: nowrap;
124
- text-overflow: ellipsis;
125
- overflow: hidden;
126
123
  -webkit-padding-start: var(--vkui--spacing_size_xl);
127
124
  padding-inline-start: var(--vkui--spacing_size_xl);
125
+ overflow: hidden;
126
+ text-overflow: ellipsis;
127
+ color: var(--vkui--color_text_secondary);
128
+ white-space: nowrap;
128
129
  }
129
130
 
130
131
  .after {
131
- flex-shrink: 0;
132
132
  display: flex;
133
+ flex-shrink: 0;
133
134
  align-items: center;
135
+ align-self: stretch;
134
136
  color: var(--vkui_internal--icon_color, var(--vkui--color_icon_accent));
135
137
  }
136
138
 
@@ -150,9 +152,9 @@
150
152
  }
151
153
 
152
154
  .chevronIcon {
153
- color: var(--vkui--color_icon_tertiary);
154
155
  -webkit-padding-start: var(--vkui--spacing_size_xl);
155
156
  padding-inline-start: var(--vkui--spacing_size_xl);
157
+ color: var(--vkui--color_icon_tertiary);
156
158
  }
157
159
 
158
160
  /**
@@ -3,13 +3,13 @@
3
3
  --vkui_internal--min_col_width: 0;
4
4
 
5
5
  display: grid;
6
- gap: var(--vkui_internal--row_gap) var(--vkui_internal--column_gap);
7
6
  grid-template-columns: repeat(var(--vkui_internal--grid_columns), minmax(0, 1fr));
7
+ gap: var(--vkui_internal--row_gap) var(--vkui_internal--column_gap);
8
8
  }
9
9
 
10
10
  .marginAuto {
11
- margin-inline: var(--vkui--size_base_padding_horizontal--regular);
12
11
  margin-block: var(--vkui--size_base_padding_vertical--regular);
12
+ margin-inline: var(--vkui--size_base_padding_horizontal--regular);
13
13
  }
14
14
 
15
15
  .marginAutoInline {
@@ -4,14 +4,14 @@
4
4
  --vkui_internal--skeleton_animation_duration: 1.5s;
5
5
  --vkui_internal--skeleton_gradient_left: 0;
6
6
 
7
- display: inline-flex;
8
7
  position: relative;
8
+ display: inline-flex;
9
9
  inline-size: 100%;
10
10
  max-inline-size: 100%;
11
- line-height: 1;
12
- border-radius: 6px;
13
11
  overflow: hidden;
12
+ line-height: 1;
14
13
  background-color: var(--vkui_internal--skeleton_color_from);
14
+ border-radius: 6px;
15
15
  }
16
16
 
17
17
  /* Если скелетон находится внутри другого скелетона он меняет цвет */
@@ -28,11 +28,11 @@
28
28
 
29
29
  .host::before {
30
30
  position: absolute;
31
- inset-inline-start: var(--vkui_internal--skeleton_gradient_left);
32
31
  inset-block-start: 0;
33
- content: ' ';
32
+ inset-inline-start: var(--vkui_internal--skeleton_gradient_left);
34
33
  inline-size: 100vw;
35
34
  block-size: 100%;
35
+ content: ' ';
36
36
  background-image: linear-gradient(
37
37
  90deg,
38
38
  var(--vkui_internal--skeleton_color_from),
@@ -41,10 +41,10 @@
41
41
  );
42
42
  transform: translateX(-100vw);
43
43
  animation-name: animation-skeleton;
44
- animation-direction: normal /*rtl:reverse*/;
45
44
  animation-duration: 1.5s;
46
45
  animation-timing-function: ease-in-out;
47
46
  animation-iteration-count: infinite;
47
+ animation-direction: normal /*rtl:reverse*/;
48
48
  }
49
49
 
50
50
  @keyframes animation-skeleton {
@@ -54,17 +54,17 @@
54
54
  }
55
55
 
56
56
  .disableAnimation::before {
57
+ background-image: none;
57
58
  /**
58
59
  * Safari тратит время не пересчет анимации даже если элемент скрыт
59
60
  * Для повышения производительности анимацию необходимо выключить
60
61
  */
61
62
  animation-name: none;
62
- background-image: none;
63
63
  }
64
64
 
65
65
  @media screen and (prefers-reduced-motion: reduce) {
66
66
  .host::before {
67
- animation-name: none;
68
67
  background-image: none;
68
+ animation-name: none;
69
69
  }
70
70
  }
@@ -3,7 +3,9 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import * as React from "react";
4
4
  import { classNames } from "@vkontakte/vkjs";
5
5
  import { clamp } from "../../helpers/math.js";
6
+ import { mergeStyle } from "../../helpers/mergeStyle.js";
6
7
  import { useAdaptivity } from "../../hooks/useAdaptivity.js";
8
+ import { useConfigDirection } from "../../hooks/useConfigDirection.js";
7
9
  import { useExternRef } from "../../hooks/useExternRef.js";
8
10
  import { Touch } from "../Touch/Touch.js";
9
11
  import { SliderThumb } from "./SliderThumb/SliderThumb.js";
@@ -23,8 +25,10 @@ const sizeClassNames = {
23
25
  */ export const Slider = ({ step = 1, min = 0, max = 100, value: valueProp, multiple: multipleProp, defaultValue = multipleProp ? [
24
26
  min,
25
27
  max
26
- ] : min, disabled, className, getRootRef, getAriaLabel, getAriaValueText, startThumbTestId, endThumbTestId, onChange, withTooltip, size = 'l', ...restProps })=>{
28
+ ] : min, disabled, className, getRootRef, getAriaLabel, getAriaValueText, startThumbTestId, endThumbTestId, onChange, withTooltip, size = 'l', style: styleProp, ...restProps })=>{
27
29
  const { sizeY = 'none' } = useAdaptivity();
30
+ const direction = useConfigDirection();
31
+ const isRtl = direction === 'rtl';
28
32
  const isControlled = valueProp !== undefined;
29
33
  const [localValue, setValue] = React.useState(defaultValue);
30
34
  const value = React.useMemo(()=>{
@@ -78,7 +82,10 @@ const sizeClassNames = {
78
82
  const { left: nextContainerX, width: nextContainerWidth } = thumbsContainerRef.current.getBoundingClientRect();
79
83
  // @ts-expect-error: TS2345 в VKUITouchEvent плохо описаны типы. `target` это просто `EventTarget`.
80
84
  const foundDraggingType = getDraggingTypeByTargetDataset(event.originalEvent.target);
81
- const nextStartX = event.startX - nextContainerX;
85
+ let nextStartX = event.startX - nextContainerX;
86
+ if (isRtl) {
87
+ nextStartX = nextContainerWidth - nextStartX;
88
+ }
82
89
  const nextValue = offsetToValue(nextStartX, nextContainerWidth, min, max, step);
83
90
  const nextDragging = snapDirection(value, nextValue, foundDraggingType);
84
91
  gesture.dragging = nextDragging;
@@ -100,7 +107,7 @@ const sizeClassNames = {
100
107
  const handlePointerMove = (event)=>{
101
108
  const { startX, containerWidth, dragging } = gesture;
102
109
  const { shiftX = 0 } = event;
103
- const nextStartX = startX + shiftX;
110
+ const nextStartX = startX + (isRtl ? -shiftX : shiftX);
104
111
  const nextValue = offsetToValue(nextStartX, containerWidth, min, max, step);
105
112
  changeValue(updateInternalStateValue(value, nextValue, min, max, dragging), event);
106
113
  event.originalEvent.stopPropagation();
@@ -114,10 +121,16 @@ const sizeClassNames = {
114
121
  const handleChangeByNativeInput = (event)=>{
115
122
  changeValue(updateInternalStateValueByNativeChange(value, Number(event.target.value), getDraggingTypeByTargetDataset(event.target)), event);
116
123
  };
124
+ const style = {
125
+ '--vkui_internal--Slider_start_value': String(startValueInPercent),
126
+ '--vkui_internal--Slider_end_value': String(endReversedValueInPercent)
127
+ };
117
128
  return /*#__PURE__*/ _jsxs(Touch, {
118
129
  "data-value": multiple ? `${startValue},${endValue}` : startValue,
119
130
  ...restPropsWithoutAriaAttributes,
120
- className: classNames(styles.host, disabled && styles.disabled, sizeY !== 'regular' && sizeYClassNames[sizeY], sizeClassNames[size], className),
131
+ className: classNames(styles.host, disabled && styles.disabled, sizeY !== 'regular' && sizeYClassNames[sizeY], sizeClassNames[size], multiple && styles.multiple, isRtl && styles.rtl, className),
132
+ style: mergeStyle(styleProp, style),
133
+ getRootRef: getRootRef,
121
134
  onStart: disabled ? undefined : handlePointerStart,
122
135
  onMove: disabled ? undefined : handlePointerMove,
123
136
  onEnd: disabled ? undefined : handlePointerEnd,
@@ -126,13 +139,7 @@ const sizeClassNames = {
126
139
  className: styles.track
127
140
  }),
128
141
  /*#__PURE__*/ _jsx("div", {
129
- className: styles.trackFill,
130
- style: multiple ? {
131
- left: `${startValueInPercent}%`,
132
- right: `${100 - endReversedValueInPercent}%`
133
- } : {
134
- width: `${startValueInPercent}%`
135
- }
142
+ className: styles.trackFill
136
143
  }),
137
144
  /*#__PURE__*/ _jsxs("div", {
138
145
  ref: thumbsContainerRef,
@@ -140,9 +147,8 @@ const sizeClassNames = {
140
147
  children: [
141
148
  /*#__PURE__*/ _jsx(SliderThumb, {
142
149
  "data-type": "start",
143
- className: styles.thumb,
150
+ className: classNames(styles.thumb, styles.thumbStart),
144
151
  style: {
145
- left: `${startValueInPercent}%`,
146
152
  // Меняем местами порядок слоёв, иначе, при достижении `start` и `end` 100%, `end` будет перекрывать `start`.
147
153
  zIndex: multiple && startValueInPercent >= 50 ? 2 : undefined
148
154
  },
@@ -165,10 +171,7 @@ const sizeClassNames = {
165
171
  }),
166
172
  multiple && /*#__PURE__*/ _jsx(SliderThumb, {
167
173
  "data-type": "end",
168
- className: styles.thumb,
169
- style: {
170
- left: `${endReversedValueInPercent}%`
171
- },
174
+ className: classNames(styles.thumb, styles.thumbEnd),
172
175
  withTooltip: withTooltip,
173
176
  inputProps: {
174
177
  'data-type': 'end',
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/Slider/Slider.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { clamp } from '../../helpers/math';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport type { HTMLAttributesWithRootRef } from '../../types';\nimport { type CustomTouchEvent, type CustomTouchEventHandler, Touch } from '../Touch/Touch';\nimport { SliderThumb } from './SliderThumb/SliderThumb';\nimport {\n extractSliderAriaAttributesFromRestProps,\n getDraggingTypeByTargetDataset,\n isMultipleValues,\n offsetToValue,\n snapDirection,\n toPercent,\n updateInternalStateValue,\n updateInternalStateValueByNativeChange,\n} from './helpers';\nimport type { InternalDraggingType, InternalGestureRef, InternalValueState } from './types';\nimport styles from './Slider.module.css';\n\nconst sizeYClassNames = {\n none: styles.sizeYNone,\n compact: styles.sizeYCompact,\n};\n\nconst sizeClassNames = {\n l: styles.sizeL,\n m: styles.sizeM,\n s: styles.sizeS,\n};\n\nexport interface SliderBaseProps\n extends Omit<HTMLAttributesWithRootRef<HTMLDivElement>, 'value' | 'defaultValue' | 'onChange'> {\n min?: number;\n max?: number;\n step?: number;\n disabled?: boolean;\n /**\n * Тоже самое, что и `aria-label`, но на вход можно получать индекс текущего ползунка и в зависимости от этого выдавать разный текст.\n *\n * > Перебивает `aria-label`.\n */\n getAriaLabel?: (index: number) => string;\n /**\n * В отличие от `aria-valuetext`, позволяет более гибко форматировать текст в зависимости от значения ползунка.\n *\n * Полезно при использовании компонента как неконтролируемого.\n *\n * > Перебивает `aria-valuetext`.\n */\n getAriaValueText?: (value: number, index: number) => string;\n withTooltip?: boolean;\n /**\n * Размер ползунка.\n */\n size?: 's' | 'm' | 'l';\n /**\n * Передает атрибут `data-testid` для первого ползунка\n */\n startThumbTestId?: string;\n /**\n * Передает атрибут `data-testid` для второго ползунка когда `multiple=true`\n */\n endThumbTestId?: string;\n}\n\nexport interface SliderProps extends SliderBaseProps {\n multiple?: false;\n value?: number;\n defaultValue?: number;\n onChange?: (value: number, event: CustomTouchEvent | React.ChangeEvent) => void;\n}\n\nexport interface SliderMultipleProps extends SliderBaseProps {\n multiple: true;\n value?: [number, number];\n defaultValue?: [number, number];\n onChange?: (value: [number, number], event: CustomTouchEvent | React.ChangeEvent) => void;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/Slider\n */\nexport const Slider = ({\n step = 1,\n min = 0,\n max = 100,\n value: valueProp,\n multiple: multipleProp,\n defaultValue = multipleProp ? [min, max] : min,\n disabled,\n className,\n getRootRef,\n getAriaLabel,\n getAriaValueText,\n startThumbTestId,\n endThumbTestId,\n onChange,\n withTooltip,\n size = 'l',\n ...restProps\n}: SliderProps | SliderMultipleProps): React.ReactNode => {\n const { sizeY = 'none' } = useAdaptivity();\n\n const isControlled = valueProp !== undefined;\n const [localValue, setValue] = React.useState(defaultValue);\n\n const value = React.useMemo<InternalValueState>(() => {\n const resolvedValue = isControlled ? valueProp : localValue;\n return Array.isArray(resolvedValue)\n ? [clamp(resolvedValue[0], min, max), clamp(resolvedValue[1], min, max)]\n : [clamp(resolvedValue, min, max), null];\n }, [isControlled, valueProp, localValue, min, max]);\n\n const [startValue, endValue] = value;\n const multiple = multipleProp && endValue !== null;\n const startValueInPercent = toPercent(startValue, min, max);\n const endReversedValueInPercent = multiple ? toPercent(endValue, min, max) : 0;\n const [activeThumb, setActiveThumb] = React.useState<InternalDraggingType | null>(null);\n\n const gesture = React.useRef<InternalGestureRef>({\n dragging: null,\n startX: 0,\n containerWidth: 0,\n }).current;\n const thumbsContainerRef = useExternRef(getRootRef);\n const thumbStartInputRef = React.useRef<HTMLInputElement>(null);\n const thumbEndInputRef = React.useRef<HTMLInputElement>(null);\n\n const { ariaLabel, ariaValueText, ariaLabelledBy, ...restPropsWithoutAriaAttributes } =\n extractSliderAriaAttributesFromRestProps(restProps);\n\n const changeValue = (\n nextValue: InternalValueState,\n event: CustomTouchEvent | React.ChangeEvent,\n ) => {\n if (disabled || (value[0] === nextValue[0] && value[1] === nextValue[1])) {\n return;\n }\n\n if (multipleProp) {\n if (isMultipleValues(nextValue)) {\n !isControlled && setValue(nextValue);\n onChange && onChange(nextValue, event);\n }\n } else {\n !isControlled && setValue(nextValue[0]);\n onChange && onChange(nextValue[0], event);\n }\n };\n\n const handlePointerStart: CustomTouchEventHandler = (event: CustomTouchEvent) => {\n if (!thumbsContainerRef.current) {\n return;\n }\n\n const { left: nextContainerX, width: nextContainerWidth } =\n thumbsContainerRef.current.getBoundingClientRect();\n\n // @ts-expect-error: TS2345 в VKUITouchEvent плохо описаны типы. `target` это просто `EventTarget`.\n const foundDraggingType = getDraggingTypeByTargetDataset(event.originalEvent.target);\n\n const nextStartX = event.startX - nextContainerX;\n const nextValue = offsetToValue(nextStartX, nextContainerWidth, min, max, step);\n const nextDragging = snapDirection(value, nextValue, foundDraggingType);\n\n gesture.dragging = nextDragging;\n gesture.containerWidth = nextContainerWidth;\n gesture.startX = nextStartX;\n\n const updatedInternalStateValue = updateInternalStateValue(\n value,\n nextValue,\n min,\n max,\n nextDragging,\n );\n\n const [nextStartValue, nextEndValue] = updatedInternalStateValue;\n if (\n thumbStartInputRef.current &&\n (foundDraggingType === 'start' ||\n (nextStartValue !== startValue && nextEndValue === endValue))\n ) {\n thumbStartInputRef.current.focus();\n event.originalEvent.preventDefault();\n } else if (\n thumbEndInputRef.current &&\n (foundDraggingType === 'end' || (nextEndValue !== endValue && nextStartValue === startValue))\n ) {\n thumbEndInputRef.current.focus();\n event.originalEvent.preventDefault();\n }\n\n changeValue(updatedInternalStateValue, event);\n\n event.originalEvent.stopPropagation();\n setActiveThumb(gesture.dragging);\n };\n\n const handlePointerMove: CustomTouchEventHandler = (event: CustomTouchEvent) => {\n const { startX, containerWidth, dragging } = gesture;\n\n const { shiftX = 0 } = event;\n const nextStartX = startX + shiftX;\n const nextValue = offsetToValue(nextStartX, containerWidth, min, max, step);\n\n changeValue(updateInternalStateValue(value, nextValue, min, max, dragging), event);\n\n event.originalEvent.stopPropagation();\n event.originalEvent.preventDefault();\n };\n\n const handlePointerEnd: CustomTouchEventHandler = (event) => {\n gesture.dragging = null;\n event.originalEvent.stopPropagation();\n setActiveThumb(null);\n };\n\n const handleChangeByNativeInput = (event: React.ChangeEvent<HTMLInputElement>) => {\n changeValue(\n updateInternalStateValueByNativeChange(\n value,\n Number(event.target.value),\n getDraggingTypeByTargetDataset(event.target),\n ),\n event,\n );\n };\n\n return (\n <Touch\n data-value={multiple ? `${startValue},${endValue}` : startValue}\n {...restPropsWithoutAriaAttributes}\n className={classNames(\n styles.host,\n disabled && styles.disabled,\n sizeY !== 'regular' && sizeYClassNames[sizeY],\n sizeClassNames[size],\n className,\n )}\n onStart={disabled ? undefined : handlePointerStart}\n onMove={disabled ? undefined : handlePointerMove}\n onEnd={disabled ? undefined : handlePointerEnd}\n >\n <div className={styles.track} />\n <div\n className={styles.trackFill}\n style={\n multiple\n ? { left: `${startValueInPercent}%`, right: `${100 - endReversedValueInPercent}%` }\n : { width: `${startValueInPercent}%` }\n }\n />\n <div ref={thumbsContainerRef} className={styles.thumbs}>\n <SliderThumb\n data-type=\"start\"\n className={styles.thumb}\n style={{\n left: `${startValueInPercent}%`,\n // Меняем местами порядок слоёв, иначе, при достижении `start` и `end` 100%, `end` будет перекрывать `start`.\n zIndex: multiple && startValueInPercent >= 50 ? 2 : undefined,\n }}\n withTooltip={withTooltip}\n inputProps={{\n 'data-type': 'start',\n 'data-testid': startThumbTestId,\n 'ref': thumbStartInputRef,\n 'step': step,\n 'min': min,\n 'value': startValue,\n 'max': multiple ? endValue : max,\n 'disabled': disabled,\n 'aria-label': getAriaLabel ? getAriaLabel(0) : ariaLabel,\n 'aria-valuetext': getAriaValueText ? getAriaValueText(startValue, 0) : ariaValueText,\n 'aria-labelledby': ariaLabelledBy,\n 'onChange': handleChangeByNativeInput,\n }}\n isActive={activeThumb === 'start'}\n />\n {multiple && (\n <SliderThumb\n data-type=\"end\"\n className={styles.thumb}\n style={{ left: `${endReversedValueInPercent}%` }}\n withTooltip={withTooltip}\n inputProps={{\n 'data-type': 'end',\n 'data-testid': endThumbTestId,\n 'ref': thumbEndInputRef,\n 'step': step,\n 'min': startValue,\n 'value': endValue,\n 'max': max,\n 'disabled': disabled,\n 'aria-label': getAriaLabel ? getAriaLabel(1) : ariaLabel,\n 'aria-valuetext': getAriaValueText ? getAriaValueText(endValue, 1) : ariaValueText,\n 'aria-labelledby': ariaLabelledBy,\n 'onChange': handleChangeByNativeInput,\n }}\n isActive={activeThumb === 'end'}\n />\n )}\n </div>\n </Touch>\n );\n};\n"],"names":["React","classNames","clamp","useAdaptivity","useExternRef","Touch","SliderThumb","extractSliderAriaAttributesFromRestProps","getDraggingTypeByTargetDataset","isMultipleValues","offsetToValue","snapDirection","toPercent","updateInternalStateValue","updateInternalStateValueByNativeChange","styles","sizeYClassNames","none","sizeYNone","compact","sizeYCompact","sizeClassNames","l","sizeL","m","sizeM","s","sizeS","Slider","step","min","max","value","valueProp","multiple","multipleProp","defaultValue","disabled","className","getRootRef","getAriaLabel","getAriaValueText","startThumbTestId","endThumbTestId","onChange","withTooltip","size","restProps","sizeY","isControlled","undefined","localValue","setValue","useState","useMemo","resolvedValue","Array","isArray","startValue","endValue","startValueInPercent","endReversedValueInPercent","activeThumb","setActiveThumb","gesture","useRef","dragging","startX","containerWidth","current","thumbsContainerRef","thumbStartInputRef","thumbEndInputRef","ariaLabel","ariaValueText","ariaLabelledBy","restPropsWithoutAriaAttributes","changeValue","nextValue","event","handlePointerStart","left","nextContainerX","width","nextContainerWidth","getBoundingClientRect","foundDraggingType","originalEvent","target","nextStartX","nextDragging","updatedInternalStateValue","nextStartValue","nextEndValue","focus","preventDefault","stopPropagation","handlePointerMove","shiftX","handlePointerEnd","handleChangeByNativeInput","Number","data-value","host","onStart","onMove","onEnd","div","track","trackFill","style","right","ref","thumbs","data-type","thumb","zIndex","inputProps","isActive"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/components/Slider/Slider.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { clamp } from '../../helpers/math';\nimport { mergeStyle } from '../../helpers/mergeStyle';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useConfigDirection } from '../../hooks/useConfigDirection';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport type { CSSCustomProperties, HTMLAttributesWithRootRef } from '../../types';\nimport { type CustomTouchEvent, type CustomTouchEventHandler, Touch } from '../Touch/Touch';\nimport { SliderThumb } from './SliderThumb/SliderThumb';\nimport {\n extractSliderAriaAttributesFromRestProps,\n getDraggingTypeByTargetDataset,\n isMultipleValues,\n offsetToValue,\n snapDirection,\n toPercent,\n updateInternalStateValue,\n updateInternalStateValueByNativeChange,\n} from './helpers';\nimport type { InternalDraggingType, InternalGestureRef, InternalValueState } from './types';\nimport styles from './Slider.module.css';\n\nconst sizeYClassNames = {\n none: styles.sizeYNone,\n compact: styles.sizeYCompact,\n};\n\nconst sizeClassNames = {\n l: styles.sizeL,\n m: styles.sizeM,\n s: styles.sizeS,\n};\n\nexport interface SliderBaseProps\n extends Omit<HTMLAttributesWithRootRef<HTMLDivElement>, 'value' | 'defaultValue' | 'onChange'> {\n min?: number;\n max?: number;\n step?: number;\n disabled?: boolean;\n /**\n * Тоже самое, что и `aria-label`, но на вход можно получать индекс текущего ползунка и в зависимости от этого выдавать разный текст.\n *\n * > Перебивает `aria-label`.\n */\n getAriaLabel?: (index: number) => string;\n /**\n * В отличие от `aria-valuetext`, позволяет более гибко форматировать текст в зависимости от значения ползунка.\n *\n * Полезно при использовании компонента как неконтролируемого.\n *\n * > Перебивает `aria-valuetext`.\n */\n getAriaValueText?: (value: number, index: number) => string;\n withTooltip?: boolean;\n /**\n * Размер ползунка.\n */\n size?: 's' | 'm' | 'l';\n /**\n * Передает атрибут `data-testid` для первого ползунка\n */\n startThumbTestId?: string;\n /**\n * Передает атрибут `data-testid` для второго ползунка когда `multiple=true`\n */\n endThumbTestId?: string;\n}\n\nexport interface SliderProps extends SliderBaseProps {\n multiple?: false;\n value?: number;\n defaultValue?: number;\n onChange?: (value: number, event: CustomTouchEvent | React.ChangeEvent) => void;\n}\n\nexport interface SliderMultipleProps extends SliderBaseProps {\n multiple: true;\n value?: [number, number];\n defaultValue?: [number, number];\n onChange?: (value: [number, number], event: CustomTouchEvent | React.ChangeEvent) => void;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/Slider\n */\nexport const Slider = ({\n step = 1,\n min = 0,\n max = 100,\n value: valueProp,\n multiple: multipleProp,\n defaultValue = multipleProp ? [min, max] : min,\n disabled,\n className,\n getRootRef,\n getAriaLabel,\n getAriaValueText,\n startThumbTestId,\n endThumbTestId,\n onChange,\n withTooltip,\n size = 'l',\n style: styleProp,\n ...restProps\n}: SliderProps | SliderMultipleProps): React.ReactNode => {\n const { sizeY = 'none' } = useAdaptivity();\n const direction = useConfigDirection();\n const isRtl = direction === 'rtl';\n\n const isControlled = valueProp !== undefined;\n const [localValue, setValue] = React.useState(defaultValue);\n\n const value = React.useMemo<InternalValueState>(() => {\n const resolvedValue = isControlled ? valueProp : localValue;\n return Array.isArray(resolvedValue)\n ? [clamp(resolvedValue[0], min, max), clamp(resolvedValue[1], min, max)]\n : [clamp(resolvedValue, min, max), null];\n }, [isControlled, valueProp, localValue, min, max]);\n\n const [startValue, endValue] = value;\n const multiple = multipleProp && endValue !== null;\n const startValueInPercent = toPercent(startValue, min, max);\n const endReversedValueInPercent = multiple ? toPercent(endValue, min, max) : 0;\n const [activeThumb, setActiveThumb] = React.useState<InternalDraggingType | null>(null);\n\n const gesture = React.useRef<InternalGestureRef>({\n dragging: null,\n startX: 0,\n containerWidth: 0,\n }).current;\n const thumbsContainerRef = useExternRef(getRootRef);\n const thumbStartInputRef = React.useRef<HTMLInputElement>(null);\n const thumbEndInputRef = React.useRef<HTMLInputElement>(null);\n\n const { ariaLabel, ariaValueText, ariaLabelledBy, ...restPropsWithoutAriaAttributes } =\n extractSliderAriaAttributesFromRestProps(restProps);\n\n const changeValue = (\n nextValue: InternalValueState,\n event: CustomTouchEvent | React.ChangeEvent,\n ) => {\n if (disabled || (value[0] === nextValue[0] && value[1] === nextValue[1])) {\n return;\n }\n\n if (multipleProp) {\n if (isMultipleValues(nextValue)) {\n !isControlled && setValue(nextValue);\n onChange && onChange(nextValue, event);\n }\n } else {\n !isControlled && setValue(nextValue[0]);\n onChange && onChange(nextValue[0], event);\n }\n };\n\n const handlePointerStart: CustomTouchEventHandler = (event: CustomTouchEvent) => {\n if (!thumbsContainerRef.current) {\n return;\n }\n\n const { left: nextContainerX, width: nextContainerWidth } =\n thumbsContainerRef.current.getBoundingClientRect();\n\n // @ts-expect-error: TS2345 в VKUITouchEvent плохо описаны типы. `target` это просто `EventTarget`.\n const foundDraggingType = getDraggingTypeByTargetDataset(event.originalEvent.target);\n\n let nextStartX = event.startX - nextContainerX;\n if (isRtl) {\n nextStartX = nextContainerWidth - nextStartX;\n }\n const nextValue = offsetToValue(nextStartX, nextContainerWidth, min, max, step);\n const nextDragging = snapDirection(value, nextValue, foundDraggingType);\n\n gesture.dragging = nextDragging;\n gesture.containerWidth = nextContainerWidth;\n gesture.startX = nextStartX;\n\n const updatedInternalStateValue = updateInternalStateValue(\n value,\n nextValue,\n min,\n max,\n nextDragging,\n );\n\n const [nextStartValue, nextEndValue] = updatedInternalStateValue;\n if (\n thumbStartInputRef.current &&\n (foundDraggingType === 'start' ||\n (nextStartValue !== startValue && nextEndValue === endValue))\n ) {\n thumbStartInputRef.current.focus();\n event.originalEvent.preventDefault();\n } else if (\n thumbEndInputRef.current &&\n (foundDraggingType === 'end' || (nextEndValue !== endValue && nextStartValue === startValue))\n ) {\n thumbEndInputRef.current.focus();\n event.originalEvent.preventDefault();\n }\n\n changeValue(updatedInternalStateValue, event);\n\n event.originalEvent.stopPropagation();\n setActiveThumb(gesture.dragging);\n };\n\n const handlePointerMove: CustomTouchEventHandler = (event: CustomTouchEvent) => {\n const { startX, containerWidth, dragging } = gesture;\n\n const { shiftX = 0 } = event;\n const nextStartX = startX + (isRtl ? -shiftX : shiftX);\n const nextValue = offsetToValue(nextStartX, containerWidth, min, max, step);\n\n changeValue(updateInternalStateValue(value, nextValue, min, max, dragging), event);\n\n event.originalEvent.stopPropagation();\n event.originalEvent.preventDefault();\n };\n\n const handlePointerEnd: CustomTouchEventHandler = (event) => {\n gesture.dragging = null;\n event.originalEvent.stopPropagation();\n setActiveThumb(null);\n };\n\n const handleChangeByNativeInput = (event: React.ChangeEvent<HTMLInputElement>) => {\n changeValue(\n updateInternalStateValueByNativeChange(\n value,\n Number(event.target.value),\n getDraggingTypeByTargetDataset(event.target),\n ),\n event,\n );\n };\n\n const style: CSSCustomProperties = {\n '--vkui_internal--Slider_start_value': String(startValueInPercent),\n '--vkui_internal--Slider_end_value': String(endReversedValueInPercent),\n };\n\n return (\n <Touch\n data-value={multiple ? `${startValue},${endValue}` : startValue}\n {...restPropsWithoutAriaAttributes}\n className={classNames(\n styles.host,\n disabled && styles.disabled,\n sizeY !== 'regular' && sizeYClassNames[sizeY],\n sizeClassNames[size],\n multiple && styles.multiple,\n isRtl && styles.rtl,\n className,\n )}\n style={mergeStyle(styleProp, style)}\n getRootRef={getRootRef}\n onStart={disabled ? undefined : handlePointerStart}\n onMove={disabled ? undefined : handlePointerMove}\n onEnd={disabled ? undefined : handlePointerEnd}\n >\n <div className={styles.track} />\n <div className={styles.trackFill} />\n <div ref={thumbsContainerRef} className={styles.thumbs}>\n <SliderThumb\n data-type=\"start\"\n className={classNames(styles.thumb, styles.thumbStart)}\n style={{\n // Меняем местами порядок слоёв, иначе, при достижении `start` и `end` 100%, `end` будет перекрывать `start`.\n zIndex: multiple && startValueInPercent >= 50 ? 2 : undefined,\n }}\n withTooltip={withTooltip}\n inputProps={{\n 'data-type': 'start',\n 'data-testid': startThumbTestId,\n 'ref': thumbStartInputRef,\n 'step': step,\n 'min': min,\n 'value': startValue,\n 'max': multiple ? endValue : max,\n 'disabled': disabled,\n 'aria-label': getAriaLabel ? getAriaLabel(0) : ariaLabel,\n 'aria-valuetext': getAriaValueText ? getAriaValueText(startValue, 0) : ariaValueText,\n 'aria-labelledby': ariaLabelledBy,\n 'onChange': handleChangeByNativeInput,\n }}\n isActive={activeThumb === 'start'}\n />\n {multiple && (\n <SliderThumb\n data-type=\"end\"\n className={classNames(styles.thumb, styles.thumbEnd)}\n withTooltip={withTooltip}\n inputProps={{\n 'data-type': 'end',\n 'data-testid': endThumbTestId,\n 'ref': thumbEndInputRef,\n 'step': step,\n 'min': startValue,\n 'value': endValue,\n 'max': max,\n 'disabled': disabled,\n 'aria-label': getAriaLabel ? getAriaLabel(1) : ariaLabel,\n 'aria-valuetext': getAriaValueText ? getAriaValueText(endValue, 1) : ariaValueText,\n 'aria-labelledby': ariaLabelledBy,\n 'onChange': handleChangeByNativeInput,\n }}\n isActive={activeThumb === 'end'}\n />\n )}\n </div>\n </Touch>\n );\n};\n"],"names":["React","classNames","clamp","mergeStyle","useAdaptivity","useConfigDirection","useExternRef","Touch","SliderThumb","extractSliderAriaAttributesFromRestProps","getDraggingTypeByTargetDataset","isMultipleValues","offsetToValue","snapDirection","toPercent","updateInternalStateValue","updateInternalStateValueByNativeChange","styles","sizeYClassNames","none","sizeYNone","compact","sizeYCompact","sizeClassNames","l","sizeL","m","sizeM","s","sizeS","Slider","step","min","max","value","valueProp","multiple","multipleProp","defaultValue","disabled","className","getRootRef","getAriaLabel","getAriaValueText","startThumbTestId","endThumbTestId","onChange","withTooltip","size","style","styleProp","restProps","sizeY","direction","isRtl","isControlled","undefined","localValue","setValue","useState","useMemo","resolvedValue","Array","isArray","startValue","endValue","startValueInPercent","endReversedValueInPercent","activeThumb","setActiveThumb","gesture","useRef","dragging","startX","containerWidth","current","thumbsContainerRef","thumbStartInputRef","thumbEndInputRef","ariaLabel","ariaValueText","ariaLabelledBy","restPropsWithoutAriaAttributes","changeValue","nextValue","event","handlePointerStart","left","nextContainerX","width","nextContainerWidth","getBoundingClientRect","foundDraggingType","originalEvent","target","nextStartX","nextDragging","updatedInternalStateValue","nextStartValue","nextEndValue","focus","preventDefault","stopPropagation","handlePointerMove","shiftX","handlePointerEnd","handleChangeByNativeInput","Number","String","data-value","host","rtl","onStart","onMove","onEnd","div","track","trackFill","ref","thumbs","data-type","thumb","thumbStart","zIndex","inputProps","isActive","thumbEnd"],"mappings":"AAAA;;AAEA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,KAAK,QAAQ,wBAAqB;AAC3C,SAASC,UAAU,QAAQ,8BAA2B;AACtD,SAASC,aAAa,QAAQ,+BAA4B;AAC1D,SAASC,kBAAkB,QAAQ,oCAAiC;AACpE,SAASC,YAAY,QAAQ,8BAA2B;AAExD,SAA8DC,KAAK,QAAQ,oBAAiB;AAC5F,SAASC,WAAW,QAAQ,+BAA4B;AACxD,SACEC,wCAAwC,EACxCC,8BAA8B,EAC9BC,gBAAgB,EAChBC,aAAa,EACbC,aAAa,EACbC,SAAS,EACTC,wBAAwB,EACxBC,sCAAsC,QACjC,eAAY;AAEnB,OAAOC,YAAY,sBAAsB;AAEzC,MAAMC,kBAAkB;IACtBC,MAAMF,OAAOG,SAAS;IACtBC,SAASJ,OAAOK,YAAY;AAC9B;AAEA,MAAMC,iBAAiB;IACrBC,GAAGP,OAAOQ,KAAK;IACfC,GAAGT,OAAOU,KAAK;IACfC,GAAGX,OAAOY,KAAK;AACjB;AAmDA;;CAEC,GACD,OAAO,MAAMC,SAAS,CAAC,EACrBC,OAAO,CAAC,EACRC,MAAM,CAAC,EACPC,MAAM,GAAG,EACTC,OAAOC,SAAS,EAChBC,UAAUC,YAAY,EACtBC,eAAeD,eAAe;IAACL;IAAKC;CAAI,GAAGD,GAAG,EAC9CO,QAAQ,EACRC,SAAS,EACTC,UAAU,EACVC,YAAY,EACZC,gBAAgB,EAChBC,gBAAgB,EAChBC,cAAc,EACdC,QAAQ,EACRC,WAAW,EACXC,OAAO,GAAG,EACVC,OAAOC,SAAS,EAChB,GAAGC,WAC+B;IAClC,MAAM,EAAEC,QAAQ,MAAM,EAAE,GAAGhD;IAC3B,MAAMiD,YAAYhD;IAClB,MAAMiD,QAAQD,cAAc;IAE5B,MAAME,eAAepB,cAAcqB;IACnC,MAAM,CAACC,YAAYC,SAAS,GAAG1D,MAAM2D,QAAQ,CAACrB;IAE9C,MAAMJ,QAAQlC,MAAM4D,OAAO,CAAqB;QAC9C,MAAMC,gBAAgBN,eAAepB,YAAYsB;QACjD,OAAOK,MAAMC,OAAO,CAACF,iBACjB;YAAC3D,MAAM2D,aAAa,CAAC,EAAE,EAAE7B,KAAKC;YAAM/B,MAAM2D,aAAa,CAAC,EAAE,EAAE7B,KAAKC;SAAK,GACtE;YAAC/B,MAAM2D,eAAe7B,KAAKC;YAAM;SAAK;IAC5C,GAAG;QAACsB;QAAcpB;QAAWsB;QAAYzB;QAAKC;KAAI;IAElD,MAAM,CAAC+B,YAAYC,SAAS,GAAG/B;IAC/B,MAAME,WAAWC,gBAAgB4B,aAAa;IAC9C,MAAMC,sBAAsBpD,UAAUkD,YAAYhC,KAAKC;IACvD,MAAMkC,4BAA4B/B,WAAWtB,UAAUmD,UAAUjC,KAAKC,OAAO;IAC7E,MAAM,CAACmC,aAAaC,eAAe,GAAGrE,MAAM2D,QAAQ,CAA8B;IAElF,MAAMW,UAAUtE,MAAMuE,MAAM,CAAqB;QAC/CC,UAAU;QACVC,QAAQ;QACRC,gBAAgB;IAClB,GAAGC,OAAO;IACV,MAAMC,qBAAqBtE,aAAamC;IACxC,MAAMoC,qBAAqB7E,MAAMuE,MAAM,CAAmB;IAC1D,MAAMO,mBAAmB9E,MAAMuE,MAAM,CAAmB;IAExD,MAAM,EAAEQ,SAAS,EAAEC,aAAa,EAAEC,cAAc,EAAE,GAAGC,gCAAgC,GACnFzE,yCAAyC0C;IAE3C,MAAMgC,cAAc,CAClBC,WACAC;QAEA,IAAI9C,YAAaL,KAAK,CAAC,EAAE,KAAKkD,SAAS,CAAC,EAAE,IAAIlD,KAAK,CAAC,EAAE,KAAKkD,SAAS,CAAC,EAAE,EAAG;YACxE;QACF;QAEA,IAAI/C,cAAc;YAChB,IAAI1B,iBAAiByE,YAAY;gBAC/B,CAAC7B,gBAAgBG,SAAS0B;gBAC1BtC,YAAYA,SAASsC,WAAWC;YAClC;QACF,OAAO;YACL,CAAC9B,gBAAgBG,SAAS0B,SAAS,CAAC,EAAE;YACtCtC,YAAYA,SAASsC,SAAS,CAAC,EAAE,EAAEC;QACrC;IACF;IAEA,MAAMC,qBAA8C,CAACD;QACnD,IAAI,CAACT,mBAAmBD,OAAO,EAAE;YAC/B;QACF;QAEA,MAAM,EAAEY,MAAMC,cAAc,EAAEC,OAAOC,kBAAkB,EAAE,GACvDd,mBAAmBD,OAAO,CAACgB,qBAAqB;QAElD,mGAAmG;QACnG,MAAMC,oBAAoBlF,+BAA+B2E,MAAMQ,aAAa,CAACC,MAAM;QAEnF,IAAIC,aAAaV,MAAMZ,MAAM,GAAGe;QAChC,IAAIlC,OAAO;YACTyC,aAAaL,qBAAqBK;QACpC;QACA,MAAMX,YAAYxE,cAAcmF,YAAYL,oBAAoB1D,KAAKC,KAAKF;QAC1E,MAAMiE,eAAenF,cAAcqB,OAAOkD,WAAWQ;QAErDtB,QAAQE,QAAQ,GAAGwB;QACnB1B,QAAQI,cAAc,GAAGgB;QACzBpB,QAAQG,MAAM,GAAGsB;QAEjB,MAAME,4BAA4BlF,yBAChCmB,OACAkD,WACApD,KACAC,KACA+D;QAGF,MAAM,CAACE,gBAAgBC,aAAa,GAAGF;QACvC,IACEpB,mBAAmBF,OAAO,IACzBiB,CAAAA,sBAAsB,WACpBM,mBAAmBlC,cAAcmC,iBAAiBlC,QAAQ,GAC7D;YACAY,mBAAmBF,OAAO,CAACyB,KAAK;YAChCf,MAAMQ,aAAa,CAACQ,cAAc;QACpC,OAAO,IACLvB,iBAAiBH,OAAO,IACvBiB,CAAAA,sBAAsB,SAAUO,iBAAiBlC,YAAYiC,mBAAmBlC,UAAU,GAC3F;YACAc,iBAAiBH,OAAO,CAACyB,KAAK;YAC9Bf,MAAMQ,aAAa,CAACQ,cAAc;QACpC;QAEAlB,YAAYc,2BAA2BZ;QAEvCA,MAAMQ,aAAa,CAACS,eAAe;QACnCjC,eAAeC,QAAQE,QAAQ;IACjC;IAEA,MAAM+B,oBAA6C,CAAClB;QAClD,MAAM,EAAEZ,MAAM,EAAEC,cAAc,EAAEF,QAAQ,EAAE,GAAGF;QAE7C,MAAM,EAAEkC,SAAS,CAAC,EAAE,GAAGnB;QACvB,MAAMU,aAAatB,SAAUnB,CAAAA,QAAQ,CAACkD,SAASA,MAAK;QACpD,MAAMpB,YAAYxE,cAAcmF,YAAYrB,gBAAgB1C,KAAKC,KAAKF;QAEtEoD,YAAYpE,yBAAyBmB,OAAOkD,WAAWpD,KAAKC,KAAKuC,WAAWa;QAE5EA,MAAMQ,aAAa,CAACS,eAAe;QACnCjB,MAAMQ,aAAa,CAACQ,cAAc;IACpC;IAEA,MAAMI,mBAA4C,CAACpB;QACjDf,QAAQE,QAAQ,GAAG;QACnBa,MAAMQ,aAAa,CAACS,eAAe;QACnCjC,eAAe;IACjB;IAEA,MAAMqC,4BAA4B,CAACrB;QACjCF,YACEnE,uCACEkB,OACAyE,OAAOtB,MAAMS,MAAM,CAAC5D,KAAK,GACzBxB,+BAA+B2E,MAAMS,MAAM,IAE7CT;IAEJ;IAEA,MAAMpC,QAA6B;QACjC,uCAAuC2D,OAAO1C;QAC9C,qCAAqC0C,OAAOzC;IAC9C;IAEA,qBACE,MAAC5D;QACCsG,cAAYzE,WAAW,GAAG4B,WAAW,CAAC,EAAEC,UAAU,GAAGD;QACpD,GAAGkB,8BAA8B;QAClC1C,WAAWvC,WACTgB,OAAO6F,IAAI,EACXvE,YAAYtB,OAAOsB,QAAQ,EAC3Ba,UAAU,aAAalC,eAAe,CAACkC,MAAM,EAC7C7B,cAAc,CAACyB,KAAK,EACpBZ,YAAYnB,OAAOmB,QAAQ,EAC3BkB,SAASrC,OAAO8F,GAAG,EACnBvE;QAEFS,OAAO9C,WAAW+C,WAAWD;QAC7BR,YAAYA;QACZuE,SAASzE,WAAWiB,YAAY8B;QAChC2B,QAAQ1E,WAAWiB,YAAY+C;QAC/BW,OAAO3E,WAAWiB,YAAYiD;;0BAE9B,KAACU;gBAAI3E,WAAWvB,OAAOmG,KAAK;;0BAC5B,KAACD;gBAAI3E,WAAWvB,OAAOoG,SAAS;;0BAChC,MAACF;gBAAIG,KAAK1C;gBAAoBpC,WAAWvB,OAAOsG,MAAM;;kCACpD,KAAC/G;wBACCgH,aAAU;wBACVhF,WAAWvC,WAAWgB,OAAOwG,KAAK,EAAExG,OAAOyG,UAAU;wBACrDzE,OAAO;4BACL,6GAA6G;4BAC7G0E,QAAQvF,YAAY8B,uBAAuB,KAAK,IAAIV;wBACtD;wBACAT,aAAaA;wBACb6E,YAAY;4BACV,aAAa;4BACb,eAAehF;4BACf,OAAOiC;4BACP,QAAQ9C;4BACR,OAAOC;4BACP,SAASgC;4BACT,OAAO5B,WAAW6B,WAAWhC;4BAC7B,YAAYM;4BACZ,cAAcG,eAAeA,aAAa,KAAKqC;4BAC/C,kBAAkBpC,mBAAmBA,iBAAiBqB,YAAY,KAAKgB;4BACvE,mBAAmBC;4BACnB,YAAYyB;wBACd;wBACAmB,UAAUzD,gBAAgB;;oBAE3BhC,0BACC,KAAC5B;wBACCgH,aAAU;wBACVhF,WAAWvC,WAAWgB,OAAOwG,KAAK,EAAExG,OAAO6G,QAAQ;wBACnD/E,aAAaA;wBACb6E,YAAY;4BACV,aAAa;4BACb,eAAe/E;4BACf,OAAOiC;4BACP,QAAQ/C;4BACR,OAAOiC;4BACP,SAASC;4BACT,OAAOhC;4BACP,YAAYM;4BACZ,cAAcG,eAAeA,aAAa,KAAKqC;4BAC/C,kBAAkBpC,mBAAmBA,iBAAiBsB,UAAU,KAAKe;4BACrE,mBAAmBC;4BACnB,YAAYyB;wBACd;wBACAmB,UAAUzD,gBAAgB;;;;;;AAMtC,EAAE"}
@@ -1,7 +1,10 @@
1
1
  .host {
2
2
  position: relative;
3
- cursor: pointer;
4
3
  block-size: var(--vkui_internal--slider_thumb_size);
4
+ cursor: pointer;
5
+
6
+ --vkui_internal--Slider_start_value: 0;
7
+ --vkui_internal--Slider_end_value: 0;
5
8
  }
6
9
 
7
10
  .disabled {
@@ -24,15 +27,21 @@
24
27
  }
25
28
 
26
29
  .trackFill {
27
- inline-size: auto;
30
+ inline-size: calc(var(--vkui_internal--Slider_start_value) * 1%);
28
31
  background: var(--vkui--color_background_accent);
29
32
  }
30
33
 
34
+ .multiple .trackFill {
35
+ inset-inline-start: calc(var(--vkui_internal--Slider_start_value) * 1%);
36
+ inset-inline-end: calc((100 - var(--vkui_internal--Slider_end_value)) * 1%);
37
+ inline-size: auto;
38
+ }
39
+
31
40
  .thumbs {
32
- isolation: isolate;
33
41
  position: relative;
34
- margin-inline: calc(var(--vkui_internal--slider_thumb_size) / 2);
35
42
  block-size: 100%;
43
+ margin-inline: calc(var(--vkui_internal--slider_thumb_size) / 2);
44
+ isolation: isolate;
36
45
  }
37
46
 
38
47
  .thumb {
@@ -40,6 +49,18 @@
40
49
  transform: translate(-50%, -50%);
41
50
  }
42
51
 
52
+ .rtl .thumb {
53
+ transform: translate(50%, -50%);
54
+ }
55
+
56
+ .thumbStart {
57
+ inset-inline-start: calc(var(--vkui_internal--Slider_start_value) * 1%);
58
+ }
59
+
60
+ .thumbEnd {
61
+ inset-inline-start: calc(var(--vkui_internal--Slider_end_value) * 1%);
62
+ }
63
+
43
64
  .sizeL {
44
65
  --vkui_internal--slider_thumb_size: 28px;
45
66
  }
@@ -70,7 +70,11 @@ export const SliderThumb = ({ className, getRootRef, inputProps, withTooltip, is
70
70
  shouldShowTooltip && /*#__PURE__*/ _jsx(TooltipBase, {
71
71
  appearance: "neutral",
72
72
  getRootRef: refs.setFloating,
73
- style: convertFloatingDataToReactCSSProperties(floatingPositionStrategy, floatingDataX, floatingDataY),
73
+ style: convertFloatingDataToReactCSSProperties({
74
+ strategy: floatingPositionStrategy,
75
+ x: floatingDataX,
76
+ y: floatingDataY
77
+ }),
74
78
  arrowProps: {
75
79
  coords: arrowCoords,
76
80
  placement: resolvedPlacement,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/components/Slider/SliderThumb/SliderThumb.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useBooleanState } from '../../../hooks/useBooleanState';\nimport { useExternRef } from '../../../hooks/useExternRef';\nimport { useFocusVisible } from '../../../hooks/useFocusVisible';\nimport { useFocusVisibleClassName } from '../../../hooks/useFocusVisibleClassName';\nimport {\n arrowMiddleware,\n convertFloatingDataToReactCSSProperties,\n flipMiddleware,\n offsetMiddleware,\n shiftMiddleware,\n useFloating,\n} from '../../../lib/floating';\nimport type { HasDataAttribute, HasRootRef } from '../../../types';\nimport { TooltipBase } from '../../TooltipBase/TooltipBase';\nimport styles from './SliderThumb.module.css';\n\ninterface SliderThumbProps extends HasRootRef<HTMLSpanElement>, HasDataAttribute {\n className?: string;\n style?: React.CSSProperties;\n inputProps?: React.InputHTMLAttributes<HTMLInputElement> &\n React.RefAttributes<HTMLInputElement> &\n HasDataAttribute;\n withTooltip?: boolean;\n isActive?: boolean;\n}\n\nexport const SliderThumb = ({\n className,\n getRootRef,\n inputProps,\n withTooltip,\n isActive,\n ...restProps\n}: SliderThumbProps): React.ReactNode => {\n const { focusVisible, onBlur, onFocus } = useFocusVisible();\n const focusVisibleClassNames = useFocusVisibleClassName({\n focusVisible,\n mode: styles.focusVisible,\n });\n const [arrowRef, setArrowRef] = React.useState<HTMLDivElement | null>(null);\n\n const memoizedMiddlewares = React.useMemo(() => {\n return [\n offsetMiddleware({\n crossAxis: 0,\n mainAxis: 15,\n }),\n flipMiddleware(),\n shiftMiddleware({ padding: 8 }),\n arrowMiddleware({\n element: arrowRef,\n }),\n ];\n }, [arrowRef]);\n\n const {\n x: floatingDataX,\n y: floatingDataY,\n placement: resolvedPlacement,\n refs,\n strategy: floatingPositionStrategy,\n middlewareData: { arrow: arrowCoords },\n update: updateTooltipPosition,\n } = useFloating({\n placement: 'top',\n middleware: memoizedMiddlewares,\n });\n\n const {\n value: isHovered,\n setTrue: setHoveredTrue,\n setFalse: setHoveredFalse,\n } = useBooleanState(false);\n\n const handleRootRef = useExternRef<HTMLSpanElement>(getRootRef, refs.setReference);\n\n const shouldShowTooltip = withTooltip && (focusVisible || isHovered || isActive);\n\n const inputValue = inputProps && inputProps.value;\n React.useEffect(\n function udpateTooltipPositionOnValueChange() {\n if (shouldShowTooltip && inputValue !== 'undefined') {\n updateTooltipPosition();\n }\n },\n [inputValue, updateTooltipPosition, shouldShowTooltip],\n );\n\n return (\n <React.Fragment>\n <span\n {...restProps}\n ref={handleRootRef}\n onMouseEnter={setHoveredTrue}\n onMouseLeave={setHoveredFalse}\n className={classNames(\n styles.host,\n focusVisibleClassNames,\n isActive && styles.active,\n isHovered && styles.hover,\n className,\n )}\n >\n <input\n {...inputProps}\n type=\"range\"\n className={styles.nativeInput}\n aria-orientation=\"horizontal\"\n onBlur={onBlur}\n onFocus={onFocus}\n />\n </span>\n {shouldShowTooltip && (\n <TooltipBase\n appearance=\"neutral\"\n getRootRef={refs.setFloating}\n style={convertFloatingDataToReactCSSProperties(\n floatingPositionStrategy,\n floatingDataX,\n floatingDataY,\n )}\n arrowProps={{\n coords: arrowCoords,\n placement: resolvedPlacement,\n getRootRef: setArrowRef,\n }}\n description={inputValue}\n />\n )}\n </React.Fragment>\n );\n};\n"],"names":["React","classNames","useBooleanState","useExternRef","useFocusVisible","useFocusVisibleClassName","arrowMiddleware","convertFloatingDataToReactCSSProperties","flipMiddleware","offsetMiddleware","shiftMiddleware","useFloating","TooltipBase","styles","SliderThumb","className","getRootRef","inputProps","withTooltip","isActive","restProps","focusVisible","onBlur","onFocus","focusVisibleClassNames","mode","arrowRef","setArrowRef","useState","memoizedMiddlewares","useMemo","crossAxis","mainAxis","padding","element","x","floatingDataX","y","floatingDataY","placement","resolvedPlacement","refs","strategy","floatingPositionStrategy","middlewareData","arrow","arrowCoords","update","updateTooltipPosition","middleware","value","isHovered","setTrue","setHoveredTrue","setFalse","setHoveredFalse","handleRootRef","setReference","shouldShowTooltip","inputValue","useEffect","udpateTooltipPositionOnValueChange","Fragment","span","ref","onMouseEnter","onMouseLeave","host","active","hover","input","type","nativeInput","aria-orientation","appearance","setFloating","style","arrowProps","coords","description"],"mappings":"AAAA;;AAEA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,eAAe,QAAQ,oCAAiC;AACjE,SAASC,YAAY,QAAQ,iCAA8B;AAC3D,SAASC,eAAe,QAAQ,oCAAiC;AACjE,SAASC,wBAAwB,QAAQ,6CAA0C;AACnF,SACEC,eAAe,EACfC,uCAAuC,EACvCC,cAAc,EACdC,gBAAgB,EAChBC,eAAe,EACfC,WAAW,QACN,iCAAwB;AAE/B,SAASC,WAAW,QAAQ,mCAAgC;AAC5D,OAAOC,YAAY,2BAA2B;AAY9C,OAAO,MAAMC,cAAc,CAAC,EAC1BC,SAAS,EACTC,UAAU,EACVC,UAAU,EACVC,WAAW,EACXC,QAAQ,EACR,GAAGC,WACc;IACjB,MAAM,EAAEC,YAAY,EAAEC,MAAM,EAAEC,OAAO,EAAE,GAAGnB;IAC1C,MAAMoB,yBAAyBnB,yBAAyB;QACtDgB;QACAI,MAAMZ,OAAOQ,YAAY;IAC3B;IACA,MAAM,CAACK,UAAUC,YAAY,GAAG3B,MAAM4B,QAAQ,CAAwB;IAEtE,MAAMC,sBAAsB7B,MAAM8B,OAAO,CAAC;QACxC,OAAO;YACLrB,iBAAiB;gBACfsB,WAAW;gBACXC,UAAU;YACZ;YACAxB;YACAE,gBAAgB;gBAAEuB,SAAS;YAAE;YAC7B3B,gBAAgB;gBACd4B,SAASR;YACX;SACD;IACH,GAAG;QAACA;KAAS;IAEb,MAAM,EACJS,GAAGC,aAAa,EAChBC,GAAGC,aAAa,EAChBC,WAAWC,iBAAiB,EAC5BC,IAAI,EACJC,UAAUC,wBAAwB,EAClCC,gBAAgB,EAAEC,OAAOC,WAAW,EAAE,EACtCC,QAAQC,qBAAqB,EAC9B,GAAGrC,YAAY;QACd4B,WAAW;QACXU,YAAYpB;IACd;IAEA,MAAM,EACJqB,OAAOC,SAAS,EAChBC,SAASC,cAAc,EACvBC,UAAUC,eAAe,EAC1B,GAAGrD,gBAAgB;IAEpB,MAAMsD,gBAAgBrD,aAA8Ba,YAAYyB,KAAKgB,YAAY;IAEjF,MAAMC,oBAAoBxC,eAAgBG,CAAAA,gBAAgB8B,aAAahC,QAAO;IAE9E,MAAMwC,aAAa1C,cAAcA,WAAWiC,KAAK;IACjDlD,MAAM4D,SAAS,CACb,SAASC;QACP,IAAIH,qBAAqBC,eAAe,aAAa;YACnDX;QACF;IACF,GACA;QAACW;QAAYX;QAAuBU;KAAkB;IAGxD,qBACE,MAAC1D,MAAM8D,QAAQ;;0BACb,KAACC;gBACE,GAAG3C,SAAS;gBACb4C,KAAKR;gBACLS,cAAcZ;gBACda,cAAcX;gBACdxC,WAAWd,WACTY,OAAOsD,IAAI,EACX3C,wBACAL,YAAYN,OAAOuD,MAAM,EACzBjB,aAAatC,OAAOwD,KAAK,EACzBtD;0BAGF,cAAA,KAACuD;oBACE,GAAGrD,UAAU;oBACdsD,MAAK;oBACLxD,WAAWF,OAAO2D,WAAW;oBAC7BC,oBAAiB;oBACjBnD,QAAQA;oBACRC,SAASA;;;YAGZmC,mCACC,KAAC9C;gBACC8D,YAAW;gBACX1D,YAAYyB,KAAKkC,WAAW;gBAC5BC,OAAOrE,wCACLoC,0BACAP,eACAE;gBAEFuC,YAAY;oBACVC,QAAQhC;oBACRP,WAAWC;oBACXxB,YAAYW;gBACd;gBACAoD,aAAapB;;;;AAKvB,EAAE"}
1
+ {"version":3,"sources":["../../../../../src/components/Slider/SliderThumb/SliderThumb.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useBooleanState } from '../../../hooks/useBooleanState';\nimport { useExternRef } from '../../../hooks/useExternRef';\nimport { useFocusVisible } from '../../../hooks/useFocusVisible';\nimport { useFocusVisibleClassName } from '../../../hooks/useFocusVisibleClassName';\nimport {\n arrowMiddleware,\n convertFloatingDataToReactCSSProperties,\n flipMiddleware,\n offsetMiddleware,\n shiftMiddleware,\n useFloating,\n} from '../../../lib/floating';\nimport type { HasDataAttribute, HasRootRef } from '../../../types';\nimport { TooltipBase } from '../../TooltipBase/TooltipBase';\nimport styles from './SliderThumb.module.css';\n\ninterface SliderThumbProps extends HasRootRef<HTMLSpanElement>, HasDataAttribute {\n className?: string;\n style?: React.CSSProperties;\n inputProps?: React.InputHTMLAttributes<HTMLInputElement> &\n React.RefAttributes<HTMLInputElement> &\n HasDataAttribute;\n withTooltip?: boolean;\n isActive?: boolean;\n}\n\nexport const SliderThumb = ({\n className,\n getRootRef,\n inputProps,\n withTooltip,\n isActive,\n ...restProps\n}: SliderThumbProps): React.ReactNode => {\n const { focusVisible, onBlur, onFocus } = useFocusVisible();\n const focusVisibleClassNames = useFocusVisibleClassName({\n focusVisible,\n mode: styles.focusVisible,\n });\n const [arrowRef, setArrowRef] = React.useState<HTMLDivElement | null>(null);\n\n const memoizedMiddlewares = React.useMemo(() => {\n return [\n offsetMiddleware({\n crossAxis: 0,\n mainAxis: 15,\n }),\n flipMiddleware(),\n shiftMiddleware({ padding: 8 }),\n arrowMiddleware({\n element: arrowRef,\n }),\n ];\n }, [arrowRef]);\n\n const {\n x: floatingDataX,\n y: floatingDataY,\n placement: resolvedPlacement,\n refs,\n strategy: floatingPositionStrategy,\n middlewareData: { arrow: arrowCoords },\n update: updateTooltipPosition,\n } = useFloating({\n placement: 'top',\n middleware: memoizedMiddlewares,\n });\n\n const {\n value: isHovered,\n setTrue: setHoveredTrue,\n setFalse: setHoveredFalse,\n } = useBooleanState(false);\n\n const handleRootRef = useExternRef<HTMLSpanElement>(getRootRef, refs.setReference);\n\n const shouldShowTooltip = withTooltip && (focusVisible || isHovered || isActive);\n\n const inputValue = inputProps && inputProps.value;\n React.useEffect(\n function udpateTooltipPositionOnValueChange() {\n if (shouldShowTooltip && inputValue !== 'undefined') {\n updateTooltipPosition();\n }\n },\n [inputValue, updateTooltipPosition, shouldShowTooltip],\n );\n\n return (\n <React.Fragment>\n <span\n {...restProps}\n ref={handleRootRef}\n onMouseEnter={setHoveredTrue}\n onMouseLeave={setHoveredFalse}\n className={classNames(\n styles.host,\n focusVisibleClassNames,\n isActive && styles.active,\n isHovered && styles.hover,\n className,\n )}\n >\n <input\n {...inputProps}\n type=\"range\"\n className={styles.nativeInput}\n aria-orientation=\"horizontal\"\n onBlur={onBlur}\n onFocus={onFocus}\n />\n </span>\n {shouldShowTooltip && (\n <TooltipBase\n appearance=\"neutral\"\n getRootRef={refs.setFloating}\n style={convertFloatingDataToReactCSSProperties({\n strategy: floatingPositionStrategy,\n x: floatingDataX,\n y: floatingDataY,\n })}\n arrowProps={{\n coords: arrowCoords,\n placement: resolvedPlacement,\n getRootRef: setArrowRef,\n }}\n description={inputValue}\n />\n )}\n </React.Fragment>\n );\n};\n"],"names":["React","classNames","useBooleanState","useExternRef","useFocusVisible","useFocusVisibleClassName","arrowMiddleware","convertFloatingDataToReactCSSProperties","flipMiddleware","offsetMiddleware","shiftMiddleware","useFloating","TooltipBase","styles","SliderThumb","className","getRootRef","inputProps","withTooltip","isActive","restProps","focusVisible","onBlur","onFocus","focusVisibleClassNames","mode","arrowRef","setArrowRef","useState","memoizedMiddlewares","useMemo","crossAxis","mainAxis","padding","element","x","floatingDataX","y","floatingDataY","placement","resolvedPlacement","refs","strategy","floatingPositionStrategy","middlewareData","arrow","arrowCoords","update","updateTooltipPosition","middleware","value","isHovered","setTrue","setHoveredTrue","setFalse","setHoveredFalse","handleRootRef","setReference","shouldShowTooltip","inputValue","useEffect","udpateTooltipPositionOnValueChange","Fragment","span","ref","onMouseEnter","onMouseLeave","host","active","hover","input","type","nativeInput","aria-orientation","appearance","setFloating","style","arrowProps","coords","description"],"mappings":"AAAA;;AAEA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,eAAe,QAAQ,oCAAiC;AACjE,SAASC,YAAY,QAAQ,iCAA8B;AAC3D,SAASC,eAAe,QAAQ,oCAAiC;AACjE,SAASC,wBAAwB,QAAQ,6CAA0C;AACnF,SACEC,eAAe,EACfC,uCAAuC,EACvCC,cAAc,EACdC,gBAAgB,EAChBC,eAAe,EACfC,WAAW,QACN,iCAAwB;AAE/B,SAASC,WAAW,QAAQ,mCAAgC;AAC5D,OAAOC,YAAY,2BAA2B;AAY9C,OAAO,MAAMC,cAAc,CAAC,EAC1BC,SAAS,EACTC,UAAU,EACVC,UAAU,EACVC,WAAW,EACXC,QAAQ,EACR,GAAGC,WACc;IACjB,MAAM,EAAEC,YAAY,EAAEC,MAAM,EAAEC,OAAO,EAAE,GAAGnB;IAC1C,MAAMoB,yBAAyBnB,yBAAyB;QACtDgB;QACAI,MAAMZ,OAAOQ,YAAY;IAC3B;IACA,MAAM,CAACK,UAAUC,YAAY,GAAG3B,MAAM4B,QAAQ,CAAwB;IAEtE,MAAMC,sBAAsB7B,MAAM8B,OAAO,CAAC;QACxC,OAAO;YACLrB,iBAAiB;gBACfsB,WAAW;gBACXC,UAAU;YACZ;YACAxB;YACAE,gBAAgB;gBAAEuB,SAAS;YAAE;YAC7B3B,gBAAgB;gBACd4B,SAASR;YACX;SACD;IACH,GAAG;QAACA;KAAS;IAEb,MAAM,EACJS,GAAGC,aAAa,EAChBC,GAAGC,aAAa,EAChBC,WAAWC,iBAAiB,EAC5BC,IAAI,EACJC,UAAUC,wBAAwB,EAClCC,gBAAgB,EAAEC,OAAOC,WAAW,EAAE,EACtCC,QAAQC,qBAAqB,EAC9B,GAAGrC,YAAY;QACd4B,WAAW;QACXU,YAAYpB;IACd;IAEA,MAAM,EACJqB,OAAOC,SAAS,EAChBC,SAASC,cAAc,EACvBC,UAAUC,eAAe,EAC1B,GAAGrD,gBAAgB;IAEpB,MAAMsD,gBAAgBrD,aAA8Ba,YAAYyB,KAAKgB,YAAY;IAEjF,MAAMC,oBAAoBxC,eAAgBG,CAAAA,gBAAgB8B,aAAahC,QAAO;IAE9E,MAAMwC,aAAa1C,cAAcA,WAAWiC,KAAK;IACjDlD,MAAM4D,SAAS,CACb,SAASC;QACP,IAAIH,qBAAqBC,eAAe,aAAa;YACnDX;QACF;IACF,GACA;QAACW;QAAYX;QAAuBU;KAAkB;IAGxD,qBACE,MAAC1D,MAAM8D,QAAQ;;0BACb,KAACC;gBACE,GAAG3C,SAAS;gBACb4C,KAAKR;gBACLS,cAAcZ;gBACda,cAAcX;gBACdxC,WAAWd,WACTY,OAAOsD,IAAI,EACX3C,wBACAL,YAAYN,OAAOuD,MAAM,EACzBjB,aAAatC,OAAOwD,KAAK,EACzBtD;0BAGF,cAAA,KAACuD;oBACE,GAAGrD,UAAU;oBACdsD,MAAK;oBACLxD,WAAWF,OAAO2D,WAAW;oBAC7BC,oBAAiB;oBACjBnD,QAAQA;oBACRC,SAASA;;;YAGZmC,mCACC,KAAC9C;gBACC8D,YAAW;gBACX1D,YAAYyB,KAAKkC,WAAW;gBAC5BC,OAAOrE,wCAAwC;oBAC7CmC,UAAUC;oBACVR,GAAGC;oBACHC,GAAGC;gBACL;gBACAuC,YAAY;oBACVC,QAAQhC;oBACRP,WAAWC;oBACXxB,YAAYW;gBACd;gBACAoD,aAAapB;;;;AAKvB,EAAE"}
@@ -4,13 +4,13 @@
4
4
  box-sizing: border-box;
5
5
  inline-size: var(--vkui_internal--slider_thumb_size);
6
6
  block-size: var(--vkui_internal--slider_thumb_size);
7
- border-radius: 50%;
8
- border: var(--vkui--size_border--regular) solid var(--vkui--color_separator_primary_alpha);
9
- background-color: var(--vkui--color_background_contrast);
10
- box-shadow: var(--vkui--elevation3);
11
7
  -webkit-user-select: none;
12
8
  -moz-user-select: none;
13
9
  user-select: none;
10
+ background-color: var(--vkui--color_background_contrast);
11
+ border: var(--vkui--size_border--regular) solid var(--vkui--color_separator_primary_alpha);
12
+ border-radius: 50%;
13
+ box-shadow: var(--vkui--elevation3);
14
14
  transition: background-color 0.15s ease-out;
15
15
  }
16
16
 
@@ -32,14 +32,14 @@
32
32
  */
33
33
 
34
34
  .nativeInput {
35
- direction: ltr;
36
35
  position: absolute;
37
36
  inline-size: 100%;
38
37
  block-size: 100%;
39
- margin: -1px;
40
38
  padding: 0;
41
- border: 0 none;
42
- clip: rect(0, 0, 0, 0);
39
+ margin: -1px;
43
40
  overflow: hidden;
44
41
  white-space: nowrap;
42
+ border: 0 none;
43
+ clip: rect(0, 0, 0, 0);
44
+ direction: ltr;
45
45
  }
@@ -2,6 +2,7 @@
2
2
  import { jsx as _jsx } from "react/jsx-runtime";
3
3
  import * as React from "react";
4
4
  import { classNames } from "@vkontakte/vkjs";
5
+ import { useConfigDirection } from "../../hooks/useConfigDirection.js";
5
6
  import { useExternRef } from "../../hooks/useExternRef.js";
6
7
  import { useFocusWithin } from "../../hooks/useFocusWithin.js";
7
8
  import { useGlobalEscKeyDown } from "../../hooks/useGlobalEscKeyDown.js";
@@ -38,6 +39,8 @@ const animationStateClassNames = {
38
39
  const platform = usePlatform();
39
40
  const [open, setOpen] = React.useState(true);
40
41
  const [touched, setTouched] = React.useState(false);
42
+ const direction = useConfigDirection();
43
+ const isRtl = direction === 'rtl';
41
44
  const rootRef = useExternRef(getRootRef);
42
45
  const focused = useFocusWithin(rootRef);
43
46
  const inRef = React.useRef(null);
@@ -85,14 +88,14 @@ const animationStateClassNames = {
85
88
  if (shiftDataRef.current && panGestureRecognizer.current) {
86
89
  panGestureRecognizer.current.setInitialTimeOnce();
87
90
  panGestureRecognizer.current.setEndCoords(event.nativeEvent);
88
- shiftDataRef.current = getMovedShiftData(placement, shiftDataRef.current, panGestureRecognizer.current.delta());
91
+ shiftDataRef.current = getMovedShiftData(placement, shiftDataRef.current, panGestureRecognizer.current.delta(), isRtl);
89
92
  if (shiftDataRef.current.shifted) {
90
93
  updateShiftAxisCSSProperties(shiftDataRef.current.x, shiftDataRef.current.y, shiftDataRef.current.direction);
91
94
  }
92
95
  }
93
96
  };
94
97
  const handleTouchEnd = ()=>{
95
- if (touched && shiftDataRef.current && panGestureRecognizer.current && shouldBeClosedByShiftData(placement, shiftDataRef.current, getRelativeBoundingClientRect(rootRef.current, inRef.current), panGestureRecognizer.current.velocity())) {
98
+ if (touched && shiftDataRef.current && panGestureRecognizer.current && shouldBeClosedByShiftData(placement, shiftDataRef.current, getRelativeBoundingClientRect(rootRef.current, inRef.current), panGestureRecognizer.current.velocity(), isRtl)) {
96
99
  close();
97
100
  }
98
101
  setTouched(false);
@@ -138,7 +141,7 @@ const animationStateClassNames = {
138
141
  return /*#__PURE__*/ _jsx(RootComponent, {
139
142
  ...restProps,
140
143
  role: "presentation",
141
- baseClassName: classNames(styles.host, platform === 'ios' && styles.ios, touched && styles.touched, placementClassNames[placement], animationStateClassNames[animationState]),
144
+ baseClassName: classNames(styles.host, platform === 'ios' && styles.ios, touched && styles.touched, placementClassNames[placement], animationStateClassNames[animationState], isRtl && styles.rtl),
142
145
  baseStyle: resolveOffsetYCssStyle(placement, offsetY),
143
146
  getRootRef: rootRef,
144
147
  children: /*#__PURE__*/ _jsx("div", {