@vkontakte/vkui 4.27.2 → 4.29.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1346) hide show
  1. package/.cache/.eslintcache +1 -1
  2. package/.cache/.stylelintcache +1 -1
  3. package/.cache/.tsbuildinfo +2781 -245
  4. package/.cache/ts/src/components/Button/Button.d.ts +1 -2
  5. package/.cache/ts/src/components/ButtonGroup/ButtonGroup.d.ts +20 -0
  6. package/.cache/ts/src/components/Calendar/Calendar.d.ts +21 -0
  7. package/.cache/ts/src/components/CalendarDay/CalendarDay.d.ts +22 -0
  8. package/.cache/ts/src/components/CalendarDays/CalendarDays.d.ts +22 -0
  9. package/.cache/ts/src/components/CalendarHeader/CalendarHeader.d.ts +16 -0
  10. package/.cache/ts/src/components/CalendarRange/CalendarRange.d.ts +16 -0
  11. package/.cache/ts/src/components/CalendarTime/CalendarTime.d.ts +11 -0
  12. package/.cache/ts/src/components/Cell/Cell.d.ts +1 -1
  13. package/.cache/ts/src/components/ChipsInput/ChipsInput.d.ts +1 -2
  14. package/.cache/ts/src/components/ChipsSelect/ChipsSelect.d.ts +2 -3
  15. package/.cache/ts/src/components/ClickPopper/ClickPopper.d.ts +1 -1
  16. package/.cache/ts/src/components/ConfigProvider/ConfigProvider.d.ts +4 -0
  17. package/.cache/ts/src/components/CustomScrollView/CustomScrollView.d.ts +1 -1
  18. package/.cache/ts/src/components/CustomSelect/CustomSelect.d.ts +11 -2
  19. package/.cache/ts/src/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +4 -1
  20. package/.cache/ts/src/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  21. package/.cache/ts/src/components/DateInput/DateInput.d.ts +12 -0
  22. package/.cache/ts/src/components/DateRangeInput/DateRangeInput.d.ts +18 -0
  23. package/.cache/ts/src/components/Div/Div.d.ts +1 -2
  24. package/.cache/ts/src/components/Gallery/Gallery.d.ts +9 -1
  25. package/.cache/ts/src/components/GridAvatar/GridAvatar.d.ts +1 -0
  26. package/.cache/ts/src/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  27. package/.cache/ts/src/components/IconButton/IconButton.d.ts +1 -1
  28. package/.cache/ts/src/components/Input/Input.d.ts +1 -2
  29. package/.cache/ts/src/components/InputLike/InputLike.d.ts +10 -0
  30. package/.cache/ts/src/components/InputLike/InputLikeDivider.d.ts +3 -0
  31. package/.cache/ts/src/components/LocaleProviderContext/LocaleProviderContext.d.ts +2 -0
  32. package/.cache/ts/src/components/ModalCard/ModalCard.d.ts +1 -1
  33. package/.cache/ts/src/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  34. package/.cache/ts/src/components/ModalPage/ModalPage.d.ts +16 -1
  35. package/.cache/ts/src/components/ModalRoot/ModalRoot.d.ts +14 -2
  36. package/.cache/ts/src/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  37. package/.cache/ts/src/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  38. package/.cache/ts/src/components/ModalRoot/types.d.ts +16 -1
  39. package/.cache/ts/src/components/ModalRoot/useModalManager.d.ts +6 -5
  40. package/.cache/ts/src/components/Pagination/Pagination.d.ts +42 -0
  41. package/.cache/ts/src/components/PanelHeaderBack/PanelHeaderBack.d.ts +1 -1
  42. package/.cache/ts/src/components/RichCell/RichCell.d.ts +3 -2
  43. package/.cache/ts/src/components/Select/Select.d.ts +1 -2
  44. package/.cache/ts/src/components/SelectMimicry/SelectMimicry.d.ts +5 -1
  45. package/.cache/ts/src/components/SimpleCell/SimpleCell.d.ts +1 -1
  46. package/.cache/ts/src/components/SimpleCheckbox/SimpleCheckbox.d.ts +0 -1
  47. package/.cache/ts/src/components/Tappable/Tappable.d.ts +3 -1
  48. package/.cache/ts/src/components/Touch/TouchContext.d.ts +1 -1
  49. package/.cache/ts/src/components/Typography/Caption/Caption.d.ts +8 -4
  50. package/.cache/ts/src/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  51. package/.cache/ts/src/components/Typography/Subhead/Subhead.d.ts +4 -3
  52. package/.cache/ts/src/components/Typography/Title/Title.d.ts +4 -3
  53. package/.cache/ts/src/components/View/ViewInfinite.d.ts +2 -2
  54. package/.cache/ts/src/hooks/useBooleanState.d.ts +6 -0
  55. package/.cache/ts/src/hooks/useBridgeAdaptivity.d.ts +6 -0
  56. package/.cache/ts/src/hooks/useCalendar.d.ts +18 -0
  57. package/.cache/ts/src/hooks/useDateInput.d.ts +30 -0
  58. package/.cache/ts/src/hooks/useKeyboard.d.ts +1 -1
  59. package/.cache/ts/src/hooks/useKeyboardInputTracker.d.ts +2 -0
  60. package/.cache/ts/src/hooks/useOrientationChange.d.ts +7 -0
  61. package/.cache/ts/src/hooks/usePagination.d.ts +34 -0
  62. package/.cache/ts/src/index.d.ts +32 -11
  63. package/.cache/ts/src/lib/calendar.d.ts +14 -0
  64. package/.cache/ts/src/lib/date.d.ts +29 -0
  65. package/.cache/ts/src/lib/getNavId.d.ts +2 -1
  66. package/.cache/ts/src/lib/utils.d.ts +2 -1
  67. package/.cache/ts/src/lib/warnOnce.d.ts +2 -1
  68. package/.cache/ts/src/testing/utils.d.ts +1 -0
  69. package/.cache/ts/src/tokenized/index.d.ts +32 -4
  70. package/.cache/ts/src/unstable/index.d.ts +6 -6
  71. package/.eslintrc.json +8 -2
  72. package/CONTRIBUTING.md +3 -2
  73. package/dist/cjs/components/ActionSheet/ActionSheet.js +5 -8
  74. package/dist/cjs/components/ActionSheet/ActionSheet.js.map +1 -1
  75. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js +2 -1
  76. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  77. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js +1 -1
  78. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  79. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js +10 -11
  80. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  81. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js +44 -11
  82. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  83. package/dist/cjs/components/Alert/Alert.js +12 -14
  84. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  85. package/dist/cjs/components/AppRoot/AppRoot.js +3 -2
  86. package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
  87. package/dist/cjs/components/Avatar/Avatar.js +4 -1
  88. package/dist/cjs/components/Avatar/Avatar.js.map +1 -1
  89. package/dist/cjs/components/Banner/Banner.js +5 -4
  90. package/dist/cjs/components/Banner/Banner.js.map +1 -1
  91. package/dist/cjs/components/Button/Button.d.ts +1 -2
  92. package/dist/cjs/components/Button/Button.js +40 -49
  93. package/dist/cjs/components/Button/Button.js.map +1 -1
  94. package/dist/cjs/components/ButtonGroup/ButtonGroup.d.ts +20 -0
  95. package/dist/cjs/components/ButtonGroup/ButtonGroup.js +38 -0
  96. package/dist/cjs/components/ButtonGroup/ButtonGroup.js.map +1 -0
  97. package/dist/cjs/components/Calendar/Calendar.d.ts +21 -0
  98. package/dist/cjs/components/Calendar/Calendar.js +160 -0
  99. package/dist/cjs/components/Calendar/Calendar.js.map +1 -0
  100. package/dist/cjs/components/CalendarDay/CalendarDay.d.ts +22 -0
  101. package/dist/cjs/components/CalendarDay/CalendarDay.js +112 -0
  102. package/dist/cjs/components/CalendarDay/CalendarDay.js.map +1 -0
  103. package/dist/cjs/components/CalendarDays/CalendarDays.d.ts +22 -0
  104. package/dist/cjs/components/CalendarDays/CalendarDays.js +118 -0
  105. package/dist/cjs/components/CalendarDays/CalendarDays.js.map +1 -0
  106. package/dist/cjs/components/CalendarHeader/CalendarHeader.d.ts +16 -0
  107. package/dist/cjs/components/CalendarHeader/CalendarHeader.js +143 -0
  108. package/dist/cjs/components/CalendarHeader/CalendarHeader.js.map +1 -0
  109. package/dist/cjs/components/CalendarRange/CalendarRange.d.ts +16 -0
  110. package/dist/cjs/components/CalendarRange/CalendarRange.js +216 -0
  111. package/dist/cjs/components/CalendarRange/CalendarRange.js.map +1 -0
  112. package/dist/cjs/components/CalendarTime/CalendarTime.d.ts +11 -0
  113. package/dist/cjs/components/CalendarTime/CalendarTime.js +90 -0
  114. package/dist/cjs/components/CalendarTime/CalendarTime.js.map +1 -0
  115. package/dist/cjs/components/CardScroll/CardScroll.js +3 -2
  116. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  117. package/dist/cjs/components/Cell/Cell.d.ts +1 -1
  118. package/dist/cjs/components/Cell/Cell.js +4 -3
  119. package/dist/cjs/components/Cell/Cell.js.map +1 -1
  120. package/dist/cjs/components/CellButton/CellButton.js +1 -0
  121. package/dist/cjs/components/CellButton/CellButton.js.map +1 -1
  122. package/dist/cjs/components/Checkbox/Checkbox.js +2 -5
  123. package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
  124. package/dist/cjs/components/Chip/Chip.js +3 -4
  125. package/dist/cjs/components/Chip/Chip.js.map +1 -1
  126. package/dist/cjs/components/ChipsInput/ChipsInput.d.ts +1 -2
  127. package/dist/cjs/components/ChipsInput/ChipsInput.js +4 -9
  128. package/dist/cjs/components/ChipsInput/ChipsInput.js.map +1 -1
  129. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts +2 -3
  130. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +15 -23
  131. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  132. package/dist/cjs/components/ClickPopper/ClickPopper.d.ts +1 -1
  133. package/dist/cjs/components/ClickPopper/ClickPopper.js.map +1 -1
  134. package/dist/cjs/components/ConfigProvider/ConfigProvider.d.ts +4 -0
  135. package/dist/cjs/components/ConfigProvider/ConfigProvider.js +8 -2
  136. package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
  137. package/dist/cjs/components/ContentCard/ContentCard.js +9 -10
  138. package/dist/cjs/components/ContentCard/ContentCard.js.map +1 -1
  139. package/dist/cjs/components/Counter/Counter.js +3 -3
  140. package/dist/cjs/components/Counter/Counter.js.map +1 -1
  141. package/dist/cjs/components/CustomScrollView/CustomScrollView.d.ts +1 -1
  142. package/dist/cjs/components/CustomScrollView/CustomScrollView.js.map +1 -1
  143. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +11 -2
  144. package/dist/cjs/components/CustomSelect/CustomSelect.js +63 -42
  145. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  146. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +4 -1
  147. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js +11 -6
  148. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  149. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  150. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js +27 -19
  151. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  152. package/dist/cjs/components/DateInput/DateInput.d.ts +12 -0
  153. package/dist/cjs/components/DateInput/DateInput.js +290 -0
  154. package/dist/cjs/components/DateInput/DateInput.js.map +1 -0
  155. package/dist/cjs/components/DatePicker/DatePicker.js +6 -6
  156. package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
  157. package/dist/cjs/components/DateRangeInput/DateRangeInput.d.ts +18 -0
  158. package/dist/cjs/components/DateRangeInput/DateRangeInput.js +310 -0
  159. package/dist/cjs/components/DateRangeInput/DateRangeInput.js.map +1 -0
  160. package/dist/cjs/components/Div/Div.d.ts +1 -2
  161. package/dist/cjs/components/Div/Div.js +2 -5
  162. package/dist/cjs/components/Div/Div.js.map +1 -1
  163. package/dist/cjs/components/File/File.js +2 -2
  164. package/dist/cjs/components/File/File.js.map +1 -1
  165. package/dist/cjs/components/FixedLayout/FixedLayout.js +2 -1
  166. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  167. package/dist/cjs/components/Footer/Footer.js +2 -4
  168. package/dist/cjs/components/Footer/Footer.js.map +1 -1
  169. package/dist/cjs/components/FormField/FormField.js +2 -6
  170. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  171. package/dist/cjs/components/FormItem/FormItem.js +6 -7
  172. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  173. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  174. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  175. package/dist/cjs/components/FormStatus/FormStatus.js +3 -8
  176. package/dist/cjs/components/FormStatus/FormStatus.js.map +1 -1
  177. package/dist/cjs/components/Gallery/Gallery.d.ts +9 -1
  178. package/dist/cjs/components/Gallery/Gallery.js +10 -2
  179. package/dist/cjs/components/Gallery/Gallery.js.map +1 -1
  180. package/dist/cjs/components/GridAvatar/GridAvatar.d.ts +1 -0
  181. package/dist/cjs/components/GridAvatar/GridAvatar.js +6 -6
  182. package/dist/cjs/components/GridAvatar/GridAvatar.js.map +1 -1
  183. package/dist/cjs/components/Group/Group.js +5 -6
  184. package/dist/cjs/components/Group/Group.js.map +1 -1
  185. package/dist/cjs/components/Header/Header.js +18 -24
  186. package/dist/cjs/components/Header/Header.js.map +1 -1
  187. package/dist/cjs/components/HorizontalCell/HorizontalCell.js +6 -9
  188. package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
  189. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  190. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js +22 -21
  191. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  192. package/dist/cjs/components/IconButton/IconButton.d.ts +1 -1
  193. package/dist/cjs/components/InfoRow/InfoRow.js +2 -2
  194. package/dist/cjs/components/InfoRow/InfoRow.js.map +1 -1
  195. package/dist/cjs/components/Input/Input.d.ts +1 -2
  196. package/dist/cjs/components/Input/Input.js +11 -15
  197. package/dist/cjs/components/Input/Input.js.map +1 -1
  198. package/dist/cjs/components/InputLike/InputLike.d.ts +10 -0
  199. package/dist/cjs/components/InputLike/InputLike.js +71 -0
  200. package/dist/cjs/components/InputLike/InputLike.js.map +1 -0
  201. package/dist/cjs/components/InputLike/InputLikeDivider.d.ts +3 -0
  202. package/dist/cjs/components/InputLike/InputLikeDivider.js +27 -0
  203. package/dist/cjs/components/InputLike/InputLikeDivider.js.map +1 -0
  204. package/dist/cjs/components/List/List.js +1 -0
  205. package/dist/cjs/components/List/List.js.map +1 -1
  206. package/dist/cjs/components/LocaleProviderContext/LocaleProviderContext.d.ts +2 -0
  207. package/dist/cjs/components/LocaleProviderContext/LocaleProviderContext.js +14 -0
  208. package/dist/cjs/components/LocaleProviderContext/LocaleProviderContext.js.map +1 -0
  209. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js +1 -0
  210. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  211. package/dist/cjs/components/ModalCard/ModalCard.d.ts +1 -1
  212. package/dist/cjs/components/ModalCard/ModalCard.js +1 -0
  213. package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
  214. package/dist/cjs/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  215. package/dist/cjs/components/ModalCardBase/ModalCardBase.js +10 -4
  216. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  217. package/dist/cjs/components/ModalPage/ModalPage.d.ts +16 -1
  218. package/dist/cjs/components/ModalPage/ModalPage.js +10 -6
  219. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  220. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js +1 -0
  221. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  222. package/dist/cjs/components/ModalRoot/ModalRoot.d.ts +14 -2
  223. package/dist/cjs/components/ModalRoot/ModalRoot.js +14 -11
  224. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  225. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  226. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  227. package/dist/cjs/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  228. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +10 -7
  229. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  230. package/dist/cjs/components/ModalRoot/types.d.ts +16 -1
  231. package/dist/cjs/components/ModalRoot/types.js.map +1 -1
  232. package/dist/cjs/components/ModalRoot/useModalManager.d.ts +6 -5
  233. package/dist/cjs/components/ModalRoot/useModalManager.js +54 -16
  234. package/dist/cjs/components/ModalRoot/useModalManager.js.map +1 -1
  235. package/dist/cjs/components/NativeSelect/NativeSelect.js +2 -1
  236. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  237. package/dist/cjs/components/Pagination/Pagination.d.ts +42 -0
  238. package/dist/cjs/components/Pagination/Pagination.js +152 -0
  239. package/dist/cjs/components/Pagination/Pagination.js.map +1 -0
  240. package/dist/cjs/components/Panel/Panel.js +2 -1
  241. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  242. package/dist/cjs/components/PanelHeader/PanelHeader.js +1 -0
  243. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  244. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.d.ts +1 -1
  245. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js +1 -0
  246. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  247. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js +5 -4
  248. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  249. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js +2 -4
  250. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  251. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js +1 -0
  252. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  253. package/dist/cjs/components/Placeholder/Placeholder.js +4 -3
  254. package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
  255. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js +1 -0
  256. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  257. package/dist/cjs/components/Popper/Popper.js +2 -2
  258. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  259. package/dist/cjs/components/PromoBanner/PromoBanner.js +5 -9
  260. package/dist/cjs/components/PromoBanner/PromoBanner.js.map +1 -1
  261. package/dist/cjs/components/PullToRefresh/PullToRefresh.js +2 -1
  262. package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
  263. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js +1 -0
  264. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  265. package/dist/cjs/components/Radio/Radio.js +2 -5
  266. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  267. package/dist/cjs/components/RichCell/RichCell.d.ts +3 -2
  268. package/dist/cjs/components/RichCell/RichCell.js +3 -2
  269. package/dist/cjs/components/RichCell/RichCell.js.map +1 -1
  270. package/dist/cjs/components/RichTooltip/RichTooltip.js +2 -1
  271. package/dist/cjs/components/RichTooltip/RichTooltip.js.map +1 -1
  272. package/dist/cjs/components/Root/Root.js +8 -7
  273. package/dist/cjs/components/Root/Root.js.map +1 -1
  274. package/dist/cjs/components/Search/Search.js +3 -2
  275. package/dist/cjs/components/Search/Search.js.map +1 -1
  276. package/dist/cjs/components/SegmentedControl/SegmentedControl.js +19 -13
  277. package/dist/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
  278. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
  279. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  280. package/dist/cjs/components/Select/Select.d.ts +1 -2
  281. package/dist/cjs/components/Select/Select.js +7 -9
  282. package/dist/cjs/components/Select/Select.js.map +1 -1
  283. package/dist/cjs/components/SelectMimicry/SelectMimicry.d.ts +5 -1
  284. package/dist/cjs/components/SelectMimicry/SelectMimicry.js +13 -6
  285. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  286. package/dist/cjs/components/Separator/Separator.js +3 -1
  287. package/dist/cjs/components/Separator/Separator.js.map +1 -1
  288. package/dist/cjs/components/SimpleCell/SimpleCell.d.ts +1 -1
  289. package/dist/cjs/components/SimpleCell/SimpleCell.js +5 -4
  290. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  291. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.d.ts +0 -1
  292. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js +8 -7
  293. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  294. package/dist/cjs/components/SliderSwitch/SliderSwitch.js +1 -0
  295. package/dist/cjs/components/SliderSwitch/SliderSwitch.js.map +1 -1
  296. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js +1 -0
  297. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  298. package/dist/cjs/components/Snackbar/Snackbar.js +3 -2
  299. package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
  300. package/dist/cjs/components/Spacing/Spacing.js +4 -3
  301. package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
  302. package/dist/cjs/components/SplitCol/SplitCol.js +2 -1
  303. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  304. package/dist/cjs/components/SplitLayout/SplitLayout.js +2 -1
  305. package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
  306. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js +2 -2
  307. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  308. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js +7 -7
  309. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  310. package/dist/cjs/components/Switch/Switch.js +1 -0
  311. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  312. package/dist/cjs/components/Tabbar/Tabbar.js +1 -0
  313. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  314. package/dist/cjs/components/TabbarItem/TabbarItem.js +2 -1
  315. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  316. package/dist/cjs/components/TabsItem/TabsItem.js +3 -2
  317. package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
  318. package/dist/cjs/components/Tappable/Tappable.d.ts +3 -1
  319. package/dist/cjs/components/Tappable/Tappable.js +16 -15
  320. package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
  321. package/dist/cjs/components/TextTooltip/TextTooltip.js +3 -3
  322. package/dist/cjs/components/TextTooltip/TextTooltip.js.map +1 -1
  323. package/dist/cjs/components/Tooltip/Tooltip.js +6 -6
  324. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  325. package/dist/cjs/components/Touch/Touch.js +9 -3
  326. package/dist/cjs/components/Touch/Touch.js.map +1 -1
  327. package/dist/cjs/components/Touch/TouchContext.d.ts +1 -1
  328. package/dist/cjs/components/Touch/TouchContext.js +1 -1
  329. package/dist/cjs/components/Touch/TouchContext.js.map +1 -1
  330. package/dist/cjs/components/Typography/Caption/Caption.d.ts +8 -4
  331. package/dist/cjs/components/Typography/Caption/Caption.js +12 -14
  332. package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
  333. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  334. package/dist/cjs/components/Typography/Paragraph/Paragraph.js +42 -0
  335. package/dist/cjs/components/Typography/Paragraph/Paragraph.js.map +1 -0
  336. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts +4 -3
  337. package/dist/cjs/components/Typography/Subhead/Subhead.js +4 -6
  338. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  339. package/dist/cjs/components/Typography/Text/Text.js +1 -1
  340. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  341. package/dist/cjs/components/Typography/Title/Title.d.ts +4 -3
  342. package/dist/cjs/components/Typography/Title/Title.js +5 -9
  343. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  344. package/dist/cjs/components/UsersStack/UsersStack.js +6 -6
  345. package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
  346. package/dist/cjs/components/View/View.js +5 -0
  347. package/dist/cjs/components/View/View.js.map +1 -1
  348. package/dist/cjs/components/View/ViewInfinite.d.ts +2 -2
  349. package/dist/cjs/components/View/ViewInfinite.js +17 -15
  350. package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
  351. package/dist/cjs/components/View/utils.js +5 -2
  352. package/dist/cjs/components/View/utils.js.map +1 -1
  353. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js +3 -2
  354. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  355. package/dist/cjs/helpers/scheme.js +2 -2
  356. package/dist/cjs/helpers/scheme.js.map +1 -1
  357. package/dist/cjs/hooks/useBooleanState.d.ts +6 -0
  358. package/dist/cjs/hooks/useBooleanState.js +42 -0
  359. package/dist/cjs/hooks/useBooleanState.js.map +1 -0
  360. package/dist/cjs/hooks/useBridgeAdaptivity.d.ts +6 -0
  361. package/dist/cjs/hooks/useBridgeAdaptivity.js +85 -0
  362. package/dist/cjs/hooks/useBridgeAdaptivity.js.map +1 -0
  363. package/dist/cjs/hooks/useCalendar.d.ts +18 -0
  364. package/dist/cjs/hooks/useCalendar.js +78 -0
  365. package/dist/cjs/hooks/useCalendar.js.map +1 -0
  366. package/dist/cjs/hooks/useDateInput.d.ts +30 -0
  367. package/dist/cjs/hooks/useDateInput.js +180 -0
  368. package/dist/cjs/hooks/useDateInput.js.map +1 -0
  369. package/dist/cjs/hooks/useKeyboard.d.ts +1 -1
  370. package/dist/cjs/hooks/useKeyboard.js +1 -1
  371. package/dist/cjs/hooks/useKeyboard.js.map +1 -1
  372. package/dist/cjs/hooks/useKeyboardInputTracker.d.ts +2 -0
  373. package/dist/cjs/hooks/useKeyboardInputTracker.js +15 -4
  374. package/dist/cjs/hooks/useKeyboardInputTracker.js.map +1 -1
  375. package/dist/cjs/hooks/useOrientationChange.d.ts +7 -0
  376. package/dist/cjs/hooks/useOrientationChange.js +56 -0
  377. package/dist/cjs/hooks/useOrientationChange.js.map +1 -0
  378. package/dist/cjs/hooks/usePagination.d.ts +34 -0
  379. package/dist/cjs/hooks/usePagination.js +81 -0
  380. package/dist/cjs/hooks/usePagination.js.map +1 -0
  381. package/dist/cjs/hooks/usePatchChildrenRef.js +1 -1
  382. package/dist/cjs/hooks/usePatchChildrenRef.js.map +1 -1
  383. package/dist/cjs/hooks/useWaitTransitionFinish.js +6 -1
  384. package/dist/cjs/hooks/useWaitTransitionFinish.js.map +1 -1
  385. package/dist/cjs/index.d.ts +32 -11
  386. package/dist/cjs/index.js +94 -22
  387. package/dist/cjs/index.js.map +1 -1
  388. package/dist/cjs/lib/calendar.d.ts +14 -0
  389. package/dist/cjs/lib/calendar.js +131 -0
  390. package/dist/cjs/lib/calendar.js.map +1 -0
  391. package/dist/cjs/lib/date.d.ts +29 -0
  392. package/dist/cjs/lib/date.js +286 -0
  393. package/dist/cjs/lib/date.js.map +1 -0
  394. package/dist/cjs/lib/getNavId.d.ts +2 -1
  395. package/dist/cjs/lib/getNavId.js +1 -1
  396. package/dist/cjs/lib/getNavId.js.map +1 -1
  397. package/dist/cjs/lib/utils.d.ts +2 -1
  398. package/dist/cjs/lib/utils.js +7 -0
  399. package/dist/cjs/lib/utils.js.map +1 -1
  400. package/dist/cjs/lib/warnOnce.d.ts +2 -1
  401. package/dist/cjs/lib/warnOnce.js +3 -1
  402. package/dist/cjs/lib/warnOnce.js.map +1 -1
  403. package/dist/cjs/tokenized/index.d.ts +32 -4
  404. package/dist/cjs/tokenized/index.js +120 -10
  405. package/dist/cjs/tokenized/index.js.map +1 -1
  406. package/dist/cjs/unstable/index.d.ts +6 -6
  407. package/dist/cjs/unstable/index.js +6 -8
  408. package/dist/cjs/unstable/index.js.map +1 -1
  409. package/dist/components/ActionSheet/ActionSheet.js +3 -6
  410. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  411. package/dist/components/ActionSheet/ActionSheetDropdown.js +2 -1
  412. package/dist/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  413. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js +1 -1
  414. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  415. package/dist/components/ActionSheetItem/ActionSheetItem.js +6 -7
  416. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  417. package/dist/components/AdaptivityProvider/AdaptivityProvider.js +43 -11
  418. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  419. package/dist/components/Alert/Alert.js +7 -9
  420. package/dist/components/Alert/Alert.js.map +1 -1
  421. package/dist/components/AppRoot/AppRoot.js +3 -2
  422. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  423. package/dist/components/Avatar/Avatar.js +4 -1
  424. package/dist/components/Avatar/Avatar.js.map +1 -1
  425. package/dist/components/Banner/Banner.js +3 -2
  426. package/dist/components/Banner/Banner.js.map +1 -1
  427. package/dist/components/Button/Button.d.ts +1 -2
  428. package/dist/components/Button/Button.js +32 -40
  429. package/dist/components/Button/Button.js.map +1 -1
  430. package/dist/components/ButtonGroup/ButtonGroup.d.ts +20 -0
  431. package/dist/components/ButtonGroup/ButtonGroup.js +23 -0
  432. package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -0
  433. package/dist/components/Calendar/Calendar.d.ts +21 -0
  434. package/dist/components/Calendar/Calendar.js +133 -0
  435. package/dist/components/Calendar/Calendar.js.map +1 -0
  436. package/dist/components/CalendarDay/CalendarDay.d.ts +22 -0
  437. package/dist/components/CalendarDay/CalendarDay.js +94 -0
  438. package/dist/components/CalendarDay/CalendarDay.js.map +1 -0
  439. package/dist/components/CalendarDays/CalendarDays.d.ts +22 -0
  440. package/dist/components/CalendarDays/CalendarDays.js +94 -0
  441. package/dist/components/CalendarDays/CalendarDays.js.map +1 -0
  442. package/dist/components/CalendarHeader/CalendarHeader.d.ts +16 -0
  443. package/dist/components/CalendarHeader/CalendarHeader.js +118 -0
  444. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -0
  445. package/dist/components/CalendarRange/CalendarRange.d.ts +16 -0
  446. package/dist/components/CalendarRange/CalendarRange.js +193 -0
  447. package/dist/components/CalendarRange/CalendarRange.js.map +1 -0
  448. package/dist/components/CalendarTime/CalendarTime.d.ts +11 -0
  449. package/dist/components/CalendarTime/CalendarTime.js +73 -0
  450. package/dist/components/CalendarTime/CalendarTime.js.map +1 -0
  451. package/dist/components/CardScroll/CardScroll.js +2 -1
  452. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  453. package/dist/components/Cell/Cell.d.ts +1 -1
  454. package/dist/components/Cell/Cell.js +4 -3
  455. package/dist/components/Cell/Cell.js.map +1 -1
  456. package/dist/components/CellButton/CellButton.js +1 -0
  457. package/dist/components/CellButton/CellButton.js.map +1 -1
  458. package/dist/components/Checkbox/Checkbox.js +1 -4
  459. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  460. package/dist/components/Chip/Chip.js +2 -3
  461. package/dist/components/Chip/Chip.js.map +1 -1
  462. package/dist/components/ChipsInput/ChipsInput.d.ts +1 -2
  463. package/dist/components/ChipsInput/ChipsInput.js +3 -10
  464. package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
  465. package/dist/components/ChipsSelect/ChipsSelect.d.ts +2 -3
  466. package/dist/components/ChipsSelect/ChipsSelect.js +7 -13
  467. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  468. package/dist/components/ClickPopper/ClickPopper.d.ts +1 -1
  469. package/dist/components/ClickPopper/ClickPopper.js.map +1 -1
  470. package/dist/components/ConfigProvider/ConfigProvider.d.ts +4 -0
  471. package/dist/components/ConfigProvider/ConfigProvider.js +7 -2
  472. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  473. package/dist/components/ContentCard/ContentCard.js +6 -7
  474. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  475. package/dist/components/Counter/Counter.js +2 -2
  476. package/dist/components/Counter/Counter.js.map +1 -1
  477. package/dist/components/CustomScrollView/CustomScrollView.d.ts +1 -1
  478. package/dist/components/CustomScrollView/CustomScrollView.js.map +1 -1
  479. package/dist/components/CustomSelect/CustomSelect.d.ts +11 -2
  480. package/dist/components/CustomSelect/CustomSelect.js +57 -35
  481. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  482. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +4 -1
  483. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js +11 -6
  484. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  485. package/dist/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  486. package/dist/components/CustomSelectOption/CustomSelectOption.js +21 -19
  487. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  488. package/dist/components/DateInput/DateInput.d.ts +12 -0
  489. package/dist/components/DateInput/DateInput.js +261 -0
  490. package/dist/components/DateInput/DateInput.js.map +1 -0
  491. package/dist/components/DatePicker/DatePicker.js +2 -2
  492. package/dist/components/DatePicker/DatePicker.js.map +1 -1
  493. package/dist/components/DateRangeInput/DateRangeInput.d.ts +18 -0
  494. package/dist/components/DateRangeInput/DateRangeInput.js +281 -0
  495. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -0
  496. package/dist/components/Div/Div.d.ts +1 -2
  497. package/dist/components/Div/Div.js +1 -3
  498. package/dist/components/Div/Div.js.map +1 -1
  499. package/dist/components/File/File.js +1 -1
  500. package/dist/components/File/File.js.map +1 -1
  501. package/dist/components/FixedLayout/FixedLayout.js +2 -1
  502. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  503. package/dist/components/Footer/Footer.js +1 -3
  504. package/dist/components/Footer/Footer.js.map +1 -1
  505. package/dist/components/FormField/FormField.js +2 -6
  506. package/dist/components/FormField/FormField.js.map +1 -1
  507. package/dist/components/FormItem/FormItem.js +4 -5
  508. package/dist/components/FormItem/FormItem.js.map +1 -1
  509. package/dist/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  510. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  511. package/dist/components/FormStatus/FormStatus.js +2 -7
  512. package/dist/components/FormStatus/FormStatus.js.map +1 -1
  513. package/dist/components/Gallery/Gallery.d.ts +9 -1
  514. package/dist/components/Gallery/Gallery.js +10 -2
  515. package/dist/components/Gallery/Gallery.js.map +1 -1
  516. package/dist/components/GridAvatar/GridAvatar.d.ts +1 -0
  517. package/dist/components/GridAvatar/GridAvatar.js +5 -6
  518. package/dist/components/GridAvatar/GridAvatar.js.map +1 -1
  519. package/dist/components/Group/Group.js +4 -5
  520. package/dist/components/Group/Group.js.map +1 -1
  521. package/dist/components/Header/Header.js +13 -19
  522. package/dist/components/Header/Header.js.map +1 -1
  523. package/dist/components/HorizontalCell/HorizontalCell.js +3 -6
  524. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  525. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  526. package/dist/components/HorizontalScroll/HorizontalScroll.js +20 -18
  527. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  528. package/dist/components/IconButton/IconButton.d.ts +1 -1
  529. package/dist/components/InfoRow/InfoRow.js +1 -1
  530. package/dist/components/InfoRow/InfoRow.js.map +1 -1
  531. package/dist/components/Input/Input.d.ts +1 -2
  532. package/dist/components/Input/Input.js +8 -10
  533. package/dist/components/Input/Input.js.map +1 -1
  534. package/dist/components/InputLike/InputLike.d.ts +10 -0
  535. package/dist/components/InputLike/InputLike.js +52 -0
  536. package/dist/components/InputLike/InputLike.js.map +1 -0
  537. package/dist/components/InputLike/InputLikeDivider.d.ts +3 -0
  538. package/dist/components/InputLike/InputLikeDivider.js +13 -0
  539. package/dist/components/InputLike/InputLikeDivider.js.map +1 -0
  540. package/dist/components/List/List.js +1 -0
  541. package/dist/components/List/List.js.map +1 -1
  542. package/dist/components/LocaleProviderContext/LocaleProviderContext.d.ts +2 -0
  543. package/dist/components/LocaleProviderContext/LocaleProviderContext.js +3 -0
  544. package/dist/components/LocaleProviderContext/LocaleProviderContext.js.map +1 -0
  545. package/dist/components/MiniInfoCell/MiniInfoCell.js +1 -0
  546. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  547. package/dist/components/ModalCard/ModalCard.d.ts +1 -1
  548. package/dist/components/ModalCard/ModalCard.js +1 -0
  549. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  550. package/dist/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  551. package/dist/components/ModalCardBase/ModalCardBase.js +9 -3
  552. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  553. package/dist/components/ModalPage/ModalPage.d.ts +16 -1
  554. package/dist/components/ModalPage/ModalPage.js +9 -6
  555. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  556. package/dist/components/ModalPageHeader/ModalPageHeader.js +1 -0
  557. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  558. package/dist/components/ModalRoot/ModalRoot.d.ts +14 -2
  559. package/dist/components/ModalRoot/ModalRoot.js +14 -11
  560. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  561. package/dist/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  562. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  563. package/dist/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  564. package/dist/components/ModalRoot/ModalRootDesktop.js +10 -7
  565. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  566. package/dist/components/ModalRoot/types.d.ts +16 -1
  567. package/dist/components/ModalRoot/types.js.map +1 -1
  568. package/dist/components/ModalRoot/useModalManager.d.ts +6 -5
  569. package/dist/components/ModalRoot/useModalManager.js +54 -16
  570. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  571. package/dist/components/NativeSelect/NativeSelect.js +2 -1
  572. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  573. package/dist/components/Pagination/Pagination.d.ts +42 -0
  574. package/dist/components/Pagination/Pagination.js +129 -0
  575. package/dist/components/Pagination/Pagination.js.map +1 -0
  576. package/dist/components/Panel/Panel.js +2 -1
  577. package/dist/components/Panel/Panel.js.map +1 -1
  578. package/dist/components/PanelHeader/PanelHeader.js +1 -0
  579. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  580. package/dist/components/PanelHeaderBack/PanelHeaderBack.d.ts +1 -1
  581. package/dist/components/PanelHeaderBack/PanelHeaderBack.js +1 -0
  582. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  583. package/dist/components/PanelHeaderButton/PanelHeaderButton.js +4 -3
  584. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  585. package/dist/components/PanelHeaderContent/PanelHeaderContent.js +1 -3
  586. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  587. package/dist/components/PanelHeaderContext/PanelHeaderContext.js +1 -0
  588. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  589. package/dist/components/Placeholder/Placeholder.js +3 -2
  590. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  591. package/dist/components/PopoutWrapper/PopoutWrapper.js +1 -0
  592. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  593. package/dist/components/Popper/Popper.js +2 -2
  594. package/dist/components/Popper/Popper.js.map +1 -1
  595. package/dist/components/PromoBanner/PromoBanner.js +2 -6
  596. package/dist/components/PromoBanner/PromoBanner.js.map +1 -1
  597. package/dist/components/PullToRefresh/PullToRefresh.js +2 -1
  598. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  599. package/dist/components/PullToRefresh/PullToRefreshSpinner.js +1 -0
  600. package/dist/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  601. package/dist/components/Radio/Radio.js +1 -4
  602. package/dist/components/Radio/Radio.js.map +1 -1
  603. package/dist/components/RichCell/RichCell.d.ts +3 -2
  604. package/dist/components/RichCell/RichCell.js +2 -1
  605. package/dist/components/RichCell/RichCell.js.map +1 -1
  606. package/dist/components/RichTooltip/RichTooltip.js +2 -1
  607. package/dist/components/RichTooltip/RichTooltip.js.map +1 -1
  608. package/dist/components/Root/Root.js +8 -7
  609. package/dist/components/Root/Root.js.map +1 -1
  610. package/dist/components/Search/Search.js +2 -1
  611. package/dist/components/Search/Search.js.map +1 -1
  612. package/dist/components/SegmentedControl/SegmentedControl.js +19 -13
  613. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  614. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
  615. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  616. package/dist/components/Select/Select.d.ts +1 -2
  617. package/dist/components/Select/Select.js +4 -5
  618. package/dist/components/Select/Select.js.map +1 -1
  619. package/dist/components/SelectMimicry/SelectMimicry.d.ts +5 -1
  620. package/dist/components/SelectMimicry/SelectMimicry.js +12 -6
  621. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  622. package/dist/components/Separator/Separator.js +3 -1
  623. package/dist/components/Separator/Separator.js.map +1 -1
  624. package/dist/components/SimpleCell/SimpleCell.d.ts +1 -1
  625. package/dist/components/SimpleCell/SimpleCell.js +3 -2
  626. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  627. package/dist/components/SimpleCheckbox/SimpleCheckbox.d.ts +0 -1
  628. package/dist/components/SimpleCheckbox/SimpleCheckbox.js +7 -5
  629. package/dist/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  630. package/dist/components/SliderSwitch/SliderSwitch.js +1 -0
  631. package/dist/components/SliderSwitch/SliderSwitch.js.map +1 -1
  632. package/dist/components/SliderSwitch/SliderSwitchButton.js +1 -0
  633. package/dist/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  634. package/dist/components/Snackbar/Snackbar.js +2 -1
  635. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  636. package/dist/components/Spacing/Spacing.js +4 -3
  637. package/dist/components/Spacing/Spacing.js.map +1 -1
  638. package/dist/components/SplitCol/SplitCol.js +2 -1
  639. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  640. package/dist/components/SplitLayout/SplitLayout.js +2 -1
  641. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  642. package/dist/components/SubnavigationBar/SubnavigationBar.js +1 -1
  643. package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  644. package/dist/components/SubnavigationButton/SubnavigationButton.js +5 -5
  645. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  646. package/dist/components/Switch/Switch.js +1 -0
  647. package/dist/components/Switch/Switch.js.map +1 -1
  648. package/dist/components/Tabbar/Tabbar.js +1 -0
  649. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  650. package/dist/components/TabbarItem/TabbarItem.js +2 -1
  651. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  652. package/dist/components/TabsItem/TabsItem.js +2 -1
  653. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  654. package/dist/components/Tappable/Tappable.d.ts +3 -1
  655. package/dist/components/Tappable/Tappable.js +15 -15
  656. package/dist/components/Tappable/Tappable.js.map +1 -1
  657. package/dist/components/TextTooltip/TextTooltip.js +1 -1
  658. package/dist/components/TextTooltip/TextTooltip.js.map +1 -1
  659. package/dist/components/Tooltip/Tooltip.js +4 -4
  660. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  661. package/dist/components/Touch/Touch.js +9 -3
  662. package/dist/components/Touch/Touch.js.map +1 -1
  663. package/dist/components/Touch/TouchContext.d.ts +1 -1
  664. package/dist/components/Touch/TouchContext.js +1 -1
  665. package/dist/components/Touch/TouchContext.js.map +1 -1
  666. package/dist/components/Typography/Caption/Caption.d.ts +8 -4
  667. package/dist/components/Typography/Caption/Caption.js +10 -14
  668. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  669. package/dist/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  670. package/dist/components/Typography/Paragraph/Paragraph.js +25 -0
  671. package/dist/components/Typography/Paragraph/Paragraph.js.map +1 -0
  672. package/dist/components/Typography/Subhead/Subhead.d.ts +4 -3
  673. package/dist/components/Typography/Subhead/Subhead.js +3 -7
  674. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  675. package/dist/components/Typography/Text/Text.js +1 -1
  676. package/dist/components/Typography/Text/Text.js.map +1 -1
  677. package/dist/components/Typography/Title/Title.d.ts +4 -3
  678. package/dist/components/Typography/Title/Title.js +3 -8
  679. package/dist/components/Typography/Title/Title.js.map +1 -1
  680. package/dist/components/UsersStack/UsersStack.js +4 -4
  681. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  682. package/dist/components/View/View.js +5 -0
  683. package/dist/components/View/View.js.map +1 -1
  684. package/dist/components/View/ViewInfinite.d.ts +2 -2
  685. package/dist/components/View/ViewInfinite.js +15 -11
  686. package/dist/components/View/ViewInfinite.js.map +1 -1
  687. package/dist/components/View/utils.js +5 -2
  688. package/dist/components/View/utils.js.map +1 -1
  689. package/dist/components/WriteBarIcon/WriteBarIcon.js +3 -2
  690. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  691. package/dist/components.css +21 -6
  692. package/dist/components.css.map +1 -1
  693. package/dist/cssm/components/ActionSheet/ActionSheet.js +3 -6
  694. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  695. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js +2 -1
  696. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  697. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js +1 -1
  698. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  699. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js +6 -7
  700. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  701. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js +43 -11
  702. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  703. package/dist/cssm/components/Alert/Alert.css +1 -1
  704. package/dist/cssm/components/Alert/Alert.js +7 -9
  705. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  706. package/dist/cssm/components/AppRoot/AppRoot.js +3 -2
  707. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  708. package/dist/cssm/components/Avatar/Avatar.js +4 -1
  709. package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
  710. package/dist/cssm/components/Banner/Banner.js +3 -2
  711. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  712. package/dist/cssm/components/Button/Button.css +1 -1
  713. package/dist/cssm/components/Button/Button.d.ts +1 -2
  714. package/dist/cssm/components/Button/Button.js +32 -40
  715. package/dist/cssm/components/Button/Button.js.map +1 -1
  716. package/dist/cssm/components/ButtonGroup/ButtonGroup.css +1 -0
  717. package/dist/cssm/components/ButtonGroup/ButtonGroup.d.ts +20 -0
  718. package/dist/cssm/components/ButtonGroup/ButtonGroup.js +24 -0
  719. package/dist/cssm/components/ButtonGroup/ButtonGroup.js.map +1 -0
  720. package/dist/cssm/components/Calendar/Calendar.css +1 -0
  721. package/dist/cssm/components/Calendar/Calendar.d.ts +21 -0
  722. package/dist/cssm/components/Calendar/Calendar.js +134 -0
  723. package/dist/cssm/components/Calendar/Calendar.js.map +1 -0
  724. package/dist/cssm/components/CalendarDay/CalendarDay.css +1 -0
  725. package/dist/cssm/components/CalendarDay/CalendarDay.d.ts +22 -0
  726. package/dist/cssm/components/CalendarDay/CalendarDay.js +95 -0
  727. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -0
  728. package/dist/cssm/components/CalendarDays/CalendarDays.css +1 -0
  729. package/dist/cssm/components/CalendarDays/CalendarDays.d.ts +22 -0
  730. package/dist/cssm/components/CalendarDays/CalendarDays.js +95 -0
  731. package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -0
  732. package/dist/cssm/components/CalendarHeader/CalendarHeader.css +1 -0
  733. package/dist/cssm/components/CalendarHeader/CalendarHeader.d.ts +16 -0
  734. package/dist/cssm/components/CalendarHeader/CalendarHeader.js +119 -0
  735. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -0
  736. package/dist/cssm/components/CalendarRange/CalendarRange.css +1 -0
  737. package/dist/cssm/components/CalendarRange/CalendarRange.d.ts +16 -0
  738. package/dist/cssm/components/CalendarRange/CalendarRange.js +194 -0
  739. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -0
  740. package/dist/cssm/components/CalendarTime/CalendarTime.css +1 -0
  741. package/dist/cssm/components/CalendarTime/CalendarTime.d.ts +11 -0
  742. package/dist/cssm/components/CalendarTime/CalendarTime.js +74 -0
  743. package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -0
  744. package/dist/cssm/components/CardScroll/CardScroll.js +2 -1
  745. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  746. package/dist/cssm/components/Cell/Cell.d.ts +1 -1
  747. package/dist/cssm/components/Cell/Cell.js +4 -3
  748. package/dist/cssm/components/Cell/Cell.js.map +1 -1
  749. package/dist/cssm/components/CellButton/CellButton.js +1 -0
  750. package/dist/cssm/components/CellButton/CellButton.js.map +1 -1
  751. package/dist/cssm/components/Checkbox/Checkbox.js +1 -4
  752. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  753. package/dist/cssm/components/Chip/Chip.js +2 -3
  754. package/dist/cssm/components/Chip/Chip.js.map +1 -1
  755. package/dist/cssm/components/ChipsInput/ChipsInput.css +1 -1
  756. package/dist/cssm/components/ChipsInput/ChipsInput.d.ts +1 -2
  757. package/dist/cssm/components/ChipsInput/ChipsInput.js +3 -10
  758. package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
  759. package/dist/cssm/components/ChipsSelect/ChipsSelect.css +1 -1
  760. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts +2 -3
  761. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +7 -13
  762. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  763. package/dist/cssm/components/ClickPopper/ClickPopper.d.ts +1 -1
  764. package/dist/cssm/components/ClickPopper/ClickPopper.js.map +1 -1
  765. package/dist/cssm/components/ConfigProvider/ConfigProvider.d.ts +4 -0
  766. package/dist/cssm/components/ConfigProvider/ConfigProvider.js +7 -2
  767. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  768. package/dist/cssm/components/ContentCard/ContentCard.js +6 -7
  769. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  770. package/dist/cssm/components/Counter/Counter.js +2 -2
  771. package/dist/cssm/components/Counter/Counter.js.map +1 -1
  772. package/dist/cssm/components/CustomScrollView/CustomScrollView.d.ts +1 -1
  773. package/dist/cssm/components/CustomScrollView/CustomScrollView.js.map +1 -1
  774. package/dist/cssm/components/CustomSelect/CustomSelect.css +1 -1
  775. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +11 -2
  776. package/dist/cssm/components/CustomSelect/CustomSelect.js +57 -35
  777. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  778. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.css +3 -1
  779. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +4 -1
  780. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js +11 -6
  781. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  782. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.css +3 -1
  783. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  784. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js +21 -19
  785. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  786. package/dist/cssm/components/DateInput/DateInput.css +1 -0
  787. package/dist/cssm/components/DateInput/DateInput.d.ts +12 -0
  788. package/dist/cssm/components/DateInput/DateInput.js +262 -0
  789. package/dist/cssm/components/DateInput/DateInput.js.map +1 -0
  790. package/dist/cssm/components/DatePicker/DatePicker.js +2 -2
  791. package/dist/cssm/components/DatePicker/DatePicker.js.map +1 -1
  792. package/dist/cssm/components/DateRangeInput/DateRangeInput.css +1 -0
  793. package/dist/cssm/components/DateRangeInput/DateRangeInput.d.ts +18 -0
  794. package/dist/cssm/components/DateRangeInput/DateRangeInput.js +282 -0
  795. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -0
  796. package/dist/cssm/components/Div/Div.css +1 -1
  797. package/dist/cssm/components/Div/Div.d.ts +1 -2
  798. package/dist/cssm/components/Div/Div.js +1 -3
  799. package/dist/cssm/components/Div/Div.js.map +1 -1
  800. package/dist/cssm/components/File/File.js +1 -1
  801. package/dist/cssm/components/File/File.js.map +1 -1
  802. package/dist/cssm/components/FixedLayout/FixedLayout.js +2 -1
  803. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  804. package/dist/cssm/components/Footer/Footer.js +1 -3
  805. package/dist/cssm/components/Footer/Footer.js.map +1 -1
  806. package/dist/cssm/components/FormField/FormField.css +5 -1
  807. package/dist/cssm/components/FormField/FormField.js +2 -6
  808. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  809. package/dist/cssm/components/FormItem/FormItem.js +4 -5
  810. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  811. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  812. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  813. package/dist/cssm/components/FormStatus/FormStatus.css +1 -1
  814. package/dist/cssm/components/FormStatus/FormStatus.js +2 -7
  815. package/dist/cssm/components/FormStatus/FormStatus.js.map +1 -1
  816. package/dist/cssm/components/Gallery/Gallery.d.ts +9 -1
  817. package/dist/cssm/components/Gallery/Gallery.js +10 -2
  818. package/dist/cssm/components/Gallery/Gallery.js.map +1 -1
  819. package/dist/cssm/components/GridAvatar/GridAvatar.css +1 -1
  820. package/dist/cssm/components/GridAvatar/GridAvatar.d.ts +1 -0
  821. package/dist/cssm/components/GridAvatar/GridAvatar.js +5 -6
  822. package/dist/cssm/components/GridAvatar/GridAvatar.js.map +1 -1
  823. package/dist/cssm/components/Group/Group.js +4 -5
  824. package/dist/cssm/components/Group/Group.js.map +1 -1
  825. package/dist/cssm/components/Header/Header.js +13 -19
  826. package/dist/cssm/components/Header/Header.js.map +1 -1
  827. package/dist/cssm/components/HorizontalCell/HorizontalCell.js +3 -6
  828. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  829. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  830. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +20 -18
  831. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  832. package/dist/cssm/components/IconButton/IconButton.d.ts +1 -1
  833. package/dist/cssm/components/InfoRow/InfoRow.js +1 -1
  834. package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
  835. package/dist/cssm/components/Input/Input.css +1 -1
  836. package/dist/cssm/components/Input/Input.d.ts +1 -2
  837. package/dist/cssm/components/Input/Input.js +8 -10
  838. package/dist/cssm/components/Input/Input.js.map +1 -1
  839. package/dist/cssm/components/InputLike/InputLike.css +1 -0
  840. package/dist/cssm/components/InputLike/InputLike.d.ts +10 -0
  841. package/dist/cssm/components/InputLike/InputLike.js +53 -0
  842. package/dist/cssm/components/InputLike/InputLike.js.map +1 -0
  843. package/dist/cssm/components/InputLike/InputLikeDivider.css +1 -0
  844. package/dist/cssm/components/InputLike/InputLikeDivider.d.ts +3 -0
  845. package/dist/cssm/components/InputLike/InputLikeDivider.js +14 -0
  846. package/dist/cssm/components/InputLike/InputLikeDivider.js.map +1 -0
  847. package/dist/cssm/components/List/List.js +1 -0
  848. package/dist/cssm/components/List/List.js.map +1 -1
  849. package/dist/cssm/components/LocaleProviderContext/LocaleProviderContext.d.ts +2 -0
  850. package/dist/cssm/components/LocaleProviderContext/LocaleProviderContext.js +3 -0
  851. package/dist/cssm/components/LocaleProviderContext/LocaleProviderContext.js.map +1 -0
  852. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js +1 -0
  853. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  854. package/dist/cssm/components/ModalCard/ModalCard.css +1 -1
  855. package/dist/cssm/components/ModalCard/ModalCard.d.ts +1 -1
  856. package/dist/cssm/components/ModalCard/ModalCard.js +1 -0
  857. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  858. package/dist/cssm/components/ModalCardBase/ModalCardBase.css +1 -1
  859. package/dist/cssm/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  860. package/dist/cssm/components/ModalCardBase/ModalCardBase.js +9 -3
  861. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  862. package/dist/cssm/components/ModalPage/ModalPage.d.ts +16 -1
  863. package/dist/cssm/components/ModalPage/ModalPage.js +9 -6
  864. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  865. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js +1 -0
  866. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  867. package/dist/cssm/components/ModalRoot/ModalRoot.d.ts +14 -2
  868. package/dist/cssm/components/ModalRoot/ModalRoot.js +14 -11
  869. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  870. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  871. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  872. package/dist/cssm/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  873. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +10 -7
  874. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  875. package/dist/cssm/components/ModalRoot/types.d.ts +16 -1
  876. package/dist/cssm/components/ModalRoot/types.js.map +1 -1
  877. package/dist/cssm/components/ModalRoot/useModalManager.d.ts +6 -5
  878. package/dist/cssm/components/ModalRoot/useModalManager.js +54 -16
  879. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  880. package/dist/cssm/components/NativeSelect/NativeSelect.js +2 -1
  881. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  882. package/dist/cssm/components/Pagination/Pagination.css +1 -0
  883. package/dist/cssm/components/Pagination/Pagination.d.ts +42 -0
  884. package/dist/cssm/components/Pagination/Pagination.js +130 -0
  885. package/dist/cssm/components/Pagination/Pagination.js.map +1 -0
  886. package/dist/cssm/components/Panel/Panel.js +2 -1
  887. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  888. package/dist/cssm/components/PanelHeader/PanelHeader.css +1 -1
  889. package/dist/cssm/components/PanelHeader/PanelHeader.js +1 -0
  890. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  891. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.d.ts +1 -1
  892. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js +1 -0
  893. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  894. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.css +1 -1
  895. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js +4 -3
  896. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  897. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.css +1 -1
  898. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js +1 -3
  899. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  900. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js +1 -0
  901. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  902. package/dist/cssm/components/Placeholder/Placeholder.js +3 -2
  903. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  904. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +1 -0
  905. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  906. package/dist/cssm/components/Popper/Popper.js +2 -2
  907. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  908. package/dist/cssm/components/PromoBanner/PromoBanner.js +2 -6
  909. package/dist/cssm/components/PromoBanner/PromoBanner.js.map +1 -1
  910. package/dist/cssm/components/PullToRefresh/PullToRefresh.js +2 -1
  911. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  912. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js +1 -0
  913. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  914. package/dist/cssm/components/Radio/Radio.js +1 -4
  915. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  916. package/dist/cssm/components/Removable/Removable.css +1 -1
  917. package/dist/cssm/components/RichCell/RichCell.d.ts +3 -2
  918. package/dist/cssm/components/RichCell/RichCell.js +2 -1
  919. package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
  920. package/dist/cssm/components/RichTooltip/RichTooltip.js +2 -1
  921. package/dist/cssm/components/RichTooltip/RichTooltip.js.map +1 -1
  922. package/dist/cssm/components/Root/Root.css +1 -1
  923. package/dist/cssm/components/Root/Root.js +8 -7
  924. package/dist/cssm/components/Root/Root.js.map +1 -1
  925. package/dist/cssm/components/Search/Search.css +1 -1
  926. package/dist/cssm/components/Search/Search.js +2 -1
  927. package/dist/cssm/components/Search/Search.js.map +1 -1
  928. package/dist/cssm/components/SegmentedControl/SegmentedControl.js +19 -13
  929. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  930. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +1 -1
  931. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
  932. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  933. package/dist/cssm/components/Select/Select.css +1 -1
  934. package/dist/cssm/components/Select/Select.d.ts +1 -2
  935. package/dist/cssm/components/Select/Select.js +4 -5
  936. package/dist/cssm/components/Select/Select.js.map +1 -1
  937. package/dist/cssm/components/SelectMimicry/SelectMimicry.css +1 -0
  938. package/dist/cssm/components/SelectMimicry/SelectMimicry.d.ts +5 -1
  939. package/dist/cssm/components/SelectMimicry/SelectMimicry.js +13 -6
  940. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  941. package/dist/cssm/components/Separator/Separator.js +3 -1
  942. package/dist/cssm/components/Separator/Separator.js.map +1 -1
  943. package/dist/cssm/components/SimpleCell/SimpleCell.css +1 -1
  944. package/dist/cssm/components/SimpleCell/SimpleCell.d.ts +1 -1
  945. package/dist/cssm/components/SimpleCell/SimpleCell.js +3 -2
  946. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  947. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.d.ts +0 -1
  948. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js +7 -5
  949. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  950. package/dist/cssm/components/SliderSwitch/SliderSwitch.js +1 -0
  951. package/dist/cssm/components/SliderSwitch/SliderSwitch.js.map +1 -1
  952. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js +1 -0
  953. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  954. package/dist/cssm/components/Snackbar/Snackbar.js +2 -1
  955. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  956. package/dist/cssm/components/Spacing/Spacing.js +4 -3
  957. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  958. package/dist/cssm/components/SplitCol/SplitCol.js +2 -1
  959. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  960. package/dist/cssm/components/SplitLayout/SplitLayout.css +1 -1
  961. package/dist/cssm/components/SplitLayout/SplitLayout.js +2 -1
  962. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  963. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js +1 -1
  964. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  965. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +5 -5
  966. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  967. package/dist/cssm/components/Switch/Switch.js +1 -0
  968. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  969. package/dist/cssm/components/Tabbar/Tabbar.js +1 -0
  970. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  971. package/dist/cssm/components/TabbarItem/TabbarItem.css +1 -1
  972. package/dist/cssm/components/TabbarItem/TabbarItem.js +2 -1
  973. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  974. package/dist/cssm/components/Tabs/Tabs.css +1 -1
  975. package/dist/cssm/components/TabsItem/TabsItem.js +2 -1
  976. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  977. package/dist/cssm/components/Tappable/Tappable.css +1 -1
  978. package/dist/cssm/components/Tappable/Tappable.d.ts +3 -1
  979. package/dist/cssm/components/Tappable/Tappable.js +15 -15
  980. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  981. package/dist/cssm/components/TextTooltip/TextTooltip.js +1 -1
  982. package/dist/cssm/components/TextTooltip/TextTooltip.js.map +1 -1
  983. package/dist/cssm/components/Textarea/Textarea.css +1 -1
  984. package/dist/cssm/components/Tooltip/Tooltip.js +4 -4
  985. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  986. package/dist/cssm/components/Touch/Touch.js +9 -3
  987. package/dist/cssm/components/Touch/Touch.js.map +1 -1
  988. package/dist/cssm/components/Touch/TouchContext.d.ts +1 -1
  989. package/dist/cssm/components/Touch/TouchContext.js +1 -1
  990. package/dist/cssm/components/Touch/TouchContext.js.map +1 -1
  991. package/dist/cssm/components/Typography/Caption/Caption.css +1 -1
  992. package/dist/cssm/components/Typography/Caption/Caption.d.ts +8 -4
  993. package/dist/cssm/components/Typography/Caption/Caption.js +10 -14
  994. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  995. package/dist/cssm/components/Typography/Headline/Headline.css +1 -1
  996. package/dist/cssm/components/Typography/Paragraph/Paragraph.css +1 -0
  997. package/dist/cssm/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  998. package/dist/cssm/components/Typography/Paragraph/Paragraph.js +26 -0
  999. package/dist/cssm/components/Typography/Paragraph/Paragraph.js.map +1 -0
  1000. package/dist/cssm/components/Typography/Subhead/Subhead.css +1 -1
  1001. package/dist/cssm/components/Typography/Subhead/Subhead.d.ts +4 -3
  1002. package/dist/cssm/components/Typography/Subhead/Subhead.js +3 -7
  1003. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  1004. package/dist/cssm/components/Typography/Text/Text.css +1 -1
  1005. package/dist/cssm/components/Typography/Text/Text.js +1 -1
  1006. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  1007. package/dist/cssm/components/Typography/Title/Title.css +1 -1
  1008. package/dist/cssm/components/Typography/Title/Title.d.ts +4 -3
  1009. package/dist/cssm/components/Typography/Title/Title.js +3 -8
  1010. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  1011. package/dist/cssm/components/UsersStack/UsersStack.js +4 -4
  1012. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  1013. package/dist/cssm/components/View/View.css +1 -1
  1014. package/dist/cssm/components/View/View.js +5 -0
  1015. package/dist/cssm/components/View/View.js.map +1 -1
  1016. package/dist/cssm/components/View/ViewIOS.css +1 -1
  1017. package/dist/cssm/components/View/ViewInfinite.d.ts +2 -2
  1018. package/dist/cssm/components/View/ViewInfinite.js +15 -11
  1019. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  1020. package/dist/cssm/components/View/utils.js +5 -2
  1021. package/dist/cssm/components/View/utils.js.map +1 -1
  1022. package/dist/cssm/components/WriteBar/WriteBar.css +1 -1
  1023. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +3 -2
  1024. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1025. package/dist/cssm/helpers/scheme.js +2 -2
  1026. package/dist/cssm/helpers/scheme.js.map +1 -1
  1027. package/dist/cssm/hooks/useBooleanState.d.ts +6 -0
  1028. package/dist/cssm/hooks/useBooleanState.js +27 -0
  1029. package/dist/cssm/hooks/useBooleanState.js.map +1 -0
  1030. package/dist/cssm/hooks/useBridgeAdaptivity.d.ts +6 -0
  1031. package/dist/cssm/hooks/useBridgeAdaptivity.js +68 -0
  1032. package/dist/cssm/hooks/useBridgeAdaptivity.js.map +1 -0
  1033. package/dist/cssm/hooks/useCalendar.d.ts +18 -0
  1034. package/dist/cssm/hooks/useCalendar.js +64 -0
  1035. package/dist/cssm/hooks/useCalendar.js.map +1 -0
  1036. package/dist/cssm/hooks/useDateInput.d.ts +30 -0
  1037. package/dist/cssm/hooks/useDateInput.js +163 -0
  1038. package/dist/cssm/hooks/useDateInput.js.map +1 -0
  1039. package/dist/cssm/hooks/useKeyboard.d.ts +1 -1
  1040. package/dist/cssm/hooks/useKeyboard.js +1 -1
  1041. package/dist/cssm/hooks/useKeyboard.js.map +1 -1
  1042. package/dist/cssm/hooks/useKeyboardInputTracker.d.ts +2 -0
  1043. package/dist/cssm/hooks/useKeyboardInputTracker.js +11 -4
  1044. package/dist/cssm/hooks/useKeyboardInputTracker.js.map +1 -1
  1045. package/dist/cssm/hooks/useOrientationChange.d.ts +7 -0
  1046. package/dist/cssm/hooks/useOrientationChange.js +42 -0
  1047. package/dist/cssm/hooks/useOrientationChange.js.map +1 -0
  1048. package/dist/cssm/hooks/usePagination.d.ts +34 -0
  1049. package/dist/cssm/hooks/usePagination.js +67 -0
  1050. package/dist/cssm/hooks/usePagination.js.map +1 -0
  1051. package/dist/cssm/hooks/usePatchChildrenRef.js +1 -1
  1052. package/dist/cssm/hooks/usePatchChildrenRef.js.map +1 -1
  1053. package/dist/cssm/hooks/useWaitTransitionFinish.js +5 -1
  1054. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  1055. package/dist/cssm/index.d.ts +32 -11
  1056. package/dist/cssm/index.js +20 -14
  1057. package/dist/cssm/index.js.map +1 -1
  1058. package/dist/cssm/lib/calendar.d.ts +14 -0
  1059. package/dist/cssm/lib/calendar.js +100 -0
  1060. package/dist/cssm/lib/calendar.js.map +1 -0
  1061. package/dist/cssm/lib/date.d.ts +29 -0
  1062. package/dist/cssm/lib/date.js +223 -0
  1063. package/dist/cssm/lib/date.js.map +1 -0
  1064. package/dist/cssm/lib/getNavId.d.ts +2 -1
  1065. package/dist/cssm/lib/getNavId.js +1 -1
  1066. package/dist/cssm/lib/getNavId.js.map +1 -1
  1067. package/dist/cssm/lib/utils.d.ts +2 -1
  1068. package/dist/cssm/lib/utils.js +3 -0
  1069. package/dist/cssm/lib/utils.js.map +1 -1
  1070. package/dist/cssm/lib/warnOnce.d.ts +2 -1
  1071. package/dist/cssm/lib/warnOnce.js +3 -1
  1072. package/dist/cssm/lib/warnOnce.js.map +1 -1
  1073. package/dist/cssm/styles/common.css +1 -1
  1074. package/dist/cssm/styles/components.css +21 -6
  1075. package/dist/cssm/styles/constants.css +8 -1
  1076. package/dist/cssm/styles/themes.css +1 -1
  1077. package/dist/cssm/styles/unstable.css +1 -1
  1078. package/dist/cssm/tokenized/index.d.ts +32 -4
  1079. package/dist/cssm/tokenized/index.js +18 -4
  1080. package/dist/cssm/tokenized/index.js.map +1 -1
  1081. package/dist/cssm/unstable/index.d.ts +6 -6
  1082. package/dist/cssm/unstable/index.js +3 -3
  1083. package/dist/cssm/unstable/index.js.map +1 -1
  1084. package/dist/helpers/scheme.js +2 -2
  1085. package/dist/helpers/scheme.js.map +1 -1
  1086. package/dist/hooks/useBooleanState.d.ts +6 -0
  1087. package/dist/hooks/useBooleanState.js +27 -0
  1088. package/dist/hooks/useBooleanState.js.map +1 -0
  1089. package/dist/hooks/useBridgeAdaptivity.d.ts +6 -0
  1090. package/dist/hooks/useBridgeAdaptivity.js +68 -0
  1091. package/dist/hooks/useBridgeAdaptivity.js.map +1 -0
  1092. package/dist/hooks/useCalendar.d.ts +18 -0
  1093. package/dist/hooks/useCalendar.js +64 -0
  1094. package/dist/hooks/useCalendar.js.map +1 -0
  1095. package/dist/hooks/useDateInput.d.ts +30 -0
  1096. package/dist/hooks/useDateInput.js +163 -0
  1097. package/dist/hooks/useDateInput.js.map +1 -0
  1098. package/dist/hooks/useKeyboard.d.ts +1 -1
  1099. package/dist/hooks/useKeyboard.js +1 -1
  1100. package/dist/hooks/useKeyboard.js.map +1 -1
  1101. package/dist/hooks/useKeyboardInputTracker.d.ts +2 -0
  1102. package/dist/hooks/useKeyboardInputTracker.js +11 -4
  1103. package/dist/hooks/useKeyboardInputTracker.js.map +1 -1
  1104. package/dist/hooks/useOrientationChange.d.ts +7 -0
  1105. package/dist/hooks/useOrientationChange.js +42 -0
  1106. package/dist/hooks/useOrientationChange.js.map +1 -0
  1107. package/dist/hooks/usePagination.d.ts +34 -0
  1108. package/dist/hooks/usePagination.js +67 -0
  1109. package/dist/hooks/usePagination.js.map +1 -0
  1110. package/dist/hooks/usePatchChildrenRef.js +1 -1
  1111. package/dist/hooks/usePatchChildrenRef.js.map +1 -1
  1112. package/dist/hooks/useWaitTransitionFinish.js +5 -1
  1113. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  1114. package/dist/index.d.ts +32 -11
  1115. package/dist/index.js +20 -14
  1116. package/dist/index.js.map +1 -1
  1117. package/dist/lib/calendar.d.ts +14 -0
  1118. package/dist/lib/calendar.js +100 -0
  1119. package/dist/lib/calendar.js.map +1 -0
  1120. package/dist/lib/date.d.ts +29 -0
  1121. package/dist/lib/date.js +223 -0
  1122. package/dist/lib/date.js.map +1 -0
  1123. package/dist/lib/getNavId.d.ts +2 -1
  1124. package/dist/lib/getNavId.js +1 -1
  1125. package/dist/lib/getNavId.js.map +1 -1
  1126. package/dist/lib/utils.d.ts +2 -1
  1127. package/dist/lib/utils.js +3 -0
  1128. package/dist/lib/utils.js.map +1 -1
  1129. package/dist/lib/warnOnce.d.ts +2 -1
  1130. package/dist/lib/warnOnce.js +3 -1
  1131. package/dist/lib/warnOnce.js.map +1 -1
  1132. package/dist/tokenized/index.d.ts +32 -4
  1133. package/dist/tokenized/index.js +18 -4
  1134. package/dist/tokenized/index.js.map +1 -1
  1135. package/dist/unstable/index.d.ts +6 -6
  1136. package/dist/unstable/index.js +3 -3
  1137. package/dist/unstable/index.js.map +1 -1
  1138. package/dist/unstable.css +1 -1
  1139. package/dist/unstable.css.map +1 -1
  1140. package/dist/vkui.css +22 -7
  1141. package/dist/vkui.css.map +1 -1
  1142. package/eslint-plugin-vkui/index.js +64 -0
  1143. package/eslint-plugin-vkui/package.json +5 -0
  1144. package/jest.unit.config.js +4 -1
  1145. package/package.json +15 -11
  1146. package/postcss-plugin-vk-sans/__tests__/custom_properties.css +4 -0
  1147. package/postcss-plugin-vk-sans/index.js +343 -0
  1148. package/src/components/ActionSheet/ActionSheet.tsx +4 -7
  1149. package/src/components/ActionSheet/ActionSheetDropdown.tsx +1 -0
  1150. package/src/components/ActionSheet/ActionSheetDropdownDesktop.tsx +1 -1
  1151. package/src/components/ActionSheetItem/ActionSheetItem.tsx +5 -10
  1152. package/src/components/AdaptivityProvider/AdaptivityProvider.tsx +50 -19
  1153. package/src/components/Alert/Alert.tsx +8 -11
  1154. package/src/components/Alert/Readme.md +4 -4
  1155. package/src/components/AppRoot/AppRoot.tsx +2 -1
  1156. package/src/components/AppRoot/Readme.md +2 -2
  1157. package/src/components/Avatar/Avatar.tsx +3 -0
  1158. package/src/components/Banner/Banner.tsx +3 -2
  1159. package/src/components/Button/Button.css +26 -1
  1160. package/src/components/Button/Button.tsx +28 -39
  1161. package/src/components/ButtonGroup/ButtonGroup.css +52 -0
  1162. package/src/components/ButtonGroup/ButtonGroup.tsx +48 -0
  1163. package/src/components/ButtonGroup/Readme.md +311 -0
  1164. package/src/components/Calendar/Calendar.css +31 -0
  1165. package/src/components/Calendar/Calendar.tsx +185 -0
  1166. package/src/components/Calendar/Readme.md +124 -0
  1167. package/src/components/CalendarDay/CalendarDay.css +85 -0
  1168. package/src/components/CalendarDay/CalendarDay.tsx +117 -0
  1169. package/src/components/CalendarDays/CalendarDays.css +31 -0
  1170. package/src/components/CalendarDays/CalendarDays.tsx +131 -0
  1171. package/src/components/CalendarHeader/CalendarHeader.css +50 -0
  1172. package/src/components/CalendarHeader/CalendarHeader.tsx +168 -0
  1173. package/src/components/CalendarRange/CalendarRange.css +27 -0
  1174. package/src/components/CalendarRange/CalendarRange.tsx +275 -0
  1175. package/src/components/CalendarRange/Readme.md +85 -0
  1176. package/src/components/CalendarTime/CalendarTime.css +18 -0
  1177. package/src/components/CalendarTime/CalendarTime.tsx +88 -0
  1178. package/src/components/CardScroll/CardScroll.tsx +3 -1
  1179. package/src/components/Cell/Cell.tsx +4 -3
  1180. package/src/components/CellButton/CellButton.tsx +1 -0
  1181. package/src/components/Checkbox/Checkbox.tsx +2 -9
  1182. package/src/components/Chip/Chip.tsx +3 -8
  1183. package/src/components/ChipsInput/ChipsInput.css +4 -4
  1184. package/src/components/ChipsInput/ChipsInput.tsx +7 -8
  1185. package/src/components/ChipsSelect/ChipsSelect.css +1 -1
  1186. package/src/components/ChipsSelect/ChipsSelect.tsx +15 -14
  1187. package/src/components/ClickPopper/ClickPopper.tsx +1 -1
  1188. package/src/components/ConfigProvider/ConfigProvider.tsx +11 -3
  1189. package/src/components/ContentCard/ContentCard.tsx +5 -11
  1190. package/src/components/Counter/Counter.tsx +2 -2
  1191. package/src/components/CustomScrollView/CustomScrollView.tsx +1 -1
  1192. package/src/components/CustomSelect/CustomSelect.css +1 -16
  1193. package/src/components/CustomSelect/CustomSelect.tsx +65 -23
  1194. package/src/components/CustomSelectDropdown/CustomSelectDropdown.css +22 -5
  1195. package/src/components/CustomSelectDropdown/CustomSelectDropdown.tsx +16 -6
  1196. package/src/components/CustomSelectOption/CustomSelectOption.css +17 -5
  1197. package/src/components/CustomSelectOption/CustomSelectOption.tsx +58 -24
  1198. package/src/components/CustomSelectOption/Readme.md +48 -29
  1199. package/src/components/DateInput/DateInput.css +20 -0
  1200. package/src/components/DateInput/DateInput.tsx +317 -0
  1201. package/src/components/DateInput/Readme.md +116 -0
  1202. package/src/components/DatePicker/DatePicker.tsx +2 -2
  1203. package/src/components/DateRangeInput/DateRangeInput.css +16 -0
  1204. package/src/components/DateRangeInput/DateRangeInput.tsx +350 -0
  1205. package/src/components/DateRangeInput/Readme.md +96 -0
  1206. package/src/components/Div/Div.css +1 -8
  1207. package/src/components/Div/Div.tsx +2 -5
  1208. package/src/components/Epic/Readme.md +5 -1
  1209. package/src/components/File/File.tsx +1 -1
  1210. package/src/components/FixedLayout/FixedLayout.tsx +1 -0
  1211. package/src/components/Footer/Footer.tsx +2 -8
  1212. package/src/components/Footer/Readme.md +1 -1
  1213. package/src/components/FormField/FormField.css +47 -39
  1214. package/src/components/FormField/FormField.tsx +5 -6
  1215. package/src/components/FormItem/FormItem.tsx +4 -5
  1216. package/src/components/FormLayoutGroup/FormLayoutGroup.tsx +1 -0
  1217. package/src/components/FormStatus/FormStatus.tsx +3 -9
  1218. package/src/components/Gallery/Gallery.tsx +14 -2
  1219. package/src/components/Gallery/Readme.md +1 -1
  1220. package/src/components/GridAvatar/GridAvatar.css +10 -13
  1221. package/src/components/GridAvatar/GridAvatar.tsx +12 -24
  1222. package/src/components/Group/Group.tsx +3 -4
  1223. package/src/components/Header/Header.tsx +15 -12
  1224. package/src/components/HorizontalCell/HorizontalCell.tsx +4 -10
  1225. package/src/components/HorizontalScroll/HorizontalScroll.tsx +41 -39
  1226. package/src/components/InfoRow/InfoRow.tsx +1 -1
  1227. package/src/components/Input/Input.css +4 -4
  1228. package/src/components/Input/Input.tsx +5 -9
  1229. package/src/components/InputLike/InputLike.css +25 -0
  1230. package/src/components/InputLike/InputLike.tsx +72 -0
  1231. package/src/components/InputLike/InputLikeDivider.css +4 -0
  1232. package/src/components/InputLike/InputLikeDivider.tsx +12 -0
  1233. package/src/components/List/List.tsx +1 -0
  1234. package/src/components/LocaleProviderContext/LocaleProviderContext.tsx +5 -0
  1235. package/src/components/MiniInfoCell/MiniInfoCell.tsx +1 -0
  1236. package/src/components/ModalCard/ModalCard.css +0 -10
  1237. package/src/components/ModalCard/ModalCard.tsx +1 -0
  1238. package/src/components/ModalCardBase/ModalCardBase.css +10 -0
  1239. package/src/components/ModalCardBase/ModalCardBase.tsx +15 -2
  1240. package/src/components/ModalPage/ModalPage.tsx +29 -4
  1241. package/src/components/ModalPageHeader/ModalPageHeader.tsx +1 -0
  1242. package/src/components/ModalRoot/ModalRoot.tsx +33 -10
  1243. package/src/components/ModalRoot/ModalRootAdaptive.tsx +17 -2
  1244. package/src/components/ModalRoot/ModalRootDesktop.tsx +25 -7
  1245. package/src/components/ModalRoot/Readme.md +112 -0
  1246. package/src/components/ModalRoot/types.ts +16 -1
  1247. package/src/components/ModalRoot/useModalManager.tsx +60 -15
  1248. package/src/components/NativeSelect/NativeSelect.tsx +1 -0
  1249. package/src/components/Pagination/Pagination.css +62 -0
  1250. package/src/components/Pagination/Pagination.tsx +196 -0
  1251. package/src/components/Pagination/Readme.md +110 -0
  1252. package/src/components/Panel/Panel.tsx +1 -0
  1253. package/src/components/PanelHeader/PanelHeader.tsx +1 -0
  1254. package/src/components/PanelHeaderBack/PanelHeaderBack.tsx +1 -0
  1255. package/src/components/PanelHeaderButton/PanelHeaderButton.tsx +4 -2
  1256. package/src/components/PanelHeaderContent/PanelHeaderContent.tsx +2 -8
  1257. package/src/components/PanelHeaderContext/PanelHeaderContext.tsx +1 -0
  1258. package/src/components/Placeholder/Placeholder.tsx +2 -1
  1259. package/src/components/PopoutWrapper/PopoutWrapper.tsx +1 -0
  1260. package/src/components/PopoutWrapper/Readme.md +1 -1
  1261. package/src/components/Popper/Popper.tsx +2 -2
  1262. package/src/components/Popper/Readme.md +1 -1
  1263. package/src/components/PromoBanner/PromoBanner.tsx +4 -6
  1264. package/src/components/PullToRefresh/PullToRefresh.tsx +1 -0
  1265. package/src/components/PullToRefresh/PullToRefreshSpinner.tsx +1 -0
  1266. package/src/components/Radio/Radio.tsx +2 -9
  1267. package/src/components/RichCell/Readme.md +4 -4
  1268. package/src/components/RichCell/RichCell.tsx +4 -2
  1269. package/src/components/RichTooltip/Readme.md +3 -3
  1270. package/src/components/RichTooltip/RichTooltip.tsx +1 -0
  1271. package/src/components/Root/Root.css +4 -11
  1272. package/src/components/Root/Root.tsx +7 -6
  1273. package/src/components/Search/Search.tsx +2 -1
  1274. package/src/components/SegmentedControl/SegmentedControl.tsx +20 -10
  1275. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +1 -1
  1276. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.tsx +1 -0
  1277. package/src/components/Select/Select.css +7 -2
  1278. package/src/components/Select/Select.tsx +3 -4
  1279. package/src/components/SelectMimicry/SelectMimicry.css +10 -0
  1280. package/src/components/SelectMimicry/SelectMimicry.tsx +14 -3
  1281. package/src/components/Separator/Separator.tsx +2 -0
  1282. package/src/components/SimpleCell/SimpleCell.tsx +3 -2
  1283. package/src/components/SimpleCheckbox/SimpleCheckbox.tsx +7 -5
  1284. package/src/components/SliderSwitch/SliderSwitch.tsx +1 -0
  1285. package/src/components/SliderSwitch/SliderSwitchButton.tsx +1 -0
  1286. package/src/components/Snackbar/Snackbar.tsx +2 -1
  1287. package/src/components/Spacing/Spacing.tsx +3 -2
  1288. package/src/components/SplitCol/SplitCol.tsx +1 -0
  1289. package/src/components/SplitLayout/SplitLayout.tsx +1 -0
  1290. package/src/components/SubnavigationBar/SubnavigationBar.tsx +2 -1
  1291. package/src/components/SubnavigationButton/SubnavigationButton.tsx +4 -9
  1292. package/src/components/Switch/Switch.tsx +1 -0
  1293. package/src/components/Tabbar/Readme.md +1 -1
  1294. package/src/components/Tabbar/Tabbar.tsx +1 -0
  1295. package/src/components/TabbarItem/TabbarItem.css +1 -0
  1296. package/src/components/TabbarItem/TabbarItem.tsx +1 -0
  1297. package/src/components/Tabs/Readme.md +7 -7
  1298. package/src/components/TabsItem/TabsItem.tsx +2 -1
  1299. package/src/components/Tappable/Tappable.css +5 -0
  1300. package/src/components/Tappable/Tappable.tsx +17 -5
  1301. package/src/components/TextTooltip/Readme.md +1 -1
  1302. package/src/components/TextTooltip/TextTooltip.tsx +1 -1
  1303. package/src/components/Tooltip/Tooltip.tsx +5 -4
  1304. package/src/components/Touch/Touch.tsx +6 -3
  1305. package/src/components/Touch/TouchContext.ts +1 -1
  1306. package/src/components/Typography/Caption/Caption.css +61 -19
  1307. package/src/components/Typography/Caption/Caption.tsx +24 -15
  1308. package/src/components/Typography/Caption/Readme.md +26 -48
  1309. package/src/components/Typography/Paragraph/Paragraph.css +17 -0
  1310. package/src/components/Typography/Paragraph/Paragraph.tsx +42 -0
  1311. package/src/components/Typography/Paragraph/Readme.md +19 -0
  1312. package/src/components/Typography/Subhead/Subhead.tsx +6 -8
  1313. package/src/components/Typography/Text/Text.tsx +1 -1
  1314. package/src/components/Typography/Title/Title.tsx +10 -10
  1315. package/src/components/UsersStack/UsersStack.tsx +4 -4
  1316. package/src/components/View/Readme.md +2 -2
  1317. package/src/components/View/View.css +1 -1
  1318. package/src/components/View/View.tsx +4 -0
  1319. package/src/components/View/ViewIOS.css +2 -2
  1320. package/src/components/View/ViewInfinite.tsx +7 -4
  1321. package/src/components/View/utils.ts +2 -1
  1322. package/src/components/WriteBarIcon/WriteBarIcon.tsx +3 -1
  1323. package/src/helpers/scheme.ts +3 -2
  1324. package/src/hooks/useBooleanState.ts +19 -0
  1325. package/src/hooks/useBridgeAdaptivity.ts +83 -0
  1326. package/src/hooks/useCalendar.ts +78 -0
  1327. package/src/hooks/useDateInput.ts +213 -0
  1328. package/src/hooks/useKeyboard.ts +1 -1
  1329. package/src/hooks/useKeyboardInputTracker.ts +25 -8
  1330. package/src/hooks/useOrientationChange.ts +39 -0
  1331. package/src/hooks/usePagination.ts +96 -0
  1332. package/src/hooks/usePatchChildrenRef.ts +2 -2
  1333. package/src/hooks/useWaitTransitionFinish.ts +7 -1
  1334. package/src/index.ts +32 -11
  1335. package/src/lib/calendar.ts +123 -0
  1336. package/src/lib/date.ts +274 -0
  1337. package/src/lib/getNavId.ts +4 -2
  1338. package/src/lib/utils.ts +4 -1
  1339. package/src/lib/warnOnce.ts +9 -3
  1340. package/src/styles/components.css +15 -0
  1341. package/src/styles/constants.css +8 -1
  1342. package/src/testing/utils.tsx +10 -1
  1343. package/src/tokenized/index.ts +46 -4
  1344. package/src/unstable/index.ts +6 -6
  1345. package/tsconfig.json +2 -0
  1346. package/postcss.config.js +0 -54
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/SubnavigationButton/SubnavigationButton.tsx"],"names":["SubnavigationButtonTypography","textLevel","restProps","SubnavigationButton","props","platform","size","selected","before","after","expandable","children","defaultProps"],"mappings":";;;;;;;;;;;;;;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;AAwBA,IAAMA,6BAAoE,GAAG,SAAvEA,6BAAuE,OAG1C;AAAA,MAFjCC,SAEiC,QAFjCA,SAEiC;AAAA,MAD9BC,SAC8B;;AACjC,MAAID,SAAS,KAAK,CAAlB,EAAqB;AACnB,WAAO,qCAAC,gBAAD,EAAaC,SAAb,CAAP;AACD;;AAED,SACE,qCAAC,gBAAD;AACE,IAAA,KAAK,EAAED,SAAS,KAAK,CAAd,GAAkB,GAAlB,GAAwB,GADjC;AAEE,IAAA,MAAM,EAAC;AAFT,KAGMC,SAHN,EADF;AAOD,CAfD;;AAiBO,IAAMC,mBAAuD,GAAG,SAA1DA,mBAA0D,CACrEC,KADqE,EAElE;AACH,MAAMC,QAAQ,GAAG,+BAAjB;AACA,MACEC,IADF,GASIF,KATJ,CACEE,IADF;AAAA,MAEEC,QAFF,GASIH,KATJ,CAEEG,QAFF;AAAA,MAGEN,SAHF,GASIG,KATJ,CAGEH,SAHF;AAAA,MAIEO,MAJF,GASIJ,KATJ,CAIEI,MAJF;AAAA,MAKEC,KALF,GASIL,KATJ,CAKEK,KALF;AAAA,MAMEC,UANF,GASIN,KATJ,CAMEM,UANF;AAAA,MAOEC,QAPF,GASIP,KATJ,CAOEO,QAPF;AAAA,MAQKT,SARL,0CASIE,KATJ;AAWA,SACE,qCAAC,iBAAD,6BACMF,SADN;AAEE,IAAA,SAAS,EAAE,KAFb;AAGE,IAAA,gBAAgB,EAAC,SAHnB;AAIE,IAAA,SAAS,EAAE,4BACT,gCAAa,qBAAb,EAAoCG,QAApC,CADS,iCAEeC,IAFf,GAGT;AACE,uCAAiCC;AADnC,KAHS,CAJb;AAWE,kBAAY,iCAAqBI,QAArB;AAXd,MAaE;AAAM,IAAA,SAAS,EAAC;AAAhB,KACG,yBAAaH,MAAb,KACC;AAAM,IAAA,SAAS,EAAC;AAAhB,KAA+CA,MAA/C,CAFJ,EAIE,qCAAC,6BAAD;AACE,IAAA,SAAS,EAAEP,SADb;AAEE,IAAA,SAAS,EAAC,4BAFZ;AAGE,IAAA,SAAS,EAAC;AAHZ,KAKGU,QALH,CAJF,EAWG,yBAAaF,KAAb,KACC;AAAM,IAAA,SAAS,EAAC;AAAhB,KAA8CA,KAA9C,CAZJ,EAcGC,UAAU,IACT,qCAAC,qBAAD;AAAgB,IAAA,SAAS,EAAC;AAA1B,IAfJ,CAbF,CADF;AAkCD,CAjDM;;;AAmDPP,mBAAmB,CAACS,YAApB,GAAmC;AACjCN,EAAAA,IAAI,EAAE,GAD2B;AAEjCL,EAAAA,SAAS,EAAE;AAFsB,CAAnC","sourcesContent":["import * as React from \"react\";\nimport { HasComponent } from \"../../types\";\nimport { classNames } from \"../../lib/classNames\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { getTitleFromChildren, hasReactNode } from \"../../lib/utils\";\nimport Tappable, { TappableProps } from \"../Tappable/Tappable\";\nimport { Icon16Dropdown } from \"@vkontakte/icons\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport Caption from \"../Typography/Caption/Caption\";\nimport Subhead from \"../Typography/Subhead/Subhead\";\nimport \"./SubnavigationButton.css\";\n\nexport interface SubnavigationButtonProps extends Omit<TappableProps, \"size\"> {\n size?: \"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 SubnavButtonTypographyProps = Pick<SubnavigationButtonProps, \"textLevel\"> &\n HasComponent;\n\nconst SubnavigationButtonTypography: React.FC<SubnavButtonTypographyProps> = ({\n textLevel,\n ...restProps\n}: SubnavButtonTypographyProps) => {\n if (textLevel === 1) {\n return <Subhead {...restProps} />;\n }\n\n return (\n <Caption\n level={textLevel === 2 ? \"1\" : \"2\"}\n weight=\"regular\"\n {...restProps}\n />\n );\n};\n\nexport const SubnavigationButton: React.FC<SubnavigationButtonProps> = (\n props: SubnavigationButtonProps\n) => {\n const platform = usePlatform();\n const {\n size,\n selected,\n textLevel,\n before,\n after,\n expandable,\n children,\n ...restProps\n } = props;\n\n return (\n <Tappable\n {...restProps}\n hasActive={false}\n focusVisibleMode=\"outside\"\n vkuiClass={classNames(\n getClassName(\"SubnavigationButton\", platform),\n `SubnavigationButton--${size}`,\n {\n \"SubnavigationButton--selected\": selected,\n }\n )}\n aria-label={getTitleFromChildren(children)}\n >\n <span vkuiClass=\"SubnavigationButton__in\">\n {hasReactNode(before) && (\n <span vkuiClass=\"SubnavigationButton__before\">{before}</span>\n )}\n <SubnavigationButtonTypography\n textLevel={textLevel}\n vkuiClass=\"SubnavigationButton__label\"\n Component=\"span\"\n >\n {children}\n </SubnavigationButtonTypography>\n {hasReactNode(after) && (\n <span vkuiClass=\"SubnavigationButton__after\">{after}</span>\n )}\n {expandable && (\n <Icon16Dropdown vkuiClass=\"SubnavigationButton__expandableIcon\" />\n )}\n </span>\n </Tappable>\n );\n};\n\nSubnavigationButton.defaultProps = {\n size: \"m\",\n textLevel: 1,\n};\n"],"file":"SubnavigationButton.js"}
1
+ {"version":3,"sources":["../../../../src/components/SubnavigationButton/SubnavigationButton.tsx"],"names":["SubnavigationButtonTypography","textLevel","restProps","SubnavigationButton","props","platform","size","selected","before","after","expandable","children","defaultProps"],"mappings":";;;;;;;;;;;;;;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;AAwBA,IAAMA,6BAAoE,GAAG,SAAvEA,6BAAuE,OAG1C;AAAA,MAFjCC,SAEiC,QAFjCA,SAEiC;AAAA,MAD9BC,SAC8B;;AACjC,MAAID,SAAS,KAAK,CAAlB,EAAqB;AACnB,WAAO,qCAAC,gBAAD,EAAaC,SAAb,CAAP;AACD;;AAED,SAAO,qCAAC,gBAAD;AAAS,IAAA,KAAK,EAAED,SAAS,KAAK,CAAd,GAAkB,GAAlB,GAAwB;AAAxC,KAAiDC,SAAjD,EAAP;AACD,CATD;;AAWO,IAAMC,mBAAuD,GAAG,SAA1DA,mBAA0D,CACrEC,KADqE,EAElE;AACH,MAAMC,QAAQ,GAAG,+BAAjB;AACA,MACEC,IADF,GASIF,KATJ,CACEE,IADF;AAAA,MAEEC,QAFF,GASIH,KATJ,CAEEG,QAFF;AAAA,MAGEN,SAHF,GASIG,KATJ,CAGEH,SAHF;AAAA,MAIEO,MAJF,GASIJ,KATJ,CAIEI,MAJF;AAAA,MAKEC,KALF,GASIL,KATJ,CAKEK,KALF;AAAA,MAMEC,UANF,GASIN,KATJ,CAMEM,UANF;AAAA,MAOEC,QAPF,GASIP,KATJ,CAOEO,QAPF;AAAA,MAQKT,SARL,0CASIE,KATJ;AAWA,SACE,qCAAC,iBAAD,6BACMF,SADN;AAEE,IAAA,SAAS,EAAE,KAFb;AAGE,IAAA,gBAAgB,EAAC,SAHnB,CAIE;AAJF;AAKE,IAAA,SAAS,EAAE,4BACT,gCAAa,qBAAb,EAAoCG,QAApC,CADS,iCAEeC,IAFf,GAGT;AACE,uCAAiCC;AADnC,KAHS,CALb;AAYE,kBAAY,iCAAqBI,QAArB;AAZd,MAcE;AAAM,IAAA,SAAS,EAAC;AAAhB,KACG,yBAAaH,MAAb,KACC;AAAM,IAAA,SAAS,EAAC;AAAhB,KAA+CA,MAA/C,CAFJ,EAIE,qCAAC,6BAAD;AACE,IAAA,SAAS,EAAEP,SADb;AAEE,IAAA,SAAS,EAAC,4BAFZ;AAGE,IAAA,SAAS,EAAC;AAHZ,KAKGU,QALH,CAJF,EAWG,yBAAaF,KAAb,KACC;AAAM,IAAA,SAAS,EAAC;AAAhB,KAA8CA,KAA9C,CAZJ,EAcGC,UAAU,IACT,qCAAC,qBAAD;AAAgB,IAAA,SAAS,EAAC;AAA1B,IAfJ,CAdF,CADF;AAmCD,CAlDM;;;AAoDPP,mBAAmB,CAACS,YAApB,GAAmC;AACjCN,EAAAA,IAAI,EAAE,GAD2B;AAEjCL,EAAAA,SAAS,EAAE;AAFsB,CAAnC","sourcesContent":["import * as React from \"react\";\nimport { HasComponent } from \"../../types\";\nimport { classNames } from \"../../lib/classNames\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { getTitleFromChildren, hasReactNode } from \"../../lib/utils\";\nimport Tappable, { TappableProps } from \"../Tappable/Tappable\";\nimport { Icon16Dropdown } from \"@vkontakte/icons\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { Caption } from \"../Typography/Caption/Caption\";\nimport { Subhead } from \"../Typography/Subhead/Subhead\";\nimport \"./SubnavigationButton.css\";\n\nexport interface SubnavigationButtonProps extends Omit<TappableProps, \"size\"> {\n size?: \"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 SubnavButtonTypographyProps = Pick<SubnavigationButtonProps, \"textLevel\"> &\n HasComponent;\n\nconst SubnavigationButtonTypography: React.FC<SubnavButtonTypographyProps> = ({\n textLevel,\n ...restProps\n}: SubnavButtonTypographyProps) => {\n if (textLevel === 1) {\n return <Subhead {...restProps} />;\n }\n\n return <Caption level={textLevel === 2 ? \"1\" : \"2\"} {...restProps} />;\n};\n\nexport const SubnavigationButton: React.FC<SubnavigationButtonProps> = (\n props: SubnavigationButtonProps\n) => {\n const platform = usePlatform();\n const {\n size,\n selected,\n textLevel,\n before,\n after,\n expandable,\n children,\n ...restProps\n } = props;\n\n return (\n <Tappable\n {...restProps}\n hasActive={false}\n focusVisibleMode=\"outside\"\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"SubnavigationButton\", platform),\n `SubnavigationButton--${size}`,\n {\n \"SubnavigationButton--selected\": selected,\n }\n )}\n aria-label={getTitleFromChildren(children)}\n >\n <span vkuiClass=\"SubnavigationButton__in\">\n {hasReactNode(before) && (\n <span vkuiClass=\"SubnavigationButton__before\">{before}</span>\n )}\n <SubnavigationButtonTypography\n textLevel={textLevel}\n vkuiClass=\"SubnavigationButton__label\"\n Component=\"span\"\n >\n {children}\n </SubnavigationButtonTypography>\n {hasReactNode(after) && (\n <span vkuiClass=\"SubnavigationButton__after\">{after}</span>\n )}\n {expandable && (\n <Icon16Dropdown vkuiClass=\"SubnavigationButton__expandableIcon\" />\n )}\n </span>\n </Tappable>\n );\n};\n\nSubnavigationButton.defaultProps = {\n size: \"m\",\n textLevel: 1,\n};\n"],"file":"SubnavigationButton.js"}
@@ -47,6 +47,7 @@ var Switch = function Switch(_ref) {
47
47
  onFocus = _useFocusVisible.onFocus;
48
48
 
49
49
  return (0, _jsxRuntime.createScopedElement)("label", {
50
+ // eslint-disable-next-line vkui/no-object-expression-in-arguments
50
51
  vkuiClass: (0, _classNames.classNames)((0, _getClassName.getClassName)("Switch", platform), "Switch--sizeY-".concat(sizeY), {
51
52
  "Switch--disabled": restProps.disabled,
52
53
  "Switch--focus-visible": focusVisible
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/Switch/Switch.tsx"],"names":["Switch","style","className","getRootRef","restProps","platform","sizeY","focusVisible","onBlur","onFocus","disabled"],"mappings":";;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AAIA;;AACA;;;;AAOO,IAAMA,MAA6B,GAAG,SAAhCA,MAAgC,OAK1B;AAAA,MAJjBC,KAIiB,QAJjBA,KAIiB;AAAA,MAHjBC,SAGiB,QAHjBA,SAGiB;AAAA,MAFjBC,UAEiB,QAFjBA,UAEiB;AAAA,MADdC,SACc;AACjB,MAAMC,QAAQ,GAAG,+BAAjB;;AACA,uBAAkB,oCAAlB;AAAA,MAAQC,KAAR,kBAAQA,KAAR;;AACA,yBAA0C,wCAA1C;AAAA,MAAQC,YAAR,oBAAQA,YAAR;AAAA,MAAsBC,MAAtB,oBAAsBA,MAAtB;AAAA,MAA8BC,OAA9B,oBAA8BA,OAA9B;;AAEA,SACE;AACE,IAAA,SAAS,EAAE,4BACT,gCAAa,QAAb,EAAuBJ,QAAvB,CADS,0BAEQC,KAFR,GAGT;AACE,0BAAoBF,SAAS,CAACM,QADhC;AAEE,+BAAyBH;AAF3B,KAHS,CADb;AASE,IAAA,SAAS,EAAEL,SATb;AAUE,IAAA,KAAK,EAAED,KAVT;AAWE,IAAA,GAAG,EAAEE,UAXP;AAYE,IAAA,IAAI,EAAC;AAZP,KAcE,qCAAC,wCAAD,6BACMC,SADN;AAEE,IAAA,IAAI,EAAC,UAFP;AAGE,IAAA,SAAS,EAAC,cAHZ;AAIE,IAAA,MAAM,EAAE,gCAAaI,MAAb,EAAqBJ,SAAS,CAACI,MAA/B,CAJV;AAKE,IAAA,OAAO,EAAE,gCAAaC,OAAb,EAAsBL,SAAS,CAACK,OAAhC;AALX,KAdF,EAqBE;AAAM,IAAA,IAAI,EAAC,cAAX;AAA0B,IAAA,SAAS,EAAC;AAApC,IArBF,EAsBE,qCAAC,0BAAD;AAAc,IAAA,IAAI,EAAC;AAAnB,IAtBF,CADF;AA0BD,CApCM","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\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 \"./Switch.css\";\n\nexport interface SwitchProps\n extends VisuallyHiddenInputProps,\n HasRootRef<HTMLLabelElement> {}\n\nexport const Switch: React.FC<SwitchProps> = ({\n style,\n className,\n getRootRef,\n ...restProps\n}: SwitchProps) => {\n const platform = usePlatform();\n const { sizeY } = useAdaptivity();\n const { focusVisible, onBlur, onFocus } = useFocusVisible();\n\n return (\n <label\n vkuiClass={classNames(\n getClassName(\"Switch\", platform),\n `Switch--sizeY-${sizeY}`,\n {\n \"Switch--disabled\": restProps.disabled,\n \"Switch--focus-visible\": focusVisible,\n }\n )}\n className={className}\n style={style}\n ref={getRootRef}\n role=\"presentation\"\n >\n <VisuallyHiddenInput\n {...restProps}\n type=\"checkbox\"\n vkuiClass=\"Switch__self\"\n onBlur={callMultiple(onBlur, restProps.onBlur)}\n onFocus={callMultiple(onFocus, restProps.onFocus)}\n />\n <span role=\"presentation\" vkuiClass=\"Switch__pseudo\" />\n <FocusVisible mode=\"outside\" />\n </label>\n );\n};\n"],"file":"Switch.js"}
1
+ {"version":3,"sources":["../../../../src/components/Switch/Switch.tsx"],"names":["Switch","style","className","getRootRef","restProps","platform","sizeY","focusVisible","onBlur","onFocus","disabled"],"mappings":";;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AAIA;;AACA;;;;AAOO,IAAMA,MAA6B,GAAG,SAAhCA,MAAgC,OAK1B;AAAA,MAJjBC,KAIiB,QAJjBA,KAIiB;AAAA,MAHjBC,SAGiB,QAHjBA,SAGiB;AAAA,MAFjBC,UAEiB,QAFjBA,UAEiB;AAAA,MADdC,SACc;AACjB,MAAMC,QAAQ,GAAG,+BAAjB;;AACA,uBAAkB,oCAAlB;AAAA,MAAQC,KAAR,kBAAQA,KAAR;;AACA,yBAA0C,wCAA1C;AAAA,MAAQC,YAAR,oBAAQA,YAAR;AAAA,MAAsBC,MAAtB,oBAAsBA,MAAtB;AAAA,MAA8BC,OAA9B,oBAA8BA,OAA9B;;AAEA,SACE;AACE;AACA,IAAA,SAAS,EAAE,4BACT,gCAAa,QAAb,EAAuBJ,QAAvB,CADS,0BAEQC,KAFR,GAGT;AACE,0BAAoBF,SAAS,CAACM,QADhC;AAEE,+BAAyBH;AAF3B,KAHS,CAFb;AAUE,IAAA,SAAS,EAAEL,SAVb;AAWE,IAAA,KAAK,EAAED,KAXT;AAYE,IAAA,GAAG,EAAEE,UAZP;AAaE,IAAA,IAAI,EAAC;AAbP,KAeE,qCAAC,wCAAD,6BACMC,SADN;AAEE,IAAA,IAAI,EAAC,UAFP;AAGE,IAAA,SAAS,EAAC,cAHZ;AAIE,IAAA,MAAM,EAAE,gCAAaI,MAAb,EAAqBJ,SAAS,CAACI,MAA/B,CAJV;AAKE,IAAA,OAAO,EAAE,gCAAaC,OAAb,EAAsBL,SAAS,CAACK,OAAhC;AALX,KAfF,EAsBE;AAAM,IAAA,IAAI,EAAC,cAAX;AAA0B,IAAA,SAAS,EAAC;AAApC,IAtBF,EAuBE,qCAAC,0BAAD;AAAc,IAAA,IAAI,EAAC;AAAnB,IAvBF,CADF;AA2BD,CArCM","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\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 \"./Switch.css\";\n\nexport interface SwitchProps\n extends VisuallyHiddenInputProps,\n HasRootRef<HTMLLabelElement> {}\n\nexport const Switch: React.FC<SwitchProps> = ({\n style,\n className,\n getRootRef,\n ...restProps\n}: SwitchProps) => {\n const platform = usePlatform();\n const { sizeY } = useAdaptivity();\n const { focusVisible, onBlur, onFocus } = useFocusVisible();\n\n return (\n <label\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"Switch\", platform),\n `Switch--sizeY-${sizeY}`,\n {\n \"Switch--disabled\": restProps.disabled,\n \"Switch--focus-visible\": focusVisible,\n }\n )}\n className={className}\n style={style}\n ref={getRootRef}\n role=\"presentation\"\n >\n <VisuallyHiddenInput\n {...restProps}\n type=\"checkbox\"\n vkuiClass=\"Switch__self\"\n onBlur={callMultiple(onBlur, restProps.onBlur)}\n onFocus={callMultiple(onFocus, restProps.onFocus)}\n />\n <span role=\"presentation\" vkuiClass=\"Switch__pseudo\" />\n <FocusVisible mode=\"outside\" />\n </label>\n );\n};\n"],"file":"Switch.js"}
@@ -44,6 +44,7 @@ var Tabbar = function Tabbar(props) {
44
44
  };
45
45
 
46
46
  return (0, _jsxRuntime.createScopedElement)("div", (0, _extends2.default)({
47
+ // eslint-disable-next-line vkui/no-object-expression-in-arguments
47
48
  vkuiClass: (0, _classNames.classNames)((0, _getClassName.getClassName)("Tabbar", platform), "Tabbar--l-".concat(getItemsLayout()), {
48
49
  "Tabbar--shadow": shadow
49
50
  })
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/Tabbar/Tabbar.tsx"],"names":["Tabbar","props","children","shadow","itemsLayout","restProps","platform","getItemsLayout","React","Children","count","defaultProps"],"mappings":";;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;;;AAWA,IAAMA,MAA4C,GAAG,SAA/CA,MAA+C,CAACC,KAAD,EAAwB;AAC3E,MAAQC,QAAR,GAAwDD,KAAxD,CAAQC,QAAR;AAAA,MAAkBC,MAAlB,GAAwDF,KAAxD,CAAkBE,MAAlB;AAAA,MAA0BC,WAA1B,GAAwDH,KAAxD,CAA0BG,WAA1B;AAAA,MAA0CC,SAA1C,0CAAwDJ,KAAxD;AACA,MAAMK,QAAQ,GAAG,+BAAjB;;AAEA,MAAMC,cAAc,GAAG,SAAjBA,cAAiB,GAAM;AAC3B,YAAQH,WAAR;AACE,WAAK,YAAL;AACA,WAAK,UAAL;AACE,eAAOA,WAAP;;AACF;AACE,eAAOI,KAAK,CAACC,QAAN,CAAeC,KAAf,CAAqBR,QAArB,IAAiC,CAAjC,GAAqC,UAArC,GAAkD,YAAzD;AALJ;AAOD,GARD;;AAUA,SACE;AACE,IAAA,SAAS,EAAE,4BACT,gCAAa,QAAb,EAAuBI,QAAvB,CADS,sBAEIC,cAAc,EAFlB,GAGT;AACE,wBAAkBJ;AADpB,KAHS;AADb,KAQME,SARN,GAUE;AAAK,IAAA,SAAS,EAAC;AAAf,KAA6BH,QAA7B,CAVF,CADF;AAcD,CA5BD;;AA8BAF,MAAM,CAACW,YAAP,GAAsB;AACpBR,EAAAA,MAAM,EAAE;AADY,CAAtB,C,CAIA;;eACeH,M","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport \"./Tabbar.css\";\n\nexport interface TabbarProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Флаг для показа/скрытия верхней тени (Android) или границы (iOS)\n */\n shadow?: boolean;\n itemsLayout?: \"vertical\" | \"horizontal\" | \"auto\";\n}\n\nconst Tabbar: React.FunctionComponent<TabbarProps> = (props: TabbarProps) => {\n const { children, shadow, itemsLayout, ...restProps } = props;\n const platform = usePlatform();\n\n const getItemsLayout = () => {\n switch (itemsLayout) {\n case \"horizontal\":\n case \"vertical\":\n return itemsLayout;\n default:\n return React.Children.count(children) > 2 ? \"vertical\" : \"horizontal\";\n }\n };\n\n return (\n <div\n vkuiClass={classNames(\n getClassName(\"Tabbar\", platform),\n `Tabbar--l-${getItemsLayout()}`,\n {\n \"Tabbar--shadow\": shadow,\n }\n )}\n {...restProps}\n >\n <div vkuiClass=\"Tabbar__in\">{children}</div>\n </div>\n );\n};\n\nTabbar.defaultProps = {\n shadow: true,\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default Tabbar;\n"],"file":"Tabbar.js"}
1
+ {"version":3,"sources":["../../../../src/components/Tabbar/Tabbar.tsx"],"names":["Tabbar","props","children","shadow","itemsLayout","restProps","platform","getItemsLayout","React","Children","count","defaultProps"],"mappings":";;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;;;AAWA,IAAMA,MAA4C,GAAG,SAA/CA,MAA+C,CAACC,KAAD,EAAwB;AAC3E,MAAQC,QAAR,GAAwDD,KAAxD,CAAQC,QAAR;AAAA,MAAkBC,MAAlB,GAAwDF,KAAxD,CAAkBE,MAAlB;AAAA,MAA0BC,WAA1B,GAAwDH,KAAxD,CAA0BG,WAA1B;AAAA,MAA0CC,SAA1C,0CAAwDJ,KAAxD;AACA,MAAMK,QAAQ,GAAG,+BAAjB;;AAEA,MAAMC,cAAc,GAAG,SAAjBA,cAAiB,GAAM;AAC3B,YAAQH,WAAR;AACE,WAAK,YAAL;AACA,WAAK,UAAL;AACE,eAAOA,WAAP;;AACF;AACE,eAAOI,KAAK,CAACC,QAAN,CAAeC,KAAf,CAAqBR,QAArB,IAAiC,CAAjC,GAAqC,UAArC,GAAkD,YAAzD;AALJ;AAOD,GARD;;AAUA,SACE;AACE;AACA,IAAA,SAAS,EAAE,4BACT,gCAAa,QAAb,EAAuBI,QAAvB,CADS,sBAEIC,cAAc,EAFlB,GAGT;AACE,wBAAkBJ;AADpB,KAHS;AAFb,KASME,SATN,GAWE;AAAK,IAAA,SAAS,EAAC;AAAf,KAA6BH,QAA7B,CAXF,CADF;AAeD,CA7BD;;AA+BAF,MAAM,CAACW,YAAP,GAAsB;AACpBR,EAAAA,MAAM,EAAE;AADY,CAAtB,C,CAIA;;eACeH,M","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport \"./Tabbar.css\";\n\nexport interface TabbarProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Флаг для показа/скрытия верхней тени (Android) или границы (iOS)\n */\n shadow?: boolean;\n itemsLayout?: \"vertical\" | \"horizontal\" | \"auto\";\n}\n\nconst Tabbar: React.FunctionComponent<TabbarProps> = (props: TabbarProps) => {\n const { children, shadow, itemsLayout, ...restProps } = props;\n const platform = usePlatform();\n\n const getItemsLayout = () => {\n switch (itemsLayout) {\n case \"horizontal\":\n case \"vertical\":\n return itemsLayout;\n default:\n return React.Children.count(children) > 2 ? \"vertical\" : \"horizontal\";\n }\n };\n\n return (\n <div\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"Tabbar\", platform),\n `Tabbar--l-${getItemsLayout()}`,\n {\n \"Tabbar--shadow\": shadow,\n }\n )}\n {...restProps}\n >\n <div vkuiClass=\"Tabbar__in\">{children}</div>\n </div>\n );\n};\n\nTabbar.defaultProps = {\n shadow: true,\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default Tabbar;\n"],"file":"Tabbar.js"}
@@ -51,7 +51,8 @@ var TabbarItem = function TabbarItem(_ref) {
51
51
 
52
52
  return (0, _jsxRuntime.createScopedElement)(Component, (0, _extends2.default)({}, restProps, {
53
53
  disabled: disabled,
54
- href: href,
54
+ href: href // eslint-disable-next-line vkui/no-object-expression-in-arguments
55
+ ,
55
56
  vkuiClass: (0, _classNames.classNames)((0, _getClassName.getClassName)("TabbarItem", platform), {
56
57
  "TabbarItem--selected": selected,
57
58
  "TabbarItem--text": !!text
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/TabbarItem/TabbarItem.tsx"],"names":["warn","TabbarItem","children","selected","label","indicator","text","href","Component","disabled","restProps","platform","process","env","NODE_ENV","Platform","IOS"],"mappings":";;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;AAsBA,IAAMA,IAAI,GAAG,wBAAS,YAAT,CAAb;;AACA,IAAMC,UAAoD,GAAG,SAAvDA,UAAuD,OAUtC;AAAA,MATrBC,QASqB,QATrBA,QASqB;AAAA,MARrBC,QAQqB,QARrBA,QAQqB;AAAA,MAPrBC,KAOqB,QAPrBA,KAOqB;AAAA,MANrBC,SAMqB,QANrBA,SAMqB;AAAA,MALrBC,IAKqB,QALrBA,IAKqB;AAAA,MAJrBC,IAIqB,QAJrBA,IAIqB;AAAA,4BAHrBC,SAGqB;AAAA,MAHrBA,SAGqB,+BAHTD,IAAI,GAAG,GAAH,GAAS,QAGJ;AAAA,MAFrBE,QAEqB,QAFrBA,QAEqB;AAAA,MADlBC,SACkB;AACrB,MAAMC,QAAQ,GAAG,+BAAjB;;AAEA,MAAIP,KAAK,IAAIQ,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAAtC,EAAqD;AACnDd,IAAAA,IAAI,CACF,yEADE,CAAJ;AAGD;;AAED,SACE,qCAAC,SAAD,6BACMU,SADN;AAEE,IAAA,QAAQ,EAAED,QAFZ;AAGE,IAAA,IAAI,EAAEF,IAHR;AAIE,IAAA,SAAS,EAAE,4BAAW,gCAAa,YAAb,EAA2BI,QAA3B,CAAX,EAAiD;AAC1D,8BAAwBR,QADkC;AAE1D,0BAAoB,CAAC,CAACG;AAFoC,KAAjD;AAJb,MASE,qCAAC,iBAAD;AACE,IAAA,IAAI,EAAC,cADP;AAEE,IAAA,SAAS,EAAC,KAFZ;AAGE,IAAA,QAAQ,EAAEG,QAHZ;AAIE,IAAA,UAAU,EACRE,QAAQ,KAAKI,mBAASC,GAAtB,GACI,8BADJ,GAEI,YAPR;AASE,IAAA,iBAAiB,EAAEL,QAAQ,KAAKI,mBAASC,GAAtB,GAA4B,CAA5B,GAAgC,GATrD;AAUE,IAAA,QAAQ,EAAE,KAVZ;AAWE,IAAA,SAAS,EAAC;AAXZ,IATF,EAsBE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE;AAAK,IAAA,SAAS,EAAC;AAAf,KACGd,QADH,EAEE;AAAK,IAAA,SAAS,EAAC;AAAf,KACG,yBAAaG,SAAb,KAA2BA,SAD9B,EAEG,CAACA,SAAD,IAAcD,KAAd,IACC,qCAAC,gBAAD;AAAS,IAAA,IAAI,EAAC,GAAd;AAAkB,IAAA,IAAI,EAAC;AAAvB,KACGA,KADH,CAHJ,CAFF,CADF,EAYGE,IAAI,IAAI;AAAK,IAAA,SAAS,EAAC;AAAf,KAAmCA,IAAnC,CAZX,CAtBF,CADF;AAuCD,CA1DD,C,CA4DA;;;eACeL,U","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport Counter from \"../Counter/Counter\";\nimport { classNames } from \"../../lib/classNames\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport Tappable from \"../Tappable/Tappable\";\nimport { Platform } from \"../../lib/platform\";\nimport { HasComponent, HasRootRef } from \"../../types\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport \"./TabbarItem.css\";\n\nexport interface TabbarItemProps\n extends Omit<React.AllHTMLAttributes<HTMLElement>, \"label\">, // TODO убрать Omit после удаления свойства label\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 * @deprecated будет удалено в 5.0.0. Используйте `indicator`\n */\n label?: React.ReactNode;\n}\n\nconst warn = warnOnce(\"TabbarItem\");\nconst TabbarItem: React.FunctionComponent<TabbarItemProps> = ({\n children,\n selected,\n label,\n indicator,\n text,\n href,\n Component = href ? \"a\" : \"button\",\n disabled,\n ...restProps\n}: TabbarItemProps) => {\n const platform = usePlatform();\n\n if (label && process.env.NODE_ENV === \"development\") {\n warn(\n \"Свойство label устарело и будет удалено в 5.0.0. Используйте indicator.\"\n );\n }\n\n return (\n <Component\n {...restProps}\n disabled={disabled}\n href={href}\n vkuiClass={classNames(getClassName(\"TabbarItem\", platform), {\n \"TabbarItem--selected\": selected,\n \"TabbarItem--text\": !!text,\n })}\n >\n <Tappable\n role=\"presentation\"\n Component=\"div\"\n disabled={disabled}\n activeMode={\n platform === Platform.IOS\n ? \"TabbarItem__tappable--active\"\n : \"background\"\n }\n activeEffectDelay={platform === Platform.IOS ? 0 : 300}\n hasHover={false}\n vkuiClass=\"TabbarItem__tappable\"\n />\n <div vkuiClass=\"TabbarItem__in\">\n <div vkuiClass=\"TabbarItem__icon\">\n {children}\n <div vkuiClass=\"TabbarItem__label\">\n {hasReactNode(indicator) && indicator}\n {!indicator && label && (\n <Counter size=\"s\" mode=\"prominent\">\n {label}\n </Counter>\n )}\n </div>\n </div>\n {text && <div vkuiClass=\"TabbarItem__text\">{text}</div>}\n </div>\n </Component>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default TabbarItem;\n"],"file":"TabbarItem.js"}
1
+ {"version":3,"sources":["../../../../src/components/TabbarItem/TabbarItem.tsx"],"names":["warn","TabbarItem","children","selected","label","indicator","text","href","Component","disabled","restProps","platform","process","env","NODE_ENV","Platform","IOS"],"mappings":";;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;AAsBA,IAAMA,IAAI,GAAG,wBAAS,YAAT,CAAb;;AACA,IAAMC,UAAoD,GAAG,SAAvDA,UAAuD,OAUtC;AAAA,MATrBC,QASqB,QATrBA,QASqB;AAAA,MARrBC,QAQqB,QARrBA,QAQqB;AAAA,MAPrBC,KAOqB,QAPrBA,KAOqB;AAAA,MANrBC,SAMqB,QANrBA,SAMqB;AAAA,MALrBC,IAKqB,QALrBA,IAKqB;AAAA,MAJrBC,IAIqB,QAJrBA,IAIqB;AAAA,4BAHrBC,SAGqB;AAAA,MAHrBA,SAGqB,+BAHTD,IAAI,GAAG,GAAH,GAAS,QAGJ;AAAA,MAFrBE,QAEqB,QAFrBA,QAEqB;AAAA,MADlBC,SACkB;AACrB,MAAMC,QAAQ,GAAG,+BAAjB;;AAEA,MAAIP,KAAK,IAAIQ,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAAtC,EAAqD;AACnDd,IAAAA,IAAI,CACF,yEADE,CAAJ;AAGD;;AAED,SACE,qCAAC,SAAD,6BACMU,SADN;AAEE,IAAA,QAAQ,EAAED,QAFZ;AAGE,IAAA,IAAI,EAAEF,IAHR,CAIE;AAJF;AAKE,IAAA,SAAS,EAAE,4BAAW,gCAAa,YAAb,EAA2BI,QAA3B,CAAX,EAAiD;AAC1D,8BAAwBR,QADkC;AAE1D,0BAAoB,CAAC,CAACG;AAFoC,KAAjD;AALb,MAUE,qCAAC,iBAAD;AACE,IAAA,IAAI,EAAC,cADP;AAEE,IAAA,SAAS,EAAC,KAFZ;AAGE,IAAA,QAAQ,EAAEG,QAHZ;AAIE,IAAA,UAAU,EACRE,QAAQ,KAAKI,mBAASC,GAAtB,GACI,8BADJ,GAEI,YAPR;AASE,IAAA,iBAAiB,EAAEL,QAAQ,KAAKI,mBAASC,GAAtB,GAA4B,CAA5B,GAAgC,GATrD;AAUE,IAAA,QAAQ,EAAE,KAVZ;AAWE,IAAA,SAAS,EAAC;AAXZ,IAVF,EAuBE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE;AAAK,IAAA,SAAS,EAAC;AAAf,KACGd,QADH,EAEE;AAAK,IAAA,SAAS,EAAC;AAAf,KACG,yBAAaG,SAAb,KAA2BA,SAD9B,EAEG,CAACA,SAAD,IAAcD,KAAd,IACC,qCAAC,gBAAD;AAAS,IAAA,IAAI,EAAC,GAAd;AAAkB,IAAA,IAAI,EAAC;AAAvB,KACGA,KADH,CAHJ,CAFF,CADF,EAYGE,IAAI,IAAI;AAAK,IAAA,SAAS,EAAC;AAAf,KAAmCA,IAAnC,CAZX,CAvBF,CADF;AAwCD,CA3DD,C,CA6DA;;;eACeL,U","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport Counter from \"../Counter/Counter\";\nimport { classNames } from \"../../lib/classNames\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport Tappable from \"../Tappable/Tappable\";\nimport { Platform } from \"../../lib/platform\";\nimport { HasComponent, HasRootRef } from \"../../types\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport \"./TabbarItem.css\";\n\nexport interface TabbarItemProps\n extends Omit<React.AllHTMLAttributes<HTMLElement>, \"label\">, // TODO убрать Omit после удаления свойства label\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 * @deprecated будет удалено в 5.0.0. Используйте `indicator`\n */\n label?: React.ReactNode;\n}\n\nconst warn = warnOnce(\"TabbarItem\");\nconst TabbarItem: React.FunctionComponent<TabbarItemProps> = ({\n children,\n selected,\n label,\n indicator,\n text,\n href,\n Component = href ? \"a\" : \"button\",\n disabled,\n ...restProps\n}: TabbarItemProps) => {\n const platform = usePlatform();\n\n if (label && process.env.NODE_ENV === \"development\") {\n warn(\n \"Свойство label устарело и будет удалено в 5.0.0. Используйте indicator.\"\n );\n }\n\n return (\n <Component\n {...restProps}\n disabled={disabled}\n href={href}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(getClassName(\"TabbarItem\", platform), {\n \"TabbarItem--selected\": selected,\n \"TabbarItem--text\": !!text,\n })}\n >\n <Tappable\n role=\"presentation\"\n Component=\"div\"\n disabled={disabled}\n activeMode={\n platform === Platform.IOS\n ? \"TabbarItem__tappable--active\"\n : \"background\"\n }\n activeEffectDelay={platform === Platform.IOS ? 0 : 300}\n hasHover={false}\n vkuiClass=\"TabbarItem__tappable\"\n />\n <div vkuiClass=\"TabbarItem__in\">\n <div vkuiClass=\"TabbarItem__icon\">\n {children}\n <div vkuiClass=\"TabbarItem__label\">\n {hasReactNode(indicator) && indicator}\n {!indicator && label && (\n <Counter size=\"s\" mode=\"prominent\">\n {label}\n </Counter>\n )}\n </div>\n </div>\n {text && <div vkuiClass=\"TabbarItem__text\">{text}</div>}\n </div>\n </Component>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default TabbarItem;\n"],"file":"TabbarItem.js"}
@@ -33,7 +33,7 @@ var _Tabs = require("../Tabs/Tabs");
33
33
 
34
34
  var _Headline = _interopRequireDefault(require("../Typography/Headline/Headline"));
35
35
 
36
- var _Subhead = _interopRequireDefault(require("../Typography/Subhead/Subhead"));
36
+ var _Subhead = require("../Typography/Subhead/Subhead");
37
37
 
38
38
  var _Text = _interopRequireDefault(require("../Typography/Text/Text"));
39
39
 
@@ -46,13 +46,14 @@ var TabsItem = function TabsItem(_ref) {
46
46
  restProps = (0, _objectWithoutProperties2.default)(_ref, _excluded);
47
47
  var platform = (0, _usePlatform.usePlatform)();
48
48
  var mode = React.useContext(_Tabs.TabsModeContext);
49
- var TypographyComponent = mode === "buttons" || mode === "segmented" ? _Subhead.default : _Headline.default;
49
+ var TypographyComponent = mode === "buttons" || mode === "segmented" ? _Subhead.Subhead : _Headline.default;
50
50
 
51
51
  if (platform === _platform.VKCOM) {
52
52
  TypographyComponent = _Text.default;
53
53
  }
54
54
 
55
55
  return (0, _jsxRuntime.createScopedElement)(_Tappable.default, (0, _extends2.default)({}, restProps, {
56
+ // eslint-disable-next-line vkui/no-object-expression-in-arguments
56
57
  vkuiClass: (0, _classNames.classNames)((0, _getClassName.getClassName)("TabsItem", platform), {
57
58
  "TabsItem--selected": selected
58
59
  }),
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/TabsItem/TabsItem.tsx"],"names":["TabsItem","children","selected","after","restProps","platform","mode","React","useContext","TabsModeContext","TypographyComponent","Subhead","Headline","VKCOM","Text","defaultProps"],"mappings":";;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAQA,IAAMA,QAAiC,GAAG,SAApCA,QAAoC,OAKrB;AAAA,MAJnBC,QAImB,QAJnBA,QAImB;AAAA,MAHnBC,QAGmB,QAHnBA,QAGmB;AAAA,MAFnBC,KAEmB,QAFnBA,KAEmB;AAAA,MADhBC,SACgB;AACnB,MAAMC,QAAQ,GAAG,+BAAjB;AACA,MAAMC,IAAuB,GAAGC,KAAK,CAACC,UAAN,CAAiBC,qBAAjB,CAAhC;AAEA,MAAIC,mBAAmB,GACrBJ,IAAI,KAAK,SAAT,IAAsBA,IAAI,KAAK,WAA/B,GAA6CK,gBAA7C,GAAuDC,iBADzD;;AAGA,MAAIP,QAAQ,KAAKQ,eAAjB,EAAwB;AACtBH,IAAAA,mBAAmB,GAAGI,aAAtB;AACD;;AAED,SACE,qCAAC,iBAAD,6BACMV,SADN;AAEE,IAAA,SAAS,EAAE,4BAAW,gCAAa,UAAb,EAAyBC,QAAzB,CAAX,EAA+C;AACxD,4BAAsBH;AADkC,KAA/C,CAFb;AAKE,IAAA,SAAS,EAAEI,IAAI,KAAK,WALtB;AAME,IAAA,UAAU,EAAC,kBANb;AAOE,IAAA,gBAAgB,EAAEA,IAAI,KAAK,WAAT,GAAuB,SAAvB,GAAmC;AAPvD,MASE,qCAAC,mBAAD;AACE,IAAA,SAAS,EAAC,MADZ;AAEE,IAAA,SAAS,EAAC,cAFZ;AAGE,IAAA,MAAM,EAAC;AAHT,KAKGL,QALH,CATF,EAgBG,yBAAaE,KAAb,KAAuB;AAAK,IAAA,SAAS,EAAC;AAAf,KAAkCA,KAAlC,CAhB1B,CADF;AAoBD,CApCD;;AAsCAH,QAAQ,CAACe,YAAT,GAAwB;AACtBb,EAAAA,QAAQ,EAAE;AADY,CAAxB,C,CAIA;;eACeF,Q","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport Tappable from \"../Tappable/Tappable\";\nimport { classNames } from \"../../lib/classNames\";\nimport { VKCOM } from \"../../lib/platform\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport { TabsProps, TabsModeContext } from \"../Tabs/Tabs\";\nimport Headline from \"../Typography/Headline/Headline\";\nimport Subhead from \"../Typography/Subhead/Subhead\";\nimport Text from \"../Typography/Text/Text\";\nimport \"./TabsItem.css\";\n\nexport interface TabsItemProps extends React.HTMLAttributes<HTMLElement> {\n after?: React.ReactNode;\n selected?: boolean;\n}\n\nconst TabsItem: React.FC<TabsItemProps> = ({\n children,\n selected,\n after,\n ...restProps\n}: TabsItemProps) => {\n const platform = usePlatform();\n const mode: TabsProps[\"mode\"] = React.useContext(TabsModeContext);\n\n let TypographyComponent =\n mode === \"buttons\" || mode === \"segmented\" ? Subhead : Headline;\n\n if (platform === VKCOM) {\n TypographyComponent = Text;\n }\n\n return (\n <Tappable\n {...restProps}\n vkuiClass={classNames(getClassName(\"TabsItem\", platform), {\n \"TabsItem--selected\": selected,\n })}\n hasActive={mode === \"segmented\"}\n activeMode=\"TabsItem--active\"\n focusVisibleMode={mode === \"segmented\" ? \"outside\" : \"inside\"}\n >\n <TypographyComponent\n Component=\"span\"\n vkuiClass=\"TabsItem__in\"\n weight=\"medium\"\n >\n {children}\n </TypographyComponent>\n {hasReactNode(after) && <div vkuiClass=\"TabsItem__after\">{after}</div>}\n </Tappable>\n );\n};\n\nTabsItem.defaultProps = {\n selected: false,\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default TabsItem;\n"],"file":"TabsItem.js"}
1
+ {"version":3,"sources":["../../../../src/components/TabsItem/TabsItem.tsx"],"names":["TabsItem","children","selected","after","restProps","platform","mode","React","useContext","TabsModeContext","TypographyComponent","Subhead","Headline","VKCOM","Text","defaultProps"],"mappings":";;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAQA,IAAMA,QAAiC,GAAG,SAApCA,QAAoC,OAKrB;AAAA,MAJnBC,QAImB,QAJnBA,QAImB;AAAA,MAHnBC,QAGmB,QAHnBA,QAGmB;AAAA,MAFnBC,KAEmB,QAFnBA,KAEmB;AAAA,MADhBC,SACgB;AACnB,MAAMC,QAAQ,GAAG,+BAAjB;AACA,MAAMC,IAAuB,GAAGC,KAAK,CAACC,UAAN,CAAiBC,qBAAjB,CAAhC;AAEA,MAAIC,mBAAmB,GACrBJ,IAAI,KAAK,SAAT,IAAsBA,IAAI,KAAK,WAA/B,GAA6CK,gBAA7C,GAAuDC,iBADzD;;AAGA,MAAIP,QAAQ,KAAKQ,eAAjB,EAAwB;AACtBH,IAAAA,mBAAmB,GAAGI,aAAtB;AACD;;AAED,SACE,qCAAC,iBAAD,6BACMV,SADN;AAEE;AACA,IAAA,SAAS,EAAE,4BAAW,gCAAa,UAAb,EAAyBC,QAAzB,CAAX,EAA+C;AACxD,4BAAsBH;AADkC,KAA/C,CAHb;AAME,IAAA,SAAS,EAAEI,IAAI,KAAK,WANtB;AAOE,IAAA,UAAU,EAAC,kBAPb;AAQE,IAAA,gBAAgB,EAAEA,IAAI,KAAK,WAAT,GAAuB,SAAvB,GAAmC;AARvD,MAUE,qCAAC,mBAAD;AACE,IAAA,SAAS,EAAC,MADZ;AAEE,IAAA,SAAS,EAAC,cAFZ;AAGE,IAAA,MAAM,EAAC;AAHT,KAKGL,QALH,CAVF,EAiBG,yBAAaE,KAAb,KAAuB;AAAK,IAAA,SAAS,EAAC;AAAf,KAAkCA,KAAlC,CAjB1B,CADF;AAqBD,CArCD;;AAuCAH,QAAQ,CAACe,YAAT,GAAwB;AACtBb,EAAAA,QAAQ,EAAE;AADY,CAAxB,C,CAIA;;eACeF,Q","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport Tappable from \"../Tappable/Tappable\";\nimport { classNames } from \"../../lib/classNames\";\nimport { VKCOM } from \"../../lib/platform\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport { TabsProps, TabsModeContext } from \"../Tabs/Tabs\";\nimport Headline from \"../Typography/Headline/Headline\";\nimport { Subhead } from \"../Typography/Subhead/Subhead\";\nimport Text from \"../Typography/Text/Text\";\nimport \"./TabsItem.css\";\n\nexport interface TabsItemProps extends React.HTMLAttributes<HTMLElement> {\n after?: React.ReactNode;\n selected?: boolean;\n}\n\nconst TabsItem: React.FC<TabsItemProps> = ({\n children,\n selected,\n after,\n ...restProps\n}: TabsItemProps) => {\n const platform = usePlatform();\n const mode: TabsProps[\"mode\"] = React.useContext(TabsModeContext);\n\n let TypographyComponent =\n mode === \"buttons\" || mode === \"segmented\" ? Subhead : Headline;\n\n if (platform === VKCOM) {\n TypographyComponent = Text;\n }\n\n return (\n <Tappable\n {...restProps}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(getClassName(\"TabsItem\", platform), {\n \"TabsItem--selected\": selected,\n })}\n hasActive={mode === \"segmented\"}\n activeMode=\"TabsItem--active\"\n focusVisibleMode={mode === \"segmented\" ? \"outside\" : \"inside\"}\n >\n <TypographyComponent\n Component=\"span\"\n vkuiClass=\"TabsItem__in\"\n weight=\"medium\"\n >\n {children}\n </TypographyComponent>\n {hasReactNode(after) && <div vkuiClass=\"TabsItem__after\">{after}</div>}\n </Tappable>\n );\n};\n\nTabsItem.defaultProps = {\n selected: false,\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default TabsItem;\n"],"file":"TabsItem.js"}
@@ -30,11 +30,13 @@ export interface TappableProps extends Omit<React.AllHTMLAttributes<HTMLElement>
30
30
  * Стиль аутлайна focus visible. Если передать произвольную строку, она добавится как css-класс во время focus-visible
31
31
  */
32
32
  focusVisibleMode?: FocusVisibleMode | string;
33
+ onEnter?: (outputEvent: MouseEvent) => void;
34
+ onLeave?: (outputEvent: MouseEvent) => void;
33
35
  }
34
36
  export interface RootComponentProps extends TouchProps {
35
37
  ref?: React.Ref<HTMLElement>;
36
38
  }
37
39
  export declare const ACTIVE_DELAY = 70;
38
40
  export declare const ACTIVE_EFFECT_DELAY = 600;
39
- declare const _default: React.FC<Pick<TappableProps, "max" | "required" | "high" | "low" | "disabled" | "default" | "start" | "open" | "media" | "hidden" | "cite" | "data" | "dir" | "form" | "label" | "slot" | "span" | "style" | "summary" | "title" | "pattern" | "async" | "defer" | "manifest" | "color" | "content" | "size" | "wrap" | "multiple" | "height" | "translate" | "width" | "prefix" | "src" | "children" | "className" | "id" | "lang" | "method" | "min" | "name" | "target" | "type" | "role" | "tabIndex" | "crossOrigin" | "href" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDownCapture" | "onMouseEnter" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancelCapture" | "onTouchEndCapture" | "onTouchMoveCapture" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "list" | "classID" | "useMap" | "wmode" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "draggable" | "placeholder" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "as" | "hrefLang" | "integrity" | "rel" | "sizes" | "charSet" | "kind" | "srcLang" | "value" | "download" | "alt" | "coords" | "shape" | "autoPlay" | "controls" | "loop" | "mediaGroup" | "muted" | "playsInline" | "preload" | "autoFocus" | "formAction" | "formEncType" | "formMethod" | "formNoValidate" | "formTarget" | "dateTime" | "acceptCharset" | "action" | "autoComplete" | "encType" | "noValidate" | "allowFullScreen" | "allowTransparency" | "frameBorder" | "marginHeight" | "marginWidth" | "sandbox" | "scrolling" | "seamless" | "srcDoc" | "srcSet" | "accept" | "capture" | "checked" | "maxLength" | "minLength" | "readOnly" | "step" | "htmlFor" | "httpEquiv" | "optimum" | "reversed" | "selected" | "nonce" | "scoped" | "cellPadding" | "cellSpacing" | "colSpan" | "headers" | "rowSpan" | "scope" | "cols" | "rows" | "poster" | "challenge" | "keyType" | "keyParams" | "onStart" | "onMove" | "onEnd" | "Component" | "getRootRef" | "stopPropagation" | "activeEffectDelay" | "hasHover" | "hoverMode" | "hasActive" | "activeMode" | "focusVisibleMode"> & import("../AdaptivityProvider/AdaptivityContext").SizeProps>;
41
+ declare const _default: React.FC<Pick<TappableProps, "max" | "required" | "high" | "low" | "disabled" | "default" | "start" | "open" | "media" | "hidden" | "cite" | "data" | "dir" | "form" | "label" | "slot" | "span" | "style" | "summary" | "title" | "pattern" | "async" | "defer" | "manifest" | "color" | "content" | "size" | "wrap" | "multiple" | "height" | "translate" | "width" | "prefix" | "src" | "children" | "className" | "id" | "lang" | "method" | "min" | "name" | "target" | "type" | "role" | "tabIndex" | "crossOrigin" | "href" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDownCapture" | "onMouseEnter" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancelCapture" | "onTouchEndCapture" | "onTouchMoveCapture" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "list" | "classID" | "useMap" | "wmode" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "draggable" | "placeholder" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "as" | "hrefLang" | "integrity" | "rel" | "sizes" | "charSet" | "kind" | "srcLang" | "value" | "download" | "alt" | "coords" | "shape" | "autoPlay" | "controls" | "loop" | "mediaGroup" | "muted" | "playsInline" | "preload" | "autoFocus" | "formAction" | "formEncType" | "formMethod" | "formNoValidate" | "formTarget" | "dateTime" | "acceptCharset" | "action" | "autoComplete" | "encType" | "noValidate" | "allowFullScreen" | "allowTransparency" | "frameBorder" | "marginHeight" | "marginWidth" | "sandbox" | "scrolling" | "seamless" | "srcDoc" | "srcSet" | "accept" | "capture" | "checked" | "maxLength" | "minLength" | "readOnly" | "step" | "htmlFor" | "httpEquiv" | "optimum" | "reversed" | "selected" | "nonce" | "scoped" | "cellPadding" | "cellSpacing" | "colSpan" | "headers" | "rowSpan" | "scope" | "cols" | "rows" | "poster" | "challenge" | "keyType" | "keyParams" | "onStart" | "onMove" | "onLeave" | "onEnter" | "onEnd" | "Component" | "getRootRef" | "stopPropagation" | "activeEffectDelay" | "hasHover" | "hoverMode" | "hasActive" | "activeMode" | "focusVisibleMode"> & import("../AdaptivityProvider/AdaptivityContext").SizeProps>;
40
42
  export default _default;
@@ -59,7 +59,9 @@ var _useFocusVisible2 = require("../../hooks/useFocusVisible");
59
59
 
60
60
  var _callMultiple = require("../../lib/callMultiple");
61
61
 
62
- var _excluded = ["children", "Component", "onClick", "onKeyDown", "activeEffectDelay", "stopPropagation", "getRootRef", "sizeX", "hasMouse", "deviceHasHover", "hasHover", "hoverMode", "hasActive", "activeMode", "focusVisibleMode"];
62
+ var _useBooleanState2 = require("../../hooks/useBooleanState");
63
+
64
+ var _excluded = ["children", "Component", "onClick", "onKeyDown", "activeEffectDelay", "stopPropagation", "getRootRef", "sizeX", "hasMouse", "deviceHasHover", "hasHover", "hoverMode", "hasActive", "activeMode", "focusVisibleMode", "onEnter", "onLeave"];
63
65
  var ACTIVE_DELAY = 70;
64
66
  exports.ACTIVE_DELAY = ACTIVE_DELAY;
65
67
  var ACTIVE_EFFECT_DELAY = 600;
@@ -174,6 +176,8 @@ var Tappable = function Tappable(_ref) {
174
176
  activeMode = _ref$activeMode === void 0 ? "background" : _ref$activeMode,
175
177
  _ref$focusVisibleMode = _ref.focusVisibleMode,
176
178
  focusVisibleMode = _ref$focusVisibleMode === void 0 ? "inside" : _ref$focusVisibleMode,
179
+ onEnter = _ref.onEnter,
180
+ onLeave = _ref.onLeave,
177
181
  props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
178
182
 
179
183
  Component = Component || (props.href ? "a" : "div");
@@ -199,10 +203,10 @@ var Tappable = function Tappable(_ref) {
199
203
  childHover = _React$useState6[0],
200
204
  setChildHover = _React$useState6[1];
201
205
 
202
- var _React$useState7 = React.useState(false),
203
- _React$useState8 = (0, _slicedToArray2.default)(_React$useState7, 2),
204
- _hovered = _React$useState8[0],
205
- setHovered = _React$useState8[1];
206
+ var _useBooleanState = (0, _useBooleanState2.useBooleanState)(false),
207
+ _hovered = _useBooleanState.value,
208
+ setHoveredTrue = _useBooleanState.setTrue,
209
+ setHoveredFalse = _useBooleanState.setFalse;
206
210
 
207
211
  var hovered = _hovered && !props.disabled;
208
212
  var hasActive = _hasActive && !childHover && !props.disabled;
@@ -301,11 +305,12 @@ var Tappable = function Tappable(_ref) {
301
305
  } // отключить без задержки при длинном тапе
302
306
 
303
307
 
304
- var activeDuraion = duration - ACTIVE_DELAY;
305
- stop(activeDuraion >= 100 ? 0 : activeEffectDelay - activeDuraion);
306
- }
308
+ var activeDuration = duration - ACTIVE_DELAY;
309
+ stop(activeDuration >= 100 ? 0 : activeEffectDelay - activeDuration);
310
+ } // eslint-disable-next-line vkui/no-object-expression-in-arguments
311
+
307
312
 
308
- var classes = (0, _classNames2.classNames)((0, _getClassName.getClassName)("Tappable", platform), "Tappable--sizeX-".concat(sizeX), hasHover && hovered && !isPresetHoverMode && hoverMode, hasActive && active && !isPresetActiveMode && activeMode, focusVisible && !isPresetFocusVisibleMode && focusVisibleMode, (_classNames = {
313
+ var classes = (0, _classNames2.classNames)((0, _getClassName.getClassName)("Tappable", platform), "Tappable--sizeX-".concat(sizeX), hasHover && "Tappable--hasHover", hasActive && "Tappable--hasActive", hasHover && hovered && !isPresetHoverMode && hoverMode, hasActive && active && !isPresetActiveMode && activeMode, focusVisible && !isPresetFocusVisibleMode && focusVisibleMode, (_classNames = {
309
314
  "Tappable--active": hasActive && active,
310
315
  "Tappable--mouse": hasMouse
311
316
  }, (0, _defineProperty2.default)(_classNames, "Tappable--hover-".concat(hoverMode), hasHover && hovered && isPresetHoverMode), (0, _defineProperty2.default)(_classNames, "Tappable--active-".concat(activeMode), hasActive && active && isPresetActiveMode), (0, _defineProperty2.default)(_classNames, "Tappable--focus-visible", focusVisible), _classNames));
@@ -318,12 +323,8 @@ var Tappable = function Tappable(_ref) {
318
323
  };
319
324
  var role = props.href ? "link" : "button";
320
325
  return (0, _jsxRuntime.createScopedElement)(_Touch.Touch, (0, _extends2.default)({
321
- onEnter: function onEnter() {
322
- return setHovered(true);
323
- },
324
- onLeave: function onLeave() {
325
- return setHovered(false);
326
- },
326
+ onEnter: (0, _callMultiple.callMultiple)(setHoveredTrue, onEnter),
327
+ onLeave: (0, _callMultiple.callMultiple)(setHoveredFalse, onLeave),
327
328
  type: Component === "button" ? "button" : undefined,
328
329
  tabIndex: isCustomElement && !props.disabled ? 0 : undefined,
329
330
  role: isCustomElement ? role : undefined,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/Tappable/Tappable.tsx"],"names":["ACTIVE_DELAY","ACTIVE_EFFECT_DELAY","activeBus","TapState","none","pending","active","exiting","TappableContext","React","createContext","onHoverChange","noop","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","sizeX","hasMouse","deviceHasHover","hasHover","_hasHover","hoverMode","_hasActive","activeMode","focusVisibleMode","props","href","useContext","insideTouchRoot","TouchRootContext","platform","focusVisible","onBlur","onFocus","clicks","setClicks","childHover","setChildHover","_hovered","setHovered","hovered","disabled","isCustomElement","contentEditable","isPresetHoverMode","includes","isPresetActiveMode","isPresetFocusVisibleMode","containerRef","childContext","useRef","current","e","preventDefault","click","onStart","originalEvent","touches","length","ANDROID","top","left","x","y","Date","now","onMove","isSlide","onEnd","duration","activeDuraion","classes","handlers","role","undefined","map","wave","filter","c","Wave","onClear","timeout","useEffect"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport mitt from \"mitt\";\nimport { noop } from \"@vkontakte/vkjs\";\nimport { Touch, TouchEvent, TouchProps } from \"../Touch/Touch\";\nimport TouchRootContext from \"../Touch/TouchContext\";\nimport { classNames } from \"../../lib/classNames\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { ANDROID } from \"../../lib/platform\";\nimport { getOffsetRect } from \"../../lib/offset\";\nimport { coordX, coordY } from \"../../lib/touch\";\nimport { HasComponent, HasRootRef } from \"../../types\";\nimport { withAdaptivity, AdaptivityProps } from \"../../hoc/withAdaptivity\";\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 \"./Tappable.css\";\n\nexport interface TappableProps\n extends Omit<\n React.AllHTMLAttributes<HTMLElement>,\n | \"onTouchStart\"\n | \"onTouchMove\"\n | \"onTouchEnd\"\n | \"onTouchCancel\"\n | \"onMouseDown\"\n | \"onMouseMove\"\n | \"onMouseUp\"\n | \"onMouseLeave\"\n >,\n HasRootRef<HTMLElement>,\n AdaptivityProps,\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?: \"opacity\" | \"background\" | string;\n /**\n * Стиль подсветки hover-состояния. Если передать произвольную строку, она добавится как css-класс во время hover\n */\n hoverMode?: \"opacity\" | \"background\" | string;\n /**\n * Стиль аутлайна focus visible. Если передать произвольную строку, она добавится как css-класс во время focus-visible\n */\n focusVisibleMode?: FocusVisibleMode | string;\n}\n\ninterface Wave {\n x: number;\n y: number;\n id: string;\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 useActivity(hasActive: boolean, stopDelay: number) {\n const id = React.useMemo(\n () => Math.round(Math.random() * 1e8).toString(16),\n []\n );\n\n const [activity, setActivity] = React.useState<\n typeof TapState[keyof typeof TapState]\n >(TapState.none);\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\nconst Tappable: React.FC<TappableProps> = ({\n children,\n Component,\n onClick,\n onKeyDown: _onKeyDown,\n activeEffectDelay = ACTIVE_EFFECT_DELAY,\n stopPropagation = false,\n getRootRef,\n sizeX,\n hasMouse,\n deviceHasHover,\n hasHover: _hasHover = true,\n hoverMode = \"background\",\n hasActive: _hasActive = true,\n activeMode = \"background\",\n focusVisibleMode = \"inside\",\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\n const [clicks, setClicks] = React.useState<Wave[]>([]);\n const [childHover, setChildHover] = React.useState(false);\n const [_hovered, setHovered] = React.useState(false);\n\n const hovered = _hovered && !props.disabled;\n const hasActive = _hasActive && !childHover && !props.disabled;\n const hasHover = deviceHasHover && _hasHover && !childHover;\n const isCustomElement =\n Component !== \"a\" && Component !== \"button\" && !props.contentEditable;\n const isPresetHoverMode = [\"opacity\", \"background\"].includes(hoverMode);\n const isPresetActiveMode = [\"opacity\", \"background\"].includes(activeMode);\n const isPresetFocusVisibleMode = [\"inside\", \"outside\"].includes(\n focusVisibleMode\n );\n\n const [activity, { start, stop, delayStart }] = useActivity(\n hasActive,\n activeEffectDelay\n );\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 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 (platform === ANDROID) {\n const { top, left } = getOffsetRect(containerRef.current);\n const x = coordX(originalEvent) - (left ?? 0);\n const y = coordY(originalEvent) - (top ?? 0);\n setClicks([...clicks, { x, y, id: Date.now().toString() }]);\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 activeDuraion = duration - ACTIVE_DELAY;\n stop(activeDuraion >= 100 ? 0 : activeEffectDelay - activeDuraion);\n }\n\n const classes = classNames(\n getClassName(\"Tappable\", platform),\n `Tappable--sizeX-${sizeX}`,\n hasHover && hovered && !isPresetHoverMode && hoverMode,\n hasActive && active && !isPresetActiveMode && activeMode,\n focusVisible && !isPresetFocusVisibleMode && focusVisibleMode,\n {\n \"Tappable--active\": hasActive && active,\n \"Tappable--mouse\": hasMouse,\n [`Tappable--hover-${hoverMode}`]:\n hasHover && hovered && isPresetHoverMode,\n [`Tappable--active-${activeMode}`]:\n hasActive && active && isPresetActiveMode,\n \"Tappable--focus-visible\": focusVisible,\n }\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={() => setHovered(true)}\n onLeave={() => setHovered(false)}\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 vkuiClass={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}>\n {children}\n </TappableContext.Provider>\n {platform === ANDROID &&\n !hasMouse &&\n hasActive &&\n activeMode === \"background\" && (\n <span aria-hidden=\"true\" vkuiClass=\"Tappable__waves\">\n {clicks.map((wave) => (\n <Wave\n {...wave}\n key={wave.id}\n onClear={() =>\n setClicks(clicks.filter((c) => c.id !== wave.id))\n }\n />\n ))}\n </span>\n )}\n {hasHover && hoverMode === \"background\" && (\n <span aria-hidden=\"true\" vkuiClass=\"Tappable__hoverShadow\" />\n )}\n {!props.disabled && isPresetFocusVisibleMode && (\n <FocusVisible mode={focusVisibleMode as FocusVisibleMode} />\n )}\n </Touch>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default withAdaptivity(Tappable, {\n sizeX: true,\n hasMouse: true,\n deviceHasHover: true,\n});\n\nfunction Wave({ x, y, onClear }: Wave & { onClear: VoidFunction }) {\n const timeout = useTimeout(onClear, 225);\n React.useEffect(() => timeout.set(), [timeout]);\n return <span vkuiClass=\"Tappable__wave\" style={{ top: y, left: x }} />;\n}\n"],"file":"Tappable.js"}
1
+ {"version":3,"sources":["../../../../src/components/Tappable/Tappable.tsx"],"names":["ACTIVE_DELAY","ACTIVE_EFFECT_DELAY","activeBus","TapState","none","pending","active","exiting","TappableContext","React","createContext","onHoverChange","noop","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","sizeX","hasMouse","deviceHasHover","hasHover","_hasHover","hoverMode","_hasActive","activeMode","focusVisibleMode","onEnter","onLeave","props","href","useContext","insideTouchRoot","TouchRootContext","platform","focusVisible","onBlur","onFocus","clicks","setClicks","childHover","setChildHover","_hovered","value","setHoveredTrue","setTrue","setHoveredFalse","setFalse","hovered","disabled","isCustomElement","contentEditable","isPresetHoverMode","includes","isPresetActiveMode","isPresetFocusVisibleMode","containerRef","childContext","useRef","current","e","preventDefault","click","onStart","originalEvent","touches","length","ANDROID","top","left","x","y","Date","now","onMove","isSlide","onEnd","duration","activeDuration","classes","handlers","role","undefined","map","wave","filter","c","Wave","onClear","timeout","useEffect"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport mitt from \"mitt\";\nimport { noop } from \"@vkontakte/vkjs\";\nimport { Touch, TouchEvent, TouchProps } from \"../Touch/Touch\";\nimport TouchRootContext from \"../Touch/TouchContext\";\nimport { classNames } from \"../../lib/classNames\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { ANDROID } from \"../../lib/platform\";\nimport { getOffsetRect } from \"../../lib/offset\";\nimport { coordX, coordY } from \"../../lib/touch\";\nimport { HasComponent, HasRootRef } from \"../../types\";\nimport { withAdaptivity, AdaptivityProps } from \"../../hoc/withAdaptivity\";\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 \"./Tappable.css\";\n\nexport interface TappableProps\n extends Omit<\n React.AllHTMLAttributes<HTMLElement>,\n | \"onTouchStart\"\n | \"onTouchMove\"\n | \"onTouchEnd\"\n | \"onTouchCancel\"\n | \"onMouseDown\"\n | \"onMouseMove\"\n | \"onMouseUp\"\n | \"onMouseLeave\"\n >,\n HasRootRef<HTMLElement>,\n AdaptivityProps,\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?: \"opacity\" | \"background\" | string;\n /**\n * Стиль подсветки hover-состояния. Если передать произвольную строку, она добавится как css-класс во время hover\n */\n hoverMode?: \"opacity\" | \"background\" | string;\n /**\n * Стиль аутлайна focus visible. Если передать произвольную строку, она добавится как css-класс во время focus-visible\n */\n focusVisibleMode?: FocusVisibleMode | string;\n onEnter?: (outputEvent: MouseEvent) => void;\n onLeave?: (outputEvent: MouseEvent) => void;\n}\n\ninterface Wave {\n x: number;\n y: number;\n id: string;\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 useActivity(hasActive: boolean, stopDelay: number) {\n const id = React.useMemo(\n () => Math.round(Math.random() * 1e8).toString(16),\n []\n );\n\n const [activity, setActivity] = React.useState<\n typeof TapState[keyof typeof TapState]\n >(TapState.none);\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\nconst Tappable: React.FC<TappableProps> = ({\n children,\n Component,\n onClick,\n onKeyDown: _onKeyDown,\n activeEffectDelay = ACTIVE_EFFECT_DELAY,\n stopPropagation = false,\n getRootRef,\n sizeX,\n hasMouse,\n deviceHasHover,\n hasHover: _hasHover = true,\n hoverMode = \"background\",\n hasActive: _hasActive = true,\n activeMode = \"background\",\n focusVisibleMode = \"inside\",\n onEnter,\n onLeave,\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\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 = deviceHasHover && _hasHover && !childHover;\n const isCustomElement =\n Component !== \"a\" && Component !== \"button\" && !props.contentEditable;\n const isPresetHoverMode = [\"opacity\", \"background\"].includes(hoverMode);\n const isPresetActiveMode = [\"opacity\", \"background\"].includes(activeMode);\n const isPresetFocusVisibleMode = [\"inside\", \"outside\"].includes(\n focusVisibleMode\n );\n\n const [activity, { start, stop, delayStart }] = useActivity(\n hasActive,\n activeEffectDelay\n );\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 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 (platform === ANDROID) {\n const { top, left } = getOffsetRect(containerRef.current);\n const x = coordX(originalEvent) - (left ?? 0);\n const y = coordY(originalEvent) - (top ?? 0);\n setClicks([...clicks, { x, y, id: Date.now().toString() }]);\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 // eslint-disable-next-line vkui/no-object-expression-in-arguments\n const classes = classNames(\n getClassName(\"Tappable\", platform),\n `Tappable--sizeX-${sizeX}`,\n hasHover && `Tappable--hasHover`,\n hasActive && `Tappable--hasActive`,\n hasHover && hovered && !isPresetHoverMode && hoverMode,\n hasActive && active && !isPresetActiveMode && activeMode,\n focusVisible && !isPresetFocusVisibleMode && focusVisibleMode,\n {\n \"Tappable--active\": hasActive && active,\n \"Tappable--mouse\": hasMouse,\n [`Tappable--hover-${hoverMode}`]:\n hasHover && hovered && isPresetHoverMode,\n [`Tappable--active-${activeMode}`]:\n hasActive && active && isPresetActiveMode,\n \"Tappable--focus-visible\": focusVisible,\n }\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 vkuiClass={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}>\n {children}\n </TappableContext.Provider>\n {platform === ANDROID &&\n !hasMouse &&\n hasActive &&\n activeMode === \"background\" && (\n <span aria-hidden=\"true\" vkuiClass=\"Tappable__waves\">\n {clicks.map((wave) => (\n <Wave\n {...wave}\n key={wave.id}\n onClear={() =>\n setClicks(clicks.filter((c) => c.id !== wave.id))\n }\n />\n ))}\n </span>\n )}\n {hasHover && hoverMode === \"background\" && (\n <span aria-hidden=\"true\" vkuiClass=\"Tappable__hoverShadow\" />\n )}\n {!props.disabled && isPresetFocusVisibleMode && (\n <FocusVisible mode={focusVisibleMode as FocusVisibleMode} />\n )}\n </Touch>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default withAdaptivity(Tappable, {\n sizeX: true,\n hasMouse: true,\n deviceHasHover: true,\n});\n\nfunction Wave({ x, y, onClear }: Wave & { onClear: VoidFunction }) {\n const timeout = useTimeout(onClear, 225);\n React.useEffect(() => timeout.set(), [timeout]);\n return <span vkuiClass=\"Tappable__wave\" style={{ top: y, left: x }} />;\n}\n"],"file":"Tappable.js"}
@@ -25,7 +25,7 @@ var _usePlatform = require("../../hooks/usePlatform");
25
25
 
26
26
  var _utils = require("../../lib/utils");
27
27
 
28
- var _Subhead = _interopRequireDefault(require("../Typography/Subhead/Subhead"));
28
+ var _Subhead = require("../Typography/Subhead/Subhead");
29
29
 
30
30
  var _prefixClass = require("../../lib/prefixClass");
31
31
 
@@ -41,11 +41,11 @@ var TextTooltip = function TextTooltip(_ref) {
41
41
  vkuiClass: (0, _getClassName.getClassName)("TextTooltip", platform),
42
42
  arrow: true,
43
43
  arrowClassName: (0, _prefixClass.prefixClass)("TextTooltip__arrow"),
44
- content: (0, _jsxRuntime.createScopedElement)(React.Fragment, null, (0, _utils.hasReactNode)(header) && (0, _jsxRuntime.createScopedElement)(_Subhead.default, {
44
+ content: (0, _jsxRuntime.createScopedElement)(React.Fragment, null, (0, _utils.hasReactNode)(header) && (0, _jsxRuntime.createScopedElement)(_Subhead.Subhead, {
45
45
  Component: "span",
46
46
  weight: "2",
47
47
  vkuiClass: "TextTooltip__header"
48
- }, header), (0, _utils.hasReactNode)(text) && (0, _jsxRuntime.createScopedElement)(_Subhead.default, {
48
+ }, header), (0, _utils.hasReactNode)(text) && (0, _jsxRuntime.createScopedElement)(_Subhead.Subhead, {
49
49
  Component: "span",
50
50
  vkuiClass: "TextTooltip__text"
51
51
  }, text))
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/TextTooltip/TextTooltip.tsx"],"names":["TextTooltip","children","text","header","popperProps","platform"],"mappings":";;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAeO,IAAMA,WAAuC,GAAG,SAA1CA,WAA0C,OAK/B;AAAA,MAJtBC,QAIsB,QAJtBA,QAIsB;AAAA,MAHtBC,IAGsB,QAHtBA,IAGsB;AAAA,MAFtBC,MAEsB,QAFtBA,MAEsB;AAAA,MADnBC,WACmB;AACtB,MAAMC,QAAQ,GAAG,+BAAjB;AAEA,SACE,qCAAC,wBAAD;AACE,IAAA,SAAS,EAAE,gCAAa,aAAb,EAA4BA,QAA5B,CADb;AAEE,IAAA,KAAK,MAFP;AAGE,IAAA,cAAc,EAAE,8BAAY,oBAAZ,CAHlB;AAIE,IAAA,OAAO,EACL,qCAAC,KAAD,CAAO,QAAP,QACG,yBAAaF,MAAb,KACC,qCAAC,gBAAD;AACE,MAAA,SAAS,EAAC,MADZ;AAEE,MAAA,MAAM,EAAC,GAFT;AAGE,MAAA,SAAS,EAAC;AAHZ,OAKGA,MALH,CAFJ,EAUG,yBAAaD,IAAb,KACC,qCAAC,gBAAD;AAAS,MAAA,SAAS,EAAC,MAAnB;AAA0B,MAAA,SAAS,EAAC;AAApC,OACGA,IADH,CAXJ;AALJ,KAsBME,WAtBN,GAwBGH,QAxBH,CADF;AA4BD,CApCM","sourcesContent":["import * as React from \"react\";\nimport { HoverPopper, HoverPopperProps } from \"../HoverPopper/HoverPopper\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport Subhead from \"../Typography/Subhead/Subhead\";\nimport { prefixClass } from \"../../lib/prefixClass\";\nimport \"./TextTooltip.css\";\n\nexport interface TextTooltipProps\n extends Omit<HoverPopperProps, \"arrow\" | \"arrowClassName\" | \"content\"> {\n /**\n * Текст тултипа\n */\n text?: React.ReactNode;\n /**\n * Заголовок тултипа\n */\n header?: React.ReactNode;\n}\n\nexport const TextTooltip: React.FC<TextTooltipProps> = ({\n children,\n text,\n header,\n ...popperProps\n}: TextTooltipProps) => {\n const platform = usePlatform();\n\n return (\n <HoverPopper\n vkuiClass={getClassName(\"TextTooltip\", platform)}\n arrow\n arrowClassName={prefixClass(\"TextTooltip__arrow\")}\n content={\n <React.Fragment>\n {hasReactNode(header) && (\n <Subhead\n Component=\"span\"\n weight=\"2\"\n vkuiClass=\"TextTooltip__header\"\n >\n {header}\n </Subhead>\n )}\n {hasReactNode(text) && (\n <Subhead Component=\"span\" vkuiClass=\"TextTooltip__text\">\n {text}\n </Subhead>\n )}\n </React.Fragment>\n }\n {...popperProps}\n >\n {children}\n </HoverPopper>\n );\n};\n"],"file":"TextTooltip.js"}
1
+ {"version":3,"sources":["../../../../src/components/TextTooltip/TextTooltip.tsx"],"names":["TextTooltip","children","text","header","popperProps","platform"],"mappings":";;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAeO,IAAMA,WAAuC,GAAG,SAA1CA,WAA0C,OAK/B;AAAA,MAJtBC,QAIsB,QAJtBA,QAIsB;AAAA,MAHtBC,IAGsB,QAHtBA,IAGsB;AAAA,MAFtBC,MAEsB,QAFtBA,MAEsB;AAAA,MADnBC,WACmB;AACtB,MAAMC,QAAQ,GAAG,+BAAjB;AAEA,SACE,qCAAC,wBAAD;AACE,IAAA,SAAS,EAAE,gCAAa,aAAb,EAA4BA,QAA5B,CADb;AAEE,IAAA,KAAK,MAFP;AAGE,IAAA,cAAc,EAAE,8BAAY,oBAAZ,CAHlB;AAIE,IAAA,OAAO,EACL,qCAAC,KAAD,CAAO,QAAP,QACG,yBAAaF,MAAb,KACC,qCAAC,gBAAD;AACE,MAAA,SAAS,EAAC,MADZ;AAEE,MAAA,MAAM,EAAC,GAFT;AAGE,MAAA,SAAS,EAAC;AAHZ,OAKGA,MALH,CAFJ,EAUG,yBAAaD,IAAb,KACC,qCAAC,gBAAD;AAAS,MAAA,SAAS,EAAC,MAAnB;AAA0B,MAAA,SAAS,EAAC;AAApC,OACGA,IADH,CAXJ;AALJ,KAsBME,WAtBN,GAwBGH,QAxBH,CADF;AA4BD,CApCM","sourcesContent":["import * as React from \"react\";\nimport { HoverPopper, HoverPopperProps } from \"../HoverPopper/HoverPopper\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport { Subhead } from \"../Typography/Subhead/Subhead\";\nimport { prefixClass } from \"../../lib/prefixClass\";\nimport \"./TextTooltip.css\";\n\nexport interface TextTooltipProps\n extends Omit<HoverPopperProps, \"arrow\" | \"arrowClassName\" | \"content\"> {\n /**\n * Текст тултипа\n */\n text?: React.ReactNode;\n /**\n * Заголовок тултипа\n */\n header?: React.ReactNode;\n}\n\nexport const TextTooltip: React.FC<TextTooltipProps> = ({\n children,\n text,\n header,\n ...popperProps\n}: TextTooltipProps) => {\n const platform = usePlatform();\n\n return (\n <HoverPopper\n vkuiClass={getClassName(\"TextTooltip\", platform)}\n arrow\n arrowClassName={prefixClass(\"TextTooltip__arrow\")}\n content={\n <React.Fragment>\n {hasReactNode(header) && (\n <Subhead\n Component=\"span\"\n weight=\"2\"\n vkuiClass=\"TextTooltip__header\"\n >\n {header}\n </Subhead>\n )}\n {hasReactNode(text) && (\n <Subhead Component=\"span\" vkuiClass=\"TextTooltip__text\">\n {text}\n </Subhead>\n )}\n </React.Fragment>\n }\n {...popperProps}\n >\n {children}\n </HoverPopper>\n );\n};\n"],"file":"TextTooltip.js"}
@@ -29,7 +29,7 @@ var _classNames = require("../../lib/classNames");
29
29
 
30
30
  var _getClassName = require("../../helpers/getClassName");
31
31
 
32
- var _Subhead = _interopRequireDefault(require("../Typography/Subhead/Subhead"));
32
+ var _Subhead = require("../Typography/Subhead/Subhead");
33
33
 
34
34
  var _NavTransitionContext = require("../NavTransitionContext/NavTransitionContext");
35
35
 
@@ -78,10 +78,10 @@ var SimpleTooltip = /*#__PURE__*/React.forwardRef(function SimpleTooltip(_ref, r
78
78
  ref: arrowRef
79
79
  })), (0, _jsxRuntime.createScopedElement)("div", {
80
80
  vkuiClass: "Tooltip__content"
81
- }, header && (0, _jsxRuntime.createScopedElement)(_Subhead.default, {
81
+ }, header && (0, _jsxRuntime.createScopedElement)(_Subhead.Subhead, {
82
82
  weight: "1",
83
83
  vkuiClass: "Tooltip__title"
84
- }, header), text && (0, _jsxRuntime.createScopedElement)(_Subhead.default, {
84
+ }, header), text && (0, _jsxRuntime.createScopedElement)(_Subhead.Subhead, {
85
85
  vkuiClass: "Tooltip__text"
86
86
  }, text))));
87
87
  });
@@ -150,7 +150,7 @@ var Tooltip = function Tooltip(_ref2) {
150
150
  var multiChildren = React.Children.count(children) > 1; // Empty children is a noop
151
151
 
152
152
  var primitiveChild = (0, _utils.hasReactNode)(children) && (0, _typeof2.default)(children) !== "object";
153
- (multiChildren || primitiveChild) && warn(["children must be a single React element, got", multiChildren && "multiple", primitiveChild && JSON.stringify(children)].filter(Boolean).join(" "));
153
+ (multiChildren || primitiveChild) && warn(["children must be a single React element, got", multiChildren && "multiple", primitiveChild && JSON.stringify(children)].filter(Boolean).join(" "), "error");
154
154
  }
155
155
  /* eslint-disable no-restricted-properties */
156
156
 
@@ -171,7 +171,7 @@ var Tooltip = function Tooltip(_ref2) {
171
171
  throw new Error("Use TooltipContainer for Tooltip outside Panel (see docs)");
172
172
  }
173
173
 
174
- var arrowOffsetModiifer = React.useMemo(function () {
174
+ var arrowOffsetModifier = React.useMemo(function () {
175
175
  return {
176
176
  name: "arrowOffset",
177
177
  enabled: true,
@@ -227,7 +227,7 @@ var Tooltip = function Tooltip(_ref2) {
227
227
  name: "preventOverflow"
228
228
  }, {
229
229
  name: "flip"
230
- }, arrowOffsetModiifer]
230
+ }, arrowOffsetModifier]
231
231
  }),
232
232
  styles = _usePopper.styles,
233
233
  attributes = _usePopper.attributes;