@vkontakte/vkui 4.37.0 → 4.37.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (289) hide show
  1. package/.cache/.eslintcache +1 -1
  2. package/.cache/.stylelintcache +1 -1
  3. package/.cache/.tsbuildinfo +5 -5
  4. package/dist/cjs/appearance/constants.d.ts +1 -0
  5. package/dist/cjs/components/ActionSheet/ActionSheet.d.ts +29 -0
  6. package/dist/cjs/components/ActionSheet/ActionSheetContext.d.ts +8 -0
  7. package/dist/cjs/components/ActionSheet/ActionSheetDefaultIosCloseItem.d.ts +3 -0
  8. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.d.ts +4 -0
  9. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.d.ts +4 -0
  10. package/dist/cjs/components/ActionSheet/types.d.ts +9 -0
  11. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.d.ts +27 -0
  12. package/dist/cjs/components/AdaptivityProvider/AdaptivityContext.d.ts +46 -0
  13. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.d.ts +15 -0
  14. package/dist/cjs/components/Alert/Alert.d.ts +25 -0
  15. package/dist/cjs/components/AppRoot/AppRoot.d.ts +23 -0
  16. package/dist/cjs/components/AppRoot/AppRootContext.d.ts +10 -0
  17. package/dist/cjs/components/AppRoot/AppRootPortal.d.ts +7 -0
  18. package/dist/cjs/components/AppRoot/ScrollContext.d.ts +27 -0
  19. package/dist/cjs/components/AppRoot/ScrollContext.js +9 -1
  20. package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
  21. package/dist/cjs/components/AppearanceProvider/AppearanceProvider.d.ts +11 -0
  22. package/dist/cjs/components/AppearanceProvider/AppearanceProviderContext.d.ts +3 -0
  23. package/dist/cjs/components/Avatar/Avatar.d.ts +24 -0
  24. package/dist/cjs/components/Badge/Badge.d.ts +9 -0
  25. package/dist/cjs/components/Banner/Banner.d.ts +67 -0
  26. package/dist/cjs/components/BaseGallery/BaseGallery.d.ts +4 -0
  27. package/dist/cjs/components/BaseGallery/helpers.d.ts +12 -0
  28. package/dist/cjs/components/BaseGallery/types.d.ts +43 -0
  29. package/dist/cjs/components/Button/Button.d.ts +22 -0
  30. package/dist/cjs/components/ButtonGroup/ButtonGroup.d.ts +27 -0
  31. package/dist/cjs/components/Calendar/Calendar.d.ts +34 -0
  32. package/dist/cjs/components/CalendarDay/CalendarDay.d.ts +24 -0
  33. package/dist/cjs/components/CalendarDays/CalendarDays.d.ts +24 -0
  34. package/dist/cjs/components/CalendarHeader/CalendarHeader.d.ts +29 -0
  35. package/dist/cjs/components/CalendarRange/CalendarRange.d.ts +19 -0
  36. package/dist/cjs/components/CalendarTime/CalendarTime.d.ts +11 -0
  37. package/dist/cjs/components/Card/Card.d.ts +10 -0
  38. package/dist/cjs/components/CardGrid/CardGrid.d.ts +14 -0
  39. package/dist/cjs/components/CardScroll/CardScroll.d.ts +15 -0
  40. package/dist/cjs/components/Cell/Cell.d.ts +50 -0
  41. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.d.ts +5 -0
  42. package/dist/cjs/components/Cell/CellDragger/CellDragger.d.ts +6 -0
  43. package/dist/cjs/components/Cell/useDraggable.d.ts +15 -0
  44. package/dist/cjs/components/CellButton/CellButton.d.ts +11 -0
  45. package/dist/cjs/components/Checkbox/Checkbox.d.ts +15 -0
  46. package/dist/cjs/components/Chip/Chip.d.ts +26 -0
  47. package/dist/cjs/components/ChipsInput/ChipsInput.d.ts +11 -0
  48. package/dist/cjs/components/ChipsInputBase/ChipsInputBase.d.ts +17 -0
  49. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts +45 -0
  50. package/dist/cjs/components/ConfigProvider/ConfigProvider.d.ts +19 -0
  51. package/dist/cjs/components/ConfigProvider/ConfigProviderContext.d.ts +37 -0
  52. package/dist/cjs/components/ContentCard/ContentCard.d.ts +36 -0
  53. package/dist/cjs/components/Counter/Counter.d.ts +13 -0
  54. package/dist/cjs/components/CustomScrollView/CustomScrollView.d.ts +11 -0
  55. package/dist/cjs/components/CustomScrollView/useTrackerVisibility.d.ts +43 -0
  56. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +62 -0
  57. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +17 -0
  58. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.d.ts +47 -0
  59. package/dist/cjs/components/DateInput/DateInput.d.ts +17 -0
  60. package/dist/cjs/components/DatePicker/DatePicker.d.ts +23 -0
  61. package/dist/cjs/components/DateRangeInput/DateRangeInput.d.ts +23 -0
  62. package/dist/cjs/components/Div/Div.d.ts +9 -0
  63. package/dist/cjs/components/Dropdown/Dropdown.d.ts +52 -0
  64. package/dist/cjs/components/DropdownIcon/DropdownIcon.d.ts +5 -0
  65. package/dist/cjs/components/Epic/Epic.d.ts +11 -0
  66. package/dist/cjs/components/Epic/ScrollSaver.d.ts +10 -0
  67. package/dist/cjs/components/File/File.d.ts +13 -0
  68. package/dist/cjs/components/FixedLayout/FixedLayout.d.ts +21 -0
  69. package/dist/cjs/components/FixedLayout/FixedLayout.js +1 -1
  70. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  71. package/dist/cjs/components/FocusTrap/FocusTrap.d.ts +11 -0
  72. package/dist/cjs/components/FocusVisible/FocusVisible.d.ts +10 -0
  73. package/dist/cjs/components/Footer/Footer.d.ts +8 -0
  74. package/dist/cjs/components/FormField/FormField.d.ts +37 -0
  75. package/dist/cjs/components/FormItem/FormItem.d.ts +17 -0
  76. package/dist/cjs/components/FormLayout/FormLayout.d.ts +8 -0
  77. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.d.ts +19 -0
  78. package/dist/cjs/components/FormStatus/FormStatus.d.ts +11 -0
  79. package/dist/cjs/components/Gallery/Gallery.d.ts +10 -0
  80. package/dist/cjs/components/Gradient/Gradient.d.ts +16 -0
  81. package/dist/cjs/components/GridAvatar/GridAvatar.d.ts +15 -0
  82. package/dist/cjs/components/Group/Group.d.ts +30 -0
  83. package/dist/cjs/components/Header/Header.d.ts +20 -0
  84. package/dist/cjs/components/HorizontalCell/HorizontalCell.d.ts +13 -0
  85. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.d.ts +22 -0
  86. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.d.ts +8 -0
  87. package/dist/cjs/components/HoverPopper/HoverPopper.d.ts +29 -0
  88. package/dist/cjs/components/IconButton/IconButton.d.ts +14 -0
  89. package/dist/cjs/components/InfoRow/InfoRow.d.ts +9 -0
  90. package/dist/cjs/components/InitialsAvatar/InitialsAvatar.d.ts +35 -0
  91. package/dist/cjs/components/Input/Input.d.ts +11 -0
  92. package/dist/cjs/components/InputLike/InputLike.d.ts +13 -0
  93. package/dist/cjs/components/InputLike/InputLikeDivider.d.ts +3 -0
  94. package/dist/cjs/components/Link/Link.d.ts +13 -0
  95. package/dist/cjs/components/List/List.d.ts +7 -0
  96. package/dist/cjs/components/List/ListContext.d.ts +4 -0
  97. package/dist/cjs/components/LocaleProviderContext/LocaleProviderContext.d.ts +2 -0
  98. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.d.ts +42 -0
  99. package/dist/cjs/components/ModalCard/ModalCard.d.ts +12 -0
  100. package/dist/cjs/components/ModalCardBase/ModalCardBase.d.ts +39 -0
  101. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.d.ts +7 -0
  102. package/dist/cjs/components/ModalPage/ModalPage.d.ts +51 -0
  103. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.d.ts +10 -0
  104. package/dist/cjs/components/ModalRoot/ModalRoot.d.ts +29 -0
  105. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.d.ts +26 -0
  106. package/dist/cjs/components/ModalRoot/ModalRootContext.d.ts +20 -0
  107. package/dist/cjs/components/ModalRoot/ModalRootDesktop.d.ts +29 -0
  108. package/dist/cjs/components/ModalRoot/constants.d.ts +3 -0
  109. package/dist/cjs/components/ModalRoot/types.d.ts +60 -0
  110. package/dist/cjs/components/ModalRoot/useModalManager.d.ts +39 -0
  111. package/dist/cjs/components/ModalRoot/withModalRootContext.d.ts +5 -0
  112. package/dist/cjs/components/NativeSelect/NativeSelect.d.ts +20 -0
  113. package/dist/cjs/components/NavTransitionContext/NavTransitionContext.d.ts +6 -0
  114. package/dist/cjs/components/Pagination/Pagination.d.ts +45 -0
  115. package/dist/cjs/components/Panel/Panel.d.ts +12 -0
  116. package/dist/cjs/components/PanelHeader/PanelHeader.d.ts +31 -0
  117. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.d.ts +12 -0
  118. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.d.ts +11 -0
  119. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.d.ts +6 -0
  120. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.d.ts +11 -0
  121. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.d.ts +10 -0
  122. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +20 -0
  123. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +6 -0
  124. package/dist/cjs/components/PanelSpinner/PanelSpinner.d.ts +9 -0
  125. package/dist/cjs/components/Placeholder/Placeholder.d.ts +25 -0
  126. package/dist/cjs/components/PopoutRoot/PopoutRoot.d.ts +13 -0
  127. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.d.ts +13 -0
  128. package/dist/cjs/components/Popper/Popper.d.ts +57 -0
  129. package/dist/cjs/components/PopperArrow/PopperArrow.d.ts +8 -0
  130. package/dist/cjs/components/Progress/Progress.d.ts +10 -0
  131. package/dist/cjs/components/PromoBanner/PromoBanner.d.ts +43 -0
  132. package/dist/cjs/components/PullToRefresh/PullToRefresh.d.ts +22 -0
  133. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.d.ts +10 -0
  134. package/dist/cjs/components/Radio/Radio.d.ts +11 -0
  135. package/dist/cjs/components/RadioGroup/RadioGroup.d.ts +9 -0
  136. package/dist/cjs/components/RangeSlider/RangeSlider.d.ts +8 -0
  137. package/dist/cjs/components/RangeSlider/UniversalSlider.d.ts +16 -0
  138. package/dist/cjs/components/Removable/Removable.d.ts +24 -0
  139. package/dist/cjs/components/RichCell/RichCell.d.ts +56 -0
  140. package/dist/cjs/components/RichTooltip/RichTooltip.d.ts +13 -0
  141. package/dist/cjs/components/Root/Root.d.ts +33 -0
  142. package/dist/cjs/components/ScreenSpinner/Icon48CancelCircle.d.ts +3 -0
  143. package/dist/cjs/components/ScreenSpinner/Icon48DoneOutline.d.ts +3 -0
  144. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.d.ts +10 -0
  145. package/dist/cjs/components/Search/Search.d.ts +16 -0
  146. package/dist/cjs/components/SegmentedControl/SegmentedControl.d.ts +20 -0
  147. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +7 -0
  148. package/dist/cjs/components/Select/Select.d.ts +18 -0
  149. package/dist/cjs/components/SelectMimicry/SelectMimicry.d.ts +15 -0
  150. package/dist/cjs/components/Separator/Separator.d.ts +16 -0
  151. package/dist/cjs/components/SimpleCell/SimpleCell.d.ts +74 -0
  152. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.d.ts +12 -0
  153. package/dist/cjs/components/Slider/Slider.d.ts +7 -0
  154. package/dist/cjs/components/SliderSwitch/SliderSwitch.d.ts +48 -0
  155. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.d.ts +11 -0
  156. package/dist/cjs/components/Snackbar/Snackbar.d.ts +42 -0
  157. package/dist/cjs/components/Spacing/Spacing.d.ts +23 -0
  158. package/dist/cjs/components/Spinner/Spinner.d.ts +9 -0
  159. package/dist/cjs/components/SplitCol/SplitCol.d.ts +26 -0
  160. package/dist/cjs/components/SplitLayout/SplitLayout.d.ts +18 -0
  161. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.d.ts +10 -0
  162. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.d.ts +25 -0
  163. package/dist/cjs/components/Switch/Switch.d.ts +10 -0
  164. package/dist/cjs/components/Tabbar/Tabbar.d.ts +20 -0
  165. package/dist/cjs/components/TabbarItem/TabbarItem.d.ts +23 -0
  166. package/dist/cjs/components/Tabs/Tabs.d.ts +23 -0
  167. package/dist/cjs/components/TabsItem/TabsItem.d.ts +31 -0
  168. package/dist/cjs/components/Tappable/Tappable.d.ts +46 -0
  169. package/dist/cjs/components/TextTooltip/TextTooltip.d.ts +21 -0
  170. package/dist/cjs/components/Textarea/Textarea.d.ts +14 -0
  171. package/dist/cjs/components/Tooltip/Tooltip.d.ts +75 -0
  172. package/dist/cjs/components/Tooltip/TooltipContainer.d.ts +5 -0
  173. package/dist/cjs/components/Touch/Touch.d.ts +52 -0
  174. package/dist/cjs/components/Touch/TouchContext.d.ts +7 -0
  175. package/dist/cjs/components/Typography/Caption/Caption.d.ts +17 -0
  176. package/dist/cjs/components/Typography/Footnote/Footnote.d.ts +14 -0
  177. package/dist/cjs/components/Typography/Headline/Headline.d.ts +16 -0
  178. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts +13 -0
  179. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts +15 -0
  180. package/dist/cjs/components/Typography/Text/Text.d.ts +15 -0
  181. package/dist/cjs/components/Typography/Title/Title.d.ts +16 -0
  182. package/dist/cjs/components/UsersStack/UsersStack.d.ts +31 -0
  183. package/dist/cjs/components/View/View.d.ts +67 -0
  184. package/dist/cjs/components/View/View.js +2 -0
  185. package/dist/cjs/components/View/View.js.map +1 -1
  186. package/dist/cjs/components/View/ViewInfinite.d.ts +66 -0
  187. package/dist/cjs/components/View/utils.d.ts +2 -0
  188. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +12 -0
  189. package/dist/cjs/components/WriteBar/WriteBar.d.ts +30 -0
  190. package/dist/cjs/components/WriteBar/WriteBar.js +2 -5
  191. package/dist/cjs/components/WriteBar/WriteBar.js.map +1 -1
  192. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.d.ts +21 -0
  193. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js +15 -3
  194. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  195. package/dist/cjs/helpers/avatar.d.ts +5 -0
  196. package/dist/cjs/helpers/getClassName.d.ts +2 -0
  197. package/dist/cjs/helpers/getScheme.d.ts +8 -0
  198. package/dist/cjs/helpers/math.d.ts +5 -0
  199. package/dist/cjs/helpers/scheme.d.ts +34 -0
  200. package/dist/cjs/hoc/withAdaptivity.d.ts +13 -0
  201. package/dist/cjs/hoc/withContext.d.ts +2 -0
  202. package/dist/cjs/hoc/withInsets.d.ts +3 -0
  203. package/dist/cjs/hoc/withPlatform.d.ts +3 -0
  204. package/dist/cjs/hooks/useAdaptivity.d.ts +4 -0
  205. package/dist/cjs/hooks/useAppearance.d.ts +1 -0
  206. package/dist/cjs/hooks/useBooleanState.d.ts +6 -0
  207. package/dist/cjs/hooks/useBridgeAdaptivity.d.ts +6 -0
  208. package/dist/cjs/hooks/useBrowserInfo.d.ts +2 -0
  209. package/dist/cjs/hooks/useCalendar.d.ts +19 -0
  210. package/dist/cjs/hooks/useChipsInput.d.ts +15 -0
  211. package/dist/cjs/hooks/useChipsSelect.d.ts +22 -0
  212. package/dist/cjs/hooks/useDateInput.d.ts +30 -0
  213. package/dist/cjs/hooks/useEffectDev.d.ts +2 -0
  214. package/dist/cjs/hooks/useEnsuredControl.d.ts +7 -0
  215. package/dist/cjs/hooks/useEventListener.d.ts +7 -0
  216. package/dist/cjs/hooks/useExternRef.d.ts +2 -0
  217. package/dist/cjs/hooks/useFocusVisible.d.ts +6 -0
  218. package/dist/cjs/hooks/useGlobalEventListener.d.ts +2 -0
  219. package/dist/cjs/hooks/useInsets.d.ts +8 -0
  220. package/dist/cjs/hooks/useKeyboard.d.ts +10 -0
  221. package/dist/cjs/hooks/useKeyboardInputTracker.d.ts +3 -0
  222. package/dist/cjs/hooks/useObjectMemo.d.ts +2 -0
  223. package/dist/cjs/hooks/useOrientationChange.d.ts +7 -0
  224. package/dist/cjs/hooks/usePagination.d.ts +34 -0
  225. package/dist/cjs/hooks/usePatchChildrenRef.d.ts +6 -0
  226. package/dist/cjs/hooks/usePlatform.d.ts +2 -0
  227. package/dist/cjs/hooks/usePrevious.d.ts +1 -0
  228. package/dist/cjs/hooks/useTimeout.d.ts +4 -0
  229. package/dist/cjs/hooks/useWaitTransitionFinish.d.ts +3 -0
  230. package/dist/cjs/index.d.ts +310 -0
  231. package/dist/cjs/lib/SSR.d.ts +18 -0
  232. package/dist/cjs/lib/accessibility.d.ts +10 -0
  233. package/dist/cjs/lib/animate.d.ts +15 -0
  234. package/dist/cjs/lib/browser.d.ts +11 -0
  235. package/dist/cjs/lib/calendar.d.ts +14 -0
  236. package/dist/cjs/lib/callMultiple.d.ts +1 -0
  237. package/dist/cjs/lib/classNames.d.ts +6 -0
  238. package/dist/cjs/lib/classScopingMode.d.ts +8 -0
  239. package/dist/cjs/lib/date.d.ts +29 -0
  240. package/dist/cjs/lib/dom.d.ts +21 -0
  241. package/dist/cjs/lib/fx.d.ts +5 -0
  242. package/dist/cjs/lib/getNavId.d.ts +7 -0
  243. package/dist/cjs/lib/is.d.ts +1 -0
  244. package/dist/cjs/lib/isRefObject.d.ts +2 -0
  245. package/dist/cjs/lib/jsxRuntime.d.ts +8 -0
  246. package/dist/cjs/lib/offset.d.ts +7 -0
  247. package/dist/cjs/lib/platform.d.ts +19 -0
  248. package/dist/cjs/lib/polyfills.d.ts +6 -0
  249. package/dist/cjs/lib/prefixClass.d.ts +1 -0
  250. package/dist/cjs/lib/removeObjectKeys.d.ts +1 -0
  251. package/dist/cjs/lib/select.d.ts +9 -0
  252. package/dist/cjs/lib/styles.d.ts +1 -0
  253. package/dist/cjs/lib/supportEvents.d.ts +9 -0
  254. package/dist/cjs/lib/taptic.d.ts +2 -0
  255. package/dist/cjs/lib/testing.d.ts +1 -0
  256. package/dist/cjs/lib/touch.d.ts +9 -0
  257. package/dist/cjs/lib/useIsomorphicLayoutEffect.d.ts +2 -0
  258. package/dist/cjs/lib/utils.d.ts +16 -0
  259. package/dist/cjs/lib/warnOnce.d.ts +2 -0
  260. package/dist/cjs/tokenized/index.d.ts +238 -0
  261. package/dist/cjs/types.d.ts +37 -0
  262. package/dist/cjs/unstable/index.d.ts +17 -0
  263. package/dist/components/AppRoot/ScrollContext.js +9 -1
  264. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  265. package/dist/components/FixedLayout/FixedLayout.js +1 -1
  266. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  267. package/dist/components/View/View.js +2 -0
  268. package/dist/components/View/View.js.map +1 -1
  269. package/dist/components/WriteBar/WriteBar.js +2 -5
  270. package/dist/components/WriteBar/WriteBar.js.map +1 -1
  271. package/dist/components/WriteBarIcon/WriteBarIcon.js +15 -3
  272. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  273. package/dist/cssm/components/AppRoot/ScrollContext.js +9 -1
  274. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  275. package/dist/cssm/components/FixedLayout/FixedLayout.js +1 -1
  276. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  277. package/dist/cssm/components/View/View.js +2 -0
  278. package/dist/cssm/components/View/View.js.map +1 -1
  279. package/dist/cssm/components/WriteBar/WriteBar.js +2 -5
  280. package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
  281. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +15 -3
  282. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  283. package/package.json +2 -2
  284. package/src/components/AppRoot/ScrollContext.tsx +13 -1
  285. package/src/components/FixedLayout/FixedLayout.tsx +1 -1
  286. package/src/components/View/View.tsx +2 -0
  287. package/src/components/WriteBar/Readme.md +14 -14
  288. package/src/components/WriteBar/WriteBar.tsx +2 -2
  289. package/src/components/WriteBarIcon/WriteBarIcon.tsx +13 -4
