@vkontakte/vkui 4.28.0 → 4.29.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1753) hide show
  1. package/.browserslistrc +2 -0
  2. package/.cache/.eslintcache +1 -0
  3. package/.cache/.stylelintcache +1 -0
  4. package/.cache/.tsbuildinfo +53757 -0
  5. package/.cache/ts/src/appearance/constants.d.ts +1 -0
  6. package/.cache/ts/src/components/ActionSheet/ActionSheet.d.ts +26 -0
  7. package/.cache/ts/src/components/ActionSheet/ActionSheetContext.d.ts +8 -0
  8. package/.cache/ts/src/components/ActionSheet/ActionSheetDropdown.d.ts +4 -0
  9. package/.cache/ts/src/components/ActionSheet/ActionSheetDropdownDesktop.d.ts +4 -0
  10. package/.cache/ts/src/components/ActionSheet/types.d.ts +9 -0
  11. package/.cache/ts/src/components/ActionSheetItem/ActionSheetItem.d.ts +20 -0
  12. package/.cache/ts/src/components/AdaptivityProvider/AdaptivityContext.d.ts +46 -0
  13. package/.cache/ts/src/components/AdaptivityProvider/AdaptivityProvider.d.ts +10 -0
  14. package/.cache/ts/src/components/Alert/Alert.d.ts +27 -0
  15. package/.cache/ts/src/components/AppRoot/AppRoot.d.ts +14 -0
  16. package/.cache/ts/src/components/AppRoot/AppRootContext.d.ts +9 -0
  17. package/.cache/ts/src/components/AppRoot/AppRootPortal.d.ts +5 -0
  18. package/.cache/ts/src/components/AppRoot/ScrollContext.d.ts +15 -0
  19. package/.cache/ts/src/components/AppearanceProvider/AppearanceProvider.d.ts +7 -0
  20. package/.cache/ts/src/components/AppearanceProvider/AppearanceProviderContext.d.ts +3 -0
  21. package/.cache/ts/src/components/Avatar/Avatar.d.ts +22 -0
  22. package/.cache/ts/src/components/Badge/Badge.d.ts +6 -0
  23. package/.cache/ts/src/components/Banner/Banner.d.ts +65 -0
  24. package/.cache/ts/src/components/Button/Button.d.ts +19 -0
  25. package/.cache/ts/src/components/ButtonGroup/ButtonGroup.d.ts +20 -0
  26. package/.cache/ts/src/components/Calendar/Calendar.d.ts +21 -0
  27. package/.cache/ts/src/components/CalendarDay/CalendarDay.d.ts +22 -0
  28. package/.cache/ts/src/components/CalendarDays/CalendarDays.d.ts +22 -0
  29. package/.cache/ts/src/components/CalendarHeader/CalendarHeader.d.ts +16 -0
  30. package/.cache/ts/src/components/CalendarRange/CalendarRange.d.ts +16 -0
  31. package/.cache/ts/src/components/CalendarTime/CalendarTime.d.ts +11 -0
  32. package/.cache/ts/src/components/Card/Card.d.ts +7 -0
  33. package/.cache/ts/src/components/CardGrid/CardGrid.d.ts +8 -0
  34. package/.cache/ts/src/components/CardScroll/CardScroll.d.ts +12 -0
  35. package/.cache/ts/src/components/Cell/Cell.d.ts +47 -0
  36. package/.cache/ts/src/components/Cell/CellCheckbox/CellCheckbox.d.ts +5 -0
  37. package/.cache/ts/src/components/Cell/CellDragger/CellDragger.d.ts +6 -0
  38. package/.cache/ts/src/components/Cell/useDraggable.d.ts +13 -0
  39. package/.cache/ts/src/components/CellButton/CellButton.d.ts +9 -0
  40. package/.cache/ts/src/components/Checkbox/Checkbox.d.ts +10 -0
  41. package/.cache/ts/src/components/Chip/Chip.d.ts +16 -0
  42. package/.cache/ts/src/components/ChipsInput/ChipsInput.d.ts +29 -0
  43. package/.cache/ts/src/components/ChipsInput/useChipsInput.d.ts +14 -0
  44. package/.cache/ts/src/components/ChipsSelect/ChipsSelect.d.ts +40 -0
  45. package/.cache/ts/src/components/ChipsSelect/useChipsSelect.d.ts +22 -0
  46. package/.cache/ts/src/components/ClickPopper/ClickPopper.d.ts +21 -0
  47. package/.cache/ts/src/components/ConfigProvider/ConfigProvider.d.ts +16 -0
  48. package/.cache/ts/src/components/ConfigProvider/ConfigProviderContext.d.ts +36 -0
  49. package/.cache/ts/src/components/ContentCard/ContentCard.d.ts +34 -0
  50. package/.cache/ts/src/components/Counter/Counter.d.ts +11 -0
  51. package/.cache/ts/src/components/CustomScrollView/CustomScrollView.d.ts +10 -0
  52. package/.cache/ts/src/components/CustomSelect/CustomSelect.d.ts +65 -0
  53. package/.cache/ts/src/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +15 -0
  54. package/.cache/ts/src/components/CustomSelectOption/CustomSelectOption.d.ts +44 -0
  55. package/.cache/ts/src/components/DateInput/DateInput.d.ts +12 -0
  56. package/.cache/ts/src/components/DatePicker/DatePicker.d.ts +24 -0
  57. package/.cache/ts/src/components/DateRangeInput/DateRangeInput.d.ts +18 -0
  58. package/.cache/ts/src/components/Div/Div.d.ts +6 -0
  59. package/.cache/ts/src/components/Dropdown/Dropdown.d.ts +8 -0
  60. package/.cache/ts/src/components/DropdownIcon/DropdownIcon.d.ts +3 -0
  61. package/.cache/ts/src/components/Epic/Epic.d.ts +10 -0
  62. package/.cache/ts/src/components/Epic/ScrollSaver.d.ts +6 -0
  63. package/.cache/ts/src/components/File/File.d.ts +9 -0
  64. package/.cache/ts/src/components/FixedLayout/FixedLayout.d.ts +19 -0
  65. package/.cache/ts/src/components/FocusTrap/FocusTrap.d.ts +8 -0
  66. package/.cache/ts/src/components/FocusVisible/FocusVisible.d.ts +8 -0
  67. package/.cache/ts/src/components/Footer/Footer.d.ts +5 -0
  68. package/.cache/ts/src/components/FormField/FormField.d.ts +28 -0
  69. package/.cache/ts/src/components/FormItem/FormItem.d.ts +14 -0
  70. package/.cache/ts/src/components/FormLayout/FormLayout.d.ts +6 -0
  71. package/.cache/ts/src/components/FormLayoutGroup/FormLayoutGroup.d.ts +13 -0
  72. package/.cache/ts/src/components/FormStatus/FormStatus.d.ts +7 -0
  73. package/.cache/ts/src/components/Gallery/Gallery.d.ts +47 -0
  74. package/.cache/ts/src/components/Gradient/Gradient.d.ts +7 -0
  75. package/.cache/ts/src/components/GridAvatar/GridAvatar.d.ts +9 -0
  76. package/.cache/ts/src/components/Group/Group.d.ts +23 -0
  77. package/.cache/ts/src/components/Header/Header.d.ts +18 -0
  78. package/.cache/ts/src/components/HorizontalCell/HorizontalCell.d.ts +10 -0
  79. package/.cache/ts/src/components/HorizontalScroll/HorizontalScroll.d.ts +18 -0
  80. package/.cache/ts/src/components/HorizontalScroll/HorizontalScrollArrow.d.ts +8 -0
  81. package/.cache/ts/src/components/HoverPopper/HoverPopper.d.ts +29 -0
  82. package/.cache/ts/src/components/IconButton/IconButton.d.ts +11 -0
  83. package/.cache/ts/src/components/InfoRow/InfoRow.d.ts +7 -0
  84. package/.cache/ts/src/components/InitialsAvatar/InitialsAvatar.d.ts +32 -0
  85. package/.cache/ts/src/components/Input/Input.d.ts +8 -0
  86. package/.cache/ts/src/components/InputLike/InputLike.d.ts +10 -0
  87. package/.cache/ts/src/components/InputLike/InputLikeDivider.d.ts +3 -0
  88. package/.cache/ts/src/components/Link/Link.d.ts +6 -0
  89. package/.cache/ts/src/components/List/List.d.ts +4 -0
  90. package/.cache/ts/src/components/List/ListContext.d.ts +4 -0
  91. package/.cache/ts/src/components/LocaleProviderContext/LocaleProviderContext.d.ts +2 -0
  92. package/.cache/ts/src/components/MiniInfoCell/MiniInfoCell.d.ts +39 -0
  93. package/.cache/ts/src/components/ModalCard/ModalCard.d.ts +10 -0
  94. package/.cache/ts/src/components/ModalCardBase/ModalCardBase.d.ts +36 -0
  95. package/.cache/ts/src/components/ModalDismissButton/ModalDismissButton.d.ts +5 -0
  96. package/.cache/ts/src/components/ModalPage/ModalPage.d.ts +37 -0
  97. package/.cache/ts/src/components/ModalPageHeader/ModalPageHeader.d.ts +8 -0
  98. package/.cache/ts/src/components/ModalRoot/ModalRoot.d.ts +28 -0
  99. package/.cache/ts/src/components/ModalRoot/ModalRootAdaptive.d.ts +22 -0
  100. package/.cache/ts/src/components/ModalRoot/ModalRootContext.d.ts +20 -0
  101. package/.cache/ts/src/components/ModalRoot/ModalRootDesktop.d.ts +28 -0
  102. package/.cache/ts/src/components/ModalRoot/constants.d.ts +3 -0
  103. package/.cache/ts/src/components/ModalRoot/types.d.ts +60 -0
  104. package/.cache/ts/src/components/ModalRoot/useModalManager.d.ts +38 -0
  105. package/.cache/ts/src/components/ModalRoot/withModalRootContext.d.ts +5 -0
  106. package/.cache/ts/src/components/NativeSelect/NativeSelect.d.ts +14 -0
  107. package/.cache/ts/src/components/NavTransitionContext/NavTransitionContext.d.ts +7 -0
  108. package/.cache/ts/src/components/Pagination/Pagination.d.ts +42 -0
  109. package/.cache/ts/src/components/Panel/Panel.d.ts +9 -0
  110. package/.cache/ts/src/components/PanelHeader/PanelHeader.d.ts +21 -0
  111. package/.cache/ts/src/components/PanelHeaderBack/PanelHeaderBack.d.ts +9 -0
  112. package/.cache/ts/src/components/PanelHeaderButton/PanelHeaderButton.d.ts +8 -0
  113. package/.cache/ts/src/components/PanelHeaderClose/PanelHeaderClose.d.ts +4 -0
  114. package/.cache/ts/src/components/PanelHeaderContent/PanelHeaderContent.d.ts +9 -0
  115. package/.cache/ts/src/components/PanelHeaderContext/PanelHeaderContext.d.ts +7 -0
  116. package/.cache/ts/src/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +18 -0
  117. package/.cache/ts/src/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +4 -0
  118. package/.cache/ts/src/components/PanelSpinner/PanelSpinner.d.ts +7 -0
  119. package/.cache/ts/src/components/Placeholder/Placeholder.d.ts +23 -0
  120. package/.cache/ts/src/components/PopoutRoot/PopoutRoot.d.ts +10 -0
  121. package/.cache/ts/src/components/PopoutWrapper/PopoutWrapper.d.ts +10 -0
  122. package/.cache/ts/src/components/Popper/Popper.d.ts +32 -0
  123. package/.cache/ts/src/components/Progress/Progress.d.ts +8 -0
  124. package/.cache/ts/src/components/PromoBanner/PromoBanner.d.ts +40 -0
  125. package/.cache/ts/src/components/PullToRefresh/PullToRefresh.d.ts +37 -0
  126. package/.cache/ts/src/components/PullToRefresh/PullToRefreshSpinner.d.ts +11 -0
  127. package/.cache/ts/src/components/Radio/Radio.d.ts +9 -0
  128. package/.cache/ts/src/components/RadioGroup/RadioGroup.d.ts +6 -0
  129. package/.cache/ts/src/components/RangeSlider/RangeSlider.d.ts +6 -0
  130. package/.cache/ts/src/components/RangeSlider/UniversalSlider.d.ts +16 -0
  131. package/.cache/ts/src/components/Removable/Removable.d.ts +21 -0
  132. package/.cache/ts/src/components/RichCell/RichCell.d.ts +37 -0
  133. package/.cache/ts/src/components/RichTooltip/RichTooltip.d.ts +5 -0
  134. package/.cache/ts/src/components/Root/Root.d.ts +31 -0
  135. package/.cache/ts/src/components/ScreenSpinner/ScreenSpinner.d.ts +6 -0
  136. package/.cache/ts/src/components/Search/Search.d.ts +17 -0
  137. package/.cache/ts/src/components/SegmentedControl/SegmentedControl.d.ts +17 -0
  138. package/.cache/ts/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +4 -0
  139. package/.cache/ts/src/components/Select/Select.d.ts +6 -0
  140. package/.cache/ts/src/components/SelectMimicry/SelectMimicry.d.ts +14 -0
  141. package/.cache/ts/src/components/Separator/Separator.d.ts +11 -0
  142. package/.cache/ts/src/components/SimpleCell/SimpleCell.d.ts +39 -0
  143. package/.cache/ts/src/components/SimpleCheckbox/SimpleCheckbox.d.ts +8 -0
  144. package/.cache/ts/src/components/Slider/Slider.d.ts +5 -0
  145. package/.cache/ts/src/components/SliderSwitch/SliderSwitch.d.ts +47 -0
  146. package/.cache/ts/src/components/SliderSwitch/SliderSwitchButton.d.ts +11 -0
  147. package/.cache/ts/src/components/Snackbar/Snackbar.d.ts +35 -0
  148. package/.cache/ts/src/components/Spacing/Spacing.d.ts +18 -0
  149. package/.cache/ts/src/components/Spinner/Spinner.d.ts +7 -0
  150. package/.cache/ts/src/components/SplitCol/SplitCol.d.ts +22 -0
  151. package/.cache/ts/src/components/SplitLayout/SplitLayout.d.ts +15 -0
  152. package/.cache/ts/src/components/SubnavigationBar/SubnavigationBar.d.ts +7 -0
  153. package/.cache/ts/src/components/SubnavigationButton/SubnavigationButton.d.ts +21 -0
  154. package/.cache/ts/src/components/Switch/Switch.d.ts +7 -0
  155. package/.cache/ts/src/components/Tabbar/Tabbar.d.ts +11 -0
  156. package/.cache/ts/src/components/TabbarItem/TabbarItem.d.ts +21 -0
  157. package/.cache/ts/src/components/Tabs/Tabs.d.ts +10 -0
  158. package/.cache/ts/src/components/TabsItem/TabsItem.d.ts +8 -0
  159. package/.cache/ts/src/components/Tappable/Tappable.d.ts +42 -0
  160. package/.cache/ts/src/components/TextTooltip/TextTooltip.d.ts +14 -0
  161. package/.cache/ts/src/components/Textarea/Textarea.d.ts +11 -0
  162. package/.cache/ts/src/components/Tooltip/Tooltip.d.ts +55 -0
  163. package/.cache/ts/src/components/Tooltip/TooltipContainer.d.ts +5 -0
  164. package/.cache/ts/src/components/Touch/Touch.d.ts +49 -0
  165. package/.cache/ts/src/components/Touch/TouchContext.d.ts +7 -0
  166. package/.cache/ts/src/components/Typography/Caption/Caption.d.ts +14 -0
  167. package/.cache/ts/src/components/Typography/Headline/Headline.d.ts +8 -0
  168. package/.cache/ts/src/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  169. package/.cache/ts/src/components/Typography/Subhead/Subhead.d.ts +12 -0
  170. package/.cache/ts/src/components/Typography/Text/Text.d.ts +8 -0
  171. package/.cache/ts/src/components/Typography/Title/Title.d.ts +13 -0
  172. package/.cache/ts/src/components/UsersStack/UsersStack.d.ts +23 -0
  173. package/.cache/ts/src/components/UsersStack/masks.d.ts +1 -0
  174. package/.cache/ts/src/components/View/View.d.ts +80 -0
  175. package/.cache/ts/src/components/View/ViewInfinite.d.ts +66 -0
  176. package/.cache/ts/src/components/View/utils.d.ts +2 -0
  177. package/.cache/ts/src/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +12 -0
  178. package/.cache/ts/src/components/WriteBar/WriteBar.d.ts +23 -0
  179. package/.cache/ts/src/components/WriteBarIcon/WriteBarIcon.d.ts +18 -0
  180. package/.cache/ts/src/helpers/avatar.d.ts +5 -0
  181. package/.cache/ts/src/helpers/getClassName.d.ts +2 -0
  182. package/.cache/ts/src/helpers/getScheme.d.ts +8 -0
  183. package/.cache/ts/src/helpers/math.d.ts +5 -0
  184. package/.cache/ts/src/helpers/scheme.d.ts +34 -0
  185. package/.cache/ts/src/hoc/withAdaptivity.d.ts +13 -0
  186. package/.cache/ts/src/hoc/withContext.d.ts +2 -0
  187. package/.cache/ts/src/hoc/withInsets.d.ts +3 -0
  188. package/.cache/ts/src/hoc/withPlatform.d.ts +3 -0
  189. package/.cache/ts/src/hooks/useAdaptivity.d.ts +3 -0
  190. package/.cache/ts/src/hooks/useAppearance.d.ts +1 -0
  191. package/.cache/ts/src/hooks/useBooleanState.d.ts +6 -0
  192. package/.cache/ts/src/hooks/useBridgeAdaptivity.d.ts +6 -0
  193. package/.cache/ts/src/hooks/useBrowserInfo.d.ts +2 -0
  194. package/.cache/ts/src/hooks/useCalendar.d.ts +18 -0
  195. package/.cache/ts/src/hooks/useDateInput.d.ts +30 -0
  196. package/.cache/ts/src/hooks/useEffectDev.d.ts +2 -0
  197. package/.cache/ts/src/hooks/useEnsuredControl.d.ts +6 -0
  198. package/.cache/ts/src/hooks/useEventListener.d.ts +7 -0
  199. package/.cache/ts/src/hooks/useExternRef.d.ts +2 -0
  200. package/.cache/ts/src/hooks/useFocusVisible.d.ts +6 -0
  201. package/.cache/ts/src/hooks/useGlobalEventListener.d.ts +2 -0
  202. package/.cache/ts/src/hooks/useInsets.d.ts +8 -0
  203. package/.cache/ts/src/hooks/useKeyboard.d.ts +11 -0
  204. package/.cache/ts/src/hooks/useKeyboardInputTracker.d.ts +3 -0
  205. package/.cache/ts/src/hooks/useObjectMemo.d.ts +2 -0
  206. package/.cache/ts/src/hooks/useOrientationChange.d.ts +7 -0
  207. package/.cache/ts/src/hooks/usePagination.d.ts +34 -0
  208. package/.cache/ts/src/hooks/usePatchChildrenRef.d.ts +6 -0
  209. package/.cache/ts/src/hooks/usePlatform.d.ts +2 -0
  210. package/.cache/ts/src/hooks/useTimeout.d.ts +4 -0
  211. package/.cache/ts/src/hooks/useWaitTransitionFinish.d.ts +3 -0
  212. package/.cache/ts/src/index.d.ts +300 -0
  213. package/.cache/ts/src/lib/SSR.d.ts +14 -0
  214. package/.cache/ts/src/lib/accessibility.d.ts +10 -0
  215. package/.cache/ts/src/lib/animate.d.ts +15 -0
  216. package/.cache/ts/src/lib/browser.d.ts +11 -0
  217. package/.cache/ts/src/lib/calendar.d.ts +14 -0
  218. package/.cache/ts/src/lib/callMultiple.d.ts +1 -0
  219. package/.cache/ts/src/lib/classNames.d.ts +6 -0
  220. package/.cache/ts/src/lib/classScopingMode.d.ts +8 -0
  221. package/.cache/ts/src/lib/date.d.ts +29 -0
  222. package/.cache/ts/src/lib/dom.d.ts +21 -0
  223. package/.cache/ts/src/lib/fx.d.ts +5 -0
  224. package/.cache/ts/src/lib/getNavId.d.ts +7 -0
  225. package/.cache/ts/src/lib/is.d.ts +1 -0
  226. package/.cache/ts/src/lib/isRefObject.d.ts +2 -0
  227. package/.cache/ts/src/lib/jsxRuntime.d.ts +8 -0
  228. package/.cache/ts/src/lib/offset.d.ts +7 -0
  229. package/.cache/ts/src/lib/platform.d.ts +19 -0
  230. package/.cache/ts/src/lib/polyfills.d.ts +6 -0
  231. package/.cache/ts/src/lib/prefixClass.d.ts +1 -0
  232. package/.cache/ts/src/lib/removeObjectKeys.d.ts +1 -0
  233. package/.cache/ts/src/lib/select.d.ts +7 -0
  234. package/.cache/ts/src/lib/styles.d.ts +1 -0
  235. package/.cache/ts/src/lib/supportEvents.d.ts +9 -0
  236. package/.cache/ts/src/lib/taptic.d.ts +2 -0
  237. package/.cache/ts/src/lib/testing.d.ts +1 -0
  238. package/.cache/ts/src/lib/touch.d.ts +9 -0
  239. package/.cache/ts/src/lib/useIsomorphicLayoutEffect.d.ts +2 -0
  240. package/.cache/ts/src/lib/utils.d.ts +16 -0
  241. package/.cache/ts/src/lib/warnOnce.d.ts +2 -0
  242. package/.cache/ts/src/testing/setup.d.ts +1 -0
  243. package/.cache/ts/src/testing/utils.d.ts +31 -0
  244. package/.cache/ts/src/tokenized/index.d.ts +42 -0
  245. package/.cache/ts/src/types.d.ts +34 -0
  246. package/.cache/ts/src/unstable/index.d.ts +17 -0
  247. package/.codesandbox/ci.json +5 -0
  248. package/.editorconfig +14 -0
  249. package/.eslintignore +6 -0
  250. package/.eslintrc.json +151 -0
  251. package/.gitattributes +1 -0
  252. package/.gitmodules +0 -0
  253. package/.prettierignore +14 -0
  254. package/.prettierrc.json +1 -0
  255. package/.stylelintignore +2 -0
  256. package/CONTRIBUTING.md +3 -2
  257. package/CSS_GUIDE.md +145 -0
  258. package/TESTING.md +58 -0
  259. package/babel.cjs.config.js +15 -0
  260. package/babel.config.js +72 -0
  261. package/dist/cjs/components/ActionSheet/ActionSheet.js +8 -8
  262. package/dist/cjs/components/ActionSheet/ActionSheet.js.map +1 -1
  263. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js +2 -1
  264. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  265. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js +1 -1
  266. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  267. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js +10 -11
  268. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  269. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js +44 -11
  270. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  271. package/dist/cjs/components/Alert/Alert.d.ts +4 -1
  272. package/dist/cjs/components/Alert/Alert.js +32 -16
  273. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  274. package/dist/cjs/components/AppRoot/AppRoot.js +20 -3
  275. package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
  276. package/dist/cjs/components/AppRoot/ScrollContext.d.ts +6 -14
  277. package/dist/cjs/components/AppRoot/ScrollContext.js +94 -2
  278. package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
  279. package/dist/cjs/components/Avatar/Avatar.js +4 -1
  280. package/dist/cjs/components/Avatar/Avatar.js.map +1 -1
  281. package/dist/cjs/components/Banner/Banner.js +5 -4
  282. package/dist/cjs/components/Banner/Banner.js.map +1 -1
  283. package/dist/cjs/components/Button/Button.d.ts +1 -2
  284. package/dist/cjs/components/Button/Button.js +40 -49
  285. package/dist/cjs/components/Button/Button.js.map +1 -1
  286. package/dist/cjs/components/Calendar/Calendar.js +5 -5
  287. package/dist/cjs/components/Calendar/Calendar.js.map +1 -1
  288. package/dist/cjs/components/CalendarDay/CalendarDay.js +4 -1
  289. package/dist/cjs/components/CalendarDay/CalendarDay.js.map +1 -1
  290. package/dist/cjs/components/CalendarDays/CalendarDays.js +5 -5
  291. package/dist/cjs/components/CalendarDays/CalendarDays.js.map +1 -1
  292. package/dist/cjs/components/CalendarHeader/CalendarHeader.js +15 -15
  293. package/dist/cjs/components/CalendarHeader/CalendarHeader.js.map +1 -1
  294. package/dist/cjs/components/CalendarRange/CalendarRange.js +12 -15
  295. package/dist/cjs/components/CalendarRange/CalendarRange.js.map +1 -1
  296. package/dist/cjs/components/CalendarTime/CalendarTime.js +8 -10
  297. package/dist/cjs/components/CalendarTime/CalendarTime.js.map +1 -1
  298. package/dist/cjs/components/CardScroll/CardScroll.js +3 -2
  299. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  300. package/dist/cjs/components/Cell/Cell.d.ts +1 -1
  301. package/dist/cjs/components/Cell/Cell.js +4 -3
  302. package/dist/cjs/components/Cell/Cell.js.map +1 -1
  303. package/dist/cjs/components/CellButton/CellButton.js +1 -0
  304. package/dist/cjs/components/CellButton/CellButton.js.map +1 -1
  305. package/dist/cjs/components/Checkbox/Checkbox.js +2 -5
  306. package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
  307. package/dist/cjs/components/Chip/Chip.js +3 -4
  308. package/dist/cjs/components/Chip/Chip.js.map +1 -1
  309. package/dist/cjs/components/ChipsInput/ChipsInput.d.ts +1 -2
  310. package/dist/cjs/components/ChipsInput/ChipsInput.js +7 -10
  311. package/dist/cjs/components/ChipsInput/ChipsInput.js.map +1 -1
  312. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts +2 -2
  313. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +10 -16
  314. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  315. package/dist/cjs/components/ClickPopper/ClickPopper.d.ts +1 -1
  316. package/dist/cjs/components/ClickPopper/ClickPopper.js.map +1 -1
  317. package/dist/cjs/components/ConfigProvider/ConfigProvider.js +1 -1
  318. package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
  319. package/dist/cjs/components/ContentCard/ContentCard.js +9 -10
  320. package/dist/cjs/components/ContentCard/ContentCard.js.map +1 -1
  321. package/dist/cjs/components/Counter/Counter.js +3 -3
  322. package/dist/cjs/components/Counter/Counter.js.map +1 -1
  323. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +2 -2
  324. package/dist/cjs/components/CustomSelect/CustomSelect.js +45 -43
  325. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  326. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js +1 -5
  327. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  328. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  329. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js +26 -18
  330. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  331. package/dist/cjs/components/DateInput/DateInput.js +5 -5
  332. package/dist/cjs/components/DateInput/DateInput.js.map +1 -1
  333. package/dist/cjs/components/DatePicker/DatePicker.js +6 -6
  334. package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
  335. package/dist/cjs/components/DateRangeInput/DateRangeInput.js +7 -7
  336. package/dist/cjs/components/DateRangeInput/DateRangeInput.js.map +1 -1
  337. package/dist/cjs/components/Epic/Epic.js +1 -1
  338. package/dist/cjs/components/Epic/Epic.js.map +1 -1
  339. package/dist/cjs/components/File/File.js +2 -2
  340. package/dist/cjs/components/File/File.js.map +1 -1
  341. package/dist/cjs/components/FixedLayout/FixedLayout.js +2 -1
  342. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  343. package/dist/cjs/components/Footer/Footer.js +2 -4
  344. package/dist/cjs/components/Footer/Footer.js.map +1 -1
  345. package/dist/cjs/components/FormField/FormField.d.ts +15 -1
  346. package/dist/cjs/components/FormField/FormField.js +8 -8
  347. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  348. package/dist/cjs/components/FormItem/FormItem.js +6 -7
  349. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  350. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  351. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  352. package/dist/cjs/components/FormStatus/FormStatus.js +3 -8
  353. package/dist/cjs/components/FormStatus/FormStatus.js.map +1 -1
  354. package/dist/cjs/components/Gallery/Gallery.d.ts +9 -1
  355. package/dist/cjs/components/Gallery/Gallery.js +10 -2
  356. package/dist/cjs/components/Gallery/Gallery.js.map +1 -1
  357. package/dist/cjs/components/GridAvatar/GridAvatar.d.ts +1 -0
  358. package/dist/cjs/components/GridAvatar/GridAvatar.js +6 -6
  359. package/dist/cjs/components/GridAvatar/GridAvatar.js.map +1 -1
  360. package/dist/cjs/components/Group/Group.js +5 -6
  361. package/dist/cjs/components/Group/Group.js.map +1 -1
  362. package/dist/cjs/components/Header/Header.js +18 -24
  363. package/dist/cjs/components/Header/Header.js.map +1 -1
  364. package/dist/cjs/components/HorizontalCell/HorizontalCell.js +6 -9
  365. package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
  366. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  367. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js +34 -24
  368. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  369. package/dist/cjs/components/InfoRow/InfoRow.js +2 -2
  370. package/dist/cjs/components/InfoRow/InfoRow.js.map +1 -1
  371. package/dist/cjs/components/Input/Input.d.ts +1 -2
  372. package/dist/cjs/components/Input/Input.js +13 -15
  373. package/dist/cjs/components/Input/Input.js.map +1 -1
  374. package/dist/cjs/components/List/List.js +1 -0
  375. package/dist/cjs/components/List/List.js.map +1 -1
  376. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js +1 -0
  377. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  378. package/dist/cjs/components/ModalCard/ModalCard.d.ts +1 -1
  379. package/dist/cjs/components/ModalCard/ModalCard.js +1 -0
  380. package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
  381. package/dist/cjs/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  382. package/dist/cjs/components/ModalCardBase/ModalCardBase.js +10 -4
  383. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  384. package/dist/cjs/components/ModalPage/ModalPage.d.ts +16 -1
  385. package/dist/cjs/components/ModalPage/ModalPage.js +10 -6
  386. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  387. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js +1 -0
  388. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  389. package/dist/cjs/components/ModalRoot/ModalRoot.d.ts +14 -2
  390. package/dist/cjs/components/ModalRoot/ModalRoot.js +14 -11
  391. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  392. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  393. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js +3 -0
  394. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  395. package/dist/cjs/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  396. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +10 -7
  397. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  398. package/dist/cjs/components/ModalRoot/types.d.ts +16 -1
  399. package/dist/cjs/components/ModalRoot/types.js.map +1 -1
  400. package/dist/cjs/components/ModalRoot/useModalManager.d.ts +6 -5
  401. package/dist/cjs/components/ModalRoot/useModalManager.js +54 -16
  402. package/dist/cjs/components/ModalRoot/useModalManager.js.map +1 -1
  403. package/dist/cjs/components/NativeSelect/NativeSelect.d.ts +1 -2
  404. package/dist/cjs/components/NativeSelect/NativeSelect.js +7 -8
  405. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  406. package/dist/cjs/components/Pagination/Pagination.d.ts +3 -3
  407. package/dist/cjs/components/Pagination/Pagination.js +3 -3
  408. package/dist/cjs/components/Pagination/Pagination.js.map +1 -1
  409. package/dist/cjs/components/Panel/Panel.js +2 -1
  410. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  411. package/dist/cjs/components/PanelHeader/PanelHeader.js +1 -0
  412. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  413. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js +1 -0
  414. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  415. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js +5 -4
  416. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  417. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js +2 -4
  418. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  419. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js +5 -1
  420. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  421. package/dist/cjs/components/Placeholder/Placeholder.js +4 -3
  422. package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
  423. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js +1 -0
  424. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  425. package/dist/cjs/components/Popper/Popper.js +2 -2
  426. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  427. package/dist/cjs/components/PromoBanner/PromoBanner.js +5 -9
  428. package/dist/cjs/components/PromoBanner/PromoBanner.js.map +1 -1
  429. package/dist/cjs/components/PullToRefresh/PullToRefresh.js +2 -1
  430. package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
  431. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js +1 -0
  432. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  433. package/dist/cjs/components/Radio/Radio.js +2 -5
  434. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  435. package/dist/cjs/components/RichCell/RichCell.js +3 -2
  436. package/dist/cjs/components/RichCell/RichCell.js.map +1 -1
  437. package/dist/cjs/components/RichTooltip/RichTooltip.js +2 -1
  438. package/dist/cjs/components/RichTooltip/RichTooltip.js.map +1 -1
  439. package/dist/cjs/components/Root/Root.js +8 -7
  440. package/dist/cjs/components/Root/Root.js.map +1 -1
  441. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js +3 -0
  442. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  443. package/dist/cjs/components/Search/Search.js +3 -2
  444. package/dist/cjs/components/Search/Search.js.map +1 -1
  445. package/dist/cjs/components/SegmentedControl/SegmentedControl.js +19 -13
  446. package/dist/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
  447. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
  448. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  449. package/dist/cjs/components/Select/Select.d.ts +1 -2
  450. package/dist/cjs/components/Select/Select.js +9 -11
  451. package/dist/cjs/components/Select/Select.js.map +1 -1
  452. package/dist/cjs/components/SelectMimicry/SelectMimicry.d.ts +3 -3
  453. package/dist/cjs/components/SelectMimicry/SelectMimicry.js +5 -2
  454. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  455. package/dist/cjs/components/Separator/Separator.js +3 -1
  456. package/dist/cjs/components/Separator/Separator.js.map +1 -1
  457. package/dist/cjs/components/SimpleCell/SimpleCell.js +5 -4
  458. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  459. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js +6 -2
  460. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  461. package/dist/cjs/components/SliderSwitch/SliderSwitch.js +1 -0
  462. package/dist/cjs/components/SliderSwitch/SliderSwitch.js.map +1 -1
  463. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js +1 -0
  464. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  465. package/dist/cjs/components/Snackbar/Snackbar.js +3 -2
  466. package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
  467. package/dist/cjs/components/Spacing/Spacing.js +2 -1
  468. package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
  469. package/dist/cjs/components/SplitCol/SplitCol.js +2 -1
  470. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  471. package/dist/cjs/components/SplitLayout/SplitLayout.js +2 -1
  472. package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
  473. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js +2 -2
  474. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  475. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js +7 -7
  476. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  477. package/dist/cjs/components/Switch/Switch.js +1 -0
  478. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  479. package/dist/cjs/components/Tabbar/Tabbar.js +1 -0
  480. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  481. package/dist/cjs/components/TabbarItem/TabbarItem.d.ts +1 -1
  482. package/dist/cjs/components/TabbarItem/TabbarItem.js +2 -1
  483. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  484. package/dist/cjs/components/TabsItem/TabsItem.js +3 -2
  485. package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
  486. package/dist/cjs/components/Tappable/Tappable.js +5 -4
  487. package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
  488. package/dist/cjs/components/TextTooltip/TextTooltip.js +3 -3
  489. package/dist/cjs/components/TextTooltip/TextTooltip.js.map +1 -1
  490. package/dist/cjs/components/Tooltip/Tooltip.js +6 -6
  491. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  492. package/dist/cjs/components/Touch/Touch.js +9 -3
  493. package/dist/cjs/components/Touch/Touch.js.map +1 -1
  494. package/dist/cjs/components/Touch/TouchContext.d.ts +1 -1
  495. package/dist/cjs/components/Touch/TouchContext.js +1 -1
  496. package/dist/cjs/components/Touch/TouchContext.js.map +1 -1
  497. package/dist/cjs/components/Typography/Caption/Caption.d.ts +8 -4
  498. package/dist/cjs/components/Typography/Caption/Caption.js +12 -14
  499. package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
  500. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  501. package/dist/cjs/components/Typography/Paragraph/Paragraph.js +42 -0
  502. package/dist/cjs/components/Typography/Paragraph/Paragraph.js.map +1 -0
  503. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts +4 -3
  504. package/dist/cjs/components/Typography/Subhead/Subhead.js +4 -6
  505. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  506. package/dist/cjs/components/Typography/Text/Text.js +1 -1
  507. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  508. package/dist/cjs/components/Typography/Title/Title.d.ts +4 -3
  509. package/dist/cjs/components/Typography/Title/Title.js +5 -9
  510. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  511. package/dist/cjs/components/UsersStack/UsersStack.js +6 -6
  512. package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
  513. package/dist/cjs/components/View/View.js +5 -0
  514. package/dist/cjs/components/View/View.js.map +1 -1
  515. package/dist/cjs/components/View/ViewInfinite.js +5 -0
  516. package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
  517. package/dist/cjs/components/View/utils.js +5 -2
  518. package/dist/cjs/components/View/utils.js.map +1 -1
  519. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js +3 -2
  520. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  521. package/dist/cjs/helpers/scheme.js +2 -2
  522. package/dist/cjs/helpers/scheme.js.map +1 -1
  523. package/dist/cjs/hooks/useBridgeAdaptivity.d.ts +6 -0
  524. package/dist/cjs/hooks/useBridgeAdaptivity.js +85 -0
  525. package/dist/cjs/hooks/useBridgeAdaptivity.js.map +1 -0
  526. package/dist/cjs/hooks/useCalendar.js +6 -6
  527. package/dist/cjs/hooks/useCalendar.js.map +1 -1
  528. package/dist/cjs/hooks/useKeyboard.d.ts +1 -1
  529. package/dist/cjs/hooks/useKeyboard.js +1 -1
  530. package/dist/cjs/hooks/useKeyboard.js.map +1 -1
  531. package/dist/cjs/hooks/useOrientationChange.d.ts +7 -0
  532. package/dist/cjs/hooks/useOrientationChange.js +56 -0
  533. package/dist/cjs/hooks/useOrientationChange.js.map +1 -0
  534. package/dist/cjs/hooks/usePagination.d.ts +3 -3
  535. package/dist/cjs/hooks/usePagination.js +3 -3
  536. package/dist/cjs/hooks/usePagination.js.map +1 -1
  537. package/dist/cjs/hooks/usePatchChildrenRef.js +1 -1
  538. package/dist/cjs/hooks/usePatchChildrenRef.js.map +1 -1
  539. package/dist/cjs/hooks/useWaitTransitionFinish.js +6 -1
  540. package/dist/cjs/hooks/useWaitTransitionFinish.js.map +1 -1
  541. package/dist/cjs/index.d.ts +22 -11
  542. package/dist/cjs/index.js +30 -22
  543. package/dist/cjs/index.js.map +1 -1
  544. package/dist/cjs/lib/calendar.js +12 -23
  545. package/dist/cjs/lib/calendar.js.map +1 -1
  546. package/dist/cjs/lib/date.d.ts +29 -0
  547. package/dist/cjs/lib/date.js +286 -0
  548. package/dist/cjs/lib/date.js.map +1 -0
  549. package/dist/cjs/lib/getNavId.d.ts +2 -1
  550. package/dist/cjs/lib/getNavId.js +1 -1
  551. package/dist/cjs/lib/getNavId.js.map +1 -1
  552. package/dist/cjs/lib/platform.js +29 -0
  553. package/dist/cjs/lib/platform.js.map +1 -1
  554. package/dist/cjs/lib/warnOnce.d.ts +2 -1
  555. package/dist/cjs/lib/warnOnce.js +3 -1
  556. package/dist/cjs/lib/warnOnce.js.map +1 -1
  557. package/dist/cjs/tokenized/index.d.ts +24 -4
  558. package/dist/cjs/tokenized/index.js +88 -10
  559. package/dist/cjs/tokenized/index.js.map +1 -1
  560. package/dist/components/ActionSheet/ActionSheet.js +5 -6
  561. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  562. package/dist/components/ActionSheet/ActionSheetDropdown.js +2 -1
  563. package/dist/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  564. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js +1 -1
  565. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  566. package/dist/components/ActionSheetItem/ActionSheetItem.js +6 -7
  567. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  568. package/dist/components/AdaptivityProvider/AdaptivityProvider.js +43 -11
  569. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  570. package/dist/components/Alert/Alert.d.ts +4 -1
  571. package/dist/components/Alert/Alert.js +25 -11
  572. package/dist/components/Alert/Alert.js.map +1 -1
  573. package/dist/components/AppRoot/AppRoot.js +19 -3
  574. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  575. package/dist/components/AppRoot/ScrollContext.d.ts +6 -14
  576. package/dist/components/AppRoot/ScrollContext.js +87 -1
  577. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  578. package/dist/components/Avatar/Avatar.js +4 -1
  579. package/dist/components/Avatar/Avatar.js.map +1 -1
  580. package/dist/components/Banner/Banner.js +3 -2
  581. package/dist/components/Banner/Banner.js.map +1 -1
  582. package/dist/components/Button/Button.d.ts +1 -2
  583. package/dist/components/Button/Button.js +32 -40
  584. package/dist/components/Button/Button.js.map +1 -1
  585. package/dist/components/Calendar/Calendar.js +3 -3
  586. package/dist/components/Calendar/Calendar.js.map +1 -1
  587. package/dist/components/CalendarDay/CalendarDay.js +4 -1
  588. package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
  589. package/dist/components/CalendarDays/CalendarDays.js +2 -2
  590. package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
  591. package/dist/components/CalendarHeader/CalendarHeader.js +8 -8
  592. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
  593. package/dist/components/CalendarRange/CalendarRange.js +2 -5
  594. package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
  595. package/dist/components/CalendarTime/CalendarTime.js +3 -3
  596. package/dist/components/CalendarTime/CalendarTime.js.map +1 -1
  597. package/dist/components/CardScroll/CardScroll.js +2 -1
  598. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  599. package/dist/components/Cell/Cell.d.ts +1 -1
  600. package/dist/components/Cell/Cell.js +4 -3
  601. package/dist/components/Cell/Cell.js.map +1 -1
  602. package/dist/components/CellButton/CellButton.js +1 -0
  603. package/dist/components/CellButton/CellButton.js.map +1 -1
  604. package/dist/components/Checkbox/Checkbox.js +1 -4
  605. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  606. package/dist/components/Chip/Chip.js +2 -3
  607. package/dist/components/Chip/Chip.js.map +1 -1
  608. package/dist/components/ChipsInput/ChipsInput.d.ts +1 -2
  609. package/dist/components/ChipsInput/ChipsInput.js +6 -11
  610. package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
  611. package/dist/components/ChipsSelect/ChipsSelect.d.ts +2 -2
  612. package/dist/components/ChipsSelect/ChipsSelect.js +4 -9
  613. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  614. package/dist/components/ClickPopper/ClickPopper.d.ts +1 -1
  615. package/dist/components/ClickPopper/ClickPopper.js.map +1 -1
  616. package/dist/components/ConfigProvider/ConfigProvider.js +1 -1
  617. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  618. package/dist/components/ContentCard/ContentCard.js +6 -7
  619. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  620. package/dist/components/Counter/Counter.js +2 -2
  621. package/dist/components/Counter/Counter.js.map +1 -1
  622. package/dist/components/CustomSelect/CustomSelect.d.ts +2 -2
  623. package/dist/components/CustomSelect/CustomSelect.js +40 -36
  624. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  625. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js +1 -5
  626. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  627. package/dist/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  628. package/dist/components/CustomSelectOption/CustomSelectOption.js +20 -18
  629. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  630. package/dist/components/DateInput/DateInput.js +3 -3
  631. package/dist/components/DateInput/DateInput.js.map +1 -1
  632. package/dist/components/DatePicker/DatePicker.js +2 -2
  633. package/dist/components/DatePicker/DatePicker.js.map +1 -1
  634. package/dist/components/DateRangeInput/DateRangeInput.js +2 -2
  635. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  636. package/dist/components/Epic/Epic.js +1 -1
  637. package/dist/components/Epic/Epic.js.map +1 -1
  638. package/dist/components/File/File.js +1 -1
  639. package/dist/components/File/File.js.map +1 -1
  640. package/dist/components/FixedLayout/FixedLayout.js +2 -1
  641. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  642. package/dist/components/Footer/Footer.js +1 -3
  643. package/dist/components/Footer/Footer.js.map +1 -1
  644. package/dist/components/FormField/FormField.d.ts +15 -1
  645. package/dist/components/FormField/FormField.js +8 -8
  646. package/dist/components/FormField/FormField.js.map +1 -1
  647. package/dist/components/FormItem/FormItem.js +4 -5
  648. package/dist/components/FormItem/FormItem.js.map +1 -1
  649. package/dist/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  650. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  651. package/dist/components/FormStatus/FormStatus.js +2 -7
  652. package/dist/components/FormStatus/FormStatus.js.map +1 -1
  653. package/dist/components/Gallery/Gallery.d.ts +9 -1
  654. package/dist/components/Gallery/Gallery.js +10 -2
  655. package/dist/components/Gallery/Gallery.js.map +1 -1
  656. package/dist/components/GridAvatar/GridAvatar.d.ts +1 -0
  657. package/dist/components/GridAvatar/GridAvatar.js +5 -6
  658. package/dist/components/GridAvatar/GridAvatar.js.map +1 -1
  659. package/dist/components/Group/Group.js +4 -5
  660. package/dist/components/Group/Group.js.map +1 -1
  661. package/dist/components/Header/Header.js +13 -19
  662. package/dist/components/Header/Header.js.map +1 -1
  663. package/dist/components/HorizontalCell/HorizontalCell.js +3 -6
  664. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  665. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  666. package/dist/components/HorizontalScroll/HorizontalScroll.js +32 -21
  667. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  668. package/dist/components/InfoRow/InfoRow.js +1 -1
  669. package/dist/components/InfoRow/InfoRow.js.map +1 -1
  670. package/dist/components/Input/Input.d.ts +1 -2
  671. package/dist/components/Input/Input.js +10 -10
  672. package/dist/components/Input/Input.js.map +1 -1
  673. package/dist/components/List/List.js +1 -0
  674. package/dist/components/List/List.js.map +1 -1
  675. package/dist/components/MiniInfoCell/MiniInfoCell.js +1 -0
  676. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  677. package/dist/components/ModalCard/ModalCard.d.ts +1 -1
  678. package/dist/components/ModalCard/ModalCard.js +1 -0
  679. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  680. package/dist/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  681. package/dist/components/ModalCardBase/ModalCardBase.js +9 -3
  682. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  683. package/dist/components/ModalPage/ModalPage.d.ts +16 -1
  684. package/dist/components/ModalPage/ModalPage.js +9 -6
  685. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  686. package/dist/components/ModalPageHeader/ModalPageHeader.js +1 -0
  687. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  688. package/dist/components/ModalRoot/ModalRoot.d.ts +14 -2
  689. package/dist/components/ModalRoot/ModalRoot.js +14 -11
  690. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  691. package/dist/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  692. package/dist/components/ModalRoot/ModalRootAdaptive.js +2 -0
  693. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  694. package/dist/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  695. package/dist/components/ModalRoot/ModalRootDesktop.js +10 -7
  696. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  697. package/dist/components/ModalRoot/types.d.ts +16 -1
  698. package/dist/components/ModalRoot/types.js.map +1 -1
  699. package/dist/components/ModalRoot/useModalManager.d.ts +6 -5
  700. package/dist/components/ModalRoot/useModalManager.js +54 -16
  701. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  702. package/dist/components/NativeSelect/NativeSelect.d.ts +1 -2
  703. package/dist/components/NativeSelect/NativeSelect.js +5 -5
  704. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  705. package/dist/components/Pagination/Pagination.d.ts +3 -3
  706. package/dist/components/Pagination/Pagination.js +1 -1
  707. package/dist/components/Pagination/Pagination.js.map +1 -1
  708. package/dist/components/Panel/Panel.js +2 -1
  709. package/dist/components/Panel/Panel.js.map +1 -1
  710. package/dist/components/PanelHeader/PanelHeader.js +1 -0
  711. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  712. package/dist/components/PanelHeaderBack/PanelHeaderBack.js +1 -0
  713. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  714. package/dist/components/PanelHeaderButton/PanelHeaderButton.js +4 -3
  715. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  716. package/dist/components/PanelHeaderContent/PanelHeaderContent.js +1 -3
  717. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  718. package/dist/components/PanelHeaderContext/PanelHeaderContext.js +4 -1
  719. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  720. package/dist/components/Placeholder/Placeholder.js +3 -2
  721. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  722. package/dist/components/PopoutWrapper/PopoutWrapper.js +1 -0
  723. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  724. package/dist/components/Popper/Popper.js +2 -2
  725. package/dist/components/Popper/Popper.js.map +1 -1
  726. package/dist/components/PromoBanner/PromoBanner.js +2 -6
  727. package/dist/components/PromoBanner/PromoBanner.js.map +1 -1
  728. package/dist/components/PullToRefresh/PullToRefresh.js +2 -1
  729. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  730. package/dist/components/PullToRefresh/PullToRefreshSpinner.js +1 -0
  731. package/dist/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  732. package/dist/components/Radio/Radio.js +1 -4
  733. package/dist/components/Radio/Radio.js.map +1 -1
  734. package/dist/components/RichCell/RichCell.js +2 -1
  735. package/dist/components/RichCell/RichCell.js.map +1 -1
  736. package/dist/components/RichTooltip/RichTooltip.js +2 -1
  737. package/dist/components/RichTooltip/RichTooltip.js.map +1 -1
  738. package/dist/components/Root/Root.js +8 -7
  739. package/dist/components/Root/Root.js.map +1 -1
  740. package/dist/components/ScreenSpinner/ScreenSpinner.js +2 -0
  741. package/dist/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  742. package/dist/components/Search/Search.js +2 -1
  743. package/dist/components/Search/Search.js.map +1 -1
  744. package/dist/components/SegmentedControl/SegmentedControl.js +19 -13
  745. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  746. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
  747. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  748. package/dist/components/Select/Select.d.ts +1 -2
  749. package/dist/components/Select/Select.js +5 -6
  750. package/dist/components/Select/Select.js.map +1 -1
  751. package/dist/components/SelectMimicry/SelectMimicry.d.ts +3 -3
  752. package/dist/components/SelectMimicry/SelectMimicry.js +5 -2
  753. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  754. package/dist/components/Separator/Separator.js +3 -1
  755. package/dist/components/Separator/Separator.js.map +1 -1
  756. package/dist/components/SimpleCell/SimpleCell.js +3 -2
  757. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  758. package/dist/components/SimpleCheckbox/SimpleCheckbox.js +6 -2
  759. package/dist/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  760. package/dist/components/SliderSwitch/SliderSwitch.js +1 -0
  761. package/dist/components/SliderSwitch/SliderSwitch.js.map +1 -1
  762. package/dist/components/SliderSwitch/SliderSwitchButton.js +1 -0
  763. package/dist/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  764. package/dist/components/Snackbar/Snackbar.js +2 -1
  765. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  766. package/dist/components/Spacing/Spacing.js +2 -1
  767. package/dist/components/Spacing/Spacing.js.map +1 -1
  768. package/dist/components/SplitCol/SplitCol.js +2 -1
  769. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  770. package/dist/components/SplitLayout/SplitLayout.js +2 -1
  771. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  772. package/dist/components/SubnavigationBar/SubnavigationBar.js +1 -1
  773. package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  774. package/dist/components/SubnavigationButton/SubnavigationButton.js +5 -5
  775. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  776. package/dist/components/Switch/Switch.js +1 -0
  777. package/dist/components/Switch/Switch.js.map +1 -1
  778. package/dist/components/Tabbar/Tabbar.js +1 -0
  779. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  780. package/dist/components/TabbarItem/TabbarItem.d.ts +1 -1
  781. package/dist/components/TabbarItem/TabbarItem.js +2 -1
  782. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  783. package/dist/components/TabsItem/TabsItem.js +2 -1
  784. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  785. package/dist/components/Tappable/Tappable.js +5 -4
  786. package/dist/components/Tappable/Tappable.js.map +1 -1
  787. package/dist/components/TextTooltip/TextTooltip.js +1 -1
  788. package/dist/components/TextTooltip/TextTooltip.js.map +1 -1
  789. package/dist/components/Tooltip/Tooltip.js +4 -4
  790. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  791. package/dist/components/Touch/Touch.js +9 -3
  792. package/dist/components/Touch/Touch.js.map +1 -1
  793. package/dist/components/Touch/TouchContext.d.ts +1 -1
  794. package/dist/components/Touch/TouchContext.js +1 -1
  795. package/dist/components/Touch/TouchContext.js.map +1 -1
  796. package/dist/components/Typography/Caption/Caption.d.ts +8 -4
  797. package/dist/components/Typography/Caption/Caption.js +10 -14
  798. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  799. package/dist/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  800. package/dist/components/Typography/Paragraph/Paragraph.js +25 -0
  801. package/dist/components/Typography/Paragraph/Paragraph.js.map +1 -0
  802. package/dist/components/Typography/Subhead/Subhead.d.ts +4 -3
  803. package/dist/components/Typography/Subhead/Subhead.js +3 -7
  804. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  805. package/dist/components/Typography/Text/Text.js +1 -1
  806. package/dist/components/Typography/Text/Text.js.map +1 -1
  807. package/dist/components/Typography/Title/Title.d.ts +4 -3
  808. package/dist/components/Typography/Title/Title.js +3 -8
  809. package/dist/components/Typography/Title/Title.js.map +1 -1
  810. package/dist/components/UsersStack/UsersStack.js +4 -4
  811. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  812. package/dist/components/View/View.js +5 -0
  813. package/dist/components/View/View.js.map +1 -1
  814. package/dist/components/View/ViewInfinite.js +5 -0
  815. package/dist/components/View/ViewInfinite.js.map +1 -1
  816. package/dist/components/View/utils.js +5 -2
  817. package/dist/components/View/utils.js.map +1 -1
  818. package/dist/components/WriteBarIcon/WriteBarIcon.js +3 -2
  819. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  820. package/dist/components.css +21 -6
  821. package/dist/components.css.map +1 -1
  822. package/dist/cssm/components/ActionSheet/ActionSheet.js +5 -6
  823. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  824. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js +2 -1
  825. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  826. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js +1 -1
  827. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  828. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js +6 -7
  829. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  830. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js +43 -11
  831. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  832. package/dist/cssm/components/Alert/Alert.css +1 -1
  833. package/dist/cssm/components/Alert/Alert.d.ts +4 -1
  834. package/dist/cssm/components/Alert/Alert.js +25 -11
  835. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  836. package/dist/cssm/components/AppRoot/AppRoot.js +19 -3
  837. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  838. package/dist/cssm/components/AppRoot/ScrollContext.d.ts +6 -14
  839. package/dist/cssm/components/AppRoot/ScrollContext.js +87 -1
  840. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  841. package/dist/cssm/components/Avatar/Avatar.js +4 -1
  842. package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
  843. package/dist/cssm/components/Banner/Banner.js +3 -2
  844. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  845. package/dist/cssm/components/Button/Button.css +1 -1
  846. package/dist/cssm/components/Button/Button.d.ts +1 -2
  847. package/dist/cssm/components/Button/Button.js +32 -40
  848. package/dist/cssm/components/Button/Button.js.map +1 -1
  849. package/dist/cssm/components/Calendar/Calendar.js +3 -3
  850. package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
  851. package/dist/cssm/components/CalendarDay/CalendarDay.css +1 -1
  852. package/dist/cssm/components/CalendarDay/CalendarDay.js +4 -1
  853. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
  854. package/dist/cssm/components/CalendarDays/CalendarDays.js +2 -2
  855. package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
  856. package/dist/cssm/components/CalendarHeader/CalendarHeader.js +8 -8
  857. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
  858. package/dist/cssm/components/CalendarRange/CalendarRange.js +2 -5
  859. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
  860. package/dist/cssm/components/CalendarTime/CalendarTime.js +3 -3
  861. package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -1
  862. package/dist/cssm/components/Card/Card.css +1 -1
  863. package/dist/cssm/components/CardScroll/CardScroll.js +2 -1
  864. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  865. package/dist/cssm/components/Cell/Cell.d.ts +1 -1
  866. package/dist/cssm/components/Cell/Cell.js +4 -3
  867. package/dist/cssm/components/Cell/Cell.js.map +1 -1
  868. package/dist/cssm/components/CellButton/CellButton.js +1 -0
  869. package/dist/cssm/components/CellButton/CellButton.js.map +1 -1
  870. package/dist/cssm/components/Checkbox/Checkbox.js +1 -4
  871. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  872. package/dist/cssm/components/Chip/Chip.js +2 -3
  873. package/dist/cssm/components/Chip/Chip.js.map +1 -1
  874. package/dist/cssm/components/ChipsInput/ChipsInput.css +1 -1
  875. package/dist/cssm/components/ChipsInput/ChipsInput.d.ts +1 -2
  876. package/dist/cssm/components/ChipsInput/ChipsInput.js +6 -11
  877. package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
  878. package/dist/cssm/components/ChipsSelect/ChipsSelect.css +1 -1
  879. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts +2 -2
  880. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +4 -9
  881. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  882. package/dist/cssm/components/ClickPopper/ClickPopper.d.ts +1 -1
  883. package/dist/cssm/components/ClickPopper/ClickPopper.js.map +1 -1
  884. package/dist/cssm/components/ConfigProvider/ConfigProvider.js +1 -1
  885. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  886. package/dist/cssm/components/ContentCard/ContentCard.js +6 -7
  887. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  888. package/dist/cssm/components/Counter/Counter.js +2 -2
  889. package/dist/cssm/components/Counter/Counter.js.map +1 -1
  890. package/dist/cssm/components/CustomSelect/CustomSelect.css +1 -1
  891. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +2 -2
  892. package/dist/cssm/components/CustomSelect/CustomSelect.js +40 -36
  893. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  894. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.css +3 -1
  895. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js +1 -5
  896. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  897. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.css +3 -1
  898. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  899. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js +20 -18
  900. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  901. package/dist/cssm/components/DateInput/DateInput.css +1 -1
  902. package/dist/cssm/components/DateInput/DateInput.js +3 -3
  903. package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
  904. package/dist/cssm/components/DatePicker/DatePicker.js +2 -2
  905. package/dist/cssm/components/DatePicker/DatePicker.js.map +1 -1
  906. package/dist/cssm/components/DateRangeInput/DateRangeInput.css +1 -1
  907. package/dist/cssm/components/DateRangeInput/DateRangeInput.js +2 -2
  908. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  909. package/dist/cssm/components/Epic/Epic.js +1 -1
  910. package/dist/cssm/components/Epic/Epic.js.map +1 -1
  911. package/dist/cssm/components/File/File.js +1 -1
  912. package/dist/cssm/components/File/File.js.map +1 -1
  913. package/dist/cssm/components/FixedLayout/FixedLayout.css +1 -1
  914. package/dist/cssm/components/FixedLayout/FixedLayout.js +2 -1
  915. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  916. package/dist/cssm/components/Footer/Footer.js +1 -3
  917. package/dist/cssm/components/Footer/Footer.js.map +1 -1
  918. package/dist/cssm/components/FormField/FormField.css +5 -1
  919. package/dist/cssm/components/FormField/FormField.d.ts +15 -1
  920. package/dist/cssm/components/FormField/FormField.js +8 -8
  921. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  922. package/dist/cssm/components/FormItem/FormItem.js +4 -5
  923. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  924. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  925. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  926. package/dist/cssm/components/FormStatus/FormStatus.css +1 -1
  927. package/dist/cssm/components/FormStatus/FormStatus.js +2 -7
  928. package/dist/cssm/components/FormStatus/FormStatus.js.map +1 -1
  929. package/dist/cssm/components/Gallery/Gallery.d.ts +9 -1
  930. package/dist/cssm/components/Gallery/Gallery.js +10 -2
  931. package/dist/cssm/components/Gallery/Gallery.js.map +1 -1
  932. package/dist/cssm/components/Gradient/Gradient.css +1 -1
  933. package/dist/cssm/components/GridAvatar/GridAvatar.css +1 -1
  934. package/dist/cssm/components/GridAvatar/GridAvatar.d.ts +1 -0
  935. package/dist/cssm/components/GridAvatar/GridAvatar.js +5 -6
  936. package/dist/cssm/components/GridAvatar/GridAvatar.js.map +1 -1
  937. package/dist/cssm/components/Group/Group.js +4 -5
  938. package/dist/cssm/components/Group/Group.js.map +1 -1
  939. package/dist/cssm/components/Header/Header.js +13 -19
  940. package/dist/cssm/components/Header/Header.js.map +1 -1
  941. package/dist/cssm/components/HorizontalCell/HorizontalCell.js +3 -6
  942. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  943. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  944. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +32 -21
  945. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  946. package/dist/cssm/components/InfoRow/InfoRow.js +1 -1
  947. package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
  948. package/dist/cssm/components/Input/Input.css +1 -1
  949. package/dist/cssm/components/Input/Input.d.ts +1 -2
  950. package/dist/cssm/components/Input/Input.js +10 -10
  951. package/dist/cssm/components/Input/Input.js.map +1 -1
  952. package/dist/cssm/components/InputLike/InputLike.css +1 -1
  953. package/dist/cssm/components/InputLike/InputLikeDivider.css +1 -1
  954. package/dist/cssm/components/List/List.js +1 -0
  955. package/dist/cssm/components/List/List.js.map +1 -1
  956. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js +1 -0
  957. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  958. package/dist/cssm/components/ModalCard/ModalCard.css +1 -1
  959. package/dist/cssm/components/ModalCard/ModalCard.d.ts +1 -1
  960. package/dist/cssm/components/ModalCard/ModalCard.js +1 -0
  961. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  962. package/dist/cssm/components/ModalCardBase/ModalCardBase.css +1 -1
  963. package/dist/cssm/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  964. package/dist/cssm/components/ModalCardBase/ModalCardBase.js +9 -3
  965. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  966. package/dist/cssm/components/ModalPage/ModalPage.d.ts +16 -1
  967. package/dist/cssm/components/ModalPage/ModalPage.js +9 -6
  968. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  969. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js +1 -0
  970. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  971. package/dist/cssm/components/ModalRoot/ModalRoot.css +1 -1
  972. package/dist/cssm/components/ModalRoot/ModalRoot.d.ts +14 -2
  973. package/dist/cssm/components/ModalRoot/ModalRoot.js +14 -11
  974. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  975. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  976. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js +2 -0
  977. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  978. package/dist/cssm/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  979. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +10 -7
  980. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  981. package/dist/cssm/components/ModalRoot/types.d.ts +16 -1
  982. package/dist/cssm/components/ModalRoot/types.js.map +1 -1
  983. package/dist/cssm/components/ModalRoot/useModalManager.d.ts +6 -5
  984. package/dist/cssm/components/ModalRoot/useModalManager.js +54 -16
  985. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  986. package/dist/cssm/components/NativeSelect/NativeSelect.d.ts +1 -2
  987. package/dist/cssm/components/NativeSelect/NativeSelect.js +5 -5
  988. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  989. package/dist/cssm/components/Pagination/Pagination.css +1 -1
  990. package/dist/cssm/components/Pagination/Pagination.d.ts +3 -3
  991. package/dist/cssm/components/Pagination/Pagination.js +1 -1
  992. package/dist/cssm/components/Pagination/Pagination.js.map +1 -1
  993. package/dist/cssm/components/Panel/Panel.js +2 -1
  994. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  995. package/dist/cssm/components/PanelHeader/PanelHeader.css +1 -1
  996. package/dist/cssm/components/PanelHeader/PanelHeader.js +1 -0
  997. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  998. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js +1 -0
  999. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  1000. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.css +1 -1
  1001. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js +4 -3
  1002. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  1003. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.css +1 -1
  1004. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js +1 -3
  1005. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  1006. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js +4 -1
  1007. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  1008. package/dist/cssm/components/Placeholder/Placeholder.js +3 -2
  1009. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  1010. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +1 -0
  1011. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  1012. package/dist/cssm/components/Popper/Popper.js +2 -2
  1013. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  1014. package/dist/cssm/components/PromoBanner/PromoBanner.js +2 -6
  1015. package/dist/cssm/components/PromoBanner/PromoBanner.js.map +1 -1
  1016. package/dist/cssm/components/PullToRefresh/PullToRefresh.js +2 -1
  1017. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  1018. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js +1 -0
  1019. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  1020. package/dist/cssm/components/Radio/Radio.js +1 -4
  1021. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  1022. package/dist/cssm/components/Removable/Removable.css +1 -1
  1023. package/dist/cssm/components/RichCell/RichCell.js +2 -1
  1024. package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
  1025. package/dist/cssm/components/RichTooltip/RichTooltip.js +2 -1
  1026. package/dist/cssm/components/RichTooltip/RichTooltip.js.map +1 -1
  1027. package/dist/cssm/components/Root/Root.css +1 -1
  1028. package/dist/cssm/components/Root/Root.js +8 -7
  1029. package/dist/cssm/components/Root/Root.js.map +1 -1
  1030. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js +2 -0
  1031. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  1032. package/dist/cssm/components/Search/Search.css +1 -1
  1033. package/dist/cssm/components/Search/Search.js +2 -1
  1034. package/dist/cssm/components/Search/Search.js.map +1 -1
  1035. package/dist/cssm/components/SegmentedControl/SegmentedControl.js +19 -13
  1036. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  1037. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +1 -1
  1038. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
  1039. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  1040. package/dist/cssm/components/Select/Select.css +1 -1
  1041. package/dist/cssm/components/Select/Select.d.ts +1 -2
  1042. package/dist/cssm/components/Select/Select.js +5 -6
  1043. package/dist/cssm/components/Select/Select.js.map +1 -1
  1044. package/dist/cssm/components/SelectMimicry/SelectMimicry.d.ts +3 -3
  1045. package/dist/cssm/components/SelectMimicry/SelectMimicry.js +5 -2
  1046. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  1047. package/dist/cssm/components/Separator/Separator.js +3 -1
  1048. package/dist/cssm/components/Separator/Separator.js.map +1 -1
  1049. package/dist/cssm/components/SimpleCell/SimpleCell.css +1 -1
  1050. package/dist/cssm/components/SimpleCell/SimpleCell.js +3 -2
  1051. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  1052. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js +6 -2
  1053. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  1054. package/dist/cssm/components/SliderSwitch/SliderSwitch.js +1 -0
  1055. package/dist/cssm/components/SliderSwitch/SliderSwitch.js.map +1 -1
  1056. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js +1 -0
  1057. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  1058. package/dist/cssm/components/Snackbar/Snackbar.css +1 -1
  1059. package/dist/cssm/components/Snackbar/Snackbar.js +2 -1
  1060. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  1061. package/dist/cssm/components/Spacing/Spacing.js +2 -1
  1062. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  1063. package/dist/cssm/components/SplitCol/SplitCol.js +2 -1
  1064. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  1065. package/dist/cssm/components/SplitLayout/SplitLayout.css +1 -1
  1066. package/dist/cssm/components/SplitLayout/SplitLayout.js +2 -1
  1067. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  1068. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js +1 -1
  1069. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  1070. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +5 -5
  1071. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  1072. package/dist/cssm/components/Switch/Switch.js +1 -0
  1073. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  1074. package/dist/cssm/components/Tabbar/Tabbar.js +1 -0
  1075. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  1076. package/dist/cssm/components/TabbarItem/TabbarItem.css +1 -1
  1077. package/dist/cssm/components/TabbarItem/TabbarItem.d.ts +1 -1
  1078. package/dist/cssm/components/TabbarItem/TabbarItem.js +2 -1
  1079. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  1080. package/dist/cssm/components/Tabs/Tabs.css +1 -1
  1081. package/dist/cssm/components/TabsItem/TabsItem.js +2 -1
  1082. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  1083. package/dist/cssm/components/Tappable/Tappable.css +1 -1
  1084. package/dist/cssm/components/Tappable/Tappable.js +5 -4
  1085. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  1086. package/dist/cssm/components/TextTooltip/TextTooltip.js +1 -1
  1087. package/dist/cssm/components/TextTooltip/TextTooltip.js.map +1 -1
  1088. package/dist/cssm/components/Textarea/Textarea.css +1 -1
  1089. package/dist/cssm/components/Tooltip/Tooltip.js +4 -4
  1090. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  1091. package/dist/cssm/components/Touch/Touch.js +9 -3
  1092. package/dist/cssm/components/Touch/Touch.js.map +1 -1
  1093. package/dist/cssm/components/Touch/TouchContext.d.ts +1 -1
  1094. package/dist/cssm/components/Touch/TouchContext.js +1 -1
  1095. package/dist/cssm/components/Touch/TouchContext.js.map +1 -1
  1096. package/dist/cssm/components/Typography/Caption/Caption.css +1 -1
  1097. package/dist/cssm/components/Typography/Caption/Caption.d.ts +8 -4
  1098. package/dist/cssm/components/Typography/Caption/Caption.js +10 -14
  1099. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  1100. package/dist/cssm/components/Typography/Headline/Headline.css +1 -1
  1101. package/dist/cssm/components/Typography/Paragraph/Paragraph.css +1 -0
  1102. package/dist/cssm/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  1103. package/dist/cssm/components/Typography/Paragraph/Paragraph.js +26 -0
  1104. package/dist/cssm/components/Typography/Paragraph/Paragraph.js.map +1 -0
  1105. package/dist/cssm/components/Typography/Subhead/Subhead.css +1 -1
  1106. package/dist/cssm/components/Typography/Subhead/Subhead.d.ts +4 -3
  1107. package/dist/cssm/components/Typography/Subhead/Subhead.js +3 -7
  1108. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  1109. package/dist/cssm/components/Typography/Text/Text.css +1 -1
  1110. package/dist/cssm/components/Typography/Text/Text.js +1 -1
  1111. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  1112. package/dist/cssm/components/Typography/Title/Title.css +1 -1
  1113. package/dist/cssm/components/Typography/Title/Title.d.ts +4 -3
  1114. package/dist/cssm/components/Typography/Title/Title.js +3 -8
  1115. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  1116. package/dist/cssm/components/UsersStack/UsersStack.js +4 -4
  1117. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  1118. package/dist/cssm/components/View/View.css +1 -1
  1119. package/dist/cssm/components/View/View.js +5 -0
  1120. package/dist/cssm/components/View/View.js.map +1 -1
  1121. package/dist/cssm/components/View/ViewIOS.css +1 -1
  1122. package/dist/cssm/components/View/ViewInfinite.js +5 -0
  1123. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  1124. package/dist/cssm/components/View/utils.js +5 -2
  1125. package/dist/cssm/components/View/utils.js.map +1 -1
  1126. package/dist/cssm/components/WriteBar/WriteBar.css +1 -1
  1127. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +3 -2
  1128. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1129. package/dist/cssm/helpers/scheme.js +2 -2
  1130. package/dist/cssm/helpers/scheme.js.map +1 -1
  1131. package/dist/cssm/hooks/useBridgeAdaptivity.d.ts +6 -0
  1132. package/dist/cssm/hooks/useBridgeAdaptivity.js +68 -0
  1133. package/dist/cssm/hooks/useBridgeAdaptivity.js.map +1 -0
  1134. package/dist/cssm/hooks/useCalendar.js +1 -1
  1135. package/dist/cssm/hooks/useCalendar.js.map +1 -1
  1136. package/dist/cssm/hooks/useKeyboard.d.ts +1 -1
  1137. package/dist/cssm/hooks/useKeyboard.js +1 -1
  1138. package/dist/cssm/hooks/useKeyboard.js.map +1 -1
  1139. package/dist/cssm/hooks/useOrientationChange.d.ts +7 -0
  1140. package/dist/cssm/hooks/useOrientationChange.js +42 -0
  1141. package/dist/cssm/hooks/useOrientationChange.js.map +1 -0
  1142. package/dist/cssm/hooks/usePagination.d.ts +3 -3
  1143. package/dist/cssm/hooks/usePagination.js +3 -3
  1144. package/dist/cssm/hooks/usePagination.js.map +1 -1
  1145. package/dist/cssm/hooks/usePatchChildrenRef.js +1 -1
  1146. package/dist/cssm/hooks/usePatchChildrenRef.js.map +1 -1
  1147. package/dist/cssm/hooks/useWaitTransitionFinish.js +5 -1
  1148. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  1149. package/dist/cssm/index.d.ts +22 -11
  1150. package/dist/cssm/index.js +13 -15
  1151. package/dist/cssm/index.js.map +1 -1
  1152. package/dist/cssm/lib/calendar.js +4 -15
  1153. package/dist/cssm/lib/calendar.js.map +1 -1
  1154. package/dist/cssm/lib/date.d.ts +29 -0
  1155. package/dist/cssm/lib/date.js +223 -0
  1156. package/dist/cssm/lib/date.js.map +1 -0
  1157. package/dist/cssm/lib/getNavId.d.ts +2 -1
  1158. package/dist/cssm/lib/getNavId.js +1 -1
  1159. package/dist/cssm/lib/getNavId.js.map +1 -1
  1160. package/dist/cssm/lib/platform.js +26 -0
  1161. package/dist/cssm/lib/platform.js.map +1 -1
  1162. package/dist/cssm/lib/warnOnce.d.ts +2 -1
  1163. package/dist/cssm/lib/warnOnce.js +3 -1
  1164. package/dist/cssm/lib/warnOnce.js.map +1 -1
  1165. package/dist/cssm/styles/bright_light.css +1 -1
  1166. package/dist/cssm/styles/common.css +1 -1
  1167. package/dist/cssm/styles/components.css +21 -6
  1168. package/dist/cssm/styles/constants.css +9 -2
  1169. package/dist/cssm/styles/space_gray.css +1 -1
  1170. package/dist/cssm/styles/themes.css +3 -3
  1171. package/dist/cssm/styles/unstable.css +1 -1
  1172. package/dist/cssm/styles/vkcom_dark.css +2 -2
  1173. package/dist/cssm/styles/vkcom_light.css +1 -1
  1174. package/dist/cssm/tokenized/index.d.ts +24 -4
  1175. package/dist/cssm/tokenized/index.js +14 -4
  1176. package/dist/cssm/tokenized/index.js.map +1 -1
  1177. package/dist/default_scheme.css +1 -1
  1178. package/dist/default_scheme.css.map +1 -1
  1179. package/dist/helpers/scheme.js +2 -2
  1180. package/dist/helpers/scheme.js.map +1 -1
  1181. package/dist/hooks/useBridgeAdaptivity.d.ts +6 -0
  1182. package/dist/hooks/useBridgeAdaptivity.js +68 -0
  1183. package/dist/hooks/useBridgeAdaptivity.js.map +1 -0
  1184. package/dist/hooks/useCalendar.js +1 -1
  1185. package/dist/hooks/useCalendar.js.map +1 -1
  1186. package/dist/hooks/useKeyboard.d.ts +1 -1
  1187. package/dist/hooks/useKeyboard.js +1 -1
  1188. package/dist/hooks/useKeyboard.js.map +1 -1
  1189. package/dist/hooks/useOrientationChange.d.ts +7 -0
  1190. package/dist/hooks/useOrientationChange.js +42 -0
  1191. package/dist/hooks/useOrientationChange.js.map +1 -0
  1192. package/dist/hooks/usePagination.d.ts +3 -3
  1193. package/dist/hooks/usePagination.js +3 -3
  1194. package/dist/hooks/usePagination.js.map +1 -1
  1195. package/dist/hooks/usePatchChildrenRef.js +1 -1
  1196. package/dist/hooks/usePatchChildrenRef.js.map +1 -1
  1197. package/dist/hooks/useWaitTransitionFinish.js +5 -1
  1198. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  1199. package/dist/index.d.ts +22 -11
  1200. package/dist/index.js +13 -15
  1201. package/dist/index.js.map +1 -1
  1202. package/dist/lib/calendar.js +4 -15
  1203. package/dist/lib/calendar.js.map +1 -1
  1204. package/dist/lib/date.d.ts +29 -0
  1205. package/dist/lib/date.js +223 -0
  1206. package/dist/lib/date.js.map +1 -0
  1207. package/dist/lib/getNavId.d.ts +2 -1
  1208. package/dist/lib/getNavId.js +1 -1
  1209. package/dist/lib/getNavId.js.map +1 -1
  1210. package/dist/lib/platform.js +26 -0
  1211. package/dist/lib/platform.js.map +1 -1
  1212. package/dist/lib/warnOnce.d.ts +2 -1
  1213. package/dist/lib/warnOnce.js +3 -1
  1214. package/dist/lib/warnOnce.js.map +1 -1
  1215. package/dist/tokenized/index.d.ts +24 -4
  1216. package/dist/tokenized/index.js +14 -4
  1217. package/dist/tokenized/index.js.map +1 -1
  1218. package/dist/unstable.css +1 -1
  1219. package/dist/unstable.css.map +1 -1
  1220. package/dist/vkui.css +24 -9
  1221. package/dist/vkui.css.map +1 -1
  1222. package/eslint-plugin-vkui/index.js +64 -0
  1223. package/eslint-plugin-vkui/package.json +5 -0
  1224. package/jest.unit.config.js +17 -0
  1225. package/package.json +10 -12
  1226. package/postcss-plugin-vk-sans/__tests__/custom_properties.css +4 -0
  1227. package/postcss-plugin-vk-sans/index.js +350 -0
  1228. package/src/appearance/constants.ts +1 -0
  1229. package/src/components/ActionSheet/ActionSheet.css +145 -0
  1230. package/src/components/ActionSheet/ActionSheet.tsx +164 -0
  1231. package/src/components/ActionSheet/ActionSheetContext.ts +18 -0
  1232. package/src/components/ActionSheet/ActionSheetDropdown.tsx +34 -0
  1233. package/src/components/ActionSheet/ActionSheetDropdownDesktop.tsx +97 -0
  1234. package/src/components/ActionSheet/Readme.md +257 -0
  1235. package/src/components/ActionSheet/types.ts +16 -0
  1236. package/src/components/ActionSheetItem/ActionSheetItem.css +306 -0
  1237. package/src/components/ActionSheetItem/ActionSheetItem.tsx +183 -0
  1238. package/src/components/ActionSheetItem/Readme.md +2 -0
  1239. package/src/components/AdaptivityProvider/AdaptivityContext.tsx +62 -0
  1240. package/src/components/AdaptivityProvider/AdaptivityProvider.tsx +169 -0
  1241. package/src/components/AdaptivityProvider/Readme.md +3 -0
  1242. package/src/components/Alert/Alert.css +297 -0
  1243. package/src/components/Alert/Alert.tsx +308 -0
  1244. package/src/components/Alert/Readme.md +133 -0
  1245. package/src/components/AppRoot/AppRoot.css +20 -0
  1246. package/src/components/AppRoot/AppRoot.tsx +221 -0
  1247. package/src/components/AppRoot/AppRootContext.ts +13 -0
  1248. package/src/components/AppRoot/AppRootPortal.tsx +24 -0
  1249. package/src/components/AppRoot/Readme.md +9 -0
  1250. package/src/components/AppRoot/ScrollContext.ts +132 -0
  1251. package/src/components/AppearanceProvider/AppearanceProvider.tsx +61 -0
  1252. package/src/components/AppearanceProvider/AppearanceProviderContext.tsx +7 -0
  1253. package/src/components/Avatar/Avatar.css +192 -0
  1254. package/src/components/Avatar/Avatar.tsx +186 -0
  1255. package/src/components/Avatar/Readme.md +838 -0
  1256. package/src/components/Badge/Badge.css +21 -0
  1257. package/src/components/Badge/Badge.tsx +27 -0
  1258. package/src/components/Badge/Readme.md +55 -0
  1259. package/src/components/Banner/Banner.css +154 -0
  1260. package/src/components/Banner/Banner.tsx +221 -0
  1261. package/src/components/Banner/Readme.md +215 -0
  1262. package/src/components/Button/Button.css +596 -0
  1263. package/src/components/Button/Button.tsx +214 -0
  1264. package/src/components/Button/Readme.md +186 -0
  1265. package/src/components/ButtonGroup/ButtonGroup.css +52 -0
  1266. package/src/components/ButtonGroup/ButtonGroup.tsx +48 -0
  1267. package/src/components/ButtonGroup/Readme.md +311 -0
  1268. package/src/components/Calendar/Calendar.css +31 -0
  1269. package/src/components/Calendar/Calendar.tsx +185 -0
  1270. package/src/components/Calendar/Readme.md +124 -0
  1271. package/src/components/CalendarDay/CalendarDay.css +85 -0
  1272. package/src/components/CalendarDay/CalendarDay.tsx +117 -0
  1273. package/src/components/CalendarDays/CalendarDays.css +31 -0
  1274. package/src/components/CalendarDays/CalendarDays.tsx +131 -0
  1275. package/src/components/CalendarHeader/CalendarHeader.css +50 -0
  1276. package/src/components/CalendarHeader/CalendarHeader.tsx +168 -0
  1277. package/src/components/CalendarRange/CalendarRange.css +27 -0
  1278. package/src/components/CalendarRange/CalendarRange.tsx +275 -0
  1279. package/src/components/CalendarRange/Readme.md +85 -0
  1280. package/src/components/CalendarTime/CalendarTime.css +18 -0
  1281. package/src/components/CalendarTime/CalendarTime.tsx +88 -0
  1282. package/src/components/Card/Card.css +84 -0
  1283. package/src/components/Card/Card.tsx +31 -0
  1284. package/src/components/Card/Readme.md +39 -0
  1285. package/src/components/CardGrid/CardGrid.css +82 -0
  1286. package/src/components/CardGrid/CardGrid.tsx +41 -0
  1287. package/src/components/CardGrid/Readme.md +41 -0
  1288. package/src/components/CardScroll/CardScroll.css +47 -0
  1289. package/src/components/CardScroll/CardScroll.tsx +118 -0
  1290. package/src/components/CardScroll/Readme.md +62 -0
  1291. package/src/components/Cell/Cell.css +56 -0
  1292. package/src/components/Cell/Cell.tsx +205 -0
  1293. package/src/components/Cell/CellCheckbox/CellCheckbox.css +17 -0
  1294. package/src/components/Cell/CellCheckbox/CellCheckbox.tsx +41 -0
  1295. package/src/components/Cell/CellDragger/CellDragger.css +4 -0
  1296. package/src/components/Cell/CellDragger/CellDragger.tsx +37 -0
  1297. package/src/components/Cell/Readme.md +163 -0
  1298. package/src/components/Cell/useDraggable.tsx +126 -0
  1299. package/src/components/CellButton/CellButton.css +46 -0
  1300. package/src/components/CellButton/CellButton.tsx +36 -0
  1301. package/src/components/CellButton/Readme.md +53 -0
  1302. package/src/components/Checkbox/Checkbox.css +127 -0
  1303. package/src/components/Checkbox/Checkbox.tsx +102 -0
  1304. package/src/components/Checkbox/Readme.md +20 -0
  1305. package/src/components/Chip/Chip.css +56 -0
  1306. package/src/components/Chip/Chip.tsx +70 -0
  1307. package/src/components/Chip/Readme.md +81 -0
  1308. package/src/components/ChipsInput/ChipsInput.css +72 -0
  1309. package/src/components/ChipsInput/ChipsInput.tsx +239 -0
  1310. package/src/components/ChipsInput/Readme.md +94 -0
  1311. package/src/components/ChipsInput/useChipsInput.ts +90 -0
  1312. package/src/components/ChipsSelect/ChipsSelect.css +23 -0
  1313. package/src/components/ChipsSelect/ChipsSelect.tsx +454 -0
  1314. package/src/components/ChipsSelect/Readme.md +115 -0
  1315. package/src/components/ChipsSelect/useChipsSelect.ts +72 -0
  1316. package/src/components/ClickPopper/ClickPopper.tsx +86 -0
  1317. package/src/components/ConfigProvider/ConfigProvider.tsx +144 -0
  1318. package/src/components/ConfigProvider/ConfigProviderContext.tsx +48 -0
  1319. package/src/components/ConfigProvider/Readme.md +1 -0
  1320. package/src/components/ContentCard/ContentCard.css +39 -0
  1321. package/src/components/ContentCard/ContentCard.tsx +153 -0
  1322. package/src/components/ContentCard/Readme.md +65 -0
  1323. package/src/components/Counter/Counter.css +161 -0
  1324. package/src/components/Counter/Counter.tsx +76 -0
  1325. package/src/components/Counter/Readme.md +114 -0
  1326. package/src/components/CustomScrollView/CustomScrollView.css +62 -0
  1327. package/src/components/CustomScrollView/CustomScrollView.tsx +168 -0
  1328. package/src/components/CustomSelect/CustomSelect.css +24 -0
  1329. package/src/components/CustomSelect/CustomSelect.tsx +784 -0
  1330. package/src/components/CustomSelect/Readme.md +248 -0
  1331. package/src/components/CustomSelectDropdown/CustomSelectDropdown.css +43 -0
  1332. package/src/components/CustomSelectDropdown/CustomSelectDropdown.tsx +76 -0
  1333. package/src/components/CustomSelectOption/CustomSelectOption.css +75 -0
  1334. package/src/components/CustomSelectOption/CustomSelectOption.tsx +126 -0
  1335. package/src/components/CustomSelectOption/Readme.md +52 -0
  1336. package/src/components/DateInput/DateInput.css +20 -0
  1337. package/src/components/DateInput/DateInput.tsx +317 -0
  1338. package/src/components/DateInput/Readme.md +116 -0
  1339. package/src/components/DatePicker/DatePicker.css +30 -0
  1340. package/src/components/DatePicker/DatePicker.tsx +238 -0
  1341. package/src/components/DatePicker/Readme.md +40 -0
  1342. package/src/components/DateRangeInput/DateRangeInput.css +16 -0
  1343. package/src/components/DateRangeInput/DateRangeInput.tsx +350 -0
  1344. package/src/components/DateRangeInput/Readme.md +96 -0
  1345. package/src/components/Div/Div.css +7 -0
  1346. package/src/components/Div/Div.tsx +26 -0
  1347. package/src/components/Div/Readme.md +17 -0
  1348. package/src/components/Dropdown/Dropdown.css +19 -0
  1349. package/src/components/Dropdown/Dropdown.tsx +42 -0
  1350. package/src/components/Dropdown/Readme.md +49 -0
  1351. package/src/components/DropdownIcon/DropdownIcon.css +3 -0
  1352. package/src/components/DropdownIcon/DropdownIcon.tsx +18 -0
  1353. package/src/components/Epic/Epic.css +4 -0
  1354. package/src/components/Epic/Epic.tsx +63 -0
  1355. package/src/components/Epic/Readme.md +244 -0
  1356. package/src/components/Epic/ScrollSaver.tsx +23 -0
  1357. package/src/components/File/File.css +6 -0
  1358. package/src/components/File/File.tsx +74 -0
  1359. package/src/components/File/Readme.md +20 -0
  1360. package/src/components/FixedLayout/FixedLayout.css +29 -0
  1361. package/src/components/FixedLayout/FixedLayout.tsx +72 -0
  1362. package/src/components/FixedLayout/Readme.md +117 -0
  1363. package/src/components/FocusTrap/FocusTrap.tsx +144 -0
  1364. package/src/components/FocusVisible/FocusVisible.css +72 -0
  1365. package/src/components/FocusVisible/FocusVisible.tsx +18 -0
  1366. package/src/components/Footer/Footer.css +8 -0
  1367. package/src/components/Footer/Footer.tsx +17 -0
  1368. package/src/components/Footer/Readme.md +23 -0
  1369. package/src/components/FormField/FormField.css +137 -0
  1370. package/src/components/FormField/FormField.tsx +95 -0
  1371. package/src/components/FormField/Readme.md +108 -0
  1372. package/src/components/FormItem/FormItem.css +83 -0
  1373. package/src/components/FormItem/FormItem.tsx +86 -0
  1374. package/src/components/FormItem/Readme.md +183 -0
  1375. package/src/components/FormLayout/FormLayout.css +16 -0
  1376. package/src/components/FormLayout/FormLayout.tsx +39 -0
  1377. package/src/components/FormLayout/Readme.md +2 -0
  1378. package/src/components/FormLayoutGroup/FormLayoutGroup.css +22 -0
  1379. package/src/components/FormLayoutGroup/FormLayoutGroup.tsx +72 -0
  1380. package/src/components/FormLayoutGroup/Readme.md +63 -0
  1381. package/src/components/FormStatus/FormStatus.css +34 -0
  1382. package/src/components/FormStatus/FormStatus.tsx +45 -0
  1383. package/src/components/FormStatus/Readme.md +23 -0
  1384. package/src/components/Gallery/Gallery.css +71 -0
  1385. package/src/components/Gallery/Gallery.tsx +574 -0
  1386. package/src/components/Gallery/Readme.md +99 -0
  1387. package/src/components/Gradient/Gradient.css +85 -0
  1388. package/src/components/Gradient/Gradient.tsx +29 -0
  1389. package/src/components/Gradient/Readme.md +55 -0
  1390. package/src/components/GridAvatar/GridAvatar.css +34 -0
  1391. package/src/components/GridAvatar/GridAvatar.tsx +41 -0
  1392. package/src/components/GridAvatar/Readme.md +24 -0
  1393. package/src/components/Group/Group.css +86 -0
  1394. package/src/components/Group/Group.tsx +95 -0
  1395. package/src/components/Group/Readme.md +156 -0
  1396. package/src/components/Header/Header.css +152 -0
  1397. package/src/components/Header/Header.tsx +177 -0
  1398. package/src/components/Header/Readme.md +114 -0
  1399. package/src/components/HorizontalCell/HorizontalCell.css +95 -0
  1400. package/src/components/HorizontalCell/HorizontalCell.tsx +86 -0
  1401. package/src/components/HorizontalCell/Readme.md +236 -0
  1402. package/src/components/HorizontalScroll/HorizontalScroll.css +31 -0
  1403. package/src/components/HorizontalScroll/HorizontalScroll.tsx +225 -0
  1404. package/src/components/HorizontalScroll/HorizontalScrollArrow.css +69 -0
  1405. package/src/components/HorizontalScroll/HorizontalScrollArrow.tsx +35 -0
  1406. package/src/components/HorizontalScroll/Readme.md +67 -0
  1407. package/src/components/HoverPopper/HoverPopper.tsx +102 -0
  1408. package/src/components/IconButton/IconButton.css +93 -0
  1409. package/src/components/IconButton/IconButton.tsx +57 -0
  1410. package/src/components/InfoRow/InfoRow.css +14 -0
  1411. package/src/components/InfoRow/InfoRow.tsx +37 -0
  1412. package/src/components/InfoRow/Readme.md +27 -0
  1413. package/src/components/InitialsAvatar/InitialsAvatar.css +55 -0
  1414. package/src/components/InitialsAvatar/InitialsAvatar.tsx +95 -0
  1415. package/src/components/InitialsAvatar/Readme.md +20 -0
  1416. package/src/components/Input/Input.css +52 -0
  1417. package/src/components/Input/Input.tsx +52 -0
  1418. package/src/components/Input/Readme.md +46 -0
  1419. package/src/components/InputLike/InputLike.css +25 -0
  1420. package/src/components/InputLike/InputLike.tsx +72 -0
  1421. package/src/components/InputLike/InputLikeDivider.css +4 -0
  1422. package/src/components/InputLike/InputLikeDivider.tsx +12 -0
  1423. package/src/components/Link/Link.css +18 -0
  1424. package/src/components/Link/Link.tsx +27 -0
  1425. package/src/components/Link/Readme.md +8 -0
  1426. package/src/components/List/List.css +2 -0
  1427. package/src/components/List/List.tsx +32 -0
  1428. package/src/components/List/ListContext.ts +6 -0
  1429. package/src/components/List/Readme.md +22 -0
  1430. package/src/components/LocaleProviderContext/LocaleProviderContext.tsx +5 -0
  1431. package/src/components/MiniInfoCell/MiniInfoCell.css +67 -0
  1432. package/src/components/MiniInfoCell/MiniInfoCell.tsx +95 -0
  1433. package/src/components/MiniInfoCell/Readme.md +150 -0
  1434. package/src/components/ModalCard/ModalCard.css +67 -0
  1435. package/src/components/ModalCard/ModalCard.tsx +94 -0
  1436. package/src/components/ModalCard/Readme.md +9 -0
  1437. package/src/components/ModalCardBase/ModalCardBase.css +104 -0
  1438. package/src/components/ModalCardBase/ModalCardBase.tsx +154 -0
  1439. package/src/components/ModalCardBase/Readme.md +38 -0
  1440. package/src/components/ModalDismissButton/ModalDismissButton.css +37 -0
  1441. package/src/components/ModalDismissButton/ModalDismissButton.tsx +32 -0
  1442. package/src/components/ModalDismissButton/Readme.md +53 -0
  1443. package/src/components/ModalPage/ModalPage.css +146 -0
  1444. package/src/components/ModalPage/ModalPage.tsx +150 -0
  1445. package/src/components/ModalPage/Readme.md +9 -0
  1446. package/src/components/ModalPageHeader/ModalPageHeader.css +24 -0
  1447. package/src/components/ModalPageHeader/ModalPageHeader.tsx +58 -0
  1448. package/src/components/ModalPageHeader/Readme.md +46 -0
  1449. package/src/components/ModalRoot/ModalRoot.css +68 -0
  1450. package/src/components/ModalRoot/ModalRoot.tsx +843 -0
  1451. package/src/components/ModalRoot/ModalRootAdaptive.tsx +60 -0
  1452. package/src/components/ModalRoot/ModalRootContext.tsx +51 -0
  1453. package/src/components/ModalRoot/ModalRootDesktop.tsx +279 -0
  1454. package/src/components/ModalRoot/Readme.md +774 -0
  1455. package/src/components/ModalRoot/constants.ts +4 -0
  1456. package/src/components/ModalRoot/types.ts +68 -0
  1457. package/src/components/ModalRoot/useModalManager.tsx +251 -0
  1458. package/src/components/ModalRoot/withModalRootContext.tsx +19 -0
  1459. package/src/components/NativeSelect/NativeSelect.tsx +113 -0
  1460. package/src/components/NativeSelect/Readme.md +17 -0
  1461. package/src/components/NavTransitionContext/NavTransitionContext.tsx +24 -0
  1462. package/src/components/Pagination/Pagination.css +62 -0
  1463. package/src/components/Pagination/Pagination.tsx +196 -0
  1464. package/src/components/Pagination/Readme.md +110 -0
  1465. package/src/components/Panel/Panel.css +116 -0
  1466. package/src/components/Panel/Panel.tsx +59 -0
  1467. package/src/components/Panel/Readme.md +97 -0
  1468. package/src/components/PanelHeader/PanelHeader.css +263 -0
  1469. package/src/components/PanelHeader/PanelHeader.tsx +143 -0
  1470. package/src/components/PanelHeader/Readme.md +244 -0
  1471. package/src/components/PanelHeaderBack/PanelHeaderBack.css +7 -0
  1472. package/src/components/PanelHeaderBack/PanelHeaderBack.tsx +61 -0
  1473. package/src/components/PanelHeaderBack/Readme.md +9 -0
  1474. package/src/components/PanelHeaderButton/PanelHeaderButton.css +102 -0
  1475. package/src/components/PanelHeaderButton/PanelHeaderButton.tsx +111 -0
  1476. package/src/components/PanelHeaderButton/Readme.md +47 -0
  1477. package/src/components/PanelHeaderClose/PanelHeaderClose.tsx +35 -0
  1478. package/src/components/PanelHeaderClose/Readme.md +9 -0
  1479. package/src/components/PanelHeaderContent/PanelHeaderContent.css +107 -0
  1480. package/src/components/PanelHeaderContent/PanelHeaderContent.tsx +105 -0
  1481. package/src/components/PanelHeaderContent/Readme.md +33 -0
  1482. package/src/components/PanelHeaderContext/PanelHeaderContext.css +143 -0
  1483. package/src/components/PanelHeaderContext/PanelHeaderContext.tsx +89 -0
  1484. package/src/components/PanelHeaderContext/Readme.md +110 -0
  1485. package/src/components/PanelHeaderEdit/PanelHeaderEdit.tsx +49 -0
  1486. package/src/components/PanelHeaderEdit/Readme.md +1 -0
  1487. package/src/components/PanelHeaderSubmit/PanelHeaderSubmit.tsx +37 -0
  1488. package/src/components/PanelHeaderSubmit/Readme.md +13 -0
  1489. package/src/components/PanelSpinner/PanelSpinner.tsx +21 -0
  1490. package/src/components/PanelSpinner/Readme.md +15 -0
  1491. package/src/components/Placeholder/Placeholder.css +50 -0
  1492. package/src/components/Placeholder/Placeholder.tsx +71 -0
  1493. package/src/components/Placeholder/Readme.md +104 -0
  1494. package/src/components/PopoutRoot/PopoutRoot.css +36 -0
  1495. package/src/components/PopoutRoot/PopoutRoot.tsx +72 -0
  1496. package/src/components/PopoutRoot/Readme.md +50 -0
  1497. package/src/components/PopoutWrapper/PopoutWrapper.css +109 -0
  1498. package/src/components/PopoutWrapper/PopoutWrapper.tsx +78 -0
  1499. package/src/components/PopoutWrapper/Readme.md +12 -0
  1500. package/src/components/Popper/Popper.css +39 -0
  1501. package/src/components/Popper/Popper.tsx +231 -0
  1502. package/src/components/Popper/Readme.md +33 -0
  1503. package/src/components/Progress/Progress.css +12 -0
  1504. package/src/components/Progress/Progress.tsx +49 -0
  1505. package/src/components/Progress/Readme.md +14 -0
  1506. package/src/components/PromoBanner/PromoBanner.css +55 -0
  1507. package/src/components/PromoBanner/PromoBanner.tsx +135 -0
  1508. package/src/components/PromoBanner/Readme.md +25 -0
  1509. package/src/components/PullToRefresh/PullToRefresh.css +98 -0
  1510. package/src/components/PullToRefresh/PullToRefresh.tsx +354 -0
  1511. package/src/components/PullToRefresh/PullToRefreshSpinner.tsx +79 -0
  1512. package/src/components/PullToRefresh/Readme.md +71 -0
  1513. package/src/components/Radio/Radio.css +187 -0
  1514. package/src/components/Radio/Radio.tsx +82 -0
  1515. package/src/components/Radio/Readme.md +29 -0
  1516. package/src/components/RadioGroup/RadioGroup.css +12 -0
  1517. package/src/components/RadioGroup/RadioGroup.tsx +29 -0
  1518. package/src/components/RadioGroup/Readme.md +56 -0
  1519. package/src/components/RangeSlider/RangeSlider.tsx +54 -0
  1520. package/src/components/RangeSlider/Readme.md +32 -0
  1521. package/src/components/RangeSlider/UniversalSlider.tsx +162 -0
  1522. package/src/components/Removable/Removable.css +125 -0
  1523. package/src/components/Removable/Removable.tsx +176 -0
  1524. package/src/components/RichCell/Readme.md +65 -0
  1525. package/src/components/RichCell/RichCell.css +115 -0
  1526. package/src/components/RichCell/RichCell.tsx +105 -0
  1527. package/src/components/RichTooltip/Readme.md +59 -0
  1528. package/src/components/RichTooltip/RichTooltip.css +10 -0
  1529. package/src/components/RichTooltip/RichTooltip.tsx +33 -0
  1530. package/src/components/Root/Readme.md +36 -0
  1531. package/src/components/Root/Root.css +177 -0
  1532. package/src/components/Root/Root.tsx +210 -0
  1533. package/src/components/ScreenSpinner/Readme.md +43 -0
  1534. package/src/components/ScreenSpinner/ScreenSpinner.css +31 -0
  1535. package/src/components/ScreenSpinner/ScreenSpinner.tsx +40 -0
  1536. package/src/components/Search/Readme.md +235 -0
  1537. package/src/components/Search/Search.css +359 -0
  1538. package/src/components/Search/Search.tsx +197 -0
  1539. package/src/components/SegmentedControl/Readme.md +94 -0
  1540. package/src/components/SegmentedControl/SegmentedControl.css +42 -0
  1541. package/src/components/SegmentedControl/SegmentedControl.tsx +115 -0
  1542. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +30 -0
  1543. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.tsx +43 -0
  1544. package/src/components/Select/Readme.md +27 -0
  1545. package/src/components/Select/Select.css +64 -0
  1546. package/src/components/Select/Select.tsx +38 -0
  1547. package/src/components/SelectMimicry/Readme.md +87 -0
  1548. package/src/components/SelectMimicry/SelectMimicry.css +10 -0
  1549. package/src/components/SelectMimicry/SelectMimicry.tsx +97 -0
  1550. package/src/components/Separator/Readme.md +23 -0
  1551. package/src/components/Separator/Separator.css +48 -0
  1552. package/src/components/Separator/Separator.tsx +42 -0
  1553. package/src/components/SimpleCell/Readme.md +136 -0
  1554. package/src/components/SimpleCell/SimpleCell.css +258 -0
  1555. package/src/components/SimpleCell/SimpleCell.tsx +133 -0
  1556. package/src/components/SimpleCheckbox/Readme.md +25 -0
  1557. package/src/components/SimpleCheckbox/SimpleCheckbox.css +129 -0
  1558. package/src/components/SimpleCheckbox/SimpleCheckbox.tsx +148 -0
  1559. package/src/components/Slider/Readme.md +83 -0
  1560. package/src/components/Slider/Slider.css +145 -0
  1561. package/src/components/Slider/Slider.tsx +54 -0
  1562. package/src/components/SliderSwitch/Readme.md +27 -0
  1563. package/src/components/SliderSwitch/SliderSwitch.css +87 -0
  1564. package/src/components/SliderSwitch/SliderSwitch.tsx +210 -0
  1565. package/src/components/SliderSwitch/SliderSwitchButton.tsx +54 -0
  1566. package/src/components/Snackbar/Readme.md +145 -0
  1567. package/src/components/Snackbar/Snackbar.css +162 -0
  1568. package/src/components/Snackbar/Snackbar.tsx +255 -0
  1569. package/src/components/Spacing/Readme.md +98 -0
  1570. package/src/components/Spacing/Spacing.css +46 -0
  1571. package/src/components/Spacing/Spacing.tsx +54 -0
  1572. package/src/components/Spinner/Readme.md +11 -0
  1573. package/src/components/Spinner/Spinner.css +33 -0
  1574. package/src/components/Spinner/Spinner.tsx +53 -0
  1575. package/src/components/SplitCol/Readme.md +1 -0
  1576. package/src/components/SplitCol/SplitCol.css +28 -0
  1577. package/src/components/SplitCol/SplitCol.tsx +76 -0
  1578. package/src/components/SplitLayout/Readme.md +154 -0
  1579. package/src/components/SplitLayout/SplitLayout.css +54 -0
  1580. package/src/components/SplitLayout/SplitLayout.tsx +55 -0
  1581. package/src/components/SubnavigationBar/Readme.md +264 -0
  1582. package/src/components/SubnavigationBar/SubnavigationBar.css +32 -0
  1583. package/src/components/SubnavigationBar/SubnavigationBar.tsx +67 -0
  1584. package/src/components/SubnavigationButton/Readme.md +128 -0
  1585. package/src/components/SubnavigationButton/SubnavigationButton.css +103 -0
  1586. package/src/components/SubnavigationButton/SubnavigationButton.tsx +100 -0
  1587. package/src/components/Switch/Readme.md +57 -0
  1588. package/src/components/Switch/Switch.css +198 -0
  1589. package/src/components/Switch/Switch.tsx +57 -0
  1590. package/src/components/Tabbar/Readme.md +7 -0
  1591. package/src/components/Tabbar/Tabbar.css +53 -0
  1592. package/src/components/Tabbar/Tabbar.tsx +51 -0
  1593. package/src/components/TabbarItem/Readme.md +102 -0
  1594. package/src/components/TabbarItem/TabbarItem.css +128 -0
  1595. package/src/components/TabbarItem/TabbarItem.tsx +95 -0
  1596. package/src/components/Tabs/Readme.md +274 -0
  1597. package/src/components/Tabs/Tabs.css +102 -0
  1598. package/src/components/Tabs/Tabs.tsx +57 -0
  1599. package/src/components/TabsItem/Readme.md +0 -0
  1600. package/src/components/TabsItem/TabsItem.css +178 -0
  1601. package/src/components/TabsItem/TabsItem.tsx +63 -0
  1602. package/src/components/Tappable/Tappable.css +146 -0
  1603. package/src/components/Tappable/Tappable.tsx +352 -0
  1604. package/src/components/TextTooltip/Readme.md +11 -0
  1605. package/src/components/TextTooltip/TextTooltip.css +18 -0
  1606. package/src/components/TextTooltip/TextTooltip.tsx +58 -0
  1607. package/src/components/Textarea/Readme.md +24 -0
  1608. package/src/components/Textarea/Textarea.css +39 -0
  1609. package/src/components/Textarea/Textarea.tsx +80 -0
  1610. package/src/components/Tooltip/Readme.md +263 -0
  1611. package/src/components/Tooltip/Tooltip.css +73 -0
  1612. package/src/components/Tooltip/Tooltip.tsx +315 -0
  1613. package/src/components/Tooltip/TooltipContainer.tsx +10 -0
  1614. package/src/components/Touch/Readme.md +116 -0
  1615. package/src/components/Touch/Touch.tsx +288 -0
  1616. package/src/components/Touch/TouchContext.ts +11 -0
  1617. package/src/components/Typography/Caption/Caption.css +97 -0
  1618. package/src/components/Typography/Caption/Caption.tsx +53 -0
  1619. package/src/components/Typography/Caption/Readme.md +29 -0
  1620. package/src/components/Typography/Headline/Headline.css +25 -0
  1621. package/src/components/Typography/Headline/Headline.tsx +36 -0
  1622. package/src/components/Typography/Headline/Readme.md +24 -0
  1623. package/src/components/Typography/Paragraph/Paragraph.css +17 -0
  1624. package/src/components/Typography/Paragraph/Paragraph.tsx +42 -0
  1625. package/src/components/Typography/Paragraph/Readme.md +19 -0
  1626. package/src/components/Typography/Subhead/Readme.md +21 -0
  1627. package/src/components/Typography/Subhead/Subhead.css +43 -0
  1628. package/src/components/Typography/Subhead/Subhead.tsx +50 -0
  1629. package/src/components/Typography/Text/Readme.md +22 -0
  1630. package/src/components/Typography/Text/Text.css +25 -0
  1631. package/src/components/Typography/Text/Text.tsx +52 -0
  1632. package/src/components/Typography/Title/Readme.md +31 -0
  1633. package/src/components/Typography/Title/Title.css +59 -0
  1634. package/src/components/Typography/Title/Title.tsx +61 -0
  1635. package/src/components/UsersStack/Readme.md +94 -0
  1636. package/src/components/UsersStack/UsersStack.css +99 -0
  1637. package/src/components/UsersStack/UsersStack.tsx +103 -0
  1638. package/src/components/UsersStack/masks.tsx +46 -0
  1639. package/src/components/View/Readme.md +98 -0
  1640. package/src/components/View/View.css +125 -0
  1641. package/src/components/View/View.tsx +677 -0
  1642. package/src/components/View/ViewIOS.css +155 -0
  1643. package/src/components/View/ViewInfinite.tsx +735 -0
  1644. package/src/components/View/utils.ts +10 -0
  1645. package/src/components/VisuallyHiddenInput/VisuallyHiddenInput.css +9 -0
  1646. package/src/components/VisuallyHiddenInput/VisuallyHiddenInput.tsx +25 -0
  1647. package/src/components/WriteBar/Readme.md +224 -0
  1648. package/src/components/WriteBar/WriteBar.css +106 -0
  1649. package/src/components/WriteBar/WriteBar.tsx +137 -0
  1650. package/src/components/WriteBarIcon/Readme.md +11 -0
  1651. package/src/components/WriteBarIcon/WriteBarIcon.css +75 -0
  1652. package/src/components/WriteBarIcon/WriteBarIcon.tsx +106 -0
  1653. package/src/fonts/VK_Sans_Display_Medium.woff +0 -0
  1654. package/src/fonts/VK_Sans_Display_Medium.woff2 +0 -0
  1655. package/src/fonts/fonts.css +7 -0
  1656. package/src/helpers/avatar.ts +10 -0
  1657. package/src/helpers/getClassName.ts +8 -0
  1658. package/src/helpers/getScheme.ts +27 -0
  1659. package/src/helpers/math.ts +40 -0
  1660. package/src/helpers/scheme.ts +87 -0
  1661. package/src/hoc/withAdaptivity.tsx +86 -0
  1662. package/src/hoc/withContext.tsx +14 -0
  1663. package/src/hoc/withInsets.tsx +12 -0
  1664. package/src/hoc/withPlatform.tsx +17 -0
  1665. package/src/hooks/useAdaptivity.ts +12 -0
  1666. package/src/hooks/useAppearance.ts +4 -0
  1667. package/src/hooks/useBooleanState.ts +19 -0
  1668. package/src/hooks/useBridgeAdaptivity.ts +83 -0
  1669. package/src/hooks/useBrowserInfo.ts +11 -0
  1670. package/src/hooks/useCalendar.ts +78 -0
  1671. package/src/hooks/useDateInput.ts +213 -0
  1672. package/src/hooks/useEffectDev.ts +5 -0
  1673. package/src/hooks/useEnsuredControl.ts +17 -0
  1674. package/src/hooks/useEventListener.ts +62 -0
  1675. package/src/hooks/useExternRef.ts +26 -0
  1676. package/src/hooks/useFocusVisible.ts +31 -0
  1677. package/src/hooks/useGlobalEventListener.ts +35 -0
  1678. package/src/hooks/useInsets.ts +69 -0
  1679. package/src/hooks/useKeyboard.ts +75 -0
  1680. package/src/hooks/useKeyboardInputTracker.ts +64 -0
  1681. package/src/hooks/useObjectMemo.ts +16 -0
  1682. package/src/hooks/useOrientationChange.ts +39 -0
  1683. package/src/hooks/usePagination.ts +96 -0
  1684. package/src/hooks/usePatchChildrenRef.ts +39 -0
  1685. package/src/hooks/usePlatform.ts +10 -0
  1686. package/src/hooks/useTimeout.ts +33 -0
  1687. package/src/hooks/useWaitTransitionFinish.ts +34 -0
  1688. package/src/index.ts +345 -0
  1689. package/src/lib/SSR.tsx +45 -0
  1690. package/src/lib/accessibility.ts +87 -0
  1691. package/src/lib/animate.ts +47 -0
  1692. package/src/lib/browser.ts +44 -0
  1693. package/src/lib/calendar.ts +123 -0
  1694. package/src/lib/callMultiple.ts +4 -0
  1695. package/src/lib/classNames.ts +44 -0
  1696. package/src/lib/classScopingMode.ts +21 -0
  1697. package/src/lib/date.ts +274 -0
  1698. package/src/lib/dom.tsx +45 -0
  1699. package/src/lib/fx.ts +7 -0
  1700. package/src/lib/getNavId.ts +15 -0
  1701. package/src/lib/is.ts +10 -0
  1702. package/src/lib/isRefObject.ts +11 -0
  1703. package/src/lib/jsxRuntime.d.ts +6 -0
  1704. package/src/lib/jsxRuntime.ts +43 -0
  1705. package/src/lib/offset.ts +17 -0
  1706. package/src/lib/platform.ts +70 -0
  1707. package/src/lib/polyfills.ts +96 -0
  1708. package/src/lib/prefixClass.ts +34 -0
  1709. package/src/lib/removeObjectKeys.ts +10 -0
  1710. package/src/lib/select.ts +54 -0
  1711. package/src/lib/styles.ts +12 -0
  1712. package/src/lib/supportEvents.ts +38 -0
  1713. package/src/lib/taptic.ts +9 -0
  1714. package/src/lib/testing.ts +4 -0
  1715. package/src/lib/touch.ts +59 -0
  1716. package/src/lib/useIsomorphicLayoutEffect.ts +7 -0
  1717. package/src/lib/utils.ts +99 -0
  1718. package/src/lib/warnOnce.ts +15 -0
  1719. package/src/styles/animations.css +19 -0
  1720. package/src/styles/bright_light.css +246 -0
  1721. package/src/styles/common.css +39 -0
  1722. package/src/styles/components.css +153 -0
  1723. package/src/styles/constants.css +79 -0
  1724. package/src/styles/space_gray.css +245 -0
  1725. package/src/styles/themes.css +10 -0
  1726. package/src/styles/unstable.css +6 -0
  1727. package/src/styles/vkcom_dark.css +251 -0
  1728. package/src/styles/vkcom_light.css +256 -0
  1729. package/src/testing/setup.ts +1 -0
  1730. package/src/testing/utils.tsx +205 -0
  1731. package/src/tokenized/index.ts +66 -0
  1732. package/src/types.ts +43 -0
  1733. package/src/unstable/index.ts +23 -0
  1734. package/src/vkui.js +1 -0
  1735. package/stylelint.config.js +46 -0
  1736. package/tasks/generate_scheme.js +13 -0
  1737. package/tasks/postcss-check-keyframes.js +36 -0
  1738. package/tasks/postcss-scope-root.js +9 -0
  1739. package/tasks/styleint-atomic.js +57 -0
  1740. package/tokenized/index.d.ts +1 -0
  1741. package/tokenized/package.json +4 -0
  1742. package/tsconfig.dist.json +16 -0
  1743. package/tsconfig.json +40 -0
  1744. package/types/global.d.ts +7 -0
  1745. package/unstable/index.d.ts +1 -0
  1746. package/unstable/package.json +4 -0
  1747. package/webpack.config.js +86 -0
  1748. package/webpack.styles.config.js +67 -0
  1749. package/dist/components.js.tmp +0 -24
  1750. package/dist/default_scheme.js.tmp +0 -24
  1751. package/dist/fonts.js.tmp +0 -24
  1752. package/dist/stable.js.tmp +0 -166
  1753. package/dist/unstable.js.tmp +0 -24
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootDesktop.tsx"],"names":["React","classNames","transitionEvent","withPlatform","withContext","ModalRootContext","ConfigProviderContext","WebviewType","ANDROID","VKCOM","getClassName","withDOM","getNavId","warnOnce","FocusTrap","withModalManager","warn","ModalRootDesktopComponent","props","undefined","maskElementRef","createRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","getModalState","onClose","closeActiveModal","isInsideModal","platform","Children","toArray","children","prevProps","exitingModal","closeModal","enteringModal","enteringState","requestAnimationFrame","waitTransitionFinish","onEnter","animateModalOpacity","activeModal","restoreFocusTo","document","activeElement","focus","prevModalState","onExit","setMaskOpacity","modalState","eventHandler","supported","onceHandler","innerElement","removeEventListener","name","addEventListener","setTimeout","timeout","display","style","transitionDelay","delayEnter","opacity","forceOpacity","history","maskAnimationFrame","cancelAnimationFrame","current","translateY","translateYCurrent","Math","max","min","toString","configProvider","webviewType","VKAPPS","modals","map","Modal","modalId","key","Boolean","Component","ModalRootDesktop"],"mappings":";;;;;;;;;AAAA,OAAO,KAAKA,KAAZ,MAAuB,OAAvB;AACA,SAASC,UAAT;AACA,SAASC,eAAT;AAEA,SAASC,YAAT;AACA,SAASC,WAAT;AACA,OAAOC,gBAAP;AAGA,SACEC,qBADF,EAGEC,WAHF;AAMA,SAASC,OAAT,EAAkBC,KAAlB;AACA,SAASC,YAAT;AACA,SAAmBC,OAAnB;AACA,SAASC,QAAT;AACA,SAASC,QAAT;AACA,SAASC,SAAT;AACA,SAA+BC,gBAA/B;AACA;AAEA,IAAMC,IAAI,GAAGH,QAAQ,CAAC,WAAD,CAArB;;IAeMI,yB;;;;;AAGJ,qCAAYC,KAAZ,EAA0D;AAAA;;AAAA;;AACxD,8BAAMA,KAAN;;AADwD;;AAAA,yEAeTC,SAfS;;AAAA;;AAAA,qEAiBRA,SAjBQ;;AAGxD,UAAKC,cAAL,gBAAsBpB,KAAK,CAACqB,SAAN,EAAtB;AAEA,UAAKC,gBAAL,GAAwB;AACtBC,MAAAA,iBAAiB,EAAE;AAAA,eAAMJ,SAAN;AAAA,OADG;AAEtBK,MAAAA,aAAa,EAAE;AAAA,YAAGC,EAAH,QAAGA,EAAH;AAAA,YAAUC,IAAV;;AAAA,eACbC,MAAM,CAACC,MAAP,CAAc,MAAKC,aAAL,CAAmBJ,EAAnB,CAAd,EAAsCC,IAAtC,CADa;AAAA,OAFO;AAItBI,MAAAA,OAAO,EAAE;AAAA,eAAM,MAAKZ,KAAL,CAAWa,gBAAX,EAAN;AAAA,OAJa;AAKtBC,MAAAA,aAAa,EAAE;AALO,KAAxB;AALwD;AAYzD;;;;SAOD,eAAsB;AACpB,aAAO,KAAKd,KAAL,CAAWe,QAAX,KAAwBzB,OAAxB,IAAmC,KAAKU,KAAL,CAAWe,QAAX,KAAwBxB,KAA3D,GACH,GADG,GAEH,GAFJ;AAGD;;;SAED,eAAqB;AACnB,aAAOT,KAAK,CAACkC,QAAN,CAAeC,OAAf,CAAuB,KAAKjB,KAAL,CAAWkB,QAAlC,CAAP;AACD;;;WAED,uBAAcX,EAAd,EAAiC;AAC/B,UAAIA,EAAE,KAAK,IAAX,EAAiB;AACf,eAAON,SAAP;AACD;;AACD,aAAO,KAAKD,KAAL,CAAWW,aAAX,CAAyBJ,EAAzB,CAAP;AACD;;;WAED,4BAAmBY,SAAnB,EAAqE;AAAA;;AACnE;AACA,UACE,KAAKnB,KAAL,CAAWoB,YAAX,IACA,KAAKpB,KAAL,CAAWoB,YAAX,KAA4BD,SAAS,CAACC,YAFxC,EAGE;AACA,aAAKC,UAAL,CAAgB,KAAKrB,KAAL,CAAWoB,YAA3B;AACD,OAPkE,CASnE;;;AACA,UACE,KAAKpB,KAAL,CAAWsB,aAAX,IACA,KAAKtB,KAAL,CAAWsB,aAAX,KAA6BH,SAAS,CAACG,aAFzC,EAGE;AACA,YAAQA,aAAR,GAA0B,KAAKtB,KAA/B,CAAQsB,aAAR;AACA,YAAMC,aAAa,GAAG,KAAKZ,aAAL,CAAmBW,aAAnB,CAAtB;AACAE,QAAAA,qBAAqB,CAAC,YAAM;AAC1B,cAAI,MAAI,CAACxB,KAAL,CAAWsB,aAAX,KAA6BA,aAAjC,EAAgD;AAC9C,YAAA,MAAI,CAACG,oBAAL,CAA0BF,aAA1B,EAAyC;AAAA,qBACvC,MAAI,CAACvB,KAAL,CAAW0B,OAAX,CAAmBJ,aAAnB,CADuC;AAAA,aAAzC;;AAGA,YAAA,MAAI,CAACK,mBAAL,CAAyBJ,aAAzB,EAAwC,IAAxC;AACD;AACF,SAPoB,CAArB;AAQD,OAxBkE,CA0BnE;;;AACA,UAAI,KAAKvB,KAAL,CAAW4B,WAAX,IAA0B,CAACT,SAAS,CAACS,WAAzC,EAAsD;AAAA;;AACpD,aAAKC,cAAL,oDAAuB,KAAK7B,KAAL,CAAW8B,QAAlC,yDAAuB,qBAAqBC,aAA5C,yEACE9B,SADF;AAED;;AACD,UACE,CAAC,KAAKD,KAAL,CAAW4B,WAAZ,IACA,CAAC,KAAK5B,KAAL,CAAWoB,YADZ,IAEA,KAAKS,cAHP,EAIE;AACA,aAAKA,cAAL,CAAoBG,KAApB;AACA,aAAKH,cAAL,GAAsB5B,SAAtB;AACD;AACF;;;WAED,oBAAWM,EAAX,EAAuB;AAAA;;AACrB,UAAM0B,cAAc,GAAG,KAAKtB,aAAL,CAAmBJ,EAAnB,CAAvB;;AACA,UAAI,CAAC0B,cAAL,EAAqB;AACnB;AACD;;AAED,WAAKR,oBAAL,CAA0BQ,cAA1B,EAA0C;AAAA,eAAM,MAAI,CAACjC,KAAL,CAAWkC,MAAX,CAAkB3B,EAAlB,CAAN;AAAA,OAA1C;AACA,WAAKoB,mBAAL,CAAyBM,cAAzB,EAAyC,KAAzC;;AACA,UAAI,CAAC,KAAKjC,KAAL,CAAW4B,WAAhB,EAA6B;AAC3B,aAAKO,cAAL,CAAoBF,cAApB,EAAoC,CAApC;AACD;AACF;;;WAED,8BACEG,UADF,EAEEC,YAFF,EAGE;AACA,UAAIrD,eAAe,CAACsD,SAApB,EAA+B;AAAA;;AAC7B,YAAMC,WAAW,GAAG,SAAdA,WAAc,GAAM;AAAA;;AACxBH,UAAAA,UAAU,SAAV,IAAAA,UAAU,WAAV,qCAAAA,UAAU,CAAEI,YAAZ,gFAA0BC,mBAA1B,CACEzD,eAAe,CAAC0D,IADlB,EAEEH,WAFF;AAIAF,UAAAA,YAAY;AACb,SAND;;AAQAD,QAAAA,UAAU,SAAV,IAAAA,UAAU,WAAV,sCAAAA,UAAU,CAAEI,YAAZ,kFAA0BG,gBAA1B,CACE3D,eAAe,CAAC0D,IADlB,EAEEH,WAFF;AAID,OAbD,MAaO;AACLK,QAAAA,UAAU,CAACP,YAAD,EAAe,KAAKQ,OAApB,CAAV;AACD;AACF;AAED;;;;WACA,6BACET,UADF,EAEEU,OAFF,EAGE;AACA,UAAIV,UAAJ,aAAIA,UAAJ,eAAIA,UAAU,CAAEI,YAAhB,EAA8B;AAC5BJ,QAAAA,UAAU,CAACI,YAAX,CAAwBO,KAAxB,CAA8BC,eAA9B,GACEF,OAAO,IAAI,KAAK9C,KAAL,CAAWiD,UAAtB,aAAsC,KAAKJ,OAA3C,UAAyD,EAD3D;AAEAT,QAAAA,UAAU,CAACI,YAAX,CAAwBO,KAAxB,CAA8BG,OAA9B,GAAwCJ,OAAO,GAAG,GAAH,GAAS,GAAxD;AACD;AACF;AAED;;;;WACA,wBACEV,UADF,EAGE;AAAA;AAAA;;AAAA,UADAe,YACA,uEAD8B,IAC9B;;AACA,UAAIA,YAAY,KAAK,IAAjB,IAAyB,6BAAKnD,KAAL,CAAWoD,OAAX,4EAAqB,CAArB,OAA4BhB,UAAU,CAAC7B,EAApE,EAAwE;AACtE;AACD;;AAED,UAAI,KAAK8C,kBAAT,EAA6B;AAC3BC,QAAAA,oBAAoB,CAAC,KAAKD,kBAAN,CAApB;AACD;;AACD,WAAKA,kBAAL,GAA0B7B,qBAAqB,CAAC,YAAM;AACpD,YAAI,MAAI,CAACtB,cAAL,CAAoBqD,OAAxB,EAAiC;AAC/B,sCAAkDnB,UAAlD,CAAQoB,UAAR;AAAA,cAAQA,UAAR,sCAAqB,CAArB;AAAA,uCAAkDpB,UAAlD,CAAwBqB,iBAAxB;AAAA,cAAwBA,iBAAxB,uCAA4C,CAA5C;AAEA,cAAMP,OAAO,GACXC,YAAY,KAAK,IAAjB,GACI,IAAI,CAACM,iBAAiB,GAAGD,UAArB,KAAoC,MAAMA,UAA1C,CAAJ,IAA6D,CADjE,GAEIL,YAHN;AAIA,UAAA,MAAI,CAACjD,cAAL,CAAoBqD,OAApB,CAA4BR,KAA5B,CAAkCG,OAAlC,GAA4CQ,IAAI,CAACC,GAAL,CAC1C,CAD0C,EAE1CD,IAAI,CAACE,GAAL,CAAS,GAAT,EAAcV,OAAd,CAF0C,EAG1CW,QAH0C,EAA5C;AAID;AACF,OAb8C,CAA/C;AAcD;;;WAED,kBAAS;AAAA;AAAA;;AACP,wBAAqD,KAAK7D,KAA1D;AAAA,UAAQoB,YAAR,eAAQA,YAAR;AAAA,UAAsBQ,WAAtB,eAAsBA,WAAtB;AAAA,UAAmCN,aAAnC,eAAmCA,aAAnC;;AAEA,UAAI,CAACM,WAAD,IAAgB,CAACR,YAArB,EAAmC;AACjC,eAAO,IAAP;AACD;;AAED,aACE,oBAAC,gBAAD,CAAkB,QAAlB;AAA2B,QAAA,KAAK,EAAE,KAAKhB;AAAvC,SACE;AACE,QAAA,SAAS,EAAErB,UAAU,CACnBS,YAAY,CAAC,WAAD,EAAc,KAAKQ,KAAL,CAAWe,QAAzB,CADO,EAEnB;AACE,+BACE,+BAAKf,KAAL,CAAW8D,cAAX,gFAA2BC,WAA3B,MAA2C1E,WAAW,CAAC2E;AAF3D,SAFmB,EAMnB,oBANmB;AADvB,SAUE;AACE,QAAA,SAAS,EAAC,iBADZ;AAEE,QAAA,GAAG,EAAE,KAAK9D,cAFZ;AAGE,QAAA,OAAO,EAAE,KAAKF,KAAL,CAAWa;AAHtB,QAVF,EAeE;AAAK,QAAA,SAAS,EAAC;AAAf,SACG,KAAKoD,MAAL,CAAYC,GAAZ,CAAgB,UAACC,KAAD,EAA+B;AAC9C,YAAMC,OAAO,GAAG1E,QAAQ,CAACyE,KAAK,CAACnE,KAAP,EAAcF,IAAd,CAAxB;;AACA,YAAIsE,OAAO,KAAKxC,WAAZ,IAA2BwC,OAAO,KAAKhD,YAA3C,EAAyD;AACvD,iBAAO,IAAP;AACD;;AAED,YAAMiD,GAAG,mBAAYD,OAAZ,CAAT;AAEA,eACE,oBAAC,SAAD;AACE,UAAA,YAAY,EAAE,KADhB;AAEE,UAAA,OAAO,EAAE,MAAI,CAACpE,KAAL,CAAWa,gBAFtB;AAGE,UAAA,OAAO,EAAE,MAAI,CAACgC,OAHhB;AAIE,UAAA,GAAG,EAAEwB,GAJP;AAKE,UAAA,SAAS,EAAEtF,UAAU,CAAC,kBAAD,EAAqB;AACxC,wCACE,CAACqC,YAAD,IACA,CAACE,aADD,IAEA8C,OAAO,KAAKxC,WAJ0B;AAKxC,sCAA0BwC,OAAO,KAAKhD,YALE;AAMxC,sCACEkD,OAAO,CAAClD,YAAD,CAAP,IAAyBgD,OAAO,KAAKxC;AAPC,WAArB;AALvB,WAeGuC,KAfH,CADF;AAmBD,OA3BA,CADH,CAfF,CADF,CADF;AAkDD;;;;EApNqCrF,KAAK,CAACyF,S;;AAuN9C,OAAO,IAAMC,gBAAgB,GAAGtF,WAAW,CACzCD,YAAY,CACVQ,OAAO,CAAiBI,gBAAgB,GAAGE,yBAAH,CAAjC,CADG,CAD6B,EAIzCX,qBAJyC,EAKzC,gBALyC,CAApC","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { transitionEvent } from \"../../lib/supportEvents\";\nimport { HasPlatform } from \"../../types\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport { withContext } from \"../../hoc/withContext\";\nimport ModalRootContext, {\n ModalRootContextInterface,\n} from \"./ModalRootContext\";\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n WebviewType,\n} from \"../ConfigProvider/ConfigProviderContext\";\nimport { ModalsStateEntry } from \"./types\";\nimport { ANDROID, VKCOM } from \"../../lib/platform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { DOMProps, withDOM } from \"../../lib/dom\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { FocusTrap } from \"../FocusTrap/FocusTrap\";\nimport { ModalTransitionProps, withModalManager } from \"./useModalManager\";\nimport \"./ModalRoot.css\";\n\nconst warn = warnOnce(\"ModalRoot\");\n\nexport interface ModalRootProps extends HasPlatform {\n activeModal?: string | null;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n\n /**\n * Будет вызвано при закрытии активной модалки с её id\n */\n onClose?(modalId: string): void;\n}\n\nclass ModalRootDesktopComponent extends React.Component<\n ModalRootProps & DOMProps & ModalTransitionProps\n> {\n constructor(props: ModalRootProps & ModalTransitionProps) {\n super(props);\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: () => undefined,\n registerModal: ({ id, ...data }) =>\n Object.assign(this.getModalState(id), data),\n onClose: () => this.props.closeActiveModal(),\n isInsideModal: true,\n };\n }\n\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private maskAnimationFrame: number | undefined = undefined;\n private readonly modalRootContext: ModalRootContextInterface;\n private restoreFocusTo: HTMLElement | undefined = undefined;\n\n private get timeout() {\n return this.props.platform === ANDROID || this.props.platform === VKCOM\n ? 320\n : 400;\n }\n\n private get modals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n getModalState(id: string | null) {\n if (id === null) {\n return undefined;\n }\n return this.props.getModalState(id);\n }\n\n componentDidUpdate(prevProps: ModalRootProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (\n this.props.exitingModal &&\n this.props.exitingModal !== prevProps.exitingModal\n ) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (\n this.props.enteringModal &&\n this.props.enteringModal !== prevProps.enteringModal\n ) {\n const { enteringModal } = this.props;\n const enteringState = this.getModalState(enteringModal);\n requestAnimationFrame(() => {\n if (this.props.enteringModal === enteringModal) {\n this.waitTransitionFinish(enteringState, () =>\n this.props.onEnter(enteringModal)\n );\n this.animateModalOpacity(enteringState, true);\n }\n });\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = (this.props.document?.activeElement ??\n undefined) as HTMLElement | undefined;\n }\n if (\n !this.props.activeModal &&\n !this.props.exitingModal &&\n this.restoreFocusTo\n ) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = undefined;\n }\n }\n\n closeModal(id: string) {\n const prevModalState = this.getModalState(id);\n if (!prevModalState) {\n return;\n }\n\n this.waitTransitionFinish(prevModalState, () => this.props.onExit(id));\n this.animateModalOpacity(prevModalState, false);\n if (!this.props.activeModal) {\n this.setMaskOpacity(prevModalState, 0);\n }\n }\n\n waitTransitionFinish(\n modalState: ModalsStateEntry | undefined,\n eventHandler: () => void\n ) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState?.innerElement?.removeEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n eventHandler();\n };\n\n modalState?.innerElement?.addEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /* Анимирует сдивг модалки */\n animateModalOpacity(\n modalState: ModalsStateEntry | undefined,\n display: boolean\n ) {\n if (modalState?.innerElement) {\n modalState.innerElement.style.transitionDelay =\n display && this.props.delayEnter ? `${this.timeout}ms` : \"\";\n modalState.innerElement.style.opacity = display ? \"1\" : \"0\";\n }\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(\n modalState: ModalsStateEntry,\n forceOpacity: number | null = null\n ) {\n if (forceOpacity === null && this.props.history?.[0] !== modalState.id) {\n return;\n }\n\n if (this.maskAnimationFrame) {\n cancelAnimationFrame(this.maskAnimationFrame);\n }\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(\n 0,\n Math.min(100, opacity)\n ).toString();\n }\n });\n }\n\n render() {\n const { exitingModal, activeModal, enteringModal } = this.props;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <ModalRootContext.Provider value={this.modalRootContext}>\n <div\n vkuiClass={classNames(\n getClassName(\"ModalRoot\", this.props.platform),\n {\n \"ModalRoot--vkapps\":\n this.props.configProvider?.webviewType === WebviewType.VKAPPS,\n },\n \"ModalRoot--desktop\"\n )}\n >\n <div\n vkuiClass=\"ModalRoot__mask\"\n ref={this.maskElementRef}\n onClick={this.props.closeActiveModal}\n />\n <div vkuiClass=\"ModalRoot__viewport\">\n {this.modals.map((Modal: React.ReactElement) => {\n const modalId = getNavId(Modal.props, warn);\n if (modalId !== activeModal && modalId !== exitingModal) {\n return null;\n }\n\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n restoreFocus={false}\n onClose={this.props.closeActiveModal}\n timeout={this.timeout}\n key={key}\n vkuiClass={classNames(\"ModalRoot__modal\", {\n \"ModalRoot__modal--active\":\n !exitingModal &&\n !enteringModal &&\n modalId === activeModal,\n \"ModalRoot__modal--prev\": modalId === exitingModal,\n \"ModalRoot__modal--next\":\n Boolean(exitingModal) && modalId === activeModal,\n })}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </div>\n </ModalRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootDesktop = withContext(\n withPlatform(\n withDOM<ModalRootProps>(withModalManager()(ModalRootDesktopComponent))\n ),\n ConfigProviderContext,\n \"configProvider\"\n);\n"],"file":"ModalRootDesktop.js"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootDesktop.tsx"],"names":["React","classNames","transitionEvent","withPlatform","withContext","ModalRootContext","ConfigProviderContext","WebviewType","ANDROID","VKCOM","getClassName","withDOM","getNavId","warnOnce","FocusTrap","withModalManager","warn","ModalRootDesktopComponent","props","undefined","maskElementRef","createRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","getModalState","onClose","onExit","isInsideModal","platform","Children","toArray","children","prevProps","exitingModal","closeModal","enteringModal","enteringState","onEnter","requestAnimationFrame","waitTransitionFinish","onEntered","animateModalOpacity","activeModal","restoreFocusTo","document","activeElement","focus","prevModalState","onExited","setMaskOpacity","modalState","eventHandler","supported","onceHandler","innerElement","removeEventListener","name","addEventListener","setTimeout","timeout","display","style","transitionDelay","delayEnter","opacity","forceOpacity","history","maskAnimationFrame","cancelAnimationFrame","current","translateY","translateYCurrent","Math","max","min","toString","configProvider","webviewType","VKAPPS","modals","map","Modal","modalId","key","Boolean","Component","ModalRootDesktop"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { transitionEvent } from \"../../lib/supportEvents\";\nimport { HasPlatform } from \"../../types\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport { withContext } from \"../../hoc/withContext\";\nimport ModalRootContext, {\n ModalRootContextInterface,\n} from \"./ModalRootContext\";\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n WebviewType,\n} from \"../ConfigProvider/ConfigProviderContext\";\nimport { ModalsStateEntry } from \"./types\";\nimport { ANDROID, VKCOM } from \"../../lib/platform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { DOMProps, withDOM } from \"../../lib/dom\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { FocusTrap } from \"../FocusTrap/FocusTrap\";\nimport { ModalTransitionProps, withModalManager } from \"./useModalManager\";\nimport \"./ModalRoot.css\";\n\nconst warn = warnOnce(\"ModalRoot\");\n\nexport interface ModalRootProps extends HasPlatform {\n activeModal?: string | null;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n\n /**\n * Будет вызвано при начале открытия активной модалки с её id\n */\n onOpen?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном открытии активной модалки с её id\n */\n onOpened?(modalId: string): void;\n\n /**\n * Будет вызвано при начале закрытия активной модалки с её id\n */\n onClose?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном закрытии активной модалки с её id\n */\n onClosed?(modalId: string): void;\n}\n\nclass ModalRootDesktopComponent extends React.Component<\n ModalRootProps & DOMProps & ModalTransitionProps\n> {\n constructor(props: ModalRootProps & ModalTransitionProps) {\n super(props);\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: () => undefined,\n registerModal: ({ id, ...data }) =>\n Object.assign(this.getModalState(id), data),\n onClose: () => this.props.onExit(),\n isInsideModal: true,\n };\n }\n\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private maskAnimationFrame: number | undefined = undefined;\n private readonly modalRootContext: ModalRootContextInterface;\n private restoreFocusTo: HTMLElement | undefined = undefined;\n\n private get timeout() {\n return this.props.platform === ANDROID || this.props.platform === VKCOM\n ? 320\n : 400;\n }\n\n private get modals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n getModalState(id: string | null) {\n if (id === null) {\n return undefined;\n }\n return this.props.getModalState(id);\n }\n\n componentDidUpdate(prevProps: ModalRootProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (\n this.props.exitingModal &&\n this.props.exitingModal !== prevProps.exitingModal\n ) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (\n this.props.enteringModal &&\n this.props.enteringModal !== prevProps.enteringModal\n ) {\n const { enteringModal } = this.props;\n const enteringState = this.getModalState(enteringModal);\n this.props.onEnter();\n requestAnimationFrame(() => {\n if (this.props.enteringModal === enteringModal) {\n this.waitTransitionFinish(enteringState, () =>\n this.props.onEntered(enteringModal)\n );\n this.animateModalOpacity(enteringState, true);\n }\n });\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = (this.props.document?.activeElement ??\n undefined) as HTMLElement | undefined;\n }\n if (\n !this.props.activeModal &&\n !this.props.exitingModal &&\n this.restoreFocusTo\n ) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = undefined;\n }\n }\n\n closeModal(id: string) {\n const prevModalState = this.getModalState(id);\n if (!prevModalState) {\n return;\n }\n\n this.waitTransitionFinish(prevModalState, () => this.props.onExited(id));\n this.animateModalOpacity(prevModalState, false);\n if (!this.props.activeModal) {\n this.setMaskOpacity(prevModalState, 0);\n }\n }\n\n waitTransitionFinish(\n modalState: ModalsStateEntry | undefined,\n eventHandler: () => void\n ) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState?.innerElement?.removeEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n eventHandler();\n };\n\n modalState?.innerElement?.addEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /* Анимирует сдвиг модалки */\n animateModalOpacity(\n modalState: ModalsStateEntry | undefined,\n display: boolean\n ) {\n if (modalState?.innerElement) {\n modalState.innerElement.style.transitionDelay =\n display && this.props.delayEnter ? `${this.timeout}ms` : \"\";\n modalState.innerElement.style.opacity = display ? \"1\" : \"0\";\n }\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(\n modalState: ModalsStateEntry,\n forceOpacity: number | null = null\n ) {\n if (forceOpacity === null && this.props.history?.[0] !== modalState.id) {\n return;\n }\n\n if (this.maskAnimationFrame) {\n cancelAnimationFrame(this.maskAnimationFrame);\n }\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(\n 0,\n Math.min(100, opacity)\n ).toString();\n }\n });\n }\n\n render() {\n const { exitingModal, activeModal, enteringModal } = this.props;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <ModalRootContext.Provider value={this.modalRootContext}>\n <div\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"ModalRoot\", this.props.platform),\n {\n \"ModalRoot--vkapps\":\n this.props.configProvider?.webviewType === WebviewType.VKAPPS,\n },\n \"ModalRoot--desktop\"\n )}\n >\n <div\n vkuiClass=\"ModalRoot__mask\"\n ref={this.maskElementRef}\n onClick={this.props.onExit}\n />\n <div vkuiClass=\"ModalRoot__viewport\">\n {this.modals.map((Modal: React.ReactElement) => {\n const modalId = getNavId(Modal.props, warn);\n if (modalId !== activeModal && modalId !== exitingModal) {\n return null;\n }\n\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n restoreFocus={false}\n onClose={this.props.onExit}\n timeout={this.timeout}\n key={key}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\"ModalRoot__modal\", {\n \"ModalRoot__modal--active\":\n !exitingModal &&\n !enteringModal &&\n modalId === activeModal,\n \"ModalRoot__modal--prev\": modalId === exitingModal,\n \"ModalRoot__modal--next\":\n Boolean(exitingModal) && modalId === activeModal,\n })}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </div>\n </ModalRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootDesktop = withContext(\n withPlatform(\n withDOM<ModalRootProps>(withModalManager()(ModalRootDesktopComponent))\n ),\n ConfigProviderContext,\n \"configProvider\"\n);\n"],"file":"ModalRootDesktop.js"}
@@ -14,7 +14,22 @@ export interface ModalElements {
14
14
  }
