@vkontakte/vkui 4.34.0 → 4.35.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 (690) hide show
  1. package/.browserslistrc +5 -0
  2. package/.cache/.eslintcache +1 -1
  3. package/.cache/.stylelintcache +1 -1
  4. package/.cache/.tsbuildinfo +291 -268
  5. package/.cache/ts/src/components/ActionSheetItem/ActionSheetItem.d.ts +1 -1
  6. package/.cache/ts/src/components/AppRoot/AppRoot.d.ts +1 -1
  7. package/.cache/ts/src/components/Button/Button.d.ts +1 -1
  8. package/.cache/ts/src/components/CardGrid/CardGrid.d.ts +1 -1
  9. package/.cache/ts/src/components/Checkbox/Checkbox.d.ts +1 -1
  10. package/.cache/ts/src/components/ChipsSelect/ChipsSelect.d.ts +1 -1
  11. package/.cache/ts/src/components/ConfigProvider/ConfigProviderContext.d.ts +1 -0
  12. package/.cache/ts/src/components/CustomSelect/CustomSelect.d.ts +1 -1
  13. package/.cache/ts/src/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +2 -1
  14. package/.cache/ts/src/components/DatePicker/DatePicker.d.ts +1 -1
  15. package/.cache/ts/src/components/Dropdown/Dropdown.d.ts +46 -5
  16. package/.cache/ts/src/components/Epic/Epic.d.ts +1 -1
  17. package/.cache/ts/src/components/FocusTrap/FocusTrap.d.ts +1 -1
  18. package/.cache/ts/src/components/Group/Group.d.ts +1 -1
  19. package/.cache/ts/src/components/HorizontalScroll/HorizontalScroll.d.ts +1 -1
  20. package/.cache/ts/src/components/IconButton/IconButton.d.ts +1 -1
  21. package/.cache/ts/src/components/Input/Input.d.ts +1 -1
  22. package/.cache/ts/src/components/ModalCard/ModalCard.d.ts +1 -1
  23. package/.cache/ts/src/components/ModalCardBase/ModalCardBase.d.ts +1 -1
  24. package/.cache/ts/src/components/ModalPage/ModalPage.d.ts +1 -1
  25. package/.cache/ts/src/components/ModalRoot/ModalRoot.d.ts +1 -1
  26. package/.cache/ts/src/components/ModalRoot/ModalRootAdaptive.d.ts +1 -1
  27. package/.cache/ts/src/components/ModalRoot/ModalRootDesktop.d.ts +1 -1
  28. package/.cache/ts/src/components/NativeSelect/NativeSelect.d.ts +1 -1
  29. package/.cache/ts/src/components/Panel/Panel.d.ts +1 -1
  30. package/.cache/ts/src/components/PanelHeader/PanelHeader.d.ts +1 -1
  31. package/.cache/ts/src/components/PanelHeaderBack/PanelHeaderBack.d.ts +1 -1
  32. package/.cache/ts/src/components/PopoutRoot/PopoutRoot.d.ts +1 -1
  33. package/.cache/ts/src/components/Popper/Popper.d.ts +18 -1
  34. package/.cache/ts/src/components/PopperArrow/PopperArrow.d.ts +8 -0
  35. package/.cache/ts/src/components/Radio/Radio.d.ts +1 -1
  36. package/.cache/ts/src/components/RangeSlider/UniversalSlider.d.ts +1 -1
  37. package/.cache/ts/src/components/RichCell/RichCell.d.ts +1 -1
  38. package/.cache/ts/src/components/RichTooltip/RichTooltip.d.ts +7 -2
  39. package/.cache/ts/src/components/Search/Search.d.ts +1 -1
  40. package/.cache/ts/src/components/Select/Select.d.ts +1 -1
  41. package/.cache/ts/src/components/SelectMimicry/SelectMimicry.d.ts +1 -1
  42. package/.cache/ts/src/components/SimpleCell/SimpleCell.d.ts +1 -1
  43. package/.cache/ts/src/components/Snackbar/Snackbar.d.ts +5 -1
  44. package/.cache/ts/src/components/SplitCol/SplitCol.d.ts +1 -0
  45. package/.cache/ts/src/components/Tabbar/Tabbar.d.ts +8 -1
  46. package/.cache/ts/src/components/Tabs/Tabs.d.ts +14 -3
  47. package/.cache/ts/src/components/TabsItem/TabsItem.d.ts +22 -1
  48. package/.cache/ts/src/components/Tappable/Tappable.d.ts +1 -1
  49. package/.cache/ts/src/components/TextTooltip/TextTooltip.d.ts +5 -1
  50. package/.cache/ts/src/components/Textarea/Textarea.d.ts +4 -1
  51. package/.cache/ts/src/components/Tooltip/Tooltip.d.ts +18 -1
  52. package/.cache/ts/src/components/Typography/Headline/Headline.d.ts +3 -3
  53. package/.cache/ts/src/components/View/View.d.ts +2 -18
  54. package/.cache/ts/src/components/View/ViewInfinite.d.ts +1 -1
  55. package/.cache/ts/src/components/WriteBar/WriteBar.d.ts +5 -1
  56. package/.cache/ts/src/hoc/withAdaptivity.d.ts +1 -1
  57. package/.cache/ts/src/hoc/withContext.d.ts +1 -1
  58. package/.cache/ts/src/hoc/withPlatform.d.ts +1 -1
  59. package/.cache/ts/src/tokenized/index.d.ts +26 -0
  60. package/.eslintrc.json +14 -4
  61. package/dist/cjs/components/AppRoot/AppRoot.js +13 -15
  62. package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
  63. package/dist/cjs/components/Button/Button.js +6 -4
  64. package/dist/cjs/components/Button/Button.js.map +1 -1
  65. package/dist/cjs/components/CardScroll/CardScroll.js +3 -1
  66. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  67. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +5 -0
  68. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  69. package/dist/cjs/components/ConfigProvider/ConfigProviderContext.js +7 -1
  70. package/dist/cjs/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  71. package/dist/cjs/components/CustomSelect/CustomSelect.js +477 -553
  72. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  73. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js +73 -35
  74. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  75. package/dist/cjs/components/Dropdown/Dropdown.js +147 -26
  76. package/dist/cjs/components/Dropdown/Dropdown.js.map +1 -1
  77. package/dist/cjs/components/Epic/Epic.js +1 -6
  78. package/dist/cjs/components/Epic/Epic.js.map +1 -1
  79. package/dist/cjs/components/FocusTrap/FocusTrap.js +9 -10
  80. package/dist/cjs/components/FocusTrap/FocusTrap.js.map +1 -1
  81. package/dist/cjs/components/FormField/FormField.js +4 -10
  82. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  83. package/dist/cjs/components/HorizontalCell/HorizontalCell.js +4 -7
  84. package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
  85. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js +1 -0
  86. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  87. package/dist/cjs/components/Input/Input.js +3 -6
  88. package/dist/cjs/components/Input/Input.js.map +1 -1
  89. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js +2 -2
  90. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  91. package/dist/cjs/components/ModalCardBase/ModalCardBase.js +1 -0
  92. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  93. package/dist/cjs/components/NativeSelect/NativeSelect.js +1 -0
  94. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  95. package/dist/cjs/components/Panel/Panel.js +1 -0
  96. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  97. package/dist/cjs/components/PanelHeader/PanelHeader.js +1 -0
  98. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  99. package/dist/cjs/components/Popper/Popper.js +16 -22
  100. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  101. package/dist/cjs/components/PopperArrow/PopperArrow.js +40 -0
  102. package/dist/cjs/components/PopperArrow/PopperArrow.js.map +1 -0
  103. package/dist/cjs/components/Radio/Radio.js +1 -0
  104. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  105. package/dist/cjs/components/RangeSlider/UniversalSlider.js +1 -0
  106. package/dist/cjs/components/RangeSlider/UniversalSlider.js.map +1 -1
  107. package/dist/cjs/components/RichTooltip/RichTooltip.js +6 -15
  108. package/dist/cjs/components/RichTooltip/RichTooltip.js.map +1 -1
  109. package/dist/cjs/components/Select/Select.js +1 -0
  110. package/dist/cjs/components/Select/Select.js.map +1 -1
  111. package/dist/cjs/components/SelectMimicry/SelectMimicry.js +4 -1
  112. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  113. package/dist/cjs/components/SimpleCell/SimpleCell.js +21 -31
  114. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  115. package/dist/cjs/components/Snackbar/Snackbar.js +7 -11
  116. package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
  117. package/dist/cjs/components/SplitCol/SplitCol.js +7 -1
  118. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  119. package/dist/cjs/components/SplitLayout/SplitLayout.js +5 -8
  120. package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
  121. package/dist/cjs/components/Tabbar/Tabbar.js +15 -14
  122. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  123. package/dist/cjs/components/TabbarItem/TabbarItem.js +8 -10
  124. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  125. package/dist/cjs/components/Tabs/Tabs.js +23 -5
  126. package/dist/cjs/components/Tabs/Tabs.js.map +1 -1
  127. package/dist/cjs/components/TabsItem/TabsItem.js +39 -22
  128. package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
  129. package/dist/cjs/components/TextTooltip/TextTooltip.js +6 -9
  130. package/dist/cjs/components/TextTooltip/TextTooltip.js.map +1 -1
  131. package/dist/cjs/components/Textarea/Textarea.js +5 -4
  132. package/dist/cjs/components/Textarea/Textarea.js.map +1 -1
  133. package/dist/cjs/components/Tooltip/Tooltip.js +94 -71
  134. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  135. package/dist/cjs/components/Typography/Headline/Headline.js +11 -2
  136. package/dist/cjs/components/Typography/Headline/Headline.js.map +1 -1
  137. package/dist/cjs/components/View/View.js +388 -453
  138. package/dist/cjs/components/View/View.js.map +1 -1
  139. package/dist/cjs/components/WriteBar/WriteBar.js +12 -5
  140. package/dist/cjs/components/WriteBar/WriteBar.js.map +1 -1
  141. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js +3 -8
  142. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  143. package/dist/cjs/hoc/withAdaptivity.js.map +1 -1
  144. package/dist/cjs/hoc/withContext.js.map +1 -1
  145. package/dist/cjs/hoc/withPlatform.js.map +1 -1
  146. package/dist/cjs/hooks/useOrientationChange.js +2 -1
  147. package/dist/cjs/hooks/useOrientationChange.js.map +1 -1
  148. package/dist/cjs/tokenized/index.js +104 -0
  149. package/dist/cjs/tokenized/index.js.map +1 -1
  150. package/dist/components/ActionSheetItem/ActionSheetItem.d.ts +1 -1
  151. package/dist/components/AppRoot/AppRoot.d.ts +1 -1
  152. package/dist/components/AppRoot/AppRoot.js +13 -15
  153. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  154. package/dist/components/Button/Button.d.ts +1 -1
  155. package/dist/components/Button/Button.js +6 -4
  156. package/dist/components/Button/Button.js.map +1 -1
  157. package/dist/components/CardGrid/CardGrid.d.ts +1 -1
  158. package/dist/components/CardScroll/CardScroll.js +3 -1
  159. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  160. package/dist/components/Checkbox/Checkbox.d.ts +1 -1
  161. package/dist/components/ChipsSelect/ChipsSelect.d.ts +1 -1
  162. package/dist/components/ChipsSelect/ChipsSelect.js +5 -0
  163. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  164. package/dist/components/ConfigProvider/ConfigProviderContext.d.ts +1 -0
  165. package/dist/components/ConfigProvider/ConfigProviderContext.js +3 -0
  166. package/dist/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  167. package/dist/components/CustomSelect/CustomSelect.d.ts +1 -1
  168. package/dist/components/CustomSelect/CustomSelect.js +473 -579
  169. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  170. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +2 -1
  171. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js +71 -35
  172. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  173. package/dist/components/DatePicker/DatePicker.d.ts +1 -1
  174. package/dist/components/Dropdown/Dropdown.d.ts +46 -5
  175. package/dist/components/Dropdown/Dropdown.js +137 -27
  176. package/dist/components/Dropdown/Dropdown.js.map +1 -1
  177. package/dist/components/Epic/Epic.d.ts +1 -1
  178. package/dist/components/Epic/Epic.js +1 -4
  179. package/dist/components/Epic/Epic.js.map +1 -1
  180. package/dist/components/FocusTrap/FocusTrap.d.ts +1 -1
  181. package/dist/components/FocusTrap/FocusTrap.js +9 -9
  182. package/dist/components/FocusTrap/FocusTrap.js.map +1 -1
  183. package/dist/components/FormField/FormField.js +4 -8
  184. package/dist/components/FormField/FormField.js.map +1 -1
  185. package/dist/components/Group/Group.d.ts +1 -1
  186. package/dist/components/HorizontalCell/HorizontalCell.js +3 -5
  187. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  188. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +1 -1
  189. package/dist/components/HorizontalScroll/HorizontalScroll.js +1 -0
  190. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  191. package/dist/components/IconButton/IconButton.d.ts +1 -1
  192. package/dist/components/Input/Input.d.ts +1 -1
  193. package/dist/components/Input/Input.js +3 -4
  194. package/dist/components/Input/Input.js.map +1 -1
  195. package/dist/components/MiniInfoCell/MiniInfoCell.js +2 -2
  196. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  197. package/dist/components/ModalCard/ModalCard.d.ts +1 -1
  198. package/dist/components/ModalCardBase/ModalCardBase.d.ts +1 -1
  199. package/dist/components/ModalCardBase/ModalCardBase.js +1 -0
  200. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  201. package/dist/components/ModalPage/ModalPage.d.ts +1 -1
  202. package/dist/components/ModalRoot/ModalRoot.d.ts +1 -1
  203. package/dist/components/ModalRoot/ModalRootAdaptive.d.ts +1 -1
  204. package/dist/components/ModalRoot/ModalRootDesktop.d.ts +1 -1
  205. package/dist/components/NativeSelect/NativeSelect.d.ts +1 -1
  206. package/dist/components/NativeSelect/NativeSelect.js +1 -0
  207. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  208. package/dist/components/Panel/Panel.d.ts +1 -1
  209. package/dist/components/Panel/Panel.js +1 -0
  210. package/dist/components/Panel/Panel.js.map +1 -1
  211. package/dist/components/PanelHeader/PanelHeader.d.ts +1 -1
  212. package/dist/components/PanelHeader/PanelHeader.js +1 -0
  213. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  214. package/dist/components/PanelHeaderBack/PanelHeaderBack.d.ts +1 -1
  215. package/dist/components/PopoutRoot/PopoutRoot.d.ts +1 -1
  216. package/dist/components/Popper/Popper.d.ts +18 -1
  217. package/dist/components/Popper/Popper.js +15 -22
  218. package/dist/components/Popper/Popper.js.map +1 -1
  219. package/dist/components/PopperArrow/PopperArrow.d.ts +8 -0
  220. package/dist/components/PopperArrow/PopperArrow.js +27 -0
  221. package/dist/components/PopperArrow/PopperArrow.js.map +1 -0
  222. package/dist/components/Radio/Radio.d.ts +1 -1
  223. package/dist/components/Radio/Radio.js +1 -0
  224. package/dist/components/Radio/Radio.js.map +1 -1
  225. package/dist/components/RangeSlider/UniversalSlider.d.ts +1 -1
  226. package/dist/components/RangeSlider/UniversalSlider.js +1 -0
  227. package/dist/components/RangeSlider/UniversalSlider.js.map +1 -1
  228. package/dist/components/RichCell/RichCell.d.ts +1 -1
  229. package/dist/components/RichTooltip/RichTooltip.d.ts +7 -2
  230. package/dist/components/RichTooltip/RichTooltip.js +5 -10
  231. package/dist/components/RichTooltip/RichTooltip.js.map +1 -1
  232. package/dist/components/Search/Search.d.ts +1 -1
  233. package/dist/components/Select/Select.d.ts +1 -1
  234. package/dist/components/Select/Select.js +1 -0
  235. package/dist/components/Select/Select.js.map +1 -1
  236. package/dist/components/SelectMimicry/SelectMimicry.d.ts +1 -1
  237. package/dist/components/SelectMimicry/SelectMimicry.js +4 -1
  238. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  239. package/dist/components/SimpleCell/SimpleCell.d.ts +1 -1
  240. package/dist/components/SimpleCell/SimpleCell.js +19 -28
  241. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  242. package/dist/components/Snackbar/Snackbar.d.ts +5 -1
  243. package/dist/components/Snackbar/Snackbar.js +8 -11
  244. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  245. package/dist/components/SplitCol/SplitCol.d.ts +1 -0
  246. package/dist/components/SplitCol/SplitCol.js +3 -0
  247. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  248. package/dist/components/SplitLayout/SplitLayout.js +4 -7
  249. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  250. package/dist/components/Tabbar/Tabbar.d.ts +8 -1
  251. package/dist/components/Tabbar/Tabbar.js +15 -14
  252. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  253. package/dist/components/TabbarItem/TabbarItem.js +7 -9
  254. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  255. package/dist/components/Tabs/Tabs.d.ts +14 -3
  256. package/dist/components/Tabs/Tabs.js +23 -5
  257. package/dist/components/Tabs/Tabs.js.map +1 -1
  258. package/dist/components/TabsItem/TabsItem.d.ts +22 -1
  259. package/dist/components/TabsItem/TabsItem.js +40 -21
  260. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  261. package/dist/components/Tappable/Tappable.d.ts +1 -1
  262. package/dist/components/TextTooltip/TextTooltip.d.ts +5 -1
  263. package/dist/components/TextTooltip/TextTooltip.js +5 -7
  264. package/dist/components/TextTooltip/TextTooltip.js.map +1 -1
  265. package/dist/components/Textarea/Textarea.d.ts +4 -1
  266. package/dist/components/Textarea/Textarea.js +5 -4
  267. package/dist/components/Textarea/Textarea.js.map +1 -1
  268. package/dist/components/Tooltip/Tooltip.d.ts +18 -1
  269. package/dist/components/Tooltip/Tooltip.js +89 -68
  270. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  271. package/dist/components/Typography/Headline/Headline.d.ts +3 -3
  272. package/dist/components/Typography/Headline/Headline.js +10 -2
  273. package/dist/components/Typography/Headline/Headline.js.map +1 -1
  274. package/dist/components/View/View.d.ts +2 -18
  275. package/dist/components/View/View.js +384 -462
  276. package/dist/components/View/View.js.map +1 -1
  277. package/dist/components/View/ViewInfinite.d.ts +1 -1
  278. package/dist/components/WriteBar/WriteBar.d.ts +5 -1
  279. package/dist/components/WriteBar/WriteBar.js +10 -5
  280. package/dist/components/WriteBar/WriteBar.js.map +1 -1
  281. package/dist/components/WriteBarIcon/WriteBarIcon.js +3 -6
  282. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  283. package/dist/components.css +143 -127
  284. package/dist/components.css.map +1 -1
  285. package/dist/cssm/components/ActionSheet/ActionSheet.css +1 -1
  286. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.css +1 -1
  287. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.d.ts +1 -1
  288. package/dist/cssm/components/Alert/Alert.css +1 -1
  289. package/dist/cssm/components/AppRoot/AppRoot.css +1 -1
  290. package/dist/cssm/components/AppRoot/AppRoot.d.ts +1 -1
  291. package/dist/cssm/components/AppRoot/AppRoot.js +13 -15
  292. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  293. package/dist/cssm/components/Avatar/Avatar.css +3 -5
  294. package/dist/cssm/components/Badge/Badge.css +3 -3
  295. package/dist/cssm/components/Banner/Banner.css +5 -5
  296. package/dist/cssm/components/BaseGallery/BaseGallery.css +1 -1
  297. package/dist/cssm/components/Button/Button.css +53 -35
  298. package/dist/cssm/components/Button/Button.d.ts +1 -1
  299. package/dist/cssm/components/Button/Button.js +6 -4
  300. package/dist/cssm/components/Button/Button.js.map +1 -1
  301. package/dist/cssm/components/Calendar/Calendar.css +1 -1
  302. package/dist/cssm/components/CalendarDay/CalendarDay.css +1 -1
  303. package/dist/cssm/components/CalendarDays/CalendarDays.css +1 -1
  304. package/dist/cssm/components/CalendarHeader/CalendarHeader.css +1 -1
  305. package/dist/cssm/components/CalendarRange/CalendarRange.css +1 -1
  306. package/dist/cssm/components/CalendarTime/CalendarTime.css +1 -1
  307. package/dist/cssm/components/Card/Card.css +5 -6
  308. package/dist/cssm/components/CardGrid/CardGrid.css +1 -1
  309. package/dist/cssm/components/CardGrid/CardGrid.d.ts +1 -1
  310. package/dist/cssm/components/CardScroll/CardScroll.css +1 -1
  311. package/dist/cssm/components/CardScroll/CardScroll.js +3 -1
  312. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  313. package/dist/cssm/components/Cell/Cell.css +3 -3
  314. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.css +1 -1
  315. package/dist/cssm/components/Cell/CellDragger/CellDragger.css +1 -1
  316. package/dist/cssm/components/CellButton/CellButton.css +1 -1
  317. package/dist/cssm/components/Checkbox/Checkbox.css +1 -1
  318. package/dist/cssm/components/Checkbox/Checkbox.d.ts +1 -1
  319. package/dist/cssm/components/Chip/Chip.css +1 -1
  320. package/dist/cssm/components/ChipsInput/ChipsInput.css +1 -1
  321. package/dist/cssm/components/ChipsSelect/ChipsSelect.css +1 -1
  322. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts +1 -1
  323. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +5 -0
  324. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  325. package/dist/cssm/components/ConfigProvider/ConfigProviderContext.d.ts +1 -0
  326. package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js +3 -0
  327. package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  328. package/dist/cssm/components/ContentCard/ContentCard.css +1 -1
  329. package/dist/cssm/components/Counter/Counter.css +31 -31
  330. package/dist/cssm/components/CustomScrollView/CustomScrollView.css +1 -1
  331. package/dist/cssm/components/CustomSelect/CustomSelect.css +1 -1
  332. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +1 -1
  333. package/dist/cssm/components/CustomSelect/CustomSelect.js +473 -579
  334. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  335. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.css +3 -3
  336. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +2 -1
  337. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js +71 -35
  338. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  339. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.css +3 -3
  340. package/dist/cssm/components/DateInput/DateInput.css +1 -1
  341. package/dist/cssm/components/DatePicker/DatePicker.css +1 -1
  342. package/dist/cssm/components/DatePicker/DatePicker.d.ts +1 -1
  343. package/dist/cssm/components/DateRangeInput/DateRangeInput.css +1 -1
  344. package/dist/cssm/components/Dropdown/Dropdown.css +1 -1
  345. package/dist/cssm/components/Dropdown/Dropdown.d.ts +46 -5
  346. package/dist/cssm/components/Dropdown/Dropdown.js +137 -27
  347. package/dist/cssm/components/Dropdown/Dropdown.js.map +1 -1
  348. package/dist/cssm/components/Epic/Epic.css +1 -1
  349. package/dist/cssm/components/Epic/Epic.d.ts +1 -1
  350. package/dist/cssm/components/Epic/Epic.js +1 -4
  351. package/dist/cssm/components/Epic/Epic.js.map +1 -1
  352. package/dist/cssm/components/FixedLayout/FixedLayout.css +1 -1
  353. package/dist/cssm/components/FocusTrap/FocusTrap.d.ts +1 -1
  354. package/dist/cssm/components/FocusTrap/FocusTrap.js +9 -9
  355. package/dist/cssm/components/FocusTrap/FocusTrap.js.map +1 -1
  356. package/dist/cssm/components/FocusVisible/FocusVisible.css +1 -1
  357. package/dist/cssm/components/Footer/Footer.css +1 -1
  358. package/dist/cssm/components/FormField/FormField.css +9 -9
  359. package/dist/cssm/components/FormField/FormField.js +4 -8
  360. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  361. package/dist/cssm/components/FormItem/FormItem.css +1 -1
  362. package/dist/cssm/components/FormLayout/FormLayout.css +1 -1
  363. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.css +1 -1
  364. package/dist/cssm/components/FormStatus/FormStatus.css +1 -1
  365. package/dist/cssm/components/Gradient/Gradient.css +1 -1
  366. package/dist/cssm/components/GridAvatar/GridAvatar.css +1 -1
  367. package/dist/cssm/components/Group/Group.css +1 -1
  368. package/dist/cssm/components/Group/Group.d.ts +1 -1
  369. package/dist/cssm/components/Header/Header.css +1 -1
  370. package/dist/cssm/components/HorizontalCell/HorizontalCell.css +1 -1
  371. package/dist/cssm/components/HorizontalCell/HorizontalCell.js +3 -5
  372. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  373. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.css +1 -1
  374. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.d.ts +1 -1
  375. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +1 -0
  376. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  377. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.css +3 -3
  378. package/dist/cssm/components/IconButton/IconButton.css +1 -1
  379. package/dist/cssm/components/IconButton/IconButton.d.ts +1 -1
  380. package/dist/cssm/components/InfoRow/InfoRow.css +1 -1
  381. package/dist/cssm/components/InitialsAvatar/InitialsAvatar.css +1 -1
  382. package/dist/cssm/components/Input/Input.css +1 -1
  383. package/dist/cssm/components/Input/Input.d.ts +1 -1
  384. package/dist/cssm/components/Input/Input.js +3 -4
  385. package/dist/cssm/components/Input/Input.js.map +1 -1
  386. package/dist/cssm/components/InputLike/InputLike.css +1 -1
  387. package/dist/cssm/components/InputLike/InputLikeDivider.css +1 -1
  388. package/dist/cssm/components/Link/Link.css +1 -1
  389. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.css +1 -1
  390. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js +2 -2
  391. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  392. package/dist/cssm/components/ModalCard/ModalCard.css +1 -1
  393. package/dist/cssm/components/ModalCard/ModalCard.d.ts +1 -1
  394. package/dist/cssm/components/ModalCardBase/ModalCardBase.css +3 -3
  395. package/dist/cssm/components/ModalCardBase/ModalCardBase.d.ts +1 -1
  396. package/dist/cssm/components/ModalCardBase/ModalCardBase.js +1 -0
  397. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  398. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.css +1 -1
  399. package/dist/cssm/components/ModalPage/ModalPage.css +1 -1
  400. package/dist/cssm/components/ModalPage/ModalPage.d.ts +1 -1
  401. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.css +1 -1
  402. package/dist/cssm/components/ModalRoot/ModalRoot.css +1 -1
  403. package/dist/cssm/components/ModalRoot/ModalRoot.d.ts +1 -1
  404. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.d.ts +1 -1
  405. package/dist/cssm/components/ModalRoot/ModalRootDesktop.d.ts +1 -1
  406. package/dist/cssm/components/NativeSelect/NativeSelect.d.ts +1 -1
  407. package/dist/cssm/components/NativeSelect/NativeSelect.js +1 -0
  408. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  409. package/dist/cssm/components/Pagination/Pagination.css +1 -1
  410. package/dist/cssm/components/Panel/Panel.css +1 -1
  411. package/dist/cssm/components/Panel/Panel.d.ts +1 -1
  412. package/dist/cssm/components/Panel/Panel.js +1 -0
  413. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  414. package/dist/cssm/components/PanelHeader/PanelHeader.css +1 -1
  415. package/dist/cssm/components/PanelHeader/PanelHeader.d.ts +1 -1
  416. package/dist/cssm/components/PanelHeader/PanelHeader.js +1 -0
  417. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  418. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.d.ts +1 -1
  419. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.css +1 -1
  420. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.css +1 -1
  421. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.css +1 -1
  422. package/dist/cssm/components/Placeholder/Placeholder.css +3 -3
  423. package/dist/cssm/components/PopoutRoot/PopoutRoot.css +1 -1
  424. package/dist/cssm/components/PopoutRoot/PopoutRoot.d.ts +1 -1
  425. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.css +1 -1
  426. package/dist/cssm/components/Popper/Popper.css +1 -1
  427. package/dist/cssm/components/Popper/Popper.d.ts +18 -1
  428. package/dist/cssm/components/Popper/Popper.js +15 -22
  429. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  430. package/dist/cssm/components/PopperArrow/PopperArrow.css +1 -0
  431. package/dist/cssm/components/PopperArrow/PopperArrow.d.ts +8 -0
  432. package/dist/cssm/components/PopperArrow/PopperArrow.js +28 -0
  433. package/dist/cssm/components/PopperArrow/PopperArrow.js.map +1 -0
  434. package/dist/cssm/components/Progress/Progress.css +1 -1
  435. package/dist/cssm/components/PromoBanner/PromoBanner.css +1 -1
  436. package/dist/cssm/components/PullToRefresh/PullToRefresh.css +3 -3
  437. package/dist/cssm/components/Radio/Radio.css +1 -1
  438. package/dist/cssm/components/Radio/Radio.d.ts +1 -1
  439. package/dist/cssm/components/Radio/Radio.js +1 -0
  440. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  441. package/dist/cssm/components/RadioGroup/RadioGroup.css +1 -1
  442. package/dist/cssm/components/RangeSlider/UniversalSlider.d.ts +1 -1
  443. package/dist/cssm/components/RangeSlider/UniversalSlider.js +1 -0
  444. package/dist/cssm/components/RangeSlider/UniversalSlider.js.map +1 -1
  445. package/dist/cssm/components/Removable/Removable.css +1 -1
  446. package/dist/cssm/components/RichCell/RichCell.css +3 -3
  447. package/dist/cssm/components/RichCell/RichCell.d.ts +1 -1
  448. package/dist/cssm/components/RichTooltip/RichTooltip.css +3 -1
  449. package/dist/cssm/components/RichTooltip/RichTooltip.d.ts +7 -2
  450. package/dist/cssm/components/RichTooltip/RichTooltip.js +5 -10
  451. package/dist/cssm/components/RichTooltip/RichTooltip.js.map +1 -1
  452. package/dist/cssm/components/Root/Root.css +1 -1
  453. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.css +1 -1
  454. package/dist/cssm/components/Search/Search.css +1 -1
  455. package/dist/cssm/components/Search/Search.d.ts +1 -1
  456. package/dist/cssm/components/SegmentedControl/SegmentedControl.css +1 -1
  457. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +1 -1
  458. package/dist/cssm/components/Select/Select.css +1 -1
  459. package/dist/cssm/components/Select/Select.d.ts +1 -1
  460. package/dist/cssm/components/Select/Select.js +1 -0
  461. package/dist/cssm/components/Select/Select.js.map +1 -1
  462. package/dist/cssm/components/SelectMimicry/SelectMimicry.d.ts +1 -1
  463. package/dist/cssm/components/SelectMimicry/SelectMimicry.js +4 -1
  464. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  465. package/dist/cssm/components/Separator/Separator.css +1 -1
  466. package/dist/cssm/components/SimpleCell/SimpleCell.css +1 -1
  467. package/dist/cssm/components/SimpleCell/SimpleCell.d.ts +1 -1
  468. package/dist/cssm/components/SimpleCell/SimpleCell.js +19 -28
  469. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  470. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.css +1 -1
  471. package/dist/cssm/components/Slider/Slider.css +3 -3
  472. package/dist/cssm/components/SliderSwitch/SliderSwitch.css +1 -1
  473. package/dist/cssm/components/Snackbar/Snackbar.css +1 -1
  474. package/dist/cssm/components/Snackbar/Snackbar.d.ts +5 -1
  475. package/dist/cssm/components/Snackbar/Snackbar.js +8 -11
  476. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  477. package/dist/cssm/components/Spacing/Spacing.css +1 -1
  478. package/dist/cssm/components/Spinner/Spinner.css +1 -1
  479. package/dist/cssm/components/SplitCol/SplitCol.css +1 -1
  480. package/dist/cssm/components/SplitCol/SplitCol.d.ts +1 -0
  481. package/dist/cssm/components/SplitCol/SplitCol.js +3 -0
  482. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  483. package/dist/cssm/components/SplitLayout/SplitLayout.css +1 -1
  484. package/dist/cssm/components/SplitLayout/SplitLayout.js +4 -7
  485. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  486. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.css +1 -1
  487. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.css +1 -1
  488. package/dist/cssm/components/Switch/Switch.css +3 -3
  489. package/dist/cssm/components/Tabbar/Tabbar.css +5 -3
  490. package/dist/cssm/components/Tabbar/Tabbar.d.ts +8 -1
  491. package/dist/cssm/components/Tabbar/Tabbar.js +15 -14
  492. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  493. package/dist/cssm/components/TabbarItem/TabbarItem.css +1 -1
  494. package/dist/cssm/components/TabbarItem/TabbarItem.js +7 -9
  495. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  496. package/dist/cssm/components/Tabs/Tabs.css +1 -1
  497. package/dist/cssm/components/Tabs/Tabs.d.ts +14 -3
  498. package/dist/cssm/components/Tabs/Tabs.js +23 -5
  499. package/dist/cssm/components/Tabs/Tabs.js.map +1 -1
  500. package/dist/cssm/components/TabsItem/TabsItem.css +5 -1
  501. package/dist/cssm/components/TabsItem/TabsItem.d.ts +22 -1
  502. package/dist/cssm/components/TabsItem/TabsItem.js +40 -21
  503. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  504. package/dist/cssm/components/Tappable/Tappable.css +5 -5
  505. package/dist/cssm/components/Tappable/Tappable.d.ts +1 -1
  506. package/dist/cssm/components/TextTooltip/TextTooltip.css +1 -1
  507. package/dist/cssm/components/TextTooltip/TextTooltip.d.ts +5 -1
  508. package/dist/cssm/components/TextTooltip/TextTooltip.js +5 -7
  509. package/dist/cssm/components/TextTooltip/TextTooltip.js.map +1 -1
  510. package/dist/cssm/components/Textarea/Textarea.css +1 -1
  511. package/dist/cssm/components/Textarea/Textarea.d.ts +4 -1
  512. package/dist/cssm/components/Textarea/Textarea.js +5 -4
  513. package/dist/cssm/components/Textarea/Textarea.js.map +1 -1
  514. package/dist/cssm/components/Tooltip/Tooltip.css +1 -1
  515. package/dist/cssm/components/Tooltip/Tooltip.d.ts +18 -1
  516. package/dist/cssm/components/Tooltip/Tooltip.js +89 -68
  517. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  518. package/dist/cssm/components/Typography/Caption/Caption.css +1 -1
  519. package/dist/cssm/components/Typography/Footnote/Footnote.css +1 -1
  520. package/dist/cssm/components/Typography/Headline/Headline.css +1 -1
  521. package/dist/cssm/components/Typography/Headline/Headline.d.ts +3 -3
  522. package/dist/cssm/components/Typography/Headline/Headline.js +10 -2
  523. package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
  524. package/dist/cssm/components/Typography/Paragraph/Paragraph.css +1 -1
  525. package/dist/cssm/components/Typography/Subhead/Subhead.css +1 -1
  526. package/dist/cssm/components/Typography/Text/Text.css +1 -1
  527. package/dist/cssm/components/Typography/Title/Title.css +1 -1
  528. package/dist/cssm/components/UsersStack/UsersStack.css +5 -5
  529. package/dist/cssm/components/View/View.css +1 -1
  530. package/dist/cssm/components/View/View.d.ts +2 -18
  531. package/dist/cssm/components/View/View.js +384 -462
  532. package/dist/cssm/components/View/View.js.map +1 -1
  533. package/dist/cssm/components/View/ViewIOS.css +1 -1
  534. package/dist/cssm/components/View/ViewInfinite.d.ts +1 -1
  535. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.css +1 -1
  536. package/dist/cssm/components/WriteBar/WriteBar.css +3 -1
  537. package/dist/cssm/components/WriteBar/WriteBar.d.ts +5 -1
  538. package/dist/cssm/components/WriteBar/WriteBar.js +10 -5
  539. package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
  540. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.css +1 -1
  541. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +3 -6
  542. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  543. package/dist/cssm/fonts/fonts.css +1 -1
  544. package/dist/cssm/hoc/withAdaptivity.d.ts +1 -1
  545. package/dist/cssm/hoc/withAdaptivity.js.map +1 -1
  546. package/dist/cssm/hoc/withContext.d.ts +1 -1
  547. package/dist/cssm/hoc/withContext.js.map +1 -1
  548. package/dist/cssm/hoc/withPlatform.d.ts +1 -1
  549. package/dist/cssm/hoc/withPlatform.js.map +1 -1
  550. package/dist/cssm/hooks/useOrientationChange.js +2 -1
  551. package/dist/cssm/hooks/useOrientationChange.js.map +1 -1
  552. package/dist/cssm/lib/calendar.d.ts +2 -2
  553. package/dist/cssm/styles/animations.css +1 -1
  554. package/dist/cssm/styles/bright_light.css +1 -1
  555. package/dist/cssm/styles/common.css +1 -1
  556. package/dist/cssm/styles/components.css +143 -127
  557. package/dist/cssm/styles/constants.css +3 -10
  558. package/dist/cssm/styles/space_gray.css +1 -1
  559. package/dist/cssm/styles/themes.css +1 -16
  560. package/dist/cssm/styles/unstable.css +3 -1
  561. package/dist/cssm/styles/vkcom_dark.css +1 -6
  562. package/dist/cssm/styles/vkcom_light.css +1 -11
  563. package/dist/cssm/tokenized/index.d.ts +26 -0
  564. package/dist/cssm/tokenized/index.js +13 -0
  565. package/dist/cssm/tokenized/index.js.map +1 -1
  566. package/dist/default_scheme.css +1 -1
  567. package/dist/default_scheme.css.map +1 -1
  568. package/dist/fonts.css +1 -1
  569. package/dist/fonts.css.map +1 -1
  570. package/dist/hoc/withAdaptivity.d.ts +1 -1
  571. package/dist/hoc/withAdaptivity.js.map +1 -1
  572. package/dist/hoc/withContext.d.ts +1 -1
  573. package/dist/hoc/withContext.js.map +1 -1
  574. package/dist/hoc/withPlatform.d.ts +1 -1
  575. package/dist/hoc/withPlatform.js.map +1 -1
  576. package/dist/hooks/useOrientationChange.js +2 -1
  577. package/dist/hooks/useOrientationChange.js.map +1 -1
  578. package/dist/lib/calendar.d.ts +2 -2
  579. package/dist/tokenized/index.d.ts +26 -0
  580. package/dist/tokenized/index.js +13 -0
  581. package/dist/tokenized/index.js.map +1 -1
  582. package/dist/unstable.css +3 -1
  583. package/dist/unstable.css.map +1 -1
  584. package/dist/vkui.css +144 -143
  585. package/dist/vkui.css.map +1 -1
  586. package/package.json +6 -5
  587. package/src/components/AppRoot/AppRoot.tsx +15 -11
  588. package/src/components/Badge/Badge.css +0 -5
  589. package/src/components/Button/Button.css +0 -4
  590. package/src/components/Button/Button.tsx +4 -2
  591. package/src/components/Button/Readme.md +30 -59
  592. package/src/components/CardScroll/CardScroll.tsx +1 -1
  593. package/src/components/Cell/Cell.css +3 -2
  594. package/src/components/ChipsInput/ChipsInput.css +2 -0
  595. package/src/components/ChipsSelect/ChipsSelect.tsx +8 -0
  596. package/src/components/ConfigProvider/ConfigProviderContext.tsx +2 -0
  597. package/src/components/Counter/Counter.css +30 -0
  598. package/src/components/CustomScrollView/CustomScrollView.css +10 -5
  599. package/src/components/CustomSelect/CustomSelect.tsx +543 -573
  600. package/src/components/CustomSelectDropdown/CustomSelectDropdown.tsx +45 -22
  601. package/src/components/Dropdown/Dropdown.css +12 -0
  602. package/src/components/Dropdown/Dropdown.tsx +174 -20
  603. package/src/components/Dropdown/Readme.md +1 -0
  604. package/src/components/Epic/Epic.tsx +1 -4
  605. package/src/components/FixedLayout/Readme.md +103 -109
  606. package/src/components/FocusTrap/FocusTrap.tsx +10 -10
  607. package/src/components/FormField/FormField.css +31 -22
  608. package/src/components/FormField/FormField.tsx +4 -8
  609. package/src/components/FormField/Readme.md +9 -82
  610. package/src/components/Group/Group.css +1 -1
  611. package/src/components/Group/Readme.md +1 -1
  612. package/src/components/HorizontalCell/HorizontalCell.css +25 -43
  613. package/src/components/HorizontalCell/HorizontalCell.tsx +3 -9
  614. package/src/components/HorizontalScroll/HorizontalScroll.css +23 -0
  615. package/src/components/HorizontalScroll/HorizontalScroll.tsx +2 -0
  616. package/src/components/IconButton/IconButton.css +46 -25
  617. package/src/components/Input/Input.css +20 -9
  618. package/src/components/Input/Input.tsx +6 -5
  619. package/src/components/Input/Readme.md +128 -24
  620. package/src/components/MiniInfoCell/MiniInfoCell.css +13 -3
  621. package/src/components/MiniInfoCell/MiniInfoCell.tsx +3 -3
  622. package/src/components/ModalCardBase/ModalCardBase.tsx +2 -0
  623. package/src/components/NativeSelect/NativeSelect.tsx +2 -0
  624. package/src/components/Panel/Panel.tsx +2 -0
  625. package/src/components/PanelHeader/PanelHeader.tsx +2 -0
  626. package/src/components/Popper/Popper.css +0 -35
  627. package/src/components/Popper/Popper.tsx +33 -25
  628. package/src/components/PopperArrow/PopperArrow.css +34 -0
  629. package/src/components/PopperArrow/PopperArrow.tsx +40 -0
  630. package/src/components/Radio/Radio.tsx +2 -0
  631. package/src/components/RangeSlider/UniversalSlider.tsx +2 -0
  632. package/src/components/RichTooltip/RichTooltip.css +44 -4
  633. package/src/components/RichTooltip/RichTooltip.tsx +9 -11
  634. package/src/components/ScreenSpinner/ScreenSpinner.css +1 -1
  635. package/src/components/Select/Select.css +23 -9
  636. package/src/components/Select/Select.tsx +2 -0
  637. package/src/components/SelectMimicry/SelectMimicry.tsx +6 -2
  638. package/src/components/SimpleCell/Readme.md +115 -129
  639. package/src/components/SimpleCell/SimpleCell.css +30 -68
  640. package/src/components/SimpleCell/SimpleCell.tsx +23 -25
  641. package/src/components/Snackbar/Readme.md +95 -123
  642. package/src/components/Snackbar/Snackbar.css +18 -27
  643. package/src/components/Snackbar/Snackbar.tsx +17 -11
  644. package/src/components/SplitCol/SplitCol.css +1 -1
  645. package/src/components/SplitCol/SplitCol.tsx +2 -0
  646. package/src/components/SplitLayout/SplitLayout.css +3 -7
  647. package/src/components/SplitLayout/SplitLayout.tsx +9 -6
  648. package/src/components/Switch/Switch.css +6 -2
  649. package/src/components/Tabbar/Tabbar.css +4 -1
  650. package/src/components/Tabbar/Tabbar.tsx +23 -12
  651. package/src/components/TabbarItem/TabbarItem.css +7 -5
  652. package/src/components/TabbarItem/TabbarItem.tsx +13 -7
  653. package/src/components/Tabs/Readme.md +191 -251
  654. package/src/components/Tabs/Tabs.css +27 -80
  655. package/src/components/Tabs/Tabs.tsx +45 -7
  656. package/src/components/TabsItem/Readme.md +1 -0
  657. package/src/components/TabsItem/TabsItem.css +191 -106
  658. package/src/components/TabsItem/TabsItem.tsx +72 -20
  659. package/src/components/TextTooltip/TextTooltip.css +41 -11
  660. package/src/components/TextTooltip/TextTooltip.tsx +9 -13
  661. package/src/components/Textarea/Textarea.css +7 -3
  662. package/src/components/Textarea/Textarea.tsx +5 -4
  663. package/src/components/Tooltip/Readme.md +128 -101
  664. package/src/components/Tooltip/Tooltip.css +29 -40
  665. package/src/components/Tooltip/Tooltip.tsx +98 -66
  666. package/src/components/Typography/Headline/Headline.tsx +15 -1
  667. package/src/components/View/Readme.md +2 -0
  668. package/src/components/View/View.tsx +451 -514
  669. package/src/components/WriteBar/WriteBar.css +27 -33
  670. package/src/components/WriteBar/WriteBar.tsx +16 -5
  671. package/src/components/WriteBarIcon/WriteBarIcon.css +6 -19
  672. package/src/components/WriteBarIcon/WriteBarIcon.tsx +6 -6
  673. package/src/hoc/withAdaptivity.tsx +4 -4
  674. package/src/hoc/withContext.tsx +1 -1
  675. package/src/hoc/withPlatform.tsx +1 -1
  676. package/src/hooks/useOrientationChange.ts +1 -0
  677. package/src/styles/components.css +1 -0
  678. package/src/styles/constants.css +8 -0
  679. package/src/tokenized/index.ts +39 -0
  680. package/tsconfig.json +1 -1
  681. package/.cache/ts/src/components/ClickPopper/ClickPopper.d.ts +0 -21
  682. package/dist/cjs/components/ClickPopper/ClickPopper.js +0 -96
  683. package/dist/cjs/components/ClickPopper/ClickPopper.js.map +0 -1
  684. package/dist/components/ClickPopper/ClickPopper.d.ts +0 -21
  685. package/dist/components/ClickPopper/ClickPopper.js +0 -71
  686. package/dist/components/ClickPopper/ClickPopper.js.map +0 -1
  687. package/dist/cssm/components/ClickPopper/ClickPopper.d.ts +0 -21
  688. package/dist/cssm/components/ClickPopper/ClickPopper.js +0 -71
  689. package/dist/cssm/components/ClickPopper/ClickPopper.js.map +0 -1
  690. package/src/components/ClickPopper/ClickPopper.tsx +0 -86
