@vkontakte/vkui 5.1.2 → 5.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 (1245) hide show
  1. package/README.md +6 -1
  2. package/dist/cjs/components/ActionSheet/ActionSheet.js +8 -8
  3. package/dist/cjs/components/ActionSheet/ActionSheet.js.map +1 -1
  4. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js +4 -4
  5. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  6. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js +7 -7
  7. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  8. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js +5 -6
  9. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  10. package/dist/cjs/components/AdaptivityProvider/AdaptivityContext.d.ts +1 -1
  11. package/dist/cjs/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  12. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js +1 -1
  13. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  14. package/dist/cjs/components/Alert/Alert.d.ts +1 -1
  15. package/dist/cjs/components/Alert/Alert.js +10 -10
  16. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  17. package/dist/cjs/components/AppRoot/AppRoot.js +20 -12
  18. package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
  19. package/dist/cjs/components/AppRoot/AppRootPortal.js +2 -2
  20. package/dist/cjs/components/AppRoot/AppRootPortal.js.map +1 -1
  21. package/dist/cjs/components/AppRoot/ScrollContext.js +1 -1
  22. package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
  23. package/dist/cjs/components/Avatar/Avatar.d.ts +1 -1
  24. package/dist/cjs/components/Avatar/Avatar.js +1 -1
  25. package/dist/cjs/components/Avatar/Avatar.js.map +1 -1
  26. package/dist/cjs/components/Avatar/AvatarBadge/AvatarBadge.js.map +1 -1
  27. package/dist/cjs/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  28. package/dist/cjs/components/Banner/Banner.js +2 -2
  29. package/dist/cjs/components/Banner/Banner.js.map +1 -1
  30. package/dist/cjs/components/BaseGallery/BaseGallery.js +4 -4
  31. package/dist/cjs/components/BaseGallery/BaseGallery.js.map +1 -1
  32. package/dist/cjs/components/BaseGallery/helpers.d.ts +1 -1
  33. package/dist/cjs/components/BaseGallery/helpers.js.map +1 -1
  34. package/dist/cjs/components/BaseGallery/types.d.ts +1 -1
  35. package/dist/cjs/components/BaseGallery/types.js.map +1 -1
  36. package/dist/cjs/components/Button/Button.d.ts +1 -1
  37. package/dist/cjs/components/Button/Button.js +12 -6
  38. package/dist/cjs/components/Button/Button.js.map +1 -1
  39. package/dist/cjs/components/ButtonGroup/ButtonGroup.d.ts +1 -1
  40. package/dist/cjs/components/ButtonGroup/ButtonGroup.js.map +1 -1
  41. package/dist/cjs/components/Calendar/Calendar.d.ts +2 -2
  42. package/dist/cjs/components/Calendar/Calendar.js +6 -6
  43. package/dist/cjs/components/Calendar/Calendar.js.map +1 -1
  44. package/dist/cjs/components/CalendarDay/CalendarDay.js +1 -1
  45. package/dist/cjs/components/CalendarDay/CalendarDay.js.map +1 -1
  46. package/dist/cjs/components/CalendarDays/CalendarDays.js +3 -3
  47. package/dist/cjs/components/CalendarDays/CalendarDays.js.map +1 -1
  48. package/dist/cjs/components/CalendarHeader/CalendarHeader.js +4 -4
  49. package/dist/cjs/components/CalendarHeader/CalendarHeader.js.map +1 -1
  50. package/dist/cjs/components/CalendarRange/CalendarRange.d.ts +2 -2
  51. package/dist/cjs/components/CalendarRange/CalendarRange.js +3 -3
  52. package/dist/cjs/components/CalendarRange/CalendarRange.js.map +1 -1
  53. package/dist/cjs/components/CalendarTime/CalendarTime.js +3 -3
  54. package/dist/cjs/components/CalendarTime/CalendarTime.js.map +1 -1
  55. package/dist/cjs/components/CardGrid/CardGrid.js +8 -3
  56. package/dist/cjs/components/CardGrid/CardGrid.js.map +1 -1
  57. package/dist/cjs/components/CardScroll/CardScroll.js +2 -6
  58. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  59. package/dist/cjs/components/Cell/Cell.d.ts +1 -1
  60. package/dist/cjs/components/Cell/Cell.js +6 -6
  61. package/dist/cjs/components/Cell/Cell.js.map +1 -1
  62. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js +8 -5
  63. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  64. package/dist/cjs/components/Cell/CellDragger/CellDragger.js +1 -1
  65. package/dist/cjs/components/Cell/CellDragger/CellDragger.js.map +1 -1
  66. package/dist/cjs/components/Checkbox/Checkbox.d.ts +1 -1
  67. package/dist/cjs/components/Checkbox/Checkbox.js +16 -10
  68. package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
  69. package/dist/cjs/components/Chip/Chip.js +11 -6
  70. package/dist/cjs/components/Chip/Chip.js.map +1 -1
  71. package/dist/cjs/components/ChipsInput/ChipsInput.d.ts +1 -1
  72. package/dist/cjs/components/ChipsInput/ChipsInput.js +1 -1
  73. package/dist/cjs/components/ChipsInput/ChipsInput.js.map +1 -1
  74. package/dist/cjs/components/ChipsInputBase/ChipsInputBase.js +4 -4
  75. package/dist/cjs/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
  76. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +5 -9
  77. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  78. package/dist/cjs/components/ConfigProvider/ConfigProvider.js +5 -5
  79. package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
  80. package/dist/cjs/components/ConfigProvider/ConfigProviderOverride.js +1 -1
  81. package/dist/cjs/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  82. package/dist/cjs/components/ContentCard/ContentCard.d.ts +1 -1
  83. package/dist/cjs/components/ContentCard/ContentCard.js +4 -3
  84. package/dist/cjs/components/ContentCard/ContentCard.js.map +1 -1
  85. package/dist/cjs/components/CustomScrollView/CustomScrollView.js +4 -4
  86. package/dist/cjs/components/CustomScrollView/CustomScrollView.js.map +1 -1
  87. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +2 -2
  88. package/dist/cjs/components/CustomSelect/CustomSelect.js +11 -10
  89. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  90. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +3 -4
  91. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js +22 -73
  92. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  93. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js +10 -5
  94. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  95. package/dist/cjs/components/DateInput/DateInput.d.ts +4 -3
  96. package/dist/cjs/components/DateInput/DateInput.js +18 -12
  97. package/dist/cjs/components/DateInput/DateInput.js.map +1 -1
  98. package/dist/cjs/components/DatePicker/DatePicker.js +2 -2
  99. package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
  100. package/dist/cjs/components/DateRangeInput/DateRangeInput.d.ts +3 -3
  101. package/dist/cjs/components/DateRangeInput/DateRangeInput.js +18 -12
  102. package/dist/cjs/components/DateRangeInput/DateRangeInput.js.map +1 -1
  103. package/dist/cjs/components/DropdownIcon/DropdownIcon.js.map +1 -1
  104. package/dist/cjs/components/Epic/Epic.js +1 -1
  105. package/dist/cjs/components/Epic/Epic.js.map +1 -1
  106. package/dist/cjs/components/Epic/ScrollSaver.js +1 -1
  107. package/dist/cjs/components/Epic/ScrollSaver.js.map +1 -1
  108. package/dist/cjs/components/File/File.d.ts +1 -1
  109. package/dist/cjs/components/File/File.js +2 -2
  110. package/dist/cjs/components/File/File.js.map +1 -1
  111. package/dist/cjs/components/FixedLayout/FixedLayout.js +6 -6
  112. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  113. package/dist/cjs/components/FormField/FormField.js +14 -13
  114. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  115. package/dist/cjs/components/FormItem/FormItem.js +11 -6
  116. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  117. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js +9 -4
  118. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  119. package/dist/cjs/components/GridAvatar/GridAvatar.js.map +1 -1
  120. package/dist/cjs/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.js.map +1 -1
  121. package/dist/cjs/components/Group/Group.js +14 -8
  122. package/dist/cjs/components/Group/Group.js.map +1 -1
  123. package/dist/cjs/components/Header/Header.js +3 -3
  124. package/dist/cjs/components/Header/Header.js.map +1 -1
  125. package/dist/cjs/components/HorizontalCell/HorizontalCell.js +3 -3
  126. package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
  127. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js +3 -3
  128. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  129. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  130. package/dist/cjs/components/HoverPopper/HoverPopper.js +2 -2
  131. package/dist/cjs/components/HoverPopper/HoverPopper.js.map +1 -1
  132. package/dist/cjs/components/IconButton/IconButton.js +19 -5
  133. package/dist/cjs/components/IconButton/IconButton.js.map +1 -1
  134. package/dist/cjs/components/Image/Image.d.ts +1 -1
  135. package/dist/cjs/components/Image/Image.js.map +1 -1
  136. package/dist/cjs/components/Image/ImageBadge/ImageBadge.js.map +1 -1
  137. package/dist/cjs/components/ImageBase/ImageBase.d.ts +1 -1
  138. package/dist/cjs/components/ImageBase/ImageBase.js.map +1 -1
  139. package/dist/cjs/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js +1 -1
  140. package/dist/cjs/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  141. package/dist/cjs/components/ImageBase/validators.js +1 -1
  142. package/dist/cjs/components/ImageBase/validators.js.map +1 -1
  143. package/dist/cjs/components/InfoRow/InfoRow.js +1 -1
  144. package/dist/cjs/components/InfoRow/InfoRow.js.map +1 -1
  145. package/dist/cjs/components/Input/Input.d.ts +1 -1
  146. package/dist/cjs/components/Input/Input.js +9 -4
  147. package/dist/cjs/components/Input/Input.js.map +1 -1
  148. package/dist/cjs/components/InputLike/InputLike.js +1 -1
  149. package/dist/cjs/components/InputLike/InputLike.js.map +1 -1
  150. package/dist/cjs/components/Link/Link.js.map +1 -1
  151. package/dist/cjs/components/LocaleProvider/LocaleProvider.js.map +1 -1
  152. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js +2 -2
  153. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  154. package/dist/cjs/components/ModalCard/ModalCard.d.ts +1 -1
  155. package/dist/cjs/components/ModalCard/ModalCard.js +9 -7
  156. package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
  157. package/dist/cjs/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  158. package/dist/cjs/components/ModalCardBase/ModalCardBase.js +15 -8
  159. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  160. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.js +1 -1
  161. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  162. package/dist/cjs/components/ModalPage/ModalPage.d.ts +2 -6
  163. package/dist/cjs/components/ModalPage/ModalPage.js +20 -14
  164. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  165. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js +4 -4
  166. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  167. package/dist/cjs/components/ModalRoot/ModalRoot.js +13 -14
  168. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  169. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js +2 -2
  170. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  171. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +6 -6
  172. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  173. package/dist/cjs/components/ModalRoot/useModalManager.js +3 -3
  174. package/dist/cjs/components/ModalRoot/useModalManager.js.map +1 -1
  175. package/dist/cjs/components/NativeSelect/NativeSelect.d.ts +1 -1
  176. package/dist/cjs/components/NativeSelect/NativeSelect.js +12 -9
  177. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  178. package/dist/cjs/components/Pagination/Pagination.js +11 -5
  179. package/dist/cjs/components/Pagination/Pagination.js.map +1 -1
  180. package/dist/cjs/components/Panel/Panel.d.ts +1 -1
  181. package/dist/cjs/components/Panel/Panel.js +13 -7
  182. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  183. package/dist/cjs/components/PanelHeader/PanelHeader.js +7 -7
  184. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  185. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js +7 -6
  186. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  187. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js +3 -3
  188. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  189. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.js +2 -2
  190. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  191. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js +3 -3
  192. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  193. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js +13 -7
  194. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  195. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.js +2 -2
  196. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  197. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.js +2 -2
  198. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  199. package/dist/cjs/components/Placeholder/Placeholder.js +1 -1
  200. package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
  201. package/dist/cjs/components/PlatformProvider/PlatformProvider.js +2 -2
  202. package/dist/cjs/components/PlatformProvider/PlatformProvider.js.map +1 -1
  203. package/dist/cjs/components/PopoutRoot/PopoutRoot.js +2 -2
  204. package/dist/cjs/components/PopoutRoot/PopoutRoot.js.map +1 -1
  205. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js +3 -3
  206. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  207. package/dist/cjs/components/Popover/Popover.js +5 -5
  208. package/dist/cjs/components/Popover/Popover.js.map +1 -1
  209. package/dist/cjs/components/Popper/Popper.d.ts +12 -9
  210. package/dist/cjs/components/Popper/Popper.js +94 -121
  211. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  212. package/dist/cjs/components/PopperArrow/PopperArrow.d.ts +15 -5
  213. package/dist/cjs/components/PopperArrow/PopperArrow.js +44 -17
  214. package/dist/cjs/components/PopperArrow/PopperArrow.js.map +1 -1
  215. package/dist/cjs/components/Progress/Progress.js +1 -1
  216. package/dist/cjs/components/Progress/Progress.js.map +1 -1
  217. package/dist/cjs/components/PromoBanner/PromoBanner.js +2 -2
  218. package/dist/cjs/components/PromoBanner/PromoBanner.js.map +1 -1
  219. package/dist/cjs/components/PullToRefresh/PullToRefresh.d.ts +1 -1
  220. package/dist/cjs/components/PullToRefresh/PullToRefresh.js +8 -8
  221. package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
  222. package/dist/cjs/components/Radio/Radio.js +12 -7
  223. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  224. package/dist/cjs/components/RangeSlider/RangeSlider.js.map +1 -1
  225. package/dist/cjs/components/RangeSlider/UniversalSlider.d.ts +1 -1
  226. package/dist/cjs/components/RangeSlider/UniversalSlider.js +10 -5
  227. package/dist/cjs/components/RangeSlider/UniversalSlider.js.map +1 -1
  228. package/dist/cjs/components/Removable/Removable.js +4 -8
  229. package/dist/cjs/components/Removable/Removable.js.map +1 -1
  230. package/dist/cjs/components/RichCell/RichCell.js +9 -4
  231. package/dist/cjs/components/RichCell/RichCell.js.map +1 -1
  232. package/dist/cjs/components/RichTooltip/RichTooltip.js +1 -1
  233. package/dist/cjs/components/RichTooltip/RichTooltip.js.map +1 -1
  234. package/dist/cjs/components/Root/Root.js +9 -9
  235. package/dist/cjs/components/Root/Root.js.map +1 -1
  236. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js +5 -5
  237. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  238. package/dist/cjs/components/Search/Search.d.ts +1 -1
  239. package/dist/cjs/components/Search/Search.js +13 -8
  240. package/dist/cjs/components/Search/Search.js.map +1 -1
  241. package/dist/cjs/components/SegmentedControl/SegmentedControl.js +18 -18
  242. package/dist/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
  243. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +10 -4
  244. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  245. package/dist/cjs/components/Select/Select.js +3 -3
  246. package/dist/cjs/components/Select/Select.js.map +1 -1
  247. package/dist/cjs/components/SelectMimicry/SelectMimicry.d.ts +1 -1
  248. package/dist/cjs/components/SelectMimicry/SelectMimicry.js +12 -9
  249. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  250. package/dist/cjs/components/SelectTypography/SelectTypography.js +1 -1
  251. package/dist/cjs/components/SelectTypography/SelectTypography.js.map +1 -1
  252. package/dist/cjs/components/SimpleCell/SimpleCell.js +13 -7
  253. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  254. package/dist/cjs/components/Snackbar/Snackbar.js +8 -8
  255. package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
  256. package/dist/cjs/components/Spinner/Spinner.js +1 -1
  257. package/dist/cjs/components/Spinner/Spinner.js.map +1 -1
  258. package/dist/cjs/components/SplitCol/SplitCol.d.ts +0 -6
  259. package/dist/cjs/components/SplitCol/SplitCol.js +12 -18
  260. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  261. package/dist/cjs/components/SplitCol/SplitColContext.d.ts +7 -0
  262. package/dist/cjs/components/SplitCol/SplitColContext.js +18 -0
  263. package/dist/cjs/components/SplitCol/SplitColContext.js.map +1 -0
  264. package/dist/cjs/components/SplitLayout/SplitLayout.js +1 -1
  265. package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
  266. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js +10 -5
  267. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  268. package/dist/cjs/components/Switch/Switch.js +12 -7
  269. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  270. package/dist/cjs/components/TabbarItem/TabbarItem.js +10 -1
  271. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  272. package/dist/cjs/components/Tabs/Tabs.js +3 -3
  273. package/dist/cjs/components/Tabs/Tabs.js.map +1 -1
  274. package/dist/cjs/components/TabsItem/TabsItem.js +10 -5
  275. package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
  276. package/dist/cjs/components/Tappable/Tappable.d.ts +1 -1
  277. package/dist/cjs/components/Tappable/Tappable.js +14 -14
  278. package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
  279. package/dist/cjs/components/TextTooltip/TextTooltip.js +1 -1
  280. package/dist/cjs/components/TextTooltip/TextTooltip.js.map +1 -1
  281. package/dist/cjs/components/Textarea/Textarea.d.ts +1 -1
  282. package/dist/cjs/components/Textarea/Textarea.js +10 -5
  283. package/dist/cjs/components/Textarea/Textarea.js.map +1 -1
  284. package/dist/cjs/components/Tooltip/Tooltip.d.ts +3 -3
  285. package/dist/cjs/components/Tooltip/Tooltip.js +120 -156
  286. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  287. package/dist/cjs/components/Touch/Touch.js +3 -3
  288. package/dist/cjs/components/Touch/Touch.js.map +1 -1
  289. package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
  290. package/dist/cjs/components/Typography/Footnote/Footnote.js.map +1 -1
  291. package/dist/cjs/components/Typography/Headline/Headline.js +9 -4
  292. package/dist/cjs/components/Typography/Headline/Headline.js.map +1 -1
  293. package/dist/cjs/components/Typography/Subhead/Subhead.js +8 -3
  294. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  295. package/dist/cjs/components/Typography/Text/Text.js +9 -4
  296. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  297. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  298. package/dist/cjs/components/UsersStack/UsersStack.js +2 -2
  299. package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
  300. package/dist/cjs/components/View/View.js +13 -13
  301. package/dist/cjs/components/View/View.js.map +1 -1
  302. package/dist/cjs/components/View/ViewInfinite.d.ts +3 -3
  303. package/dist/cjs/components/View/ViewInfinite.js +10 -10
  304. package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
  305. package/dist/cjs/components/WriteBar/WriteBar.js +4 -4
  306. package/dist/cjs/components/WriteBar/WriteBar.js.map +1 -1
  307. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js +12 -10
  308. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  309. package/dist/cjs/helpers/getPlatformClassName.js.map +1 -1
  310. package/dist/cjs/hoc/withPlatform.js.map +1 -1
  311. package/dist/cjs/hooks/useAdaptivityConditionalRender/helpers.d.ts +2 -2
  312. package/dist/cjs/hooks/useAdaptivityConditionalRender/helpers.js.map +1 -1
  313. package/dist/cjs/hooks/useAdaptivityConditionalRender/useAdaptivityConditionalRender.js.map +1 -1
  314. package/dist/cjs/hooks/useAdaptivityWithJSMediaQueries.js +1 -1
  315. package/dist/cjs/hooks/useAdaptivityWithJSMediaQueries.js.map +1 -1
  316. package/dist/cjs/hooks/useAutoDetectAppearance.js +1 -1
  317. package/dist/cjs/hooks/useAutoDetectAppearance.js.map +1 -1
  318. package/dist/cjs/hooks/useCalendar.js.map +1 -1
  319. package/dist/cjs/hooks/useChipsSelect.d.ts +1 -1
  320. package/dist/cjs/hooks/useChipsSelect.js.map +1 -1
  321. package/dist/cjs/hooks/useDateInput.js +1 -1
  322. package/dist/cjs/hooks/useDateInput.js.map +1 -1
  323. package/dist/cjs/hooks/useFocusVisible.js.map +1 -1
  324. package/dist/cjs/hooks/useMediaQueries.js.map +1 -1
  325. package/dist/cjs/hooks/usePatchChildrenRef.js +1 -1
  326. package/dist/cjs/hooks/usePatchChildrenRef.js.map +1 -1
  327. package/dist/cjs/hooks/useTimeout.js +1 -1
  328. package/dist/cjs/hooks/useTimeout.js.map +1 -1
  329. package/dist/cjs/hooks/useTodayDate.js.map +1 -1
  330. package/dist/cjs/hooks/useWaitTransitionFinish.js +1 -1
  331. package/dist/cjs/hooks/useWaitTransitionFinish.js.map +1 -1
  332. package/dist/cjs/index.d.ts +37 -30
  333. package/dist/cjs/index.js +13 -13
  334. package/dist/cjs/index.js.map +1 -1
  335. package/dist/cjs/lib/SSR.js +3 -3
  336. package/dist/cjs/lib/SSR.js.map +1 -1
  337. package/dist/cjs/lib/adaptivity/constants.d.ts +7 -0
  338. package/dist/cjs/lib/adaptivity/constants.js +6 -1
  339. package/dist/cjs/lib/adaptivity/constants.js.map +1 -1
  340. package/dist/cjs/lib/adaptivity/functions.d.ts +9 -1
  341. package/dist/cjs/lib/adaptivity/functions.js +43 -0
  342. package/dist/cjs/lib/adaptivity/functions.js.map +1 -1
  343. package/dist/cjs/lib/adaptivity/types.d.ts +2 -1
  344. package/dist/cjs/lib/adaptivity/types.js.map +1 -1
  345. package/dist/cjs/lib/calendar.js.map +1 -1
  346. package/dist/cjs/lib/floating/adapters.d.ts +2 -0
  347. package/dist/cjs/lib/floating/adapters.js +63 -0
  348. package/dist/cjs/lib/floating/adapters.js.map +1 -0
  349. package/dist/cjs/lib/floating/functions.d.ts +10 -0
  350. package/dist/cjs/lib/floating/functions.js +36 -0
  351. package/dist/cjs/lib/floating/functions.js.map +1 -0
  352. package/dist/cjs/lib/floating/index.d.ts +4 -0
  353. package/dist/cjs/lib/floating/index.js +75 -0
  354. package/dist/cjs/lib/floating/index.js.map +1 -0
  355. package/dist/cjs/lib/floating/types.d.ts +4 -0
  356. package/dist/cjs/lib/floating/types.js +6 -0
  357. package/dist/cjs/lib/floating/types.js.map +1 -0
  358. package/dist/cjs/lib/platform.js +1 -1
  359. package/dist/cjs/lib/platform.js.map +1 -1
  360. package/dist/cjs/lib/select.js.map +1 -1
  361. package/dist/cjs/lib/useIsomorphicLayoutEffect.d.ts +1 -1
  362. package/dist/cjs/lib/warnOnce.d.ts +7 -0
  363. package/dist/cjs/lib/warnOnce.js +14 -0
  364. package/dist/cjs/lib/warnOnce.js.map +1 -1
  365. package/dist/cjs/shared/breakpoints.d.ts +44 -0
  366. package/dist/cjs/shared/breakpoints.js +79 -13
  367. package/dist/cjs/shared/breakpoints.js.map +1 -1
  368. package/dist/cjs/types.d.ts +9 -1
  369. package/dist/cjs/types.js.map +1 -1
  370. package/dist/components/ActionSheet/ActionSheet.js +8 -8
  371. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  372. package/dist/components/ActionSheet/ActionSheetDropdown.js +4 -4
  373. package/dist/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  374. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js +7 -7
  375. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  376. package/dist/components/ActionSheetItem/ActionSheetItem.js +5 -6
  377. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  378. package/dist/components/AdaptivityProvider/AdaptivityContext.d.ts +1 -1
  379. package/dist/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  380. package/dist/components/AdaptivityProvider/AdaptivityProvider.js +1 -1
  381. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  382. package/dist/components/Alert/Alert.d.ts +1 -1
  383. package/dist/components/Alert/Alert.js +10 -10
  384. package/dist/components/Alert/Alert.js.map +1 -1
  385. package/dist/components/AppRoot/AppRoot.js +20 -12
  386. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  387. package/dist/components/AppRoot/AppRootPortal.js +2 -2
  388. package/dist/components/AppRoot/AppRootPortal.js.map +1 -1
  389. package/dist/components/AppRoot/ScrollContext.js +1 -1
  390. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  391. package/dist/components/Avatar/Avatar.d.ts +1 -1
  392. package/dist/components/Avatar/Avatar.js +1 -1
  393. package/dist/components/Avatar/Avatar.js.map +1 -1
  394. package/dist/components/Avatar/AvatarBadge/AvatarBadge.js.map +1 -1
  395. package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js +1 -1
  396. package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  397. package/dist/components/Banner/Banner.js +2 -2
  398. package/dist/components/Banner/Banner.js.map +1 -1
  399. package/dist/components/BaseGallery/BaseGallery.js +4 -4
  400. package/dist/components/BaseGallery/BaseGallery.js.map +1 -1
  401. package/dist/components/BaseGallery/helpers.d.ts +1 -1
  402. package/dist/components/BaseGallery/helpers.js.map +1 -1
  403. package/dist/components/BaseGallery/types.d.ts +1 -1
  404. package/dist/components/BaseGallery/types.js.map +1 -1
  405. package/dist/components/Button/Button.d.ts +1 -1
  406. package/dist/components/Button/Button.js +12 -6
  407. package/dist/components/Button/Button.js.map +1 -1
  408. package/dist/components/ButtonGroup/ButtonGroup.d.ts +1 -1
  409. package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -1
  410. package/dist/components/Calendar/Calendar.d.ts +2 -2
  411. package/dist/components/Calendar/Calendar.js +7 -7
  412. package/dist/components/Calendar/Calendar.js.map +1 -1
  413. package/dist/components/CalendarDay/CalendarDay.js +1 -1
  414. package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
  415. package/dist/components/CalendarDays/CalendarDays.js +3 -3
  416. package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
  417. package/dist/components/CalendarHeader/CalendarHeader.js +5 -5
  418. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
  419. package/dist/components/CalendarRange/CalendarRange.d.ts +2 -2
  420. package/dist/components/CalendarRange/CalendarRange.js +4 -4
  421. package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
  422. package/dist/components/CalendarTime/CalendarTime.js +3 -3
  423. package/dist/components/CalendarTime/CalendarTime.js.map +1 -1
  424. package/dist/components/CardGrid/CardGrid.js +8 -3
  425. package/dist/components/CardGrid/CardGrid.js.map +1 -1
  426. package/dist/components/CardScroll/CardScroll.js +2 -6
  427. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  428. package/dist/components/Cell/Cell.d.ts +1 -1
  429. package/dist/components/Cell/Cell.js +6 -6
  430. package/dist/components/Cell/Cell.js.map +1 -1
  431. package/dist/components/Cell/CellCheckbox/CellCheckbox.js +8 -5
  432. package/dist/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  433. package/dist/components/Cell/CellDragger/CellDragger.js +1 -1
  434. package/dist/components/Cell/CellDragger/CellDragger.js.map +1 -1
  435. package/dist/components/Checkbox/Checkbox.d.ts +1 -1
  436. package/dist/components/Checkbox/Checkbox.js +16 -10
  437. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  438. package/dist/components/Chip/Chip.js +11 -6
  439. package/dist/components/Chip/Chip.js.map +1 -1
  440. package/dist/components/ChipsInput/ChipsInput.d.ts +1 -1
  441. package/dist/components/ChipsInput/ChipsInput.js +1 -1
  442. package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
  443. package/dist/components/ChipsInputBase/ChipsInputBase.js +4 -4
  444. package/dist/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
  445. package/dist/components/ChipsSelect/ChipsSelect.js +5 -9
  446. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  447. package/dist/components/ConfigProvider/ConfigProvider.js +5 -5
  448. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  449. package/dist/components/ConfigProvider/ConfigProviderOverride.js +1 -1
  450. package/dist/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  451. package/dist/components/ContentCard/ContentCard.d.ts +1 -1
  452. package/dist/components/ContentCard/ContentCard.js +4 -3
  453. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  454. package/dist/components/CustomScrollView/CustomScrollView.js +4 -4
  455. package/dist/components/CustomScrollView/CustomScrollView.js.map +1 -1
  456. package/dist/components/CustomSelect/CustomSelect.d.ts +2 -2
  457. package/dist/components/CustomSelect/CustomSelect.js +11 -10
  458. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  459. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +3 -4
  460. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js +22 -73
  461. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  462. package/dist/components/CustomSelectOption/CustomSelectOption.js +10 -5
  463. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  464. package/dist/components/DateInput/DateInput.d.ts +4 -3
  465. package/dist/components/DateInput/DateInput.js +18 -12
  466. package/dist/components/DateInput/DateInput.js.map +1 -1
  467. package/dist/components/DatePicker/DatePicker.js +2 -2
  468. package/dist/components/DatePicker/DatePicker.js.map +1 -1
  469. package/dist/components/DateRangeInput/DateRangeInput.d.ts +3 -3
  470. package/dist/components/DateRangeInput/DateRangeInput.js +18 -12
  471. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  472. package/dist/components/DropdownIcon/DropdownIcon.js +1 -1
  473. package/dist/components/DropdownIcon/DropdownIcon.js.map +1 -1
  474. package/dist/components/Epic/Epic.js +1 -1
  475. package/dist/components/Epic/Epic.js.map +1 -1
  476. package/dist/components/Epic/ScrollSaver.js +1 -1
  477. package/dist/components/Epic/ScrollSaver.js.map +1 -1
  478. package/dist/components/File/File.d.ts +1 -1
  479. package/dist/components/File/File.js +2 -2
  480. package/dist/components/File/File.js.map +1 -1
  481. package/dist/components/FixedLayout/FixedLayout.js +5 -5
  482. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  483. package/dist/components/FormField/FormField.js +14 -13
  484. package/dist/components/FormField/FormField.js.map +1 -1
  485. package/dist/components/FormItem/FormItem.js +11 -6
  486. package/dist/components/FormItem/FormItem.js.map +1 -1
  487. package/dist/components/FormLayoutGroup/FormLayoutGroup.js +9 -4
  488. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  489. package/dist/components/GridAvatar/GridAvatar.js.map +1 -1
  490. package/dist/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.js.map +1 -1
  491. package/dist/components/Group/Group.js +14 -8
  492. package/dist/components/Group/Group.js.map +1 -1
  493. package/dist/components/Header/Header.js +3 -3
  494. package/dist/components/Header/Header.js.map +1 -1
  495. package/dist/components/HorizontalCell/HorizontalCell.js +3 -3
  496. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  497. package/dist/components/HorizontalScroll/HorizontalScroll.js +3 -3
  498. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  499. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js +1 -1
  500. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  501. package/dist/components/HoverPopper/HoverPopper.js +2 -2
  502. package/dist/components/HoverPopper/HoverPopper.js.map +1 -1
  503. package/dist/components/IconButton/IconButton.js +19 -5
  504. package/dist/components/IconButton/IconButton.js.map +1 -1
  505. package/dist/components/Image/Image.d.ts +1 -1
  506. package/dist/components/Image/Image.js.map +1 -1
  507. package/dist/components/Image/ImageBadge/ImageBadge.js.map +1 -1
  508. package/dist/components/ImageBase/ImageBase.d.ts +1 -1
  509. package/dist/components/ImageBase/ImageBase.js +1 -1
  510. package/dist/components/ImageBase/ImageBase.js.map +1 -1
  511. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js +1 -1
  512. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  513. package/dist/components/ImageBase/validators.js +1 -1
  514. package/dist/components/ImageBase/validators.js.map +1 -1
  515. package/dist/components/InfoRow/InfoRow.js +1 -1
  516. package/dist/components/InfoRow/InfoRow.js.map +1 -1
  517. package/dist/components/Input/Input.d.ts +1 -1
  518. package/dist/components/Input/Input.js +9 -4
  519. package/dist/components/Input/Input.js.map +1 -1
  520. package/dist/components/InputLike/InputLike.js +1 -1
  521. package/dist/components/InputLike/InputLike.js.map +1 -1
  522. package/dist/components/Link/Link.js.map +1 -1
  523. package/dist/components/LocaleProvider/LocaleProvider.js.map +1 -1
  524. package/dist/components/MiniInfoCell/MiniInfoCell.js +2 -2
  525. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  526. package/dist/components/ModalCard/ModalCard.d.ts +1 -1
  527. package/dist/components/ModalCard/ModalCard.js +9 -7
  528. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  529. package/dist/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  530. package/dist/components/ModalCardBase/ModalCardBase.js +15 -8
  531. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  532. package/dist/components/ModalDismissButton/ModalDismissButton.js +1 -1
  533. package/dist/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  534. package/dist/components/ModalPage/ModalPage.d.ts +2 -6
  535. package/dist/components/ModalPage/ModalPage.js +20 -14
  536. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  537. package/dist/components/ModalPageHeader/ModalPageHeader.js +4 -4
  538. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  539. package/dist/components/ModalRoot/ModalRoot.js +13 -14
  540. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  541. package/dist/components/ModalRoot/ModalRootAdaptive.js +2 -2
  542. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  543. package/dist/components/ModalRoot/ModalRootDesktop.js +6 -6
  544. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  545. package/dist/components/ModalRoot/useModalManager.js +3 -3
  546. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  547. package/dist/components/NativeSelect/NativeSelect.d.ts +1 -1
  548. package/dist/components/NativeSelect/NativeSelect.js +12 -9
  549. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  550. package/dist/components/Pagination/Pagination.js +11 -5
  551. package/dist/components/Pagination/Pagination.js.map +1 -1
  552. package/dist/components/Panel/Panel.d.ts +1 -1
  553. package/dist/components/Panel/Panel.js +13 -7
  554. package/dist/components/Panel/Panel.js.map +1 -1
  555. package/dist/components/PanelHeader/PanelHeader.js +7 -7
  556. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  557. package/dist/components/PanelHeaderBack/PanelHeaderBack.js +8 -7
  558. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  559. package/dist/components/PanelHeaderButton/PanelHeaderButton.js +3 -3
  560. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  561. package/dist/components/PanelHeaderClose/PanelHeaderClose.js +2 -2
  562. package/dist/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  563. package/dist/components/PanelHeaderContent/PanelHeaderContent.js +3 -3
  564. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  565. package/dist/components/PanelHeaderContext/PanelHeaderContext.js +13 -7
  566. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  567. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js +3 -3
  568. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  569. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.js +2 -2
  570. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  571. package/dist/components/Placeholder/Placeholder.js +1 -1
  572. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  573. package/dist/components/PlatformProvider/PlatformProvider.js +2 -2
  574. package/dist/components/PlatformProvider/PlatformProvider.js.map +1 -1
  575. package/dist/components/PopoutRoot/PopoutRoot.js +2 -2
  576. package/dist/components/PopoutRoot/PopoutRoot.js.map +1 -1
  577. package/dist/components/PopoutWrapper/PopoutWrapper.js +3 -3
  578. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  579. package/dist/components/Popover/Popover.js +5 -5
  580. package/dist/components/Popover/Popover.js.map +1 -1
  581. package/dist/components/Popper/Popper.d.ts +12 -9
  582. package/dist/components/Popper/Popper.js +95 -122
  583. package/dist/components/Popper/Popper.js.map +1 -1
  584. package/dist/components/PopperArrow/PopperArrow.d.ts +15 -5
  585. package/dist/components/PopperArrow/PopperArrow.js +40 -15
  586. package/dist/components/PopperArrow/PopperArrow.js.map +1 -1
  587. package/dist/components/Progress/Progress.js +1 -1
  588. package/dist/components/Progress/Progress.js.map +1 -1
  589. package/dist/components/PromoBanner/PromoBanner.js +2 -2
  590. package/dist/components/PromoBanner/PromoBanner.js.map +1 -1
  591. package/dist/components/PullToRefresh/PullToRefresh.d.ts +1 -1
  592. package/dist/components/PullToRefresh/PullToRefresh.js +8 -8
  593. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  594. package/dist/components/Radio/Radio.js +12 -7
  595. package/dist/components/Radio/Radio.js.map +1 -1
  596. package/dist/components/RangeSlider/RangeSlider.js.map +1 -1
  597. package/dist/components/RangeSlider/UniversalSlider.d.ts +1 -1
  598. package/dist/components/RangeSlider/UniversalSlider.js +10 -5
  599. package/dist/components/RangeSlider/UniversalSlider.js.map +1 -1
  600. package/dist/components/Removable/Removable.js +4 -8
  601. package/dist/components/Removable/Removable.js.map +1 -1
  602. package/dist/components/RichCell/RichCell.js +9 -4
  603. package/dist/components/RichCell/RichCell.js.map +1 -1
  604. package/dist/components/RichTooltip/RichTooltip.js +1 -1
  605. package/dist/components/RichTooltip/RichTooltip.js.map +1 -1
  606. package/dist/components/Root/Root.js +8 -8
  607. package/dist/components/Root/Root.js.map +1 -1
  608. package/dist/components/ScreenSpinner/ScreenSpinner.js +5 -5
  609. package/dist/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  610. package/dist/components/Search/Search.d.ts +1 -1
  611. package/dist/components/Search/Search.js +13 -8
  612. package/dist/components/Search/Search.js.map +1 -1
  613. package/dist/components/SegmentedControl/SegmentedControl.js +18 -18
  614. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  615. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +10 -4
  616. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  617. package/dist/components/Select/Select.js +3 -3
  618. package/dist/components/Select/Select.js.map +1 -1
  619. package/dist/components/SelectMimicry/SelectMimicry.d.ts +1 -1
  620. package/dist/components/SelectMimicry/SelectMimicry.js +12 -9
  621. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  622. package/dist/components/SelectTypography/SelectTypography.js +1 -1
  623. package/dist/components/SelectTypography/SelectTypography.js.map +1 -1
  624. package/dist/components/SimpleCell/SimpleCell.js +13 -7
  625. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  626. package/dist/components/Snackbar/Snackbar.js +8 -8
  627. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  628. package/dist/components/Spinner/Spinner.js +1 -1
  629. package/dist/components/Spinner/Spinner.js.map +1 -1
  630. package/dist/components/SplitCol/SplitCol.d.ts +0 -6
  631. package/dist/components/SplitCol/SplitCol.js +10 -14
  632. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  633. package/dist/components/SplitCol/SplitColContext.d.ts +7 -0
  634. package/dist/components/SplitCol/SplitColContext.js +9 -0
  635. package/dist/components/SplitCol/SplitColContext.js.map +1 -0
  636. package/dist/components/SplitLayout/SplitLayout.js +1 -1
  637. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  638. package/dist/components/SubnavigationButton/SubnavigationButton.js +10 -5
  639. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  640. package/dist/components/Switch/Switch.js +12 -7
  641. package/dist/components/Switch/Switch.js.map +1 -1
  642. package/dist/components/TabbarItem/TabbarItem.js +10 -1
  643. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  644. package/dist/components/Tabs/Tabs.js +3 -3
  645. package/dist/components/Tabs/Tabs.js.map +1 -1
  646. package/dist/components/TabsItem/TabsItem.js +10 -5
  647. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  648. package/dist/components/Tappable/Tappable.d.ts +1 -1
  649. package/dist/components/Tappable/Tappable.js +14 -14
  650. package/dist/components/Tappable/Tappable.js.map +1 -1
  651. package/dist/components/TextTooltip/TextTooltip.js +1 -1
  652. package/dist/components/TextTooltip/TextTooltip.js.map +1 -1
  653. package/dist/components/Textarea/Textarea.d.ts +1 -1
  654. package/dist/components/Textarea/Textarea.js +10 -5
  655. package/dist/components/Textarea/Textarea.js.map +1 -1
  656. package/dist/components/Tooltip/Tooltip.d.ts +3 -3
  657. package/dist/components/Tooltip/Tooltip.js +120 -156
  658. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  659. package/dist/components/Touch/Touch.js +3 -3
  660. package/dist/components/Touch/Touch.js.map +1 -1
  661. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  662. package/dist/components/Typography/Footnote/Footnote.js.map +1 -1
  663. package/dist/components/Typography/Headline/Headline.js +9 -4
  664. package/dist/components/Typography/Headline/Headline.js.map +1 -1
  665. package/dist/components/Typography/Subhead/Subhead.js +8 -3
  666. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  667. package/dist/components/Typography/Text/Text.js +9 -4
  668. package/dist/components/Typography/Text/Text.js.map +1 -1
  669. package/dist/components/Typography/Title/Title.js.map +1 -1
  670. package/dist/components/UsersStack/UsersStack.js +2 -2
  671. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  672. package/dist/components/View/View.js +12 -12
  673. package/dist/components/View/View.js.map +1 -1
  674. package/dist/components/View/ViewInfinite.d.ts +3 -3
  675. package/dist/components/View/ViewInfinite.js +9 -9
  676. package/dist/components/View/ViewInfinite.js.map +1 -1
  677. package/dist/components/WriteBar/WriteBar.js +4 -4
  678. package/dist/components/WriteBar/WriteBar.js.map +1 -1
  679. package/dist/components/WriteBarIcon/WriteBarIcon.js +12 -10
  680. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  681. package/dist/components.css +142 -2
  682. package/dist/components.css.map +1 -1
  683. package/dist/components.js.tmp +62123 -4
  684. package/dist/cssm/components/ActionSheet/ActionSheet.js +8 -8
  685. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  686. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js +4 -4
  687. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  688. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js +7 -7
  689. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  690. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js +5 -6
  691. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  692. package/dist/cssm/components/AdaptivityProvider/AdaptivityContext.d.ts +1 -1
  693. package/dist/cssm/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  694. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js +1 -1
  695. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  696. package/dist/cssm/components/Alert/Alert.d.ts +1 -1
  697. package/dist/cssm/components/Alert/Alert.js +10 -10
  698. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  699. package/dist/cssm/components/Alert/Alert.module.css +1 -1
  700. package/dist/cssm/components/AppRoot/AppRoot.js +20 -12
  701. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  702. package/dist/cssm/components/AppRoot/AppRootPortal.js +2 -2
  703. package/dist/cssm/components/AppRoot/AppRootPortal.js.map +1 -1
  704. package/dist/cssm/components/AppRoot/ScrollContext.js +1 -1
  705. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  706. package/dist/cssm/components/Avatar/Avatar.d.ts +1 -1
  707. package/dist/cssm/components/Avatar/Avatar.js +1 -1
  708. package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
  709. package/dist/cssm/components/Avatar/Avatar.module.css +1 -1
  710. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadge.js.map +1 -1
  711. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js +1 -1
  712. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  713. package/dist/cssm/components/Banner/Banner.js +2 -2
  714. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  715. package/dist/cssm/components/BaseGallery/BaseGallery.js +4 -4
  716. package/dist/cssm/components/BaseGallery/BaseGallery.js.map +1 -1
  717. package/dist/cssm/components/BaseGallery/helpers.d.ts +1 -1
  718. package/dist/cssm/components/BaseGallery/helpers.js.map +1 -1
  719. package/dist/cssm/components/BaseGallery/types.d.ts +1 -1
  720. package/dist/cssm/components/BaseGallery/types.js.map +1 -1
  721. package/dist/cssm/components/Button/Button.d.ts +1 -1
  722. package/dist/cssm/components/Button/Button.js +12 -6
  723. package/dist/cssm/components/Button/Button.js.map +1 -1
  724. package/dist/cssm/components/Button/Button.module.css +1 -1
  725. package/dist/cssm/components/ButtonGroup/ButtonGroup.d.ts +1 -1
  726. package/dist/cssm/components/ButtonGroup/ButtonGroup.js.map +1 -1
  727. package/dist/cssm/components/Calendar/Calendar.d.ts +2 -2
  728. package/dist/cssm/components/Calendar/Calendar.js +7 -7
  729. package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
  730. package/dist/cssm/components/CalendarDay/CalendarDay.js +1 -1
  731. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
  732. package/dist/cssm/components/CalendarDay/CalendarDay.module.css +1 -1
  733. package/dist/cssm/components/CalendarDays/CalendarDays.js +3 -3
  734. package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
  735. package/dist/cssm/components/CalendarHeader/CalendarHeader.js +5 -5
  736. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
  737. package/dist/cssm/components/CalendarRange/CalendarRange.d.ts +2 -2
  738. package/dist/cssm/components/CalendarRange/CalendarRange.js +4 -4
  739. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
  740. package/dist/cssm/components/CalendarTime/CalendarTime.js +3 -3
  741. package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -1
  742. package/dist/cssm/components/CalendarTime/CalendarTime.module.css +1 -1
  743. package/dist/cssm/components/CardGrid/CardGrid.js +8 -3
  744. package/dist/cssm/components/CardGrid/CardGrid.js.map +1 -1
  745. package/dist/cssm/components/CardGrid/CardGrid.module.css +1 -1
  746. package/dist/cssm/components/CardScroll/CardScroll.js +2 -6
  747. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  748. package/dist/cssm/components/Cell/Cell.d.ts +1 -1
  749. package/dist/cssm/components/Cell/Cell.js +6 -6
  750. package/dist/cssm/components/Cell/Cell.js.map +1 -1
  751. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js +8 -5
  752. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  753. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.module.css +1 -1
  754. package/dist/cssm/components/Cell/CellDragger/CellDragger.js +1 -1
  755. package/dist/cssm/components/Cell/CellDragger/CellDragger.js.map +1 -1
  756. package/dist/cssm/components/Checkbox/Checkbox.d.ts +1 -1
  757. package/dist/cssm/components/Checkbox/Checkbox.js +16 -10
  758. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  759. package/dist/cssm/components/Checkbox/Checkbox.module.css +1 -1
  760. package/dist/cssm/components/Chip/Chip.js +11 -6
  761. package/dist/cssm/components/Chip/Chip.js.map +1 -1
  762. package/dist/cssm/components/Chip/Chip.module.css +1 -1
  763. package/dist/cssm/components/ChipsInput/ChipsInput.d.ts +1 -1
  764. package/dist/cssm/components/ChipsInput/ChipsInput.js +1 -1
  765. package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
  766. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.js +4 -4
  767. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
  768. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +5 -9
  769. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  770. package/dist/cssm/components/ConfigProvider/ConfigProvider.js +5 -5
  771. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  772. package/dist/cssm/components/ConfigProvider/ConfigProviderOverride.js +1 -1
  773. package/dist/cssm/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  774. package/dist/cssm/components/ContentCard/ContentCard.d.ts +1 -1
  775. package/dist/cssm/components/ContentCard/ContentCard.js +4 -3
  776. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  777. package/dist/cssm/components/CustomScrollView/CustomScrollView.js +4 -4
  778. package/dist/cssm/components/CustomScrollView/CustomScrollView.js.map +1 -1
  779. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +2 -2
  780. package/dist/cssm/components/CustomSelect/CustomSelect.js +11 -10
  781. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  782. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +3 -4
  783. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js +22 -73
  784. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  785. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js +10 -5
  786. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  787. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.module.css +1 -1
  788. package/dist/cssm/components/DateInput/DateInput.d.ts +4 -3
  789. package/dist/cssm/components/DateInput/DateInput.js +19 -12
  790. package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
  791. package/dist/cssm/components/DateInput/DateInput.module.css +1 -1
  792. package/dist/cssm/components/DatePicker/DatePicker.js +2 -2
  793. package/dist/cssm/components/DatePicker/DatePicker.js.map +1 -1
  794. package/dist/cssm/components/DateRangeInput/DateRangeInput.d.ts +3 -3
  795. package/dist/cssm/components/DateRangeInput/DateRangeInput.js +18 -12
  796. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  797. package/dist/cssm/components/DateRangeInput/DateRangeInput.module.css +1 -1
  798. package/dist/cssm/components/DropdownIcon/DropdownIcon.js +1 -1
  799. package/dist/cssm/components/DropdownIcon/DropdownIcon.js.map +1 -1
  800. package/dist/cssm/components/Epic/Epic.js +1 -1
  801. package/dist/cssm/components/Epic/Epic.js.map +1 -1
  802. package/dist/cssm/components/Epic/ScrollSaver.js +1 -1
  803. package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
  804. package/dist/cssm/components/File/File.d.ts +1 -1
  805. package/dist/cssm/components/File/File.js +2 -2
  806. package/dist/cssm/components/File/File.js.map +1 -1
  807. package/dist/cssm/components/FixedLayout/FixedLayout.js +5 -5
  808. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  809. package/dist/cssm/components/FormField/FormField.js +14 -13
  810. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  811. package/dist/cssm/components/FormField/FormField.module.css +1 -1
  812. package/dist/cssm/components/FormItem/FormItem.js +11 -6
  813. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  814. package/dist/cssm/components/FormItem/FormItem.module.css +1 -1
  815. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js +9 -4
  816. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  817. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.module.css +1 -1
  818. package/dist/cssm/components/GridAvatar/GridAvatar.js.map +1 -1
  819. package/dist/cssm/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.js.map +1 -1
  820. package/dist/cssm/components/Group/Group.js +14 -8
  821. package/dist/cssm/components/Group/Group.js.map +1 -1
  822. package/dist/cssm/components/Group/Group.module.css +1 -1
  823. package/dist/cssm/components/Header/Header.js +3 -3
  824. package/dist/cssm/components/Header/Header.js.map +1 -1
  825. package/dist/cssm/components/Header/Header.module.css +1 -1
  826. package/dist/cssm/components/HorizontalCell/HorizontalCell.js +3 -3
  827. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  828. package/dist/cssm/components/HorizontalCell/HorizontalCell.module.css +1 -1
  829. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +3 -3
  830. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  831. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js +1 -1
  832. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  833. package/dist/cssm/components/HoverPopper/HoverPopper.js +2 -2
  834. package/dist/cssm/components/HoverPopper/HoverPopper.js.map +1 -1
  835. package/dist/cssm/components/IconButton/IconButton.js +19 -5
  836. package/dist/cssm/components/IconButton/IconButton.js.map +1 -1
  837. package/dist/cssm/components/IconButton/IconButton.module.css +1 -1
  838. package/dist/cssm/components/Image/Image.d.ts +1 -1
  839. package/dist/cssm/components/Image/Image.js.map +1 -1
  840. package/dist/cssm/components/Image/ImageBadge/ImageBadge.js.map +1 -1
  841. package/dist/cssm/components/ImageBase/ImageBase.d.ts +1 -1
  842. package/dist/cssm/components/ImageBase/ImageBase.js +1 -1
  843. package/dist/cssm/components/ImageBase/ImageBase.js.map +1 -1
  844. package/dist/cssm/components/ImageBase/ImageBase.module.css +1 -1
  845. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js +1 -1
  846. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  847. package/dist/cssm/components/ImageBase/validators.js +1 -1
  848. package/dist/cssm/components/ImageBase/validators.js.map +1 -1
  849. package/dist/cssm/components/InfoRow/InfoRow.js +1 -1
  850. package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
  851. package/dist/cssm/components/Input/Input.d.ts +1 -1
  852. package/dist/cssm/components/Input/Input.js +9 -4
  853. package/dist/cssm/components/Input/Input.js.map +1 -1
  854. package/dist/cssm/components/Input/Input.module.css +1 -1
  855. package/dist/cssm/components/InputLike/InputLike.js +1 -1
  856. package/dist/cssm/components/InputLike/InputLike.js.map +1 -1
  857. package/dist/cssm/components/InputLike/InputLike.module.css +1 -1
  858. package/dist/cssm/components/Link/Link.js.map +1 -1
  859. package/dist/cssm/components/LocaleProvider/LocaleProvider.js.map +1 -1
  860. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js +2 -2
  861. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  862. package/dist/cssm/components/ModalCard/ModalCard.d.ts +1 -1
  863. package/dist/cssm/components/ModalCard/ModalCard.js +9 -7
  864. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  865. package/dist/cssm/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  866. package/dist/cssm/components/ModalCardBase/ModalCardBase.js +15 -8
  867. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  868. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js +1 -1
  869. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  870. package/dist/cssm/components/ModalPage/ModalPage.d.ts +2 -6
  871. package/dist/cssm/components/ModalPage/ModalPage.js +20 -14
  872. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  873. package/dist/cssm/components/ModalPage/ModalPage.module.css +1 -1
  874. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js +4 -4
  875. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  876. package/dist/cssm/components/ModalRoot/ModalRoot.js +13 -14
  877. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  878. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js +2 -2
  879. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  880. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +6 -6
  881. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  882. package/dist/cssm/components/ModalRoot/useModalManager.js +3 -3
  883. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  884. package/dist/cssm/components/NativeSelect/NativeSelect.d.ts +1 -1
  885. package/dist/cssm/components/NativeSelect/NativeSelect.js +12 -9
  886. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  887. package/dist/cssm/components/Pagination/Pagination.js +11 -5
  888. package/dist/cssm/components/Pagination/Pagination.js.map +1 -1
  889. package/dist/cssm/components/Pagination/Pagination.module.css +1 -1
  890. package/dist/cssm/components/Panel/Panel.d.ts +1 -1
  891. package/dist/cssm/components/Panel/Panel.js +13 -7
  892. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  893. package/dist/cssm/components/Panel/Panel.module.css +1 -1
  894. package/dist/cssm/components/PanelHeader/PanelHeader.js +7 -7
  895. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  896. package/dist/cssm/components/PanelHeader/PanelHeader.module.css +1 -1
  897. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js +8 -7
  898. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  899. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js +3 -3
  900. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  901. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.module.css +1 -1
  902. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.js +2 -2
  903. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  904. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js +3 -3
  905. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  906. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.module.css +1 -1
  907. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js +13 -7
  908. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  909. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.module.css +1 -1
  910. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js +3 -3
  911. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  912. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.js +2 -2
  913. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  914. package/dist/cssm/components/Placeholder/Placeholder.js +1 -1
  915. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  916. package/dist/cssm/components/PlatformProvider/PlatformProvider.js +2 -2
  917. package/dist/cssm/components/PlatformProvider/PlatformProvider.js.map +1 -1
  918. package/dist/cssm/components/PopoutRoot/PopoutRoot.js +2 -2
  919. package/dist/cssm/components/PopoutRoot/PopoutRoot.js.map +1 -1
  920. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +3 -3
  921. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  922. package/dist/cssm/components/Popover/Popover.js +5 -5
  923. package/dist/cssm/components/Popover/Popover.js.map +1 -1
  924. package/dist/cssm/components/Popper/Popper.d.ts +12 -9
  925. package/dist/cssm/components/Popper/Popper.js +95 -122
  926. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  927. package/dist/cssm/components/PopperArrow/PopperArrow.d.ts +15 -5
  928. package/dist/cssm/components/PopperArrow/PopperArrow.js +40 -15
  929. package/dist/cssm/components/PopperArrow/PopperArrow.js.map +1 -1
  930. package/dist/cssm/components/PopperArrow/PopperArrow.module.css +1 -1
  931. package/dist/cssm/components/Progress/Progress.js +1 -1
  932. package/dist/cssm/components/Progress/Progress.js.map +1 -1
  933. package/dist/cssm/components/PromoBanner/PromoBanner.js +2 -2
  934. package/dist/cssm/components/PromoBanner/PromoBanner.js.map +1 -1
  935. package/dist/cssm/components/PullToRefresh/PullToRefresh.d.ts +1 -1
  936. package/dist/cssm/components/PullToRefresh/PullToRefresh.js +8 -8
  937. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  938. package/dist/cssm/components/Radio/Radio.js +12 -7
  939. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  940. package/dist/cssm/components/Radio/Radio.module.css +1 -1
  941. package/dist/cssm/components/RangeSlider/RangeSlider.js.map +1 -1
  942. package/dist/cssm/components/RangeSlider/UniversalSlider.d.ts +1 -1
  943. package/dist/cssm/components/RangeSlider/UniversalSlider.js +10 -5
  944. package/dist/cssm/components/RangeSlider/UniversalSlider.js.map +1 -1
  945. package/dist/cssm/components/Removable/Removable.js +4 -8
  946. package/dist/cssm/components/Removable/Removable.js.map +1 -1
  947. package/dist/cssm/components/Removable/Removable.module.css +1 -1
  948. package/dist/cssm/components/RichCell/RichCell.js +9 -4
  949. package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
  950. package/dist/cssm/components/RichCell/RichCell.module.css +1 -1
  951. package/dist/cssm/components/RichTooltip/RichTooltip.js +1 -1
  952. package/dist/cssm/components/RichTooltip/RichTooltip.js.map +1 -1
  953. package/dist/cssm/components/Root/Root.js +8 -8
  954. package/dist/cssm/components/Root/Root.js.map +1 -1
  955. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js +5 -5
  956. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  957. package/dist/cssm/components/Search/Search.d.ts +1 -1
  958. package/dist/cssm/components/Search/Search.js +13 -8
  959. package/dist/cssm/components/Search/Search.js.map +1 -1
  960. package/dist/cssm/components/Search/Search.module.css +1 -1
  961. package/dist/cssm/components/SegmentedControl/SegmentedControl.js +18 -18
  962. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  963. package/dist/cssm/components/SegmentedControl/SegmentedControl.module.css +1 -1
  964. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +10 -4
  965. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  966. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.module.css +1 -1
  967. package/dist/cssm/components/Select/Select.js +3 -3
  968. package/dist/cssm/components/Select/Select.js.map +1 -1
  969. package/dist/cssm/components/Select/Select.module.css +1 -1
  970. package/dist/cssm/components/SelectMimicry/SelectMimicry.d.ts +1 -1
  971. package/dist/cssm/components/SelectMimicry/SelectMimicry.js +12 -9
  972. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  973. package/dist/cssm/components/SelectTypography/SelectTypography.js +1 -1
  974. package/dist/cssm/components/SelectTypography/SelectTypography.js.map +1 -1
  975. package/dist/cssm/components/SelectTypography/SelectTypography.module.css +1 -1
  976. package/dist/cssm/components/SimpleCell/SimpleCell.js +13 -7
  977. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  978. package/dist/cssm/components/SimpleCell/SimpleCell.module.css +1 -1
  979. package/dist/cssm/components/Slider/Slider.module.css +1 -1
  980. package/dist/cssm/components/Snackbar/Snackbar.js +8 -8
  981. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  982. package/dist/cssm/components/Spinner/Spinner.js +1 -1
  983. package/dist/cssm/components/Spinner/Spinner.js.map +1 -1
  984. package/dist/cssm/components/SplitCol/SplitCol.d.ts +0 -6
  985. package/dist/cssm/components/SplitCol/SplitCol.js +10 -14
  986. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  987. package/dist/cssm/components/SplitCol/SplitCol.module.css +1 -1
  988. package/dist/cssm/components/SplitCol/SplitColContext.d.ts +7 -0
  989. package/dist/cssm/components/SplitCol/SplitColContext.js +9 -0
  990. package/dist/cssm/components/SplitCol/SplitColContext.js.map +1 -0
  991. package/dist/cssm/components/SplitLayout/SplitLayout.js +1 -1
  992. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  993. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +10 -5
  994. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  995. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.module.css +1 -1
  996. package/dist/cssm/components/Switch/Switch.js +12 -7
  997. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  998. package/dist/cssm/components/Switch/Switch.module.css +1 -1
  999. package/dist/cssm/components/TabbarItem/TabbarItem.js +10 -1
  1000. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  1001. package/dist/cssm/components/Tabs/Tabs.js +3 -3
  1002. package/dist/cssm/components/Tabs/Tabs.js.map +1 -1
  1003. package/dist/cssm/components/Tabs/Tabs.module.css +1 -1
  1004. package/dist/cssm/components/TabsItem/TabsItem.js +10 -5
  1005. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  1006. package/dist/cssm/components/TabsItem/TabsItem.module.css +1 -1
  1007. package/dist/cssm/components/Tappable/Tappable.d.ts +1 -1
  1008. package/dist/cssm/components/Tappable/Tappable.js +14 -14
  1009. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  1010. package/dist/cssm/components/Tappable/Tappable.module.css +1 -1
  1011. package/dist/cssm/components/TextTooltip/TextTooltip.js +1 -1
  1012. package/dist/cssm/components/TextTooltip/TextTooltip.js.map +1 -1
  1013. package/dist/cssm/components/Textarea/Textarea.d.ts +1 -1
  1014. package/dist/cssm/components/Textarea/Textarea.js +10 -5
  1015. package/dist/cssm/components/Textarea/Textarea.js.map +1 -1
  1016. package/dist/cssm/components/Textarea/Textarea.module.css +1 -1
  1017. package/dist/cssm/components/Tooltip/Tooltip.d.ts +3 -3
  1018. package/dist/cssm/components/Tooltip/Tooltip.js +126 -156
  1019. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  1020. package/dist/cssm/components/Tooltip/Tooltip.module.css +1 -1
  1021. package/dist/cssm/components/Touch/Touch.js +3 -3
  1022. package/dist/cssm/components/Touch/Touch.js.map +1 -1
  1023. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  1024. package/dist/cssm/components/Typography/Caption/Caption.module.css +1 -1
  1025. package/dist/cssm/components/Typography/Footnote/Footnote.js.map +1 -1
  1026. package/dist/cssm/components/Typography/Footnote/Footnote.module.css +1 -1
  1027. package/dist/cssm/components/Typography/Headline/Headline.js +9 -4
  1028. package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
  1029. package/dist/cssm/components/Typography/Headline/Headline.module.css +1 -1
  1030. package/dist/cssm/components/Typography/Paragraph/Paragraph.module.css +1 -1
  1031. package/dist/cssm/components/Typography/Subhead/Subhead.js +8 -3
  1032. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  1033. package/dist/cssm/components/Typography/Subhead/Subhead.module.css +1 -1
  1034. package/dist/cssm/components/Typography/Text/Text.js +9 -4
  1035. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  1036. package/dist/cssm/components/Typography/Text/Text.module.css +1 -1
  1037. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  1038. package/dist/cssm/components/Typography/Title/Title.module.css +1 -1
  1039. package/dist/cssm/components/UsersStack/UsersStack.js +2 -2
  1040. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  1041. package/dist/cssm/components/View/View.js +12 -12
  1042. package/dist/cssm/components/View/View.js.map +1 -1
  1043. package/dist/cssm/components/View/View.module.css +1 -1
  1044. package/dist/cssm/components/View/ViewInfinite.d.ts +3 -3
  1045. package/dist/cssm/components/View/ViewInfinite.js +9 -9
  1046. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  1047. package/dist/cssm/components/WriteBar/WriteBar.js +4 -4
  1048. package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
  1049. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +12 -10
  1050. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1051. package/dist/cssm/helpers/getPlatformClassName.js.map +1 -1
  1052. package/dist/cssm/hoc/withPlatform.js.map +1 -1
  1053. package/dist/cssm/hooks/useAdaptivityConditionalRender/helpers.d.ts +2 -2
  1054. package/dist/cssm/hooks/useAdaptivityConditionalRender/helpers.js +1 -1
  1055. package/dist/cssm/hooks/useAdaptivityConditionalRender/helpers.js.map +1 -1
  1056. package/dist/cssm/hooks/useAdaptivityConditionalRender/useAdaptivityConditionalRender.js +2 -2
  1057. package/dist/cssm/hooks/useAdaptivityConditionalRender/useAdaptivityConditionalRender.js.map +1 -1
  1058. package/dist/cssm/hooks/useAdaptivityWithJSMediaQueries.js +3 -3
  1059. package/dist/cssm/hooks/useAdaptivityWithJSMediaQueries.js.map +1 -1
  1060. package/dist/cssm/hooks/useAutoDetectAppearance.js +1 -1
  1061. package/dist/cssm/hooks/useAutoDetectAppearance.js.map +1 -1
  1062. package/dist/cssm/hooks/useCalendar.js +1 -1
  1063. package/dist/cssm/hooks/useCalendar.js.map +1 -1
  1064. package/dist/cssm/hooks/useChipsSelect.d.ts +1 -1
  1065. package/dist/cssm/hooks/useChipsSelect.js.map +1 -1
  1066. package/dist/cssm/hooks/useDateInput.js +1 -1
  1067. package/dist/cssm/hooks/useDateInput.js.map +1 -1
  1068. package/dist/cssm/hooks/useFocusVisible.js +1 -1
  1069. package/dist/cssm/hooks/useFocusVisible.js.map +1 -1
  1070. package/dist/cssm/hooks/useMediaQueries.js.map +1 -1
  1071. package/dist/cssm/hooks/usePatchChildrenRef.js +1 -1
  1072. package/dist/cssm/hooks/usePatchChildrenRef.js.map +1 -1
  1073. package/dist/cssm/hooks/useTimeout.js +1 -1
  1074. package/dist/cssm/hooks/useTimeout.js.map +1 -1
  1075. package/dist/cssm/hooks/useTodayDate.js.map +1 -1
  1076. package/dist/cssm/hooks/useWaitTransitionFinish.js +1 -1
  1077. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  1078. package/dist/cssm/index.d.ts +37 -30
  1079. package/dist/cssm/index.js +24 -18
  1080. package/dist/cssm/index.js.map +1 -1
  1081. package/dist/cssm/lib/SSR.js +3 -3
  1082. package/dist/cssm/lib/SSR.js.map +1 -1
  1083. package/dist/cssm/lib/adaptivity/constants.d.ts +7 -0
  1084. package/dist/cssm/lib/adaptivity/constants.js +3 -0
  1085. package/dist/cssm/lib/adaptivity/constants.js.map +1 -1
  1086. package/dist/cssm/lib/adaptivity/functions.d.ts +9 -1
  1087. package/dist/cssm/lib/adaptivity/functions.js +43 -1
  1088. package/dist/cssm/lib/adaptivity/functions.js.map +1 -1
  1089. package/dist/cssm/lib/adaptivity/types.d.ts +2 -1
  1090. package/dist/cssm/lib/adaptivity/types.js.map +1 -1
  1091. package/dist/cssm/lib/calendar.js +1 -1
  1092. package/dist/cssm/lib/calendar.js.map +1 -1
  1093. package/dist/cssm/lib/floating/adapters.d.ts +2 -0
  1094. package/dist/cssm/lib/floating/adapters.js +56 -0
  1095. package/dist/cssm/lib/floating/adapters.js.map +1 -0
  1096. package/dist/cssm/lib/floating/functions.d.ts +10 -0
  1097. package/dist/cssm/lib/floating/functions.js +28 -0
  1098. package/dist/cssm/lib/floating/functions.js.map +1 -0
  1099. package/dist/cssm/lib/floating/index.d.ts +4 -0
  1100. package/dist/cssm/lib/floating/index.js +4 -0
  1101. package/dist/cssm/lib/floating/index.js.map +1 -0
  1102. package/dist/cssm/lib/floating/types.d.ts +4 -0
  1103. package/dist/cssm/lib/floating/types.js +2 -0
  1104. package/dist/cssm/lib/floating/types.js.map +1 -0
  1105. package/dist/cssm/lib/platform.js +1 -1
  1106. package/dist/cssm/lib/platform.js.map +1 -1
  1107. package/dist/cssm/lib/select.js.map +1 -1
  1108. package/dist/cssm/lib/useIsomorphicLayoutEffect.d.ts +1 -1
  1109. package/dist/cssm/lib/warnOnce.d.ts +7 -0
  1110. package/dist/cssm/lib/warnOnce.js +12 -0
  1111. package/dist/cssm/lib/warnOnce.js.map +1 -1
  1112. package/dist/cssm/shared/breakpoints.d.ts +44 -0
  1113. package/dist/cssm/shared/breakpoints.js +79 -13
  1114. package/dist/cssm/shared/breakpoints.js.map +1 -1
  1115. package/dist/cssm/styles/adaptivity.module.css +1 -1
  1116. package/dist/cssm/styles/common.css +1 -1
  1117. package/dist/cssm/styles/themes.css +1 -1
  1118. package/dist/cssm/types.d.ts +9 -1
  1119. package/dist/cssm/types.js.map +1 -1
  1120. package/dist/helpers/getPlatformClassName.js.map +1 -1
  1121. package/dist/hoc/withPlatform.js.map +1 -1
  1122. package/dist/hooks/useAdaptivityConditionalRender/helpers.d.ts +2 -2
  1123. package/dist/hooks/useAdaptivityConditionalRender/helpers.js +1 -1
  1124. package/dist/hooks/useAdaptivityConditionalRender/helpers.js.map +1 -1
  1125. package/dist/hooks/useAdaptivityConditionalRender/useAdaptivityConditionalRender.js +2 -2
  1126. package/dist/hooks/useAdaptivityConditionalRender/useAdaptivityConditionalRender.js.map +1 -1
  1127. package/dist/hooks/useAdaptivityWithJSMediaQueries.js +3 -3
  1128. package/dist/hooks/useAdaptivityWithJSMediaQueries.js.map +1 -1
  1129. package/dist/hooks/useAutoDetectAppearance.js +1 -1
  1130. package/dist/hooks/useAutoDetectAppearance.js.map +1 -1
  1131. package/dist/hooks/useCalendar.js +1 -1
  1132. package/dist/hooks/useCalendar.js.map +1 -1
  1133. package/dist/hooks/useChipsSelect.d.ts +1 -1
  1134. package/dist/hooks/useChipsSelect.js.map +1 -1
  1135. package/dist/hooks/useDateInput.js +1 -1
  1136. package/dist/hooks/useDateInput.js.map +1 -1
  1137. package/dist/hooks/useFocusVisible.js +1 -1
  1138. package/dist/hooks/useFocusVisible.js.map +1 -1
  1139. package/dist/hooks/useMediaQueries.js.map +1 -1
  1140. package/dist/hooks/usePatchChildrenRef.js +1 -1
  1141. package/dist/hooks/usePatchChildrenRef.js.map +1 -1
  1142. package/dist/hooks/useTimeout.js +1 -1
  1143. package/dist/hooks/useTimeout.js.map +1 -1
  1144. package/dist/hooks/useTodayDate.js.map +1 -1
  1145. package/dist/hooks/useWaitTransitionFinish.js +1 -1
  1146. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  1147. package/dist/index.d.ts +37 -30
  1148. package/dist/index.js +22 -16
  1149. package/dist/index.js.map +1 -1
  1150. package/dist/lib/SSR.js +3 -3
  1151. package/dist/lib/SSR.js.map +1 -1
  1152. package/dist/lib/adaptivity/constants.d.ts +7 -0
  1153. package/dist/lib/adaptivity/constants.js +3 -0
  1154. package/dist/lib/adaptivity/constants.js.map +1 -1
  1155. package/dist/lib/adaptivity/functions.d.ts +9 -1
  1156. package/dist/lib/adaptivity/functions.js +43 -1
  1157. package/dist/lib/adaptivity/functions.js.map +1 -1
  1158. package/dist/lib/adaptivity/types.d.ts +2 -1
  1159. package/dist/lib/adaptivity/types.js.map +1 -1
  1160. package/dist/lib/calendar.js +1 -1
  1161. package/dist/lib/calendar.js.map +1 -1
  1162. package/dist/lib/floating/adapters.d.ts +2 -0
  1163. package/dist/lib/floating/adapters.js +56 -0
  1164. package/dist/lib/floating/adapters.js.map +1 -0
  1165. package/dist/lib/floating/functions.d.ts +10 -0
  1166. package/dist/lib/floating/functions.js +28 -0
  1167. package/dist/lib/floating/functions.js.map +1 -0
  1168. package/dist/lib/floating/index.d.ts +4 -0
  1169. package/dist/lib/floating/index.js +4 -0
  1170. package/dist/lib/floating/index.js.map +1 -0
  1171. package/dist/lib/floating/types.d.ts +4 -0
  1172. package/dist/lib/floating/types.js +2 -0
  1173. package/dist/lib/floating/types.js.map +1 -0
  1174. package/dist/lib/platform.js +1 -1
  1175. package/dist/lib/platform.js.map +1 -1
  1176. package/dist/lib/select.js.map +1 -1
  1177. package/dist/lib/useIsomorphicLayoutEffect.d.ts +1 -1
  1178. package/dist/lib/warnOnce.d.ts +7 -0
  1179. package/dist/lib/warnOnce.js +12 -0
  1180. package/dist/lib/warnOnce.js.map +1 -1
  1181. package/dist/shared/breakpoints.d.ts +44 -0
  1182. package/dist/shared/breakpoints.js +79 -13
  1183. package/dist/shared/breakpoints.js.map +1 -1
  1184. package/dist/stable.js.tmp +69 -21
  1185. package/dist/types.d.ts +9 -1
  1186. package/dist/types.js.map +1 -1
  1187. package/dist/vkui.css +143 -3
  1188. package/dist/vkui.css.map +1 -1
  1189. package/dist/vkui.js.tmp +62039 -0
  1190. package/package.json +4 -5
  1191. package/dist/cjs/helpers/getHoverClassName.d.ts +0 -2
  1192. package/dist/cjs/helpers/getHoverClassName.js +0 -22
  1193. package/dist/cjs/helpers/getHoverClassName.js.map +0 -1
  1194. package/dist/cjs/helpers/getPointerClassName.d.ts +0 -2
  1195. package/dist/cjs/helpers/getPointerClassName.js +0 -22
  1196. package/dist/cjs/helpers/getPointerClassName.js.map +0 -1
  1197. package/dist/cjs/helpers/getSizeXClassName.d.ts +0 -5
  1198. package/dist/cjs/helpers/getSizeXClassName.js +0 -18
  1199. package/dist/cjs/helpers/getSizeXClassName.js.map +0 -1
  1200. package/dist/cjs/helpers/getSizeYClassName.d.ts +0 -5
  1201. package/dist/cjs/helpers/getSizeYClassName.js +0 -18
  1202. package/dist/cjs/helpers/getSizeYClassName.js.map +0 -1
  1203. package/dist/cjs/helpers/getViewHeightClassName.d.ts +0 -3
  1204. package/dist/cjs/helpers/getViewHeightClassName.js +0 -31
  1205. package/dist/cjs/helpers/getViewHeightClassName.js.map +0 -1
  1206. package/dist/cjs/helpers/getViewWidthClassName.d.ts +0 -3
  1207. package/dist/cjs/helpers/getViewWidthClassName.js +0 -52
  1208. package/dist/cjs/helpers/getViewWidthClassName.js.map +0 -1
  1209. package/dist/cssm/helpers/getHoverClassName.d.ts +0 -2
  1210. package/dist/cssm/helpers/getHoverClassName.js +0 -16
  1211. package/dist/cssm/helpers/getHoverClassName.js.map +0 -1
  1212. package/dist/cssm/helpers/getPointerClassName.d.ts +0 -2
  1213. package/dist/cssm/helpers/getPointerClassName.js +0 -16
  1214. package/dist/cssm/helpers/getPointerClassName.js.map +0 -1
  1215. package/dist/cssm/helpers/getSizeXClassName.d.ts +0 -5
  1216. package/dist/cssm/helpers/getSizeXClassName.js +0 -12
  1217. package/dist/cssm/helpers/getSizeXClassName.js.map +0 -1
  1218. package/dist/cssm/helpers/getSizeYClassName.d.ts +0 -5
  1219. package/dist/cssm/helpers/getSizeYClassName.js +0 -12
  1220. package/dist/cssm/helpers/getSizeYClassName.js.map +0 -1
  1221. package/dist/cssm/helpers/getViewHeightClassName.d.ts +0 -3
  1222. package/dist/cssm/helpers/getViewHeightClassName.js +0 -25
  1223. package/dist/cssm/helpers/getViewHeightClassName.js.map +0 -1
  1224. package/dist/cssm/helpers/getViewWidthClassName.d.ts +0 -3
  1225. package/dist/cssm/helpers/getViewWidthClassName.js +0 -46
  1226. package/dist/cssm/helpers/getViewWidthClassName.js.map +0 -1
  1227. package/dist/cssm/styles/components.css +0 -3
  1228. package/dist/helpers/getHoverClassName.d.ts +0 -2
  1229. package/dist/helpers/getHoverClassName.js +0 -16
  1230. package/dist/helpers/getHoverClassName.js.map +0 -1
  1231. package/dist/helpers/getPointerClassName.d.ts +0 -2
  1232. package/dist/helpers/getPointerClassName.js +0 -16
  1233. package/dist/helpers/getPointerClassName.js.map +0 -1
  1234. package/dist/helpers/getSizeXClassName.d.ts +0 -5
  1235. package/dist/helpers/getSizeXClassName.js +0 -12
  1236. package/dist/helpers/getSizeXClassName.js.map +0 -1
  1237. package/dist/helpers/getSizeYClassName.d.ts +0 -5
  1238. package/dist/helpers/getSizeYClassName.js +0 -12
  1239. package/dist/helpers/getSizeYClassName.js.map +0 -1
  1240. package/dist/helpers/getViewHeightClassName.d.ts +0 -3
  1241. package/dist/helpers/getViewHeightClassName.js +0 -25
  1242. package/dist/helpers/getViewHeightClassName.js.map +0 -1
  1243. package/dist/helpers/getViewWidthClassName.d.ts +0 -3
  1244. package/dist/helpers/getViewWidthClassName.js +0 -46
  1245. package/dist/helpers/getViewWidthClassName.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"CustomSelect.js","names":["findIndexAfter","options","startIndex","length","findIndex","option","i","disabled","findIndexBefore","endIndex","result","warn","warnOnce","checkOptionsValueType","Set","map","item","value","size","defaultRenderOptionFn","props","handleOptionDown","e","preventDefault","findSelectedIndex","Number","filter","inputValue","filterFn","defaultOptions","CustomSelect","React","useState","opened","setOpened","before","name","className","getRef","getRootRef","popupDirection","style","onChange","children","onInputChangeProp","onInputChange","renderDropdown","onOpen","onClose","fetching","forceDropdownPortal","selectType","autoHideScrollbar","autoHideScrollbarDelay","searchable","renderOption","renderOptionProp","optionsProp","emptyText","defaultFilterFn","icon","dropdownOffsetDistance","fixDropdownWidth","restProps","process","env","NODE_ENV","containerRef","useRef","scrollBoxRef","selectElRef","focusedOptionIndex","setFocusedOptionIndex","undefined","isControlledOutside","setIsControlledOutside","setInputValue","defaultValue","nativeSelectValue","setNativeSelectValue","keyboardInput","setKeyboardInput","popperPlacement","setPopperPlacement","setOptions","selectedOptionIndex","setSelectedOptionIndex","useEffect","useIsomorphicLayoutEffect","some","event","Event","bubbles","current","dispatchEvent","selected","useMemo","openedClassNames","classNames","includes","resetKeyboardInput","useCallback","scrollToElement","index","center","dropdown","dropdownHeight","offsetHeight","scrollTop","itemTop","offsetTop","itemHeight","isValidIndex","focusOptionByIndex","scrollTo","areOptionsShown","setScrollBoxRef","ref","onKeyboardInput","key","fullInput","optionIndex","getTitleFromChildren","label","toLowerCase","close","selectFocused","open","onBlur","resetFocusedOption","onFocus","onClick","handleKeyUp","debounce","focusOption","type","nextIndex","beforeIndex","updateOptionsAndSelectedOptionIndex","onLabelClick","contains","target","onNativeSelectChange","newSelectedOptionIndex","currentTarget","onInputKeyDown","handleKeyDownSelect","handleOptionClick","Array","prototype","indexOf","call","parentNode","handleOptionHover","hovered","onMouseDown","onMouseOver","resolvedContent","defaultDropdownContent","multiRef","getFormFieldModeFromSelectType"],"sources":["../../../../src/components/CustomSelect/CustomSelect.tsx"],"sourcesContent":["import * as React from 'react';\nimport { SelectMimicry } from '../SelectMimicry/SelectMimicry';\nimport { debounce, multiRef, getTitleFromChildren } from '../../lib/utils';\nimport { classNames } from '@vkontakte/vkjs';\nimport { NativeSelectProps } from '../NativeSelect/NativeSelect';\nimport {\n CustomSelectOption,\n CustomSelectOptionProps,\n} from '../CustomSelectOption/CustomSelectOption';\nimport { FormFieldProps } from '../FormField/FormField';\nimport { Input } from '../Input/Input';\nimport { DropdownIcon } from '../DropdownIcon/DropdownIcon';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { defaultFilterFn, getFormFieldModeFromSelectType } from '../../lib/select';\nimport { Placement } from '../Popper/Popper';\nimport { CustomSelectDropdown } from '../CustomSelectDropdown/CustomSelectDropdown';\nimport { TrackerOptionsProps } from '../CustomScrollView/useTrackerVisibility';\nimport { SelectType } from '../Select/Select';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport styles from './CustomSelect.module.css';\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 = (options: CustomSelectOptionInterface[]) => {\n if (new Set(options.map((item) => typeof item.value)).size > 1) {\n warn(\n 'Некоторые значения ваших опций имеют разные типы. onChange всегда возвращает строковый тип.',\n 'error',\n );\n }\n};\n\nfunction defaultRenderOptionFn({ option, ...props }: CustomSelectOptionProps): React.ReactNode {\n return <CustomSelectOption {...props} />;\n}\n\nconst handleOptionDown: MouseEventHandler = (e: React.MouseEvent<HTMLElement>) => {\n e.preventDefault();\n};\n\nfunction findSelectedIndex(options: CustomSelectOptionInterface[], value: SelectValue) {\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 = (\n options: SelectProps['options'],\n inputValue: string,\n filterFn: SelectProps['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 SelectProps extends NativeSelectProps, FormFieldProps, TrackerOptionsProps {\n /**\n * Если `true`, то при клике на селект в нём появится текстовое поле для поиска по `options`. По умолчанию поиск\n * производится по `option.label`.\n */\n searchable?: boolean;\n /**\n * Текст, который будет отображен, если приходит пустой `options`.\n */\n emptyText?: string;\n /**\n * > ⚠️ В v6 из возвращаемых типов будет удалён `CustomSelectOptionInterface[]`. Для кастомной фильтрации используйте\n * > `filterFn`.\n */\n onInputChange?: (\n e: React.ChangeEvent,\n options: CustomSelectOptionInterface[],\n ) => void | CustomSelectOptionInterface[];\n options: CustomSelectOptionInterface[];\n /**\n * Функция для кастомной фильтрации. По умолчанию поиск производится по `option.label`.\n */\n filterFn?:\n | false\n | ((\n value: string,\n option: CustomSelectOptionInterface,\n getOptionLabel?: (option: Partial<CustomSelectOptionInterface>) => string,\n ) => boolean);\n popupDirection?: 'top' | 'bottom';\n /**\n * Рендер-проп для кастомного рендера опции.\n * В объекте аргумента приходят [свойства опции](https://vkcom.github.io/VKUI/#/CustomSelectOption?id=props)\n */\n renderOption?: (props: CustomSelectOptionProps) => 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 icon?: React.ReactNode;\n dropdownOffsetDistance?: number;\n fixDropdownWidth?: boolean;\n forceDropdownPortal?: boolean;\n selectType?: SelectType;\n}\n\ntype MouseEventHandler = (event: React.MouseEvent<HTMLElement>) => void;\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelect\n */\nexport function CustomSelect(props: SelectProps) {\n const [opened, setOpened] = React.useState(false);\n const {\n before,\n name,\n className,\n getRef,\n getRootRef,\n popupDirection,\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,\n emptyText = 'Ничего не найдено',\n filterFn = defaultFilterFn,\n icon = <DropdownIcon opened={opened} />,\n dropdownOffsetDistance = 0,\n fixDropdownWidth = true,\n ...restProps\n } = props;\n\n if (process.env.NODE_ENV === 'development') {\n checkOptionsValueType(optionsProp);\n }\n\n const containerRef = React.useRef<HTMLLabelElement>(null);\n const scrollBoxRef = React.useRef<HTMLDivElement | null>(null);\n const selectElRef = React.useRef<HTMLSelectElement>(null);\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 ?? props.defaultValue,\n );\n const [keyboardInput, setKeyboardInput] = React.useState('');\n const [popperPlacement, setPopperPlacement] = React.useState<Placement | undefined>(undefined);\n const [options, setOptions] = React.useState(optionsProp);\n const [selectedOptionIndex, setSelectedOptionIndex] = React.useState<number | undefined>(\n findSelectedIndex(optionsProp, props.value ?? props.defaultValue),\n );\n\n React.useEffect(() => {\n setIsControlledOutside(props.value !== undefined);\n setNativeSelectValue((nativeSelectValue) => props.value ?? nativeSelectValue);\n }, [props.value]);\n\n useIsomorphicLayoutEffect(() => {\n if (options.some(({ value }) => nativeSelectValue === value)) {\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 classNames(\n opened &&\n dropdownOffsetDistance === 0 &&\n (popperPlacement?.includes('top')\n ? styles['CustomSelect--pop-up']\n : styles['CustomSelect--pop-down']),\n ),\n [dropdownOffsetDistance, opened, popperPlacement],\n );\n\n const resetKeyboardInput = React.useCallback(() => {\n setKeyboardInput('');\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 isValidIndex = React.useCallback(\n (index: number) => {\n return index >= 0 && index < (options.length ?? 0);\n },\n [options.length],\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 // Это оптимизация, прежде всего, под `onMouseOver`\n setFocusedOptionIndex((focusedOptionIndex) =>\n focusedOptionIndex !== index ? index : focusedOptionIndex,\n );\n },\n [options, scrollToElement],\n );\n\n const areOptionsShown = React.useCallback(() => {\n return scrollBoxRef.current !== null;\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 onKeyboardInput = React.useCallback(\n (key: string) => {\n const fullInput = keyboardInput + key;\n\n const optionIndex = options.findIndex((option) => {\n return getTitleFromChildren(option.label).toLowerCase().includes(fullInput);\n });\n\n if (optionIndex !== undefined && optionIndex > -1) {\n focusOptionByIndex(optionIndex);\n }\n\n setKeyboardInput(fullInput);\n },\n [focusOptionByIndex, keyboardInput, options],\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 setFocusedOptionIndex(-1);\n onClose?.();\n }, [onClose, resetKeyboardInput]);\n\n const selectFocused = React.useCallback(() => {\n if (focusedOptionIndex !== undefined && isValidIndex(focusedOptionIndex)) {\n const item = options[focusedOptionIndex];\n\n setNativeSelectValue(item?.value);\n close();\n }\n }, [close, focusedOptionIndex, isValidIndex, options]);\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('blur');\n selectElRef.current?.dispatchEvent(event);\n }, [close]);\n\n const resetFocusedOption = React.useCallback(() => {\n setFocusedOptionIndex(-1);\n }, []);\n\n const onFocus = React.useCallback(() => {\n const event = new Event('focus');\n selectElRef.current?.dispatchEvent(event);\n }, []);\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 ?? props.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));\n },\n [\n filterFn,\n inputValue,\n nativeSelectValue,\n optionsProp,\n props.defaultValue,\n props.value,\n searchable,\n ],\n );\n\n /**\n * Нужен для правильного поведения обработчика onClick на select. Фильтрует клики, которые были сделаны по\n * выпадающему списку.\n */\n const onLabelClick = React.useCallback((e: React.MouseEvent<HTMLLabelElement>) => {\n if (scrollBoxRef.current?.contains(e.target as Node)) {\n e.preventDefault();\n }\n }, []);\n\n const onNativeSelectChange: React.ChangeEventHandler<HTMLSelectElement> = (e) => {\n const newSelectedOptionIndex = findSelectedIndex(options, e.currentTarget.value);\n\n if (selectedOptionIndex !== newSelectedOptionIndex) {\n if (!isControlledOutside) {\n setSelectedOptionIndex(newSelectedOptionIndex);\n }\n onChange?.(e);\n }\n };\n\n const onInputKeyDown: React.KeyboardEventHandler<HTMLInputElement> = React.useCallback(\n (event) => {\n ['ArrowUp', 'ArrowDown', 'Escape', 'Enter'].includes(event.key) &&\n areOptionsShown() &&\n event.preventDefault();\n\n switch (event.key) {\n case 'ArrowUp':\n areOptionsShown() && focusOption('prev');\n break;\n case 'ArrowDown':\n areOptionsShown() && focusOption('next');\n break;\n case 'Escape':\n close();\n break;\n case 'Enter':\n areOptionsShown() && selectFocused();\n break;\n }\n },\n [areOptionsShown, close, focusOption, selectFocused],\n );\n\n const onInputChange: React.ChangeEventHandler<HTMLInputElement> = React.useCallback(\n (e) => {\n // TODO v6 удалить `onInputChangeProp`.\n if (onInputChangeProp) {\n const options = onInputChangeProp(e, optionsProp);\n if (options) {\n if (process.env.NODE_ENV === 'development') {\n warn(\n 'Этот метод фильтрации устарел. Возвращаемое значение onInputChange будет ' +\n 'проигнорировано в v6.0.0. Для фильтрации обновляйте props.options самостоятельно или используйте свойство filterFn.',\n );\n }\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, nativeSelectValue));\n }\n } else {\n const options = filter(optionsProp, e.target.value, filterFn);\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, nativeSelectValue));\n }\n setInputValue(e.target.value);\n },\n [filterFn, nativeSelectValue, onInputChangeProp, optionsProp],\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 'Enter':\n case 'Spacebar':\n case ' ':\n if (opened) {\n areOptionsShown() && selectFocused();\n } else {\n open();\n }\n break;\n }\n },\n [areOptionsShown, close, focusOption, onKeyboardInput, open, opened, selectFocused],\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 selectFocused();\n }\n },\n [options, selectFocused],\n );\n\n const handleOptionHover = React.useCallback(\n (e: React.MouseEvent<HTMLElement>) => {\n focusOptionByIndex(\n Array.prototype.indexOf.call(e.currentTarget.parentNode?.children, e.currentTarget),\n false,\n );\n },\n [focusOptionByIndex],\n );\n\n const renderOption = React.useCallback(\n (option: CustomSelectOptionInterface, 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 // Используем `onMouseOver` вместо `onMouseEnter`.\n // При параметре `searchable`, обновляется \"ребёнок\", из-за чего `onMouseEnter` не срабатывает в следующих кейсах:\n // 1. До загрузки выпадающего списка, курсор мышки находится над произвольным элементом этого списка.\n // > Лечение: только увод курсора мыши и возвращении его обратно вызывает событие `onMouseEnter` на этот элемент.\n // 2. Если это тач-устройство.\n // > Лечение: нужно нажать на какой-нибудь произвольный элемент списка, после чего `onMouseEnter` будет работать на соседние элементы,\n // но не на тот, на который нажали в первый раз.\n // Более подробно по ссылке https://github.com/facebook/react/issues/13956#issuecomment-1082055744\n onMouseOver: handleOptionHover,\n })}\n </React.Fragment>\n );\n },\n [\n focusedOptionIndex,\n handleOptionClick,\n handleOptionHover,\n renderOptionProp,\n selectedOptionIndex,\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 return (\n <label\n className={classNames(styles['CustomSelect'], className)}\n style={style}\n ref={multiRef(containerRef, getRootRef)}\n onClick={onLabelClick}\n >\n {opened && searchable ? (\n <Input\n {...restProps}\n autoFocus\n onBlur={onBlur}\n className={openedClassNames}\n value={inputValue}\n onKeyDown={onInputKeyDown}\n onChange={onInputChange}\n // TODO Ожидается, что клик поймает нативный select, но его перехватывает Input. К сожалению, это приводит к конфликтам типизации.\n // TODO Нужно перестать пытаться превратить CustomSelect в select. Тогда эта проблема уйдёт.\n // @ts-expect-error: TS2322 MouseEventHandler<HTMLSelectElement> !== MouseEventHandler<HTMLInputElement>\n onClick={props.onClick}\n before={before}\n after={icon}\n mode={getFormFieldModeFromSelectType(selectType)}\n />\n ) : (\n <SelectMimicry\n {...restProps}\n aria-hidden\n onClick={onClick}\n onKeyDown={handleKeyDownSelect}\n onKeyUp={handleKeyUp}\n onFocus={onFocus}\n onBlur={onBlur}\n className={openedClassNames}\n before={before}\n after={icon}\n selectType={selectType}\n >\n {selected?.label}\n </SelectMimicry>\n )}\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 >\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 sameWidth={fixDropdownWidth}\n forcePortal={forceDropdownPortal}\n autoHideScrollbar={autoHideScrollbar}\n autoHideScrollbarDelay={autoHideScrollbarDelay}\n observableRefs={scrollBoxRef}\n >\n {resolvedContent}\n </CustomSelectDropdown>\n )}\n </label>\n );\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"CustomSelect.js","names":["findIndexAfter","options","startIndex","length","findIndex","option","i","disabled","findIndexBefore","endIndex","result","warn","warnOnce","checkOptionsValueType","Set","map","item","value","size","defaultRenderOptionFn","props","handleOptionDown","e","preventDefault","findSelectedIndex","Number","filter","inputValue","filterFn","defaultOptions","CustomSelect","React","useState","opened","setOpened","before","name","className","getRef","getRootRef","popupDirection","style","onChange","children","onInputChangeProp","onInputChange","renderDropdown","onOpen","onClose","fetching","forceDropdownPortal","selectType","autoHideScrollbar","autoHideScrollbarDelay","searchable","renderOption","renderOptionProp","optionsProp","emptyText","defaultFilterFn","icon","dropdownOffsetDistance","fixDropdownWidth","restProps","process","env","NODE_ENV","containerRef","useRef","handleRootRef","useExternRef","scrollBoxRef","selectElRef","focusedOptionIndex","setFocusedOptionIndex","undefined","isControlledOutside","setIsControlledOutside","setInputValue","defaultValue","nativeSelectValue","setNativeSelectValue","keyboardInput","setKeyboardInput","popperPlacement","setPopperPlacement","setOptions","selectedOptionIndex","setSelectedOptionIndex","useEffect","useIsomorphicLayoutEffect","some","event","Event","bubbles","current","dispatchEvent","selected","useMemo","openedClassNames","classNames","includes","resetKeyboardInput","useCallback","scrollToElement","index","center","dropdown","dropdownHeight","offsetHeight","scrollTop","itemTop","offsetTop","itemHeight","isValidIndex","focusOptionByIndex","scrollTo","areOptionsShown","setScrollBoxRef","ref","onKeyboardInput","key","fullInput","optionIndex","getTitleFromChildren","label","toLowerCase","close","selectFocused","open","onBlur","resetFocusedOption","onFocus","onClick","handleKeyUp","debounce","focusOption","type","nextIndex","beforeIndex","updateOptionsAndSelectedOptionIndex","onLabelClick","contains","target","onNativeSelectChange","newSelectedOptionIndex","currentTarget","onInputKeyDown","handleKeyDownSelect","handleOptionClick","Array","prototype","indexOf","call","parentNode","handleOptionHover","hovered","onMouseDown","onMouseOver","resolvedContent","defaultDropdownContent","getFormFieldModeFromSelectType"],"sources":["../../../../src/components/CustomSelect/CustomSelect.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport type { PlacementWithAuto } from '../../lib/floating';\nimport { defaultFilterFn, getFormFieldModeFromSelectType } from '../../lib/select';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { debounce, getTitleFromChildren } 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 { Input } from '../Input/Input';\nimport { NativeSelectProps } from '../NativeSelect/NativeSelect';\nimport { SelectType } from '../Select/Select';\nimport { SelectMimicry } from '../SelectMimicry/SelectMimicry';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport styles from './CustomSelect.module.css';\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 = (options: CustomSelectOptionInterface[]) => {\n if (new Set(options.map((item) => typeof item.value)).size > 1) {\n warn(\n 'Некоторые значения ваших опций имеют разные типы. onChange всегда возвращает строковый тип.',\n 'error',\n );\n }\n};\n\nfunction defaultRenderOptionFn({ option, ...props }: CustomSelectOptionProps): React.ReactNode {\n return <CustomSelectOption {...props} />;\n}\n\nconst handleOptionDown: MouseEventHandler = (e: React.MouseEvent<HTMLElement>) => {\n e.preventDefault();\n};\n\nfunction findSelectedIndex(options: CustomSelectOptionInterface[], value: SelectValue) {\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 = (\n options: SelectProps['options'],\n inputValue: string,\n filterFn: SelectProps['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 SelectProps extends NativeSelectProps, FormFieldProps, TrackerOptionsProps {\n /**\n * Если `true`, то при клике на селект в нём появится текстовое поле для поиска по `options`. По умолчанию поиск\n * производится по `option.label`.\n */\n searchable?: boolean;\n /**\n * Текст, который будет отображен, если приходит пустой `options`.\n */\n emptyText?: string;\n /**\n * > ⚠️ В v6 из возвращаемых типов будет удалён `CustomSelectOptionInterface[]`. Для кастомной фильтрации используйте\n * > `filterFn`.\n */\n onInputChange?: (\n e: React.ChangeEvent,\n options: CustomSelectOptionInterface[],\n ) => void | CustomSelectOptionInterface[];\n options: CustomSelectOptionInterface[];\n /**\n * Функция для кастомной фильтрации. По умолчанию поиск производится по `option.label`.\n */\n filterFn?:\n | false\n | ((\n value: string,\n option: CustomSelectOptionInterface,\n getOptionLabel?: (option: Partial<CustomSelectOptionInterface>) => string,\n ) => boolean);\n popupDirection?: 'top' | 'bottom';\n /**\n * Рендер-проп для кастомного рендера опции.\n * В объекте аргумента приходят [свойства опции](https://vkcom.github.io/VKUI/#/CustomSelectOption?id=props)\n */\n renderOption?: (props: CustomSelectOptionProps) => 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 icon?: React.ReactNode;\n dropdownOffsetDistance?: number;\n fixDropdownWidth?: boolean;\n forceDropdownPortal?: boolean;\n selectType?: SelectType;\n}\n\ntype MouseEventHandler = (event: React.MouseEvent<HTMLElement>) => void;\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelect\n */\nexport function CustomSelect(props: SelectProps) {\n const [opened, setOpened] = React.useState(false);\n const {\n before,\n name,\n className,\n getRef,\n getRootRef,\n popupDirection,\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,\n emptyText = 'Ничего не найдено',\n filterFn = defaultFilterFn,\n icon = <DropdownIcon opened={opened} />,\n dropdownOffsetDistance = 0,\n fixDropdownWidth = true,\n ...restProps\n } = props;\n\n if (process.env.NODE_ENV === 'development') {\n checkOptionsValueType(optionsProp);\n }\n\n const containerRef = React.useRef<HTMLLabelElement>(null);\n const handleRootRef = useExternRef(containerRef, getRootRef);\n const scrollBoxRef = React.useRef<HTMLDivElement | null>(null);\n const selectElRef = React.useRef<HTMLSelectElement>(null);\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 ?? props.defaultValue,\n );\n const [keyboardInput, setKeyboardInput] = React.useState('');\n const [popperPlacement, setPopperPlacement] = React.useState<PlacementWithAuto | undefined>(\n undefined,\n );\n const [options, setOptions] = React.useState(optionsProp);\n const [selectedOptionIndex, setSelectedOptionIndex] = React.useState<number | undefined>(\n findSelectedIndex(optionsProp, props.value ?? props.defaultValue),\n );\n\n React.useEffect(() => {\n setIsControlledOutside(props.value !== undefined);\n setNativeSelectValue((nativeSelectValue) => props.value ?? nativeSelectValue);\n }, [props.value]);\n\n useIsomorphicLayoutEffect(() => {\n if (options.some(({ value }) => nativeSelectValue === value)) {\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 classNames(\n opened &&\n dropdownOffsetDistance === 0 &&\n (popperPlacement?.includes('top')\n ? styles['CustomSelect--pop-up']\n : styles['CustomSelect--pop-down']),\n ),\n [dropdownOffsetDistance, opened, popperPlacement],\n );\n\n const resetKeyboardInput = React.useCallback(() => {\n setKeyboardInput('');\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 isValidIndex = React.useCallback(\n (index: number) => {\n return index >= 0 && index < (options.length ?? 0);\n },\n [options.length],\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 // Это оптимизация, прежде всего, под `onMouseOver`\n setFocusedOptionIndex((focusedOptionIndex) =>\n focusedOptionIndex !== index ? index : focusedOptionIndex,\n );\n },\n [options, scrollToElement],\n );\n\n const areOptionsShown = React.useCallback(() => {\n return scrollBoxRef.current !== null;\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 onKeyboardInput = React.useCallback(\n (key: string) => {\n const fullInput = keyboardInput + key;\n\n const optionIndex = options.findIndex((option) => {\n return getTitleFromChildren(option.label).toLowerCase().includes(fullInput);\n });\n\n if (optionIndex !== undefined && optionIndex > -1) {\n focusOptionByIndex(optionIndex);\n }\n\n setKeyboardInput(fullInput);\n },\n [focusOptionByIndex, keyboardInput, options],\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 setFocusedOptionIndex(-1);\n onClose?.();\n }, [onClose, resetKeyboardInput]);\n\n const selectFocused = React.useCallback(() => {\n if (focusedOptionIndex !== undefined && isValidIndex(focusedOptionIndex)) {\n const item = options[focusedOptionIndex];\n\n setNativeSelectValue(item?.value);\n close();\n }\n }, [close, focusedOptionIndex, isValidIndex, options]);\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('blur');\n selectElRef.current?.dispatchEvent(event);\n }, [close]);\n\n const resetFocusedOption = React.useCallback(() => {\n setFocusedOptionIndex(-1);\n }, []);\n\n const onFocus = React.useCallback(() => {\n const event = new Event('focus');\n selectElRef.current?.dispatchEvent(event);\n }, []);\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 ?? props.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));\n },\n [\n filterFn,\n inputValue,\n nativeSelectValue,\n optionsProp,\n props.defaultValue,\n props.value,\n searchable,\n ],\n );\n\n /**\n * Нужен для правильного поведения обработчика onClick на select. Фильтрует клики, которые были сделаны по\n * выпадающему списку.\n */\n const onLabelClick = React.useCallback((e: React.MouseEvent<HTMLLabelElement>) => {\n if (scrollBoxRef.current?.contains(e.target as Node)) {\n e.preventDefault();\n }\n }, []);\n\n const onNativeSelectChange: React.ChangeEventHandler<HTMLSelectElement> = (e) => {\n const newSelectedOptionIndex = findSelectedIndex(options, e.currentTarget.value);\n\n if (selectedOptionIndex !== newSelectedOptionIndex) {\n if (!isControlledOutside) {\n setSelectedOptionIndex(newSelectedOptionIndex);\n }\n onChange?.(e);\n }\n };\n\n const onInputKeyDown: React.KeyboardEventHandler<HTMLInputElement> = React.useCallback(\n (event) => {\n ['ArrowUp', 'ArrowDown', 'Escape', 'Enter'].includes(event.key) &&\n areOptionsShown() &&\n event.preventDefault();\n\n switch (event.key) {\n case 'ArrowUp':\n areOptionsShown() && focusOption('prev');\n break;\n case 'ArrowDown':\n areOptionsShown() && focusOption('next');\n break;\n case 'Escape':\n close();\n break;\n case 'Enter':\n areOptionsShown() && selectFocused();\n break;\n }\n },\n [areOptionsShown, close, focusOption, selectFocused],\n );\n\n const onInputChange: React.ChangeEventHandler<HTMLInputElement> = React.useCallback(\n (e) => {\n // TODO v6 удалить `onInputChangeProp`.\n if (onInputChangeProp) {\n const options = onInputChangeProp(e, optionsProp);\n if (options) {\n if (process.env.NODE_ENV === 'development') {\n warn(\n 'Этот метод фильтрации устарел. Возвращаемое значение onInputChange будет ' +\n 'проигнорировано в v6.0.0. Для фильтрации обновляйте props.options самостоятельно или используйте свойство filterFn.',\n );\n }\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, nativeSelectValue));\n }\n } else {\n const options = filter(optionsProp, e.target.value, filterFn);\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, nativeSelectValue));\n }\n setInputValue(e.target.value);\n },\n [filterFn, nativeSelectValue, onInputChangeProp, optionsProp],\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 'Enter':\n case 'Spacebar':\n case ' ':\n if (opened) {\n areOptionsShown() && selectFocused();\n } else {\n open();\n }\n break;\n }\n },\n [areOptionsShown, close, focusOption, onKeyboardInput, open, opened, selectFocused],\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 selectFocused();\n }\n },\n [options, selectFocused],\n );\n\n const handleOptionHover = React.useCallback(\n (e: React.MouseEvent<HTMLElement>) => {\n focusOptionByIndex(\n Array.prototype.indexOf.call(e.currentTarget.parentNode?.children, e.currentTarget),\n false,\n );\n },\n [focusOptionByIndex],\n );\n\n const renderOption = React.useCallback(\n (option: CustomSelectOptionInterface, 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 // Используем `onMouseOver` вместо `onMouseEnter`.\n // При параметре `searchable`, обновляется \"ребёнок\", из-за чего `onMouseEnter` не срабатывает в следующих кейсах:\n // 1. До загрузки выпадающего списка, курсор мышки находится над произвольным элементом этого списка.\n // > Лечение: только увод курсора мыши и возвращении его обратно вызывает событие `onMouseEnter` на этот элемент.\n // 2. Если это тач-устройство.\n // > Лечение: нужно нажать на какой-нибудь произвольный элемент списка, после чего `onMouseEnter` будет работать на соседние элементы,\n // но не на тот, на который нажали в первый раз.\n // Более подробно по ссылке https://github.com/facebook/react/issues/13956#issuecomment-1082055744\n onMouseOver: handleOptionHover,\n })}\n </React.Fragment>\n );\n },\n [\n focusedOptionIndex,\n handleOptionClick,\n handleOptionHover,\n renderOptionProp,\n selectedOptionIndex,\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 return (\n <label\n className={classNames(styles['CustomSelect'], className)}\n style={style}\n ref={handleRootRef}\n onClick={onLabelClick}\n >\n {opened && searchable ? (\n <Input\n {...restProps}\n autoFocus\n onBlur={onBlur}\n className={openedClassNames}\n value={inputValue}\n onKeyDown={onInputKeyDown}\n onChange={onInputChange}\n // TODO Ожидается, что клик поймает нативный select, но его перехватывает Input. К сожалению, это приводит к конфликтам типизации.\n // TODO Нужно перестать пытаться превратить CustomSelect в select. Тогда эта проблема уйдёт.\n // @ts-expect-error: TS2322 MouseEventHandler<HTMLSelectElement> !== MouseEventHandler<HTMLInputElement>\n onClick={props.onClick}\n before={before}\n after={icon}\n mode={getFormFieldModeFromSelectType(selectType)}\n />\n ) : (\n <SelectMimicry\n {...restProps}\n aria-hidden\n onClick={onClick}\n onKeyDown={handleKeyDownSelect}\n onKeyUp={handleKeyUp}\n onFocus={onFocus}\n onBlur={onBlur}\n className={openedClassNames}\n before={before}\n after={icon}\n selectType={selectType}\n >\n {selected?.label}\n </SelectMimicry>\n )}\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 >\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 sameWidth={fixDropdownWidth}\n forcePortal={forceDropdownPortal}\n autoHideScrollbar={autoHideScrollbar}\n autoHideScrollbarDelay={autoHideScrollbarDelay}\n >\n {resolvedContent}\n </CustomSelectDropdown>\n )}\n </label>\n );\n}\n"],"mappings":"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"}
@@ -1,16 +1,15 @@
1
1
  import * as React from 'react';
2
- import { TrackerOptionsProps } from '../CustomScrollView/useTrackerVisibility';
3
- import { Placement } from '../Popper/Popper';
2
+ import type { Placement } from '../../lib/floating';
4
3
  import { HasRef } from '../../types';
4
+ import { TrackerOptionsProps } from '../CustomScrollView/useTrackerVisibility';
5
5
  export interface CustomSelectDropdownProps extends React.HTMLAttributes<HTMLElement>, HasRef<HTMLDivElement>, TrackerOptionsProps {
6
6
  targetRef: React.RefObject<HTMLElement>;
7
7
  placement?: Placement;
8
8
  scrollBoxRef?: React.Ref<HTMLDivElement>;
9
- observableRefs?: Array<React.RefObject<HTMLElement>> | React.RefObject<HTMLElement>;
10
9
  fetching?: boolean;
11
10
  offsetDistance?: number;
12
11
  sameWidth?: boolean;
13
12
  forcePortal?: boolean;
14
13
  onPlacementChange?: (placement?: Placement) => void;
15
14
  }
16
- export declare const CustomSelectDropdown: ({ children, targetRef, scrollBoxRef, placement, fetching, onPlacementChange: parentOnPlacementChange, offsetDistance, sameWidth, forcePortal, autoHideScrollbar, autoHideScrollbarDelay, observableRefs, className, ...restProps }: CustomSelectDropdownProps) => JSX.Element;
15
+ export declare const CustomSelectDropdown: ({ children, targetRef, scrollBoxRef, placement, fetching, onPlacementChange: parentOnPlacementChange, offsetDistance, sameWidth, forcePortal, autoHideScrollbar, autoHideScrollbarDelay, className, ...restProps }: CustomSelectDropdownProps) => JSX.Element;
@@ -7,93 +7,42 @@ Object.defineProperty(exports, "__esModule", {
7
7
  });
8
8
  exports.CustomSelectDropdown = void 0;
9
9
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
- var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/createForOfIteratorHelper"));
11
10
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
12
11
  var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
12
  var React = _interopRequireWildcard(require("react"));
14
- var _CustomScrollView = require("../CustomScrollView/CustomScrollView");
15
13
  var _vkjs = require("@vkontakte/vkjs");
14
+ var _CustomScrollView = require("../CustomScrollView/CustomScrollView");
16
15
  var _Popper = require("../Popper/Popper");
17
16
  var _Spinner = require("../Spinner/Spinner");
18
- var _useIsomorphicLayoutEffect = require("../../lib/useIsomorphicLayoutEffect");
19
- var _excluded = ["children", "targetRef", "scrollBoxRef", "placement", "fetching", "onPlacementChange", "offsetDistance", "sameWidth", "forcePortal", "autoHideScrollbar", "autoHideScrollbarDelay", "observableRefs", "className"];
17
+ var _excluded = ["children", "targetRef", "scrollBoxRef", "placement", "fetching", "onPlacementChange", "offsetDistance", "sameWidth", "forcePortal", "autoHideScrollbar", "autoHideScrollbarDelay", "className"];
20
18
  var calcIsTop = function calcIsTop(placement) {
21
19
  return placement === null || placement === void 0 ? void 0 : placement.includes('top');
22
20
  };
23
- function getObserverModifier(element) {
24
- return {
25
- name: 'customSelectChildrenChange',
26
- enabled: true,
27
- phase: 'main',
28
- fn: _vkjs.noop,
29
- effect: function effect(_ref) {
30
- var instance = _ref.instance;
31
- var observer = new MutationObserver(instance.forceUpdate);
32
- observer.observe(element, {
33
- childList: true,
34
- subtree: true
35
- });
36
- return function () {
37
- observer.disconnect();
38
- };
39
- }
40
- };
41
- }
42
- var CustomSelectDropdown = function CustomSelectDropdown(_ref2) {
43
- var children = _ref2.children,
44
- targetRef = _ref2.targetRef,
45
- scrollBoxRef = _ref2.scrollBoxRef,
46
- placement = _ref2.placement,
47
- fetching = _ref2.fetching,
48
- parentOnPlacementChange = _ref2.onPlacementChange,
49
- _ref2$offsetDistance = _ref2.offsetDistance,
50
- offsetDistance = _ref2$offsetDistance === void 0 ? 0 : _ref2$offsetDistance,
51
- _ref2$sameWidth = _ref2.sameWidth,
52
- sameWidth = _ref2$sameWidth === void 0 ? true : _ref2$sameWidth,
53
- _ref2$forcePortal = _ref2.forcePortal,
54
- forcePortal = _ref2$forcePortal === void 0 ? true : _ref2$forcePortal,
55
- autoHideScrollbar = _ref2.autoHideScrollbar,
56
- autoHideScrollbarDelay = _ref2.autoHideScrollbarDelay,
57
- observableRefs = _ref2.observableRefs,
58
- className = _ref2.className,
59
- restProps = (0, _objectWithoutProperties2.default)(_ref2, _excluded);
21
+ var CustomSelectDropdown = function CustomSelectDropdown(_ref) {
22
+ var children = _ref.children,
23
+ targetRef = _ref.targetRef,
24
+ scrollBoxRef = _ref.scrollBoxRef,
25
+ placement = _ref.placement,
26
+ fetching = _ref.fetching,
27
+ parentOnPlacementChange = _ref.onPlacementChange,
28
+ _ref$offsetDistance = _ref.offsetDistance,
29
+ offsetDistance = _ref$offsetDistance === void 0 ? 0 : _ref$offsetDistance,
30
+ _ref$sameWidth = _ref.sameWidth,
31
+ sameWidth = _ref$sameWidth === void 0 ? true : _ref$sameWidth,
32
+ _ref$forcePortal = _ref.forcePortal,
33
+ forcePortal = _ref$forcePortal === void 0 ? true : _ref$forcePortal,
34
+ autoHideScrollbar = _ref.autoHideScrollbar,
35
+ autoHideScrollbarDelay = _ref.autoHideScrollbarDelay,
36
+ className = _ref.className,
37
+ restProps = (0, _objectWithoutProperties2.default)(_ref, _excluded);
60
38
  var _React$useState = React.useState(function () {
61
39
  return calcIsTop(placement);
62
40
  }),
63
41
  _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
64
42
  isTop = _React$useState2[0],
65
43
  setIsTop = _React$useState2[1];
66
- var _React$useState3 = React.useState([]),
67
- _React$useState4 = (0, _slicedToArray2.default)(_React$useState3, 2),
68
- customModifiers = _React$useState4[0],
69
- setCustomModifiers = _React$useState4[1];
70
- (0, _useIsomorphicLayoutEffect.useIsomorphicLayoutEffect)(function () {
71
- if (!observableRefs) {
72
- return;
73
- }
74
- var customModifiers = [];
75
- if (Array.isArray(observableRefs)) {
76
- var _iterator = (0, _createForOfIteratorHelper2.default)(observableRefs),
77
- _step;
78
- try {
79
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
80
- var ref = _step.value;
81
- if (ref !== null && ref !== void 0 && ref.current) {
82
- customModifiers.push(getObserverModifier(ref.current));
83
- }
84
- }
85
- } catch (err) {
86
- _iterator.e(err);
87
- } finally {
88
- _iterator.f();
89
- }
90
- } else if (observableRefs.current) {
91
- customModifiers.push(getObserverModifier(observableRefs.current));
92
- }
93
- setCustomModifiers(customModifiers);
94
- }, [observableRefs]);
95
- var onPlacementChange = React.useCallback(function (_ref3) {
96
- var placement = _ref3.placement;
44
+ var onPlacementChange = React.useCallback(function (_ref2) {
45
+ var placement = _ref2.placement;
97
46
  setIsTop(calcIsTop(placement));
98
47
  parentOnPlacementChange === null || parentOnPlacementChange === void 0 ? void 0 : parentOnPlacementChange(placement);
99
48
  }, [parentOnPlacementChange, setIsTop]);
@@ -105,7 +54,7 @@ var CustomSelectDropdown = function CustomSelectDropdown(_ref2) {
105
54
  placement: placement,
106
55
  className: (0, _vkjs.classNames)("vkuiCustomSelectDropdown", offsetDistance === 0 && (isTop ? "vkuiCustomSelectDropdown--top" : "vkuiCustomSelectDropdown--bottom"), sameWidth && "vkuiCustomSelectDropdown--wide", className),
107
56
  forcePortal: forcePortal,
108
- customModifiers: customModifiers
57
+ autoUpdateOnTargetResize: true
109
58
  }, restProps), /*#__PURE__*/React.createElement(_CustomScrollView.CustomScrollView, {
110
59
  boxRef: scrollBoxRef,
111
60
  className: "vkuiCustomSelectDropdown__in",
@@ -1 +1 @@
1
- {"version":3,"file":"CustomSelectDropdown.js","names":["calcIsTop","placement","includes","getObserverModifier","element","name","enabled","phase","fn","noop","effect","instance","observer","MutationObserver","forceUpdate","observe","childList","subtree","disconnect","CustomSelectDropdown","children","targetRef","scrollBoxRef","fetching","parentOnPlacementChange","onPlacementChange","offsetDistance","sameWidth","forcePortal","autoHideScrollbar","autoHideScrollbarDelay","observableRefs","className","restProps","React","useState","isTop","setIsTop","customModifiers","setCustomModifiers","useIsomorphicLayoutEffect","Array","isArray","ref","current","push","useCallback","classNames"],"sources":["../../../../src/components/CustomSelectDropdown/CustomSelectDropdown.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Modifier } from 'react-popper';\nimport { CustomScrollView } from '../CustomScrollView/CustomScrollView';\nimport { TrackerOptionsProps } from '../CustomScrollView/useTrackerVisibility';\nimport { classNames, noop } from '@vkontakte/vkjs';\nimport { Popper, Placement } from '../Popper/Popper';\nimport { Spinner } from '../Spinner/Spinner';\nimport { HasRef } from '../../types';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport styles from './CustomSelectDropdown.module.css';\n\nexport interface CustomSelectDropdownProps\n extends React.HTMLAttributes<HTMLElement>,\n HasRef<HTMLDivElement>,\n TrackerOptionsProps {\n targetRef: React.RefObject<HTMLElement>;\n placement?: Placement;\n scrollBoxRef?: React.Ref<HTMLDivElement>;\n observableRefs?: Array<React.RefObject<HTMLElement>> | React.RefObject<HTMLElement>;\n fetching?: boolean;\n offsetDistance?: number;\n sameWidth?: boolean;\n forcePortal?: boolean;\n onPlacementChange?: (placement?: Placement) => void;\n}\n\nconst calcIsTop = (placement?: Placement) => placement?.includes('top');\n\nfunction getObserverModifier<T extends HTMLElement>(element: T): Modifier<string> {\n return {\n name: 'customSelectChildrenChange',\n enabled: true,\n phase: 'main',\n fn: noop,\n effect: ({ instance }) => {\n const observer = new MutationObserver(instance.forceUpdate);\n\n observer.observe(element, {\n childList: true,\n subtree: true,\n });\n\n return () => {\n observer.disconnect();\n };\n },\n };\n}\n\nexport const CustomSelectDropdown = ({\n children,\n targetRef,\n scrollBoxRef,\n placement,\n fetching,\n onPlacementChange: parentOnPlacementChange,\n offsetDistance = 0,\n sameWidth = true,\n forcePortal = true,\n autoHideScrollbar,\n autoHideScrollbarDelay,\n observableRefs,\n className,\n ...restProps\n}: CustomSelectDropdownProps) => {\n const [isTop, setIsTop] = React.useState(() => calcIsTop(placement));\n const [customModifiers, setCustomModifiers] = React.useState<Array<Modifier<string>>>([]);\n\n useIsomorphicLayoutEffect(() => {\n if (!observableRefs) {\n return;\n }\n const customModifiers: Array<Modifier<string>> = [];\n\n if (Array.isArray(observableRefs)) {\n for (const ref of observableRefs) {\n if (ref?.current) {\n customModifiers.push(getObserverModifier(ref.current));\n }\n }\n } else if (observableRefs.current) {\n customModifiers.push(getObserverModifier(observableRefs.current));\n }\n\n setCustomModifiers(customModifiers);\n }, [observableRefs]);\n\n const onPlacementChange = React.useCallback(\n ({ placement }: { placement?: Placement }) => {\n setIsTop(calcIsTop(placement));\n parentOnPlacementChange?.(placement);\n },\n [parentOnPlacementChange, setIsTop],\n );\n\n return (\n <Popper\n targetRef={targetRef}\n offsetDistance={offsetDistance}\n sameWidth={sameWidth}\n onPlacementChange={onPlacementChange}\n placement={placement}\n className={classNames(\n styles['CustomSelectDropdown'],\n offsetDistance === 0 &&\n (isTop ? styles['CustomSelectDropdown--top'] : styles['CustomSelectDropdown--bottom']),\n sameWidth && styles['CustomSelectDropdown--wide'],\n className,\n )}\n forcePortal={forcePortal}\n customModifiers={customModifiers}\n {...restProps}\n >\n <CustomScrollView\n boxRef={scrollBoxRef}\n className={styles['CustomSelectDropdown__in']}\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"],"mappings":"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"}
1
+ {"version":3,"file":"CustomSelectDropdown.js","names":["calcIsTop","placement","includes","CustomSelectDropdown","children","targetRef","scrollBoxRef","fetching","parentOnPlacementChange","onPlacementChange","offsetDistance","sameWidth","forcePortal","autoHideScrollbar","autoHideScrollbarDelay","className","restProps","React","useState","isTop","setIsTop","useCallback","classNames"],"sources":["../../../../src/components/CustomSelectDropdown/CustomSelectDropdown.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport type { Placement } from '../../lib/floating';\nimport { HasRef } 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 React.HTMLAttributes<HTMLElement>,\n HasRef<HTMLDivElement>,\n TrackerOptionsProps {\n targetRef: React.RefObject<HTMLElement>;\n placement?: Placement;\n scrollBoxRef?: React.Ref<HTMLDivElement>;\n fetching?: boolean;\n offsetDistance?: number;\n sameWidth?: boolean;\n forcePortal?: boolean;\n onPlacementChange?: (placement?: Placement) => void;\n}\n\nconst calcIsTop = (placement?: Placement) => placement?.includes('top');\n\nexport const CustomSelectDropdown = ({\n children,\n targetRef,\n scrollBoxRef,\n placement,\n fetching,\n onPlacementChange: parentOnPlacementChange,\n offsetDistance = 0,\n sameWidth = true,\n forcePortal = true,\n autoHideScrollbar,\n autoHideScrollbarDelay,\n className,\n ...restProps\n}: CustomSelectDropdownProps) => {\n const [isTop, setIsTop] = React.useState(() => calcIsTop(placement));\n\n const onPlacementChange = React.useCallback(\n ({ placement }: { placement?: Placement }) => {\n setIsTop(calcIsTop(placement));\n parentOnPlacementChange?.(placement);\n },\n [parentOnPlacementChange, setIsTop],\n );\n\n return (\n <Popper\n targetRef={targetRef}\n offsetDistance={offsetDistance}\n sameWidth={sameWidth}\n onPlacementChange={onPlacementChange}\n placement={placement}\n className={classNames(\n styles['CustomSelectDropdown'],\n offsetDistance === 0 &&\n (isTop ? styles['CustomSelectDropdown--top'] : styles['CustomSelectDropdown--bottom']),\n sameWidth && styles['CustomSelectDropdown--wide'],\n className,\n )}\n forcePortal={forcePortal}\n autoUpdateOnTargetResize\n {...restProps}\n >\n <CustomScrollView\n boxRef={scrollBoxRef}\n className={styles['CustomSelectDropdown__in']}\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"],"mappings":";;;;;;;;;;;AAAA;AACA;AAGA;AAEA;AACA;AAA6C;AAiB7C,IAAMA,SAAS,GAAG,SAAZA,SAAS,CAAIC,SAAqB;EAAA,OAAKA,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEC,QAAQ,CAAC,KAAK,CAAC;AAAA;AAEhE,IAAMC,oBAAoB,GAAG,SAAvBA,oBAAoB,OAcA;EAAA,IAb/BC,QAAQ,QAARA,QAAQ;IACRC,SAAS,QAATA,SAAS;IACTC,YAAY,QAAZA,YAAY;IACZL,SAAS,QAATA,SAAS;IACTM,QAAQ,QAARA,QAAQ;IACWC,uBAAuB,QAA1CC,iBAAiB;IAAA,2BACjBC,cAAc;IAAdA,cAAc,oCAAG,CAAC;IAAA,sBAClBC,SAAS;IAATA,SAAS,+BAAG,IAAI;IAAA,wBAChBC,WAAW;IAAXA,WAAW,iCAAG,IAAI;IAClBC,iBAAiB,QAAjBA,iBAAiB;IACjBC,sBAAsB,QAAtBA,sBAAsB;IACtBC,SAAS,QAATA,SAAS;IACNC,SAAS;EAEZ,sBAA0BC,KAAK,CAACC,QAAQ,CAAC;MAAA,OAAMlB,SAAS,CAACC,SAAS,CAAC;IAAA,EAAC;IAAA;IAA7DkB,KAAK;IAAEC,QAAQ;EAEtB,IAAMX,iBAAiB,GAAGQ,KAAK,CAACI,WAAW,CACzC,iBAA8C;IAAA,IAA3CpB,SAAS,SAATA,SAAS;IACVmB,QAAQ,CAACpB,SAAS,CAACC,SAAS,CAAC,CAAC;IAC9BO,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAGP,SAAS,CAAC;EACtC,CAAC,EACD,CAACO,uBAAuB,EAAEY,QAAQ,CAAC,CACpC;EAED,oBACE,oBAAC,cAAM;IACL,SAAS,EAAEf,SAAU;IACrB,cAAc,EAAEK,cAAe;IAC/B,SAAS,EAAEC,SAAU;IACrB,iBAAiB,EAAEF,iBAAkB;IACrC,SAAS,EAAER,SAAU;IACrB,SAAS,EAAE,IAAAqB,gBAAU,8BAEnBZ,cAAc,KAAK,CAAC,KACjBS,KAAK,uEAA+E,CAAC,EACxFR,SAAS,oCAAwC,EACjDI,SAAS,CACT;IACF,WAAW,EAAEH,WAAY;IACzB,wBAAwB;EAAA,GACpBI,SAAS,gBAEb,oBAAC,kCAAgB;IACf,MAAM,EAAEV,YAAa;IACrB,SAAS,gCAAqC;IAC9C,iBAAiB,EAAEO,iBAAkB;IACrC,sBAAsB,EAAEC;EAAuB,GAE9CP,QAAQ,gBACP;IAAK,SAAS;EAA2C,gBACvD,oBAAC,gBAAO;IAAC,IAAI,EAAC;EAAO,EAAG,CACpB,GAENH,QACD,CACgB,CACZ;AAEb,CAAC;AAAC"}
@@ -9,15 +9,19 @@ exports.CustomSelectOption = void 0;
9
9
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
10
  var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
11
  var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
12
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
12
13
  var React = _interopRequireWildcard(require("react"));
13
14
  var _icons = require("@vkontakte/icons");
14
15
  var _vkjs = require("@vkontakte/vkjs");
15
- var _Paragraph = require("../Typography/Paragraph/Paragraph");
16
- var _Footnote = require("../Typography/Footnote/Footnote");
17
16
  var _useAdaptivity2 = require("../../hooks/useAdaptivity");
17
+ var _adaptivity = require("../../lib/adaptivity");
18
18
  var _warnOnce = require("../../lib/warnOnce");
19
- var _getSizeYClassName = require("../../helpers/getSizeYClassName");
19
+ var _Footnote = require("../Typography/Footnote/Footnote");
20
+ var _Paragraph = require("../Typography/Paragraph/Paragraph");
20
21
  var _excluded = ["children", "hierarchy", "hovered", "selected", "before", "after", "option", "description", "disabled", "style", "className"];
22
+ var sizeYClassNames = (0, _defineProperty2.default)({
23
+ none: "vkuiCustomSelectOption--sizeY-none"
24
+ }, _adaptivity.SizeType.REGULAR, "vkuiCustomSelectOption--sizeY-regular");
21
25
  var warn = (0, _warnOnce.warnOnce)('CustomSelectOption');
22
26
 
23
27
  /**
@@ -39,7 +43,8 @@ var CustomSelectOption = function CustomSelectOption(_ref) {
39
43
  restProps = (0, _objectWithoutProperties2.default)(_ref, _excluded);
40
44
  var title = typeof children === 'string' ? children : undefined;
41
45
  var _useAdaptivity = (0, _useAdaptivity2.useAdaptivity)(),
42
- sizeY = _useAdaptivity.sizeY;
46
+ _useAdaptivity$sizeY = _useAdaptivity.sizeY,
47
+ sizeY = _useAdaptivity$sizeY === void 0 ? 'none' : _useAdaptivity$sizeY;
43
48
  var style = React.useMemo(function () {
44
49
  return hierarchy > 0 ? (0, _objectSpread2.default)({
45
50
  '--vkui_internal--custom_select_option_hierarchy_level': hierarchy
@@ -55,7 +60,7 @@ var CustomSelectOption = function CustomSelectOption(_ref) {
55
60
  title: title,
56
61
  "aria-disabled": disabled,
57
62
  "aria-selected": selected,
58
- className: (0, _vkjs.classNames)("vkuiCustomSelectOption", (0, _getSizeYClassName.getSizeYClassName)("vkuiCustomSelectOption", sizeY), hovered && !disabled && "vkuiCustomSelectOption--hover",
63
+ className: (0, _vkjs.classNames)("vkuiCustomSelectOption", sizeY !== _adaptivity.SizeType.COMPACT && sizeYClassNames[sizeY], hovered && !disabled && "vkuiCustomSelectOption--hover",
59
64
  // Note: пустой класс
60
65
  selected && "vkuiCustomSelectOption--selected", disabled && "vkuiCustomSelectOption--disabled", hierarchy > 0 && "vkuiCustomSelectOption--hierarchy", className),
61
66
  style: style
@@ -1 +1 @@
1
- {"version":3,"file":"CustomSelectOption.js","names":["warn","warnOnce","CustomSelectOption","children","hierarchy","hovered","selected","before","after","option","description","disabled","styleProp","style","className","restProps","title","undefined","useAdaptivity","sizeY","React","useMemo","process","env","NODE_ENV","classNames","getSizeYClassName","hasReactNode"],"sources":["../../../../src/components/CustomSelectOption/CustomSelectOption.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Icon16Done } from '@vkontakte/icons';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { Paragraph } from '../Typography/Paragraph/Paragraph';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { HasRootRef } from '../../types';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { getSizeYClassName } from '../../helpers/getSizeYClassName';\nimport styles from './CustomSelectOption.module.css';\n\nexport interface CustomSelectOptionProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n /**\n * Вставляет основной контент.\n * @deprecated since v6.0.0\n */\n option?: any;\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 disabled?: boolean;\n}\n\nconst warn = warnOnce('CustomSelectOption');\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelectOption\n */\nexport const CustomSelectOption = ({\n children,\n hierarchy = 0,\n hovered,\n selected,\n before,\n after,\n option,\n description,\n disabled,\n style: styleProp,\n className,\n ...restProps\n}: CustomSelectOptionProps) => {\n const title = typeof children === 'string' ? children : undefined;\n const { sizeY } = 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\n if (!!option && process.env.NODE_ENV === 'development') {\n // TODO v6.0.0. Удалить св-во `option`\n warn('Свойство option было добавлено по ошибке и будет удалено в v6.0.0.');\n }\n\n return (\n <Paragraph\n {...restProps}\n Component=\"div\"\n role=\"option\"\n title={title}\n aria-disabled={disabled}\n aria-selected={selected}\n className={classNames(\n styles['CustomSelectOption'],\n getSizeYClassName(styles['CustomSelectOption'], sizeY),\n hovered && !disabled && styles['CustomSelectOption--hover'],\n // Note: пустой класс\n selected && styles['CustomSelectOption--selected'],\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']}>{description}</Footnote>\n )}\n </div>\n <div className={styles['CustomSelectOption__after']}>\n {hasReactNode(after) && (\n <div className={styles['CustomSelectOption__afterIn']}>{after}</div>\n )}\n {selected && <Icon16Done className={styles['CustomSelectOption__selectedIcon']} />}\n </div>\n </Paragraph>\n );\n};\n"],"mappings":";;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAoE;AA+CpE,IAAMA,IAAI,GAAG,IAAAC,kBAAQ,EAAC,oBAAoB,CAAC;;AAE3C;AACA;AACA;AACO,IAAMC,kBAAkB,GAAG,SAArBA,kBAAkB,OAaA;EAAA,IAZ7BC,QAAQ,QAARA,QAAQ;IAAA,sBACRC,SAAS;IAATA,SAAS,+BAAG,CAAC;IACbC,OAAO,QAAPA,OAAO;IACPC,QAAQ,QAARA,QAAQ;IACRC,MAAM,QAANA,MAAM;IACNC,KAAK,QAALA,KAAK;IACLC,MAAM,QAANA,MAAM;IACNC,WAAW,QAAXA,WAAW;IACXC,QAAQ,QAARA,QAAQ;IACDC,SAAS,QAAhBC,KAAK;IACLC,SAAS,QAATA,SAAS;IACNC,SAAS;EAEZ,IAAMC,KAAK,GAAG,OAAOb,QAAQ,KAAK,QAAQ,GAAGA,QAAQ,GAAGc,SAAS;EACjE,qBAAkB,IAAAC,6BAAa,GAAE;IAAzBC,KAAK,kBAALA,KAAK;EACb,IAAMN,KAAK,GAAGO,KAAK,CAACC,OAAO,CACzB;IAAA,OACEjB,SAAS,GAAG,CAAC;MAEP,uDAAuD,EAAEA;IAAS,GAC/DQ,SAAS,IAEdA,SAAS;EAAA,GACf,CAACR,SAAS,EAAEQ,SAAS,CAAC,CACvB;EAED,IAAI,CAAC,CAACH,MAAM,IAAIa,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,aAAa,EAAE;IACtD;IACAxB,IAAI,CAAC,oEAAoE,CAAC;EAC5E;EAEA,oBACE,oBAAC,oBAAS,6BACJe,SAAS;IACb,SAAS,EAAC,KAAK;IACf,IAAI,EAAC,QAAQ;IACb,KAAK,EAAEC,KAAM;IACb,iBAAeL,QAAS;IACxB,iBAAeL,QAAS;IACxB,SAAS,EAAE,IAAAmB,gBAAU,4BAEnB,IAAAC,oCAAiB,4BAA+BP,KAAK,CAAC,EACtDd,OAAO,IAAI,CAACM,QAAQ,mCAAuC;IAC3D;IACAL,QAAQ,sCAA0C,EAClDK,QAAQ,sCAA0C,EAClDP,SAAS,GAAG,CAAC,uCAA2C,EACxDU,SAAS,CACT;IACF,KAAK,EAAED;EAAM,IAEZ,IAAAc,kBAAY,EAACpB,MAAM,CAAC,iBAAI;IAAK,SAAS;EAAuC,GAAEA,MAAM,CAAO,eAC7F;IAAK,SAAS;EAAqC,gBACjD;IAAK,SAAS;EAAyC,GAAEJ,QAAQ,CAAO,EACvE,IAAAwB,kBAAY,EAACjB,WAAW,CAAC,iBACxB,oBAAC,kBAAQ;IAAC,SAAS;EAA4C,GAAEA,WAAW,CAC7E,CACG,eACN;IAAK,SAAS;EAAsC,GACjD,IAAAiB,kBAAY,EAACnB,KAAK,CAAC,iBAClB;IAAK,SAAS;EAAwC,GAAEA,KAAK,CAC9D,EACAF,QAAQ,iBAAI,oBAAC,iBAAU;IAAC,SAAS;EAA6C,EAAG,CAC9E,CACI;AAEhB,CAAC;AAAC"}
1
+ {"version":3,"file":"CustomSelectOption.js","names":["sizeYClassNames","none","SizeType","REGULAR","warn","warnOnce","CustomSelectOption","children","hierarchy","hovered","selected","before","after","option","description","disabled","styleProp","style","className","restProps","title","undefined","useAdaptivity","sizeY","React","useMemo","process","env","NODE_ENV","classNames","COMPACT","hasReactNode"],"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 { SizeType } from '../../lib/adaptivity';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { HasRootRef } from '../../types';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { Paragraph } from '../Typography/Paragraph/Paragraph';\nimport styles from './CustomSelectOption.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelectOption--sizeY-none'],\n [SizeType.REGULAR]: styles['CustomSelectOption--sizeY-regular'],\n};\n\nexport interface CustomSelectOptionProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n /**\n * Вставляет основной контент.\n * @deprecated since v6.0.0\n */\n option?: any;\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 disabled?: boolean;\n}\n\nconst warn = warnOnce('CustomSelectOption');\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelectOption\n */\nexport const CustomSelectOption = ({\n children,\n hierarchy = 0,\n hovered,\n selected,\n before,\n after,\n option,\n description,\n disabled,\n style: styleProp,\n className,\n ...restProps\n}: CustomSelectOptionProps) => {\n const title = typeof children === 'string' ? children : undefined;\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\n if (!!option && process.env.NODE_ENV === 'development') {\n // TODO v6.0.0. Удалить св-во `option`\n warn('Свойство option было добавлено по ошибке и будет удалено в v6.0.0.');\n }\n\n return (\n <Paragraph\n {...restProps}\n Component=\"div\"\n role=\"option\"\n title={title}\n aria-disabled={disabled}\n aria-selected={selected}\n className={classNames(\n styles['CustomSelectOption'],\n sizeY !== SizeType.COMPACT && sizeYClassNames[sizeY],\n hovered && !disabled && styles['CustomSelectOption--hover'],\n // Note: пустой класс\n selected && styles['CustomSelectOption--selected'],\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']}>{description}</Footnote>\n )}\n </div>\n <div className={styles['CustomSelectOption__after']}>\n {hasReactNode(after) && (\n <div className={styles['CustomSelectOption__afterIn']}>{after}</div>\n )}\n {selected && <Icon16Done className={styles['CustomSelectOption__selectedIcon']} />}\n </div>\n </Paragraph>\n );\n};\n"],"mappings":";;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAA8D;AAG9D,IAAMA,eAAe;EACnBC,IAAI;AAA0C,GAC7CC,oBAAQ,CAACC,OAAO,0CAClB;AA8CD,IAAMC,IAAI,GAAG,IAAAC,kBAAQ,EAAC,oBAAoB,CAAC;;AAE3C;AACA;AACA;AACO,IAAMC,kBAAkB,GAAG,SAArBA,kBAAkB,OAaA;EAAA,IAZ7BC,QAAQ,QAARA,QAAQ;IAAA,sBACRC,SAAS;IAATA,SAAS,+BAAG,CAAC;IACbC,OAAO,QAAPA,OAAO;IACPC,QAAQ,QAARA,QAAQ;IACRC,MAAM,QAANA,MAAM;IACNC,KAAK,QAALA,KAAK;IACLC,MAAM,QAANA,MAAM;IACNC,WAAW,QAAXA,WAAW;IACXC,QAAQ,QAARA,QAAQ;IACDC,SAAS,QAAhBC,KAAK;IACLC,SAAS,QAATA,SAAS;IACNC,SAAS;EAEZ,IAAMC,KAAK,GAAG,OAAOb,QAAQ,KAAK,QAAQ,GAAGA,QAAQ,GAAGc,SAAS;EACjE,qBAA2B,IAAAC,6BAAa,GAAE;IAAA,sCAAlCC,KAAK;IAALA,KAAK,qCAAG,MAAM;EACtB,IAAMN,KAAK,GAAGO,KAAK,CAACC,OAAO,CACzB;IAAA,OACEjB,SAAS,GAAG,CAAC;MAEP,uDAAuD,EAAEA;IAAS,GAC/DQ,SAAS,IAEdA,SAAS;EAAA,GACf,CAACR,SAAS,EAAEQ,SAAS,CAAC,CACvB;EAED,IAAI,CAAC,CAACH,MAAM,IAAIa,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,aAAa,EAAE;IACtD;IACAxB,IAAI,CAAC,oEAAoE,CAAC;EAC5E;EAEA,oBACE,oBAAC,oBAAS,6BACJe,SAAS;IACb,SAAS,EAAC,KAAK;IACf,IAAI,EAAC,QAAQ;IACb,KAAK,EAAEC,KAAM;IACb,iBAAeL,QAAS;IACxB,iBAAeL,QAAS;IACxB,SAAS,EAAE,IAAAmB,gBAAU,4BAEnBN,KAAK,KAAKrB,oBAAQ,CAAC4B,OAAO,IAAI9B,eAAe,CAACuB,KAAK,CAAC,EACpDd,OAAO,IAAI,CAACM,QAAQ,mCAAuC;IAC3D;IACAL,QAAQ,sCAA0C,EAClDK,QAAQ,sCAA0C,EAClDP,SAAS,GAAG,CAAC,uCAA2C,EACxDU,SAAS,CACT;IACF,KAAK,EAAED;EAAM,IAEZ,IAAAc,kBAAY,EAACpB,MAAM,CAAC,iBAAI;IAAK,SAAS;EAAuC,GAAEA,MAAM,CAAO,eAC7F;IAAK,SAAS;EAAqC,gBACjD;IAAK,SAAS;EAAyC,GAAEJ,QAAQ,CAAO,EACvE,IAAAwB,kBAAY,EAACjB,WAAW,CAAC,iBACxB,oBAAC,kBAAQ;IAAC,SAAS;EAA4C,GAAEA,WAAW,CAC7E,CACG,eACN;IAAK,SAAS;EAAsC,GACjD,IAAAiB,kBAAY,EAACnB,KAAK,CAAC,iBAClB;IAAK,SAAS;EAAwC,GAAEA,KAAK,CAC9D,EACAF,QAAQ,iBAAI,oBAAC,iBAAU;IAAC,SAAS;EAA6C,EAAG,CAC9E,CACI;AAEhB,CAAC;AAAC"}
@@ -1,10 +1,11 @@
1
1
  import * as React from 'react';
2
+ import type { PlacementWithAuto } from '../../lib/floating';
3
+ import { HasRootRef } from '../../types';
2
4
  import { CalendarProps } from '../Calendar/Calendar';
3
- import { Placement } from '../Popper/Popper';
4
5
  import { FormFieldProps } from '../FormField/FormField';
5
- import { HasRootRef } from '../../types';
6
+ import '../InputLike/InputLikeDivider.module.css';
6
7
  export interface DateInputProps extends Omit<React.InputHTMLAttributes<HTMLDivElement>, 'value' | 'onChange' | 'size'>, Pick<CalendarProps, 'disablePast' | 'disableFuture' | 'enableTime' | 'shouldDisableDate' | 'onChange' | 'value' | 'doneButtonText' | 'weekStartsOn' | 'disablePickers' | 'changeHoursAriaLabel' | 'changeMinutesAriaLabel' | 'prevMonthAriaLabel' | 'nextMonthAriaLabel' | 'changeMonthAriaLabel' | 'changeYearAriaLabel' | 'changeDayAriaLabel' | 'showNeighboringMonth' | 'size' | 'viewDate' | 'onHeaderChange' | 'onNextMonth' | 'onPrevMonth' | 'prevMonthIcon' | 'nextMonthIcon'>, HasRootRef<HTMLDivElement>, FormFieldProps {
7
- calendarPlacement?: Placement;
8
+ calendarPlacement?: PlacementWithAuto;
8
9
  closeOnChange?: boolean;
9
10
  clearFieldAriaLabel?: string;
10
11
  showCalendarAriaLabel?: string;
@@ -8,22 +8,26 @@ Object.defineProperty(exports, "__esModule", {
8
8
  exports.DateInput = void 0;
9
9
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
10
  var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
11
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
12
  var React = _interopRequireWildcard(require("react"));
12
- var _date = require("../../lib/date");
13
13
  var _icons = require("@vkontakte/icons");
14
- var _Calendar = require("../Calendar/Calendar");
15
- var _Popper = require("../Popper/Popper");
16
- var _utils = require("../../lib/utils");
17
- var _IconButton = require("../IconButton/IconButton");
18
14
  var _vkjs = require("@vkontakte/vkjs");
19
- var _FormField = require("../FormField/FormField");
15
+ var _useAdaptivity2 = require("../../hooks/useAdaptivity");
20
16
  var _useDateInput2 = require("../../hooks/useDateInput");
17
+ var _useExternRef = require("../../hooks/useExternRef");
18
+ var _adaptivity = require("../../lib/adaptivity");
19
+ var _callMultiple = require("../../lib/callMultiple");
20
+ var _date = require("../../lib/date");
21
+ var _Calendar = require("../Calendar/Calendar");
22
+ var _FormField = require("../FormField/FormField");
23
+ var _IconButton = require("../IconButton/IconButton");
21
24
  var _InputLike = require("../InputLike/InputLike");
22
25
  var _InputLikeDivider = require("../InputLike/InputLikeDivider");
23
- var _useAdaptivity2 = require("../../hooks/useAdaptivity");
24
- var _callMultiple = require("../../lib/callMultiple");
25
- var _getSizeYClassName = require("../../helpers/getSizeYClassName");
26
+ var _Popper = require("../Popper/Popper");
26
27
  var _excluded = ["enableTime", "shouldDisableDate", "disableFuture", "disablePast", "value", "onChange", "calendarPlacement", "style", "className", "doneButtonText", "closeOnChange", "disablePickers", "getRootRef", "name", "autoFocus", "disabled", "onClick", "onFocus", "prevMonthAriaLabel", "nextMonthAriaLabel", "showNeighboringMonth", "size", "changeMonthAriaLabel", "changeYearAriaLabel", "changeDayAriaLabel", "changeHoursAriaLabel", "changeMinutesAriaLabel", "clearFieldAriaLabel", "showCalendarAriaLabel", "viewDate", "onHeaderChange", "onNextMonth", "onPrevMonth", "prevMonthIcon", "nextMonthIcon", "disableCalendar"];
28
+ var sizeYClassNames = (0, _defineProperty2.default)({
29
+ none: "vkuiDateInput--sizeY-none"
30
+ }, _adaptivity.SizeType.COMPACT, "vkuiDateInput--sizeY-compact");
27
31
  var elementsConfig = function elementsConfig(index) {
28
32
  var length = 2;
29
33
  var min = 1;
@@ -164,7 +168,9 @@ var DateInput = function DateInput(_ref) {
164
168
  clear = _useDateInput.clear,
165
169
  removeFocusFromField = _useDateInput.removeFocusFromField;
166
170
  var _useAdaptivity = (0, _useAdaptivity2.useAdaptivity)(),
167
- sizeY = _useAdaptivity.sizeY;
171
+ _useAdaptivity$sizeY = _useAdaptivity.sizeY,
172
+ sizeY = _useAdaptivity$sizeY === void 0 ? 'none' : _useAdaptivity$sizeY;
173
+ var handleRootRef = (0, _useExternRef.useExternRef)(rootRef, getRootRef);
168
174
  var onCalendarChange = React.useCallback(function (value) {
169
175
  onChange === null || onChange === void 0 ? void 0 : onChange(value);
170
176
  if (closeOnChange && !enableTime) {
@@ -173,8 +179,8 @@ var DateInput = function DateInput(_ref) {
173
179
  }, [onChange, removeFocusFromField, closeOnChange, enableTime]);
174
180
  return /*#__PURE__*/React.createElement(_FormField.FormField, (0, _extends2.default)({
175
181
  style: style,
176
- className: (0, _vkjs.classNames)("vkuiDateInput", (0, _getSizeYClassName.getSizeYClassName)("vkuiDateInput", sizeY), className),
177
- getRootRef: (0, _utils.multiRef)(rootRef, getRootRef),
182
+ className: (0, _vkjs.classNames)("vkuiDateInput", sizeY !== _adaptivity.SizeType.REGULAR && sizeYClassNames[sizeY], className),
183
+ getRootRef: handleRootRef,
178
184
  after: value ? /*#__PURE__*/React.createElement(_IconButton.IconButton, {
179
185
  hoverMode: "opacity",
180
186
  "aria-label": clearFieldAriaLabel,