15
15
  export interface ModalsStateEntry extends ModalElements {
16
16
  id: string | null;
17
- onClose?: () => any;
17
+ /**
18
+ * Событие начала открытия модалки.
19
+ */
20
+ onOpen?: VoidFunction;
21
+ /**
22
+ * Событие открытия модалки.
23
+ */
24
+ onOpened?: VoidFunction;
25
+ /**
26
+ * Событие начала закрытия модалки.
27
+ */
28
+ onClose?: VoidFunction;
29
+ /**
30
+ * Событие закрытия модалки.
31
+ */
32
+ onClosed?: VoidFunction;
18
33
  type?: ModalType;
19
34
  settlingHeight?: number;
20
35
  dynamicContentHeight?: boolean;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/types.ts"],"names":["ModalType"],"mappings":"AAAA,WAAYA,SAAZ;;WAAYA,S;AAAAA,EAAAA,S;AAAAA,EAAAA,S;GAAAA,S,KAAAA,S","sourcesContent":["export enum ModalType {\n PAGE = \"page\",\n CARD = \"card\",\n}\n\nexport type TranslateRange = [number, number];\n\nexport type ModalsState = { [index: string]: ModalsStateEntry };\n\nexport interface ModalElements {\n modalElement?: HTMLElement | null;\n innerElement?: HTMLElement | null;\n headerElement?: HTMLElement | null;\n contentElement?: HTMLElement | null;\n}\n\nexport interface ModalsStateEntry extends ModalElements {\n id: string | null;\n onClose?: () => any;\n type?: ModalType;\n\n settlingHeight?: number;\n dynamicContentHeight?: boolean;\n expandable?: boolean;\n\n /**\n * Процент текущего сдвига модалки\n */\n translateY?: number;\n /**\n * Процент сдвига модалки в изначальном состоянии\n */\n translateYFrom?: number;\n /**\n * Процент сдвига модалки во время взаимодействия с ней (потянуть, чтобы открыть или закрыть)\n */\n translateYCurrent?: number;\n\n touchStartContentScrollTop?: number;\n touchMovePositive?: boolean | null;\n touchShiftYPercent?: number;\n\n expanded?: boolean;\n collapsed?: boolean;\n hidden?: boolean;\n\n contentScrolled?: boolean;\n contentScrollStopTimeout?: ReturnType<typeof setTimeout>;\n\n expandedRange?: TranslateRange;\n collapsedRange?: TranslateRange;\n hiddenRange?: TranslateRange;\n}\n"],"file":"types.js"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/types.ts"],"names":["ModalType"],"mappings":"AAAA,WAAYA,SAAZ;;WAAYA,S;AAAAA,EAAAA,S;AAAAA,EAAAA,S;GAAAA,S,KAAAA,S","sourcesContent":["export enum ModalType {\n PAGE = \"page\",\n CARD = \"card\",\n}\n\nexport type TranslateRange = [number, number];\n\nexport type ModalsState = { [index: string]: ModalsStateEntry };\n\nexport interface ModalElements {\n modalElement?: HTMLElement | null;\n innerElement?: HTMLElement | null;\n headerElement?: HTMLElement | null;\n contentElement?: HTMLElement | null;\n}\n\nexport interface ModalsStateEntry extends ModalElements {\n id: string | null;\n /**\n * Событие начала открытия модалки.\n */\n onOpen?: VoidFunction;\n /**\n * Событие открытия модалки.\n */\n onOpened?: VoidFunction;\n /**\n * Событие начала закрытия модалки.\n */\n onClose?: VoidFunction;\n /**\n * Событие закрытия модалки.\n */\n onClosed?: VoidFunction;\n type?: ModalType;\n\n settlingHeight?: number;\n dynamicContentHeight?: boolean;\n expandable?: boolean;\n\n /**\n * Процент текущего сдвига модалки\n */\n translateY?: number;\n /**\n * Процент сдвига модалки в изначальном состоянии\n */\n translateYFrom?: number;\n /**\n * Процент сдвига модалки во время взаимодействия с ней (потянуть, чтобы открыть или закрыть)\n */\n translateYCurrent?: number;\n\n touchStartContentScrollTop?: number;\n touchMovePositive?: boolean | null;\n touchShiftYPercent?: number;\n\n expanded?: boolean;\n collapsed?: boolean;\n hidden?: boolean;\n\n contentScrolled?: boolean;\n contentScrollStopTimeout?: ReturnType<typeof setTimeout>;\n\n expandedRange?: TranslateRange;\n collapsedRange?: TranslateRange;\n hiddenRange?: TranslateRange;\n}\n"],"file":"types.js"}