@@ -13,19 +13,9 @@ var _jsxRuntime = require("../../lib/jsxRuntime");
13
13
 
14
14
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
15
15
 
16
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
17
-
18
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
19
-
20
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
21
-
22
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
16
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
23
17
 
24
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
25
-
26
- var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
27
-
28
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
18
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
29
19
 
30
20
  var React = _interopRequireWildcard(require("react"));
31
21
 
@@ -37,10 +27,6 @@ var _platform = require("../../lib/platform");
37
27
 
38
28
  var _Touch = require("../Touch/Touch");
39
29
 
40
- var _withPlatform = require("../../hoc/withPlatform");
41
-
42
- var _withContext = require("../../hoc/withContext");
43
-
44
30
  var _ConfigProviderContext = require("../ConfigProvider/ConfigProviderContext");
45
31
 
46
32
  var _SplitCol = require("../SplitCol/SplitCol");
@@ -57,9 +43,21 @@ var _getNavId = require("../../lib/getNavId");
57
43
 
58
44
  var _warnOnce = require("../../lib/warnOnce");
59
45
 
46
+ var _usePlatform = require("../../hooks/usePlatform");
47
+
60
48
  var _utils = require("./utils");
61
49
 
62
- var _excluded = ["popout", "modal", "platform", "activePanel", "splitCol", "configProvider", "history", "nav", "onTransition", "onSwipeBack", "onSwipeBackStart", "onSwipeBackCancel", "window", "document", "scroll"];
50
+ var _useWaitTransitionFinish = require("../../hooks/useWaitTransitionFinish");
51
+
52
+ var _useTimeout = require("../../hooks/useTimeout");
53
+
54
+ var _usePrevious = require("../../hooks/usePrevious");
55
+
56
+ var _useIsomorphicLayoutEffect = require("../../lib/useIsomorphicLayoutEffect");
57
+
58
+ var _utils2 = require("../../lib/utils");
59
+
60
+ var _excluded = ["popout", "modal", "activePanel", "history", "nav", "onTransition", "onSwipeBack", "onSwipeBackStart", "onSwipeBackCancel", "children"];
63
61
  var SwipeBackResults;
