@vkontakte/vkui 5.3.2 → 5.4.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 (786) hide show
  1. package/dist/cjs/components/Accordion/Accordion.d.ts +2 -2
  2. package/dist/cjs/components/Accordion/Accordion.js.map +1 -1
  3. package/dist/cjs/components/Accordion/AccordionSummary.d.ts +1 -1
  4. package/dist/cjs/components/Accordion/AccordionSummary.js.map +1 -1
  5. package/dist/cjs/components/ActionSheet/types.d.ts +1 -1
  6. package/dist/cjs/components/ActionSheet/types.js.map +1 -1
  7. package/dist/cjs/components/AdaptiveIconRenderer/AdaptiveIconRenderer.d.ts +14 -0
  8. package/dist/cjs/components/{WriteBarIcon/WriteBarIconRenderer.js → AdaptiveIconRenderer/AdaptiveIconRenderer.js} +4 -4
  9. package/dist/cjs/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -0
  10. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.d.ts +4 -4
  11. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  12. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  13. package/dist/cjs/components/AppRoot/AppRootPortal.d.ts +3 -3
  14. package/dist/cjs/components/AppRoot/AppRootPortal.js.map +1 -1
  15. package/dist/cjs/components/AppRoot/ScrollContext.d.ts +2 -2
  16. package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
  17. package/dist/cjs/components/Button/Button.d.ts +1 -0
  18. package/dist/cjs/components/Button/Button.js +2 -2
  19. package/dist/cjs/components/Button/Button.js.map +1 -1
  20. package/dist/cjs/components/Card/Card.js +1 -3
  21. package/dist/cjs/components/Card/Card.js.map +1 -1
  22. package/dist/cjs/components/CardGrid/CardGrid.js +4 -4
  23. package/dist/cjs/components/CardGrid/CardGrid.js.map +1 -1
  24. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.d.ts +4 -2
  25. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js +10 -6
  26. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  27. package/dist/cjs/components/Checkbox/Checkbox.d.ts +2 -1
  28. package/dist/cjs/components/Checkbox/Checkbox.js +12 -8
  29. package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
  30. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts +4 -0
  31. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +3 -2
  32. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  33. package/dist/cjs/components/Counter/Counter.js +3 -5
  34. package/dist/cjs/components/Counter/Counter.js.map +1 -1
  35. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +3 -0
  36. package/dist/cjs/components/CustomSelect/CustomSelect.js +1 -1
  37. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  38. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js +1 -1
  39. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  40. package/dist/cjs/components/Epic/ScrollSaver.d.ts +3 -3
  41. package/dist/cjs/components/Epic/ScrollSaver.js.map +1 -1
  42. package/dist/cjs/components/File/File.js +4 -3
  43. package/dist/cjs/components/File/File.js.map +1 -1
  44. package/dist/cjs/components/FixedLayout/FixedLayout.js +1 -1
  45. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  46. package/dist/cjs/components/FocusVisible/FocusVisible.d.ts +4 -2
  47. package/dist/cjs/components/FocusVisible/FocusVisible.js +4 -3
  48. package/dist/cjs/components/FocusVisible/FocusVisible.js.map +1 -1
  49. package/dist/cjs/components/FormField/FormField.js +10 -1
  50. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  51. package/dist/cjs/components/FormItem/FormItem.d.ts +3 -1
  52. package/dist/cjs/components/FormItem/FormItem.js +2 -1
  53. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  54. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.d.ts +3 -1
  55. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  56. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  57. package/dist/cjs/components/Group/Group.d.ts +5 -3
  58. package/dist/cjs/components/Group/Group.js +2 -2
  59. package/dist/cjs/components/Group/Group.js.map +1 -1
  60. package/dist/cjs/components/Header/Header.js +20 -16
  61. package/dist/cjs/components/Header/Header.js.map +1 -1
  62. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.d.ts +5 -1
  63. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js +4 -1
  64. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  65. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.d.ts +2 -1
  66. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.js +6 -2
  67. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  68. package/dist/cjs/components/HoverPopper/HoverPopper.d.ts +1 -1
  69. package/dist/cjs/components/HoverPopper/HoverPopper.js.map +1 -1
  70. package/dist/cjs/components/IconButton/IconButton.d.ts +3 -3
  71. package/dist/cjs/components/IconButton/IconButton.js.map +1 -1
  72. package/dist/cjs/components/LocaleProvider/LocaleProvider.d.ts +2 -2
  73. package/dist/cjs/components/LocaleProvider/LocaleProvider.js.map +1 -1
  74. package/dist/cjs/components/ModalPage/ModalPage.d.ts +1 -1
  75. package/dist/cjs/components/ModalPage/ModalPage.js +19 -3
  76. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  77. package/dist/cjs/components/ModalPage/ModalPageContext.d.ts +5 -0
  78. package/dist/cjs/components/{Typography/types.js → ModalPage/ModalPageContext.js} +8 -1
  79. package/dist/cjs/components/ModalPage/ModalPageContext.js.map +1 -0
  80. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js +6 -1
  81. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  82. package/dist/cjs/components/ModalRoot/ModalRoot.d.ts +2 -27
  83. package/dist/cjs/components/ModalRoot/ModalRoot.js +13 -22
  84. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  85. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.d.ts +2 -21
  86. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  87. package/dist/cjs/components/ModalRoot/ModalRootDesktop.d.ts +3 -28
  88. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +145 -219
  89. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  90. package/dist/cjs/components/ModalRoot/types.d.ts +28 -0
  91. package/dist/cjs/components/ModalRoot/types.js.map +1 -1
  92. package/dist/cjs/components/ModalRoot/useModalManager.d.ts +6 -5
  93. package/dist/cjs/components/ModalRoot/useModalManager.js +3 -3
  94. package/dist/cjs/components/ModalRoot/useModalManager.js.map +1 -1
  95. package/dist/cjs/components/NativeSelect/NativeSelect.d.ts +6 -2
  96. package/dist/cjs/components/NativeSelect/NativeSelect.js +6 -3
  97. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  98. package/dist/cjs/components/Panel/Panel.js +2 -2
  99. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  100. package/dist/cjs/components/PanelHeader/PanelHeader.d.ts +11 -2
  101. package/dist/cjs/components/PanelHeader/PanelHeader.js +17 -7
  102. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  103. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js +1 -1
  104. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  105. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  106. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js +3 -3
  107. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  108. package/dist/cjs/components/PlatformProvider/PlatformProvider.d.ts +1 -1
  109. package/dist/cjs/components/PlatformProvider/PlatformProvider.js.map +1 -1
  110. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  111. package/dist/cjs/components/Popover/Popover.d.ts +3 -2
  112. package/dist/cjs/components/Popover/Popover.js +5 -3
  113. package/dist/cjs/components/Popover/Popover.js.map +1 -1
  114. package/dist/cjs/components/PromoBanner/PromoBanner.js.map +1 -1
  115. package/dist/cjs/components/PullToRefresh/PullToRefresh.d.ts +3 -4
  116. package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
  117. package/dist/cjs/components/Radio/Radio.d.ts +2 -1
  118. package/dist/cjs/components/Radio/Radio.js +14 -8
  119. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  120. package/dist/cjs/components/Removable/Removable.d.ts +7 -2
  121. package/dist/cjs/components/Removable/Removable.js +4 -3
  122. package/dist/cjs/components/Removable/Removable.js.map +1 -1
  123. package/dist/cjs/components/Root/Root.js.map +1 -1
  124. package/dist/cjs/components/Search/Search.d.ts +3 -1
  125. package/dist/cjs/components/Search/Search.js +42 -57
  126. package/dist/cjs/components/Search/Search.js.map +1 -1
  127. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +5 -3
  128. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +8 -4
  129. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  130. package/dist/cjs/components/SelectMimicry/SelectMimicry.js +1 -1
  131. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  132. package/dist/cjs/components/SelectTypography/SelectTypography.d.ts +2 -3
  133. package/dist/cjs/components/SelectTypography/SelectTypography.js.map +1 -1
  134. package/dist/cjs/components/SimpleCell/SimpleCell.js +8 -5
  135. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  136. package/dist/cjs/components/Spacing/Spacing.d.ts +2 -2
  137. package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
  138. package/dist/cjs/components/SplitCol/SplitCol.js +1 -0
  139. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  140. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js +1 -3
  141. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  142. package/dist/cjs/components/Switch/Switch.d.ts +4 -5
  143. package/dist/cjs/components/Switch/Switch.js +12 -8
  144. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  145. package/dist/cjs/components/Tabbar/Tabbar.js +2 -4
  146. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  147. package/dist/cjs/components/TabbarItem/TabbarItem.js +1 -1
  148. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  149. package/dist/cjs/components/Tappable/Tappable.d.ts +2 -3
  150. package/dist/cjs/components/Tappable/Tappable.js +1 -0
  151. package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
  152. package/dist/cjs/components/Typography/Caption/Caption.d.ts +2 -2
  153. package/dist/cjs/components/Typography/Caption/Caption.js +10 -13
  154. package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
  155. package/dist/cjs/components/Typography/Footnote/Footnote.d.ts +2 -2
  156. package/dist/cjs/components/Typography/Footnote/Footnote.js +10 -13
  157. package/dist/cjs/components/Typography/Footnote/Footnote.js.map +1 -1
  158. package/dist/cjs/components/Typography/Headline/Headline.d.ts +3 -4
  159. package/dist/cjs/components/Typography/Headline/Headline.js +9 -12
  160. package/dist/cjs/components/Typography/Headline/Headline.js.map +1 -1
  161. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts +3 -5
  162. package/dist/cjs/components/Typography/Paragraph/Paragraph.js +8 -13
  163. package/dist/cjs/components/Typography/Paragraph/Paragraph.js.map +1 -1
  164. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts +2 -2
  165. package/dist/cjs/components/Typography/Subhead/Subhead.js +9 -12
  166. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  167. package/dist/cjs/components/Typography/Text/Text.d.ts +3 -5
  168. package/dist/cjs/components/Typography/Text/Text.js +8 -13
  169. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  170. package/dist/cjs/components/Typography/Title/Title.d.ts +2 -2
  171. package/dist/cjs/components/Typography/Title/Title.js +10 -13
  172. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  173. package/dist/cjs/components/Typography/Typography.d.ts +16 -0
  174. package/dist/cjs/components/Typography/Typography.js +35 -0
  175. package/dist/cjs/components/Typography/Typography.js.map +1 -0
  176. package/dist/cjs/components/UsersStack/UsersStack.d.ts +2 -2
  177. package/dist/cjs/components/UsersStack/UsersStack.js +2 -1
  178. package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
  179. package/dist/cjs/components/View/View.js +1 -1
  180. package/dist/cjs/components/View/View.js.map +1 -1
  181. package/dist/cjs/components/View/ViewInfinite.js +1 -1
  182. package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
  183. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.d.ts +14 -0
  184. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.js +29 -0
  185. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.js.map +1 -0
  186. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +4 -4
  187. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.js +5 -0
  188. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -1
  189. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js +2 -2
  190. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  191. package/dist/cjs/helpers/getPlatformClassName.js +1 -1
  192. package/dist/cjs/helpers/getPlatformClassName.js.map +1 -1
  193. package/dist/cjs/hooks/useFocusWithin.d.ts +2 -0
  194. package/dist/cjs/hooks/useFocusWithin.js +38 -0
  195. package/dist/cjs/hooks/useFocusWithin.js.map +1 -0
  196. package/dist/cjs/hooks/useId.js +1 -1
  197. package/dist/cjs/hooks/useId.js.map +1 -1
  198. package/dist/cjs/hooks/useWaitTransitionFinish.d.ts +1 -1
  199. package/dist/cjs/hooks/useWaitTransitionFinish.js.map +1 -1
  200. package/dist/cjs/index.d.ts +4 -2
  201. package/dist/cjs/index.js +8 -0
  202. package/dist/cjs/index.js.map +1 -1
  203. package/dist/cjs/lib/utils.js +2 -2
  204. package/dist/cjs/lib/utils.js.map +1 -1
  205. package/dist/components/Accordion/Accordion.d.ts +2 -2
  206. package/dist/components/Accordion/Accordion.js +2 -2
  207. package/dist/components/Accordion/Accordion.js.map +1 -1
  208. package/dist/components/Accordion/AccordionSummary.d.ts +1 -1
  209. package/dist/components/Accordion/AccordionSummary.js +1 -1
  210. package/dist/components/Accordion/AccordionSummary.js.map +1 -1
  211. package/dist/components/ActionSheet/types.d.ts +1 -1
  212. package/dist/components/ActionSheet/types.js.map +1 -1
  213. package/dist/components/AdaptiveIconRenderer/AdaptiveIconRenderer.d.ts +14 -0
  214. package/dist/components/{WriteBarIcon/WriteBarIconRenderer.js → AdaptiveIconRenderer/AdaptiveIconRenderer.js} +5 -2
  215. package/dist/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -0
  216. package/dist/components/AdaptivityProvider/AdaptivityProvider.d.ts +4 -4
  217. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  218. package/dist/components/Alert/Alert.js.map +1 -1
  219. package/dist/components/AppRoot/AppRootPortal.d.ts +3 -3
  220. package/dist/components/AppRoot/AppRootPortal.js.map +1 -1
  221. package/dist/components/AppRoot/ScrollContext.d.ts +2 -2
  222. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  223. package/dist/components/Button/Button.d.ts +1 -0
  224. package/dist/components/Button/Button.js +2 -2
  225. package/dist/components/Button/Button.js.map +1 -1
  226. package/dist/components/Card/Card.js +1 -3
  227. package/dist/components/Card/Card.js.map +1 -1
  228. package/dist/components/CardGrid/CardGrid.js +4 -4
  229. package/dist/components/CardGrid/CardGrid.js.map +1 -1
  230. package/dist/components/Cell/CellCheckbox/CellCheckbox.d.ts +4 -2
  231. package/dist/components/Cell/CellCheckbox/CellCheckbox.js +10 -6
  232. package/dist/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  233. package/dist/components/Checkbox/Checkbox.d.ts +2 -1
  234. package/dist/components/Checkbox/Checkbox.js +12 -8
  235. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  236. package/dist/components/ChipsSelect/ChipsSelect.d.ts +4 -0
  237. package/dist/components/ChipsSelect/ChipsSelect.js +3 -2
  238. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  239. package/dist/components/Counter/Counter.js +4 -6
  240. package/dist/components/Counter/Counter.js.map +1 -1
  241. package/dist/components/CustomSelect/CustomSelect.d.ts +3 -0
  242. package/dist/components/CustomSelect/CustomSelect.js +1 -1
  243. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  244. package/dist/components/CustomSelectOption/CustomSelectOption.js +1 -1
  245. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  246. package/dist/components/Epic/ScrollSaver.d.ts +3 -3
  247. package/dist/components/Epic/ScrollSaver.js.map +1 -1
  248. package/dist/components/File/File.js +4 -3
  249. package/dist/components/File/File.js.map +1 -1
  250. package/dist/components/FixedLayout/FixedLayout.js +1 -1
  251. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  252. package/dist/components/FocusVisible/FocusVisible.d.ts +4 -2
  253. package/dist/components/FocusVisible/FocusVisible.js +4 -3
  254. package/dist/components/FocusVisible/FocusVisible.js.map +1 -1
  255. package/dist/components/FormField/FormField.js +10 -1
  256. package/dist/components/FormField/FormField.js.map +1 -1
  257. package/dist/components/FormItem/FormItem.d.ts +3 -1
  258. package/dist/components/FormItem/FormItem.js +2 -1
  259. package/dist/components/FormItem/FormItem.js.map +1 -1
  260. package/dist/components/FormLayoutGroup/FormLayoutGroup.d.ts +3 -1
  261. package/dist/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  262. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  263. package/dist/components/Group/Group.d.ts +5 -3
  264. package/dist/components/Group/Group.js +5 -3
  265. package/dist/components/Group/Group.js.map +1 -1
  266. package/dist/components/Header/Header.js +20 -16
  267. package/dist/components/Header/Header.js.map +1 -1
  268. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +5 -1
  269. package/dist/components/HorizontalScroll/HorizontalScroll.js +4 -1
  270. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  271. package/dist/components/HorizontalScroll/HorizontalScrollArrow.d.ts +2 -1
  272. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js +6 -2
  273. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  274. package/dist/components/HoverPopper/HoverPopper.d.ts +1 -1
  275. package/dist/components/HoverPopper/HoverPopper.js.map +1 -1
  276. package/dist/components/IconButton/IconButton.d.ts +3 -3
  277. package/dist/components/IconButton/IconButton.js.map +1 -1
  278. package/dist/components/LocaleProvider/LocaleProvider.d.ts +2 -2
  279. package/dist/components/LocaleProvider/LocaleProvider.js +2 -2
  280. package/dist/components/LocaleProvider/LocaleProvider.js.map +1 -1
  281. package/dist/components/ModalPage/ModalPage.d.ts +1 -1
  282. package/dist/components/ModalPage/ModalPage.js +19 -3
  283. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  284. package/dist/components/ModalPage/ModalPageContext.d.ts +5 -0
  285. package/dist/components/ModalPage/ModalPageContext.js +4 -0
  286. package/dist/components/ModalPage/ModalPageContext.js.map +1 -0
  287. package/dist/components/ModalPageHeader/ModalPageHeader.js +6 -1
  288. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  289. package/dist/components/ModalRoot/ModalRoot.d.ts +2 -27
  290. package/dist/components/ModalRoot/ModalRoot.js +13 -22
  291. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  292. package/dist/components/ModalRoot/ModalRootAdaptive.d.ts +2 -21
  293. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  294. package/dist/components/ModalRoot/ModalRootDesktop.d.ts +3 -28
  295. package/dist/components/ModalRoot/ModalRootDesktop.js +149 -223
  296. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  297. package/dist/components/ModalRoot/types.d.ts +28 -0
  298. package/dist/components/ModalRoot/types.js.map +1 -1
  299. package/dist/components/ModalRoot/useModalManager.d.ts +6 -5
  300. package/dist/components/ModalRoot/useModalManager.js +3 -3
  301. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  302. package/dist/components/NativeSelect/NativeSelect.d.ts +6 -2
  303. package/dist/components/NativeSelect/NativeSelect.js +6 -3
  304. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  305. package/dist/components/Panel/Panel.js +2 -2
  306. package/dist/components/Panel/Panel.js.map +1 -1
  307. package/dist/components/PanelHeader/PanelHeader.d.ts +11 -2
  308. package/dist/components/PanelHeader/PanelHeader.js +17 -7
  309. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  310. package/dist/components/PanelHeaderButton/PanelHeaderButton.js +1 -1
  311. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  312. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  313. package/dist/components/PanelHeaderContext/PanelHeaderContext.js +3 -3
  314. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  315. package/dist/components/PlatformProvider/PlatformProvider.d.ts +1 -1
  316. package/dist/components/PlatformProvider/PlatformProvider.js +1 -1
  317. package/dist/components/PlatformProvider/PlatformProvider.js.map +1 -1
  318. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  319. package/dist/components/Popover/Popover.d.ts +3 -2
  320. package/dist/components/Popover/Popover.js +5 -3
  321. package/dist/components/Popover/Popover.js.map +1 -1
  322. package/dist/components/PromoBanner/PromoBanner.js +1 -0
  323. package/dist/components/PromoBanner/PromoBanner.js.map +1 -1
  324. package/dist/components/PullToRefresh/PullToRefresh.d.ts +3 -4
  325. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  326. package/dist/components/Radio/Radio.d.ts +2 -1
  327. package/dist/components/Radio/Radio.js +14 -8
  328. package/dist/components/Radio/Radio.js.map +1 -1
  329. package/dist/components/Removable/Removable.d.ts +7 -2
  330. package/dist/components/Removable/Removable.js +4 -3
  331. package/dist/components/Removable/Removable.js.map +1 -1
  332. package/dist/components/Root/Root.js.map +1 -1
  333. package/dist/components/Search/Search.d.ts +3 -1
  334. package/dist/components/Search/Search.js +42 -57
  335. package/dist/components/Search/Search.js.map +1 -1
  336. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +5 -3
  337. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +8 -4
  338. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  339. package/dist/components/SelectMimicry/SelectMimicry.js +1 -1
  340. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  341. package/dist/components/SelectTypography/SelectTypography.d.ts +2 -3
  342. package/dist/components/SelectTypography/SelectTypography.js.map +1 -1
  343. package/dist/components/SimpleCell/SimpleCell.js +8 -5
  344. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  345. package/dist/components/Spacing/Spacing.d.ts +2 -2
  346. package/dist/components/Spacing/Spacing.js.map +1 -1
  347. package/dist/components/SplitCol/SplitCol.js +1 -0
  348. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  349. package/dist/components/SubnavigationButton/SubnavigationButton.js +1 -3
  350. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  351. package/dist/components/Switch/Switch.d.ts +4 -5
  352. package/dist/components/Switch/Switch.js +12 -8
  353. package/dist/components/Switch/Switch.js.map +1 -1
  354. package/dist/components/Tabbar/Tabbar.js +2 -4
  355. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  356. package/dist/components/TabbarItem/TabbarItem.js +1 -1
  357. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  358. package/dist/components/Tappable/Tappable.d.ts +2 -3
  359. package/dist/components/Tappable/Tappable.js +1 -0
  360. package/dist/components/Tappable/Tappable.js.map +1 -1
  361. package/dist/components/Typography/Caption/Caption.d.ts +2 -2
  362. package/dist/components/Typography/Caption/Caption.js +10 -13
  363. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  364. package/dist/components/Typography/Footnote/Footnote.d.ts +2 -2
  365. package/dist/components/Typography/Footnote/Footnote.js +10 -13
  366. package/dist/components/Typography/Footnote/Footnote.js.map +1 -1
  367. package/dist/components/Typography/Headline/Headline.d.ts +3 -4
  368. package/dist/components/Typography/Headline/Headline.js +9 -12
  369. package/dist/components/Typography/Headline/Headline.js.map +1 -1
  370. package/dist/components/Typography/Paragraph/Paragraph.d.ts +3 -5
  371. package/dist/components/Typography/Paragraph/Paragraph.js +8 -13
  372. package/dist/components/Typography/Paragraph/Paragraph.js.map +1 -1
  373. package/dist/components/Typography/Subhead/Subhead.d.ts +2 -2
  374. package/dist/components/Typography/Subhead/Subhead.js +9 -12
  375. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  376. package/dist/components/Typography/Text/Text.d.ts +3 -5
  377. package/dist/components/Typography/Text/Text.js +8 -13
  378. package/dist/components/Typography/Text/Text.js.map +1 -1
  379. package/dist/components/Typography/Title/Title.d.ts +2 -2
  380. package/dist/components/Typography/Title/Title.js +10 -13
  381. package/dist/components/Typography/Title/Title.js.map +1 -1
  382. package/dist/components/Typography/Typography.d.ts +16 -0
  383. package/dist/components/Typography/Typography.js +24 -0
  384. package/dist/components/Typography/Typography.js.map +1 -0
  385. package/dist/components/UsersStack/UsersStack.d.ts +2 -2
  386. package/dist/components/UsersStack/UsersStack.js +2 -1
  387. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  388. package/dist/components/View/View.js +1 -1
  389. package/dist/components/View/View.js.map +1 -1
  390. package/dist/components/View/ViewInfinite.js +1 -1
  391. package/dist/components/View/ViewInfinite.js.map +1 -1
  392. package/dist/components/VisuallyHidden/VisuallyHidden.d.ts +14 -0
  393. package/dist/components/VisuallyHidden/VisuallyHidden.js +25 -0
  394. package/dist/components/VisuallyHidden/VisuallyHidden.js.map +1 -0
  395. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +4 -4
  396. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.js +9 -4
  397. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -1
  398. package/dist/components/WriteBarIcon/WriteBarIcon.js +2 -2
  399. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  400. package/dist/components.css +138 -138
  401. package/dist/components.css.map +1 -1
  402. package/dist/components.js.tmp +3802 -3692
  403. package/dist/cssm/components/Accordion/Accordion.d.ts +2 -2
  404. package/dist/cssm/components/Accordion/Accordion.js +2 -2
  405. package/dist/cssm/components/Accordion/Accordion.js.map +1 -1
  406. package/dist/cssm/components/Accordion/Accordion.module.css +13 -1
  407. package/dist/cssm/components/Accordion/AccordionSummary.d.ts +1 -1
  408. package/dist/cssm/components/Accordion/AccordionSummary.js +1 -1
  409. package/dist/cssm/components/Accordion/AccordionSummary.js.map +1 -1
  410. package/dist/cssm/components/ActionSheet/ActionSheet.module.css +115 -1
  411. package/dist/cssm/components/ActionSheet/types.d.ts +1 -1
  412. package/dist/cssm/components/ActionSheet/types.js.map +1 -1
  413. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.module.css +241 -1
  414. package/dist/cssm/components/AdaptiveIconRenderer/AdaptiveIconRenderer.d.ts +14 -0
  415. package/dist/cssm/components/{WriteBarIcon/WriteBarIconRenderer.js → AdaptiveIconRenderer/AdaptiveIconRenderer.js} +5 -2
  416. package/dist/cssm/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -0
  417. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.d.ts +4 -4
  418. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  419. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  420. package/dist/cssm/components/Alert/Alert.module.css +287 -1
  421. package/dist/cssm/components/AppRoot/AppRoot.module.css +23 -1
  422. package/dist/cssm/components/AppRoot/AppRootPortal.d.ts +3 -3
  423. package/dist/cssm/components/AppRoot/AppRootPortal.js.map +1 -1
  424. package/dist/cssm/components/AppRoot/ScrollContext.d.ts +2 -2
  425. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  426. package/dist/cssm/components/Avatar/Avatar.module.css +55 -1
  427. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadge.module.css +29 -1
  428. package/dist/cssm/components/Badge/Badge.module.css +27 -1
  429. package/dist/cssm/components/Banner/Banner.module.css +167 -1
  430. package/dist/cssm/components/BaseGallery/BaseGallery.module.css +82 -1
  431. package/dist/cssm/components/Button/Button.d.ts +1 -0
  432. package/dist/cssm/components/Button/Button.js +2 -1
  433. package/dist/cssm/components/Button/Button.js.map +1 -1
  434. package/dist/cssm/components/Button/Button.module.css +676 -1
  435. package/dist/cssm/components/ButtonGroup/ButtonGroup.module.css +77 -1
  436. package/dist/cssm/components/Calendar/Calendar.module.css +30 -1
  437. package/dist/cssm/components/CalendarDay/CalendarDay.module.css +84 -1
  438. package/dist/cssm/components/CalendarDays/CalendarDays.module.css +31 -1
  439. package/dist/cssm/components/CalendarHeader/CalendarHeader.module.css +41 -1
  440. package/dist/cssm/components/CalendarRange/CalendarRange.module.css +26 -1
  441. package/dist/cssm/components/CalendarTime/CalendarTime.module.css +19 -1
  442. package/dist/cssm/components/Card/Card.js +1 -3
  443. package/dist/cssm/components/Card/Card.js.map +1 -1
  444. package/dist/cssm/components/Card/Card.module.css +131 -3
  445. package/dist/cssm/components/CardGrid/CardGrid.js +4 -4
  446. package/dist/cssm/components/CardGrid/CardGrid.js.map +1 -1
  447. package/dist/cssm/components/CardGrid/CardGrid.module.css +59 -1
  448. package/dist/cssm/components/CardScroll/CardScroll.module.css +64 -1
  449. package/dist/cssm/components/Cell/Cell.module.css +63 -1
  450. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.d.ts +4 -2
  451. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js +7 -5
  452. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  453. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.module.css +13 -1
  454. package/dist/cssm/components/Cell/CellDragger/CellDragger.module.css +4 -1
  455. package/dist/cssm/components/CellButton/CellButton.module.css +57 -1
  456. package/dist/cssm/components/Checkbox/Checkbox.d.ts +2 -1
  457. package/dist/cssm/components/Checkbox/Checkbox.js +10 -7
  458. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  459. package/dist/cssm/components/Checkbox/Checkbox.module.css +172 -1
  460. package/dist/cssm/components/Chip/Chip.module.css +67 -1
  461. package/dist/cssm/components/ChipsInput/ChipsInput.module.css +3 -1
  462. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.module.css +115 -1
  463. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts +4 -0
  464. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +2 -2
  465. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  466. package/dist/cssm/components/ChipsSelect/ChipsSelect.module.css +27 -1
  467. package/dist/cssm/components/ContentCard/ContentCard.module.css +31 -1
  468. package/dist/cssm/components/Counter/Counter.js +4 -6
  469. package/dist/cssm/components/Counter/Counter.js.map +1 -1
  470. package/dist/cssm/components/Counter/Counter.module.css +72 -3
  471. package/dist/cssm/components/CustomScrollView/CustomScrollView.module.css +86 -1
  472. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +3 -0
  473. package/dist/cssm/components/CustomSelect/CustomSelect.js +1 -1
  474. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  475. package/dist/cssm/components/CustomSelect/CustomSelect.module.css +58 -1
  476. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.module.css +43 -1
  477. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js +1 -1
  478. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  479. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.module.css +81 -1
  480. package/dist/cssm/components/DateInput/DateInput.module.css +30 -1
  481. package/dist/cssm/components/DatePicker/DatePicker.module.css +30 -1
  482. package/dist/cssm/components/DateRangeInput/DateRangeInput.module.css +26 -1
  483. package/dist/cssm/components/Div/Div.module.css +4 -1
  484. package/dist/cssm/components/Epic/Epic.module.css +4 -1
  485. package/dist/cssm/components/Epic/ScrollSaver.d.ts +3 -3
  486. package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
  487. package/dist/cssm/components/File/File.js +4 -3
  488. package/dist/cssm/components/File/File.js.map +1 -1
  489. package/dist/cssm/components/FixedLayout/FixedLayout.js +1 -1
  490. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  491. package/dist/cssm/components/FixedLayout/FixedLayout.module.css +58 -1
  492. package/dist/cssm/components/FocusVisible/FocusVisible.d.ts +4 -2
  493. package/dist/cssm/components/FocusVisible/FocusVisible.js +4 -3
  494. package/dist/cssm/components/FocusVisible/FocusVisible.js.map +1 -1
  495. package/dist/cssm/components/FocusVisible/FocusVisible.module.css +104 -1
  496. package/dist/cssm/components/Footer/Footer.module.css +9 -1
  497. package/dist/cssm/components/FormField/FormField.js +10 -1
  498. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  499. package/dist/cssm/components/FormField/FormField.module.css +211 -1
  500. package/dist/cssm/components/FormItem/FormItem.d.ts +3 -1
  501. package/dist/cssm/components/FormItem/FormItem.js +2 -1
  502. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  503. package/dist/cssm/components/FormItem/FormItem.module.css +104 -1
  504. package/dist/cssm/components/FormLayout/FormLayout.module.css +18 -1
  505. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.d.ts +3 -1
  506. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  507. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  508. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.module.css +61 -1
  509. package/dist/cssm/components/FormStatus/FormStatus.module.css +3 -1
  510. package/dist/cssm/components/Gradient/Gradient.module.css +23 -1
  511. package/dist/cssm/components/GridAvatar/GridAvatar.module.css +37 -1
  512. package/dist/cssm/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.module.css +9 -1
  513. package/dist/cssm/components/Group/Group.d.ts +5 -3
  514. package/dist/cssm/components/Group/Group.js +5 -3
  515. package/dist/cssm/components/Group/Group.js.map +1 -1
  516. package/dist/cssm/components/Group/Group.module.css +166 -1
  517. package/dist/cssm/components/Header/Header.js +23 -18
  518. package/dist/cssm/components/Header/Header.js.map +1 -1
  519. package/dist/cssm/components/Header/Header.module.css +207 -1
  520. package/dist/cssm/components/HorizontalCell/HorizontalCell.module.css +79 -1
  521. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.d.ts +5 -1
  522. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +3 -1
  523. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  524. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.module.css +59 -1
  525. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.d.ts +2 -1
  526. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js +5 -2
  527. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  528. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.module.css +67 -1
  529. package/dist/cssm/components/HoverPopper/HoverPopper.d.ts +1 -1
  530. package/dist/cssm/components/HoverPopper/HoverPopper.js.map +1 -1
  531. package/dist/cssm/components/IconButton/IconButton.d.ts +3 -3
  532. package/dist/cssm/components/IconButton/IconButton.js.map +1 -1
  533. package/dist/cssm/components/IconButton/IconButton.module.css +152 -1
  534. package/dist/cssm/components/Image/ImageBadge/ImageBadge.module.css +10 -1
  535. package/dist/cssm/components/ImageBase/ImageBase.module.css +131 -1
  536. package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.module.css +28 -1
  537. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.module.css +36 -1
  538. package/dist/cssm/components/InfoRow/InfoRow.module.css +17 -1
  539. package/dist/cssm/components/Input/Input.module.css +101 -1
  540. package/dist/cssm/components/InputLike/InputLike.module.css +31 -1
  541. package/dist/cssm/components/Link/Link.module.css +43 -1
  542. package/dist/cssm/components/List/List.module.css +3 -1
  543. package/dist/cssm/components/LocaleProvider/LocaleProvider.d.ts +2 -2
  544. package/dist/cssm/components/LocaleProvider/LocaleProvider.js +2 -2
  545. package/dist/cssm/components/LocaleProvider/LocaleProvider.js.map +1 -1
  546. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.module.css +78 -1
  547. package/dist/cssm/components/ModalCard/ModalCard.module.css +62 -1
  548. package/dist/cssm/components/ModalCardBase/ModalCardBase.module.css +102 -1
  549. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.module.css +38 -1
  550. package/dist/cssm/components/ModalPage/ModalPage.d.ts +1 -1
  551. package/dist/cssm/components/ModalPage/ModalPage.js +17 -3
  552. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  553. package/dist/cssm/components/ModalPage/ModalPage.module.css +151 -1
  554. package/dist/cssm/components/ModalPage/ModalPageContext.d.ts +5 -0
  555. package/dist/cssm/components/ModalPage/ModalPageContext.js +4 -0
  556. package/dist/cssm/components/ModalPage/ModalPageContext.js.map +1 -0
  557. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js +6 -1
  558. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  559. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.module.css +18 -1
  560. package/dist/cssm/components/ModalRoot/ModalRoot.d.ts +2 -27
  561. package/dist/cssm/components/ModalRoot/ModalRoot.js +12 -18
  562. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  563. package/dist/cssm/components/ModalRoot/ModalRoot.module.css +65 -1
  564. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.d.ts +2 -21
  565. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  566. package/dist/cssm/components/ModalRoot/ModalRootDesktop.d.ts +3 -28
  567. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +106 -125
  568. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  569. package/dist/cssm/components/ModalRoot/types.d.ts +28 -0
  570. package/dist/cssm/components/ModalRoot/types.js.map +1 -1
  571. package/dist/cssm/components/ModalRoot/useModalManager.d.ts +6 -5
  572. package/dist/cssm/components/ModalRoot/useModalManager.js +3 -3
  573. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  574. package/dist/cssm/components/NativeSelect/NativeSelect.d.ts +6 -2
  575. package/dist/cssm/components/NativeSelect/NativeSelect.js +4 -3
  576. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  577. package/dist/cssm/components/Pagination/Pagination.module.css +83 -1
  578. package/dist/cssm/components/Panel/Panel.js +2 -2
  579. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  580. package/dist/cssm/components/Panel/Panel.module.css +177 -1
  581. package/dist/cssm/components/PanelHeader/PanelHeader.d.ts +11 -2
  582. package/dist/cssm/components/PanelHeader/PanelHeader.js +16 -7
  583. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  584. package/dist/cssm/components/PanelHeader/PanelHeader.module.css +321 -1
  585. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js +1 -1
  586. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  587. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.module.css +111 -1
  588. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  589. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.module.css +96 -1
  590. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js +3 -3
  591. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  592. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.module.css +169 -1
  593. package/dist/cssm/components/Placeholder/Placeholder.module.css +41 -1
  594. package/dist/cssm/components/PlatformProvider/PlatformProvider.d.ts +1 -1
  595. package/dist/cssm/components/PlatformProvider/PlatformProvider.js +1 -1
  596. package/dist/cssm/components/PlatformProvider/PlatformProvider.js.map +1 -1
  597. package/dist/cssm/components/PopoutRoot/PopoutRoot.module.css +32 -1
  598. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +1 -1
  599. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  600. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.module.css +96 -1
  601. package/dist/cssm/components/Popover/Popover.d.ts +3 -2
  602. package/dist/cssm/components/Popover/Popover.js +3 -2
  603. package/dist/cssm/components/Popover/Popover.js.map +1 -1
  604. package/dist/cssm/components/Popover/Popover.module.css +28 -1
  605. package/dist/cssm/components/Popper/Popper.module.css +16 -1
  606. package/dist/cssm/components/PopperArrow/PopperArrow.module.css +23 -1
  607. package/dist/cssm/components/Progress/Progress.module.css +12 -1
  608. package/dist/cssm/components/PromoBanner/PromoBanner.js +1 -0
  609. package/dist/cssm/components/PromoBanner/PromoBanner.js.map +1 -1
  610. package/dist/cssm/components/PromoBanner/PromoBanner.module.css +39 -1
  611. package/dist/cssm/components/PullToRefresh/PullToRefresh.d.ts +3 -4
  612. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  613. package/dist/cssm/components/PullToRefresh/PullToRefresh.module.css +101 -1
  614. package/dist/cssm/components/Radio/Radio.d.ts +2 -1
  615. package/dist/cssm/components/Radio/Radio.js +11 -7
  616. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  617. package/dist/cssm/components/Radio/Radio.module.css +140 -1
  618. package/dist/cssm/components/RadioGroup/RadioGroup.module.css +13 -1
  619. package/dist/cssm/components/Removable/Removable.d.ts +7 -2
  620. package/dist/cssm/components/Removable/Removable.js +2 -2
  621. package/dist/cssm/components/Removable/Removable.js.map +1 -1
  622. package/dist/cssm/components/Removable/Removable.module.css +153 -1
  623. package/dist/cssm/components/RichCell/RichCell.module.css +144 -1
  624. package/dist/cssm/components/RichCell/RichCellIcon/RichCellIcon.module.css +11 -1
  625. package/dist/cssm/components/RichTooltip/RichTooltip.module.css +57 -1
  626. package/dist/cssm/components/Root/Root.js +4 -4
  627. package/dist/cssm/components/Root/Root.js.map +1 -1
  628. package/dist/cssm/components/Root/Root.module.css +136 -1
  629. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.module.css +66 -1
  630. package/dist/cssm/components/Search/Search.d.ts +3 -1
  631. package/dist/cssm/components/Search/Search.js +38 -54
  632. package/dist/cssm/components/Search/Search.js.map +1 -1
  633. package/dist/cssm/components/Search/Search.module.css +156 -1
  634. package/dist/cssm/components/SegmentedControl/SegmentedControl.module.css +64 -1
  635. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +5 -3
  636. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +7 -4
  637. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  638. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.module.css +52 -1
  639. package/dist/cssm/components/Select/Select.module.css +87 -1
  640. package/dist/cssm/components/SelectMimicry/SelectMimicry.js +1 -1
  641. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  642. package/dist/cssm/components/SelectTypography/SelectTypography.d.ts +2 -3
  643. package/dist/cssm/components/SelectTypography/SelectTypography.js.map +1 -1
  644. package/dist/cssm/components/SelectTypography/SelectTypography.module.css +30 -1
  645. package/dist/cssm/components/Separator/Separator.module.css +48 -1
  646. package/dist/cssm/components/SimpleCell/SimpleCell.js +8 -5
  647. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  648. package/dist/cssm/components/SimpleCell/SimpleCell.module.css +223 -1
  649. package/dist/cssm/components/Slider/Slider.module.css +134 -1
  650. package/dist/cssm/components/Snackbar/Snackbar.module.css +165 -1
  651. package/dist/cssm/components/Spacing/Spacing.d.ts +2 -2
  652. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  653. package/dist/cssm/components/Spacing/Spacing.module.css +4 -1
  654. package/dist/cssm/components/Spinner/Spinner.module.css +36 -1
  655. package/dist/cssm/components/SplitCol/SplitCol.js +1 -0
  656. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  657. package/dist/cssm/components/SplitCol/SplitCol.module.css +51 -1
  658. package/dist/cssm/components/SplitLayout/SplitLayout.module.css +29 -1
  659. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.module.css +16 -1
  660. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +1 -3
  661. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  662. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.module.css +166 -1
  663. package/dist/cssm/components/Switch/Switch.d.ts +4 -5
  664. package/dist/cssm/components/Switch/Switch.js +11 -8
  665. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  666. package/dist/cssm/components/Switch/Switch.module.css +200 -1
  667. package/dist/cssm/components/Tabbar/Tabbar.js +2 -4
  668. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  669. package/dist/cssm/components/Tabbar/Tabbar.module.css +34 -1
  670. package/dist/cssm/components/TabbarItem/TabbarItem.js +1 -1
  671. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  672. package/dist/cssm/components/TabbarItem/TabbarItem.module.css +118 -1
  673. package/dist/cssm/components/Tabs/Tabs.module.css +62 -1
  674. package/dist/cssm/components/TabsItem/TabsItem.module.css +229 -1
  675. package/dist/cssm/components/Tappable/Tappable.d.ts +2 -3
  676. package/dist/cssm/components/Tappable/Tappable.js +1 -0
  677. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  678. package/dist/cssm/components/Tappable/Tappable.module.css +142 -1
  679. package/dist/cssm/components/TextTooltip/TextTooltip.module.css +58 -1
  680. package/dist/cssm/components/Textarea/Textarea.module.css +87 -1
  681. package/dist/cssm/components/Tooltip/Tooltip.module.css +57 -1
  682. package/dist/cssm/components/Typography/Caption/Caption.d.ts +2 -2
  683. package/dist/cssm/components/Typography/Caption/Caption.js +9 -10
  684. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  685. package/dist/cssm/components/Typography/Caption/Caption.module.css +45 -1
  686. package/dist/cssm/components/Typography/Footnote/Footnote.d.ts +2 -2
  687. package/dist/cssm/components/Typography/Footnote/Footnote.js +7 -10
  688. package/dist/cssm/components/Typography/Footnote/Footnote.js.map +1 -1
  689. package/dist/cssm/components/Typography/Footnote/Footnote.module.css +14 -1
  690. package/dist/cssm/components/Typography/Headline/Headline.d.ts +3 -4
  691. package/dist/cssm/components/Typography/Headline/Headline.js +9 -10
  692. package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
  693. package/dist/cssm/components/Typography/Headline/Headline.module.css +48 -1
  694. package/dist/cssm/components/Typography/Paragraph/Paragraph.d.ts +3 -5
  695. package/dist/cssm/components/Typography/Paragraph/Paragraph.js +8 -10
  696. package/dist/cssm/components/Typography/Paragraph/Paragraph.js.map +1 -1
  697. package/dist/cssm/components/Typography/Paragraph/Paragraph.module.css +6 -1
  698. package/dist/cssm/components/Typography/Subhead/Subhead.d.ts +2 -2
  699. package/dist/cssm/components/Typography/Subhead/Subhead.js +8 -9
  700. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  701. package/dist/cssm/components/Typography/Subhead/Subhead.module.css +18 -1
  702. package/dist/cssm/components/Typography/Text/Text.d.ts +3 -5
  703. package/dist/cssm/components/Typography/Text/Text.js +8 -10
  704. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  705. package/dist/cssm/components/Typography/Text/Text.module.css +29 -1
  706. package/dist/cssm/components/Typography/Title/Title.d.ts +2 -2
  707. package/dist/cssm/components/Typography/Title/Title.js +9 -10
  708. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  709. package/dist/cssm/components/Typography/Title/Title.module.css +20 -1
  710. package/dist/cssm/components/Typography/Typography.d.ts +16 -0
  711. package/dist/cssm/components/Typography/Typography.js +14 -0
  712. package/dist/cssm/components/Typography/Typography.js.map +1 -0
  713. package/dist/cssm/components/Typography/Typography.module.css +18 -0
  714. package/dist/cssm/components/UsersStack/UsersStack.d.ts +2 -2
  715. package/dist/cssm/components/UsersStack/UsersStack.js +2 -1
  716. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  717. package/dist/cssm/components/UsersStack/UsersStack.module.css +77 -1
  718. package/dist/cssm/components/View/View.js +6 -7
  719. package/dist/cssm/components/View/View.js.map +1 -1
  720. package/dist/cssm/components/View/View.module.css +228 -1
  721. package/dist/cssm/components/View/ViewInfinite.js +6 -7
  722. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  723. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.d.ts +14 -0
  724. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.js +19 -0
  725. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.js.map +1 -0
  726. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.module.css +10 -0
  727. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +4 -4
  728. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.js +9 -4
  729. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -1
  730. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.module.css +10 -1
  731. package/dist/cssm/components/WriteBar/WriteBar.module.css +119 -1
  732. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +2 -2
  733. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  734. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.module.css +66 -1
  735. package/dist/cssm/helpers/getPlatformClassName.js +1 -1
  736. package/dist/cssm/helpers/getPlatformClassName.js.map +1 -1
  737. package/dist/cssm/hooks/useFocusWithin.d.ts +2 -0
  738. package/dist/cssm/hooks/useFocusWithin.js +26 -0
  739. package/dist/cssm/hooks/useFocusWithin.js.map +1 -0
  740. package/dist/cssm/hooks/useId.js +1 -1
  741. package/dist/cssm/hooks/useId.js.map +1 -1
  742. package/dist/cssm/hooks/useWaitTransitionFinish.d.ts +1 -1
  743. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  744. package/dist/cssm/index.d.ts +4 -2
  745. package/dist/cssm/index.js +2 -1
  746. package/dist/cssm/index.js.map +1 -1
  747. package/dist/cssm/lib/utils.js +2 -2
  748. package/dist/cssm/lib/utils.js.map +1 -1
  749. package/dist/cssm/styles/adaptivity.module.css +87 -1
  750. package/dist/cssm/styles/common.css +36 -1
  751. package/dist/cssm/styles/constants.css +86 -1
  752. package/dist/cssm/styles/themes.css +1039 -1
  753. package/dist/helpers/getPlatformClassName.js +1 -1
  754. package/dist/helpers/getPlatformClassName.js.map +1 -1
  755. package/dist/hooks/useFocusWithin.d.ts +2 -0
  756. package/dist/hooks/useFocusWithin.js +27 -0
  757. package/dist/hooks/useFocusWithin.js.map +1 -0
  758. package/dist/hooks/useId.js +1 -1
  759. package/dist/hooks/useId.js.map +1 -1
  760. package/dist/hooks/useWaitTransitionFinish.d.ts +1 -1
  761. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  762. package/dist/index.d.ts +4 -2
  763. package/dist/index.js +2 -0
  764. package/dist/index.js.map +1 -1
  765. package/dist/lib/utils.js +2 -2
  766. package/dist/lib/utils.js.map +1 -1
  767. package/dist/vkui.css +139 -139
  768. package/dist/vkui.css.map +1 -1
  769. package/dist/vkui.js.tmp +3802 -3692
  770. package/package.json +24 -17
  771. package/dist/cjs/components/Typography/types.d.ts +0 -11
  772. package/dist/cjs/components/Typography/types.js.map +0 -1
  773. package/dist/cjs/components/WriteBarIcon/WriteBarIconRenderer.d.ts +0 -10
  774. package/dist/cjs/components/WriteBarIcon/WriteBarIconRenderer.js.map +0 -1
  775. package/dist/components/Typography/types.d.ts +0 -11
  776. package/dist/components/Typography/types.js +0 -3
  777. package/dist/components/Typography/types.js.map +0 -1
  778. package/dist/components/WriteBarIcon/WriteBarIconRenderer.d.ts +0 -10
  779. package/dist/components/WriteBarIcon/WriteBarIconRenderer.js.map +0 -1
  780. package/dist/cssm/components/Typography/types.d.ts +0 -11
  781. package/dist/cssm/components/Typography/types.js +0 -3
  782. package/dist/cssm/components/Typography/types.js.map +0 -1
  783. package/dist/cssm/components/View/ViewIOS.module.css +0 -1
  784. package/dist/cssm/components/WriteBarIcon/WriteBarIconRenderer.d.ts +0 -10
  785. package/dist/cssm/components/WriteBarIcon/WriteBarIconRenderer.js.map +0 -1
  786. package/dist/cssm/styles/animations.css +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/ModalRoot/useModalManager.tsx"],"sourcesContent":["import * as React from 'react';\nimport { isFunction, noop } from '@vkontakte/vkjs';\nimport { getNavId } from '../../lib/getNavId';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { ModalsState, ModalsStateEntry, ModalType } from './types';\n\ninterface ModalTransitionState {\n activeModal?: string | null;\n enteringModal?: string | null;\n exitingModal?: string | null;\n\n history?: string[];\n isBack?: boolean | null;\n}\n\nexport interface ModalTransitionProps extends ModalTransitionState {\n onEnter: VoidFunction;\n onEntered: (id: string | null) => void;\n onExit: VoidFunction;\n onExited: (id: string | null) => void;\n getModalState: (id: string) => ModalsStateEntry;\n delayEnter: boolean;\n}\n\nfunction getModals(children: React.ReactNode | React.ReactNode[]) {\n return React.Children.toArray(children) as React.ReactElement[];\n}\n\nconst warn = warnOnce('ModalRoot');\n\nexport function modalTransitionReducer(\n state: ModalTransitionState,\n action: {\n type: 'setActive' | 'entered' | 'exited' | 'inited';\n id: string | null;\n },\n): ModalTransitionState {\n if (action.type === 'setActive' && action.id !== state.activeModal) {\n const nextModal = action.id;\n // preserve exiting modal if switching mid-transition\n const prevModal = state.exitingModal || state.activeModal;\n let history = state.history ? [...state.history] : [];\n const isBack = Boolean(nextModal && history.includes(nextModal));\n\n if (nextModal === null) {\n history = [];\n } else if (isBack) {\n history = history.splice(0, history.indexOf(nextModal) + 1);\n } else {\n history.push(nextModal);\n }\n\n return {\n activeModal: nextModal,\n // not entering yet\n enteringModal: null,\n exitingModal: prevModal,\n history,\n isBack,\n };\n }\n if (action.type === 'entered' && action.id === state.enteringModal) {\n return { ...state, enteringModal: null };\n }\n if (action.type === 'exited' && action.id === state.exitingModal) {\n return { ...state, exitingModal: null };\n }\n if (action.type === 'inited' && action.id === state.activeModal) {\n return { ...state, enteringModal: action.id };\n }\n return state;\n}\n\n/**\n * Реализует переход модалок. При смене activeModal m1 -> m2:\n * 1. activeModal: m1, exitingModal: null, enteringModal: null, триггер перехода\n * 2. activeModal: m2, exitingModal: m1, enteringModal: null, рендерим m2 чтобы прошел init, начинаем анимацию выхода\n * одновременный переход между ModalPage:\n * 3a. activeModal: m2, exitingModal: m1, enteringModal: m2\n * 4a. exitingModal и enteringModal переходят в null в порядке завершения анимации\n * ИЛИ дожидаемся скрытия ModalCard\n * 3b. activeModal: m2, exitingModal: null, enteringModal: m2\n * 4b. enteringModal переходит в null после завершения анимации\n * 5. activeModal: m2, exitingModal: null, enteringModal: null, переход закончен\n */\nexport function useModalManager(\n activeModal: string | null | undefined,\n children: React.ReactNode | React.ReactNode[],\n onOpen: (id: string) => void = noop,\n onOpened: (id: string) => void = noop,\n onClose: (id: string) => void = noop,\n onClosed: (id: string) => void = noop,\n initModal: (state: ModalsStateEntry) => void = noop,\n): ModalTransitionProps {\n const modalsState = React.useRef<ModalsState>({}).current;\n getModals(children).forEach((Modal) => {\n const modalProps = Modal.props;\n const id = getNavId(modalProps, warn);\n const state: ModalsStateEntry = (id !== undefined && modalsState[id]) || {\n id: id ?? null,\n };\n\n state.onOpen = Modal.props.onOpen;\n state.onOpened = Modal.props.onOpened;\n state.onClose = Modal.props.onClose;\n state.onClosed = Modal.props.onClosed;\n state.dynamicContentHeight = !!modalProps.dynamicContentHeight;\n // ModalPage props\n if (typeof modalProps.settlingHeight === 'number') {\n state.settlingHeight = modalProps.settlingHeight;\n }\n\n if (state.id !== null) {\n modalsState[state.id] = state;\n }\n });\n\n const isMissing = activeModal && !modalsState[activeModal];\n const safeActiveModal = isMissing ? null : activeModal;\n const [transitionState, dispatchTransition] = React.useReducer(modalTransitionReducer, {\n activeModal: safeActiveModal,\n enteringModal: null,\n exitingModal: null,\n history: safeActiveModal ? [safeActiveModal] : [],\n isBack: false,\n });\n\n // Map props to state, render activeModal for init\n useIsomorphicLayoutEffect(() => {\n // ignore non-existent activeModal\n if (process.env.NODE_ENV === 'development' && isMissing) {\n warn(`Переход невозможен - модальное окно (страница) ${activeModal} не существует`, 'error');\n }\n dispatchTransition({ type: 'setActive', id: safeActiveModal ?? null });\n }, [activeModal]);\n\n // Init activeModal & set enteringModal\n useIsomorphicLayoutEffect(() => {\n if (transitionState.activeModal) {\n initModal(modalsState[transitionState.activeModal]);\n dispatchTransition({ type: 'inited', id: transitionState.activeModal });\n }\n }, [transitionState.activeModal]);\n\n const isCard = (id: string | null | undefined) =>\n id != null && modalsState[id]?.type === ModalType.CARD;\n const onEntered = React.useCallback(\n (id: string | null) => {\n if (id) {\n const modalState = modalsState[id];\n\n if (isFunction(modalState.onOpened)) {\n modalState.onOpened();\n } else if (isFunction(onOpened)) {\n onOpened(id);\n }\n }\n\n dispatchTransition({ type: 'entered', id });\n },\n [modalsState, onOpened],\n );\n const onExited = React.useCallback(\n (id: string | null) => {\n if (id) {\n const modalState = modalsState[id];\n\n if (isFunction(modalState.onClosed)) {\n modalState.onClosed();\n } else if (isFunction(onClosed)) {\n onClosed(id);\n }\n }\n\n dispatchTransition({ type: 'exited', id });\n },\n [modalsState, onClosed],\n );\n const delayEnter = Boolean(\n transitionState.exitingModal && (isCard(activeModal) || isCard(transitionState.exitingModal)),\n );\n const getModalState = React.useCallback((id: string) => modalsState[id], [modalsState]);\n\n function onEnter() {\n const modalState = transitionState.activeModal && modalsState[transitionState.activeModal];\n if (modalState) {\n if (isFunction(modalState.onOpen)) {\n modalState.onOpen();\n } else if (isFunction(onOpen)) {\n onOpen(modalState.id);\n }\n }\n }\n\n function onExit() {\n const modalState = transitionState.activeModal && modalsState[transitionState.activeModal];\n if (modalState) {\n if (isFunction(modalState.onClose)) {\n modalState.onClose();\n } else if (isFunction(onClose)) {\n onClose(modalState.id);\n }\n }\n }\n\n return {\n onEnter,\n onEntered,\n onExit,\n onExited,\n ...transitionState,\n delayEnter,\n getModalState,\n };\n}\n\nexport function withModalManager(initModal: (a: ModalsStateEntry) => void = noop) {\n return function <Props extends ModalTransitionProps>(\n Wrapped: React.ComponentType<Props>,\n ): React.ComponentType<\n Omit<Props, keyof ModalTransitionProps> & {\n activeModal?: string | null;\n children?: React.ReactNode;\n }\n > {\n return function WithModalManager(props) {\n const transitionManager = useModalManager(\n props.activeModal,\n props.children,\n (props as any).onOpen,\n (props as any).onOpened,\n (props as any).onClose,\n (props as any).onClosed,\n initModal,\n );\n return <Wrapped {...(props as any)} {...transitionManager} />;\n };\n };\n}\n"],"names":["React","isFunction","noop","getNavId","useIsomorphicLayoutEffect","warnOnce","ModalType","getModals","children","Children","toArray","warn","modalTransitionReducer","state","action","type","id","activeModal","nextModal","prevModal","exitingModal","history","isBack","Boolean","includes","splice","indexOf","push","enteringModal","useModalManager","onOpen","onOpened","onClose","onClosed","initModal","onEnter","modalState","transitionState","modalsState","onExit","useRef","current","forEach","Modal","modalProps","props","undefined","dynamicContentHeight","settlingHeight","isMissing","safeActiveModal","useReducer","dispatchTransition","process","env","NODE_ENV","isCard","CARD","onEntered","useCallback","onExited","delayEnter","getModalState","withModalManager","Wrapped","WithModalManager","transitionManager"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../src/components/ModalRoot/useModalManager.tsx"],"sourcesContent":["import * as React from 'react';\nimport { isFunction, noop } from '@vkontakte/vkjs';\nimport { getNavId } from '../../lib/getNavId';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { HasChildren } from '../../types';\nimport { ModalsState, ModalsStateEntry, ModalType } from './types';\n\ninterface ModalTransitionState {\n activeModal?: string | null;\n enteringModal?: string | null;\n exitingModal?: string | null;\n history?: string[];\n isBack?: boolean | null;\n}\n\nexport interface ModalTransitionProps extends ModalTransitionState {\n onEnter: VoidFunction;\n onEntered: (id: string | null) => void;\n onExit: VoidFunction;\n onExited: (id: string | null) => void;\n getModalState: (id: string | undefined | null) => ModalsStateEntry | undefined;\n delayEnter: boolean;\n}\n\nfunction getModals(children: React.ReactNode | React.ReactNode[]) {\n return React.Children.toArray(children) as React.ReactElement[];\n}\n\nconst warn = warnOnce('ModalRoot');\n\nexport function modalTransitionReducer(\n state: ModalTransitionState,\n action: {\n type: 'setActive' | 'entered' | 'exited' | 'inited';\n id: string | null;\n },\n): ModalTransitionState {\n if (action.type === 'setActive' && action.id !== state.activeModal) {\n const nextModal = action.id;\n // preserve exiting modal if switching mid-transition\n const prevModal = state.exitingModal || state.activeModal;\n let history = state.history ? [...state.history] : [];\n const isBack = Boolean(nextModal && history.includes(nextModal));\n\n if (nextModal === null) {\n history = [];\n } else if (isBack) {\n history = history.splice(0, history.indexOf(nextModal) + 1);\n } else {\n history.push(nextModal);\n }\n\n return {\n activeModal: nextModal,\n // not entering yet\n enteringModal: null,\n exitingModal: prevModal,\n history,\n isBack,\n };\n }\n if (action.type === 'entered' && action.id === state.enteringModal) {\n return { ...state, enteringModal: null };\n }\n if (action.type === 'exited' && action.id === state.exitingModal) {\n return { ...state, exitingModal: null };\n }\n if (action.type === 'inited' && action.id === state.activeModal) {\n return { ...state, enteringModal: action.id };\n }\n return state;\n}\n\n/**\n * Реализует переход модалок. При смене activeModal m1 -> m2:\n * 1. activeModal: m1, exitingModal: null, enteringModal: null, триггер перехода\n * 2. activeModal: m2, exitingModal: m1, enteringModal: null, рендерим m2 чтобы прошел init, начинаем анимацию выхода\n * одновременный переход между ModalPage:\n * 3a. activeModal: m2, exitingModal: m1, enteringModal: m2\n * 4a. exitingModal и enteringModal переходят в null в порядке завершения анимации\n * ИЛИ дожидаемся скрытия ModalCard\n * 3b. activeModal: m2, exitingModal: null, enteringModal: m2\n * 4b. enteringModal переходит в null после завершения анимации\n * 5. activeModal: m2, exitingModal: null, enteringModal: null, переход закончен\n */\nexport function useModalManager(\n activeModal: string | null | undefined,\n children: React.ReactNode | React.ReactNode[],\n onOpen: (id: string) => void = noop,\n onOpened: (id: string) => void = noop,\n onClose: (id: string) => void = noop,\n onClosed: (id: string) => void = noop,\n initModal: (state: ModalsStateEntry) => void = noop,\n): ModalTransitionProps {\n const modalsState = React.useRef<ModalsState>({}).current;\n getModals(children).forEach((Modal) => {\n const modalProps = Modal.props;\n const id = getNavId(modalProps, warn);\n const state: ModalsStateEntry = (id !== undefined && modalsState[id]) || {\n id: id ?? null,\n };\n\n state.onOpen = Modal.props.onOpen;\n state.onOpened = Modal.props.onOpened;\n state.onClose = Modal.props.onClose;\n state.onClosed = Modal.props.onClosed;\n state.dynamicContentHeight = !!modalProps.dynamicContentHeight;\n // ModalPage props\n if (typeof modalProps.settlingHeight === 'number') {\n state.settlingHeight = modalProps.settlingHeight;\n }\n\n if (state.id !== null) {\n modalsState[state.id] = state;\n }\n });\n\n const isMissing = activeModal && !modalsState[activeModal];\n const safeActiveModal = isMissing ? null : activeModal;\n const [transitionState, dispatchTransition] = React.useReducer(modalTransitionReducer, {\n activeModal: safeActiveModal,\n enteringModal: null,\n exitingModal: null,\n history: safeActiveModal ? [safeActiveModal] : [],\n isBack: false,\n });\n\n // Map props to state, render activeModal for init\n useIsomorphicLayoutEffect(() => {\n // ignore non-existent activeModal\n if (process.env.NODE_ENV === 'development' && isMissing) {\n warn(`Переход невозможен - модальное окно (страница) ${activeModal} не существует`, 'error');\n }\n dispatchTransition({ type: 'setActive', id: safeActiveModal ?? null });\n }, [activeModal]);\n\n // Init activeModal & set enteringModal\n useIsomorphicLayoutEffect(() => {\n if (transitionState.activeModal) {\n initModal(modalsState[transitionState.activeModal]);\n dispatchTransition({ type: 'inited', id: transitionState.activeModal });\n }\n }, [transitionState.activeModal]);\n\n const isCard = (id: string | null | undefined) =>\n id != null && modalsState[id]?.type === ModalType.CARD;\n const onEntered = React.useCallback(\n (id: string | null) => {\n if (id) {\n const modalState = modalsState[id];\n\n if (isFunction(modalState.onOpened)) {\n modalState.onOpened();\n } else if (isFunction(onOpened)) {\n onOpened(id);\n }\n }\n\n dispatchTransition({ type: 'entered', id });\n },\n [modalsState, onOpened],\n );\n const onExited = React.useCallback(\n (id: string | null) => {\n if (id) {\n const modalState = modalsState[id];\n\n if (isFunction(modalState.onClosed)) {\n modalState.onClosed();\n } else if (isFunction(onClosed)) {\n onClosed(id);\n }\n }\n\n dispatchTransition({ type: 'exited', id });\n },\n [modalsState, onClosed],\n );\n const delayEnter = Boolean(\n transitionState.exitingModal && (isCard(activeModal) || isCard(transitionState.exitingModal)),\n );\n const getModalState = React.useCallback(\n (id: string | undefined | null) => (id ? modalsState[id] : undefined),\n [modalsState],\n );\n\n function onEnter() {\n const modalState = transitionState.activeModal && modalsState[transitionState.activeModal];\n if (modalState) {\n if (isFunction(modalState.onOpen)) {\n modalState.onOpen();\n } else if (isFunction(onOpen) && modalState.id) {\n onOpen(modalState.id);\n }\n }\n }\n\n function onExit() {\n const modalState = transitionState.activeModal && modalsState[transitionState.activeModal];\n if (modalState) {\n if (isFunction(modalState.onClose)) {\n modalState.onClose();\n } else if (isFunction(onClose) && modalState.id) {\n onClose(modalState.id);\n }\n }\n }\n\n return {\n onEnter,\n onEntered,\n onExit,\n onExited,\n ...transitionState,\n delayEnter,\n getModalState,\n };\n}\n\ntype WithModalManager<Props extends ModalTransitionProps> = HasChildren &\n Omit<Props, keyof ModalTransitionProps> & {\n activeModal?: string | null;\n };\n\nexport function withModalManager(initModal: (a: ModalsStateEntry) => void = noop) {\n return function <Props extends ModalTransitionProps>(\n Wrapped: React.ComponentType<Props>,\n ): React.ComponentType<WithModalManager<Props>> {\n return function WithModalManager(props) {\n const transitionManager = useModalManager(\n props.activeModal,\n props.children,\n (props as any).onOpen,\n (props as any).onOpened,\n (props as any).onClose,\n (props as any).onClosed,\n initModal,\n );\n return <Wrapped {...(props as any)} {...transitionManager} />;\n };\n };\n}\n"],"names":["React","isFunction","noop","getNavId","useIsomorphicLayoutEffect","warnOnce","ModalType","getModals","children","Children","toArray","warn","modalTransitionReducer","state","action","type","id","activeModal","nextModal","prevModal","exitingModal","history","isBack","Boolean","includes","splice","indexOf","push","enteringModal","useModalManager","onOpen","onOpened","onClose","onClosed","initModal","onEnter","modalState","transitionState","modalsState","onExit","useRef","current","forEach","Modal","modalProps","props","undefined","dynamicContentHeight","settlingHeight","isMissing","safeActiveModal","useReducer","dispatchTransition","process","env","NODE_ENV","isCard","CARD","onEntered","useCallback","onExited","delayEnter","getModalState","withModalManager","Wrapped","WithModalManager","transitionManager"],"mappings":"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"}
@@ -2,10 +2,14 @@ import * as React from 'react';
2
2
  import { HasAlign, HasRef, HasRootRef } from '../../types';
3
3
  import { FormFieldProps } from '../FormField/FormField';
4
4
  import type { SelectType } from '../Select/Select';
5
- export interface NativeSelectProps extends React.SelectHTMLAttributes<HTMLSelectElement>, HasRef<HTMLSelectElement>, HasRootRef<HTMLLabelElement>, HasAlign, Pick<FormFieldProps, 'status'> {
5
+ export interface NativeSelectProps extends React.SelectHTMLAttributes<HTMLSelectElement>, HasRef<HTMLSelectElement>, HasRootRef<HTMLLabelElement>, HasAlign, Pick<FormFieldProps, 'before' | 'status'> {
6
6
  placeholder?: string;
7
7
  multiline?: boolean;
8
8
  selectType?: SelectType;
9
+ /**
10
+ * Иконка раскрывающегося списка
11
+ */
12
+ icon?: React.ReactNode;
9
13
  }
10
14
  export interface SelectState {
11
15
  value?: React.SelectHTMLAttributes<HTMLSelectElement>['value'];
@@ -15,5 +19,5 @@ export interface SelectState {
15
19
  /**
16
20
  * @see https://vkcom.github.io/VKUI/#/NativeSelect
17
21
  */
18
- declare const NativeSelect: ({ style, defaultValue, align, placeholder, children, className, getRef, getRootRef, disabled, multiline, selectType, status, onChange: onChangeProp, value: valueProp, ...restProps }: NativeSelectProps) => JSX.Element;
22
+ declare const NativeSelect: ({ style, defaultValue, align, placeholder, children, className, getRef, getRootRef, disabled, multiline, selectType, status, icon, before, onChange: onChangeProp, value: valueProp, ...restProps }: NativeSelectProps) => JSX.Element;
19
23
  export { NativeSelect };
@@ -19,7 +19,7 @@ var sizeYClassNames = _define_property({
19
19
  /**
20
20
  * @see https://vkcom.github.io/VKUI/#/NativeSelect
21
21
  */ var NativeSelect = function(_param) {
22
- var style = _param.style, _param_defaultValue = _param.defaultValue, defaultValue = _param_defaultValue === void 0 ? "" : _param_defaultValue, align = _param.align, placeholder = _param.placeholder, children = _param.children, className = _param.className, getRef = _param.getRef, getRootRef = _param.getRootRef, disabled = _param.disabled, multiline = _param.multiline, _param_selectType = _param.selectType, selectType = _param_selectType === void 0 ? "default" : _param_selectType, status = _param.status, onChangeProp = _param.onChange, valueProp = _param.value, restProps = _object_without_properties(_param, [
22
+ var style = _param.style, _param_defaultValue = _param.defaultValue, defaultValue = _param_defaultValue === void 0 ? "" : _param_defaultValue, align = _param.align, placeholder = _param.placeholder, children = _param.children, className = _param.className, getRef = _param.getRef, getRootRef = _param.getRootRef, disabled = _param.disabled, multiline = _param.multiline, _param_selectType = _param.selectType, selectType = _param_selectType === void 0 ? "default" : _param_selectType, status = _param.status, _param_icon = _param.icon, icon = _param_icon === void 0 ? /*#__PURE__*/ React.createElement(DropdownIcon, null) : _param_icon, before = _param.before, onChangeProp = _param.onChange, valueProp = _param.value, restProps = _object_without_properties(_param, [
23
23
  "style",
24
24
  "defaultValue",
25
25
  "align",
@@ -32,6 +32,8 @@ var sizeYClassNames = _define_property({
32
32
  "multiline",
33
33
  "selectType",
34
34
  "status",
35
+ "icon",
36
+ "before",
35
37
  "onChange",
36
38
  "value"
37
39
  ]);
@@ -58,11 +60,12 @@ var sizeYClassNames = _define_property({
58
60
  ]);
59
61
  return /*#__PURE__*/ React.createElement(FormField, {
60
62
  Component: "label",
61
- className: classNames("vkuiSelect", "vkuiInternalNativeSelect", empty && "vkuiSelect--empty", multiline && "vkuiSelect--multiline", (placeholder === null || placeholder === void 0 ? void 0 : placeholder.length) && "vkuiSelect--hasPlaceholder", align === "center" && "vkuiSelect--align-center", align === "right" && "vkuiSelect--align-right", sizeY !== SizeType.REGULAR && sizeYClassNames[sizeY], className),
63
+ className: classNames("vkuiSelect", "vkuiInternalNativeSelect", before && "vkuiSelect--hasBefore", empty && "vkuiSelect--empty", multiline && "vkuiSelect--multiline", align === "center" && "vkuiSelect--align-center", align === "right" && "vkuiSelect--align-right", sizeY !== SizeType.REGULAR && sizeYClassNames[sizeY], className),
62
64
  style: style,
63
65
  getRootRef: getRootRef,
64
66
  disabled: disabled,
65
- after: /*#__PURE__*/ React.createElement(DropdownIcon, null),
67
+ before: before,
68
+ after: icon,
66
69
  status: status
67
70
  }, /*#__PURE__*/ React.createElement("select", _object_spread_props(_object_spread({}, restProps), {
68
71
  disabled: disabled,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/NativeSelect/NativeSelect.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useEnsuredControl } from '../../hooks/useEnsuredControl';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { SizeType } from '../../lib/adaptivity';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { HasAlign, HasRef, HasRootRef } from '../../types';\nimport { DropdownIcon } from '../DropdownIcon/DropdownIcon';\nimport { FormField, FormFieldProps } from '../FormField/FormField';\nimport type { SelectType } from '../Select/Select';\nimport { SelectTypography } from '../SelectTypography/SelectTypography';\nimport styles from '../Select/Select.module.css';\n\nconst sizeYClassNames = {\n none: styles['Select--sizeY-none'],\n [SizeType.COMPACT]: styles['Select--sizeY-compact'],\n};\n\nexport interface NativeSelectProps\n extends React.SelectHTMLAttributes<HTMLSelectElement>,\n HasRef<HTMLSelectElement>,\n HasRootRef<HTMLLabelElement>,\n HasAlign,\n Pick<FormFieldProps, 'status'> {\n placeholder?: string;\n multiline?: boolean;\n selectType?: SelectType;\n}\n\nexport interface SelectState {\n value?: React.SelectHTMLAttributes<HTMLSelectElement>['value'];\n title?: string;\n notSelected?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/NativeSelect\n */\nconst NativeSelect = ({\n style,\n defaultValue = '',\n align,\n placeholder,\n children,\n className,\n getRef,\n getRootRef,\n disabled,\n multiline,\n selectType = 'default',\n status,\n onChange: onChangeProp,\n value: valueProp,\n ...restProps\n}: NativeSelectProps) => {\n const [title, setTitle] = React.useState('');\n const [empty, setEmpty] = React.useState(false);\n const [value, onChange] = useEnsuredControl({\n defaultValue,\n disabled,\n onChange: onChangeProp,\n value: valueProp,\n });\n const selectRef = useExternRef(getRef);\n const { sizeY = 'none' } = useAdaptivity();\n\n useIsomorphicLayoutEffect(() => {\n const selectedOption = selectRef.current?.options[selectRef.current.selectedIndex];\n if (selectedOption) {\n setTitle(selectedOption.text);\n setEmpty(selectedOption.value === '' && placeholder != null);\n }\n }, [value, children]);\n\n return (\n <FormField\n Component=\"label\"\n className={classNames(\n styles['Select'],\n 'vkuiInternalNativeSelect',\n empty && styles['Select--empty'],\n multiline && styles['Select--multiline'],\n placeholder?.length && styles['Select--hasPlaceholder'],\n align === 'center' && styles['Select--align-center'],\n align === 'right' && styles['Select--align-right'],\n sizeY !== SizeType.REGULAR && sizeYClassNames[sizeY],\n className,\n )}\n style={style}\n getRootRef={getRootRef}\n disabled={disabled}\n after={<DropdownIcon />}\n status={status}\n >\n <select\n {...restProps}\n disabled={disabled}\n className={styles['Select__el']}\n onChange={onChange}\n value={value}\n ref={selectRef}\n >\n {placeholder && <option value=\"\">{placeholder}</option>}\n {children}\n </select>\n <div className={styles['Select__container']}>\n <SelectTypography className={styles['Select__title']} selectType={selectType}>\n {title}\n </SelectTypography>\n </div>\n </FormField>\n );\n};\n\nexport { NativeSelect };\n"],"names":["React","classNames","useAdaptivity","useEnsuredControl","useExternRef","SizeType","useIsomorphicLayoutEffect","DropdownIcon","FormField","SelectTypography","sizeYClassNames","none","COMPACT","NativeSelect","style","defaultValue","align","placeholder","children","className","getRef","getRootRef","disabled","multiline","selectType","status","onChange","onChangeProp","value","valueProp","restProps","useState","title","setTitle","empty","setEmpty","selectRef","sizeY","selectedOption","current","options","selectedIndex","text","Component","length","REGULAR","after","select","ref","option","div"],"mappings":";;;;;AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,aAAa,QAAQ,4BAA4B;AAC1D,SAASC,iBAAiB,QAAQ,gCAAgC;AAClE,SAASC,YAAY,QAAQ,2BAA2B;AACxD,SAASC,QAAQ,QAAQ,uBAAuB;AAChD,SAASC,yBAAyB,QAAQ,sCAAsC;AAEhF,SAASC,YAAY,QAAQ,+BAA+B;AAC5D,SAASC,SAAS,QAAwB,yBAAyB;AAEnE,SAASC,gBAAgB,QAAQ,uCAAuC;AAGxE,IAAMC;IACJC,IAAI;GACHN,SAASO,OAAO;AAoBnB;;CAEC,GACD,IAAMC,eAAe,iBAgBI;QAfvBC,eAAAA,oCACAC,cAAAA,gDAAe,0BACfC,eAAAA,OACAC,qBAAAA,aACAC,kBAAAA,UACAC,mBAAAA,WACAC,gBAAAA,QACAC,oBAAAA,YACAC,kBAAAA,UACAC,mBAAAA,sCACAC,YAAAA,4CAAa,+BACbC,gBAAAA,QACAC,AAAUC,sBAAVD,UACAE,AAAOC,mBAAPD,OACGE;QAdHhB;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAE;;IAGA,IAA0B5B,mCAAAA,MAAM+B,QAAQ,CAAC,SAAlCC,QAAmBhC,oBAAZiC,WAAYjC;IAC1B,IAA0BA,oCAAAA,MAAM+B,QAAQ,CAAC,KAAK,OAAvCG,QAAmBlC,qBAAZmC,WAAYnC;IAC1B,IAA0BG,sCAAAA,kBAAkB;QAC1CY,cAAAA;QACAO,UAAAA;QACAI,UAAUC;QACVC,OAAOC;IACT,QALOD,QAAmBzB,uBAAZuB,WAAYvB;IAM1B,IAAMiC,YAAYhC,aAAagB;IAC/B,IAA2BlB,iBAAAA,wCAAAA,eAAnBmC,OAAAA,0CAAQ;IAEhB/B,0BAA0B,WAAM;YACP8B;QAAvB,IAAME,iBAAiBF,CAAAA,qBAAAA,UAAUG,OAAO,cAAjBH,gCAAAA,KAAAA,IAAAA,mBAAmBI,OAAO,CAACJ,UAAUG,OAAO,CAACE,aAAa,CAAC;QAClF,IAAIH,gBAAgB;YAClBL,SAASK,eAAeI,IAAI;YAC5BP,SAASG,eAAeV,KAAK,KAAK,MAAMX,eAAe,IAAI;QAC7D,CAAC;IACH,GAAG;QAACW;QAAOV;KAAS;IAEpB,qBACE,oBAACV;QACCmC,WAAU;QACVxB,WAAWlB,yBAET,4BACAiC,8BACAX,sCACAN,CAAAA,wBAAAA,yBAAAA,KAAAA,IAAAA,YAAa2B,MAAM,AAAD,mCAClB5B,UAAU,wCACVA,UAAU,sCACVqB,UAAUhC,SAASwC,OAAO,IAAInC,eAAe,CAAC2B,MAAM,EACpDlB;QAEFL,OAAOA;QACPO,YAAYA;QACZC,UAAUA;QACVwB,qBAAO,oBAACvC;QACRkB,QAAQA;qBAER,oBAACsB,kDACKjB;QACJR,UAAUA;QACVH,SAAS;QACTO,UAAUA;QACVE,OAAOA;QACPoB,KAAKZ;QAEJnB,6BAAe,oBAACgC;QAAOrB,OAAM;OAAIX,cACjCC,yBAEH,oBAACgC;QAAI/B,SAAS;qBACZ,oBAACV;QAAiBU,SAAS;QAA2BK,YAAYA;OAC/DQ;AAKX;AAEA,SAASnB,YAAY,GAAG"}
1
+ {"version":3,"sources":["../../../src/components/NativeSelect/NativeSelect.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useEnsuredControl } from '../../hooks/useEnsuredControl';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { SizeType } from '../../lib/adaptivity';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { HasAlign, HasRef, HasRootRef } from '../../types';\nimport { DropdownIcon } from '../DropdownIcon/DropdownIcon';\nimport { FormField, FormFieldProps } from '../FormField/FormField';\nimport type { SelectType } from '../Select/Select';\nimport { SelectTypography } from '../SelectTypography/SelectTypography';\nimport styles from '../Select/Select.module.css';\n\nconst sizeYClassNames = {\n none: styles['Select--sizeY-none'],\n [SizeType.COMPACT]: styles['Select--sizeY-compact'],\n};\n\nexport interface NativeSelectProps\n extends React.SelectHTMLAttributes<HTMLSelectElement>,\n HasRef<HTMLSelectElement>,\n HasRootRef<HTMLLabelElement>,\n HasAlign,\n Pick<FormFieldProps, 'before' | 'status'> {\n placeholder?: string;\n multiline?: boolean;\n selectType?: SelectType;\n /**\n * Иконка раскрывающегося списка\n */\n icon?: React.ReactNode;\n}\n\nexport interface SelectState {\n value?: React.SelectHTMLAttributes<HTMLSelectElement>['value'];\n title?: string;\n notSelected?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/NativeSelect\n */\nconst NativeSelect = ({\n style,\n defaultValue = '',\n align,\n placeholder,\n children,\n className,\n getRef,\n getRootRef,\n disabled,\n multiline,\n selectType = 'default',\n status,\n icon = <DropdownIcon />,\n before,\n onChange: onChangeProp,\n value: valueProp,\n ...restProps\n}: NativeSelectProps) => {\n const [title, setTitle] = React.useState('');\n const [empty, setEmpty] = React.useState(false);\n const [value, onChange] = useEnsuredControl({\n defaultValue,\n disabled,\n onChange: onChangeProp,\n value: valueProp,\n });\n const selectRef = useExternRef(getRef);\n const { sizeY = 'none' } = useAdaptivity();\n\n useIsomorphicLayoutEffect(() => {\n const selectedOption = selectRef.current?.options[selectRef.current.selectedIndex];\n if (selectedOption) {\n setTitle(selectedOption.text);\n setEmpty(selectedOption.value === '' && placeholder != null);\n }\n }, [value, children]);\n\n return (\n <FormField\n Component=\"label\"\n className={classNames(\n styles['Select'],\n 'vkuiInternalNativeSelect',\n before && styles['Select--hasBefore'],\n empty && styles['Select--empty'],\n multiline && styles['Select--multiline'],\n align === 'center' && styles['Select--align-center'],\n align === 'right' && styles['Select--align-right'],\n sizeY !== SizeType.REGULAR && sizeYClassNames[sizeY],\n className,\n )}\n style={style}\n getRootRef={getRootRef}\n disabled={disabled}\n before={before}\n after={icon}\n status={status}\n >\n <select\n {...restProps}\n disabled={disabled}\n className={styles['Select__el']}\n onChange={onChange}\n value={value}\n ref={selectRef}\n >\n {placeholder && <option value=\"\">{placeholder}</option>}\n {children}\n </select>\n <div className={styles['Select__container']}>\n <SelectTypography className={styles['Select__title']} selectType={selectType}>\n {title}\n </SelectTypography>\n </div>\n </FormField>\n );\n};\n\nexport { NativeSelect };\n"],"names":["React","classNames","useAdaptivity","useEnsuredControl","useExternRef","SizeType","useIsomorphicLayoutEffect","DropdownIcon","FormField","SelectTypography","sizeYClassNames","none","COMPACT","NativeSelect","style","defaultValue","align","placeholder","children","className","getRef","getRootRef","disabled","multiline","selectType","status","icon","before","onChange","onChangeProp","value","valueProp","restProps","useState","title","setTitle","empty","setEmpty","selectRef","sizeY","selectedOption","current","options","selectedIndex","text","Component","REGULAR","after","select","ref","option","div"],"mappings":";;;;;AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,aAAa,QAAQ,4BAA4B;AAC1D,SAASC,iBAAiB,QAAQ,gCAAgC;AAClE,SAASC,YAAY,QAAQ,2BAA2B;AACxD,SAASC,QAAQ,QAAQ,uBAAuB;AAChD,SAASC,yBAAyB,QAAQ,sCAAsC;AAEhF,SAASC,YAAY,QAAQ,+BAA+B;AAC5D,SAASC,SAAS,QAAwB,yBAAyB;AAEnE,SAASC,gBAAgB,QAAQ,uCAAuC;AAGxE,IAAMC;IACJC,IAAI;GACHN,SAASO,OAAO;AAwBnB;;CAEC,GACD,IAAMC,eAAe,iBAkBI;QAjBvBC,eAAAA,oCACAC,cAAAA,gDAAe,0BACfC,eAAAA,OACAC,qBAAAA,aACAC,kBAAAA,UACAC,mBAAAA,WACAC,gBAAAA,QACAC,oBAAAA,YACAC,kBAAAA,UACAC,mBAAAA,sCACAC,YAAAA,4CAAa,+BACbC,gBAAAA,6BACAC,MAAAA,8CAAO,oBAACnB,mCACRoB,gBAAAA,QACAC,AAAUC,sBAAVD,UACAE,AAAOC,mBAAPD,OACGE;QAhBHlB;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAE;;IAGA,IAA0B9B,mCAAAA,MAAMiC,QAAQ,CAAC,SAAlCC,QAAmBlC,oBAAZmC,WAAYnC;IAC1B,IAA0BA,oCAAAA,MAAMiC,QAAQ,CAAC,KAAK,OAAvCG,QAAmBpC,qBAAZqC,WAAYrC;IAC1B,IAA0BG,sCAAAA,kBAAkB;QAC1CY,cAAAA;QACAO,UAAAA;QACAM,UAAUC;QACVC,OAAOC;IACT,QALOD,QAAmB3B,uBAAZyB,WAAYzB;IAM1B,IAAMmC,YAAYlC,aAAagB;IAC/B,IAA2BlB,iBAAAA,wCAAAA,eAAnBqC,OAAAA,0CAAQ;IAEhBjC,0BAA0B,WAAM;YACPgC;QAAvB,IAAME,iBAAiBF,CAAAA,qBAAAA,UAAUG,OAAO,cAAjBH,gCAAAA,KAAAA,IAAAA,mBAAmBI,OAAO,CAACJ,UAAUG,OAAO,CAACE,aAAa,CAAC;QAClF,IAAIH,gBAAgB;YAClBL,SAASK,eAAeI,IAAI;YAC5BP,SAASG,eAAeV,KAAK,KAAK,MAAMb,eAAe,IAAI;QAC7D,CAAC;IACH,GAAG;QAACa;QAAOZ;KAAS;IAEpB,qBACE,oBAACV;QACCqC,WAAU;QACV1B,WAAWlB,yBAET,4BACA0B,mCACAS,8BACAb,sCACAP,UAAU,wCACVA,UAAU,sCACVuB,UAAUlC,SAASyC,OAAO,IAAIpC,eAAe,CAAC6B,MAAM,EACpDpB;QAEFL,OAAOA;QACPO,YAAYA;QACZC,UAAUA;QACVK,QAAQA;QACRoB,OAAOrB;QACPD,QAAQA;qBAER,oBAACuB,kDACKhB;QACJV,UAAUA;QACVH,SAAS;QACTS,UAAUA;QACVE,OAAOA;QACPmB,KAAKX;QAEJrB,6BAAe,oBAACiC;QAAOpB,OAAM;OAAIb,cACjCC,yBAEH,oBAACiC;QAAIhC,SAAS;qBACZ,oBAACV;QAAiBU,SAAS;QAA2BK,YAAYA;OAC/DU;AAKX;AAEA,SAASrB,YAAY,GAAG"}
@@ -28,10 +28,10 @@ var sizeXClassNames = (_obj = {
28
28
  var _useAdaptivity = useAdaptivity(), _useAdaptivity_sizeX = _useAdaptivity.sizeX, sizeX = _useAdaptivity_sizeX === void 0 ? "none" : _useAdaptivity_sizeX;
29
29
  return /*#__PURE__*/ React.createElement("div", _object_spread_props(_object_spread({}, restProps), {
30
30
  ref: getRootRef,
31
- className: classNames("vkuiPanel", sizeXClassNames[sizeX], centered && "vkuiPanel--centered", className)
31
+ className: classNames("vkuiPanel", sizeXClassNames[sizeX], centered && "vkuiInternalPanel--centered", className)
32
32
  }), /*#__PURE__*/ React.createElement(Touch, {
33
33
  Component: TooltipContainer,
34
- className: "vkuiPanel__in"
34
+ className: classNames("vkuiPanel__in", "vkuiInternalPanel__in")
35
35
  }, platform === Platform.IOS && /*#__PURE__*/ React.createElement("div", {
36
36
  className: "vkuiInternalPanel__fade"
37
37
  }), /*#__PURE__*/ React.createElement("div", {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/Panel/Panel.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { SizeType } from '../../lib/adaptivity';\nimport { NavIdProps } from '../../lib/getNavId';\nimport { Platform } from '../../lib/platform';\nimport { HasRootRef } from '../../types';\nimport { TooltipContainer } from '../Tooltip/TooltipContainer';\nimport { Touch } from '../Touch/Touch';\nimport styles from './Panel.module.css';\n\nconst sizeXClassNames = {\n none: styles['Panel--sizeX-none'],\n [SizeType.COMPACT]: styles['Panel--sizeX-compact'],\n [SizeType.REGULAR]: styles['Panel--sizeX-regular'],\n};\n\nexport interface PanelProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement>,\n NavIdProps {\n centered?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/Panel\n */\nexport const Panel = ({\n centered = false,\n children,\n getRootRef,\n nav,\n className,\n ...restProps\n}: PanelProps) => {\n const platform = usePlatform();\n const { sizeX = 'none' } = useAdaptivity();\n\n return (\n <div\n {...restProps}\n ref={getRootRef}\n className={classNames(\n styles['Panel'],\n sizeXClassNames[sizeX],\n centered && styles['Panel--centered'],\n className,\n )}\n >\n <Touch Component={TooltipContainer} className={styles['Panel__in']}>\n {platform === Platform.IOS && <div className=\"vkuiInternalPanel__fade\" />}\n <div className={styles['Panel__in-before']} />\n {centered ? <div className={styles['Panel__centered']}>{children}</div> : children}\n <div className={styles['Panel__in-after']} />\n </Touch>\n </div>\n );\n};\n"],"names":["React","classNames","useAdaptivity","usePlatform","SizeType","Platform","TooltipContainer","Touch","sizeXClassNames","none","COMPACT","REGULAR","Panel","centered","children","getRootRef","nav","className","restProps","platform","sizeX","div","ref","Component","IOS"],"mappings":";;;;AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,aAAa,QAAQ,4BAA4B;AAC1D,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,QAAQ,QAAQ,uBAAuB;AAEhD,SAASC,QAAQ,QAAQ,qBAAqB;AAE9C,SAASC,gBAAgB,QAAQ,8BAA8B;AAC/D,SAASC,KAAK,QAAQ,iBAAiB;IAGf;AAAxB,IAAMC,mBAAkB;IACtBC,IAAI;oBADkB,MAErBL,SAASM,OAAO,gDAFK,MAGrBN,SAASO,OAAO,+BAHK;AAaxB;;CAEC,GACD,OAAO,IAAMC,QAAQ,iBAOH;iCANhBC,UAAAA,wCAAW,KAAK,oBAChBC,kBAAAA,UACAC,oBAAAA,YACAC,aAAAA,KACAC,mBAAAA,WACGC;QALHL;QACAC;QACAC;QACAC;QACAC;;IAGA,IAAME,WAAWhB;IACjB,IAA2BD,iBAAAA,wCAAAA,eAAnBkB,OAAAA,0CAAQ;IAEhB,qBACE,oBAACC,+CACKH;QACJI,KAAKP;QACLE,WAAWhB,wBAETO,eAAe,CAACY,MAAM,EACtBP,mCACAI;sBAGF,oBAACV;QAAMgB,WAAWjB;QAAkBW,SAAS;OAC1CE,aAAad,SAASmB,GAAG,kBAAI,oBAACH;QAAIJ,WAAU;sBAC7C,oBAACI;QAAIJ,SAAS;QACbJ,yBAAW,oBAACQ;QAAIJ,SAAS;OAA8BH,YAAkBA,QAAQ,gBAClF,oBAACO;QAAIJ,SAAS;;AAItB,EAAE"}
1
+ {"version":3,"sources":["../../../src/components/Panel/Panel.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { SizeType } from '../../lib/adaptivity';\nimport { NavIdProps } from '../../lib/getNavId';\nimport { Platform } from '../../lib/platform';\nimport { HasRootRef } from '../../types';\nimport { TooltipContainer } from '../Tooltip/TooltipContainer';\nimport { Touch } from '../Touch/Touch';\nimport styles from './Panel.module.css';\n\nconst sizeXClassNames = {\n none: styles['Panel--sizeX-none'],\n [SizeType.COMPACT]: styles['Panel--sizeX-compact'],\n [SizeType.REGULAR]: styles['Panel--sizeX-regular'],\n};\n\nexport interface PanelProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement>,\n NavIdProps {\n centered?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/Panel\n */\nexport const Panel = ({\n centered = false,\n children,\n getRootRef,\n nav,\n className,\n ...restProps\n}: PanelProps) => {\n const platform = usePlatform();\n const { sizeX = 'none' } = useAdaptivity();\n\n return (\n <div\n {...restProps}\n ref={getRootRef}\n className={classNames(\n styles['Panel'],\n sizeXClassNames[sizeX],\n centered && 'vkuiInternalPanel--centered',\n className,\n )}\n >\n <Touch\n Component={TooltipContainer}\n className={classNames(styles['Panel__in'], 'vkuiInternalPanel__in')}\n >\n {platform === Platform.IOS && <div className=\"vkuiInternalPanel__fade\" />}\n <div className={styles['Panel__in-before']} />\n {centered ? <div className={styles['Panel__centered']}>{children}</div> : children}\n <div className={styles['Panel__in-after']} />\n </Touch>\n </div>\n );\n};\n"],"names":["React","classNames","useAdaptivity","usePlatform","SizeType","Platform","TooltipContainer","Touch","sizeXClassNames","none","COMPACT","REGULAR","Panel","centered","children","getRootRef","nav","className","restProps","platform","sizeX","div","ref","Component","IOS"],"mappings":";;;;AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,aAAa,QAAQ,4BAA4B;AAC1D,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,QAAQ,QAAQ,uBAAuB;AAEhD,SAASC,QAAQ,QAAQ,qBAAqB;AAE9C,SAASC,gBAAgB,QAAQ,8BAA8B;AAC/D,SAASC,KAAK,QAAQ,iBAAiB;IAGf;AAAxB,IAAMC,mBAAkB;IACtBC,IAAI;oBADkB,MAErBL,SAASM,OAAO,gDAFK,MAGrBN,SAASO,OAAO,+BAHK;AAaxB;;CAEC,GACD,OAAO,IAAMC,QAAQ,iBAOH;iCANhBC,UAAAA,wCAAW,KAAK,oBAChBC,kBAAAA,UACAC,oBAAAA,YACAC,aAAAA,KACAC,mBAAAA,WACGC;QALHL;QACAC;QACAC;QACAC;QACAC;;IAGA,IAAME,WAAWhB;IACjB,IAA2BD,iBAAAA,wCAAAA,eAAnBkB,OAAAA,0CAAQ;IAEhB,qBACE,oBAACC,+CACKH;QACJI,KAAKP;QACLE,WAAWhB,wBAETO,eAAe,CAACY,MAAM,EACtBP,YAAY,+BACZI;sBAGF,oBAACV;QACCgB,WAAWjB;QACXW,WAAWhB,4BAAgC;OAE1CkB,aAAad,SAASmB,GAAG,kBAAI,oBAACH;QAAIJ,WAAU;sBAC7C,oBAACI;QAAIJ,SAAS;QACbJ,yBAAW,oBAACQ;QAAIJ,SAAS;OAA8BH,YAAkBA,QAAQ,gBAClF,oBAACO;QAAIJ,SAAS;;AAItB,EAAE"}
@@ -1,5 +1,5 @@
1
1
  import * as React from 'react';
2
- import { HasRef, HasRootRef } from '../../types';
2
+ import { HasComponent, HasRef, HasRootRef } from '../../types';
3
3
  export interface PanelHeaderProps extends React.HTMLAttributes<HTMLDivElement>, HasRef<HTMLDivElement>, HasRootRef<HTMLDivElement> {
4
4
  before?: React.ReactNode;
5
5
  after?: React.ReactNode;
@@ -15,7 +15,16 @@ export interface PanelHeaderProps extends React.HTMLAttributes<HTMLDivElement>,
15
15
  */
16
16
  fixed?: boolean;
17
17
  }
18
+ interface PanelHeaderContentProps extends React.HTMLAttributes<HTMLElement>, HasComponent {
19
+ }
18
20
  /**
19
21
  * @see https://vkcom.github.io/VKUI/#/PanelHeader
20
22
  */
21
- export declare const PanelHeader: ({ before, children, after, separator, visor, transparent, shadow, getRef, getRootRef, fixed, className, ...restProps }: PanelHeaderProps) => JSX.Element;
23
+ export declare const PanelHeader: {
24
+ ({ before, children, after, separator, visor, transparent, shadow, getRef, getRootRef, fixed, className, ...restProps }: PanelHeaderProps): JSX.Element;
25
+ Content: {
26
+ ({ children, Component, id }: PanelHeaderContentProps): JSX.Element;
27
+ displayName: string;
28
+ };
29
+ };
30
+ export {};
@@ -17,13 +17,26 @@ import { TooltipContainer } from "../Tooltip/TooltipContainer";
17
17
  import { Text } from "../Typography/Text/Text";
18
18
  var platformClassNames = {
19
19
  ios: classNames("vkuiPanelHeader--ios", "vkuiInternalPanelHeader--ios"),
20
- android: "vkuiPanelHeader--android",
20
+ android: classNames("vkuiPanelHeader--android", "vkuiInternalPanelHeader--android"),
21
21
  vkcom: classNames("vkuiPanelHeader--vkcom", "vkuiInternalPanelHeader--vkcom")
22
22
  };
23
23
  var sizeXClassNames = {
24
24
  none: "vkuiPanelHeader--sizeX-none",
25
25
  regular: "vkuiPanelHeader--sizeX-regular"
26
26
  };
27
+ var PanelHeaderContent = function(param) {
28
+ var children = param.children, _param_Component = param.Component, Component = _param_Component === void 0 ? "span" : _param_Component, id = param.id;
29
+ var platform = usePlatform();
30
+ return platform === Platform.VKCOM ? /*#__PURE__*/ React.createElement(Text, {
31
+ weight: "2",
32
+ Component: Component,
33
+ id: id
34
+ }, children) : /*#__PURE__*/ React.createElement(Component, {
35
+ className: "vkuiPanelHeader__content-in",
36
+ id: id
37
+ }, children);
38
+ };
39
+ PanelHeaderContent.displayName = "PanelHeaderContent";
27
40
  var PanelHeaderIn = function(param) {
28
41
  var before = param.before, after = param.after, separator = param.separator, children = param.children;
29
42
  var webviewType = useConfigProvider().webviewType;
@@ -36,11 +49,7 @@ var PanelHeaderIn = function(param) {
36
49
  className: classNames("vkuiPanelHeader__before", "vkuiInternalPanelHeader__before")
37
50
  }, before), /*#__PURE__*/ React.createElement("div", {
38
51
  className: "vkuiPanelHeader__content"
39
- }, platform === Platform.VKCOM ? /*#__PURE__*/ React.createElement(Text, {
40
- weight: "2"
41
- }, children) : /*#__PURE__*/ React.createElement("span", {
42
- className: "vkuiPanelHeader__content-in"
43
- }, children)), /*#__PURE__*/ React.createElement("div", {
52
+ }, /*#__PURE__*/ React.isValidElement(children) && children.type.displayName === PanelHeaderContent.displayName ? children : /*#__PURE__*/ React.createElement(PanelHeaderContent, null, children)), /*#__PURE__*/ React.createElement("div", {
44
53
  className: classNames("vkuiPanelHeader__after", "vkuiInternalPanelHeader__after")
45
54
  }, (webviewType === WebviewType.INTERNAL || isInsideModal) && after)), separator && platform === Platform.VKCOM && /*#__PURE__*/ React.createElement(Separator, {
46
55
  className: "vkuiPanelHeader__separator",
@@ -73,7 +82,7 @@ var PanelHeaderIn = function(param) {
73
82
  className: classNames("vkuiPanelHeader", "vkuiInternalPanelHeader", platformClassNames.hasOwnProperty(platform) ? platformClassNames[platform] : platformClassNames.android, transparent && "vkuiPanelHeader--trnsp", shadow && "vkuiPanelHeader--shadow", visor && classNames("vkuiPanelHeader--vis", "vkuiInternalPanelHeader--vis"), separator && visor && classNames("vkuiPanelHeader--sep", "vkuiInternalPanelHeader--sep"), webviewType === WebviewType.VKAPPS && !isInsideModal && "vkuiPanelHeader--vkapps", !before && "vkuiPanelHeader--no-before", !after && "vkuiPanelHeader--no-after", isFixed && "vkuiPanelHeader--fixed", sizeX !== SizeType.COMPACT && sizeXClassNames[sizeX], className),
74
83
  ref: isFixed ? getRootRef : getRef
75
84
  }), isFixed ? /*#__PURE__*/ React.createElement(FixedLayout, {
76
- className: "vkuiPanelHeader__fixed",
85
+ className: classNames("vkuiPanelHeader__fixed", "vkuiInternalPanelHeader__fixed"),
77
86
  vertical: "top",
78
87
  getRootRef: getRef
79
88
  }, /*#__PURE__*/ React.createElement(PanelHeaderIn, {
@@ -91,5 +100,6 @@ var PanelHeaderIn = function(param) {
91
100
  size: 16
92
101
  })));
93
102
  };
103
+ PanelHeader.Content = PanelHeaderContent;
94
104
 
95
105
  //# sourceMappingURL=PanelHeader.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/PanelHeader/PanelHeader.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useAdaptivityConditionalRender } from '../../hooks/useAdaptivityConditionalRender';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { SizeType } from '../../lib/adaptivity';\nimport { Platform } from '../../lib/platform';\nimport { HasRef, HasRootRef } from '../../types';\nimport { useConfigProvider, WebviewType } from '../ConfigProvider/ConfigProviderContext';\nimport { FixedLayout } from '../FixedLayout/FixedLayout';\nimport { ModalRootContext } from '../ModalRoot/ModalRootContext';\nimport { Separator } from '../Separator/Separator';\nimport { Spacing } from '../Spacing/Spacing';\nimport { TooltipContainer } from '../Tooltip/TooltipContainer';\nimport { Text } from '../Typography/Text/Text';\nimport styles from './PanelHeader.module.css';\n\nconst platformClassNames = {\n ios: classNames(styles['PanelHeader--ios'], 'vkuiInternalPanelHeader--ios'),\n android: styles['PanelHeader--android'],\n vkcom: classNames(styles['PanelHeader--vkcom'], 'vkuiInternalPanelHeader--vkcom'),\n};\n\nconst sizeXClassNames = {\n none: styles['PanelHeader--sizeX-none'],\n regular: styles['PanelHeader--sizeX-regular'],\n};\n\nexport interface PanelHeaderProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRef<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n before?: React.ReactNode;\n after?: React.ReactNode;\n separator?: boolean;\n transparent?: boolean;\n shadow?: boolean;\n /**\n * Если `false`, то шапка будет нулевой высоты и контент панели \"залезет\" под неё\n */\n visor?: boolean;\n /**\n * Если `false`, то шапка будет в потоке. По умолчанию `true`, но если платформа vkcom, то по умолчанию `false`.\n */\n fixed?: boolean;\n}\n\nconst PanelHeaderIn = ({ before, after, separator, children }: PanelHeaderProps) => {\n const { webviewType } = useConfigProvider();\n const { isInsideModal } = React.useContext(ModalRootContext);\n const platform = usePlatform();\n\n return (\n <React.Fragment>\n <TooltipContainer fixed className={styles['PanelHeader__in']}>\n <div\n className={classNames(styles['PanelHeader__before'], 'vkuiInternalPanelHeader__before')}\n >\n {before}\n </div>\n <div className={styles['PanelHeader__content']}>\n {platform === Platform.VKCOM ? (\n <Text weight=\"2\">{children}</Text>\n ) : (\n <span className={styles['PanelHeader__content-in']}>{children}</span>\n )}\n </div>\n <div className={classNames(styles['PanelHeader__after'], 'vkuiInternalPanelHeader__after')}>\n {(webviewType === WebviewType.INTERNAL || isInsideModal) && after}\n </div>\n </TooltipContainer>\n {separator && platform === Platform.VKCOM && (\n <Separator className={styles['PanelHeader__separator']} wide />\n )}\n </React.Fragment>\n );\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/PanelHeader\n */\nexport const PanelHeader = ({\n before,\n children,\n after,\n separator = true,\n visor = true,\n transparent = false,\n shadow,\n getRef,\n getRootRef,\n fixed,\n className,\n ...restProps\n}: PanelHeaderProps) => {\n const platform = usePlatform();\n const { webviewType } = useConfigProvider();\n const { isInsideModal } = React.useContext(ModalRootContext);\n const { sizeX = 'none' } = useAdaptivity();\n const { sizeX: adaptiveSizeX } = useAdaptivityConditionalRender();\n let isFixed = fixed !== undefined ? fixed : platform !== Platform.VKCOM;\n\n return (\n <div\n {...restProps}\n className={classNames(\n styles['PanelHeader'],\n 'vkuiInternalPanelHeader',\n platformClassNames.hasOwnProperty(platform)\n ? platformClassNames[platform]\n : platformClassNames.android,\n transparent && styles['PanelHeader--trnsp'],\n shadow && styles['PanelHeader--shadow'],\n visor && classNames(styles['PanelHeader--vis'], 'vkuiInternalPanelHeader--vis'),\n separator &&\n visor &&\n classNames(styles['PanelHeader--sep'], 'vkuiInternalPanelHeader--sep'),\n webviewType === WebviewType.VKAPPS && !isInsideModal && styles['PanelHeader--vkapps'],\n !before && styles['PanelHeader--no-before'],\n !after && styles['PanelHeader--no-after'],\n isFixed && styles['PanelHeader--fixed'],\n sizeX !== SizeType.COMPACT && sizeXClassNames[sizeX],\n className,\n )}\n ref={isFixed ? getRootRef : getRef}\n >\n {isFixed ? (\n <FixedLayout className={styles['PanelHeader__fixed']} vertical=\"top\" getRootRef={getRef}>\n <PanelHeaderIn before={before} after={after} separator={separator}>\n {children}\n </PanelHeaderIn>\n </FixedLayout>\n ) : (\n <PanelHeaderIn before={before} after={after} separator={separator}>\n {children}\n </PanelHeaderIn>\n )}\n {separator && visor && platform !== Platform.VKCOM && (\n <React.Fragment>\n {adaptiveSizeX.compact && <Separator className={adaptiveSizeX.compact.className} />}\n {adaptiveSizeX.regular && (\n <Spacing className={adaptiveSizeX.regular.className} size={16} />\n )}\n </React.Fragment>\n )}\n </div>\n );\n};\n"],"names":["React","classNames","useAdaptivity","useAdaptivityConditionalRender","usePlatform","SizeType","Platform","useConfigProvider","WebviewType","FixedLayout","ModalRootContext","Separator","Spacing","TooltipContainer","Text","platformClassNames","ios","android","vkcom","sizeXClassNames","none","regular","PanelHeaderIn","before","after","separator","children","webviewType","isInsideModal","useContext","platform","Fragment","fixed","className","div","VKCOM","weight","span","INTERNAL","wide","PanelHeader","visor","transparent","shadow","getRef","getRootRef","restProps","sizeX","adaptiveSizeX","isFixed","undefined","hasOwnProperty","VKAPPS","COMPACT","ref","vertical","compact","size"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../src/components/PanelHeader/PanelHeader.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useAdaptivityConditionalRender } from '../../hooks/useAdaptivityConditionalRender';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { SizeType } from '../../lib/adaptivity';\nimport { Platform } from '../../lib/platform';\nimport { HasComponent, HasRef, HasRootRef } from '../../types';\nimport { useConfigProvider, WebviewType } from '../ConfigProvider/ConfigProviderContext';\nimport { FixedLayout } from '../FixedLayout/FixedLayout';\nimport { ModalRootContext } from '../ModalRoot/ModalRootContext';\nimport { Separator } from '../Separator/Separator';\nimport { Spacing } from '../Spacing/Spacing';\nimport { TooltipContainer } from '../Tooltip/TooltipContainer';\nimport { Text } from '../Typography/Text/Text';\nimport styles from './PanelHeader.module.css';\n\nconst platformClassNames = {\n ios: classNames(styles['PanelHeader--ios'], 'vkuiInternalPanelHeader--ios'),\n android: classNames(styles['PanelHeader--android'], 'vkuiInternalPanelHeader--android'),\n vkcom: classNames(styles['PanelHeader--vkcom'], 'vkuiInternalPanelHeader--vkcom'),\n};\n\nconst sizeXClassNames = {\n none: styles['PanelHeader--sizeX-none'],\n regular: styles['PanelHeader--sizeX-regular'],\n};\n\nexport interface PanelHeaderProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRef<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n before?: React.ReactNode;\n after?: React.ReactNode;\n separator?: boolean;\n transparent?: boolean;\n shadow?: boolean;\n /**\n * Если `false`, то шапка будет нулевой высоты и контент панели \"залезет\" под неё\n */\n visor?: boolean;\n /**\n * Если `false`, то шапка будет в потоке. По умолчанию `true`, но если платформа vkcom, то по умолчанию `false`.\n */\n fixed?: boolean;\n}\n\ninterface PanelHeaderContentProps extends React.HTMLAttributes<HTMLElement>, HasComponent {}\n\nconst PanelHeaderContent = ({ children, Component = 'span', id }: PanelHeaderContentProps) => {\n const platform = usePlatform();\n\n return platform === Platform.VKCOM ? (\n <Text weight=\"2\" Component={Component} id={id}>\n {children}\n </Text>\n ) : (\n <Component className={styles['PanelHeader__content-in']} id={id}>\n {children}\n </Component>\n );\n};\n\nPanelHeaderContent.displayName = 'PanelHeaderContent';\n\nconst PanelHeaderIn = ({ before, after, separator, children }: PanelHeaderProps) => {\n const { webviewType } = useConfigProvider();\n const { isInsideModal } = React.useContext(ModalRootContext);\n const platform = usePlatform();\n\n return (\n <React.Fragment>\n <TooltipContainer fixed className={styles['PanelHeader__in']}>\n <div\n className={classNames(styles['PanelHeader__before'], 'vkuiInternalPanelHeader__before')}\n >\n {before}\n </div>\n <div className={styles['PanelHeader__content']}>\n {/* Поддерживаем обратную совместимость для подкомпонентного подхода */}\n {React.isValidElement(children) &&\n (children as JSX.Element).type.displayName === PanelHeaderContent.displayName ? (\n children\n ) : (\n <PanelHeaderContent>{children}</PanelHeaderContent>\n )}\n </div>\n <div className={classNames(styles['PanelHeader__after'], 'vkuiInternalPanelHeader__after')}>\n {(webviewType === WebviewType.INTERNAL || isInsideModal) && after}\n </div>\n </TooltipContainer>\n {separator && platform === Platform.VKCOM && (\n <Separator className={styles['PanelHeader__separator']} wide />\n )}\n </React.Fragment>\n );\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/PanelHeader\n */\nexport const PanelHeader = ({\n before,\n children,\n after,\n separator = true,\n visor = true,\n transparent = false,\n shadow,\n getRef,\n getRootRef,\n fixed,\n className,\n ...restProps\n}: PanelHeaderProps) => {\n const platform = usePlatform();\n const { webviewType } = useConfigProvider();\n const { isInsideModal } = React.useContext(ModalRootContext);\n const { sizeX = 'none' } = useAdaptivity();\n const { sizeX: adaptiveSizeX } = useAdaptivityConditionalRender();\n let isFixed = fixed !== undefined ? fixed : platform !== Platform.VKCOM;\n\n return (\n <div\n {...restProps}\n className={classNames(\n styles['PanelHeader'],\n 'vkuiInternalPanelHeader',\n platformClassNames.hasOwnProperty(platform)\n ? platformClassNames[platform]\n : platformClassNames.android,\n transparent && styles['PanelHeader--trnsp'],\n shadow && styles['PanelHeader--shadow'],\n visor && classNames(styles['PanelHeader--vis'], 'vkuiInternalPanelHeader--vis'),\n separator &&\n visor &&\n classNames(styles['PanelHeader--sep'], 'vkuiInternalPanelHeader--sep'),\n webviewType === WebviewType.VKAPPS && !isInsideModal && styles['PanelHeader--vkapps'],\n !before && styles['PanelHeader--no-before'],\n !after && styles['PanelHeader--no-after'],\n isFixed && styles['PanelHeader--fixed'],\n sizeX !== SizeType.COMPACT && sizeXClassNames[sizeX],\n className,\n )}\n ref={isFixed ? getRootRef : getRef}\n >\n {isFixed ? (\n <FixedLayout\n className={classNames(styles['PanelHeader__fixed'], 'vkuiInternalPanelHeader__fixed')}\n vertical=\"top\"\n getRootRef={getRef}\n >\n <PanelHeaderIn before={before} after={after} separator={separator}>\n {children}\n </PanelHeaderIn>\n </FixedLayout>\n ) : (\n <PanelHeaderIn before={before} after={after} separator={separator}>\n {children}\n </PanelHeaderIn>\n )}\n {separator && visor && platform !== Platform.VKCOM && (\n <React.Fragment>\n {adaptiveSizeX.compact && <Separator className={adaptiveSizeX.compact.className} />}\n {adaptiveSizeX.regular && (\n <Spacing className={adaptiveSizeX.regular.className} size={16} />\n )}\n </React.Fragment>\n )}\n </div>\n );\n};\n\nPanelHeader.Content = PanelHeaderContent;\n"],"names":["React","classNames","useAdaptivity","useAdaptivityConditionalRender","usePlatform","SizeType","Platform","useConfigProvider","WebviewType","FixedLayout","ModalRootContext","Separator","Spacing","TooltipContainer","Text","platformClassNames","ios","android","vkcom","sizeXClassNames","none","regular","PanelHeaderContent","children","Component","id","platform","VKCOM","weight","className","displayName","PanelHeaderIn","before","after","separator","webviewType","isInsideModal","useContext","Fragment","fixed","div","isValidElement","type","INTERNAL","wide","PanelHeader","visor","transparent","shadow","getRef","getRootRef","restProps","sizeX","adaptiveSizeX","isFixed","undefined","hasOwnProperty","VKAPPS","COMPACT","ref","vertical","compact","size","Content"],"mappings":"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"}
@@ -69,7 +69,7 @@ var warn = warnOnce("PanelHeaderButton");
69
69
  hoverMode: hoverMode,
70
70
  activeEffectDelay: 200,
71
71
  activeMode: activeMode,
72
- className: classNames("vkuiPanelHeaderButton", platformClassNames.hasOwnProperty(platform) ? platformClassNames[platform] : platformClassNames.android, isPrimitive && "vkuiPanelHeaderButton--primitive", !isPrimitive && !isPrimitiveLabel && "vkuiPanelHeaderButton--notPrimitive", className)
72
+ className: classNames("vkuiInternalPanelHeaderButton", "vkuiPanelHeaderButton", platformClassNames.hasOwnProperty(platform) ? platformClassNames[platform] : platformClassNames.android, isPrimitive && "vkuiPanelHeaderButton--primitive", !isPrimitive && !isPrimitiveLabel && "vkuiPanelHeaderButton--notPrimitive", className)
73
73
  }), isPrimitive ? /*#__PURE__*/ React.createElement(ButtonTypography, {
74
74
  primary: primary
75
75
  }, children) : children, isPrimitiveLabel ? /*#__PURE__*/ React.createElement(ButtonTypography, {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/PanelHeaderButton/PanelHeaderButton.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, isPrimitiveReactNode } from '@vkontakte/vkjs';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { Platform } from '../../lib/platform';\nimport { getTitleFromChildren } from '../../lib/utils';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { Tappable, TappableProps } from '../Tappable/Tappable';\nimport { Text } from '../Typography/Text/Text';\nimport { Title } from '../Typography/Title/Title';\nimport styles from './PanelHeaderButton.module.css';\n\nconst platformClassNames = {\n ios: styles['PanelHeaderButton--ios'],\n android: styles['PanelHeaderButton--android'],\n vkcom: styles['PanelHeaderButton--vkcom'],\n};\n\nexport interface PanelHeaderButtonProps extends Omit<TappableProps, 'label'> {\n primary?: boolean;\n label?: React.ReactNode;\n}\n\ninterface ButtonTypographyProps extends React.AllHTMLAttributes<HTMLElement> {\n primary?: PanelHeaderButtonProps['primary'];\n}\n\nconst ButtonTypography = ({ primary, children }: ButtonTypographyProps) => {\n const platform = usePlatform();\n\n if (platform === Platform.IOS) {\n return (\n <Title Component=\"span\" level=\"3\" weight={primary ? '1' : '3'}>\n {children}\n </Title>\n );\n }\n\n return <Text weight={platform === Platform.VKCOM ? undefined : '2'}>{children}</Text>;\n};\n\nconst warn = warnOnce('PanelHeaderButton');\n\n/**\n * @see https://vkcom.github.io/VKUI/#/PanelHeaderButton\n */\nexport const PanelHeaderButton = ({\n children,\n primary = false,\n label,\n className,\n ...restProps\n}: PanelHeaderButtonProps) => {\n const isPrimitive = isPrimitiveReactNode(children);\n const isPrimitiveLabel = isPrimitiveReactNode(label);\n const platform = usePlatform();\n\n let hoverMode;\n let activeMode;\n\n switch (platform) {\n case Platform.IOS:\n hoverMode = 'background';\n activeMode = 'opacity';\n break;\n case Platform.VKCOM:\n hoverMode = styles['PanelHeaderButton--hover'];\n activeMode = styles['PanelHeaderButton--active'];\n break;\n default:\n hoverMode = 'background';\n activeMode = 'background';\n }\n\n if (process.env.NODE_ENV === 'development') {\n const hasAccessibleName = Boolean(\n getTitleFromChildren(children) ||\n getTitleFromChildren(label) ||\n restProps['aria-label'] ||\n restProps['aria-labelledby'],\n );\n\n if (!hasAccessibleName) {\n warn(\n 'a11y: У кнопки нет названия, которое может прочитать скринридер, и она недоступна для части пользователей. Замените содержимое на текст или добавьте описание действия с помощью пропа aria-label.',\n 'error',\n );\n }\n }\n\n return (\n <Tappable\n Component={restProps.href ? 'a' : 'button'}\n {...restProps}\n hoverMode={hoverMode}\n activeEffectDelay={200}\n activeMode={activeMode}\n className={classNames(\n styles['PanelHeaderButton'],\n platformClassNames.hasOwnProperty(platform)\n ? platformClassNames[platform]\n : platformClassNames.android,\n isPrimitive && styles['PanelHeaderButton--primitive'],\n !isPrimitive && !isPrimitiveLabel && styles['PanelHeaderButton--notPrimitive'],\n className,\n )}\n >\n {isPrimitive ? <ButtonTypography primary={primary}>{children}</ButtonTypography> : children}\n {isPrimitiveLabel ? (\n <ButtonTypography primary={primary} className={styles['PanelHeaderButton__label']}>\n {label}\n </ButtonTypography>\n ) : (\n label\n )}\n </Tappable>\n );\n};\n"],"names":["React","classNames","isPrimitiveReactNode","usePlatform","Platform","getTitleFromChildren","warnOnce","Tappable","Text","Title","platformClassNames","ios","android","vkcom","ButtonTypography","primary","children","platform","IOS","Component","level","weight","VKCOM","undefined","warn","PanelHeaderButton","label","className","restProps","isPrimitive","isPrimitiveLabel","hoverMode","activeMode","process","env","NODE_ENV","hasAccessibleName","Boolean","href","activeEffectDelay","hasOwnProperty"],"mappings":";;;AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,EAAEC,oBAAoB,QAAQ,kBAAkB;AACnE,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,QAAQ,QAAQ,qBAAqB;AAC9C,SAASC,oBAAoB,QAAQ,kBAAkB;AACvD,SAASC,QAAQ,QAAQ,qBAAqB;AAC9C,SAASC,QAAQ,QAAuB,uBAAuB;AAC/D,SAASC,IAAI,QAAQ,0BAA0B;AAC/C,SAASC,KAAK,QAAQ,4BAA4B;AAGlD,IAAMC,qBAAqB;IACzBC,GAAG;IACHC,OAAO;IACPC,KAAK;AACP;AAWA,IAAMC,mBAAmB,gBAAkD;QAA/CC,gBAAAA,SAASC,iBAAAA;IACnC,IAAMC,WAAWd;IAEjB,IAAIc,aAAab,SAASc,GAAG,EAAE;QAC7B,qBACE,oBAACT;YAAMU,WAAU;YAAOC,OAAM;YAAIC,QAAQN,UAAU,MAAM,GAAG;WAC1DC;IAGP,CAAC;IAED,qBAAO,oBAACR;QAAKa,QAAQJ,aAAab,SAASkB,KAAK,GAAGC,YAAY,GAAG;OAAGP;AACvE;AAEA,IAAMQ,OAAOlB,SAAS;AAEtB;;CAEC,GACD,OAAO,IAAMmB,oBAAoB,iBAMH;QAL5BT,kBAAAA,kCACAD,SAAAA,sCAAU,KAAK,mBACfW,eAAAA,OACAC,mBAAAA,WACGC;QAJHZ;QACAD;QACAW;QACAC;;IAGA,IAAME,cAAc3B,qBAAqBc;IACzC,IAAMc,mBAAmB5B,qBAAqBwB;IAC9C,IAAMT,WAAWd;IAEjB,IAAI4B;IACJ,IAAIC;IAEJ,OAAQf;QACN,KAAKb,SAASc,GAAG;YACfa,YAAY;YACZC,aAAa;YACb,KAAM;QACR,KAAK5B,SAASkB,KAAK;YACjBS;YACAC;YACA,KAAM;QACR;YACED,YAAY;YACZC,aAAa;IACjB;IAEA,IAAIC,QAAQC,GAAG,CAACC,QAAQ,KAAK,eAAe;QAC1C,IAAMC,oBAAoBC,QACxBhC,qBAAqBW,aACnBX,qBAAqBqB,UACrBE,SAAS,CAAC,aAAa,IACvBA,SAAS,CAAC,kBAAkB;QAGhC,IAAI,CAACQ,mBAAmB;YACtBZ,KACE,sMACA;QAEJ,CAAC;IACH,CAAC;IAED,qBACE,oBAACjB;QACCY,WAAWS,UAAUU,IAAI,GAAG,MAAM,QAAQ;OACtCV;QACJG,WAAWA;QACXQ,mBAAmB;QACnBP,YAAYA;QACZL,WAAW1B,oCAETS,mBAAmB8B,cAAc,CAACvB,YAC9BP,kBAAkB,CAACO,SAAS,GAC5BP,mBAAmBE,OAAO,EAC9BiB,mDACA,CAACA,eAAe,CAACC,2DACjBH;QAGDE,4BAAc,oBAACf;QAAiBC,SAASA;OAAUC,YAA+BA,QAAQ,EAC1Fc,iCACC,oBAAChB;QAAiBC,SAASA;QAASY,SAAS;OAC1CD,SAGHA,KACD;AAGP,EAAE"}
1
+ {"version":3,"sources":["../../../src/components/PanelHeaderButton/PanelHeaderButton.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, isPrimitiveReactNode } from '@vkontakte/vkjs';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { Platform } from '../../lib/platform';\nimport { getTitleFromChildren } from '../../lib/utils';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { Tappable, TappableProps } from '../Tappable/Tappable';\nimport { Text } from '../Typography/Text/Text';\nimport { Title } from '../Typography/Title/Title';\nimport styles from './PanelHeaderButton.module.css';\n\nconst platformClassNames = {\n ios: styles['PanelHeaderButton--ios'],\n android: styles['PanelHeaderButton--android'],\n vkcom: styles['PanelHeaderButton--vkcom'],\n};\n\nexport interface PanelHeaderButtonProps extends Omit<TappableProps, 'label'> {\n primary?: boolean;\n label?: React.ReactNode;\n}\n\ninterface ButtonTypographyProps extends React.AllHTMLAttributes<HTMLElement> {\n primary?: PanelHeaderButtonProps['primary'];\n}\n\nconst ButtonTypography = ({ primary, children }: ButtonTypographyProps) => {\n const platform = usePlatform();\n\n if (platform === Platform.IOS) {\n return (\n <Title Component=\"span\" level=\"3\" weight={primary ? '1' : '3'}>\n {children}\n </Title>\n );\n }\n\n return <Text weight={platform === Platform.VKCOM ? undefined : '2'}>{children}</Text>;\n};\n\nconst warn = warnOnce('PanelHeaderButton');\n\n/**\n * @see https://vkcom.github.io/VKUI/#/PanelHeaderButton\n */\nexport const PanelHeaderButton = ({\n children,\n primary = false,\n label,\n className,\n ...restProps\n}: PanelHeaderButtonProps) => {\n const isPrimitive = isPrimitiveReactNode(children);\n const isPrimitiveLabel = isPrimitiveReactNode(label);\n const platform = usePlatform();\n\n let hoverMode;\n let activeMode;\n\n switch (platform) {\n case Platform.IOS:\n hoverMode = 'background';\n activeMode = 'opacity';\n break;\n case Platform.VKCOM:\n hoverMode = styles['PanelHeaderButton--hover'];\n activeMode = styles['PanelHeaderButton--active'];\n break;\n default:\n hoverMode = 'background';\n activeMode = 'background';\n }\n\n if (process.env.NODE_ENV === 'development') {\n const hasAccessibleName = Boolean(\n getTitleFromChildren(children) ||\n getTitleFromChildren(label) ||\n restProps['aria-label'] ||\n restProps['aria-labelledby'],\n );\n\n if (!hasAccessibleName) {\n warn(\n 'a11y: У кнопки нет названия, которое может прочитать скринридер, и она недоступна для части пользователей. Замените содержимое на текст или добавьте описание действия с помощью пропа aria-label.',\n 'error',\n );\n }\n }\n\n return (\n <Tappable\n Component={restProps.href ? 'a' : 'button'}\n {...restProps}\n hoverMode={hoverMode}\n activeEffectDelay={200}\n activeMode={activeMode}\n className={classNames(\n 'vkuiInternalPanelHeaderButton',\n styles['PanelHeaderButton'],\n platformClassNames.hasOwnProperty(platform)\n ? platformClassNames[platform]\n : platformClassNames.android,\n isPrimitive && styles['PanelHeaderButton--primitive'],\n !isPrimitive && !isPrimitiveLabel && styles['PanelHeaderButton--notPrimitive'],\n className,\n )}\n >\n {isPrimitive ? <ButtonTypography primary={primary}>{children}</ButtonTypography> : children}\n {isPrimitiveLabel ? (\n <ButtonTypography primary={primary} className={styles['PanelHeaderButton__label']}>\n {label}\n </ButtonTypography>\n ) : (\n label\n )}\n </Tappable>\n );\n};\n"],"names":["React","classNames","isPrimitiveReactNode","usePlatform","Platform","getTitleFromChildren","warnOnce","Tappable","Text","Title","platformClassNames","ios","android","vkcom","ButtonTypography","primary","children","platform","IOS","Component","level","weight","VKCOM","undefined","warn","PanelHeaderButton","label","className","restProps","isPrimitive","isPrimitiveLabel","hoverMode","activeMode","process","env","NODE_ENV","hasAccessibleName","Boolean","href","activeEffectDelay","hasOwnProperty"],"mappings":";;;AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,EAAEC,oBAAoB,QAAQ,kBAAkB;AACnE,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,QAAQ,QAAQ,qBAAqB;AAC9C,SAASC,oBAAoB,QAAQ,kBAAkB;AACvD,SAASC,QAAQ,QAAQ,qBAAqB;AAC9C,SAASC,QAAQ,QAAuB,uBAAuB;AAC/D,SAASC,IAAI,QAAQ,0BAA0B;AAC/C,SAASC,KAAK,QAAQ,4BAA4B;AAGlD,IAAMC,qBAAqB;IACzBC,GAAG;IACHC,OAAO;IACPC,KAAK;AACP;AAWA,IAAMC,mBAAmB,gBAAkD;QAA/CC,gBAAAA,SAASC,iBAAAA;IACnC,IAAMC,WAAWd;IAEjB,IAAIc,aAAab,SAASc,GAAG,EAAE;QAC7B,qBACE,oBAACT;YAAMU,WAAU;YAAOC,OAAM;YAAIC,QAAQN,UAAU,MAAM,GAAG;WAC1DC;IAGP,CAAC;IAED,qBAAO,oBAACR;QAAKa,QAAQJ,aAAab,SAASkB,KAAK,GAAGC,YAAY,GAAG;OAAGP;AACvE;AAEA,IAAMQ,OAAOlB,SAAS;AAEtB;;CAEC,GACD,OAAO,IAAMmB,oBAAoB,iBAMH;QAL5BT,kBAAAA,kCACAD,SAAAA,sCAAU,KAAK,mBACfW,eAAAA,OACAC,mBAAAA,WACGC;QAJHZ;QACAD;QACAW;QACAC;;IAGA,IAAME,cAAc3B,qBAAqBc;IACzC,IAAMc,mBAAmB5B,qBAAqBwB;IAC9C,IAAMT,WAAWd;IAEjB,IAAI4B;IACJ,IAAIC;IAEJ,OAAQf;QACN,KAAKb,SAASc,GAAG;YACfa,YAAY;YACZC,aAAa;YACb,KAAM;QACR,KAAK5B,SAASkB,KAAK;YACjBS;YACAC;YACA,KAAM;QACR;YACED,YAAY;YACZC,aAAa;IACjB;IAEA,IAAIC,QAAQC,GAAG,CAACC,QAAQ,KAAK,eAAe;QAC1C,IAAMC,oBAAoBC,QACxBhC,qBAAqBW,aACnBX,qBAAqBqB,UACrBE,SAAS,CAAC,aAAa,IACvBA,SAAS,CAAC,kBAAkB;QAGhC,IAAI,CAACQ,mBAAmB;YACtBZ,KACE,sMACA;QAEJ,CAAC;IACH,CAAC;IAED,qBACE,oBAACjB;QACCY,WAAWS,UAAUU,IAAI,GAAG,MAAM,QAAQ;OACtCV;QACJG,WAAWA;QACXQ,mBAAmB;QACnBP,YAAYA;QACZL,WAAW1B,WACT,0DAEAS,mBAAmB8B,cAAc,CAACvB,YAC9BP,kBAAkB,CAACO,SAAS,GAC5BP,mBAAmBE,OAAO,EAC9BiB,mDACA,CAACA,eAAe,CAACC,2DACjBH;QAGDE,4BAAc,oBAACf;QAAiBC,SAASA;OAAUC,YAA+BA,QAAQ,EAC1Fc,iCACC,oBAAChB;QAAiBC,SAASA;QAASY,SAAS;OAC1CD,SAGHA,KACD;AAGP,EAAE"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/PanelHeaderContent/PanelHeaderContent.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { Platform } from '../../lib/platform';\nimport { Tappable } from '../Tappable/Tappable';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { Headline } from '../Typography/Headline/Headline';\nimport { Text } from '../Typography/Text/Text';\nimport styles from './PanelHeaderContent.module.css';\n\nconst platformClassNames = {\n ios: styles['PanelHeaderContent--ios'],\n android: styles['PanelHeaderContent--android'],\n vkcom: styles['PanelHeaderContent--vkcom'],\n};\n\nexport interface PanelHeaderContentProps extends React.HTMLAttributes<HTMLDivElement> {\n aside?: React.ReactNode;\n before?: React.ReactNode;\n status?: React.ReactNode;\n}\n\ninterface PanelHeaderChildrenProps {\n hasStatus: boolean;\n hasBefore: boolean;\n children?: React.ReactNode;\n}\n\nconst PanelHeaderChildren = ({ hasStatus, hasBefore, children }: PanelHeaderChildrenProps) => {\n const platform = usePlatform();\n if (platform === Platform.VKCOM) {\n return (\n <Text Component=\"div\" weight=\"2\">\n {children}\n </Text>\n );\n }\n\n return hasStatus || hasBefore ? (\n <Headline Component=\"div\" weight=\"2\">\n {children}\n </Headline>\n ) : (\n <div className={styles['PanelHeaderContent__children-in']}>{children}</div>\n );\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/PanelHeaderContent\n */\nexport const PanelHeaderContent = ({\n className,\n style,\n aside,\n status,\n before,\n children,\n onClick,\n ...restProps\n}: PanelHeaderContentProps) => {\n const InComponent = onClick ? Tappable : 'div';\n const rootProps = onClick ? {} : restProps;\n const platform = usePlatform();\n const inProps = onClick\n ? {\n ...restProps,\n onClick,\n activeEffectDelay: 200,\n hasActive: platform === Platform.IOS,\n activeMode: 'opacity',\n }\n : {};\n\n return (\n <div\n {...rootProps}\n style={style}\n className={classNames(\n styles['PanelHeaderContent'],\n platformClassNames.hasOwnProperty(platform)\n ? platformClassNames[platform]\n : platformClassNames.android,\n className,\n )}\n >\n {hasReactNode(before) && <div className={styles['PanelHeaderContent__before']}>{before}</div>}\n <InComponent\n {...inProps}\n className={classNames(\n styles['PanelHeaderContent__in'],\n !before && platform !== Platform.ANDROID && styles['PanelHeaderContent__in--centered'],\n )}\n >\n {hasReactNode(status) && (\n <Footnote className={styles['PanelHeaderContent__status']}>{status}</Footnote>\n )}\n <div\n className={classNames(\n 'vkuiInternalPanelHeaderContent__children',\n styles['PanelHeaderContent__children'],\n )}\n >\n <PanelHeaderChildren hasStatus={hasReactNode(status)} hasBefore={hasReactNode(before)}>\n {children}\n </PanelHeaderChildren>\n {hasReactNode(aside) && (\n <div className={styles['PanelHeaderContent__aside']}>{aside}</div>\n )}\n </div>\n {hasReactNode(before) && <div className={styles['PanelHeaderContent__width']} />}\n </InComponent>\n </div>\n );\n};\n"],"names":["React","classNames","hasReactNode","usePlatform","Platform","Tappable","Footnote","Headline","Text","platformClassNames","ios","android","vkcom","PanelHeaderChildren","hasStatus","hasBefore","children","platform","VKCOM","Component","weight","div","className","PanelHeaderContent","style","aside","status","before","onClick","restProps","InComponent","rootProps","inProps","activeEffectDelay","hasActive","IOS","activeMode","hasOwnProperty","ANDROID"],"mappings":";;;AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,EAAEC,YAAY,QAAQ,kBAAkB;AAC3D,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,QAAQ,QAAQ,qBAAqB;AAC9C,SAASC,QAAQ,QAAQ,uBAAuB;AAChD,SAASC,QAAQ,QAAQ,kCAAkC;AAC3D,SAASC,QAAQ,QAAQ,kCAAkC;AAC3D,SAASC,IAAI,QAAQ,0BAA0B;AAG/C,IAAMC,qBAAqB;IACzBC,GAAG;IACHC,OAAO;IACPC,KAAK;AACP;AAcA,IAAMC,sBAAsB,gBAAkE;QAA/DC,kBAAAA,WAAWC,kBAAAA,WAAWC,iBAAAA;IACnD,IAAMC,WAAWd;IACjB,IAAIc,aAAab,SAASc,KAAK,EAAE;QAC/B,qBACE,oBAACV;YAAKW,WAAU;YAAMC,QAAO;WAC1BJ;IAGP,CAAC;IAED,OAAOF,aAAaC,0BAClB,oBAACR;QAASY,WAAU;QAAMC,QAAO;OAC9BJ,0BAGH,oBAACK;QAAIC,SAAS;OAA8CN,SAC7D;AACH;AAEA;;CAEC,GACD,OAAO,IAAMO,qBAAqB,iBASH;QAR7BD,mBAAAA,WACAE,eAAAA,OACAC,eAAAA,OACAC,gBAAAA,QACAC,gBAAAA,QACAX,kBAAAA,UACAY,iBAAAA,SACGC;QAPHP;QACAE;QACAC;QACAC;QACAC;QACAX;QACAY;;IAGA,IAAME,cAAcF,UAAUvB,WAAW,KAAK;IAC9C,IAAM0B,YAAYH,UAAU,CAAC,IAAIC,SAAS;IAC1C,IAAMZ,WAAWd;IACjB,IAAM6B,UAAUJ,UACZ,wCACKC;QACHD,SAAAA;QACAK,mBAAmB;QACnBC,WAAWjB,aAAab,SAAS+B,GAAG;QACpCC,YAAY;SAEd,CAAC,CAAC;IAEN,qBACE,oBAACf,+CACKU;QACJP,OAAOA;QACPF,WAAWrB,qCAETQ,mBAAmB4B,cAAc,CAACpB,YAC9BR,kBAAkB,CAACQ,SAAS,GAC5BR,mBAAmBE,OAAO,EAC9BW;QAGDpB,aAAayB,yBAAW,oBAACN;QAAIC,SAAS;OAAyCK,uBAChF,oBAACG,qDACKE;QACJV,WAAWrB,yCAET,CAAC0B,UAAUV,aAAab,SAASkC,OAAO;QAGzCpC,aAAawB,yBACZ,oBAACpB;QAASgB,SAAS;OAAyCI,uBAE9D,oBAACL;QACCC,WAAWrB,WACT;qBAIF,oBAACY;QAAoBC,WAAWZ,aAAawB;QAASX,WAAWb,aAAayB;OAC3EX,WAEFd,aAAauB,wBACZ,oBAACJ;QAAIC,SAAS;OAAwCG,SAGzDvB,aAAayB,yBAAW,oBAACN;QAAIC,SAAS;;AAI/C,EAAE"}
1
+ {"version":3,"sources":["../../../src/components/PanelHeaderContent/PanelHeaderContent.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { Platform } from '../../lib/platform';\nimport { HasChildren } from '../../types';\nimport { Tappable } from '../Tappable/Tappable';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { Headline } from '../Typography/Headline/Headline';\nimport { Text } from '../Typography/Text/Text';\nimport styles from './PanelHeaderContent.module.css';\n\nconst platformClassNames = {\n ios: styles['PanelHeaderContent--ios'],\n android: styles['PanelHeaderContent--android'],\n vkcom: styles['PanelHeaderContent--vkcom'],\n};\n\nexport interface PanelHeaderContentProps extends React.HTMLAttributes<HTMLDivElement> {\n aside?: React.ReactNode;\n before?: React.ReactNode;\n status?: React.ReactNode;\n}\n\ninterface PanelHeaderChildrenProps extends HasChildren {\n hasStatus: boolean;\n hasBefore: boolean;\n}\n\nconst PanelHeaderChildren = ({ hasStatus, hasBefore, children }: PanelHeaderChildrenProps) => {\n const platform = usePlatform();\n if (platform === Platform.VKCOM) {\n return (\n <Text Component=\"div\" weight=\"2\">\n {children}\n </Text>\n );\n }\n\n return hasStatus || hasBefore ? (\n <Headline Component=\"div\" weight=\"2\">\n {children}\n </Headline>\n ) : (\n <div className={styles['PanelHeaderContent__children-in']}>{children}</div>\n );\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/PanelHeaderContent\n */\nexport const PanelHeaderContent = ({\n className,\n style,\n aside,\n status,\n before,\n children,\n onClick,\n ...restProps\n}: PanelHeaderContentProps) => {\n const InComponent = onClick ? Tappable : 'div';\n const rootProps = onClick ? {} : restProps;\n const platform = usePlatform();\n const inProps = onClick\n ? {\n ...restProps,\n onClick,\n activeEffectDelay: 200,\n hasActive: platform === Platform.IOS,\n activeMode: 'opacity',\n }\n : {};\n\n return (\n <div\n {...rootProps}\n style={style}\n className={classNames(\n styles['PanelHeaderContent'],\n platformClassNames.hasOwnProperty(platform)\n ? platformClassNames[platform]\n : platformClassNames.android,\n className,\n )}\n >\n {hasReactNode(before) && <div className={styles['PanelHeaderContent__before']}>{before}</div>}\n <InComponent\n {...inProps}\n className={classNames(\n styles['PanelHeaderContent__in'],\n !before && platform !== Platform.ANDROID && styles['PanelHeaderContent__in--centered'],\n )}\n >\n {hasReactNode(status) && (\n <Footnote className={styles['PanelHeaderContent__status']}>{status}</Footnote>\n )}\n <div\n className={classNames(\n 'vkuiInternalPanelHeaderContent__children',\n styles['PanelHeaderContent__children'],\n )}\n >\n <PanelHeaderChildren hasStatus={hasReactNode(status)} hasBefore={hasReactNode(before)}>\n {children}\n </PanelHeaderChildren>\n {hasReactNode(aside) && (\n <div className={styles['PanelHeaderContent__aside']}>{aside}</div>\n )}\n </div>\n {hasReactNode(before) && <div className={styles['PanelHeaderContent__width']} />}\n </InComponent>\n </div>\n );\n};\n"],"names":["React","classNames","hasReactNode","usePlatform","Platform","Tappable","Footnote","Headline","Text","platformClassNames","ios","android","vkcom","PanelHeaderChildren","hasStatus","hasBefore","children","platform","VKCOM","Component","weight","div","className","PanelHeaderContent","style","aside","status","before","onClick","restProps","InComponent","rootProps","inProps","activeEffectDelay","hasActive","IOS","activeMode","hasOwnProperty","ANDROID"],"mappings":";;;AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,EAAEC,YAAY,QAAQ,kBAAkB;AAC3D,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,QAAQ,QAAQ,qBAAqB;AAE9C,SAASC,QAAQ,QAAQ,uBAAuB;AAChD,SAASC,QAAQ,QAAQ,kCAAkC;AAC3D,SAASC,QAAQ,QAAQ,kCAAkC;AAC3D,SAASC,IAAI,QAAQ,0BAA0B;AAG/C,IAAMC,qBAAqB;IACzBC,GAAG;IACHC,OAAO;IACPC,KAAK;AACP;AAaA,IAAMC,sBAAsB,gBAAkE;QAA/DC,kBAAAA,WAAWC,kBAAAA,WAAWC,iBAAAA;IACnD,IAAMC,WAAWd;IACjB,IAAIc,aAAab,SAASc,KAAK,EAAE;QAC/B,qBACE,oBAACV;YAAKW,WAAU;YAAMC,QAAO;WAC1BJ;IAGP,CAAC;IAED,OAAOF,aAAaC,0BAClB,oBAACR;QAASY,WAAU;QAAMC,QAAO;OAC9BJ,0BAGH,oBAACK;QAAIC,SAAS;OAA8CN,SAC7D;AACH;AAEA;;CAEC,GACD,OAAO,IAAMO,qBAAqB,iBASH;QAR7BD,mBAAAA,WACAE,eAAAA,OACAC,eAAAA,OACAC,gBAAAA,QACAC,gBAAAA,QACAX,kBAAAA,UACAY,iBAAAA,SACGC;QAPHP;QACAE;QACAC;QACAC;QACAC;QACAX;QACAY;;IAGA,IAAME,cAAcF,UAAUvB,WAAW,KAAK;IAC9C,IAAM0B,YAAYH,UAAU,CAAC,IAAIC,SAAS;IAC1C,IAAMZ,WAAWd;IACjB,IAAM6B,UAAUJ,UACZ,wCACKC;QACHD,SAAAA;QACAK,mBAAmB;QACnBC,WAAWjB,aAAab,SAAS+B,GAAG;QACpCC,YAAY;SAEd,CAAC,CAAC;IAEN,qBACE,oBAACf,+CACKU;QACJP,OAAOA;QACPF,WAAWrB,qCAETQ,mBAAmB4B,cAAc,CAACpB,YAC9BR,kBAAkB,CAACQ,SAAS,GAC5BR,mBAAmBE,OAAO,EAC9BW;QAGDpB,aAAayB,yBAAW,oBAACN;QAAIC,SAAS;OAAyCK,uBAChF,oBAACG,qDACKE;QACJV,WAAWrB,yCAET,CAAC0B,UAAUV,aAAab,SAASkC,OAAO;QAGzCpC,aAAawB,yBACZ,oBAACpB;QAASgB,SAAS;OAAyCI,uBAE9D,oBAACL;QACCC,WAAWrB,WACT;qBAIF,oBAACY;QAAoBC,WAAWZ,aAAawB;QAASX,WAAWb,aAAayB;OAC3EX,WAEFd,aAAauB,wBACZ,oBAACJ;QAAIC,SAAS;OAAwCG,SAGzDvB,aAAayB,yBAAW,oBAACN;QAAIC,SAAS;;AAI/C,EAAE"}
@@ -61,7 +61,7 @@ var sizeXClassNames = (_obj = {
61
61
  closing
62
62
  ]);
63
63
  return /*#__PURE__*/ React.createElement(FixedLayout, _object_spread_props(_object_spread({}, restProps), {
64
- className: classNames("vkuiPanelHeaderContext", platform === Platform.IOS && "vkuiPanelHeaderContext--ios", opened && "vkuiPanelHeaderContext--opened", closing && "vkuiPanelHeaderContext--closing", sizeXClassNames[sizeX], "vkuiPanelHeaderContext--rounded", className),
64
+ className: classNames("vkuiPanelHeaderContext", platform === Platform.IOS && "vkuiPanelHeaderContext--ios", opened && "vkuiPanelHeaderContext--opened", closing && "vkuiPanelHeaderContext--closing", sizeXClassNames[sizeX], className),
65
65
  vertical: "top"
66
66
  }), visible && /*#__PURE__*/ React.createElement("div", {
67
67
  onClick: function(event) {
@@ -73,9 +73,9 @@ var sizeXClassNames = (_obj = {
73
73
  className: "vkuiPanelHeaderContext__in",
74
74
  ref: elementRef,
75
75
  onAnimationEnd: closing ? onAnimationEnd : undefined
76
- }, /*#__PURE__*/ React.createElement("div", {
76
+ }, visible && /*#__PURE__*/ React.createElement("div", {
77
77
  className: "vkuiPanelHeaderContext__content"
78
- }, visible && children)));
78
+ }, children)));
79
79
  };
80
80
 
81
81
  //# sourceMappingURL=PanelHeaderContext.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/PanelHeaderContext/PanelHeaderContext.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useGlobalEventListener } from '../../hooks/useGlobalEventListener';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { useTimeout } from '../../hooks/useTimeout';\nimport { SizeType } from '../../lib/adaptivity';\nimport { useDOM } from '../../lib/dom';\nimport { Platform } from '../../lib/platform';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { useScrollLock } from '../AppRoot/ScrollContext';\nimport { FixedLayout } from '../FixedLayout/FixedLayout';\nimport styles from './PanelHeaderContext.module.css';\n\nconst sizeXClassNames = {\n none: styles['PanelHeaderContext--sizeX-none'],\n [SizeType.COMPACT]: styles['PanelHeaderContext--sizeX-compact'],\n [SizeType.REGULAR]: styles['PanelHeaderContext--sizeX-regular'],\n};\n\nexport interface PanelHeaderContextProps extends React.HTMLAttributes<HTMLDivElement> {\n opened: boolean;\n onClose: VoidFunction;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/PanelHeaderContext\n */\nexport const PanelHeaderContext = ({\n children,\n onClose,\n opened = false,\n className,\n ...restProps\n}: PanelHeaderContextProps) => {\n const { document } = useDOM();\n const platform = usePlatform();\n const [visible, setVisible] = React.useState(opened);\n const closing = visible && !opened;\n const { sizeX = 'none' } = useAdaptivity();\n const elementRef = React.useRef<HTMLDivElement>(null);\n\n useIsomorphicLayoutEffect(() => {\n opened && setVisible(true);\n }, [opened]);\n\n useScrollLock(platform !== Platform.VKCOM && opened);\n\n // start closing on outer click\n useGlobalEventListener(\n document,\n 'click',\n opened &&\n !closing &&\n ((event) => {\n if (elementRef.current && !elementRef.current.contains(event.target as Node)) {\n event.stopPropagation();\n onClose();\n }\n }),\n { capture: true },\n );\n\n // fallback onAnimationEnd when animationend not supported\n const onAnimationEnd = () => setVisible(false);\n const animationFallback = useTimeout(onAnimationEnd, 200);\n React.useEffect(\n () => (closing ? animationFallback.set() : animationFallback.clear()),\n [animationFallback, closing],\n );\n\n return (\n <FixedLayout\n {...restProps}\n className={classNames(\n styles['PanelHeaderContext'],\n platform === Platform.IOS && styles['PanelHeaderContext--ios'],\n opened && styles['PanelHeaderContext--opened'],\n closing && styles['PanelHeaderContext--closing'],\n sizeXClassNames[sizeX],\n styles['PanelHeaderContext--rounded'],\n className,\n )}\n vertical=\"top\"\n >\n {visible && (\n <div\n onClick={(event) => {\n event.stopPropagation();\n onClose();\n }}\n className={styles['PanelHeaderContext__fade']}\n />\n )}\n <div\n className={styles['PanelHeaderContext__in']}\n ref={elementRef}\n onAnimationEnd={closing ? onAnimationEnd : undefined}\n >\n <div className={styles['PanelHeaderContext__content']}>{visible && children}</div>\n </div>\n </FixedLayout>\n );\n};\n"],"names":["React","classNames","useAdaptivity","useGlobalEventListener","usePlatform","useTimeout","SizeType","useDOM","Platform","useIsomorphicLayoutEffect","useScrollLock","FixedLayout","sizeXClassNames","none","COMPACT","REGULAR","PanelHeaderContext","children","onClose","opened","className","restProps","document","platform","useState","visible","setVisible","closing","sizeX","elementRef","useRef","VKCOM","event","current","contains","target","stopPropagation","capture","onAnimationEnd","animationFallback","useEffect","set","clear","IOS","vertical","div","onClick","ref","undefined"],"mappings":";;;;;AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,aAAa,QAAQ,4BAA4B;AAC1D,SAASC,sBAAsB,QAAQ,qCAAqC;AAC5E,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,UAAU,QAAQ,yBAAyB;AACpD,SAASC,QAAQ,QAAQ,uBAAuB;AAChD,SAASC,MAAM,QAAQ,gBAAgB;AACvC,SAASC,QAAQ,QAAQ,qBAAqB;AAC9C,SAASC,yBAAyB,QAAQ,sCAAsC;AAChF,SAASC,aAAa,QAAQ,2BAA2B;AACzD,SAASC,WAAW,QAAQ,6BAA6B;IAGjC;AAAxB,IAAMC,mBAAkB;IACtBC,IAAI;oBADkB,MAErBP,SAASQ,OAAO,6DAFK,MAGrBR,SAASS,OAAO,4CAHK;AAWxB;;CAEC,GACD,OAAO,IAAMC,qBAAqB,iBAMH;QAL7BC,kBAAAA,UACAC,iBAAAA,gCACAC,QAAAA,oCAAS,KAAK,kBACdC,mBAAAA,WACGC;QAJHJ;QACAC;QACAC;QACAC;;IAGA,IAAM,AAAEE,WAAaf,SAAbe;IACR,IAAMC,WAAWnB;IACjB,IAA8BJ,mCAAAA,MAAMwB,QAAQ,CAACL,aAAtCM,UAAuBzB,oBAAd0B,aAAc1B;IAC9B,IAAM2B,UAAUF,WAAW,CAACN;IAC5B,IAA2BjB,iBAAAA,wCAAAA,eAAnB0B,OAAAA,0CAAQ;IAChB,IAAMC,aAAa7B,MAAM8B,MAAM,CAAiB,IAAI;IAEpDrB,0BAA0B,WAAM;QAC9BU,UAAUO,WAAW,IAAI;IAC3B,GAAG;QAACP;KAAO;IAEXT,cAAca,aAAaf,SAASuB,KAAK,IAAIZ;IAE7C,+BAA+B;IAC/BhB,uBACEmB,UACA,SACAH,UACE,CAACQ,WACA,SAACK,OAAU;QACV,IAAIH,WAAWI,OAAO,IAAI,CAACJ,WAAWI,OAAO,CAACC,QAAQ,CAACF,MAAMG,MAAM,GAAW;YAC5EH,MAAMI,eAAe;YACrBlB;QACF,CAAC;IACH,GACF;QAAEmB,SAAS,IAAI;IAAC;IAGlB,0DAA0D;IAC1D,IAAMC,iBAAiB;eAAMZ,WAAW,KAAK;;IAC7C,IAAMa,oBAAoBlC,WAAWiC,gBAAgB;IACrDtC,MAAMwC,SAAS,CACb;eAAOb,UAAUY,kBAAkBE,GAAG,KAAKF,kBAAkBG,KAAK,EAAE;OACpE;QAACH;QAAmBZ;KAAQ;IAG9B,qBACE,oBAAChB,qDACKU;QACJD,WAAWnB,qCAETsB,aAAaf,SAASmC,GAAG,mCACzBxB,4CACAQ,8CACAf,eAAe,CAACgB,MAAM,qCAEtBR;QAEFwB,UAAS;QAERnB,yBACC,oBAACoB;QACCC,SAAS,SAACd,OAAU;YAClBA,MAAMI,eAAe;YACrBlB;QACF;QACAE,SAAS;sBAGb,oBAACyB;QACCzB,SAAS;QACT2B,KAAKlB;QACLS,gBAAgBX,UAAUW,iBAAiBU,SAAS;qBAEpD,oBAACH;QAAIzB,SAAS;OAA0CK,WAAWR;AAI3E,EAAE"}
1
+ {"version":3,"sources":["../../../src/components/PanelHeaderContext/PanelHeaderContext.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useGlobalEventListener } from '../../hooks/useGlobalEventListener';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { useTimeout } from '../../hooks/useTimeout';\nimport { SizeType } from '../../lib/adaptivity';\nimport { useDOM } from '../../lib/dom';\nimport { Platform } from '../../lib/platform';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { useScrollLock } from '../AppRoot/ScrollContext';\nimport { FixedLayout } from '../FixedLayout/FixedLayout';\nimport styles from './PanelHeaderContext.module.css';\n\nconst sizeXClassNames = {\n none: styles['PanelHeaderContext--sizeX-none'],\n [SizeType.COMPACT]: styles['PanelHeaderContext--sizeX-compact'],\n [SizeType.REGULAR]: styles['PanelHeaderContext--sizeX-regular'],\n};\n\nexport interface PanelHeaderContextProps extends React.HTMLAttributes<HTMLDivElement> {\n opened: boolean;\n onClose: VoidFunction;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/PanelHeaderContext\n */\nexport const PanelHeaderContext = ({\n children,\n onClose,\n opened = false,\n className,\n ...restProps\n}: PanelHeaderContextProps) => {\n const { document } = useDOM();\n const platform = usePlatform();\n const [visible, setVisible] = React.useState(opened);\n const closing = visible && !opened;\n const { sizeX = 'none' } = useAdaptivity();\n const elementRef = React.useRef<HTMLDivElement>(null);\n\n useIsomorphicLayoutEffect(() => {\n opened && setVisible(true);\n }, [opened]);\n\n useScrollLock(platform !== Platform.VKCOM && opened);\n\n // start closing on outer click\n useGlobalEventListener(\n document,\n 'click',\n opened &&\n !closing &&\n ((event) => {\n if (elementRef.current && !elementRef.current.contains(event.target as Node)) {\n event.stopPropagation();\n onClose();\n }\n }),\n { capture: true },\n );\n\n // fallback onAnimationEnd when animationend not supported\n const onAnimationEnd = () => setVisible(false);\n const animationFallback = useTimeout(onAnimationEnd, 200);\n React.useEffect(\n () => (closing ? animationFallback.set() : animationFallback.clear()),\n [animationFallback, closing],\n );\n\n return (\n <FixedLayout\n {...restProps}\n className={classNames(\n styles['PanelHeaderContext'],\n platform === Platform.IOS && styles['PanelHeaderContext--ios'],\n opened && styles['PanelHeaderContext--opened'],\n closing && styles['PanelHeaderContext--closing'],\n sizeXClassNames[sizeX],\n className,\n )}\n vertical=\"top\"\n >\n {visible && (\n <div\n onClick={(event) => {\n event.stopPropagation();\n onClose();\n }}\n className={styles['PanelHeaderContext__fade']}\n />\n )}\n <div\n className={styles['PanelHeaderContext__in']}\n ref={elementRef}\n onAnimationEnd={closing ? onAnimationEnd : undefined}\n >\n {visible && <div className={styles['PanelHeaderContext__content']}>{children}</div>}\n </div>\n </FixedLayout>\n );\n};\n"],"names":["React","classNames","useAdaptivity","useGlobalEventListener","usePlatform","useTimeout","SizeType","useDOM","Platform","useIsomorphicLayoutEffect","useScrollLock","FixedLayout","sizeXClassNames","none","COMPACT","REGULAR","PanelHeaderContext","children","onClose","opened","className","restProps","document","platform","useState","visible","setVisible","closing","sizeX","elementRef","useRef","VKCOM","event","current","contains","target","stopPropagation","capture","onAnimationEnd","animationFallback","useEffect","set","clear","IOS","vertical","div","onClick","ref","undefined"],"mappings":";;;;;AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,aAAa,QAAQ,4BAA4B;AAC1D,SAASC,sBAAsB,QAAQ,qCAAqC;AAC5E,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,UAAU,QAAQ,yBAAyB;AACpD,SAASC,QAAQ,QAAQ,uBAAuB;AAChD,SAASC,MAAM,QAAQ,gBAAgB;AACvC,SAASC,QAAQ,QAAQ,qBAAqB;AAC9C,SAASC,yBAAyB,QAAQ,sCAAsC;AAChF,SAASC,aAAa,QAAQ,2BAA2B;AACzD,SAASC,WAAW,QAAQ,6BAA6B;IAGjC;AAAxB,IAAMC,mBAAkB;IACtBC,IAAI;oBADkB,MAErBP,SAASQ,OAAO,6DAFK,MAGrBR,SAASS,OAAO,4CAHK;AAWxB;;CAEC,GACD,OAAO,IAAMC,qBAAqB,iBAMH;QAL7BC,kBAAAA,UACAC,iBAAAA,gCACAC,QAAAA,oCAAS,KAAK,kBACdC,mBAAAA,WACGC;QAJHJ;QACAC;QACAC;QACAC;;IAGA,IAAM,AAAEE,WAAaf,SAAbe;IACR,IAAMC,WAAWnB;IACjB,IAA8BJ,mCAAAA,MAAMwB,QAAQ,CAACL,aAAtCM,UAAuBzB,oBAAd0B,aAAc1B;IAC9B,IAAM2B,UAAUF,WAAW,CAACN;IAC5B,IAA2BjB,iBAAAA,wCAAAA,eAAnB0B,OAAAA,0CAAQ;IAChB,IAAMC,aAAa7B,MAAM8B,MAAM,CAAiB,IAAI;IAEpDrB,0BAA0B,WAAM;QAC9BU,UAAUO,WAAW,IAAI;IAC3B,GAAG;QAACP;KAAO;IAEXT,cAAca,aAAaf,SAASuB,KAAK,IAAIZ;IAE7C,+BAA+B;IAC/BhB,uBACEmB,UACA,SACAH,UACE,CAACQ,WACA,SAACK,OAAU;QACV,IAAIH,WAAWI,OAAO,IAAI,CAACJ,WAAWI,OAAO,CAACC,QAAQ,CAACF,MAAMG,MAAM,GAAW;YAC5EH,MAAMI,eAAe;YACrBlB;QACF,CAAC;IACH,GACF;QAAEmB,SAAS,IAAI;IAAC;IAGlB,0DAA0D;IAC1D,IAAMC,iBAAiB;eAAMZ,WAAW,KAAK;;IAC7C,IAAMa,oBAAoBlC,WAAWiC,gBAAgB;IACrDtC,MAAMwC,SAAS,CACb;eAAOb,UAAUY,kBAAkBE,GAAG,KAAKF,kBAAkBG,KAAK,EAAE;OACpE;QAACH;QAAmBZ;KAAQ;IAG9B,qBACE,oBAAChB,qDACKU;QACJD,WAAWnB,qCAETsB,aAAaf,SAASmC,GAAG,mCACzBxB,4CACAQ,8CACAf,eAAe,CAACgB,MAAM,EACtBR;QAEFwB,UAAS;QAERnB,yBACC,oBAACoB;QACCC,SAAS,SAACd,OAAU;YAClBA,MAAMI,eAAe;YACrBlB;QACF;QACAE,SAAS;sBAGb,oBAACyB;QACCzB,SAAS;QACT2B,KAAKlB;QACLS,gBAAgBX,UAAUW,iBAAiBU,SAAS;OAEnDvB,yBAAW,oBAACoB;QAAIzB,SAAS;OAA0CH;AAI5E,EAAE"}
@@ -10,7 +10,7 @@ export interface PlatformProviderProps {
10
10
  /**
11
11
  * Компонент, позволяющий переопределить платформу для части приложения
12
12
  *
13
- * @version 5.1.0
13
+ * @since 5.1.0
14
14
  * @see https://vkcom.github.io/VKUI/#/PlatformProvider
15
15
  */
16
16
  export declare function PlatformProvider({ value, children }: PlatformProviderProps): JSX.Element;
@@ -5,7 +5,7 @@ import { ConfigProviderOverride } from "../ConfigProvider/ConfigProviderOverride
5
5
  /**
6
6
  * Компонент, позволяющий переопределить платформу для части приложения
7
7
  *
8
- * @version 5.1.0
8
+ * @since 5.1.0
9
9
  * @see https://vkcom.github.io/VKUI/#/PlatformProvider
10
10
  */ export function PlatformProvider(param) {
11
11
  var value = param.value, children = param.children;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/PlatformProvider/PlatformProvider.tsx"],"sourcesContent":["import React from 'react';\nimport { useAppearance } from '../../hooks/useAppearance';\nimport { PlatformType } from '../../lib/platform';\nimport { TokensClassProvider } from '../../lib/tokensClassProvider';\nimport { ConfigProviderOverride } from '../ConfigProvider/ConfigProviderOverride';\n\nexport interface PlatformProviderProps {\n /**\n * Платформа\n */\n value: PlatformType;\n children: React.ReactNode;\n}\n\n/**\n * Компонент, позволяющий переопределить платформу для части приложения\n *\n * @version 5.1.0\n * @see https://vkcom.github.io/VKUI/#/PlatformProvider\n */\nexport function PlatformProvider({ value, children }: PlatformProviderProps) {\n const appearance = useAppearance();\n\n return (\n <ConfigProviderOverride platform={value}>\n <TokensClassProvider platform={value} appearance={appearance}>\n {children}\n </TokensClassProvider>\n </ConfigProviderOverride>\n );\n}\n"],"names":["React","useAppearance","TokensClassProvider","ConfigProviderOverride","PlatformProvider","value","children","appearance","platform"],"mappings":"AAAA,OAAOA,WAAW,QAAQ;AAC1B,SAASC,aAAa,QAAQ,4BAA4B;AAE1D,SAASC,mBAAmB,QAAQ,gCAAgC;AACpE,SAASC,sBAAsB,QAAQ,2CAA2C;AAUlF;;;;;CAKC,GACD,OAAO,SAASC,iBAAiB,KAA0C,EAAE;QAA1CC,QAAF,MAAEA,OAAOC,WAAT,MAASA;IACxC,IAAMC,aAAaN;IAEnB,qBACE,oBAACE;QAAuBK,UAAUH;qBAChC,oBAACH;QAAoBM,UAAUH;QAAOE,YAAYA;OAC/CD;AAIT,CAAC"}
1
+ {"version":3,"sources":["../../../src/components/PlatformProvider/PlatformProvider.tsx"],"sourcesContent":["import React from 'react';\nimport { useAppearance } from '../../hooks/useAppearance';\nimport { PlatformType } from '../../lib/platform';\nimport { TokensClassProvider } from '../../lib/tokensClassProvider';\nimport { ConfigProviderOverride } from '../ConfigProvider/ConfigProviderOverride';\n\nexport interface PlatformProviderProps {\n /**\n * Платформа\n */\n value: PlatformType;\n children: React.ReactNode;\n}\n\n/**\n * Компонент, позволяющий переопределить платформу для части приложения\n *\n * @since 5.1.0\n * @see https://vkcom.github.io/VKUI/#/PlatformProvider\n */\nexport function PlatformProvider({ value, children }: PlatformProviderProps) {\n const appearance = useAppearance();\n\n return (\n <ConfigProviderOverride platform={value}>\n <TokensClassProvider platform={value} appearance={appearance}>\n {children}\n </TokensClassProvider>\n </ConfigProviderOverride>\n );\n}\n"],"names":["React","useAppearance","TokensClassProvider","ConfigProviderOverride","PlatformProvider","value","children","appearance","platform"],"mappings":"AAAA,OAAOA,WAAW,QAAQ;AAC1B,SAASC,aAAa,QAAQ,4BAA4B;AAE1D,SAASC,mBAAmB,QAAQ,gCAAgC;AACpE,SAASC,sBAAsB,QAAQ,2CAA2C;AAUlF;;;;;CAKC,GACD,OAAO,SAASC,iBAAiB,KAA0C,EAAE;QAA1CC,QAAF,MAAEA,OAAOC,WAAT,MAASA;IACxC,IAAMC,aAAaN;IAEnB,qBACE,oBAACE;QAAuBK,UAAUH;qBAChC,oBAACH;QAAoBM,UAAUH;QAAOE,YAAYA;OAC/CD;AAIT,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/PopoutWrapper/PopoutWrapper.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useGlobalEventListener } from '../../hooks/useGlobalEventListener';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { useTimeout } from '../../hooks/useTimeout';\nimport { useDOM } from '../../lib/dom';\nimport { Platform } from '../../lib/platform';\nimport styles from './PopoutWrapper.module.css';\n\nexport interface PopoutWrapperProps extends React.HTMLAttributes<HTMLDivElement> {\n hasMask?: boolean;\n fixed?: boolean;\n alignY?: 'top' | 'center' | 'bottom';\n alignX?: 'left' | 'center' | 'right';\n closing?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/PopoutWrapper\n */\nexport const PopoutWrapper = ({\n alignY = 'center',\n alignX = 'center',\n closing = false,\n hasMask = true,\n fixed = true,\n children,\n onClick,\n className,\n ...restProps\n}: PopoutWrapperProps) => {\n const platform = usePlatform();\n const [opened, setOpened] = React.useState(!hasMask);\n const elRef = React.useRef<HTMLDivElement>(null);\n\n const onFadeInEnd = (e?: React.AnimationEvent) => {\n if (!e || e.animationName === 'vkui-animation-full-fade-in') {\n setOpened(true);\n }\n };\n const animationFinishFallback = useTimeout(onFadeInEnd, platform === Platform.IOS ? 300 : 200);\n React.useEffect(() => {\n !opened && animationFinishFallback.set();\n }, [animationFinishFallback, opened]);\n\n const { window } = useDOM();\n useGlobalEventListener(window, 'touchmove', (e) => e.preventDefault(), {\n passive: false,\n });\n\n return (\n <div\n {...restProps}\n className={classNames(\n styles['PopoutWrapper'],\n {\n center: styles['PopoutWrapper--alignY-center'],\n top: styles['PopoutWrapper--alignY-top'],\n bottom: styles['PopoutWrapper--alignY-bottom'],\n }[alignY],\n {\n center: styles['PopoutWrapper--alignX-center'],\n left: styles['PopoutWrapper--alignX-left'],\n right: styles['PopoutWrapper--alignX-right'],\n }[alignX],\n closing && styles['PopoutWrapper--closing'],\n opened && styles['PopoutWrapper--opened'],\n fixed && styles['PopoutWrapper--fixed'],\n hasMask && styles['PopoutWrapper--masked'],\n className,\n )}\n onAnimationEnd={opened ? undefined : onFadeInEnd}\n ref={elRef}\n >\n <div className={styles['PopoutWrapper__container']}>\n <div className={styles['PopoutWrapper__overlay']} onClick={onClick} />\n <div className={styles['PopoutWrapper__content']}>{children}</div>\n </div>\n </div>\n );\n};\n"],"names":["React","classNames","useGlobalEventListener","usePlatform","useTimeout","useDOM","Platform","PopoutWrapper","alignY","alignX","closing","hasMask","fixed","children","onClick","className","restProps","platform","useState","opened","setOpened","elRef","useRef","onFadeInEnd","e","animationName","animationFinishFallback","IOS","useEffect","set","window","preventDefault","passive","div","center","top","bottom","left","right","onAnimationEnd","undefined","ref"],"mappings":";;;;AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,sBAAsB,QAAQ,qCAAqC;AAC5E,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,UAAU,QAAQ,yBAAyB;AACpD,SAASC,MAAM,QAAQ,gBAAgB;AACvC,SAASC,QAAQ,QAAQ,qBAAqB;AAW9C;;CAEC,GACD,OAAO,IAAMC,gBAAgB,iBAUH;+BATxBC,QAAAA,oCAAS,iDACTC,QAAAA,oCAAS,kDACTC,SAAAA,sCAAU,KAAK,2CACfC,SAAAA,sCAAU,IAAI,yCACdC,OAAAA,kCAAQ,IAAI,iBACZC,kBAAAA,UACAC,iBAAAA,SACAC,mBAAAA,WACGC;QARHR;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;;IAGA,IAAME,WAAWd;IACjB,IAA4BH,mCAAAA,MAAMkB,QAAQ,CAAC,CAACP,cAArCQ,SAAqBnB,oBAAboB,YAAapB;IAC5B,IAAMqB,QAAQrB,MAAMsB,MAAM,CAAiB,IAAI;IAE/C,IAAMC,cAAc,SAACC,GAA6B;QAChD,IAAI,CAACA,KAAKA,EAAEC,aAAa,KAAK,+BAA+B;YAC3DL,UAAU,IAAI;QAChB,CAAC;IACH;IACA,IAAMM,0BAA0BtB,WAAWmB,aAAaN,aAAaX,SAASqB,GAAG,GAAG,MAAM,GAAG;IAC7F3B,MAAM4B,SAAS,CAAC,WAAM;QACpB,CAACT,UAAUO,wBAAwBG,GAAG;IACxC,GAAG;QAACH;QAAyBP;KAAO;IAEpC,IAAM,AAAEW,SAAWzB,SAAXyB;IACR5B,uBAAuB4B,QAAQ,aAAa,SAACN;eAAMA,EAAEO,cAAc;OAAI;QACrEC,SAAS,KAAK;IAChB;IAEA,qBACE,oBAACC,+CACKjB;QACJD,WAAWd,gCAET;YACEiC,MAAM;YACNC,GAAG;YACHC,MAAM;QACR,CAAC,CAAC5B,OAAO,EACT;YACE0B,MAAM;YACNG,IAAI;YACJC,KAAK;QACP,CAAC,CAAC7B,OAAO,EACTC,yCACAS,uCACAP,qCACAD,wCACAI;QAEFwB,gBAAgBpB,SAASqB,YAAYjB,WAAW;QAChDkB,KAAKpB;sBAEL,oBAACY;QAAIlB,SAAS;qBACZ,oBAACkB;QAAIlB,SAAS;QAAoCD,SAASA;sBAC3D,oBAACmB;QAAIlB,SAAS;OAAqCF;AAI3D,EAAE"}
1
+ {"version":3,"sources":["../../../src/components/PopoutWrapper/PopoutWrapper.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useGlobalEventListener } from '../../hooks/useGlobalEventListener';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { useTimeout } from '../../hooks/useTimeout';\nimport { useDOM } from '../../lib/dom';\nimport { Platform } from '../../lib/platform';\nimport styles from './PopoutWrapper.module.css';\n\nexport interface PopoutWrapperProps extends React.HTMLAttributes<HTMLDivElement> {\n hasMask?: boolean;\n fixed?: boolean;\n alignY?: 'top' | 'center' | 'bottom';\n alignX?: 'left' | 'center' | 'right';\n closing?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/PopoutWrapper\n */\nexport const PopoutWrapper = ({\n alignY = 'center',\n alignX = 'center',\n closing = false,\n hasMask = true,\n fixed = true,\n children,\n onClick,\n className,\n ...restProps\n}: PopoutWrapperProps) => {\n const platform = usePlatform();\n const [opened, setOpened] = React.useState(!hasMask);\n const elRef = React.useRef<HTMLDivElement>(null);\n\n const onFadeInEnd = (e?: React.AnimationEvent) => {\n if (!e || e.animationName === styles['vkui-animation-full-fade-in']) {\n setOpened(true);\n }\n };\n const animationFinishFallback = useTimeout(onFadeInEnd, platform === Platform.IOS ? 300 : 200);\n React.useEffect(() => {\n !opened && animationFinishFallback.set();\n }, [animationFinishFallback, opened]);\n\n const { window } = useDOM();\n useGlobalEventListener(window, 'touchmove', (e) => e.preventDefault(), {\n passive: false,\n });\n\n return (\n <div\n {...restProps}\n className={classNames(\n styles['PopoutWrapper'],\n {\n center: styles['PopoutWrapper--alignY-center'],\n top: styles['PopoutWrapper--alignY-top'],\n bottom: styles['PopoutWrapper--alignY-bottom'],\n }[alignY],\n {\n center: styles['PopoutWrapper--alignX-center'],\n left: styles['PopoutWrapper--alignX-left'],\n right: styles['PopoutWrapper--alignX-right'],\n }[alignX],\n closing && styles['PopoutWrapper--closing'],\n opened && styles['PopoutWrapper--opened'],\n fixed && styles['PopoutWrapper--fixed'],\n hasMask && styles['PopoutWrapper--masked'],\n className,\n )}\n onAnimationEnd={opened ? undefined : onFadeInEnd}\n ref={elRef}\n >\n <div className={styles['PopoutWrapper__container']}>\n <div className={styles['PopoutWrapper__overlay']} onClick={onClick} />\n <div className={styles['PopoutWrapper__content']}>{children}</div>\n </div>\n </div>\n );\n};\n"],"names":["React","classNames","useGlobalEventListener","usePlatform","useTimeout","useDOM","Platform","PopoutWrapper","alignY","alignX","closing","hasMask","fixed","children","onClick","className","restProps","platform","useState","opened","setOpened","elRef","useRef","onFadeInEnd","e","animationName","animationFinishFallback","IOS","useEffect","set","window","preventDefault","passive","div","center","top","bottom","left","right","onAnimationEnd","undefined","ref"],"mappings":";;;;AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,sBAAsB,QAAQ,qCAAqC;AAC5E,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,UAAU,QAAQ,yBAAyB;AACpD,SAASC,MAAM,QAAQ,gBAAgB;AACvC,SAASC,QAAQ,QAAQ,qBAAqB;AAW9C;;CAEC,GACD,OAAO,IAAMC,gBAAgB,iBAUH;+BATxBC,QAAAA,oCAAS,iDACTC,QAAAA,oCAAS,kDACTC,SAAAA,sCAAU,KAAK,2CACfC,SAAAA,sCAAU,IAAI,yCACdC,OAAAA,kCAAQ,IAAI,iBACZC,kBAAAA,UACAC,iBAAAA,SACAC,mBAAAA,WACGC;QARHR;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;;IAGA,IAAME,WAAWd;IACjB,IAA4BH,mCAAAA,MAAMkB,QAAQ,CAAC,CAACP,cAArCQ,SAAqBnB,oBAAboB,YAAapB;IAC5B,IAAMqB,QAAQrB,MAAMsB,MAAM,CAAiB,IAAI;IAE/C,IAAMC,cAAc,SAACC,GAA6B;QAChD,IAAI,CAACA,KAAKA,EAAEC,aAAa,oCAA4C;YACnEL,UAAU,IAAI;QAChB,CAAC;IACH;IACA,IAAMM,0BAA0BtB,WAAWmB,aAAaN,aAAaX,SAASqB,GAAG,GAAG,MAAM,GAAG;IAC7F3B,MAAM4B,SAAS,CAAC,WAAM;QACpB,CAACT,UAAUO,wBAAwBG,GAAG;IACxC,GAAG;QAACH;QAAyBP;KAAO;IAEpC,IAAM,AAAEW,SAAWzB,SAAXyB;IACR5B,uBAAuB4B,QAAQ,aAAa,SAACN;eAAMA,EAAEO,cAAc;OAAI;QACrEC,SAAS,KAAK;IAChB;IAEA,qBACE,oBAACC,+CACKjB;QACJD,WAAWd,gCAET;YACEiC,MAAM;YACNC,GAAG;YACHC,MAAM;QACR,CAAC,CAAC5B,OAAO,EACT;YACE0B,MAAM;YACNG,IAAI;YACJC,KAAK;QACP,CAAC,CAAC7B,OAAO,EACTC,yCACAS,uCACAP,qCACAD,wCACAI;QAEFwB,gBAAgBpB,SAASqB,YAAYjB,WAAW;QAChDkB,KAAKpB;sBAEL,oBAACY;QAAIlB,SAAS;qBACZ,oBAACkB;QAAIlB,SAAS;QAAoCD,SAASA;sBAC3D,oBAACmB;QAAIlB,SAAS;OAAqCF;AAI3D,EAAE"}
@@ -1,6 +1,7 @@
1
1
  import * as React from 'react';
2
+ import { FocusTrapProps } from '../FocusTrap/FocusTrap';
2
3
  import { PopperCommonProps } from '../Popper/Popper';
3
- export interface PopoverProps extends Omit<PopperCommonProps, 'arrow' | 'arrowClassName'> {
4
+ export interface PopoverProps extends Omit<PopperCommonProps, 'arrow' | 'arrowClassName' | 'content'>, Pick<FocusTrapProps, 'restoreFocus'> {
4
5
  /**
5
6
  * Механика вызова всплывающего окна.
6
7
  *
@@ -46,4 +47,4 @@ export interface PopoverProps extends Omit<PopperCommonProps, 'arrow' | 'arrowCl
46
47
  /**
47
48
  * @see https://vkcom.github.io/VKUI/#/Popover
48
49
  */
49
- export declare const Popover: ({ action, shown: shownProp, showDelay, hideDelay, offsetDistance, content, children, style: styleProp, className, getRef, onShownChange, ...restProps }: PopoverProps) => JSX.Element;
50
+ export declare const Popover: ({ action, shown: shownProp, showDelay, hideDelay, offsetDistance, content, children, style: styleProp, className, getRef, onShownChange, restoreFocus, ...restProps }: PopoverProps) => JSX.Element;