@vkontakte/vkui 4.35.4 → 4.37.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 (1275) hide show
  1. package/.cache/.eslintcache +1 -1
  2. package/.cache/.stylelintcache +1 -1
  3. package/.cache/.tsbuildinfo +21771 -18514
  4. package/.cache/ts/src/components/ActionSheet/ActionSheetDefaultIosCloseItem.d.ts +3 -0
  5. package/.cache/ts/src/components/ActionSheetItem/ActionSheetItem.d.ts +5 -1
  6. package/.cache/ts/src/components/AdaptivityProvider/AdaptivityProvider.d.ts +4 -4
  7. package/.cache/ts/src/components/AppRoot/AppRoot.d.ts +1 -1
  8. package/.cache/ts/src/components/Calendar/Calendar.d.ts +3 -2
  9. package/.cache/ts/src/components/CalendarDay/CalendarDay.d.ts +4 -2
  10. package/.cache/ts/src/components/CalendarDays/CalendarDays.d.ts +3 -1
  11. package/.cache/ts/src/components/CalendarHeader/CalendarHeader.d.ts +6 -1
  12. package/.cache/ts/src/components/Checkbox/Checkbox.d.ts +1 -1
  13. package/.cache/ts/src/components/Chip/Chip.d.ts +12 -5
  14. package/.cache/ts/src/components/ChipsInput/ChipsInput.d.ts +5 -26
  15. package/.cache/ts/src/components/ChipsInputBase/ChipsInputBase.d.ts +17 -0
  16. package/.cache/ts/src/components/ChipsSelect/ChipsSelect.d.ts +6 -4
  17. package/.cache/ts/src/components/CustomSelect/CustomSelect.d.ts +1 -1
  18. package/.cache/ts/src/components/DateInput/DateInput.d.ts +4 -2
  19. package/.cache/ts/src/components/DateRangeInput/DateRangeInput.d.ts +4 -2
  20. package/.cache/ts/src/components/DropdownIcon/DropdownIcon.d.ts +4 -2
  21. package/.cache/ts/src/components/FormField/FormField.d.ts +2 -1
  22. package/.cache/ts/src/components/FormLayoutGroup/FormLayoutGroup.d.ts +5 -1
  23. package/.cache/ts/src/components/FormStatus/FormStatus.d.ts +1 -0
  24. package/.cache/ts/src/components/Group/Group.d.ts +5 -1
  25. package/.cache/ts/src/components/Input/Input.d.ts +1 -1
  26. package/.cache/ts/src/components/List/List.d.ts +2 -1
  27. package/.cache/ts/src/components/ModalPage/ModalPage.d.ts +13 -1
  28. package/.cache/ts/src/components/NativeSelect/NativeSelect.d.ts +3 -2
  29. package/.cache/ts/src/components/Radio/Radio.d.ts +1 -1
  30. package/.cache/ts/src/components/Select/Select.d.ts +1 -1
  31. package/.cache/ts/src/components/SelectMimicry/SelectMimicry.d.ts +2 -2
  32. package/.cache/ts/src/components/SimpleCell/SimpleCell.d.ts +34 -1
  33. package/.cache/ts/src/components/SubnavigationButton/SubnavigationButton.d.ts +3 -2
  34. package/.cache/ts/src/components/Tappable/Tappable.d.ts +2 -1
  35. package/.cache/ts/src/components/Textarea/Textarea.d.ts +3 -2
  36. package/.cache/ts/src/components/UsersStack/UsersStack.d.ts +7 -1
  37. package/.cache/ts/src/{components/ChipsInput → hooks}/useChipsInput.d.ts +4 -3
  38. package/{dist/cssm/components/ChipsSelect → .cache/ts/src/hooks}/useChipsSelect.d.ts +4 -4
  39. package/.cache/ts/src/index.d.ts +5 -0
  40. package/.cache/ts/src/tokenized/index.d.ts +58 -0
  41. package/.eslintrc.json +2 -1
  42. package/README.md +3 -2
  43. package/dist/appearance/constants.js.map +1 -1
  44. package/dist/cjs/appearance/constants.js.map +1 -1
  45. package/dist/cjs/components/ActionSheet/ActionSheet.js +4 -4
  46. package/dist/cjs/components/ActionSheet/ActionSheet.js.map +1 -1
  47. package/dist/cjs/components/ActionSheet/ActionSheetContext.js.map +1 -1
  48. package/dist/cjs/components/ActionSheet/ActionSheetDefaultIosCloseItem.js +24 -0
  49. package/dist/cjs/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -0
  50. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js +10 -8
  51. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  52. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js +4 -5
  53. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  54. package/dist/cjs/components/ActionSheet/types.js.map +1 -1
  55. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js +15 -39
  56. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  57. package/dist/cjs/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  58. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js +2 -3
  59. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  60. package/dist/cjs/components/Alert/Alert.js +11 -12
  61. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  62. package/dist/cjs/components/AppRoot/AppRoot.js +2 -5
  63. package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
  64. package/dist/cjs/components/AppRoot/AppRootContext.js.map +1 -1
  65. package/dist/cjs/components/AppRoot/AppRootPortal.js.map +1 -1
  66. package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
  67. package/dist/cjs/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  68. package/dist/cjs/components/AppearanceProvider/AppearanceProviderContext.js.map +1 -1
  69. package/dist/cjs/components/Avatar/Avatar.js +4 -17
  70. package/dist/cjs/components/Avatar/Avatar.js.map +1 -1
  71. package/dist/cjs/components/Badge/Badge.js.map +1 -1
  72. package/dist/cjs/components/Banner/Banner.js.map +1 -1
  73. package/dist/cjs/components/BaseGallery/BaseGallery.js +11 -10
  74. package/dist/cjs/components/BaseGallery/BaseGallery.js.map +1 -1
  75. package/dist/cjs/components/BaseGallery/helpers.js.map +1 -1
  76. package/dist/cjs/components/BaseGallery/types.js.map +1 -1
  77. package/dist/cjs/components/Button/Button.js.map +1 -1
  78. package/dist/cjs/components/ButtonGroup/ButtonGroup.js.map +1 -1
  79. package/dist/cjs/components/Calendar/Calendar.js +9 -3
  80. package/dist/cjs/components/Calendar/Calendar.js.map +1 -1
  81. package/dist/cjs/components/CalendarDay/CalendarDay.js +14 -23
  82. package/dist/cjs/components/CalendarDay/CalendarDay.js.map +1 -1
  83. package/dist/cjs/components/CalendarDays/CalendarDays.js +4 -3
  84. package/dist/cjs/components/CalendarDays/CalendarDays.js.map +1 -1
  85. package/dist/cjs/components/CalendarHeader/CalendarHeader.js +10 -4
  86. package/dist/cjs/components/CalendarHeader/CalendarHeader.js.map +1 -1
  87. package/dist/cjs/components/CalendarRange/CalendarRange.js.map +1 -1
  88. package/dist/cjs/components/CalendarTime/CalendarTime.js.map +1 -1
  89. package/dist/cjs/components/Card/Card.js.map +1 -1
  90. package/dist/cjs/components/CardGrid/CardGrid.js.map +1 -1
  91. package/dist/cjs/components/CardScroll/CardScroll.js +2 -5
  92. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  93. package/dist/cjs/components/Cell/Cell.js.map +1 -1
  94. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  95. package/dist/cjs/components/Cell/CellDragger/CellDragger.js.map +1 -1
  96. package/dist/cjs/components/Cell/useDraggable.js.map +1 -1
  97. package/dist/cjs/components/CellButton/CellButton.js.map +1 -1
  98. package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
  99. package/dist/cjs/components/Chip/Chip.js.map +1 -1
  100. package/dist/cjs/components/ChipsInput/ChipsInput.js +15 -198
  101. package/dist/cjs/components/ChipsInput/ChipsInput.js.map +1 -1
  102. package/dist/cjs/components/ChipsInputBase/ChipsInputBase.js +215 -0
  103. package/dist/cjs/components/ChipsInputBase/ChipsInputBase.js.map +1 -0
  104. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +49 -28
  105. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  106. package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
  107. package/dist/cjs/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  108. package/dist/cjs/components/ContentCard/ContentCard.js.map +1 -1
  109. package/dist/cjs/components/Counter/Counter.js.map +1 -1
  110. package/dist/cjs/components/CustomScrollView/CustomScrollView.js.map +1 -1
  111. package/dist/cjs/components/CustomScrollView/useTrackerVisibility.js.map +1 -1
  112. package/dist/cjs/components/CustomSelect/CustomSelect.js +32 -31
  113. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  114. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  115. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  116. package/dist/cjs/components/DateInput/DateInput.js +4 -2
  117. package/dist/cjs/components/DateInput/DateInput.js.map +1 -1
  118. package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
  119. package/dist/cjs/components/DateRangeInput/DateRangeInput.js +4 -2
  120. package/dist/cjs/components/DateRangeInput/DateRangeInput.js.map +1 -1
  121. package/dist/cjs/components/Div/Div.js.map +1 -1
  122. package/dist/cjs/components/Dropdown/Dropdown.js.map +1 -1
  123. package/dist/cjs/components/DropdownIcon/DropdownIcon.js +16 -7
  124. package/dist/cjs/components/DropdownIcon/DropdownIcon.js.map +1 -1
  125. package/dist/cjs/components/Epic/Epic.js.map +1 -1
  126. package/dist/cjs/components/Epic/ScrollSaver.js.map +1 -1
  127. package/dist/cjs/components/File/File.js.map +1 -1
  128. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  129. package/dist/cjs/components/FocusTrap/FocusTrap.js.map +1 -1
  130. package/dist/cjs/components/FocusVisible/FocusVisible.js.map +1 -1
  131. package/dist/cjs/components/Footer/Footer.js.map +1 -1
  132. package/dist/cjs/components/FormField/FormField.js +4 -2
  133. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  134. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  135. package/dist/cjs/components/FormLayout/FormLayout.js.map +1 -1
  136. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js +12 -3
  137. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  138. package/dist/cjs/components/FormStatus/FormStatus.js +4 -6
  139. package/dist/cjs/components/FormStatus/FormStatus.js.map +1 -1
  140. package/dist/cjs/components/Gallery/Gallery.js +2 -0
  141. package/dist/cjs/components/Gallery/Gallery.js.map +1 -1
  142. package/dist/cjs/components/Gradient/Gradient.js.map +1 -1
  143. package/dist/cjs/components/GridAvatar/GridAvatar.js.map +1 -1
  144. package/dist/cjs/components/Group/Group.js +4 -2
  145. package/dist/cjs/components/Group/Group.js.map +1 -1
  146. package/dist/cjs/components/Header/Header.js +3 -11
  147. package/dist/cjs/components/Header/Header.js.map +1 -1
  148. package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
  149. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  150. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  151. package/dist/cjs/components/HoverPopper/HoverPopper.js.map +1 -1
  152. package/dist/cjs/components/IconButton/IconButton.js +4 -3
  153. package/dist/cjs/components/IconButton/IconButton.js.map +1 -1
  154. package/dist/cjs/components/InfoRow/InfoRow.js.map +1 -1
  155. package/dist/cjs/components/InitialsAvatar/InitialsAvatar.js.map +1 -1
  156. package/dist/cjs/components/Input/Input.js +4 -2
  157. package/dist/cjs/components/Input/Input.js.map +1 -1
  158. package/dist/cjs/components/InputLike/InputLike.js.map +1 -1
  159. package/dist/cjs/components/InputLike/InputLikeDivider.js.map +1 -1
  160. package/dist/cjs/components/Link/Link.js.map +1 -1
  161. package/dist/cjs/components/List/List.js.map +1 -1
  162. package/dist/cjs/components/List/ListContext.js.map +1 -1
  163. package/dist/cjs/components/LocaleProviderContext/LocaleProviderContext.js.map +1 -1
  164. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  165. package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
  166. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  167. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.js +1 -6
  168. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  169. package/dist/cjs/components/ModalPage/ModalPage.js +11 -10
  170. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  171. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js +3 -4
  172. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  173. package/dist/cjs/components/ModalRoot/ModalRoot.js +4 -18
  174. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  175. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  176. package/dist/cjs/components/ModalRoot/ModalRootContext.js.map +1 -1
  177. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +3 -11
  178. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  179. package/dist/cjs/components/ModalRoot/constants.js.map +1 -1
  180. package/dist/cjs/components/ModalRoot/types.js.map +1 -1
  181. package/dist/cjs/components/ModalRoot/useModalManager.js.map +1 -1
  182. package/dist/cjs/components/ModalRoot/withModalRootContext.js.map +1 -1
  183. package/dist/cjs/components/NativeSelect/NativeSelect.js +4 -2
  184. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  185. package/dist/cjs/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  186. package/dist/cjs/components/Pagination/Pagination.js.map +1 -1
  187. package/dist/cjs/components/Panel/Panel.js +4 -10
  188. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  189. package/dist/cjs/components/PanelHeader/PanelHeader.js +2 -11
  190. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  191. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js +2 -7
  192. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  193. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js +2 -7
  194. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  195. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.js +1 -1
  196. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  197. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js +4 -2
  198. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  199. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js +4 -8
  200. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  201. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.js +1 -1
  202. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  203. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.js +1 -1
  204. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  205. package/dist/cjs/components/PanelSpinner/PanelSpinner.js.map +1 -1
  206. package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
  207. package/dist/cjs/components/PopoutRoot/PopoutRoot.js.map +1 -1
  208. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  209. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  210. package/dist/cjs/components/PopperArrow/PopperArrow.js.map +1 -1
  211. package/dist/cjs/components/Progress/Progress.js.map +1 -1
  212. package/dist/cjs/components/PromoBanner/PromoBanner.js +2 -7
  213. package/dist/cjs/components/PromoBanner/PromoBanner.js.map +1 -1
  214. package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
  215. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  216. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  217. package/dist/cjs/components/RadioGroup/RadioGroup.js.map +1 -1
  218. package/dist/cjs/components/RangeSlider/RangeSlider.js.map +1 -1
  219. package/dist/cjs/components/RangeSlider/UniversalSlider.js.map +1 -1
  220. package/dist/cjs/components/Removable/Removable.js.map +1 -1
  221. package/dist/cjs/components/RichCell/RichCell.js.map +1 -1
  222. package/dist/cjs/components/RichTooltip/RichTooltip.js.map +1 -1
  223. package/dist/cjs/components/Root/Root.js.map +1 -1
  224. package/dist/cjs/components/ScreenSpinner/Icon48CancelCircle.js.map +1 -1
  225. package/dist/cjs/components/ScreenSpinner/Icon48DoneOutline.js.map +1 -1
  226. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  227. package/dist/cjs/components/Search/Search.js +7 -9
  228. package/dist/cjs/components/Search/Search.js.map +1 -1
  229. package/dist/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
  230. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  231. package/dist/cjs/components/Select/Select.js.map +1 -1
  232. package/dist/cjs/components/SelectMimicry/SelectMimicry.js +4 -2
  233. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  234. package/dist/cjs/components/Separator/Separator.js.map +1 -1
  235. package/dist/cjs/components/SimpleCell/SimpleCell.js +30 -8
  236. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  237. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  238. package/dist/cjs/components/Slider/Slider.js.map +1 -1
  239. package/dist/cjs/components/SliderSwitch/SliderSwitch.js +2 -5
  240. package/dist/cjs/components/SliderSwitch/SliderSwitch.js.map +1 -1
  241. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js +2 -7
  242. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  243. package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
  244. package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
  245. package/dist/cjs/components/Spinner/Spinner.js.map +1 -1
  246. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  247. package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
  248. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js +1 -6
  249. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  250. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js +17 -16
  251. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  252. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  253. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  254. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  255. package/dist/cjs/components/Tabs/Tabs.js.map +1 -1
  256. package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
  257. package/dist/cjs/components/Tappable/Tappable.js +8 -16
  258. package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
  259. package/dist/cjs/components/TextTooltip/TextTooltip.js.map +1 -1
  260. package/dist/cjs/components/Textarea/Textarea.js +4 -2
  261. package/dist/cjs/components/Textarea/Textarea.js.map +1 -1
  262. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  263. package/dist/cjs/components/Tooltip/TooltipContainer.js.map +1 -1
  264. package/dist/cjs/components/Touch/Touch.js.map +1 -1
  265. package/dist/cjs/components/Touch/TouchContext.js.map +1 -1
  266. package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
  267. package/dist/cjs/components/Typography/Footnote/Footnote.js.map +1 -1
  268. package/dist/cjs/components/Typography/Headline/Headline.js.map +1 -1
  269. package/dist/cjs/components/Typography/Paragraph/Paragraph.js.map +1 -1
  270. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  271. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  272. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  273. package/dist/cjs/components/UsersStack/UsersStack.js +75 -37
  274. package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
  275. package/dist/cjs/components/View/View.js +2 -7
  276. package/dist/cjs/components/View/View.js.map +1 -1
  277. package/dist/cjs/components/View/ViewInfinite.js +1 -10
  278. package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
  279. package/dist/cjs/components/View/utils.js.map +1 -1
  280. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.js +1 -4
  281. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -1
  282. package/dist/cjs/components/WriteBar/WriteBar.js.map +1 -1
  283. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  284. package/dist/cjs/helpers/avatar.js.map +1 -1
  285. package/dist/cjs/helpers/getClassName.js.map +1 -1
  286. package/dist/cjs/helpers/getScheme.js.map +1 -1
  287. package/dist/cjs/helpers/math.js.map +1 -1
  288. package/dist/cjs/helpers/scheme.js.map +1 -1
  289. package/dist/cjs/hoc/withAdaptivity.js.map +1 -1
  290. package/dist/cjs/hoc/withContext.js.map +1 -1
  291. package/dist/cjs/hoc/withInsets.js.map +1 -1
  292. package/dist/cjs/hoc/withPlatform.js.map +1 -1
  293. package/dist/cjs/hooks/useAdaptivity.js.map +1 -1
  294. package/dist/cjs/hooks/useAppearance.js.map +1 -1
  295. package/dist/cjs/hooks/useBooleanState.js.map +1 -1
  296. package/dist/cjs/hooks/useBridgeAdaptivity.js.map +1 -1
  297. package/dist/cjs/hooks/useBrowserInfo.js.map +1 -1
  298. package/dist/cjs/hooks/useCalendar.js.map +1 -1
  299. package/dist/cjs/{components/ChipsInput → hooks}/useChipsInput.js +0 -0
  300. package/dist/cjs/hooks/useChipsInput.js.map +1 -0
  301. package/dist/cjs/{components/ChipsSelect → hooks}/useChipsSelect.js +1 -1
  302. package/dist/cjs/hooks/useChipsSelect.js.map +1 -0
  303. package/dist/cjs/hooks/useDateInput.js.map +1 -1
  304. package/dist/cjs/hooks/useEffectDev.js.map +1 -1
  305. package/dist/cjs/hooks/useEnsuredControl.js.map +1 -1
  306. package/dist/cjs/hooks/useEventListener.js.map +1 -1
  307. package/dist/cjs/hooks/useExternRef.js.map +1 -1
  308. package/dist/cjs/hooks/useFocusVisible.js.map +1 -1
  309. package/dist/cjs/hooks/useGlobalEventListener.js.map +1 -1
  310. package/dist/cjs/hooks/useInsets.js.map +1 -1
  311. package/dist/cjs/hooks/useKeyboard.js.map +1 -1
  312. package/dist/cjs/hooks/useKeyboardInputTracker.js.map +1 -1
  313. package/dist/cjs/hooks/useObjectMemo.js.map +1 -1
  314. package/dist/cjs/hooks/useOrientationChange.js.map +1 -1
  315. package/dist/cjs/hooks/usePagination.js.map +1 -1
  316. package/dist/cjs/hooks/usePatchChildrenRef.js.map +1 -1
  317. package/dist/cjs/hooks/usePlatform.js.map +1 -1
  318. package/dist/cjs/hooks/usePrevious.js.map +1 -1
  319. package/dist/cjs/hooks/useTimeout.js.map +1 -1
  320. package/dist/cjs/hooks/useWaitTransitionFinish.js.map +1 -1
  321. package/dist/cjs/index.js +16 -0
  322. package/dist/cjs/index.js.map +1 -1
  323. package/dist/cjs/lib/SSR.js.map +1 -1
  324. package/dist/cjs/lib/accessibility.js.map +1 -1
  325. package/dist/cjs/lib/animate.js +2 -2
  326. package/dist/cjs/lib/animate.js.map +1 -1
  327. package/dist/cjs/lib/browser.js.map +1 -1
  328. package/dist/cjs/lib/calendar.js.map +1 -1
  329. package/dist/cjs/lib/callMultiple.js.map +1 -1
  330. package/dist/cjs/lib/classNames.js.map +1 -1
  331. package/dist/cjs/lib/classScopingMode.js.map +1 -1
  332. package/dist/cjs/lib/date.js.map +1 -1
  333. package/dist/cjs/lib/dom.js.map +1 -1
  334. package/dist/cjs/lib/fx.js.map +1 -1
  335. package/dist/cjs/lib/getNavId.js.map +1 -1
  336. package/dist/cjs/lib/is.js.map +1 -1
  337. package/dist/cjs/lib/isRefObject.js.map +1 -1
  338. package/dist/cjs/lib/jsxRuntime.d.js.map +1 -1
  339. package/dist/cjs/lib/jsxRuntime.js.map +1 -1
  340. package/dist/cjs/lib/offset.js.map +1 -1
  341. package/dist/cjs/lib/platform.js.map +1 -1
  342. package/dist/cjs/lib/polyfills.js.map +1 -1
  343. package/dist/cjs/lib/prefixClass.js.map +1 -1
  344. package/dist/cjs/lib/removeObjectKeys.js.map +1 -1
  345. package/dist/cjs/lib/select.js.map +1 -1
  346. package/dist/cjs/lib/styles.js.map +1 -1
  347. package/dist/cjs/lib/supportEvents.js.map +1 -1
  348. package/dist/cjs/lib/taptic.js.map +1 -1
  349. package/dist/cjs/lib/testing.js +2 -2
  350. package/dist/cjs/lib/testing.js.map +1 -1
  351. package/dist/cjs/lib/touch.js +2 -2
  352. package/dist/cjs/lib/touch.js.map +1 -1
  353. package/dist/cjs/lib/useIsomorphicLayoutEffect.js.map +1 -1
  354. package/dist/cjs/lib/utils.js.map +1 -1
  355. package/dist/cjs/lib/warnOnce.js.map +1 -1
  356. package/dist/cjs/tokenized/index.js +240 -0
  357. package/dist/cjs/tokenized/index.js.map +1 -1
  358. package/dist/cjs/types.js.map +1 -1
  359. package/dist/cjs/unstable/index.js.map +1 -1
  360. package/dist/components/ActionSheet/ActionSheet.js +4 -4
  361. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  362. package/dist/components/ActionSheet/ActionSheetContext.js.map +1 -1
  363. package/dist/components/ActionSheet/ActionSheetDefaultIosCloseItem.d.ts +3 -0
  364. package/dist/components/ActionSheet/ActionSheetDefaultIosCloseItem.js +10 -0
  365. package/dist/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -0
  366. package/dist/components/ActionSheet/ActionSheetDropdown.js +7 -7
  367. package/dist/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  368. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js +3 -4
  369. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  370. package/dist/components/ActionSheet/types.js.map +1 -1
  371. package/dist/components/ActionSheetItem/ActionSheetItem.d.ts +5 -1
  372. package/dist/components/ActionSheetItem/ActionSheetItem.js +16 -36
  373. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  374. package/dist/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  375. package/dist/components/AdaptivityProvider/AdaptivityProvider.d.ts +4 -4
  376. package/dist/components/AdaptivityProvider/AdaptivityProvider.js +2 -4
  377. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  378. package/dist/components/Alert/Alert.js +12 -12
  379. package/dist/components/Alert/Alert.js.map +1 -1
  380. package/dist/components/AppRoot/AppRoot.js +2 -5
  381. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  382. package/dist/components/AppRoot/AppRootContext.js.map +1 -1
  383. package/dist/components/AppRoot/AppRootPortal.js.map +1 -1
  384. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  385. package/dist/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  386. package/dist/components/AppearanceProvider/AppearanceProviderContext.js.map +1 -1
  387. package/dist/components/Avatar/Avatar.js +4 -17
  388. package/dist/components/Avatar/Avatar.js.map +1 -1
  389. package/dist/components/Badge/Badge.js.map +1 -1
  390. package/dist/components/Banner/Banner.js.map +1 -1
  391. package/dist/components/BaseGallery/BaseGallery.js +11 -10
  392. package/dist/components/BaseGallery/BaseGallery.js.map +1 -1
  393. package/dist/components/BaseGallery/helpers.js.map +1 -1
  394. package/dist/components/BaseGallery/types.js.map +1 -1
  395. package/dist/components/Button/Button.js.map +1 -1
  396. package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -1
  397. package/dist/components/Calendar/Calendar.d.ts +3 -2
  398. package/dist/components/Calendar/Calendar.js +9 -3
  399. package/dist/components/Calendar/Calendar.js.map +1 -1
  400. package/dist/components/CalendarDay/CalendarDay.d.ts +4 -2
  401. package/dist/components/CalendarDay/CalendarDay.js +11 -23
  402. package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
  403. package/dist/components/CalendarDays/CalendarDays.d.ts +3 -1
  404. package/dist/components/CalendarDays/CalendarDays.js +4 -3
  405. package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
  406. package/dist/components/CalendarHeader/CalendarHeader.d.ts +6 -1
  407. package/dist/components/CalendarHeader/CalendarHeader.js +7 -4
  408. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
  409. package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
  410. package/dist/components/CalendarTime/CalendarTime.js.map +1 -1
  411. package/dist/components/Card/Card.js.map +1 -1
  412. package/dist/components/CardGrid/CardGrid.js.map +1 -1
  413. package/dist/components/CardScroll/CardScroll.js +1 -3
  414. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  415. package/dist/components/Cell/Cell.js.map +1 -1
  416. package/dist/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  417. package/dist/components/Cell/CellDragger/CellDragger.js.map +1 -1
  418. package/dist/components/Cell/useDraggable.js.map +1 -1
  419. package/dist/components/CellButton/CellButton.js.map +1 -1
  420. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  421. package/dist/components/Chip/Chip.d.ts +12 -5
  422. package/dist/components/Chip/Chip.js.map +1 -1
  423. package/dist/components/ChipsInput/ChipsInput.d.ts +5 -26
  424. package/dist/components/ChipsInput/ChipsInput.js +14 -183
  425. package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
  426. package/dist/components/ChipsInputBase/ChipsInputBase.d.ts +17 -0
  427. package/dist/components/ChipsInputBase/ChipsInputBase.js +188 -0
  428. package/dist/components/ChipsInputBase/ChipsInputBase.js.map +1 -0
  429. package/dist/components/ChipsSelect/ChipsSelect.d.ts +6 -4
  430. package/dist/components/ChipsSelect/ChipsSelect.js +47 -27
  431. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  432. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  433. package/dist/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  434. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  435. package/dist/components/Counter/Counter.js.map +1 -1
  436. package/dist/components/CustomScrollView/CustomScrollView.js.map +1 -1
  437. package/dist/components/CustomScrollView/useTrackerVisibility.js.map +1 -1
  438. package/dist/components/CustomSelect/CustomSelect.d.ts +1 -1
  439. package/dist/components/CustomSelect/CustomSelect.js +32 -31
  440. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  441. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  442. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  443. package/dist/components/DateInput/DateInput.d.ts +4 -2
  444. package/dist/components/DateInput/DateInput.js +4 -2
  445. package/dist/components/DateInput/DateInput.js.map +1 -1
  446. package/dist/components/DatePicker/DatePicker.js.map +1 -1
  447. package/dist/components/DateRangeInput/DateRangeInput.d.ts +4 -2
  448. package/dist/components/DateRangeInput/DateRangeInput.js +4 -2
  449. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  450. package/dist/components/Div/Div.js.map +1 -1
  451. package/dist/components/Dropdown/Dropdown.js.map +1 -1
  452. package/dist/components/DropdownIcon/DropdownIcon.d.ts +4 -2
  453. package/dist/components/DropdownIcon/DropdownIcon.js +15 -7
  454. package/dist/components/DropdownIcon/DropdownIcon.js.map +1 -1
  455. package/dist/components/Epic/Epic.js.map +1 -1
  456. package/dist/components/Epic/ScrollSaver.js.map +1 -1
  457. package/dist/components/File/File.js.map +1 -1
  458. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  459. package/dist/components/FocusTrap/FocusTrap.js.map +1 -1
  460. package/dist/components/FocusVisible/FocusVisible.js.map +1 -1
  461. package/dist/components/Footer/Footer.js.map +1 -1
  462. package/dist/components/FormField/FormField.d.ts +2 -1
  463. package/dist/components/FormField/FormField.js +4 -2
  464. package/dist/components/FormField/FormField.js.map +1 -1
  465. package/dist/components/FormItem/FormItem.js.map +1 -1
  466. package/dist/components/FormLayout/FormLayout.js.map +1 -1
  467. package/dist/components/FormLayoutGroup/FormLayoutGroup.d.ts +5 -1
  468. package/dist/components/FormLayoutGroup/FormLayoutGroup.js +9 -3
  469. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  470. package/dist/components/FormStatus/FormStatus.d.ts +1 -0
  471. package/dist/components/FormStatus/FormStatus.js +4 -4
  472. package/dist/components/FormStatus/FormStatus.js.map +1 -1
  473. package/dist/components/Gallery/Gallery.js +2 -0
  474. package/dist/components/Gallery/Gallery.js.map +1 -1
  475. package/dist/components/Gradient/Gradient.js.map +1 -1
  476. package/dist/components/GridAvatar/GridAvatar.js.map +1 -1
  477. package/dist/components/Group/Group.d.ts +5 -1
  478. package/dist/components/Group/Group.js +4 -2
  479. package/dist/components/Group/Group.js.map +1 -1
  480. package/dist/components/Header/Header.js +3 -10
  481. package/dist/components/Header/Header.js.map +1 -1
  482. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  483. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  484. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  485. package/dist/components/HoverPopper/HoverPopper.js.map +1 -1
  486. package/dist/components/IconButton/IconButton.js +4 -3
  487. package/dist/components/IconButton/IconButton.js.map +1 -1
  488. package/dist/components/InfoRow/InfoRow.js.map +1 -1
  489. package/dist/components/InitialsAvatar/InitialsAvatar.js.map +1 -1
  490. package/dist/components/Input/Input.d.ts +1 -1
  491. package/dist/components/Input/Input.js +4 -2
  492. package/dist/components/Input/Input.js.map +1 -1
  493. package/dist/components/InputLike/InputLike.js.map +1 -1
  494. package/dist/components/InputLike/InputLikeDivider.js.map +1 -1
  495. package/dist/components/Link/Link.js.map +1 -1
  496. package/dist/components/List/List.d.ts +2 -1
  497. package/dist/components/List/List.js.map +1 -1
  498. package/dist/components/List/ListContext.js.map +1 -1
  499. package/dist/components/LocaleProviderContext/LocaleProviderContext.js.map +1 -1
  500. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  501. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  502. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  503. package/dist/components/ModalDismissButton/ModalDismissButton.js +1 -4
  504. package/dist/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  505. package/dist/components/ModalPage/ModalPage.d.ts +13 -1
  506. package/dist/components/ModalPage/ModalPage.js +12 -10
  507. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  508. package/dist/components/ModalPageHeader/ModalPageHeader.js +3 -3
  509. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  510. package/dist/components/ModalRoot/ModalRoot.js +4 -18
  511. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  512. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  513. package/dist/components/ModalRoot/ModalRootContext.js.map +1 -1
  514. package/dist/components/ModalRoot/ModalRootDesktop.js +3 -11
  515. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  516. package/dist/components/ModalRoot/constants.js.map +1 -1
  517. package/dist/components/ModalRoot/types.js.map +1 -1
  518. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  519. package/dist/components/ModalRoot/withModalRootContext.js.map +1 -1
  520. package/dist/components/NativeSelect/NativeSelect.d.ts +3 -2
  521. package/dist/components/NativeSelect/NativeSelect.js +4 -2
  522. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  523. package/dist/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  524. package/dist/components/Pagination/Pagination.js.map +1 -1
  525. package/dist/components/Panel/Panel.js +4 -8
  526. package/dist/components/Panel/Panel.js.map +1 -1
  527. package/dist/components/PanelHeader/PanelHeader.js +2 -11
  528. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  529. package/dist/components/PanelHeaderBack/PanelHeaderBack.js +2 -6
  530. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  531. package/dist/components/PanelHeaderButton/PanelHeaderButton.js +2 -7
  532. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  533. package/dist/components/PanelHeaderClose/PanelHeaderClose.js +2 -2
  534. package/dist/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  535. package/dist/components/PanelHeaderContent/PanelHeaderContent.js +4 -3
  536. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  537. package/dist/components/PanelHeaderContext/PanelHeaderContext.js +3 -7
  538. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  539. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js +2 -2
  540. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  541. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.js +2 -2
  542. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  543. package/dist/components/PanelSpinner/PanelSpinner.js.map +1 -1
  544. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  545. package/dist/components/PopoutRoot/PopoutRoot.js.map +1 -1
  546. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  547. package/dist/components/Popper/Popper.js.map +1 -1
  548. package/dist/components/PopperArrow/PopperArrow.js.map +1 -1
  549. package/dist/components/Progress/Progress.js.map +1 -1
  550. package/dist/components/PromoBanner/PromoBanner.js +2 -5
  551. package/dist/components/PromoBanner/PromoBanner.js.map +1 -1
  552. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  553. package/dist/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  554. package/dist/components/Radio/Radio.js.map +1 -1
  555. package/dist/components/RadioGroup/RadioGroup.js.map +1 -1
  556. package/dist/components/RangeSlider/RangeSlider.js.map +1 -1
  557. package/dist/components/RangeSlider/UniversalSlider.js.map +1 -1
  558. package/dist/components/Removable/Removable.js.map +1 -1
  559. package/dist/components/RichCell/RichCell.js.map +1 -1
  560. package/dist/components/RichTooltip/RichTooltip.js.map +1 -1
  561. package/dist/components/Root/Root.js.map +1 -1
  562. package/dist/components/ScreenSpinner/Icon48CancelCircle.js.map +1 -1
  563. package/dist/components/ScreenSpinner/Icon48DoneOutline.js.map +1 -1
  564. package/dist/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  565. package/dist/components/Search/Search.js +6 -8
  566. package/dist/components/Search/Search.js.map +1 -1
  567. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  568. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  569. package/dist/components/Select/Select.d.ts +1 -1
  570. package/dist/components/Select/Select.js.map +1 -1
  571. package/dist/components/SelectMimicry/SelectMimicry.d.ts +2 -2
  572. package/dist/components/SelectMimicry/SelectMimicry.js +4 -2
  573. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  574. package/dist/components/Separator/Separator.js.map +1 -1
  575. package/dist/components/SimpleCell/SimpleCell.d.ts +34 -1
  576. package/dist/components/SimpleCell/SimpleCell.js +29 -8
  577. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  578. package/dist/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  579. package/dist/components/Slider/Slider.js.map +1 -1
  580. package/dist/components/SliderSwitch/SliderSwitch.js +1 -4
  581. package/dist/components/SliderSwitch/SliderSwitch.js.map +1 -1
  582. package/dist/components/SliderSwitch/SliderSwitchButton.js +1 -5
  583. package/dist/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  584. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  585. package/dist/components/Spacing/Spacing.js.map +1 -1
  586. package/dist/components/Spinner/Spinner.js.map +1 -1
  587. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  588. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  589. package/dist/components/SubnavigationBar/SubnavigationBar.js +1 -4
  590. package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  591. package/dist/components/SubnavigationButton/SubnavigationButton.d.ts +3 -2
  592. package/dist/components/SubnavigationButton/SubnavigationButton.js +16 -15
  593. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  594. package/dist/components/Switch/Switch.js.map +1 -1
  595. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  596. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  597. package/dist/components/Tabs/Tabs.js.map +1 -1
  598. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  599. package/dist/components/Tappable/Tappable.d.ts +2 -1
  600. package/dist/components/Tappable/Tappable.js +3 -10
  601. package/dist/components/Tappable/Tappable.js.map +1 -1
  602. package/dist/components/TextTooltip/TextTooltip.js.map +1 -1
  603. package/dist/components/Textarea/Textarea.d.ts +3 -2
  604. package/dist/components/Textarea/Textarea.js +4 -2
  605. package/dist/components/Textarea/Textarea.js.map +1 -1
  606. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  607. package/dist/components/Tooltip/TooltipContainer.js.map +1 -1
  608. package/dist/components/Touch/Touch.js.map +1 -1
  609. package/dist/components/Touch/TouchContext.js.map +1 -1
  610. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  611. package/dist/components/Typography/Footnote/Footnote.js.map +1 -1
  612. package/dist/components/Typography/Headline/Headline.js.map +1 -1
  613. package/dist/components/Typography/Paragraph/Paragraph.js.map +1 -1
  614. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  615. package/dist/components/Typography/Text/Text.js.map +1 -1
  616. package/dist/components/Typography/Title/Title.js.map +1 -1
  617. package/dist/components/UsersStack/UsersStack.d.ts +7 -1
  618. package/dist/components/UsersStack/UsersStack.js +73 -31
  619. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  620. package/dist/components/View/View.js +2 -7
  621. package/dist/components/View/View.js.map +1 -1
  622. package/dist/components/View/ViewInfinite.js +1 -10
  623. package/dist/components/View/ViewInfinite.js.map +1 -1
  624. package/dist/components/View/utils.js.map +1 -1
  625. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.js +1 -3
  626. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -1
  627. package/dist/components/WriteBar/WriteBar.js.map +1 -1
  628. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  629. package/dist/components.css +124 -17
  630. package/dist/components.css.map +1 -1
  631. package/dist/cssm/appearance/constants.js.map +1 -1
  632. package/dist/cssm/components/ActionSheet/ActionSheet.css +3 -1
  633. package/dist/cssm/components/ActionSheet/ActionSheet.js +4 -4
  634. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  635. package/dist/cssm/components/ActionSheet/ActionSheetContext.js.map +1 -1
  636. package/dist/cssm/components/ActionSheet/ActionSheetDefaultIosCloseItem.d.ts +3 -0
  637. package/dist/cssm/components/ActionSheet/ActionSheetDefaultIosCloseItem.js +10 -0
  638. package/dist/cssm/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -0
  639. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js +7 -7
  640. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  641. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js +3 -4
  642. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  643. package/dist/cssm/components/ActionSheet/types.js.map +1 -1
  644. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.css +7 -1
  645. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.d.ts +5 -1
  646. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js +16 -36
  647. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  648. package/dist/cssm/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  649. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.d.ts +4 -4
  650. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js +2 -4
  651. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  652. package/dist/cssm/components/Alert/Alert.css +7 -1
  653. package/dist/cssm/components/Alert/Alert.js +12 -12
  654. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  655. package/dist/cssm/components/AppRoot/AppRoot.css +1 -1
  656. package/dist/cssm/components/AppRoot/AppRoot.js +2 -5
  657. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  658. package/dist/cssm/components/AppRoot/AppRootContext.js.map +1 -1
  659. package/dist/cssm/components/AppRoot/AppRootPortal.js.map +1 -1
  660. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  661. package/dist/cssm/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  662. package/dist/cssm/components/AppearanceProvider/AppearanceProviderContext.js.map +1 -1
  663. package/dist/cssm/components/Avatar/Avatar.js +4 -17
  664. package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
  665. package/dist/cssm/components/Badge/Badge.js.map +1 -1
  666. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  667. package/dist/cssm/components/BaseGallery/BaseGallery.js +11 -10
  668. package/dist/cssm/components/BaseGallery/BaseGallery.js.map +1 -1
  669. package/dist/cssm/components/BaseGallery/helpers.js.map +1 -1
  670. package/dist/cssm/components/BaseGallery/types.js.map +1 -1
  671. package/dist/cssm/components/Button/Button.js.map +1 -1
  672. package/dist/cssm/components/ButtonGroup/ButtonGroup.js.map +1 -1
  673. package/dist/cssm/components/Calendar/Calendar.d.ts +3 -2
  674. package/dist/cssm/components/Calendar/Calendar.js +9 -3
  675. package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
  676. package/dist/cssm/components/CalendarDay/CalendarDay.d.ts +4 -2
  677. package/dist/cssm/components/CalendarDay/CalendarDay.js +11 -23
  678. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
  679. package/dist/cssm/components/CalendarDays/CalendarDays.d.ts +3 -1
  680. package/dist/cssm/components/CalendarDays/CalendarDays.js +4 -3
  681. package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
  682. package/dist/cssm/components/CalendarHeader/CalendarHeader.d.ts +6 -1
  683. package/dist/cssm/components/CalendarHeader/CalendarHeader.js +7 -4
  684. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
  685. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
  686. package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -1
  687. package/dist/cssm/components/Card/Card.js.map +1 -1
  688. package/dist/cssm/components/CardGrid/CardGrid.js.map +1 -1
  689. package/dist/cssm/components/CardScroll/CardScroll.js +1 -3
  690. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  691. package/dist/cssm/components/Cell/Cell.js.map +1 -1
  692. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.css +1 -1
  693. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  694. package/dist/cssm/components/Cell/CellDragger/CellDragger.css +1 -1
  695. package/dist/cssm/components/Cell/CellDragger/CellDragger.js.map +1 -1
  696. package/dist/cssm/components/Cell/useDraggable.js.map +1 -1
  697. package/dist/cssm/components/CellButton/CellButton.js.map +1 -1
  698. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  699. package/dist/cssm/components/Chip/Chip.css +1 -1
  700. package/dist/cssm/components/Chip/Chip.d.ts +12 -5
  701. package/dist/cssm/components/Chip/Chip.js.map +1 -1
  702. package/dist/cssm/components/ChipsInput/ChipsInput.css +1 -1
  703. package/dist/cssm/components/ChipsInput/ChipsInput.d.ts +5 -26
  704. package/dist/cssm/components/ChipsInput/ChipsInput.js +14 -183
  705. package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
  706. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.css +1 -0
  707. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.d.ts +17 -0
  708. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.js +189 -0
  709. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.js.map +1 -0
  710. package/dist/cssm/components/ChipsSelect/ChipsSelect.css +1 -1
  711. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts +6 -4
  712. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +47 -27
  713. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  714. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  715. package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  716. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  717. package/dist/cssm/components/Counter/Counter.css +3 -1
  718. package/dist/cssm/components/Counter/Counter.js.map +1 -1
  719. package/dist/cssm/components/CustomScrollView/CustomScrollView.js.map +1 -1
  720. package/dist/cssm/components/CustomScrollView/useTrackerVisibility.js.map +1 -1
  721. package/dist/cssm/components/CustomSelect/CustomSelect.css +1 -1
  722. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +1 -1
  723. package/dist/cssm/components/CustomSelect/CustomSelect.js +32 -31
  724. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  725. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  726. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  727. package/dist/cssm/components/DateInput/DateInput.css +1 -1
  728. package/dist/cssm/components/DateInput/DateInput.d.ts +4 -2
  729. package/dist/cssm/components/DateInput/DateInput.js +4 -2
  730. package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
  731. package/dist/cssm/components/DatePicker/DatePicker.js.map +1 -1
  732. package/dist/cssm/components/DateRangeInput/DateRangeInput.css +1 -1
  733. package/dist/cssm/components/DateRangeInput/DateRangeInput.d.ts +4 -2
  734. package/dist/cssm/components/DateRangeInput/DateRangeInput.js +4 -2
  735. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  736. package/dist/cssm/components/Div/Div.js.map +1 -1
  737. package/dist/cssm/components/Dropdown/Dropdown.js.map +1 -1
  738. package/dist/cssm/components/DropdownIcon/DropdownIcon.d.ts +4 -2
  739. package/dist/cssm/components/DropdownIcon/DropdownIcon.js +15 -8
  740. package/dist/cssm/components/DropdownIcon/DropdownIcon.js.map +1 -1
  741. package/dist/cssm/components/Epic/Epic.js.map +1 -1
  742. package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
  743. package/dist/cssm/components/File/File.js.map +1 -1
  744. package/dist/cssm/components/FixedLayout/FixedLayout.css +7 -1
  745. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  746. package/dist/cssm/components/FocusTrap/FocusTrap.js.map +1 -1
  747. package/dist/cssm/components/FocusVisible/FocusVisible.js.map +1 -1
  748. package/dist/cssm/components/Footer/Footer.js.map +1 -1
  749. package/dist/cssm/components/FormField/FormField.css +4 -4
  750. package/dist/cssm/components/FormField/FormField.d.ts +2 -1
  751. package/dist/cssm/components/FormField/FormField.js +4 -2
  752. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  753. package/dist/cssm/components/FormItem/FormItem.css +1 -1
  754. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  755. package/dist/cssm/components/FormLayout/FormLayout.js.map +1 -1
  756. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.css +1 -1
  757. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.d.ts +5 -1
  758. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js +9 -3
  759. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  760. package/dist/cssm/components/FormStatus/FormStatus.css +3 -1
  761. package/dist/cssm/components/FormStatus/FormStatus.d.ts +1 -0
  762. package/dist/cssm/components/FormStatus/FormStatus.js +4 -4
  763. package/dist/cssm/components/FormStatus/FormStatus.js.map +1 -1
  764. package/dist/cssm/components/Gallery/Gallery.js +2 -0
  765. package/dist/cssm/components/Gallery/Gallery.js.map +1 -1
  766. package/dist/cssm/components/Gradient/Gradient.js.map +1 -1
  767. package/dist/cssm/components/GridAvatar/GridAvatar.js.map +1 -1
  768. package/dist/cssm/components/Group/Group.css +1 -1
  769. package/dist/cssm/components/Group/Group.d.ts +5 -1
  770. package/dist/cssm/components/Group/Group.js +4 -2
  771. package/dist/cssm/components/Group/Group.js.map +1 -1
  772. package/dist/cssm/components/Header/Header.css +1 -1
  773. package/dist/cssm/components/Header/Header.js +3 -10
  774. package/dist/cssm/components/Header/Header.js.map +1 -1
  775. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  776. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  777. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  778. package/dist/cssm/components/HoverPopper/HoverPopper.js.map +1 -1
  779. package/dist/cssm/components/IconButton/IconButton.js +4 -3
  780. package/dist/cssm/components/IconButton/IconButton.js.map +1 -1
  781. package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
  782. package/dist/cssm/components/InitialsAvatar/InitialsAvatar.js.map +1 -1
  783. package/dist/cssm/components/Input/Input.css +1 -1
  784. package/dist/cssm/components/Input/Input.d.ts +1 -1
  785. package/dist/cssm/components/Input/Input.js +4 -2
  786. package/dist/cssm/components/Input/Input.js.map +1 -1
  787. package/dist/cssm/components/InputLike/InputLike.js.map +1 -1
  788. package/dist/cssm/components/InputLike/InputLikeDivider.js.map +1 -1
  789. package/dist/cssm/components/Link/Link.css +1 -1
  790. package/dist/cssm/components/Link/Link.js.map +1 -1
  791. package/dist/cssm/components/List/List.d.ts +2 -1
  792. package/dist/cssm/components/List/List.js +1 -1
  793. package/dist/cssm/components/List/List.js.map +1 -1
  794. package/dist/cssm/components/List/ListContext.js.map +1 -1
  795. package/dist/cssm/components/LocaleProviderContext/LocaleProviderContext.js.map +1 -1
  796. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  797. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  798. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  799. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.css +1 -1
  800. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js +1 -4
  801. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  802. package/dist/cssm/components/ModalPage/ModalPage.css +5 -1
  803. package/dist/cssm/components/ModalPage/ModalPage.d.ts +13 -1
  804. package/dist/cssm/components/ModalPage/ModalPage.js +12 -10
  805. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  806. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.css +1 -1
  807. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js +3 -3
  808. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  809. package/dist/cssm/components/ModalRoot/ModalRoot.css +4 -1
  810. package/dist/cssm/components/ModalRoot/ModalRoot.js +4 -18
  811. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  812. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  813. package/dist/cssm/components/ModalRoot/ModalRootContext.js.map +1 -1
  814. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +3 -11
  815. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  816. package/dist/cssm/components/ModalRoot/constants.js.map +1 -1
  817. package/dist/cssm/components/ModalRoot/types.js.map +1 -1
  818. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  819. package/dist/cssm/components/ModalRoot/withModalRootContext.js.map +1 -1
  820. package/dist/cssm/components/NativeSelect/NativeSelect.d.ts +3 -2
  821. package/dist/cssm/components/NativeSelect/NativeSelect.js +4 -2
  822. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  823. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  824. package/dist/cssm/components/Pagination/Pagination.js.map +1 -1
  825. package/dist/cssm/components/Panel/Panel.css +19 -1
  826. package/dist/cssm/components/Panel/Panel.js +4 -8
  827. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  828. package/dist/cssm/components/PanelHeader/PanelHeader.css +9 -1
  829. package/dist/cssm/components/PanelHeader/PanelHeader.js +2 -11
  830. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  831. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js +2 -6
  832. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  833. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.css +1 -1
  834. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js +2 -7
  835. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  836. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.js +2 -2
  837. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  838. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.css +5 -1
  839. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js +4 -3
  840. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  841. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.css +1 -1
  842. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js +3 -7
  843. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  844. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js +2 -2
  845. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  846. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.js +2 -2
  847. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  848. package/dist/cssm/components/PanelSpinner/PanelSpinner.js.map +1 -1
  849. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  850. package/dist/cssm/components/PopoutRoot/PopoutRoot.js.map +1 -1
  851. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  852. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  853. package/dist/cssm/components/PopperArrow/PopperArrow.js.map +1 -1
  854. package/dist/cssm/components/Progress/Progress.js.map +1 -1
  855. package/dist/cssm/components/PromoBanner/PromoBanner.css +3 -1
  856. package/dist/cssm/components/PromoBanner/PromoBanner.js +2 -5
  857. package/dist/cssm/components/PromoBanner/PromoBanner.js.map +1 -1
  858. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  859. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  860. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  861. package/dist/cssm/components/RadioGroup/RadioGroup.js.map +1 -1
  862. package/dist/cssm/components/RangeSlider/RangeSlider.js.map +1 -1
  863. package/dist/cssm/components/RangeSlider/UniversalSlider.js.map +1 -1
  864. package/dist/cssm/components/Removable/Removable.js.map +1 -1
  865. package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
  866. package/dist/cssm/components/RichTooltip/RichTooltip.js.map +1 -1
  867. package/dist/cssm/components/Root/Root.js.map +1 -1
  868. package/dist/cssm/components/ScreenSpinner/Icon48CancelCircle.js.map +1 -1
  869. package/dist/cssm/components/ScreenSpinner/Icon48DoneOutline.js.map +1 -1
  870. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  871. package/dist/cssm/components/Search/Search.css +27 -1
  872. package/dist/cssm/components/Search/Search.js +6 -8
  873. package/dist/cssm/components/Search/Search.js.map +1 -1
  874. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  875. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  876. package/dist/cssm/components/Select/Select.css +1 -1
  877. package/dist/cssm/components/Select/Select.d.ts +1 -1
  878. package/dist/cssm/components/Select/Select.js.map +1 -1
  879. package/dist/cssm/components/SelectMimicry/SelectMimicry.d.ts +2 -2
  880. package/dist/cssm/components/SelectMimicry/SelectMimicry.js +4 -2
  881. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  882. package/dist/cssm/components/Separator/Separator.js.map +1 -1
  883. package/dist/cssm/components/SimpleCell/SimpleCell.css +1 -1
  884. package/dist/cssm/components/SimpleCell/SimpleCell.d.ts +34 -1
  885. package/dist/cssm/components/SimpleCell/SimpleCell.js +29 -8
  886. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  887. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  888. package/dist/cssm/components/Slider/Slider.js.map +1 -1
  889. package/dist/cssm/components/SliderSwitch/SliderSwitch.js +1 -4
  890. package/dist/cssm/components/SliderSwitch/SliderSwitch.js.map +1 -1
  891. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js +1 -5
  892. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  893. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  894. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  895. package/dist/cssm/components/Spinner/Spinner.js.map +1 -1
  896. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  897. package/dist/cssm/components/SplitLayout/SplitLayout.css +7 -1
  898. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  899. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.css +1 -1
  900. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js +1 -4
  901. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  902. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.css +9 -1
  903. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.d.ts +3 -2
  904. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +16 -15
  905. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  906. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  907. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  908. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  909. package/dist/cssm/components/Tabs/Tabs.js.map +1 -1
  910. package/dist/cssm/components/TabsItem/TabsItem.css +5 -1
  911. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  912. package/dist/cssm/components/Tappable/Tappable.d.ts +2 -1
  913. package/dist/cssm/components/Tappable/Tappable.js +3 -10
  914. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  915. package/dist/cssm/components/TextTooltip/TextTooltip.js.map +1 -1
  916. package/dist/cssm/components/Textarea/Textarea.css +1 -1
  917. package/dist/cssm/components/Textarea/Textarea.d.ts +3 -2
  918. package/dist/cssm/components/Textarea/Textarea.js +4 -2
  919. package/dist/cssm/components/Textarea/Textarea.js.map +1 -1
  920. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  921. package/dist/cssm/components/Tooltip/TooltipContainer.js.map +1 -1
  922. package/dist/cssm/components/Touch/Touch.js.map +1 -1
  923. package/dist/cssm/components/Touch/TouchContext.js.map +1 -1
  924. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  925. package/dist/cssm/components/Typography/Footnote/Footnote.js.map +1 -1
  926. package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
  927. package/dist/cssm/components/Typography/Paragraph/Paragraph.js.map +1 -1
  928. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  929. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  930. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  931. package/dist/cssm/components/UsersStack/UsersStack.css +1 -1
  932. package/dist/cssm/components/UsersStack/UsersStack.d.ts +7 -1
  933. package/dist/cssm/components/UsersStack/UsersStack.js +73 -31
  934. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  935. package/dist/cssm/components/View/View.js +2 -7
  936. package/dist/cssm/components/View/View.js.map +1 -1
  937. package/dist/cssm/components/View/ViewInfinite.js +1 -10
  938. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  939. package/dist/cssm/components/View/utils.js.map +1 -1
  940. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.js +1 -3
  941. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -1
  942. package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
  943. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  944. package/dist/cssm/helpers/avatar.js.map +1 -1
  945. package/dist/cssm/helpers/getClassName.js.map +1 -1
  946. package/dist/cssm/helpers/getScheme.js.map +1 -1
  947. package/dist/cssm/helpers/math.js.map +1 -1
  948. package/dist/cssm/helpers/scheme.js.map +1 -1
  949. package/dist/cssm/hoc/withAdaptivity.js.map +1 -1
  950. package/dist/cssm/hoc/withContext.js.map +1 -1
  951. package/dist/cssm/hoc/withInsets.js.map +1 -1
  952. package/dist/cssm/hoc/withPlatform.js.map +1 -1
  953. package/dist/cssm/hooks/useAdaptivity.js.map +1 -1
  954. package/dist/cssm/hooks/useAppearance.js.map +1 -1
  955. package/dist/cssm/hooks/useBooleanState.js.map +1 -1
  956. package/dist/cssm/hooks/useBridgeAdaptivity.js.map +1 -1
  957. package/dist/cssm/hooks/useBrowserInfo.js.map +1 -1
  958. package/dist/cssm/hooks/useCalendar.js.map +1 -1
  959. package/dist/cssm/{components/ChipsInput → hooks}/useChipsInput.d.ts +4 -3
  960. package/dist/{components/ChipsInput → cssm/hooks}/useChipsInput.js +0 -0
  961. package/dist/cssm/hooks/useChipsInput.js.map +1 -0
  962. package/{.cache/ts/src/components/ChipsSelect → dist/cssm/hooks}/useChipsSelect.d.ts +4 -4
  963. package/dist/{components/ChipsSelect → cssm/hooks}/useChipsSelect.js +1 -1
  964. package/dist/cssm/hooks/useChipsSelect.js.map +1 -0
  965. package/dist/cssm/hooks/useDateInput.js.map +1 -1
  966. package/dist/cssm/hooks/useEffectDev.js.map +1 -1
  967. package/dist/cssm/hooks/useEnsuredControl.js.map +1 -1
  968. package/dist/cssm/hooks/useEventListener.js.map +1 -1
  969. package/dist/cssm/hooks/useExternRef.js.map +1 -1
  970. package/dist/cssm/hooks/useFocusVisible.js.map +1 -1
  971. package/dist/cssm/hooks/useGlobalEventListener.js.map +1 -1
  972. package/dist/cssm/hooks/useInsets.js.map +1 -1
  973. package/dist/cssm/hooks/useKeyboard.js.map +1 -1
  974. package/dist/cssm/hooks/useKeyboardInputTracker.js.map +1 -1
  975. package/dist/cssm/hooks/useObjectMemo.js.map +1 -1
  976. package/dist/cssm/hooks/useOrientationChange.js.map +1 -1
  977. package/dist/cssm/hooks/usePagination.js.map +1 -1
  978. package/dist/cssm/hooks/usePatchChildrenRef.js.map +1 -1
  979. package/dist/cssm/hooks/usePlatform.js.map +1 -1
  980. package/dist/cssm/hooks/usePrevious.js.map +1 -1
  981. package/dist/cssm/hooks/useTimeout.js.map +1 -1
  982. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  983. package/dist/cssm/index.d.ts +5 -0
  984. package/dist/cssm/index.js +2 -0
  985. package/dist/cssm/index.js.map +1 -1
  986. package/dist/cssm/lib/SSR.js.map +1 -1
  987. package/dist/cssm/lib/accessibility.js.map +1 -1
  988. package/dist/cssm/lib/animate.js +1 -1
  989. package/dist/cssm/lib/animate.js.map +1 -1
  990. package/dist/cssm/lib/browser.js.map +1 -1
  991. package/dist/cssm/lib/calendar.js.map +1 -1
  992. package/dist/cssm/lib/callMultiple.js.map +1 -1
  993. package/dist/cssm/lib/classNames.js.map +1 -1
  994. package/dist/cssm/lib/classScopingMode.js.map +1 -1
  995. package/dist/cssm/lib/date.js.map +1 -1
  996. package/dist/cssm/lib/dom.js.map +1 -1
  997. package/dist/cssm/lib/fx.js.map +1 -1
  998. package/dist/cssm/lib/getNavId.js.map +1 -1
  999. package/dist/cssm/lib/is.js.map +1 -1
  1000. package/dist/cssm/lib/isRefObject.js.map +1 -1
  1001. package/dist/cssm/lib/jsxRuntime.d.js.map +1 -1
  1002. package/dist/cssm/lib/jsxRuntime.js.map +1 -1
  1003. package/dist/cssm/lib/offset.js.map +1 -1
  1004. package/dist/cssm/lib/platform.js.map +1 -1
  1005. package/dist/cssm/lib/polyfills.js.map +1 -1
  1006. package/dist/cssm/lib/prefixClass.js.map +1 -1
  1007. package/dist/cssm/lib/removeObjectKeys.js.map +1 -1
  1008. package/dist/cssm/lib/select.js.map +1 -1
  1009. package/dist/cssm/lib/styles.js.map +1 -1
  1010. package/dist/cssm/lib/supportEvents.js.map +1 -1
  1011. package/dist/cssm/lib/taptic.js.map +1 -1
  1012. package/dist/cssm/lib/testing.js +1 -1
  1013. package/dist/cssm/lib/testing.js.map +1 -1
  1014. package/dist/cssm/lib/touch.js +1 -1
  1015. package/dist/cssm/lib/touch.js.map +1 -1
  1016. package/dist/cssm/lib/useIsomorphicLayoutEffect.js.map +1 -1
  1017. package/dist/cssm/lib/utils.js.map +1 -1
  1018. package/dist/cssm/lib/warnOnce.js.map +1 -1
  1019. package/dist/cssm/styles/components.css +124 -17
  1020. package/dist/cssm/styles/themes.css +1 -1
  1021. package/dist/cssm/styles/unstable.css +1 -1
  1022. package/dist/cssm/styles/vkcom_dark.css +1 -1
  1023. package/dist/cssm/styles/vkcom_light.css +1 -1
  1024. package/dist/cssm/tokenized/index.d.ts +58 -0
  1025. package/dist/cssm/tokenized/index.js +30 -0
  1026. package/dist/cssm/tokenized/index.js.map +1 -1
  1027. package/dist/cssm/types.js.map +1 -1
  1028. package/dist/cssm/unstable/index.js.map +1 -1
  1029. package/dist/helpers/avatar.js.map +1 -1
  1030. package/dist/helpers/getClassName.js.map +1 -1
  1031. package/dist/helpers/getScheme.js.map +1 -1
  1032. package/dist/helpers/math.js.map +1 -1
  1033. package/dist/helpers/scheme.js.map +1 -1
  1034. package/dist/hoc/withAdaptivity.js.map +1 -1
  1035. package/dist/hoc/withContext.js.map +1 -1
  1036. package/dist/hoc/withInsets.js.map +1 -1
  1037. package/dist/hoc/withPlatform.js.map +1 -1
  1038. package/dist/hooks/useAdaptivity.js.map +1 -1
  1039. package/dist/hooks/useAppearance.js.map +1 -1
  1040. package/dist/hooks/useBooleanState.js.map +1 -1
  1041. package/dist/hooks/useBridgeAdaptivity.js.map +1 -1
  1042. package/dist/hooks/useBrowserInfo.js.map +1 -1
  1043. package/dist/hooks/useCalendar.js.map +1 -1
  1044. package/dist/{components/ChipsInput → hooks}/useChipsInput.d.ts +4 -3
  1045. package/dist/{cssm/components/ChipsInput → hooks}/useChipsInput.js +0 -0
  1046. package/dist/hooks/useChipsInput.js.map +1 -0
  1047. package/dist/{components/ChipsSelect → hooks}/useChipsSelect.d.ts +4 -4
  1048. package/dist/{cssm/components/ChipsSelect → hooks}/useChipsSelect.js +1 -1
  1049. package/dist/hooks/useChipsSelect.js.map +1 -0
  1050. package/dist/hooks/useDateInput.js.map +1 -1
  1051. package/dist/hooks/useEffectDev.js.map +1 -1
  1052. package/dist/hooks/useEnsuredControl.js.map +1 -1
  1053. package/dist/hooks/useEventListener.js.map +1 -1
  1054. package/dist/hooks/useExternRef.js.map +1 -1
  1055. package/dist/hooks/useFocusVisible.js.map +1 -1
  1056. package/dist/hooks/useGlobalEventListener.js.map +1 -1
  1057. package/dist/hooks/useInsets.js.map +1 -1
  1058. package/dist/hooks/useKeyboard.js.map +1 -1
  1059. package/dist/hooks/useKeyboardInputTracker.js.map +1 -1
  1060. package/dist/hooks/useObjectMemo.js.map +1 -1
  1061. package/dist/hooks/useOrientationChange.js.map +1 -1
  1062. package/dist/hooks/usePagination.js.map +1 -1
  1063. package/dist/hooks/usePatchChildrenRef.js.map +1 -1
  1064. package/dist/hooks/usePlatform.js.map +1 -1
  1065. package/dist/hooks/usePrevious.js.map +1 -1
  1066. package/dist/hooks/useTimeout.js.map +1 -1
  1067. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  1068. package/dist/index.d.ts +5 -0
  1069. package/dist/index.js +2 -0
  1070. package/dist/index.js.map +1 -1
  1071. package/dist/lib/SSR.js.map +1 -1
  1072. package/dist/lib/accessibility.js.map +1 -1
  1073. package/dist/lib/animate.js +1 -1
  1074. package/dist/lib/animate.js.map +1 -1
  1075. package/dist/lib/browser.js.map +1 -1
  1076. package/dist/lib/calendar.js.map +1 -1
  1077. package/dist/lib/callMultiple.js.map +1 -1
  1078. package/dist/lib/classNames.js.map +1 -1
  1079. package/dist/lib/classScopingMode.js.map +1 -1
  1080. package/dist/lib/date.js.map +1 -1
  1081. package/dist/lib/dom.js.map +1 -1
  1082. package/dist/lib/fx.js.map +1 -1
  1083. package/dist/lib/getNavId.js.map +1 -1
  1084. package/dist/lib/is.js.map +1 -1
  1085. package/dist/lib/isRefObject.js.map +1 -1
  1086. package/dist/lib/jsxRuntime.d.js.map +1 -1
  1087. package/dist/lib/jsxRuntime.js.map +1 -1
  1088. package/dist/lib/offset.js.map +1 -1
  1089. package/dist/lib/platform.js.map +1 -1
  1090. package/dist/lib/polyfills.js.map +1 -1
  1091. package/dist/lib/prefixClass.js.map +1 -1
  1092. package/dist/lib/removeObjectKeys.js.map +1 -1
  1093. package/dist/lib/select.js.map +1 -1
  1094. package/dist/lib/styles.js.map +1 -1
  1095. package/dist/lib/supportEvents.js.map +1 -1
  1096. package/dist/lib/taptic.js.map +1 -1
  1097. package/dist/lib/testing.js +1 -1
  1098. package/dist/lib/testing.js.map +1 -1
  1099. package/dist/lib/touch.js +1 -1
  1100. package/dist/lib/touch.js.map +1 -1
  1101. package/dist/lib/useIsomorphicLayoutEffect.js.map +1 -1
  1102. package/dist/lib/utils.js.map +1 -1
  1103. package/dist/lib/warnOnce.js.map +1 -1
  1104. package/dist/tokenized/index.d.ts +58 -0
  1105. package/dist/tokenized/index.js +30 -0
  1106. package/dist/tokenized/index.js.map +1 -1
  1107. package/dist/types.js.map +1 -1
  1108. package/dist/unstable/index.js.map +1 -1
  1109. package/dist/unstable.css +1 -1
  1110. package/dist/unstable.css.map +1 -1
  1111. package/dist/vkui.css +125 -18
  1112. package/dist/vkui.css.map +1 -1
  1113. package/package.json +24 -25
  1114. package/src/components/ActionSheet/ActionSheet.css +31 -59
  1115. package/src/components/ActionSheet/ActionSheet.tsx +4 -7
  1116. package/src/components/ActionSheet/ActionSheetDefaultIosCloseItem.tsx +12 -0
  1117. package/src/components/ActionSheet/ActionSheetDropdown.tsx +9 -6
  1118. package/src/components/ActionSheet/ActionSheetDropdownDesktop.tsx +4 -4
  1119. package/src/components/ActionSheet/Readme.md +6 -30
  1120. package/src/components/ActionSheetItem/ActionSheetItem.css +67 -120
  1121. package/src/components/ActionSheetItem/ActionSheetItem.tsx +42 -71
  1122. package/src/components/AdaptivityProvider/AdaptivityProvider.tsx +5 -5
  1123. package/src/components/Alert/Alert.css +79 -79
  1124. package/src/components/Alert/Alert.tsx +14 -14
  1125. package/src/components/Alert/Readme.md +83 -104
  1126. package/src/components/AppRoot/AppRoot.css +2 -1
  1127. package/src/components/AppRoot/AppRoot.tsx +1 -4
  1128. package/src/components/Avatar/Avatar.tsx +15 -17
  1129. package/src/components/Avatar/Readme.md +11 -11
  1130. package/src/components/BaseGallery/BaseGallery.tsx +9 -5
  1131. package/src/components/Calendar/Calendar.tsx +10 -1
  1132. package/src/components/Calendar/Readme.md +3 -0
  1133. package/src/components/CalendarDay/CalendarDay.tsx +30 -22
  1134. package/src/components/CalendarDays/CalendarDays.tsx +7 -1
  1135. package/src/components/CalendarHeader/CalendarHeader.tsx +9 -1
  1136. package/src/components/CalendarRange/Readme.md +3 -0
  1137. package/src/components/CardScroll/CardScroll.tsx +1 -2
  1138. package/src/components/Cell/CellCheckbox/CellCheckbox.css +2 -2
  1139. package/src/components/Cell/CellDragger/CellDragger.css +1 -1
  1140. package/src/components/Chip/Chip.css +1 -0
  1141. package/src/components/Chip/Chip.tsx +14 -2
  1142. package/src/components/ChipsInput/ChipsInput.css +0 -71
  1143. package/src/components/ChipsInput/ChipsInput.tsx +20 -220
  1144. package/src/components/ChipsInputBase/ChipsInputBase.css +73 -0
  1145. package/src/components/ChipsInputBase/ChipsInputBase.tsx +206 -0
  1146. package/src/components/ChipsSelect/ChipsSelect.css +8 -0
  1147. package/src/components/ChipsSelect/ChipsSelect.tsx +53 -39
  1148. package/src/components/Counter/Counter.css +13 -0
  1149. package/src/components/CustomSelect/CustomSelect.css +1 -0
  1150. package/src/components/CustomSelect/CustomSelect.tsx +2 -3
  1151. package/src/components/CustomSelect/Readme.md +8 -2
  1152. package/src/components/DateInput/DateInput.css +1 -1
  1153. package/src/components/DateInput/DateInput.tsx +6 -3
  1154. package/src/components/DateInput/Readme.md +13 -0
  1155. package/src/components/DateRangeInput/DateRangeInput.css +1 -1
  1156. package/src/components/DateRangeInput/DateRangeInput.tsx +6 -3
  1157. package/src/components/DateRangeInput/Readme.md +13 -0
  1158. package/src/components/DropdownIcon/DropdownIcon.tsx +22 -8
  1159. package/src/components/Epic/Readme.md +10 -5
  1160. package/src/components/FixedLayout/FixedLayout.css +19 -3
  1161. package/src/components/FormField/FormField.css +58 -6
  1162. package/src/components/FormField/FormField.tsx +3 -0
  1163. package/src/components/FormItem/FormItem.css +5 -3
  1164. package/src/components/FormLayoutGroup/FormLayoutGroup.css +35 -0
  1165. package/src/components/FormLayoutGroup/FormLayoutGroup.tsx +13 -2
  1166. package/src/components/FormLayoutGroup/Readme.md +58 -48
  1167. package/src/components/FormStatus/FormStatus.css +8 -5
  1168. package/src/components/FormStatus/FormStatus.tsx +4 -8
  1169. package/src/components/FormStatus/Readme.md +4 -0
  1170. package/src/components/Gallery/Gallery.tsx +1 -0
  1171. package/src/components/Gallery/Readme.md +64 -18
  1172. package/src/components/Gradient/Readme.md +1 -1
  1173. package/src/components/Group/Group.css +11 -2
  1174. package/src/components/Group/Group.tsx +7 -1
  1175. package/src/components/Group/Readme.md +2 -2
  1176. package/src/components/Header/Header.css +10 -11
  1177. package/src/components/Header/Header.tsx +9 -8
  1178. package/src/components/HorizontalCell/Readme.md +1 -1
  1179. package/src/components/IconButton/IconButton.tsx +2 -2
  1180. package/src/components/Input/Input.css +1 -1
  1181. package/src/components/Input/Input.tsx +2 -0
  1182. package/src/components/Link/Link.css +2 -1
  1183. package/src/components/List/List.tsx +3 -4
  1184. package/src/components/ModalDismissButton/ModalDismissButton.css +6 -6
  1185. package/src/components/ModalDismissButton/ModalDismissButton.tsx +1 -5
  1186. package/src/components/ModalDismissButton/Readme.md +1 -1
  1187. package/src/components/ModalPage/ModalPage.css +69 -63
  1188. package/src/components/ModalPage/ModalPage.tsx +24 -11
  1189. package/src/components/ModalPageHeader/ModalPageHeader.css +9 -12
  1190. package/src/components/ModalPageHeader/ModalPageHeader.tsx +3 -2
  1191. package/src/components/ModalRoot/ModalRoot.css +14 -2
  1192. package/src/components/ModalRoot/ModalRoot.tsx +24 -24
  1193. package/src/components/ModalRoot/ModalRootDesktop.tsx +12 -14
  1194. package/src/components/ModalRoot/Readme.md +8 -3
  1195. package/src/components/NativeSelect/NativeSelect.tsx +5 -2
  1196. package/src/components/Panel/Panel.css +54 -24
  1197. package/src/components/Panel/Panel.tsx +7 -9
  1198. package/src/components/PanelHeader/PanelHeader.css +20 -8
  1199. package/src/components/PanelHeader/PanelHeader.tsx +11 -12
  1200. package/src/components/PanelHeaderBack/PanelHeaderBack.tsx +6 -5
  1201. package/src/components/PanelHeaderButton/PanelHeaderButton.css +8 -15
  1202. package/src/components/PanelHeaderButton/PanelHeaderButton.tsx +6 -6
  1203. package/src/components/PanelHeaderClose/PanelHeaderClose.tsx +2 -6
  1204. package/src/components/PanelHeaderContent/PanelHeaderContent.css +14 -26
  1205. package/src/components/PanelHeaderContent/PanelHeaderContent.tsx +10 -3
  1206. package/src/components/PanelHeaderContent/Readme.md +5 -1
  1207. package/src/components/PanelHeaderContext/PanelHeaderContext.css +9 -25
  1208. package/src/components/PanelHeaderContext/PanelHeaderContext.tsx +11 -7
  1209. package/src/components/PanelHeaderContext/Readme.md +85 -101
  1210. package/src/components/PanelHeaderEdit/PanelHeaderEdit.tsx +2 -2
  1211. package/src/components/PanelHeaderSubmit/PanelHeaderSubmit.tsx +2 -6
  1212. package/src/components/PromoBanner/PromoBanner.css +10 -22
  1213. package/src/components/PromoBanner/PromoBanner.tsx +2 -6
  1214. package/src/components/RichTooltip/Readme.md +2 -2
  1215. package/src/components/Search/Search.css +134 -48
  1216. package/src/components/Search/Search.tsx +13 -8
  1217. package/src/components/Select/Select.css +2 -2
  1218. package/src/components/SelectMimicry/Readme.md +3 -3
  1219. package/src/components/SelectMimicry/SelectMimicry.tsx +3 -1
  1220. package/src/components/SimpleCell/Readme.md +3 -3
  1221. package/src/components/SimpleCell/SimpleCell.css +6 -1
  1222. package/src/components/SimpleCell/SimpleCell.tsx +71 -8
  1223. package/src/components/SliderSwitch/SliderSwitch.tsx +5 -5
  1224. package/src/components/SliderSwitch/SliderSwitchButton.tsx +7 -7
  1225. package/src/components/Snackbar/Readme.md +12 -3
  1226. package/src/components/SplitLayout/Readme.md +1 -1
  1227. package/src/components/SplitLayout/SplitLayout.css +8 -2
  1228. package/src/components/SubnavigationBar/SubnavigationBar.css +7 -19
  1229. package/src/components/SubnavigationBar/SubnavigationBar.tsx +1 -8
  1230. package/src/components/SubnavigationButton/Readme.md +133 -116
  1231. package/src/components/SubnavigationButton/SubnavigationButton.css +95 -49
  1232. package/src/components/SubnavigationButton/SubnavigationButton.tsx +22 -18
  1233. package/src/components/TabbarItem/Readme.md +6 -1
  1234. package/src/components/Tabs/Readme.md +10 -2
  1235. package/src/components/TabsItem/TabsItem.css +9 -3
  1236. package/src/components/Tappable/Tappable.tsx +22 -22
  1237. package/src/components/Textarea/Textarea.css +1 -1
  1238. package/src/components/Textarea/Textarea.tsx +5 -2
  1239. package/src/components/Tooltip/Readme.md +9 -9
  1240. package/src/components/Touch/Readme.md +4 -4
  1241. package/src/components/UsersStack/UsersStack.css +42 -0
  1242. package/src/components/UsersStack/UsersStack.tsx +80 -18
  1243. package/src/components/View/Readme.md +5 -5
  1244. package/src/components/View/View.tsx +2 -9
  1245. package/src/components/View/ViewInfinite.tsx +14 -14
  1246. package/src/components/VisuallyHiddenInput/VisuallyHiddenInput.tsx +1 -6
  1247. package/src/{components/ChipsInput → hooks}/useChipsInput.ts +5 -8
  1248. package/src/{components/ChipsSelect → hooks}/useChipsSelect.ts +4 -4
  1249. package/src/index.ts +5 -0
  1250. package/src/lib/animate.ts +1 -1
  1251. package/src/lib/testing.ts +1 -1
  1252. package/src/lib/touch.ts +1 -1
  1253. package/src/styles/components.css +1 -0
  1254. package/src/styles/vkcom_dark.css +8 -8
  1255. package/src/styles/vkcom_light.css +34 -34
  1256. package/src/testing/utils.tsx +1 -1
  1257. package/src/tokenized/index.ts +88 -0
  1258. package/.cache/ts/src/components/UsersStack/masks.d.ts +0 -1
  1259. package/dist/cjs/components/ChipsInput/useChipsInput.js.map +0 -1
  1260. package/dist/cjs/components/ChipsSelect/useChipsSelect.js.map +0 -1
  1261. package/dist/cjs/components/UsersStack/masks.js +0 -29
  1262. package/dist/cjs/components/UsersStack/masks.js.map +0 -1
  1263. package/dist/components/ChipsInput/useChipsInput.js.map +0 -1
  1264. package/dist/components/ChipsSelect/useChipsSelect.js.map +0 -1
  1265. package/dist/components/UsersStack/masks.d.ts +0 -1
  1266. package/dist/components/UsersStack/masks.js +0 -20
  1267. package/dist/components/UsersStack/masks.js.map +0 -1
  1268. package/dist/cssm/components/ChipsInput/useChipsInput.js.map +0 -1
  1269. package/dist/cssm/components/ChipsSelect/useChipsSelect.js.map +0 -1
  1270. package/dist/cssm/components/DropdownIcon/DropdownIcon.css +0 -1
  1271. package/dist/cssm/components/UsersStack/masks.d.ts +0 -1
  1272. package/dist/cssm/components/UsersStack/masks.js +0 -20
  1273. package/dist/cssm/components/UsersStack/masks.js.map +0 -1
  1274. package/src/components/DropdownIcon/DropdownIcon.css +0 -3
  1275. package/src/components/UsersStack/masks.tsx +0 -69
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/ModalPage/ModalPage.tsx"],"names":["React","getClassName","classNames","ModalRootContext","useModalRegistry","usePlatform","useOrientationChange","withAdaptivity","ViewWidth","ModalDismissButton","multiRef","ModalType","getNavId","warnOnce","Platform","useAdaptivityIsDesktop","warn","ModalPageComponent","children","header","viewWidth","viewHeight","sizeX","hasMouse","onOpen","onOpened","onClose","onClosed","settlingHeight","dynamicContentHeight","getModalContentRef","nav","id","restProps","useContext","updateModalHeight","platform","orientation","useEffect","isDesktop","canShowCloseBtn","SMALL_TABLET","VKCOM","modalContext","PAGE","refs","innerElement","headerElement","contentElement","ModalPage","displayName"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport {\n ModalRootContext,\n useModalRegistry,\n} from \"../ModalRoot/ModalRootContext\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useOrientationChange } from \"../../hooks/useOrientationChange\";\nimport { withAdaptivity, ViewWidth } from \"../../hoc/withAdaptivity\";\nimport {\n AdaptivityContextInterface,\n AdaptivityProps,\n} from \"../AdaptivityProvider/AdaptivityContext\";\nimport { ModalDismissButton } from \"../ModalDismissButton/ModalDismissButton\";\nimport { multiRef } from \"../../lib/utils\";\nimport { ModalType } from \"../ModalRoot/types\";\nimport { getNavId, NavIdProps } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { Platform } from \"../../lib/platform\";\nimport { useAdaptivityIsDesktop } from \"../../hooks/useAdaptivity\";\nimport \"./ModalPage.css\";\n\nexport interface ModalPageProps\n extends React.HTMLAttributes<HTMLDivElement>,\n AdaptivityProps,\n NavIdProps {\n /**\n * Шапка модальной страницы, `<ModalPageHeader />`\n */\n header?: React.ReactNode;\n /**\n * Будет вызвано при начале открытия модалки.\n */\n onOpen?: VoidFunction;\n /**\n * Будет вызвано при окончательном открытии модалки.\n */\n onOpened?: VoidFunction;\n /**\n * Будет вызвано при начале закрытия модалки.\n */\n onClose?: VoidFunction;\n /**\n * Будет вызвано при окончательном закрытии модалки.\n */\n onClosed?: VoidFunction;\n /**\n * Процент, на который изначально будет открыта модальная страница. При `settlingHeight={100}` модальная страница раскрывается на всю высоту.\n */\n settlingHeight?: number;\n /**\n * Если высота контента в модальной странице может поменяться, нужно установить это свойство\n */\n dynamicContentHeight?: boolean;\n getModalContentRef?: React.Ref<HTMLDivElement>;\n}\n\nconst warn = warnOnce(\"ModalPage\");\n\nconst ModalPageComponent = ({\n children,\n header,\n viewWidth,\n viewHeight,\n sizeX,\n hasMouse,\n onOpen,\n onOpened,\n onClose,\n onClosed,\n settlingHeight, // 75\n dynamicContentHeight,\n getModalContentRef,\n nav,\n id,\n ...restProps\n}: ModalPageProps & AdaptivityContextInterface) => {\n const { updateModalHeight } = React.useContext(ModalRootContext);\n\n const platform = usePlatform();\n const orientation = useOrientationChange();\n\n React.useEffect(updateModalHeight, [\n children,\n orientation,\n updateModalHeight,\n ]);\n\n const isDesktop = useAdaptivityIsDesktop();\n const canShowCloseBtn =\n viewWidth >= ViewWidth.SMALL_TABLET || platform === Platform.VKCOM;\n\n const modalContext = React.useContext(ModalRootContext);\n const { refs } = useModalRegistry(\n getNavId({ nav, id }, warn),\n ModalType.PAGE\n );\n\n return (\n <div\n {...restProps}\n id={id}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"ModalPage\", platform),\n `ModalPage--sizeX-${sizeX}`,\n {\n \"ModalPage--desktop\": isDesktop,\n }\n )}\n >\n <div vkuiClass=\"ModalPage__in-wrap\" ref={refs.innerElement}>\n <div vkuiClass=\"ModalPage__in\">\n <div vkuiClass=\"ModalPage__header\" ref={refs.headerElement}>\n {header}\n </div>\n\n <div vkuiClass=\"ModalPage__content-wrap\">\n <div\n vkuiClass=\"ModalPage__content\"\n ref={multiRef<HTMLDivElement>(\n refs.contentElement,\n getModalContentRef\n )}\n >\n <div vkuiClass=\"ModalPage__content-in\">{children}</div>\n </div>\n </div>\n {canShowCloseBtn && (\n <ModalDismissButton onClick={onClose || modalContext.onClose} />\n )}\n </div>\n </div>\n </div>\n );\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalPage\n */\nexport const ModalPage = withAdaptivity(ModalPageComponent, {\n viewWidth: true,\n viewHeight: true,\n sizeX: true,\n hasMouse: true,\n});\n\nModalPage.displayName = \"ModalPage\";\n"],"file":"ModalPage.js"}
1
+ {"version":3,"file":"ModalPage.js","names":["React","classNames","ModalRootContext","useModalRegistry","usePlatform","useOrientationChange","withAdaptivity","ModalDismissButton","multiRef","ModalType","getNavId","warnOnce","Platform","useAdaptivityIsDesktop","warn","ModalPageComponent","children","header","size","sizeProp","viewWidth","viewHeight","sizeX","hasMouse","onOpen","onOpened","onClose","onClosed","settlingHeight","dynamicContentHeight","getModalContentRef","nav","id","hideCloseButton","restProps","useContext","updateModalHeight","platform","orientation","useEffect","isDesktop","isCloseButtonShown","modalContext","PAGE","refs","IOS","VKCOM","innerElement","headerElement","contentElement","ModalPage","displayName"],"sources":["../../../src/components/ModalPage/ModalPage.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport {\n ModalRootContext,\n useModalRegistry,\n} from \"../ModalRoot/ModalRootContext\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useOrientationChange } from \"../../hooks/useOrientationChange\";\nimport { withAdaptivity } from \"../../hoc/withAdaptivity\";\nimport {\n AdaptivityContextInterface,\n AdaptivityProps,\n} from \"../AdaptivityProvider/AdaptivityContext\";\nimport { ModalDismissButton } from \"../ModalDismissButton/ModalDismissButton\";\nimport { multiRef } from \"../../lib/utils\";\nimport { ModalType } from \"../ModalRoot/types\";\nimport { getNavId, NavIdProps } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { Platform } from \"../../lib/platform\";\nimport { useAdaptivityIsDesktop } from \"../../hooks/useAdaptivity\";\nimport \"./ModalPage.css\";\n\nexport interface ModalPageProps\n extends React.HTMLAttributes<HTMLDivElement>,\n AdaptivityProps,\n NavIdProps {\n /**\n * Шапка модальной страницы, `<ModalPageHeader />`\n */\n header?: React.ReactNode;\n /**\n * Задаёт контенту максимальную ширину.\n *\n * > ⚠️ **Заметки:**\n * > - Для `viewWidth < SMALL_TABLET_SIZE` будет всегда `\"s\"`\n * > - Для `platform === VKCOM` максимальная ширина зашита, её не изменить.\n */\n size?: \"s\" | \"m\" | \"l\";\n /**\n * Будет вызвано при начале открытия модалки.\n */\n onOpen?: VoidFunction;\n /**\n * Будет вызвано при окончательном открытии модалки.\n */\n onOpened?: VoidFunction;\n /**\n * Будет вызвано при начале закрытия модалки.\n */\n onClose?: VoidFunction;\n /**\n * Будет вызвано при окончательном закрытии модалки.\n */\n onClosed?: VoidFunction;\n /**\n * Процент, на который изначально будет открыта модальная страница. При `settlingHeight={100}` модальная страница раскрывается на всю высоту.\n */\n settlingHeight?: number;\n /**\n * Если высота контента в модальной странице может поменяться, нужно установить это свойство\n */\n dynamicContentHeight?: boolean;\n getModalContentRef?: React.Ref<HTMLDivElement>;\n /**\n * Скрывает кнопку закрытия (актуально для iOS, т.к. можно отрисовать кнопку закрытия внутри модалки)\n */\n hideCloseButton?: boolean;\n}\n\nconst warn = warnOnce(\"ModalPage\");\n\nconst ModalPageComponent = ({\n children,\n header,\n size: sizeProp = \"s\",\n viewWidth,\n viewHeight,\n sizeX,\n hasMouse,\n onOpen,\n onOpened,\n onClose,\n onClosed,\n settlingHeight, // 75\n dynamicContentHeight,\n getModalContentRef,\n nav,\n id,\n hideCloseButton = false,\n ...restProps\n}: ModalPageProps & AdaptivityContextInterface) => {\n const { updateModalHeight } = React.useContext(ModalRootContext);\n\n const platform = usePlatform();\n const orientation = useOrientationChange();\n\n React.useEffect(updateModalHeight, [\n children,\n orientation,\n updateModalHeight,\n ]);\n\n const isDesktop = useAdaptivityIsDesktop();\n const isCloseButtonShown = !hideCloseButton && isDesktop;\n const size = isDesktop ? sizeProp : \"s\";\n\n const modalContext = React.useContext(ModalRootContext);\n const { refs } = useModalRegistry(\n getNavId({ nav, id }, warn),\n ModalType.PAGE\n );\n\n return (\n <div\n {...restProps}\n id={id}\n vkuiClass={classNames(\n \"ModalPage\",\n platform === Platform.IOS && \"ModalPage--ios\",\n platform === Platform.VKCOM && \"ModalPage--vkcom\",\n `ModalPage--sizeX-${sizeX}`, // TODO v5.0.0 поправить под новую адаптивность\n isDesktop && \"ModalPage--desktop\",\n size && `ModalPage--${size}`\n )}\n >\n <div vkuiClass=\"ModalPage__in-wrap\" ref={refs.innerElement}>\n <div vkuiClass=\"ModalPage__in\">\n <div vkuiClass=\"ModalPage__header\" ref={refs.headerElement}>\n {header}\n </div>\n\n <div vkuiClass=\"ModalPage__content-wrap\">\n <div\n vkuiClass=\"ModalPage__content\"\n ref={multiRef<HTMLDivElement>(\n refs.contentElement,\n getModalContentRef\n )}\n >\n <div vkuiClass=\"ModalPage__content-in\">{children}</div>\n </div>\n </div>\n {isCloseButtonShown && (\n <ModalDismissButton onClick={onClose || modalContext.onClose} />\n )}\n </div>\n </div>\n </div>\n );\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalPage\n */\nexport const ModalPage = withAdaptivity(ModalPageComponent, {\n viewWidth: true,\n viewHeight: true,\n sizeX: true,\n hasMouse: true,\n});\n\nModalPage.displayName = \"ModalPage\";\n"],"mappings":";;;;AAAA,OAAO,KAAKA,KAAZ,MAAuB,OAAvB;AACA,SAASC,UAAT;AACA,SACEC,gBADF,EAEEC,gBAFF;AAIA,SAASC,WAAT;AACA,SAASC,oBAAT;AACA,SAASC,cAAT;AAKA,SAASC,kBAAT;AACA,SAASC,QAAT;AACA,SAASC,SAAT;AACA,SAASC,QAAT;AACA,SAASC,QAAT;AACA,SAASC,QAAT;AACA,SAASC,sBAAT;AAkDA,IAAMC,IAAI,GAAGH,QAAQ,CAAC,WAAD,CAArB;;AAEA,IAAMI,kBAAkB,GAAG,SAArBA,kBAAqB,OAmBwB;EAAA,IAlBjDC,QAkBiD,QAlBjDA,QAkBiD;EAAA,IAjBjDC,MAiBiD,QAjBjDA,MAiBiD;EAAA,qBAhBjDC,IAgBiD;EAAA,IAhB3CC,QAgB2C,0BAhBhC,GAgBgC;EAAA,IAfjDC,SAeiD,QAfjDA,SAeiD;EAAA,IAdjDC,UAciD,QAdjDA,UAciD;EAAA,IAbjDC,KAaiD,QAbjDA,KAaiD;EAAA,IAZjDC,QAYiD,QAZjDA,QAYiD;EAAA,IAXjDC,MAWiD,QAXjDA,MAWiD;EAAA,IAVjDC,QAUiD,QAVjDA,QAUiD;EAAA,IATjDC,OASiD,QATjDA,OASiD;EAAA,IARjDC,QAQiD,QARjDA,QAQiD;EAAA,IAPjDC,cAOiD,QAPjDA,cAOiD;EAAA,IANjDC,oBAMiD,QANjDA,oBAMiD;EAAA,IALjDC,kBAKiD,QALjDA,kBAKiD;EAAA,IAJjDC,GAIiD,QAJjDA,GAIiD;EAAA,IAHjDC,EAGiD,QAHjDA,EAGiD;EAAA,gCAFjDC,eAEiD;EAAA,IAFjDA,eAEiD,qCAF/B,KAE+B;EAAA,IAD9CC,SAC8C;;EACjD,wBAA8BlC,KAAK,CAACmC,UAAN,CAAiBjC,gBAAjB,CAA9B;EAAA,IAAQkC,iBAAR,qBAAQA,iBAAR;;EAEA,IAAMC,QAAQ,GAAGjC,WAAW,EAA5B;EACA,IAAMkC,WAAW,GAAGjC,oBAAoB,EAAxC;EAEAL,KAAK,CAACuC,SAAN,CAAgBH,iBAAhB,EAAmC,CACjCpB,QADiC,EAEjCsB,WAFiC,EAGjCF,iBAHiC,CAAnC;EAMA,IAAMI,SAAS,GAAG3B,sBAAsB,EAAxC;EACA,IAAM4B,kBAAkB,GAAG,CAACR,eAAD,IAAoBO,SAA/C;EACA,IAAMtB,IAAI,GAAGsB,SAAS,GAAGrB,QAAH,GAAc,GAApC;EAEA,IAAMuB,YAAY,GAAG1C,KAAK,CAACmC,UAAN,CAAiBjC,gBAAjB,CAArB;;EACA,wBAAiBC,gBAAgB,CAC/BO,QAAQ,CAAC;IAAEqB,GAAG,EAAHA,GAAF;IAAOC,EAAE,EAAFA;EAAP,CAAD,EAAclB,IAAd,CADuB,EAE/BL,SAAS,CAACkC,IAFqB,CAAjC;EAAA,IAAQC,IAAR,qBAAQA,IAAR;;EAKA,OACE,wCACMV,SADN;IAEE,EAAE,EAAEF,EAFN;IAGE,SAAS,EAAE/B,UAAU,CACnB,WADmB,EAEnBoC,QAAQ,KAAKzB,QAAQ,CAACiC,GAAtB,IAA6B,gBAFV,EAGnBR,QAAQ,KAAKzB,QAAQ,CAACkC,KAAtB,IAA+B,kBAHZ,6BAICxB,KAJD,GAIU;IAC7BkB,SAAS,IAAI,oBALM,EAMnBtB,IAAI,yBAAkBA,IAAlB,CANe;EAHvB,IAYE;IAAK,SAAS,EAAC,oBAAf;IAAoC,GAAG,EAAE0B,IAAI,CAACG;EAA9C,GACE;IAAK,SAAS,EAAC;EAAf,GACE;IAAK,SAAS,EAAC,mBAAf;IAAmC,GAAG,EAAEH,IAAI,CAACI;EAA7C,GACG/B,MADH,CADF,EAKE;IAAK,SAAS,EAAC;EAAf,GACE;IACE,SAAS,EAAC,oBADZ;IAEE,GAAG,EAAET,QAAQ,CACXoC,IAAI,CAACK,cADM,EAEXnB,kBAFW;EAFf,GAOE;IAAK,SAAS,EAAC;EAAf,GAAwCd,QAAxC,CAPF,CADF,CALF,EAgBGyB,kBAAkB,IACjB,oBAAC,kBAAD;IAAoB,OAAO,EAAEf,OAAO,IAAIgB,YAAY,CAAChB;EAArD,EAjBJ,CADF,CAZF,CADF;AAqCD,CA9ED;AAgFA;AACA;AACA;;;AACA,OAAO,IAAMwB,SAAS,GAAG5C,cAAc,CAACS,kBAAD,EAAqB;EAC1DK,SAAS,EAAE,IAD+C;EAE1DC,UAAU,EAAE,IAF8C;EAG1DC,KAAK,EAAE,IAHmD;EAI1DC,QAAQ,EAAE;AAJgD,CAArB,CAAhC;AAOP2B,SAAS,CAACC,WAAV,GAAwB,WAAxB"}
@@ -8,7 +8,6 @@ import { VKCOM } from "../../lib/platform";
8
8
  import { Separator } from "../Separator/Separator";