64
62
 
65
63
  (function (SwipeBackResults) {
@@ -70,493 +68,430 @@ var SwipeBackResults;
70
68
  var scrollsCache = {};
71
69
  exports.scrollsCache = scrollsCache;
72
70
  var warn = (0, _warnOnce.warnOnce)("View");
71
+ /**
72
+ * @see https://vkcom.github.io/VKUI/#/View
73
+ */
73
74
 
74
- var ViewComponent = /*#__PURE__*/function (_React$Component) {
75
- (0, _inherits2.default)(ViewComponent, _React$Component);
76
-
77
- var _super = (0, _createSuper2.default)(ViewComponent);
78
-
79
- function ViewComponent(props) {
80
- var _this;
81
-
82
- (0, _classCallCheck2.default)(this, ViewComponent);
83
- _this = _super.call(this, props);
84
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "scrolls", scrollsCache[(0, _getNavId.getNavId)(_this.props)] || {});
85
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "transitionFinishTimeout", undefined);
86
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "animationFinishTimeout", undefined);
87
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "panelNodes", {});
88
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "transitionEndHandler", function (e) {
89
- if ((!e || ["vkui-animation-ios-next-forward", "vkui-animation-ios-prev-back", "vkui-animation-view-next-forward", "vkui-animation-view-prev-back"].includes(e.animationName)) && _this.state.prevPanel !== null) {
90
- _this.flushTransition(_this.state.prevPanel, Boolean(_this.state.isBack));
91
- }
92
- });
93
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "swipingBackTransitionEndHandler", function (e) {
94
- // indexOf because of vendor prefixes in old browsers
95
- if (!e || e !== null && e !== void 0 && e.propertyName.includes("transform") && (e === null || e === void 0 ? void 0 : e.target) === _this.pickPanel(_this.state.swipeBackNextPanel)) {
96
- switch (_this.state.swipeBackResult) {
97
- case SwipeBackResults.fail:
98
- _this.onSwipeBackCancel();
99
-
100
- break;
101
-
102
- case SwipeBackResults.success:
103
- _this.onSwipeBackSuccess();
104
-
105
- }
106
- }
107
- });
108
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onMoveX", function (e) {
109
- if ((0, _utils.swipeBackExcluded)(e)) {
110
- return;
111
- }
75
+ var View = function View(_ref) {
76
+ var popout = _ref.popout,
77
+ modal = _ref.modal,
78
+ activePanelProp = _ref.activePanel,
79
+ history = _ref.history,
80
+ nav = _ref.nav,
81
+ onTransition = _ref.onTransition,
82
+ onSwipeBack = _ref.onSwipeBack,
83
+ onSwipeBackStart = _ref.onSwipeBackStart,
84
+ onSwipeBackCancelProp = _ref.onSwipeBackCancel,
85
+ children = _ref.children,
86
+ restProps = (0, _objectWithoutProperties2.default)(_ref, _excluded);
87
+
88
+ if (process.env.NODE_ENV === "development") {
89
+ popout && warn("Свойство popout устарело и будет удалено в 5.0.0. Используйте одноименное свойство у SplitLayout.");
90
+ modal && warn("Свойство modal устарело и будет удалено в 5.0.0. Используйте одноименное свойство у SplitLayout.");
91
+ }
112
92
 
113
- var _this$props = _this.props,
114
- platform = _this$props.platform,
115
- configProvider = _this$props.configProvider;
93
+ var scrolls = React.useRef(scrollsCache[(0, _getNavId.getNavId)({
94
+ nav: nav,
95
+ id: restProps.id
96
+ })] || {});
97
+ var afterTransition = React.useRef(_utils2.noop);
98
+ React.useEffect(function () {
99
+ return function () {
100
+ var id = (0, _getNavId.getNavId)({
101
+ nav: nav,
102
+ id: restProps.id
103
+ });
116
104
 
117
- if (platform === _platform.IOS && !(configProvider !== null && configProvider !== void 0 && configProvider.isWebView) && (e.startX <= 70 || e.startX >= _this.window.innerWidth - 70) && !_this.state.browserSwipe) {
118
- _this.setState({
119
- browserSwipe: true
120
- });
105
+ if (id) {
106
+ scrollsCache[id] = scrolls.current;
121
107
  }
108
+ };
109
+ });
110
+ var panelNodes = React.useRef({});
111
+
112
+ var _useDOM = (0, _dom.useDOM)(),
113
+ window = _useDOM.window,
114
+ document = _useDOM.document;
115
+
116
+ var scroll = (0, _ScrollContext.useScroll)();
117
+ var configProvider = (0, _ConfigProviderContext.useConfigProvider)();
118
+ var splitCol = (0, _SplitCol.useSplitCol)();
119
+ var platform = (0, _usePlatform.usePlatform)();
120
+
121
+ var _React$useState = React.useState(false),
122
+ _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
123
+ animated = _React$useState2[0],
124
+ setAnimated = _React$useState2[1];
125
+
126
+ var _React$useState3 = React.useState([activePanelProp]),
127
+ _React$useState4 = (0, _slicedToArray2.default)(_React$useState3, 2),
128
+ visiblePanels = _React$useState4[0],
129
+ setVisiblePanels = _React$useState4[1];
130
+
131
+ var _React$useState5 = React.useState(activePanelProp),
132
+ _React$useState6 = (0, _slicedToArray2.default)(_React$useState5, 2),
133
+ activePanel = _React$useState6[0],
134
+ setActivePanel = _React$useState6[1];
135
+
136
+ var _React$useState7 = React.useState(undefined),
137
+ _React$useState8 = (0, _slicedToArray2.default)(_React$useState7, 2),
138
+ isBack = _React$useState8[0],
139
+ setIsBack = _React$useState8[1];
140
+
141
+ var _React$useState9 = React.useState(null),
142
+ _React$useState10 = (0, _slicedToArray2.default)(_React$useState9, 2),
143
+ prevPanel = _React$useState10[0],
144
+ setPrevPanel = _React$useState10[1];
145
+
146
+ var _React$useState11 = React.useState(null),
147
+ _React$useState12 = (0, _slicedToArray2.default)(_React$useState11, 2),
148
+ nextPanel = _React$useState12[0],
149
+ setNextPanel = _React$useState12[1];
150
+
151
+ var _React$useState13 = React.useState(false),
152
+ _React$useState14 = (0, _slicedToArray2.default)(_React$useState13, 2),
153
+ swipingBack = _React$useState14[0],
154
+ setSwipingBack = _React$useState14[1];
155
+
156
+ var _React$useState15 = React.useState(0),
157
+ _React$useState16 = (0, _slicedToArray2.default)(_React$useState15, 2),
158
+ swipeBackStartX = _React$useState16[0],
159
+ setSwipeBackStartX = _React$useState16[1];
160
+
161
+ var _React$useState17 = React.useState(0),
162
+ _React$useState18 = (0, _slicedToArray2.default)(_React$useState17, 2),
163
+ swipeBackShift = _React$useState18[0],
164
+ setSwipeBackShift = _React$useState18[1];
165
+
166
+ var _React$useState19 = React.useState(null),
167
+ _React$useState20 = (0, _slicedToArray2.default)(_React$useState19, 2),
168
+ swipeBackNextPanel = _React$useState20[0],
169
+ setSwipeBackNextPanel = _React$useState20[1];
170
+
171
+ var _React$useState21 = React.useState(null),
172
+ _React$useState22 = (0, _slicedToArray2.default)(_React$useState21, 2),
173
+ swipeBackPrevPanel = _React$useState22[0],
174
+ setSwipeBackPrevPanel = _React$useState22[1];
175
+
176
+ var _React$useState23 = React.useState(null),
177
+ _React$useState24 = (0, _slicedToArray2.default)(_React$useState23, 2),
178
+ swipeBackResult = _React$useState24[0],
179
+ setSwipeBackResult = _React$useState24[1];
180
+
181
+ var _React$useState25 = React.useState(false),
182
+ _React$useState26 = (0, _slicedToArray2.default)(_React$useState25, 2),
183
+ browserSwipe = _React$useState26[0],
184
+ setBrowserSwipe = _React$useState26[1];
185
+
186
+ var prevActivePanel = (0, _usePrevious.usePrevious)(activePanelProp);
187
+ var prevSwipingBack = (0, _usePrevious.usePrevious)(swipingBack);
188
+ var prevBrowserSwipe = (0, _usePrevious.usePrevious)(browserSwipe);
189
+ var prevSwipeBackResult = (0, _usePrevious.usePrevious)(swipeBackResult);
190
+ var prevSwipeBackPrevPanel = (0, _usePrevious.usePrevious)(swipeBackPrevPanel);
191
+ var prevOnTransition = (0, _usePrevious.usePrevious)(onTransition);
192
+ var hasPopout = !!popout;
193
+ var hasModal = !!modal;
194
+ var panels = React.Children.toArray(children).filter(function (panel) {
195
+ var panelId = (0, _getNavId.getNavId)(panel.props, warn);
196
+ return panelId !== undefined && visiblePanels.includes(panelId) || panelId === swipeBackPrevPanel || panelId === swipeBackNextPanel;
197
+ });
198
+ var disableAnimation = (configProvider === null || configProvider === void 0 ? void 0 : configProvider.transitionMotionEnabled) === false || !(splitCol !== null && splitCol !== void 0 && splitCol.animate);
199
+
200
+ var pickPanel = function pickPanel(id) {
201
+ if (id === null) {
202
+ return null;
203
+ }
122
204
 
123
- if (platform === _platform.IOS && configProvider !== null && configProvider !== void 0 && configProvider.isWebView && _this.props.onSwipeBack) {
124
- var _this$props$history$l, _this$props$history;
125
-
126
- if (_this.state.animated && e.startX <= 70 || !_this.window) {
127
- return;
128
- }
129
-
130
- if (e.startX <= 70 && !_this.state.swipingBack && ((_this$props$history$l = (_this$props$history = _this.props.history) === null || _this$props$history === void 0 ? void 0 : _this$props$history.length) !== null && _this$props$history$l !== void 0 ? _this$props$history$l : 0) > 1) {
131
- if (_this.state.activePanel !== null) {
132
- var _this$props$scroll;
133
-
134
- _this.scrolls[_this.state.activePanel] = (_this$props$scroll = _this.props.scroll) === null || _this$props$scroll === void 0 ? void 0 : _this$props$scroll.getScroll().y;
135
- }
136
-
137
- _this.setState({
138
- swipingBack: true,
139
- swipeBackStartX: e.startX,
140
- swipeBackPrevPanel: _this.state.activePanel,
141
- swipeBackNextPanel: _this.props.history.slice(-2)[0]
142
- });
143
- }
144
-
145
- if (_this.state.swipingBack) {
146
- var swipeBackShift = 0;
147
-
148
- if (e.shiftX < 0) {
149
- swipeBackShift = 0;
150
- } else if (e.shiftX > _this.window.innerWidth - _this.state.swipeBackStartX) {
151
- var _this$window;
205
+ return panelNodes.current[id];
206
+ };
152
207
 
153
- swipeBackShift = (_this$window = _this.window) === null || _this$window === void 0 ? void 0 : _this$window.innerWidth;
154
- } else {
155
- swipeBackShift = e.shiftX;
156
- }
208
+ var flushTransition = React.useCallback(function (prevPanel, isBackTransition) {
209
+ if (isBackTransition) {
210
+ scrolls.current[prevPanel] = 0;
211
+ }
157
212
 
158
- _this.setState({
159
- swipeBackShift: swipeBackShift
160
- });
161
- }
162
- }
163
- });
164
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onEnd", function (e) {
165
- if (_this.state.swipingBack && _this.window) {
166
- var _this$window$innerWid, _this$window2;
167
-
168
- var speed = _this.state.swipeBackShift / e.duration * 1000;
169
-
170
- if (_this.state.swipeBackShift === 0) {
171
- _this.onSwipeBackCancel();
172
- } else if (_this.state.swipeBackShift >= ((_this$window$innerWid = (_this$window2 = _this.window) === null || _this$window2 === void 0 ? void 0 : _this$window2.innerWidth) !== null && _this$window$innerWid !== void 0 ? _this$window$innerWid : 0)) {
173
- _this.onSwipeBackSuccess();
174
- } else if (speed > 250 || _this.state.swipeBackStartX + _this.state.swipeBackShift > _this.window.innerWidth / 2) {
175
- _this.setState({
176
- swipeBackResult: SwipeBackResults.success
177
- });
178
- } else {
179
- _this.setState({
180
- swipeBackResult: SwipeBackResults.fail
181
- });
182
- }
183
- }
184
- });
185
- _this.state = {
186
- animated: false,
187
- visiblePanels: [props.activePanel],
188
- activePanel: props.activePanel,
189
- isBack: undefined,
190
- prevPanel: null,
191
- nextPanel: null,
192
- swipingBack: false,
193
- swipeBackStartX: 0,
194
- swipeBackShift: 0,
195
- swipeBackNextPanel: null,
196
- swipeBackPrevPanel: null,
197
- swipeBackResult: null,
198
- browserSwipe: false
213
+ setPrevPanel(null);
214
+ setNextPanel(null);
215
+ setVisiblePanels([activePanelProp]);
216
+ setActivePanel(activePanelProp);
217
+ setAnimated(false);
218
+ setIsBack(undefined);
219
+
220
+ afterTransition.current = function () {
221
+ scroll === null || scroll === void 0 ? void 0 : scroll.scrollTo(0, isBackTransition ? scrolls.current[activePanelProp] : 0);
222
+ onTransition && onTransition({
223
+ isBack: isBackTransition,
224
+ from: prevPanel,
225
+ to: activePanelProp
226
+ });
199
227
  };
200
- return _this;
201
- }
202
-
203
- (0, _createClass2.default)(ViewComponent, [{
204
- key: "document",
205
- get: function get() {
206
- return this.props.document;
207
- }
208
- }, {
209
- key: "window",
210
- get: function get() {
211
- return this.props.window;
228
+ }, [activePanelProp, onTransition, scroll]);
229
+ (0, _useIsomorphicLayoutEffect.useIsomorphicLayoutEffect)(function () {
230
+ afterTransition.current();
231
+ afterTransition.current = _utils2.noop;
232
+ }, [afterTransition.current]);
233
+ var transitionEndHandler = React.useCallback(function (e) {
234
+ if ((!e || ["vkui-animation-ios-next-forward", "vkui-animation-ios-prev-back", "vkui-animation-view-next-forward", "vkui-animation-view-prev-back"].includes(e.animationName)) && prevPanel !== null) {
235
+ flushTransition(prevPanel, Boolean(isBack));
212
236
  }
213
- }, {
214
- key: "panels",
215
- get: function get() {
216
- return React.Children.toArray(this.props.children);
217
- }
218
- }, {
219
- key: "componentDidMount",
220
- value: function componentDidMount() {
221
- if (process.env.NODE_ENV === "development") {
222
- var _this$props2 = this.props,
223
- popout = _this$props2.popout,
224
- modal = _this$props2.modal;
225
- popout && warn("Свойство popout устарело и будет удалено в 5.0.0. Используйте одноименное свойство у SplitLayout.");
226
- modal && warn("Свойство modal устарело и будет удалено в 5.0.0. Используйте одноименное свойство у SplitLayout.");
237
+ }, [flushTransition, isBack, prevPanel]);
238
+
239
+ var _useWaitTransitionFin = (0, _useWaitTransitionFinish.useWaitTransitionFinish)(),
240
+ waitTransitionFinish = _useWaitTransitionFin.waitTransitionFinish;
241
+
242
+ var animationFinishTimeout = (0, _useTimeout.useTimeout)(transitionEndHandler, platform === _platform.IOS ? 600 : 300);
243
+ var onSwipeBackSuccess = React.useCallback(function () {
244
+ onSwipeBack && onSwipeBack();
245
+ }, [onSwipeBack]);
246
+ var onSwipeBackCancel = React.useCallback(function () {
247
+ onSwipeBackCancelProp && onSwipeBackCancelProp();
248
+ setSwipeBackPrevPanel(null);
249
+ setSwipeBackNextPanel(null);
250
+ setSwipingBack(false);
251
+ setSwipeBackResult(null);
252
+ setSwipeBackStartX(0);
253
+ setSwipeBackShift(0);
254
+ }, [onSwipeBackCancelProp]);
255
+ var swipingBackTransitionEndHandler = React.useCallback(function (e) {
256
+ // indexOf because of vendor prefixes in old browsers
257
+ if (!e || e !== null && e !== void 0 && e.propertyName.includes("transform") && (e === null || e === void 0 ? void 0 : e.target) === pickPanel(swipeBackNextPanel)) {
258
+ switch (swipeBackResult) {
259
+ case SwipeBackResults.fail:
260
+ onSwipeBackCancel();
261
+ break;
262
+
263
+ case SwipeBackResults.success:
264
+ onSwipeBackSuccess();
227
265
  }
228
266
  }
229
- }, {
230
- key: "componentWillUnmount",
231
- value: function componentWillUnmount() {
232
- var id = (0, _getNavId.getNavId)(this.props);
267
+ }, [onSwipeBackCancel, onSwipeBackSuccess, swipeBackNextPanel, swipeBackResult]);
233
268
 
234
- if (id) {
235
- scrollsCache[id] = this.scrolls;
236
- }
237
-
238
- if (this.animationFinishTimeout) {
239
- clearTimeout(this.animationFinishTimeout);
240
- }
269
+ var onMoveX = function onMoveX(e) {
270
+ if ((0, _utils.swipeBackExcluded)(e)) {
271
+ return;
241
272
  }
242
- }, {
243
- key: "componentDidUpdate",
244
- value: function componentDidUpdate(prevProps, prevState) {
245
- var _this2 = this;
246
273
 
247
- this.props.popout && !prevProps.popout && this.blurActiveElement();
248
- this.props.modal && !prevProps.modal && this.blurActiveElement(); // Нужен переход
249
-
250
- if (prevProps.activePanel !== this.props.activePanel && !prevState.swipingBack && !prevState.browserSwipe) {
251
- var _this$props$scroll2;
274
+ if (platform === _platform.IOS && !(configProvider !== null && configProvider !== void 0 && configProvider.isWebView) && (e.startX <= 70 || e.startX >= window.innerWidth - 70) && !browserSwipe) {
275
+ setBrowserSwipe(true);
276
+ }
252
277
 
253
- var firstLayerId = this.panels.map(function (panel) {
254
- return (0, _getNavId.getNavId)(panel.props, warn);
255
- }).find(function (id) {
256
- return id === prevProps.activePanel || id === _this2.props.activePanel;
257
- });
258
- var isBack = firstLayerId === this.props.activePanel;
259
- this.scrolls[prevProps.activePanel] = (_this$props$scroll2 = this.props.scroll) === null || _this$props$scroll2 === void 0 ? void 0 : _this$props$scroll2.getScroll().y;
278
+ if (platform === _platform.IOS && configProvider !== null && configProvider !== void 0 && configProvider.isWebView && onSwipeBack) {
279
+ if (animated && e.startX <= 70 || !window) {
280
+ return;
281
+ }
260
282
 
261
- if (this.shouldDisableTransitionMotion()) {
262
- this.flushTransition(prevProps.activePanel, isBack);
263
- } else {
264
- this.blurActiveElement();
265
- this.setState({
266
- visiblePanels: [prevProps.activePanel, this.props.activePanel],
267
- prevPanel: prevProps.activePanel,
268
- nextPanel: this.props.activePanel,
269
- activePanel: null,
270
- animated: true,
271
- isBack: isBack
272
- }); // Фолбек анимации перехода
273
-
274
- if (!_supportEvents.animationEvent.supported) {
275
- if (this.animationFinishTimeout) {
276
- clearTimeout(this.animationFinishTimeout);
277
- }
278
-
279
- this.animationFinishTimeout = setTimeout(this.transitionEndHandler, this.props.platform === _platform.IOS ? 600 : 300);
280
- }
283
+ if (e.startX <= 70 && !swipingBack && history && history.length > 1) {
284
+ if (activePanel !== null) {
285
+ scrolls.current[activePanel] = scroll === null || scroll === void 0 ? void 0 : scroll.getScroll().y;
281
286
  }
282
- } // Закончилась анимация свайпа назад
283
287
 
288
+ setSwipingBack(true);
289
+ setSwipeBackStartX(e.startX);
290
+ setSwipeBackPrevPanel(activePanel);
291
+ setSwipeBackNextPanel(history.slice(-2)[0]);
292
+ }
284
293
 
285
- if (prevProps.activePanel !== this.props.activePanel && prevState.swipingBack) {
286
- var nextPanel = this.props.activePanel;
287
- var prevPanel = prevProps.activePanel;
294
+ if (swipingBack) {
295
+ var _swipeBackShift = 0;
288
296
 
289
- if (prevState.swipeBackPrevPanel !== null) {
290
- this.scrolls[prevState.swipeBackPrevPanel] = 0;
297
+ if (e.shiftX < 0) {
298
+ _swipeBackShift = 0;
299
+ } else if (e.shiftX > window.innerWidth - swipeBackStartX) {
300
+ _swipeBackShift = window === null || window === void 0 ? void 0 : window.innerWidth;
301
+ } else {
302
+ _swipeBackShift = e.shiftX;
291
303
  }
292
304
 
293
- this.setState({
294
- swipeBackPrevPanel: null,
295
- swipeBackNextPanel: null,
296
- swipingBack: false,
297
- swipeBackResult: null,
298
- swipeBackStartX: 0,
299
- swipeBackShift: 0,
300
- activePanel: nextPanel,
301
- visiblePanels: [nextPanel]
302
- }, function () {
303
- if (_this2.state.activePanel !== null) {
304
- var _this2$props$scroll;
305
-
306
- (_this2$props$scroll = _this2.props.scroll) === null || _this2$props$scroll === void 0 ? void 0 : _this2$props$scroll.scrollTo(0, _this2.scrolls[_this2.state.activePanel]);
307
- }
308
-
309
- prevProps.onTransition && prevProps.onTransition({
310
- isBack: true,
311
- from: prevPanel,
312
- to: nextPanel
313
- });
314
- });
315
- } // Начался свайп назад
316
-
305
+ setSwipeBackShift(_swipeBackShift);
306
+ }
307
+ }
308
+ };
317
309
 
318
- if (!prevState.swipingBack && this.state.swipingBack) {
319
- this.props.onSwipeBackStart && this.props.onSwipeBackStart();
320
- } // Началась анимация завершения свайпа назад.
310
+ var onEnd = React.useCallback(function (e) {
311
+ if (swipingBack && window) {
312
+ var _window$innerWidth;
321
313
 
314
+ var speed = swipeBackShift / e.duration * 1000;
322
315
 
323
- if (!prevState.swipeBackResult && this.state.swipeBackResult) {
324
- this.waitTransitionFinish(this.pickPanel(this.state.swipeBackNextPanel), this.swipingBackTransitionEndHandler);
325
- } // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)
316
+ if (swipeBackShift === 0) {
317
+ onSwipeBackCancel();
318
+ } else if (swipeBackShift >= ((_window$innerWidth = window === null || window === void 0 ? void 0 : window.innerWidth) !== null && _window$innerWidth !== void 0 ? _window$innerWidth : 0)) {
319
+ onSwipeBackSuccess();
320
+ } else if (speed > 250 || swipeBackStartX + swipeBackShift > window.innerWidth / 2) {
321
+ setSwipeBackResult(SwipeBackResults.success);
322
+ } else {
323
+ setSwipeBackResult(SwipeBackResults.fail);
324
+ }
325
+ }
326
+ }, [onSwipeBackCancel, onSwipeBackSuccess, swipeBackShift, swipeBackStartX, swipingBack, window]);
326
327
 
328
+ var calcPanelSwipeStyles = function calcPanelSwipeStyles(panelId) {
329
+ if (!_dom.canUseDOM || !window) {
330
+ return {};
331
+ }
327
332
 
328
- if (prevState.swipeBackResult === SwipeBackResults.fail && !this.state.swipeBackResult && this.state.activePanel !== null) {
329
- var _this$props$scroll3;
333
+ var isPrev = panelId === swipeBackPrevPanel;
334
+ var isNext = panelId === swipeBackNextPanel;
330
335
 
331
- (_this$props$scroll3 = this.props.scroll) === null || _this$props$scroll3 === void 0 ? void 0 : _this$props$scroll3.scrollTo(0, this.scrolls[this.state.activePanel]);
332
- } // Закончился Safari свайп
336
+ if (!isPrev && !isNext || swipeBackResult) {
337
+ return {};
338
+ }
333
339
 
340
+ var prevPanelTranslate = "".concat(swipeBackShift, "px");
341
+ var nextPanelTranslate = "".concat(-50 + swipeBackShift * 100 / window.innerWidth / 2, "%");
342
+ var prevPanelShadow = 0.3 * (window.innerWidth - swipeBackShift) / window.innerWidth;
334
343
 
335
- if (prevProps.activePanel !== this.props.activePanel && this.state.browserSwipe) {
336
- this.setState({
337
- browserSwipe: false,
338
- nextPanel: null,
339
- prevPanel: null,
340
- animated: false,
341
- visiblePanels: [this.props.activePanel],
342
- activePanel: this.props.activePanel
343
- });
344
- }
344
+ if (swipeBackResult) {
345
+ return isPrev ? {
346
+ boxShadow: "-2px 0 12px rgba(0, 0, 0, ".concat(prevPanelShadow, ")")
347
+ } : {};
345
348
  }
346
- }, {
347
- key: "shouldDisableTransitionMotion",
348
- value: function shouldDisableTransitionMotion() {
349
- var _this$props$configPro, _this$props$splitCol;
350
349
 
351
- return ((_this$props$configPro = this.props.configProvider) === null || _this$props$configPro === void 0 ? void 0 : _this$props$configPro.transitionMotionEnabled) === false || !((_this$props$splitCol = this.props.splitCol) !== null && _this$props$splitCol !== void 0 && _this$props$splitCol.animate);
350
+ if (isNext) {
351
+ return {
352
+ transform: "translate3d(".concat(nextPanelTranslate, ", 0, 0)"),
353
+ WebkitTransform: "translate3d(".concat(nextPanelTranslate, ", 0, 0)")
354
+ };
352
355
  }
353
- }, {
354
- key: "waitTransitionFinish",
355
- value: function waitTransitionFinish(elem, eventHandler) {
356
- if (_supportEvents.transitionEvent.supported && _supportEvents.transitionEvent.name && elem) {
357
- elem.removeEventListener(_supportEvents.transitionEvent.name, eventHandler);
358
- elem.addEventListener(_supportEvents.transitionEvent.name, eventHandler);
359
- } else {
360
- if (this.transitionFinishTimeout) {
361
- clearTimeout(this.transitionFinishTimeout);
362
- }
363
356
 
364
- this.transitionFinishTimeout = setTimeout(eventHandler, this.props.platform === _platform.IOS ? 600 : 300);
365
- }
357
+ if (isPrev) {
358
+ return {
359
+ transform: "translate3d(".concat(prevPanelTranslate, ", 0, 0)"),
360
+ WebkitTransform: "translate3d(".concat(prevPanelTranslate, ", 0, 0)"),
361
+ boxShadow: "-2px 0 12px rgba(0, 0, 0, ".concat(prevPanelShadow, ")")
362
+ };
366
363
  }
367
- }, {
368
- key: "blurActiveElement",
369
- value: function blurActiveElement() {
370
- var _this$document;
371
364
 
372
- if (typeof this.window !== "undefined" && (_this$document = this.document) !== null && _this$document !== void 0 && _this$document.activeElement) {
373
- this.document.activeElement.blur();
374
- }
375
- }
376
- }, {
377
- key: "pickPanel",
378
- value: function pickPanel(id) {
379
- if (id === null) {
380
- return undefined;
365
+ return {};
366
+ };
367
+
368
+ React.useEffect(function () {
369
+ popout && (0, _dom.blurActiveElement)(document);
370
+ }, [document, popout]);
371
+ React.useEffect(function () {
372
+ modal && (0, _dom.blurActiveElement)(document);
373
+ }, [document, modal]);
374
+ React.useEffect(function () {
375
+ // Нужен переход
376
+ if (prevActivePanel && prevActivePanel !== activePanelProp && !prevSwipingBack && !prevBrowserSwipe) {
377
+ var firstLayerId = React.Children.toArray(children).map(function (panel) {
378
+ return (0, _getNavId.getNavId)(panel.props, warn);
379
+ }).find(function (id) {
380
+ return id === prevActivePanel || id === activePanelProp;
381
+ });
382
+ var isBackTransition = firstLayerId === activePanelProp;
383
+ scrolls.current[prevActivePanel] = scroll === null || scroll === void 0 ? void 0 : scroll.getScroll().y;
384
+
385
+ if (disableAnimation) {
386
+ flushTransition(prevActivePanel, isBackTransition);
387
+ } else {
388
+ (0, _dom.blurActiveElement)(document);
389
+ setVisiblePanels([prevActivePanel, activePanelProp]);
390
+ setPrevPanel(prevActivePanel);
391
+ setNextPanel(activePanelProp);
392
+ setActivePanel(null);
393
+ setAnimated(true);
394
+ setIsBack(isBackTransition); // Фолбек анимации перехода
395
+
396
+ if (!_supportEvents.animationEvent.supported) {
397
+ animationFinishTimeout.set();
398
+ }
381
399
  }
400
+ } // Закончилась анимация свайпа назад
382
401
 
383
- return this.panelNodes[id];
384
- }
385
- }, {
386
- key: "flushTransition",
387
- value: function flushTransition(prevPanel, isBack) {
388
- var _this3 = this;
389
402
 
390
- var activePanel = this.props.activePanel;
403
+ if (prevActivePanel && prevActivePanel !== activePanelProp && prevSwipingBack) {
404
+ var _nextPanel = activePanelProp;
405
+ var _prevPanel = prevActivePanel;
391
406
 
392
- if (isBack) {
393
- this.scrolls[prevPanel] = 0;
407
+ if (prevSwipeBackPrevPanel) {
408
+ scrolls.current[prevSwipeBackPrevPanel] = 0;
394
409
  }
395
410
 
396
- this.setState({
397
- prevPanel: null,
398
- nextPanel: null,
399
- visiblePanels: [activePanel],
400
- activePanel: activePanel,
401
- animated: false,
402
- isBack: undefined
403
- }, function () {
404
- var _this3$props$scroll;
405
-
406
- (_this3$props$scroll = _this3.props.scroll) === null || _this3$props$scroll === void 0 ? void 0 : _this3$props$scroll.scrollTo(0, isBack ? _this3.scrolls[activePanel] : 0);
407
- _this3.props.onTransition && _this3.props.onTransition({
408
- isBack: isBack,
409
- from: prevPanel,
410
- to: activePanel
411
+ setSwipeBackPrevPanel(null);
412
+ setSwipeBackNextPanel(null);
413
+ setSwipingBack(false);
414
+ setSwipeBackResult(null);
415
+ setSwipeBackStartX(0);
416
+ setSwipeBackShift(0);
417
+ setActivePanel(_nextPanel);
418
+ setVisiblePanels([_nextPanel]);
419
+
420
+ afterTransition.current = function () {
421
+ if (_nextPanel !== null) {
422
+ scroll === null || scroll === void 0 ? void 0 : scroll.scrollTo(0, scrolls.current[_nextPanel]);
423
+ }
424
+
425
+ prevOnTransition && prevOnTransition({
426
+ isBack: true,
427
+ from: _prevPanel,
428
+ to: _nextPanel
411
429
  });
412
- });
413
- }
414
- }, {
415
- key: "onSwipeBackSuccess",
416
- value: function onSwipeBackSuccess() {
417
- this.props.onSwipeBack && this.props.onSwipeBack();
418
- }
419
- }, {
420
- key: "onSwipeBackCancel",
421
- value: function onSwipeBackCancel() {
422
- this.props.onSwipeBackCancel && this.props.onSwipeBackCancel();
423
- this.setState({
424
- swipeBackPrevPanel: null,
425
- swipeBackNextPanel: null,
426
- swipingBack: false,
427
- swipeBackResult: null,
428
- swipeBackStartX: 0,
429
- swipeBackShift: 0
430
- });
431
- }
432
- }, {
433
- key: "calcPanelSwipeStyles",
434
- value: function calcPanelSwipeStyles(panelId) {
435
- if (!_dom.canUseDOM || !this.window) {
436
- return {};
437
- }
430
+ };
431
+ } // Начался свайп назад
438
432
 
439
- var isPrev = panelId === this.state.swipeBackPrevPanel;
440
- var isNext = panelId === this.state.swipeBackNextPanel;
441
433
 
442
- if (!isPrev && !isNext || this.state.swipeBackResult) {
443
- return {};
444
- }
434
+ if (!prevSwipingBack && swipingBack) {
435
+ onSwipeBackStart && onSwipeBackStart();
436
+ } // Началась анимация завершения свайпа назад.
445
437
 
446
- var prevPanelTranslate = "".concat(this.state.swipeBackShift, "px");
447
- var nextPanelTranslate = "".concat(-50 + this.state.swipeBackShift * 100 / this.window.innerWidth / 2, "%");
448
- var prevPanelShadow = 0.3 * (this.window.innerWidth - this.state.swipeBackShift) / this.window.innerWidth;
449
438
 
450
- if (this.state.swipeBackResult) {
451
- return isPrev ? {
452
- boxShadow: "-2px 0 12px rgba(0, 0, 0, ".concat(prevPanelShadow, ")")
453
- } : {};
454
- }
439
+ if (!prevSwipeBackResult && swipeBackResult) {
440
+ waitTransitionFinish(pickPanel(swipeBackNextPanel), swipingBackTransitionEndHandler, platform === _platform.IOS ? 600 : 300);
441
+ } // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)
455
442
 
456
- if (isNext) {
457
- return {
458
- transform: "translate3d(".concat(nextPanelTranslate, ", 0, 0)"),
459
- WebkitTransform: "translate3d(".concat(nextPanelTranslate, ", 0, 0)")
460
- };
461
- }
462
443
 
463
- if (isPrev) {
464
- return {
465
- transform: "translate3d(".concat(prevPanelTranslate, ", 0, 0)"),
466
- WebkitTransform: "translate3d(".concat(prevPanelTranslate, ", 0, 0)"),
467
- boxShadow: "-2px 0 12px rgba(0, 0, 0, ".concat(prevPanelShadow, ")")
468
- };
469
- }
444
+ if (prevSwipeBackResult === SwipeBackResults.fail && !swipeBackResult && activePanel !== null) {
445
+ scroll === null || scroll === void 0 ? void 0 : scroll.scrollTo(0, scrolls.current[activePanel]);
446
+ } // Закончился Safari свайп
470
447
 
471
- return {};
472
- }
473
- }, {
474
- key: "render",
475
- value: function render() {
476
- var _this4 = this;
477
-
478
- var _this$props3 = this.props,
479
- popout = _this$props3.popout,
480
- modal = _this$props3.modal,
481
- platform = _this$props3.platform,
482
- _1 = _this$props3.activePanel,
483
- splitCol = _this$props3.splitCol,
484
- configProvider = _this$props3.configProvider,
485
- history = _this$props3.history,
486
- nav = _this$props3.nav,
487
- onTransition = _this$props3.onTransition,
488
- onSwipeBack = _this$props3.onSwipeBack,
489
- onSwipeBackStart = _this$props3.onSwipeBackStart,
490
- onSwipeBackCancel = _this$props3.onSwipeBackCancel,
491
- window = _this$props3.window,
492
- document = _this$props3.document,
493
- scroll = _this$props3.scroll,
494
- restProps = (0, _objectWithoutProperties2.default)(_this$props3, _excluded);
495
- var _this$state = this.state,
496
- prevPanel = _this$state.prevPanel,
497
- nextPanel = _this$state.nextPanel,
498
- activePanel = _this$state.activePanel,
499
- swipeBackPrevPanel = _this$state.swipeBackPrevPanel,
500
- swipeBackNextPanel = _this$state.swipeBackNextPanel,
501
- swipeBackResult = _this$state.swipeBackResult,
502
- isBack = _this$state.isBack,
503
- animated = _this$state.animated;
504
- var hasPopout = !!popout;
505
- var hasModal = !!modal;
506
- var panels = this.panels.filter(function (panel) {
507
- var panelId = (0, _getNavId.getNavId)(panel.props, warn);
508
- return panelId !== undefined && _this4.state.visiblePanels.includes(panelId) || panelId === swipeBackPrevPanel || panelId === swipeBackNextPanel;
509
- });
510
- var disableAnimation = this.shouldDisableTransitionMotion();
511
- return (0, _jsxRuntime.createScopedElement)(_Touch.Touch, (0, _extends2.default)({
512
- Component: "section"
513
- }, restProps, {
514
- vkuiClass: (0, _classNames.classNames)("View", platform === _platform.IOS && "View--ios", !disableAnimation && animated && "View--animated", !disableAnimation && this.state.swipingBack && "View--swiping-back", disableAnimation && "View--no-motion"),
515
- onMoveX: this.onMoveX,
516
- onEnd: this.onEnd
517
- }), (0, _jsxRuntime.createScopedElement)("div", {
518
- vkuiClass: "View__panels"
519
- }, panels.map(function (panel) {
520
- var _this4$scrolls;
521
-
522
- var panelId = (0, _getNavId.getNavId)(panel.props, warn);
523
- var isPrev = panelId === prevPanel || panelId === swipeBackPrevPanel;
524
- var isTransitionTarget = animated && panelId === (isBack ? prevPanel : nextPanel);
525
- var compensateScroll = isPrev || panelId === swipeBackNextPanel || panelId === nextPanel && isBack;
526
- return (0, _jsxRuntime.createScopedElement)("div", {
527
- vkuiClass: (0, _classNames.classNames)("View__panel", panelId === activePanel && "View__panel--active", panelId === prevPanel && "View__panel--prev", panelId === nextPanel && "View__panel--next", panelId === swipeBackPrevPanel && "View__panel--swipe-back-prev", panelId === swipeBackNextPanel && "View__panel--swipe-back-next", swipeBackResult === SwipeBackResults.success && "View__panel--swipe-back-success", swipeBackResult === SwipeBackResults.fail && "View__panel--swipe-back-failed"),
528
- onAnimationEnd: isTransitionTarget ? _this4.transitionEndHandler : undefined,
529
- ref: function ref(el) {
530
- return panelId !== undefined && (_this4.panelNodes[panelId] = el);
531
- },
532
- style: _this4.calcPanelSwipeStyles(panelId),
533
- key: panelId
534
- }, (0, _jsxRuntime.createScopedElement)("div", {
535
- vkuiClass: "View__panel-in",
536
- style: {
537
- marginTop: compensateScroll ? -((_this4$scrolls = _this4.scrolls[panelId]) !== null && _this4$scrolls !== void 0 ? _this4$scrolls : 0) : undefined
538
- }
539
- }, (0, _jsxRuntime.createScopedElement)(_NavTransitionContext.NavTransitionProvider, {
540
- entering: panelId === nextPanel || panelId === swipeBackNextPanel
541
- }, panel)));
542
- })), (0, _jsxRuntime.createScopedElement)(_AppRootPortal.AppRootPortal, null, hasPopout && (0, _jsxRuntime.createScopedElement)("div", {
543
- vkuiClass: "View__popout"
544
- }, popout), hasModal && (0, _jsxRuntime.createScopedElement)("div", {
545
- vkuiClass: "View__modal"
546
- }, modal)));
547
- }
548
- }]);
549
- return ViewComponent;
550
- }(React.Component);
551
- /**
552
- * @see https://vkcom.github.io/VKUI/#/View
553
- */
554
448
 
449
+ if (prevActivePanel !== activePanelProp && browserSwipe) {
450
+ setBrowserSwipe(false);
451
+ setNextPanel(null);
452
+ setPrevPanel(null);
453
+ setAnimated(false);
454
+ setVisiblePanels([activePanelProp]);
455
+ setActivePanel(activePanelProp);
456
+ }
457
+ }, [activePanelProp, activePanel, animationFinishTimeout, browserSwipe, children, disableAnimation, document, flushTransition, onSwipeBackStart, panels, platform, prevActivePanel, prevBrowserSwipe, prevOnTransition, prevSwipeBackPrevPanel, prevSwipeBackResult, prevSwipingBack, scroll, swipeBackNextPanel, swipeBackResult, swipingBack, swipingBackTransitionEndHandler, waitTransitionFinish]);
458
+ return (0, _jsxRuntime.createScopedElement)(_Touch.Touch, (0, _extends2.default)({
459
+ Component: "section"
460
+ }, restProps, {
461
+ vkuiClass: (0, _classNames.classNames)("View", platform === _platform.IOS && "View--ios", !disableAnimation && animated && "View--animated", !disableAnimation && swipingBack && "View--swiping-back", disableAnimation && "View--no-motion"),
462
+ onMoveX: onMoveX,
463
+ onEnd: onEnd
464
+ }), (0, _jsxRuntime.createScopedElement)("div", {
465
+ vkuiClass: "View__panels"
466
+ }, panels.map(function (panel) {
467
+ var _scrolls$current;
468
+
469
+ var panelId = (0, _getNavId.getNavId)(panel.props, warn);
470
+ var isPrev = panelId === prevPanel || panelId === swipeBackPrevPanel;
471
+ var isTransitionTarget = animated && panelId === (isBack ? prevPanel : nextPanel);
472
+ var compensateScroll = isPrev || panelId === swipeBackNextPanel || panelId === nextPanel && isBack;
473
+ return (0, _jsxRuntime.createScopedElement)("div", {
474
+ vkuiClass: (0, _classNames.classNames)("View__panel", panelId === activePanel && "View__panel--active", panelId === prevPanel && "View__panel--prev", panelId === nextPanel && "View__panel--next", panelId === swipeBackPrevPanel && "View__panel--swipe-back-prev", panelId === swipeBackNextPanel && "View__panel--swipe-back-next", swipeBackResult === SwipeBackResults.success && "View__panel--swipe-back-success", swipeBackResult === SwipeBackResults.fail && "View__panel--swipe-back-failed"),
475
+ onAnimationEnd: isTransitionTarget ? transitionEndHandler : undefined,
476
+ ref: function ref(el) {
477
+ return panelId !== undefined && (panelNodes.current[panelId] = el);
478
+ },
479
+ style: calcPanelSwipeStyles(panelId),
480
+ key: panelId
481
+ }, (0, _jsxRuntime.createScopedElement)("div", {
482
+ vkuiClass: "View__panel-in",
483
+ style: {
484
+ marginTop: compensateScroll ? -((_scrolls$current = scrolls.current[panelId]) !== null && _scrolls$current !== void 0 ? _scrolls$current : 0) : undefined
485
+ }
486
+ }, (0, _jsxRuntime.createScopedElement)(_NavTransitionContext.NavTransitionProvider, {
487
+ entering: panelId === nextPanel || panelId === swipeBackNextPanel
488
+ }, panel)));
489
+ })), (0, _jsxRuntime.createScopedElement)(_AppRootPortal.AppRootPortal, null, hasPopout && (0, _jsxRuntime.createScopedElement)("div", {
490
+ vkuiClass: "View__popout"
491
+ }, popout), hasModal && (0, _jsxRuntime.createScopedElement)("div", {
492
+ vkuiClass: "View__modal"
493
+ }, modal)));
494
+ };
555
495
 
556
- (0, _defineProperty2.default)(ViewComponent, "defaultProps", {
557
- history: []
558
- });
559
- var View = (0, _withContext.withContext)((0, _withContext.withContext)((0, _withContext.withContext)((0, _withPlatform.withPlatform)((0, _dom.withDOM)(ViewComponent)), _SplitCol.SplitColContext, "splitCol"), _ConfigProviderContext.ConfigProviderContext, "configProvider"), _ScrollContext.ScrollContext, "scroll");
560
496
  exports.View = View;
561
- View.displayName = "View";
562
497
  //# sourceMappingURL=View.js.map