@@ -1 +1 @@
1
- {"version":3,"file":"View.js","names":["React","classNames","animationEvent","IOS","Touch","useConfigProvider","useSplitCol","AppRootPortal","canUseDOM","useDOM","blurActiveElement","useScroll","NavTransitionProvider","getNavId","warnOnce","usePlatform","swipeBackExcluded","useWaitTransitionFinish","useTimeout","usePrevious","useIsomorphicLayoutEffect","noop","SwipeBackResults","scrollsCache","warn","View","popout","modal","activePanelProp","activePanel","history","nav","onTransition","onSwipeBack","onSwipeBackStart","onSwipeBackCancelProp","onSwipeBackCancel","children","restProps","process","env","NODE_ENV","scrolls","useRef","id","afterTransition","useEffect","current","panelNodes","window","document","scroll","configProvider","splitCol","platform","useState","animated","setAnimated","visiblePanels","setVisiblePanels","setActivePanel","undefined","isBack","setIsBack","prevPanel","setPrevPanel","nextPanel","setNextPanel","swipingBack","setSwipingBack","swipeBackStartX","setSwipeBackStartX","swipeBackShift","setSwipeBackShift","swipeBackNextPanel","setSwipeBackNextPanel","swipeBackPrevPanel","setSwipeBackPrevPanel","swipeBackResult","setSwipeBackResult","browserSwipe","setBrowserSwipe","prevActivePanel","prevSwipingBack","prevBrowserSwipe","prevSwipeBackResult","prevSwipeBackPrevPanel","prevOnTransition","panels","Children","toArray","filter","panel","panelId","props","includes","disableAnimation","transitionMotionEnabled","animate","pickPanel","flushTransition","useCallback","isBackTransition","scrollTo","from","to","transitionEndHandler","e","animationName","Boolean","waitTransitionFinish","animationFinishTimeout","onSwipeBackSuccess","swipingBackTransitionEndHandler","propertyName","target","fail","success","onMoveX","isWebView","startX","innerWidth","length","getScroll","y","slice","shiftX","onEnd","speed","duration","calcPanelSwipeStyles","isPrev","isNext","prevPanelTranslate","nextPanelTranslate","prevPanelShadow","boxShadow","transform","WebkitTransform","firstLayerId","map","find","supported","set","isTransitionTarget","compensateScroll","el","marginTop"],"sources":["../../../../src/components/View/View.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { animationEvent } from \"../../lib/supportEvents\";\nimport { IOS } from \"../../lib/platform\";\nimport { Touch, TouchEvent } from \"../Touch/Touch\";\nimport { useConfigProvider } from \"../ConfigProvider/ConfigProviderContext\";\nimport { useSplitCol } from \"../SplitCol/SplitCol\";\nimport { AppRootPortal } from \"../AppRoot/AppRootPortal\";\nimport { canUseDOM, useDOM, blurActiveElement } from \"../../lib/dom\";\nimport { useScroll } from \"../AppRoot/ScrollContext\";\nimport { NavTransitionProvider } from \"../NavTransitionContext/NavTransitionContext\";\nimport { getNavId, NavIdProps } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { swipeBackExcluded } from \"./utils\";\nimport { useWaitTransitionFinish } from \"../../hooks/useWaitTransitionFinish\";\nimport { useTimeout } from \"../../hooks/useTimeout\";\nimport { usePrevious } from \"../../hooks/usePrevious\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { noop } from \"../../lib/utils\";\nimport \"./View.css\";\n\nenum SwipeBackResults {\n fail = 1,\n success,\n}\n\ninterface Scrolls {\n [index: string]: number | undefined;\n}\n\ninterface ViewsScrolls {\n [index: string]: Scrolls;\n}\n\nexport let scrollsCache: ViewsScrolls = {};\n\nexport interface ViewProps\n extends React.HTMLAttributes<HTMLElement>,\n NavIdProps {\n activePanel: string;\n /**\n * @deprecated будет удалено в 5.0.0. Используйте одноименное свойство у `SplitLayout`.\n *\n * Свойство для отрисовки `Alert`, `ActionSheet` и `ScreenSpinner`.\n */\n popout?: React.ReactNode;\n /**\n * @deprecated будет удалено в 5.0.0. Используйте одноименное свойство у `SplitLayout`.\n *\n * Свойство для отрисовки `ModalRoot`.\n */\n modal?: React.ReactNode;\n onTransition?(params: { isBack: boolean; from: string; to: string }): void;\n /**\n * callback свайпа назад\n */\n onSwipeBack?(): void;\n /**\n * callback начала анимации свайпа назад.\n */\n onSwipeBackStart?(): void;\n /**\n * callback завершения анимации отмененного пользователем свайпа\n */\n onSwipeBackCancel?(): void;\n history?: string[];\n}\n\nexport interface ViewState {\n animated: boolean;\n\n visiblePanels: string[];\n activePanel: string | null;\n isBack: boolean | undefined;\n prevPanel: string | null;\n nextPanel: string | null;\n\n swipingBack: boolean;\n swipeBackStartX: number;\n swipeBackShift: number;\n swipeBackNextPanel: string | null;\n swipeBackPrevPanel: string | null;\n swipeBackResult: SwipeBackResults | null;\n\n browserSwipe: boolean;\n}\n\nconst warn = warnOnce(\"View\");\n\n/**\n * @see https://vkcom.github.io/VKUI/#/View\n */\nexport const View = ({\n popout,\n modal,\n activePanel: activePanelProp,\n history,\n nav,\n onTransition,\n onSwipeBack,\n onSwipeBackStart,\n onSwipeBackCancel: onSwipeBackCancelProp,\n children,\n\n ...restProps\n}: ViewProps) => {\n if (process.env.NODE_ENV === \"development\") {\n popout &&\n warn(\n \"Свойство popout устарело и будет удалено в 5.0.0. Используйте одноименное свойство у SplitLayout.\"\n );\n modal &&\n warn(\n \"Свойство modal устарело и будет удалено в 5.0.0. Используйте одноименное свойство у SplitLayout.\"\n );\n }\n\n const scrolls = React.useRef(\n scrollsCache[getNavId({ nav, id: restProps.id }) as string] || {}\n );\n const afterTransition = React.useRef(noop);\n\n React.useEffect(() => () => {\n const id = getNavId({ nav, id: restProps.id });\n if (id) {\n scrollsCache[id] = scrolls.current;\n }\n });\n\n const panelNodes = React.useRef<{ [id: string]: HTMLDivElement | null }>({});\n\n const { window, document } = useDOM();\n const scroll = useScroll();\n const configProvider = useConfigProvider();\n const splitCol = useSplitCol();\n const platform = usePlatform();\n\n const [animated, setAnimated] = React.useState(false);\n\n const [visiblePanels, setVisiblePanels] = React.useState([activePanelProp]);\n const [activePanel, setActivePanel] = React.useState<string | null>(\n activePanelProp\n );\n const [isBack, setIsBack] = React.useState<boolean | undefined>(undefined);\n const [prevPanel, setPrevPanel] = React.useState<string | null>(null);\n const [nextPanel, setNextPanel] = React.useState<string | null>(null);\n\n const [swipingBack, setSwipingBack] = React.useState<boolean>(false);\n const [swipeBackStartX, setSwipeBackStartX] = React.useState<number>(0);\n const [swipeBackShift, setSwipeBackShift] = React.useState<number>(0);\n const [swipeBackNextPanel, setSwipeBackNextPanel] = React.useState<\n string | null\n >(null);\n const [swipeBackPrevPanel, setSwipeBackPrevPanel] = React.useState<\n string | null\n >(null);\n const [swipeBackResult, setSwipeBackResult] =\n React.useState<SwipeBackResults | null>(null);\n\n const [browserSwipe, setBrowserSwipe] = React.useState(false);\n\n const prevActivePanel = usePrevious(activePanelProp);\n const prevSwipingBack = usePrevious(swipingBack);\n const prevBrowserSwipe = usePrevious(browserSwipe);\n const prevSwipeBackResult = usePrevious(swipeBackResult);\n const prevSwipeBackPrevPanel = usePrevious(swipeBackPrevPanel);\n const prevOnTransition = usePrevious(onTransition);\n\n const panels = (\n React.Children.toArray(children) as React.ReactElement[]\n ).filter((panel: React.ReactElement) => {\n const panelId = getNavId(panel.props, warn);\n\n return (\n (panelId !== undefined && visiblePanels.includes(panelId)) ||\n panelId === swipeBackPrevPanel ||\n panelId === swipeBackNextPanel\n );\n });\n\n const disableAnimation =\n configProvider?.transitionMotionEnabled === false || !splitCol?.animate;\n\n const pickPanel = (id: string | null) => {\n if (id === null) {\n return null;\n }\n return panelNodes.current[id];\n };\n\n const flushTransition = React.useCallback(\n (prevPanel: string, isBackTransition: boolean) => {\n if (isBackTransition) {\n scrolls.current[prevPanel] = 0;\n }\n setPrevPanel(null);\n setNextPanel(null);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n setAnimated(false);\n setIsBack(undefined);\n\n afterTransition.current = () => {\n scroll?.scrollTo(\n 0,\n isBackTransition ? scrolls.current[activePanelProp] : 0\n );\n onTransition &&\n onTransition({\n isBack: isBackTransition,\n from: prevPanel,\n to: activePanelProp,\n });\n };\n },\n [activePanelProp, onTransition, scroll]\n );\n\n useIsomorphicLayoutEffect(() => {\n afterTransition.current();\n afterTransition.current = noop;\n }, [afterTransition.current]);\n\n const transitionEndHandler = React.useCallback(\n (e?: React.AnimationEvent): void => {\n if (\n (!e ||\n [\n \"vkui-animation-ios-next-forward\",\n \"vkui-animation-ios-prev-back\",\n \"vkui-animation-view-next-forward\",\n \"vkui-animation-view-prev-back\",\n ].includes(e.animationName)) &&\n prevPanel !== null\n ) {\n flushTransition(prevPanel, Boolean(isBack));\n }\n },\n [flushTransition, isBack, prevPanel]\n );\n\n const { waitTransitionFinish } = useWaitTransitionFinish();\n const animationFinishTimeout = useTimeout(\n transitionEndHandler,\n platform === IOS ? 600 : 300\n );\n\n const onSwipeBackSuccess = React.useCallback(() => {\n onSwipeBack && onSwipeBack();\n }, [onSwipeBack]);\n\n const onSwipeBackCancel = React.useCallback(() => {\n onSwipeBackCancelProp && onSwipeBackCancelProp();\n setSwipeBackPrevPanel(null);\n setSwipeBackNextPanel(null);\n setSwipingBack(false);\n setSwipeBackResult(null);\n setSwipeBackStartX(0);\n setSwipeBackShift(0);\n }, [onSwipeBackCancelProp]);\n\n const swipingBackTransitionEndHandler = React.useCallback(\n (e?: TransitionEvent): void => {\n // indexOf because of vendor prefixes in old browsers\n if (\n !e ||\n (e?.propertyName.includes(\"transform\") &&\n e?.target === pickPanel(swipeBackNextPanel))\n ) {\n switch (swipeBackResult) {\n case SwipeBackResults.fail:\n onSwipeBackCancel();\n break;\n case SwipeBackResults.success:\n onSwipeBackSuccess();\n }\n }\n },\n [onSwipeBackCancel, onSwipeBackSuccess, swipeBackNextPanel, swipeBackResult]\n );\n\n const onMoveX = (e: TouchEvent): void => {\n if (swipeBackExcluded(e)) {\n return;\n }\n\n if (\n platform === IOS &&\n !configProvider?.isWebView &&\n (e.startX <= 70 || e.startX >= window!.innerWidth - 70) &&\n !browserSwipe\n ) {\n setBrowserSwipe(true);\n }\n\n if (platform === IOS && configProvider?.isWebView && onSwipeBack) {\n if ((animated && e.startX <= 70) || !window) {\n return;\n }\n\n if (e.startX <= 70 && !swipingBack && history && history.length > 1) {\n if (activePanel !== null) {\n scrolls.current[activePanel] = scroll?.getScroll().y;\n }\n\n setSwipingBack(true);\n setSwipeBackStartX(e.startX);\n setSwipeBackPrevPanel(activePanel);\n setSwipeBackNextPanel(history.slice(-2)[0]);\n }\n if (swipingBack) {\n let swipeBackShift = 0;\n if (e.shiftX < 0) {\n swipeBackShift = 0;\n } else if (e.shiftX > window.innerWidth - swipeBackStartX) {\n swipeBackShift = window?.innerWidth;\n } else {\n swipeBackShift = e.shiftX;\n }\n setSwipeBackShift(swipeBackShift);\n }\n }\n };\n\n const onEnd = React.useCallback(\n (e: TouchEvent): void => {\n if (swipingBack && window) {\n const speed = (swipeBackShift / e.duration) * 1000;\n if (swipeBackShift === 0) {\n onSwipeBackCancel();\n } else if (swipeBackShift >= (window?.innerWidth ?? 0)) {\n onSwipeBackSuccess();\n } else if (\n speed > 250 ||\n swipeBackStartX + swipeBackShift > window.innerWidth / 2\n ) {\n setSwipeBackResult(SwipeBackResults.success);\n } else {\n setSwipeBackResult(SwipeBackResults.fail);\n }\n }\n },\n [\n onSwipeBackCancel,\n onSwipeBackSuccess,\n swipeBackShift,\n swipeBackStartX,\n swipingBack,\n window,\n ]\n );\n\n const calcPanelSwipeStyles = (\n panelId: string | undefined\n ): React.CSSProperties => {\n if (!canUseDOM || !window) {\n return {};\n }\n\n const isPrev = panelId === swipeBackPrevPanel;\n const isNext = panelId === swipeBackNextPanel;\n\n if ((!isPrev && !isNext) || swipeBackResult) {\n return {};\n }\n\n let prevPanelTranslate = `${swipeBackShift}px`;\n let nextPanelTranslate = `${\n -50 + (swipeBackShift * 100) / window.innerWidth / 2\n }%`;\n let prevPanelShadow =\n (0.3 * (window.innerWidth - swipeBackShift)) / window.innerWidth;\n\n if (swipeBackResult) {\n return isPrev\n ? { boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})` }\n : {};\n }\n\n if (isNext) {\n return {\n transform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n WebkitTransform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n };\n }\n if (isPrev) {\n return {\n transform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n WebkitTransform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})`,\n };\n }\n\n return {};\n };\n\n React.useEffect(() => {\n popout && blurActiveElement(document);\n }, [document, popout]);\n\n React.useEffect(() => {\n // Нужен переход\n if (\n prevActivePanel &&\n prevActivePanel !== activePanelProp &&\n !prevSwipingBack &&\n !prevBrowserSwipe\n ) {\n const firstLayerId = (\n React.Children.toArray(children) as React.ReactElement[]\n )\n .map((panel) => getNavId(panel.props, warn))\n .find((id) => id === prevActivePanel || id === activePanelProp);\n\n const isBackTransition = firstLayerId === activePanelProp;\n scrolls.current[prevActivePanel] = scroll?.getScroll().y;\n\n if (disableAnimation) {\n flushTransition(prevActivePanel, isBackTransition);\n } else {\n blurActiveElement(document);\n\n setVisiblePanels([prevActivePanel, activePanelProp]);\n setPrevPanel(prevActivePanel);\n setNextPanel(activePanelProp);\n setActivePanel(null);\n setAnimated(true);\n setIsBack(isBackTransition);\n\n // Фолбек анимации перехода\n if (!animationEvent.supported) {\n animationFinishTimeout.set();\n }\n }\n }\n\n // Закончилась анимация свайпа назад\n if (\n prevActivePanel &&\n prevActivePanel !== activePanelProp &&\n prevSwipingBack\n ) {\n const nextPanel = activePanelProp;\n const prevPanel = prevActivePanel;\n if (prevSwipeBackPrevPanel) {\n scrolls.current[prevSwipeBackPrevPanel] = 0;\n }\n\n setSwipeBackPrevPanel(null);\n setSwipeBackNextPanel(null);\n setSwipingBack(false);\n setSwipeBackResult(null);\n setSwipeBackStartX(0);\n setSwipeBackShift(0);\n setActivePanel(nextPanel);\n setVisiblePanels([nextPanel]);\n\n afterTransition.current = () => {\n if (nextPanel !== null) {\n scroll?.scrollTo(0, scrolls.current[nextPanel]);\n }\n prevOnTransition &&\n prevOnTransition({\n isBack: true,\n from: prevPanel,\n to: nextPanel,\n });\n };\n }\n\n // Начался свайп назад\n if (!prevSwipingBack && swipingBack) {\n onSwipeBackStart && onSwipeBackStart();\n }\n\n // Началась анимация завершения свайпа назад.\n if (!prevSwipeBackResult && swipeBackResult) {\n waitTransitionFinish(\n pickPanel(swipeBackNextPanel),\n swipingBackTransitionEndHandler,\n platform === IOS ? 600 : 300\n );\n }\n\n // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)\n if (\n prevSwipeBackResult === SwipeBackResults.fail &&\n !swipeBackResult &&\n activePanel !== null\n ) {\n scroll?.scrollTo(0, scrolls.current[activePanel]);\n }\n\n // Закончился Safari свайп\n if (prevActivePanel !== activePanelProp && browserSwipe) {\n setBrowserSwipe(false);\n setNextPanel(null);\n setPrevPanel(null);\n setAnimated(false);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n }\n }, [\n activePanelProp,\n activePanel,\n animationFinishTimeout,\n browserSwipe,\n children,\n disableAnimation,\n document,\n flushTransition,\n onSwipeBackStart,\n panels,\n platform,\n prevActivePanel,\n prevBrowserSwipe,\n prevOnTransition,\n prevSwipeBackPrevPanel,\n prevSwipeBackResult,\n prevSwipingBack,\n scroll,\n swipeBackNextPanel,\n swipeBackResult,\n swipingBack,\n swipingBackTransitionEndHandler,\n waitTransitionFinish,\n ]);\n\n return (\n <Touch\n Component=\"section\"\n {...restProps}\n vkuiClass={classNames(\n \"View\",\n platform === IOS && \"View--ios\",\n !disableAnimation && animated && \"View--animated\",\n !disableAnimation && swipingBack && \"View--swiping-back\",\n disableAnimation && \"View--no-motion\"\n )}\n onMoveX={onMoveX}\n onEnd={onEnd}\n >\n <div vkuiClass=\"View__panels\">\n {panels.map((panel: React.ReactElement) => {\n const panelId = getNavId(panel.props, warn);\n const isPrev =\n panelId === prevPanel || panelId === swipeBackPrevPanel;\n const isTransitionTarget =\n animated && panelId === (isBack ? prevPanel : nextPanel);\n const compensateScroll =\n isPrev ||\n panelId === swipeBackNextPanel ||\n (panelId === nextPanel && isBack);\n\n return (\n <div\n vkuiClass={classNames(\n \"View__panel\",\n panelId === activePanel && \"View__panel--active\",\n panelId === prevPanel && \"View__panel--prev\",\n panelId === nextPanel && \"View__panel--next\",\n panelId === swipeBackPrevPanel &&\n \"View__panel--swipe-back-prev\",\n panelId === swipeBackNextPanel &&\n \"View__panel--swipe-back-next\",\n swipeBackResult === SwipeBackResults.success &&\n \"View__panel--swipe-back-success\",\n swipeBackResult === SwipeBackResults.fail &&\n \"View__panel--swipe-back-failed\"\n )}\n onAnimationEnd={\n isTransitionTarget ? transitionEndHandler : undefined\n }\n ref={(el) =>\n panelId !== undefined && (panelNodes.current[panelId] = el)\n }\n style={calcPanelSwipeStyles(panelId)}\n key={panelId}\n >\n <div\n vkuiClass=\"View__panel-in\"\n style={{\n marginTop: compensateScroll\n ? -(scrolls.current[panelId as string] ?? 0)\n : undefined,\n }}\n >\n <NavTransitionProvider\n entering={\n panelId === nextPanel || panelId === swipeBackNextPanel\n }\n >\n {panel}\n </NavTransitionProvider>\n </div>\n </div>\n );\n })}\n </div>\n <AppRootPortal>\n {!!popout && <div vkuiClass=\"View__popout\">{popout}</div>}\n {!!modal && <div vkuiClass=\"View__modal\">{modal}</div>}\n </AppRootPortal>\n </Touch>\n );\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"View.js","names":["React","classNames","animationEvent","IOS","Touch","useConfigProvider","useSplitCol","AppRootPortal","canUseDOM","useDOM","blurActiveElement","useScroll","NavTransitionProvider","getNavId","warnOnce","usePlatform","swipeBackExcluded","useWaitTransitionFinish","useTimeout","usePrevious","useIsomorphicLayoutEffect","noop","SwipeBackResults","scrollsCache","warn","View","popout","modal","activePanelProp","activePanel","history","nav","onTransition","onSwipeBack","onSwipeBackStart","onSwipeBackCancelProp","onSwipeBackCancel","children","restProps","process","env","NODE_ENV","scrolls","useRef","id","afterTransition","useEffect","current","panelNodes","window","document","scroll","configProvider","splitCol","platform","useState","animated","setAnimated","visiblePanels","setVisiblePanels","setActivePanel","undefined","isBack","setIsBack","prevPanel","setPrevPanel","nextPanel","setNextPanel","swipingBack","setSwipingBack","swipeBackStartX","setSwipeBackStartX","swipeBackShift","setSwipeBackShift","swipeBackNextPanel","setSwipeBackNextPanel","swipeBackPrevPanel","setSwipeBackPrevPanel","swipeBackResult","setSwipeBackResult","browserSwipe","setBrowserSwipe","prevActivePanel","prevSwipingBack","prevBrowserSwipe","prevSwipeBackResult","prevSwipeBackPrevPanel","prevOnTransition","panels","Children","toArray","filter","panel","panelId","props","includes","disableAnimation","transitionMotionEnabled","animate","pickPanel","flushTransition","useCallback","isBackTransition","scrollTo","from","to","transitionEndHandler","e","animationName","Boolean","waitTransitionFinish","animationFinishTimeout","onSwipeBackSuccess","swipingBackTransitionEndHandler","propertyName","target","fail","success","onMoveX","isWebView","startX","innerWidth","length","getScroll","y","slice","shiftX","onEnd","speed","duration","calcPanelSwipeStyles","isPrev","isNext","prevPanelTranslate","nextPanelTranslate","prevPanelShadow","boxShadow","transform","WebkitTransform","firstLayerId","map","find","supported","set","isTransitionTarget","compensateScroll","el","marginTop"],"sources":["../../../../src/components/View/View.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { animationEvent } from \"../../lib/supportEvents\";\nimport { IOS } from \"../../lib/platform\";\nimport { Touch, TouchEvent } from \"../Touch/Touch\";\nimport { useConfigProvider } from \"../ConfigProvider/ConfigProviderContext\";\nimport { useSplitCol } from \"../SplitCol/SplitCol\";\nimport { AppRootPortal } from \"../AppRoot/AppRootPortal\";\nimport { canUseDOM, useDOM, blurActiveElement } from \"../../lib/dom\";\nimport { useScroll } from \"../AppRoot/ScrollContext\";\nimport { NavTransitionProvider } from \"../NavTransitionContext/NavTransitionContext\";\nimport { getNavId, NavIdProps } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { swipeBackExcluded } from \"./utils\";\nimport { useWaitTransitionFinish } from \"../../hooks/useWaitTransitionFinish\";\nimport { useTimeout } from \"../../hooks/useTimeout\";\nimport { usePrevious } from \"../../hooks/usePrevious\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { noop } from \"../../lib/utils\";\nimport \"./View.css\";\n\nenum SwipeBackResults {\n fail = 1,\n success,\n}\n\ninterface Scrolls {\n [index: string]: number | undefined;\n}\n\ninterface ViewsScrolls {\n [index: string]: Scrolls;\n}\n\nexport let scrollsCache: ViewsScrolls = {};\n\nexport interface ViewProps\n extends React.HTMLAttributes<HTMLElement>,\n NavIdProps {\n activePanel: string;\n /**\n * @deprecated будет удалено в 5.0.0. Используйте одноименное свойство у `SplitLayout`.\n *\n * Свойство для отрисовки `Alert`, `ActionSheet` и `ScreenSpinner`.\n */\n popout?: React.ReactNode;\n /**\n * @deprecated будет удалено в 5.0.0. Используйте одноименное свойство у `SplitLayout`.\n *\n * Свойство для отрисовки `ModalRoot`.\n */\n modal?: React.ReactNode;\n onTransition?(params: { isBack: boolean; from: string; to: string }): void;\n /**\n * callback свайпа назад\n */\n onSwipeBack?(): void;\n /**\n * callback начала анимации свайпа назад.\n */\n onSwipeBackStart?(): void;\n /**\n * callback завершения анимации отмененного пользователем свайпа\n */\n onSwipeBackCancel?(): void;\n history?: string[];\n}\n\nexport interface ViewState {\n animated: boolean;\n\n visiblePanels: string[];\n activePanel: string | null;\n isBack: boolean | undefined;\n prevPanel: string | null;\n nextPanel: string | null;\n\n swipingBack: boolean;\n swipeBackStartX: number;\n swipeBackShift: number;\n swipeBackNextPanel: string | null;\n swipeBackPrevPanel: string | null;\n swipeBackResult: SwipeBackResults | null;\n\n browserSwipe: boolean;\n}\n\nconst warn = warnOnce(\"View\");\n\n/**\n * @see https://vkcom.github.io/VKUI/#/View\n */\nexport const View = ({\n popout,\n modal,\n activePanel: activePanelProp,\n history,\n nav,\n onTransition,\n onSwipeBack,\n onSwipeBackStart,\n onSwipeBackCancel: onSwipeBackCancelProp,\n children,\n\n ...restProps\n}: ViewProps) => {\n if (process.env.NODE_ENV === \"development\") {\n popout &&\n warn(\n \"Свойство popout устарело и будет удалено в 5.0.0. Используйте одноименное свойство у SplitLayout.\"\n );\n modal &&\n warn(\n \"Свойство modal устарело и будет удалено в 5.0.0. Используйте одноименное свойство у SplitLayout.\"\n );\n }\n\n const scrolls = React.useRef(\n scrollsCache[getNavId({ nav, id: restProps.id }) as string] || {}\n );\n const afterTransition = React.useRef(noop);\n\n React.useEffect(() => () => {\n const id = getNavId({ nav, id: restProps.id });\n if (id) {\n scrollsCache[id] = scrolls.current;\n }\n });\n\n const panelNodes = React.useRef<{ [id: string]: HTMLDivElement | null }>({});\n\n const { window, document } = useDOM();\n const scroll = useScroll();\n const configProvider = useConfigProvider();\n const splitCol = useSplitCol();\n const platform = usePlatform();\n\n const [animated, setAnimated] = React.useState(false);\n\n const [visiblePanels, setVisiblePanels] = React.useState([activePanelProp]);\n const [activePanel, setActivePanel] = React.useState<string | null>(\n activePanelProp\n );\n const [isBack, setIsBack] = React.useState<boolean | undefined>(undefined);\n const [prevPanel, setPrevPanel] = React.useState<string | null>(null);\n const [nextPanel, setNextPanel] = React.useState<string | null>(null);\n\n const [swipingBack, setSwipingBack] = React.useState<boolean>(false);\n const [swipeBackStartX, setSwipeBackStartX] = React.useState<number>(0);\n const [swipeBackShift, setSwipeBackShift] = React.useState<number>(0);\n const [swipeBackNextPanel, setSwipeBackNextPanel] = React.useState<\n string | null\n >(null);\n const [swipeBackPrevPanel, setSwipeBackPrevPanel] = React.useState<\n string | null\n >(null);\n const [swipeBackResult, setSwipeBackResult] =\n React.useState<SwipeBackResults | null>(null);\n\n const [browserSwipe, setBrowserSwipe] = React.useState(false);\n\n const prevActivePanel = usePrevious(activePanelProp);\n const prevSwipingBack = usePrevious(swipingBack);\n const prevBrowserSwipe = usePrevious(browserSwipe);\n const prevSwipeBackResult = usePrevious(swipeBackResult);\n const prevSwipeBackPrevPanel = usePrevious(swipeBackPrevPanel);\n const prevOnTransition = usePrevious(onTransition);\n\n const panels = (\n React.Children.toArray(children) as React.ReactElement[]\n ).filter((panel: React.ReactElement) => {\n const panelId = getNavId(panel.props, warn);\n\n return (\n (panelId !== undefined && visiblePanels.includes(panelId)) ||\n panelId === swipeBackPrevPanel ||\n panelId === swipeBackNextPanel\n );\n });\n\n const disableAnimation =\n configProvider?.transitionMotionEnabled === false || !splitCol?.animate;\n\n const pickPanel = (id: string | null) => {\n if (id === null) {\n return null;\n }\n return panelNodes.current[id];\n };\n\n const flushTransition = React.useCallback(\n (prevPanel: string, isBackTransition: boolean) => {\n if (isBackTransition) {\n scrolls.current[prevPanel] = 0;\n }\n setPrevPanel(null);\n setNextPanel(null);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n setAnimated(false);\n setIsBack(undefined);\n\n afterTransition.current = () => {\n scroll?.scrollTo(\n 0,\n isBackTransition ? scrolls.current[activePanelProp] : 0\n );\n onTransition &&\n onTransition({\n isBack: isBackTransition,\n from: prevPanel,\n to: activePanelProp,\n });\n };\n },\n [activePanelProp, onTransition, scroll]\n );\n\n useIsomorphicLayoutEffect(() => {\n afterTransition.current();\n afterTransition.current = noop;\n }, [afterTransition.current]);\n\n const transitionEndHandler = React.useCallback(\n (e?: React.AnimationEvent): void => {\n if (\n (!e ||\n [\n \"vkui-animation-ios-next-forward\",\n \"vkui-animation-ios-prev-back\",\n \"vkui-animation-view-next-forward\",\n \"vkui-animation-view-prev-back\",\n ].includes(e.animationName)) &&\n prevPanel !== null\n ) {\n flushTransition(prevPanel, Boolean(isBack));\n }\n },\n [flushTransition, isBack, prevPanel]\n );\n\n const { waitTransitionFinish } = useWaitTransitionFinish();\n const animationFinishTimeout = useTimeout(\n transitionEndHandler,\n platform === IOS ? 600 : 300\n );\n\n const onSwipeBackSuccess = React.useCallback(() => {\n onSwipeBack && onSwipeBack();\n }, [onSwipeBack]);\n\n const onSwipeBackCancel = React.useCallback(() => {\n onSwipeBackCancelProp && onSwipeBackCancelProp();\n setSwipeBackPrevPanel(null);\n setSwipeBackNextPanel(null);\n setSwipingBack(false);\n setSwipeBackResult(null);\n setSwipeBackStartX(0);\n setSwipeBackShift(0);\n }, [onSwipeBackCancelProp]);\n\n const swipingBackTransitionEndHandler = React.useCallback(\n (e?: TransitionEvent): void => {\n // indexOf because of vendor prefixes in old browsers\n if (\n !e ||\n (e?.propertyName.includes(\"transform\") &&\n e?.target === pickPanel(swipeBackNextPanel))\n ) {\n switch (swipeBackResult) {\n case SwipeBackResults.fail:\n onSwipeBackCancel();\n break;\n case SwipeBackResults.success:\n onSwipeBackSuccess();\n }\n }\n },\n [onSwipeBackCancel, onSwipeBackSuccess, swipeBackNextPanel, swipeBackResult]\n );\n\n const onMoveX = (e: TouchEvent): void => {\n if (swipeBackExcluded(e)) {\n return;\n }\n\n if (\n platform === IOS &&\n !configProvider?.isWebView &&\n (e.startX <= 70 || e.startX >= window!.innerWidth - 70) &&\n !browserSwipe\n ) {\n setBrowserSwipe(true);\n }\n\n if (platform === IOS && configProvider?.isWebView && onSwipeBack) {\n if ((animated && e.startX <= 70) || !window) {\n return;\n }\n\n if (e.startX <= 70 && !swipingBack && history && history.length > 1) {\n if (activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n blurActiveElement(document);\n scrolls.current[activePanel] = scroll?.getScroll().y;\n }\n\n setSwipingBack(true);\n setSwipeBackStartX(e.startX);\n setSwipeBackPrevPanel(activePanel);\n setSwipeBackNextPanel(history.slice(-2)[0]);\n }\n if (swipingBack) {\n let swipeBackShift = 0;\n if (e.shiftX < 0) {\n swipeBackShift = 0;\n } else if (e.shiftX > window.innerWidth - swipeBackStartX) {\n swipeBackShift = window?.innerWidth;\n } else {\n swipeBackShift = e.shiftX;\n }\n setSwipeBackShift(swipeBackShift);\n }\n }\n };\n\n const onEnd = React.useCallback(\n (e: TouchEvent): void => {\n if (swipingBack && window) {\n const speed = (swipeBackShift / e.duration) * 1000;\n if (swipeBackShift === 0) {\n onSwipeBackCancel();\n } else if (swipeBackShift >= (window?.innerWidth ?? 0)) {\n onSwipeBackSuccess();\n } else if (\n speed > 250 ||\n swipeBackStartX + swipeBackShift > window.innerWidth / 2\n ) {\n setSwipeBackResult(SwipeBackResults.success);\n } else {\n setSwipeBackResult(SwipeBackResults.fail);\n }\n }\n },\n [\n onSwipeBackCancel,\n onSwipeBackSuccess,\n swipeBackShift,\n swipeBackStartX,\n swipingBack,\n window,\n ]\n );\n\n const calcPanelSwipeStyles = (\n panelId: string | undefined\n ): React.CSSProperties => {\n if (!canUseDOM || !window) {\n return {};\n }\n\n const isPrev = panelId === swipeBackPrevPanel;\n const isNext = panelId === swipeBackNextPanel;\n\n if ((!isPrev && !isNext) || swipeBackResult) {\n return {};\n }\n\n let prevPanelTranslate = `${swipeBackShift}px`;\n let nextPanelTranslate = `${\n -50 + (swipeBackShift * 100) / window.innerWidth / 2\n }%`;\n let prevPanelShadow =\n (0.3 * (window.innerWidth - swipeBackShift)) / window.innerWidth;\n\n if (swipeBackResult) {\n return isPrev\n ? { boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})` }\n : {};\n }\n\n if (isNext) {\n return {\n transform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n WebkitTransform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n };\n }\n if (isPrev) {\n return {\n transform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n WebkitTransform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})`,\n };\n }\n\n return {};\n };\n\n React.useEffect(() => {\n popout && blurActiveElement(document);\n }, [document, popout]);\n\n React.useEffect(() => {\n // Нужен переход\n if (\n prevActivePanel &&\n prevActivePanel !== activePanelProp &&\n !prevSwipingBack &&\n !prevBrowserSwipe\n ) {\n const firstLayerId = (\n React.Children.toArray(children) as React.ReactElement[]\n )\n .map((panel) => getNavId(panel.props, warn))\n .find((id) => id === prevActivePanel || id === activePanelProp);\n\n const isBackTransition = firstLayerId === activePanelProp;\n scrolls.current[prevActivePanel] = scroll?.getScroll().y;\n\n if (disableAnimation) {\n flushTransition(prevActivePanel, isBackTransition);\n } else {\n blurActiveElement(document);\n\n setVisiblePanels([prevActivePanel, activePanelProp]);\n setPrevPanel(prevActivePanel);\n setNextPanel(activePanelProp);\n setActivePanel(null);\n setAnimated(true);\n setIsBack(isBackTransition);\n\n // Фолбек анимации перехода\n if (!animationEvent.supported) {\n animationFinishTimeout.set();\n }\n }\n }\n\n // Закончилась анимация свайпа назад\n if (\n prevActivePanel &&\n prevActivePanel !== activePanelProp &&\n prevSwipingBack\n ) {\n const nextPanel = activePanelProp;\n const prevPanel = prevActivePanel;\n if (prevSwipeBackPrevPanel) {\n scrolls.current[prevSwipeBackPrevPanel] = 0;\n }\n\n setSwipeBackPrevPanel(null);\n setSwipeBackNextPanel(null);\n setSwipingBack(false);\n setSwipeBackResult(null);\n setSwipeBackStartX(0);\n setSwipeBackShift(0);\n setActivePanel(nextPanel);\n setVisiblePanels([nextPanel]);\n\n afterTransition.current = () => {\n if (nextPanel !== null) {\n scroll?.scrollTo(0, scrolls.current[nextPanel]);\n }\n prevOnTransition &&\n prevOnTransition({\n isBack: true,\n from: prevPanel,\n to: nextPanel,\n });\n };\n }\n\n // Начался свайп назад\n if (!prevSwipingBack && swipingBack) {\n onSwipeBackStart && onSwipeBackStart();\n }\n\n // Началась анимация завершения свайпа назад.\n if (!prevSwipeBackResult && swipeBackResult) {\n waitTransitionFinish(\n pickPanel(swipeBackNextPanel),\n swipingBackTransitionEndHandler,\n platform === IOS ? 600 : 300\n );\n }\n\n // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)\n if (\n prevSwipeBackResult === SwipeBackResults.fail &&\n !swipeBackResult &&\n activePanel !== null\n ) {\n scroll?.scrollTo(0, scrolls.current[activePanel]);\n }\n\n // Закончился Safari свайп\n if (prevActivePanel !== activePanelProp && browserSwipe) {\n setBrowserSwipe(false);\n setNextPanel(null);\n setPrevPanel(null);\n setAnimated(false);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n }\n }, [\n activePanelProp,\n activePanel,\n animationFinishTimeout,\n browserSwipe,\n children,\n disableAnimation,\n document,\n flushTransition,\n onSwipeBackStart,\n panels,\n platform,\n prevActivePanel,\n prevBrowserSwipe,\n prevOnTransition,\n prevSwipeBackPrevPanel,\n prevSwipeBackResult,\n prevSwipingBack,\n scroll,\n swipeBackNextPanel,\n swipeBackResult,\n swipingBack,\n swipingBackTransitionEndHandler,\n waitTransitionFinish,\n ]);\n\n return (\n <Touch\n Component=\"section\"\n {...restProps}\n vkuiClass={classNames(\n \"View\",\n platform === IOS && \"View--ios\",\n !disableAnimation && animated && \"View--animated\",\n !disableAnimation && swipingBack && \"View--swiping-back\",\n disableAnimation && \"View--no-motion\"\n )}\n onMoveX={onMoveX}\n onEnd={onEnd}\n >\n <div vkuiClass=\"View__panels\">\n {panels.map((panel: React.ReactElement) => {\n const panelId = getNavId(panel.props, warn);\n const isPrev =\n panelId === prevPanel || panelId === swipeBackPrevPanel;\n const isTransitionTarget =\n animated && panelId === (isBack ? prevPanel : nextPanel);\n const compensateScroll =\n isPrev ||\n panelId === swipeBackNextPanel ||\n (panelId === nextPanel && isBack);\n\n return (\n <div\n vkuiClass={classNames(\n \"View__panel\",\n panelId === activePanel && \"View__panel--active\",\n panelId === prevPanel && \"View__panel--prev\",\n panelId === nextPanel && \"View__panel--next\",\n panelId === swipeBackPrevPanel &&\n \"View__panel--swipe-back-prev\",\n panelId === swipeBackNextPanel &&\n \"View__panel--swipe-back-next\",\n swipeBackResult === SwipeBackResults.success &&\n \"View__panel--swipe-back-success\",\n swipeBackResult === SwipeBackResults.fail &&\n \"View__panel--swipe-back-failed\"\n )}\n onAnimationEnd={\n isTransitionTarget ? transitionEndHandler : undefined\n }\n ref={(el) =>\n panelId !== undefined && (panelNodes.current[panelId] = el)\n }\n style={calcPanelSwipeStyles(panelId)}\n key={panelId}\n >\n <div\n vkuiClass=\"View__panel-in\"\n style={{\n marginTop: compensateScroll\n ? -(scrolls.current[panelId as string] ?? 0)\n : undefined,\n }}\n >\n <NavTransitionProvider\n entering={\n panelId === nextPanel || panelId === swipeBackNextPanel\n }\n >\n {panel}\n </NavTransitionProvider>\n </div>\n </div>\n );\n })}\n </div>\n <AppRootPortal>\n {!!popout && <div vkuiClass=\"View__popout\">{popout}</div>}\n {!!modal && <div vkuiClass=\"View__modal\">{modal}</div>}\n </AppRootPortal>\n </Touch>\n );\n};\n"],"mappings":"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"}
@@ -69,11 +69,8 @@ export var WriteBar = function WriteBar(_ref) {
69
69
  vkuiClass: classNames("WriteBar", platform === IOS && "WriteBar--ios", shadow && "WriteBar--shadow"),
70
70
  className: className,
71
71
  style: style
72
- }, createScopedElement("form", {
73
- vkuiClass: "WriteBar__form",
74
- onSubmit: function onSubmit(e) {
75
- return e.preventDefault();
76
- }
72
+ }, createScopedElement("div", {
73
+ vkuiClass: "WriteBar__form"
77
74
  }, hasReactNode(before) && createScopedElement("div", {
78
75
  vkuiClass: "WriteBar__before"
79
76
  }, before), createScopedElement("div", {
@@ -1 +1 @@
1
- {"version":3,"file":"WriteBar.js","names":["React","Headline","usePlatform","useExternRef","hasReactNode","isFunction","classNames","IOS","WriteBar","className","style","before","inlineAfter","after","value","onChange","getRootRef","getRef","onHeightChange","shadow","restProps","platform","isControlledOutside","textareaRef","currentScrollHeight","useRef","resize","useCallback","textareaEl","current","offsetParent","height","scrollHeight","onTextareaChange","event","useEffect","e","preventDefault"],"sources":["../../../../src/components/WriteBar/WriteBar.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { Headline } from \"../Typography/Headline/Headline\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useExternRef } from \"../../hooks/useExternRef\";\nimport { hasReactNode, isFunction } from \"../../lib/utils\";\nimport { classNames } from \"../../lib/classNames\";\nimport { IOS } from \"../../lib/platform\";\nimport { HasRef, HasRootRef } from \"../../types\";\nimport \"./WriteBar.css\";\n\nexport interface WriteBarProps\n extends React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n HasRootRef<HTMLDivElement>,\n HasRef<HTMLTextAreaElement> {\n /**\n * Содержимое, отображаемое слева от поля ввода.\n */\n before?: React.ReactNode;\n /**\n * Содержимое, отображаемое поверх поля ввода (актуально для iOS)\n */\n inlineAfter?: React.ReactNode;\n /**\n * Содержимое, отображаемое справа от поля ввода\n */\n after?: React.ReactNode;\n /**\n * Вызывается при смене высоты поля ввода\n */\n onHeightChange?: VoidFunction;\n /**\n * Добавляет тень вокруг поля ввода\n */\n shadow?: boolean;\n\n children?: never;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/WriteBar\n */\nexport const WriteBar = ({\n className,\n style,\n before,\n inlineAfter,\n after,\n value,\n onChange,\n getRootRef,\n getRef,\n onHeightChange,\n shadow = false,\n ...restProps\n}: WriteBarProps) => {\n const platform = usePlatform();\n\n const isControlledOutside = value != null;\n\n const textareaRef = useExternRef(getRef);\n const currentScrollHeight = React.useRef<number>();\n\n const resize = React.useCallback(() => {\n const textareaEl = textareaRef.current;\n if (!textareaEl) {\n return;\n }\n\n if (textareaEl.offsetParent) {\n textareaEl.style.height = \"\";\n textareaEl.style.height = `${textareaEl.scrollHeight}px`;\n\n if (\n textareaEl.scrollHeight !== currentScrollHeight.current &&\n onHeightChange\n ) {\n onHeightChange();\n currentScrollHeight.current = textareaEl.scrollHeight;\n }\n }\n }, [onHeightChange, textareaRef]);\n\n const onTextareaChange: React.ChangeEventHandler<HTMLTextAreaElement> = (\n event\n ) => {\n if (isFunction(onChange)) {\n onChange(event);\n }\n\n if (!isControlledOutside) {\n resize();\n }\n };\n\n React.useEffect(() => {\n resize();\n }, [resize, value]);\n\n return (\n <div\n ref={getRootRef}\n vkuiClass={classNames(\n \"WriteBar\",\n platform === IOS && \"WriteBar--ios\",\n shadow && \"WriteBar--shadow\"\n )}\n className={className}\n style={style}\n >\n <form vkuiClass=\"WriteBar__form\" onSubmit={(e) => e.preventDefault()}>\n {hasReactNode(before) && (\n <div vkuiClass=\"WriteBar__before\">{before}</div>\n )}\n\n <div vkuiClass=\"WriteBar__formIn\">\n <Headline\n {...restProps}\n Component=\"textarea\"\n vkuiClass=\"WriteBar__textarea\"\n onChange={onTextareaChange}\n getRootRef={textareaRef}\n value={value}\n />\n {hasReactNode(inlineAfter) && (\n <div vkuiClass=\"WriteBar__inlineAfter\">{inlineAfter}</div>\n )}\n </div>\n\n {hasReactNode(after) && <div vkuiClass=\"WriteBar__after\">{after}</div>}\n </form>\n </div>\n );\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"WriteBar.js","names":["React","Headline","usePlatform","useExternRef","hasReactNode","isFunction","classNames","IOS","WriteBar","className","style","before","inlineAfter","after","value","onChange","getRootRef","getRef","onHeightChange","shadow","restProps","platform","isControlledOutside","textareaRef","currentScrollHeight","useRef","resize","useCallback","textareaEl","current","offsetParent","height","scrollHeight","onTextareaChange","event","useEffect"],"sources":["../../../../src/components/WriteBar/WriteBar.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { Headline } from \"../Typography/Headline/Headline\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useExternRef } from \"../../hooks/useExternRef\";\nimport { hasReactNode, isFunction } from \"../../lib/utils\";\nimport { classNames } from \"../../lib/classNames\";\nimport { IOS } from \"../../lib/platform\";\nimport { HasRef, HasRootRef } from \"../../types\";\nimport \"./WriteBar.css\";\n\nexport interface WriteBarProps\n extends React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n HasRootRef<HTMLDivElement>,\n HasRef<HTMLTextAreaElement> {\n /**\n * Содержимое, отображаемое слева от поля ввода.\n */\n before?: React.ReactNode;\n /**\n * Содержимое, отображаемое поверх поля ввода (актуально для iOS)\n */\n inlineAfter?: React.ReactNode;\n /**\n * Содержимое, отображаемое справа от поля ввода\n */\n after?: React.ReactNode;\n /**\n * Вызывается при смене высоты поля ввода\n */\n onHeightChange?: VoidFunction;\n /**\n * Добавляет тень вокруг поля ввода\n */\n shadow?: boolean;\n\n children?: never;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/WriteBar\n */\nexport const WriteBar = ({\n className,\n style,\n before,\n inlineAfter,\n after,\n value,\n onChange,\n getRootRef,\n getRef,\n onHeightChange,\n shadow = false,\n ...restProps\n}: WriteBarProps) => {\n const platform = usePlatform();\n\n const isControlledOutside = value != null;\n\n const textareaRef = useExternRef(getRef);\n const currentScrollHeight = React.useRef<number>();\n\n const resize = React.useCallback(() => {\n const textareaEl = textareaRef.current;\n if (!textareaEl) {\n return;\n }\n\n if (textareaEl.offsetParent) {\n textareaEl.style.height = \"\";\n textareaEl.style.height = `${textareaEl.scrollHeight}px`;\n\n if (\n textareaEl.scrollHeight !== currentScrollHeight.current &&\n onHeightChange\n ) {\n onHeightChange();\n currentScrollHeight.current = textareaEl.scrollHeight;\n }\n }\n }, [onHeightChange, textareaRef]);\n\n const onTextareaChange: React.ChangeEventHandler<HTMLTextAreaElement> = (\n event\n ) => {\n if (isFunction(onChange)) {\n onChange(event);\n }\n\n if (!isControlledOutside) {\n resize();\n }\n };\n\n React.useEffect(() => {\n resize();\n }, [resize, value]);\n\n return (\n <div\n ref={getRootRef}\n vkuiClass={classNames(\n \"WriteBar\",\n platform === IOS && \"WriteBar--ios\",\n shadow && \"WriteBar--shadow\"\n )}\n className={className}\n style={style}\n >\n <div vkuiClass=\"WriteBar__form\">\n {hasReactNode(before) && (\n <div vkuiClass=\"WriteBar__before\">{before}</div>\n )}\n\n <div vkuiClass=\"WriteBar__formIn\">\n <Headline\n {...restProps}\n Component=\"textarea\"\n vkuiClass=\"WriteBar__textarea\"\n onChange={onTextareaChange}\n getRootRef={textareaRef}\n value={value}\n />\n {hasReactNode(inlineAfter) && (\n <div vkuiClass=\"WriteBar__inlineAfter\">{inlineAfter}</div>\n )}\n </div>\n\n {hasReactNode(after) && <div vkuiClass=\"WriteBar__after\">{after}</div>}\n </div>\n </div>\n );\n};\n"],"mappings":"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"}
@@ -29,17 +29,29 @@ export var WriteBarIcon = function WriteBarIcon(_ref) {
29
29
 
30
30
  switch (mode) {
31
31
  case "attach":
32
- icon = platform === IOS ? createScopedElement(Icon28AddCircleOutline, null) : createScopedElement(Icon28AttachOutline, null);
32
+ icon = platform === IOS ? createScopedElement(Icon28AddCircleOutline, {
33
+ "aria-hidden": true
34
+ }) : createScopedElement(Icon28AttachOutline, {
35
+ "aria-hidden": true
36
+ });
33
37
  ariaLabel = "Прикрепить файл";
34
38
  break;
35
39
 
36
40
  case "send":
37
- icon = platform === IOS ? createScopedElement(Icon48WritebarSend, null) : createScopedElement(Icon24Send, null);
41
+ icon = platform === IOS ? createScopedElement(Icon48WritebarSend, {
42
+ "aria-hidden": true
43
+ }) : createScopedElement(Icon24Send, {
44
+ "aria-hidden": true
45
+ });
38
46
  ariaLabel = "Отправить";
39
47
  break;
40
48
 
41
49
  case "done":
42
- icon = platform === IOS ? createScopedElement(Icon48WritebarDone, null) : createScopedElement(Icon28CheckCircleOutline, null);
50
+ icon = platform === IOS ? createScopedElement(Icon48WritebarDone, {
51
+ "aria-hidden": true
52
+ }) : createScopedElement(Icon28CheckCircleOutline, {
53
+ "aria-hidden": true
54
+ });
43
55
  ariaLabel = "Готово";
44
56
  break;
45
57
 
@@ -1 +1 @@
1
- {"version":3,"file":"WriteBarIcon.js","names":["Icon24Send","Icon28AddCircleOutline","Icon28AttachOutline","Icon28CheckCircleOutline","Icon48WritebarDone","Icon48WritebarSend","usePlatform","classNames","IOS","Platform","Counter","Tappable","warnOnce","hasReactNode","warn","IS_DEV","process","env","NODE_ENV","WriteBarIcon","mode","children","count","restProps","platform","icon","ariaLabel","undefined"],"sources":["../../../../src/components/WriteBarIcon/WriteBarIcon.tsx"],"sourcesContent":["import * as React from \"react\";\nimport {\n Icon24Send,\n Icon28AddCircleOutline,\n Icon28AttachOutline,\n Icon28CheckCircleOutline,\n Icon48WritebarDone,\n Icon48WritebarSend,\n} from \"@vkontakte/icons\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { classNames } from \"../../lib/classNames\";\nimport { IOS, Platform } from \"../../lib/platform\";\nimport { Counter } from \"../Counter/Counter\";\nimport { Tappable } from \"../Tappable/Tappable\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport \"./WriteBarIcon.css\";\n\nexport interface WriteBarIconProps\n extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n /**\n * Предустановленные типы кнопок в WriteBar для отрисовки иконки в зависимости от платформы.\n * Если передать валидное значение для этого свойства, `children` игнорируется.\n *\n * - `attach` – иконка прикрепления.\n * - `send` – иконка отправки.\n * - `done` – иконка отправки в режиме редактирования.\n */\n mode?: \"attach\" | \"send\" | \"done\";\n /**\n * Значение счётчика для кнопки. Например, для количества прикреплённых файлов.\n */\n count?: number;\n}\n\nconst warn = warnOnce(\"WriteBarIcon\");\nconst IS_DEV = process.env.NODE_ENV === \"development\";\n\n/**\n * @see https://vkcom.github.io/VKUI/#/WriteBarIcon\n */\nexport const WriteBarIcon = ({\n mode,\n children,\n count,\n ...restProps\n}: WriteBarIconProps) => {\n const platform = usePlatform();\n\n let icon: React.ReactNode;\n let ariaLabel: string | undefined = undefined;\n\n switch (mode) {\n case \"attach\":\n icon =\n platform === IOS ? <Icon28AddCircleOutline /> : <Icon28AttachOutline />;\n ariaLabel = \"Прикрепить файл\";\n break;\n\n case \"send\":\n icon = platform === IOS ? <Icon48WritebarSend /> : <Icon24Send />;\n ariaLabel = \"Отправить\";\n break;\n\n case \"done\":\n icon =\n platform === IOS ? (\n <Icon48WritebarDone />\n ) : (\n <Icon28CheckCircleOutline />\n );\n ariaLabel = \"Готово\";\n break;\n\n default:\n break;\n }\n\n if (IS_DEV && !restProps[\"aria-label\"] && !ariaLabel) {\n warn(\n \"a11y: У WriteBarIcon нет aria-label. Кнопка будет недоступной для части пользователей.\",\n \"error\"\n );\n }\n\n return (\n <Tappable\n aria-label={ariaLabel}\n {...restProps}\n Component=\"button\"\n hasHover={false}\n activeMode=\"WriteBarIcon__active\"\n vkuiClass={classNames(\n \"WriteBarIcon\",\n platform === Platform.IOS && \"WriteBarIcon--ios\",\n !!mode && `WriteBarIcon--${mode}`\n )}\n >\n <span vkuiClass=\"WriteBarIcon__in\">\n {icon || children}\n {hasReactNode(count) && (\n <Counter vkuiClass=\"WriteBarIcon__counter\" size=\"s\">\n {count}\n </Counter>\n )}\n </span>\n </Tappable>\n );\n};\n"],"mappings":";;;;AACA,SACEA,UADF,EAEEC,sBAFF,EAGEC,mBAHF,EAIEC,wBAJF,EAKEC,kBALF,EAMEC,kBANF,QAOO,kBAPP;AAQA,SAASC,WAAT;AACA,SAASC,UAAT;AACA,SAASC,GAAT,EAAcC,QAAd;AACA,SAASC,OAAT;AACA,SAASC,QAAT;AACA,SAASC,QAAT;AACA,SAASC,YAAT;AACA;AAmBA,IAAMC,IAAI,GAAGF,QAAQ,CAAC,cAAD,CAArB;AACA,IAAMG,MAAM,GAAGC,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAAxC;AAEA;AACA;AACA;;AACA,OAAO,IAAMC,YAAY,GAAG,SAAfA,YAAe,OAKH;EAAA,IAJvBC,IAIuB,QAJvBA,IAIuB;EAAA,IAHvBC,QAGuB,QAHvBA,QAGuB;EAAA,IAFvBC,KAEuB,QAFvBA,KAEuB;EAAA,IADpBC,SACoB;;EACvB,IAAMC,QAAQ,GAAGlB,WAAW,EAA5B;EAEA,IAAImB,IAAJ;EACA,IAAIC,SAA6B,GAAGC,SAApC;;EAEA,QAAQP,IAAR;IACE,KAAK,QAAL;MACEK,IAAI,GACFD,QAAQ,KAAKhB,GAAb,GAAmB,oBAAC,sBAAD,OAAnB,GAAgD,oBAAC,mBAAD,OADlD;MAEAkB,SAAS,GAAG,iBAAZ;MACA;;IAEF,KAAK,MAAL;MACED,IAAI,GAAGD,QAAQ,KAAKhB,GAAb,GAAmB,oBAAC,kBAAD,OAAnB,GAA4C,oBAAC,UAAD,OAAnD;MACAkB,SAAS,GAAG,WAAZ;MACA;;IAEF,KAAK,MAAL;MACED,IAAI,GACFD,QAAQ,KAAKhB,GAAb,GACE,oBAAC,kBAAD,OADF,GAGE,oBAAC,wBAAD,OAJJ;MAMAkB,SAAS,GAAG,QAAZ;MACA;;IAEF;MACE;EAvBJ;;EA0BA,IAAIX,MAAM,IAAI,CAACQ,SAAS,CAAC,YAAD,CAApB,IAAsC,CAACG,SAA3C,EAAsD;IACpDZ,IAAI,CACF,wFADE,EAEF,OAFE,CAAJ;EAID;;EAED,OACE,oBAAC,QAAD;IACE,cAAYY;EADd,GAEMH,SAFN;IAGE,SAAS,EAAC,QAHZ;IAIE,QAAQ,EAAE,KAJZ;IAKE,UAAU,EAAC,sBALb;IAME,SAAS,EAAEhB,UAAU,CACnB,cADmB,EAEnBiB,QAAQ,KAAKf,QAAQ,CAACD,GAAtB,IAA6B,mBAFV,EAGnB,CAAC,CAACY,IAAF,4BAA2BA,IAA3B,CAHmB;EANvB,IAYE;IAAM,SAAS,EAAC;EAAhB,GACGK,IAAI,IAAIJ,QADX,EAEGR,YAAY,CAACS,KAAD,CAAZ,IACC,oBAAC,OAAD;IAAS,SAAS,EAAC,uBAAnB;IAA2C,IAAI,EAAC;EAAhD,GACGA,KADH,CAHJ,CAZF,CADF;AAuBD,CAnEM"}
1
+ {"version":3,"file":"WriteBarIcon.js","names":["Icon24Send","Icon28AddCircleOutline","Icon28AttachOutline","Icon28CheckCircleOutline","Icon48WritebarDone","Icon48WritebarSend","usePlatform","classNames","IOS","Platform","Counter","Tappable","warnOnce","hasReactNode","warn","IS_DEV","process","env","NODE_ENV","WriteBarIcon","mode","children","count","restProps","platform","icon","ariaLabel","undefined"],"sources":["../../../../src/components/WriteBarIcon/WriteBarIcon.tsx"],"sourcesContent":["import * as React from \"react\";\nimport {\n Icon24Send,\n Icon28AddCircleOutline,\n Icon28AttachOutline,\n Icon28CheckCircleOutline,\n Icon48WritebarDone,\n Icon48WritebarSend,\n} from \"@vkontakte/icons\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { classNames } from \"../../lib/classNames\";\nimport { IOS, Platform } from \"../../lib/platform\";\nimport { Counter } from \"../Counter/Counter\";\nimport { Tappable } from \"../Tappable/Tappable\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport \"./WriteBarIcon.css\";\n\nexport interface WriteBarIconProps\n extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n /**\n * Предустановленные типы кнопок в WriteBar для отрисовки иконки в зависимости от платформы.\n * Если передать валидное значение для этого свойства, `children` игнорируется.\n *\n * - `attach` – иконка прикрепления.\n * - `send` – иконка отправки.\n * - `done` – иконка отправки в режиме редактирования.\n */\n mode?: \"attach\" | \"send\" | \"done\";\n /**\n * Значение счётчика для кнопки. Например, для количества прикреплённых файлов.\n */\n count?: number;\n}\n\nconst warn = warnOnce(\"WriteBarIcon\");\nconst IS_DEV = process.env.NODE_ENV === \"development\";\n\n/**\n * @see https://vkcom.github.io/VKUI/#/WriteBarIcon\n */\nexport const WriteBarIcon = ({\n mode,\n children,\n count,\n ...restProps\n}: WriteBarIconProps) => {\n const platform = usePlatform();\n\n let icon: React.ReactNode;\n let ariaLabel: string | undefined = undefined;\n\n switch (mode) {\n case \"attach\":\n icon =\n platform === IOS ? (\n <Icon28AddCircleOutline aria-hidden />\n ) : (\n <Icon28AttachOutline aria-hidden />\n );\n ariaLabel = \"Прикрепить файл\";\n break;\n\n case \"send\":\n icon =\n platform === IOS ? (\n <Icon48WritebarSend aria-hidden />\n ) : (\n <Icon24Send aria-hidden />\n );\n ariaLabel = \"Отправить\";\n break;\n\n case \"done\":\n icon =\n platform === IOS ? (\n <Icon48WritebarDone aria-hidden />\n ) : (\n <Icon28CheckCircleOutline aria-hidden />\n );\n ariaLabel = \"Готово\";\n break;\n\n default:\n break;\n }\n\n if (IS_DEV && !restProps[\"aria-label\"] && !ariaLabel) {\n warn(\n \"a11y: У WriteBarIcon нет aria-label. Кнопка будет недоступной для части пользователей.\",\n \"error\"\n );\n }\n\n return (\n <Tappable\n aria-label={ariaLabel}\n {...restProps}\n Component=\"button\"\n hasHover={false}\n activeMode=\"WriteBarIcon__active\"\n vkuiClass={classNames(\n \"WriteBarIcon\",\n platform === Platform.IOS && \"WriteBarIcon--ios\",\n !!mode && `WriteBarIcon--${mode}`\n )}\n >\n <span vkuiClass=\"WriteBarIcon__in\">\n {icon || children}\n {hasReactNode(count) && (\n <Counter vkuiClass=\"WriteBarIcon__counter\" size=\"s\">\n {count}\n </Counter>\n )}\n </span>\n </Tappable>\n );\n};\n"],"mappings":";;;;AACA,SACEA,UADF,EAEEC,sBAFF,EAGEC,mBAHF,EAIEC,wBAJF,EAKEC,kBALF,EAMEC,kBANF,QAOO,kBAPP;AAQA,SAASC,WAAT;AACA,SAASC,UAAT;AACA,SAASC,GAAT,EAAcC,QAAd;AACA,SAASC,OAAT;AACA,SAASC,QAAT;AACA,SAASC,QAAT;AACA,SAASC,YAAT;AACA;AAmBA,IAAMC,IAAI,GAAGF,QAAQ,CAAC,cAAD,CAArB;AACA,IAAMG,MAAM,GAAGC,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAAxC;AAEA;AACA;AACA;;AACA,OAAO,IAAMC,YAAY,GAAG,SAAfA,YAAe,OAKH;EAAA,IAJvBC,IAIuB,QAJvBA,IAIuB;EAAA,IAHvBC,QAGuB,QAHvBA,QAGuB;EAAA,IAFvBC,KAEuB,QAFvBA,KAEuB;EAAA,IADpBC,SACoB;;EACvB,IAAMC,QAAQ,GAAGlB,WAAW,EAA5B;EAEA,IAAImB,IAAJ;EACA,IAAIC,SAA6B,GAAGC,SAApC;;EAEA,QAAQP,IAAR;IACE,KAAK,QAAL;MACEK,IAAI,GACFD,QAAQ,KAAKhB,GAAb,GACE,oBAAC,sBAAD;QAAwB;MAAxB,EADF,GAGE,oBAAC,mBAAD;QAAqB;MAArB,EAJJ;MAMAkB,SAAS,GAAG,iBAAZ;MACA;;IAEF,KAAK,MAAL;MACED,IAAI,GACFD,QAAQ,KAAKhB,GAAb,GACE,oBAAC,kBAAD;QAAoB;MAApB,EADF,GAGE,oBAAC,UAAD;QAAY;MAAZ,EAJJ;MAMAkB,SAAS,GAAG,WAAZ;MACA;;IAEF,KAAK,MAAL;MACED,IAAI,GACFD,QAAQ,KAAKhB,GAAb,GACE,oBAAC,kBAAD;QAAoB;MAApB,EADF,GAGE,oBAAC,wBAAD;QAA0B;MAA1B,EAJJ;MAMAkB,SAAS,GAAG,QAAZ;MACA;;IAEF;MACE;EAhCJ;;EAmCA,IAAIX,MAAM,IAAI,CAACQ,SAAS,CAAC,YAAD,CAApB,IAAsC,CAACG,SAA3C,EAAsD;IACpDZ,IAAI,CACF,wFADE,EAEF,OAFE,CAAJ;EAID;;EAED,OACE,oBAAC,QAAD;IACE,cAAYY;EADd,GAEMH,SAFN;IAGE,SAAS,EAAC,QAHZ;IAIE,QAAQ,EAAE,KAJZ;IAKE,UAAU,EAAC,sBALb;IAME,SAAS,EAAEhB,UAAU,CACnB,cADmB,EAEnBiB,QAAQ,KAAKf,QAAQ,CAACD,GAAtB,IAA6B,mBAFV,EAGnB,CAAC,CAACY,IAAF,4BAA2BA,IAA3B,CAHmB;EANvB,IAYE;IAAM,SAAS,EAAC;EAAhB,GACGK,IAAI,IAAIJ,QADX,EAEGR,YAAY,CAACS,KAAD,CAAZ,IACC,oBAAC,OAAD;IAAS,SAAS,EAAC,uBAAnB;IAA2C,IAAI,EAAC;EAAhD,GACGA,KADH,CAHJ,CAZF,CADF;AAuBD,CA5EM"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vkontakte/vkui",
3
- "version": "4.37.0",
3
+ "version": "4.37.1",
4
4
  "main": "dist/cjs/index.js",
5
5
  "module": "dist/index.js",
6
6
  "typings": "dist/index.d.ts",
@@ -185,7 +185,7 @@
185
185
  "babel-dev": "yarn babel-base --out-dir dist/ --watch",
186
186
  "babel-cjs-dev": "yarn babel-base --config-file ./babel.cjs.config.js --out-dir dist/cjs/ --watch",
187
187
  "tsc-dev": "tsc --emitDeclarationOnly --declaration --outDir dist/ --watch --preserveWatchOutput",
188
- "build:types": "yarn tsc && yarn tsc-cssm",
188
+ "build:types": "yarn tsc && yarn tsc-cjs && yarn tsc-cssm",
189
189
  "build:no-types": "concurrently 'yarn:babel' 'yarn:babel-cssm' 'yarn:babel-cjs' 'yarn:postcss'",
190
190
  "build": "yarn build:types && yarn build:no-types",
191
191
  "postcss": "cross-env NODE_ENV=production concurrently 'yarn:postcss-bundle' 'yarn:postcss-modules'",
@@ -15,6 +15,15 @@ const clearDisableScrollStyle = (node: HTMLElement) => {
15
15
  });
16
16
  };
17
17
 
18
+ const getPageYOffsetWithoutKeyboardHeight = (window: Window) => {
19
+ // Note: здесь расчёт на то, что `clientHeight` равен `window.innerHeight`.
20
+ // Это достигается тем, что тегу `html` задали`height: 100%` и у него нет отступов сверху и снизу. Если есть отступы,
21
+ // то надо задать `box-sizing: border-box`, чтобы они не учитывались.
22
+ const diffOfClientHeightAndViewportHeight =
23
+ window.document.documentElement.clientHeight - window.innerHeight;
24
+ return window.pageYOffset - diffOfClientHeightAndViewportHeight;
25
+ };
26
+
18
27
  export interface ScrollContextInterface {
19
28
  getScroll(this: void): { x: number; y: number };
20
29
  scrollTo(this: void, x?: number, y?: number): void;
@@ -45,7 +54,10 @@ export const GlobalScrollController = ({ children }: ScrollControllerProps) => {
45
54
  const beforeScrollLockFnSetRef = React.useRef<Set<() => void>>(new Set());
46
55
 
47
56
  const getScroll = React.useCallback<ScrollContextInterface["getScroll"]>(
48
- () => ({ x: window!.pageXOffset, y: window!.pageYOffset }),
57
+ () => ({
58
+ x: window!.pageXOffset,
59
+ y: getPageYOffsetWithoutKeyboardHeight(window!),
60
+ }),
49
61
  [window]
50
62
  );
51
63
  const scrollTo = React.useCallback<ScrollContextInterface["scrollTo"]>(
@@ -46,7 +46,7 @@ export const FixedLayout = ({
46
46
  const { colRef } = React.useContext(SplitColContext);
47
47
  const doResize = () =>
48
48
  setWidth(colRef?.current ? `${colRef.current.offsetWidth}px` : undefined);
49
- React.useEffect(doResize, [colRef]);
49
+ React.useEffect(doResize, [colRef, platform]);
50
50
  useGlobalEventListener(window, "resize", doResize);
51
51
 
52
52
  return (
@@ -301,6 +301,8 @@ export const View = ({
301
301
 
302
302
  if (e.startX <= 70 && !swipingBack && history && history.length > 1) {
303
303
  if (activePanel !== null) {
304
+ // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.
305
+ blurActiveElement(document);
304
306
  scrolls.current[activePanel] = scroll?.getScroll().y;
305
307
  }
306
308
 
@@ -46,15 +46,15 @@ const WriteBarExample = (props) => {
46
46
  after={
47
47
  <Fragment>
48
48
  <WriteBarIcon aria-label="Эмоджи и стикеры">
49
- <Icon28SmileOutline />
49
+ <Icon28SmileOutline aria-hidden />
50
50
  </WriteBarIcon>
51
51
 
52
52
  <WriteBarIcon aria-label="Записать видео-сообщение">
53
- <Icon28CameraOutline />
53
+ <Icon28CameraOutline aria-hidden />
54
54
  </WriteBarIcon>
55
55
 
56
56
  <WriteBarIcon aria-label="Записать голосовое сообщение">
57
- <Icon28VoiceOutline />
57
+ <Icon28VoiceOutline aria-hidden />
58
58
  </WriteBarIcon>
59
59
  </Fragment>
60
60
  }
@@ -71,13 +71,13 @@ const WriteBarExample = (props) => {
71
71
  <Fragment>
72
72
  {text2.length === 0 && (
73
73
  <WriteBarIcon aria-label="Открыть меню бота">
74
- <Icon28KeyboardBotsOutline />
74
+ <Icon28KeyboardBotsOutline aria-hidden />
75
75
  </WriteBarIcon>
76
76
  )}
77
77
 
78
78
  {text2.length > 0 && (
79
79
  <WriteBarIcon aria-label="Эмоджи и стикеры">
80
- <Icon28SmileOutline />
80
+ <Icon28SmileOutline aria-hidden />
81
81
  </WriteBarIcon>
82
82
  )}
83
83
  </Fragment>
@@ -86,13 +86,13 @@ const WriteBarExample = (props) => {
86
86
  <Fragment>
87
87
  {text2.length === 0 && (
88
88
  <WriteBarIcon aria-label="Эмоджи и стикеры">
89
- <Icon28SmileOutline />
89
+ <Icon28SmileOutline aria-hidden />
90
90
  </WriteBarIcon>
91
91
  )}
92
92
 
93
93
  {text2.length === 0 && (
94
94
  <WriteBarIcon aria-label="Записать голосовое сообщение">
95
- <Icon28VoiceOutline />
95
+ <Icon28VoiceOutline aria-hidden />
96
96
  </WriteBarIcon>
97
97
  )}
98
98
 
@@ -112,7 +112,7 @@ const WriteBarExample = (props) => {
112
112
  <Fragment>
113
113
  {text3.length > 0 && (
114
114
  <WriteBarIcon aria-label="Смайлы и стикеры">
115
- <Icon28SmileOutline />
115
+ <Icon28SmileOutline aria-hidden />
116
116
  </WriteBarIcon>
117
117
  )}
118
118
  </Fragment>
@@ -121,7 +121,7 @@ const WriteBarExample = (props) => {
121
121
  <Fragment>
122
122
  {text3.length === 0 && (
123
123
  <WriteBarIcon aria-label="Смайлы и стикеры">
124
- <Icon28SmileOutline />
124
+ <Icon28SmileOutline aria-hidden />
125
125
  </WriteBarIcon>
126
126
  )}
127
127
 
@@ -141,7 +141,7 @@ const WriteBarExample = (props) => {
141
141
  <Fragment>
142
142
  {text4.length > 0 && (
143
143
  <WriteBarIcon aria-label="Смайлы и стикеры">
144
- <Icon28SmileOutline />
144
+ <Icon28SmileOutline aria-hidden />
145
145
  </WriteBarIcon>
146
146
  )}
147
147
  </Fragment>
@@ -150,7 +150,7 @@ const WriteBarExample = (props) => {
150
150
  <Fragment>
151
151
  {text4.length === 0 && (
152
152
  <WriteBarIcon aria-label="Смайлы и стикеры">
153
- <Icon28SmileOutline />
153
+ <Icon28SmileOutline aria-hidden />
154
154
  </WriteBarIcon>
155
155
  )}
156
156
 
@@ -186,7 +186,7 @@ const WriteBarExample = (props) => {
186
186
  <Fragment>
187
187
  {text.length > 0 && (
188
188
  <WriteBarIcon aria-label="Смайлы и стикеры">
189
- <Icon28SmileOutline />
189
+ <Icon28SmileOutline aria-hidden />
190
190
  </WriteBarIcon>
191
191
  )}
192
192
  </Fragment>
@@ -195,13 +195,13 @@ const WriteBarExample = (props) => {
195
195
  <Fragment>
196
196
  {text.length === 0 && (
197
197
  <WriteBarIcon aria-label="Смайлы и стикеры">
198
- <Icon28SmileOutline />
198
+ <Icon28SmileOutline aria-hidden />
199
199
  </WriteBarIcon>
200
200
  )}
201
201
 
202
202
  {text.length === 0 && (
203
203
  <WriteBarIcon aria-label="Записать голосовое сообщение">
204
- <Icon28VoiceOutline />
204
+ <Icon28VoiceOutline aria-hidden />
205
205
  </WriteBarIcon>
206
206
  )}
207
207
 
@@ -107,7 +107,7 @@ export const WriteBar = ({
107
107
  className={className}
108
108
  style={style}
109
109
  >
110
- <form vkuiClass="WriteBar__form" onSubmit={(e) => e.preventDefault()}>
110
+ <div vkuiClass="WriteBar__form">
111
111
  {hasReactNode(before) && (
112
112
  <div vkuiClass="WriteBar__before">{before}</div>
113
113
  )}
@@ -127,7 +127,7 @@ export const WriteBar = ({
127
127
  </div>
128
128
 
129
129
  {hasReactNode(after) && <div vkuiClass="WriteBar__after">{after}</div>}
130
- </form>
130
+ </div>
131
131
  </div>
132
132
  );
133
133
  };
@@ -53,21 +53,30 @@ export const WriteBarIcon = ({
53
53
  switch (mode) {
54
54
  case "attach":
55
55
  icon =
56
- platform === IOS ? <Icon28AddCircleOutline /> : <Icon28AttachOutline />;
56
+ platform === IOS ? (
57
+ <Icon28AddCircleOutline aria-hidden />
58
+ ) : (
59
+ <Icon28AttachOutline aria-hidden />
60
+ );
57
61
  ariaLabel = "Прикрепить файл";
58
62
  break;
59
63
 
60
64
  case "send":
61
- icon = platform === IOS ? <Icon48WritebarSend /> : <Icon24Send />;
65
+ icon =
66
+ platform === IOS ? (
67
+ <Icon48WritebarSend aria-hidden />
68
+ ) : (
69
+ <Icon24Send aria-hidden />
70
+ );
62
71
  ariaLabel = "Отправить";
63
72
  break;
64
73
 
65
74
  case "done":
66
75
  icon =
67
76
  platform === IOS ? (
68
- <Icon48WritebarDone />
77
+ <Icon48WritebarDone aria-hidden />
69
78
  ) : (
70
- <Icon28CheckCircleOutline />
79
+ <Icon28CheckCircleOutline aria-hidden />
71
80
  );
72
81
  ariaLabel = "Готово";
73
82
  break;