9
9
  import { PanelHeader } from "../PanelHeader/PanelHeader";
10
10
  import { classNames } from "../../lib/classNames";
11
- import { getClassName } from "../../helpers/getClassName";
12
11
 
13
12
  /**
14
13
  * @see https://vkcom.github.io/VKUI/#/ModalPageHeader
@@ -21,10 +20,11 @@ export var ModalPageHeader = function ModalPageHeader(_ref) {
21
20
  restProps = _objectWithoutProperties(_ref, _excluded);
22
21
 
23
22
  var platform = usePlatform();
24
- var hasSeparator = separator && platform === VKCOM;
23
+ var hasSeparator = separator && platform === VKCOM; // TODO v5.0.0 поправить под новую адаптивность
24
+
25
25
  var isDesktop = useAdaptivityIsDesktop();
26
26
  return createScopedElement("div", {
27
- vkuiClass: classNames(getClassName("ModalPageHeader", platform), isDesktop && "ModalPageHeader--desktop"),
27
+ vkuiClass: classNames("ModalPageHeader", platform !== VKCOM && "ModalPageHeader--withGaps", isDesktop && "ModalPageHeader--desktop"),
28
28
  ref: getRef
29
29
  }, createScopedElement(PanelHeader, _extends({
30
30
  vkuiClass: "ModalPageHeader__in"
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/ModalPageHeader/ModalPageHeader.tsx"],"names":["usePlatform","useAdaptivityIsDesktop","VKCOM","Separator","PanelHeader","classNames","getClassName","ModalPageHeader","children","separator","getRef","restProps","platform","hasSeparator","isDesktop"],"mappings":";;;;AACA,SAASA,WAAT;AACA,SAASC,sBAAT;AAEA,SAASC,KAAT;AACA,SAASC,SAAT;AACA,SAASC,WAAT;AACA,SAASC,UAAT;AACA,SAASC,YAAT;;AAQA;AACA;AACA;AACA,OAAO,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,OAKH;AAAA,MAJ1BC,QAI0B,QAJ1BA,QAI0B;AAAA,4BAH1BC,SAG0B;AAAA,MAH1BA,SAG0B,+BAHd,IAGc;AAAA,MAF1BC,MAE0B,QAF1BA,MAE0B;AAAA,MADvBC,SACuB;;AAC1B,MAAMC,QAAQ,GAAGZ,WAAW,EAA5B;AACA,MAAMa,YAAY,GAAGJ,SAAS,IAAIG,QAAQ,KAAKV,KAA/C;AACA,MAAMY,SAAS,GAAGb,sBAAsB,EAAxC;AAEA,SACE;AACE,IAAA,SAAS,EAAEI,UAAU,CACnBC,YAAY,CAAC,iBAAD,EAAoBM,QAApB,CADO,EAEnBE,SAAS,IAAI,0BAFM,CADvB;AAKE,IAAA,GAAG,EAAEJ;AALP,KAOE,oBAAC,WAAD;AACE,IAAA,SAAS,EAAC;AADZ,KAEMC,SAFN;AAGE,IAAA,KAAK,EAAE,KAHT;AAIE,IAAA,SAAS,EAAE,KAJb;AAKE,IAAA,WAAW;AALb,MAOGH,QAPH,CAPF,EAgBGK,YAAY,IAAI,oBAAC,SAAD;AAAW,IAAA,IAAI;AAAf,IAhBnB,CADF;AAoBD,CA9BM","sourcesContent":["import * as React from \"react\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useAdaptivityIsDesktop } from \"../../hooks/useAdaptivity\";\nimport { HasRef } from \"../../types\";\nimport { VKCOM } from \"../../lib/platform\";\nimport { Separator } from \"../Separator/Separator\";\nimport { PanelHeader, PanelHeaderProps } from \"../PanelHeader/PanelHeader\";\nimport { classNames } from \"../../lib/classNames\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport \"./ModalPageHeader.css\";\n\nexport interface ModalPageHeaderProps\n extends React.HTMLAttributes<HTMLDivElement>,\n Omit<PanelHeaderProps, \"fixed\" | \"shadow\">,\n HasRef<HTMLDivElement> {}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalPageHeader\n */\nexport const ModalPageHeader = ({\n children,\n separator = true,\n getRef,\n ...restProps\n}: ModalPageHeaderProps) => {\n const platform = usePlatform();\n const hasSeparator = separator && platform === VKCOM;\n const isDesktop = useAdaptivityIsDesktop();\n\n return (\n <div\n vkuiClass={classNames(\n getClassName(\"ModalPageHeader\", platform),\n isDesktop && \"ModalPageHeader--desktop\"\n )}\n ref={getRef}\n >\n <PanelHeader\n vkuiClass=\"ModalPageHeader__in\"\n {...restProps}\n fixed={false}\n separator={false}\n transparent\n >\n {children}\n </PanelHeader>\n {hasSeparator && <Separator wide />}\n </div>\n );\n};\n"],"file":"ModalPageHeader.js"}
1
+ {"version":3,"file":"ModalPageHeader.js","names":["usePlatform","useAdaptivityIsDesktop","VKCOM","Separator","PanelHeader","classNames","ModalPageHeader","children","separator","getRef","restProps","platform","hasSeparator","isDesktop"],"sources":["../../../src/components/ModalPageHeader/ModalPageHeader.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useAdaptivityIsDesktop } from \"../../hooks/useAdaptivity\";\nimport { HasRef } from \"../../types\";\nimport { VKCOM } from \"../../lib/platform\";\nimport { Separator } from \"../Separator/Separator\";\nimport { PanelHeader, PanelHeaderProps } from \"../PanelHeader/PanelHeader\";\nimport { classNames } from \"../../lib/classNames\";\nimport \"./ModalPageHeader.css\";\n\nexport interface ModalPageHeaderProps\n extends React.HTMLAttributes<HTMLDivElement>,\n Omit<PanelHeaderProps, \"fixed\" | \"shadow\">,\n HasRef<HTMLDivElement> {}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalPageHeader\n */\nexport const ModalPageHeader = ({\n children,\n separator = true,\n getRef,\n ...restProps\n}: ModalPageHeaderProps) => {\n const platform = usePlatform();\n const hasSeparator = separator && platform === VKCOM;\n // TODO v5.0.0 поправить под новую адаптивность\n const isDesktop = useAdaptivityIsDesktop();\n\n return (\n <div\n vkuiClass={classNames(\n \"ModalPageHeader\",\n platform !== VKCOM && \"ModalPageHeader--withGaps\",\n isDesktop && \"ModalPageHeader--desktop\"\n )}\n ref={getRef}\n >\n <PanelHeader\n vkuiClass=\"ModalPageHeader__in\"\n {...restProps}\n fixed={false}\n separator={false}\n transparent\n >\n {children}\n </PanelHeader>\n {hasSeparator && <Separator wide />}\n </div>\n );\n};\n"],"mappings":";;;;AACA,SAASA,WAAT;AACA,SAASC,sBAAT;AAEA,SAASC,KAAT;AACA,SAASC,SAAT;AACA,SAASC,WAAT;AACA,SAASC,UAAT;;AAQA;AACA;AACA;AACA,OAAO,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,OAKH;EAAA,IAJ1BC,QAI0B,QAJ1BA,QAI0B;EAAA,0BAH1BC,SAG0B;EAAA,IAH1BA,SAG0B,+BAHd,IAGc;EAAA,IAF1BC,MAE0B,QAF1BA,MAE0B;EAAA,IADvBC,SACuB;;EAC1B,IAAMC,QAAQ,GAAGX,WAAW,EAA5B;EACA,IAAMY,YAAY,GAAGJ,SAAS,IAAIG,QAAQ,KAAKT,KAA/C,CAF0B,CAG1B;;EACA,IAAMW,SAAS,GAAGZ,sBAAsB,EAAxC;EAEA,OACE;IACE,SAAS,EAAEI,UAAU,CACnB,iBADmB,EAEnBM,QAAQ,KAAKT,KAAb,IAAsB,2BAFH,EAGnBW,SAAS,IAAI,0BAHM,CADvB;IAME,GAAG,EAAEJ;EANP,GAQE,oBAAC,WAAD;IACE,SAAS,EAAC;EADZ,GAEMC,SAFN;IAGE,KAAK,EAAE,KAHT;IAIE,SAAS,EAAE,KAJb;IAKE,WAAW;EALb,IAOGH,QAPH,CARF,EAiBGK,YAAY,IAAI,oBAAC,SAAD;IAAW,IAAI;EAAf,EAjBnB,CADF;AAqBD,CAhCM"}
@@ -652,13 +652,8 @@ var ModalRootTouchComponent = /*#__PURE__*/function (_React$Component) {
652
652
  value: true
653
653
  }, createScopedElement(ModalRootContext.Provider, {
654
654
  value: this.modalRootContext
655
- }, createScopedElement(Touch // eslint-disable-next-line vkui/no-object-expression-in-arguments
656
- , {
657
- vkuiClass: classNames(getClassName("ModalRoot", this.props.platform), {
658
- "ModalRoot--vkapps": ((_this$props$configPro = this.props.configProvider) === null || _this$props$configPro === void 0 ? void 0 : _this$props$configPro.webviewType) === WebviewType.VKAPPS,
659
- "ModalRoot--touched": touchDown,
660
- "ModalRoot--switching": !!(enteringModal || exitingModal)
661
- }),
655
+ }, createScopedElement(Touch, {
656
+ vkuiClass: classNames(getClassName("ModalRoot", this.props.platform), ((_this$props$configPro = this.props.configProvider) === null || _this$props$configPro === void 0 ? void 0 : _this$props$configPro.webviewType) === WebviewType.VKAPPS && "ModalRoot--vkapps", touchDown && "ModalRoot--touched", !!(enteringModal || exitingModal) && "ModalRoot--switching"),
662
657
  onMove: this.onTouchMove,
663
658
  onEnd: this.onTouchEnd,
664
659
  onScroll: this.onScroll
@@ -692,17 +687,8 @@ var ModalRootTouchComponent = /*#__PURE__*/function (_React$Component) {
692
687
  }
693
688
  },
694
689
  onClose: _this7.props.onExit,
695
- timeout: _this7.timeout // eslint-disable-next-line vkui/no-object-expression-in-arguments
696
- ,
697
- vkuiClass: classNames("ModalRoot__modal", {
698
- "ModalRoot__modal--active": modalId === activeModal,
699
- "ModalRoot__modal--prev": modalId === exitingModal,
700
- "ModalRoot__modal--next": exitingModal && modalId === activeModal || modalId === enteringModal,
701
- "ModalRoot__modal--dragging": dragging,
702
- "ModalRoot__modal--expandable": isPage && modalState.expandable,
703
- "ModalRoot__modal--expanded": isPage && modalState.expanded,
704
- "ModalRoot__modal--collapsed": isPage && modalState.collapsed
705
- }),
690
+ timeout: _this7.timeout,
691
+ vkuiClass: classNames("ModalRoot__modal", modalId === activeModal && "ModalRoot__modal--active", modalId === exitingModal && "ModalRoot__modal--prev", (exitingModal && modalId === activeModal || modalId === enteringModal) && "ModalRoot__modal--next", dragging && "ModalRoot__modal--dragging", isPage && modalState.expandable && "ModalRoot__modal--expandable", isPage && modalState.expanded && "ModalRoot__modal--expanded", isPage && modalState.collapsed && "ModalRoot__modal--collapsed"),
706
692
  restoreFocus: false
707
693
  }, Modal);
708
694
  })))));
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/ModalRoot/ModalRoot.tsx"],"names":["React","Touch","TouchRootContext","getClassName","classNames","setTransformStyle","rubber","ANDROID","IOS","VKCOM","transitionEvent","withPlatform","withContext","ModalRootContext","ConfigProviderContext","WebviewType","ModalType","MODAL_PAGE_DEFAULT_PERCENT_HEIGHT","withDOM","getNavId","warnOnce","FocusTrap","withModalManager","warn","IS_DEV","process","env","NODE_ENV","numberInRange","number","range","rangeTranslate","Math","max","min","ModalRootTouchComponent","props","createRef","undefined","event","originalEvent","preventDefault","modalState","getModalState","activeModal","animateTranslate","translateY","type","PAGE","dynamicContentHeight","enteringModal","waitTransitionFinish","requestAnimationFrame","checkPageContentHeight","e","exitingModal","onPageTouchMove","CARD","onCardTouchMove","onPageTouchEnd","onCardTouchEnd","target","contentElement","contains","contentScrolled","contentScrollStopTimeout","clearTimeout","setTimeout","state","touchDown","dragging","maskElementRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","onClose","onExit","isInsideModal","frameIds","platform","document","window","Children","toArray","children","addEventListener","updateModalTranslate","toggleDocumentScrolling","removeEventListener","prevProps","closeModal","enteringState","onEnter","innerElement","style","transitionDelay","onEntered","delayEnter","timeout","restoreFocusTo","activeElement","focus","enabled","documentScrolling","preventTouch","passive","modalElement","prevModalState","initPageModal","currentModalState","needAnimate","expandable","translateYFrom","setState","nextModalState","nextIsPage","prevIsPage","onExited","exitTranslate","isBack","setMaskOpacity","shiftY","isY","viewportRef","current","stopPropagation","collapsed","expanded","touchStartContentScrollTop","scrollTop","touchMovePositive","headerElement","shiftYPercent","innerHeight","shiftYCurrent","touchShiftYPercent","translateYCurrent","offsetHeight","startY","setStateCallback","shiftYEndPercent","expectTranslateY","duration","settlingHeight","expandedRange","collapsedRange","hiddenRange","hidden","eventHandler","supported","onceHandler","name","percent","frameId","cancelAnimationFrame","forceOpacity","history","maskAnimationFrame","opacity","toString","configProvider","webviewType","VKAPPS","onTouchMove","onTouchEnd","onScroll","getModals","map","Modal","modalId","_modalState","isPage","key","Component","ModalRootTouch","initModal","initCardModal","contentHeight","firstElementChild","prevTranslateY","clientHeight","shiftHalf","visiblePart","headerHeight","height","parentElement"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { Touch, TouchEvent } from \"../Touch/Touch\";\nimport TouchRootContext from \"../Touch/TouchContext\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport { setTransformStyle } from \"../../lib/styles\";\nimport { rubber } from \"../../lib/touch\";\nimport { ANDROID, IOS, VKCOM } from \"../../lib/platform\";\nimport { transitionEvent } from \"../../lib/supportEvents\";\nimport { HasPlatform } from \"../../types\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport { withContext } from \"../../hoc/withContext\";\nimport {\n ModalRootContext,\n ModalRootContextInterface,\n} from \"./ModalRootContext\";\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n WebviewType,\n} from \"../ConfigProvider/ConfigProviderContext\";\nimport { ModalsStateEntry, ModalType, TranslateRange } from \"./types\";\nimport { MODAL_PAGE_DEFAULT_PERCENT_HEIGHT } from \"./constants\";\nimport { DOMProps, withDOM } from \"../../lib/dom\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { FocusTrap } from \"../FocusTrap/FocusTrap\";\nimport { ModalTransitionProps, withModalManager } from \"./useModalManager\";\nimport \"./ModalRoot.css\";\n\nconst warn = warnOnce(\"ModalRoot\");\nconst IS_DEV = process.env.NODE_ENV === \"development\";\n\nfunction numberInRange(number: number, range: TranslateRange | undefined) {\n if (!range) {\n return false;\n }\n return number >= range[0] && number <= range[1];\n}\n\nfunction rangeTranslate(number: number) {\n return Math.max(0, Math.min(98, number));\n}\n\nexport interface ModalRootProps extends HasPlatform {\n activeModal?: string | null;\n\n /**\n * Будет вызвано при начале открытия активной модалки с её id\n */\n onOpen?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном открытии активной модалки с её id\n */\n onOpened?(modalId: string): void;\n\n /**\n * Будет вызвано при начале закрытия активной модалки с её id\n */\n onClose?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном закрытии активной модалки с её id\n */\n onClosed?(modalId: string): void;\n\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n children?: React.ReactNode;\n}\n\ninterface ModalRootState {\n touchDown?: boolean;\n dragging?: boolean;\n}\n\nclass ModalRootTouchComponent extends React.Component<\n ModalRootProps & DOMProps & ModalTransitionProps,\n ModalRootState\n> {\n constructor(props: ModalRootProps & ModalTransitionProps) {\n super(props);\n this.state = {\n touchDown: false,\n dragging: false,\n };\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: this.updateModalHeight,\n registerModal: ({ id, ...data }) =>\n Object.assign(this.getModalState(id), data),\n onClose: () => this.props.onExit(),\n isInsideModal: true,\n };\n\n this.frameIds = {};\n }\n\n private documentScrolling = false;\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private readonly viewportRef = React.createRef<HTMLDivElement>();\n private maskAnimationFrame: number | undefined = undefined;\n private readonly modalRootContext: ModalRootContextInterface;\n private readonly frameIds: {\n [index: string]: number;\n };\n private restoreFocusTo: HTMLElement | undefined | null = undefined;\n\n get timeout(): number {\n return this.props.platform === ANDROID || this.props.platform === VKCOM\n ? 320\n : 400;\n }\n\n get document() {\n return this.props.document;\n }\n\n get window() {\n return this.props.window;\n }\n\n getModalState(id: string | undefined | null) {\n if (!id) {\n return undefined;\n }\n return this.props.getModalState(id);\n }\n\n getModals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n componentDidMount() {\n // Отслеживаем изменение размеров viewport (Необходимо для iOS)\n if (this.props.platform === IOS) {\n this.window?.addEventListener(\"resize\", this.updateModalTranslate, false);\n }\n }\n\n componentWillUnmount() {\n this.toggleDocumentScrolling(true);\n this.window!.removeEventListener(\n \"resize\",\n this.updateModalTranslate,\n false\n );\n }\n\n componentDidUpdate(prevProps: ModalRootProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (\n this.props.exitingModal &&\n this.props.exitingModal !== prevProps.exitingModal\n ) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (\n this.props.enteringModal &&\n this.props.enteringModal !== prevProps.enteringModal\n ) {\n const { enteringModal } = this.props;\n const enteringState = this.getModalState(enteringModal);\n this.props.onEnter();\n this.waitTransitionFinish(enteringState, () => {\n if (enteringState?.innerElement) {\n enteringState.innerElement.style.transitionDelay = \"\";\n }\n this.props.onEntered(enteringModal);\n });\n\n if (enteringState?.innerElement) {\n enteringState.innerElement.style.transitionDelay = this.props.delayEnter\n ? `${this.timeout}ms`\n : \"\";\n this.animateTranslate(enteringState, enteringState.translateY);\n }\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = this.document!.activeElement as HTMLElement;\n }\n if (\n !this.props.activeModal &&\n !this.props.exitingModal &&\n this.restoreFocusTo\n ) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = null;\n }\n\n this.toggleDocumentScrolling(\n !this.props.activeModal && !this.props.exitingModal\n );\n }\n\n /* Отключает скролл документа */\n toggleDocumentScrolling(enabled: boolean) {\n if (this.documentScrolling === enabled) {\n return;\n }\n this.documentScrolling = enabled;\n\n if (enabled) {\n // Здесь нужен последний аргумент с такими же параметрами, потому что\n // некоторые браузеры на странных вендорах типа Meizu не удаляют обработчик.\n // https://github.com/VKCOM/VKUI/issues/444\n this.window!.removeEventListener(\"touchmove\", this.preventTouch, {\n // @ts-ignore (В интерфейсе EventListenerOptions нет поля passive)\n passive: false,\n });\n } else {\n this.window!.addEventListener(\"touchmove\", this.preventTouch, {\n passive: false,\n });\n }\n }\n\n preventTouch = (event: any) => {\n if (!event) {\n return false;\n }\n while (event.originalEvent) {\n event = event.originalEvent;\n }\n if (event.preventDefault) {\n event.preventDefault();\n }\n return false;\n };\n\n updateModalTranslate = () => {\n const modalState = this.getModalState(this.props.activeModal);\n modalState && this.animateTranslate(modalState, modalState.translateY);\n };\n\n checkPageContentHeight() {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState?.type === ModalType.PAGE && modalState?.modalElement) {\n const prevModalState = { ...modalState };\n initPageModal(modalState);\n const currentModalState = { ...modalState };\n\n let needAnimate = false;\n\n if (prevModalState.expandable === currentModalState.expandable) {\n if (\n prevModalState.translateYFrom !== currentModalState.translateYFrom\n ) {\n needAnimate = true;\n }\n } else {\n needAnimate = true;\n }\n\n if (needAnimate) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n }\n }\n\n updateModalHeight = () => {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (\n modalState &&\n modalState.type === ModalType.PAGE &&\n modalState.dynamicContentHeight\n ) {\n if (this.props.enteringModal) {\n this.waitTransitionFinish(modalState, () => {\n requestAnimationFrame(() => this.checkPageContentHeight());\n });\n } else {\n requestAnimationFrame(() => this.checkPageContentHeight());\n }\n }\n };\n\n closeModal(id: string) {\n // Сбрасываем состояния, которые могут помешать закрытию модального окна\n this.setState({ touchDown: false });\n\n const prevModalState = this.getModalState(id);\n\n if (!prevModalState) {\n id &&\n warn(\n `closeActiveModal: модальное окно (страница) ${id} не существует`,\n \"error\"\n );\n return;\n }\n\n const nextModalState = this.getModalState(this.props.activeModal);\n const nextIsPage =\n !!nextModalState && nextModalState.type === ModalType.PAGE;\n\n const prevIsPage =\n !!prevModalState && prevModalState.type === ModalType.PAGE;\n this.waitTransitionFinish(prevModalState, () => this.props.onExited(id));\n const exitTranslate =\n prevIsPage &&\n nextIsPage &&\n (prevModalState.translateY ?? 0) <=\n (nextModalState?.translateYFrom ?? 0) &&\n !this.props.isBack\n ? (nextModalState?.translateYFrom ?? 0) + 10\n : 100;\n this.animateTranslate(prevModalState, exitTranslate);\n\n if (!nextModalState) {\n // NOTE: was only for clean exit\n this.setMaskOpacity(prevModalState, 0);\n }\n }\n\n onTouchMove = (e: TouchEvent) => {\n if (this.props.exitingModal) {\n return;\n }\n const modalState = this.getModalState(this.props.activeModal);\n if (!modalState) {\n return;\n }\n\n if (modalState.type === ModalType.PAGE) {\n return this.onPageTouchMove(e, modalState);\n }\n\n if (modalState.type === ModalType.CARD) {\n return this.onCardTouchMove(e, modalState);\n }\n };\n\n onPageTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { shiftY, originalEvent } = event;\n const target = originalEvent.target as HTMLElement;\n\n if (!event.isY) {\n if (this.viewportRef.current?.contains(target)) {\n originalEvent.preventDefault();\n }\n return;\n }\n\n if (!modalState.innerElement?.contains(target)) {\n return originalEvent.preventDefault();\n }\n\n originalEvent.stopPropagation();\n\n const { expandable, contentScrolled, collapsed, expanded } = modalState;\n\n if (!this.state.touchDown) {\n modalState.touchStartContentScrollTop =\n modalState.contentElement?.scrollTop ?? 0;\n this.setState({ touchDown: true });\n }\n\n if (contentScrolled) {\n return;\n }\n\n if (modalState.touchMovePositive === null) {\n modalState.touchMovePositive = shiftY > 0;\n }\n\n if (\n !modalState.expandable ||\n collapsed ||\n (expanded &&\n modalState.touchMovePositive &&\n modalState.touchStartContentScrollTop === 0) ||\n modalState.headerElement?.contains(target)\n ) {\n originalEvent.preventDefault();\n\n if ((!expandable && shiftY < 0) || !this.window) {\n return;\n }\n\n !this.state.dragging && this.setState({ dragging: true });\n\n const shiftYPercent = (shiftY / this.window.innerHeight) * 100;\n const shiftYCurrent = rubber(\n shiftYPercent,\n 72,\n 0.8,\n this.props.platform === ANDROID || this.props.platform === VKCOM\n );\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = rangeTranslate(\n (modalState.translateY ?? 0) + shiftYCurrent\n );\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onCardTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { originalEvent, shiftY } = event;\n const target = originalEvent.target as HTMLElement;\n if (modalState.innerElement?.contains(target)) {\n if (!this.state.touchDown) {\n this.setState({ touchDown: true, dragging: true });\n }\n\n const shiftYPercent =\n (shiftY / modalState.innerElement.offsetHeight) * 100;\n const shiftYCurrent = rubber(\n shiftYPercent,\n 72,\n 1.2,\n this.props.platform === ANDROID || this.props.platform === VKCOM\n );\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = Math.max(\n 0,\n (modalState.translateY ?? 0) + shiftYCurrent\n );\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onTouchEnd = (e: TouchEvent) => {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState?.type === ModalType.PAGE) {\n return this.onPageTouchEnd(e, modalState);\n }\n\n if (modalState?.type === ModalType.CARD) {\n return this.onCardTouchEnd(e, modalState);\n }\n };\n\n onPageTouchEnd(event: TouchEvent, modalState: ModalsStateEntry) {\n const { startY, shiftY } = event;\n\n modalState.contentScrolled = false;\n modalState.touchMovePositive = null;\n\n let setStateCallback;\n\n if (this.state.dragging && this.window) {\n const shiftYEndPercent =\n ((startY + shiftY) / this.window.innerHeight) * 100;\n\n let translateY = modalState.translateYCurrent ?? 0;\n const expectTranslateY =\n (translateY / event.duration) *\n 240 *\n 0.6 *\n ((modalState.touchShiftYPercent ?? 0) < 0 ? -1 : 1);\n translateY = rangeTranslate(translateY + expectTranslateY);\n\n if (modalState.settlingHeight !== 100) {\n if (numberInRange(translateY, modalState.expandedRange)) {\n translateY = modalState.expandedRange?.[0] ?? 0;\n } else if (numberInRange(translateY, modalState.collapsedRange)) {\n translateY = modalState.translateYFrom ?? 0;\n } else if (numberInRange(translateY, modalState.hiddenRange)) {\n translateY = 100;\n } else {\n translateY = modalState.translateYFrom ?? 0;\n }\n } else {\n if (numberInRange(translateY, [0, 25])) {\n translateY = 0;\n } else {\n translateY = 100;\n }\n }\n\n if (translateY !== 100 && shiftYEndPercent >= 75) {\n translateY = 100;\n }\n\n modalState.translateY = translateY;\n modalState.translateYCurrent = translateY;\n modalState.collapsed = translateY > 0 && translateY < shiftYEndPercent;\n modalState.expanded = translateY === 0;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.onExit();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback\n );\n }\n\n onCardTouchEnd({ duration }: TouchEvent, modalState: ModalsStateEntry) {\n let setStateCallback;\n\n if (this.state.dragging) {\n let translateY = modalState.translateYCurrent ?? 0;\n\n const expectTranslateY =\n (translateY / duration) *\n 240 *\n 0.6 *\n ((modalState.touchShiftYPercent ?? 0) < 0 ? -1 : 1);\n translateY = Math.max(0, translateY + expectTranslateY);\n\n if (translateY >= 30) {\n translateY = 100;\n } else {\n translateY = 0;\n }\n\n modalState.translateY = translateY;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.onExit();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback\n );\n }\n\n onScroll = (e: React.SyntheticEvent) => {\n const activeModal = this.props.activeModal;\n\n const target = e.target as HTMLElement;\n\n if (!activeModal) {\n return;\n }\n const modalState = this.getModalState(activeModal);\n if (\n modalState?.type === ModalType.PAGE &&\n modalState?.contentElement?.contains(target)\n ) {\n modalState.contentScrolled = true;\n\n if (modalState.contentScrollStopTimeout) {\n clearTimeout(modalState.contentScrollStopTimeout);\n }\n\n modalState.contentScrollStopTimeout = setTimeout(() => {\n if (modalState.contentScrolled) {\n modalState.contentScrolled = false;\n }\n }, 250);\n }\n };\n\n waitTransitionFinish(\n modalState: ModalsStateEntry | undefined,\n eventHandler: () => void\n ) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState?.innerElement?.removeEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n eventHandler();\n };\n\n modalState?.innerElement?.addEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /**\n * Анимирует сдвиг модалки\n *\n * @param {ModalsStateEntry} modalState\n * @param {number} percent Процент сдвига: 0 – полностью открыта, 100 – полностью закрыта\n */\n animateTranslate(modalState: ModalsStateEntry, percent: number | undefined) {\n const frameId = `animateTranslateFrame${modalState.id}`;\n\n cancelAnimationFrame(this.frameIds[frameId]);\n\n this.frameIds[frameId] = requestAnimationFrame(() => {\n setTransformStyle(\n modalState.innerElement,\n `translate3d(0, ${percent}%, 0)`\n );\n });\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(\n modalState: ModalsStateEntry,\n forceOpacity: number | null = null\n ) {\n if (forceOpacity === null && this.props.history?.[0] !== modalState.id) {\n return;\n }\n if (this.maskAnimationFrame) {\n cancelAnimationFrame(this.maskAnimationFrame);\n }\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(\n 0,\n Math.min(100, opacity)\n ).toString();\n }\n });\n }\n\n render() {\n const { activeModal, exitingModal, enteringModal } = this.props;\n const { touchDown, dragging } = this.state;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <TouchRootContext.Provider value={true}>\n <ModalRootContext.Provider value={this.modalRootContext}>\n <Touch\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"ModalRoot\", this.props.platform),\n {\n \"ModalRoot--vkapps\":\n this.props.configProvider?.webviewType === WebviewType.VKAPPS,\n \"ModalRoot--touched\": touchDown,\n \"ModalRoot--switching\": !!(enteringModal || exitingModal),\n }\n )}\n onMove={this.onTouchMove}\n onEnd={this.onTouchEnd}\n onScroll={this.onScroll}\n >\n <div\n vkuiClass=\"ModalRoot__mask\"\n onClick={this.props.onExit}\n ref={this.maskElementRef}\n />\n <div vkuiClass=\"ModalRoot__viewport\" ref={this.viewportRef}>\n {this.getModals().map((Modal) => {\n const modalId = getNavId(Modal.props, warn);\n const _modalState = this.getModalState(modalId);\n if (\n (modalId !== activeModal && modalId !== exitingModal) ||\n !_modalState\n ) {\n return null;\n }\n const modalState = { ..._modalState };\n\n const isPage = modalState.type === ModalType.PAGE;\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n key={key}\n getRootRef={(e) => {\n const modalState = this.getModalState(modalId);\n if (modalState) {\n modalState.modalElement = e;\n }\n }}\n onClose={this.props.onExit}\n timeout={this.timeout}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\"ModalRoot__modal\", {\n \"ModalRoot__modal--active\": modalId === activeModal,\n \"ModalRoot__modal--prev\": modalId === exitingModal,\n \"ModalRoot__modal--next\":\n (exitingModal && modalId === activeModal) ||\n modalId === enteringModal,\n\n \"ModalRoot__modal--dragging\": dragging,\n\n \"ModalRoot__modal--expandable\":\n isPage && modalState.expandable,\n \"ModalRoot__modal--expanded\":\n isPage && modalState.expanded,\n \"ModalRoot__modal--collapsed\":\n isPage && modalState.collapsed,\n })}\n restoreFocus={false}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </Touch>\n </ModalRootContext.Provider>\n </TouchRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootTouch = withContext(\n withPlatform(\n withDOM<ModalRootProps>(\n withModalManager(initModal)(ModalRootTouchComponent)\n )\n ),\n ConfigProviderContext,\n \"configProvider\"\n);\n\n/**\n * Инициализирует модалку перед анимацией открытия\n */\nfunction initModal(modalState: ModalsStateEntry) {\n switch (modalState.type) {\n case ModalType.PAGE:\n modalState.settlingHeight =\n modalState.settlingHeight || MODAL_PAGE_DEFAULT_PERCENT_HEIGHT;\n return initPageModal(modalState);\n case ModalType.CARD:\n return initCardModal(modalState);\n default:\n IS_DEV &&\n warn(\n `initActiveModal: modalState.type=\"${modalState.type}\" не поддерживается`,\n \"error\"\n );\n }\n}\n\nfunction initPageModal(modalState: ModalsStateEntry) {\n const { contentElement } = modalState;\n const contentHeight = (contentElement?.firstElementChild as HTMLElement)\n .offsetHeight;\n\n let prevTranslateY = modalState.translateY;\n\n modalState.expandable =\n contentHeight > (contentElement?.clientHeight ?? 0) ||\n modalState.settlingHeight === 100;\n\n let collapsed = false;\n let expanded = false;\n let translateYFrom;\n let translateY;\n let expandedRange: TranslateRange;\n let collapsedRange: TranslateRange;\n let hiddenRange: TranslateRange;\n\n if (modalState.expandable) {\n translateYFrom = 100 - (modalState.settlingHeight ?? 0);\n\n const shiftHalf = translateYFrom / 2;\n const visiblePart = 100 - translateYFrom;\n\n expandedRange = [0, shiftHalf];\n collapsedRange = [shiftHalf, translateYFrom + visiblePart / 4];\n hiddenRange = [translateYFrom + visiblePart / 4, 100];\n\n collapsed = translateYFrom > 0;\n expanded = translateYFrom <= 0;\n translateY = translateYFrom;\n } else {\n const headerHeight = modalState.headerElement?.offsetHeight ?? 0;\n const height = contentHeight + headerHeight;\n\n translateYFrom =\n 100 -\n (height / (modalState.innerElement?.parentElement?.offsetHeight ?? 0)) *\n 100;\n translateY = translateYFrom;\n\n expandedRange = [translateY, translateY + 25];\n collapsedRange = [translateY + 25, translateY + 25];\n hiddenRange = [translateY + 25, translateY + 100];\n }\n\n // Если модалка может открываться на весь экран, и новый сдвиг больше предыдущего, то откроем её на весь экран\n if (\n (modalState.expandable && translateY > (prevTranslateY ?? 0)) ||\n modalState.settlingHeight === 100\n ) {\n translateY = 0;\n }\n\n // Если модалка уже раскрыта обновляем состояния\n if (translateY === 0) {\n expanded = true;\n collapsed = false;\n }\n\n modalState.expandedRange = expandedRange;\n modalState.collapsedRange = collapsedRange;\n modalState.hiddenRange = hiddenRange;\n modalState.translateY = translateY;\n modalState.translateYFrom = translateYFrom;\n modalState.collapsed = collapsed;\n modalState.expanded = expanded;\n}\n\nfunction initCardModal(modalState: ModalsStateEntry) {\n modalState.translateY = 0;\n}\n"],"file":"ModalRoot.js"}
1
+ {"version":3,"file":"ModalRoot.js","names":["React","Touch","TouchRootContext","getClassName","classNames","setTransformStyle","rubber","ANDROID","IOS","VKCOM","transitionEvent","withPlatform","withContext","ModalRootContext","ConfigProviderContext","WebviewType","ModalType","MODAL_PAGE_DEFAULT_PERCENT_HEIGHT","withDOM","getNavId","warnOnce","FocusTrap","withModalManager","warn","IS_DEV","process","env","NODE_ENV","numberInRange","number","range","rangeTranslate","Math","max","min","ModalRootTouchComponent","props","createRef","undefined","event","originalEvent","preventDefault","modalState","getModalState","activeModal","animateTranslate","translateY","type","PAGE","dynamicContentHeight","enteringModal","waitTransitionFinish","requestAnimationFrame","checkPageContentHeight","e","exitingModal","onPageTouchMove","CARD","onCardTouchMove","onPageTouchEnd","onCardTouchEnd","target","contentElement","contains","contentScrolled","contentScrollStopTimeout","clearTimeout","setTimeout","state","touchDown","dragging","maskElementRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","onClose","onExit","isInsideModal","frameIds","platform","document","window","Children","toArray","children","addEventListener","updateModalTranslate","toggleDocumentScrolling","removeEventListener","prevProps","closeModal","enteringState","onEnter","innerElement","style","transitionDelay","onEntered","delayEnter","timeout","restoreFocusTo","activeElement","focus","enabled","documentScrolling","preventTouch","passive","modalElement","prevModalState","initPageModal","currentModalState","needAnimate","expandable","translateYFrom","setState","nextModalState","nextIsPage","prevIsPage","onExited","exitTranslate","isBack","setMaskOpacity","shiftY","isY","viewportRef","current","stopPropagation","collapsed","expanded","touchStartContentScrollTop","scrollTop","touchMovePositive","headerElement","shiftYPercent","innerHeight","shiftYCurrent","touchShiftYPercent","translateYCurrent","offsetHeight","startY","setStateCallback","shiftYEndPercent","expectTranslateY","duration","settlingHeight","expandedRange","collapsedRange","hiddenRange","hidden","eventHandler","supported","onceHandler","name","percent","frameId","cancelAnimationFrame","forceOpacity","history","maskAnimationFrame","opacity","toString","configProvider","webviewType","VKAPPS","onTouchMove","onTouchEnd","onScroll","getModals","map","Modal","modalId","_modalState","isPage","key","Component","ModalRootTouch","initModal","initCardModal","contentHeight","firstElementChild","prevTranslateY","clientHeight","shiftHalf","visiblePart","headerHeight","height","parentElement"],"sources":["../../../src/components/ModalRoot/ModalRoot.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { Touch, TouchEvent } from \"../Touch/Touch\";\nimport TouchRootContext from \"../Touch/TouchContext\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport { setTransformStyle } from \"../../lib/styles\";\nimport { rubber } from \"../../lib/touch\";\nimport { ANDROID, IOS, VKCOM } from \"../../lib/platform\";\nimport { transitionEvent } from \"../../lib/supportEvents\";\nimport { HasPlatform } from \"../../types\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport { withContext } from \"../../hoc/withContext\";\nimport {\n ModalRootContext,\n ModalRootContextInterface,\n} from \"./ModalRootContext\";\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n WebviewType,\n} from \"../ConfigProvider/ConfigProviderContext\";\nimport { ModalsStateEntry, ModalType, TranslateRange } from \"./types\";\nimport { MODAL_PAGE_DEFAULT_PERCENT_HEIGHT } from \"./constants\";\nimport { DOMProps, withDOM } from \"../../lib/dom\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { FocusTrap } from \"../FocusTrap/FocusTrap\";\nimport { ModalTransitionProps, withModalManager } from \"./useModalManager\";\nimport \"./ModalRoot.css\";\n\nconst warn = warnOnce(\"ModalRoot\");\nconst IS_DEV = process.env.NODE_ENV === \"development\";\n\nfunction numberInRange(number: number, range: TranslateRange | undefined) {\n if (!range) {\n return false;\n }\n return number >= range[0] && number <= range[1];\n}\n\nfunction rangeTranslate(number: number) {\n return Math.max(0, Math.min(98, number));\n}\n\nexport interface ModalRootProps extends HasPlatform {\n activeModal?: string | null;\n\n /**\n * Будет вызвано при начале открытия активной модалки с её id\n */\n onOpen?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном открытии активной модалки с её id\n */\n onOpened?(modalId: string): void;\n\n /**\n * Будет вызвано при начале закрытия активной модалки с её id\n */\n onClose?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном закрытии активной модалки с её id\n */\n onClosed?(modalId: string): void;\n\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n children?: React.ReactNode;\n}\n\ninterface ModalRootState {\n touchDown?: boolean;\n dragging?: boolean;\n}\n\nclass ModalRootTouchComponent extends React.Component<\n ModalRootProps & DOMProps & ModalTransitionProps,\n ModalRootState\n> {\n constructor(props: ModalRootProps & ModalTransitionProps) {\n super(props);\n this.state = {\n touchDown: false,\n dragging: false,\n };\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: this.updateModalHeight,\n registerModal: ({ id, ...data }) =>\n Object.assign(this.getModalState(id), data),\n onClose: () => this.props.onExit(),\n isInsideModal: true,\n };\n\n this.frameIds = {};\n }\n\n private documentScrolling = false;\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private readonly viewportRef = React.createRef<HTMLDivElement>();\n private maskAnimationFrame: number | undefined = undefined;\n private readonly modalRootContext: ModalRootContextInterface;\n private readonly frameIds: {\n [index: string]: number;\n };\n private restoreFocusTo: HTMLElement | undefined | null = undefined;\n\n get timeout(): number {\n return this.props.platform === ANDROID || this.props.platform === VKCOM\n ? 320\n : 400;\n }\n\n get document() {\n return this.props.document;\n }\n\n get window() {\n return this.props.window;\n }\n\n getModalState(id: string | undefined | null) {\n if (!id) {\n return undefined;\n }\n return this.props.getModalState(id);\n }\n\n getModals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n componentDidMount() {\n // Отслеживаем изменение размеров viewport (Необходимо для iOS)\n if (this.props.platform === IOS) {\n this.window?.addEventListener(\"resize\", this.updateModalTranslate, false);\n }\n }\n\n componentWillUnmount() {\n this.toggleDocumentScrolling(true);\n this.window!.removeEventListener(\n \"resize\",\n this.updateModalTranslate,\n false\n );\n }\n\n componentDidUpdate(prevProps: ModalRootProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (\n this.props.exitingModal &&\n this.props.exitingModal !== prevProps.exitingModal\n ) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (\n this.props.enteringModal &&\n this.props.enteringModal !== prevProps.enteringModal\n ) {\n const { enteringModal } = this.props;\n const enteringState = this.getModalState(enteringModal);\n this.props.onEnter();\n this.waitTransitionFinish(enteringState, () => {\n if (enteringState?.innerElement) {\n enteringState.innerElement.style.transitionDelay = \"\";\n }\n this.props.onEntered(enteringModal);\n });\n\n if (enteringState?.innerElement) {\n enteringState.innerElement.style.transitionDelay = this.props.delayEnter\n ? `${this.timeout}ms`\n : \"\";\n this.animateTranslate(enteringState, enteringState.translateY);\n }\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = this.document!.activeElement as HTMLElement;\n }\n if (\n !this.props.activeModal &&\n !this.props.exitingModal &&\n this.restoreFocusTo\n ) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = null;\n }\n\n this.toggleDocumentScrolling(\n !this.props.activeModal && !this.props.exitingModal\n );\n }\n\n /* Отключает скролл документа */\n toggleDocumentScrolling(enabled: boolean) {\n if (this.documentScrolling === enabled) {\n return;\n }\n this.documentScrolling = enabled;\n\n if (enabled) {\n // Здесь нужен последний аргумент с такими же параметрами, потому что\n // некоторые браузеры на странных вендорах типа Meizu не удаляют обработчик.\n // https://github.com/VKCOM/VKUI/issues/444\n this.window!.removeEventListener(\"touchmove\", this.preventTouch, {\n // @ts-ignore (В интерфейсе EventListenerOptions нет поля passive)\n passive: false,\n });\n } else {\n this.window!.addEventListener(\"touchmove\", this.preventTouch, {\n passive: false,\n });\n }\n }\n\n preventTouch = (event: any) => {\n if (!event) {\n return false;\n }\n while (event.originalEvent) {\n event = event.originalEvent;\n }\n if (event.preventDefault) {\n event.preventDefault();\n }\n return false;\n };\n\n updateModalTranslate = () => {\n const modalState = this.getModalState(this.props.activeModal);\n modalState && this.animateTranslate(modalState, modalState.translateY);\n };\n\n checkPageContentHeight() {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState?.type === ModalType.PAGE && modalState?.modalElement) {\n const prevModalState = { ...modalState };\n initPageModal(modalState);\n const currentModalState = { ...modalState };\n\n let needAnimate = false;\n\n if (prevModalState.expandable === currentModalState.expandable) {\n if (\n prevModalState.translateYFrom !== currentModalState.translateYFrom\n ) {\n needAnimate = true;\n }\n } else {\n needAnimate = true;\n }\n\n if (needAnimate) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n }\n }\n\n updateModalHeight = () => {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (\n modalState &&\n modalState.type === ModalType.PAGE &&\n modalState.dynamicContentHeight\n ) {\n if (this.props.enteringModal) {\n this.waitTransitionFinish(modalState, () => {\n requestAnimationFrame(() => this.checkPageContentHeight());\n });\n } else {\n requestAnimationFrame(() => this.checkPageContentHeight());\n }\n }\n };\n\n closeModal(id: string) {\n // Сбрасываем состояния, которые могут помешать закрытию модального окна\n this.setState({ touchDown: false });\n\n const prevModalState = this.getModalState(id);\n\n if (!prevModalState) {\n id &&\n warn(\n `closeActiveModal: модальное окно (страница) ${id} не существует`,\n \"error\"\n );\n return;\n }\n\n const nextModalState = this.getModalState(this.props.activeModal);\n const nextIsPage =\n !!nextModalState && nextModalState.type === ModalType.PAGE;\n\n const prevIsPage =\n !!prevModalState && prevModalState.type === ModalType.PAGE;\n this.waitTransitionFinish(prevModalState, () => this.props.onExited(id));\n const exitTranslate =\n prevIsPage &&\n nextIsPage &&\n (prevModalState.translateY ?? 0) <=\n (nextModalState?.translateYFrom ?? 0) &&\n !this.props.isBack\n ? (nextModalState?.translateYFrom ?? 0) + 10\n : 100;\n this.animateTranslate(prevModalState, exitTranslate);\n\n if (!nextModalState) {\n // NOTE: was only for clean exit\n this.setMaskOpacity(prevModalState, 0);\n }\n }\n\n onTouchMove = (e: TouchEvent) => {\n if (this.props.exitingModal) {\n return;\n }\n const modalState = this.getModalState(this.props.activeModal);\n if (!modalState) {\n return;\n }\n\n if (modalState.type === ModalType.PAGE) {\n return this.onPageTouchMove(e, modalState);\n }\n\n if (modalState.type === ModalType.CARD) {\n return this.onCardTouchMove(e, modalState);\n }\n };\n\n onPageTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { shiftY, originalEvent } = event;\n const target = originalEvent.target as HTMLElement;\n\n if (!event.isY) {\n if (this.viewportRef.current?.contains(target)) {\n originalEvent.preventDefault();\n }\n return;\n }\n\n if (!modalState.innerElement?.contains(target)) {\n return originalEvent.preventDefault();\n }\n\n originalEvent.stopPropagation();\n\n const { expandable, contentScrolled, collapsed, expanded } = modalState;\n\n if (!this.state.touchDown) {\n modalState.touchStartContentScrollTop =\n modalState.contentElement?.scrollTop ?? 0;\n this.setState({ touchDown: true });\n }\n\n if (contentScrolled) {\n return;\n }\n\n if (modalState.touchMovePositive === null) {\n modalState.touchMovePositive = shiftY > 0;\n }\n\n if (\n !modalState.expandable ||\n collapsed ||\n (expanded &&\n modalState.touchMovePositive &&\n modalState.touchStartContentScrollTop === 0) ||\n modalState.headerElement?.contains(target)\n ) {\n originalEvent.preventDefault();\n\n if ((!expandable && shiftY < 0) || !this.window) {\n return;\n }\n\n !this.state.dragging && this.setState({ dragging: true });\n\n const shiftYPercent = (shiftY / this.window.innerHeight) * 100;\n const shiftYCurrent = rubber(\n shiftYPercent,\n 72,\n 0.8,\n this.props.platform === ANDROID || this.props.platform === VKCOM\n );\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = rangeTranslate(\n (modalState.translateY ?? 0) + shiftYCurrent\n );\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onCardTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { originalEvent, shiftY } = event;\n const target = originalEvent.target as HTMLElement;\n if (modalState.innerElement?.contains(target)) {\n if (!this.state.touchDown) {\n this.setState({ touchDown: true, dragging: true });\n }\n\n const shiftYPercent =\n (shiftY / modalState.innerElement.offsetHeight) * 100;\n const shiftYCurrent = rubber(\n shiftYPercent,\n 72,\n 1.2,\n this.props.platform === ANDROID || this.props.platform === VKCOM\n );\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = Math.max(\n 0,\n (modalState.translateY ?? 0) + shiftYCurrent\n );\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onTouchEnd = (e: TouchEvent) => {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState?.type === ModalType.PAGE) {\n return this.onPageTouchEnd(e, modalState);\n }\n\n if (modalState?.type === ModalType.CARD) {\n return this.onCardTouchEnd(e, modalState);\n }\n };\n\n onPageTouchEnd(event: TouchEvent, modalState: ModalsStateEntry) {\n const { startY, shiftY } = event;\n\n modalState.contentScrolled = false;\n modalState.touchMovePositive = null;\n\n let setStateCallback;\n\n if (this.state.dragging && this.window) {\n const shiftYEndPercent =\n ((startY + shiftY) / this.window.innerHeight) * 100;\n\n let translateY = modalState.translateYCurrent ?? 0;\n const expectTranslateY =\n (translateY / event.duration) *\n 240 *\n 0.6 *\n ((modalState.touchShiftYPercent ?? 0) < 0 ? -1 : 1);\n translateY = rangeTranslate(translateY + expectTranslateY);\n\n if (modalState.settlingHeight !== 100) {\n if (numberInRange(translateY, modalState.expandedRange)) {\n translateY = modalState.expandedRange?.[0] ?? 0;\n } else if (numberInRange(translateY, modalState.collapsedRange)) {\n translateY = modalState.translateYFrom ?? 0;\n } else if (numberInRange(translateY, modalState.hiddenRange)) {\n translateY = 100;\n } else {\n translateY = modalState.translateYFrom ?? 0;\n }\n } else {\n if (numberInRange(translateY, [0, 25])) {\n translateY = 0;\n } else {\n translateY = 100;\n }\n }\n\n if (translateY !== 100 && shiftYEndPercent >= 75) {\n translateY = 100;\n }\n\n modalState.translateY = translateY;\n modalState.translateYCurrent = translateY;\n modalState.collapsed = translateY > 0 && translateY < shiftYEndPercent;\n modalState.expanded = translateY === 0;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.onExit();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback\n );\n }\n\n onCardTouchEnd({ duration }: TouchEvent, modalState: ModalsStateEntry) {\n let setStateCallback;\n\n if (this.state.dragging) {\n let translateY = modalState.translateYCurrent ?? 0;\n\n const expectTranslateY =\n (translateY / duration) *\n 240 *\n 0.6 *\n ((modalState.touchShiftYPercent ?? 0) < 0 ? -1 : 1);\n translateY = Math.max(0, translateY + expectTranslateY);\n\n if (translateY >= 30) {\n translateY = 100;\n } else {\n translateY = 0;\n }\n\n modalState.translateY = translateY;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.onExit();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback\n );\n }\n\n onScroll = (e: React.SyntheticEvent) => {\n const activeModal = this.props.activeModal;\n\n const target = e.target as HTMLElement;\n\n if (!activeModal) {\n return;\n }\n const modalState = this.getModalState(activeModal);\n if (\n modalState?.type === ModalType.PAGE &&\n modalState?.contentElement?.contains(target)\n ) {\n modalState.contentScrolled = true;\n\n if (modalState.contentScrollStopTimeout) {\n clearTimeout(modalState.contentScrollStopTimeout);\n }\n\n modalState.contentScrollStopTimeout = setTimeout(() => {\n if (modalState.contentScrolled) {\n modalState.contentScrolled = false;\n }\n }, 250);\n }\n };\n\n waitTransitionFinish(\n modalState: ModalsStateEntry | undefined,\n eventHandler: () => void\n ) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState?.innerElement?.removeEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n eventHandler();\n };\n\n modalState?.innerElement?.addEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /**\n * Анимирует сдвиг модалки\n *\n * @param {ModalsStateEntry} modalState\n * @param {number} percent Процент сдвига: 0 – полностью открыта, 100 – полностью закрыта\n */\n animateTranslate(modalState: ModalsStateEntry, percent: number | undefined) {\n const frameId = `animateTranslateFrame${modalState.id}`;\n\n cancelAnimationFrame(this.frameIds[frameId]);\n\n this.frameIds[frameId] = requestAnimationFrame(() => {\n setTransformStyle(\n modalState.innerElement,\n `translate3d(0, ${percent}%, 0)`\n );\n });\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(\n modalState: ModalsStateEntry,\n forceOpacity: number | null = null\n ) {\n if (forceOpacity === null && this.props.history?.[0] !== modalState.id) {\n return;\n }\n if (this.maskAnimationFrame) {\n cancelAnimationFrame(this.maskAnimationFrame);\n }\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(\n 0,\n Math.min(100, opacity)\n ).toString();\n }\n });\n }\n\n render() {\n const { activeModal, exitingModal, enteringModal } = this.props;\n const { touchDown, dragging } = this.state;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <TouchRootContext.Provider value={true}>\n <ModalRootContext.Provider value={this.modalRootContext}>\n <Touch\n vkuiClass={classNames(\n getClassName(\"ModalRoot\", this.props.platform),\n this.props.configProvider?.webviewType === WebviewType.VKAPPS &&\n \"ModalRoot--vkapps\",\n touchDown && \"ModalRoot--touched\",\n !!(enteringModal || exitingModal) && \"ModalRoot--switching\"\n )}\n onMove={this.onTouchMove}\n onEnd={this.onTouchEnd}\n onScroll={this.onScroll}\n >\n <div\n vkuiClass=\"ModalRoot__mask\"\n onClick={this.props.onExit}\n ref={this.maskElementRef}\n />\n <div vkuiClass=\"ModalRoot__viewport\" ref={this.viewportRef}>\n {this.getModals().map((Modal) => {\n const modalId = getNavId(Modal.props, warn);\n const _modalState = this.getModalState(modalId);\n if (\n (modalId !== activeModal && modalId !== exitingModal) ||\n !_modalState\n ) {\n return null;\n }\n const modalState = { ..._modalState };\n\n const isPage = modalState.type === ModalType.PAGE;\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n key={key}\n getRootRef={(e) => {\n const modalState = this.getModalState(modalId);\n if (modalState) {\n modalState.modalElement = e;\n }\n }}\n onClose={this.props.onExit}\n timeout={this.timeout}\n vkuiClass={classNames(\n \"ModalRoot__modal\",\n modalId === activeModal && \"ModalRoot__modal--active\",\n modalId === exitingModal && \"ModalRoot__modal--prev\",\n ((exitingModal && modalId === activeModal) ||\n modalId === enteringModal) &&\n \"ModalRoot__modal--next\",\n\n dragging && \"ModalRoot__modal--dragging\",\n\n isPage &&\n modalState.expandable &&\n \"ModalRoot__modal--expandable\",\n isPage &&\n modalState.expanded &&\n \"ModalRoot__modal--expanded\",\n isPage &&\n modalState.collapsed &&\n \"ModalRoot__modal--collapsed\"\n )}\n restoreFocus={false}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </Touch>\n </ModalRootContext.Provider>\n </TouchRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootTouch = withContext(\n withPlatform(\n withDOM<ModalRootProps>(\n withModalManager(initModal)(ModalRootTouchComponent)\n )\n ),\n ConfigProviderContext,\n \"configProvider\"\n);\n\n/**\n * Инициализирует модалку перед анимацией открытия\n */\nfunction initModal(modalState: ModalsStateEntry) {\n switch (modalState.type) {\n case ModalType.PAGE:\n modalState.settlingHeight =\n modalState.settlingHeight || MODAL_PAGE_DEFAULT_PERCENT_HEIGHT;\n return initPageModal(modalState);\n case ModalType.CARD:\n return initCardModal(modalState);\n default:\n IS_DEV &&\n warn(\n `initActiveModal: modalState.type=\"${modalState.type}\" не поддерживается`,\n \"error\"\n );\n }\n}\n\nfunction initPageModal(modalState: ModalsStateEntry) {\n const { contentElement } = modalState;\n const contentHeight = (contentElement?.firstElementChild as HTMLElement)\n .offsetHeight;\n\n let prevTranslateY = modalState.translateY;\n\n modalState.expandable =\n contentHeight > (contentElement?.clientHeight ?? 0) ||\n modalState.settlingHeight === 100;\n\n let collapsed = false;\n let expanded = false;\n let translateYFrom;\n let translateY;\n let expandedRange: TranslateRange;\n let collapsedRange: TranslateRange;\n let hiddenRange: TranslateRange;\n\n if (modalState.expandable) {\n translateYFrom = 100 - (modalState.settlingHeight ?? 0);\n\n const shiftHalf = translateYFrom / 2;\n const visiblePart = 100 - translateYFrom;\n\n expandedRange = [0, shiftHalf];\n collapsedRange = [shiftHalf, translateYFrom + visiblePart / 4];\n hiddenRange = [translateYFrom + visiblePart / 4, 100];\n\n collapsed = translateYFrom > 0;\n expanded = translateYFrom <= 0;\n translateY = translateYFrom;\n } else {\n const headerHeight = modalState.headerElement?.offsetHeight ?? 0;\n const height = contentHeight + headerHeight;\n\n translateYFrom =\n 100 -\n (height / (modalState.innerElement?.parentElement?.offsetHeight ?? 0)) *\n 100;\n translateY = translateYFrom;\n\n expandedRange = [translateY, translateY + 25];\n collapsedRange = [translateY + 25, translateY + 25];\n hiddenRange = [translateY + 25, translateY + 100];\n }\n\n // Если модалка может открываться на весь экран, и новый сдвиг больше предыдущего, то откроем её на весь экран\n if (\n (modalState.expandable && translateY > (prevTranslateY ?? 0)) ||\n modalState.settlingHeight === 100\n ) {\n translateY = 0;\n }\n\n // Если модалка уже раскрыта обновляем состояния\n if (translateY === 0) {\n expanded = true;\n collapsed = false;\n }\n\n modalState.expandedRange = expandedRange;\n modalState.collapsedRange = collapsedRange;\n modalState.hiddenRange = hiddenRange;\n modalState.translateY = translateY;\n modalState.translateYFrom = translateYFrom;\n modalState.collapsed = collapsed;\n modalState.expanded = expanded;\n}\n\nfunction initCardModal(modalState: ModalsStateEntry) {\n modalState.translateY = 0;\n}\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/ModalRoot/ModalRootAdaptive.tsx"],"names":["withAdaptivity","ModalRootTouch","ModalRootDesktop","useScrollLock","useAdaptivityIsDesktop","ModalRootComponent","props","isDesktop","activeModal","RootComponent","displayName","ModalRoot","viewWidth","viewHeight","hasMouse"],"mappings":";AACA,SAASA,cAAT;AACA,SAASC,cAAT;AACA,SAASC,gBAAT;AAKA,SAASC,aAAT;AACA,SAASC,sBAAT;;AA2BA,IAAMC,kBAAkB,GAAG,SAArBA,kBAAqB,CACzBC,KADyB,EAEtB;AACH,MAAMC,SAAS,GAAGH,sBAAsB,EAAxC;AAEAD,EAAAA,aAAa,CAAC,CAAC,CAACG,KAAK,CAACE,WAAT,CAAb;AAEA,MAAMC,aAAa,GAAGF,SAAS,GAAGL,gBAAH,GAAsBD,cAArD;AAEA,SAAO,oBAAC,aAAD,EAAmBK,KAAnB,CAAP;AACD,CAVD;;AAYAD,kBAAkB,CAACK,WAAnB,GAAiC,WAAjC;AAEA;AACA;AACA;;AACA,OAAO,IAAMC,SAAS,GAAGX,cAAc,CAACK,kBAAD,EAAqB;AAC1DO,EAAAA,SAAS,EAAE,IAD+C;AAE1DC,EAAAA,UAAU,EAAE,IAF8C;AAG1DC,EAAAA,QAAQ,EAAE;AAHgD,CAArB,CAAhC","sourcesContent":["import * as React from \"react\";\nimport { withAdaptivity } from \"../../hoc/withAdaptivity\";\nimport { ModalRootTouch } from \"./ModalRoot\";\nimport { ModalRootDesktop } from \"./ModalRootDesktop\";\nimport {\n AdaptivityContextInterface,\n AdaptivityProps,\n} from \"../AdaptivityProvider/AdaptivityContext\";\nimport { useScrollLock } from \"../AppRoot/ScrollContext\";\nimport { useAdaptivityIsDesktop } from \"../../hooks/useAdaptivity\";\n\nexport interface ModalRootProps extends AdaptivityProps {\n activeModal?: string | null;\n\n /**\n * Будет вызвано при начале открытия активной модалки с её id\n */\n onOpen?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном открытии активной модалки с её id\n */\n onOpened?(modalId: string): void;\n\n /**\n * Будет вызвано при начале закрытия активной модалки с её id\n */\n onClose?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном закрытии активной модалки с её id\n */\n onClosed?(modalId: string): void;\n children?: React.ReactNode;\n}\n\nconst ModalRootComponent = (\n props: ModalRootProps & AdaptivityContextInterface\n) => {\n const isDesktop = useAdaptivityIsDesktop();\n\n useScrollLock(!!props.activeModal);\n\n const RootComponent = isDesktop ? ModalRootDesktop : ModalRootTouch;\n\n return <RootComponent {...props} />;\n};\n\nModalRootComponent.displayName = \"ModalRoot\";\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalRoot\n */\nexport const ModalRoot = withAdaptivity(ModalRootComponent, {\n viewWidth: true,\n viewHeight: true,\n hasMouse: true,\n});\n"],"file":"ModalRootAdaptive.js"}
1
+ {"version":3,"file":"ModalRootAdaptive.js","names":["withAdaptivity","ModalRootTouch","ModalRootDesktop","useScrollLock","useAdaptivityIsDesktop","ModalRootComponent","props","isDesktop","activeModal","RootComponent","displayName","ModalRoot","viewWidth","viewHeight","hasMouse"],"sources":["../../../src/components/ModalRoot/ModalRootAdaptive.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { withAdaptivity } from \"../../hoc/withAdaptivity\";\nimport { ModalRootTouch } from \"./ModalRoot\";\nimport { ModalRootDesktop } from \"./ModalRootDesktop\";\nimport {\n AdaptivityContextInterface,\n AdaptivityProps,\n} from \"../AdaptivityProvider/AdaptivityContext\";\nimport { useScrollLock } from \"../AppRoot/ScrollContext\";\nimport { useAdaptivityIsDesktop } from \"../../hooks/useAdaptivity\";\n\nexport interface ModalRootProps extends AdaptivityProps {\n activeModal?: string | null;\n\n /**\n * Будет вызвано при начале открытия активной модалки с её id\n */\n onOpen?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном открытии активной модалки с её id\n */\n onOpened?(modalId: string): void;\n\n /**\n * Будет вызвано при начале закрытия активной модалки с её id\n */\n onClose?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном закрытии активной модалки с её id\n */\n onClosed?(modalId: string): void;\n children?: React.ReactNode;\n}\n\nconst ModalRootComponent = (\n props: ModalRootProps & AdaptivityContextInterface\n) => {\n const isDesktop = useAdaptivityIsDesktop();\n\n useScrollLock(!!props.activeModal);\n\n const RootComponent = isDesktop ? ModalRootDesktop : ModalRootTouch;\n\n return <RootComponent {...props} />;\n};\n\nModalRootComponent.displayName = \"ModalRoot\";\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalRoot\n */\nexport const ModalRoot = withAdaptivity(ModalRootComponent, {\n viewWidth: true,\n viewHeight: true,\n hasMouse: true,\n});\n"],"mappings":";AACA,SAASA,cAAT;AACA,SAASC,cAAT;AACA,SAASC,gBAAT;AAKA,SAASC,aAAT;AACA,SAASC,sBAAT;;AA2BA,IAAMC,kBAAkB,GAAG,SAArBA,kBAAqB,CACzBC,KADyB,EAEtB;EACH,IAAMC,SAAS,GAAGH,sBAAsB,EAAxC;EAEAD,aAAa,CAAC,CAAC,CAACG,KAAK,CAACE,WAAT,CAAb;EAEA,IAAMC,aAAa,GAAGF,SAAS,GAAGL,gBAAH,GAAsBD,cAArD;EAEA,OAAO,oBAAC,aAAD,EAAmBK,KAAnB,CAAP;AACD,CAVD;;AAYAD,kBAAkB,CAACK,WAAnB,GAAiC,WAAjC;AAEA;AACA;AACA;;AACA,OAAO,IAAMC,SAAS,GAAGX,cAAc,CAACK,kBAAD,EAAqB;EAC1DO,SAAS,EAAE,IAD+C;EAE1DC,UAAU,EAAE,IAF8C;EAG1DC,QAAQ,EAAE;AAHgD,CAArB,CAAhC"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/ModalRoot/ModalRootContext.tsx"],"names":["React","useIsomorphicLayoutEffect","ModalRootContext","createContext","updateModalHeight","undefined","registerModal","isInsideModal","useModalRegistry","id","type","modalContext","useContext","elements","useRef","current","reset","Object","keys","reduce","acc","k","refs","modalElement","e","innerElement","headerElement","contentElement"],"mappings":";;AAAA,OAAO,KAAKA,KAAZ,MAAuB,OAAvB;AACA,SAASC,yBAAT;AAcA,OAAO,IAAMC,gBAAgB,gBAAGF,KAAK,CAACG,aAAN,CAA+C;AAC7EC,EAAAA,iBAAiB,EAAE;AAAA,WAAMC,SAAN;AAAA,GAD0D;AAE7EC,EAAAA,aAAa,EAAE;AAAA,WAAMD,SAAN;AAAA,GAF8D;AAG7EE,EAAAA,aAAa,EAAE;AAH8D,CAA/C,CAAzB;AAMP;AACA;AACA;;AACA,OAAO,SAASC,gBAAT,CAA0BC,EAA1B,EAAkDC,IAAlD,EAAmE;AACxE,MAAMC,YAAY,GAAGX,KAAK,CAACY,UAAN,CAAiBV,gBAAjB,CAArB;AACA,MAAMW,QAAQ,GAAGb,KAAK,CAACc,MAAN,CAA4B,EAA5B,EAAgCC,OAAjD;AACAd,EAAAA,yBAAyB,CAAC,YAAM;AAC9B,QAAIQ,EAAE,KAAKJ,SAAX,EAAsB;AACpBM,MAAAA,YAAY,CAACL,aAAb,iCAAgCO,QAAhC;AAA0CH,QAAAA,IAAI,EAAJA,IAA1C;AAAgDD,QAAAA,EAAE,EAAFA;AAAhD,UADoB,CAEpB;;AACA,UAAMO,KAAK,GAAGC,MAAM,CAACC,IAAP,CAAYL,QAAZ,EAAsBM,MAAtB,CACZ,UAACC,GAAD,EAAMC,CAAN;AAAA,+CAAkBD,GAAlB,2BAAwBC,CAAxB,EAA4B,IAA5B;AAAA,OADY,EAEZ;AAAEX,QAAAA,IAAI,EAAJA,IAAF;AAAQD,QAAAA,EAAE,EAAFA;AAAR,OAFY,CAAd;AAIA,aAAO;AAAA,eAAME,YAAY,CAACL,aAAb,CAA2BU,KAA3B,CAAN;AAAA,OAAP;AACD;;AACD,WAAOX,SAAP;AACD,GAXwB,EAWtB,EAXsB,CAAzB;AAaA,MAAMiB,IAAI,GAAGtB,KAAK,CAACc,MAAN,CAAkC;AAC7CS,IAAAA,YAAY,EAAE,sBAACC,CAAD;AAAA,aAAQX,QAAQ,CAACU,YAAT,GAAwBC,CAAhC;AAAA,KAD+B;AAE7CC,IAAAA,YAAY,EAAE,sBAACD,CAAD;AAAA,aAAQX,QAAQ,CAACY,YAAT,GAAwBD,CAAhC;AAAA,KAF+B;AAG7CE,IAAAA,aAAa,EAAE,uBAACF,CAAD;AAAA,aAAQX,QAAQ,CAACa,aAAT,GAAyBF,CAAjC;AAAA,KAH8B;AAI7CG,IAAAA,cAAc,EAAE,wBAACH,CAAD;AAAA,aAAQX,QAAQ,CAACc,cAAT,GAA0BH,CAAlC;AAAA;AAJ6B,GAAlC,EAKVT,OALH;AAMA,SAAO;AAAEO,IAAAA,IAAI,EAAJA;AAAF,GAAP;AACD","sourcesContent":["import * as React from \"react\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { ModalElements, ModalsStateEntry, ModalType } from \"./types\";\n\nexport type ModalRegistryEntry = ModalElements &\n Required<Pick<ModalsStateEntry, \"type\" | \"id\">>;\ntype ModalRefs = { [k in keyof ModalElements]: (e: ModalElements[k]) => void };\n\nexport interface ModalRootContextInterface {\n updateModalHeight: VoidFunction;\n registerModal(data: ModalRegistryEntry): void;\n onClose?: VoidFunction;\n isInsideModal: boolean;\n}\n\nexport const ModalRootContext = React.createContext<ModalRootContextInterface>({\n updateModalHeight: () => undefined,\n registerModal: () => undefined,\n isInsideModal: false,\n});\n\n/**\n * All referenced elements must be static\n */\nexport function useModalRegistry(id: string | undefined, type: ModalType) {\n const modalContext = React.useContext(ModalRootContext);\n const elements = React.useRef<ModalElements>({}).current;\n useIsomorphicLayoutEffect(() => {\n if (id !== undefined) {\n modalContext.registerModal({ ...elements, type, id });\n // unset refs on unmount to prevent leak\n const reset = Object.keys(elements).reduce<ModalRegistryEntry>(\n (acc, k) => ({ ...acc, [k]: null }),\n { type, id }\n );\n return () => modalContext.registerModal(reset);\n }\n return undefined;\n }, []);\n\n const refs = React.useRef<Required<ModalRefs>>({\n modalElement: (e) => (elements.modalElement = e),\n innerElement: (e) => (elements.innerElement = e),\n headerElement: (e) => (elements.headerElement = e),\n contentElement: (e) => (elements.contentElement = e),\n }).current;\n return { refs };\n}\n"],"file":"ModalRootContext.js"}
1
+ {"version":3,"file":"ModalRootContext.js","names":["React","useIsomorphicLayoutEffect","ModalRootContext","createContext","updateModalHeight","undefined","registerModal","isInsideModal","useModalRegistry","id","type","modalContext","useContext","elements","useRef","current","reset","Object","keys","reduce","acc","k","refs","modalElement","e","innerElement","headerElement","contentElement"],"sources":["../../../src/components/ModalRoot/ModalRootContext.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { ModalElements, ModalsStateEntry, ModalType } from \"./types\";\n\nexport type ModalRegistryEntry = ModalElements &\n Required<Pick<ModalsStateEntry, \"type\" | \"id\">>;\ntype ModalRefs = { [k in keyof ModalElements]: (e: ModalElements[k]) => void };\n\nexport interface ModalRootContextInterface {\n updateModalHeight: VoidFunction;\n registerModal(data: ModalRegistryEntry): void;\n onClose?: VoidFunction;\n isInsideModal: boolean;\n}\n\nexport const ModalRootContext = React.createContext<ModalRootContextInterface>({\n updateModalHeight: () => undefined,\n registerModal: () => undefined,\n isInsideModal: false,\n});\n\n/**\n * All referenced elements must be static\n */\nexport function useModalRegistry(id: string | undefined, type: ModalType) {\n const modalContext = React.useContext(ModalRootContext);\n const elements = React.useRef<ModalElements>({}).current;\n useIsomorphicLayoutEffect(() => {\n if (id !== undefined) {\n modalContext.registerModal({ ...elements, type, id });\n // unset refs on unmount to prevent leak\n const reset = Object.keys(elements).reduce<ModalRegistryEntry>(\n (acc, k) => ({ ...acc, [k]: null }),\n { type, id }\n );\n return () => modalContext.registerModal(reset);\n }\n return undefined;\n }, []);\n\n const refs = React.useRef<Required<ModalRefs>>({\n modalElement: (e) => (elements.modalElement = e),\n innerElement: (e) => (elements.innerElement = e),\n headerElement: (e) => (elements.headerElement = e),\n contentElement: (e) => (elements.contentElement = e),\n }).current;\n return { refs };\n}\n"],"mappings":";;AAAA,OAAO,KAAKA,KAAZ,MAAuB,OAAvB;AACA,SAASC,yBAAT;AAcA,OAAO,IAAMC,gBAAgB,gBAAGF,KAAK,CAACG,aAAN,CAA+C;EAC7EC,iBAAiB,EAAE;IAAA,OAAMC,SAAN;EAAA,CAD0D;EAE7EC,aAAa,EAAE;IAAA,OAAMD,SAAN;EAAA,CAF8D;EAG7EE,aAAa,EAAE;AAH8D,CAA/C,CAAzB;AAMP;AACA;AACA;;AACA,OAAO,SAASC,gBAAT,CAA0BC,EAA1B,EAAkDC,IAAlD,EAAmE;EACxE,IAAMC,YAAY,GAAGX,KAAK,CAACY,UAAN,CAAiBV,gBAAjB,CAArB;EACA,IAAMW,QAAQ,GAAGb,KAAK,CAACc,MAAN,CAA4B,EAA5B,EAAgCC,OAAjD;EACAd,yBAAyB,CAAC,YAAM;IAC9B,IAAIQ,EAAE,KAAKJ,SAAX,EAAsB;MACpBM,YAAY,CAACL,aAAb,iCAAgCO,QAAhC;QAA0CH,IAAI,EAAJA,IAA1C;QAAgDD,EAAE,EAAFA;MAAhD,IADoB,CAEpB;;MACA,IAAMO,KAAK,GAAGC,MAAM,CAACC,IAAP,CAAYL,QAAZ,EAAsBM,MAAtB,CACZ,UAACC,GAAD,EAAMC,CAAN;QAAA,uCAAkBD,GAAlB,2BAAwBC,CAAxB,EAA4B,IAA5B;MAAA,CADY,EAEZ;QAAEX,IAAI,EAAJA,IAAF;QAAQD,EAAE,EAAFA;MAAR,CAFY,CAAd;MAIA,OAAO;QAAA,OAAME,YAAY,CAACL,aAAb,CAA2BU,KAA3B,CAAN;MAAA,CAAP;IACD;;IACD,OAAOX,SAAP;EACD,CAXwB,EAWtB,EAXsB,CAAzB;EAaA,IAAMiB,IAAI,GAAGtB,KAAK,CAACc,MAAN,CAAkC;IAC7CS,YAAY,EAAE,sBAACC,CAAD;MAAA,OAAQX,QAAQ,CAACU,YAAT,GAAwBC,CAAhC;IAAA,CAD+B;IAE7CC,YAAY,EAAE,sBAACD,CAAD;MAAA,OAAQX,QAAQ,CAACY,YAAT,GAAwBD,CAAhC;IAAA,CAF+B;IAG7CE,aAAa,EAAE,uBAACF,CAAD;MAAA,OAAQX,QAAQ,CAACa,aAAT,GAAyBF,CAAjC;IAAA,CAH8B;IAI7CG,cAAc,EAAE,wBAACH,CAAD;MAAA,OAAQX,QAAQ,CAACc,cAAT,GAA0BH,CAAlC;IAAA;EAJ6B,CAAlC,EAKVT,OALH;EAMA,OAAO;IAAEO,IAAI,EAAJA;EAAF,CAAP;AACD"}
@@ -214,10 +214,7 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
214
214
  return createScopedElement(ModalRootContext.Provider, {
215
215
  value: this.modalRootContext
216
216
  }, createScopedElement("div", {
217
- // eslint-disable-next-line vkui/no-object-expression-in-arguments
218
- vkuiClass: classNames(getClassName("ModalRoot", this.props.platform), {
219
- "ModalRoot--vkapps": ((_this$props$configPro = this.props.configProvider) === null || _this$props$configPro === void 0 ? void 0 : _this$props$configPro.webviewType) === WebviewType.VKAPPS
220
- }, "ModalRoot--desktop")
217
+ vkuiClass: classNames(getClassName("ModalRoot", this.props.platform), ((_this$props$configPro = this.props.configProvider) === null || _this$props$configPro === void 0 ? void 0 : _this$props$configPro.webviewType) === WebviewType.VKAPPS && "ModalRoot--vkapps", "ModalRoot--desktop")
221
218
  }, createScopedElement("div", {
222
219
  vkuiClass: "ModalRoot__mask",
223
220
  ref: this.maskElementRef,
@@ -236,13 +233,8 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
236
233
  restoreFocus: false,
237
234
  onClose: _this5.props.onExit,
238
235
  timeout: _this5.timeout,
239
- key: key // eslint-disable-next-line vkui/no-object-expression-in-arguments
240
- ,
241
- vkuiClass: classNames("ModalRoot__modal", {
242
- "ModalRoot__modal--active": !exitingModal && !enteringModal && modalId === activeModal,
243
- "ModalRoot__modal--prev": modalId === exitingModal,
244
- "ModalRoot__modal--next": Boolean(exitingModal) && modalId === activeModal
245
- })
236
+ key: key,
237
+ vkuiClass: classNames("ModalRoot__modal", !exitingModal && !enteringModal && modalId === activeModal && "ModalRoot__modal--active", modalId === exitingModal && "ModalRoot__modal--prev", Boolean(exitingModal) && modalId === activeModal && "ModalRoot__modal--next")
246
238
  }, Modal);
247
239
  }))));
