@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":"SubnavigationButton.js","names":["React","getSizeYClassName","classNames","getTitleFromChildren","useAdaptivity","Tappable","Icon16Dropdown","Caption","Subhead","SubnavigationButtonTypography","textLevel","restProps","SubnavigationButton","mode","size","selected","before","after","expandable","children","className","sizeY","styles"],"sources":["../../../../src/components/SubnavigationButton/SubnavigationButton.tsx"],"sourcesContent":["import * as React from 'react';\nimport { getSizeYClassName } from '../../helpers/getSizeYClassName';\nimport { HasComponent, HasChildren } from '../../types';\nimport { classNames } from '@vkontakte/vkjs';\nimport { getTitleFromChildren } from '../../lib/utils';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { TappableProps, Tappable } from '../Tappable/Tappable';\nimport { Icon16Dropdown } from '@vkontakte/icons';\nimport { Caption } from '../Typography/Caption/Caption';\nimport { Subhead } from '../Typography/Subhead/Subhead';\nimport styles from './SubnavigationButton.module.css';\n\nexport interface SubnavigationButtonProps extends Omit<TappableProps, 'size'> {\n mode?: 'primary' | 'outline' | 'tertiary';\n size?: 's' | 'm' | 'l';\n selected?: boolean;\n /**\n * Размер шрифта. Этим свойством рекомендуется пользоваться, чтобы отрегулировать размер шрифта у кнопок в `<SubnavigationBar mode=\"fixed\" />`\n */\n textLevel?: '1' | '2' | '3';\n /**\n * Рекомендуется использовать только иконки с размером 24\n */\n before?: React.ReactNode;\n /**\n * Рекомендуется использовать только `<Counter size=\"s\" />` или `<Badge />`\n */\n after?: React.ReactNode;\n expandable?: boolean;\n}\n\ntype SubnavigationButtonTypographyProps = Pick<\n SubnavigationButtonProps,\n 'textLevel' | 'className'\n> &\n HasComponent &\n HasChildren;\n\nconst SubnavigationButtonTypography = ({\n textLevel,\n ...restProps\n}: SubnavigationButtonTypographyProps) => {\n if (textLevel === '1') {\n return <Subhead {...restProps} />;\n }\n\n return <Caption level={textLevel === '2' ? '1' : '2'} {...restProps} />;\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/SubnavigationButton\n */\nexport const SubnavigationButton = ({\n mode = 'primary',\n size = 'm',\n selected,\n textLevel = '1',\n before,\n after,\n expandable,\n children,\n className,\n ...restProps\n}: SubnavigationButtonProps) => {\n const { sizeY } = useAdaptivity();\n\n return (\n <Tappable\n {...restProps}\n hasActive={false}\n focusVisibleMode=\"outside\"\n className={classNames(\n styles['SubnavigationButton'],\n styles[`SubnavigationButton--size-${size}`],\n styles[`SubnavigationButton--mode-${mode}`],\n selected && styles['SubnavigationButton--selected'],\n getSizeYClassName(styles['SubnavigationButton'], sizeY),\n className,\n )}\n aria-label={getTitleFromChildren(children)}\n >\n <span className={styles['SubnavigationButton__in']}>\n {before && <span className={styles['SubnavigationButton__before']}>{before}</span>}\n <SubnavigationButtonTypography\n textLevel={textLevel}\n className={styles['SubnavigationButton__label']}\n Component=\"span\"\n >\n {children}\n </SubnavigationButtonTypography>\n {after && <span className={styles['SubnavigationButton__after']}>{after}</span>}\n {expandable && <Icon16Dropdown className={styles['SubnavigationButton__expandableIcon']} />}\n </span>\n </Tappable>\n );\n};\n"],"mappings":";;;;AAAA,OAAO,KAAKA,KAAK,MAAM,OAAO;AAC9B,SAASC,iBAAiB,QAAQ,iCAAiC;AAEnE,SAASC,UAAU,QAAQ,iBAAiB;AAC5C,SAASC,oBAAoB,QAAQ,iBAAiB;AACtD,SAASC,aAAa,QAAQ,2BAA2B;AACzD,SAAwBC,QAAQ,QAAQ,sBAAsB;AAC9D,SAASC,cAAc,QAAQ,kBAAkB;AACjD,SAASC,OAAO,QAAQ,+BAA+B;AACvD,SAASC,OAAO,QAAQ,+BAA+B;AAAC;AA6BxD,IAAMC,6BAA6B,GAAG,SAAhCA,6BAA6B,OAGO;EAAA,IAFxCC,SAAS,QAATA,SAAS;IACNC,SAAS;EAEZ,IAAID,SAAS,KAAK,GAAG,EAAE;IACrB,oBAAO,oBAAC,OAAO,EAAKC,SAAS,CAAI;EACnC;EAEA,oBAAO,oBAAC,OAAO;IAAC,KAAK,EAAED,SAAS,KAAK,GAAG,GAAG,GAAG,GAAG;EAAI,GAAKC,SAAS,EAAI;AACzE,CAAC;;AAED;AACA;AACA;AACA,OAAO,IAAMC,mBAAmB,GAAG,SAAtBA,mBAAmB,QAWA;EAAA,uBAV9BC,IAAI;IAAJA,IAAI,2BAAG,SAAS;IAAA,mBAChBC,IAAI;IAAJA,IAAI,2BAAG,GAAG;IACVC,QAAQ,SAARA,QAAQ;IAAA,wBACRL,SAAS;IAATA,SAAS,gCAAG,GAAG;IACfM,MAAM,SAANA,MAAM;IACNC,KAAK,SAALA,KAAK;IACLC,UAAU,SAAVA,UAAU;IACVC,QAAQ,SAARA,QAAQ;IACRC,SAAS,SAATA,SAAS;IACNT,SAAS;EAEZ,qBAAkBP,aAAa,EAAE;IAAzBiB,KAAK,kBAALA,KAAK;EAEb,oBACE,oBAAC,QAAQ,eACHV,SAAS;IACb,SAAS,EAAE,KAAM;IACjB,gBAAgB,EAAC,SAAS;IAC1B,SAAS,EAAET,UAAU,4BAEnBoB,MAAM,qCAA8BR,IAAI,EAAG,EAC3CQ,MAAM,qCAA8BT,IAAI,EAAG,EAC3CE,QAAQ,uCAA2C,EACnDd,iBAAiB,4BAAgCoB,KAAK,CAAC,EACvDD,SAAS,CACT;IACF,cAAYjB,oBAAoB,CAACgB,QAAQ;EAAE,iBAE3C;IAAM,SAAS;EAAoC,GAChDH,MAAM,iBAAI;IAAM,SAAS;EAAwC,GAAEA,MAAM,CAAQ,eAClF,oBAAC,6BAA6B;IAC5B,SAAS,EAAEN,SAAU;IACrB,SAAS,kCAAuC;IAChD,SAAS,EAAC;EAAM,GAEfS,QAAQ,CACqB,EAC/BF,KAAK,iBAAI;IAAM,SAAS;EAAuC,GAAEA,KAAK,CAAQ,EAC9EC,UAAU,iBAAI,oBAAC,cAAc;IAAC,SAAS;EAAgD,EAAG,CACtF,CACE;AAEf,CAAC;AAAC;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;AAAA"}
1
+ {"version":3,"file":"SubnavigationButton.js","names":["React","Icon16Dropdown","classNames","useAdaptivity","SizeType","getTitleFromChildren","Tappable","Caption","Subhead","sizeYClassNames","none","COMPACT","SubnavigationButtonTypography","textLevel","restProps","SubnavigationButton","mode","size","selected","before","after","expandable","children","className","sizeY","styles","REGULAR"],"sources":["../../../../src/components/SubnavigationButton/SubnavigationButton.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Icon16Dropdown } from '@vkontakte/icons';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { SizeType } from '../../lib/adaptivity';\nimport { getTitleFromChildren } from '../../lib/utils';\nimport { HasChildren, HasComponent } from '../../types';\nimport { Tappable, TappableProps } from '../Tappable/Tappable';\nimport { Caption } from '../Typography/Caption/Caption';\nimport { Subhead } from '../Typography/Subhead/Subhead';\nimport styles from './SubnavigationButton.module.css';\n\nconst sizeYClassNames = {\n none: styles['SubnavigationButton--sizeY-none'],\n [SizeType.COMPACT]: styles['SubnavigationButton--sizeY-compact'],\n};\n\nexport interface SubnavigationButtonProps extends Omit<TappableProps, 'size'> {\n mode?: 'primary' | 'outline' | 'tertiary';\n size?: 's' | 'm' | 'l';\n selected?: boolean;\n /**\n * Размер шрифта. Этим свойством рекомендуется пользоваться, чтобы отрегулировать размер шрифта у кнопок в `<SubnavigationBar mode=\"fixed\" />`\n */\n textLevel?: '1' | '2' | '3';\n /**\n * Рекомендуется использовать только иконки с размером 24\n */\n before?: React.ReactNode;\n /**\n * Рекомендуется использовать только `<Counter size=\"s\" />` или `<Badge />`\n */\n after?: React.ReactNode;\n expandable?: boolean;\n}\n\ntype SubnavigationButtonTypographyProps = Pick<\n SubnavigationButtonProps,\n 'textLevel' | 'className'\n> &\n HasComponent &\n HasChildren;\n\nconst SubnavigationButtonTypography = ({\n textLevel,\n ...restProps\n}: SubnavigationButtonTypographyProps) => {\n if (textLevel === '1') {\n return <Subhead {...restProps} />;\n }\n\n return <Caption level={textLevel === '2' ? '1' : '2'} {...restProps} />;\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/SubnavigationButton\n */\nexport const SubnavigationButton = ({\n mode = 'primary',\n size = 'm',\n selected,\n textLevel = '1',\n before,\n after,\n expandable,\n children,\n className,\n ...restProps\n}: SubnavigationButtonProps) => {\n const { sizeY = 'none' } = useAdaptivity();\n\n return (\n <Tappable\n {...restProps}\n hasActive={false}\n focusVisibleMode=\"outside\"\n className={classNames(\n styles['SubnavigationButton'],\n styles[`SubnavigationButton--size-${size}`],\n styles[`SubnavigationButton--mode-${mode}`],\n selected && styles['SubnavigationButton--selected'],\n sizeY !== SizeType.REGULAR && sizeYClassNames[sizeY],\n className,\n )}\n aria-label={getTitleFromChildren(children)}\n >\n <span className={styles['SubnavigationButton__in']}>\n {before && <span className={styles['SubnavigationButton__before']}>{before}</span>}\n <SubnavigationButtonTypography\n textLevel={textLevel}\n className={styles['SubnavigationButton__label']}\n Component=\"span\"\n >\n {children}\n </SubnavigationButtonTypography>\n {after && <span className={styles['SubnavigationButton__after']}>{after}</span>}\n {expandable && <Icon16Dropdown className={styles['SubnavigationButton__expandableIcon']} />}\n </span>\n </Tappable>\n );\n};\n"],"mappings":";;;;;AAAA,OAAO,KAAKA,KAAK,MAAM,OAAO;AAC9B,SAASC,cAAc,QAAQ,kBAAkB;AACjD,SAASC,UAAU,QAAQ,iBAAiB;AAC5C,SAASC,aAAa,QAAQ,2BAA2B;AACzD,SAASC,QAAQ,QAAQ,sBAAsB;AAC/C,SAASC,oBAAoB,QAAQ,iBAAiB;AAEtD,SAASC,QAAQ,QAAuB,sBAAsB;AAC9D,SAASC,OAAO,QAAQ,+BAA+B;AACvD,SAASC,OAAO,QAAQ,+BAA+B;AAAC;AAGxD,IAAMC,eAAe;EACnBC,IAAI;AAA2C,GAC9CN,QAAQ,CAACO,OAAO,2CAClB;AA4BD,IAAMC,6BAA6B,GAAG,SAAhCA,6BAA6B,OAGO;EAAA,IAFxCC,SAAS,QAATA,SAAS;IACNC,SAAS;EAEZ,IAAID,SAAS,KAAK,GAAG,EAAE;IACrB,oBAAO,oBAAC,OAAO,EAAKC,SAAS,CAAI;EACnC;EAEA,oBAAO,oBAAC,OAAO;IAAC,KAAK,EAAED,SAAS,KAAK,GAAG,GAAG,GAAG,GAAG;EAAI,GAAKC,SAAS,EAAI;AACzE,CAAC;;AAED;AACA;AACA;AACA,OAAO,IAAMC,mBAAmB,GAAG,SAAtBA,mBAAmB,QAWA;EAAA,uBAV9BC,IAAI;IAAJA,IAAI,2BAAG,SAAS;IAAA,mBAChBC,IAAI;IAAJA,IAAI,2BAAG,GAAG;IACVC,QAAQ,SAARA,QAAQ;IAAA,wBACRL,SAAS;IAATA,SAAS,gCAAG,GAAG;IACfM,MAAM,SAANA,MAAM;IACNC,KAAK,SAALA,KAAK;IACLC,UAAU,SAAVA,UAAU;IACVC,QAAQ,SAARA,QAAQ;IACRC,SAAS,SAATA,SAAS;IACNT,SAAS;EAEZ,qBAA2BX,aAAa,EAAE;IAAA,sCAAlCqB,KAAK;IAALA,KAAK,qCAAG,MAAM;EAEtB,oBACE,oBAAC,QAAQ,eACHV,SAAS;IACb,SAAS,EAAE,KAAM;IACjB,gBAAgB,EAAC,SAAS;IAC1B,SAAS,EAAEZ,UAAU,4BAEnBuB,MAAM,qCAA8BR,IAAI,EAAG,EAC3CQ,MAAM,qCAA8BT,IAAI,EAAG,EAC3CE,QAAQ,uCAA2C,EACnDM,KAAK,KAAKpB,QAAQ,CAACsB,OAAO,IAAIjB,eAAe,CAACe,KAAK,CAAC,EACpDD,SAAS,CACT;IACF,cAAYlB,oBAAoB,CAACiB,QAAQ;EAAE,iBAE3C;IAAM,SAAS;EAAoC,GAChDH,MAAM,iBAAI;IAAM,SAAS;EAAwC,GAAEA,MAAM,CAAQ,eAClF,oBAAC,6BAA6B;IAC5B,SAAS,EAAEN,SAAU;IACrB,SAAS,kCAAuC;IAChD,SAAS,EAAC;EAAM,GAEfS,QAAQ,CACqB,EAC/BF,KAAK,iBAAI;IAAM,SAAS;EAAuC,GAAEA,KAAK,CAAQ,EAC9EC,UAAU,iBAAI,oBAAC,cAAc;IAAC,SAAS;EAAgD,EAAG,CACtF,CACE;AAEf,CAAC;AAAC;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;AAAA"}
@@ -1 +1 @@
1
- .vkuiSubnavigationButton{border-radius:8px;border-radius:var(--vkui--size_border_radius--regular);display:inline-block;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.vkuiSubnavigationButton__in{align-items:center;display:flex;justify-content:center}.vkuiSubnavigationButton--size-s .vkuiSubnavigationButton__in{height:30px;height:var(--vkui--size_button_small_height--regular)}.vkuiSubnavigationButton--size-m .vkuiSubnavigationButton__in{height:36px;height:var(--vkui--size_button_medium_height--regular)}.vkuiSubnavigationButton--size-l .vkuiSubnavigationButton__in{height:44px;height:var(--vkui--size_button_large_height--regular)}.vkuiSubnavigationButton--sizeY-compact.vkuiSubnavigationButton--size-s .vkuiSubnavigationButton__in{height:28px;height:var(--vkui--size_button_small_height--compact)}.vkuiSubnavigationButton--sizeY-compact.vkuiSubnavigationButton--size-m .vkuiSubnavigationButton__in{height:32px;height:var(--vkui--size_button_medium_height--compact)}.vkuiSubnavigationButton--sizeY-compact.vkuiSubnavigationButton--size-l .vkuiSubnavigationButton__in{height:36px;height:var(--vkui--size_button_large_height--compact)}@media (pointer:fine) and (min-width:768px),not (min-height:415px){.vkuiSubnavigationButton--sizeY-none.vkuiSubnavigationButton--size-s .vkuiSubnavigationButton__in{height:28px;height:var(--vkui--size_button_small_height--compact)}.vkuiSubnavigationButton--sizeY-none.vkuiSubnavigationButton--size-m .vkuiSubnavigationButton__in{height:32px;height:var(--vkui--size_button_medium_height--compact)}.vkuiSubnavigationButton--sizeY-none.vkuiSubnavigationButton--size-l .vkuiSubnavigationButton__in{height:36px;height:var(--vkui--size_button_large_height--compact)}}.vkuiSubnavigationButton__before{color:#2688eb;color:var(--vkui--color_icon_accent);margin-right:8px}.vkuiSubnavigationButton__label{flex-grow:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vkuiSubnavigationButton__after{margin-left:8px}.vkuiSubnavigationButton__expandableIcon{color:#99a2ad;color:var(--vkui--color_icon_secondary);margin-left:8px;margin-top:1px}.vkuiSubnavigationButton__before:first-child,.vkuiSubnavigationButton__label:first-child{padding-left:12px;padding-left:var(--vkui--size_button_base_small_padding_horizontal_icon--regular)}.vkuiSubnavigationButton__after:last-child,.vkuiSubnavigationButton__expandableIcon,.vkuiSubnavigationButton__label:last-child{padding-right:12px;padding-right:var(--vkui--size_button_base_small_padding_horizontal_icon--regular)}.vkuiSubnavigationButton--mode-primary{background-color:#fff;background-color:var(--vkui--color_background_modal);box-shadow:0 0 2px rgba(0,0,0,.08),0 4px 16px rgba(0,0,0,.08);box-shadow:var(--vkui--elevation3)}.vkuiSubnavigationButton--mode-outline{box-shadow:inset 0 0 0 1px rgba(0,0,0,.12);box-shadow:inset 0 0 0 var(--vkui_internal--thin_border) var(--vkui--color_field_border_alpha)}.vkuiSubnavigationButton--selected{background-color:#2688eb;background-color:var(--vkui--color_background_accent_themed);border:none;box-shadow:none;color:#fff;color:var(--vkui--color_text_contrast_themed)}.vkuiSubnavigationButton--selected.vkuiSubnavigationButton--mode-tertiary{background-color:rgba(0,16,61,.08);background-color:var(--vkui--color_transparent--active);color:#000;color:var(--vkui--color_text_primary)}.vkuiSubnavigationButton--selected:not(.vkuiSubnavigationButton--mode-tertiary) .vkuiSubnavigationButton__before,.vkuiSubnavigationButton--selected:not(.vkuiSubnavigationButton--mode-tertiary) .vkuiSubnavigationButton__expandableIcon{color:inherit}.vkuiSubnavigationBar .vkuiSubnavigationButton+.vkuiSubnavigationButton{margin-left:8px;margin-left:var(--vkui--size_subnavigation_bar_gap--regular)}.vkuiSubnavigationBar--mode-fixed .vkuiSubnavigationButton{flex:1;min-width:0}
1
+ .vkuiSubnavigationButton{border-radius:8px;border-radius:var(--vkui--size_border_radius--regular);display:inline-block;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.vkuiSubnavigationButton__in{align-items:center;display:flex;justify-content:center}.vkuiSubnavigationButton--size-s .vkuiSubnavigationButton__in{height:30px;height:var(--vkui--size_button_small_height--regular)}.vkuiSubnavigationButton--size-m .vkuiSubnavigationButton__in{height:36px;height:var(--vkui--size_button_medium_height--regular)}.vkuiSubnavigationButton--size-l .vkuiSubnavigationButton__in{height:44px;height:var(--vkui--size_button_large_height--regular)}.vkuiSubnavigationButton--sizeY-compact.vkuiSubnavigationButton--size-s .vkuiSubnavigationButton__in{height:28px;height:var(--vkui--size_button_small_height--compact)}.vkuiSubnavigationButton--sizeY-compact.vkuiSubnavigationButton--size-m .vkuiSubnavigationButton__in{height:32px;height:var(--vkui--size_button_medium_height--compact)}.vkuiSubnavigationButton--sizeY-compact.vkuiSubnavigationButton--size-l .vkuiSubnavigationButton__in{height:36px;height:var(--vkui--size_button_large_height--compact)}@media (max-height:414.9px),(pointer:fine) and (min-width:768px){.vkuiSubnavigationButton--sizeY-none.vkuiSubnavigationButton--size-s .vkuiSubnavigationButton__in{height:28px;height:var(--vkui--size_button_small_height--compact)}.vkuiSubnavigationButton--sizeY-none.vkuiSubnavigationButton--size-m .vkuiSubnavigationButton__in{height:32px;height:var(--vkui--size_button_medium_height--compact)}.vkuiSubnavigationButton--sizeY-none.vkuiSubnavigationButton--size-l .vkuiSubnavigationButton__in{height:36px;height:var(--vkui--size_button_large_height--compact)}}.vkuiSubnavigationButton__before{color:#2688eb;color:var(--vkui--color_icon_accent);margin-right:8px}.vkuiSubnavigationButton__label{flex-grow:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vkuiSubnavigationButton__after{margin-left:8px}.vkuiSubnavigationButton__expandableIcon{color:#99a2ad;color:var(--vkui--color_icon_secondary);margin-left:8px;margin-top:1px}.vkuiSubnavigationButton__before:first-child,.vkuiSubnavigationButton__label:first-child{padding-left:12px;padding-left:var(--vkui--size_button_base_small_padding_horizontal_icon--regular)}.vkuiSubnavigationButton__after:last-child,.vkuiSubnavigationButton__expandableIcon,.vkuiSubnavigationButton__label:last-child{padding-right:12px;padding-right:var(--vkui--size_button_base_small_padding_horizontal_icon--regular)}.vkuiSubnavigationButton--mode-primary{background-color:#fff;background-color:var(--vkui--color_background_modal);box-shadow:0 0 2px rgba(0,0,0,.08),0 4px 16px rgba(0,0,0,.08);box-shadow:var(--vkui--elevation3)}.vkuiSubnavigationButton--mode-outline{box-shadow:inset 0 0 0 1px rgba(0,0,0,.12);box-shadow:inset 0 0 0 var(--vkui_internal--thin_border) var(--vkui--color_field_border_alpha)}.vkuiSubnavigationButton--selected{background-color:#2688eb;background-color:var(--vkui--color_background_accent_themed);border:none;box-shadow:none;color:#fff;color:var(--vkui--color_text_contrast_themed)}.vkuiSubnavigationButton--selected.vkuiSubnavigationButton--mode-tertiary{background-color:rgba(0,16,61,.08);background-color:var(--vkui--color_transparent--active);color:#000;color:var(--vkui--color_text_primary)}.vkuiSubnavigationButton--selected:not(.vkuiSubnavigationButton--mode-tertiary) .vkuiSubnavigationButton__before,.vkuiSubnavigationButton--selected:not(.vkuiSubnavigationButton--mode-tertiary) .vkuiSubnavigationButton__expandableIcon{color:inherit}.vkuiSubnavigationBar .vkuiSubnavigationButton+.vkuiSubnavigationButton{margin-left:8px;margin-left:var(--vkui--size_subnavigation_bar_gap--regular)}.vkuiSubnavigationBar--mode-fixed .vkuiSubnavigationButton{flex:1;min-width:0}
@@ -1,17 +1,21 @@
1
1
  import _extends from "@babel/runtime/helpers/extends";
2
2
  import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
3
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
4
  var _excluded = ["style", "className", "getRootRef"];
4
5
  import * as React from 'react';
5
- import { getPlatformClassName } from '../../helpers/getPlatformClassName';
6
6
  import { classNames } from '@vkontakte/vkjs';
7
- import { callMultiple } from '../../lib/callMultiple';
8
- import { usePlatform } from '../../hooks/usePlatform';
7
+ import { getPlatformClassName } from '../../helpers/getPlatformClassName';
9
8
  import { useAdaptivity } from '../../hooks/useAdaptivity';
10
- import { VisuallyHiddenInput } from '../VisuallyHiddenInput/VisuallyHiddenInput';
11
9
  import { useFocusVisible } from '../../hooks/useFocusVisible';
10
+ import { usePlatform } from '../../hooks/usePlatform';
11
+ import { SizeType } from '../../lib/adaptivity';
12
+ import { callMultiple } from '../../lib/callMultiple';
12
13
  import { FocusVisible } from '../FocusVisible/FocusVisible';
13
- import { getSizeYClassName } from '../../helpers/getSizeYClassName';
14
+ import { VisuallyHiddenInput } from '../VisuallyHiddenInput/VisuallyHiddenInput';
14
15
  import "./Switch.module.css";
16
+ var sizeYClassNames = _defineProperty({
17
+ none: "vkuiSwitch--sizeY-none"
18
+ }, SizeType.COMPACT, "vkuiSwitch--sizeY-compact");
15
19
  /**
16
20
  * @see https://vkcom.github.io/VKUI/#/Switch
17
21
  */
@@ -22,13 +26,14 @@ export var Switch = function Switch(_ref) {
22
26
  restProps = _objectWithoutProperties(_ref, _excluded);
23
27
  var platform = usePlatform();
24
28
  var _useAdaptivity = useAdaptivity(),
25
- sizeY = _useAdaptivity.sizeY;
29
+ _useAdaptivity$sizeY = _useAdaptivity.sizeY,
30
+ sizeY = _useAdaptivity$sizeY === void 0 ? 'none' : _useAdaptivity$sizeY;
26
31
  var _useFocusVisible = useFocusVisible(),
27
32
  focusVisible = _useFocusVisible.focusVisible,
28
33
  onBlur = _useFocusVisible.onBlur,
29
34
  onFocus = _useFocusVisible.onFocus;
30
35
  return /*#__PURE__*/React.createElement("label", {
31
- className: classNames("vkuiSwitch", getPlatformClassName("vkuiSwitch", platform), getSizeYClassName("vkuiSwitch", sizeY), restProps.disabled && "vkuiSwitch--disabled", focusVisible && "vkuiSwitch--focus-visible", className),
36
+ className: classNames("vkuiSwitch", getPlatformClassName("vkuiSwitch", platform), sizeY !== SizeType.REGULAR && sizeYClassNames[sizeY], restProps.disabled && "vkuiSwitch--disabled", focusVisible && "vkuiSwitch--focus-visible", className),
32
37
  style: style,
33
38
  ref: getRootRef
34
39
  }, /*#__PURE__*/React.createElement(VisuallyHiddenInput, _extends({}, restProps, {
@@ -1 +1 @@
1
- {"version":3,"file":"Switch.js","names":["React","getPlatformClassName","classNames","callMultiple","usePlatform","useAdaptivity","VisuallyHiddenInput","useFocusVisible","FocusVisible","getSizeYClassName","Switch","style","className","getRootRef","restProps","platform","sizeY","focusVisible","onBlur","onFocus","disabled"],"sources":["../../../../src/components/Switch/Switch.tsx"],"sourcesContent":["import * as React from 'react';\nimport { getPlatformClassName } from '../../helpers/getPlatformClassName';\nimport { classNames } from '@vkontakte/vkjs';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { HasRootRef } from '../../types';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport {\n VisuallyHiddenInput,\n VisuallyHiddenInputProps,\n} from '../VisuallyHiddenInput/VisuallyHiddenInput';\nimport { useFocusVisible } from '../../hooks/useFocusVisible';\nimport { FocusVisible } from '../FocusVisible/FocusVisible';\nimport { getSizeYClassName } from '../../helpers/getSizeYClassName';\nimport styles from './Switch.module.css';\n\nexport interface SwitchProps extends VisuallyHiddenInputProps, HasRootRef<HTMLLabelElement> {}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/Switch\n */\nexport const Switch = ({ style, className, getRootRef, ...restProps }: SwitchProps) => {\n const platform = usePlatform();\n const { sizeY } = useAdaptivity();\n const { focusVisible, onBlur, onFocus } = useFocusVisible();\n\n return (\n <label\n className={classNames(\n styles['Switch'],\n getPlatformClassName(styles['Switch'], platform),\n getSizeYClassName(styles['Switch'], sizeY),\n restProps.disabled && styles['Switch--disabled'],\n focusVisible && styles['Switch--focus-visible'],\n className,\n )}\n style={style}\n ref={getRootRef}\n >\n <VisuallyHiddenInput\n {...restProps}\n type=\"checkbox\"\n className={styles['Switch__self']}\n onBlur={callMultiple(onBlur, restProps.onBlur)}\n onFocus={callMultiple(onFocus, restProps.onFocus)}\n />\n <span aria-hidden className={styles['Switch__pseudo']} />\n <FocusVisible mode=\"outside\" />\n </label>\n );\n};\n"],"mappings":";;;AAAA,OAAO,KAAKA,KAAK,MAAM,OAAO;AAC9B,SAASC,oBAAoB,QAAQ,oCAAoC;AACzE,SAASC,UAAU,QAAQ,iBAAiB;AAC5C,SAASC,YAAY,QAAQ,wBAAwB;AACrD,SAASC,WAAW,QAAQ,yBAAyB;AAErD,SAASC,aAAa,QAAQ,2BAA2B;AACzD,SACEC,mBAAmB,QAEd,4CAA4C;AACnD,SAASC,eAAe,QAAQ,6BAA6B;AAC7D,SAASC,YAAY,QAAQ,8BAA8B;AAC3D,SAASC,iBAAiB,QAAQ,iCAAiC;AAAC;AAKpE;AACA;AACA;AACA,OAAO,IAAMC,MAAM,GAAG,SAATA,MAAM,OAAoE;EAAA,IAA9DC,KAAK,QAALA,KAAK;IAAEC,SAAS,QAATA,SAAS;IAAEC,UAAU,QAAVA,UAAU;IAAKC,SAAS;EACjE,IAAMC,QAAQ,GAAGX,WAAW,EAAE;EAC9B,qBAAkBC,aAAa,EAAE;IAAzBW,KAAK,kBAALA,KAAK;EACb,uBAA0CT,eAAe,EAAE;IAAnDU,YAAY,oBAAZA,YAAY;IAAEC,MAAM,oBAANA,MAAM;IAAEC,OAAO,oBAAPA,OAAO;EAErC,oBACE;IACE,SAAS,EAAEjB,UAAU,eAEnBD,oBAAoB,eAAmBc,QAAQ,CAAC,EAChDN,iBAAiB,eAAmBO,KAAK,CAAC,EAC1CF,SAAS,CAACM,QAAQ,0BAA8B,EAChDH,YAAY,+BAAmC,EAC/CL,SAAS,CACT;IACF,KAAK,EAAED,KAAM;IACb,GAAG,EAAEE;EAAW,gBAEhB,oBAAC,mBAAmB,eACdC,SAAS;IACb,IAAI,EAAC,UAAU;IACf,SAAS,oBAAyB;IAClC,MAAM,EAAEX,YAAY,CAACe,MAAM,EAAEJ,SAAS,CAACI,MAAM,CAAE;IAC/C,OAAO,EAAEf,YAAY,CAACgB,OAAO,EAAEL,SAAS,CAACK,OAAO;EAAE,GAClD,eACF;IAAM,mBAAW;IAAC,SAAS;EAA2B,EAAG,eACzD,oBAAC,YAAY;IAAC,IAAI,EAAC;EAAS,EAAG,CACzB;AAEZ,CAAC"}
1
+ {"version":3,"file":"Switch.js","names":["React","classNames","getPlatformClassName","useAdaptivity","useFocusVisible","usePlatform","SizeType","callMultiple","FocusVisible","VisuallyHiddenInput","sizeYClassNames","none","COMPACT","Switch","style","className","getRootRef","restProps","platform","sizeY","focusVisible","onBlur","onFocus","REGULAR","disabled"],"sources":["../../../../src/components/Switch/Switch.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { getPlatformClassName } from '../../helpers/getPlatformClassName';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useFocusVisible } from '../../hooks/useFocusVisible';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { SizeType } from '../../lib/adaptivity';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { HasRootRef } from '../../types';\nimport { FocusVisible } from '../FocusVisible/FocusVisible';\nimport {\n VisuallyHiddenInput,\n VisuallyHiddenInputProps,\n} from '../VisuallyHiddenInput/VisuallyHiddenInput';\nimport styles from './Switch.module.css';\n\nconst sizeYClassNames = {\n none: styles['Switch--sizeY-none'],\n [SizeType.COMPACT]: styles['Switch--sizeY-compact'],\n};\n\nexport interface SwitchProps extends VisuallyHiddenInputProps, HasRootRef<HTMLLabelElement> {}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/Switch\n */\nexport const Switch = ({ style, className, getRootRef, ...restProps }: SwitchProps) => {\n const platform = usePlatform();\n const { sizeY = 'none' } = useAdaptivity();\n const { focusVisible, onBlur, onFocus } = useFocusVisible();\n\n return (\n <label\n className={classNames(\n styles['Switch'],\n getPlatformClassName(styles['Switch'], platform),\n sizeY !== SizeType.REGULAR && sizeYClassNames[sizeY],\n restProps.disabled && styles['Switch--disabled'],\n focusVisible && styles['Switch--focus-visible'],\n className,\n )}\n style={style}\n ref={getRootRef}\n >\n <VisuallyHiddenInput\n {...restProps}\n type=\"checkbox\"\n className={styles['Switch__self']}\n onBlur={callMultiple(onBlur, restProps.onBlur)}\n onFocus={callMultiple(onFocus, restProps.onFocus)}\n />\n <span aria-hidden className={styles['Switch__pseudo']} />\n <FocusVisible mode=\"outside\" />\n </label>\n );\n};\n"],"mappings":";;;;AAAA,OAAO,KAAKA,KAAK,MAAM,OAAO;AAC9B,SAASC,UAAU,QAAQ,iBAAiB;AAC5C,SAASC,oBAAoB,QAAQ,oCAAoC;AACzE,SAASC,aAAa,QAAQ,2BAA2B;AACzD,SAASC,eAAe,QAAQ,6BAA6B;AAC7D,SAASC,WAAW,QAAQ,yBAAyB;AACrD,SAASC,QAAQ,QAAQ,sBAAsB;AAC/C,SAASC,YAAY,QAAQ,wBAAwB;AAErD,SAASC,YAAY,QAAQ,8BAA8B;AAC3D,SACEC,mBAAmB,QAEd,4CAA4C;AAAC;AAGpD,IAAMC,eAAe;EACnBC,IAAI;AAA8B,GACjCL,QAAQ,CAACM,OAAO,8BAClB;AAID;AACA;AACA;AACA,OAAO,IAAMC,MAAM,GAAG,SAATA,MAAM,OAAoE;EAAA,IAA9DC,KAAK,QAALA,KAAK;IAAEC,SAAS,QAATA,SAAS;IAAEC,UAAU,QAAVA,UAAU;IAAKC,SAAS;EACjE,IAAMC,QAAQ,GAAGb,WAAW,EAAE;EAC9B,qBAA2BF,aAAa,EAAE;IAAA,sCAAlCgB,KAAK;IAALA,KAAK,qCAAG,MAAM;EACtB,uBAA0Cf,eAAe,EAAE;IAAnDgB,YAAY,oBAAZA,YAAY;IAAEC,MAAM,oBAANA,MAAM;IAAEC,OAAO,oBAAPA,OAAO;EAErC,oBACE;IACE,SAAS,EAAErB,UAAU,eAEnBC,oBAAoB,eAAmBgB,QAAQ,CAAC,EAChDC,KAAK,KAAKb,QAAQ,CAACiB,OAAO,IAAIb,eAAe,CAACS,KAAK,CAAC,EACpDF,SAAS,CAACO,QAAQ,0BAA8B,EAChDJ,YAAY,+BAAmC,EAC/CL,SAAS,CACT;IACF,KAAK,EAAED,KAAM;IACb,GAAG,EAAEE;EAAW,gBAEhB,oBAAC,mBAAmB,eACdC,SAAS;IACb,IAAI,EAAC,UAAU;IACf,SAAS,oBAAyB;IAClC,MAAM,EAAEV,YAAY,CAACc,MAAM,EAAEJ,SAAS,CAACI,MAAM,CAAE;IAC/C,OAAO,EAAEd,YAAY,CAACe,OAAO,EAAEL,SAAS,CAACK,OAAO;EAAE,GAClD,eACF;IAAM,mBAAW;IAAC,SAAS;EAA2B,EAAG,eACzD,oBAAC,YAAY;IAAC,IAAI,EAAC;EAAS,EAAG,CACzB;AAEZ,CAAC"}
@@ -1 +1 @@
1
- .vkuiSwitch{cursor:pointer;display:block;padding:calc((20px - 14px) / 2);padding:calc((var(--vkui--size_switch_pin--regular) - var(--vkui--size_switch_height--regular)) / 2);position:relative}.vkuiSwitch--sizeY-compact{padding:calc((18px - 12px) / 2);padding:calc((var(--vkui--size_switch_pin--compact) - var(--vkui--size_switch_height--compact)) / 2)}@media (pointer:fine) and (min-width:768px),not (min-height:415px){.vkuiSwitch--sizeY-none{padding:calc((18px - 12px) / 2);padding:calc((var(--vkui--size_switch_pin--compact) - var(--vkui--size_switch_height--compact)) / 2)}}.vkuiSwitch--disabled{cursor:default}.vkuiSwitch__pseudo{-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-tap-highlight-color:transparent;box-sizing:border-box;display:block;position:relative}.vkuiSwitch__pseudo:before{background:#f2f3f5;background:var(--vkui--color_icon_contrast_secondary);border-radius:50%;box-shadow:0 0 2px 0 rgba(0,0,0,.12),0 2px 2px 0 rgba(0,0,0,.24);box-sizing:border-box;content:"";height:20px;height:var(--vkui--size_switch_pin--regular);left:calc((14px - 20px) / 2);left:calc((var(--vkui--size_switch_height--regular) - var(--vkui--size_switch_pin--regular)) / 2);position:absolute;top:calc((14px - 20px) / 2);top:calc((var(--vkui--size_switch_height--regular) - var(--vkui--size_switch_pin--regular)) / 2);width:20px;width:var(--vkui--size_switch_pin--regular)}.vkuiSwitch--sizeY-compact .vkuiSwitch__pseudo:before{height:18px;height:var(--vkui--size_switch_pin--compact);left:calc((12px - 18px) / 2);left:calc((var(--vkui--size_switch_height--compact) - var(--vkui--size_switch_pin--compact)) / 2);top:calc((12px - 18px) / 2);top:calc((var(--vkui--size_switch_height--compact) - var(--vkui--size_switch_pin--compact)) / 2);width:18px;width:var(--vkui--size_switch_pin--compact)}@media (pointer:fine) and (min-width:768px),not (min-height:415px){.vkuiSwitch--sizeY-none .vkuiSwitch__pseudo:before{height:18px;height:var(--vkui--size_switch_pin--compact);left:calc((12px - 18px) / 2);left:calc((var(--vkui--size_switch_height--compact) - var(--vkui--size_switch_pin--compact)) / 2);top:calc((12px - 18px) / 2);top:calc((var(--vkui--size_switch_height--compact) - var(--vkui--size_switch_pin--compact)) / 2);width:18px;width:var(--vkui--size_switch_pin--compact)}}.vkuiSwitch__self:checked+.vkuiSwitch__pseudo:before{background:#2688eb;background:var(--vkui--color_icon_accent);transform:translateX(calc(34px - 14px));transform:translateX(calc(var(--vkui--size_switch_width--regular) - var(--vkui--size_switch_height--regular)))}.vkuiSwitch__pseudo:after{background:rgba(0,0,0,.24);background:var(--vkui--color_icon_tertiary_alpha);border-radius:calc(34px / 2);border-radius:calc(var(--vkui--size_switch_width--regular) / 2);content:"";display:block;height:14px;height:var(--vkui--size_switch_height--regular);width:34px;width:var(--vkui--size_switch_width--regular)}.vkuiSwitch--sizeY-compact .vkuiSwitch__pseudo:after{border-radius:calc(32px / 2);border-radius:calc(var(--vkui--size_switch_width--compact) / 2);height:12px;height:var(--vkui--size_switch_height--compact);width:32px;width:var(--vkui--size_switch_width--compact)}@media (pointer:fine) and (min-width:768px),not (min-height:415px){.vkuiSwitch--sizeY-none .vkuiSwitch__pseudo:after{border-radius:calc(32px / 2);border-radius:calc(var(--vkui--size_switch_width--compact) / 2);height:12px;height:var(--vkui--size_switch_height--compact);width:32px;width:var(--vkui--size_switch_width--compact)}}.vkuiSwitch__self:checked+.vkuiSwitch__pseudo:after{background:#2688eb;background:var(--vkui--color_icon_accent);opacity:.48}.vkuiSwitch--sizeY-compact .vkuiSwitch__self:checked+.vkuiSwitch__pseudo:before{transform:translateX(calc(32px - 12px));transform:translateX(calc(var(--vkui--size_switch_width--compact) - var(--vkui--size_switch_height--compact)))}@media (pointer:fine) and (min-width:768px),not (min-height:415px){.vkuiSwitch--sizeY-none .vkuiSwitch__self:checked+.vkuiSwitch__pseudo:before{transform:translateX(calc(32px - 12px));transform:translateX(calc(var(--vkui--size_switch_width--compact) - var(--vkui--size_switch_height--compact)))}}.vkuiSwitch__self[disabled]+.vkuiSwitch__pseudo{opacity:.4;opacity:var(--vkui--opacity_disable)}.vkuiSwitch--ios .vkuiSwitch__pseudo:before{box-shadow:0 3px 8px rgba(0,0,0,.15),0 3px 1px rgba(0,0,0,.06),inset 0 0 0 .5px rgba(0,0,0,.04)}.vkuiSwitch--ios .vkuiSwitch__pseudo:before,.vkuiSwitch--ios .vkuiSwitch__self:checked+.vkuiSwitch__pseudo:before{background:#fff;background:var(--vkui_internal--white)}.vkuiSwitch--ios .vkuiSwitch__pseudo:after{background:#e1e3e6;background:var(--vkui--color_track_background)}.vkuiSwitch--ios .vkuiSwitch__self:checked+.vkuiSwitch__pseudo:after{opacity:1}@media (prefers-reduced-motion:no-preference){.vkuiSwitch__pseudo:after{transition:background-color .1s ease}.vkuiSwitch__pseudo:before{transition:transform .1s ease}.vkuiSwitch--ios .vkuiSwitch__pseudo:after{transition:background-color .2s ease}.vkuiSwitch--ios .vkuiSwitch__pseudo:before{transition:transform .2s cubic-bezier(.36,-.24,.26,1.32)}}.vkuiSimpleCell__after>.vkuiSwitch{margin-left:12px}.vkuiSimpleCell>.vkuiSwitch:first-child{margin-right:12px}
1
+ .vkuiSwitch{cursor:pointer;display:block;padding:calc((20px - 14px) / 2);padding:calc((var(--vkui--size_switch_pin--regular) - var(--vkui--size_switch_height--regular)) / 2);position:relative}.vkuiSwitch--sizeY-compact{padding:calc((18px - 12px) / 2);padding:calc((var(--vkui--size_switch_pin--compact) - var(--vkui--size_switch_height--compact)) / 2)}@media (max-height:414.9px),(pointer:fine) and (min-width:768px){.vkuiSwitch--sizeY-none{padding:calc((18px - 12px) / 2);padding:calc((var(--vkui--size_switch_pin--compact) - var(--vkui--size_switch_height--compact)) / 2)}}.vkuiSwitch--disabled{cursor:default}.vkuiSwitch__pseudo{-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-tap-highlight-color:transparent;box-sizing:border-box;display:block;position:relative}.vkuiSwitch__pseudo:before{background:#f2f3f5;background:var(--vkui--color_icon_contrast_secondary);border-radius:50%;box-shadow:0 0 2px 0 rgba(0,0,0,.12),0 2px 2px 0 rgba(0,0,0,.24);box-sizing:border-box;content:"";height:20px;height:var(--vkui--size_switch_pin--regular);left:calc((14px - 20px) / 2);left:calc((var(--vkui--size_switch_height--regular) - var(--vkui--size_switch_pin--regular)) / 2);position:absolute;top:calc((14px - 20px) / 2);top:calc((var(--vkui--size_switch_height--regular) - var(--vkui--size_switch_pin--regular)) / 2);width:20px;width:var(--vkui--size_switch_pin--regular)}.vkuiSwitch--sizeY-compact .vkuiSwitch__pseudo:before{height:18px;height:var(--vkui--size_switch_pin--compact);left:calc((12px - 18px) / 2);left:calc((var(--vkui--size_switch_height--compact) - var(--vkui--size_switch_pin--compact)) / 2);top:calc((12px - 18px) / 2);top:calc((var(--vkui--size_switch_height--compact) - var(--vkui--size_switch_pin--compact)) / 2);width:18px;width:var(--vkui--size_switch_pin--compact)}@media (max-height:414.9px),(pointer:fine) and (min-width:768px){.vkuiSwitch--sizeY-none .vkuiSwitch__pseudo:before{height:18px;height:var(--vkui--size_switch_pin--compact);left:calc((12px - 18px) / 2);left:calc((var(--vkui--size_switch_height--compact) - var(--vkui--size_switch_pin--compact)) / 2);top:calc((12px - 18px) / 2);top:calc((var(--vkui--size_switch_height--compact) - var(--vkui--size_switch_pin--compact)) / 2);width:18px;width:var(--vkui--size_switch_pin--compact)}}.vkuiSwitch__self:checked+.vkuiSwitch__pseudo:before{background:#2688eb;background:var(--vkui--color_icon_accent);transform:translateX(calc(34px - 14px));transform:translateX(calc(var(--vkui--size_switch_width--regular) - var(--vkui--size_switch_height--regular)))}.vkuiSwitch__pseudo:after{background:rgba(0,0,0,.24);background:var(--vkui--color_icon_tertiary_alpha);border-radius:calc(34px / 2);border-radius:calc(var(--vkui--size_switch_width--regular) / 2);content:"";display:block;height:14px;height:var(--vkui--size_switch_height--regular);width:34px;width:var(--vkui--size_switch_width--regular)}.vkuiSwitch--sizeY-compact .vkuiSwitch__pseudo:after{border-radius:calc(32px / 2);border-radius:calc(var(--vkui--size_switch_width--compact) / 2);height:12px;height:var(--vkui--size_switch_height--compact);width:32px;width:var(--vkui--size_switch_width--compact)}@media (max-height:414.9px),(pointer:fine) and (min-width:768px){.vkuiSwitch--sizeY-none .vkuiSwitch__pseudo:after{border-radius:calc(32px / 2);border-radius:calc(var(--vkui--size_switch_width--compact) / 2);height:12px;height:var(--vkui--size_switch_height--compact);width:32px;width:var(--vkui--size_switch_width--compact)}}.vkuiSwitch__self:checked+.vkuiSwitch__pseudo:after{background:#2688eb;background:var(--vkui--color_icon_accent);opacity:.48}.vkuiSwitch--sizeY-compact .vkuiSwitch__self:checked+.vkuiSwitch__pseudo:before{transform:translateX(calc(32px - 12px));transform:translateX(calc(var(--vkui--size_switch_width--compact) - var(--vkui--size_switch_height--compact)))}@media (max-height:414.9px),(pointer:fine) and (min-width:768px){.vkuiSwitch--sizeY-none .vkuiSwitch__self:checked+.vkuiSwitch__pseudo:before{transform:translateX(calc(32px - 12px));transform:translateX(calc(var(--vkui--size_switch_width--compact) - var(--vkui--size_switch_height--compact)))}}.vkuiSwitch__self[disabled]+.vkuiSwitch__pseudo{opacity:.4;opacity:var(--vkui--opacity_disable)}.vkuiSwitch--ios .vkuiSwitch__pseudo:before{box-shadow:0 3px 8px rgba(0,0,0,.15),0 3px 1px rgba(0,0,0,.06),inset 0 0 0 .5px rgba(0,0,0,.04)}.vkuiSwitch--ios .vkuiSwitch__pseudo:before,.vkuiSwitch--ios .vkuiSwitch__self:checked+.vkuiSwitch__pseudo:before{background:#fff;background:var(--vkui_internal--white)}.vkuiSwitch--ios .vkuiSwitch__pseudo:after{background:#e1e3e6;background:var(--vkui--color_track_background)}.vkuiSwitch--ios .vkuiSwitch__self:checked+.vkuiSwitch__pseudo:after{opacity:1}@media (prefers-reduced-motion:no-preference){.vkuiSwitch__pseudo:after{transition:background-color .1s ease}.vkuiSwitch__pseudo:before{transition:transform .1s ease}.vkuiSwitch--ios .vkuiSwitch__pseudo:after{transition:background-color .2s ease}.vkuiSwitch--ios .vkuiSwitch__pseudo:before{transition:transform .2s cubic-bezier(.36,-.24,.26,1.32)}}.vkuiSimpleCell__after>.vkuiSwitch{margin-left:12px}.vkuiSimpleCell>.vkuiSwitch:first-child{margin-right:12px}
@@ -4,10 +4,13 @@ var _excluded = ["children", "selected", "indicator", "text", "href", "Component
4
4
  import * as React from 'react';
5
5
  import { classNames, hasReactNode } from '@vkontakte/vkjs';
6
6
  import { usePlatform } from '../../hooks/usePlatform';
7
+ import { Platform } from '../../lib/platform';
8
+ import { COMMON_WARNINGS, warnOnce } from '../../lib/warnOnce';
7
9
  import { Tappable } from '../Tappable/Tappable';
8
10
  import { Footnote } from '../Typography/Footnote/Footnote';
9
- import { Platform } from '../../lib/platform';
10
11
  import "./TabbarItem.module.css";
12
+ var warn = warnOnce('TabbarItem');
13
+
11
14
  /**
12
15
  * @see https://vkcom.github.io/VKUI/#/TabbarItem
13
16
  */
@@ -23,6 +26,12 @@ export var TabbarItem = function TabbarItem(_ref) {
23
26
  className = _ref.className,
24
27
  restProps = _objectWithoutProperties(_ref, _excluded);
25
28
  var platform = usePlatform();
29
+ if (process.env.NODE_ENV === 'development') {
30
+ var isAccessible = !text && (!restProps['aria-label'] || !restProps['aria-labelledby']);
31
+ if (!isAccessible) {
32
+ warn(COMMON_WARNINGS.a11y[Component === 'a' ? 'link-name' : 'button-name'], 'error');
33
+ }
34
+ }
26
35
  return /*#__PURE__*/React.createElement(Component, _extends({}, restProps, {
27
36
  disabled: disabled,
28
37
  href: href,
@@ -1 +1 @@
1
- {"version":3,"file":"TabbarItem.js","names":["React","classNames","hasReactNode","usePlatform","Tappable","Footnote","Platform","TabbarItem","children","selected","indicator","text","href","Component","disabled","className","restProps","platform","IOS","ANDROID"],"sources":["../../../../src/components/TabbarItem/TabbarItem.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { Tappable } from '../Tappable/Tappable';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { Platform } from '../../lib/platform';\nimport { HasComponent, HasRootRef } from '../../types';\nimport styles from './TabbarItem.module.css';\n\nexport interface TabbarItemProps\n extends React.AllHTMLAttributes<HTMLElement>,\n HasRootRef<HTMLElement>,\n HasComponent {\n selected?: boolean;\n /**\n * Текст рядом с иконкой\n */\n text?: React.ReactNode;\n /**\n * Индикатор над иконкой. Принимает `<Badge mode=\"prominent\" />` или `<Counter size=\"s\" mode=\"prominent\" />`\n */\n indicator?: React.ReactNode;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/TabbarItem\n */\nexport const TabbarItem = ({\n children,\n selected,\n indicator,\n text,\n href,\n Component = href ? 'a' : 'button',\n disabled,\n className,\n ...restProps\n}: TabbarItemProps) => {\n const platform = usePlatform();\n\n return (\n <Component\n {...restProps}\n disabled={disabled}\n href={href}\n className={classNames(\n styles['TabbarItem'],\n platform === Platform.IOS && styles['TabbarItem--ios'],\n platform === Platform.ANDROID && styles['TabbarItem--android'],\n selected && styles['TabbarItem--selected'],\n !!text && styles['TabbarItem--text'],\n className,\n )}\n >\n <Tappable\n role=\"presentation\"\n Component=\"div\"\n disabled={disabled}\n activeMode={\n platform === Platform.IOS ? styles['TabbarItem__tappable--active'] : 'background'\n }\n activeEffectDelay={platform === Platform.IOS ? 0 : 300}\n hasHover={false}\n className={styles['TabbarItem__tappable']}\n />\n <div className={styles['TabbarItem__in']}>\n <div className={styles['TabbarItem__icon']}>\n {children}\n <div className={styles['TabbarItem__label']}>{hasReactNode(indicator) && indicator}</div>\n </div>\n {text && (\n <Footnote Component=\"div\" className={styles['TabbarItem__text']} weight=\"2\">\n {text}\n </Footnote>\n )}\n </div>\n </Component>\n );\n};\n"],"mappings":";;;AAAA,OAAO,KAAKA,KAAK,MAAM,OAAO;AAC9B,SAASC,UAAU,EAAEC,YAAY,QAAQ,iBAAiB;AAC1D,SAASC,WAAW,QAAQ,yBAAyB;AACrD,SAASC,QAAQ,QAAQ,sBAAsB;AAC/C,SAASC,QAAQ,QAAQ,iCAAiC;AAC1D,SAASC,QAAQ,QAAQ,oBAAoB;AAAC;AAmB9C;AACA;AACA;AACA,OAAO,IAAMC,UAAU,GAAG,SAAbA,UAAU,OAUA;EAAA,IATrBC,QAAQ,QAARA,QAAQ;IACRC,QAAQ,QAARA,QAAQ;IACRC,SAAS,QAATA,SAAS;IACTC,IAAI,QAAJA,IAAI;IACJC,IAAI,QAAJA,IAAI;IAAA,sBACJC,SAAS;IAATA,SAAS,+BAAGD,IAAI,GAAG,GAAG,GAAG,QAAQ;IACjCE,QAAQ,QAARA,QAAQ;IACRC,SAAS,QAATA,SAAS;IACNC,SAAS;EAEZ,IAAMC,QAAQ,GAAGd,WAAW,EAAE;EAE9B,oBACE,oBAAC,SAAS,eACJa,SAAS;IACb,QAAQ,EAAEF,QAAS;IACnB,IAAI,EAAEF,IAAK;IACX,SAAS,EAAEX,UAAU,mBAEnBgB,QAAQ,KAAKX,QAAQ,CAACY,GAAG,yBAA6B,EACtDD,QAAQ,KAAKX,QAAQ,CAACa,OAAO,6BAAiC,EAC9DV,QAAQ,8BAAkC,EAC1C,CAAC,CAACE,IAAI,0BAA8B,EACpCI,SAAS;EACT,iBAEF,oBAAC,QAAQ;IACP,IAAI,EAAC,cAAc;IACnB,SAAS,EAAC,KAAK;IACf,QAAQ,EAAED,QAAS;IACnB,UAAU,EACRG,QAAQ,KAAKX,QAAQ,CAACY,GAAG,wCAA4C,YACtE;IACD,iBAAiB,EAAED,QAAQ,KAAKX,QAAQ,CAACY,GAAG,GAAG,CAAC,GAAG,GAAI;IACvD,QAAQ,EAAE,KAAM;IAChB,SAAS;EAAiC,EAC1C,eACF;IAAK,SAAS;EAA2B,gBACvC;IAAK,SAAS;EAA6B,GACxCV,QAAQ,eACT;IAAK,SAAS;EAA8B,GAAEN,YAAY,CAACQ,SAAS,CAAC,IAAIA,SAAS,CAAO,CACrF,EACLC,IAAI,iBACH,oBAAC,QAAQ;IAAC,SAAS,EAAC,KAAK;IAAC,SAAS,wBAA6B;IAAC,MAAM,EAAC;EAAG,GACxEA,IAAI,CAER,CACG,CACI;AAEhB,CAAC"}
1
+ {"version":3,"file":"TabbarItem.js","names":["React","classNames","hasReactNode","usePlatform","Platform","COMMON_WARNINGS","warnOnce","Tappable","Footnote","warn","TabbarItem","children","selected","indicator","text","href","Component","disabled","className","restProps","platform","process","env","NODE_ENV","isAccessible","a11y","IOS","ANDROID"],"sources":["../../../../src/components/TabbarItem/TabbarItem.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { Platform } from '../../lib/platform';\nimport { COMMON_WARNINGS, warnOnce } from '../../lib/warnOnce';\nimport { HasComponent, HasRootRef } from '../../types';\nimport { Tappable } from '../Tappable/Tappable';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport styles from './TabbarItem.module.css';\n\nexport interface TabbarItemProps\n extends React.AllHTMLAttributes<HTMLElement>,\n HasRootRef<HTMLElement>,\n HasComponent {\n selected?: boolean;\n /**\n * Текст рядом с иконкой\n */\n text?: React.ReactNode;\n /**\n * Индикатор над иконкой. Принимает `<Badge mode=\"prominent\" />` или `<Counter size=\"s\" mode=\"prominent\" />`\n */\n indicator?: React.ReactNode;\n}\n\nconst warn = warnOnce('TabbarItem');\n\n/**\n * @see https://vkcom.github.io/VKUI/#/TabbarItem\n */\nexport const TabbarItem = ({\n children,\n selected,\n indicator,\n text,\n href,\n Component = href ? 'a' : 'button',\n disabled,\n className,\n ...restProps\n}: TabbarItemProps) => {\n const platform = usePlatform();\n\n if (process.env.NODE_ENV === 'development') {\n const isAccessible = !text && (!restProps['aria-label'] || !restProps['aria-labelledby']);\n\n if (!isAccessible) {\n warn(COMMON_WARNINGS.a11y[Component === 'a' ? 'link-name' : 'button-name'], 'error');\n }\n }\n\n return (\n <Component\n {...restProps}\n disabled={disabled}\n href={href}\n className={classNames(\n styles['TabbarItem'],\n platform === Platform.IOS && styles['TabbarItem--ios'],\n platform === Platform.ANDROID && styles['TabbarItem--android'],\n selected && styles['TabbarItem--selected'],\n !!text && styles['TabbarItem--text'],\n className,\n )}\n >\n <Tappable\n role=\"presentation\"\n Component=\"div\"\n disabled={disabled}\n activeMode={\n platform === Platform.IOS ? styles['TabbarItem__tappable--active'] : 'background'\n }\n activeEffectDelay={platform === Platform.IOS ? 0 : 300}\n hasHover={false}\n className={styles['TabbarItem__tappable']}\n />\n <div className={styles['TabbarItem__in']}>\n <div className={styles['TabbarItem__icon']}>\n {children}\n <div className={styles['TabbarItem__label']}>{hasReactNode(indicator) && indicator}</div>\n </div>\n {text && (\n <Footnote Component=\"div\" className={styles['TabbarItem__text']} weight=\"2\">\n {text}\n </Footnote>\n )}\n </div>\n </Component>\n );\n};\n"],"mappings":";;;AAAA,OAAO,KAAKA,KAAK,MAAM,OAAO;AAC9B,SAASC,UAAU,EAAEC,YAAY,QAAQ,iBAAiB;AAC1D,SAASC,WAAW,QAAQ,yBAAyB;AACrD,SAASC,QAAQ,QAAQ,oBAAoB;AAC7C,SAASC,eAAe,EAAEC,QAAQ,QAAQ,oBAAoB;AAE9D,SAASC,QAAQ,QAAQ,sBAAsB;AAC/C,SAASC,QAAQ,QAAQ,iCAAiC;AAAC;AAkB3D,IAAMC,IAAI,GAAGH,QAAQ,CAAC,YAAY,CAAC;;AAEnC;AACA;AACA;AACA,OAAO,IAAMI,UAAU,GAAG,SAAbA,UAAU,OAUA;EAAA,IATrBC,QAAQ,QAARA,QAAQ;IACRC,QAAQ,QAARA,QAAQ;IACRC,SAAS,QAATA,SAAS;IACTC,IAAI,QAAJA,IAAI;IACJC,IAAI,QAAJA,IAAI;IAAA,sBACJC,SAAS;IAATA,SAAS,+BAAGD,IAAI,GAAG,GAAG,GAAG,QAAQ;IACjCE,QAAQ,QAARA,QAAQ;IACRC,SAAS,QAATA,SAAS;IACNC,SAAS;EAEZ,IAAMC,QAAQ,GAAGjB,WAAW,EAAE;EAE9B,IAAIkB,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,aAAa,EAAE;IAC1C,IAAMC,YAAY,GAAG,CAACV,IAAI,KAAK,CAACK,SAAS,CAAC,YAAY,CAAC,IAAI,CAACA,SAAS,CAAC,iBAAiB,CAAC,CAAC;IAEzF,IAAI,CAACK,YAAY,EAAE;MACjBf,IAAI,CAACJ,eAAe,CAACoB,IAAI,CAACT,SAAS,KAAK,GAAG,GAAG,WAAW,GAAG,aAAa,CAAC,EAAE,OAAO,CAAC;IACtF;EACF;EAEA,oBACE,oBAAC,SAAS,eACJG,SAAS;IACb,QAAQ,EAAEF,QAAS;IACnB,IAAI,EAAEF,IAAK;IACX,SAAS,EAAEd,UAAU,mBAEnBmB,QAAQ,KAAKhB,QAAQ,CAACsB,GAAG,yBAA6B,EACtDN,QAAQ,KAAKhB,QAAQ,CAACuB,OAAO,6BAAiC,EAC9Df,QAAQ,8BAAkC,EAC1C,CAAC,CAACE,IAAI,0BAA8B,EACpCI,SAAS;EACT,iBAEF,oBAAC,QAAQ;IACP,IAAI,EAAC,cAAc;IACnB,SAAS,EAAC,KAAK;IACf,QAAQ,EAAED,QAAS;IACnB,UAAU,EACRG,QAAQ,KAAKhB,QAAQ,CAACsB,GAAG,wCAA4C,YACtE;IACD,iBAAiB,EAAEN,QAAQ,KAAKhB,QAAQ,CAACsB,GAAG,GAAG,CAAC,GAAG,GAAI;IACvD,QAAQ,EAAE,KAAM;IAChB,SAAS;EAAiC,EAC1C,eACF;IAAK,SAAS;EAA2B,gBACvC;IAAK,SAAS;EAA6B,GACxCf,QAAQ,eACT;IAAK,SAAS;EAA8B,GAAET,YAAY,CAACW,SAAS,CAAC,IAAIA,SAAS,CAAO,CACrF,EACLC,IAAI,iBACH,oBAAC,QAAQ;IAAC,SAAS,EAAC,KAAK;IAAC,SAAS,wBAA6B;IAAC,MAAM,EAAC;EAAG,GACxEA,IAAI,CAER,CACG,CACI;AAEhB,CAAC"}
@@ -3,11 +3,11 @@ import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProper
3
3
  var _excluded = ["children", "mode", "getRootRef", "className", "role"];
4
4
  import * as React from 'react';
5
5
  import { classNames } from '@vkontakte/vkjs';
6
- import { usePlatform } from '../../hooks/usePlatform';
7
- import { Platform } from '../../lib/platform';
8
6
  import { useGlobalEventListener } from '../../hooks/useGlobalEventListener';
9
- import { useDOM } from '../../lib/dom';
7
+ import { usePlatform } from '../../hooks/usePlatform';
10
8
  import { pressedKey } from '../../lib/accessibility';
9
+ import { useDOM } from '../../lib/dom';
10
+ import { Platform } from '../../lib/platform';
11
11
  import "./Tabs.module.css";
12
12
  var modeClassNames = {
13
13
  default: "vkuiTabs--mode-default",
@@ -1 +1 @@
1
- {"version":3,"file":"Tabs.js","names":["React","classNames","usePlatform","Platform","useGlobalEventListener","useDOM","pressedKey","modeClassNames","default","accent","secondary","TabsModeContext","createContext","mode","withGaps","Tabs","children","getRootRef","className","role","restProps","platform","document","isTabFlow","tabsRef","useRef","getTabEls","current","Array","from","querySelectorAll","handleDocumentKeydown","event","key","tabEls","currentFocusedElIndex","findIndex","el","activeElement","nextIndex","length","offset","nextTabEl","preventDefault","focus","currentFocusedEl","find","getAttribute","relatedContentElId","relatedContentEl","getElementById","click","capture","VKCOM"],"sources":["../../../../src/components/Tabs/Tabs.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { HasRootRef } from '../../types';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { Platform } from '../../lib/platform';\nimport { useGlobalEventListener } from '../../hooks/useGlobalEventListener';\nimport { useDOM } from '../../lib/dom';\nimport { pressedKey } from '../../lib/accessibility';\nimport styles from './Tabs.module.css';\n\nconst modeClassNames = {\n default: styles['Tabs--mode-default'],\n accent: styles['Tabs--mode-accent'],\n secondary: styles['Tabs--mode-secondary'],\n};\n\nexport interface TabsProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n mode?: 'default' | 'accent' | 'secondary';\n}\n\nexport interface TabsContextProps {\n mode: TabsProps['mode'];\n withGaps: boolean;\n}\n\nexport const TabsModeContext = React.createContext<TabsContextProps>({\n mode: 'default',\n withGaps: false,\n});\n\n/**\n * @see https://vkcom.github.io/VKUI/#/Tabs\n */\nexport const Tabs = ({\n children,\n mode = 'default',\n getRootRef,\n className,\n role = 'tablist',\n ...restProps\n}: TabsProps) => {\n const platform = usePlatform();\n const { document } = useDOM();\n\n const isTabFlow = role === 'tablist';\n\n const tabsRef = React.useRef<HTMLDivElement>(null);\n\n const withGaps = mode === 'accent' || mode === 'secondary';\n\n const getTabEls = () => {\n if (!tabsRef.current) {\n return [];\n }\n\n return Array.from(\n // eslint-disable-next-line no-restricted-properties\n tabsRef.current.querySelectorAll<HTMLDivElement>('[role=tab]:not([disabled])'),\n );\n };\n\n const handleDocumentKeydown = (event: KeyboardEvent) => {\n if (!document || !tabsRef.current || !isTabFlow) {\n return;\n }\n\n const key = pressedKey(event);\n\n switch (key) {\n case 'ArrowLeft':\n case 'ArrowRight':\n case 'End':\n case 'Home': {\n const tabEls = getTabEls();\n const currentFocusedElIndex = tabEls.findIndex((el) => document.activeElement === el);\n if (currentFocusedElIndex === -1) {\n return;\n }\n\n let nextIndex = 0;\n if (key === 'Home') {\n nextIndex = 0;\n } else if (key === 'End') {\n nextIndex = tabEls.length - 1;\n } else {\n const offset = key === 'ArrowRight' ? 1 : -1;\n nextIndex = currentFocusedElIndex + offset;\n }\n\n const nextTabEl = tabEls[nextIndex];\n\n if (nextTabEl) {\n event.preventDefault();\n nextTabEl.focus();\n }\n\n break;\n }\n /*\n В JAWS и NVDA стрелка вниз активирует контент.\n Это не прописано в стандартах, но по ссылке ниже это рекомендуется делать.\n https://inclusive-components.design/tabbed-interfaces/\n */\n case 'ArrowDown': {\n const tabEls = getTabEls();\n const currentFocusedEl = tabEls.find((el) => document.activeElement === el);\n\n if (!currentFocusedEl || currentFocusedEl.getAttribute('aria-selected') !== 'true') {\n return;\n }\n\n const relatedContentElId = currentFocusedEl.getAttribute('aria-controls');\n if (!relatedContentElId) {\n return;\n }\n\n // eslint-disable-next-line no-restricted-properties\n const relatedContentEl = document.getElementById(relatedContentElId);\n if (!relatedContentEl) {\n return;\n }\n\n event.preventDefault();\n relatedContentEl.focus();\n\n break;\n }\n case 'Space':\n case 'Enter': {\n const tabEls = getTabEls();\n const currentFocusedEl = tabEls.find((el) => document.activeElement === el);\n if (currentFocusedEl) {\n currentFocusedEl.click();\n }\n }\n }\n };\n\n useGlobalEventListener(document, 'keydown', handleDocumentKeydown, {\n capture: true,\n });\n\n return (\n <div\n {...restProps}\n ref={getRootRef}\n className={classNames(\n styles['Tabs'],\n platform === Platform.VKCOM && styles['Tabs--vkcom'],\n withGaps && styles['Tabs--withGaps'],\n modeClassNames[mode],\n className,\n )}\n role={role}\n >\n <div className={styles['Tabs__in']} ref={tabsRef}>\n <TabsModeContext.Provider value={{ mode, withGaps }}>{children}</TabsModeContext.Provider>\n </div>\n </div>\n );\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"Tabs.js","names":["React","classNames","useGlobalEventListener","usePlatform","pressedKey","useDOM","Platform","modeClassNames","default","accent","secondary","TabsModeContext","createContext","mode","withGaps","Tabs","children","getRootRef","className","role","restProps","platform","document","isTabFlow","tabsRef","useRef","getTabEls","current","Array","from","querySelectorAll","handleDocumentKeydown","event","key","tabEls","currentFocusedElIndex","findIndex","el","activeElement","nextIndex","length","offset","nextTabEl","preventDefault","focus","currentFocusedEl","find","getAttribute","relatedContentElId","relatedContentEl","getElementById","click","capture","VKCOM"],"sources":["../../../../src/components/Tabs/Tabs.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useGlobalEventListener } from '../../hooks/useGlobalEventListener';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { pressedKey } from '../../lib/accessibility';\nimport { useDOM } from '../../lib/dom';\nimport { Platform } from '../../lib/platform';\nimport { HasRootRef } from '../../types';\nimport styles from './Tabs.module.css';\n\nconst modeClassNames = {\n default: styles['Tabs--mode-default'],\n accent: styles['Tabs--mode-accent'],\n secondary: styles['Tabs--mode-secondary'],\n};\n\nexport interface TabsProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n mode?: 'default' | 'accent' | 'secondary';\n}\n\nexport interface TabsContextProps {\n mode: TabsProps['mode'];\n withGaps: boolean;\n}\n\nexport const TabsModeContext = React.createContext<TabsContextProps>({\n mode: 'default',\n withGaps: false,\n});\n\n/**\n * @see https://vkcom.github.io/VKUI/#/Tabs\n */\nexport const Tabs = ({\n children,\n mode = 'default',\n getRootRef,\n className,\n role = 'tablist',\n ...restProps\n}: TabsProps) => {\n const platform = usePlatform();\n const { document } = useDOM();\n\n const isTabFlow = role === 'tablist';\n\n const tabsRef = React.useRef<HTMLDivElement>(null);\n\n const withGaps = mode === 'accent' || mode === 'secondary';\n\n const getTabEls = () => {\n if (!tabsRef.current) {\n return [];\n }\n\n return Array.from(\n // eslint-disable-next-line no-restricted-properties\n tabsRef.current.querySelectorAll<HTMLDivElement>('[role=tab]:not([disabled])'),\n );\n };\n\n const handleDocumentKeydown = (event: KeyboardEvent) => {\n if (!document || !tabsRef.current || !isTabFlow) {\n return;\n }\n\n const key = pressedKey(event);\n\n switch (key) {\n case 'ArrowLeft':\n case 'ArrowRight':\n case 'End':\n case 'Home': {\n const tabEls = getTabEls();\n const currentFocusedElIndex = tabEls.findIndex((el) => document.activeElement === el);\n if (currentFocusedElIndex === -1) {\n return;\n }\n\n let nextIndex = 0;\n if (key === 'Home') {\n nextIndex = 0;\n } else if (key === 'End') {\n nextIndex = tabEls.length - 1;\n } else {\n const offset = key === 'ArrowRight' ? 1 : -1;\n nextIndex = currentFocusedElIndex + offset;\n }\n\n const nextTabEl = tabEls[nextIndex];\n\n if (nextTabEl) {\n event.preventDefault();\n nextTabEl.focus();\n }\n\n break;\n }\n /*\n В JAWS и NVDA стрелка вниз активирует контент.\n Это не прописано в стандартах, но по ссылке ниже это рекомендуется делать.\n https://inclusive-components.design/tabbed-interfaces/\n */\n case 'ArrowDown': {\n const tabEls = getTabEls();\n const currentFocusedEl = tabEls.find((el) => document.activeElement === el);\n\n if (!currentFocusedEl || currentFocusedEl.getAttribute('aria-selected') !== 'true') {\n return;\n }\n\n const relatedContentElId = currentFocusedEl.getAttribute('aria-controls');\n if (!relatedContentElId) {\n return;\n }\n\n // eslint-disable-next-line no-restricted-properties\n const relatedContentEl = document.getElementById(relatedContentElId);\n if (!relatedContentEl) {\n return;\n }\n\n event.preventDefault();\n relatedContentEl.focus();\n\n break;\n }\n case 'Space':\n case 'Enter': {\n const tabEls = getTabEls();\n const currentFocusedEl = tabEls.find((el) => document.activeElement === el);\n if (currentFocusedEl) {\n currentFocusedEl.click();\n }\n }\n }\n };\n\n useGlobalEventListener(document, 'keydown', handleDocumentKeydown, {\n capture: true,\n });\n\n return (\n <div\n {...restProps}\n ref={getRootRef}\n className={classNames(\n styles['Tabs'],\n platform === Platform.VKCOM && styles['Tabs--vkcom'],\n withGaps && styles['Tabs--withGaps'],\n modeClassNames[mode],\n className,\n )}\n role={role}\n >\n <div className={styles['Tabs__in']} ref={tabsRef}>\n <TabsModeContext.Provider value={{ mode, withGaps }}>{children}</TabsModeContext.Provider>\n </div>\n </div>\n );\n};\n"],"mappings":"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"}
@@ -1 +1 @@
1
- .vkuiTabs__in{align-items:stretch;display:flex}.vkuiTabs--withGaps{justify-content:flex-start}.vkuiPanelHeader .vkuiTabs{font-family:VK Sans Text,-apple-system,system-ui,Helvetica Neue,Roboto,sans-serif;font-family:var(--vkui--font_family_base);overflow:hidden}.vkuiPanelHeader .vkuiTabs:after{content:"";display:block;width:1000px}.vkuiFixedLayout--ios.vkuiFixedLayout--vertical-bottom .vkuiTabs:after{background:#fff;background:var(--vkui--color_background_content);content:"";height:100%;left:0;position:absolute;top:0;width:100%}.vkuiFixedLayout--ios.vkuiFixedLayout--vertical-bottom .vkuiSeparator,.vkuiFixedLayout--ios.vkuiFixedLayout--vertical-bottom .vkuiTabs__in{position:relative;z-index:2;z-index:var(--vkui_internal--z_index_tabs)}.vkuiGroup--mode-plain .vkuiGroup__inner>.vkuiTabs--mode-default:first-child{margin-top:-8px}.vkuiGroup--mode-card>.vkuiGroup__inner>.vkuiTabs--mode-default:first-child{margin-top:-4px}
1
+ .vkuiTabs__in{align-items:stretch;display:flex}.vkuiTabs--withGaps{justify-content:flex-start}.vkuiPanelHeader .vkuiTabs{font-family:-apple-system,system-ui,Helvetica Neue,Roboto,sans-serif;font-family:var(--vkui--font_family_base);overflow:hidden}.vkuiPanelHeader .vkuiTabs:after{content:"";display:block;width:1000px}.vkuiFixedLayout--ios.vkuiFixedLayout--vertical-bottom .vkuiTabs:after{background:#fff;background:var(--vkui--color_background_content);content:"";height:100%;left:0;position:absolute;top:0;width:100%}.vkuiFixedLayout--ios.vkuiFixedLayout--vertical-bottom .vkuiSeparator,.vkuiFixedLayout--ios.vkuiFixedLayout--vertical-bottom .vkuiTabs__in{position:relative;z-index:2;z-index:var(--vkui_internal--z_index_tabs)}.vkuiGroup--mode-plain .vkuiGroup__inner>.vkuiTabs--mode-default:first-child{margin-top:-8px}.vkuiGroup--mode-card>.vkuiGroup__inner>.vkuiTabs--mode-default:first-child{margin-top:-4px}
@@ -1,16 +1,20 @@
1
1
  import _extends from "@babel/runtime/helpers/extends";
2
2
  import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
3
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
4
  var _excluded = ["before", "children", "status", "after", "selected", "className", "role", "tabIndex"];
4
5
  import * as React from 'react';
5
- import { Tappable } from '../Tappable/Tappable';
6
6
  import { classNames } from '@vkontakte/vkjs';
7
7
  import { useAdaptivity } from '../../hooks/useAdaptivity';
8
+ import { SizeType } from '../../lib/adaptivity';
9
+ import { warnOnce } from '../../lib/warnOnce';
8
10
  import { TabsModeContext } from '../Tabs/Tabs';
11
+ import { Tappable } from '../Tappable/Tappable';
9
12
  import { Headline } from '../Typography/Headline/Headline';
10
13
  import { Subhead } from '../Typography/Subhead/Subhead';
11
- import { getSizeYClassName } from '../../helpers/getSizeYClassName';
12
- import { warnOnce } from '../../lib/warnOnce';
13
14
  import "./TabsItem.module.css";
15
+ var sizeYClassNames = _defineProperty({
16
+ none: "vkuiTabsItem--sizeY-none"
17
+ }, SizeType.COMPACT, "vkuiTabsItem--sizeY-compact");
14
18
  var warn = warnOnce('TabsItem');
15
19
 
16
20
  /**
@@ -29,7 +33,8 @@ export var TabsItem = function TabsItem(_ref) {
29
33
  tabIndexProp = _ref.tabIndex,
30
34
  restProps = _objectWithoutProperties(_ref, _excluded);
31
35
  var _useAdaptivity = useAdaptivity(),
32
- sizeY = _useAdaptivity.sizeY;
36
+ _useAdaptivity$sizeY = _useAdaptivity.sizeY,
37
+ sizeY = _useAdaptivity$sizeY === void 0 ? 'none' : _useAdaptivity$sizeY;
33
38
  var _React$useContext = React.useContext(TabsModeContext),
34
39
  mode = _React$useContext.mode,
35
40
  withGaps = _React$useContext.withGaps;
@@ -56,7 +61,7 @@ export var TabsItem = function TabsItem(_ref) {
56
61
  tabIndex = selected ? 0 : -1;
57
62
  }
58
63
  return /*#__PURE__*/React.createElement(Tappable, _extends({}, restProps, {
59
- className: classNames("vkuiTabsItem", mode && styles["TabsItem--mode-".concat(mode)], selected && "vkuiTabsItem--selected", getSizeYClassName("vkuiTabsItem", sizeY), withGaps && "vkuiTabsItem--withGaps", className),
64
+ className: classNames("vkuiTabsItem", mode && styles["TabsItem--mode-".concat(mode)], selected && "vkuiTabsItem--selected", sizeY !== SizeType.REGULAR && sizeYClassNames[sizeY], withGaps && "vkuiTabsItem--withGaps", className),
60
65
  hoverMode: "vkuiTabsItem--hover",
61
66
  activeMode: "vkuiTabsItem--active",
62
67
  focusVisibleMode: "inside",
@@ -1 +1 @@
1
- {"version":3,"file":"TabsItem.js","names":["React","Tappable","classNames","useAdaptivity","TabsModeContext","Headline","Subhead","getSizeYClassName","warnOnce","warn","TabsItem","before","children","status","after","selected","className","role","tabIndexProp","tabIndex","restProps","sizeY","useContext","mode","withGaps","statusComponent","isTabFlow","process","env","NODE_ENV","undefined","styles"],"sources":["../../../../src/components/TabsItem/TabsItem.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Tappable } from '../Tappable/Tappable';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { TabsModeContext, TabsContextProps } from '../Tabs/Tabs';\nimport { Headline } from '../Typography/Headline/Headline';\nimport { Subhead } from '../Typography/Subhead/Subhead';\nimport { getSizeYClassName } from '../../helpers/getSizeYClassName';\nimport { warnOnce } from '../../lib/warnOnce';\nimport styles from './TabsItem.module.css';\n\nexport interface TabsItemProps extends React.HTMLAttributes<HTMLElement> {\n /**\n * Добавляет иконку слева.\n *\n * - Для `mode=\"default\"` используйте иконки размером 24.\n * - Для всех остальных `mode` используйте иконки размером 20.\n */\n before?: React.ReactNode;\n /**\n * Добавляет элемент слева от `after`.\n *\n * - `React.ReactElement` – либо [`Badge`](https://vkcom.github.io/VKUI/#/Badge) с параметром `mode=\"prominent\"`.\n * либо [`Counter`](https://vkcom.github.io/VKUI/#/Counter) с параметрами `mode=\"prominent\" size=\"s\"`.\n * - `number` – для показа текстового блока с переданным числом.\n */\n status?: React.ReactElement | number;\n /**\n * Добавляет иконку справа.\n *\n * Например, `<Icon16Dropdown />`\n */\n after?: React.ReactNode;\n selected?: boolean;\n disabled?: boolean;\n}\n\nconst warn = warnOnce('TabsItem');\n\n/**\n * @see https://vkcom.github.io/VKUI/#/TabsItem\n */\nexport const TabsItem = ({\n before,\n children,\n status,\n after,\n selected = false,\n className,\n role = 'tab',\n tabIndex: tabIndexProp,\n ...restProps\n}: TabsItemProps) => {\n const { sizeY } = useAdaptivity();\n const { mode, withGaps }: TabsContextProps = React.useContext(TabsModeContext);\n let statusComponent = null;\n\n const isTabFlow = role === 'tab';\n\n if (status) {\n statusComponent =\n typeof status === 'number' ? (\n <Subhead\n Component=\"span\"\n className={classNames(styles['TabsItem__status'], styles['TabsItem__status--count'])}\n weight=\"2\"\n >\n {status}\n </Subhead>\n ) : (\n <span className={styles['TabsItem__status']}>{status}</span>\n );\n }\n\n if (process.env.NODE_ENV === 'development' && isTabFlow) {\n if (!restProps['aria-controls']) {\n warn(`Передайте в \"aria-controls\" id контролируемого блока`, 'warn');\n } else if (!restProps['id']) {\n warn(\n `Передайте \"id\" компоненту для использования в \"aria-labelledby\" контролируемого блока`,\n 'warn',\n );\n }\n }\n\n let tabIndex = tabIndexProp;\n if (isTabFlow && tabIndex === undefined) {\n tabIndex = selected ? 0 : -1;\n }\n\n return (\n <Tappable\n {...restProps}\n className={classNames(\n styles['TabsItem'],\n mode && styles[`TabsItem--mode-${mode}`],\n selected && styles['TabsItem--selected'],\n getSizeYClassName(styles['TabsItem'], sizeY),\n withGaps && styles['TabsItem--withGaps'],\n className,\n )}\n hoverMode={styles['TabsItem--hover']}\n activeMode={styles['TabsItem--active']}\n focusVisibleMode=\"inside\"\n hasActive={false}\n role={role}\n aria-selected={selected}\n tabIndex={tabIndex}\n >\n {before && <div className={styles['TabsItem__before']}>{before}</div>}\n <Headline\n Component=\"span\"\n className={styles['TabsItem__label']}\n level={mode === 'default' ? '1' : '2'}\n weight=\"2\"\n >\n {children}\n </Headline>\n {statusComponent}\n {after && <div className={styles['TabsItem__after']}>{after}</div>}\n {mode === 'default' && (\n <div className={styles['TabsItem__underline']} aria-hidden data-selected={selected} />\n )}\n </Tappable>\n );\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"TabsItem.js","names":["React","classNames","useAdaptivity","SizeType","warnOnce","TabsModeContext","Tappable","Headline","Subhead","sizeYClassNames","none","COMPACT","warn","TabsItem","before","children","status","after","selected","className","role","tabIndexProp","tabIndex","restProps","sizeY","useContext","mode","withGaps","statusComponent","isTabFlow","process","env","NODE_ENV","undefined","styles","REGULAR"],"sources":["../../../../src/components/TabsItem/TabsItem.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { SizeType } from '../../lib/adaptivity';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { TabsContextProps, TabsModeContext } from '../Tabs/Tabs';\nimport { Tappable } from '../Tappable/Tappable';\nimport { Headline } from '../Typography/Headline/Headline';\nimport { Subhead } from '../Typography/Subhead/Subhead';\nimport styles from './TabsItem.module.css';\n\nconst sizeYClassNames = {\n none: styles['TabsItem--sizeY-none'],\n [SizeType.COMPACT]: styles['TabsItem--sizeY-compact'],\n};\n\nexport interface TabsItemProps extends React.HTMLAttributes<HTMLElement> {\n /**\n * Добавляет иконку слева.\n *\n * - Для `mode=\"default\"` используйте иконки размером 24.\n * - Для всех остальных `mode` используйте иконки размером 20.\n */\n before?: React.ReactNode;\n /**\n * Добавляет элемент слева от `after`.\n *\n * - `React.ReactElement` – либо [`Badge`](https://vkcom.github.io/VKUI/#/Badge) с параметром `mode=\"prominent\"`.\n * либо [`Counter`](https://vkcom.github.io/VKUI/#/Counter) с параметрами `mode=\"prominent\" size=\"s\"`.\n * - `number` – для показа текстового блока с переданным числом.\n */\n status?: React.ReactElement | number;\n /**\n * Добавляет иконку справа.\n *\n * Например, `<Icon16Dropdown />`\n */\n after?: React.ReactNode;\n selected?: boolean;\n disabled?: boolean;\n}\n\nconst warn = warnOnce('TabsItem');\n\n/**\n * @see https://vkcom.github.io/VKUI/#/TabsItem\n */\nexport const TabsItem = ({\n before,\n children,\n status,\n after,\n selected = false,\n className,\n role = 'tab',\n tabIndex: tabIndexProp,\n ...restProps\n}: TabsItemProps) => {\n const { sizeY = 'none' } = useAdaptivity();\n const { mode, withGaps }: TabsContextProps = React.useContext(TabsModeContext);\n let statusComponent = null;\n\n const isTabFlow = role === 'tab';\n\n if (status) {\n statusComponent =\n typeof status === 'number' ? (\n <Subhead\n Component=\"span\"\n className={classNames(styles['TabsItem__status'], styles['TabsItem__status--count'])}\n weight=\"2\"\n >\n {status}\n </Subhead>\n ) : (\n <span className={styles['TabsItem__status']}>{status}</span>\n );\n }\n\n if (process.env.NODE_ENV === 'development' && isTabFlow) {\n if (!restProps['aria-controls']) {\n warn(`Передайте в \"aria-controls\" id контролируемого блока`, 'warn');\n } else if (!restProps['id']) {\n warn(\n `Передайте \"id\" компоненту для использования в \"aria-labelledby\" контролируемого блока`,\n 'warn',\n );\n }\n }\n\n let tabIndex = tabIndexProp;\n if (isTabFlow && tabIndex === undefined) {\n tabIndex = selected ? 0 : -1;\n }\n\n return (\n <Tappable\n {...restProps}\n className={classNames(\n styles['TabsItem'],\n mode && styles[`TabsItem--mode-${mode}`],\n selected && styles['TabsItem--selected'],\n sizeY !== SizeType.REGULAR && sizeYClassNames[sizeY],\n withGaps && styles['TabsItem--withGaps'],\n className,\n )}\n hoverMode={styles['TabsItem--hover']}\n activeMode={styles['TabsItem--active']}\n focusVisibleMode=\"inside\"\n hasActive={false}\n role={role}\n aria-selected={selected}\n tabIndex={tabIndex}\n >\n {before && <div className={styles['TabsItem__before']}>{before}</div>}\n <Headline\n Component=\"span\"\n className={styles['TabsItem__label']}\n level={mode === 'default' ? '1' : '2'}\n weight=\"2\"\n >\n {children}\n </Headline>\n {statusComponent}\n {after && <div className={styles['TabsItem__after']}>{after}</div>}\n {mode === 'default' && (\n <div className={styles['TabsItem__underline']} aria-hidden data-selected={selected} />\n )}\n </Tappable>\n );\n};\n"],"mappings":"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"}
@@ -1 +1 @@
1
- .vkuiTabsItem{align-items:center;border-radius:8px;border-radius:var(--vkui--size_border_radius--regular);box-sizing:border-box;display:flex;justify-content:center;max-width:100%;min-height:32px;min-width:0;padding:4px 8px;transition:background-color .15s ease-out}.vkuiTabsItem--withGaps{margin-bottom:8px;margin-top:8px}.vkuiTabsItem--withGaps:not(:first-of-type){margin-left:6px}.vkuiTabsItem--sizeY-compact{min-height:28px;padding-bottom:2px;padding-top:2px}@media (pointer:fine) and (min-width:768px),not (min-height:415px){.vkuiTabsItem--sizeY-none{min-height:28px;padding-bottom:2px;padding-top:2px}}.vkuiTabsItem[disabled]{opacity:.64;opacity:var(--vkui--opacity_disable_accessibility)}.vkuiTabsItem--mode-default{flex-basis:0;flex-grow:1;flex-shrink:0;min-height:48px;padding:12px 16px;position:relative}.vkuiTabsItem--sizeY-compact.vkuiTabsItem--mode-default{min-height:44px;padding-bottom:10px;padding-top:10px}@media (pointer:fine) and (min-width:768px),not (min-height:415px){.vkuiTabsItem--sizeY-none.vkuiTabsItem--mode-default{min-height:44px;padding-bottom:10px;padding-top:10px}}.vkuiTabsItem--hover.vkuiTabsItem--mode-default{background-color:rgba(0,16,61,.04);background-color:var(--vkui--color_transparent--hover)}.vkuiTabsItem--mode-accent{transition:background-color .15s ease-out,box-shadow .15s ease-out}.vkuiTabsItem--selected.vkuiTabsItem--mode-accent{background-color:#fff;background-color:var(--vkui--color_background_modal);box-shadow:0 4px 8px rgba(0,0,0,.04),0 0 4px rgba(0,0,0,.06);box-shadow:var(--vkui--elevation2)}.vkuiTabsItem--hover.vkuiTabsItem--mode-accent{background-color:#f5f5f5;background-color:var(--vkui--color_background_secondary)}.vkuiTabsItem--mode-accent:before{border:1px solid transparent;border:var(--vkui_internal--thin_border) solid transparent;border-radius:inherit;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.vkuiTabsItem--selected.vkuiTabsItem--mode-accent:before{border-color:#d7d8d9;border-color:var(--vkui--color_separator_primary)}.vkuiTabsItem--selected.vkuiTabsItem--mode-secondary{background-color:rgba(0,0,0,.04);background-color:var(--vkui--color_background_secondary_alpha)}.vkuiTabsItem--hover.vkuiTabsItem--mode-secondary{background-color:rgba(0,0,0,.08);background-color:var(--vkui--color_background_secondary_alpha--hover)}.vkuiTabsItem__before{color:#818c99;color:var(--vkui--color_icon_medium);margin-right:6px;transition:color .15s ease-out}.vkuiTabsItem--selected .vkuiTabsItem__before{color:#2c2d2e;color:var(--vkui--color_icon_primary)}.vkuiTabsItem--selected.vkuiTabsItem--mode-accent .vkuiTabsItem__before{color:#2688eb;color:var(--vkui--color_icon_accent_themed)}.vkuiTabsItem--selected.vkuiTabsItem--mode-secondary .vkuiTabsItem__before{opacity:.72}.vkuiTabsItem__label{color:#818c99;color:var(--vkui--color_text_secondary);max-width:100%;min-width:0;overflow:hidden;text-overflow:ellipsis;transition:color .15s ease-out;white-space:nowrap}.vkuiTabsItem--selected .vkuiTabsItem__label{color:#000;color:var(--vkui--color_text_primary)}.vkuiTabsItem--selected.vkuiTabsItem--mode-accent .vkuiTabsItem__label{color:#2688eb;color:var(--vkui--color_text_accent_themed)}.vkuiTabsItem--selected.vkuiTabsItem--mode-secondary .vkuiTabsItem__label{opacity:.72}.vkuiTabsItem__status{margin-left:6px}.vkuiTabsItem__status--count{color:#99a2ad;color:var(--vkui--color_text_tertiary)}.vkuiTabsItem__after{color:#2688eb;color:var(--vkui--color_icon_accent_themed);margin-left:6px}.vkuiTabsItem__underline{background-color:#2688eb;background-color:var(--vkui--color_background_accent);border-radius:2px;bottom:5px;height:2px;left:16px;opacity:0;pointer-events:none;position:absolute;right:16px;transition:opacity .15s ease-out}.vkuiTabsItem--sizeY-compact .vkuiTabsItem__underline{bottom:3px}@media (pointer:fine) and (min-width:768px),not (min-height:415px){.vkuiTabsItem--sizeY-none .vkuiTabsItem__underline{bottom:3px}}.vkuiTabsItem__underline[data-selected=true]{opacity:1}.vkuiTabs--vkcom .vkuiTabsItem{flex-grow:0;min-width:auto;padding-left:10px;padding-right:10px}.vkuiTabs--vkcom .vkuiTabsItem__underline{bottom:0;left:2px;right:2px}.vkuiHorizontalScroll .vkuiTabsItem{flex-basis:auto;flex-grow:1;flex-shrink:0;min-width:64px}
1
+ .vkuiTabsItem{align-items:center;border-radius:8px;border-radius:var(--vkui--size_border_radius--regular);box-sizing:border-box;display:flex;justify-content:center;max-width:100%;min-height:32px;min-width:0;padding:4px 8px;transition:background-color .15s ease-out}.vkuiTabsItem--withGaps{margin-bottom:8px;margin-top:8px}.vkuiTabsItem--withGaps:not(:first-of-type){margin-left:6px}.vkuiTabsItem--sizeY-compact{min-height:28px;padding-bottom:2px;padding-top:2px}@media (max-height:414.9px),(pointer:fine) and (min-width:768px){.vkuiTabsItem--sizeY-none{min-height:28px;padding-bottom:2px;padding-top:2px}}.vkuiTabsItem[disabled]{opacity:.64;opacity:var(--vkui--opacity_disable_accessibility)}.vkuiTabsItem--mode-default{flex-basis:0;flex-grow:1;flex-shrink:0;min-height:48px;padding:12px 16px;position:relative}.vkuiTabsItem--sizeY-compact.vkuiTabsItem--mode-default{min-height:44px;padding-bottom:10px;padding-top:10px}@media (max-height:414.9px),(pointer:fine) and (min-width:768px){.vkuiTabsItem--sizeY-none.vkuiTabsItem--mode-default{min-height:44px;padding-bottom:10px;padding-top:10px}}.vkuiTabsItem--hover.vkuiTabsItem--mode-default{background-color:rgba(0,16,61,.04);background-color:var(--vkui--color_transparent--hover)}.vkuiTabsItem--mode-accent{transition:background-color .15s ease-out,box-shadow .15s ease-out}.vkuiTabsItem--selected.vkuiTabsItem--mode-accent{background-color:#fff;background-color:var(--vkui--color_background_modal);box-shadow:0 4px 8px rgba(0,0,0,.04),0 0 4px rgba(0,0,0,.06);box-shadow:var(--vkui--elevation2)}.vkuiTabsItem--hover.vkuiTabsItem--mode-accent{background-color:#f5f5f5;background-color:var(--vkui--color_background_secondary)}.vkuiTabsItem--mode-accent:before{border:1px solid transparent;border:var(--vkui_internal--thin_border) solid transparent;border-radius:inherit;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.vkuiTabsItem--selected.vkuiTabsItem--mode-accent:before{border-color:#d7d8d9;border-color:var(--vkui--color_separator_primary)}.vkuiTabsItem--selected.vkuiTabsItem--mode-secondary{background-color:rgba(0,0,0,.04);background-color:var(--vkui--color_background_secondary_alpha)}.vkuiTabsItem--hover.vkuiTabsItem--mode-secondary{background-color:rgba(0,0,0,.08);background-color:var(--vkui--color_background_secondary_alpha--hover)}.vkuiTabsItem__before{color:#818c99;color:var(--vkui--color_icon_medium);margin-right:6px;transition:color .15s ease-out}.vkuiTabsItem--selected .vkuiTabsItem__before{color:#2c2d2e;color:var(--vkui--color_icon_primary)}.vkuiTabsItem--selected.vkuiTabsItem--mode-accent .vkuiTabsItem__before{color:#2688eb;color:var(--vkui--color_icon_accent_themed)}.vkuiTabsItem--selected.vkuiTabsItem--mode-secondary .vkuiTabsItem__before{opacity:.72}.vkuiTabsItem__label{color:#818c99;color:var(--vkui--color_text_secondary);max-width:100%;min-width:0;overflow:hidden;text-overflow:ellipsis;transition:color .15s ease-out;white-space:nowrap}.vkuiTabsItem--selected .vkuiTabsItem__label{color:#000;color:var(--vkui--color_text_primary)}.vkuiTabsItem--selected.vkuiTabsItem--mode-accent .vkuiTabsItem__label{color:#2688eb;color:var(--vkui--color_text_accent_themed)}.vkuiTabsItem--selected.vkuiTabsItem--mode-secondary .vkuiTabsItem__label{opacity:.72}.vkuiTabsItem__status{margin-left:6px}.vkuiTabsItem__status--count{color:#99a2ad;color:var(--vkui--color_text_tertiary)}.vkuiTabsItem__after{color:#2688eb;color:var(--vkui--color_icon_accent_themed);margin-left:6px}.vkuiTabsItem__underline{background-color:#2688eb;background-color:var(--vkui--color_background_accent);border-radius:2px;bottom:5px;height:2px;left:16px;opacity:0;pointer-events:none;position:absolute;right:16px;transition:opacity .15s ease-out}.vkuiTabsItem--sizeY-compact .vkuiTabsItem__underline{bottom:3px}@media (max-height:414.9px),(pointer:fine) and (min-width:768px){.vkuiTabsItem--sizeY-none .vkuiTabsItem__underline{bottom:3px}}.vkuiTabsItem__underline[data-selected=true]{opacity:1}.vkuiTabs--vkcom .vkuiTabsItem{flex-grow:0;min-width:auto;padding-left:10px;padding-right:10px}.vkuiTabs--vkcom .vkuiTabsItem__underline{bottom:0;left:2px;right:2px}.vkuiHorizontalScroll .vkuiTabsItem{flex-basis:auto;flex-grow:1;flex-shrink:0;min-width:64px}
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react';
2
- import { TouchProps } from '../Touch/Touch';
3
2
  import { AnchorHTMLAttributesOnly, HasComponent, HasRootRef } from '../../types';
4
3
  import { FocusVisibleMode } from '../FocusVisible/FocusVisible';
4
+ import { TouchProps } from '../Touch/Touch';
5
5
  declare type StateMode = 'opacity' | 'background';
6
6
  export declare type TappableElementProps = Omit<React.AllHTMLAttributes<HTMLElement>, 'onTouchStart' | 'onTouchMove' | 'onTouchEnd' | 'onTouchCancel' | 'onMouseDown' | 'onMouseMove' | 'onMouseUp' | 'onMouseLeave'> & AnchorHTMLAttributesOnly;
7
7
  export interface TappableProps extends TappableElementProps, HasRootRef<HTMLElement>, HasComponent, Pick<TouchProps, 'onStart' | 'onEnd' | 'onMove'> {
@@ -4,25 +4,25 @@ import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProper
4
4
  import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
5
5
  var _excluded = ["children", "Component", "onClick", "onKeyDown", "activeEffectDelay", "stopPropagation", "getRootRef", "hasHover", "hoverMode", "hasActive", "activeMode", "focusVisibleMode", "onEnter", "onLeave", "className"];
6
6
  import * as React from 'react';
7
- import mitt from 'mitt';
8
7
  import { classNames, noop } from '@vkontakte/vkjs';
9
- import { Touch } from '../Touch/Touch';
10
- import TouchRootContext from '../Touch/TouchContext';
11
- import { Platform } from '../../lib/platform';
8
+ import mitt from 'mitt';
9
+ import { useAdaptivity } from '../../hooks/useAdaptivity';
10
+ import { useAdaptivityHasHover } from '../../hooks/useAdaptivityHasHover';
11
+ import { useAdaptivityHasPointer } from '../../hooks/useAdaptivityHasPointer';
12
+ import { useBooleanState } from '../../hooks/useBooleanState';
13
+ import { useExternRef } from '../../hooks/useExternRef';
14
+ import { useFocusVisible } from '../../hooks/useFocusVisible';
15
+ import { usePlatform } from '../../hooks/usePlatform';
16
+ import { useTimeout } from '../../hooks/useTimeout';
17
+ import { shouldTriggerClickOnEnterOrSpace } from '../../lib/accessibility';
18
+ import { callMultiple } from '../../lib/callMultiple';
12
19
  import { getOffsetRect } from '../../lib/offset';
20
+ import { Platform } from '../../lib/platform';
13
21
  import { coordX, coordY } from '../../lib/touch';
14
- import { shouldTriggerClickOnEnterOrSpace } from '../../lib/accessibility';
15
22
  import { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';
16
23
  import { FocusVisible } from '../FocusVisible/FocusVisible';
17
- import { useTimeout } from '../../hooks/useTimeout';
18
- import { useExternRef } from '../../hooks/useExternRef';
19
- import { usePlatform } from '../../hooks/usePlatform';
20
- import { useFocusVisible } from '../../hooks/useFocusVisible';
21
- import { callMultiple } from '../../lib/callMultiple';
22
- import { useBooleanState } from '../../hooks/useBooleanState';
23
- import { useAdaptivity } from '../../hooks/useAdaptivity';
24
- import { useAdaptivityHasHover } from '../../hooks/useAdaptivityHasHover';
25
- import { useAdaptivityHasPointer } from '../../hooks/useAdaptivityHasPointer';
24
+ import { Touch } from '../Touch/Touch';
25
+ import TouchRootContext from '../Touch/TouchContext';
26
26
  import "./Tappable.module.css";
27
27
  var sizeXClassNames = {
28
28
  none: "vkuiTappable--sizeX-none",
@@ -1 +1 @@
1
- {"version":3,"file":"Tappable.js","names":["React","mitt","classNames","noop","Touch","TouchRootContext","Platform","getOffsetRect","coordX","coordY","shouldTriggerClickOnEnterOrSpace","useIsomorphicLayoutEffect","FocusVisible","useTimeout","useExternRef","usePlatform","useFocusVisible","callMultiple","useBooleanState","useAdaptivity","useAdaptivityHasHover","useAdaptivityHasPointer","sizeXClassNames","none","compact","regular","WAVE_LIVE","ACTIVE_DELAY","ACTIVE_EFFECT_DELAY","activeBus","TapState","pending","active","exiting","TappableContext","createContext","onHoverChange","isPresetStateMode","stateMode","useActivity","hasActive","stopDelay","id","useMemo","Math","round","random","toString","useState","activity","setActivity","_stop","start","delayStart","activeTimeout","stopTimeout","set","clear","emit","onActiveChange","activeId","on","off","stop","delay","Tappable","children","Component","onClick","_onKeyDown","onKeyDown","activeEffectDelay","stopPropagation","getRootRef","hasHover","_hasHover","hoverMode","_hasActive","activeMode","focusVisibleMode","onEnter","onLeave","className","props","href","useContext","insideTouchRoot","platform","focusVisible","onBlur","onFocus","sizeX","hasPointerContext","hasHoverContext","clicks","setClicks","childHover","setChildHover","_hovered","value","setHoveredTrue","setTrue","setHoveredFalse","setFalse","hovered","disabled","isCustomElement","contentEditable","isPresetHoverMode","isPresetActiveMode","isPresetFocusVisibleMode","includes","containerRef","childContext","useRef","current","e","preventDefault","click","needWaves","ANDROID","clearClicks","addClick","x","y","dateNow","Date","now","filteredClicks","filter","onStart","originalEvent","touches","length","top","left","onMove","isSlide","onEnd","duration","activeDuration","classes","IOS","styles","handlers","role","undefined","map","wave"],"sources":["../../../../src/components/Tappable/Tappable.tsx"],"sourcesContent":["import * as React from 'react';\nimport mitt from 'mitt';\nimport { classNames, noop } from '@vkontakte/vkjs';\nimport { Touch, TouchEvent, TouchProps } from '../Touch/Touch';\nimport TouchRootContext from '../Touch/TouchContext';\nimport { Platform } from '../../lib/platform';\nimport { getOffsetRect } from '../../lib/offset';\nimport { coordX, coordY } from '../../lib/touch';\nimport { AnchorHTMLAttributesOnly, HasComponent, HasRootRef } from '../../types';\nimport { shouldTriggerClickOnEnterOrSpace } from '../../lib/accessibility';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { FocusVisible, FocusVisibleMode } from '../FocusVisible/FocusVisible';\nimport { useTimeout } from '../../hooks/useTimeout';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { useFocusVisible } from '../../hooks/useFocusVisible';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { useBooleanState } from '../../hooks/useBooleanState';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useAdaptivityHasHover } from '../../hooks/useAdaptivityHasHover';\nimport { useAdaptivityHasPointer } from '../../hooks/useAdaptivityHasPointer';\nimport styles from './Tappable.module.css';\n\nconst sizeXClassNames = {\n none: styles['Tappable--sizeX-none'],\n compact: styles['Tappable--sizeX-compact'],\n regular: styles['Tappable--sizeX-regular'],\n};\n\ntype StateMode = 'opacity' | 'background';\n\nconst WAVE_LIVE = 225;\n\nexport type TappableElementProps = Omit<\n React.AllHTMLAttributes<HTMLElement>,\n | 'onTouchStart'\n | 'onTouchMove'\n | 'onTouchEnd'\n | 'onTouchCancel'\n | 'onMouseDown'\n | 'onMouseMove'\n | 'onMouseUp'\n | 'onMouseLeave'\n> &\n AnchorHTMLAttributesOnly; // В AllHTMLAttributes не хватает типов для ссылок\n\nexport interface TappableProps\n extends TappableElementProps,\n HasRootRef<HTMLElement>,\n HasComponent,\n Pick<TouchProps, 'onStart' | 'onEnd' | 'onMove'> {\n /**\n * Длительность показа active-состояния\n */\n activeEffectDelay?: number;\n stopPropagation?: boolean;\n /**\n * Указывает, должен ли компонент реагировать на hover-состояние\n */\n hasHover?: boolean;\n /**\n * Указывает, должен ли компонент реагировать на active-состояние\n */\n hasActive?: boolean;\n /**\n * Стиль подсветки active-состояния. Если передать произвольную строку, она добавится как css-класс во время active\n */\n activeMode?: StateMode | string;\n /**\n * Стиль подсветки hover-состояния. Если передать произвольную строку, она добавится как css-класс во время hover\n */\n hoverMode?: StateMode | string;\n /**\n * Стиль аутлайна focus visible. Если передать произвольную строку, она добавится как css-класс во время focus-visible\n */\n focusVisibleMode?: FocusVisibleMode | string;\n children?: React.ReactNode;\n onEnter?(outputEvent: MouseEvent): void;\n onLeave?(outputEvent: MouseEvent): void;\n}\n\ninterface Wave {\n x: number;\n y: number;\n id: number;\n}\n\nexport interface RootComponentProps extends TouchProps {\n ref?: React.Ref<HTMLElement>;\n}\n\nexport const ACTIVE_DELAY = 70;\nexport const ACTIVE_EFFECT_DELAY = 600;\n\nconst activeBus = mitt<{ active: string }>();\nconst TapState = { none: 0, pending: 1, active: 2, exiting: 3 } as const;\n\ntype TappableContextInterface = { onHoverChange: (s: boolean) => void };\nconst TappableContext = React.createContext<TappableContextInterface>({\n onHoverChange: noop,\n});\n\nfunction isPresetStateMode(stateMode: StateMode | string): stateMode is StateMode {\n switch (stateMode) {\n case 'opacity':\n case 'background':\n return true;\n default:\n return false;\n }\n}\n\nfunction useActivity(hasActive: boolean, stopDelay: number) {\n const id = React.useMemo(() => Math.round(Math.random() * 1e8).toString(16), []);\n\n const [activity, setActivity] = React.useState<(typeof TapState)[keyof typeof TapState]>(\n TapState.none,\n );\n const _stop = () => setActivity(TapState.none);\n const start = () => hasActive && setActivity(TapState.active);\n const delayStart = () => {\n hasActive && setActivity(TapState.pending);\n };\n\n const activeTimeout = useTimeout(start, ACTIVE_DELAY);\n const stopTimeout = useTimeout(_stop, stopDelay);\n\n useIsomorphicLayoutEffect(() => {\n if (activity === TapState.pending) {\n activeTimeout.set();\n return activeTimeout.clear;\n }\n if (activity === TapState.exiting) {\n return stopTimeout.clear;\n }\n if (activity === TapState.active) {\n activeBus.emit('active', id);\n }\n return noop;\n }, [activity]);\n\n useIsomorphicLayoutEffect(() => {\n if (activity === TapState.none) {\n return noop;\n }\n const onActiveChange = (activeId: string) => {\n activeId !== id && _stop();\n };\n activeBus.on('active', onActiveChange);\n return () => activeBus.off('active', onActiveChange);\n }, [activity === TapState.none]);\n\n useIsomorphicLayoutEffect(() => {\n !hasActive && _stop();\n }, [hasActive]);\n\n const stop = (delay?: number) => {\n if (delay) {\n setActivity(TapState.exiting);\n return stopTimeout.set(delay);\n }\n _stop();\n };\n\n return [activity, { delayStart, start, stop }] as const;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/Tappable\n */\nexport const Tappable = ({\n children,\n Component,\n onClick,\n onKeyDown: _onKeyDown,\n activeEffectDelay = ACTIVE_EFFECT_DELAY,\n stopPropagation = false,\n getRootRef,\n hasHover: _hasHover = true,\n hoverMode = 'background',\n hasActive: _hasActive = true,\n activeMode = 'background',\n focusVisibleMode = 'inside',\n onEnter,\n onLeave,\n className,\n ...props\n}: TappableProps) => {\n Component = Component || ((props.href ? 'a' : 'div') as React.ElementType);\n\n const { onHoverChange } = React.useContext(TappableContext);\n const insideTouchRoot = React.useContext(TouchRootContext);\n const platform = usePlatform();\n const { focusVisible, onBlur, onFocus } = useFocusVisible();\n const { sizeX = 'none' } = useAdaptivity();\n const hasPointerContext = useAdaptivityHasPointer();\n const hasHoverContext = useAdaptivityHasHover();\n\n const [clicks, setClicks] = React.useState<Wave[]>([]);\n const [childHover, setChildHover] = React.useState(false);\n const {\n value: _hovered,\n setTrue: setHoveredTrue,\n setFalse: setHoveredFalse,\n } = useBooleanState(false);\n\n const hovered = _hovered && !props.disabled;\n const hasActive = _hasActive && !childHover && !props.disabled;\n const hasHover = hasHoverContext && _hasHover && !childHover;\n const isCustomElement =\n Component !== 'a' && Component !== 'button' && Component !== 'label' && !props.contentEditable;\n const isPresetHoverMode = isPresetStateMode(hoverMode);\n const isPresetActiveMode = isPresetStateMode(activeMode);\n const isPresetFocusVisibleMode = ['inside', 'outside'].includes(focusVisibleMode);\n\n const [activity, { start, stop, delayStart }] = useActivity(hasActive, activeEffectDelay);\n const active = activity === TapState.active || activity === TapState.exiting;\n\n const containerRef = useExternRef(getRootRef);\n\n // hover propagation\n const childContext = React.useRef({ onHoverChange: setChildHover }).current;\n useIsomorphicLayoutEffect(() => {\n if (!hovered) {\n return noop;\n }\n onHoverChange(true);\n return () => onHoverChange(false);\n }, [hovered]);\n\n /*\n * [a11y]\n * Обрабатывает событие onkeydown\n * для кастомных доступных элементов:\n * - role=\"link\" (активация по Enter)\n * - role=\"button\" (активация по Space и Enter)\n */\n function onKeyDown(e: React.KeyboardEvent<HTMLElement>) {\n if (isCustomElement && shouldTriggerClickOnEnterOrSpace(e)) {\n e.preventDefault();\n containerRef.current?.click();\n }\n }\n\n const needWaves =\n platform === Platform.ANDROID && !hasPointerContext && hasActive && activeMode === 'background';\n\n const clearClicks = useTimeout(() => setClicks([]), WAVE_LIVE);\n\n function addClick(x: number, y: number) {\n const dateNow = Date.now();\n const filteredClicks = clicks.filter((click) => click.id + WAVE_LIVE > dateNow);\n\n setClicks([...filteredClicks, { x, y, id: dateNow }]);\n clearClicks.set();\n }\n\n function onStart({ originalEvent }: TouchEvent) {\n if (hasActive) {\n if (originalEvent.touches && originalEvent.touches.length > 1) {\n // r сожалению я так и не понял, что это делает и можно ли упихнуть его в Touch\n return stop();\n }\n\n if (needWaves) {\n const { top, left } = getOffsetRect(containerRef.current);\n const x = coordX(originalEvent) - (left ?? 0);\n const y = coordY(originalEvent) - (top ?? 0);\n addClick(x, y);\n }\n\n delayStart();\n }\n }\n\n function onMove({ isSlide }: TouchEvent) {\n if (isSlide) {\n stop();\n }\n }\n\n function onEnd({ duration }: TouchEvent) {\n if (activity === TapState.none) {\n return;\n }\n if (activity === TapState.pending) {\n // активировать при коротком тапе\n start();\n }\n\n // отключить без задержки при длинном тапе\n const activeDuration = duration - ACTIVE_DELAY;\n stop(activeDuration >= 100 ? 0 : activeEffectDelay - activeDuration);\n }\n\n const classes = classNames(\n className,\n styles['Tappable'],\n platform === Platform.IOS && styles['Tappable--ios'],\n sizeXClassNames[sizeX],\n hasHoverContext && styles['Tappable--hover-has'],\n hasActive && styles['Tappable--hasActive'],\n hasHover && hovered && !isPresetHoverMode && hoverMode,\n hasActive && active && !isPresetActiveMode && activeMode,\n focusVisible && !isPresetFocusVisibleMode && focusVisibleMode,\n hasActive && active && styles['Tappable--active'],\n hasHover && hovered && isPresetHoverMode && styles[`Tappable--hover-${hoverMode}`],\n hasActive && active && isPresetActiveMode && styles[`Tappable--active-${activeMode}`],\n focusVisible && styles['Tappable--focus-visible'],\n );\n\n const handlers: RootComponentProps = {\n onStart: callMultiple(onStart, props.onStart),\n onMove: callMultiple(onMove, props.onMove),\n onEnd: callMultiple(onEnd, props.onEnd),\n onClick,\n onKeyDown: callMultiple(onKeyDown, _onKeyDown),\n };\n const role = props.href ? 'link' : 'button';\n\n return (\n <Touch\n onEnter={callMultiple(setHoveredTrue, onEnter)}\n onLeave={callMultiple(setHoveredFalse, onLeave)}\n type={Component === 'button' ? 'button' : undefined}\n tabIndex={isCustomElement && !props.disabled ? 0 : undefined}\n role={isCustomElement ? role : undefined}\n aria-disabled={isCustomElement ? props.disabled : undefined}\n stopPropagation={stopPropagation && !insideTouchRoot && !props.disabled}\n {...props}\n slideThreshold={20}\n usePointerHover\n className={classes}\n Component={Component}\n getRootRef={containerRef}\n onBlur={callMultiple(onBlur, props.onBlur)}\n onFocus={callMultiple(onFocus, props.onFocus)}\n {...(props.disabled ? {} : handlers)}\n >\n <TappableContext.Provider value={childContext}>{children}</TappableContext.Provider>\n {needWaves && (\n <span aria-hidden className={styles.Tappable__waves}>\n {clicks.map((wave) => (\n <span\n key={wave.id}\n className={styles.Tappable__wave}\n style={{ top: wave.y, left: wave.x }}\n />\n ))}\n </span>\n )}\n {((hasHover && hoverMode === 'background') || (hasActive && activeMode === 'background')) && (\n <span aria-hidden className={styles.Tappable__stateLayer} />\n )}\n {!props.disabled && isPresetFocusVisibleMode && (\n <FocusVisible mode={focusVisibleMode as FocusVisibleMode} />\n )}\n </Touch>\n );\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"Tappable.js","names":["React","classNames","noop","mitt","useAdaptivity","useAdaptivityHasHover","useAdaptivityHasPointer","useBooleanState","useExternRef","useFocusVisible","usePlatform","useTimeout","shouldTriggerClickOnEnterOrSpace","callMultiple","getOffsetRect","Platform","coordX","coordY","useIsomorphicLayoutEffect","FocusVisible","Touch","TouchRootContext","sizeXClassNames","none","compact","regular","WAVE_LIVE","ACTIVE_DELAY","ACTIVE_EFFECT_DELAY","activeBus","TapState","pending","active","exiting","TappableContext","createContext","onHoverChange","isPresetStateMode","stateMode","useActivity","hasActive","stopDelay","id","useMemo","Math","round","random","toString","useState","activity","setActivity","_stop","start","delayStart","activeTimeout","stopTimeout","set","clear","emit","onActiveChange","activeId","on","off","stop","delay","Tappable","children","Component","onClick","_onKeyDown","onKeyDown","activeEffectDelay","stopPropagation","getRootRef","hasHover","_hasHover","hoverMode","_hasActive","activeMode","focusVisibleMode","onEnter","onLeave","className","props","href","useContext","insideTouchRoot","platform","focusVisible","onBlur","onFocus","sizeX","hasPointerContext","hasHoverContext","clicks","setClicks","childHover","setChildHover","_hovered","value","setHoveredTrue","setTrue","setHoveredFalse","setFalse","hovered","disabled","isCustomElement","contentEditable","isPresetHoverMode","isPresetActiveMode","isPresetFocusVisibleMode","includes","containerRef","childContext","useRef","current","e","preventDefault","click","needWaves","ANDROID","clearClicks","addClick","x","y","dateNow","Date","now","filteredClicks","filter","onStart","originalEvent","touches","length","top","left","onMove","isSlide","onEnd","duration","activeDuration","classes","IOS","styles","handlers","role","undefined","map","wave"],"sources":["../../../../src/components/Tappable/Tappable.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, noop } from '@vkontakte/vkjs';\nimport mitt from 'mitt';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useAdaptivityHasHover } from '../../hooks/useAdaptivityHasHover';\nimport { useAdaptivityHasPointer } from '../../hooks/useAdaptivityHasPointer';\nimport { useBooleanState } from '../../hooks/useBooleanState';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useFocusVisible } from '../../hooks/useFocusVisible';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { useTimeout } from '../../hooks/useTimeout';\nimport { shouldTriggerClickOnEnterOrSpace } from '../../lib/accessibility';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { getOffsetRect } from '../../lib/offset';\nimport { Platform } from '../../lib/platform';\nimport { coordX, coordY } from '../../lib/touch';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { AnchorHTMLAttributesOnly, HasComponent, HasRootRef } from '../../types';\nimport { FocusVisible, FocusVisibleMode } from '../FocusVisible/FocusVisible';\nimport { Touch, TouchEvent, TouchProps } from '../Touch/Touch';\nimport TouchRootContext from '../Touch/TouchContext';\nimport styles from './Tappable.module.css';\n\nconst sizeXClassNames = {\n none: styles['Tappable--sizeX-none'],\n compact: styles['Tappable--sizeX-compact'],\n regular: styles['Tappable--sizeX-regular'],\n};\n\ntype StateMode = 'opacity' | 'background';\n\nconst WAVE_LIVE = 225;\n\nexport type TappableElementProps = Omit<\n React.AllHTMLAttributes<HTMLElement>,\n | 'onTouchStart'\n | 'onTouchMove'\n | 'onTouchEnd'\n | 'onTouchCancel'\n | 'onMouseDown'\n | 'onMouseMove'\n | 'onMouseUp'\n | 'onMouseLeave'\n> &\n AnchorHTMLAttributesOnly; // В AllHTMLAttributes не хватает типов для ссылок\n\nexport interface TappableProps\n extends TappableElementProps,\n HasRootRef<HTMLElement>,\n HasComponent,\n Pick<TouchProps, 'onStart' | 'onEnd' | 'onMove'> {\n /**\n * Длительность показа active-состояния\n */\n activeEffectDelay?: number;\n stopPropagation?: boolean;\n /**\n * Указывает, должен ли компонент реагировать на hover-состояние\n */\n hasHover?: boolean;\n /**\n * Указывает, должен ли компонент реагировать на active-состояние\n */\n hasActive?: boolean;\n /**\n * Стиль подсветки active-состояния. Если передать произвольную строку, она добавится как css-класс во время active\n */\n activeMode?: StateMode | string;\n /**\n * Стиль подсветки hover-состояния. Если передать произвольную строку, она добавится как css-класс во время hover\n */\n hoverMode?: StateMode | string;\n /**\n * Стиль аутлайна focus visible. Если передать произвольную строку, она добавится как css-класс во время focus-visible\n */\n focusVisibleMode?: FocusVisibleMode | string;\n children?: React.ReactNode;\n onEnter?(outputEvent: MouseEvent): void;\n onLeave?(outputEvent: MouseEvent): void;\n}\n\ninterface Wave {\n x: number;\n y: number;\n id: number;\n}\n\nexport interface RootComponentProps extends TouchProps {\n ref?: React.Ref<HTMLElement>;\n}\n\nexport const ACTIVE_DELAY = 70;\nexport const ACTIVE_EFFECT_DELAY = 600;\n\nconst activeBus = mitt<{ active: string }>();\nconst TapState = { none: 0, pending: 1, active: 2, exiting: 3 } as const;\n\ntype TappableContextInterface = { onHoverChange: (s: boolean) => void };\nconst TappableContext = React.createContext<TappableContextInterface>({\n onHoverChange: noop,\n});\n\nfunction isPresetStateMode(stateMode: StateMode | string): stateMode is StateMode {\n switch (stateMode) {\n case 'opacity':\n case 'background':\n return true;\n default:\n return false;\n }\n}\n\nfunction useActivity(hasActive: boolean, stopDelay: number) {\n const id = React.useMemo(() => Math.round(Math.random() * 1e8).toString(16), []);\n\n const [activity, setActivity] = React.useState<(typeof TapState)[keyof typeof TapState]>(\n TapState.none,\n );\n const _stop = () => setActivity(TapState.none);\n const start = () => hasActive && setActivity(TapState.active);\n const delayStart = () => {\n hasActive && setActivity(TapState.pending);\n };\n\n const activeTimeout = useTimeout(start, ACTIVE_DELAY);\n const stopTimeout = useTimeout(_stop, stopDelay);\n\n useIsomorphicLayoutEffect(() => {\n if (activity === TapState.pending) {\n activeTimeout.set();\n return activeTimeout.clear;\n }\n if (activity === TapState.exiting) {\n return stopTimeout.clear;\n }\n if (activity === TapState.active) {\n activeBus.emit('active', id);\n }\n return noop;\n }, [activity]);\n\n useIsomorphicLayoutEffect(() => {\n if (activity === TapState.none) {\n return noop;\n }\n const onActiveChange = (activeId: string) => {\n activeId !== id && _stop();\n };\n activeBus.on('active', onActiveChange);\n return () => activeBus.off('active', onActiveChange);\n }, [activity === TapState.none]);\n\n useIsomorphicLayoutEffect(() => {\n !hasActive && _stop();\n }, [hasActive]);\n\n const stop = (delay?: number) => {\n if (delay) {\n setActivity(TapState.exiting);\n return stopTimeout.set(delay);\n }\n _stop();\n };\n\n return [activity, { delayStart, start, stop }] as const;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/Tappable\n */\nexport const Tappable = ({\n children,\n Component,\n onClick,\n onKeyDown: _onKeyDown,\n activeEffectDelay = ACTIVE_EFFECT_DELAY,\n stopPropagation = false,\n getRootRef,\n hasHover: _hasHover = true,\n hoverMode = 'background',\n hasActive: _hasActive = true,\n activeMode = 'background',\n focusVisibleMode = 'inside',\n onEnter,\n onLeave,\n className,\n ...props\n}: TappableProps) => {\n Component = Component || ((props.href ? 'a' : 'div') as React.ElementType);\n\n const { onHoverChange } = React.useContext(TappableContext);\n const insideTouchRoot = React.useContext(TouchRootContext);\n const platform = usePlatform();\n const { focusVisible, onBlur, onFocus } = useFocusVisible();\n const { sizeX = 'none' } = useAdaptivity();\n const hasPointerContext = useAdaptivityHasPointer();\n const hasHoverContext = useAdaptivityHasHover();\n\n const [clicks, setClicks] = React.useState<Wave[]>([]);\n const [childHover, setChildHover] = React.useState(false);\n const {\n value: _hovered,\n setTrue: setHoveredTrue,\n setFalse: setHoveredFalse,\n } = useBooleanState(false);\n\n const hovered = _hovered && !props.disabled;\n const hasActive = _hasActive && !childHover && !props.disabled;\n const hasHover = hasHoverContext && _hasHover && !childHover;\n const isCustomElement =\n Component !== 'a' && Component !== 'button' && Component !== 'label' && !props.contentEditable;\n const isPresetHoverMode = isPresetStateMode(hoverMode);\n const isPresetActiveMode = isPresetStateMode(activeMode);\n const isPresetFocusVisibleMode = ['inside', 'outside'].includes(focusVisibleMode);\n\n const [activity, { start, stop, delayStart }] = useActivity(hasActive, activeEffectDelay);\n const active = activity === TapState.active || activity === TapState.exiting;\n\n const containerRef = useExternRef(getRootRef);\n\n // hover propagation\n const childContext = React.useRef({ onHoverChange: setChildHover }).current;\n useIsomorphicLayoutEffect(() => {\n if (!hovered) {\n return noop;\n }\n onHoverChange(true);\n return () => onHoverChange(false);\n }, [hovered]);\n\n /*\n * [a11y]\n * Обрабатывает событие onkeydown\n * для кастомных доступных элементов:\n * - role=\"link\" (активация по Enter)\n * - role=\"button\" (активация по Space и Enter)\n */\n function onKeyDown(e: React.KeyboardEvent<HTMLElement>) {\n if (isCustomElement && shouldTriggerClickOnEnterOrSpace(e)) {\n e.preventDefault();\n containerRef.current?.click();\n }\n }\n\n const needWaves =\n platform === Platform.ANDROID && !hasPointerContext && hasActive && activeMode === 'background';\n\n const clearClicks = useTimeout(() => setClicks([]), WAVE_LIVE);\n\n function addClick(x: number, y: number) {\n const dateNow = Date.now();\n const filteredClicks = clicks.filter((click) => click.id + WAVE_LIVE > dateNow);\n\n setClicks([...filteredClicks, { x, y, id: dateNow }]);\n clearClicks.set();\n }\n\n function onStart({ originalEvent }: TouchEvent) {\n if (hasActive) {\n if (originalEvent.touches && originalEvent.touches.length > 1) {\n // r сожалению я так и не понял, что это делает и можно ли упихнуть его в Touch\n return stop();\n }\n\n if (needWaves) {\n const { top, left } = getOffsetRect(containerRef.current);\n const x = coordX(originalEvent) - (left ?? 0);\n const y = coordY(originalEvent) - (top ?? 0);\n addClick(x, y);\n }\n\n delayStart();\n }\n }\n\n function onMove({ isSlide }: TouchEvent) {\n if (isSlide) {\n stop();\n }\n }\n\n function onEnd({ duration }: TouchEvent) {\n if (activity === TapState.none) {\n return;\n }\n if (activity === TapState.pending) {\n // активировать при коротком тапе\n start();\n }\n\n // отключить без задержки при длинном тапе\n const activeDuration = duration - ACTIVE_DELAY;\n stop(activeDuration >= 100 ? 0 : activeEffectDelay - activeDuration);\n }\n\n const classes = classNames(\n className,\n styles['Tappable'],\n platform === Platform.IOS && styles['Tappable--ios'],\n sizeXClassNames[sizeX],\n hasHoverContext && styles['Tappable--hover-has'],\n hasActive && styles['Tappable--hasActive'],\n hasHover && hovered && !isPresetHoverMode && hoverMode,\n hasActive && active && !isPresetActiveMode && activeMode,\n focusVisible && !isPresetFocusVisibleMode && focusVisibleMode,\n hasActive && active && styles['Tappable--active'],\n hasHover && hovered && isPresetHoverMode && styles[`Tappable--hover-${hoverMode}`],\n hasActive && active && isPresetActiveMode && styles[`Tappable--active-${activeMode}`],\n focusVisible && styles['Tappable--focus-visible'],\n );\n\n const handlers: RootComponentProps = {\n onStart: callMultiple(onStart, props.onStart),\n onMove: callMultiple(onMove, props.onMove),\n onEnd: callMultiple(onEnd, props.onEnd),\n onClick,\n onKeyDown: callMultiple(onKeyDown, _onKeyDown),\n };\n const role = props.href ? 'link' : 'button';\n\n return (\n <Touch\n onEnter={callMultiple(setHoveredTrue, onEnter)}\n onLeave={callMultiple(setHoveredFalse, onLeave)}\n type={Component === 'button' ? 'button' : undefined}\n tabIndex={isCustomElement && !props.disabled ? 0 : undefined}\n role={isCustomElement ? role : undefined}\n aria-disabled={isCustomElement ? props.disabled : undefined}\n stopPropagation={stopPropagation && !insideTouchRoot && !props.disabled}\n {...props}\n slideThreshold={20}\n usePointerHover\n className={classes}\n Component={Component}\n getRootRef={containerRef}\n onBlur={callMultiple(onBlur, props.onBlur)}\n onFocus={callMultiple(onFocus, props.onFocus)}\n {...(props.disabled ? {} : handlers)}\n >\n <TappableContext.Provider value={childContext}>{children}</TappableContext.Provider>\n {needWaves && (\n <span aria-hidden className={styles.Tappable__waves}>\n {clicks.map((wave) => (\n <span\n key={wave.id}\n className={styles.Tappable__wave}\n style={{ top: wave.y, left: wave.x }}\n />\n ))}\n </span>\n )}\n {((hasHover && hoverMode === 'background') || (hasActive && activeMode === 'background')) && (\n <span aria-hidden className={styles.Tappable__stateLayer} />\n )}\n {!props.disabled && isPresetFocusVisibleMode && (\n <FocusVisible mode={focusVisibleMode as FocusVisibleMode} />\n )}\n </Touch>\n );\n};\n"],"mappings":"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"}
@@ -1 +1 @@
1
- .vkuiTappable{-webkit-tap-highlight-color:transparent;border-radius:8px;border-radius:var(--vkui--size_border_radius--regular);cursor:default;isolation:isolate;position:relative;transition:background-color .15s ease-out,opacity .15s ease-out}.vkuiTappable>*{position:relative;z-index:1;z-index:var(--vkui_internal--z_index_tappable_element)}.vkuiTappable--hasActive,.vkuiTappable--hover-has{cursor:pointer}.vkuiTappable[aria-disabled=true],.vkuiTappable[disabled]{cursor:default}.vkuiTappable--focus-visible{outline:none}.vkuiTappable__stateLayer{border-radius:inherit;bottom:0;left:0;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;transition:background-color .15s ease-out;z-index:0;z-index:var(--vkui_internal--z_index_tappable_state)}.vkuiTappable--hover-background>.vkuiTappable__stateLayer{background-color:rgba(0,16,61,.04);background-color:var(--vkui--color_transparent--hover)}.vkuiTappable--hover-opacity{opacity:.8}.vkuiTappable--active-background>.vkuiTappable__stateLayer{background-color:rgba(0,16,61,.08);background-color:var(--vkui--color_transparent--active)}.vkuiTappable--active-opacity{opacity:.7}.vkuiTappable--ios.vkuiTappable--active-background{transition:none}.vkuiTappable .vkuiTappable__waves{border-radius:inherit;bottom:0;left:0;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;will-change:transform;z-index:0;z-index:var(--vkui_internal--z_index_tappable_state)}.vkuiTappable .vkuiTappable__wave{animation:vkui-animation-wave .3s cubic-bezier(.4,0,.2,1);animation:vkui-animation-wave .3s var(--vkui--animation_easing_platform);background:rgba(0,16,61,.08);background:var(--vkui--color_transparent--active);border-radius:50%;content:"";height:24px;left:0;margin:-12px 0 0 -12px;opacity:0;position:absolute;top:0;width:24px}.vkuiTappable--sizeX-compact{border-radius:0}@media not (min-width:768px){.vkuiTappable--sizeX-none{border-radius:0}}@keyframes vkui-animation-wave{0%{opacity:1;transform:scale(1)}30%{opacity:1}to{opacity:0;transform:scale(8)}}
1
+ .vkuiTappable{-webkit-tap-highlight-color:transparent;border-radius:8px;border-radius:var(--vkui--size_border_radius--regular);cursor:default;isolation:isolate;position:relative;transition:background-color .15s ease-out,opacity .15s ease-out}.vkuiTappable>*{position:relative;z-index:1;z-index:var(--vkui_internal--z_index_tappable_element)}.vkuiTappable--hasActive,.vkuiTappable--hover-has{cursor:pointer}.vkuiTappable[aria-disabled=true],.vkuiTappable[disabled]{cursor:default}.vkuiTappable--focus-visible{outline:none}.vkuiTappable__stateLayer{border-radius:inherit;bottom:0;left:0;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;transition:background-color .15s ease-out;z-index:0;z-index:var(--vkui_internal--z_index_tappable_state)}.vkuiTappable--hover-background>.vkuiTappable__stateLayer{background-color:rgba(0,16,61,.04);background-color:var(--vkui--color_transparent--hover)}.vkuiTappable--hover-opacity{opacity:.8}.vkuiTappable--active-background>.vkuiTappable__stateLayer{background-color:rgba(0,16,61,.08);background-color:var(--vkui--color_transparent--active)}.vkuiTappable--active-opacity{opacity:.7}.vkuiTappable--ios.vkuiTappable--active-background{transition:none}.vkuiTappable .vkuiTappable__waves{border-radius:inherit;bottom:0;left:0;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;will-change:transform;z-index:0;z-index:var(--vkui_internal--z_index_tappable_state)}.vkuiTappable .vkuiTappable__wave{animation:vkui-animation-wave .3s cubic-bezier(.4,0,.2,1);animation:vkui-animation-wave .3s var(--vkui--animation_easing_platform);background:rgba(0,16,61,.08);background:var(--vkui--color_transparent--active);border-radius:50%;content:"";height:24px;left:0;margin:-12px 0 0 -12px;opacity:0;position:absolute;top:0;width:24px}.vkuiTappable--sizeX-compact{border-radius:0}@media (max-width:767.9px){.vkuiTappable--sizeX-none{border-radius:0}}@keyframes vkui-animation-wave{0%{opacity:1;transform:scale(1)}30%{opacity:1}to{opacity:0;transform:scale(8)}}