@vkontakte/vkui 6.1.2 → 6.2.1

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 (2068) hide show
  1. package/dist/cjs/components/Accordion/Accordion.js.map +1 -1
  2. package/dist/cjs/components/Accordion/AccordionContent.d.ts.map +1 -1
  3. package/dist/cjs/components/Accordion/AccordionContent.js +35 -39
  4. package/dist/cjs/components/Accordion/AccordionContent.js.map +1 -1
  5. package/dist/cjs/components/Accordion/AccordionContext.js.map +1 -1
  6. package/dist/cjs/components/Accordion/AccordionSummary.js.map +1 -1
  7. package/dist/cjs/components/ActionSheet/ActionSheet.d.ts +1 -1
  8. package/dist/cjs/components/ActionSheet/ActionSheet.d.ts.map +1 -1
  9. package/dist/cjs/components/ActionSheet/ActionSheet.js +24 -32
  10. package/dist/cjs/components/ActionSheet/ActionSheet.js.map +1 -1
  11. package/dist/cjs/components/ActionSheet/ActionSheetContext.js.map +1 -1
  12. package/dist/cjs/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -1
  13. package/dist/cjs/components/ActionSheet/ActionSheetDropdownMenu.d.ts +1 -1
  14. package/dist/cjs/components/ActionSheet/ActionSheetDropdownMenu.d.ts.map +1 -1
  15. package/dist/cjs/components/ActionSheet/ActionSheetDropdownMenu.js +7 -3
  16. package/dist/cjs/components/ActionSheet/ActionSheetDropdownMenu.js.map +1 -1
  17. package/dist/cjs/components/ActionSheet/ActionSheetDropdownSheet.js +1 -1
  18. package/dist/cjs/components/ActionSheet/ActionSheetDropdownSheet.js.map +1 -1
  19. package/dist/cjs/components/ActionSheet/types.js.map +1 -1
  20. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  21. package/dist/cjs/components/ActionSheetItem/subcomponents/Radio/Radio.js.map +1 -1
  22. package/dist/cjs/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -1
  23. package/dist/cjs/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  24. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  25. package/dist/cjs/components/Alert/Alert.d.ts.map +1 -1
  26. package/dist/cjs/components/Alert/Alert.js +22 -33
  27. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  28. package/dist/cjs/components/Alert/AlertAction.js.map +1 -1
  29. package/dist/cjs/components/Alert/AlertActions.js.map +1 -1
  30. package/dist/cjs/components/Alert/AlertTypography.js.map +1 -1
  31. package/dist/cjs/components/AppRoot/AppRoot.d.ts +14 -2
  32. package/dist/cjs/components/AppRoot/AppRoot.d.ts.map +1 -1
  33. package/dist/cjs/components/AppRoot/AppRoot.js +11 -3
  34. package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
  35. package/dist/cjs/components/AppRoot/AppRootContext.js.map +1 -1
  36. package/dist/cjs/components/AppRoot/AppRootPortal.js.map +1 -1
  37. package/dist/cjs/components/AppRoot/ScrollContext.d.ts.map +1 -1
  38. package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
  39. package/dist/cjs/components/AppRoot/helpers.d.ts +6 -1
  40. package/dist/cjs/components/AppRoot/helpers.d.ts.map +1 -1
  41. package/dist/cjs/components/AppRoot/helpers.js +24 -0
  42. package/dist/cjs/components/AppRoot/helpers.js.map +1 -1
  43. package/dist/cjs/components/AppRoot/types.d.ts +1 -0
  44. package/dist/cjs/components/AppRoot/types.d.ts.map +1 -1
  45. package/dist/cjs/components/AppRoot/types.js.map +1 -1
  46. package/dist/cjs/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  47. package/dist/cjs/components/AspectRatio/AspectRatio.js.map +1 -1
  48. package/dist/cjs/components/Avatar/Avatar.d.ts +2 -5
  49. package/dist/cjs/components/Avatar/Avatar.d.ts.map +1 -1
  50. package/dist/cjs/components/Avatar/Avatar.js.map +1 -1
  51. package/dist/cjs/components/Avatar/AvatarBadge/AvatarBadge.js.map +1 -1
  52. package/dist/cjs/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  53. package/dist/cjs/components/Avatar/AvatarBadge/icons.d.ts.map +1 -1
  54. package/dist/cjs/components/Avatar/AvatarBadge/icons.js.map +1 -1
  55. package/dist/cjs/components/Avatar/helpers.js.map +1 -1
  56. package/dist/cjs/components/Badge/Badge.js.map +1 -1
  57. package/dist/cjs/components/Banner/Banner.js.map +1 -1
  58. package/dist/cjs/components/BaseGallery/BaseGallery.js.map +1 -1
  59. package/dist/cjs/components/BaseGallery/CarouselBase/CarouselBase.js.map +1 -1
  60. package/dist/cjs/components/BaseGallery/CarouselBase/constants.js.map +1 -1
  61. package/dist/cjs/components/BaseGallery/CarouselBase/helpers.js.map +1 -1
  62. package/dist/cjs/components/BaseGallery/CarouselBase/hooks.js.map +1 -1
  63. package/dist/cjs/components/BaseGallery/CarouselBase/types.js.map +1 -1
  64. package/dist/cjs/components/BaseGallery/helpers.js.map +1 -1
  65. package/dist/cjs/components/BaseGallery/types.js.map +1 -1
  66. package/dist/cjs/components/Button/Button.js.map +1 -1
  67. package/dist/cjs/components/ButtonGroup/ButtonGroup.js.map +1 -1
  68. package/dist/cjs/components/Calendar/Calendar.d.ts.map +1 -1
  69. package/dist/cjs/components/Calendar/Calendar.js +4 -2
  70. package/dist/cjs/components/Calendar/Calendar.js.map +1 -1
  71. package/dist/cjs/components/CalendarDay/CalendarDay.js.map +1 -1
  72. package/dist/cjs/components/CalendarDays/CalendarDays.js.map +1 -1
  73. package/dist/cjs/components/CalendarHeader/CalendarHeader.d.ts +3 -1
  74. package/dist/cjs/components/CalendarHeader/CalendarHeader.d.ts.map +1 -1
  75. package/dist/cjs/components/CalendarHeader/CalendarHeader.js +23 -10
  76. package/dist/cjs/components/CalendarHeader/CalendarHeader.js.map +1 -1
  77. package/dist/cjs/components/CalendarRange/CalendarRange.d.ts.map +1 -1
  78. package/dist/cjs/components/CalendarRange/CalendarRange.js +11 -4
  79. package/dist/cjs/components/CalendarRange/CalendarRange.js.map +1 -1
  80. package/dist/cjs/components/CalendarTime/CalendarTime.js.map +1 -1
  81. package/dist/cjs/components/Card/Card.js.map +1 -1
  82. package/dist/cjs/components/CardGrid/CardGrid.js.map +1 -1
  83. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  84. package/dist/cjs/components/Cell/Cell.js.map +1 -1
  85. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  86. package/dist/cjs/components/Cell/CellDragger/CellDragger.js.map +1 -1
  87. package/dist/cjs/components/Cell/constants.js.map +1 -1
  88. package/dist/cjs/components/CellButton/CellButton.js.map +1 -1
  89. package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
  90. package/dist/cjs/components/ChipsInput/ChipsInput.d.ts.map +1 -1
  91. package/dist/cjs/components/ChipsInput/ChipsInput.js.map +1 -1
  92. package/dist/cjs/components/ChipsInput/useChipsInput.d.ts.map +1 -1
  93. package/dist/cjs/components/ChipsInput/useChipsInput.js.map +1 -1
  94. package/dist/cjs/components/ChipsInputBase/Chip/Chip.js.map +1 -1
  95. package/dist/cjs/components/ChipsInputBase/ChipsInputBase.d.ts.map +1 -1
  96. package/dist/cjs/components/ChipsInputBase/ChipsInputBase.js +2 -2
  97. package/dist/cjs/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
  98. package/dist/cjs/components/ChipsInputBase/constants.js +2 -3
  99. package/dist/cjs/components/ChipsInputBase/constants.js.map +1 -1
  100. package/dist/cjs/components/ChipsInputBase/helpers.d.ts.map +1 -1
  101. package/dist/cjs/components/ChipsInputBase/helpers.js.map +1 -1
  102. package/dist/cjs/components/ChipsInputBase/types.js.map +1 -1
  103. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts +5 -1
  104. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts.map +1 -1
  105. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +15 -8
  106. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  107. package/dist/cjs/components/ChipsSelect/constants.d.ts.map +1 -1
  108. package/dist/cjs/components/ChipsSelect/constants.js.map +1 -1
  109. package/dist/cjs/components/ChipsSelect/types.js.map +1 -1
  110. package/dist/cjs/components/ChipsSelect/useChipsSelect.d.ts +10 -2
  111. package/dist/cjs/components/ChipsSelect/useChipsSelect.d.ts.map +1 -1
  112. package/dist/cjs/components/ChipsSelect/useChipsSelect.js +12 -4
  113. package/dist/cjs/components/ChipsSelect/useChipsSelect.js.map +1 -1
  114. package/dist/cjs/components/Clickable/Clickable.d.ts.map +1 -1
  115. package/dist/cjs/components/Clickable/Clickable.js.map +1 -1
  116. package/dist/cjs/components/Clickable/useKeyboard.d.ts.map +1 -1
  117. package/dist/cjs/components/Clickable/useKeyboard.js.map +1 -1
  118. package/dist/cjs/components/Clickable/useState.d.ts.map +1 -1
  119. package/dist/cjs/components/Clickable/useState.js.map +1 -1
  120. package/dist/cjs/components/Clickable/useStateWithDelay.js.map +1 -1
  121. package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
  122. package/dist/cjs/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  123. package/dist/cjs/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  124. package/dist/cjs/components/ContentBadge/ContentBadge.js.map +1 -1
  125. package/dist/cjs/components/ContentBadge/ContentBadgeContext.js.map +1 -1
  126. package/dist/cjs/components/ContentBadge/ContentBadgeSlotIcon.js.map +1 -1
  127. package/dist/cjs/components/ContentBadge/types.js.map +1 -1
  128. package/dist/cjs/components/ContentCard/ContentCard.js.map +1 -1
  129. package/dist/cjs/components/Counter/Counter.js.map +1 -1
  130. package/dist/cjs/components/CustomScrollView/CustomScrollView.js.map +1 -1
  131. package/dist/cjs/components/CustomScrollView/useTrackerVisibility.d.ts.map +1 -1
  132. package/dist/cjs/components/CustomScrollView/useTrackerVisibility.js +31 -37
  133. package/dist/cjs/components/CustomScrollView/useTrackerVisibility.js.map +1 -1
  134. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +5 -2
  135. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts.map +1 -1
  136. package/dist/cjs/components/CustomSelect/CustomSelect.js +4 -5
  137. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  138. package/dist/cjs/components/CustomSelect/CustomSelectClearButton.js.map +1 -1
  139. package/dist/cjs/components/CustomSelect/CustomSelectInput.js.map +1 -1
  140. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  141. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  142. package/dist/cjs/components/DateInput/DateInput.js.map +1 -1
  143. package/dist/cjs/components/DatePicker/DatePicker.d.ts +6 -0
  144. package/dist/cjs/components/DatePicker/DatePicker.d.ts.map +1 -1
  145. package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
  146. package/dist/cjs/components/DateRangeInput/DateRangeInput.js.map +1 -1
  147. package/dist/cjs/components/Div/Div.js.map +1 -1
  148. package/dist/cjs/components/DropZone/DropZone.js.map +1 -1
  149. package/dist/cjs/components/DropZone/components/DropZoneGrid.js.map +1 -1
  150. package/dist/cjs/components/DropdownIcon/DropdownIcon.js.map +1 -1
  151. package/dist/cjs/components/Epic/Epic.js.map +1 -1
  152. package/dist/cjs/components/Epic/ScrollSaver.js.map +1 -1
  153. package/dist/cjs/components/File/File.js.map +1 -1
  154. package/dist/cjs/components/FixedLayout/FixedLayout.d.ts.map +1 -1
  155. package/dist/cjs/components/FixedLayout/FixedLayout.js +18 -6
  156. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  157. package/dist/cjs/components/Flex/Flex.d.ts +42 -0
  158. package/dist/cjs/components/Flex/Flex.d.ts.map +1 -0
  159. package/dist/cjs/components/Flex/Flex.js +60 -0
  160. package/dist/cjs/components/Flex/Flex.js.map +1 -0
  161. package/dist/cjs/components/Flex/FlexItem/FlexItem.d.ts +20 -0
  162. package/dist/cjs/components/Flex/FlexItem/FlexItem.d.ts.map +1 -0
  163. package/dist/cjs/components/Flex/FlexItem/FlexItem.js +47 -0
  164. package/dist/cjs/components/Flex/FlexItem/FlexItem.js.map +1 -0
  165. package/dist/cjs/components/FloatingArrow/DefaultIcon.d.ts.map +1 -1
  166. package/dist/cjs/components/FloatingArrow/DefaultIcon.js.map +1 -1
  167. package/dist/cjs/components/FloatingArrow/FloatingArrow.js +14 -4
  168. package/dist/cjs/components/FloatingArrow/FloatingArrow.js.map +1 -1
  169. package/dist/cjs/components/FocusTrap/FocusTrap.d.ts +6 -1
  170. package/dist/cjs/components/FocusTrap/FocusTrap.d.ts.map +1 -1
  171. package/dist/cjs/components/FocusTrap/FocusTrap.js +44 -19
  172. package/dist/cjs/components/FocusTrap/FocusTrap.js.map +1 -1
  173. package/dist/cjs/components/Footer/Footer.js.map +1 -1
  174. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  175. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  176. package/dist/cjs/components/FormItem/FormItemTop/FormItemTop.js.map +1 -1
  177. package/dist/cjs/components/FormItem/FormItemTop/FormItemTopAside.js.map +1 -1
  178. package/dist/cjs/components/FormItem/FormItemTop/FormItemTopLabel.js.map +1 -1
  179. package/dist/cjs/components/FormItem/context.js.map +1 -1
  180. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  181. package/dist/cjs/components/FormStatus/FormStatus.js.map +1 -1
  182. package/dist/cjs/components/Gallery/Gallery.js.map +1 -1
  183. package/dist/cjs/components/Gallery/hooks.d.ts +1 -1
  184. package/dist/cjs/components/Gallery/hooks.d.ts.map +1 -1
  185. package/dist/cjs/components/Gallery/hooks.js +24 -21
  186. package/dist/cjs/components/Gallery/hooks.js.map +1 -1
  187. package/dist/cjs/components/Gradient/Gradient.js.map +1 -1
  188. package/dist/cjs/components/GridAvatar/GridAvatar.d.ts +1 -1
  189. package/dist/cjs/components/GridAvatar/GridAvatar.js +1 -1
  190. package/dist/cjs/components/GridAvatar/GridAvatar.js.map +1 -1
  191. package/dist/cjs/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.js.map +1 -1
  192. package/dist/cjs/components/Group/Group.js.map +1 -1
  193. package/dist/cjs/components/Header/Header.js.map +1 -1
  194. package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
  195. package/dist/cjs/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.js.map +1 -1
  196. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  197. package/dist/cjs/components/IconButton/IconButton.js.map +1 -1
  198. package/dist/cjs/components/Image/Image.d.ts +3 -5
  199. package/dist/cjs/components/Image/Image.d.ts.map +1 -1
  200. package/dist/cjs/components/Image/Image.js.map +1 -1
  201. package/dist/cjs/components/Image/ImageBadge/ImageBadge.js.map +1 -1
  202. package/dist/cjs/components/ImageBase/ImageBase.d.ts +1 -4
  203. package/dist/cjs/components/ImageBase/ImageBase.d.ts.map +1 -1
  204. package/dist/cjs/components/ImageBase/ImageBase.js.map +1 -1
  205. package/dist/cjs/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
  206. package/dist/cjs/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.d.ts +4 -38
  207. package/dist/cjs/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.d.ts.map +1 -1
  208. package/dist/cjs/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js +60 -19
  209. package/dist/cjs/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  210. package/dist/cjs/components/ImageBase/ImageBaseOverlay/hooks.d.ts +6 -0
  211. package/dist/cjs/components/ImageBase/ImageBaseOverlay/hooks.d.ts.map +1 -0
  212. package/dist/cjs/components/ImageBase/ImageBaseOverlay/hooks.js +37 -0
  213. package/dist/cjs/components/ImageBase/ImageBaseOverlay/hooks.js.map +1 -0
  214. package/dist/cjs/components/ImageBase/ImageBaseOverlay/types.d.ts +54 -0
  215. package/dist/cjs/components/ImageBase/ImageBaseOverlay/types.d.ts.map +1 -0
  216. package/dist/cjs/components/ImageBase/ImageBaseOverlay/types.js +8 -0
  217. package/dist/cjs/components/ImageBase/ImageBaseOverlay/types.js.map +1 -0
  218. package/dist/cjs/components/ImageBase/context.js.map +1 -1
  219. package/dist/cjs/components/ImageBase/helpers.js.map +1 -1
  220. package/dist/cjs/components/ImageBase/types.js.map +1 -1
  221. package/dist/cjs/components/ImageBase/validators.js.map +1 -1
  222. package/dist/cjs/components/InfoRow/InfoRow.js.map +1 -1
  223. package/dist/cjs/components/Input/Input.js.map +1 -1
  224. package/dist/cjs/components/InputLike/InputLike.js.map +1 -1
  225. package/dist/cjs/components/InputLike/InputLikeDivider.d.ts.map +1 -1
  226. package/dist/cjs/components/InputLike/InputLikeDivider.js.map +1 -1
  227. package/dist/cjs/components/Link/Link.d.ts.map +1 -1
  228. package/dist/cjs/components/Link/Link.js +1 -0
  229. package/dist/cjs/components/Link/Link.js.map +1 -1
  230. package/dist/cjs/components/List/List.js.map +1 -1
  231. package/dist/cjs/components/LocaleProvider/LocaleProvider.js.map +1 -1
  232. package/dist/cjs/components/Mark/Mark.js.map +1 -1
  233. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  234. package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
  235. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  236. package/dist/cjs/components/ModalCardBase/ModalCardBaseCloseButton.js.map +1 -1
  237. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  238. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  239. package/dist/cjs/components/ModalPage/ModalPageContext.js.map +1 -1
  240. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  241. package/dist/cjs/components/ModalRoot/ModalRoot.d.ts.map +1 -1
  242. package/dist/cjs/components/ModalRoot/ModalRoot.js +6 -9
  243. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  244. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  245. package/dist/cjs/components/ModalRoot/ModalRootContext.js.map +1 -1
  246. package/dist/cjs/components/ModalRoot/ModalRootDesktop.d.ts.map +1 -1
  247. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +2 -1
  248. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  249. package/dist/cjs/components/ModalRoot/constants.js.map +1 -1
  250. package/dist/cjs/components/ModalRoot/types.d.ts +0 -1
  251. package/dist/cjs/components/ModalRoot/types.d.ts.map +1 -1
  252. package/dist/cjs/components/ModalRoot/types.js.map +1 -1
  253. package/dist/cjs/components/ModalRoot/useModalManager.d.ts.map +1 -1
  254. package/dist/cjs/components/ModalRoot/useModalManager.js.map +1 -1
  255. package/dist/cjs/components/ModalRoot/useModalRootContext.js.map +1 -1
  256. package/dist/cjs/components/ModalRoot/withModalRootContext.js.map +1 -1
  257. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  258. package/dist/cjs/components/NavIdContext/NavIdContext.js.map +1 -1
  259. package/dist/cjs/components/NavIdContext/useNavId.js.map +1 -1
  260. package/dist/cjs/components/NavTransitionContext/NavTransitionContext.d.ts.map +1 -1
  261. package/dist/cjs/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  262. package/dist/cjs/components/NavTransitionDirectionContext/NavTransitionDirectionContext.d.ts.map +1 -1
  263. package/dist/cjs/components/NavTransitionDirectionContext/NavTransitionDirectionContext.js.map +1 -1
  264. package/dist/cjs/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  265. package/dist/cjs/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts +1 -1
  266. package/dist/cjs/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts.map +1 -1
  267. package/dist/cjs/components/OnboardingTooltip/OnboardingTooltipContainer.js.map +1 -1
  268. package/dist/cjs/components/Pagination/Pagination.js.map +1 -1
  269. package/dist/cjs/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.d.ts.map +1 -1
  270. package/dist/cjs/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.js.map +1 -1
  271. package/dist/cjs/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -1
  272. package/dist/cjs/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -1
  273. package/dist/cjs/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -1
  274. package/dist/cjs/components/Pagination/utils.js.map +1 -1
  275. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  276. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  277. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  278. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  279. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  280. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  281. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.d.ts +2 -2
  282. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.d.ts.map +1 -1
  283. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js +27 -37
  284. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  285. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  286. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  287. package/dist/cjs/components/PanelSpinner/PanelSpinner.js.map +1 -1
  288. package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
  289. package/dist/cjs/components/PlatformProvider/PlatformProvider.js.map +1 -1
  290. package/dist/cjs/components/PopoutRoot/PopoutRoot.d.ts.map +1 -1
  291. package/dist/cjs/components/PopoutRoot/PopoutRoot.js +0 -8
  292. package/dist/cjs/components/PopoutRoot/PopoutRoot.js.map +1 -1
  293. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.d.ts.map +1 -1
  294. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js +1 -20
  295. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  296. package/dist/cjs/components/Popover/Popover.d.ts +6 -2
  297. package/dist/cjs/components/Popover/Popover.d.ts.map +1 -1
  298. package/dist/cjs/components/Popover/Popover.js +14 -6
  299. package/dist/cjs/components/Popover/Popover.js.map +1 -1
  300. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  301. package/dist/cjs/components/Progress/Progress.js.map +1 -1
  302. package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
  303. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  304. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  305. package/dist/cjs/components/RadioGroup/RadioGroup.js.map +1 -1
  306. package/dist/cjs/components/Removable/Removable.js.map +1 -1
  307. package/dist/cjs/components/RichCell/RichCell.js.map +1 -1
  308. package/dist/cjs/components/RichCell/RichCellIcon/RichCellIcon.js.map +1 -1
  309. package/dist/cjs/components/Root/Root.d.ts.map +1 -1
  310. package/dist/cjs/components/Root/Root.js +8 -18
  311. package/dist/cjs/components/Root/Root.js.map +1 -1
  312. package/dist/cjs/components/RootComponent/RootComponent.d.ts.map +1 -1
  313. package/dist/cjs/components/RootComponent/RootComponent.js.map +1 -1
  314. package/dist/cjs/components/ScreenSpinner/Icon48CancelCircle.d.ts.map +1 -1
  315. package/dist/cjs/components/ScreenSpinner/Icon48CancelCircle.js.map +1 -1
  316. package/dist/cjs/components/ScreenSpinner/Icon48DoneOutline.d.ts.map +1 -1
  317. package/dist/cjs/components/ScreenSpinner/Icon48DoneOutline.js.map +1 -1
  318. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  319. package/dist/cjs/components/ScrollArrow/ScrollArrow.js.map +1 -1
  320. package/dist/cjs/components/Search/Search.js.map +1 -1
  321. package/dist/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
  322. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  323. package/dist/cjs/components/Select/Select.d.ts.map +1 -1
  324. package/dist/cjs/components/Select/Select.js.map +1 -1
  325. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  326. package/dist/cjs/components/SelectTypography/SelectTypography.js.map +1 -1
  327. package/dist/cjs/components/Separator/Separator.js.map +1 -1
  328. package/dist/cjs/components/SimpleCell/Chevron/Chevron.js.map +1 -1
  329. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  330. package/dist/cjs/components/Skeleton/Skeleton.js.map +1 -1
  331. package/dist/cjs/components/Slider/Slider.d.ts.map +1 -1
  332. package/dist/cjs/components/Slider/Slider.js +7 -2
  333. package/dist/cjs/components/Slider/Slider.js.map +1 -1
  334. package/dist/cjs/components/Slider/SliderThumb/SliderThumb.d.ts +2 -1
  335. package/dist/cjs/components/Slider/SliderThumb/SliderThumb.d.ts.map +1 -1
  336. package/dist/cjs/components/Slider/SliderThumb/SliderThumb.js +6 -5
  337. package/dist/cjs/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
  338. package/dist/cjs/components/Slider/helpers.d.ts.map +1 -1
  339. package/dist/cjs/components/Slider/helpers.js.map +1 -1
  340. package/dist/cjs/components/Slider/types.js.map +1 -1
  341. package/dist/cjs/components/Snackbar/Snackbar.d.ts +1 -1
  342. package/dist/cjs/components/Snackbar/Snackbar.d.ts.map +1 -1
  343. package/dist/cjs/components/Snackbar/Snackbar.js +11 -10
  344. package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
  345. package/dist/cjs/components/Snackbar/subcomponents/Basic/Basic.js.map +1 -1
  346. package/dist/cjs/components/Snackbar/types.js.map +1 -1
  347. package/dist/cjs/components/Snackbar/utils.d.ts +0 -1
  348. package/dist/cjs/components/Snackbar/utils.d.ts.map +1 -1
  349. package/dist/cjs/components/Snackbar/utils.js.map +1 -1
  350. package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
  351. package/dist/cjs/components/Spinner/Spinner.d.ts.map +1 -1
  352. package/dist/cjs/components/Spinner/Spinner.js +37 -18
  353. package/dist/cjs/components/Spinner/Spinner.js.map +1 -1
  354. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  355. package/dist/cjs/components/SplitCol/SplitColContext.js.map +1 -1
  356. package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
  357. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  358. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  359. package/dist/cjs/components/Switch/Switch.d.ts +1 -1
  360. package/dist/cjs/components/Switch/Switch.d.ts.map +1 -1
  361. package/dist/cjs/components/Switch/Switch.js +41 -19
  362. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  363. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  364. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  365. package/dist/cjs/components/Tabs/Tabs.js.map +1 -1
  366. package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
  367. package/dist/cjs/components/Tappable/Ripple.d.ts.map +1 -1
  368. package/dist/cjs/components/Tappable/Ripple.js +10 -3
  369. package/dist/cjs/components/Tappable/Ripple.js.map +1 -1
  370. package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
  371. package/dist/cjs/components/Tappable/state.js.map +1 -1
  372. package/dist/cjs/components/Textarea/Textarea.d.ts.map +1 -1
  373. package/dist/cjs/components/Textarea/Textarea.js +7 -19
  374. package/dist/cjs/components/Textarea/Textarea.js.map +1 -1
  375. package/dist/cjs/components/Textarea/useResizeTextarea.d.ts +3 -0
  376. package/dist/cjs/components/Textarea/useResizeTextarea.d.ts.map +1 -0
  377. package/dist/cjs/components/Textarea/useResizeTextarea.js +45 -0
  378. package/dist/cjs/components/Textarea/useResizeTextarea.js.map +1 -0
  379. package/dist/cjs/components/ToolButton/ToolButton.js.map +1 -1
  380. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  381. package/dist/cjs/components/TooltipBase/TooltipBase.js.map +1 -1
  382. package/dist/cjs/components/Touch/Touch.js.map +1 -1
  383. package/dist/cjs/components/Touch/TouchContext.js.map +1 -1
  384. package/dist/cjs/components/Typography/Caption/Caption.d.ts +1 -1
  385. package/dist/cjs/components/Typography/Caption/Caption.d.ts.map +1 -1
  386. package/dist/cjs/components/Typography/Caption/Caption.js +4 -2
  387. package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
  388. package/dist/cjs/components/Typography/DisplayTitle/DisplayTitle.d.ts +11 -0
  389. package/dist/cjs/components/Typography/DisplayTitle/DisplayTitle.d.ts.map +1 -0
  390. package/dist/cjs/components/Typography/DisplayTitle/DisplayTitle.js +38 -0
  391. package/dist/cjs/components/Typography/DisplayTitle/DisplayTitle.js.map +1 -0
  392. package/dist/cjs/components/Typography/EllipsisText/EllipsisText.js.map +1 -1
  393. package/dist/cjs/components/Typography/Footnote/Footnote.d.ts +1 -1
  394. package/dist/cjs/components/Typography/Footnote/Footnote.d.ts.map +1 -1
  395. package/dist/cjs/components/Typography/Footnote/Footnote.js +4 -2
  396. package/dist/cjs/components/Typography/Footnote/Footnote.js.map +1 -1
  397. package/dist/cjs/components/Typography/Headline/Headline.d.ts +1 -1
  398. package/dist/cjs/components/Typography/Headline/Headline.d.ts.map +1 -1
  399. package/dist/cjs/components/Typography/Headline/Headline.js +4 -2
  400. package/dist/cjs/components/Typography/Headline/Headline.js.map +1 -1
  401. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts +1 -1
  402. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts.map +1 -1
  403. package/dist/cjs/components/Typography/Paragraph/Paragraph.js +4 -2
  404. package/dist/cjs/components/Typography/Paragraph/Paragraph.js.map +1 -1
  405. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts +1 -1
  406. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts.map +1 -1
  407. package/dist/cjs/components/Typography/Subhead/Subhead.js +4 -2
  408. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  409. package/dist/cjs/components/Typography/Text/Text.d.ts +1 -1
  410. package/dist/cjs/components/Typography/Text/Text.d.ts.map +1 -1
  411. package/dist/cjs/components/Typography/Text/Text.js +4 -2
  412. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  413. package/dist/cjs/components/Typography/Title/Title.d.ts +1 -1
  414. package/dist/cjs/components/Typography/Title/Title.d.ts.map +1 -1
  415. package/dist/cjs/components/Typography/Title/Title.js +4 -2
  416. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  417. package/dist/cjs/components/Typography/Typography.d.ts +5 -1
  418. package/dist/cjs/components/Typography/Typography.d.ts.map +1 -1
  419. package/dist/cjs/components/Typography/Typography.js +4 -3
  420. package/dist/cjs/components/Typography/Typography.js.map +1 -1
  421. package/dist/cjs/components/UnstyledTextField/UnstyledTextField.js.map +1 -1
  422. package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
  423. package/dist/cjs/components/View/View.d.ts.map +1 -1
  424. package/dist/cjs/components/View/View.js +36 -50
  425. package/dist/cjs/components/View/View.js.map +1 -1
  426. package/dist/cjs/components/View/ViewInfinite.d.ts.map +1 -1
  427. package/dist/cjs/components/View/ViewInfinite.js +16 -18
  428. package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
  429. package/dist/cjs/components/View/utils.js.map +1 -1
  430. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.d.ts.map +1 -1
  431. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.js.map +1 -1
  432. package/dist/cjs/components/WriteBar/WriteBar.d.ts.map +1 -1
  433. package/dist/cjs/components/WriteBar/WriteBar.js +3 -19
  434. package/dist/cjs/components/WriteBar/WriteBar.js.map +1 -1
  435. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  436. package/dist/cjs/helpers/avatar.js.map +1 -1
  437. package/dist/cjs/helpers/getMergedSameEventsByProps.d.ts +1 -1
  438. package/dist/cjs/helpers/getMergedSameEventsByProps.d.ts.map +1 -1
  439. package/dist/cjs/helpers/getMergedSameEventsByProps.js.map +1 -1
  440. package/dist/cjs/helpers/getOrDefault.js.map +1 -1
  441. package/dist/cjs/helpers/math.js.map +1 -1
  442. package/dist/cjs/helpers/range.js.map +1 -1
  443. package/dist/cjs/hoc/withContext.js.map +1 -1
  444. package/dist/cjs/hoc/withPlatform.js.map +1 -1
  445. package/dist/cjs/hooks/useAdaptivity.js.map +1 -1
  446. package/dist/cjs/hooks/useAdaptivityConditionalRender/constants.js.map +1 -1
  447. package/dist/cjs/hooks/useAdaptivityConditionalRender/helpers.d.ts +3 -3
  448. package/dist/cjs/hooks/useAdaptivityConditionalRender/helpers.d.ts.map +1 -1
  449. package/dist/cjs/hooks/useAdaptivityConditionalRender/helpers.js.map +1 -1
  450. package/dist/cjs/hooks/useAdaptivityConditionalRender/index.js.map +1 -1
  451. package/dist/cjs/hooks/useAdaptivityConditionalRender/types.js.map +1 -1
  452. package/dist/cjs/hooks/useAdaptivityConditionalRender/useAdaptivityConditionalRender.js.map +1 -1
  453. package/dist/cjs/hooks/useAdaptivityHasPointer.js.map +1 -1
  454. package/dist/cjs/hooks/useAdaptivityWithJSMediaQueries.js.map +1 -1
  455. package/dist/cjs/hooks/useAppearance.js.map +1 -1
  456. package/dist/cjs/hooks/useAutoDetectAppearance.js.map +1 -1
  457. package/dist/cjs/hooks/useAutoFocus.js.map +1 -1
  458. package/dist/cjs/hooks/useBooleanState.js.map +1 -1
  459. package/dist/cjs/hooks/useCalendar.d.ts +2 -0
  460. package/dist/cjs/hooks/useCalendar.d.ts.map +1 -1
  461. package/dist/cjs/hooks/useCalendar.js +43 -1
  462. package/dist/cjs/hooks/useCalendar.js.map +1 -1
  463. package/dist/cjs/hooks/useDateInput.d.ts.map +1 -1
  464. package/dist/cjs/hooks/useDateInput.js.map +1 -1
  465. package/dist/cjs/hooks/useDirection.js.map +1 -1
  466. package/dist/cjs/hooks/useDraggableWithDomApi/autoScroll.js.map +1 -1
  467. package/dist/cjs/hooks/useDraggableWithDomApi/constants.js.map +1 -1
  468. package/dist/cjs/hooks/useDraggableWithDomApi/index.js.map +1 -1
  469. package/dist/cjs/hooks/useDraggableWithDomApi/types.js.map +1 -1
  470. package/dist/cjs/hooks/useDraggableWithDomApi/useDraggableWithDomApi.d.ts.map +1 -1
  471. package/dist/cjs/hooks/useDraggableWithDomApi/useDraggableWithDomApi.js.map +1 -1
  472. package/dist/cjs/hooks/useDraggableWithDomApi/utils.d.ts +2 -2
  473. package/dist/cjs/hooks/useDraggableWithDomApi/utils.d.ts.map +1 -1
  474. package/dist/cjs/hooks/useDraggableWithDomApi/utils.js.map +1 -1
  475. package/dist/cjs/hooks/useEffectDev.js.map +1 -1
  476. package/dist/cjs/hooks/useEnsuredControl.js +1 -1
  477. package/dist/cjs/hooks/useEnsuredControl.js.map +1 -1
  478. package/dist/cjs/hooks/useEventListener.js.map +1 -1
  479. package/dist/cjs/hooks/useExternRef.js.map +1 -1
  480. package/dist/cjs/hooks/useFocusVisible.d.ts.map +1 -1
  481. package/dist/cjs/hooks/useFocusVisible.js.map +1 -1
  482. package/dist/cjs/hooks/useFocusVisibleClassName.js.map +1 -1
  483. package/dist/cjs/hooks/useFocusWithin.js.map +1 -1
  484. package/dist/cjs/hooks/useGlobalEscKeyDown.js.map +1 -1
  485. package/dist/cjs/hooks/useGlobalEventListener.js.map +1 -1
  486. package/dist/cjs/hooks/useGlobalOnClickOutside.d.ts +1 -1
  487. package/dist/cjs/hooks/useGlobalOnClickOutside.d.ts.map +1 -1
  488. package/dist/cjs/hooks/useGlobalOnClickOutside.js.map +1 -1
  489. package/dist/cjs/hooks/useIsClient.js.map +1 -1
  490. package/dist/cjs/hooks/useKeyboard.js.map +1 -1
  491. package/dist/cjs/hooks/useKeyboardInputTracker.js.map +1 -1
  492. package/dist/cjs/hooks/useMediaQueries.d.ts.map +1 -1
  493. package/dist/cjs/hooks/useMediaQueries.js +21 -18
  494. package/dist/cjs/hooks/useMediaQueries.js.map +1 -1
  495. package/dist/cjs/hooks/useNativeFormResetListener.d.ts.map +1 -1
  496. package/dist/cjs/hooks/useNativeFormResetListener.js.map +1 -1
  497. package/dist/cjs/hooks/useObjectMemo.js.map +1 -1
  498. package/dist/cjs/hooks/useOrientationChange.js.map +1 -1
  499. package/dist/cjs/hooks/usePagination.d.ts.map +1 -1
  500. package/dist/cjs/hooks/usePagination.js.map +1 -1
  501. package/dist/cjs/hooks/usePatchChildren.d.ts.map +1 -1
  502. package/dist/cjs/hooks/usePatchChildren.js.map +1 -1
  503. package/dist/cjs/hooks/usePlatform.js.map +1 -1
  504. package/dist/cjs/hooks/usePrevious.js.map +1 -1
  505. package/dist/cjs/hooks/useResizeObserver.d.ts +1 -1
  506. package/dist/cjs/hooks/useResizeObserver.d.ts.map +1 -1
  507. package/dist/cjs/hooks/useResizeObserver.js +4 -4
  508. package/dist/cjs/hooks/useResizeObserver.js.map +1 -1
  509. package/dist/cjs/hooks/useStableCallback.js.map +1 -1
  510. package/dist/cjs/hooks/useTodayDate.js.map +1 -1
  511. package/dist/cjs/hooks/useWaitTransitionFinish.d.ts +1 -3
  512. package/dist/cjs/hooks/useWaitTransitionFinish.d.ts.map +1 -1
  513. package/dist/cjs/hooks/useWaitTransitionFinish.js +4 -9
  514. package/dist/cjs/hooks/useWaitTransitionFinish.js.map +1 -1
  515. package/dist/cjs/index.d.ts +7 -1
  516. package/dist/cjs/index.d.ts.map +1 -1
  517. package/dist/cjs/index.js +8 -0
  518. package/dist/cjs/index.js.map +1 -1
  519. package/dist/cjs/lib/SSR.js.map +1 -1
  520. package/dist/cjs/lib/accessibility.d.ts +1 -1
  521. package/dist/cjs/lib/accessibility.d.ts.map +1 -1
  522. package/dist/cjs/lib/accessibility.js +1 -0
  523. package/dist/cjs/lib/accessibility.js.map +1 -1
  524. package/dist/cjs/lib/adaptivity/constants.js.map +1 -1
  525. package/dist/cjs/lib/adaptivity/functions.js.map +1 -1
  526. package/dist/cjs/lib/adaptivity/index.js.map +1 -1
  527. package/dist/cjs/lib/adaptivity/types.js.map +1 -1
  528. package/dist/cjs/lib/animate.js.map +1 -1
  529. package/dist/cjs/lib/animation/fades.js.map +1 -1
  530. package/dist/cjs/lib/animation/index.d.ts +1 -0
  531. package/dist/cjs/lib/animation/index.d.ts.map +1 -1
  532. package/dist/cjs/lib/animation/index.js +7 -0
  533. package/dist/cjs/lib/animation/index.js.map +1 -1
  534. package/dist/cjs/lib/animation/rubberbandIfOutOfBounds.js.map +1 -1
  535. package/dist/cjs/lib/animation/transformOrigin.js.map +1 -1
  536. package/dist/cjs/lib/animation/useCSSKeyframesAnimationController.d.ts +1 -1
  537. package/dist/cjs/lib/animation/useCSSKeyframesAnimationController.d.ts.map +1 -1
  538. package/dist/cjs/lib/animation/useCSSKeyframesAnimationController.js +5 -6
  539. package/dist/cjs/lib/animation/useCSSKeyframesAnimationController.js.map +1 -1
  540. package/dist/cjs/lib/animation/useReducedMotion.js.map +1 -1
  541. package/dist/cjs/lib/appearance/index.js.map +1 -1
  542. package/dist/cjs/lib/appearance/types.js.map +1 -1
  543. package/dist/cjs/lib/browser.js.map +1 -1
  544. package/dist/cjs/lib/calendar.js.map +1 -1
  545. package/dist/cjs/lib/callMultiple.js.map +1 -1
  546. package/dist/cjs/lib/children.d.ts.map +1 -1
  547. package/dist/cjs/lib/children.js.map +1 -1
  548. package/dist/cjs/lib/comparing.js.map +1 -1
  549. package/dist/cjs/lib/createPortal.d.ts.map +1 -1
  550. package/dist/cjs/lib/createPortal.js.map +1 -1
  551. package/dist/cjs/lib/date.js.map +1 -1
  552. package/dist/cjs/lib/dom.d.ts +0 -1
  553. package/dist/cjs/lib/dom.d.ts.map +1 -1
  554. package/dist/cjs/lib/dom.js.map +1 -1
  555. package/dist/cjs/lib/floating/adapters.js.map +1 -1
  556. package/dist/cjs/lib/floating/customResizeObserver.js.map +1 -1
  557. package/dist/cjs/lib/floating/functions.d.ts +1 -1
  558. package/dist/cjs/lib/floating/functions.js.map +1 -1
  559. package/dist/cjs/lib/floating/index.js.map +1 -1
  560. package/dist/cjs/lib/floating/types/common.js.map +1 -1
  561. package/dist/cjs/lib/floating/types/component.js.map +1 -1
  562. package/dist/cjs/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts +1 -11
  563. package/dist/cjs/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts.map +1 -1
  564. package/dist/cjs/lib/floating/useFloatingMiddlewaresBootstrap/index.js.map +1 -1
  565. package/dist/cjs/lib/floating/useFloatingWithInteractions/constants.js.map +1 -1
  566. package/dist/cjs/lib/floating/useFloatingWithInteractions/index.js.map +1 -1
  567. package/dist/cjs/lib/floating/useFloatingWithInteractions/types.d.ts +0 -1
  568. package/dist/cjs/lib/floating/useFloatingWithInteractions/types.d.ts.map +1 -1
  569. package/dist/cjs/lib/floating/useFloatingWithInteractions/types.js.map +1 -1
  570. package/dist/cjs/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.d.ts.map +1 -1
  571. package/dist/cjs/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
  572. package/dist/cjs/lib/floating/useFloatingWithInteractions/useResolveTriggerType.js.map +1 -1
  573. package/dist/cjs/lib/floating/usePlacementChangeCallback.js.map +1 -1
  574. package/dist/cjs/lib/fx.js.map +1 -1
  575. package/dist/cjs/lib/getNavId.js.map +1 -1
  576. package/dist/cjs/lib/isRefObject.d.ts.map +1 -1
  577. package/dist/cjs/lib/isRefObject.js.map +1 -1
  578. package/dist/cjs/lib/layouts/gaps.d.ts +32 -0
  579. package/dist/cjs/lib/layouts/gaps.d.ts.map +1 -0
  580. package/dist/cjs/lib/layouts/gaps.js +60 -0
  581. package/dist/cjs/lib/layouts/gaps.js.map +1 -0
  582. package/dist/cjs/lib/layouts/index.d.ts +2 -0
  583. package/dist/cjs/lib/layouts/index.d.ts.map +1 -0
  584. package/dist/cjs/lib/layouts/index.js +24 -0
  585. package/dist/cjs/lib/layouts/index.js.map +1 -0
  586. package/dist/cjs/lib/matchMedia.js.map +1 -1
  587. package/dist/cjs/lib/mergeCalls.js.map +1 -1
  588. package/dist/cjs/lib/offset.js.map +1 -1
  589. package/dist/cjs/lib/platform.js.map +1 -1
  590. package/dist/cjs/lib/rafSchd.d.ts.map +1 -1
  591. package/dist/cjs/lib/rafSchd.js.map +1 -1
  592. package/dist/cjs/lib/react/index.js.map +1 -1
  593. package/dist/cjs/lib/react/simulateReactInput.js.map +1 -1
  594. package/dist/cjs/lib/removeObjectKeys.js.map +1 -1
  595. package/dist/cjs/lib/select.js.map +1 -1
  596. package/dist/cjs/lib/styles.js.map +1 -1
  597. package/dist/cjs/lib/testing.js.map +1 -1
  598. package/dist/cjs/lib/tokens/TokensClassProvider.d.ts.map +1 -1
  599. package/dist/cjs/lib/tokens/TokensClassProvider.js +1 -1
  600. package/dist/cjs/lib/tokens/TokensClassProvider.js.map +1 -1
  601. package/dist/cjs/lib/tokens/constants.js.map +1 -1
  602. package/dist/cjs/lib/tokens/index.js.map +1 -1
  603. package/dist/cjs/lib/tokens/types.js.map +1 -1
  604. package/dist/cjs/lib/tokens/useTokenClassName.js.map +1 -1
  605. package/dist/cjs/lib/touch/UIPanGestureRecognizer.js.map +1 -1
  606. package/dist/cjs/lib/touch/functions.js.map +1 -1
  607. package/dist/cjs/lib/touch/index.js.map +1 -1
  608. package/dist/cjs/lib/useIsomorphicLayoutEffect.js.map +1 -1
  609. package/dist/cjs/lib/utils.d.ts +1 -1
  610. package/dist/cjs/lib/utils.d.ts.map +1 -1
  611. package/dist/cjs/lib/utils.js.map +1 -1
  612. package/dist/cjs/lib/warnOnce.js.map +1 -1
  613. package/dist/cjs/shared/breakpoints.d.js +8 -0
  614. package/dist/cjs/shared/breakpoints.d.js.map +1 -0
  615. package/dist/cjs/shared/breakpoints.js.map +1 -1
  616. package/dist/cjs/types.d.ts +1 -0
  617. package/dist/cjs/types.d.ts.map +1 -1
  618. package/dist/cjs/types.js.map +1 -1
  619. package/dist/cjs/vkui.js.map +1 -1
  620. package/dist/components/Accordion/Accordion.js.map +1 -1
  621. package/dist/components/Accordion/AccordionContent.d.ts.map +1 -1
  622. package/dist/components/Accordion/AccordionContent.js +35 -39
  623. package/dist/components/Accordion/AccordionContent.js.map +1 -1
  624. package/dist/components/Accordion/AccordionContext.js.map +1 -1
  625. package/dist/components/Accordion/AccordionSummary.js.map +1 -1
  626. package/dist/components/ActionSheet/ActionSheet.d.ts +1 -1
  627. package/dist/components/ActionSheet/ActionSheet.d.ts.map +1 -1
  628. package/dist/components/ActionSheet/ActionSheet.js +24 -32
  629. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  630. package/dist/components/ActionSheet/ActionSheetContext.js.map +1 -1
  631. package/dist/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -1
  632. package/dist/components/ActionSheet/ActionSheetDropdownMenu.d.ts +1 -1
  633. package/dist/components/ActionSheet/ActionSheetDropdownMenu.d.ts.map +1 -1
  634. package/dist/components/ActionSheet/ActionSheetDropdownMenu.js +7 -3
  635. package/dist/components/ActionSheet/ActionSheetDropdownMenu.js.map +1 -1
  636. package/dist/components/ActionSheet/ActionSheetDropdownSheet.js +1 -1
  637. package/dist/components/ActionSheet/ActionSheetDropdownSheet.js.map +1 -1
  638. package/dist/components/ActionSheet/types.js.map +1 -1
  639. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  640. package/dist/components/ActionSheetItem/subcomponents/Radio/Radio.js.map +1 -1
  641. package/dist/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -1
  642. package/dist/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  643. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  644. package/dist/components/Alert/Alert.d.ts.map +1 -1
  645. package/dist/components/Alert/Alert.js +23 -34
  646. package/dist/components/Alert/Alert.js.map +1 -1
  647. package/dist/components/Alert/AlertAction.js.map +1 -1
  648. package/dist/components/Alert/AlertActions.js.map +1 -1
  649. package/dist/components/Alert/AlertTypography.js.map +1 -1
  650. package/dist/components/AppRoot/AppRoot.d.ts +14 -2
  651. package/dist/components/AppRoot/AppRoot.d.ts.map +1 -1
  652. package/dist/components/AppRoot/AppRoot.js +12 -4
  653. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  654. package/dist/components/AppRoot/AppRootContext.js.map +1 -1
  655. package/dist/components/AppRoot/AppRootPortal.js.map +1 -1
  656. package/dist/components/AppRoot/ScrollContext.d.ts.map +1 -1
  657. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  658. package/dist/components/AppRoot/helpers.d.ts +6 -1
  659. package/dist/components/AppRoot/helpers.d.ts.map +1 -1
  660. package/dist/components/AppRoot/helpers.js +21 -0
  661. package/dist/components/AppRoot/helpers.js.map +1 -1
  662. package/dist/components/AppRoot/types.d.ts +1 -0
  663. package/dist/components/AppRoot/types.d.ts.map +1 -1
  664. package/dist/components/AppRoot/types.js.map +1 -1
  665. package/dist/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  666. package/dist/components/AspectRatio/AspectRatio.js.map +1 -1
  667. package/dist/components/Avatar/Avatar.d.ts +2 -5
  668. package/dist/components/Avatar/Avatar.d.ts.map +1 -1
  669. package/dist/components/Avatar/Avatar.js.map +1 -1
  670. package/dist/components/Avatar/AvatarBadge/AvatarBadge.js.map +1 -1
  671. package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  672. package/dist/components/Avatar/AvatarBadge/icons.d.ts.map +1 -1
  673. package/dist/components/Avatar/AvatarBadge/icons.js.map +1 -1
  674. package/dist/components/Avatar/helpers.js.map +1 -1
  675. package/dist/components/Badge/Badge.js.map +1 -1
  676. package/dist/components/Banner/Banner.js.map +1 -1
  677. package/dist/components/BaseGallery/BaseGallery.js.map +1 -1
  678. package/dist/components/BaseGallery/CarouselBase/CarouselBase.js.map +1 -1
  679. package/dist/components/BaseGallery/CarouselBase/constants.js.map +1 -1
  680. package/dist/components/BaseGallery/CarouselBase/helpers.js.map +1 -1
  681. package/dist/components/BaseGallery/CarouselBase/hooks.js.map +1 -1
  682. package/dist/components/BaseGallery/CarouselBase/types.js.map +1 -1
  683. package/dist/components/BaseGallery/helpers.js.map +1 -1
  684. package/dist/components/BaseGallery/types.js.map +1 -1
  685. package/dist/components/Button/Button.js.map +1 -1
  686. package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -1
  687. package/dist/components/Calendar/Calendar.d.ts.map +1 -1
  688. package/dist/components/Calendar/Calendar.js +4 -2
  689. package/dist/components/Calendar/Calendar.js.map +1 -1
  690. package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
  691. package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
  692. package/dist/components/CalendarHeader/CalendarHeader.d.ts +3 -1
  693. package/dist/components/CalendarHeader/CalendarHeader.d.ts.map +1 -1
  694. package/dist/components/CalendarHeader/CalendarHeader.js +23 -10
  695. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
  696. package/dist/components/CalendarRange/CalendarRange.d.ts.map +1 -1
  697. package/dist/components/CalendarRange/CalendarRange.js +12 -5
  698. package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
  699. package/dist/components/CalendarTime/CalendarTime.js.map +1 -1
  700. package/dist/components/Card/Card.js.map +1 -1
  701. package/dist/components/CardGrid/CardGrid.js.map +1 -1
  702. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  703. package/dist/components/Cell/Cell.js.map +1 -1
  704. package/dist/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  705. package/dist/components/Cell/CellDragger/CellDragger.js.map +1 -1
  706. package/dist/components/Cell/constants.js.map +1 -1
  707. package/dist/components/CellButton/CellButton.js.map +1 -1
  708. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  709. package/dist/components/ChipsInput/ChipsInput.d.ts.map +1 -1
  710. package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
  711. package/dist/components/ChipsInput/useChipsInput.d.ts.map +1 -1
  712. package/dist/components/ChipsInput/useChipsInput.js.map +1 -1
  713. package/dist/components/ChipsInputBase/Chip/Chip.js.map +1 -1
  714. package/dist/components/ChipsInputBase/ChipsInputBase.d.ts.map +1 -1
  715. package/dist/components/ChipsInputBase/ChipsInputBase.js +2 -2
  716. package/dist/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
  717. package/dist/components/ChipsInputBase/constants.js +2 -3
  718. package/dist/components/ChipsInputBase/constants.js.map +1 -1
  719. package/dist/components/ChipsInputBase/helpers.d.ts.map +1 -1
  720. package/dist/components/ChipsInputBase/helpers.js.map +1 -1
  721. package/dist/components/ChipsInputBase/types.js.map +1 -1
  722. package/dist/components/ChipsSelect/ChipsSelect.d.ts +5 -1
  723. package/dist/components/ChipsSelect/ChipsSelect.d.ts.map +1 -1
  724. package/dist/components/ChipsSelect/ChipsSelect.js +15 -8
  725. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  726. package/dist/components/ChipsSelect/constants.d.ts.map +1 -1
  727. package/dist/components/ChipsSelect/constants.js.map +1 -1
  728. package/dist/components/ChipsSelect/types.js.map +1 -1
  729. package/dist/components/ChipsSelect/useChipsSelect.d.ts +10 -2
  730. package/dist/components/ChipsSelect/useChipsSelect.d.ts.map +1 -1
  731. package/dist/components/ChipsSelect/useChipsSelect.js +12 -4
  732. package/dist/components/ChipsSelect/useChipsSelect.js.map +1 -1
  733. package/dist/components/Clickable/Clickable.d.ts.map +1 -1
  734. package/dist/components/Clickable/Clickable.js.map +1 -1
  735. package/dist/components/Clickable/useKeyboard.d.ts.map +1 -1
  736. package/dist/components/Clickable/useKeyboard.js.map +1 -1
  737. package/dist/components/Clickable/useState.d.ts.map +1 -1
  738. package/dist/components/Clickable/useState.js.map +1 -1
  739. package/dist/components/Clickable/useStateWithDelay.js.map +1 -1
  740. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  741. package/dist/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  742. package/dist/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  743. package/dist/components/ContentBadge/ContentBadge.js.map +1 -1
  744. package/dist/components/ContentBadge/ContentBadgeContext.js.map +1 -1
  745. package/dist/components/ContentBadge/ContentBadgeSlotIcon.js.map +1 -1
  746. package/dist/components/ContentBadge/types.js.map +1 -1
  747. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  748. package/dist/components/Counter/Counter.js.map +1 -1
  749. package/dist/components/CustomScrollView/CustomScrollView.js.map +1 -1
  750. package/dist/components/CustomScrollView/useTrackerVisibility.d.ts.map +1 -1
  751. package/dist/components/CustomScrollView/useTrackerVisibility.js +31 -37
  752. package/dist/components/CustomScrollView/useTrackerVisibility.js.map +1 -1
  753. package/dist/components/CustomSelect/CustomSelect.d.ts +5 -2
  754. package/dist/components/CustomSelect/CustomSelect.d.ts.map +1 -1
  755. package/dist/components/CustomSelect/CustomSelect.js +4 -5
  756. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  757. package/dist/components/CustomSelect/CustomSelectClearButton.js.map +1 -1
  758. package/dist/components/CustomSelect/CustomSelectInput.js.map +1 -1
  759. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  760. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  761. package/dist/components/DateInput/DateInput.js.map +1 -1
  762. package/dist/components/DatePicker/DatePicker.d.ts +6 -0
  763. package/dist/components/DatePicker/DatePicker.d.ts.map +1 -1
  764. package/dist/components/DatePicker/DatePicker.js +6 -0
  765. package/dist/components/DatePicker/DatePicker.js.map +1 -1
  766. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  767. package/dist/components/Div/Div.js.map +1 -1
  768. package/dist/components/DropZone/DropZone.js.map +1 -1
  769. package/dist/components/DropZone/components/DropZoneGrid.js.map +1 -1
  770. package/dist/components/DropdownIcon/DropdownIcon.js.map +1 -1
  771. package/dist/components/Epic/Epic.js.map +1 -1
  772. package/dist/components/Epic/ScrollSaver.js.map +1 -1
  773. package/dist/components/File/File.js.map +1 -1
  774. package/dist/components/FixedLayout/FixedLayout.d.ts.map +1 -1
  775. package/dist/components/FixedLayout/FixedLayout.js +19 -6
  776. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  777. package/dist/components/Flex/Flex.d.ts +42 -0
  778. package/dist/components/Flex/Flex.d.ts.map +1 -0
  779. package/dist/components/Flex/Flex.js +50 -0
  780. package/dist/components/Flex/Flex.js.map +1 -0
  781. package/dist/components/Flex/FlexItem/FlexItem.d.ts +20 -0
  782. package/dist/components/Flex/FlexItem/FlexItem.d.ts.map +1 -0
  783. package/dist/components/Flex/FlexItem/FlexItem.js +37 -0
  784. package/dist/components/Flex/FlexItem/FlexItem.js.map +1 -0
  785. package/dist/components/FloatingArrow/DefaultIcon.d.ts.map +1 -1
  786. package/dist/components/FloatingArrow/DefaultIcon.js.map +1 -1
  787. package/dist/components/FloatingArrow/FloatingArrow.js +14 -4
  788. package/dist/components/FloatingArrow/FloatingArrow.js.map +1 -1
  789. package/dist/components/FocusTrap/FocusTrap.d.ts +6 -1
  790. package/dist/components/FocusTrap/FocusTrap.d.ts.map +1 -1
  791. package/dist/components/FocusTrap/FocusTrap.js +45 -20
  792. package/dist/components/FocusTrap/FocusTrap.js.map +1 -1
  793. package/dist/components/Footer/Footer.js.map +1 -1
  794. package/dist/components/FormField/FormField.js.map +1 -1
  795. package/dist/components/FormItem/FormItem.js.map +1 -1
  796. package/dist/components/FormItem/FormItemTop/FormItemTop.js.map +1 -1
  797. package/dist/components/FormItem/FormItemTop/FormItemTopAside.js.map +1 -1
  798. package/dist/components/FormItem/FormItemTop/FormItemTopLabel.js.map +1 -1
  799. package/dist/components/FormItem/context.js.map +1 -1
  800. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  801. package/dist/components/FormStatus/FormStatus.js.map +1 -1
  802. package/dist/components/Gallery/Gallery.js.map +1 -1
  803. package/dist/components/Gallery/hooks.d.ts +1 -1
  804. package/dist/components/Gallery/hooks.d.ts.map +1 -1
  805. package/dist/components/Gallery/hooks.js +24 -21
  806. package/dist/components/Gallery/hooks.js.map +1 -1
  807. package/dist/components/Gradient/Gradient.js.map +1 -1
  808. package/dist/components/GridAvatar/GridAvatar.d.ts +1 -1
  809. package/dist/components/GridAvatar/GridAvatar.js +1 -1
  810. package/dist/components/GridAvatar/GridAvatar.js.map +1 -1
  811. package/dist/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.js.map +1 -1
  812. package/dist/components/Group/Group.js.map +1 -1
  813. package/dist/components/Header/Header.js.map +1 -1
  814. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  815. package/dist/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.js.map +1 -1
  816. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  817. package/dist/components/IconButton/IconButton.js.map +1 -1
  818. package/dist/components/Image/Image.d.ts +3 -5
  819. package/dist/components/Image/Image.d.ts.map +1 -1
  820. package/dist/components/Image/Image.js.map +1 -1
  821. package/dist/components/Image/ImageBadge/ImageBadge.js.map +1 -1
  822. package/dist/components/ImageBase/ImageBase.d.ts +1 -4
  823. package/dist/components/ImageBase/ImageBase.d.ts.map +1 -1
  824. package/dist/components/ImageBase/ImageBase.js.map +1 -1
  825. package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
  826. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.d.ts +4 -38
  827. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.d.ts.map +1 -1
  828. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js +64 -23
  829. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  830. package/dist/components/ImageBase/ImageBaseOverlay/hooks.d.ts +6 -0
  831. package/dist/components/ImageBase/ImageBaseOverlay/hooks.d.ts.map +1 -0
  832. package/dist/components/ImageBase/ImageBaseOverlay/hooks.js +26 -0
  833. package/dist/components/ImageBase/ImageBaseOverlay/hooks.js.map +1 -0
  834. package/dist/components/ImageBase/ImageBaseOverlay/types.d.ts +54 -0
  835. package/dist/components/ImageBase/ImageBaseOverlay/types.d.ts.map +1 -0
  836. package/dist/components/ImageBase/ImageBaseOverlay/types.js +3 -0
  837. package/dist/components/ImageBase/ImageBaseOverlay/types.js.map +1 -0
  838. package/dist/components/ImageBase/context.js.map +1 -1
  839. package/dist/components/ImageBase/helpers.js.map +1 -1
  840. package/dist/components/ImageBase/types.js.map +1 -1
  841. package/dist/components/ImageBase/validators.js.map +1 -1
  842. package/dist/components/InfoRow/InfoRow.js.map +1 -1
  843. package/dist/components/Input/Input.js.map +1 -1
  844. package/dist/components/InputLike/InputLike.js.map +1 -1
  845. package/dist/components/InputLike/InputLikeDivider.d.ts.map +1 -1
  846. package/dist/components/InputLike/InputLikeDivider.js.map +1 -1
  847. package/dist/components/Link/Link.d.ts.map +1 -1
  848. package/dist/components/Link/Link.js +1 -0
  849. package/dist/components/Link/Link.js.map +1 -1
  850. package/dist/components/List/List.js.map +1 -1
  851. package/dist/components/LocaleProvider/LocaleProvider.js.map +1 -1
  852. package/dist/components/Mark/Mark.js.map +1 -1
  853. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  854. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  855. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  856. package/dist/components/ModalCardBase/ModalCardBaseCloseButton.js.map +1 -1
  857. package/dist/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  858. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  859. package/dist/components/ModalPage/ModalPageContext.js.map +1 -1
  860. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  861. package/dist/components/ModalRoot/ModalRoot.d.ts.map +1 -1
  862. package/dist/components/ModalRoot/ModalRoot.js +6 -9
  863. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  864. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  865. package/dist/components/ModalRoot/ModalRootContext.js.map +1 -1
  866. package/dist/components/ModalRoot/ModalRootDesktop.d.ts.map +1 -1
  867. package/dist/components/ModalRoot/ModalRootDesktop.js +2 -1
  868. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  869. package/dist/components/ModalRoot/constants.js.map +1 -1
  870. package/dist/components/ModalRoot/types.d.ts +0 -1
  871. package/dist/components/ModalRoot/types.d.ts.map +1 -1
  872. package/dist/components/ModalRoot/types.js.map +1 -1
  873. package/dist/components/ModalRoot/useModalManager.d.ts.map +1 -1
  874. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  875. package/dist/components/ModalRoot/useModalRootContext.js.map +1 -1
  876. package/dist/components/ModalRoot/withModalRootContext.js.map +1 -1
  877. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  878. package/dist/components/NavIdContext/NavIdContext.js.map +1 -1
  879. package/dist/components/NavIdContext/useNavId.js.map +1 -1
  880. package/dist/components/NavTransitionContext/NavTransitionContext.d.ts.map +1 -1
  881. package/dist/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  882. package/dist/components/NavTransitionDirectionContext/NavTransitionDirectionContext.d.ts.map +1 -1
  883. package/dist/components/NavTransitionDirectionContext/NavTransitionDirectionContext.js.map +1 -1
  884. package/dist/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  885. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts +1 -1
  886. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts.map +1 -1
  887. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.js.map +1 -1
  888. package/dist/components/Pagination/Pagination.js.map +1 -1
  889. package/dist/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.d.ts.map +1 -1
  890. package/dist/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.js.map +1 -1
  891. package/dist/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -1
  892. package/dist/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -1
  893. package/dist/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -1
  894. package/dist/components/Pagination/utils.js.map +1 -1
  895. package/dist/components/Panel/Panel.js.map +1 -1
  896. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  897. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  898. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  899. package/dist/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  900. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  901. package/dist/components/PanelHeaderContext/PanelHeaderContext.d.ts +2 -2
  902. package/dist/components/PanelHeaderContext/PanelHeaderContext.d.ts.map +1 -1
  903. package/dist/components/PanelHeaderContext/PanelHeaderContext.js +27 -37
  904. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  905. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  906. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  907. package/dist/components/PanelSpinner/PanelSpinner.js.map +1 -1
  908. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  909. package/dist/components/PlatformProvider/PlatformProvider.js.map +1 -1
  910. package/dist/components/PopoutRoot/PopoutRoot.d.ts.map +1 -1
  911. package/dist/components/PopoutRoot/PopoutRoot.js +0 -8
  912. package/dist/components/PopoutRoot/PopoutRoot.js.map +1 -1
  913. package/dist/components/PopoutWrapper/PopoutWrapper.d.ts.map +1 -1
  914. package/dist/components/PopoutWrapper/PopoutWrapper.js +1 -19
  915. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  916. package/dist/components/Popover/Popover.d.ts +6 -2
  917. package/dist/components/Popover/Popover.d.ts.map +1 -1
  918. package/dist/components/Popover/Popover.js +14 -6
  919. package/dist/components/Popover/Popover.js.map +1 -1
  920. package/dist/components/Popper/Popper.js.map +1 -1
  921. package/dist/components/Progress/Progress.js.map +1 -1
  922. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  923. package/dist/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  924. package/dist/components/Radio/Radio.js.map +1 -1
  925. package/dist/components/RadioGroup/RadioGroup.js.map +1 -1
  926. package/dist/components/Removable/Removable.js.map +1 -1
  927. package/dist/components/RichCell/RichCell.js.map +1 -1
  928. package/dist/components/RichCell/RichCellIcon/RichCellIcon.js.map +1 -1
  929. package/dist/components/Root/Root.d.ts.map +1 -1
  930. package/dist/components/Root/Root.js +8 -18
  931. package/dist/components/Root/Root.js.map +1 -1
  932. package/dist/components/RootComponent/RootComponent.d.ts.map +1 -1
  933. package/dist/components/RootComponent/RootComponent.js.map +1 -1
  934. package/dist/components/ScreenSpinner/Icon48CancelCircle.d.ts.map +1 -1
  935. package/dist/components/ScreenSpinner/Icon48CancelCircle.js.map +1 -1
  936. package/dist/components/ScreenSpinner/Icon48DoneOutline.d.ts.map +1 -1
  937. package/dist/components/ScreenSpinner/Icon48DoneOutline.js.map +1 -1
  938. package/dist/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  939. package/dist/components/ScrollArrow/ScrollArrow.js.map +1 -1
  940. package/dist/components/Search/Search.js.map +1 -1
  941. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  942. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  943. package/dist/components/Select/Select.d.ts.map +1 -1
  944. package/dist/components/Select/Select.js.map +1 -1
  945. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  946. package/dist/components/SelectTypography/SelectTypography.js.map +1 -1
  947. package/dist/components/Separator/Separator.js.map +1 -1
  948. package/dist/components/SimpleCell/Chevron/Chevron.js.map +1 -1
  949. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  950. package/dist/components/Skeleton/Skeleton.js.map +1 -1
  951. package/dist/components/Slider/Slider.d.ts.map +1 -1
  952. package/dist/components/Slider/Slider.js +7 -2
  953. package/dist/components/Slider/Slider.js.map +1 -1
  954. package/dist/components/Slider/SliderThumb/SliderThumb.d.ts +2 -1
  955. package/dist/components/Slider/SliderThumb/SliderThumb.d.ts.map +1 -1
  956. package/dist/components/Slider/SliderThumb/SliderThumb.js +6 -5
  957. package/dist/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
  958. package/dist/components/Slider/helpers.d.ts.map +1 -1
  959. package/dist/components/Slider/helpers.js.map +1 -1
  960. package/dist/components/Slider/types.js.map +1 -1
  961. package/dist/components/Snackbar/Snackbar.d.ts +1 -1
  962. package/dist/components/Snackbar/Snackbar.d.ts.map +1 -1
  963. package/dist/components/Snackbar/Snackbar.js +11 -10
  964. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  965. package/dist/components/Snackbar/subcomponents/Basic/Basic.js.map +1 -1
  966. package/dist/components/Snackbar/types.js.map +1 -1
  967. package/dist/components/Snackbar/utils.d.ts +0 -1
  968. package/dist/components/Snackbar/utils.d.ts.map +1 -1
  969. package/dist/components/Snackbar/utils.js.map +1 -1
  970. package/dist/components/Spacing/Spacing.js.map +1 -1
  971. package/dist/components/Spinner/Spinner.d.ts.map +1 -1
  972. package/dist/components/Spinner/Spinner.js +37 -18
  973. package/dist/components/Spinner/Spinner.js.map +1 -1
  974. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  975. package/dist/components/SplitCol/SplitColContext.js.map +1 -1
  976. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  977. package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  978. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  979. package/dist/components/Switch/Switch.d.ts +1 -1
  980. package/dist/components/Switch/Switch.d.ts.map +1 -1
  981. package/dist/components/Switch/Switch.js +41 -19
  982. package/dist/components/Switch/Switch.js.map +1 -1
  983. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  984. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  985. package/dist/components/Tabs/Tabs.js.map +1 -1
  986. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  987. package/dist/components/Tappable/Ripple.d.ts.map +1 -1
  988. package/dist/components/Tappable/Ripple.js +10 -3
  989. package/dist/components/Tappable/Ripple.js.map +1 -1
  990. package/dist/components/Tappable/Tappable.js.map +1 -1
  991. package/dist/components/Tappable/state.js.map +1 -1
  992. package/dist/components/Textarea/Textarea.d.ts.map +1 -1
  993. package/dist/components/Textarea/Textarea.js +7 -19
  994. package/dist/components/Textarea/Textarea.js.map +1 -1
  995. package/dist/components/Textarea/useResizeTextarea.d.ts +3 -0
  996. package/dist/components/Textarea/useResizeTextarea.d.ts.map +1 -0
  997. package/dist/components/Textarea/useResizeTextarea.js +34 -0
  998. package/dist/components/Textarea/useResizeTextarea.js.map +1 -0
  999. package/dist/components/ToolButton/ToolButton.js.map +1 -1
  1000. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  1001. package/dist/components/TooltipBase/TooltipBase.js.map +1 -1
  1002. package/dist/components/Touch/Touch.js.map +1 -1
  1003. package/dist/components/Touch/TouchContext.js.map +1 -1
  1004. package/dist/components/Typography/Caption/Caption.d.ts +1 -1
  1005. package/dist/components/Typography/Caption/Caption.d.ts.map +1 -1
  1006. package/dist/components/Typography/Caption/Caption.js +4 -2
  1007. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  1008. package/dist/components/Typography/DisplayTitle/DisplayTitle.d.ts +11 -0
  1009. package/dist/components/Typography/DisplayTitle/DisplayTitle.d.ts.map +1 -0
  1010. package/dist/components/Typography/DisplayTitle/DisplayTitle.js +32 -0
  1011. package/dist/components/Typography/DisplayTitle/DisplayTitle.js.map +1 -0
  1012. package/dist/components/Typography/EllipsisText/EllipsisText.js.map +1 -1
  1013. package/dist/components/Typography/Footnote/Footnote.d.ts +1 -1
  1014. package/dist/components/Typography/Footnote/Footnote.d.ts.map +1 -1
  1015. package/dist/components/Typography/Footnote/Footnote.js +4 -2
  1016. package/dist/components/Typography/Footnote/Footnote.js.map +1 -1
  1017. package/dist/components/Typography/Headline/Headline.d.ts +1 -1
  1018. package/dist/components/Typography/Headline/Headline.d.ts.map +1 -1
  1019. package/dist/components/Typography/Headline/Headline.js +4 -2
  1020. package/dist/components/Typography/Headline/Headline.js.map +1 -1
  1021. package/dist/components/Typography/Paragraph/Paragraph.d.ts +1 -1
  1022. package/dist/components/Typography/Paragraph/Paragraph.d.ts.map +1 -1
  1023. package/dist/components/Typography/Paragraph/Paragraph.js +4 -2
  1024. package/dist/components/Typography/Paragraph/Paragraph.js.map +1 -1
  1025. package/dist/components/Typography/Subhead/Subhead.d.ts +1 -1
  1026. package/dist/components/Typography/Subhead/Subhead.d.ts.map +1 -1
  1027. package/dist/components/Typography/Subhead/Subhead.js +4 -2
  1028. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  1029. package/dist/components/Typography/Text/Text.d.ts +1 -1
  1030. package/dist/components/Typography/Text/Text.d.ts.map +1 -1
  1031. package/dist/components/Typography/Text/Text.js +4 -2
  1032. package/dist/components/Typography/Text/Text.js.map +1 -1
  1033. package/dist/components/Typography/Title/Title.d.ts +1 -1
  1034. package/dist/components/Typography/Title/Title.d.ts.map +1 -1
  1035. package/dist/components/Typography/Title/Title.js +4 -2
  1036. package/dist/components/Typography/Title/Title.js.map +1 -1
  1037. package/dist/components/Typography/Typography.d.ts +5 -1
  1038. package/dist/components/Typography/Typography.d.ts.map +1 -1
  1039. package/dist/components/Typography/Typography.js +4 -3
  1040. package/dist/components/Typography/Typography.js.map +1 -1
  1041. package/dist/components/UnstyledTextField/UnstyledTextField.js.map +1 -1
  1042. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  1043. package/dist/components/View/View.d.ts.map +1 -1
  1044. package/dist/components/View/View.js +36 -50
  1045. package/dist/components/View/View.js.map +1 -1
  1046. package/dist/components/View/ViewInfinite.d.ts.map +1 -1
  1047. package/dist/components/View/ViewInfinite.js +17 -19
  1048. package/dist/components/View/ViewInfinite.js.map +1 -1
  1049. package/dist/components/View/utils.js.map +1 -1
  1050. package/dist/components/VisuallyHidden/VisuallyHidden.d.ts.map +1 -1
  1051. package/dist/components/VisuallyHidden/VisuallyHidden.js.map +1 -1
  1052. package/dist/components/WriteBar/WriteBar.d.ts.map +1 -1
  1053. package/dist/components/WriteBar/WriteBar.js +3 -19
  1054. package/dist/components/WriteBar/WriteBar.js.map +1 -1
  1055. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1056. package/dist/components.css +3 -153
  1057. package/dist/components.css.map +1 -1
  1058. package/dist/components.js.tmp +26254 -70158
  1059. package/dist/cssm/components/Accordion/Accordion.js.map +1 -1
  1060. package/dist/cssm/components/Accordion/Accordion.module.css +94 -2
  1061. package/dist/cssm/components/Accordion/AccordionContent.d.ts.map +1 -1
  1062. package/dist/cssm/components/Accordion/AccordionContent.js +33 -37
  1063. package/dist/cssm/components/Accordion/AccordionContent.js.map +1 -1
  1064. package/dist/cssm/components/Accordion/AccordionContext.js.map +1 -1
  1065. package/dist/cssm/components/Accordion/AccordionSummary.js.map +1 -1
  1066. package/dist/cssm/components/ActionSheet/ActionSheet.d.ts +1 -1
  1067. package/dist/cssm/components/ActionSheet/ActionSheet.d.ts.map +1 -1
  1068. package/dist/cssm/components/ActionSheet/ActionSheet.js +22 -30
  1069. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  1070. package/dist/cssm/components/ActionSheet/ActionSheet.module.css +42 -11
  1071. package/dist/cssm/components/ActionSheet/ActionSheetContext.js.map +1 -1
  1072. package/dist/cssm/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -1
  1073. package/dist/cssm/components/ActionSheet/ActionSheetDropdownMenu.d.ts +1 -1
  1074. package/dist/cssm/components/ActionSheet/ActionSheetDropdownMenu.d.ts.map +1 -1
  1075. package/dist/cssm/components/ActionSheet/ActionSheetDropdownMenu.js +4 -2
  1076. package/dist/cssm/components/ActionSheet/ActionSheetDropdownMenu.js.map +1 -1
  1077. package/dist/cssm/components/ActionSheet/ActionSheetDropdownSheet.js +1 -1
  1078. package/dist/cssm/components/ActionSheet/ActionSheetDropdownSheet.js.map +1 -1
  1079. package/dist/cssm/components/ActionSheet/types.js.map +1 -1
  1080. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  1081. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.module.css +3 -1
  1082. package/dist/cssm/components/ActionSheetItem/subcomponents/Radio/Radio.js.map +1 -1
  1083. package/dist/cssm/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -1
  1084. package/dist/cssm/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  1085. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  1086. package/dist/cssm/components/Alert/Alert.d.ts.map +1 -1
  1087. package/dist/cssm/components/Alert/Alert.js +23 -33
  1088. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  1089. package/dist/cssm/components/Alert/Alert.module.css +31 -19
  1090. package/dist/cssm/components/Alert/AlertAction.js.map +1 -1
  1091. package/dist/cssm/components/Alert/AlertActions.js.map +1 -1
  1092. package/dist/cssm/components/Alert/AlertTypography.js.map +1 -1
  1093. package/dist/cssm/components/AppRoot/AppRoot.d.ts +14 -2
  1094. package/dist/cssm/components/AppRoot/AppRoot.d.ts.map +1 -1
  1095. package/dist/cssm/components/AppRoot/AppRoot.js +10 -3
  1096. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  1097. package/dist/cssm/components/AppRoot/AppRoot.module.css +5 -5
  1098. package/dist/cssm/components/AppRoot/AppRootContext.js.map +1 -1
  1099. package/dist/cssm/components/AppRoot/AppRootPortal.js.map +1 -1
  1100. package/dist/cssm/components/AppRoot/ScrollContext.d.ts.map +1 -1
  1101. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  1102. package/dist/cssm/components/AppRoot/helpers.d.ts +6 -1
  1103. package/dist/cssm/components/AppRoot/helpers.d.ts.map +1 -1
  1104. package/dist/cssm/components/AppRoot/helpers.js +22 -0
  1105. package/dist/cssm/components/AppRoot/helpers.js.map +1 -1
  1106. package/dist/cssm/components/AppRoot/types.d.ts +1 -0
  1107. package/dist/cssm/components/AppRoot/types.d.ts.map +1 -1
  1108. package/dist/cssm/components/AppRoot/types.js.map +1 -1
  1109. package/dist/cssm/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  1110. package/dist/cssm/components/AspectRatio/AspectRatio.js.map +1 -1
  1111. package/dist/cssm/components/Avatar/Avatar.d.ts +2 -5
  1112. package/dist/cssm/components/Avatar/Avatar.d.ts.map +1 -1
  1113. package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
  1114. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadge.js.map +1 -1
  1115. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  1116. package/dist/cssm/components/Avatar/AvatarBadge/icons.d.ts.map +1 -1
  1117. package/dist/cssm/components/Avatar/AvatarBadge/icons.js.map +1 -1
  1118. package/dist/cssm/components/Avatar/helpers.js.map +1 -1
  1119. package/dist/cssm/components/Badge/Badge.js.map +1 -1
  1120. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  1121. package/dist/cssm/components/BaseGallery/BaseGallery.js.map +1 -1
  1122. package/dist/cssm/components/BaseGallery/CarouselBase/CarouselBase.js.map +1 -1
  1123. package/dist/cssm/components/BaseGallery/CarouselBase/constants.js.map +1 -1
  1124. package/dist/cssm/components/BaseGallery/CarouselBase/helpers.js.map +1 -1
  1125. package/dist/cssm/components/BaseGallery/CarouselBase/hooks.js.map +1 -1
  1126. package/dist/cssm/components/BaseGallery/CarouselBase/types.js.map +1 -1
  1127. package/dist/cssm/components/BaseGallery/helpers.js.map +1 -1
  1128. package/dist/cssm/components/BaseGallery/types.js.map +1 -1
  1129. package/dist/cssm/components/Button/Button.js.map +1 -1
  1130. package/dist/cssm/components/Button/Button.module.css +3 -6
  1131. package/dist/cssm/components/ButtonGroup/ButtonGroup.js.map +1 -1
  1132. package/dist/cssm/components/Calendar/Calendar.d.ts.map +1 -1
  1133. package/dist/cssm/components/Calendar/Calendar.js +4 -2
  1134. package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
  1135. package/dist/cssm/components/Calendar/Calendar.module.css +1 -1
  1136. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
  1137. package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
  1138. package/dist/cssm/components/CalendarHeader/CalendarHeader.d.ts +3 -1
  1139. package/dist/cssm/components/CalendarHeader/CalendarHeader.d.ts.map +1 -1
  1140. package/dist/cssm/components/CalendarHeader/CalendarHeader.js +21 -9
  1141. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
  1142. package/dist/cssm/components/CalendarRange/CalendarRange.d.ts.map +1 -1
  1143. package/dist/cssm/components/CalendarRange/CalendarRange.js +12 -5
  1144. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
  1145. package/dist/cssm/components/CalendarRange/CalendarRange.module.css +1 -1
  1146. package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -1
  1147. package/dist/cssm/components/Card/Card.js.map +1 -1
  1148. package/dist/cssm/components/Card/Card.module.css +2 -2
  1149. package/dist/cssm/components/CardGrid/CardGrid.js.map +1 -1
  1150. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  1151. package/dist/cssm/components/Cell/Cell.js.map +1 -1
  1152. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  1153. package/dist/cssm/components/Cell/CellDragger/CellDragger.js.map +1 -1
  1154. package/dist/cssm/components/Cell/constants.js.map +1 -1
  1155. package/dist/cssm/components/CellButton/CellButton.js.map +1 -1
  1156. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  1157. package/dist/cssm/components/ChipsInput/ChipsInput.d.ts.map +1 -1
  1158. package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
  1159. package/dist/cssm/components/ChipsInput/useChipsInput.d.ts.map +1 -1
  1160. package/dist/cssm/components/ChipsInput/useChipsInput.js.map +1 -1
  1161. package/dist/cssm/components/ChipsInputBase/Chip/Chip.js.map +1 -1
  1162. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.d.ts.map +1 -1
  1163. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.js +2 -2
  1164. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
  1165. package/dist/cssm/components/ChipsInputBase/constants.js +2 -2
  1166. package/dist/cssm/components/ChipsInputBase/constants.js.map +1 -1
  1167. package/dist/cssm/components/ChipsInputBase/helpers.d.ts.map +1 -1
  1168. package/dist/cssm/components/ChipsInputBase/helpers.js.map +1 -1
  1169. package/dist/cssm/components/ChipsInputBase/types.js.map +1 -1
  1170. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts +5 -1
  1171. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts.map +1 -1
  1172. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +11 -7
  1173. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  1174. package/dist/cssm/components/ChipsSelect/constants.d.ts.map +1 -1
  1175. package/dist/cssm/components/ChipsSelect/constants.js.map +1 -1
  1176. package/dist/cssm/components/ChipsSelect/types.js.map +1 -1
  1177. package/dist/cssm/components/ChipsSelect/useChipsSelect.d.ts +10 -2
  1178. package/dist/cssm/components/ChipsSelect/useChipsSelect.d.ts.map +1 -1
  1179. package/dist/cssm/components/ChipsSelect/useChipsSelect.js +12 -4
  1180. package/dist/cssm/components/ChipsSelect/useChipsSelect.js.map +1 -1
  1181. package/dist/cssm/components/Clickable/Clickable.d.ts.map +1 -1
  1182. package/dist/cssm/components/Clickable/Clickable.js.map +1 -1
  1183. package/dist/cssm/components/Clickable/useKeyboard.d.ts.map +1 -1
  1184. package/dist/cssm/components/Clickable/useKeyboard.js.map +1 -1
  1185. package/dist/cssm/components/Clickable/useState.d.ts.map +1 -1
  1186. package/dist/cssm/components/Clickable/useState.js.map +1 -1
  1187. package/dist/cssm/components/Clickable/useStateWithDelay.js.map +1 -1
  1188. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  1189. package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  1190. package/dist/cssm/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  1191. package/dist/cssm/components/ContentBadge/ContentBadge.js.map +1 -1
  1192. package/dist/cssm/components/ContentBadge/ContentBadgeContext.js.map +1 -1
  1193. package/dist/cssm/components/ContentBadge/ContentBadgeSlotIcon.js.map +1 -1
  1194. package/dist/cssm/components/ContentBadge/types.js.map +1 -1
  1195. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  1196. package/dist/cssm/components/Counter/Counter.js.map +1 -1
  1197. package/dist/cssm/components/CustomScrollView/CustomScrollView.js.map +1 -1
  1198. package/dist/cssm/components/CustomScrollView/CustomScrollView.module.css +5 -1
  1199. package/dist/cssm/components/CustomScrollView/useTrackerVisibility.d.ts.map +1 -1
  1200. package/dist/cssm/components/CustomScrollView/useTrackerVisibility.js +31 -37
  1201. package/dist/cssm/components/CustomScrollView/useTrackerVisibility.js.map +1 -1
  1202. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +5 -2
  1203. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts.map +1 -1
  1204. package/dist/cssm/components/CustomSelect/CustomSelect.js +4 -4
  1205. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  1206. package/dist/cssm/components/CustomSelect/CustomSelectClearButton.js.map +1 -1
  1207. package/dist/cssm/components/CustomSelect/CustomSelectInput.js.map +1 -1
  1208. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  1209. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.module.css +1 -1
  1210. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  1211. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.module.css +1 -0
  1212. package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
  1213. package/dist/cssm/components/DatePicker/DatePicker.d.ts +6 -0
  1214. package/dist/cssm/components/DatePicker/DatePicker.d.ts.map +1 -1
  1215. package/dist/cssm/components/DatePicker/DatePicker.js +6 -0
  1216. package/dist/cssm/components/DatePicker/DatePicker.js.map +1 -1
  1217. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  1218. package/dist/cssm/components/Div/Div.js.map +1 -1
  1219. package/dist/cssm/components/DropZone/DropZone.js.map +1 -1
  1220. package/dist/cssm/components/DropZone/components/DropZoneGrid.js.map +1 -1
  1221. package/dist/cssm/components/DropdownIcon/DropdownIcon.js.map +1 -1
  1222. package/dist/cssm/components/Epic/Epic.js.map +1 -1
  1223. package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
  1224. package/dist/cssm/components/File/File.js.map +1 -1
  1225. package/dist/cssm/components/FixedLayout/FixedLayout.d.ts.map +1 -1
  1226. package/dist/cssm/components/FixedLayout/FixedLayout.js +19 -5
  1227. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  1228. package/dist/cssm/components/Flex/Flex.d.ts +42 -0
  1229. package/dist/cssm/components/Flex/Flex.d.ts.map +1 -0
  1230. package/dist/cssm/components/Flex/Flex.js +42 -0
  1231. package/dist/cssm/components/Flex/Flex.js.map +1 -0
  1232. package/dist/cssm/components/Flex/Flex.module.css +90 -0
  1233. package/dist/cssm/components/Flex/FlexItem/FlexItem.d.ts +20 -0
  1234. package/dist/cssm/components/Flex/FlexItem/FlexItem.d.ts.map +1 -0
  1235. package/dist/cssm/components/Flex/FlexItem/FlexItem.js +30 -0
  1236. package/dist/cssm/components/Flex/FlexItem/FlexItem.js.map +1 -0
  1237. package/dist/cssm/components/Flex/FlexItem/FlexItem.module.css +43 -0
  1238. package/dist/cssm/components/FloatingArrow/DefaultIcon.d.ts.map +1 -1
  1239. package/dist/cssm/components/FloatingArrow/DefaultIcon.js.map +1 -1
  1240. package/dist/cssm/components/FloatingArrow/FloatingArrow.js +14 -4
  1241. package/dist/cssm/components/FloatingArrow/FloatingArrow.js.map +1 -1
  1242. package/dist/cssm/components/FocusTrap/FocusTrap.d.ts +6 -1
  1243. package/dist/cssm/components/FocusTrap/FocusTrap.d.ts.map +1 -1
  1244. package/dist/cssm/components/FocusTrap/FocusTrap.js +43 -20
  1245. package/dist/cssm/components/FocusTrap/FocusTrap.js.map +1 -1
  1246. package/dist/cssm/components/Footer/Footer.js.map +1 -1
  1247. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  1248. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  1249. package/dist/cssm/components/FormItem/FormItemTop/FormItemTop.js.map +1 -1
  1250. package/dist/cssm/components/FormItem/FormItemTop/FormItemTopAside.js.map +1 -1
  1251. package/dist/cssm/components/FormItem/FormItemTop/FormItemTopLabel.js.map +1 -1
  1252. package/dist/cssm/components/FormItem/context.js.map +1 -1
  1253. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  1254. package/dist/cssm/components/FormStatus/FormStatus.js.map +1 -1
  1255. package/dist/cssm/components/Gallery/Gallery.js.map +1 -1
  1256. package/dist/cssm/components/Gallery/hooks.d.ts +1 -1
  1257. package/dist/cssm/components/Gallery/hooks.d.ts.map +1 -1
  1258. package/dist/cssm/components/Gallery/hooks.js +24 -21
  1259. package/dist/cssm/components/Gallery/hooks.js.map +1 -1
  1260. package/dist/cssm/components/Gradient/Gradient.js.map +1 -1
  1261. package/dist/cssm/components/GridAvatar/GridAvatar.d.ts +1 -1
  1262. package/dist/cssm/components/GridAvatar/GridAvatar.js +1 -1
  1263. package/dist/cssm/components/GridAvatar/GridAvatar.js.map +1 -1
  1264. package/dist/cssm/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.js.map +1 -1
  1265. package/dist/cssm/components/Group/Group.js.map +1 -1
  1266. package/dist/cssm/components/Header/Header.js.map +1 -1
  1267. package/dist/cssm/components/Header/Header.module.css +0 -4
  1268. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  1269. package/dist/cssm/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.js.map +1 -1
  1270. package/dist/cssm/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.module.css +2 -2
  1271. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  1272. package/dist/cssm/components/IconButton/IconButton.js.map +1 -1
  1273. package/dist/cssm/components/Image/Image.d.ts +3 -5
  1274. package/dist/cssm/components/Image/Image.d.ts.map +1 -1
  1275. package/dist/cssm/components/Image/Image.js.map +1 -1
  1276. package/dist/cssm/components/Image/ImageBadge/ImageBadge.js.map +1 -1
  1277. package/dist/cssm/components/ImageBase/ImageBase.d.ts +1 -4
  1278. package/dist/cssm/components/ImageBase/ImageBase.d.ts.map +1 -1
  1279. package/dist/cssm/components/ImageBase/ImageBase.js.map +1 -1
  1280. package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
  1281. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.d.ts +4 -38
  1282. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.d.ts.map +1 -1
  1283. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js +54 -18
  1284. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  1285. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.module.css +10 -0
  1286. package/dist/cssm/components/ImageBase/ImageBaseOverlay/hooks.d.ts +6 -0
  1287. package/dist/cssm/components/ImageBase/ImageBaseOverlay/hooks.d.ts.map +1 -0
  1288. package/dist/cssm/components/ImageBase/ImageBaseOverlay/hooks.js +26 -0
  1289. package/dist/cssm/components/ImageBase/ImageBaseOverlay/hooks.js.map +1 -0
  1290. package/dist/cssm/components/ImageBase/ImageBaseOverlay/types.d.ts +54 -0
  1291. package/dist/cssm/components/ImageBase/ImageBaseOverlay/types.d.ts.map +1 -0
  1292. package/dist/cssm/components/ImageBase/ImageBaseOverlay/types.js +3 -0
  1293. package/dist/cssm/components/ImageBase/ImageBaseOverlay/types.js.map +1 -0
  1294. package/dist/cssm/components/ImageBase/context.js.map +1 -1
  1295. package/dist/cssm/components/ImageBase/helpers.js.map +1 -1
  1296. package/dist/cssm/components/ImageBase/types.js.map +1 -1
  1297. package/dist/cssm/components/ImageBase/validators.js.map +1 -1
  1298. package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
  1299. package/dist/cssm/components/Input/Input.js.map +1 -1
  1300. package/dist/cssm/components/InputLike/InputLike.js.map +1 -1
  1301. package/dist/cssm/components/InputLike/InputLikeDivider.d.ts.map +1 -1
  1302. package/dist/cssm/components/InputLike/InputLikeDivider.js.map +1 -1
  1303. package/dist/cssm/components/Link/Link.d.ts.map +1 -1
  1304. package/dist/cssm/components/Link/Link.js +1 -0
  1305. package/dist/cssm/components/Link/Link.js.map +1 -1
  1306. package/dist/cssm/components/Link/Link.module.css +0 -2
  1307. package/dist/cssm/components/List/List.js.map +1 -1
  1308. package/dist/cssm/components/LocaleProvider/LocaleProvider.js.map +1 -1
  1309. package/dist/cssm/components/Mark/Mark.js.map +1 -1
  1310. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  1311. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  1312. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  1313. package/dist/cssm/components/ModalCardBase/ModalCardBaseCloseButton.js.map +1 -1
  1314. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  1315. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.module.css +5 -6
  1316. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  1317. package/dist/cssm/components/ModalPage/ModalPageContext.js.map +1 -1
  1318. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  1319. package/dist/cssm/components/ModalRoot/ModalRoot.d.ts.map +1 -1
  1320. package/dist/cssm/components/ModalRoot/ModalRoot.js +6 -7
  1321. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  1322. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  1323. package/dist/cssm/components/ModalRoot/ModalRootContext.js.map +1 -1
  1324. package/dist/cssm/components/ModalRoot/ModalRootDesktop.d.ts.map +1 -1
  1325. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +2 -1
  1326. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  1327. package/dist/cssm/components/ModalRoot/constants.js.map +1 -1
  1328. package/dist/cssm/components/ModalRoot/types.d.ts +0 -1
  1329. package/dist/cssm/components/ModalRoot/types.d.ts.map +1 -1
  1330. package/dist/cssm/components/ModalRoot/types.js.map +1 -1
  1331. package/dist/cssm/components/ModalRoot/useModalManager.d.ts.map +1 -1
  1332. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  1333. package/dist/cssm/components/ModalRoot/useModalRootContext.js.map +1 -1
  1334. package/dist/cssm/components/ModalRoot/withModalRootContext.js.map +1 -1
  1335. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  1336. package/dist/cssm/components/NavIdContext/NavIdContext.js.map +1 -1
  1337. package/dist/cssm/components/NavIdContext/useNavId.js.map +1 -1
  1338. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.d.ts.map +1 -1
  1339. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  1340. package/dist/cssm/components/NavTransitionDirectionContext/NavTransitionDirectionContext.d.ts.map +1 -1
  1341. package/dist/cssm/components/NavTransitionDirectionContext/NavTransitionDirectionContext.js.map +1 -1
  1342. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  1343. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts +1 -1
  1344. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts.map +1 -1
  1345. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContainer.js.map +1 -1
  1346. package/dist/cssm/components/Pagination/Pagination.js.map +1 -1
  1347. package/dist/cssm/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.d.ts.map +1 -1
  1348. package/dist/cssm/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.js.map +1 -1
  1349. package/dist/cssm/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -1
  1350. package/dist/cssm/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -1
  1351. package/dist/cssm/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -1
  1352. package/dist/cssm/components/Pagination/utils.js.map +1 -1
  1353. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  1354. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  1355. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  1356. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  1357. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  1358. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  1359. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.d.ts +2 -2
  1360. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.d.ts.map +1 -1
  1361. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js +22 -32
  1362. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  1363. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.module.css +34 -30
  1364. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  1365. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  1366. package/dist/cssm/components/PanelSpinner/PanelSpinner.js.map +1 -1
  1367. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  1368. package/dist/cssm/components/PlatformProvider/PlatformProvider.js.map +1 -1
  1369. package/dist/cssm/components/PopoutRoot/PopoutRoot.d.ts.map +1 -1
  1370. package/dist/cssm/components/PopoutRoot/PopoutRoot.js +0 -8
  1371. package/dist/cssm/components/PopoutRoot/PopoutRoot.js.map +1 -1
  1372. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.d.ts.map +1 -1
  1373. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +1 -19
  1374. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  1375. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.module.css +16 -2
  1376. package/dist/cssm/components/Popover/Popover.d.ts +6 -2
  1377. package/dist/cssm/components/Popover/Popover.d.ts.map +1 -1
  1378. package/dist/cssm/components/Popover/Popover.js +12 -6
  1379. package/dist/cssm/components/Popover/Popover.js.map +1 -1
  1380. package/dist/cssm/components/Popover/Popover.module.css +6 -2
  1381. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  1382. package/dist/cssm/components/Progress/Progress.js.map +1 -1
  1383. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  1384. package/dist/cssm/components/PullToRefresh/PullToRefresh.module.css +3 -1
  1385. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  1386. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  1387. package/dist/cssm/components/RadioGroup/RadioGroup.js.map +1 -1
  1388. package/dist/cssm/components/Removable/Removable.js.map +1 -1
  1389. package/dist/cssm/components/Removable/Removable.module.css +1 -6
  1390. package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
  1391. package/dist/cssm/components/RichCell/RichCellIcon/RichCellIcon.js.map +1 -1
  1392. package/dist/cssm/components/Root/Root.d.ts.map +1 -1
  1393. package/dist/cssm/components/Root/Root.js +8 -18
  1394. package/dist/cssm/components/Root/Root.js.map +1 -1
  1395. package/dist/cssm/components/Root/Root.module.css +44 -51
  1396. package/dist/cssm/components/RootComponent/RootComponent.d.ts.map +1 -1
  1397. package/dist/cssm/components/RootComponent/RootComponent.js.map +1 -1
  1398. package/dist/cssm/components/ScreenSpinner/Icon48CancelCircle.d.ts.map +1 -1
  1399. package/dist/cssm/components/ScreenSpinner/Icon48CancelCircle.js.map +1 -1
  1400. package/dist/cssm/components/ScreenSpinner/Icon48DoneOutline.d.ts.map +1 -1
  1401. package/dist/cssm/components/ScreenSpinner/Icon48DoneOutline.js.map +1 -1
  1402. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  1403. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.module.css +1 -1
  1404. package/dist/cssm/components/ScrollArrow/ScrollArrow.js.map +1 -1
  1405. package/dist/cssm/components/ScrollArrow/ScrollArrow.module.css +1 -1
  1406. package/dist/cssm/components/Search/Search.js.map +1 -1
  1407. package/dist/cssm/components/Search/Search.module.css +4 -1
  1408. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  1409. package/dist/cssm/components/SegmentedControl/SegmentedControl.module.css +3 -1
  1410. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  1411. package/dist/cssm/components/Select/Select.d.ts.map +1 -1
  1412. package/dist/cssm/components/Select/Select.js.map +1 -1
  1413. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  1414. package/dist/cssm/components/SelectTypography/SelectTypography.js.map +1 -1
  1415. package/dist/cssm/components/Separator/Separator.js.map +1 -1
  1416. package/dist/cssm/components/SimpleCell/Chevron/Chevron.js.map +1 -1
  1417. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  1418. package/dist/cssm/components/Skeleton/Skeleton.js.map +1 -1
  1419. package/dist/cssm/components/Skeleton/Skeleton.module.css +7 -0
  1420. package/dist/cssm/components/Slider/Slider.d.ts.map +1 -1
  1421. package/dist/cssm/components/Slider/Slider.js +7 -2
  1422. package/dist/cssm/components/Slider/Slider.js.map +1 -1
  1423. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.d.ts +2 -1
  1424. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.d.ts.map +1 -1
  1425. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.js +4 -4
  1426. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
  1427. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.module.css +10 -2
  1428. package/dist/cssm/components/Slider/helpers.d.ts.map +1 -1
  1429. package/dist/cssm/components/Slider/helpers.js.map +1 -1
  1430. package/dist/cssm/components/Slider/types.js.map +1 -1
  1431. package/dist/cssm/components/Snackbar/Snackbar.d.ts +1 -1
  1432. package/dist/cssm/components/Snackbar/Snackbar.d.ts.map +1 -1
  1433. package/dist/cssm/components/Snackbar/Snackbar.js +11 -10
  1434. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  1435. package/dist/cssm/components/Snackbar/Snackbar.module.css +72 -112
  1436. package/dist/cssm/components/Snackbar/subcomponents/Basic/Basic.js.map +1 -1
  1437. package/dist/cssm/components/Snackbar/types.js.map +1 -1
  1438. package/dist/cssm/components/Snackbar/utils.d.ts +0 -1
  1439. package/dist/cssm/components/Snackbar/utils.d.ts.map +1 -1
  1440. package/dist/cssm/components/Snackbar/utils.js.map +1 -1
  1441. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  1442. package/dist/cssm/components/Spacing/Spacing.module.css +1 -0
  1443. package/dist/cssm/components/Spinner/Spinner.d.ts.map +1 -1
  1444. package/dist/cssm/components/Spinner/Spinner.js +37 -18
  1445. package/dist/cssm/components/Spinner/Spinner.js.map +1 -1
  1446. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  1447. package/dist/cssm/components/SplitCol/SplitColContext.js.map +1 -1
  1448. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  1449. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  1450. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  1451. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.module.css +1 -1
  1452. package/dist/cssm/components/Switch/Switch.d.ts +1 -1
  1453. package/dist/cssm/components/Switch/Switch.d.ts.map +1 -1
  1454. package/dist/cssm/components/Switch/Switch.js +37 -19
  1455. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  1456. package/dist/cssm/components/Switch/Switch.module.css +198 -142
  1457. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  1458. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  1459. package/dist/cssm/components/Tabs/Tabs.js.map +1 -1
  1460. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  1461. package/dist/cssm/components/TabsItem/TabsItem.module.css +4 -2
  1462. package/dist/cssm/components/Tappable/Ripple.d.ts.map +1 -1
  1463. package/dist/cssm/components/Tappable/Ripple.js +10 -3
  1464. package/dist/cssm/components/Tappable/Ripple.js.map +1 -1
  1465. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  1466. package/dist/cssm/components/Tappable/Tappable.module.css +0 -2
  1467. package/dist/cssm/components/Tappable/state.js.map +1 -1
  1468. package/dist/cssm/components/Textarea/Textarea.d.ts.map +1 -1
  1469. package/dist/cssm/components/Textarea/Textarea.js +7 -19
  1470. package/dist/cssm/components/Textarea/Textarea.js.map +1 -1
  1471. package/dist/cssm/components/Textarea/useResizeTextarea.d.ts +3 -0
  1472. package/dist/cssm/components/Textarea/useResizeTextarea.d.ts.map +1 -0
  1473. package/dist/cssm/components/Textarea/useResizeTextarea.js +34 -0
  1474. package/dist/cssm/components/Textarea/useResizeTextarea.js.map +1 -0
  1475. package/dist/cssm/components/ToolButton/ToolButton.js.map +1 -1
  1476. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  1477. package/dist/cssm/components/TooltipBase/TooltipBase.js.map +1 -1
  1478. package/dist/cssm/components/TooltipBase/TooltipBase.module.css +2 -2
  1479. package/dist/cssm/components/Touch/Touch.js.map +1 -1
  1480. package/dist/cssm/components/Touch/TouchContext.js.map +1 -1
  1481. package/dist/cssm/components/Typography/Caption/Caption.d.ts +1 -1
  1482. package/dist/cssm/components/Typography/Caption/Caption.d.ts.map +1 -1
  1483. package/dist/cssm/components/Typography/Caption/Caption.js +2 -1
  1484. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  1485. package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.d.ts +11 -0
  1486. package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.d.ts.map +1 -0
  1487. package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.js +25 -0
  1488. package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.js.map +1 -0
  1489. package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.module.css +27 -0
  1490. package/dist/cssm/components/Typography/EllipsisText/EllipsisText.js.map +1 -1
  1491. package/dist/cssm/components/Typography/Footnote/Footnote.d.ts +1 -1
  1492. package/dist/cssm/components/Typography/Footnote/Footnote.d.ts.map +1 -1
  1493. package/dist/cssm/components/Typography/Footnote/Footnote.js +2 -1
  1494. package/dist/cssm/components/Typography/Footnote/Footnote.js.map +1 -1
  1495. package/dist/cssm/components/Typography/Headline/Headline.d.ts +1 -1
  1496. package/dist/cssm/components/Typography/Headline/Headline.d.ts.map +1 -1
  1497. package/dist/cssm/components/Typography/Headline/Headline.js +2 -1
  1498. package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
  1499. package/dist/cssm/components/Typography/Paragraph/Paragraph.d.ts +1 -1
  1500. package/dist/cssm/components/Typography/Paragraph/Paragraph.d.ts.map +1 -1
  1501. package/dist/cssm/components/Typography/Paragraph/Paragraph.js +2 -1
  1502. package/dist/cssm/components/Typography/Paragraph/Paragraph.js.map +1 -1
  1503. package/dist/cssm/components/Typography/Subhead/Subhead.d.ts +1 -1
  1504. package/dist/cssm/components/Typography/Subhead/Subhead.d.ts.map +1 -1
  1505. package/dist/cssm/components/Typography/Subhead/Subhead.js +2 -1
  1506. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  1507. package/dist/cssm/components/Typography/Text/Text.d.ts +1 -1
  1508. package/dist/cssm/components/Typography/Text/Text.d.ts.map +1 -1
  1509. package/dist/cssm/components/Typography/Text/Text.js +2 -1
  1510. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  1511. package/dist/cssm/components/Typography/Title/Title.d.ts +1 -1
  1512. package/dist/cssm/components/Typography/Title/Title.d.ts.map +1 -1
  1513. package/dist/cssm/components/Typography/Title/Title.js +2 -1
  1514. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  1515. package/dist/cssm/components/Typography/Typography.d.ts +5 -1
  1516. package/dist/cssm/components/Typography/Typography.d.ts.map +1 -1
  1517. package/dist/cssm/components/Typography/Typography.js +2 -2
  1518. package/dist/cssm/components/Typography/Typography.js.map +1 -1
  1519. package/dist/cssm/components/Typography/Typography.module.css +4 -0
  1520. package/dist/cssm/components/UnstyledTextField/UnstyledTextField.js.map +1 -1
  1521. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  1522. package/dist/cssm/components/View/View.d.ts.map +1 -1
  1523. package/dist/cssm/components/View/View.js +36 -49
  1524. package/dist/cssm/components/View/View.js.map +1 -1
  1525. package/dist/cssm/components/View/View.module.css +105 -83
  1526. package/dist/cssm/components/View/ViewInfinite.d.ts.map +1 -1
  1527. package/dist/cssm/components/View/ViewInfinite.js +17 -19
  1528. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  1529. package/dist/cssm/components/View/utils.js.map +1 -1
  1530. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.d.ts.map +1 -1
  1531. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.js.map +1 -1
  1532. package/dist/cssm/components/WriteBar/WriteBar.d.ts.map +1 -1
  1533. package/dist/cssm/components/WriteBar/WriteBar.js +3 -19
  1534. package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
  1535. package/dist/cssm/components/WriteBar/WriteBar.module.css +1 -1
  1536. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1537. package/dist/cssm/helpers/avatar.js.map +1 -1
  1538. package/dist/cssm/helpers/getMergedSameEventsByProps.d.ts +1 -1
  1539. package/dist/cssm/helpers/getMergedSameEventsByProps.d.ts.map +1 -1
  1540. package/dist/cssm/helpers/getMergedSameEventsByProps.js.map +1 -1
  1541. package/dist/cssm/helpers/getOrDefault.js.map +1 -1
  1542. package/dist/cssm/helpers/math.js.map +1 -1
  1543. package/dist/cssm/helpers/range.js.map +1 -1
  1544. package/dist/cssm/hoc/withContext.js.map +1 -1
  1545. package/dist/cssm/hoc/withPlatform.js.map +1 -1
  1546. package/dist/cssm/hooks/useAdaptivity.js.map +1 -1
  1547. package/dist/cssm/hooks/useAdaptivityConditionalRender/constants.js.map +1 -1
  1548. package/dist/cssm/hooks/useAdaptivityConditionalRender/helpers.d.ts +3 -3
  1549. package/dist/cssm/hooks/useAdaptivityConditionalRender/helpers.d.ts.map +1 -1
  1550. package/dist/cssm/hooks/useAdaptivityConditionalRender/helpers.js.map +1 -1
  1551. package/dist/cssm/hooks/useAdaptivityConditionalRender/index.js.map +1 -1
  1552. package/dist/cssm/hooks/useAdaptivityConditionalRender/types.js.map +1 -1
  1553. package/dist/cssm/hooks/useAdaptivityConditionalRender/useAdaptivityConditionalRender.js.map +1 -1
  1554. package/dist/cssm/hooks/useAdaptivityHasPointer.js.map +1 -1
  1555. package/dist/cssm/hooks/useAdaptivityWithJSMediaQueries.js.map +1 -1
  1556. package/dist/cssm/hooks/useAppearance.js.map +1 -1
  1557. package/dist/cssm/hooks/useAutoDetectAppearance.js.map +1 -1
  1558. package/dist/cssm/hooks/useAutoFocus.js.map +1 -1
  1559. package/dist/cssm/hooks/useBooleanState.js.map +1 -1
  1560. package/dist/cssm/hooks/useCalendar.d.ts +2 -0
  1561. package/dist/cssm/hooks/useCalendar.d.ts.map +1 -1
  1562. package/dist/cssm/hooks/useCalendar.js +44 -2
  1563. package/dist/cssm/hooks/useCalendar.js.map +1 -1
  1564. package/dist/cssm/hooks/useDateInput.d.ts.map +1 -1
  1565. package/dist/cssm/hooks/useDateInput.js.map +1 -1
  1566. package/dist/cssm/hooks/useDirection.js.map +1 -1
  1567. package/dist/cssm/hooks/useDraggableWithDomApi/autoScroll.js.map +1 -1
  1568. package/dist/cssm/hooks/useDraggableWithDomApi/constants.js.map +1 -1
  1569. package/dist/cssm/hooks/useDraggableWithDomApi/index.js.map +1 -1
  1570. package/dist/cssm/hooks/useDraggableWithDomApi/types.js.map +1 -1
  1571. package/dist/cssm/hooks/useDraggableWithDomApi/useDraggableWithDomApi.d.ts.map +1 -1
  1572. package/dist/cssm/hooks/useDraggableWithDomApi/useDraggableWithDomApi.js.map +1 -1
  1573. package/dist/cssm/hooks/useDraggableWithDomApi/utils.d.ts +2 -2
  1574. package/dist/cssm/hooks/useDraggableWithDomApi/utils.d.ts.map +1 -1
  1575. package/dist/cssm/hooks/useDraggableWithDomApi/utils.js.map +1 -1
  1576. package/dist/cssm/hooks/useEffectDev.js.map +1 -1
  1577. package/dist/cssm/hooks/useEnsuredControl.js +1 -1
  1578. package/dist/cssm/hooks/useEnsuredControl.js.map +1 -1
  1579. package/dist/cssm/hooks/useEventListener.js.map +1 -1
  1580. package/dist/cssm/hooks/useExternRef.js.map +1 -1
  1581. package/dist/cssm/hooks/useFocusVisible.d.ts.map +1 -1
  1582. package/dist/cssm/hooks/useFocusVisible.js.map +1 -1
  1583. package/dist/cssm/hooks/useFocusVisibleClassName.js.map +1 -1
  1584. package/dist/cssm/hooks/useFocusWithin.js.map +1 -1
  1585. package/dist/cssm/hooks/useGlobalEscKeyDown.js.map +1 -1
  1586. package/dist/cssm/hooks/useGlobalEventListener.js.map +1 -1
  1587. package/dist/cssm/hooks/useGlobalOnClickOutside.d.ts +1 -1
  1588. package/dist/cssm/hooks/useGlobalOnClickOutside.d.ts.map +1 -1
  1589. package/dist/cssm/hooks/useGlobalOnClickOutside.js.map +1 -1
  1590. package/dist/cssm/hooks/useIsClient.js.map +1 -1
  1591. package/dist/cssm/hooks/useKeyboard.js.map +1 -1
  1592. package/dist/cssm/hooks/useKeyboardInputTracker.js.map +1 -1
  1593. package/dist/cssm/hooks/useMediaQueries.d.ts.map +1 -1
  1594. package/dist/cssm/hooks/useMediaQueries.js +21 -18
  1595. package/dist/cssm/hooks/useMediaQueries.js.map +1 -1
  1596. package/dist/cssm/hooks/useNativeFormResetListener.d.ts.map +1 -1
  1597. package/dist/cssm/hooks/useNativeFormResetListener.js.map +1 -1
  1598. package/dist/cssm/hooks/useObjectMemo.js.map +1 -1
  1599. package/dist/cssm/hooks/useOrientationChange.js.map +1 -1
  1600. package/dist/cssm/hooks/usePagination.d.ts.map +1 -1
  1601. package/dist/cssm/hooks/usePagination.js.map +1 -1
  1602. package/dist/cssm/hooks/usePatchChildren.d.ts.map +1 -1
  1603. package/dist/cssm/hooks/usePatchChildren.js.map +1 -1
  1604. package/dist/cssm/hooks/usePlatform.js.map +1 -1
  1605. package/dist/cssm/hooks/usePrevious.js.map +1 -1
  1606. package/dist/cssm/hooks/useResizeObserver.d.ts +1 -1
  1607. package/dist/cssm/hooks/useResizeObserver.d.ts.map +1 -1
  1608. package/dist/cssm/hooks/useResizeObserver.js +5 -4
  1609. package/dist/cssm/hooks/useResizeObserver.js.map +1 -1
  1610. package/dist/cssm/hooks/useStableCallback.js.map +1 -1
  1611. package/dist/cssm/hooks/useTodayDate.js.map +1 -1
  1612. package/dist/cssm/hooks/useWaitTransitionFinish.d.ts +1 -3
  1613. package/dist/cssm/hooks/useWaitTransitionFinish.d.ts.map +1 -1
  1614. package/dist/cssm/hooks/useWaitTransitionFinish.js +4 -9
  1615. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  1616. package/dist/cssm/index.d.ts +7 -1
  1617. package/dist/cssm/index.d.ts.map +1 -1
  1618. package/dist/cssm/index.js +3 -0
  1619. package/dist/cssm/index.js.map +1 -1
  1620. package/dist/cssm/lib/SSR.js.map +1 -1
  1621. package/dist/cssm/lib/accessibility.d.ts +1 -1
  1622. package/dist/cssm/lib/accessibility.d.ts.map +1 -1
  1623. package/dist/cssm/lib/accessibility.js +1 -0
  1624. package/dist/cssm/lib/accessibility.js.map +1 -1
  1625. package/dist/cssm/lib/adaptivity/constants.js.map +1 -1
  1626. package/dist/cssm/lib/adaptivity/functions.js.map +1 -1
  1627. package/dist/cssm/lib/adaptivity/index.js.map +1 -1
  1628. package/dist/cssm/lib/adaptivity/types.js.map +1 -1
  1629. package/dist/cssm/lib/animate.js.map +1 -1
  1630. package/dist/cssm/lib/animation/fades.js.map +1 -1
  1631. package/dist/cssm/lib/animation/index.d.ts +1 -0
  1632. package/dist/cssm/lib/animation/index.d.ts.map +1 -1
  1633. package/dist/cssm/lib/animation/index.js +1 -0
  1634. package/dist/cssm/lib/animation/index.js.map +1 -1
  1635. package/dist/cssm/lib/animation/rubberbandIfOutOfBounds.js.map +1 -1
  1636. package/dist/cssm/lib/animation/transformOrigin.js.map +1 -1
  1637. package/dist/cssm/lib/animation/useCSSKeyframesAnimationController.d.ts +1 -1
  1638. package/dist/cssm/lib/animation/useCSSKeyframesAnimationController.d.ts.map +1 -1
  1639. package/dist/cssm/lib/animation/useCSSKeyframesAnimationController.js +5 -6
  1640. package/dist/cssm/lib/animation/useCSSKeyframesAnimationController.js.map +1 -1
  1641. package/dist/cssm/lib/animation/useReducedMotion.js.map +1 -1
  1642. package/dist/cssm/lib/appearance/index.js.map +1 -1
  1643. package/dist/cssm/lib/appearance/types.js.map +1 -1
  1644. package/dist/cssm/lib/browser.js.map +1 -1
  1645. package/dist/cssm/lib/calendar.js.map +1 -1
  1646. package/dist/cssm/lib/callMultiple.js.map +1 -1
  1647. package/dist/cssm/lib/children.d.ts.map +1 -1
  1648. package/dist/cssm/lib/children.js.map +1 -1
  1649. package/dist/cssm/lib/comparing.js.map +1 -1
  1650. package/dist/cssm/lib/createPortal.d.ts.map +1 -1
  1651. package/dist/cssm/lib/createPortal.js.map +1 -1
  1652. package/dist/cssm/lib/date.js.map +1 -1
  1653. package/dist/cssm/lib/dom.d.ts +0 -1
  1654. package/dist/cssm/lib/dom.d.ts.map +1 -1
  1655. package/dist/cssm/lib/dom.js.map +1 -1
  1656. package/dist/cssm/lib/floating/adapters.js.map +1 -1
  1657. package/dist/cssm/lib/floating/customResizeObserver.js.map +1 -1
  1658. package/dist/cssm/lib/floating/functions.d.ts +1 -1
  1659. package/dist/cssm/lib/floating/functions.js.map +1 -1
  1660. package/dist/cssm/lib/floating/index.js.map +1 -1
  1661. package/dist/cssm/lib/floating/types/common.js.map +1 -1
  1662. package/dist/cssm/lib/floating/types/component.js.map +1 -1
  1663. package/dist/cssm/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts +1 -11
  1664. package/dist/cssm/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts.map +1 -1
  1665. package/dist/cssm/lib/floating/useFloatingMiddlewaresBootstrap/index.js.map +1 -1
  1666. package/dist/cssm/lib/floating/useFloatingWithInteractions/constants.js.map +1 -1
  1667. package/dist/cssm/lib/floating/useFloatingWithInteractions/index.js.map +1 -1
  1668. package/dist/cssm/lib/floating/useFloatingWithInteractions/types.d.ts +0 -1
  1669. package/dist/cssm/lib/floating/useFloatingWithInteractions/types.d.ts.map +1 -1
  1670. package/dist/cssm/lib/floating/useFloatingWithInteractions/types.js.map +1 -1
  1671. package/dist/cssm/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.d.ts.map +1 -1
  1672. package/dist/cssm/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
  1673. package/dist/cssm/lib/floating/useFloatingWithInteractions/useResolveTriggerType.js.map +1 -1
  1674. package/dist/cssm/lib/floating/usePlacementChangeCallback.js.map +1 -1
  1675. package/dist/cssm/lib/fx.js.map +1 -1
  1676. package/dist/cssm/lib/getNavId.js.map +1 -1
  1677. package/dist/cssm/lib/isRefObject.d.ts.map +1 -1
  1678. package/dist/cssm/lib/isRefObject.js.map +1 -1
  1679. package/dist/cssm/lib/layouts/gaps.d.ts +32 -0
  1680. package/dist/cssm/lib/layouts/gaps.d.ts.map +1 -0
  1681. package/dist/cssm/lib/layouts/gaps.js +42 -0
  1682. package/dist/cssm/lib/layouts/gaps.js.map +1 -0
  1683. package/dist/cssm/lib/layouts/index.d.ts +2 -0
  1684. package/dist/cssm/lib/layouts/index.d.ts.map +1 -0
  1685. package/dist/cssm/lib/layouts/index.js +3 -0
  1686. package/dist/cssm/lib/layouts/index.js.map +1 -0
  1687. package/dist/cssm/lib/matchMedia.js.map +1 -1
  1688. package/dist/cssm/lib/mergeCalls.js.map +1 -1
  1689. package/dist/cssm/lib/offset.js.map +1 -1
  1690. package/dist/cssm/lib/platform.js.map +1 -1
  1691. package/dist/cssm/lib/rafSchd.d.ts.map +1 -1
  1692. package/dist/cssm/lib/rafSchd.js.map +1 -1
  1693. package/dist/cssm/lib/react/index.js.map +1 -1
  1694. package/dist/cssm/lib/react/simulateReactInput.js.map +1 -1
  1695. package/dist/cssm/lib/removeObjectKeys.js.map +1 -1
  1696. package/dist/cssm/lib/select.js.map +1 -1
  1697. package/dist/cssm/lib/styles.js.map +1 -1
  1698. package/dist/cssm/lib/testing.js.map +1 -1
  1699. package/dist/cssm/lib/tokens/TokensClassProvider.d.ts.map +1 -1
  1700. package/dist/cssm/lib/tokens/TokensClassProvider.js +2 -1
  1701. package/dist/cssm/lib/tokens/TokensClassProvider.js.map +1 -1
  1702. package/dist/cssm/lib/tokens/TokensClassProvider.module.css +4 -0
  1703. package/dist/cssm/lib/tokens/constants.js.map +1 -1
  1704. package/dist/cssm/lib/tokens/index.js.map +1 -1
  1705. package/dist/cssm/lib/tokens/types.js.map +1 -1
  1706. package/dist/cssm/lib/tokens/useTokenClassName.js.map +1 -1
  1707. package/dist/cssm/lib/touch/UIPanGestureRecognizer.js.map +1 -1
  1708. package/dist/cssm/lib/touch/functions.js.map +1 -1
  1709. package/dist/cssm/lib/touch/index.js.map +1 -1
  1710. package/dist/cssm/lib/useIsomorphicLayoutEffect.js.map +1 -1
  1711. package/dist/cssm/lib/utils.d.ts +1 -1
  1712. package/dist/cssm/lib/utils.d.ts.map +1 -1
  1713. package/dist/cssm/lib/utils.js.map +1 -1
  1714. package/dist/cssm/lib/warnOnce.js.map +1 -1
  1715. package/dist/cssm/shared/breakpoints.d.js +5 -0
  1716. package/dist/cssm/shared/breakpoints.d.js.map +1 -0
  1717. package/dist/cssm/shared/breakpoints.js.map +1 -1
  1718. package/dist/cssm/styles/animationFades.module.css +7 -13
  1719. package/dist/cssm/styles/constants.css +4 -0
  1720. package/dist/cssm/styles/customMedias.generated.css +1 -0
  1721. package/dist/cssm/styles/focusVisible.module.css +10 -26
  1722. package/dist/cssm/styles/gaps.module.css +75 -0
  1723. package/dist/cssm/styles/themes.css +45 -31
  1724. package/dist/cssm/types.d.ts +1 -0
  1725. package/dist/cssm/types.d.ts.map +1 -1
  1726. package/dist/cssm/types.js.map +1 -1
  1727. package/dist/cssm/vkui.js.map +1 -1
  1728. package/dist/helpers/avatar.js.map +1 -1
  1729. package/dist/helpers/getMergedSameEventsByProps.d.ts +1 -1
  1730. package/dist/helpers/getMergedSameEventsByProps.d.ts.map +1 -1
  1731. package/dist/helpers/getMergedSameEventsByProps.js.map +1 -1
  1732. package/dist/helpers/getOrDefault.js.map +1 -1
  1733. package/dist/helpers/math.js.map +1 -1
  1734. package/dist/helpers/range.js.map +1 -1
  1735. package/dist/hoc/withContext.js.map +1 -1
  1736. package/dist/hoc/withPlatform.js.map +1 -1
  1737. package/dist/hooks/useAdaptivity.js.map +1 -1
  1738. package/dist/hooks/useAdaptivityConditionalRender/constants.js.map +1 -1
  1739. package/dist/hooks/useAdaptivityConditionalRender/helpers.d.ts +3 -3
  1740. package/dist/hooks/useAdaptivityConditionalRender/helpers.d.ts.map +1 -1
  1741. package/dist/hooks/useAdaptivityConditionalRender/helpers.js.map +1 -1
  1742. package/dist/hooks/useAdaptivityConditionalRender/index.js.map +1 -1
  1743. package/dist/hooks/useAdaptivityConditionalRender/types.js.map +1 -1
  1744. package/dist/hooks/useAdaptivityConditionalRender/useAdaptivityConditionalRender.js.map +1 -1
  1745. package/dist/hooks/useAdaptivityHasPointer.js.map +1 -1
  1746. package/dist/hooks/useAdaptivityWithJSMediaQueries.js.map +1 -1
  1747. package/dist/hooks/useAppearance.js.map +1 -1
  1748. package/dist/hooks/useAutoDetectAppearance.js.map +1 -1
  1749. package/dist/hooks/useAutoFocus.js.map +1 -1
  1750. package/dist/hooks/useBooleanState.js.map +1 -1
  1751. package/dist/hooks/useCalendar.d.ts +2 -0
  1752. package/dist/hooks/useCalendar.d.ts.map +1 -1
  1753. package/dist/hooks/useCalendar.js +44 -2
  1754. package/dist/hooks/useCalendar.js.map +1 -1
  1755. package/dist/hooks/useDateInput.d.ts.map +1 -1
  1756. package/dist/hooks/useDateInput.js.map +1 -1
  1757. package/dist/hooks/useDirection.js.map +1 -1
  1758. package/dist/hooks/useDraggableWithDomApi/autoScroll.js.map +1 -1
  1759. package/dist/hooks/useDraggableWithDomApi/constants.js.map +1 -1
  1760. package/dist/hooks/useDraggableWithDomApi/index.js.map +1 -1
  1761. package/dist/hooks/useDraggableWithDomApi/types.js.map +1 -1
  1762. package/dist/hooks/useDraggableWithDomApi/useDraggableWithDomApi.d.ts.map +1 -1
  1763. package/dist/hooks/useDraggableWithDomApi/useDraggableWithDomApi.js.map +1 -1
  1764. package/dist/hooks/useDraggableWithDomApi/utils.d.ts +2 -2
  1765. package/dist/hooks/useDraggableWithDomApi/utils.d.ts.map +1 -1
  1766. package/dist/hooks/useDraggableWithDomApi/utils.js.map +1 -1
  1767. package/dist/hooks/useEffectDev.js.map +1 -1
  1768. package/dist/hooks/useEnsuredControl.js +1 -1
  1769. package/dist/hooks/useEnsuredControl.js.map +1 -1
  1770. package/dist/hooks/useEventListener.js.map +1 -1
  1771. package/dist/hooks/useExternRef.js.map +1 -1
  1772. package/dist/hooks/useFocusVisible.d.ts.map +1 -1
  1773. package/dist/hooks/useFocusVisible.js.map +1 -1
  1774. package/dist/hooks/useFocusVisibleClassName.js.map +1 -1
  1775. package/dist/hooks/useFocusWithin.js.map +1 -1
  1776. package/dist/hooks/useGlobalEscKeyDown.js.map +1 -1
  1777. package/dist/hooks/useGlobalEventListener.js.map +1 -1
  1778. package/dist/hooks/useGlobalOnClickOutside.d.ts +1 -1
  1779. package/dist/hooks/useGlobalOnClickOutside.d.ts.map +1 -1
  1780. package/dist/hooks/useGlobalOnClickOutside.js.map +1 -1
  1781. package/dist/hooks/useIsClient.js.map +1 -1
  1782. package/dist/hooks/useKeyboard.js.map +1 -1
  1783. package/dist/hooks/useKeyboardInputTracker.js.map +1 -1
  1784. package/dist/hooks/useMediaQueries.d.ts.map +1 -1
  1785. package/dist/hooks/useMediaQueries.js +21 -18
  1786. package/dist/hooks/useMediaQueries.js.map +1 -1
  1787. package/dist/hooks/useNativeFormResetListener.d.ts.map +1 -1
  1788. package/dist/hooks/useNativeFormResetListener.js.map +1 -1
  1789. package/dist/hooks/useObjectMemo.js.map +1 -1
  1790. package/dist/hooks/useOrientationChange.js.map +1 -1
  1791. package/dist/hooks/usePagination.d.ts.map +1 -1
  1792. package/dist/hooks/usePagination.js.map +1 -1
  1793. package/dist/hooks/usePatchChildren.d.ts.map +1 -1
  1794. package/dist/hooks/usePatchChildren.js.map +1 -1
  1795. package/dist/hooks/usePlatform.js.map +1 -1
  1796. package/dist/hooks/usePrevious.js.map +1 -1
  1797. package/dist/hooks/useResizeObserver.d.ts +1 -1
  1798. package/dist/hooks/useResizeObserver.d.ts.map +1 -1
  1799. package/dist/hooks/useResizeObserver.js +5 -4
  1800. package/dist/hooks/useResizeObserver.js.map +1 -1
  1801. package/dist/hooks/useStableCallback.js.map +1 -1
  1802. package/dist/hooks/useTodayDate.js.map +1 -1
  1803. package/dist/hooks/useWaitTransitionFinish.d.ts +1 -3
  1804. package/dist/hooks/useWaitTransitionFinish.d.ts.map +1 -1
  1805. package/dist/hooks/useWaitTransitionFinish.js +4 -9
  1806. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  1807. package/dist/index.d.ts +7 -1
  1808. package/dist/index.d.ts.map +1 -1
  1809. package/dist/index.js +2 -0
  1810. package/dist/index.js.map +1 -1
  1811. package/dist/lib/SSR.js.map +1 -1
  1812. package/dist/lib/accessibility.d.ts +1 -1
  1813. package/dist/lib/accessibility.d.ts.map +1 -1
  1814. package/dist/lib/accessibility.js +1 -0
  1815. package/dist/lib/accessibility.js.map +1 -1
  1816. package/dist/lib/adaptivity/constants.js.map +1 -1
  1817. package/dist/lib/adaptivity/functions.js.map +1 -1
  1818. package/dist/lib/adaptivity/index.js.map +1 -1
  1819. package/dist/lib/adaptivity/types.js.map +1 -1
  1820. package/dist/lib/animate.js.map +1 -1
  1821. package/dist/lib/animation/fades.js.map +1 -1
  1822. package/dist/lib/animation/index.d.ts +1 -0
  1823. package/dist/lib/animation/index.d.ts.map +1 -1
  1824. package/dist/lib/animation/index.js +1 -0
  1825. package/dist/lib/animation/index.js.map +1 -1
  1826. package/dist/lib/animation/rubberbandIfOutOfBounds.js.map +1 -1
  1827. package/dist/lib/animation/transformOrigin.js.map +1 -1
  1828. package/dist/lib/animation/useCSSKeyframesAnimationController.d.ts +1 -1
  1829. package/dist/lib/animation/useCSSKeyframesAnimationController.d.ts.map +1 -1
  1830. package/dist/lib/animation/useCSSKeyframesAnimationController.js +5 -6
  1831. package/dist/lib/animation/useCSSKeyframesAnimationController.js.map +1 -1
  1832. package/dist/lib/animation/useReducedMotion.js.map +1 -1
  1833. package/dist/lib/appearance/index.js.map +1 -1
  1834. package/dist/lib/appearance/types.js.map +1 -1
  1835. package/dist/lib/browser.js.map +1 -1
  1836. package/dist/lib/calendar.js.map +1 -1
  1837. package/dist/lib/callMultiple.js.map +1 -1
  1838. package/dist/lib/children.d.ts.map +1 -1
  1839. package/dist/lib/children.js.map +1 -1
  1840. package/dist/lib/comparing.js.map +1 -1
  1841. package/dist/lib/createPortal.d.ts.map +1 -1
  1842. package/dist/lib/createPortal.js.map +1 -1
  1843. package/dist/lib/date.js.map +1 -1
  1844. package/dist/lib/dom.d.ts +0 -1
  1845. package/dist/lib/dom.d.ts.map +1 -1
  1846. package/dist/lib/dom.js.map +1 -1
  1847. package/dist/lib/floating/adapters.js.map +1 -1
  1848. package/dist/lib/floating/customResizeObserver.js.map +1 -1
  1849. package/dist/lib/floating/functions.d.ts +1 -1
  1850. package/dist/lib/floating/functions.js.map +1 -1
  1851. package/dist/lib/floating/index.js.map +1 -1
  1852. package/dist/lib/floating/types/common.js.map +1 -1
  1853. package/dist/lib/floating/types/component.js.map +1 -1
  1854. package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts +1 -11
  1855. package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts.map +1 -1
  1856. package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.js.map +1 -1
  1857. package/dist/lib/floating/useFloatingWithInteractions/constants.js.map +1 -1
  1858. package/dist/lib/floating/useFloatingWithInteractions/index.js.map +1 -1
  1859. package/dist/lib/floating/useFloatingWithInteractions/types.d.ts +0 -1
  1860. package/dist/lib/floating/useFloatingWithInteractions/types.d.ts.map +1 -1
  1861. package/dist/lib/floating/useFloatingWithInteractions/types.js.map +1 -1
  1862. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.d.ts.map +1 -1
  1863. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
  1864. package/dist/lib/floating/useFloatingWithInteractions/useResolveTriggerType.js.map +1 -1
  1865. package/dist/lib/floating/usePlacementChangeCallback.js.map +1 -1
  1866. package/dist/lib/fx.js.map +1 -1
  1867. package/dist/lib/getNavId.js.map +1 -1
  1868. package/dist/lib/isRefObject.d.ts.map +1 -1
  1869. package/dist/lib/isRefObject.js.map +1 -1
  1870. package/dist/lib/layouts/gaps.d.ts +32 -0
  1871. package/dist/lib/layouts/gaps.d.ts.map +1 -0
  1872. package/dist/lib/layouts/gaps.js +41 -0
  1873. package/dist/lib/layouts/gaps.js.map +1 -0
  1874. package/dist/lib/layouts/index.d.ts +2 -0
  1875. package/dist/lib/layouts/index.d.ts.map +1 -0
  1876. package/dist/lib/layouts/index.js +3 -0
  1877. package/dist/lib/layouts/index.js.map +1 -0
  1878. package/dist/lib/matchMedia.js.map +1 -1
  1879. package/dist/lib/mergeCalls.js.map +1 -1
  1880. package/dist/lib/offset.js.map +1 -1
  1881. package/dist/lib/platform.js.map +1 -1
  1882. package/dist/lib/rafSchd.d.ts.map +1 -1
  1883. package/dist/lib/rafSchd.js.map +1 -1
  1884. package/dist/lib/react/index.js.map +1 -1
  1885. package/dist/lib/react/simulateReactInput.js.map +1 -1
  1886. package/dist/lib/removeObjectKeys.js.map +1 -1
  1887. package/dist/lib/select.js.map +1 -1
  1888. package/dist/lib/styles.js.map +1 -1
  1889. package/dist/lib/testing.js.map +1 -1
  1890. package/dist/lib/tokens/TokensClassProvider.d.ts.map +1 -1
  1891. package/dist/lib/tokens/TokensClassProvider.js +1 -1
  1892. package/dist/lib/tokens/TokensClassProvider.js.map +1 -1
  1893. package/dist/lib/tokens/constants.js.map +1 -1
  1894. package/dist/lib/tokens/index.js.map +1 -1
  1895. package/dist/lib/tokens/types.js.map +1 -1
  1896. package/dist/lib/tokens/useTokenClassName.js.map +1 -1
  1897. package/dist/lib/touch/UIPanGestureRecognizer.js.map +1 -1
  1898. package/dist/lib/touch/functions.js.map +1 -1
  1899. package/dist/lib/touch/index.js.map +1 -1
  1900. package/dist/lib/useIsomorphicLayoutEffect.js.map +1 -1
  1901. package/dist/lib/utils.d.ts +1 -1
  1902. package/dist/lib/utils.d.ts.map +1 -1
  1903. package/dist/lib/utils.js.map +1 -1
  1904. package/dist/lib/warnOnce.js.map +1 -1
  1905. package/dist/shared/breakpoints.d.js +5 -0
  1906. package/dist/shared/breakpoints.d.js.map +1 -0
  1907. package/dist/shared/breakpoints.js.map +1 -1
  1908. package/dist/types.d.ts +1 -0
  1909. package/dist/types.d.ts.map +1 -1
  1910. package/dist/types.js.map +1 -1
  1911. package/dist/vkui.css +3 -154
  1912. package/dist/vkui.css.map +1 -1
  1913. package/dist/vkui.js.map +1 -1
  1914. package/dist/vkui.js.tmp +26927 -70749
  1915. package/package.json +3 -3
  1916. package/src/components/Accordion/Accordion.module.css +91 -2
  1917. package/src/components/Accordion/AccordionContent.tsx +41 -46
  1918. package/src/components/ActionSheet/ActionSheet.module.css +42 -11
  1919. package/src/components/ActionSheet/ActionSheet.tsx +23 -27
  1920. package/src/components/ActionSheet/ActionSheetDropdownMenu.tsx +5 -0
  1921. package/src/components/ActionSheet/ActionSheetDropdownSheet.tsx +1 -1
  1922. package/src/components/ActionSheetItem/ActionSheetItem.module.css +3 -1
  1923. package/src/components/Alert/Alert.module.css +29 -19
  1924. package/src/components/Alert/Alert.tsx +25 -33
  1925. package/src/components/AppRoot/AppRoot.module.css +5 -5
  1926. package/src/components/AppRoot/AppRoot.tsx +30 -8
  1927. package/src/components/AppRoot/helpers.ts +33 -1
  1928. package/src/components/AppRoot/types.ts +2 -0
  1929. package/src/components/Button/Button.module.css +3 -6
  1930. package/src/components/Calendar/Calendar.module.css +1 -1
  1931. package/src/components/Calendar/Calendar.tsx +4 -0
  1932. package/src/components/CalendarHeader/CalendarHeader.tsx +32 -7
  1933. package/src/components/CalendarRange/CalendarRange.module.css +1 -1
  1934. package/src/components/CalendarRange/CalendarRange.tsx +13 -1
  1935. package/src/components/Card/Card.module.css +2 -2
  1936. package/src/components/ChipsInputBase/ChipsInputBase.tsx +2 -2
  1937. package/src/components/ChipsInputBase/constants.tsx +2 -2
  1938. package/src/components/ChipsSelect/ChipsSelect.tsx +23 -12
  1939. package/src/components/ChipsSelect/useChipsSelect.ts +21 -3
  1940. package/src/components/CustomScrollView/CustomScrollView.module.css +5 -1
  1941. package/src/components/CustomScrollView/useTrackerVisibility.ts +45 -32
  1942. package/src/components/CustomSelect/CustomSelect.tsx +16 -8
  1943. package/src/components/CustomSelectDropdown/CustomSelectDropdown.module.css +1 -1
  1944. package/src/components/CustomSelectOption/CustomSelectOption.module.css +1 -0
  1945. package/src/components/DatePicker/DatePicker.tsx +6 -0
  1946. package/src/components/FixedLayout/FixedLayout.tsx +23 -5
  1947. package/src/components/Flex/Flex.module.css +89 -0
  1948. package/src/components/Flex/Flex.tsx +113 -0
  1949. package/src/components/Flex/FlexItem/FlexItem.module.css +43 -0
  1950. package/src/components/Flex/FlexItem/FlexItem.tsx +60 -0
  1951. package/src/components/FloatingArrow/FloatingArrow.tsx +16 -4
  1952. package/src/components/FocusTrap/FocusTrap.tsx +52 -24
  1953. package/src/components/Gallery/hooks.ts +27 -19
  1954. package/src/components/GridAvatar/GridAvatar.tsx +1 -1
  1955. package/src/components/Header/Header.module.css +0 -1
  1956. package/src/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.module.css +2 -2
  1957. package/src/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.module.css +10 -0
  1958. package/src/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.tsx +89 -65
  1959. package/src/components/ImageBase/ImageBaseOverlay/hooks.ts +26 -0
  1960. package/src/components/ImageBase/ImageBaseOverlay/types.ts +58 -0
  1961. package/src/components/Link/Link.module.css +1 -2
  1962. package/src/components/Link/Link.tsx +1 -0
  1963. package/src/components/ModalDismissButton/ModalDismissButton.module.css +5 -6
  1964. package/src/components/ModalRoot/ModalRoot.tsx +4 -8
  1965. package/src/components/ModalRoot/ModalRootDesktop.tsx +2 -1
  1966. package/src/components/PanelHeaderContext/PanelHeaderContext.module.css +34 -30
  1967. package/src/components/PanelHeaderContext/PanelHeaderContext.tsx +35 -49
  1968. package/src/components/PopoutRoot/PopoutRoot.tsx +0 -7
  1969. package/src/components/PopoutWrapper/PopoutWrapper.module.css +15 -2
  1970. package/src/components/PopoutWrapper/PopoutWrapper.tsx +1 -19
  1971. package/src/components/Popover/Popover.module.css +6 -2
  1972. package/src/components/Popover/Popover.tsx +21 -4
  1973. package/src/components/PullToRefresh/PullToRefresh.module.css +3 -1
  1974. package/src/components/Removable/Removable.module.css +1 -6
  1975. package/src/components/Root/Root.module.css +44 -50
  1976. package/src/components/Root/Root.tsx +10 -20
  1977. package/src/components/ScreenSpinner/ScreenSpinner.module.css +1 -1
  1978. package/src/components/ScrollArrow/ScrollArrow.module.css +1 -1
  1979. package/src/components/Search/Search.module.css +3 -1
  1980. package/src/components/SegmentedControl/SegmentedControl.module.css +3 -1
  1981. package/src/components/Skeleton/Skeleton.module.css +7 -0
  1982. package/src/components/Slider/Slider.tsx +6 -1
  1983. package/src/components/Slider/SliderThumb/SliderThumb.module.css +10 -2
  1984. package/src/components/Slider/SliderThumb/SliderThumb.tsx +11 -3
  1985. package/src/components/Snackbar/Snackbar.module.css +73 -75
  1986. package/src/components/Snackbar/Snackbar.tsx +12 -10
  1987. package/src/components/Spacing/Spacing.module.css +1 -0
  1988. package/src/components/Spinner/Spinner.tsx +40 -22
  1989. package/src/components/SubnavigationButton/SubnavigationButton.module.css +1 -1
  1990. package/src/components/Switch/Switch.module.css +200 -141
  1991. package/src/components/Switch/Switch.tsx +43 -17
  1992. package/src/components/TabsItem/TabsItem.module.css +4 -2
  1993. package/src/components/Tappable/Ripple.tsx +11 -3
  1994. package/src/components/Tappable/Tappable.module.css +0 -2
  1995. package/src/components/Textarea/Textarea.tsx +5 -17
  1996. package/src/components/Textarea/useResizeTextarea.ts +35 -0
  1997. package/src/components/TooltipBase/TooltipBase.module.css +2 -2
  1998. package/src/components/Typography/Caption/Caption.tsx +2 -0
  1999. package/src/components/Typography/DisplayTitle/DisplayTitle.module.css +27 -0
  2000. package/src/components/Typography/DisplayTitle/DisplayTitle.tsx +38 -0
  2001. package/src/components/Typography/Footnote/Footnote.tsx +2 -0
  2002. package/src/components/Typography/Headline/Headline.tsx +2 -0
  2003. package/src/components/Typography/Paragraph/Paragraph.tsx +2 -0
  2004. package/src/components/Typography/Subhead/Subhead.tsx +2 -0
  2005. package/src/components/Typography/Text/Text.tsx +2 -0
  2006. package/src/components/Typography/Title/Title.tsx +2 -0
  2007. package/src/components/Typography/Typography.module.css +4 -0
  2008. package/src/components/Typography/Typography.tsx +6 -0
  2009. package/src/components/View/View.module.css +104 -82
  2010. package/src/components/View/View.tsx +51 -83
  2011. package/src/components/View/ViewInfinite.tsx +22 -37
  2012. package/src/components/WriteBar/WriteBar.module.css +1 -1
  2013. package/src/components/WriteBar/WriteBar.tsx +3 -19
  2014. package/src/hooks/useAdaptivityConditionalRender/helpers.ts +8 -8
  2015. package/src/hooks/useCalendar.ts +52 -1
  2016. package/src/hooks/useEnsuredControl.ts +1 -1
  2017. package/src/hooks/useMediaQueries.ts +23 -39
  2018. package/src/hooks/usePatchChildren.ts +2 -2
  2019. package/src/hooks/useResizeObserver.ts +5 -5
  2020. package/src/hooks/useWaitTransitionFinish.ts +4 -9
  2021. package/src/index.ts +7 -0
  2022. package/src/lib/accessibility.ts +1 -0
  2023. package/src/lib/animation/index.ts +1 -0
  2024. package/src/lib/animation/useCSSKeyframesAnimationController.ts +7 -5
  2025. package/src/lib/dom.tsx +2 -2
  2026. package/src/lib/layouts/gaps.ts +48 -0
  2027. package/src/lib/layouts/index.ts +7 -0
  2028. package/src/lib/tokens/TokensClassProvider.module.css +4 -0
  2029. package/src/lib/tokens/TokensClassProvider.tsx +6 -1
  2030. package/src/styles/animationFades.module.css +5 -13
  2031. package/src/styles/constants.css +4 -0
  2032. package/src/styles/customMedias.generated.css +3 -1
  2033. package/src/styles/focusVisible.module.css +10 -26
  2034. package/src/styles/gaps.module.css +75 -0
  2035. package/src/types.ts +2 -0
  2036. package/dist/cjs/hooks/useTimeout.d.ts +0 -5
  2037. package/dist/cjs/hooks/useTimeout.d.ts.map +0 -1
  2038. package/dist/cjs/hooks/useTimeout.js +0 -51
  2039. package/dist/cjs/hooks/useTimeout.js.map +0 -1
  2040. package/dist/cjs/lib/supportEvents.d.ts +0 -10
  2041. package/dist/cjs/lib/supportEvents.d.ts.map +0 -1
  2042. package/dist/cjs/lib/supportEvents.js +0 -43
  2043. package/dist/cjs/lib/supportEvents.js.map +0 -1
  2044. package/dist/cjs/shared/breakpoints.d.ts +0 -74
  2045. package/dist/cjs/shared/breakpoints.d.ts.map +0 -1
  2046. package/dist/cssm/hooks/useTimeout.d.ts +0 -5
  2047. package/dist/cssm/hooks/useTimeout.d.ts.map +0 -1
  2048. package/dist/cssm/hooks/useTimeout.js +0 -40
  2049. package/dist/cssm/hooks/useTimeout.js.map +0 -1
  2050. package/dist/cssm/lib/supportEvents.d.ts +0 -10
  2051. package/dist/cssm/lib/supportEvents.d.ts.map +0 -1
  2052. package/dist/cssm/lib/supportEvents.js +0 -26
  2053. package/dist/cssm/lib/supportEvents.js.map +0 -1
  2054. package/dist/cssm/shared/breakpoints.d.ts +0 -74
  2055. package/dist/cssm/shared/breakpoints.d.ts.map +0 -1
  2056. package/dist/hooks/useTimeout.d.ts +0 -5
  2057. package/dist/hooks/useTimeout.d.ts.map +0 -1
  2058. package/dist/hooks/useTimeout.js +0 -40
  2059. package/dist/hooks/useTimeout.js.map +0 -1
  2060. package/dist/lib/supportEvents.d.ts +0 -10
  2061. package/dist/lib/supportEvents.d.ts.map +0 -1
  2062. package/dist/lib/supportEvents.js +0 -26
  2063. package/dist/lib/supportEvents.js.map +0 -1
  2064. package/dist/shared/breakpoints.d.ts +0 -74
  2065. package/dist/shared/breakpoints.d.ts.map +0 -1
  2066. package/dist/stable.js.tmp +0 -180
  2067. package/src/hooks/useTimeout.ts +0 -33
  2068. package/src/lib/supportEvents.ts +0 -38
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/CustomSelect/CustomSelect.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useFocusWithin } from '../../hooks/useFocusWithin';\nimport { useDOM } from '../../lib/dom';\nimport type { PlacementWithAuto } from '../../lib/floating';\nimport { defaultFilterFn, type FilterFn } from '../../lib/select';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { debounce } from '../../lib/utils';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { TrackerOptionsProps } from '../CustomScrollView/useTrackerVisibility';\nimport { CustomSelectDropdown } from '../CustomSelectDropdown/CustomSelectDropdown';\nimport {\n CustomSelectOption,\n CustomSelectOptionProps,\n} from '../CustomSelectOption/CustomSelectOption';\nimport { DropdownIcon } from '../DropdownIcon/DropdownIcon';\nimport { FormFieldProps } from '../FormField/FormField';\nimport { NativeSelectProps } from '../NativeSelect/NativeSelect';\nimport { SelectType } from '../Select/Select';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport { CustomSelectClearButton, CustomSelectClearButtonProps } from './CustomSelectClearButton';\nimport { CustomSelectInput } from './CustomSelectInput';\nimport styles from './CustomSelect.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelect--sizeY-none'],\n ['compact']: styles['CustomSelect--sizeY-compact'],\n};\n\nconst findIndexAfter = (options: CustomSelectOptionInterface[] = [], startIndex = -1) => {\n if (startIndex >= options.length - 1) {\n return -1;\n }\n return options.findIndex((option, i) => i > startIndex && !option.disabled);\n};\n\nconst findIndexBefore = (\n options: CustomSelectOptionInterface[] = [],\n endIndex: number = options.length,\n) => {\n let result = -1;\n if (endIndex <= 0) {\n return result;\n }\n for (let i = endIndex - 1; i >= 0; i--) {\n let option = options[i];\n\n if (!option.disabled) {\n result = i;\n break;\n }\n }\n return result;\n};\n\nconst warn = warnOnce('CustomSelect');\n\nconst checkOptionsValueType = <T extends CustomSelectOptionInterface>(options: T[]) => {\n if (new Set(options.map((item) => typeof item.value)).size > 1) {\n warn(\n 'Некоторые значения ваших опций имеют разные типы. onChange всегда возвращает строковый тип.',\n 'error',\n );\n }\n};\n\nfunction defaultRenderOptionFn<T extends CustomSelectOptionInterface>({\n option,\n ...props\n}: CustomSelectRenderOption<T>): React.ReactNode {\n return <CustomSelectOption {...props} />;\n}\n\nconst handleOptionDown: MouseEventHandler = (e: React.MouseEvent<HTMLElement>) => {\n e.preventDefault();\n};\n\nfunction findSelectedIndex<T extends CustomSelectOptionInterface>(\n options: T[] = [],\n value: SelectValue,\n withClear: boolean,\n) {\n if (withClear && value === '') {\n return -1;\n }\n return (\n options.findIndex((item) => {\n value = typeof item.value === 'number' ? Number(value) : value;\n return item.value === value;\n }) ?? -1\n );\n}\n\nconst filter = <T extends CustomSelectOptionInterface>(\n options: SelectProps<T>['options'],\n inputValue: string,\n filterFn: SelectProps<T>['filterFn'],\n) => {\n return typeof filterFn === 'function'\n ? options.filter((option) => filterFn(inputValue, option))\n : options;\n};\n\nconst defaultOptions: CustomSelectOptionInterface[] = [];\n\ntype SelectValue = React.SelectHTMLAttributes<HTMLSelectElement>['value'];\n\nexport interface CustomSelectOptionInterface {\n value: SelectValue;\n label: React.ReactElement | string;\n disabled?: boolean;\n [index: string]: any;\n}\n\nexport interface CustomSelectRenderOption<T extends CustomSelectOptionInterface>\n extends CustomSelectOptionProps {\n option: T;\n}\n\nexport interface SelectProps<\n OptionInterfaceT extends CustomSelectOptionInterface = CustomSelectOptionInterface,\n> extends NativeSelectProps,\n FormFieldProps,\n TrackerOptionsProps {\n /**\n * Если `true`, то при клике на `CustomSelect` в нём появится текстовое поле для поиска по `options`. По умолчанию поиск\n * производится по `option.label`.\n */\n searchable?: boolean;\n /**\n * Текст, который будет отображен, если приходит пустой `options`.\n */\n emptyText?: string;\n /**\n * Событие изменения текстового поля\n */\n onInputChange?: (e: React.ChangeEvent) => void;\n options: OptionInterfaceT[];\n /**\n * Функция для кастомной фильтрации. По умолчанию поиск производится по `option.label`.\n */\n filterFn?: false | FilterFn<OptionInterfaceT>;\n popupDirection?: 'top' | 'bottom';\n /**\n * Рендер-проп для кастомного рендера опции.\n * В объекте аргумента приходят [свойства опции](https://vkcom.github.io/VKUI/#/CustomSelectOption?id=props)\n *\n * > ⚠️ Важно: cвойство опции `disabled` должно выставляться только через проп `options`.\n * > Запрещается выставлять `disabled` проп опциям в обход `options`, иначе `CustomSelect` не будет знать об актуальном состоянии\n * опции.\n */\n renderOption?: (props: CustomSelectRenderOption<OptionInterfaceT>) => React.ReactNode;\n /**\n * Рендер-проп для кастомного рендера содержимого дропдауна.\n * В `defaultDropdownContent` содержится список опций в виде скроллящегося блока.\n */\n renderDropdown?: ({\n defaultDropdownContent,\n }: {\n defaultDropdownContent: React.ReactNode;\n }) => React.ReactNode;\n /**\n * Если `true`, то в дропдауне вместо списка опций рисуется спиннер. При переданных `renderDropdown` и `fetching: true`\n * \"победит\" `renderDropdown`.\n */\n fetching?: boolean;\n onClose?: VoidFunction;\n onOpen?: VoidFunction;\n /**\n * Иконка раскрывающегося списка\n */\n icon?: React.ReactNode;\n /**\n * Кастомная кнопка для очистки значения.\n * Должна принимать обязательное свойство `onClick`\n */\n ClearButton?: React.ComponentType<CustomSelectClearButtonProps>;\n /**\n * Если `true`, то справа будет отображаться кнопка для очистки значения\n */\n allowClearButton?: boolean;\n /**\n * (e2e) testId кнопки очистки\n */\n clearButtonTestId?: string;\n dropdownOffsetDistance?: number;\n /**\n * Ширина раскрывающегося списка зависит от контента\n */\n dropdownAutoWidth?: boolean;\n forceDropdownPortal?: boolean;\n selectType?: SelectType;\n /**\n * Отключает максимальную высоту по умолчанию\n */\n noMaxHeight?: boolean;\n /**\n * (e2e) testId элемента, внутри которого отображается текст выбранной опции `CustomSelect` или плейсхолдер.\n */\n labelTextTestId?: string;\n nativeSelectTestId?: string;\n}\n\ntype MouseEventHandler = (event: React.MouseEvent<HTMLElement>) => void;\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelect\n */\nexport function CustomSelect<OptionInterfaceT extends CustomSelectOptionInterface>(\n props: SelectProps<OptionInterfaceT>,\n) {\n const [opened, setOpened] = React.useState(false);\n const {\n before,\n name,\n className,\n getRef,\n getRootRef,\n popupDirection = 'bottom',\n style,\n onChange,\n children,\n onInputChange: onInputChangeProp,\n renderDropdown,\n onOpen,\n onClose,\n fetching,\n forceDropdownPortal,\n selectType = 'default',\n autoHideScrollbar,\n autoHideScrollbarDelay,\n searchable = false,\n renderOption: renderOptionProp = defaultRenderOptionFn,\n options: optionsProp = defaultOptions as OptionInterfaceT[],\n emptyText = 'Ничего не найдено',\n filterFn = defaultFilterFn,\n icon: iconProp,\n ClearButton = CustomSelectClearButton,\n allowClearButton = false,\n dropdownOffsetDistance = 0,\n dropdownAutoWidth = false,\n noMaxHeight = false,\n ['aria-labelledby']: ariaLabelledBy,\n clearButtonTestId,\n nativeSelectTestId,\n defaultValue,\n required,\n ...restProps\n } = props;\n\n if (process.env.NODE_ENV === 'development') {\n checkOptionsValueType(optionsProp);\n }\n\n const { sizeY = 'none' } = useAdaptivity();\n\n const containerRef = React.useRef<HTMLDivElement>(null);\n const handleRootRef = useExternRef(containerRef, getRootRef);\n const scrollBoxRef = React.useRef<HTMLDivElement | null>(null);\n const selectElRef = useExternRef(getRef);\n\n const [focusedOptionIndex, setFocusedOptionIndex] = React.useState<number | undefined>(-1);\n const [isControlledOutside, setIsControlledOutside] = React.useState(props.value !== undefined);\n const [inputValue, setInputValue] = React.useState('');\n const [nativeSelectValue, setNativeSelectValue] = React.useState(\n () => props.value ?? defaultValue ?? (allowClearButton ? '' : undefined),\n );\n const [popperPlacement, setPopperPlacement] = React.useState<PlacementWithAuto | undefined>(\n popupDirection,\n );\n const [options, setOptions] = React.useState(optionsProp);\n const [selectedOptionIndex, setSelectedOptionIndex] = React.useState<number | undefined>(\n findSelectedIndex(optionsProp, props.value ?? defaultValue, allowClearButton),\n );\n\n React.useEffect(() => {\n setIsControlledOutside(props.value !== undefined);\n setNativeSelectValue((nativeSelectValue) => props.value ?? nativeSelectValue);\n }, [props.value]);\n\n useIsomorphicLayoutEffect(() => {\n if (\n options.some(({ value }) => nativeSelectValue === value) ||\n (allowClearButton && nativeSelectValue === '')\n ) {\n const event = new Event('change', { bubbles: true });\n\n selectElRef.current?.dispatchEvent(event);\n }\n }, [nativeSelectValue]);\n\n const selected = React.useMemo(() => {\n if (!options.length) {\n return null;\n }\n\n return selectedOptionIndex !== undefined ? options[selectedOptionIndex] : undefined;\n }, [options, selectedOptionIndex]);\n\n const openedClassNames = React.useMemo(\n () =>\n (opened &&\n dropdownOffsetDistance === 0 &&\n (popperPlacement?.includes('top')\n ? styles['CustomSelect--pop-up']\n : styles['CustomSelect--pop-down'])) ||\n undefined,\n [dropdownOffsetDistance, opened, popperPlacement],\n );\n\n const scrollToElement = React.useCallback((index: number, center = false) => {\n const dropdown = scrollBoxRef.current;\n const item = dropdown ? (dropdown.children[index] as HTMLElement) : null;\n\n if (!item || !dropdown) {\n return;\n }\n\n const dropdownHeight = dropdown.offsetHeight;\n const scrollTop = dropdown.scrollTop;\n const itemTop = item.offsetTop;\n const itemHeight = item.offsetHeight;\n\n if (center) {\n dropdown.scrollTop = itemTop - dropdownHeight / 2 + itemHeight / 2;\n } else if (itemTop + itemHeight > dropdownHeight + scrollTop) {\n dropdown.scrollTop = itemTop - dropdownHeight + itemHeight;\n } else if (itemTop < scrollTop) {\n dropdown.scrollTop = itemTop;\n }\n }, []);\n\n const focusOptionByIndex = React.useCallback(\n (index: number | undefined, scrollTo = true) => {\n if (index === undefined || index < 0 || index > (options.length ?? 0) - 1) {\n return;\n }\n\n const option = options[index];\n\n if (option?.disabled) {\n return;\n }\n\n if (scrollTo) {\n scrollToElement(index);\n }\n\n // Это оптимизация, прежде всего, под `onMouseMove`\n setFocusedOptionIndex((focusedOptionIndex) =>\n focusedOptionIndex !== index ? index : focusedOptionIndex,\n );\n },\n [options, scrollToElement],\n );\n\n const isValidIndex = React.useCallback(\n (index: number) => {\n return index >= 0 && index < (options.length ?? 0);\n },\n [options.length],\n );\n\n const setScrollBoxRef = React.useCallback(\n (ref: HTMLDivElement | null) => {\n scrollBoxRef.current = ref;\n\n if (ref && selectedOptionIndex !== undefined && isValidIndex(selectedOptionIndex)) {\n {\n scrollToElement(selectedOptionIndex, true);\n }\n }\n },\n [isValidIndex, scrollToElement, selectedOptionIndex],\n );\n\n const [keyboardInput, setKeyboardInput] = React.useState('');\n const resetKeyboardInput = React.useCallback(() => {\n setKeyboardInput('');\n }, []);\n\n const resetFocusedOption = React.useCallback(() => {\n setFocusedOptionIndex(-1);\n }, []);\n\n const onKeyboardInput = React.useCallback(\n (key: string) => {\n if (!opened) {\n setOpened(true);\n }\n resetFocusedOption();\n const fullInput = keyboardInput + key;\n\n setKeyboardInput(fullInput);\n },\n [keyboardInput, opened, resetFocusedOption],\n );\n\n /**\n * Note: сбрасывать `options` через `setOptions(optionsProp)` не нужно.\n * Сброс происходит в одном из эффекте `updateOptionsAndSelectedOptionIndex()`.\n */\n const close = React.useCallback(() => {\n resetKeyboardInput();\n\n setInputValue('');\n setOpened(false);\n resetFocusedOption();\n onClose?.();\n }, [onClose, resetKeyboardInput, resetFocusedOption]);\n\n const selectOption = React.useCallback(\n (index: number) => {\n const item = options[index];\n\n setNativeSelectValue(item?.value);\n close();\n\n const shouldTriggerOnChangeWhenControlledAndInnerValueIsOutOfSync =\n isControlledOutside &&\n props.value !== nativeSelectValue &&\n nativeSelectValue === item?.value;\n\n if (shouldTriggerOnChangeWhenControlledAndInnerValueIsOutOfSync) {\n const event = new Event('change', { bubbles: true });\n selectElRef.current?.dispatchEvent(event);\n }\n },\n [close, options, selectElRef, isControlledOutside, props.value, nativeSelectValue],\n );\n\n const selectFocused = React.useCallback(() => {\n if (focusedOptionIndex === undefined || !isValidIndex(focusedOptionIndex)) {\n return;\n }\n\n selectOption(focusedOptionIndex);\n }, [focusedOptionIndex, isValidIndex, selectOption]);\n\n const open = React.useCallback(() => {\n setOpened(true);\n setFocusedOptionIndex(selectedOptionIndex);\n\n if (typeof onOpen === 'function') {\n onOpen();\n }\n }, [onOpen, selectedOptionIndex]);\n\n const onBlur = React.useCallback(() => {\n close();\n const event = new Event('focusout', { bubbles: true });\n selectElRef.current?.dispatchEvent(event);\n }, [close, selectElRef]);\n\n const onFocus = React.useCallback(() => {\n const event = new Event('focusin', { bubbles: true });\n selectElRef.current?.dispatchEvent(event);\n }, [selectElRef]);\n\n const onClick = React.useCallback(() => {\n if (opened) {\n close();\n } else {\n open();\n }\n }, [close, open, opened]);\n\n const handleKeyUp = React.useMemo(() => debounce(resetKeyboardInput, 1000), [resetKeyboardInput]);\n\n const focusOption = React.useCallback(\n (type: 'next' | 'prev') => {\n let index = focusedOptionIndex;\n\n if (type === 'next') {\n const nextIndex = findIndexAfter(options, index);\n index = nextIndex === -1 ? findIndexAfter(options) : nextIndex; // Следующий за index или первый валидный до index\n } else if (type === 'prev') {\n const beforeIndex = findIndexBefore(options, index);\n index = beforeIndex === -1 ? findIndexBefore(options) : beforeIndex; // Предшествующий index или последний валидный после index\n }\n\n focusOptionByIndex(index);\n },\n [focusOptionByIndex, focusedOptionIndex, options],\n );\n\n React.useEffect(\n function updateOptionsAndSelectedOptionIndex() {\n const value = props.value ?? nativeSelectValue ?? defaultValue;\n\n const options =\n searchable && inputValue !== undefined\n ? filter(optionsProp, inputValue, filterFn)\n : optionsProp;\n\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, value, allowClearButton));\n },\n [\n filterFn,\n inputValue,\n nativeSelectValue,\n optionsProp,\n defaultValue,\n props.value,\n searchable,\n allowClearButton,\n ],\n );\n\n const onNativeSelectChange: React.ChangeEventHandler<HTMLSelectElement> = (e) => {\n const newSelectedOptionIndex = findSelectedIndex(\n options,\n e.currentTarget.value,\n allowClearButton,\n );\n\n if (selectedOptionIndex !== newSelectedOptionIndex) {\n if (!isControlledOutside) {\n setSelectedOptionIndex(newSelectedOptionIndex);\n }\n onChange?.(e);\n }\n };\n\n const onInputChange: React.ChangeEventHandler<HTMLInputElement> = React.useCallback(\n (e) => {\n onInputChangeProp && onInputChangeProp(e);\n\n const options = filter(optionsProp, e.target.value, filterFn);\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, nativeSelectValue, allowClearButton));\n\n setInputValue(e.target.value);\n },\n [filterFn, nativeSelectValue, onInputChangeProp, optionsProp, allowClearButton],\n );\n\n const areOptionsShown = React.useCallback(() => {\n return scrollBoxRef.current !== null;\n }, []);\n\n const handleKeyDownSelect = React.useCallback(\n (event: React.KeyboardEvent) => {\n if (event.key.length === 1 && event.key !== ' ') {\n onKeyboardInput(event.key);\n return;\n }\n\n ['ArrowUp', 'ArrowDown', 'Escape', 'Enter'].includes(event.key) &&\n areOptionsShown() &&\n event.preventDefault();\n\n switch (event.key) {\n case 'ArrowUp':\n if (opened) {\n areOptionsShown() && focusOption('prev');\n } else {\n open();\n }\n break;\n case 'ArrowDown':\n if (opened) {\n areOptionsShown() && focusOption('next');\n } else {\n open();\n }\n break;\n case 'Escape':\n close();\n break;\n case 'Backspace':\n case 'Delete': {\n if (!opened) {\n setOpened(true);\n }\n resetFocusedOption();\n\n break;\n }\n case 'Enter':\n case 'Spacebar':\n case ' ':\n if (opened) {\n areOptionsShown() && selectFocused();\n } else {\n open();\n }\n break;\n }\n },\n [\n areOptionsShown,\n close,\n focusOption,\n onKeyboardInput,\n open,\n opened,\n selectFocused,\n resetFocusedOption,\n ],\n );\n\n const handleOptionClick = React.useCallback(\n (e: React.MouseEvent<HTMLElement>) => {\n const index = Array.prototype.indexOf.call(\n e.currentTarget.parentNode?.children,\n e.currentTarget,\n );\n const option = options[index];\n\n if (option && !option.disabled) {\n selectOption(index);\n }\n },\n [options, selectOption],\n );\n\n const prevMousePositionRef = React.useRef<{\n x: React.MouseEvent['clientX'];\n y: React.MouseEvent['clientY'];\n }>({ x: 0, y: 0 });\n const focusOptionOnMouseMove = React.useCallback(\n (e: React.MouseEvent<HTMLElement>) => {\n const isMouseChangedPosition =\n Math.abs(prevMousePositionRef.current.x - e.clientX) >= 1 ||\n Math.abs(prevMousePositionRef.current.y - e.clientY) >= 1;\n\n if (isMouseChangedPosition) {\n focusOptionByIndex(\n Array.prototype.indexOf.call(e.currentTarget.parentNode?.children, e.currentTarget),\n false,\n );\n }\n\n prevMousePositionRef.current = { x: e.clientX, y: e.clientY };\n },\n [focusOptionByIndex],\n );\n\n const popupAriaId = React.useId();\n const renderOption = React.useCallback(\n (option: OptionInterfaceT, index: number) => {\n const hovered = index === focusedOptionIndex;\n const selected = index === selectedOptionIndex;\n\n return (\n <React.Fragment key={`${option.value}`}>\n {renderOptionProp({\n option,\n hovered,\n children: option.label,\n selected,\n disabled: option.disabled,\n onClick: handleOptionClick,\n onMouseDown: handleOptionDown,\n // Используем `onMouseMove` вместо `onMouseEnter/onMouseOver`.\n // Потому что если при навигации с клавиатуры курсор наведён на\n // список, то при первом автоматическом скролле списка вызывается событие MouseOver/MouseEnter\n // обработчик которого фокусирует опцию под курсором, хотя при навигация с клавиатуры пользователь мог уйти дальше по списку, это путает.\n // Причём координаты события меняются на пару пикселей по сравнению с прошлым вызовом,\n // а значит нельзя на них опираться, чтобы запретить обработку такого события.\n // C mousemove такой проблемы нет, что позволяет реализовать поведение при наведении с клавиатуры и при наведении мышью идентично `<select>`.\n onMouseMove: focusOptionOnMouseMove,\n id: `${popupAriaId}-${option.value}`,\n })}\n </React.Fragment>\n );\n },\n [\n focusedOptionIndex,\n handleOptionClick,\n focusOptionOnMouseMove,\n renderOptionProp,\n selectedOptionIndex,\n popupAriaId,\n ],\n );\n\n const resolvedContent = React.useMemo(() => {\n const defaultDropdownContent =\n options?.length > 0 ? (\n options.map(renderOption)\n ) : (\n <Footnote className={styles['CustomSelect__empty']}>{emptyText}</Footnote>\n );\n\n if (typeof renderDropdown === 'function') {\n return renderDropdown({ defaultDropdownContent });\n } else {\n return defaultDropdownContent;\n }\n }, [emptyText, options, renderDropdown, renderOption]);\n\n const selectInputRef = React.useRef<HTMLInputElement | null>(null);\n const focusOnInputTimerRef = React.useRef<ReturnType<typeof setTimeout>>();\n const focusOnInput = React.useCallback(() => {\n clearTimeout(focusOnInputTimerRef.current);\n\n focusOnInputTimerRef.current = setTimeout(() => {\n selectInputRef.current && selectInputRef.current.focus();\n }, 0);\n }, []);\n useIsomorphicLayoutEffect(function clearFocusOnInputTimer() {\n return () => {\n clearTimeout(focusOnInputTimerRef.current);\n };\n }, []);\n\n const controlledValueSet = isControlledOutside && props.value !== '';\n const uncontrolledValueSet = !isControlledOutside && nativeSelectValue !== '';\n const clearButtonShown =\n allowClearButton && !opened && (controlledValueSet || uncontrolledValueSet);\n\n const clearButton = React.useMemo(() => {\n if (!clearButtonShown) {\n return null;\n }\n\n return (\n <ClearButton\n className={iconProp === undefined ? styles['CustomSelect--clear-icon'] : undefined}\n onClick={function clearSelectState() {\n setNativeSelectValue('');\n setInputValue('');\n focusOnInput();\n }}\n disabled={restProps.disabled}\n data-testid={clearButtonTestId}\n />\n );\n }, [\n clearButtonShown,\n ClearButton,\n iconProp,\n restProps.disabled,\n clearButtonTestId,\n focusOnInput,\n ]);\n\n const icon = React.useMemo(() => {\n if (iconProp !== undefined) {\n return iconProp;\n }\n\n return (\n <DropdownIcon\n className={clearButtonShown ? styles['CustomSelect__dropdown-icon'] : undefined}\n opened={opened}\n />\n );\n }, [clearButtonShown, iconProp, opened]);\n\n const afterIcons = (icon || clearButtonShown) && (\n <React.Fragment>\n {clearButton}\n {icon}\n </React.Fragment>\n );\n\n const { document } = useDOM();\n const passClickAndFocusToInputOnClick = React.useCallback(\n (e: React.MouseEvent<HTMLDivElement>) => {\n // Раньше внешней оберткой CustomSelect был <label>, что позволяло по клику в любую область CustomSelect,\n // даже где нету интерактивного элемента, фокусировать <input> и передавать на него событие клика.\n // Так как мы больше не оборачиваем CustomSelect в <label>, то для обертки CustomSelect мы симулируем работу <label>.\n // передаем фокус и клик по <input>, если пользователь кликнул в зоне обертки.\n // В <label> мы не больше не оборачиваем, потому что это заставляет скринридер\n // дважды произносить текст выбранной опции при фокусе, если CustomSelect связан с внешним <label>.\n // Воспроизводится в некоторых версиях Chrome, при навигации по странице с помощью стрелок.\n // Договорились со специалистом по доступности убрать <label>-обёртки из Select и CustomSelect\n\n if (!selectInputRef.current || !document) {\n return;\n }\n\n const clickTargetIsNotAnInput = e.target !== selectInputRef.current;\n if (clickTargetIsNotAnInput) {\n selectInputRef.current.click();\n\n const inputIsNotFocused = document.activeElement !== selectInputRef.current;\n if (inputIsNotFocused) {\n focusOnInput();\n }\n }\n },\n [document, focusOnInput],\n );\n\n const preventInputBlurWhenClickInsideFocusedSelectArea = (\n e: React.MouseEvent<HTMLDivElement>,\n ) => {\n // Так как инпут больше не оборачивается пустым лэйблом, то клик внутри обертки,\n // но вне инпута (например по иконке дропдауна), будет убирать фокус с инпута.\n // Чтобы в такой ситуации отключить blur инпута мы превентим mousedown событие обёртки\n const isInputFocused = document && document.activeElement === selectInputRef.current;\n if (isInputFocused) {\n e.preventDefault();\n }\n };\n\n const ariaActiveDescendantOptionIndex: undefined | number =\n focusedOptionIndex !== -1 ? focusedOptionIndex : undefined;\n const ariaActiveDescendantId =\n ariaActiveDescendantOptionIndex !== undefined\n ? options[ariaActiveDescendantOptionIndex] && options[ariaActiveDescendantOptionIndex].value\n : null;\n\n const selectInputAriaProps: React.HTMLAttributes<HTMLElement> = {\n 'role': 'combobox',\n 'aria-controls': popupAriaId,\n 'aria-owns': popupAriaId,\n 'aria-expanded': opened,\n ['aria-activedescendant']:\n ariaActiveDescendantId && opened ? `${popupAriaId}-${ariaActiveDescendantId}` : undefined,\n 'aria-labelledby': ariaLabelledBy,\n 'aria-haspopup': 'listbox',\n 'aria-autocomplete': 'none',\n };\n\n const focusWithin = useFocusWithin(handleRootRef);\n\n return (\n <div\n className={classNames(\n styles['CustomSelect'],\n sizeY !== 'regular' && sizeYClassNames[sizeY],\n className,\n )}\n style={style}\n ref={handleRootRef}\n onClick={passClickAndFocusToInputOnClick}\n onMouseDown={preventInputBlurWhenClickInsideFocusedSelectArea}\n >\n {focusWithin && selected && !opened && (\n <VisuallyHidden aria-live=\"polite\">{selected.label}</VisuallyHidden>\n )}\n <CustomSelectInput\n autoComplete=\"off\"\n autoCapitalize=\"none\"\n autoCorrect=\"off\"\n spellCheck=\"false\"\n {...restProps}\n {...selectInputAriaProps}\n getRef={selectInputRef}\n onFocus={onFocus}\n onBlur={onBlur}\n className={openedClassNames}\n readOnly={!searchable}\n fetching={fetching}\n value={inputValue}\n onKeyUp={handleKeyUp}\n onKeyDown={handleKeyDownSelect}\n onChange={onInputChange}\n onClick={onClick}\n before={before}\n after={afterIcons}\n selectType={selectType}\n >\n {selected?.label}\n </CustomSelectInput>\n <select\n ref={selectElRef}\n name={name}\n onChange={onNativeSelectChange}\n onBlur={props.onBlur}\n onFocus={props.onFocus}\n onClick={props.onClick}\n value={nativeSelectValue}\n aria-hidden\n className={styles['CustomSelect__control']}\n data-testid={nativeSelectTestId}\n required={required}\n >\n {allowClearButton && <option key=\"\" value=\"\" />}\n {optionsProp.map((item) => (\n <option key={`${item.value}`} value={item.value} />\n ))}\n </select>\n {opened && (\n <CustomSelectDropdown\n targetRef={containerRef}\n placement={popupDirection}\n scrollBoxRef={setScrollBoxRef}\n onPlacementChange={setPopperPlacement}\n onMouseLeave={resetFocusedOption}\n fetching={fetching}\n offsetDistance={dropdownOffsetDistance}\n autoWidth={dropdownAutoWidth}\n forcePortal={forceDropdownPortal}\n autoHideScrollbar={autoHideScrollbar}\n autoHideScrollbarDelay={autoHideScrollbarDelay}\n noMaxHeight={noMaxHeight}\n role=\"listbox\"\n id={popupAriaId}\n aria-labelledby={ariaLabelledBy}\n tabIndex={-1}\n >\n {resolvedContent}\n </CustomSelectDropdown>\n )}\n </div>\n );\n}\n"],"names":["CustomSelect","sizeYClassNames","none","findIndexAfter","options","startIndex","length","findIndex","option","i","disabled","findIndexBefore","endIndex","result","warn","warnOnce","checkOptionsValueType","Set","map","item","value","size","defaultRenderOptionFn","props","CustomSelectOption","handleOptionDown","e","preventDefault","findSelectedIndex","withClear","Number","filter","inputValue","filterFn","defaultOptions","opened","setOpened","React","useState","before","name","className","getRef","getRootRef","popupDirection","style","onChange","children","onInputChange","onInputChangeProp","renderDropdown","onOpen","onClose","fetching","forceDropdownPortal","selectType","autoHideScrollbar","autoHideScrollbarDelay","searchable","renderOption","renderOptionProp","optionsProp","emptyText","defaultFilterFn","icon","iconProp","ClearButton","CustomSelectClearButton","allowClearButton","dropdownOffsetDistance","dropdownAutoWidth","noMaxHeight","ariaLabelledBy","clearButtonTestId","nativeSelectTestId","defaultValue","required","restProps","process","env","NODE_ENV","sizeY","useAdaptivity","containerRef","useRef","handleRootRef","useExternRef","scrollBoxRef","selectElRef","focusedOptionIndex","setFocusedOptionIndex","isControlledOutside","setIsControlledOutside","undefined","setInputValue","nativeSelectValue","setNativeSelectValue","popperPlacement","setPopperPlacement","setOptions","selectedOptionIndex","setSelectedOptionIndex","useEffect","useIsomorphicLayoutEffect","some","event","Event","bubbles","current","dispatchEvent","selected","useMemo","openedClassNames","includes","scrollToElement","useCallback","index","center","dropdown","dropdownHeight","offsetHeight","scrollTop","itemTop","offsetTop","itemHeight","focusOptionByIndex","scrollTo","isValidIndex","setScrollBoxRef","ref","keyboardInput","setKeyboardInput","resetKeyboardInput","resetFocusedOption","onKeyboardInput","key","fullInput","close","selectOption","shouldTriggerOnChangeWhenControlledAndInnerValueIsOutOfSync","selectFocused","open","onBlur","onFocus","onClick","handleKeyUp","debounce","focusOption","type","nextIndex","beforeIndex","updateOptionsAndSelectedOptionIndex","onNativeSelectChange","newSelectedOptionIndex","currentTarget","target","areOptionsShown","handleKeyDownSelect","handleOptionClick","Array","prototype","indexOf","call","parentNode","prevMousePositionRef","x","y","focusOptionOnMouseMove","isMouseChangedPosition","Math","abs","clientX","clientY","popupAriaId","useId","hovered","Fragment","label","onMouseDown","onMouseMove","id","resolvedContent","defaultDropdownContent","Footnote","selectInputRef","focusOnInputTimerRef","focusOnInput","clearTimeout","setTimeout","focus","clearFocusOnInputTimer","controlledValueSet","uncontrolledValueSet","clearButtonShown","clearButton","clearSelectState","data-testid","DropdownIcon","afterIcons","document","useDOM","passClickAndFocusToInputOnClick","clickTargetIsNotAnInput","click","inputIsNotFocused","activeElement","preventInputBlurWhenClickInsideFocusedSelectArea","isInputFocused","ariaActiveDescendantOptionIndex","ariaActiveDescendantId","selectInputAriaProps","focusWithin","useFocusWithin","div","classNames","VisuallyHidden","aria-live","CustomSelectInput","autoComplete","autoCapitalize","autoCorrect","spellCheck","readOnly","onKeyUp","onKeyDown","after","select","aria-hidden","CustomSelectDropdown","targetRef","placement","onPlacementChange","onMouseLeave","offsetDistance","autoWidth","forcePortal","role","aria-labelledby","tabIndex"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/components/CustomSelect/CustomSelect.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useFocusWithin } from '../../hooks/useFocusWithin';\nimport { useDOM } from '../../lib/dom';\nimport type { PlacementWithAuto } from '../../lib/floating';\nimport { defaultFilterFn, type FilterFn } from '../../lib/select';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { debounce } from '../../lib/utils';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { TrackerOptionsProps } from '../CustomScrollView/useTrackerVisibility';\nimport { CustomSelectDropdown } from '../CustomSelectDropdown/CustomSelectDropdown';\nimport {\n CustomSelectOption,\n CustomSelectOptionProps,\n} from '../CustomSelectOption/CustomSelectOption';\nimport { DropdownIcon } from '../DropdownIcon/DropdownIcon';\nimport { FormFieldProps } from '../FormField/FormField';\nimport { NativeSelectProps } from '../NativeSelect/NativeSelect';\nimport { SelectType } from '../Select/Select';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport {\n CustomSelectClearButton,\n type CustomSelectClearButtonProps,\n} from './CustomSelectClearButton';\nimport { CustomSelectInput } from './CustomSelectInput';\nimport styles from './CustomSelect.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelect--sizeY-none'],\n ['compact']: styles['CustomSelect--sizeY-compact'],\n};\n\nconst findIndexAfter = (options: CustomSelectOptionInterface[] = [], startIndex = -1) => {\n if (startIndex >= options.length - 1) {\n return -1;\n }\n return options.findIndex((option, i) => i > startIndex && !option.disabled);\n};\n\nconst findIndexBefore = (\n options: CustomSelectOptionInterface[] = [],\n endIndex: number = options.length,\n) => {\n let result = -1;\n if (endIndex <= 0) {\n return result;\n }\n for (let i = endIndex - 1; i >= 0; i--) {\n let option = options[i];\n\n if (!option.disabled) {\n result = i;\n break;\n }\n }\n return result;\n};\n\nconst warn = warnOnce('CustomSelect');\n\nconst checkOptionsValueType = <T extends CustomSelectOptionInterface>(options: T[]) => {\n if (new Set(options.map((item) => typeof item.value)).size > 1) {\n warn(\n 'Некоторые значения ваших опций имеют разные типы. onChange всегда возвращает строковый тип.',\n 'error',\n );\n }\n};\n\nfunction defaultRenderOptionFn<T extends CustomSelectOptionInterface>({\n option,\n ...props\n}: CustomSelectRenderOption<T>): React.ReactNode {\n return <CustomSelectOption {...props} />;\n}\n\nconst handleOptionDown: MouseEventHandler = (e: React.MouseEvent<HTMLElement>) => {\n e.preventDefault();\n};\n\nfunction findSelectedIndex<T extends CustomSelectOptionInterface>(\n options: T[] = [],\n value: SelectValue,\n withClear: boolean,\n) {\n if (withClear && value === '') {\n return -1;\n }\n return (\n options.findIndex((item) => {\n value = typeof item.value === 'number' ? Number(value) : value;\n return item.value === value;\n }) ?? -1\n );\n}\n\nconst filter = <T extends CustomSelectOptionInterface>(\n options: SelectProps<T>['options'],\n inputValue: string,\n filterFn: SelectProps<T>['filterFn'],\n) => {\n return typeof filterFn === 'function'\n ? options.filter((option) => filterFn(inputValue, option))\n : options;\n};\n\nconst defaultOptions: CustomSelectOptionInterface[] = [];\n\ntype SelectValue = React.SelectHTMLAttributes<HTMLSelectElement>['value'];\n\nexport interface CustomSelectOptionInterface {\n value: SelectValue;\n label: React.ReactElement | string;\n disabled?: boolean;\n [index: string]: any;\n}\n\nexport interface CustomSelectRenderOption<T extends CustomSelectOptionInterface>\n extends CustomSelectOptionProps {\n option: T;\n}\n\nexport type { CustomSelectClearButtonProps };\n\nexport interface SelectProps<\n OptionInterfaceT extends CustomSelectOptionInterface = CustomSelectOptionInterface,\n> extends NativeSelectProps,\n FormFieldProps,\n TrackerOptionsProps {\n /**\n * Если `true`, то при клике на `CustomSelect` в нём появится текстовое поле для поиска по `options`. По умолчанию поиск\n * производится по `option.label`.\n */\n searchable?: boolean;\n /**\n * Текст, который будет отображен, если приходит пустой `options`.\n */\n emptyText?: string;\n /**\n * Событие изменения текстового поля\n */\n onInputChange?: (e: React.ChangeEvent) => void;\n options: OptionInterfaceT[];\n /**\n * Функция для кастомной фильтрации. По умолчанию поиск производится по `option.label`.\n */\n filterFn?: false | FilterFn<OptionInterfaceT>;\n popupDirection?: 'top' | 'bottom';\n /**\n * Рендер-проп для кастомного рендера опции.\n * В объекте аргумента приходят [свойства опции](https://vkcom.github.io/VKUI/#/CustomSelectOption?id=props)\n *\n * > ⚠️ Важно: cвойство опции `disabled` должно выставляться только через проп `options`.\n * > Запрещается выставлять `disabled` проп опциям в обход `options`, иначе `CustomSelect` не будет знать об актуальном состоянии\n * опции.\n */\n renderOption?: (props: CustomSelectRenderOption<OptionInterfaceT>) => React.ReactNode;\n /**\n * Рендер-проп для кастомного рендера содержимого дропдауна.\n * В `defaultDropdownContent` содержится список опций в виде скроллящегося блока.\n */\n renderDropdown?: ({\n defaultDropdownContent,\n }: {\n defaultDropdownContent: React.ReactNode;\n }) => React.ReactNode;\n /**\n * Если `true`, то в дропдауне вместо списка опций рисуется спиннер. При переданных `renderDropdown` и `fetching: true`\n * \"победит\" `renderDropdown`.\n */\n fetching?: boolean;\n onClose?: VoidFunction;\n onOpen?: VoidFunction;\n /**\n * Иконка раскрывающегося списка\n */\n icon?: React.ReactNode;\n /**\n * Кастомная кнопка для очистки значения.\n * Должна принимать обязательное свойство `onClick`\n */\n ClearButton?: React.ComponentType<CustomSelectClearButtonProps>;\n /**\n * Если `true`, то справа будет отображаться кнопка для очистки значения\n */\n allowClearButton?: boolean;\n /**\n * (e2e) testId кнопки очистки\n */\n clearButtonTestId?: string;\n /**\n * Отступ от выпадающего списка\n */\n dropdownOffsetDistance?: number;\n /**\n * Ширина раскрывающегося списка зависит от контента\n */\n dropdownAutoWidth?: boolean;\n forceDropdownPortal?: boolean;\n selectType?: SelectType;\n /**\n * Отключает максимальную высоту по умолчанию\n */\n noMaxHeight?: boolean;\n /**\n * (e2e) testId элемента, внутри которого отображается текст выбранной опции `CustomSelect` или плейсхолдер.\n */\n labelTextTestId?: string;\n nativeSelectTestId?: string;\n}\n\ntype MouseEventHandler = (event: React.MouseEvent<HTMLElement>) => void;\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelect\n */\nexport function CustomSelect<OptionInterfaceT extends CustomSelectOptionInterface>(\n props: SelectProps<OptionInterfaceT>,\n) {\n const [opened, setOpened] = React.useState(false);\n const {\n before,\n name,\n className,\n getRef,\n getRootRef,\n popupDirection = 'bottom',\n style,\n onChange,\n children,\n onInputChange: onInputChangeProp,\n renderDropdown,\n onOpen,\n onClose,\n fetching,\n forceDropdownPortal,\n selectType = 'default',\n autoHideScrollbar,\n autoHideScrollbarDelay,\n searchable = false,\n renderOption: renderOptionProp = defaultRenderOptionFn,\n options: optionsProp = defaultOptions as OptionInterfaceT[],\n emptyText = 'Ничего не найдено',\n filterFn = defaultFilterFn,\n icon: iconProp,\n ClearButton = CustomSelectClearButton,\n allowClearButton = false,\n dropdownOffsetDistance = 0,\n dropdownAutoWidth = false,\n noMaxHeight = false,\n ['aria-labelledby']: ariaLabelledBy,\n clearButtonTestId,\n nativeSelectTestId,\n defaultValue,\n required,\n ...restProps\n } = props;\n\n if (process.env.NODE_ENV === 'development') {\n checkOptionsValueType(optionsProp);\n }\n\n const { sizeY = 'none' } = useAdaptivity();\n\n const containerRef = React.useRef<HTMLDivElement>(null);\n const handleRootRef = useExternRef(containerRef, getRootRef);\n const scrollBoxRef = React.useRef<HTMLDivElement | null>(null);\n const selectElRef = useExternRef(getRef);\n\n const [focusedOptionIndex, setFocusedOptionIndex] = React.useState<number | undefined>(-1);\n const [isControlledOutside, setIsControlledOutside] = React.useState(props.value !== undefined);\n const [inputValue, setInputValue] = React.useState('');\n const [nativeSelectValue, setNativeSelectValue] = React.useState(\n () => props.value ?? defaultValue ?? (allowClearButton ? '' : undefined),\n );\n const [popperPlacement, setPopperPlacement] = React.useState<PlacementWithAuto | undefined>(\n popupDirection,\n );\n const [options, setOptions] = React.useState(optionsProp);\n const [selectedOptionIndex, setSelectedOptionIndex] = React.useState<number | undefined>(\n findSelectedIndex(optionsProp, props.value ?? defaultValue, allowClearButton),\n );\n\n React.useEffect(() => {\n setIsControlledOutside(props.value !== undefined);\n setNativeSelectValue((nativeSelectValue) => props.value ?? nativeSelectValue);\n }, [props.value]);\n\n useIsomorphicLayoutEffect(() => {\n if (\n options.some(({ value }) => nativeSelectValue === value) ||\n (allowClearButton && nativeSelectValue === '')\n ) {\n const event = new Event('change', { bubbles: true });\n\n selectElRef.current?.dispatchEvent(event);\n }\n }, [nativeSelectValue]);\n\n const selected = React.useMemo(() => {\n if (!options.length) {\n return null;\n }\n\n return selectedOptionIndex !== undefined ? options[selectedOptionIndex] : undefined;\n }, [options, selectedOptionIndex]);\n\n const openedClassNames = React.useMemo(\n () =>\n (opened &&\n dropdownOffsetDistance === 0 &&\n (popperPlacement?.includes('top')\n ? styles['CustomSelect--pop-up']\n : styles['CustomSelect--pop-down'])) ||\n undefined,\n [dropdownOffsetDistance, opened, popperPlacement],\n );\n\n const scrollToElement = React.useCallback((index: number, center = false) => {\n const dropdown = scrollBoxRef.current;\n const item =\n dropdown && dropdown.firstElementChild\n ? (dropdown.firstElementChild.children[index] as HTMLElement)\n : null;\n\n if (!item || !dropdown) {\n return;\n }\n\n const dropdownHeight = dropdown.offsetHeight;\n const scrollTop = dropdown.scrollTop;\n const itemTop = item.offsetTop;\n const itemHeight = item.offsetHeight;\n\n if (center) {\n dropdown.scrollTop = itemTop - dropdownHeight / 2 + itemHeight / 2;\n } else if (itemTop + itemHeight > dropdownHeight + scrollTop) {\n dropdown.scrollTop = itemTop - dropdownHeight + itemHeight;\n } else if (itemTop < scrollTop) {\n dropdown.scrollTop = itemTop;\n }\n }, []);\n\n const focusOptionByIndex = React.useCallback(\n (index: number | undefined, scrollTo = true) => {\n if (index === undefined || index < 0 || index > (options.length ?? 0) - 1) {\n return;\n }\n\n const option = options[index];\n\n if (option?.disabled) {\n return;\n }\n\n if (scrollTo) {\n scrollToElement(index);\n }\n\n // Это оптимизация, прежде всего, под `onMouseMove`\n setFocusedOptionIndex((focusedOptionIndex) =>\n focusedOptionIndex !== index ? index : focusedOptionIndex,\n );\n },\n [options, scrollToElement],\n );\n\n const isValidIndex = React.useCallback(\n (index: number) => {\n return index >= 0 && index < (options.length ?? 0);\n },\n [options.length],\n );\n\n const setScrollBoxRef = React.useCallback(\n (ref: HTMLDivElement | null) => {\n scrollBoxRef.current = ref;\n\n if (ref && selectedOptionIndex !== undefined && isValidIndex(selectedOptionIndex)) {\n {\n scrollToElement(selectedOptionIndex, true);\n }\n }\n },\n [isValidIndex, scrollToElement, selectedOptionIndex],\n );\n\n const [keyboardInput, setKeyboardInput] = React.useState('');\n const resetKeyboardInput = React.useCallback(() => {\n setKeyboardInput('');\n }, []);\n\n const resetFocusedOption = React.useCallback(() => {\n setFocusedOptionIndex(-1);\n }, []);\n\n const onKeyboardInput = React.useCallback(\n (key: string) => {\n if (!opened) {\n setOpened(true);\n }\n resetFocusedOption();\n const fullInput = keyboardInput + key;\n\n setKeyboardInput(fullInput);\n },\n [keyboardInput, opened, resetFocusedOption],\n );\n\n /**\n * Note: сбрасывать `options` через `setOptions(optionsProp)` не нужно.\n * Сброс происходит в одном из эффекте `updateOptionsAndSelectedOptionIndex()`.\n */\n const close = React.useCallback(() => {\n resetKeyboardInput();\n\n setInputValue('');\n setOpened(false);\n resetFocusedOption();\n onClose?.();\n }, [onClose, resetKeyboardInput, resetFocusedOption]);\n\n const selectOption = React.useCallback(\n (index: number) => {\n const item = options[index];\n\n setNativeSelectValue(item?.value);\n close();\n\n const shouldTriggerOnChangeWhenControlledAndInnerValueIsOutOfSync =\n isControlledOutside &&\n props.value !== nativeSelectValue &&\n nativeSelectValue === item?.value;\n\n if (shouldTriggerOnChangeWhenControlledAndInnerValueIsOutOfSync) {\n const event = new Event('change', { bubbles: true });\n selectElRef.current?.dispatchEvent(event);\n }\n },\n [close, options, selectElRef, isControlledOutside, props.value, nativeSelectValue],\n );\n\n const selectFocused = React.useCallback(() => {\n if (focusedOptionIndex === undefined || !isValidIndex(focusedOptionIndex)) {\n return;\n }\n\n selectOption(focusedOptionIndex);\n }, [focusedOptionIndex, isValidIndex, selectOption]);\n\n const open = React.useCallback(() => {\n setOpened(true);\n setFocusedOptionIndex(selectedOptionIndex);\n\n if (typeof onOpen === 'function') {\n onOpen();\n }\n }, [onOpen, selectedOptionIndex]);\n\n const onBlur = React.useCallback(() => {\n close();\n const event = new Event('focusout', { bubbles: true });\n selectElRef.current?.dispatchEvent(event);\n }, [close, selectElRef]);\n\n const onFocus = React.useCallback(() => {\n const event = new Event('focusin', { bubbles: true });\n selectElRef.current?.dispatchEvent(event);\n }, [selectElRef]);\n\n const onClick = React.useCallback(() => {\n if (opened) {\n close();\n } else {\n open();\n }\n }, [close, open, opened]);\n\n const handleKeyUp = React.useMemo(() => debounce(resetKeyboardInput, 1000), [resetKeyboardInput]);\n\n const focusOption = React.useCallback(\n (type: 'next' | 'prev') => {\n let index = focusedOptionIndex;\n\n if (type === 'next') {\n const nextIndex = findIndexAfter(options, index);\n index = nextIndex === -1 ? findIndexAfter(options) : nextIndex; // Следующий за index или первый валидный до index\n } else if (type === 'prev') {\n const beforeIndex = findIndexBefore(options, index);\n index = beforeIndex === -1 ? findIndexBefore(options) : beforeIndex; // Предшествующий index или последний валидный после index\n }\n\n focusOptionByIndex(index);\n },\n [focusOptionByIndex, focusedOptionIndex, options],\n );\n\n React.useEffect(\n function updateOptionsAndSelectedOptionIndex() {\n const value = props.value ?? nativeSelectValue ?? defaultValue;\n\n const options =\n searchable && inputValue !== undefined\n ? filter(optionsProp, inputValue, filterFn)\n : optionsProp;\n\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, value, allowClearButton));\n },\n [\n filterFn,\n inputValue,\n nativeSelectValue,\n optionsProp,\n defaultValue,\n props.value,\n searchable,\n allowClearButton,\n ],\n );\n\n const onNativeSelectChange: React.ChangeEventHandler<HTMLSelectElement> = (e) => {\n const newSelectedOptionIndex = findSelectedIndex(\n options,\n e.currentTarget.value,\n allowClearButton,\n );\n\n if (selectedOptionIndex !== newSelectedOptionIndex) {\n if (!isControlledOutside) {\n setSelectedOptionIndex(newSelectedOptionIndex);\n }\n onChange?.(e);\n }\n };\n\n const onInputChange: React.ChangeEventHandler<HTMLInputElement> = React.useCallback(\n (e) => {\n onInputChangeProp && onInputChangeProp(e);\n\n const options = filter(optionsProp, e.target.value, filterFn);\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, nativeSelectValue, allowClearButton));\n\n setInputValue(e.target.value);\n },\n [filterFn, nativeSelectValue, onInputChangeProp, optionsProp, allowClearButton],\n );\n\n const areOptionsShown = React.useCallback(() => {\n return scrollBoxRef.current !== null;\n }, []);\n\n const handleKeyDownSelect = React.useCallback(\n (event: React.KeyboardEvent) => {\n if (event.key.length === 1 && event.key !== ' ') {\n onKeyboardInput(event.key);\n return;\n }\n\n ['ArrowUp', 'ArrowDown', 'Escape', 'Enter'].includes(event.key) &&\n areOptionsShown() &&\n event.preventDefault();\n\n switch (event.key) {\n case 'ArrowUp':\n if (opened) {\n areOptionsShown() && focusOption('prev');\n } else {\n open();\n }\n break;\n case 'ArrowDown':\n if (opened) {\n areOptionsShown() && focusOption('next');\n } else {\n open();\n }\n break;\n case 'Escape':\n close();\n break;\n case 'Backspace':\n case 'Delete': {\n if (!opened) {\n setOpened(true);\n }\n resetFocusedOption();\n\n break;\n }\n case 'Enter':\n case 'Spacebar':\n case ' ':\n if (opened) {\n areOptionsShown() && selectFocused();\n } else {\n open();\n }\n break;\n }\n },\n [\n areOptionsShown,\n close,\n focusOption,\n onKeyboardInput,\n open,\n opened,\n selectFocused,\n resetFocusedOption,\n ],\n );\n\n const handleOptionClick = React.useCallback(\n (e: React.MouseEvent<HTMLElement>) => {\n const index = Array.prototype.indexOf.call(\n e.currentTarget.parentNode?.children,\n e.currentTarget,\n );\n const option = options[index];\n\n if (option && !option.disabled) {\n selectOption(index);\n }\n },\n [options, selectOption],\n );\n\n const prevMousePositionRef = React.useRef<{\n x: React.MouseEvent['clientX'];\n y: React.MouseEvent['clientY'];\n }>({ x: 0, y: 0 });\n const focusOptionOnMouseMove = React.useCallback(\n (e: React.MouseEvent<HTMLElement>, index: number) => {\n const isMouseChangedPosition =\n Math.abs(prevMousePositionRef.current.x - e.clientX) >= 1 ||\n Math.abs(prevMousePositionRef.current.y - e.clientY) >= 1;\n\n if (isMouseChangedPosition) {\n focusOptionByIndex(index, false);\n }\n\n prevMousePositionRef.current = { x: e.clientX, y: e.clientY };\n },\n [focusOptionByIndex],\n );\n\n const popupAriaId = React.useId();\n const renderOption = React.useCallback(\n (option: OptionInterfaceT, index: number) => {\n const hovered = index === focusedOptionIndex;\n const selected = index === selectedOptionIndex;\n\n return (\n <React.Fragment key={`${option.value}`}>\n {renderOptionProp({\n option,\n hovered,\n children: option.label,\n selected,\n disabled: option.disabled,\n onClick: handleOptionClick,\n onMouseDown: handleOptionDown,\n // Используем `onMouseMove` вместо `onMouseEnter/onMouseOver`.\n // Потому что если при навигации с клавиатуры курсор наведён на\n // список, то при первом автоматическом скролле списка вызывается событие MouseOver/MouseEnter\n // обработчик которого фокусирует опцию под курсором, хотя при навигация с клавиатуры пользователь мог уйти дальше по списку, это путает.\n // Причём координаты события меняются на пару пикселей по сравнению с прошлым вызовом,\n // а значит нельзя на них опираться, чтобы запретить обработку такого события.\n // C mousemove такой проблемы нет, что позволяет реализовать поведение при наведении с клавиатуры и при наведении мышью идентично `<select>`.\n onMouseMove: (e) => focusOptionOnMouseMove(e, index),\n id: `${popupAriaId}-${option.value}`,\n })}\n </React.Fragment>\n );\n },\n [\n focusedOptionIndex,\n handleOptionClick,\n focusOptionOnMouseMove,\n renderOptionProp,\n selectedOptionIndex,\n popupAriaId,\n ],\n );\n\n const resolvedContent = React.useMemo(() => {\n const defaultDropdownContent =\n options?.length > 0 ? (\n options.map(renderOption)\n ) : (\n <Footnote className={styles['CustomSelect__empty']}>{emptyText}</Footnote>\n );\n\n if (typeof renderDropdown === 'function') {\n return renderDropdown({ defaultDropdownContent });\n } else {\n return defaultDropdownContent;\n }\n }, [emptyText, options, renderDropdown, renderOption]);\n\n const selectInputRef = React.useRef<HTMLInputElement | null>(null);\n const focusOnInputTimerRef = React.useRef<ReturnType<typeof setTimeout>>();\n const focusOnInput = React.useCallback(() => {\n clearTimeout(focusOnInputTimerRef.current);\n\n focusOnInputTimerRef.current = setTimeout(() => {\n selectInputRef.current && selectInputRef.current.focus();\n }, 0);\n }, []);\n useIsomorphicLayoutEffect(function clearFocusOnInputTimer() {\n return () => {\n clearTimeout(focusOnInputTimerRef.current);\n };\n }, []);\n\n const controlledValueSet = isControlledOutside && props.value !== '';\n const uncontrolledValueSet = !isControlledOutside && nativeSelectValue !== '';\n const clearButtonShown =\n allowClearButton && !opened && (controlledValueSet || uncontrolledValueSet);\n\n const clearButton = React.useMemo(() => {\n if (!clearButtonShown) {\n return null;\n }\n\n return (\n <ClearButton\n className={iconProp === undefined ? styles['CustomSelect--clear-icon'] : undefined}\n onClick={function clearSelectState() {\n setNativeSelectValue('');\n setInputValue('');\n focusOnInput();\n }}\n disabled={restProps.disabled}\n data-testid={clearButtonTestId}\n />\n );\n }, [\n clearButtonShown,\n ClearButton,\n iconProp,\n restProps.disabled,\n clearButtonTestId,\n focusOnInput,\n ]);\n\n const icon = React.useMemo(() => {\n if (iconProp !== undefined) {\n return iconProp;\n }\n\n return (\n <DropdownIcon\n className={clearButtonShown ? styles['CustomSelect__dropdown-icon'] : undefined}\n opened={opened}\n />\n );\n }, [clearButtonShown, iconProp, opened]);\n\n const afterIcons = (icon || clearButtonShown) && (\n <React.Fragment>\n {clearButton}\n {icon}\n </React.Fragment>\n );\n\n const { document } = useDOM();\n const passClickAndFocusToInputOnClick = React.useCallback(\n (e: React.MouseEvent<HTMLDivElement>) => {\n // Раньше внешней оберткой CustomSelect был <label>, что позволяло по клику в любую область CustomSelect,\n // даже где нету интерактивного элемента, фокусировать <input> и передавать на него событие клика.\n // Так как мы больше не оборачиваем CustomSelect в <label>, то для обертки CustomSelect мы симулируем работу <label>.\n // передаем фокус и клик по <input>, если пользователь кликнул в зоне обертки.\n // В <label> мы не больше не оборачиваем, потому что это заставляет скринридер\n // дважды произносить текст выбранной опции при фокусе, если CustomSelect связан с внешним <label>.\n // Воспроизводится в некоторых версиях Chrome, при навигации по странице с помощью стрелок.\n // Договорились со специалистом по доступности убрать <label>-обёртки из Select и CustomSelect\n\n if (!selectInputRef.current || !document) {\n return;\n }\n\n const clickTargetIsNotAnInput = e.target !== selectInputRef.current;\n if (clickTargetIsNotAnInput) {\n selectInputRef.current.click();\n\n const inputIsNotFocused = document.activeElement !== selectInputRef.current;\n if (inputIsNotFocused) {\n focusOnInput();\n }\n }\n },\n [document, focusOnInput],\n );\n\n const preventInputBlurWhenClickInsideFocusedSelectArea = (\n e: React.MouseEvent<HTMLDivElement>,\n ) => {\n // Так как инпут больше не оборачивается пустым лэйблом, то клик внутри обертки,\n // но вне инпута (например по иконке дропдауна), будет убирать фокус с инпута.\n // Чтобы в такой ситуации отключить blur инпута мы превентим mousedown событие обёртки\n const isInputFocused = document && document.activeElement === selectInputRef.current;\n if (isInputFocused) {\n e.preventDefault();\n }\n };\n\n const ariaActiveDescendantOptionIndex: undefined | number =\n focusedOptionIndex !== -1 ? focusedOptionIndex : undefined;\n const ariaActiveDescendantId =\n ariaActiveDescendantOptionIndex !== undefined\n ? options[ariaActiveDescendantOptionIndex] && options[ariaActiveDescendantOptionIndex].value\n : null;\n\n const selectInputAriaProps: React.HTMLAttributes<HTMLElement> = {\n 'role': 'combobox',\n 'aria-controls': popupAriaId,\n 'aria-owns': popupAriaId,\n 'aria-expanded': opened,\n ['aria-activedescendant']:\n ariaActiveDescendantId && opened ? `${popupAriaId}-${ariaActiveDescendantId}` : undefined,\n 'aria-labelledby': ariaLabelledBy,\n 'aria-haspopup': 'listbox',\n 'aria-autocomplete': 'none',\n };\n\n const focusWithin = useFocusWithin(handleRootRef);\n\n return (\n <div\n className={classNames(\n styles['CustomSelect'],\n sizeY !== 'regular' && sizeYClassNames[sizeY],\n className,\n )}\n style={style}\n ref={handleRootRef}\n onClick={passClickAndFocusToInputOnClick}\n onMouseDown={preventInputBlurWhenClickInsideFocusedSelectArea}\n >\n {focusWithin && selected && !opened && (\n <VisuallyHidden aria-live=\"polite\">{selected.label}</VisuallyHidden>\n )}\n <CustomSelectInput\n autoComplete=\"off\"\n autoCapitalize=\"none\"\n autoCorrect=\"off\"\n spellCheck=\"false\"\n {...restProps}\n {...selectInputAriaProps}\n getRef={selectInputRef}\n onFocus={onFocus}\n onBlur={onBlur}\n className={openedClassNames}\n readOnly={!searchable}\n fetching={fetching}\n value={inputValue}\n onKeyUp={handleKeyUp}\n onKeyDown={handleKeyDownSelect}\n onChange={onInputChange}\n onClick={onClick}\n before={before}\n after={afterIcons}\n selectType={selectType}\n >\n {selected?.label}\n </CustomSelectInput>\n <select\n ref={selectElRef}\n name={name}\n onChange={onNativeSelectChange}\n onBlur={props.onBlur}\n onFocus={props.onFocus}\n onClick={props.onClick}\n value={nativeSelectValue}\n aria-hidden\n className={styles['CustomSelect__control']}\n data-testid={nativeSelectTestId}\n required={required}\n >\n {allowClearButton && <option key=\"\" value=\"\" />}\n {optionsProp.map((item) => (\n <option key={`${item.value}`} value={item.value} />\n ))}\n </select>\n {opened && (\n <CustomSelectDropdown\n targetRef={containerRef}\n placement={popupDirection}\n scrollBoxRef={setScrollBoxRef}\n onPlacementChange={setPopperPlacement}\n onMouseLeave={resetFocusedOption}\n fetching={fetching}\n offsetDistance={dropdownOffsetDistance}\n autoWidth={dropdownAutoWidth}\n forcePortal={forceDropdownPortal}\n autoHideScrollbar={autoHideScrollbar}\n autoHideScrollbarDelay={autoHideScrollbarDelay}\n noMaxHeight={noMaxHeight}\n role=\"listbox\"\n id={popupAriaId}\n aria-labelledby={ariaLabelledBy}\n tabIndex={-1}\n >\n {resolvedContent}\n </CustomSelectDropdown>\n )}\n </div>\n );\n}\n"],"names":["CustomSelect","sizeYClassNames","none","findIndexAfter","options","startIndex","length","findIndex","option","i","disabled","findIndexBefore","endIndex","result","warn","warnOnce","checkOptionsValueType","Set","map","item","value","size","defaultRenderOptionFn","props","CustomSelectOption","handleOptionDown","e","preventDefault","findSelectedIndex","withClear","Number","filter","inputValue","filterFn","defaultOptions","opened","setOpened","React","useState","before","name","className","getRef","getRootRef","popupDirection","style","onChange","children","onInputChange","onInputChangeProp","renderDropdown","onOpen","onClose","fetching","forceDropdownPortal","selectType","autoHideScrollbar","autoHideScrollbarDelay","searchable","renderOption","renderOptionProp","optionsProp","emptyText","defaultFilterFn","icon","iconProp","ClearButton","CustomSelectClearButton","allowClearButton","dropdownOffsetDistance","dropdownAutoWidth","noMaxHeight","ariaLabelledBy","clearButtonTestId","nativeSelectTestId","defaultValue","required","restProps","process","env","NODE_ENV","sizeY","useAdaptivity","containerRef","useRef","handleRootRef","useExternRef","scrollBoxRef","selectElRef","focusedOptionIndex","setFocusedOptionIndex","isControlledOutside","setIsControlledOutside","undefined","setInputValue","nativeSelectValue","setNativeSelectValue","popperPlacement","setPopperPlacement","setOptions","selectedOptionIndex","setSelectedOptionIndex","useEffect","useIsomorphicLayoutEffect","some","event","Event","bubbles","current","dispatchEvent","selected","useMemo","openedClassNames","includes","scrollToElement","useCallback","index","center","dropdown","firstElementChild","dropdownHeight","offsetHeight","scrollTop","itemTop","offsetTop","itemHeight","focusOptionByIndex","scrollTo","isValidIndex","setScrollBoxRef","ref","keyboardInput","setKeyboardInput","resetKeyboardInput","resetFocusedOption","onKeyboardInput","key","fullInput","close","selectOption","shouldTriggerOnChangeWhenControlledAndInnerValueIsOutOfSync","selectFocused","open","onBlur","onFocus","onClick","handleKeyUp","debounce","focusOption","type","nextIndex","beforeIndex","updateOptionsAndSelectedOptionIndex","onNativeSelectChange","newSelectedOptionIndex","currentTarget","target","areOptionsShown","handleKeyDownSelect","handleOptionClick","Array","prototype","indexOf","call","parentNode","prevMousePositionRef","x","y","focusOptionOnMouseMove","isMouseChangedPosition","Math","abs","clientX","clientY","popupAriaId","useId","hovered","Fragment","label","onMouseDown","onMouseMove","id","resolvedContent","defaultDropdownContent","Footnote","selectInputRef","focusOnInputTimerRef","focusOnInput","clearTimeout","setTimeout","focus","clearFocusOnInputTimer","controlledValueSet","uncontrolledValueSet","clearButtonShown","clearButton","clearSelectState","data-testid","DropdownIcon","afterIcons","document","useDOM","passClickAndFocusToInputOnClick","clickTargetIsNotAnInput","click","inputIsNotFocused","activeElement","preventInputBlurWhenClickInsideFocusedSelectArea","isInputFocused","ariaActiveDescendantOptionIndex","ariaActiveDescendantId","selectInputAriaProps","focusWithin","useFocusWithin","div","classNames","VisuallyHidden","aria-live","CustomSelectInput","autoComplete","autoCapitalize","autoCorrect","spellCheck","readOnly","onKeyUp","onKeyDown","after","select","aria-hidden","CustomSelectDropdown","targetRef","placement","onPlacementChange","onMouseLeave","offsetDistance","autoWidth","forcePortal","role","aria-labelledby","tabIndex"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/CustomSelect/CustomSelectClearButton.tsx"],"sourcesContent":["import { Icon16Cancel } from '@vkontakte/icons';\nimport { stopPropagation } from '../../lib/utils';\nimport { HasDataAttribute } from '../../types';\nimport { IconButton } from '../IconButton/IconButton';\n\nexport interface CustomSelectClearButtonProps extends HasDataAttribute {\n className?: string;\n onClick: () => void;\n disabled?: boolean;\n}\n\nexport const CustomSelectClearButton = ({\n className,\n onClick,\n ...restProps\n}: CustomSelectClearButtonProps) => {\n return (\n <IconButton\n Component=\"button\"\n label=\"Очистить поле\"\n onKeyDown={stopPropagation}\n type=\"button\"\n activeMode=\"opacity\"\n hoverMode=\"opacity\"\n {...restProps}\n className={className}\n onClick={(e) => {\n stopPropagation(e);\n e.preventDefault();\n onClick();\n }}\n >\n <Icon16Cancel />\n </IconButton>\n );\n};\n"],"names":["CustomSelectClearButton","className","onClick","restProps","IconButton","Component","label","onKeyDown","stopPropagation","type","activeMode","hoverMode","e","preventDefault","Icon16Cancel"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";;;;+BAWaA;;;eAAAA;;;;;;;uBAXgB;uBACG;4BAEL;AAQpB,MAAMA,0BAA0B;QAAC,EACtCC,SAAS,EACTC,OAAO,EAEsB,WAD1BC;QAFHF;QACAC;;IAGA,qBACE,qBAACE,sBAAU;QACTC,WAAU;QACVC,OAAM;QACNC,WAAWC,sBAAe;QAC1BC,MAAK;QACLC,YAAW;QACXC,WAAU;OACNR;QACJF,WAAWA;QACXC,SAAS,CAACU;YACRJ,IAAAA,sBAAe,EAACI;YAChBA,EAAEC,cAAc;YAChBX;QACF;kBAEA,cAAA,qBAACY,mBAAY;;AAGnB"}
1
+ {"version":3,"sources":["../../../../src/components/CustomSelect/CustomSelectClearButton.tsx"],"sourcesContent":["import { Icon16Cancel } from '@vkontakte/icons';\nimport { stopPropagation } from '../../lib/utils';\nimport { HasDataAttribute } from '../../types';\nimport { IconButton } from '../IconButton/IconButton';\n\nexport interface CustomSelectClearButtonProps extends HasDataAttribute {\n className?: string;\n onClick: () => void;\n disabled?: boolean;\n}\n\nexport const CustomSelectClearButton = ({\n className,\n onClick,\n ...restProps\n}: CustomSelectClearButtonProps) => {\n return (\n <IconButton\n Component=\"button\"\n label=\"Очистить поле\"\n onKeyDown={stopPropagation}\n type=\"button\"\n activeMode=\"opacity\"\n hoverMode=\"opacity\"\n {...restProps}\n className={className}\n onClick={(e) => {\n stopPropagation(e);\n e.preventDefault();\n onClick();\n }}\n >\n <Icon16Cancel />\n </IconButton>\n );\n};\n"],"names":["CustomSelectClearButton","className","onClick","restProps","IconButton","Component","label","onKeyDown","stopPropagation","type","activeMode","hoverMode","e","preventDefault","Icon16Cancel"],"mappings":";;;;+BAWaA;;;eAAAA;;;;;;;uBAXgB;uBACG;4BAEL;AAQpB,MAAMA,0BAA0B;QAAC,EACtCC,SAAS,EACTC,OAAO,EAEsB,WAD1BC;QAFHF;QACAC;;IAGA,qBACE,qBAACE,sBAAU;QACTC,WAAU;QACVC,OAAM;QACNC,WAAWC,sBAAe;QAC1BC,MAAK;QACLC,YAAW;QACXC,WAAU;OACNR;QACJF,WAAWA;QACXC,SAAS,CAACU;YACRJ,IAAAA,sBAAe,EAACI;YAChBA,EAAEC,cAAc;YAChBX;QACF;kBAEA,cAAA,qBAACY,mBAAY;;AAGnB"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/CustomSelect/CustomSelectInput.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useFocusWithin } from '../../hooks/useFocusWithin';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { getFormFieldModeFromSelectType } from '../../lib/select';\nimport { HasAlign, HasRef, HasRootRef } from '../../types';\nimport { FormField, FormFieldProps } from '../FormField/FormField';\nimport type { SelectType } from '../Select/Select';\nimport { SelectTypography } from '../SelectTypography/SelectTypography';\nimport { Text } from '../Typography/Text/Text';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport styles from './CustomSelectInput.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelectInput--sizeY-none'],\n compact: styles['CustomSelectInput--sizeY-compact'],\n};\n\nexport interface CustomSelectInputProps\n extends React.InputHTMLAttributes<HTMLInputElement>,\n HasRef<HTMLInputElement>,\n HasRootRef<HTMLDivElement>,\n HasAlign,\n Omit<FormFieldProps, 'mode' | 'type'> {\n selectType?: SelectType;\n multiline?: boolean;\n labelTextTestId?: string;\n fetching?: boolean;\n}\n\n/**\n * @since 5.10.0\n * @private\n */\nexport const CustomSelectInput = ({\n align = 'left',\n getRef,\n className,\n getRootRef,\n style,\n before,\n after,\n status,\n children,\n placeholder,\n selectType = 'default',\n multiline,\n disabled,\n fetching,\n labelTextTestId,\n ...restProps\n}: CustomSelectInputProps) => {\n const { sizeY = 'none' } = useAdaptivity();\n\n const title = children || placeholder;\n const showLabelOrPlaceholder = !Boolean(restProps.value);\n\n const handleRootRef = useExternRef(getRootRef);\n const focusWithin = useFocusWithin(handleRootRef);\n\n const input = (\n <Text\n type=\"text\"\n {...restProps}\n disabled={disabled && !fetching}\n readOnly={restProps.readOnly || (disabled && fetching)}\n Component=\"input\"\n normalize={false}\n className={classNames(\n styles['CustomSelectInput__el'],\n (restProps.readOnly || (showLabelOrPlaceholder && !focusWithin)) &&\n styles['CustomSelectInput__el--cursor-pointer'],\n )}\n getRootRef={getRef}\n placeholder={children ? '' : placeholder}\n />\n );\n\n const platform = usePlatform();\n return (\n <FormField\n Component=\"div\"\n style={style}\n className={classNames(\n styles['CustomSelectInput'],\n align === 'right' && styles['CustomSelectInput--align-right'],\n align === 'center' && styles['CustomSelectInput--align-center'],\n !children && styles['CustomSelectInput--empty'],\n multiline && styles['CustomSelectInput--multiline'],\n sizeY !== 'regular' && sizeYClassNames[sizeY],\n before && styles['CustomSelectInput--hasBefore'],\n after && styles['CustomSelectInput--hasAfter'],\n className,\n )}\n getRootRef={handleRootRef}\n before={before}\n after={after}\n disabled={disabled}\n mode={getFormFieldModeFromSelectType(selectType)}\n status={status}\n >\n <div className={styles['CustomSelectInput__input-group']}>\n <div\n className={classNames(styles['CustomSelectInput__container'], className)}\n tabIndex={-1}\n aria-hidden\n data-testid={labelTextTestId}\n >\n <SelectTypography selectType={selectType} className={styles['CustomSelectInput__title']}>\n {showLabelOrPlaceholder && title}\n </SelectTypography>\n </div>\n {/* Чтобы отключить autosuggestion в iOS, тултипы которого начинают всплывать даже когда input\n * в режиме readonly, мы оборачиваем инпут в VisuallyHidden.\n * Тултипы появляются при каждом клике на input.\n * смотри: https://github.com/VKCOM/VKUI/issues/6205\n *\n * Достаточно не дать пользователю кликнуть по инпуту.\n * Делаем это только для режима read-only. Потому что проблема именно в режиме read-only.\n * Обертка вокруг инпута обрабатывает клики и передаёт фокус, так что на взаимодействии с инпутом это никак не скажется.\n **/}\n {restProps.readOnly && platform === 'ios' ? (\n <VisuallyHidden>{input}</VisuallyHidden>\n ) : (\n input\n )}\n </div>\n </FormField>\n );\n};\n"],"names":["CustomSelectInput","sizeYClassNames","none","compact","align","getRef","className","getRootRef","style","before","after","status","children","placeholder","selectType","multiline","disabled","fetching","labelTextTestId","restProps","sizeY","useAdaptivity","title","showLabelOrPlaceholder","Boolean","value","handleRootRef","useExternRef","focusWithin","useFocusWithin","input","Text","type","readOnly","Component","normalize","classNames","platform","usePlatform","FormField","mode","getFormFieldModeFromSelectType","div","tabIndex","aria-hidden","data-testid","SelectTypography","VisuallyHidden"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";;;;+BAoCaA;;;eAAAA;;;;;;;;iEApCU;sBACI;+BACG;8BACD;gCACE;6BACH;wBACmB;2BAEL;kCAET;sBACZ;gCACU;AAG/B,MAAMC,kBAAkB;IACtBC,IAAI;IACJC,OAAO;AACT;AAkBO,MAAMH,oBAAoB;QAAC,EAChCI,QAAQ,MAAM,EACdC,MAAM,EACNC,SAAS,EACTC,UAAU,EACVC,KAAK,EACLC,MAAM,EACNC,KAAK,EACLC,MAAM,EACNC,QAAQ,EACRC,WAAW,EACXC,aAAa,SAAS,EACtBC,SAAS,EACTC,QAAQ,EACRC,QAAQ,EACRC,eAAe,EAEQ,WADpBC;QAfHf;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;;IAGA,MAAM,EAAEE,QAAQ,MAAM,EAAE,GAAGC,IAAAA,4BAAa;IAExC,MAAMC,QAAQV,YAAYC;IAC1B,MAAMU,yBAAyB,CAACC,QAAQL,UAAUM,KAAK;IAEvD,MAAMC,gBAAgBC,IAAAA,0BAAY,EAACpB;IACnC,MAAMqB,cAAcC,IAAAA,8BAAc,EAACH;IAEnC,MAAMI,sBACJ,qBAACC,UAAI;QACHC,MAAK;OACDb;QACJH,UAAUA,YAAY,CAACC;QACvBgB,UAAUd,UAAUc,QAAQ,IAAKjB,YAAYC;QAC7CiB,WAAU;QACVC,WAAW;QACX7B,WAAW8B,IAAAA,gBAAU,+BAEnB,AAACjB,CAAAA,UAAUc,QAAQ,IAAKV,0BAA0B,CAACK,WAAW;QAGhErB,YAAYF;QACZQ,aAAaD,WAAW,KAAKC;;IAIjC,MAAMwB,WAAWC,IAAAA,wBAAW;IAC5B,qBACE,qBAACC,oBAAS;QACRL,WAAU;QACV1B,OAAOA;QACPF,WAAW8B,IAAAA,gBAAU,2BAEnBhC,UAAU,iDACVA,UAAU,mDACV,CAACQ,4CACDG,iDACAK,UAAU,aAAanB,eAAe,CAACmB,MAAM,EAC7CX,8CACAC,4CACAJ;QAEFC,YAAYmB;QACZjB,QAAQA;QACRC,OAAOA;QACPM,UAAUA;QACVwB,MAAMC,IAAAA,sCAA8B,EAAC3B;QACrCH,QAAQA;kBAER,cAAA,sBAAC+B;YAAIpC,SAAS;;8BACZ,qBAACoC;oBACCpC,WAAW8B,IAAAA,gBAAU,sCAAyC9B;oBAC9DqC,UAAU,CAAC;oBACXC,aAAW;oBACXC,eAAa3B;8BAEb,cAAA,qBAAC4B,kCAAgB;wBAAChC,YAAYA;wBAAYR,SAAS;kCAChDiB,0BAA0BD;;;gBAY9BH,UAAUc,QAAQ,IAAII,aAAa,sBAClC,qBAACU,8BAAc;8BAAEjB;qBAEjBA;;;;AAKV"}
1
+ {"version":3,"sources":["../../../../src/components/CustomSelect/CustomSelectInput.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useFocusWithin } from '../../hooks/useFocusWithin';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { getFormFieldModeFromSelectType } from '../../lib/select';\nimport { HasAlign, HasRef, HasRootRef } from '../../types';\nimport { FormField, FormFieldProps } from '../FormField/FormField';\nimport type { SelectType } from '../Select/Select';\nimport { SelectTypography } from '../SelectTypography/SelectTypography';\nimport { Text } from '../Typography/Text/Text';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport styles from './CustomSelectInput.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelectInput--sizeY-none'],\n compact: styles['CustomSelectInput--sizeY-compact'],\n};\n\nexport interface CustomSelectInputProps\n extends React.InputHTMLAttributes<HTMLInputElement>,\n HasRef<HTMLInputElement>,\n HasRootRef<HTMLDivElement>,\n HasAlign,\n Omit<FormFieldProps, 'mode' | 'type'> {\n selectType?: SelectType;\n multiline?: boolean;\n labelTextTestId?: string;\n fetching?: boolean;\n}\n\n/**\n * @since 5.10.0\n * @private\n */\nexport const CustomSelectInput = ({\n align = 'left',\n getRef,\n className,\n getRootRef,\n style,\n before,\n after,\n status,\n children,\n placeholder,\n selectType = 'default',\n multiline,\n disabled,\n fetching,\n labelTextTestId,\n ...restProps\n}: CustomSelectInputProps) => {\n const { sizeY = 'none' } = useAdaptivity();\n\n const title = children || placeholder;\n const showLabelOrPlaceholder = !Boolean(restProps.value);\n\n const handleRootRef = useExternRef(getRootRef);\n const focusWithin = useFocusWithin(handleRootRef);\n\n const input = (\n <Text\n type=\"text\"\n {...restProps}\n disabled={disabled && !fetching}\n readOnly={restProps.readOnly || (disabled && fetching)}\n Component=\"input\"\n normalize={false}\n className={classNames(\n styles['CustomSelectInput__el'],\n (restProps.readOnly || (showLabelOrPlaceholder && !focusWithin)) &&\n styles['CustomSelectInput__el--cursor-pointer'],\n )}\n getRootRef={getRef}\n placeholder={children ? '' : placeholder}\n />\n );\n\n const platform = usePlatform();\n return (\n <FormField\n Component=\"div\"\n style={style}\n className={classNames(\n styles['CustomSelectInput'],\n align === 'right' && styles['CustomSelectInput--align-right'],\n align === 'center' && styles['CustomSelectInput--align-center'],\n !children && styles['CustomSelectInput--empty'],\n multiline && styles['CustomSelectInput--multiline'],\n sizeY !== 'regular' && sizeYClassNames[sizeY],\n before && styles['CustomSelectInput--hasBefore'],\n after && styles['CustomSelectInput--hasAfter'],\n className,\n )}\n getRootRef={handleRootRef}\n before={before}\n after={after}\n disabled={disabled}\n mode={getFormFieldModeFromSelectType(selectType)}\n status={status}\n >\n <div className={styles['CustomSelectInput__input-group']}>\n <div\n className={classNames(styles['CustomSelectInput__container'], className)}\n tabIndex={-1}\n aria-hidden\n data-testid={labelTextTestId}\n >\n <SelectTypography selectType={selectType} className={styles['CustomSelectInput__title']}>\n {showLabelOrPlaceholder && title}\n </SelectTypography>\n </div>\n {/* Чтобы отключить autosuggestion в iOS, тултипы которого начинают всплывать даже когда input\n * в режиме readonly, мы оборачиваем инпут в VisuallyHidden.\n * Тултипы появляются при каждом клике на input.\n * смотри: https://github.com/VKCOM/VKUI/issues/6205\n *\n * Достаточно не дать пользователю кликнуть по инпуту.\n * Делаем это только для режима read-only. Потому что проблема именно в режиме read-only.\n * Обертка вокруг инпута обрабатывает клики и передаёт фокус, так что на взаимодействии с инпутом это никак не скажется.\n **/}\n {restProps.readOnly && platform === 'ios' ? (\n <VisuallyHidden>{input}</VisuallyHidden>\n ) : (\n input\n )}\n </div>\n </FormField>\n );\n};\n"],"names":["CustomSelectInput","sizeYClassNames","none","compact","align","getRef","className","getRootRef","style","before","after","status","children","placeholder","selectType","multiline","disabled","fetching","labelTextTestId","restProps","sizeY","useAdaptivity","title","showLabelOrPlaceholder","Boolean","value","handleRootRef","useExternRef","focusWithin","useFocusWithin","input","Text","type","readOnly","Component","normalize","classNames","platform","usePlatform","FormField","mode","getFormFieldModeFromSelectType","div","tabIndex","aria-hidden","data-testid","SelectTypography","VisuallyHidden"],"mappings":";;;;+BAoCaA;;;eAAAA;;;;;;;;iEApCU;sBACI;+BACG;8BACD;gCACE;6BACH;wBACmB;2BAEL;kCAET;sBACZ;gCACU;AAG/B,MAAMC,kBAAkB;IACtBC,IAAI;IACJC,OAAO;AACT;AAkBO,MAAMH,oBAAoB;QAAC,EAChCI,QAAQ,MAAM,EACdC,MAAM,EACNC,SAAS,EACTC,UAAU,EACVC,KAAK,EACLC,MAAM,EACNC,KAAK,EACLC,MAAM,EACNC,QAAQ,EACRC,WAAW,EACXC,aAAa,SAAS,EACtBC,SAAS,EACTC,QAAQ,EACRC,QAAQ,EACRC,eAAe,EAEQ,WADpBC;QAfHf;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;;IAGA,MAAM,EAAEE,QAAQ,MAAM,EAAE,GAAGC,IAAAA,4BAAa;IAExC,MAAMC,QAAQV,YAAYC;IAC1B,MAAMU,yBAAyB,CAACC,QAAQL,UAAUM,KAAK;IAEvD,MAAMC,gBAAgBC,IAAAA,0BAAY,EAACpB;IACnC,MAAMqB,cAAcC,IAAAA,8BAAc,EAACH;IAEnC,MAAMI,sBACJ,qBAACC,UAAI;QACHC,MAAK;OACDb;QACJH,UAAUA,YAAY,CAACC;QACvBgB,UAAUd,UAAUc,QAAQ,IAAKjB,YAAYC;QAC7CiB,WAAU;QACVC,WAAW;QACX7B,WAAW8B,IAAAA,gBAAU,+BAEnB,AAACjB,CAAAA,UAAUc,QAAQ,IAAKV,0BAA0B,CAACK,WAAW;QAGhErB,YAAYF;QACZQ,aAAaD,WAAW,KAAKC;;IAIjC,MAAMwB,WAAWC,IAAAA,wBAAW;IAC5B,qBACE,qBAACC,oBAAS;QACRL,WAAU;QACV1B,OAAOA;QACPF,WAAW8B,IAAAA,gBAAU,2BAEnBhC,UAAU,iDACVA,UAAU,mDACV,CAACQ,4CACDG,iDACAK,UAAU,aAAanB,eAAe,CAACmB,MAAM,EAC7CX,8CACAC,4CACAJ;QAEFC,YAAYmB;QACZjB,QAAQA;QACRC,OAAOA;QACPM,UAAUA;QACVwB,MAAMC,IAAAA,sCAA8B,EAAC3B;QACrCH,QAAQA;kBAER,cAAA,sBAAC+B;YAAIpC,SAAS;;8BACZ,qBAACoC;oBACCpC,WAAW8B,IAAAA,gBAAU,sCAAyC9B;oBAC9DqC,UAAU,CAAC;oBACXC,aAAW;oBACXC,eAAa3B;8BAEb,cAAA,qBAAC4B,kCAAgB;wBAAChC,YAAYA;wBAAYR,SAAS;kCAChDiB,0BAA0BD;;;gBAY9BH,UAAUc,QAAQ,IAAII,aAAa,sBAClC,qBAACU,8BAAc;8BAAEjB;qBAEjBA;;;;AAKV"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/CustomSelectDropdown/CustomSelectDropdown.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport type { Placement } from '../../lib/floating';\nimport { HTMLAttributesWithRootRef } from '../../types';\nimport { CustomScrollView } from '../CustomScrollView/CustomScrollView';\nimport { TrackerOptionsProps } from '../CustomScrollView/useTrackerVisibility';\nimport { Popper } from '../Popper/Popper';\nimport { Spinner } from '../Spinner/Spinner';\nimport styles from './CustomSelectDropdown.module.css';\n\nexport interface CustomSelectDropdownProps\n extends HTMLAttributesWithRootRef<HTMLDivElement>,\n TrackerOptionsProps {\n targetRef: React.RefObject<HTMLElement>;\n placement?: Placement;\n scrollBoxRef?: React.Ref<HTMLDivElement>;\n fetching?: boolean;\n offsetDistance?: number;\n /**\n * Ширина раскрывающегося списка зависит от контента\n */\n autoWidth?: boolean;\n forcePortal?: boolean;\n onPlacementChange?: (placement: Placement) => void;\n /**\n * Отключает максимальную высоту по умолчанию\n */\n noMaxHeight?: boolean;\n}\n\nconst calcIsTop = (placement: Placement) => placement.startsWith('top');\n\nexport const CustomSelectDropdown = ({\n children,\n targetRef,\n scrollBoxRef,\n placement = 'bottom',\n fetching,\n onPlacementChange: parentOnPlacementChange,\n offsetDistance = 0,\n autoWidth = false,\n forcePortal = true,\n autoHideScrollbar,\n autoHideScrollbarDelay,\n className,\n noMaxHeight = false,\n ...restProps\n}: CustomSelectDropdownProps) => {\n const [isTop, setIsTop] = React.useState(() => calcIsTop(placement));\n\n const onPlacementChange = React.useCallback(\n (placement: Placement) => {\n setIsTop(calcIsTop(placement));\n if (parentOnPlacementChange) {\n parentOnPlacementChange(placement);\n }\n },\n [parentOnPlacementChange],\n );\n\n return (\n <Popper\n targetRef={targetRef}\n offsetByMainAxis={offsetDistance}\n sameWidth={!autoWidth}\n onPlacementChange={onPlacementChange}\n placement={placement}\n className={classNames(\n styles['CustomSelectDropdown'],\n 'vkuiInternalCustomSelectDropdown',\n offsetDistance === 0 &&\n (isTop ? styles['CustomSelectDropdown--top'] : styles['CustomSelectDropdown--bottom']),\n autoWidth &&\n classNames(\n styles['CustomSelectDropdown--wide'],\n 'vkuiInternalCustomSelectDropdown--wide',\n ),\n className,\n )}\n usePortal={forcePortal}\n autoUpdateOnTargetResize\n {...restProps}\n >\n <CustomScrollView\n boxRef={scrollBoxRef}\n className={noMaxHeight ? undefined : styles['CustomSelectDropdown__in--withMaxHeight']}\n autoHideScrollbar={autoHideScrollbar}\n autoHideScrollbarDelay={autoHideScrollbarDelay}\n >\n {fetching ? (\n <div className={styles['CustomSelectDropdown__fetching']}>\n <Spinner size=\"small\" />\n </div>\n ) : (\n children\n )}\n </CustomScrollView>\n </Popper>\n );\n};\n"],"names":["CustomSelectDropdown","calcIsTop","placement","startsWith","children","targetRef","scrollBoxRef","fetching","onPlacementChange","parentOnPlacementChange","offsetDistance","autoWidth","forcePortal","autoHideScrollbar","autoHideScrollbarDelay","className","noMaxHeight","restProps","isTop","setIsTop","React","useState","useCallback","Popper","offsetByMainAxis","sameWidth","classNames","usePortal","autoUpdateOnTargetResize","CustomScrollView","boxRef","undefined","div","Spinner","size"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";;;;+BAgCaA;;;eAAAA;;;;;;;;iEAhCU;sBACI;kCAGM;wBAEV;yBACC;AAuBxB,MAAMC,YAAY,CAACC,YAAyBA,UAAUC,UAAU,CAAC;AAE1D,MAAMH,uBAAuB;QAAC,EACnCI,QAAQ,EACRC,SAAS,EACTC,YAAY,EACZJ,YAAY,QAAQ,EACpBK,QAAQ,EACRC,mBAAmBC,uBAAuB,EAC1CC,iBAAiB,CAAC,EAClBC,YAAY,KAAK,EACjBC,cAAc,IAAI,EAClBC,iBAAiB,EACjBC,sBAAsB,EACtBC,SAAS,EACTC,cAAc,KAAK,EAEO,WADvBC;QAbHb;QACAC;QACAC;QACAJ;QACAK;QACAC;QACAE;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;;IAGA,MAAM,CAACE,OAAOC,SAAS,GAAGC,OAAMC,QAAQ,CAAC,IAAMpB,UAAUC;IAEzD,MAAMM,oBAAoBY,OAAME,WAAW,CACzC,CAACpB;QACCiB,SAASlB,UAAUC;QACnB,IAAIO,yBAAyB;YAC3BA,wBAAwBP;QAC1B;IACF,GACA;QAACO;KAAwB;IAG3B,qBACE,qBAACc,cAAM;QACLlB,WAAWA;QACXmB,kBAAkBd;QAClBe,WAAW,CAACd;QACZH,mBAAmBA;QACnBN,WAAWA;QACXa,WAAWW,IAAAA,gBAAU,8BAEnB,oCACAhB,mBAAmB,KAChBQ,CAAAA,4EAAmF,GACtFP,aACEe,IAAAA,gBAAU,oCAER,2CAEJX;QAEFY,WAAWf;QACXgB,wBAAwB;OACpBX;kBAEJ,cAAA,qBAACY,kCAAgB;YACfC,QAAQxB;YACRS,WAAWC,cAAce;YACzBlB,mBAAmBA;YACnBC,wBAAwBA;sBAEvBP,yBACC,qBAACyB;gBAAIjB,SAAS;0BACZ,cAAA,qBAACkB,gBAAO;oBAACC,MAAK;;iBAGhB9B;;;AAKV"}
1
+ {"version":3,"sources":["../../../../src/components/CustomSelectDropdown/CustomSelectDropdown.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport type { Placement } from '../../lib/floating';\nimport { HTMLAttributesWithRootRef } from '../../types';\nimport { CustomScrollView } from '../CustomScrollView/CustomScrollView';\nimport { TrackerOptionsProps } from '../CustomScrollView/useTrackerVisibility';\nimport { Popper } from '../Popper/Popper';\nimport { Spinner } from '../Spinner/Spinner';\nimport styles from './CustomSelectDropdown.module.css';\n\nexport interface CustomSelectDropdownProps\n extends HTMLAttributesWithRootRef<HTMLDivElement>,\n TrackerOptionsProps {\n targetRef: React.RefObject<HTMLElement>;\n placement?: Placement;\n scrollBoxRef?: React.Ref<HTMLDivElement>;\n fetching?: boolean;\n offsetDistance?: number;\n /**\n * Ширина раскрывающегося списка зависит от контента\n */\n autoWidth?: boolean;\n forcePortal?: boolean;\n onPlacementChange?: (placement: Placement) => void;\n /**\n * Отключает максимальную высоту по умолчанию\n */\n noMaxHeight?: boolean;\n}\n\nconst calcIsTop = (placement: Placement) => placement.startsWith('top');\n\nexport const CustomSelectDropdown = ({\n children,\n targetRef,\n scrollBoxRef,\n placement = 'bottom',\n fetching,\n onPlacementChange: parentOnPlacementChange,\n offsetDistance = 0,\n autoWidth = false,\n forcePortal = true,\n autoHideScrollbar,\n autoHideScrollbarDelay,\n className,\n noMaxHeight = false,\n ...restProps\n}: CustomSelectDropdownProps) => {\n const [isTop, setIsTop] = React.useState(() => calcIsTop(placement));\n\n const onPlacementChange = React.useCallback(\n (placement: Placement) => {\n setIsTop(calcIsTop(placement));\n if (parentOnPlacementChange) {\n parentOnPlacementChange(placement);\n }\n },\n [parentOnPlacementChange],\n );\n\n return (\n <Popper\n targetRef={targetRef}\n offsetByMainAxis={offsetDistance}\n sameWidth={!autoWidth}\n onPlacementChange={onPlacementChange}\n placement={placement}\n className={classNames(\n styles['CustomSelectDropdown'],\n 'vkuiInternalCustomSelectDropdown',\n offsetDistance === 0 &&\n (isTop ? styles['CustomSelectDropdown--top'] : styles['CustomSelectDropdown--bottom']),\n autoWidth &&\n classNames(\n styles['CustomSelectDropdown--wide'],\n 'vkuiInternalCustomSelectDropdown--wide',\n ),\n className,\n )}\n usePortal={forcePortal}\n autoUpdateOnTargetResize\n {...restProps}\n >\n <CustomScrollView\n boxRef={scrollBoxRef}\n className={noMaxHeight ? undefined : styles['CustomSelectDropdown__in--withMaxHeight']}\n autoHideScrollbar={autoHideScrollbar}\n autoHideScrollbarDelay={autoHideScrollbarDelay}\n >\n {fetching ? (\n <div className={styles['CustomSelectDropdown__fetching']}>\n <Spinner size=\"small\" />\n </div>\n ) : (\n children\n )}\n </CustomScrollView>\n </Popper>\n );\n};\n"],"names":["CustomSelectDropdown","calcIsTop","placement","startsWith","children","targetRef","scrollBoxRef","fetching","onPlacementChange","parentOnPlacementChange","offsetDistance","autoWidth","forcePortal","autoHideScrollbar","autoHideScrollbarDelay","className","noMaxHeight","restProps","isTop","setIsTop","React","useState","useCallback","Popper","offsetByMainAxis","sameWidth","classNames","usePortal","autoUpdateOnTargetResize","CustomScrollView","boxRef","undefined","div","Spinner","size"],"mappings":";;;;+BAgCaA;;;eAAAA;;;;;;;;iEAhCU;sBACI;kCAGM;wBAEV;yBACC;AAuBxB,MAAMC,YAAY,CAACC,YAAyBA,UAAUC,UAAU,CAAC;AAE1D,MAAMH,uBAAuB;QAAC,EACnCI,QAAQ,EACRC,SAAS,EACTC,YAAY,EACZJ,YAAY,QAAQ,EACpBK,QAAQ,EACRC,mBAAmBC,uBAAuB,EAC1CC,iBAAiB,CAAC,EAClBC,YAAY,KAAK,EACjBC,cAAc,IAAI,EAClBC,iBAAiB,EACjBC,sBAAsB,EACtBC,SAAS,EACTC,cAAc,KAAK,EAEO,WADvBC;QAbHb;QACAC;QACAC;QACAJ;QACAK;QACAC;QACAE;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;;IAGA,MAAM,CAACE,OAAOC,SAAS,GAAGC,OAAMC,QAAQ,CAAC,IAAMpB,UAAUC;IAEzD,MAAMM,oBAAoBY,OAAME,WAAW,CACzC,CAACpB;QACCiB,SAASlB,UAAUC;QACnB,IAAIO,yBAAyB;YAC3BA,wBAAwBP;QAC1B;IACF,GACA;QAACO;KAAwB;IAG3B,qBACE,qBAACc,cAAM;QACLlB,WAAWA;QACXmB,kBAAkBd;QAClBe,WAAW,CAACd;QACZH,mBAAmBA;QACnBN,WAAWA;QACXa,WAAWW,IAAAA,gBAAU,8BAEnB,oCACAhB,mBAAmB,KAChBQ,CAAAA,4EAAmF,GACtFP,aACEe,IAAAA,gBAAU,oCAER,2CAEJX;QAEFY,WAAWf;QACXgB,wBAAwB;OACpBX;kBAEJ,cAAA,qBAACY,kCAAgB;YACfC,QAAQxB;YACRS,WAAWC,cAAce;YACzBlB,mBAAmBA;YACnBC,wBAAwBA;sBAEvBP,yBACC,qBAACyB;gBAAIjB,SAAS;0BACZ,cAAA,qBAACkB,gBAAO;oBAACC,MAAK;;iBAGhB9B;;;AAKV"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/CustomSelectOption/CustomSelectOption.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Icon16Done } from '@vkontakte/icons';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { HTMLAttributesWithRootRef } from '../../types';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { Paragraph } from '../Typography/Paragraph/Paragraph';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport styles from './CustomSelectOption.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelectOption--sizeY-none'],\n ['regular']: styles['CustomSelectOption--sizeY-regular'],\n};\n\nexport interface CustomSelectOptionProps extends HTMLAttributesWithRootRef<HTMLDivElement> {\n /**\n * Добавляет описание под основным блоком.\n */\n description?: React.ReactNode;\n /**\n * Вставляет элемент в начало блока перед основным контентом.\n * Например, можно передать компонент `Avatar`, `Icon<Name>` или другие изображения.\n */\n before?: React.ReactNode;\n /**\n * Вставляет элемент в конец блока после основного контента.\n * Например, можно передать компонент `Avatar`, `Icon<Name>` или другие изображения.\n */\n after?: React.ReactNode;\n /**\n * Позволяет создавать вложенность.\n */\n hierarchy?: number;\n /**\n * Включает состояние выбранного элемента списка.\n */\n selected?: boolean;\n /**\n * Включает состояние наведения.\n */\n hovered?: boolean;\n /**\n * Включает состояние фокуса.\n */\n focused?: boolean;\n /**\n * Блокирует весь блок.\n *\n * > ⚠️ Важно: если CustomSelectOption используется внутри [Select](https://vkcom.github.io/VKUI/#/Select), [CustomSelect](https://vkcom.github.io/VKUI/#/CustomSelect) или [ChipsSelect](https://vkcom.github.io/VKUI/#/ChipsSelect), то свойство явно должно выставляться только через структуру `options`.\n * > Запрещается выставлять `disabled` проп опциям в обход `options`, иначе [CustomSelect](https://vkcom.github.io/VKUI/#/CustomSelect) и [ChipsSelect](https://vkcom.github.io/VKUI/#/ChipsSelect) не будут знать об актуальном состоянии\n * опции.\n */\n disabled?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelectOption\n */\nexport const CustomSelectOption = ({\n children,\n hierarchy = 0,\n hovered: hoveredProp,\n selected,\n before,\n after,\n description,\n disabled,\n style: styleProp,\n className,\n onClick,\n ...restProps\n}: CustomSelectOptionProps) => {\n const { sizeY = 'none' } = useAdaptivity();\n const style = React.useMemo(\n () =>\n hierarchy > 0\n ? {\n '--vkui_internal--custom_select_option_hierarchy_level': hierarchy,\n ...styleProp,\n }\n : styleProp,\n [hierarchy, styleProp],\n );\n const hovered = hoveredProp && !disabled ? true : false;\n\n return (\n <Paragraph\n {...restProps}\n onClick={disabled ? undefined : onClick}\n Component=\"div\"\n role=\"option\"\n aria-disabled={disabled}\n aria-selected={selected}\n data-hovered={hovered}\n className={classNames(\n styles['CustomSelectOption'],\n sizeY !== 'compact' && sizeYClassNames[sizeY],\n hovered && styles['CustomSelectOption--hover'],\n disabled && styles['CustomSelectOption--disabled'],\n hierarchy > 0 && styles['CustomSelectOption--hierarchy'],\n className,\n )}\n style={style}\n >\n {hasReactNode(before) && <div className={styles['CustomSelectOption__before']}>{before}</div>}\n <div className={styles['CustomSelectOption__main']}>\n <div className={styles['CustomSelectOption__children']}>{children}</div>\n {hasReactNode(description) && (\n <Footnote className={styles['CustomSelectOption__description']}>\n <VisuallyHidden>&nbsp;</VisuallyHidden>\n {description}\n </Footnote>\n )}\n </div>\n <div className={styles['CustomSelectOption__after']}>\n {hasReactNode(after) && <div>{after}</div>}\n {selected && <Icon16Done className={styles['CustomSelectOption__selectedIcon']} />}\n </div>\n </Paragraph>\n );\n};\n"],"names":["CustomSelectOption","sizeYClassNames","none","children","hierarchy","hovered","hoveredProp","selected","before","after","description","disabled","style","styleProp","className","onClick","restProps","sizeY","useAdaptivity","React","useMemo","Paragraph","undefined","Component","role","aria-disabled","aria-selected","data-hovered","classNames","hasReactNode","div","Footnote","VisuallyHidden","Icon16Done"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";;;;+BA2DaA;;;eAAAA;;;;;;;;iEA3DU;uBACI;sBACc;+BACX;0BAEL;2BACC;gCACK;AAG/B,MAAMC,kBAAkB;IACtBC,IAAI;IACJ,CAAC,UAAU;AACb;AA8CO,MAAMF,qBAAqB;QAAC,EACjCG,QAAQ,EACRC,YAAY,CAAC,EACbC,SAASC,WAAW,EACpBC,QAAQ,EACRC,MAAM,EACNC,KAAK,EACLC,WAAW,EACXC,QAAQ,EACRC,OAAOC,SAAS,EAChBC,SAAS,EACTC,OAAO,EAEiB,WADrBC;QAXHb;QACAC;QACAC;QACAE;QACAC;QACAC;QACAC;QACAC;QACAC;QACAE;QACAC;;IAGA,MAAM,EAAEE,QAAQ,MAAM,EAAE,GAAGC,IAAAA,4BAAa;IACxC,MAAMN,QAAQO,OAAMC,OAAO,CACzB,IACEhB,YAAY,IACR;YACE,yDAAyDA;WACtDS,aAELA,WACN;QAACT;QAAWS;KAAU;IAExB,MAAMR,UAAUC,eAAe,CAACK,WAAW,OAAO;IAElD,qBACE,sBAACU,oBAAS,8CACJL;QACJD,SAASJ,WAAWW,YAAYP;QAChCQ,WAAU;QACVC,MAAK;QACLC,iBAAed;QACfe,iBAAenB;QACfoB,gBAActB;QACdS,WAAWc,IAAAA,gBAAU,4BAEnBX,UAAU,aAAahB,eAAe,CAACgB,MAAM,EAC7CZ,4CACAM,gDACAP,YAAY,0CACZU;QAEFF,OAAOA;;YAENiB,IAAAA,kBAAY,EAACrB,yBAAW,qBAACsB;gBAAIhB,SAAS;0BAAyCN;;0BAChF,sBAACsB;gBAAIhB,SAAS;;kCACZ,qBAACgB;wBAAIhB,SAAS;kCAA2CX;;oBACxD0B,IAAAA,kBAAY,EAACnB,8BACZ,sBAACqB,kBAAQ;wBAACjB,SAAS;;0CACjB,qBAACkB,8BAAc;0CAAC;;4BACftB;;;;;0BAIP,sBAACoB;gBAAIhB,SAAS;;oBACXe,IAAAA,kBAAY,EAACpB,wBAAU,qBAACqB;kCAAKrB;;oBAC7BF,0BAAY,qBAAC0B,iBAAU;wBAACnB,SAAS;;;;;;AAI1C"}
1
+ {"version":3,"sources":["../../../../src/components/CustomSelectOption/CustomSelectOption.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Icon16Done } from '@vkontakte/icons';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { HTMLAttributesWithRootRef } from '../../types';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { Paragraph } from '../Typography/Paragraph/Paragraph';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport styles from './CustomSelectOption.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelectOption--sizeY-none'],\n ['regular']: styles['CustomSelectOption--sizeY-regular'],\n};\n\nexport interface CustomSelectOptionProps extends HTMLAttributesWithRootRef<HTMLDivElement> {\n /**\n * Добавляет описание под основным блоком.\n */\n description?: React.ReactNode;\n /**\n * Вставляет элемент в начало блока перед основным контентом.\n * Например, можно передать компонент `Avatar`, `Icon<Name>` или другие изображения.\n */\n before?: React.ReactNode;\n /**\n * Вставляет элемент в конец блока после основного контента.\n * Например, можно передать компонент `Avatar`, `Icon<Name>` или другие изображения.\n */\n after?: React.ReactNode;\n /**\n * Позволяет создавать вложенность.\n */\n hierarchy?: number;\n /**\n * Включает состояние выбранного элемента списка.\n */\n selected?: boolean;\n /**\n * Включает состояние наведения.\n */\n hovered?: boolean;\n /**\n * Включает состояние фокуса.\n */\n focused?: boolean;\n /**\n * Блокирует весь блок.\n *\n * > ⚠️ Важно: если CustomSelectOption используется внутри [Select](https://vkcom.github.io/VKUI/#/Select), [CustomSelect](https://vkcom.github.io/VKUI/#/CustomSelect) или [ChipsSelect](https://vkcom.github.io/VKUI/#/ChipsSelect), то свойство явно должно выставляться только через структуру `options`.\n * > Запрещается выставлять `disabled` проп опциям в обход `options`, иначе [CustomSelect](https://vkcom.github.io/VKUI/#/CustomSelect) и [ChipsSelect](https://vkcom.github.io/VKUI/#/ChipsSelect) не будут знать об актуальном состоянии\n * опции.\n */\n disabled?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelectOption\n */\nexport const CustomSelectOption = ({\n children,\n hierarchy = 0,\n hovered: hoveredProp,\n selected,\n before,\n after,\n description,\n disabled,\n style: styleProp,\n className,\n onClick,\n ...restProps\n}: CustomSelectOptionProps) => {\n const { sizeY = 'none' } = useAdaptivity();\n const style = React.useMemo(\n () =>\n hierarchy > 0\n ? {\n '--vkui_internal--custom_select_option_hierarchy_level': hierarchy,\n ...styleProp,\n }\n : styleProp,\n [hierarchy, styleProp],\n );\n const hovered = hoveredProp && !disabled ? true : false;\n\n return (\n <Paragraph\n {...restProps}\n onClick={disabled ? undefined : onClick}\n Component=\"div\"\n role=\"option\"\n aria-disabled={disabled}\n aria-selected={selected}\n data-hovered={hovered}\n className={classNames(\n styles['CustomSelectOption'],\n sizeY !== 'compact' && sizeYClassNames[sizeY],\n hovered && styles['CustomSelectOption--hover'],\n disabled && styles['CustomSelectOption--disabled'],\n hierarchy > 0 && styles['CustomSelectOption--hierarchy'],\n className,\n )}\n style={style}\n >\n {hasReactNode(before) && <div className={styles['CustomSelectOption__before']}>{before}</div>}\n <div className={styles['CustomSelectOption__main']}>\n <div className={styles['CustomSelectOption__children']}>{children}</div>\n {hasReactNode(description) && (\n <Footnote className={styles['CustomSelectOption__description']}>\n <VisuallyHidden>&nbsp;</VisuallyHidden>\n {description}\n </Footnote>\n )}\n </div>\n <div className={styles['CustomSelectOption__after']}>\n {hasReactNode(after) && <div>{after}</div>}\n {selected && <Icon16Done className={styles['CustomSelectOption__selectedIcon']} />}\n </div>\n </Paragraph>\n );\n};\n"],"names":["CustomSelectOption","sizeYClassNames","none","children","hierarchy","hovered","hoveredProp","selected","before","after","description","disabled","style","styleProp","className","onClick","restProps","sizeY","useAdaptivity","React","useMemo","Paragraph","undefined","Component","role","aria-disabled","aria-selected","data-hovered","classNames","hasReactNode","div","Footnote","VisuallyHidden","Icon16Done"],"mappings":";;;;+BA2DaA;;;eAAAA;;;;;;;;iEA3DU;uBACI;sBACc;+BACX;0BAEL;2BACC;gCACK;AAG/B,MAAMC,kBAAkB;IACtBC,IAAI;IACJ,CAAC,UAAU;AACb;AA8CO,MAAMF,qBAAqB;QAAC,EACjCG,QAAQ,EACRC,YAAY,CAAC,EACbC,SAASC,WAAW,EACpBC,QAAQ,EACRC,MAAM,EACNC,KAAK,EACLC,WAAW,EACXC,QAAQ,EACRC,OAAOC,SAAS,EAChBC,SAAS,EACTC,OAAO,EAEiB,WADrBC;QAXHb;QACAC;QACAC;QACAE;QACAC;QACAC;QACAC;QACAC;QACAC;QACAE;QACAC;;IAGA,MAAM,EAAEE,QAAQ,MAAM,EAAE,GAAGC,IAAAA,4BAAa;IACxC,MAAMN,QAAQO,OAAMC,OAAO,CACzB,IACEhB,YAAY,IACR;YACE,yDAAyDA;WACtDS,aAELA,WACN;QAACT;QAAWS;KAAU;IAExB,MAAMR,UAAUC,eAAe,CAACK,WAAW,OAAO;IAElD,qBACE,sBAACU,oBAAS,8CACJL;QACJD,SAASJ,WAAWW,YAAYP;QAChCQ,WAAU;QACVC,MAAK;QACLC,iBAAed;QACfe,iBAAenB;QACfoB,gBAActB;QACdS,WAAWc,IAAAA,gBAAU,4BAEnBX,UAAU,aAAahB,eAAe,CAACgB,MAAM,EAC7CZ,4CACAM,gDACAP,YAAY,0CACZU;QAEFF,OAAOA;;YAENiB,IAAAA,kBAAY,EAACrB,yBAAW,qBAACsB;gBAAIhB,SAAS;0BAAyCN;;0BAChF,sBAACsB;gBAAIhB,SAAS;;kCACZ,qBAACgB;wBAAIhB,SAAS;kCAA2CX;;oBACxD0B,IAAAA,kBAAY,EAACnB,8BACZ,sBAACqB,kBAAQ;wBAACjB,SAAS;;0CACjB,qBAACkB,8BAAc;0CAAC;;4BACftB;;;;;0BAIP,sBAACoB;gBAAIhB,SAAS;;oBACXe,IAAAA,kBAAY,EAACpB,wBAAU,qBAACqB;kCAAKrB;;oBAC7BF,0BAAY,qBAAC0B,iBAAU;wBAACnB,SAAS;;;;;;AAI1C"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/DateInput/DateInput.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Icon16Clear, Icon20CalendarOutline } from '@vkontakte/icons';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useDateInput } from '../../hooks/useDateInput';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { format, isMatch, parse } from '../../lib/date';\nimport type { PlacementWithAuto } from '../../lib/floating';\nimport { HasRootRef } from '../../types';\nimport { Calendar, CalendarProps } from '../Calendar/Calendar';\nimport { FormField, FormFieldProps } from '../FormField/FormField';\nimport { IconButton } from '../IconButton/IconButton';\nimport { InputLike } from '../InputLike/InputLike';\nimport { InputLikeDivider } from '../InputLike/InputLikeDivider';\nimport { Popper } from '../Popper/Popper';\nimport { Text } from '../Typography/Text/Text';\nimport '../InputLike/InputLike.module.css'; // Reorder css\nimport styles from './DateInput.module.css';\n\nconst sizeYClassNames = {\n none: styles['DateInput--sizeY-none'],\n ['compact']: styles['DateInput--sizeY-compact'],\n};\n\nexport interface DateInputProps\n extends Omit<React.InputHTMLAttributes<HTMLDivElement>, 'value' | 'onChange' | 'size'>,\n Pick<\n CalendarProps,\n | 'disablePast'\n | 'disableFuture'\n | 'enableTime'\n | 'shouldDisableDate'\n | 'onChange'\n | 'value'\n | 'doneButtonText'\n | 'weekStartsOn'\n | 'disablePickers'\n | 'changeHoursLabel'\n | 'changeMinutesLabel'\n | 'prevMonthLabel'\n | 'nextMonthLabel'\n | 'changeMonthLabel'\n | 'changeYearLabel'\n | 'changeDayLabel'\n | 'showNeighboringMonth'\n | 'size'\n | 'viewDate'\n | 'onHeaderChange'\n | 'onNextMonth'\n | 'onPrevMonth'\n | 'prevMonthIcon'\n | 'nextMonthIcon'\n | 'minDateTime'\n | 'maxDateTime'\n >,\n HasRootRef<HTMLDivElement>,\n FormFieldProps {\n calendarPlacement?: PlacementWithAuto;\n closeOnChange?: boolean;\n clearFieldLabel?: string;\n showCalendarLabel?: string;\n disableCalendar?: boolean;\n}\n\nconst elementsConfig = (index: number) => {\n let length = 2;\n let min = 1;\n let max = 0;\n\n switch (index) {\n case 0:\n max = 31;\n break;\n case 1:\n max = 12;\n break;\n case 2:\n max = 2100;\n min = 1900;\n length = 4;\n break;\n case 3:\n max = 23;\n break;\n case 4:\n max = 59;\n break;\n }\n\n return { length, min, max };\n};\n\nconst getInternalValue = (value: CalendarProps['value']) => {\n const newValue = ['', '', '', '', ''];\n if (value) {\n newValue[0] = String(value.getDate()).padStart(2, '0');\n newValue[1] = String(value.getMonth() + 1).padStart(2, '0');\n newValue[2] = String(value.getFullYear()).padStart(4, '0');\n newValue[3] = String(value.getHours()).padStart(2, '0');\n newValue[4] = String(value.getMinutes()).padStart(2, '0');\n }\n return newValue;\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/DateInput\n */\nexport const DateInput = ({\n enableTime,\n shouldDisableDate,\n disableFuture,\n disablePast,\n minDateTime,\n maxDateTime,\n value,\n onChange,\n calendarPlacement = 'bottom-start',\n style,\n className,\n doneButtonText,\n closeOnChange = true,\n disablePickers,\n getRootRef,\n name,\n autoFocus,\n disabled,\n onClick,\n onFocus,\n prevMonthLabel = 'Предыдущий месяц',\n nextMonthLabel = 'Следующий месяц',\n showNeighboringMonth,\n size,\n changeMonthLabel = 'Изменить месяц',\n changeYearLabel = 'Изменить год',\n changeDayLabel = 'Изменить день',\n changeHoursLabel = 'Изменить час',\n changeMinutesLabel = 'Изменить минуту',\n clearFieldLabel = 'Очистить поле',\n showCalendarLabel = 'Показать календарь',\n viewDate,\n onHeaderChange,\n onNextMonth,\n onPrevMonth,\n prevMonthIcon,\n nextMonthIcon,\n disableCalendar = false,\n ...props\n}: DateInputProps) => {\n const daysRef = React.useRef<HTMLSpanElement>(null);\n const monthsRef = React.useRef<HTMLSpanElement>(null);\n const yearsRef = React.useRef<HTMLSpanElement>(null);\n const hoursRef = React.useRef<HTMLSpanElement>(null);\n const minutesRef = React.useRef<HTMLSpanElement>(null);\n\n const maxElement = enableTime ? 4 : 2;\n\n const onInternalValueChange = React.useCallback(\n (internalValue: string[]) => {\n for (let i = 0; i <= maxElement; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n return;\n }\n }\n\n let formattedValue = `${internalValue[0]}.${internalValue[1]}.${internalValue[2]}`;\n let mask = 'DD.MM.YYYY';\n if (enableTime) {\n formattedValue += ` ${internalValue[3]}:${internalValue[4]}`;\n mask += ' HH:mm';\n }\n\n if (isMatch(formattedValue, mask)) {\n onChange?.(parse(formattedValue, mask, value ?? new Date()));\n }\n },\n [enableTime, maxElement, onChange, value],\n );\n\n const refs = React.useMemo(\n () => [daysRef, monthsRef, yearsRef, hoursRef, minutesRef],\n [daysRef, monthsRef, yearsRef, hoursRef, minutesRef],\n );\n\n const {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n internalValue,\n handleKeyDown,\n setFocusedElement,\n handleFieldEnter,\n clear,\n removeFocusFromField,\n } = useDateInput({\n maxElement,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange,\n onInternalValueChange,\n getInternalValue,\n value,\n });\n\n const { sizeY = 'none' } = useAdaptivity();\n\n const handleRootRef = useExternRef(rootRef, getRootRef);\n\n const onCalendarChange = React.useCallback(\n (value?: Date | undefined) => {\n onChange?.(value);\n if (closeOnChange && !enableTime) {\n removeFocusFromField();\n }\n },\n [onChange, removeFocusFromField, closeOnChange, enableTime],\n );\n\n return (\n <FormField\n style={style}\n className={classNames(sizeY !== 'regular' && sizeYClassNames[sizeY], className)}\n getRootRef={handleRootRef}\n after={\n value ? (\n <IconButton hoverMode=\"opacity\" label={clearFieldLabel} onClick={clear}>\n <Icon16Clear />\n </IconButton>\n ) : (\n <IconButton hoverMode=\"opacity\" label={showCalendarLabel} onClick={openCalendar}>\n <Icon20CalendarOutline />\n </IconButton>\n )\n }\n disabled={disabled}\n onClick={callMultiple(handleFieldEnter, onClick)}\n onFocus={callMultiple(handleFieldEnter, onFocus)}\n {...props}\n >\n <input\n type=\"hidden\"\n name={name}\n value={value ? format(value, enableTime ? 'DD.MM.YYYYTHH:mm' : 'DD.MM.YYYY') : ''}\n />\n <Text\n className={styles['DateInput__input']}\n onKeyDown={handleKeyDown}\n // Инцидент: в PR https://github.com/VKCOM/VKUI/pull/6649 стабильно ломается порядок стилей\n // из-за чего `.Typography--normalize` перебивает стили.\n normalize={false}\n Component=\"span\" // для <span> нормализация не нужна\n >\n <InputLike\n length={2}\n getRootRef={daysRef}\n index={0}\n onElementSelect={setFocusedElement}\n value={internalValue[0]}\n label={changeDayLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsRef}\n index={1}\n onElementSelect={setFocusedElement}\n value={internalValue[1]}\n label={changeMonthLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsRef}\n index={2}\n onElementSelect={setFocusedElement}\n value={internalValue[2]}\n label={changeYearLabel}\n />\n {enableTime && (\n <React.Fragment>\n <InputLikeDivider className={styles['DateInput__input--time-divider']}>\n {' '}\n </InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={hoursRef}\n index={3}\n onElementSelect={setFocusedElement}\n value={internalValue[3]}\n label={changeHoursLabel}\n />\n <InputLikeDivider>:</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={minutesRef}\n index={4}\n onElementSelect={setFocusedElement}\n value={internalValue[4]}\n label={changeMinutesLabel}\n />\n </React.Fragment>\n )}\n </Text>\n {open && !disableCalendar && (\n <Popper\n targetRef={rootRef}\n offsetByMainAxis={8}\n placement={calendarPlacement}\n autoUpdateOnTargetResize\n >\n <Calendar\n value={value}\n onChange={onCalendarChange}\n enableTime={enableTime}\n disablePast={disablePast}\n disableFuture={disableFuture}\n shouldDisableDate={shouldDisableDate}\n onClose={removeFocusFromField}\n getRootRef={calendarRef}\n doneButtonText={doneButtonText}\n disablePickers={disablePickers}\n changeHoursLabel={changeHoursLabel}\n changeMinutesLabel={changeMinutesLabel}\n prevMonthLabel={prevMonthLabel}\n nextMonthLabel={nextMonthLabel}\n changeMonthLabel={changeMonthLabel}\n changeYearLabel={changeYearLabel}\n changeDayLabel={changeDayLabel}\n showNeighboringMonth={showNeighboringMonth}\n size={size}\n viewDate={viewDate}\n onHeaderChange={onHeaderChange}\n onNextMonth={onNextMonth}\n onPrevMonth={onPrevMonth}\n prevMonthIcon={prevMonthIcon}\n nextMonthIcon={nextMonthIcon}\n minDateTime={minDateTime}\n maxDateTime={maxDateTime}\n />\n </Popper>\n )}\n </FormField>\n );\n};\n"],"names":["DateInput","sizeYClassNames","none","elementsConfig","index","length","min","max","getInternalValue","value","newValue","String","getDate","padStart","getMonth","getFullYear","getHours","getMinutes","enableTime","shouldDisableDate","disableFuture","disablePast","minDateTime","maxDateTime","onChange","calendarPlacement","style","className","doneButtonText","closeOnChange","disablePickers","getRootRef","name","autoFocus","disabled","onClick","onFocus","prevMonthLabel","nextMonthLabel","showNeighboringMonth","size","changeMonthLabel","changeYearLabel","changeDayLabel","changeHoursLabel","changeMinutesLabel","clearFieldLabel","showCalendarLabel","viewDate","onHeaderChange","onNextMonth","onPrevMonth","prevMonthIcon","nextMonthIcon","disableCalendar","props","daysRef","React","useRef","monthsRef","yearsRef","hoursRef","minutesRef","maxElement","onInternalValueChange","useCallback","internalValue","i","formattedValue","mask","isMatch","parse","Date","refs","useMemo","rootRef","calendarRef","open","openCalendar","handleKeyDown","setFocusedElement","handleFieldEnter","clear","removeFocusFromField","useDateInput","sizeY","useAdaptivity","handleRootRef","useExternRef","onCalendarChange","FormField","classNames","after","IconButton","hoverMode","label","Icon16Clear","Icon20CalendarOutline","callMultiple","input","type","format","Text","onKeyDown","normalize","Component","InputLike","onElementSelect","InputLikeDivider","Fragment","Popper","targetRef","offsetByMainAxis","placement","autoUpdateOnTargetResize","Calendar","onClose"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";;;;+BA4GaA;;;eAAAA;;;;;;;;iEA5GU;uBAC4B;sBACxB;+BACG;8BACD;8BACA;8BACA;sBACU;0BAGC;2BACE;4BACf;2BACD;kCACO;wBACV;sBACF;AAIrB,MAAMC,kBAAkB;IACtBC,IAAI;IACJ,CAAC,UAAU;AACb;AA0CA,MAAMC,iBAAiB,CAACC;IACtB,IAAIC,SAAS;IACb,IAAIC,MAAM;IACV,IAAIC,MAAM;IAEV,OAAQH;QACN,KAAK;YACHG,MAAM;YACN;QACF,KAAK;YACHA,MAAM;YACN;QACF,KAAK;YACHA,MAAM;YACND,MAAM;YACND,SAAS;YACT;QACF,KAAK;YACHE,MAAM;YACN;QACF,KAAK;YACHA,MAAM;YACN;IACJ;IAEA,OAAO;QAAEF;QAAQC;QAAKC;IAAI;AAC5B;AAEA,MAAMC,mBAAmB,CAACC;IACxB,MAAMC,WAAW;QAAC;QAAI;QAAI;QAAI;QAAI;KAAG;IACrC,IAAID,OAAO;QACTC,QAAQ,CAAC,EAAE,GAAGC,OAAOF,MAAMG,OAAO,IAAIC,QAAQ,CAAC,GAAG;QAClDH,QAAQ,CAAC,EAAE,GAAGC,OAAOF,MAAMK,QAAQ,KAAK,GAAGD,QAAQ,CAAC,GAAG;QACvDH,QAAQ,CAAC,EAAE,GAAGC,OAAOF,MAAMM,WAAW,IAAIF,QAAQ,CAAC,GAAG;QACtDH,QAAQ,CAAC,EAAE,GAAGC,OAAOF,MAAMO,QAAQ,IAAIH,QAAQ,CAAC,GAAG;QACnDH,QAAQ,CAAC,EAAE,GAAGC,OAAOF,MAAMQ,UAAU,IAAIJ,QAAQ,CAAC,GAAG;IACvD;IACA,OAAOH;AACT;AAKO,MAAMV,YAAY;QAAC,EACxBkB,UAAU,EACVC,iBAAiB,EACjBC,aAAa,EACbC,WAAW,EACXC,WAAW,EACXC,WAAW,EACXd,KAAK,EACLe,QAAQ,EACRC,oBAAoB,cAAc,EAClCC,KAAK,EACLC,SAAS,EACTC,cAAc,EACdC,gBAAgB,IAAI,EACpBC,cAAc,EACdC,UAAU,EACVC,IAAI,EACJC,SAAS,EACTC,QAAQ,EACRC,OAAO,EACPC,OAAO,EACPC,iBAAiB,kBAAkB,EACnCC,iBAAiB,iBAAiB,EAClCC,oBAAoB,EACpBC,IAAI,EACJC,mBAAmB,gBAAgB,EACnCC,kBAAkB,cAAc,EAChCC,iBAAiB,eAAe,EAChCC,mBAAmB,cAAc,EACjCC,qBAAqB,iBAAiB,EACtCC,kBAAkB,eAAe,EACjCC,oBAAoB,oBAAoB,EACxCC,QAAQ,EACRC,cAAc,EACdC,WAAW,EACXC,WAAW,EACXC,aAAa,EACbC,aAAa,EACbC,kBAAkB,KAAK,EAER,WADZC;QAtCHrC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAd;QACAe;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;;IAGA,MAAME,UAAUC,OAAMC,MAAM,CAAkB;IAC9C,MAAMC,YAAYF,OAAMC,MAAM,CAAkB;IAChD,MAAME,WAAWH,OAAMC,MAAM,CAAkB;IAC/C,MAAMG,WAAWJ,OAAMC,MAAM,CAAkB;IAC/C,MAAMI,aAAaL,OAAMC,MAAM,CAAkB;IAEjD,MAAMK,aAAa7C,aAAa,IAAI;IAEpC,MAAM8C,wBAAwBP,OAAMQ,WAAW,CAC7C,CAACC;QACC,IAAK,IAAIC,IAAI,GAAGA,KAAKJ,YAAYI,KAAK,EAAG;YACvC,IAAID,aAAa,CAACC,EAAE,CAAC9D,MAAM,GAAGF,eAAegE,GAAG9D,MAAM,EAAE;gBACtD;YACF;QACF;QAEA,IAAI+D,iBAAiB,CAAC,EAAEF,aAAa,CAAC,EAAE,CAAC,CAAC,EAAEA,aAAa,CAAC,EAAE,CAAC,CAAC,EAAEA,aAAa,CAAC,EAAE,CAAC,CAAC;QAClF,IAAIG,OAAO;QACX,IAAInD,YAAY;YACdkD,kBAAkB,CAAC,CAAC,EAAEF,aAAa,CAAC,EAAE,CAAC,CAAC,EAAEA,aAAa,CAAC,EAAE,CAAC,CAAC;YAC5DG,QAAQ;QACV;QAEA,IAAIC,IAAAA,aAAO,EAACF,gBAAgBC,OAAO;YACjC7C,qBAAAA,+BAAAA,SAAW+C,IAAAA,WAAK,EAACH,gBAAgBC,MAAM5D,kBAAAA,mBAAAA,QAAS,IAAI+D;QACtD;IACF,GACA;QAACtD;QAAY6C;QAAYvC;QAAUf;KAAM;IAG3C,MAAMgE,OAAOhB,OAAMiB,OAAO,CACxB,IAAM;YAAClB;YAASG;YAAWC;YAAUC;YAAUC;SAAW,EAC1D;QAACN;QAASG;QAAWC;QAAUC;QAAUC;KAAW;IAGtD,MAAM,EACJa,OAAO,EACPC,WAAW,EACXC,IAAI,EACJC,YAAY,EACZZ,aAAa,EACba,aAAa,EACbC,iBAAiB,EACjBC,gBAAgB,EAChBC,KAAK,EACLC,oBAAoB,EACrB,GAAGC,IAAAA,0BAAY,EAAC;QACfrB;QACAU;QACAxC;QACAC;QACA/B;QACAqB;QACAwC;QACAxD;QACAC;IACF;IAEA,MAAM,EAAE4E,QAAQ,MAAM,EAAE,GAAGC,IAAAA,4BAAa;IAExC,MAAMC,gBAAgBC,IAAAA,0BAAY,EAACb,SAAS5C;IAE5C,MAAM0D,mBAAmBhC,OAAMQ,WAAW,CACxC,CAACxD;QACCe,qBAAAA,+BAAAA,SAAWf;QACX,IAAIoB,iBAAiB,CAACX,YAAY;YAChCiE;QACF;IACF,GACA;QAAC3D;QAAU2D;QAAsBtD;QAAeX;KAAW;IAG7D,qBACE,sBAACwE,oBAAS;QACRhE,OAAOA;QACPC,WAAWgE,IAAAA,gBAAU,EAACN,UAAU,aAAapF,eAAe,CAACoF,MAAM,EAAE1D;QACrEI,YAAYwD;QACZK,OACEnF,sBACE,qBAACoF,sBAAU;YAACC,WAAU;YAAUC,OAAOjD;YAAiBX,SAAS+C;sBAC/D,cAAA,qBAACc,kBAAW;2BAGd,qBAACH,sBAAU;YAACC,WAAU;YAAUC,OAAOhD;YAAmBZ,SAAS2C;sBACjE,cAAA,qBAACmB,4BAAqB;;QAI5B/D,UAAUA;QACVC,SAAS+D,IAAAA,0BAAY,EAACjB,kBAAkB9C;QACxCC,SAAS8D,IAAAA,0BAAY,EAACjB,kBAAkB7C;OACpCmB;;0BAEJ,qBAAC4C;gBACCC,MAAK;gBACLpE,MAAMA;gBACNvB,OAAOA,QAAQ4F,IAAAA,YAAM,EAAC5F,OAAOS,aAAa,qBAAqB,gBAAgB;;0BAEjF,sBAACoF,UAAI;gBACH3E,SAAS;gBACT4E,WAAWxB;gBACX,2FAA2F;gBAC3F,wDAAwD;gBACxDyB,WAAW;gBACXC,WAAU,OAAO,mCAAmC;;;kCAEpD,qBAACC,oBAAS;wBACRrG,QAAQ;wBACR0B,YAAYyB;wBACZpD,OAAO;wBACPuG,iBAAiB3B;wBACjBvE,OAAOyD,aAAa,CAAC,EAAE;wBACvB6B,OAAOpD;;kCAET,qBAACiE,kCAAgB;kCAAC;;kCAClB,qBAACF,oBAAS;wBACRrG,QAAQ;wBACR0B,YAAY4B;wBACZvD,OAAO;wBACPuG,iBAAiB3B;wBACjBvE,OAAOyD,aAAa,CAAC,EAAE;wBACvB6B,OAAOtD;;kCAET,qBAACmE,kCAAgB;kCAAC;;kCAClB,qBAACF,oBAAS;wBACRrG,QAAQ;wBACR0B,YAAY6B;wBACZxD,OAAO;wBACPuG,iBAAiB3B;wBACjBvE,OAAOyD,aAAa,CAAC,EAAE;wBACvB6B,OAAOrD;;oBAERxB,4BACC,sBAACuC,OAAMoD,QAAQ;;0CACb,qBAACD,kCAAgB;gCAACjF,SAAS;0CACxB;;0CAEH,qBAAC+E,oBAAS;gCACRrG,QAAQ;gCACR0B,YAAY8B;gCACZzD,OAAO;gCACPuG,iBAAiB3B;gCACjBvE,OAAOyD,aAAa,CAAC,EAAE;gCACvB6B,OAAOnD;;0CAET,qBAACgE,kCAAgB;0CAAC;;0CAClB,qBAACF,oBAAS;gCACRrG,QAAQ;gCACR0B,YAAY+B;gCACZ1D,OAAO;gCACPuG,iBAAiB3B;gCACjBvE,OAAOyD,aAAa,CAAC,EAAE;gCACvB6B,OAAOlD;;;;;;YAKdgC,QAAQ,CAACvB,iCACR,qBAACwD,cAAM;gBACLC,WAAWpC;gBACXqC,kBAAkB;gBAClBC,WAAWxF;gBACXyF,wBAAwB;0BAExB,cAAA,qBAACC,kBAAQ;oBACP1G,OAAOA;oBACPe,UAAUiE;oBACVvE,YAAYA;oBACZG,aAAaA;oBACbD,eAAeA;oBACfD,mBAAmBA;oBACnBiG,SAASjC;oBACTpD,YAAY6C;oBACZhD,gBAAgBA;oBAChBE,gBAAgBA;oBAChBc,kBAAkBA;oBAClBC,oBAAoBA;oBACpBR,gBAAgBA;oBAChBC,gBAAgBA;oBAChBG,kBAAkBA;oBAClBC,iBAAiBA;oBACjBC,gBAAgBA;oBAChBJ,sBAAsBA;oBACtBC,MAAMA;oBACNQ,UAAUA;oBACVC,gBAAgBA;oBAChBC,aAAaA;oBACbC,aAAaA;oBACbC,eAAeA;oBACfC,eAAeA;oBACf/B,aAAaA;oBACbC,aAAaA;;;;;AAMzB"}
1
+ {"version":3,"sources":["../../../../src/components/DateInput/DateInput.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Icon16Clear, Icon20CalendarOutline } from '@vkontakte/icons';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useDateInput } from '../../hooks/useDateInput';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { format, isMatch, parse } from '../../lib/date';\nimport type { PlacementWithAuto } from '../../lib/floating';\nimport { HasRootRef } from '../../types';\nimport { Calendar, CalendarProps } from '../Calendar/Calendar';\nimport { FormField, FormFieldProps } from '../FormField/FormField';\nimport { IconButton } from '../IconButton/IconButton';\nimport { InputLike } from '../InputLike/InputLike';\nimport { InputLikeDivider } from '../InputLike/InputLikeDivider';\nimport { Popper } from '../Popper/Popper';\nimport { Text } from '../Typography/Text/Text';\nimport '../InputLike/InputLike.module.css'; // Reorder css\nimport styles from './DateInput.module.css';\n\nconst sizeYClassNames = {\n none: styles['DateInput--sizeY-none'],\n ['compact']: styles['DateInput--sizeY-compact'],\n};\n\nexport interface DateInputProps\n extends Omit<React.InputHTMLAttributes<HTMLDivElement>, 'value' | 'onChange' | 'size'>,\n Pick<\n CalendarProps,\n | 'disablePast'\n | 'disableFuture'\n | 'enableTime'\n | 'shouldDisableDate'\n | 'onChange'\n | 'value'\n | 'doneButtonText'\n | 'weekStartsOn'\n | 'disablePickers'\n | 'changeHoursLabel'\n | 'changeMinutesLabel'\n | 'prevMonthLabel'\n | 'nextMonthLabel'\n | 'changeMonthLabel'\n | 'changeYearLabel'\n | 'changeDayLabel'\n | 'showNeighboringMonth'\n | 'size'\n | 'viewDate'\n | 'onHeaderChange'\n | 'onNextMonth'\n | 'onPrevMonth'\n | 'prevMonthIcon'\n | 'nextMonthIcon'\n | 'minDateTime'\n | 'maxDateTime'\n >,\n HasRootRef<HTMLDivElement>,\n FormFieldProps {\n calendarPlacement?: PlacementWithAuto;\n closeOnChange?: boolean;\n clearFieldLabel?: string;\n showCalendarLabel?: string;\n disableCalendar?: boolean;\n}\n\nconst elementsConfig = (index: number) => {\n let length = 2;\n let min = 1;\n let max = 0;\n\n switch (index) {\n case 0:\n max = 31;\n break;\n case 1:\n max = 12;\n break;\n case 2:\n max = 2100;\n min = 1900;\n length = 4;\n break;\n case 3:\n max = 23;\n break;\n case 4:\n max = 59;\n break;\n }\n\n return { length, min, max };\n};\n\nconst getInternalValue = (value: CalendarProps['value']) => {\n const newValue = ['', '', '', '', ''];\n if (value) {\n newValue[0] = String(value.getDate()).padStart(2, '0');\n newValue[1] = String(value.getMonth() + 1).padStart(2, '0');\n newValue[2] = String(value.getFullYear()).padStart(4, '0');\n newValue[3] = String(value.getHours()).padStart(2, '0');\n newValue[4] = String(value.getMinutes()).padStart(2, '0');\n }\n return newValue;\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/DateInput\n */\nexport const DateInput = ({\n enableTime,\n shouldDisableDate,\n disableFuture,\n disablePast,\n minDateTime,\n maxDateTime,\n value,\n onChange,\n calendarPlacement = 'bottom-start',\n style,\n className,\n doneButtonText,\n closeOnChange = true,\n disablePickers,\n getRootRef,\n name,\n autoFocus,\n disabled,\n onClick,\n onFocus,\n prevMonthLabel = 'Предыдущий месяц',\n nextMonthLabel = 'Следующий месяц',\n showNeighboringMonth,\n size,\n changeMonthLabel = 'Изменить месяц',\n changeYearLabel = 'Изменить год',\n changeDayLabel = 'Изменить день',\n changeHoursLabel = 'Изменить час',\n changeMinutesLabel = 'Изменить минуту',\n clearFieldLabel = 'Очистить поле',\n showCalendarLabel = 'Показать календарь',\n viewDate,\n onHeaderChange,\n onNextMonth,\n onPrevMonth,\n prevMonthIcon,\n nextMonthIcon,\n disableCalendar = false,\n ...props\n}: DateInputProps) => {\n const daysRef = React.useRef<HTMLSpanElement>(null);\n const monthsRef = React.useRef<HTMLSpanElement>(null);\n const yearsRef = React.useRef<HTMLSpanElement>(null);\n const hoursRef = React.useRef<HTMLSpanElement>(null);\n const minutesRef = React.useRef<HTMLSpanElement>(null);\n\n const maxElement = enableTime ? 4 : 2;\n\n const onInternalValueChange = React.useCallback(\n (internalValue: string[]) => {\n for (let i = 0; i <= maxElement; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n return;\n }\n }\n\n let formattedValue = `${internalValue[0]}.${internalValue[1]}.${internalValue[2]}`;\n let mask = 'DD.MM.YYYY';\n if (enableTime) {\n formattedValue += ` ${internalValue[3]}:${internalValue[4]}`;\n mask += ' HH:mm';\n }\n\n if (isMatch(formattedValue, mask)) {\n onChange?.(parse(formattedValue, mask, value ?? new Date()));\n }\n },\n [enableTime, maxElement, onChange, value],\n );\n\n const refs = React.useMemo(\n () => [daysRef, monthsRef, yearsRef, hoursRef, minutesRef],\n [daysRef, monthsRef, yearsRef, hoursRef, minutesRef],\n );\n\n const {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n internalValue,\n handleKeyDown,\n setFocusedElement,\n handleFieldEnter,\n clear,\n removeFocusFromField,\n } = useDateInput({\n maxElement,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange,\n onInternalValueChange,\n getInternalValue,\n value,\n });\n\n const { sizeY = 'none' } = useAdaptivity();\n\n const handleRootRef = useExternRef(rootRef, getRootRef);\n\n const onCalendarChange = React.useCallback(\n (value?: Date | undefined) => {\n onChange?.(value);\n if (closeOnChange && !enableTime) {\n removeFocusFromField();\n }\n },\n [onChange, removeFocusFromField, closeOnChange, enableTime],\n );\n\n return (\n <FormField\n style={style}\n className={classNames(sizeY !== 'regular' && sizeYClassNames[sizeY], className)}\n getRootRef={handleRootRef}\n after={\n value ? (\n <IconButton hoverMode=\"opacity\" label={clearFieldLabel} onClick={clear}>\n <Icon16Clear />\n </IconButton>\n ) : (\n <IconButton hoverMode=\"opacity\" label={showCalendarLabel} onClick={openCalendar}>\n <Icon20CalendarOutline />\n </IconButton>\n )\n }\n disabled={disabled}\n onClick={callMultiple(handleFieldEnter, onClick)}\n onFocus={callMultiple(handleFieldEnter, onFocus)}\n {...props}\n >\n <input\n type=\"hidden\"\n name={name}\n value={value ? format(value, enableTime ? 'DD.MM.YYYYTHH:mm' : 'DD.MM.YYYY') : ''}\n />\n <Text\n className={styles['DateInput__input']}\n onKeyDown={handleKeyDown}\n // Инцидент: в PR https://github.com/VKCOM/VKUI/pull/6649 стабильно ломается порядок стилей\n // из-за чего `.Typography--normalize` перебивает стили.\n normalize={false}\n Component=\"span\" // для <span> нормализация не нужна\n >\n <InputLike\n length={2}\n getRootRef={daysRef}\n index={0}\n onElementSelect={setFocusedElement}\n value={internalValue[0]}\n label={changeDayLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsRef}\n index={1}\n onElementSelect={setFocusedElement}\n value={internalValue[1]}\n label={changeMonthLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsRef}\n index={2}\n onElementSelect={setFocusedElement}\n value={internalValue[2]}\n label={changeYearLabel}\n />\n {enableTime && (\n <React.Fragment>\n <InputLikeDivider className={styles['DateInput__input--time-divider']}>\n {' '}\n </InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={hoursRef}\n index={3}\n onElementSelect={setFocusedElement}\n value={internalValue[3]}\n label={changeHoursLabel}\n />\n <InputLikeDivider>:</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={minutesRef}\n index={4}\n onElementSelect={setFocusedElement}\n value={internalValue[4]}\n label={changeMinutesLabel}\n />\n </React.Fragment>\n )}\n </Text>\n {open && !disableCalendar && (\n <Popper\n targetRef={rootRef}\n offsetByMainAxis={8}\n placement={calendarPlacement}\n autoUpdateOnTargetResize\n >\n <Calendar\n value={value}\n onChange={onCalendarChange}\n enableTime={enableTime}\n disablePast={disablePast}\n disableFuture={disableFuture}\n shouldDisableDate={shouldDisableDate}\n onClose={removeFocusFromField}\n getRootRef={calendarRef}\n doneButtonText={doneButtonText}\n disablePickers={disablePickers}\n changeHoursLabel={changeHoursLabel}\n changeMinutesLabel={changeMinutesLabel}\n prevMonthLabel={prevMonthLabel}\n nextMonthLabel={nextMonthLabel}\n changeMonthLabel={changeMonthLabel}\n changeYearLabel={changeYearLabel}\n changeDayLabel={changeDayLabel}\n showNeighboringMonth={showNeighboringMonth}\n size={size}\n viewDate={viewDate}\n onHeaderChange={onHeaderChange}\n onNextMonth={onNextMonth}\n onPrevMonth={onPrevMonth}\n prevMonthIcon={prevMonthIcon}\n nextMonthIcon={nextMonthIcon}\n minDateTime={minDateTime}\n maxDateTime={maxDateTime}\n />\n </Popper>\n )}\n </FormField>\n );\n};\n"],"names":["DateInput","sizeYClassNames","none","elementsConfig","index","length","min","max","getInternalValue","value","newValue","String","getDate","padStart","getMonth","getFullYear","getHours","getMinutes","enableTime","shouldDisableDate","disableFuture","disablePast","minDateTime","maxDateTime","onChange","calendarPlacement","style","className","doneButtonText","closeOnChange","disablePickers","getRootRef","name","autoFocus","disabled","onClick","onFocus","prevMonthLabel","nextMonthLabel","showNeighboringMonth","size","changeMonthLabel","changeYearLabel","changeDayLabel","changeHoursLabel","changeMinutesLabel","clearFieldLabel","showCalendarLabel","viewDate","onHeaderChange","onNextMonth","onPrevMonth","prevMonthIcon","nextMonthIcon","disableCalendar","props","daysRef","React","useRef","monthsRef","yearsRef","hoursRef","minutesRef","maxElement","onInternalValueChange","useCallback","internalValue","i","formattedValue","mask","isMatch","parse","Date","refs","useMemo","rootRef","calendarRef","open","openCalendar","handleKeyDown","setFocusedElement","handleFieldEnter","clear","removeFocusFromField","useDateInput","sizeY","useAdaptivity","handleRootRef","useExternRef","onCalendarChange","FormField","classNames","after","IconButton","hoverMode","label","Icon16Clear","Icon20CalendarOutline","callMultiple","input","type","format","Text","onKeyDown","normalize","Component","InputLike","onElementSelect","InputLikeDivider","Fragment","Popper","targetRef","offsetByMainAxis","placement","autoUpdateOnTargetResize","Calendar","onClose"],"mappings":"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"}
@@ -20,6 +20,12 @@ export interface DatePickerProps extends Omit<HTMLAttributesWithRootRef<HTMLDivE
20
20
  }
21
21
  /**
22
22
  * @see https://vkcom.github.io/VKUI/#/DatePicker
23
+ *
24
+ * @deprecated 6.2.0
25
+ *
26
+ * Компонент устарел и будет удален в v7. Используйте вместо него компоненты
27
+ * [Input](https://vkcom.github.io/VKUI/#/Input) и
28
+ * [Select](https://vkcom.github.io/VKUI/#/Select).
23
29
  */
24
30
  export declare const DatePicker: ({ onDateChange, ...props }: DatePickerProps) => import("react/jsx-runtime").JSX.Element;
25
31
  //# sourceMappingURL=DatePicker.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"DatePicker.d.ts","sourceRoot":"","sources":["../../../../src/components/DatePicker/DatePicker.tsx"],"names":[],"mappings":"AAOA,OAAO,EAAwB,yBAAyB,EAAE,MAAM,aAAa,CAAC;AAqB9E,MAAM,MAAM,oBAAoB,GAAG;IACjC,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAIF,MAAM,WAAW,eACf,SAAQ,IAAI,CACV,yBAAyB,CAAC,cAAc,CAAC,EACzC,cAAc,GAAG,OAAO,GAAG,KAAK,GAAG,KAAK,CACzC;IACD,GAAG,CAAC,EAAE,oBAAoB,CAAC;IAC3B,GAAG,CAAC,EAAE,oBAAoB,CAAC;IAC3B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,YAAY,CAAC,EAAE,oBAAoB,CAAC;IACpC,KAAK,CAAC,EAAE,oBAAoB,CAAC;IAC7B,cAAc,CAAC,EAAE,KAAK,GAAG,QAAQ,CAAC;IAClC,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,oBAAoB,KAAK,IAAI,CAAC;IACrD,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AA6KD;;GAEG;AACH,eAAO,MAAM,UAAU,+BAAgC,eAAe,4CASrE,CAAC"}
1
+ {"version":3,"file":"DatePicker.d.ts","sourceRoot":"","sources":["../../../../src/components/DatePicker/DatePicker.tsx"],"names":[],"mappings":"AAOA,OAAO,EAAwB,yBAAyB,EAAE,MAAM,aAAa,CAAC;AAqB9E,MAAM,MAAM,oBAAoB,GAAG;IACjC,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAIF,MAAM,WAAW,eACf,SAAQ,IAAI,CACV,yBAAyB,CAAC,cAAc,CAAC,EACzC,cAAc,GAAG,OAAO,GAAG,KAAK,GAAG,KAAK,CACzC;IACD,GAAG,CAAC,EAAE,oBAAoB,CAAC;IAC3B,GAAG,CAAC,EAAE,oBAAoB,CAAC;IAC3B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,YAAY,CAAC,EAAE,oBAAoB,CAAC;IACpC,KAAK,CAAC,EAAE,oBAAoB,CAAC;IAC7B,cAAc,CAAC,EAAE,KAAK,GAAG,QAAQ,CAAC;IAClC,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,oBAAoB,KAAK,IAAI,CAAC;IACrD,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AA6KD;;;;;;;;GAQG;AACH,eAAO,MAAM,UAAU,+BAAgC,eAAe,4CASrE,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/DatePicker/DatePicker.tsx"],"sourcesContent":["import * as React from 'react';\nimport { leadingZero } from '@vkontakte/vkjs';\nimport { clamp } from '../../helpers/math';\nimport { range } from '../../helpers/range';\nimport { useAdaptivityHasPointer } from '../../hooks/useAdaptivityHasPointer';\nimport { useCustomEnsuredControl } from '../../hooks/useEnsuredControl';\nimport { useNativeFormResetListener } from '../../hooks/useNativeFormResetListener';\nimport { HasOnlyExpectedProps, HTMLAttributesWithRootRef } from '../../types';\nimport { CustomSelect } from '../CustomSelect/CustomSelect';\nimport { Input, type InputProps } from '../Input/Input';\nimport { RootComponent } from '../RootComponent/RootComponent';\nimport styles from './DatePicker.module.css';\n\nconst DefaultMonths: string[] = [\n 'Января',\n 'Февраля',\n 'Марта',\n 'Апреля',\n 'Мая',\n 'Июня',\n 'Июля',\n 'Августа',\n 'Сентября',\n 'Октября',\n 'Ноября',\n 'Декабря',\n];\n\nexport type DatePickerDateFormat = {\n day: number;\n month: number;\n year: number;\n};\n\nconst DEFAULT_EMPTY_DATE = { day: 0, month: 0, year: 0 };\n\nexport interface DatePickerProps\n extends Omit<\n HTMLAttributesWithRootRef<HTMLDivElement>,\n 'defaultValue' | 'value' | 'min' | 'max'\n > {\n min?: DatePickerDateFormat;\n max?: DatePickerDateFormat;\n name?: string;\n defaultValue?: DatePickerDateFormat;\n value?: DatePickerDateFormat;\n popupDirection?: 'top' | 'bottom';\n monthNames?: string[];\n dayPlaceholder?: string;\n monthPlaceholder?: string;\n yearPlaceholder?: string;\n onDateChange?: (value: DatePickerDateFormat) => void; // TODO [>=7] заменить на onChange\n disabled?: boolean;\n}\n\n// Переводим state к формату гг-мм-дд\nfunction convertToInputFormat(value: Partial<DatePickerDateFormat> | undefined) {\n if (!value) {\n return undefined;\n }\n const { day = 0, month = 0, year = 0 } = value;\n return `${year}-${leadingZero(month)}-${leadingZero(day)}`;\n}\n\n// Переводим дату формата гг-мм-дд к объекту\nfunction parseInputDate(date: string): DatePickerDateFormat {\n if (date.length === 0) {\n return DEFAULT_EMPTY_DATE;\n }\n const splited = date.split('-');\n\n return {\n day: Number(splited[2]),\n month: Number(splited[1]),\n year: Number(splited[0]),\n };\n}\n\nfunction getMonthMaxDay(month?: number, year?: number) {\n return month ? new Date(year || 2016, month, 0).getDate() : 31;\n}\n\nconst DatePickerCustom = ({\n name,\n min = { day: 0, month: 0, year: 0 },\n max = { day: 31, month: 12, year: 2100 },\n dayPlaceholder,\n monthPlaceholder,\n yearPlaceholder,\n popupDirection,\n value,\n monthNames,\n onDateChange,\n disabled,\n defaultValue = DEFAULT_EMPTY_DATE,\n ...restProps\n}: DatePickerProps) => {\n const isControlled = value !== undefined;\n const [internalValue, setInternalValue] = useCustomEnsuredControl({ value, defaultValue });\n const hiddenInput = React.useRef<HTMLInputElement>(null);\n\n const onSelectChange: React.ChangeEventHandler<HTMLSelectElement> = (e) => {\n const nextDate = {\n day: internalValue.day,\n month: internalValue.month,\n year: internalValue.year,\n };\n nextDate[e.target.name as keyof typeof nextDate] = Number(e.target.value);\n nextDate.day = nextDate.day\n ? clamp(nextDate.day, 1, getMonthMaxDay(nextDate.month, nextDate.year))\n : nextDate.day;\n setInternalValue(nextDate);\n onDateChange?.(nextDate);\n };\n const dayOptions = range(1, getMonthMaxDay(internalValue.month, internalValue.year)).map(\n (value) => ({\n label: String(value),\n value,\n }),\n );\n const monthOptions = (monthNames || DefaultMonths).map((name, index) => ({\n label: name,\n value: index + 1,\n }));\n const yearOptions = range(max.year, min.year).map((value) => ({\n label: String(value),\n value: value,\n }));\n\n useNativeFormResetListener(hiddenInput, () => {\n if (!isControlled) {\n setInternalValue(defaultValue);\n }\n });\n\n return (\n <RootComponent baseClassName={styles['DatePicker']} {...restProps}>\n <div className={styles['DatePicker__container']}>\n <div className={styles['DatePicker__day']}>\n <CustomSelect\n name=\"day\"\n value={internalValue.day}\n options={dayOptions}\n placeholder={dayPlaceholder}\n popupDirection={popupDirection}\n onChange={onSelectChange}\n disabled={disabled}\n />\n </div>\n <div className={styles['DatePicker__month']}>\n <CustomSelect\n className={styles['DatePicker__monthSelect']}\n name=\"month\"\n value={internalValue.month}\n options={monthOptions}\n placeholder={monthPlaceholder}\n popupDirection={popupDirection}\n onChange={onSelectChange}\n disabled={disabled}\n />\n </div>\n <div className={styles['DatePicker__year']}>\n <CustomSelect\n name=\"year\"\n value={internalValue.year}\n options={yearOptions}\n placeholder={yearPlaceholder}\n popupDirection={popupDirection}\n onChange={onSelectChange}\n disabled={disabled}\n />\n </div>\n </div>\n <input\n type=\"hidden\"\n name={name}\n ref={hiddenInput}\n value={convertToInputFormat(internalValue)}\n />\n </RootComponent>\n );\n};\n\nconst DatePickerNative = ({\n min = { day: 0, month: 0, year: 0 },\n max = { day: 31, month: 12, year: 2100 },\n monthNames,\n popupDirection,\n dayPlaceholder,\n monthPlaceholder,\n yearPlaceholder,\n value,\n defaultValue = DEFAULT_EMPTY_DATE,\n onDateChange,\n ...restProps\n}: DatePickerProps) => {\n const onStringChange: React.ChangeEventHandler<HTMLInputElement> = React.useCallback(\n (e) => {\n onDateChange?.(parseInputDate(e.currentTarget.value));\n },\n [onDateChange],\n );\n const inputProps: HasOnlyExpectedProps<\n typeof restProps & Pick<InputProps, 'value' | 'defaultValue'>,\n InputProps\n > = restProps;\n\n if (value) {\n // контролируемый компонент\n inputProps.value = convertToInputFormat(value);\n } else {\n // неконтролируемый компонент\n inputProps.defaultValue = convertToInputFormat(defaultValue);\n }\n\n return (\n <Input\n {...inputProps}\n type=\"date\"\n onChange={onStringChange}\n min={convertToInputFormat(min)}\n max={convertToInputFormat(max)}\n />\n );\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/DatePicker\n */\nexport const DatePicker = ({ onDateChange, ...props }: DatePickerProps) => {\n const hasPointer = useAdaptivityHasPointer();\n\n const onChange = (update: DatePickerDateFormat) => {\n onDateChange && onDateChange({ ...update });\n };\n\n const Cmp = hasPointer ? DatePickerCustom : DatePickerNative;\n return <Cmp {...props} onDateChange={onChange} />;\n};\n"],"names":["DatePicker","DefaultMonths","DEFAULT_EMPTY_DATE","day","month","year","convertToInputFormat","value","undefined","leadingZero","parseInputDate","date","length","splited","split","Number","getMonthMaxDay","Date","getDate","DatePickerCustom","name","min","max","dayPlaceholder","monthPlaceholder","yearPlaceholder","popupDirection","monthNames","onDateChange","disabled","defaultValue","restProps","isControlled","internalValue","setInternalValue","useCustomEnsuredControl","hiddenInput","React","useRef","onSelectChange","e","nextDate","target","clamp","dayOptions","range","map","label","String","monthOptions","index","yearOptions","useNativeFormResetListener","RootComponent","baseClassName","div","className","CustomSelect","options","placeholder","onChange","input","type","ref","DatePickerNative","onStringChange","useCallback","currentTarget","inputProps","Input","props","hasPointer","useAdaptivityHasPointer","update","Cmp"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/components/DatePicker/DatePicker.tsx"],"sourcesContent":["import * as React from 'react';\nimport { leadingZero } from '@vkontakte/vkjs';\nimport { clamp } from '../../helpers/math';\nimport { range } from '../../helpers/range';\nimport { useAdaptivityHasPointer } from '../../hooks/useAdaptivityHasPointer';\nimport { useCustomEnsuredControl } from '../../hooks/useEnsuredControl';\nimport { useNativeFormResetListener } from '../../hooks/useNativeFormResetListener';\nimport { HasOnlyExpectedProps, HTMLAttributesWithRootRef } from '../../types';\nimport { CustomSelect } from '../CustomSelect/CustomSelect';\nimport { Input, type InputProps } from '../Input/Input';\nimport { RootComponent } from '../RootComponent/RootComponent';\nimport styles from './DatePicker.module.css';\n\nconst DefaultMonths: string[] = [\n 'Января',\n 'Февраля',\n 'Марта',\n 'Апреля',\n 'Мая',\n 'Июня',\n 'Июля',\n 'Августа',\n 'Сентября',\n 'Октября',\n 'Ноября',\n 'Декабря',\n];\n\nexport type DatePickerDateFormat = {\n day: number;\n month: number;\n year: number;\n};\n\nconst DEFAULT_EMPTY_DATE = { day: 0, month: 0, year: 0 };\n\nexport interface DatePickerProps\n extends Omit<\n HTMLAttributesWithRootRef<HTMLDivElement>,\n 'defaultValue' | 'value' | 'min' | 'max'\n > {\n min?: DatePickerDateFormat;\n max?: DatePickerDateFormat;\n name?: string;\n defaultValue?: DatePickerDateFormat;\n value?: DatePickerDateFormat;\n popupDirection?: 'top' | 'bottom';\n monthNames?: string[];\n dayPlaceholder?: string;\n monthPlaceholder?: string;\n yearPlaceholder?: string;\n onDateChange?: (value: DatePickerDateFormat) => void; // TODO [>=7] заменить на onChange\n disabled?: boolean;\n}\n\n// Переводим state к формату гг-мм-дд\nfunction convertToInputFormat(value: Partial<DatePickerDateFormat> | undefined) {\n if (!value) {\n return undefined;\n }\n const { day = 0, month = 0, year = 0 } = value;\n return `${year}-${leadingZero(month)}-${leadingZero(day)}`;\n}\n\n// Переводим дату формата гг-мм-дд к объекту\nfunction parseInputDate(date: string): DatePickerDateFormat {\n if (date.length === 0) {\n return DEFAULT_EMPTY_DATE;\n }\n const splited = date.split('-');\n\n return {\n day: Number(splited[2]),\n month: Number(splited[1]),\n year: Number(splited[0]),\n };\n}\n\nfunction getMonthMaxDay(month?: number, year?: number) {\n return month ? new Date(year || 2016, month, 0).getDate() : 31;\n}\n\nconst DatePickerCustom = ({\n name,\n min = { day: 0, month: 0, year: 0 },\n max = { day: 31, month: 12, year: 2100 },\n dayPlaceholder,\n monthPlaceholder,\n yearPlaceholder,\n popupDirection,\n value,\n monthNames,\n onDateChange,\n disabled,\n defaultValue = DEFAULT_EMPTY_DATE,\n ...restProps\n}: DatePickerProps) => {\n const isControlled = value !== undefined;\n const [internalValue, setInternalValue] = useCustomEnsuredControl({ value, defaultValue });\n const hiddenInput = React.useRef<HTMLInputElement>(null);\n\n const onSelectChange: React.ChangeEventHandler<HTMLSelectElement> = (e) => {\n const nextDate = {\n day: internalValue.day,\n month: internalValue.month,\n year: internalValue.year,\n };\n nextDate[e.target.name as keyof typeof nextDate] = Number(e.target.value);\n nextDate.day = nextDate.day\n ? clamp(nextDate.day, 1, getMonthMaxDay(nextDate.month, nextDate.year))\n : nextDate.day;\n setInternalValue(nextDate);\n onDateChange?.(nextDate);\n };\n const dayOptions = range(1, getMonthMaxDay(internalValue.month, internalValue.year)).map(\n (value) => ({\n label: String(value),\n value,\n }),\n );\n const monthOptions = (monthNames || DefaultMonths).map((name, index) => ({\n label: name,\n value: index + 1,\n }));\n const yearOptions = range(max.year, min.year).map((value) => ({\n label: String(value),\n value: value,\n }));\n\n useNativeFormResetListener(hiddenInput, () => {\n if (!isControlled) {\n setInternalValue(defaultValue);\n }\n });\n\n return (\n <RootComponent baseClassName={styles['DatePicker']} {...restProps}>\n <div className={styles['DatePicker__container']}>\n <div className={styles['DatePicker__day']}>\n <CustomSelect\n name=\"day\"\n value={internalValue.day}\n options={dayOptions}\n placeholder={dayPlaceholder}\n popupDirection={popupDirection}\n onChange={onSelectChange}\n disabled={disabled}\n />\n </div>\n <div className={styles['DatePicker__month']}>\n <CustomSelect\n className={styles['DatePicker__monthSelect']}\n name=\"month\"\n value={internalValue.month}\n options={monthOptions}\n placeholder={monthPlaceholder}\n popupDirection={popupDirection}\n onChange={onSelectChange}\n disabled={disabled}\n />\n </div>\n <div className={styles['DatePicker__year']}>\n <CustomSelect\n name=\"year\"\n value={internalValue.year}\n options={yearOptions}\n placeholder={yearPlaceholder}\n popupDirection={popupDirection}\n onChange={onSelectChange}\n disabled={disabled}\n />\n </div>\n </div>\n <input\n type=\"hidden\"\n name={name}\n ref={hiddenInput}\n value={convertToInputFormat(internalValue)}\n />\n </RootComponent>\n );\n};\n\nconst DatePickerNative = ({\n min = { day: 0, month: 0, year: 0 },\n max = { day: 31, month: 12, year: 2100 },\n monthNames,\n popupDirection,\n dayPlaceholder,\n monthPlaceholder,\n yearPlaceholder,\n value,\n defaultValue = DEFAULT_EMPTY_DATE,\n onDateChange,\n ...restProps\n}: DatePickerProps) => {\n const onStringChange: React.ChangeEventHandler<HTMLInputElement> = React.useCallback(\n (e) => {\n onDateChange?.(parseInputDate(e.currentTarget.value));\n },\n [onDateChange],\n );\n const inputProps: HasOnlyExpectedProps<\n typeof restProps & Pick<InputProps, 'value' | 'defaultValue'>,\n InputProps\n > = restProps;\n\n if (value) {\n // контролируемый компонент\n inputProps.value = convertToInputFormat(value);\n } else {\n // неконтролируемый компонент\n inputProps.defaultValue = convertToInputFormat(defaultValue);\n }\n\n return (\n <Input\n {...inputProps}\n type=\"date\"\n onChange={onStringChange}\n min={convertToInputFormat(min)}\n max={convertToInputFormat(max)}\n />\n );\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/DatePicker\n *\n * @deprecated 6.2.0\n *\n * Компонент устарел и будет удален в v7. Используйте вместо него компоненты\n * [Input](https://vkcom.github.io/VKUI/#/Input) и\n * [Select](https://vkcom.github.io/VKUI/#/Select).\n */\nexport const DatePicker = ({ onDateChange, ...props }: DatePickerProps) => {\n const hasPointer = useAdaptivityHasPointer();\n\n const onChange = (update: DatePickerDateFormat) => {\n onDateChange && onDateChange({ ...update });\n };\n\n const Cmp = hasPointer ? DatePickerCustom : DatePickerNative;\n return <Cmp {...props} onDateChange={onChange} />;\n};\n"],"names":["DatePicker","DefaultMonths","DEFAULT_EMPTY_DATE","day","month","year","convertToInputFormat","value","undefined","leadingZero","parseInputDate","date","length","splited","split","Number","getMonthMaxDay","Date","getDate","DatePickerCustom","name","min","max","dayPlaceholder","monthPlaceholder","yearPlaceholder","popupDirection","monthNames","onDateChange","disabled","defaultValue","restProps","isControlled","internalValue","setInternalValue","useCustomEnsuredControl","hiddenInput","React","useRef","onSelectChange","e","nextDate","target","clamp","dayOptions","range","map","label","String","monthOptions","index","yearOptions","useNativeFormResetListener","RootComponent","baseClassName","div","className","CustomSelect","options","placeholder","onChange","input","type","ref","DatePickerNative","onStringChange","useCallback","currentTarget","inputProps","Input","props","hasPointer","useAdaptivityHasPointer","update","Cmp"],"mappings":"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"}