248
240
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/ModalRoot/ModalRootDesktop.tsx"],"names":["React","classNames","transitionEvent","withPlatform","withContext","ModalRootContext","ConfigProviderContext","WebviewType","ANDROID","VKCOM","getClassName","withDOM","getNavId","warnOnce","FocusTrap","withModalManager","warn","ModalRootDesktopComponent","props","undefined","maskElementRef","createRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","getModalState","onClose","onExit","isInsideModal","platform","Children","toArray","children","prevProps","exitingModal","closeModal","enteringModal","enteringState","onEnter","requestAnimationFrame","waitTransitionFinish","onEntered","animateModalOpacity","activeModal","restoreFocusTo","document","activeElement","focus","prevModalState","onExited","setMaskOpacity","modalState","eventHandler","supported","onceHandler","innerElement","removeEventListener","name","addEventListener","setTimeout","timeout","display","style","transitionDelay","delayEnter","opacity","forceOpacity","history","maskAnimationFrame","cancelAnimationFrame","current","translateY","translateYCurrent","Math","max","min","toString","configProvider","webviewType","VKAPPS","modals","map","Modal","modalId","key","Boolean","Component","ModalRootDesktop"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { transitionEvent } from \"../../lib/supportEvents\";\nimport { HasPlatform } from \"../../types\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport { withContext } from \"../../hoc/withContext\";\nimport {\n ModalRootContext,\n ModalRootContextInterface,\n} from \"./ModalRootContext\";\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n WebviewType,\n} from \"../ConfigProvider/ConfigProviderContext\";\nimport { ModalsStateEntry } from \"./types\";\nimport { ANDROID, VKCOM } from \"../../lib/platform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { DOMProps, withDOM } from \"../../lib/dom\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { FocusTrap } from \"../FocusTrap/FocusTrap\";\nimport { ModalTransitionProps, withModalManager } from \"./useModalManager\";\nimport \"./ModalRoot.css\";\n\nconst warn = warnOnce(\"ModalRoot\");\n\nexport interface ModalRootProps extends HasPlatform {\n activeModal?: string | null;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n children?: React.ReactNode;\n\n /**\n * Будет вызвано при начале открытия активной модалки с её id\n */\n onOpen?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном открытии активной модалки с её id\n */\n onOpened?(modalId: string): void;\n\n /**\n * Будет вызвано при начале закрытия активной модалки с её id\n */\n onClose?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном закрытии активной модалки с её id\n */\n onClosed?(modalId: string): void;\n}\n\nclass ModalRootDesktopComponent extends React.Component<\n ModalRootProps & DOMProps & ModalTransitionProps\n> {\n constructor(props: ModalRootProps & ModalTransitionProps) {\n super(props);\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: () => undefined,\n registerModal: ({ id, ...data }) =>\n Object.assign(this.getModalState(id), data),\n onClose: () => this.props.onExit(),\n isInsideModal: true,\n };\n }\n\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private maskAnimationFrame: number | undefined = undefined;\n private readonly modalRootContext: ModalRootContextInterface;\n private restoreFocusTo: HTMLElement | undefined = undefined;\n\n private get timeout() {\n return this.props.platform === ANDROID || this.props.platform === VKCOM\n ? 320\n : 400;\n }\n\n private get modals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n getModalState(id: string | null) {\n if (id === null) {\n return undefined;\n }\n return this.props.getModalState(id);\n }\n\n componentDidUpdate(prevProps: ModalRootProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (\n this.props.exitingModal &&\n this.props.exitingModal !== prevProps.exitingModal\n ) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (\n this.props.enteringModal &&\n this.props.enteringModal !== prevProps.enteringModal\n ) {\n const { enteringModal } = this.props;\n const enteringState = this.getModalState(enteringModal);\n this.props.onEnter();\n requestAnimationFrame(() => {\n if (this.props.enteringModal === enteringModal) {\n this.waitTransitionFinish(enteringState, () =>\n this.props.onEntered(enteringModal)\n );\n this.animateModalOpacity(enteringState, true);\n }\n });\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = (this.props.document?.activeElement ??\n undefined) as HTMLElement | undefined;\n }\n if (\n !this.props.activeModal &&\n !this.props.exitingModal &&\n this.restoreFocusTo\n ) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = undefined;\n }\n }\n\n closeModal(id: string) {\n const prevModalState = this.getModalState(id);\n if (!prevModalState) {\n return;\n }\n\n this.waitTransitionFinish(prevModalState, () => this.props.onExited(id));\n this.animateModalOpacity(prevModalState, false);\n if (!this.props.activeModal) {\n this.setMaskOpacity(prevModalState, 0);\n }\n }\n\n waitTransitionFinish(\n modalState: ModalsStateEntry | undefined,\n eventHandler: () => void\n ) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState?.innerElement?.removeEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n eventHandler();\n };\n\n modalState?.innerElement?.addEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /* Анимирует сдвиг модалки */\n animateModalOpacity(\n modalState: ModalsStateEntry | undefined,\n display: boolean\n ) {\n if (modalState?.innerElement) {\n modalState.innerElement.style.transitionDelay =\n display && this.props.delayEnter ? `${this.timeout}ms` : \"\";\n modalState.innerElement.style.opacity = display ? \"1\" : \"0\";\n }\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(\n modalState: ModalsStateEntry,\n forceOpacity: number | null = null\n ) {\n if (forceOpacity === null && this.props.history?.[0] !== modalState.id) {\n return;\n }\n\n if (this.maskAnimationFrame) {\n cancelAnimationFrame(this.maskAnimationFrame);\n }\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(\n 0,\n Math.min(100, opacity)\n ).toString();\n }\n });\n }\n\n render() {\n const { exitingModal, activeModal, enteringModal } = this.props;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <ModalRootContext.Provider value={this.modalRootContext}>\n <div\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"ModalRoot\", this.props.platform),\n {\n \"ModalRoot--vkapps\":\n this.props.configProvider?.webviewType === WebviewType.VKAPPS,\n },\n \"ModalRoot--desktop\"\n )}\n >\n <div\n vkuiClass=\"ModalRoot__mask\"\n ref={this.maskElementRef}\n onClick={this.props.onExit}\n />\n <div vkuiClass=\"ModalRoot__viewport\">\n {this.modals.map((Modal: React.ReactElement) => {\n const modalId = getNavId(Modal.props, warn);\n if (modalId !== activeModal && modalId !== exitingModal) {\n return null;\n }\n\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n restoreFocus={false}\n onClose={this.props.onExit}\n timeout={this.timeout}\n key={key}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\"ModalRoot__modal\", {\n \"ModalRoot__modal--active\":\n !exitingModal &&\n !enteringModal &&\n modalId === activeModal,\n \"ModalRoot__modal--prev\": modalId === exitingModal,\n \"ModalRoot__modal--next\":\n Boolean(exitingModal) && modalId === activeModal,\n })}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </div>\n </ModalRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootDesktop = withContext(\n withPlatform(\n withDOM<ModalRootProps>(withModalManager()(ModalRootDesktopComponent))\n ),\n ConfigProviderContext,\n \"configProvider\"\n);\n"],"file":"ModalRootDesktop.js"}
1
+ {"version":3,"file":"ModalRootDesktop.js","names":["React","classNames","transitionEvent","withPlatform","withContext","ModalRootContext","ConfigProviderContext","WebviewType","ANDROID","VKCOM","getClassName","withDOM","getNavId","warnOnce","FocusTrap","withModalManager","warn","ModalRootDesktopComponent","props","undefined","maskElementRef","createRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","getModalState","onClose","onExit","isInsideModal","platform","Children","toArray","children","prevProps","exitingModal","closeModal","enteringModal","enteringState","onEnter","requestAnimationFrame","waitTransitionFinish","onEntered","animateModalOpacity","activeModal","restoreFocusTo","document","activeElement","focus","prevModalState","onExited","setMaskOpacity","modalState","eventHandler","supported","onceHandler","innerElement","removeEventListener","name","addEventListener","setTimeout","timeout","display","style","transitionDelay","delayEnter","opacity","forceOpacity","history","maskAnimationFrame","cancelAnimationFrame","current","translateY","translateYCurrent","Math","max","min","toString","configProvider","webviewType","VKAPPS","modals","map","Modal","modalId","key","Boolean","Component","ModalRootDesktop"],"sources":["../../../src/components/ModalRoot/ModalRootDesktop.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { transitionEvent } from \"../../lib/supportEvents\";\nimport { HasPlatform } from \"../../types\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport { withContext } from \"../../hoc/withContext\";\nimport {\n ModalRootContext,\n ModalRootContextInterface,\n} from \"./ModalRootContext\";\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n WebviewType,\n} from \"../ConfigProvider/ConfigProviderContext\";\nimport { ModalsStateEntry } from \"./types\";\nimport { ANDROID, VKCOM } from \"../../lib/platform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { DOMProps, withDOM } from \"../../lib/dom\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { FocusTrap } from \"../FocusTrap/FocusTrap\";\nimport { ModalTransitionProps, withModalManager } from \"./useModalManager\";\nimport \"./ModalRoot.css\";\n\nconst warn = warnOnce(\"ModalRoot\");\n\nexport interface ModalRootProps extends HasPlatform {\n activeModal?: string | null;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n children?: React.ReactNode;\n\n /**\n * Будет вызвано при начале открытия активной модалки с её id\n */\n onOpen?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном открытии активной модалки с её id\n */\n onOpened?(modalId: string): void;\n\n /**\n * Будет вызвано при начале закрытия активной модалки с её id\n */\n onClose?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном закрытии активной модалки с её id\n */\n onClosed?(modalId: string): void;\n}\n\nclass ModalRootDesktopComponent extends React.Component<\n ModalRootProps & DOMProps & ModalTransitionProps\n> {\n constructor(props: ModalRootProps & ModalTransitionProps) {\n super(props);\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: () => undefined,\n registerModal: ({ id, ...data }) =>\n Object.assign(this.getModalState(id), data),\n onClose: () => this.props.onExit(),\n isInsideModal: true,\n };\n }\n\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private maskAnimationFrame: number | undefined = undefined;\n private readonly modalRootContext: ModalRootContextInterface;\n private restoreFocusTo: HTMLElement | undefined = undefined;\n\n private get timeout() {\n return this.props.platform === ANDROID || this.props.platform === VKCOM\n ? 320\n : 400;\n }\n\n private get modals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n getModalState(id: string | null) {\n if (id === null) {\n return undefined;\n }\n return this.props.getModalState(id);\n }\n\n componentDidUpdate(prevProps: ModalRootProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (\n this.props.exitingModal &&\n this.props.exitingModal !== prevProps.exitingModal\n ) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (\n this.props.enteringModal &&\n this.props.enteringModal !== prevProps.enteringModal\n ) {\n const { enteringModal } = this.props;\n const enteringState = this.getModalState(enteringModal);\n this.props.onEnter();\n requestAnimationFrame(() => {\n if (this.props.enteringModal === enteringModal) {\n this.waitTransitionFinish(enteringState, () =>\n this.props.onEntered(enteringModal)\n );\n this.animateModalOpacity(enteringState, true);\n }\n });\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = (this.props.document?.activeElement ??\n undefined) as HTMLElement | undefined;\n }\n if (\n !this.props.activeModal &&\n !this.props.exitingModal &&\n this.restoreFocusTo\n ) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = undefined;\n }\n }\n\n closeModal(id: string) {\n const prevModalState = this.getModalState(id);\n if (!prevModalState) {\n return;\n }\n\n this.waitTransitionFinish(prevModalState, () => this.props.onExited(id));\n this.animateModalOpacity(prevModalState, false);\n if (!this.props.activeModal) {\n this.setMaskOpacity(prevModalState, 0);\n }\n }\n\n waitTransitionFinish(\n modalState: ModalsStateEntry | undefined,\n eventHandler: () => void\n ) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState?.innerElement?.removeEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n eventHandler();\n };\n\n modalState?.innerElement?.addEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /* Анимирует сдвиг модалки */\n animateModalOpacity(\n modalState: ModalsStateEntry | undefined,\n display: boolean\n ) {\n if (modalState?.innerElement) {\n modalState.innerElement.style.transitionDelay =\n display && this.props.delayEnter ? `${this.timeout}ms` : \"\";\n modalState.innerElement.style.opacity = display ? \"1\" : \"0\";\n }\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(\n modalState: ModalsStateEntry,\n forceOpacity: number | null = null\n ) {\n if (forceOpacity === null && this.props.history?.[0] !== modalState.id) {\n return;\n }\n\n if (this.maskAnimationFrame) {\n cancelAnimationFrame(this.maskAnimationFrame);\n }\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(\n 0,\n Math.min(100, opacity)\n ).toString();\n }\n });\n }\n\n render() {\n const { exitingModal, activeModal, enteringModal } = this.props;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <ModalRootContext.Provider value={this.modalRootContext}>\n <div\n vkuiClass={classNames(\n getClassName(\"ModalRoot\", this.props.platform),\n this.props.configProvider?.webviewType === WebviewType.VKAPPS &&\n \"ModalRoot--vkapps\",\n \"ModalRoot--desktop\"\n )}\n >\n <div\n vkuiClass=\"ModalRoot__mask\"\n ref={this.maskElementRef}\n onClick={this.props.onExit}\n />\n <div vkuiClass=\"ModalRoot__viewport\">\n {this.modals.map((Modal: React.ReactElement) => {\n const modalId = getNavId(Modal.props, warn);\n if (modalId !== activeModal && modalId !== exitingModal) {\n return null;\n }\n\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n restoreFocus={false}\n onClose={this.props.onExit}\n timeout={this.timeout}\n key={key}\n vkuiClass={classNames(\n \"ModalRoot__modal\",\n !exitingModal &&\n !enteringModal &&\n modalId === activeModal &&\n \"ModalRoot__modal--active\",\n modalId === exitingModal && \"ModalRoot__modal--prev\",\n Boolean(exitingModal) &&\n modalId === activeModal &&\n \"ModalRoot__modal--next\"\n )}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </div>\n </ModalRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootDesktop = withContext(\n withPlatform(\n withDOM<ModalRootProps>(withModalManager()(ModalRootDesktopComponent))\n ),\n ConfigProviderContext,\n \"configProvider\"\n);\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/ModalRoot/constants.ts"],"names":["MODAL_PAGE_DEFAULT_PERCENT_HEIGHT","PERCENT_OPENED","PERCENT_CLOSED"],"mappings":"AAAA,OAAO,IAAMA,iCAAiC,GAAG,EAA1C;AAEP,OAAO,IAAMC,cAAc,GAAG,CAAvB;AACP,OAAO,IAAMC,cAAc,GAAG,GAAvB","sourcesContent":["export const MODAL_PAGE_DEFAULT_PERCENT_HEIGHT = 75;\n\nexport const PERCENT_OPENED = 0;\nexport const PERCENT_CLOSED = 100;\n"],"file":"constants.js"}
1
+ {"version":3,"file":"constants.js","names":["MODAL_PAGE_DEFAULT_PERCENT_HEIGHT","PERCENT_OPENED","PERCENT_CLOSED"],"sources":["../../../src/components/ModalRoot/constants.ts"],"sourcesContent":["export const MODAL_PAGE_DEFAULT_PERCENT_HEIGHT = 75;\n\nexport const PERCENT_OPENED = 0;\nexport const PERCENT_CLOSED = 100;\n"],"mappings":"AAAA,OAAO,IAAMA,iCAAiC,GAAG,EAA1C;AAEP,OAAO,IAAMC,cAAc,GAAG,CAAvB;AACP,OAAO,IAAMC,cAAc,GAAG,GAAvB"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/ModalRoot/types.ts"],"names":["ModalType"],"mappings":"AAAA,WAAYA,SAAZ;;WAAYA,S;AAAAA,EAAAA,S;AAAAA,EAAAA,S;GAAAA,S,KAAAA,S","sourcesContent":["export enum ModalType {\n PAGE = \"page\",\n CARD = \"card\",\n}\n\nexport type TranslateRange = [number, number];\n\nexport type ModalsState = { [index: string]: ModalsStateEntry };\n\nexport interface ModalElements {\n modalElement?: HTMLElement | null;\n innerElement?: HTMLElement | null;\n headerElement?: HTMLElement | null;\n contentElement?: HTMLElement | null;\n}\n\nexport interface ModalsStateEntry extends ModalElements {\n id: string | null;\n /**\n * Событие начала открытия модалки.\n */\n onOpen?: VoidFunction;\n /**\n * Событие открытия модалки.\n */\n onOpened?: VoidFunction;\n /**\n * Событие начала закрытия модалки.\n */\n onClose?: VoidFunction;\n /**\n * Событие закрытия модалки.\n */\n onClosed?: VoidFunction;\n type?: ModalType;\n\n settlingHeight?: number;\n dynamicContentHeight?: boolean;\n expandable?: boolean;\n\n /**\n * Процент текущего сдвига модалки\n */\n translateY?: number;\n /**\n * Процент сдвига модалки в изначальном состоянии\n */\n translateYFrom?: number;\n /**\n * Процент сдвига модалки во время взаимодействия с ней (потянуть, чтобы открыть или закрыть)\n */\n translateYCurrent?: number;\n\n touchStartContentScrollTop?: number;\n touchMovePositive?: boolean | null;\n touchShiftYPercent?: number;\n\n expanded?: boolean;\n collapsed?: boolean;\n hidden?: boolean;\n\n contentScrolled?: boolean;\n contentScrollStopTimeout?: ReturnType<typeof setTimeout>;\n\n expandedRange?: TranslateRange;\n collapsedRange?: TranslateRange;\n hiddenRange?: TranslateRange;\n}\n"],"file":"types.js"}
1
+ {"version":3,"file":"types.js","names":["ModalType"],"sources":["../../../src/components/ModalRoot/types.ts"],"sourcesContent":["export enum ModalType {\n PAGE = \"page\",\n CARD = \"card\",\n}\n\nexport type TranslateRange = [number, number];\n\nexport type ModalsState = { [index: string]: ModalsStateEntry };\n\nexport interface ModalElements {\n modalElement?: HTMLElement | null;\n innerElement?: HTMLElement | null;\n headerElement?: HTMLElement | null;\n contentElement?: HTMLElement | null;\n}\n\nexport interface ModalsStateEntry extends ModalElements {\n id: string | null;\n /**\n * Событие начала открытия модалки.\n */\n onOpen?: VoidFunction;\n /**\n * Событие открытия модалки.\n */\n onOpened?: VoidFunction;\n /**\n * Событие начала закрытия модалки.\n */\n onClose?: VoidFunction;\n /**\n * Событие закрытия модалки.\n */\n onClosed?: VoidFunction;\n type?: ModalType;\n\n settlingHeight?: number;\n dynamicContentHeight?: boolean;\n expandable?: boolean;\n\n /**\n * Процент текущего сдвига модалки\n */\n translateY?: number;\n /**\n * Процент сдвига модалки в изначальном состоянии\n */\n translateYFrom?: number;\n /**\n * Процент сдвига модалки во время взаимодействия с ней (потянуть, чтобы открыть или закрыть)\n */\n translateYCurrent?: number;\n\n touchStartContentScrollTop?: number;\n touchMovePositive?: boolean | null;\n touchShiftYPercent?: number;\n\n expanded?: boolean;\n collapsed?: boolean;\n hidden?: boolean;\n\n contentScrolled?: boolean;\n contentScrollStopTimeout?: ReturnType<typeof setTimeout>;\n\n expandedRange?: TranslateRange;\n collapsedRange?: TranslateRange;\n hiddenRange?: TranslateRange;\n}\n"],"mappings":"AAAA,WAAYA,SAAZ;;WAAYA,S;EAAAA,S;EAAAA,S;GAAAA,S,KAAAA,S"}