@@ -8,10 +8,11 @@ interface ModalTransitionState {
8
8
  isBack?: boolean | null;
9
9
  }
10
10
  export interface ModalTransitionProps extends ModalTransitionState {
11
- onEnter: (id: string | null) => void;
12
- onExit: (id: string | null) => void;
11
+ onEnter: VoidFunction;
12
+ onEntered: (id: string | null) => void;
13
+ onExit: VoidFunction;
14
+ onExited: (id: string | null) => void;
13
15
  getModalState: (id: string) => ModalsStateEntry;
14
- closeActiveModal: VoidFunction;
15
16
  delayEnter: boolean;
16
17
  }
17
18
  export declare function modalTransitionReducer(state: ModalTransitionState, action: {
@@ -30,8 +31,8 @@ export declare function modalTransitionReducer(state: ModalTransitionState, acti
30
31
  * 4b. enteringModal переходит в null после завершения анимации
31
32
  * 5. activeModal: m2, exitingModal: null, enteringModal: null, переход закончен
32
33
  */
33
- export declare function useModalManager(activeModal: string | null | undefined, children: React.ReactNode | React.ReactNode[], onClose: (id: string) => void, initModal?: (state: ModalsStateEntry) => void): ModalTransitionProps;
34
- export declare function withModalManager(initModal?: (a: ModalsStateEntry) => void): <Props extends ModalTransitionProps>(Wrapped: React.ComponentType<Props>) => React.FC<Pick<Props, Exclude<keyof Props, "isBack" | "onEnter" | "history" | "onExit" | "getModalState" | "closeActiveModal" | "delayEnter" | "activeModal" | "enteringModal" | "exitingModal">> & {
34
+ export declare function useModalManager(activeModal: string | null | undefined, children: React.ReactNode | React.ReactNode[], onOpen?: (id: string) => void, onOpened?: (id: string) => void, onClose?: (id: string) => void, onClosed?: (id: string) => void, initModal?: (state: ModalsStateEntry) => void): ModalTransitionProps;
35
+ export declare function withModalManager(initModal?: (a: ModalsStateEntry) => void): <Props extends ModalTransitionProps>(Wrapped: React.ComponentType<Props>) => React.FC<Pick<Props, Exclude<keyof Props, "isBack" | "onEnter" | "history" | "onEntered" | "onExit" | "onExited" | "getModalState" | "delayEnter" | "activeModal" | "enteringModal" | "exitingModal">> & {
35
36
  activeModal?: string | null | undefined;
36
37
  }>;
37
38
  export {};
@@ -74,8 +74,12 @@ export function modalTransitionReducer(state, action) {
74
74
  * 5. activeModal: m2, exitingModal: null, enteringModal: null, переход закончен
75
75
  */
76
76
 
77
- export function useModalManager(activeModal, children, onClose) {
78
- var initModal = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : noop;
77
+ export function useModalManager(activeModal, children) {
78
+ var onOpen = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : noop;
79
+ var onOpened = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : noop;
80
+ var onClose = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : noop;
81
+ var onClosed = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : noop;
82
+ var initModal = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : noop;
79
83
  var modalsState = React.useRef({}).current;
80
84
  getModals(children).forEach(function (Modal) {
81
85
  var modalProps = Modal.props;
@@ -83,7 +87,10 @@ export function useModalManager(activeModal, children, onClose) {
83
87
  var state = id !== undefined && modalsState[id] || {
84
88
  id: id !== null && id !== void 0 ? id : null
85
89
  };
90
+ state.onOpen = Modal.props.onOpen;
91
+ state.onOpened = Modal.props.onOpened;
86
92
  state.onClose = Modal.props.onClose;
93
+ state.onClosed = Modal.props.onClosed;
87
94
  state.dynamicContentHeight = !!modalProps.dynamicContentHeight; // ModalPage props
88
95
 
89
96
  if (typeof modalProps.settlingHeight === "number") {
@@ -112,7 +119,7 @@ export function useModalManager(activeModal, children, onClose) {
112
119
  useIsomorphicLayoutEffect(function () {
113
120
  // ignore non-existent activeModal
114
121
  if (process.env.NODE_ENV === "development" && isMissing) {
115
- warn("Can't transition - modal ".concat(activeModal, " not found"));
122
+ warn("\u041F\u0435\u0440\u0435\u0445\u043E\u0434 \u043D\u0435\u0432\u043E\u0437\u043C\u043E\u0436\u0435\u043D - \u043C\u043E\u0434\u0430\u043B\u044C\u043D\u043E\u0435 \u043E\u043A\u043D\u043E (\u0441\u0442\u0440\u0430\u043D\u0438\u0446\u0430) ".concat(activeModal, " \u043D\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442"), "error");
116
123
  }
117
124
 
118
125
  dispatchTransition({
@@ -137,24 +144,56 @@ export function useModalManager(activeModal, children, onClose) {
137
144
  return id != null && ((_modalsState$id = modalsState[id]) === null || _modalsState$id === void 0 ? void 0 : _modalsState$id.type) === ModalType.CARD;
138
145
  };
139
146
 
140
- var onEnter = React.useCallback(function (id) {
141
- return dispatchTransition({
147
+ var onEntered = React.useCallback(function (id) {
148
+ if (id) {
149
+ var modalState = modalsState[id];
150
+
151
+ if (isFunction(modalState.onOpened)) {
152
+ modalState.onOpened();
153
+ } else if (isFunction(onOpened)) {
154
+ onOpened(id);
155
+ }
156
+ }
157
+
158
+ dispatchTransition({
142
159
  type: "entered",
143
160
  id: id
144
161
  });
145
- }, []);
146
- var onExit = React.useCallback(function (id) {
147
- return dispatchTransition({
162
+ }, [modalsState, onOpened]);
163
+ var onExited = React.useCallback(function (id) {
164
+ if (id) {
165
+ var modalState = modalsState[id];
166
+
167
+ if (isFunction(modalState.onClosed)) {
168
+ modalState.onClosed();
169
+ } else if (isFunction(onClosed)) {
170
+ onClosed(id);
171
+ }
172
+ }
173
+
174
+ dispatchTransition({
148
175
  type: "exited",
149
176
  id: id
150
177
  });
151
- }, []);
178
+ }, [modalsState, onClosed]);
152
179
  var delayEnter = Boolean(transitionState.exitingModal && (isCard(activeModal) || isCard(transitionState.exitingModal)));
153
180
  var getModalState = React.useCallback(function (id) {
154
181
  return modalsState[id];
155
182
  }, [modalsState]);
156
183
 
157
- function closeActiveModal() {
184
+ function onEnter() {
185
+ var modalState = transitionState.activeModal && modalsState[transitionState.activeModal];
186
+
187
+ if (modalState) {
188
+ if (isFunction(modalState.onOpen)) {
189
+ modalState.onOpen();
190
+ } else if (isFunction(onOpen)) {
191
+ onOpen(modalState.id);
192
+ }
193
+ }
194
+ }
195
+
196
+ function onExit() {
158
197
  var modalState = transitionState.activeModal && modalsState[transitionState.activeModal];
159
198
 
160
199
  if (modalState) {
@@ -162,26 +201,25 @@ export function useModalManager(activeModal, children, onClose) {
162
201
  modalState.onClose();
163
202
  } else if (isFunction(onClose)) {
164
203
  onClose(modalState.id);
165
- } else if (process.env.NODE_ENV === "development") {
166
- warn("onClose is undefined");
167
204
  }
168
205
  }
169
206
  }
170
207
 
171
208
  return _objectSpread(_objectSpread({
172
209
  onEnter: onEnter,
173
- onExit: onExit
210
+ onEntered: onEntered,
211
+ onExit: onExit,
212
+ onExited: onExited
174
213
  }, transitionState), {}, {
175
214
  delayEnter: delayEnter,
176
- getModalState: getModalState,
177
- closeActiveModal: closeActiveModal
215
+ getModalState: getModalState
178
216
  });
179
217
  }
180
218
  export function withModalManager() {
181
219
  var initModal = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : noop;
182
220
  return function (Wrapped) {
183
221
  return function WithModalManager(props) {
184
- var transitionManager = useModalManager(props.activeModal, props.children, props.onClose, initModal);
222
+ var transitionManager = useModalManager(props.activeModal, props.children, props.onOpen, props.onOpened, props.onClose, props.onClosed, initModal);
185
223
  return createScopedElement(Wrapped, _extends({}, props, transitionManager));
186
224
  };
187
225
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/useModalManager.tsx"],"names":["React","ModalType","warnOnce","getNavId","useIsomorphicLayoutEffect","noop","isFunction","getModals","children","Children","toArray","warn","modalTransitionReducer","state","action","type","id","activeModal","nextModal","prevModal","exitingModal","history","isBack","Boolean","includes","splice","indexOf","push","enteringModal","useModalManager","onClose","initModal","modalsState","useRef","current","forEach","Modal","modalProps","props","undefined","dynamicContentHeight","settlingHeight","isMissing","safeActiveModal","useReducer","transitionState","dispatchTransition","process","env","NODE_ENV","isCard","CARD","onEnter","useCallback","onExit","delayEnter","getModalState","closeActiveModal","modalState","withModalManager","Wrapped","WithModalManager","transitionManager"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { ModalsState, ModalsStateEntry, ModalType } from \"./types\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { noop, isFunction } from \"../../lib/utils\";\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: (id: string | null) => void;\n onExit: (id: string | null) => void;\n getModalState: (id: string) => ModalsStateEntry;\n closeActiveModal: VoidFunction;\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 onClose: (id: string) => void,\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.onClose = Modal.props.onClose;\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(\n modalTransitionReducer,\n {\n activeModal: safeActiveModal,\n enteringModal: null,\n exitingModal: null,\n history: safeActiveModal ? [safeActiveModal] : [],\n isBack: false,\n }\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(`Can't transition - modal ${activeModal} not found`);\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 onEnter = React.useCallback(\n (id: string | null) => dispatchTransition({ type: \"entered\", id }),\n []\n );\n const onExit = React.useCallback(\n (id: string | null) => dispatchTransition({ type: \"exited\", id }),\n []\n );\n const delayEnter = Boolean(\n transitionState.exitingModal &&\n (isCard(activeModal) || isCard(transitionState.exitingModal))\n );\n const getModalState = React.useCallback(\n (id: string) => modalsState[id],\n [modalsState]\n );\n\n function closeActiveModal() {\n const modalState =\n 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 } else if (process.env.NODE_ENV === \"development\") {\n warn(\"onClose is undefined\");\n }\n }\n }\n\n return {\n onEnter,\n onExit,\n ...transitionState,\n delayEnter,\n getModalState,\n closeActiveModal,\n };\n}\n\nexport function withModalManager(\n initModal: (a: ModalsStateEntry) => void = noop\n) {\n return function <Props extends ModalTransitionProps>(\n Wrapped: React.ComponentType<Props>\n ): React.FC<\n Omit<Props, keyof ModalTransitionProps> & { activeModal?: string | null }\n > {\n return function WithModalManager(props) {\n const transitionManager = useModalManager(\n props.activeModal,\n props.children,\n (props as any).onClose,\n initModal\n );\n return <Wrapped {...(props as any)} {...transitionManager} />;\n };\n };\n}\n"],"file":"useModalManager.js"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/useModalManager.tsx"],"names":["React","ModalType","warnOnce","getNavId","useIsomorphicLayoutEffect","noop","isFunction","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","modalsState","useRef","current","forEach","Modal","modalProps","props","undefined","dynamicContentHeight","settlingHeight","isMissing","safeActiveModal","useReducer","transitionState","dispatchTransition","process","env","NODE_ENV","isCard","CARD","onEntered","useCallback","modalState","onExited","delayEnter","getModalState","onEnter","onExit","withModalManager","Wrapped","WithModalManager","transitionManager"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { ModalsState, ModalsStateEntry, ModalType } from \"./types\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { noop, isFunction } from \"../../lib/utils\";\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(\n modalTransitionReducer,\n {\n activeModal: safeActiveModal,\n enteringModal: null,\n exitingModal: null,\n history: safeActiveModal ? [safeActiveModal] : [],\n isBack: false,\n }\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(\n `Переход невозможен - модальное окно (страница) ${activeModal} не существует`,\n \"error\"\n );\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 &&\n (isCard(activeModal) || isCard(transitionState.exitingModal))\n );\n const getModalState = React.useCallback(\n (id: string) => modalsState[id],\n [modalsState]\n );\n\n function onEnter() {\n const modalState =\n 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 =\n 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(\n initModal: (a: ModalsStateEntry) => void = noop\n) {\n return function <Props extends ModalTransitionProps>(\n Wrapped: React.ComponentType<Props>\n ): React.FC<\n Omit<Props, keyof ModalTransitionProps> & { activeModal?: string | null }\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"],"file":"useModalManager.js"}
@@ -11,5 +11,4 @@ export interface SelectState {
11
11
  title?: string;
12
12
  notSelected?: boolean;
13
13
  }
14
- declare const _default: React.FC<Pick<NativeSelectProps & AdaptivityContextInterface, "required" | "disabled" | "hidden" | "dir" | "form" | "slot" | "style" | "title" | "color" | "size" | "multiple" | "translate" | "prefix" | "children" | "className" | "id" | "lang" | "name" | "role" | "tabIndex" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "draggable" | "placeholder" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "value" | "autoFocus" | "autoComplete" | "align" | "getRootRef" | "getRef" | "multiline"> & import("../AdaptivityProvider/AdaptivityContext").SizeProps>;
15
- export default _default;
14
+ export declare const NativeSelect: React.FC<Pick<NativeSelectProps & AdaptivityContextInterface, "required" | "disabled" | "hidden" | "dir" | "form" | "slot" | "style" | "title" | "color" | "size" | "multiple" | "translate" | "prefix" | "children" | "className" | "id" | "lang" | "name" | "role" | "tabIndex" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "draggable" | "placeholder" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "value" | "autoFocus" | "autoComplete" | "align" | "getRootRef" | "getRef" | "multiline"> & import("../AdaptivityProvider/AdaptivityContext").SizeProps>;
@@ -19,7 +19,7 @@ import { useExternRef } from "../../hooks/useExternRef";
19
19
  import { usePlatform } from "../../hooks/usePlatform";
20
20
  import "../Select/Select.css";
21
21
 
22
- var NativeSelect = function NativeSelect(_ref) {
22
+ var NativeSelectComponent = function NativeSelectComponent(_ref) {
23
23
  var _classNames;
24
24
 
25
25
  var style = _ref.style,
@@ -69,7 +69,8 @@ var NativeSelect = function NativeSelect(_ref) {
69
69
  }, [value, children]);
70
70
  var TypographyComponent = platform === VKCOM || sizeY === SizeType.COMPACT ? Text : Headline;
71
71
  return createScopedElement(FormField, {
72
- Component: "label",
72
+ Component: "label" // eslint-disable-next-line vkui/no-object-expression-in-arguments
73
+ ,
73
74
  vkuiClass: classNames(getClassName("Select", platform), (_classNames = {}, _defineProperty(_classNames, "Select--not-selected", notSelected), _defineProperty(_classNames, "Select--align-".concat(align), !!align), _defineProperty(_classNames, "Select--sizeX--".concat(sizeX), !!sizeX), _defineProperty(_classNames, "Select--sizeY--".concat(sizeY), !!sizeY), _defineProperty(_classNames, "Select--multiline", multiline), _classNames)),
74
75
  className: className,
75
76
  style: style,
@@ -91,10 +92,9 @@ var NativeSelect = function NativeSelect(_ref) {
91
92
  }, createScopedElement("span", {
92
93
  vkuiClass: "Select__title"
93
94
  }, title)));
94
- }; // eslint-disable-next-line import/no-default-export
95
+ };
95
96
 
96
-
97
- export default withAdaptivity(NativeSelect, {
97
+ export var NativeSelect = withAdaptivity(NativeSelectComponent, {
98
98
  sizeX: true,
99
99
  sizeY: true
100
100
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/NativeSelect/NativeSelect.tsx"],"names":["React","classNames","DropdownIcon","FormField","withAdaptivity","SizeType","getClassName","Headline","Text","VKCOM","useIsomorphicLayoutEffect","useEnsuredControl","useExternRef","usePlatform","NativeSelect","style","defaultValue","align","placeholder","children","className","getRef","getRootRef","disabled","sizeX","sizeY","multiline","restProps","platform","useState","title","setTitle","notSelected","setNotSelected","value","onChange","selectRef","selectedOption","current","options","selectedIndex","text","TypographyComponent","COMPACT"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { DropdownIcon } from \"../DropdownIcon/DropdownIcon\";\nimport { FormField } from \"../FormField/FormField\";\nimport { HasAlign, HasRef, HasRootRef } from \"../../types\";\nimport { withAdaptivity, SizeType } from \"../../hoc/withAdaptivity\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport Headline from \"../Typography/Headline/Headline\";\nimport Text from \"../Typography/Text/Text\";\nimport { VKCOM } from \"../../lib/platform\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { useEnsuredControl } from \"../../hooks/useEnsuredControl\";\nimport { useExternRef } from \"../../hooks/useExternRef\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport {\n AdaptivityContextInterface,\n AdaptivityProps,\n} from \"../AdaptivityProvider/AdaptivityContext\";\nimport \"../Select/Select.css\";\n\nexport interface NativeSelectProps\n extends React.SelectHTMLAttributes<HTMLSelectElement>,\n HasRef<HTMLSelectElement>,\n HasRootRef<HTMLLabelElement>,\n HasAlign,\n AdaptivityProps {\n placeholder?: string;\n multiline?: boolean;\n}\n\nexport interface SelectState {\n value?: React.SelectHTMLAttributes<HTMLSelectElement>[\"value\"];\n title?: string;\n notSelected?: boolean;\n}\n\nconst NativeSelect: React.FC<\n NativeSelectProps & AdaptivityContextInterface\n> = ({\n style,\n defaultValue = \"\",\n align,\n placeholder,\n children,\n className,\n getRef,\n getRootRef,\n disabled,\n sizeX,\n sizeY,\n multiline,\n ...restProps\n}) => {\n const platform = usePlatform();\n const [title, setTitle] = React.useState(\"\");\n const [notSelected, setNotSelected] = React.useState(false);\n const [value, onChange] = useEnsuredControl(restProps, { defaultValue });\n const selectRef = useExternRef(getRef);\n useIsomorphicLayoutEffect(() => {\n const selectedOption =\n selectRef.current?.options[selectRef.current.selectedIndex];\n if (selectedOption) {\n setTitle(selectedOption.text);\n setNotSelected(selectedOption.value === \"\" && placeholder != null);\n }\n }, [value, children]);\n\n const TypographyComponent =\n platform === VKCOM || sizeY === SizeType.COMPACT ? Text : Headline;\n\n return (\n <FormField\n Component=\"label\"\n vkuiClass={classNames(getClassName(\"Select\", platform), {\n [\"Select--not-selected\"]: notSelected,\n [`Select--align-${align}`]: !!align,\n [`Select--sizeX--${sizeX}`]: !!sizeX,\n [`Select--sizeY--${sizeY}`]: !!sizeY,\n \"Select--multiline\": multiline,\n })}\n className={className}\n style={style}\n getRootRef={getRootRef}\n disabled={disabled}\n after={<DropdownIcon />}\n >\n <select\n {...restProps}\n disabled={disabled}\n vkuiClass=\"Select__el\"\n onChange={onChange}\n value={value}\n ref={selectRef}\n >\n {placeholder && <option value=\"\">{placeholder}</option>}\n {children}\n </select>\n <TypographyComponent\n Component=\"div\"\n weight=\"regular\"\n vkuiClass=\"Select__container\"\n >\n <span vkuiClass=\"Select__title\">{title}</span>\n </TypographyComponent>\n </FormField>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default withAdaptivity(NativeSelect, {\n sizeX: true,\n sizeY: true,\n});\n"],"file":"NativeSelect.js"}
1
+ {"version":3,"sources":["../../../../src/components/NativeSelect/NativeSelect.tsx"],"names":["React","classNames","DropdownIcon","FormField","withAdaptivity","SizeType","getClassName","Headline","Text","VKCOM","useIsomorphicLayoutEffect","useEnsuredControl","useExternRef","usePlatform","NativeSelectComponent","style","defaultValue","align","placeholder","children","className","getRef","getRootRef","disabled","sizeX","sizeY","multiline","restProps","platform","useState","title","setTitle","notSelected","setNotSelected","value","onChange","selectRef","selectedOption","current","options","selectedIndex","text","TypographyComponent","COMPACT","NativeSelect"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { DropdownIcon } from \"../DropdownIcon/DropdownIcon\";\nimport { FormField } from \"../FormField/FormField\";\nimport { HasAlign, HasRef, HasRootRef } from \"../../types\";\nimport { withAdaptivity, SizeType } from \"../../hoc/withAdaptivity\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport Headline from \"../Typography/Headline/Headline\";\nimport Text from \"../Typography/Text/Text\";\nimport { VKCOM } from \"../../lib/platform\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { useEnsuredControl } from \"../../hooks/useEnsuredControl\";\nimport { useExternRef } from \"../../hooks/useExternRef\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport {\n AdaptivityContextInterface,\n AdaptivityProps,\n} from \"../AdaptivityProvider/AdaptivityContext\";\nimport \"../Select/Select.css\";\n\nexport interface NativeSelectProps\n extends React.SelectHTMLAttributes<HTMLSelectElement>,\n HasRef<HTMLSelectElement>,\n HasRootRef<HTMLLabelElement>,\n HasAlign,\n AdaptivityProps {\n placeholder?: string;\n multiline?: boolean;\n}\n\nexport interface SelectState {\n value?: React.SelectHTMLAttributes<HTMLSelectElement>[\"value\"];\n title?: string;\n notSelected?: boolean;\n}\n\nconst NativeSelectComponent: React.FC<\n NativeSelectProps & AdaptivityContextInterface\n> = ({\n style,\n defaultValue = \"\",\n align,\n placeholder,\n children,\n className,\n getRef,\n getRootRef,\n disabled,\n sizeX,\n sizeY,\n multiline,\n ...restProps\n}) => {\n const platform = usePlatform();\n const [title, setTitle] = React.useState(\"\");\n const [notSelected, setNotSelected] = React.useState(false);\n const [value, onChange] = useEnsuredControl(restProps, { defaultValue });\n const selectRef = useExternRef(getRef);\n useIsomorphicLayoutEffect(() => {\n const selectedOption =\n selectRef.current?.options[selectRef.current.selectedIndex];\n if (selectedOption) {\n setTitle(selectedOption.text);\n setNotSelected(selectedOption.value === \"\" && placeholder != null);\n }\n }, [value, children]);\n\n const TypographyComponent =\n platform === VKCOM || sizeY === SizeType.COMPACT ? Text : Headline;\n\n return (\n <FormField\n Component=\"label\"\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(getClassName(\"Select\", platform), {\n [\"Select--not-selected\"]: notSelected,\n [`Select--align-${align}`]: !!align,\n [`Select--sizeX--${sizeX}`]: !!sizeX,\n [`Select--sizeY--${sizeY}`]: !!sizeY,\n \"Select--multiline\": multiline,\n })}\n className={className}\n style={style}\n getRootRef={getRootRef}\n disabled={disabled}\n after={<DropdownIcon />}\n >\n <select\n {...restProps}\n disabled={disabled}\n vkuiClass=\"Select__el\"\n onChange={onChange}\n value={value}\n ref={selectRef}\n >\n {placeholder && <option value=\"\">{placeholder}</option>}\n {children}\n </select>\n <TypographyComponent\n Component=\"div\"\n weight=\"regular\"\n vkuiClass=\"Select__container\"\n >\n <span vkuiClass=\"Select__title\">{title}</span>\n </TypographyComponent>\n </FormField>\n );\n};\n\nexport const NativeSelect = withAdaptivity(NativeSelectComponent, {\n sizeX: true,\n sizeY: true,\n});\n"],"file":"NativeSelect.js"}
@@ -1 +1 @@
1
- .vkuiPagination__list{display:flex;margin:0;padding:0;list-style-type:none}.vkuiPagination__prevButtonContainer{margin-right:8px}.vkuiPagination__nextButtonContainer{margin-left:8px}.vkuiPagination__page{box-sizing:border-box;padding-right:8px;padding-left:8px;width:100%;min-width:40px;border-radius:8px;border-radius:var(--vkui--size_border_radius--regular);text-align:center;color:#818c99;color:var(--vkui--color_text_secondary);-webkit-user-select:none;user-select:none}.vkuiPagination__page--state-hover{background-color:rgba(0,16,61,.04);background-color:var(--vkui--color_transparent--hover)}.vkuiPagination__page--state-active,.vkuiPagination__page--current{color:#000;color:var(--vkui--color_text_primary);background-color:rgba(0,16,61,.08);background-color:var(--vkui--color_transparent--active)}.vkuiPagination__page--disabled{opacity:.4;opacity:var(--vkui--opacity_disable)}.vkuiPagination__page--sizeY-compact{font-size:15px;font-size:var(--vkui--font_text--font_size--compact);line-height:36px;line-height:var(--vkui--size_button_large_height--compact);height:36px;height:var(--vkui--size_button_large_height--compact)}.vkuiPagination__page--sizeY-regular{font-size:16px;font-size:var(--vkui--font_text--font_size--regular);line-height:44px;line-height:var(--vkui--size_button_large_height--regular);height:44px;height:var(--vkui--size_button_large_height--regular)}.vkuiPagination__page--type-ellipsis{min-width:16px;padding-right:0;padding-left:0}
1
+ .vkuiPagination__list{display:flex;margin:0;padding:0;list-style-type:none}.vkuiPagination__prevButtonContainer{margin-right:8px}.vkuiPagination__nextButtonContainer{margin-left:8px}.vkuiPagination__page{box-sizing:border-box;padding-right:8px;padding-left:8px;width:100%;min-width:40px;border-radius:8px;border-radius:var(--vkui--size_border_radius--regular);text-align:center;color:#818c99;color:var(--vkui--color_text_secondary);-webkit-user-select:none;user-select:none}.vkuiPagination__page--state-hover{background-color:rgba(0,16,61,.04);background-color:var(--vkui--color_transparent--hover)}.vkuiPagination__page--state-active,.vkuiPagination__page--current{color:#000;color:var(--vkui--color_text_primary);background-color:rgba(0,16,61,.08);background-color:var(--vkui--color_transparent--active)}.vkuiPagination__page--disabled{opacity:.4;opacity:var(--vkui--opacity_disable)}.vkuiPagination__page--sizeY-compact{font-size:15px;font-size:var(--vkui--font_text--font_size--compact);line-height:36px;line-height:var(--vkui--size_button_large_height--compact);height:36px;height:var(--vkui--size_button_large_height--compact);letter-spacing:var(--vk-sans-ls-17)}.vkuiPagination__page--sizeY-regular{font-size:16px;font-size:var(--vkui--font_text--font_size--regular);line-height:44px;line-height:var(--vkui--size_button_large_height--regular);height:44px;height:var(--vkui--size_button_large_height--regular);letter-spacing:var(--vk-sans-ls-2)}.vkuiPagination__page--type-ellipsis{min-width:16px;padding-right:0;padding-left:0}
@@ -23,17 +23,17 @@ export interface PaginationProps extends Omit<React.HTMLAttributes<HTMLElement>,
23
23
  */
24
24
  disabled?: boolean;
25
25
  /**
26
- * Переобределение `aria-label` для кнопки навигации назад.
26
+ * Переопределение `aria-label` для кнопки навигации назад.
27
27
  * По умолчанию используется текст на "ru_RU".
28
28
  */
29
29
  prevButtonAriaLabel?: string;
30
30
  /**
31
- * Переобределение `aria-label` для кнопки навигации вперёд.
31
+ * Переопределение `aria-label` для кнопки навигации вперёд.
32
32
  * По умолчанию используется текст на "ru_RU".
33
33
  */
34
34
  nextButtonAriaLabel?: string;
35
35
  /**
36
- * Функция для переопределния и/или локализации `aria-label` атрибута.
36
+ * Функция для переопределения и/или локализации `aria-label` атрибута.
37
37
  * По умолчанию используется текст на "ru_RU".
38
38
  */
39
39
  getPageAriaLabel?(page: number, isCurrent: boolean): string;
@@ -8,7 +8,7 @@ import { classNames } from "../../lib/classNames";
8
8
  import { useAdaptivity } from "../../hooks/useAdaptivity";
9
9
  import { usePagination } from "../../hooks/usePagination";
10
10
  import Tappable from "../Tappable/Tappable";
11
- import Button from "../Button/Button";
11
+ import { Button } from "../Button/Button";
12
12
  import "./Pagination.css";
13
13
 
14
14
  function getPageAriaLabelDefault(page, isCurrent) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/Pagination/Pagination.tsx"],"names":["React","Icon24ChevronCompactLeft","Icon24ChevronCompactRight","classNames","useAdaptivity","usePagination","Tappable","Button","getPageAriaLabelDefault","page","isCurrent","Pagination","currentPage","siblingCount","boundaryCount","totalPages","disabled","getPageAriaLabel","prevButtonAriaLabel","nextButtonAriaLabel","getRootRef","onChange","resetProps","sizeY","pages","isFirstPage","isLastPage","handlePrevClick","useCallback","handleClick","event","currentTarget","dataset","Number","handleNextClick","renderPages","undefined","map"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport {\n Icon24ChevronCompactLeft,\n Icon24ChevronCompactRight,\n} from \"@vkontakte/icons\";\n\nimport type { HasRootRef } from \"../../types\";\n\nimport { classNames } from \"../../lib/classNames\";\n\nimport { useAdaptivity } from \"../../hooks/useAdaptivity\";\nimport { PaginationPageType, usePagination } from \"../../hooks/usePagination\";\n\nimport Tappable from \"../Tappable/Tappable\";\nimport Button from \"../Button/Button\";\n\nimport \"./Pagination.css\";\n\nfunction getPageAriaLabelDefault(page: number, isCurrent: boolean): string {\n return isCurrent ? `${page} страница` : `Перейти на ${page} страницу`;\n}\n\nexport interface PaginationProps\n extends Omit<React.HTMLAttributes<HTMLElement>, \"onChange\">,\n HasRootRef<HTMLElement> {\n /**\n * Текущая страница.\n */\n currentPage?: number;\n /**\n * Кол-во всегда видимых страниц по краям текущей страницы.\n */\n siblingCount?: number;\n /**\n * Кол-во всегда видимых страниц в начале и в конце.\n */\n boundaryCount?: number;\n /**\n * Общее кол-во страниц.\n */\n totalPages?: number;\n /**\n * Блокировка всех кнопок.\n */\n disabled?: boolean;\n /**\n * Переобределение `aria-label` для кнопки навигации назад.\n * По умолчанию используется текст на \"ru_RU\".\n */\n prevButtonAriaLabel?: string;\n /**\n * Переобределение `aria-label` для кнопки навигации вперёд.\n * По умолчанию используется текст на \"ru_RU\".\n */\n nextButtonAriaLabel?: string;\n /**\n * Функция для переопределния и/или локализации `aria-label` атрибута.\n * По умолчанию используется текст на \"ru_RU\".\n */\n getPageAriaLabel?(page: number, isCurrent: boolean): string;\n onChange?(page: number): void;\n}\n\nexport const Pagination: React.FC<PaginationProps> = ({\n currentPage = 1,\n siblingCount = 1,\n boundaryCount = 1,\n totalPages = 1,\n disabled,\n getPageAriaLabel = getPageAriaLabelDefault,\n prevButtonAriaLabel = \"Перейти на предыдущую страницу\",\n nextButtonAriaLabel = \"Перейти на следующую страницу\",\n getRootRef,\n onChange,\n ...resetProps\n}) => {\n const { sizeY } = useAdaptivity();\n\n const pages = usePagination({\n currentPage,\n totalPages,\n siblingCount,\n boundaryCount,\n });\n const isFirstPage = currentPage === 1;\n const isLastPage = currentPage === totalPages;\n\n const handlePrevClick = React.useCallback(() => {\n if (onChange && !isFirstPage) {\n onChange(currentPage - 1);\n }\n }, [currentPage, isFirstPage, onChange]);\n\n const handleClick = React.useCallback(\n (event: React.MouseEvent<HTMLElement>) => {\n const page: string = event.currentTarget.dataset.page || \"1\";\n onChange?.(Number(page));\n },\n [onChange]\n );\n\n const handleNextClick = React.useCallback(() => {\n if (onChange && !isLastPage) {\n onChange(currentPage + 1);\n }\n }, [currentPage, isLastPage, onChange]);\n\n const renderPages = React.useCallback(\n (page: PaginationPageType) => {\n switch (page) {\n case \"start-ellipsis\":\n case \"end-ellipsis\":\n return (\n <li key={page}>\n <div\n vkuiClass={classNames(\n \"Pagination__page\",\n \"Pagination__page--type-ellipsis\",\n `Pagination__page--sizeY-${sizeY}`,\n disabled && \"Pagination__page--disabled\"\n )}\n >\n ...\n </div>\n </li>\n );\n default: {\n const isCurrent = page === currentPage;\n return (\n <li key={page}>\n <Tappable\n vkuiClass={classNames(\n \"Pagination__page\",\n `Pagination__page--sizeY-${sizeY}`,\n isCurrent && \"Pagination__page--current\",\n disabled && \"Pagination__page--disabled\"\n )}\n activeMode=\"Pagination__page--state-active\"\n hoverMode=\"Pagination__page--state-hover\"\n hasActive={!isCurrent}\n hasHover={!isCurrent}\n focusVisibleMode=\"outside\"\n disabled={disabled}\n data-page={page}\n aria-current={isCurrent ? true : undefined}\n aria-label={getPageAriaLabel(page, isCurrent)}\n onClick={handleClick}\n >\n {page}\n </Tappable>\n </li>\n );\n }\n }\n },\n [sizeY, currentPage, disabled, getPageAriaLabel, handleClick]\n );\n\n return (\n <nav\n vkuiClass=\"Pagination\"\n role=\"navigation\"\n aria-label=\"Навигация по страницам\"\n ref={getRootRef}\n {...resetProps}\n >\n <ul vkuiClass=\"Pagination__list\">\n <li vkuiClass=\"Pagination__prevButtonContainer\">\n <Button\n size=\"l\"\n before={<Icon24ChevronCompactLeft width={24} />}\n appearance=\"accent\"\n mode=\"tertiary\"\n stretched\n disabled={isFirstPage || disabled}\n aria-label={prevButtonAriaLabel}\n onClick={handlePrevClick}\n />\n </li>\n {pages.map(renderPages)}\n <li vkuiClass=\"Pagination__nextButtonContainer\">\n <Button\n size=\"l\"\n after={<Icon24ChevronCompactRight width={24} />}\n appearance=\"accent\"\n mode=\"tertiary\"\n stretched\n disabled={isLastPage || disabled}\n aria-label={nextButtonAriaLabel}\n onClick={handleNextClick}\n />\n </li>\n </ul>\n </nav>\n );\n};\n"],"file":"Pagination.js"}
1
+ {"version":3,"sources":["../../../../src/components/Pagination/Pagination.tsx"],"names":["React","Icon24ChevronCompactLeft","Icon24ChevronCompactRight","classNames","useAdaptivity","usePagination","Tappable","Button","getPageAriaLabelDefault","page","isCurrent","Pagination","currentPage","siblingCount","boundaryCount","totalPages","disabled","getPageAriaLabel","prevButtonAriaLabel","nextButtonAriaLabel","getRootRef","onChange","resetProps","sizeY","pages","isFirstPage","isLastPage","handlePrevClick","useCallback","handleClick","event","currentTarget","dataset","Number","handleNextClick","renderPages","undefined","map"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport {\n Icon24ChevronCompactLeft,\n Icon24ChevronCompactRight,\n} from \"@vkontakte/icons\";\n\nimport type { HasRootRef } from \"../../types\";\n\nimport { classNames } from \"../../lib/classNames\";\n\nimport { useAdaptivity } from \"../../hooks/useAdaptivity\";\nimport { PaginationPageType, usePagination } from \"../../hooks/usePagination\";\n\nimport Tappable from \"../Tappable/Tappable\";\nimport { Button } from \"../Button/Button\";\n\nimport \"./Pagination.css\";\n\nfunction getPageAriaLabelDefault(page: number, isCurrent: boolean): string {\n return isCurrent ? `${page} страница` : `Перейти на ${page} страницу`;\n}\n\nexport interface PaginationProps\n extends Omit<React.HTMLAttributes<HTMLElement>, \"onChange\">,\n HasRootRef<HTMLElement> {\n /**\n * Текущая страница.\n */\n currentPage?: number;\n /**\n * Кол-во всегда видимых страниц по краям текущей страницы.\n */\n siblingCount?: number;\n /**\n * Кол-во всегда видимых страниц в начале и в конце.\n */\n boundaryCount?: number;\n /**\n * Общее кол-во страниц.\n */\n totalPages?: number;\n /**\n * Блокировка всех кнопок.\n */\n disabled?: boolean;\n /**\n * Переопределение `aria-label` для кнопки навигации назад.\n * По умолчанию используется текст на \"ru_RU\".\n */\n prevButtonAriaLabel?: string;\n /**\n * Переопределение `aria-label` для кнопки навигации вперёд.\n * По умолчанию используется текст на \"ru_RU\".\n */\n nextButtonAriaLabel?: string;\n /**\n * Функция для переопределения и/или локализации `aria-label` атрибута.\n * По умолчанию используется текст на \"ru_RU\".\n */\n getPageAriaLabel?(page: number, isCurrent: boolean): string;\n onChange?(page: number): void;\n}\n\nexport const Pagination: React.FC<PaginationProps> = ({\n currentPage = 1,\n siblingCount = 1,\n boundaryCount = 1,\n totalPages = 1,\n disabled,\n getPageAriaLabel = getPageAriaLabelDefault,\n prevButtonAriaLabel = \"Перейти на предыдущую страницу\",\n nextButtonAriaLabel = \"Перейти на следующую страницу\",\n getRootRef,\n onChange,\n ...resetProps\n}) => {\n const { sizeY } = useAdaptivity();\n\n const pages = usePagination({\n currentPage,\n totalPages,\n siblingCount,\n boundaryCount,\n });\n const isFirstPage = currentPage === 1;\n const isLastPage = currentPage === totalPages;\n\n const handlePrevClick = React.useCallback(() => {\n if (onChange && !isFirstPage) {\n onChange(currentPage - 1);\n }\n }, [currentPage, isFirstPage, onChange]);\n\n const handleClick = React.useCallback(\n (event: React.MouseEvent<HTMLElement>) => {\n const page: string = event.currentTarget.dataset.page || \"1\";\n onChange?.(Number(page));\n },\n [onChange]\n );\n\n const handleNextClick = React.useCallback(() => {\n if (onChange && !isLastPage) {\n onChange(currentPage + 1);\n }\n }, [currentPage, isLastPage, onChange]);\n\n const renderPages = React.useCallback(\n (page: PaginationPageType) => {\n switch (page) {\n case \"start-ellipsis\":\n case \"end-ellipsis\":\n return (\n <li key={page}>\n <div\n vkuiClass={classNames(\n \"Pagination__page\",\n \"Pagination__page--type-ellipsis\",\n `Pagination__page--sizeY-${sizeY}`,\n disabled && \"Pagination__page--disabled\"\n )}\n >\n ...\n </div>\n </li>\n );\n default: {\n const isCurrent = page === currentPage;\n return (\n <li key={page}>\n <Tappable\n vkuiClass={classNames(\n \"Pagination__page\",\n `Pagination__page--sizeY-${sizeY}`,\n isCurrent && \"Pagination__page--current\",\n disabled && \"Pagination__page--disabled\"\n )}\n activeMode=\"Pagination__page--state-active\"\n hoverMode=\"Pagination__page--state-hover\"\n hasActive={!isCurrent}\n hasHover={!isCurrent}\n focusVisibleMode=\"outside\"\n disabled={disabled}\n data-page={page}\n aria-current={isCurrent ? true : undefined}\n aria-label={getPageAriaLabel(page, isCurrent)}\n onClick={handleClick}\n >\n {page}\n </Tappable>\n </li>\n );\n }\n }\n },\n [sizeY, currentPage, disabled, getPageAriaLabel, handleClick]\n );\n\n return (\n <nav\n vkuiClass=\"Pagination\"\n role=\"navigation\"\n aria-label=\"Навигация по страницам\"\n ref={getRootRef}\n {...resetProps}\n >\n <ul vkuiClass=\"Pagination__list\">\n <li vkuiClass=\"Pagination__prevButtonContainer\">\n <Button\n size=\"l\"\n before={<Icon24ChevronCompactLeft width={24} />}\n appearance=\"accent\"\n mode=\"tertiary\"\n stretched\n disabled={isFirstPage || disabled}\n aria-label={prevButtonAriaLabel}\n onClick={handlePrevClick}\n />\n </li>\n {pages.map(renderPages)}\n <li vkuiClass=\"Pagination__nextButtonContainer\">\n <Button\n size=\"l\"\n after={<Icon24ChevronCompactRight width={24} />}\n appearance=\"accent\"\n mode=\"tertiary\"\n stretched\n disabled={isLastPage || disabled}\n aria-label={nextButtonAriaLabel}\n onClick={handleNextClick}\n />\n </li>\n </ul>\n </nav>\n );\n};\n"],"file":"Pagination.js"}
@@ -22,7 +22,8 @@ export var Panel = withAdaptivity(function (_ref) {
22
22
 
23
23
  var platform = usePlatform();
24
24
  return createScopedElement("div", _extends({}, restProps, {
25
- ref: getRootRef,
25
+ ref: getRootRef // eslint-disable-next-line vkui/no-object-expression-in-arguments
26
+ ,
26
27
  vkuiClass: classNames(getClassName("Panel", platform), "Panel--".concat(sizeX), _defineProperty({
27
28
  "Panel--centered": centered
28
29
  }, "Panel--sizeX-".concat(sizeX), true))
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/Panel/Panel.tsx"],"names":["getClassName","classNames","Touch","TooltipContainer","withAdaptivity","IOS","usePlatform","Panel","centered","children","getRootRef","sizeX","nav","restProps","platform"],"mappings":";;;;;AACA,SAASA,YAAT;AACA,SAASC,UAAT;AACA,SAASC,KAAT;AACA,SAASC,gBAAT;AAEA,SAASC,cAAT;AACA,SAASC,GAAT;AACA,SAASC,WAAT;AAMA;AAUA,OAAO,IAAMC,KAAK,GAAGH,cAAc,CACjC,gBAA0E;AAAA,2BAAvEI,QAAuE;AAAA,MAAvEA,QAAuE,8BAA5D,KAA4D;AAAA,MAArDC,QAAqD,QAArDA,QAAqD;AAAA,MAA3CC,UAA2C,QAA3CA,UAA2C;AAAA,MAA/BC,KAA+B,QAA/BA,KAA+B;AAAA,MAAxBC,GAAwB,QAAxBA,GAAwB;AAAA,MAAhBC,SAAgB;;AACxE,MAAMC,QAAQ,GAAGR,WAAW,EAA5B;AAEA,SACE,wCACMO,SADN;AAEE,IAAA,GAAG,EAAEH,UAFP;AAGE,IAAA,SAAS,EAAET,UAAU,CACnBD,YAAY,CAAC,OAAD,EAAUc,QAAV,CADO,mBAETH,KAFS;AAIjB,yBAAmBH;AAJF,8BAKAG,KALA,GAKU,IALV;AAHvB,MAYE,oBAAC,KAAD;AAAO,IAAA,SAAS,EAAER,gBAAlB;AAAoC,IAAA,SAAS,EAAC;AAA9C,KACGW,QAAQ,KAAKT,GAAb,IAAoB;AAAK,IAAA,SAAS,EAAC;AAAf,IADvB,EAEE;AAAK,IAAA,SAAS,EAAC;AAAf,IAFF,EAGGG,QAAQ,GACP;AAAK,IAAA,SAAS,EAAC;AAAf,KAAkCC,QAAlC,CADO,GAGPA,QANJ,EAQE;AAAK,IAAA,SAAS,EAAC;AAAf,IARF,CAZF,CADF;AAyBD,CA7BgC,EA8BjC;AACEE,EAAAA,KAAK,EAAE;AADT,CA9BiC,CAA5B","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport { Touch } from \"../Touch/Touch\";\nimport { TooltipContainer } from \"../Tooltip/TooltipContainer\";\nimport { HasRootRef } from \"../../types\";\nimport { withAdaptivity } from \"../../hoc/withAdaptivity\";\nimport { IOS } from \"../../lib/platform\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { NavIdProps } from \"../../lib/getNavId\";\nimport {\n AdaptivityContextInterface,\n AdaptivityProps,\n} from \"../AdaptivityProvider/AdaptivityContext\";\nimport \"./Panel.css\";\n\nexport interface PanelProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement>,\n AdaptivityProps,\n NavIdProps {\n centered?: boolean;\n}\n\nexport const Panel = withAdaptivity<PanelProps & AdaptivityContextInterface>(\n ({ centered = false, children, getRootRef, sizeX, nav, ...restProps }) => {\n const platform = usePlatform();\n\n return (\n <div\n {...restProps}\n ref={getRootRef}\n vkuiClass={classNames(\n getClassName(\"Panel\", platform),\n `Panel--${sizeX}`,\n {\n \"Panel--centered\": centered,\n [`Panel--sizeX-${sizeX}`]: true,\n }\n )}\n >\n <Touch Component={TooltipContainer} vkuiClass=\"Panel__in\">\n {platform === IOS && <div vkuiClass=\"Panel__fade\" />}\n <div vkuiClass=\"Panel__in-before\" />\n {centered ? (\n <div vkuiClass=\"Panel__centered\">{children}</div>\n ) : (\n children\n )}\n <div vkuiClass=\"Panel__in-after\" />\n </Touch>\n </div>\n );\n },\n {\n sizeX: true,\n }\n);\n"],"file":"Panel.js"}
1
+ {"version":3,"sources":["../../../../src/components/Panel/Panel.tsx"],"names":["getClassName","classNames","Touch","TooltipContainer","withAdaptivity","IOS","usePlatform","Panel","centered","children","getRootRef","sizeX","nav","restProps","platform"],"mappings":";;;;;AACA,SAASA,YAAT;AACA,SAASC,UAAT;AACA,SAASC,KAAT;AACA,SAASC,gBAAT;AAEA,SAASC,cAAT;AACA,SAASC,GAAT;AACA,SAASC,WAAT;AAMA;AAUA,OAAO,IAAMC,KAAK,GAAGH,cAAc,CACjC,gBAA0E;AAAA,2BAAvEI,QAAuE;AAAA,MAAvEA,QAAuE,8BAA5D,KAA4D;AAAA,MAArDC,QAAqD,QAArDA,QAAqD;AAAA,MAA3CC,UAA2C,QAA3CA,UAA2C;AAAA,MAA/BC,KAA+B,QAA/BA,KAA+B;AAAA,MAAxBC,GAAwB,QAAxBA,GAAwB;AAAA,MAAhBC,SAAgB;;AACxE,MAAMC,QAAQ,GAAGR,WAAW,EAA5B;AAEA,SACE,wCACMO,SADN;AAEE,IAAA,GAAG,EAAEH,UAFP,CAGE;AAHF;AAIE,IAAA,SAAS,EAAET,UAAU,CACnBD,YAAY,CAAC,OAAD,EAAUc,QAAV,CADO,mBAETH,KAFS;AAIjB,yBAAmBH;AAJF,8BAKAG,KALA,GAKU,IALV;AAJvB,MAaE,oBAAC,KAAD;AAAO,IAAA,SAAS,EAAER,gBAAlB;AAAoC,IAAA,SAAS,EAAC;AAA9C,KACGW,QAAQ,KAAKT,GAAb,IAAoB;AAAK,IAAA,SAAS,EAAC;AAAf,IADvB,EAEE;AAAK,IAAA,SAAS,EAAC;AAAf,IAFF,EAGGG,QAAQ,GACP;AAAK,IAAA,SAAS,EAAC;AAAf,KAAkCC,QAAlC,CADO,GAGPA,QANJ,EAQE;AAAK,IAAA,SAAS,EAAC;AAAf,IARF,CAbF,CADF;AA0BD,CA9BgC,EA+BjC;AACEE,EAAAA,KAAK,EAAE;AADT,CA/BiC,CAA5B","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport { Touch } from \"../Touch/Touch\";\nimport { TooltipContainer } from \"../Tooltip/TooltipContainer\";\nimport { HasRootRef } from \"../../types\";\nimport { withAdaptivity } from \"../../hoc/withAdaptivity\";\nimport { IOS } from \"../../lib/platform\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { NavIdProps } from \"../../lib/getNavId\";\nimport {\n AdaptivityContextInterface,\n AdaptivityProps,\n} from \"../AdaptivityProvider/AdaptivityContext\";\nimport \"./Panel.css\";\n\nexport interface PanelProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement>,\n AdaptivityProps,\n NavIdProps {\n centered?: boolean;\n}\n\nexport const Panel = withAdaptivity<PanelProps & AdaptivityContextInterface>(\n ({ centered = false, children, getRootRef, sizeX, nav, ...restProps }) => {\n const platform = usePlatform();\n\n return (\n <div\n {...restProps}\n ref={getRootRef}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"Panel\", platform),\n `Panel--${sizeX}`,\n {\n \"Panel--centered\": centered,\n [`Panel--sizeX-${sizeX}`]: true,\n }\n )}\n >\n <Touch Component={TooltipContainer} vkuiClass=\"Panel__in\">\n {platform === IOS && <div vkuiClass=\"Panel__fade\" />}\n <div vkuiClass=\"Panel__in-before\" />\n {centered ? (\n <div vkuiClass=\"Panel__centered\">{children}</div>\n ) : (\n children\n )}\n <div vkuiClass=\"Panel__in-after\" />\n </Touch>\n </div>\n );\n },\n {\n sizeX: true,\n }\n);\n"],"file":"Panel.js"}