@vkontakte/vkui 4.23.0 → 4.24.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2192) hide show
  1. package/.cache/.eslintcache +1 -1
  2. package/.cache/.stylelintcache +1 -1
  3. package/.cache/.tsbuildinfo +6136 -1112
  4. package/.cache/ts/src/components/ActionSheet/ActionSheet.d.ts +3 -3
  5. package/.cache/ts/src/components/ActionSheet/ActionSheetContext.d.ts +1 -1
  6. package/.cache/ts/src/components/ActionSheet/ActionSheetDropdown.d.ts +3 -3
  7. package/.cache/ts/src/components/ActionSheet/ActionSheetDropdownDesktop.d.ts +3 -3
  8. package/.cache/ts/src/components/ActionSheet/types.d.ts +3 -3
  9. package/.cache/ts/src/components/ActionSheetItem/ActionSheetItem.d.ts +5 -5
  10. package/.cache/ts/src/components/AdaptivityProvider/AdaptivityContext.d.ts +1 -1
  11. package/.cache/ts/src/components/AdaptivityProvider/AdaptivityProvider.d.ts +2 -2
  12. package/.cache/ts/src/components/Alert/Alert.d.ts +9 -9
  13. package/.cache/ts/src/components/AppRoot/AppRoot.d.ts +6 -6
  14. package/.cache/ts/src/components/AppRoot/AppRootContext.d.ts +2 -2
  15. package/.cache/ts/src/components/AppRoot/AppRootPortal.d.ts +1 -1
  16. package/.cache/ts/src/components/AppRoot/ScrollContext.d.ts +1 -1
  17. package/.cache/ts/src/components/Avatar/Avatar.d.ts +11 -4
  18. package/.cache/ts/src/components/Badge/Badge.d.ts +3 -3
  19. package/.cache/ts/src/components/Banner/Banner.d.ts +6 -6
  20. package/.cache/ts/src/components/Button/Button.d.ts +11 -7
  21. package/.cache/ts/src/components/Card/Card.d.ts +4 -4
  22. package/.cache/ts/src/components/CardGrid/CardGrid.d.ts +4 -4
  23. package/.cache/ts/src/components/CardScroll/CardScroll.d.ts +4 -4
  24. package/.cache/ts/src/components/Cell/Cell.d.ts +6 -6
  25. package/.cache/ts/src/components/Cell/CellCheckbox/CellCheckbox.d.ts +4 -4
  26. package/.cache/ts/src/components/Cell/CellDragger/CellDragger.d.ts +3 -3
  27. package/.cache/ts/src/components/Cell/useDraggable.d.ts +3 -3
  28. package/.cache/ts/src/components/CellButton/CellButton.d.ts +4 -4
  29. package/.cache/ts/src/components/Checkbox/Checkbox.d.ts +5 -4
  30. package/.cache/ts/src/components/Chip/Chip.d.ts +2 -2
  31. package/.cache/ts/src/components/ChipsInput/ChipsInput.d.ts +6 -6
  32. package/.cache/ts/src/components/ChipsInput/useChipsInput.d.ts +2 -2
  33. package/.cache/ts/src/components/ChipsSelect/ChipsSelect.d.ts +7 -7
  34. package/.cache/ts/src/components/ChipsSelect/useChipsSelect.d.ts +3 -3
  35. package/.cache/ts/src/components/ClickPopper/ClickPopper.d.ts +2 -2
  36. package/.cache/ts/src/components/ConfigProvider/ConfigProvider.d.ts +2 -2
  37. package/.cache/ts/src/components/ConfigProvider/ConfigProviderContext.d.ts +6 -4
  38. package/.cache/ts/src/components/ContentCard/ContentCard.d.ts +7 -21
  39. package/.cache/ts/src/components/Counter/Counter.d.ts +4 -4
  40. package/.cache/ts/src/components/CustomScrollView/CustomScrollView.d.ts +4 -3
  41. package/.cache/ts/src/components/CustomSelect/CustomSelect.d.ts +13 -9
  42. package/.cache/ts/src/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +12 -0
  43. package/.cache/ts/src/components/CustomSelectOption/CustomSelectOption.d.ts +3 -3
  44. package/.cache/ts/src/components/DatePicker/DatePicker.d.ts +6 -6
  45. package/.cache/ts/src/components/Div/Div.d.ts +3 -3
  46. package/.cache/ts/src/components/Dropdown/Dropdown.d.ts +7 -7
  47. package/.cache/ts/src/components/DropdownIcon/DropdownIcon.d.ts +2 -2
  48. package/.cache/ts/src/components/Epic/Epic.d.ts +3 -3
  49. package/.cache/ts/src/components/Epic/ScrollSaver.d.ts +1 -1
  50. package/.cache/ts/src/components/File/File.d.ts +6 -6
  51. package/.cache/ts/src/components/FixedLayout/FixedLayout.d.ts +5 -5
  52. package/.cache/ts/src/components/FocusTrap/FocusTrap.d.ts +2 -2
  53. package/.cache/ts/src/components/FocusVisible/FocusVisible.d.ts +3 -3
  54. package/.cache/ts/src/components/Footer/Footer.d.ts +3 -3
  55. package/.cache/ts/src/components/FormField/FormField.d.ts +3 -3
  56. package/.cache/ts/src/components/FormItem/FormItem.d.ts +5 -5
  57. package/.cache/ts/src/components/FormLayout/FormLayout.d.ts +3 -3
  58. package/.cache/ts/src/components/FormLayoutGroup/FormLayoutGroup.d.ts +5 -5
  59. package/.cache/ts/src/components/FormStatus/FormStatus.d.ts +3 -3
  60. package/.cache/ts/src/components/Gallery/Gallery.d.ts +6 -6
  61. package/.cache/ts/src/components/Gradient/Gradient.d.ts +4 -4
  62. package/.cache/ts/src/components/GridAvatar/GridAvatar.d.ts +5 -6
  63. package/.cache/ts/src/components/Group/Group.d.ts +6 -6
  64. package/.cache/ts/src/components/Header/Header.d.ts +4 -4
  65. package/.cache/ts/src/components/HorizontalCell/HorizontalCell.d.ts +4 -4
  66. package/.cache/ts/src/components/HorizontalScroll/HorizontalScroll.d.ts +4 -4
  67. package/.cache/ts/src/components/HorizontalScroll/HorizontalScrollArrow.d.ts +3 -3
  68. package/.cache/ts/src/components/HoverPopper/HoverPopper.d.ts +2 -2
  69. package/.cache/ts/src/components/IconButton/IconButton.d.ts +3 -3
  70. package/.cache/ts/src/components/InfoRow/InfoRow.d.ts +2 -2
  71. package/.cache/ts/src/components/InitialsAvatar/InitialsAvatar.d.ts +6 -7
  72. package/.cache/ts/src/components/Input/Input.d.ts +5 -5
  73. package/.cache/ts/src/components/Link/Link.d.ts +3 -3
  74. package/.cache/ts/src/components/List/List.d.ts +2 -2
  75. package/.cache/ts/src/components/List/ListContext.d.ts +1 -1
  76. package/.cache/ts/src/components/MiniInfoCell/MiniInfoCell.d.ts +5 -5
  77. package/.cache/ts/src/components/ModalCard/ModalCard.d.ts +6 -6
  78. package/.cache/ts/src/components/ModalCardBase/ModalCardBase.d.ts +4 -4
  79. package/.cache/ts/src/components/ModalDismissButton/ModalDismissButton.d.ts +2 -2
  80. package/.cache/ts/src/components/ModalPage/ModalPage.d.ts +4 -4
  81. package/.cache/ts/src/components/ModalPageHeader/ModalPageHeader.d.ts +3 -3
  82. package/.cache/ts/src/components/ModalRoot/ModalRoot.d.ts +4 -4
  83. package/.cache/ts/src/components/ModalRoot/ModalRootAdaptive.d.ts +2 -2
  84. package/.cache/ts/src/components/ModalRoot/ModalRootContext.d.ts +3 -3
  85. package/.cache/ts/src/components/ModalRoot/ModalRootDesktop.d.ts +4 -4
  86. package/.cache/ts/src/components/ModalRoot/useModalManager.d.ts +3 -3
  87. package/.cache/ts/src/components/ModalRoot/withModalRootContext.d.ts +3 -3
  88. package/.cache/ts/src/components/NativeSelect/NativeSelect.d.ts +5 -5
  89. package/.cache/ts/src/components/NavTransitionContext/NavTransitionContext.d.ts +1 -1
  90. package/.cache/ts/src/components/Panel/Panel.d.ts +5 -5
  91. package/.cache/ts/src/components/PanelHeader/PanelHeader.d.ts +4 -4
  92. package/.cache/ts/src/components/PanelHeaderBack/PanelHeaderBack.d.ts +5 -5
  93. package/.cache/ts/src/components/PanelHeaderButton/PanelHeaderButton.d.ts +4 -4
  94. package/.cache/ts/src/components/PanelHeaderClose/PanelHeaderClose.d.ts +2 -2
  95. package/.cache/ts/src/components/PanelHeaderContent/PanelHeaderContent.d.ts +2 -2
  96. package/.cache/ts/src/components/PanelHeaderContext/PanelHeaderContext.d.ts +2 -2
  97. package/.cache/ts/src/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +2 -2
  98. package/.cache/ts/src/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +2 -2
  99. package/.cache/ts/src/components/PanelSpinner/PanelSpinner.d.ts +2 -2
  100. package/.cache/ts/src/components/Placeholder/Placeholder.d.ts +3 -3
  101. package/.cache/ts/src/components/PopoutRoot/PopoutRoot.d.ts +4 -4
  102. package/.cache/ts/src/components/PopoutWrapper/PopoutWrapper.d.ts +4 -4
  103. package/.cache/ts/src/components/Popper/Popper.d.ts +9 -4
  104. package/.cache/ts/src/components/Progress/Progress.d.ts +3 -3
  105. package/.cache/ts/src/components/PromoBanner/PromoBanner.d.ts +3 -3
  106. package/.cache/ts/src/components/PullToRefresh/PullToRefresh.d.ts +6 -6
  107. package/.cache/ts/src/components/PullToRefresh/PullToRefreshSpinner.d.ts +3 -3
  108. package/.cache/ts/src/components/Radio/Radio.d.ts +4 -4
  109. package/.cache/ts/src/components/RadioGroup/RadioGroup.d.ts +6 -0
  110. package/.cache/ts/src/components/RangeSlider/RangeSlider.d.ts +2 -2
  111. package/.cache/ts/src/components/RangeSlider/UniversalSlider.d.ts +6 -6
  112. package/.cache/ts/src/components/Removable/Removable.d.ts +4 -4
  113. package/.cache/ts/src/components/RichCell/RichCell.d.ts +3 -3
  114. package/.cache/ts/src/components/RichTooltip/RichTooltip.d.ts +3 -3
  115. package/.cache/ts/src/components/Root/Root.d.ts +3 -3
  116. package/.cache/ts/src/components/ScreenSpinner/ScreenSpinner.d.ts +3 -3
  117. package/.cache/ts/src/components/Search/Search.d.ts +4 -4
  118. package/.cache/ts/src/components/Select/Select.d.ts +3 -3
  119. package/.cache/ts/src/components/SelectMimicry/SelectMimicry.d.ts +4 -4
  120. package/.cache/ts/src/components/Separator/Separator.d.ts +2 -2
  121. package/.cache/ts/src/components/SimpleCell/SimpleCell.d.ts +4 -4
  122. package/.cache/ts/src/components/SimpleCheckbox/SimpleCheckbox.d.ts +3 -3
  123. package/.cache/ts/src/components/Slider/Slider.d.ts +1 -1
  124. package/.cache/ts/src/components/SliderSwitch/SliderSwitch.d.ts +6 -6
  125. package/.cache/ts/src/components/SliderSwitch/SliderSwitchButton.d.ts +3 -3
  126. package/.cache/ts/src/components/Snackbar/Snackbar.d.ts +5 -5
  127. package/.cache/ts/src/components/Spacing/Spacing.d.ts +3 -3
  128. package/.cache/ts/src/components/Spinner/Spinner.d.ts +3 -3
  129. package/.cache/ts/src/components/SplitCol/SplitCol.d.ts +2 -2
  130. package/.cache/ts/src/components/SplitLayout/SplitLayout.d.ts +3 -3
  131. package/.cache/ts/src/components/SubnavigationBar/SubnavigationBar.d.ts +5 -5
  132. package/.cache/ts/src/components/SubnavigationButton/SubnavigationButton.d.ts +5 -5
  133. package/.cache/ts/src/components/Switch/Switch.d.ts +3 -3
  134. package/.cache/ts/src/components/Tabbar/Tabbar.d.ts +3 -3
  135. package/.cache/ts/src/components/TabbarItem/TabbarItem.d.ts +4 -4
  136. package/.cache/ts/src/components/Tabs/Tabs.d.ts +5 -5
  137. package/.cache/ts/src/components/TabsItem/TabsItem.d.ts +2 -2
  138. package/.cache/ts/src/components/Tappable/Tappable.d.ts +11 -11
  139. package/.cache/ts/src/components/TextTooltip/TextTooltip.d.ts +3 -3
  140. package/.cache/ts/src/components/Textarea/Textarea.d.ts +4 -4
  141. package/.cache/ts/src/components/Tooltip/Tooltip.d.ts +5 -5
  142. package/.cache/ts/src/components/Tooltip/TooltipContainer.d.ts +1 -1
  143. package/.cache/ts/src/components/Touch/Touch.d.ts +3 -3
  144. package/.cache/ts/src/components/Touch/TouchContext.d.ts +1 -1
  145. package/.cache/ts/src/components/Typography/Caption/Caption.d.ts +5 -5
  146. package/.cache/ts/src/components/Typography/Headline/Headline.d.ts +4 -4
  147. package/.cache/ts/src/components/Typography/Subhead/Subhead.d.ts +4 -4
  148. package/.cache/ts/src/components/Typography/Text/Text.d.ts +4 -4
  149. package/.cache/ts/src/components/Typography/Title/Title.d.ts +5 -5
  150. package/.cache/ts/src/components/UsersStack/UsersStack.d.ts +4 -4
  151. package/.cache/ts/src/components/View/View.d.ts +7 -7
  152. package/.cache/ts/src/components/View/ViewInfinite.d.ts +7 -7
  153. package/.cache/ts/src/components/View/utils.d.ts +1 -1
  154. package/.cache/ts/src/components/WriteBar/WriteBar.d.ts +3 -3
  155. package/.cache/ts/src/components/WriteBarIcon/WriteBarIcon.d.ts +3 -3
  156. package/.cache/ts/src/helpers/avatar.d.ts +5 -0
  157. package/.cache/ts/src/helpers/getClassName.d.ts +1 -1
  158. package/.cache/ts/src/hoc/withAdaptivity.d.ts +1 -1
  159. package/.cache/ts/src/hoc/withContext.d.ts +1 -1
  160. package/.cache/ts/src/hooks/useAdaptivity.d.ts +1 -1
  161. package/.cache/ts/src/hooks/useBrowserInfo.d.ts +1 -1
  162. package/.cache/ts/src/hooks/useEffectDev.d.ts +2 -0
  163. package/.cache/ts/src/hooks/useExternRef.d.ts +1 -1
  164. package/.cache/ts/src/hooks/useFocusVisible.d.ts +6 -0
  165. package/.cache/ts/src/hooks/useInsets.d.ts +1 -1
  166. package/.cache/ts/src/hooks/usePatchChildrenRef.d.ts +1 -1
  167. package/.cache/ts/src/hooks/usePlatform.d.ts +1 -1
  168. package/.cache/ts/src/index.d.ts +236 -232
  169. package/.cache/ts/src/lib/SSR.d.ts +3 -3
  170. package/.cache/ts/src/lib/accessibility.d.ts +1 -1
  171. package/.cache/ts/src/lib/animate.d.ts +1 -1
  172. package/.cache/ts/src/lib/browser.d.ts +1 -1
  173. package/.cache/ts/src/lib/callMultiple.d.ts +1 -0
  174. package/.cache/ts/src/lib/dom.d.ts +2 -2
  175. package/.cache/ts/src/lib/isRefObject.d.ts +2 -0
  176. package/.cache/ts/src/lib/jsxRuntime.d.ts +1 -1
  177. package/.cache/ts/src/lib/platform.d.ts +1 -1
  178. package/.cache/ts/src/lib/styles.d.ts +1 -1
  179. package/.cache/ts/src/lib/taptic.d.ts +1 -1
  180. package/.cache/ts/src/lib/useIsomorphicLayoutEffect.d.ts +1 -1
  181. package/.cache/ts/src/lib/utils.d.ts +2 -2
  182. package/.cache/ts/src/testing/setup.d.ts +1 -1
  183. package/.cache/ts/src/testing/utils.d.ts +3 -3
  184. package/.cache/ts/src/types.d.ts +4 -4
  185. package/.cache/ts/src/unstable/index.d.ts +14 -14
  186. package/.codesandbox/ci.json +1 -3
  187. package/.eslintignore +1 -0
  188. package/.eslintrc.json +88 -61
  189. package/.husky/pre-commit +4 -0
  190. package/.prettierignore +14 -0
  191. package/.prettierrc.json +1 -0
  192. package/CONTRIBUTING.md +46 -22
  193. package/README.md +19 -9
  194. package/TESTING.md +17 -15
  195. package/babel.cjs.config.js +13 -8
  196. package/babel.config.js +60 -39
  197. package/dist/5c1a8c271e68390145da2b270f47c843.woff +0 -0
  198. package/dist/7082adfe0b49e2f8da5bf38d29e318ac.woff2 +0 -0
  199. package/dist/cjs/components/ActionSheet/ActionSheet.d.ts +3 -3
  200. package/dist/cjs/components/ActionSheet/ActionSheet.js +24 -16
  201. package/dist/cjs/components/ActionSheet/ActionSheet.js.map +1 -1
  202. package/dist/cjs/components/ActionSheet/ActionSheetContext.d.ts +1 -1
  203. package/dist/cjs/components/ActionSheet/ActionSheetContext.js.map +1 -1
  204. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.d.ts +3 -3
  205. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js +2 -2
  206. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  207. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.d.ts +3 -3
  208. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js +34 -39
  209. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  210. package/dist/cjs/components/ActionSheet/types.d.ts +3 -3
  211. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.d.ts +5 -5
  212. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js +11 -11
  213. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  214. package/dist/cjs/components/AdaptivityProvider/AdaptivityContext.d.ts +1 -1
  215. package/dist/cjs/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  216. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.d.ts +2 -2
  217. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js +2 -2
  218. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  219. package/dist/cjs/components/Alert/Alert.d.ts +9 -9
  220. package/dist/cjs/components/Alert/Alert.js +17 -17
  221. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  222. package/dist/cjs/components/AppRoot/AppRoot.d.ts +6 -6
  223. package/dist/cjs/components/AppRoot/AppRoot.js +25 -26
  224. package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
  225. package/dist/cjs/components/AppRoot/AppRootContext.d.ts +2 -2
  226. package/dist/cjs/components/AppRoot/AppRootContext.js.map +1 -1
  227. package/dist/cjs/components/AppRoot/AppRootPortal.d.ts +1 -1
  228. package/dist/cjs/components/AppRoot/AppRootPortal.js +1 -1
  229. package/dist/cjs/components/AppRoot/AppRootPortal.js.map +1 -1
  230. package/dist/cjs/components/AppRoot/ScrollContext.d.ts +1 -1
  231. package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
  232. package/dist/cjs/components/Avatar/Avatar.d.ts +11 -4
  233. package/dist/cjs/components/Avatar/Avatar.js +56 -12
  234. package/dist/cjs/components/Avatar/Avatar.js.map +1 -1
  235. package/dist/cjs/components/Badge/Badge.d.ts +3 -3
  236. package/dist/cjs/components/Badge/Badge.js +2 -2
  237. package/dist/cjs/components/Badge/Badge.js.map +1 -1
  238. package/dist/cjs/components/Banner/Banner.d.ts +6 -6
  239. package/dist/cjs/components/Banner/Banner.js +14 -14
  240. package/dist/cjs/components/Banner/Banner.js.map +1 -1
  241. package/dist/cjs/components/Button/Button.d.ts +11 -7
  242. package/dist/cjs/components/Button/Button.js +72 -12
  243. package/dist/cjs/components/Button/Button.js.map +1 -1
  244. package/dist/cjs/components/Card/Card.d.ts +4 -4
  245. package/dist/cjs/components/Card/Card.js +2 -2
  246. package/dist/cjs/components/Card/Card.js.map +1 -1
  247. package/dist/cjs/components/CardGrid/CardGrid.d.ts +4 -4
  248. package/dist/cjs/components/CardGrid/CardGrid.js +2 -2
  249. package/dist/cjs/components/CardGrid/CardGrid.js.map +1 -1
  250. package/dist/cjs/components/CardScroll/CardScroll.d.ts +4 -4
  251. package/dist/cjs/components/CardScroll/CardScroll.js +2 -2
  252. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  253. package/dist/cjs/components/Cell/Cell.d.ts +6 -6
  254. package/dist/cjs/components/Cell/Cell.js +18 -14
  255. package/dist/cjs/components/Cell/Cell.js.map +1 -1
  256. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.d.ts +4 -4
  257. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js +1 -1
  258. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  259. package/dist/cjs/components/Cell/CellDragger/CellDragger.d.ts +3 -3
  260. package/dist/cjs/components/Cell/CellDragger/CellDragger.js +1 -1
  261. package/dist/cjs/components/Cell/CellDragger/CellDragger.js.map +1 -1
  262. package/dist/cjs/components/Cell/useDraggable.d.ts +3 -3
  263. package/dist/cjs/components/Cell/useDraggable.js +9 -9
  264. package/dist/cjs/components/Cell/useDraggable.js.map +1 -1
  265. package/dist/cjs/components/CellButton/CellButton.d.ts +4 -4
  266. package/dist/cjs/components/CellButton/CellButton.js +2 -2
  267. package/dist/cjs/components/CellButton/CellButton.js.map +1 -1
  268. package/dist/cjs/components/Checkbox/Checkbox.d.ts +5 -4
  269. package/dist/cjs/components/Checkbox/Checkbox.js +17 -4
  270. package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
  271. package/dist/cjs/components/Chip/Chip.d.ts +2 -2
  272. package/dist/cjs/components/Chip/Chip.js +4 -4
  273. package/dist/cjs/components/Chip/Chip.js.map +1 -1
  274. package/dist/cjs/components/ChipsInput/ChipsInput.d.ts +6 -6
  275. package/dist/cjs/components/ChipsInput/ChipsInput.js +9 -9
  276. package/dist/cjs/components/ChipsInput/ChipsInput.js.map +1 -1
  277. package/dist/cjs/components/ChipsInput/useChipsInput.d.ts +2 -2
  278. package/dist/cjs/components/ChipsInput/useChipsInput.js +3 -3
  279. package/dist/cjs/components/ChipsInput/useChipsInput.js.map +1 -1
  280. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts +7 -7
  281. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +40 -31
  282. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  283. package/dist/cjs/components/ChipsSelect/useChipsSelect.d.ts +3 -3
  284. package/dist/cjs/components/ChipsSelect/useChipsSelect.js.map +1 -1
  285. package/dist/cjs/components/ClickPopper/ClickPopper.d.ts +2 -2
  286. package/dist/cjs/components/ClickPopper/ClickPopper.js +5 -5
  287. package/dist/cjs/components/ClickPopper/ClickPopper.js.map +1 -1
  288. package/dist/cjs/components/ConfigProvider/ConfigProvider.d.ts +2 -2
  289. package/dist/cjs/components/ConfigProvider/ConfigProvider.js +13 -13
  290. package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
  291. package/dist/cjs/components/ConfigProvider/ConfigProviderContext.d.ts +6 -4
  292. package/dist/cjs/components/ConfigProvider/ConfigProviderContext.js +2 -1
  293. package/dist/cjs/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  294. package/dist/cjs/components/ContentCard/ContentCard.d.ts +7 -21
  295. package/dist/cjs/components/ContentCard/ContentCard.js +9 -4
  296. package/dist/cjs/components/ContentCard/ContentCard.js.map +1 -1
  297. package/dist/cjs/components/Counter/Counter.d.ts +4 -4
  298. package/dist/cjs/components/Counter/Counter.js +5 -5
  299. package/dist/cjs/components/Counter/Counter.js.map +1 -1
  300. package/dist/cjs/components/CustomScrollView/CustomScrollView.d.ts +4 -3
  301. package/dist/cjs/components/CustomScrollView/CustomScrollView.js +20 -16
  302. package/dist/cjs/components/CustomScrollView/CustomScrollView.js.map +1 -1
  303. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +13 -9
  304. package/dist/cjs/components/CustomSelect/CustomSelect.js +68 -64
  305. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  306. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +12 -0
  307. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js +77 -0
  308. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -0
  309. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.d.ts +3 -3
  310. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js +8 -8
  311. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  312. package/dist/cjs/components/DatePicker/DatePicker.d.ts +6 -6
  313. package/dist/cjs/components/DatePicker/DatePicker.js +2 -2
  314. package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
  315. package/dist/cjs/components/Div/Div.d.ts +3 -3
  316. package/dist/cjs/components/Div/Div.js +1 -1
  317. package/dist/cjs/components/Div/Div.js.map +1 -1
  318. package/dist/cjs/components/Dropdown/Dropdown.d.ts +7 -7
  319. package/dist/cjs/components/Dropdown/Dropdown.js +4 -4
  320. package/dist/cjs/components/Dropdown/Dropdown.js.map +1 -1
  321. package/dist/cjs/components/DropdownIcon/DropdownIcon.d.ts +2 -2
  322. package/dist/cjs/components/DropdownIcon/DropdownIcon.js +1 -1
  323. package/dist/cjs/components/DropdownIcon/DropdownIcon.js.map +1 -1
  324. package/dist/cjs/components/Epic/Epic.d.ts +3 -3
  325. package/dist/cjs/components/Epic/Epic.js +4 -4
  326. package/dist/cjs/components/Epic/Epic.js.map +1 -1
  327. package/dist/cjs/components/Epic/ScrollSaver.d.ts +1 -1
  328. package/dist/cjs/components/Epic/ScrollSaver.js +1 -1
  329. package/dist/cjs/components/Epic/ScrollSaver.js.map +1 -1
  330. package/dist/cjs/components/File/File.d.ts +6 -6
  331. package/dist/cjs/components/File/File.js +6 -4
  332. package/dist/cjs/components/File/File.js.map +1 -1
  333. package/dist/cjs/components/FixedLayout/FixedLayout.d.ts +5 -5
  334. package/dist/cjs/components/FixedLayout/FixedLayout.js +3 -3
  335. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  336. package/dist/cjs/components/FocusTrap/FocusTrap.d.ts +2 -2
  337. package/dist/cjs/components/FocusTrap/FocusTrap.js +7 -9
  338. package/dist/cjs/components/FocusTrap/FocusTrap.js.map +1 -1
  339. package/dist/cjs/components/FocusVisible/FocusVisible.d.ts +3 -3
  340. package/dist/cjs/components/FocusVisible/FocusVisible.js +1 -1
  341. package/dist/cjs/components/FocusVisible/FocusVisible.js.map +1 -1
  342. package/dist/cjs/components/Footer/Footer.d.ts +3 -3
  343. package/dist/cjs/components/Footer/Footer.js.map +1 -1
  344. package/dist/cjs/components/FormField/FormField.d.ts +3 -3
  345. package/dist/cjs/components/FormField/FormField.js +5 -5
  346. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  347. package/dist/cjs/components/FormItem/FormItem.d.ts +5 -5
  348. package/dist/cjs/components/FormItem/FormItem.js +9 -7
  349. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  350. package/dist/cjs/components/FormLayout/FormLayout.d.ts +3 -3
  351. package/dist/cjs/components/FormLayout/FormLayout.js +3 -3
  352. package/dist/cjs/components/FormLayout/FormLayout.js.map +1 -1
  353. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.d.ts +5 -5
  354. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js +10 -6
  355. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  356. package/dist/cjs/components/FormStatus/FormStatus.d.ts +3 -3
  357. package/dist/cjs/components/FormStatus/FormStatus.js +1 -1
  358. package/dist/cjs/components/FormStatus/FormStatus.js.map +1 -1
  359. package/dist/cjs/components/Gallery/Gallery.d.ts +6 -6
  360. package/dist/cjs/components/Gallery/Gallery.js +21 -23
  361. package/dist/cjs/components/Gallery/Gallery.js.map +1 -1
  362. package/dist/cjs/components/Gradient/Gradient.d.ts +4 -4
  363. package/dist/cjs/components/Gradient/Gradient.js +3 -3
  364. package/dist/cjs/components/Gradient/Gradient.js.map +1 -1
  365. package/dist/cjs/components/GridAvatar/GridAvatar.d.ts +5 -6
  366. package/dist/cjs/components/GridAvatar/GridAvatar.js +5 -13
  367. package/dist/cjs/components/GridAvatar/GridAvatar.js.map +1 -1
  368. package/dist/cjs/components/Group/Group.d.ts +6 -6
  369. package/dist/cjs/components/Group/Group.js +7 -7
  370. package/dist/cjs/components/Group/Group.js.map +1 -1
  371. package/dist/cjs/components/Header/Header.d.ts +4 -4
  372. package/dist/cjs/components/Header/Header.js +16 -16
  373. package/dist/cjs/components/Header/Header.js.map +1 -1
  374. package/dist/cjs/components/HorizontalCell/HorizontalCell.d.ts +4 -4
  375. package/dist/cjs/components/HorizontalCell/HorizontalCell.js +3 -3
  376. package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
  377. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.d.ts +4 -4
  378. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js +2 -2
  379. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  380. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.d.ts +3 -3
  381. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.js +1 -1
  382. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  383. package/dist/cjs/components/HoverPopper/HoverPopper.d.ts +2 -2
  384. package/dist/cjs/components/HoverPopper/HoverPopper.js +5 -5
  385. package/dist/cjs/components/HoverPopper/HoverPopper.js.map +1 -1
  386. package/dist/cjs/components/IconButton/IconButton.d.ts +3 -3
  387. package/dist/cjs/components/IconButton/IconButton.js +4 -4
  388. package/dist/cjs/components/IconButton/IconButton.js.map +1 -1
  389. package/dist/cjs/components/InfoRow/InfoRow.d.ts +2 -2
  390. package/dist/cjs/components/InfoRow/InfoRow.js +1 -1
  391. package/dist/cjs/components/InfoRow/InfoRow.js.map +1 -1
  392. package/dist/cjs/components/InitialsAvatar/InitialsAvatar.d.ts +6 -7
  393. package/dist/cjs/components/InitialsAvatar/InitialsAvatar.js +9 -12
  394. package/dist/cjs/components/InitialsAvatar/InitialsAvatar.js.map +1 -1
  395. package/dist/cjs/components/Input/Input.d.ts +5 -5
  396. package/dist/cjs/components/Input/Input.js +2 -2
  397. package/dist/cjs/components/Input/Input.js.map +1 -1
  398. package/dist/cjs/components/Link/Link.d.ts +3 -3
  399. package/dist/cjs/components/Link/Link.js +2 -2
  400. package/dist/cjs/components/Link/Link.js.map +1 -1
  401. package/dist/cjs/components/List/List.d.ts +2 -2
  402. package/dist/cjs/components/List/List.js +2 -2
  403. package/dist/cjs/components/List/List.js.map +1 -1
  404. package/dist/cjs/components/List/ListContext.d.ts +1 -1
  405. package/dist/cjs/components/List/ListContext.js.map +1 -1
  406. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.d.ts +5 -5
  407. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js +6 -6
  408. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  409. package/dist/cjs/components/ModalCard/ModalCard.d.ts +6 -6
  410. package/dist/cjs/components/ModalCard/ModalCard.js +4 -4
  411. package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
  412. package/dist/cjs/components/ModalCardBase/ModalCardBase.d.ts +4 -4
  413. package/dist/cjs/components/ModalCardBase/ModalCardBase.js +6 -6
  414. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  415. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.d.ts +2 -2
  416. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.js +2 -2
  417. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  418. package/dist/cjs/components/ModalPage/ModalPage.d.ts +4 -4
  419. package/dist/cjs/components/ModalPage/ModalPage.js +3 -3
  420. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  421. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.d.ts +3 -3
  422. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js +1 -1
  423. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  424. package/dist/cjs/components/ModalRoot/ModalRoot.d.ts +4 -4
  425. package/dist/cjs/components/ModalRoot/ModalRoot.js +23 -23
  426. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  427. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.d.ts +2 -2
  428. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js +1 -1
  429. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  430. package/dist/cjs/components/ModalRoot/ModalRootContext.d.ts +3 -3
  431. package/dist/cjs/components/ModalRoot/ModalRootContext.js.map +1 -1
  432. package/dist/cjs/components/ModalRoot/ModalRootDesktop.d.ts +4 -4
  433. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +12 -12
  434. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  435. package/dist/cjs/components/ModalRoot/types.js.map +1 -1
  436. package/dist/cjs/components/ModalRoot/useModalManager.d.ts +3 -3
  437. package/dist/cjs/components/ModalRoot/useModalManager.js +13 -13
  438. package/dist/cjs/components/ModalRoot/useModalManager.js.map +1 -1
  439. package/dist/cjs/components/ModalRoot/withModalRootContext.d.ts +3 -3
  440. package/dist/cjs/components/ModalRoot/withModalRootContext.js.map +1 -1
  441. package/dist/cjs/components/NativeSelect/NativeSelect.d.ts +5 -5
  442. package/dist/cjs/components/NativeSelect/NativeSelect.js +4 -4
  443. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  444. package/dist/cjs/components/NavTransitionContext/NavTransitionContext.d.ts +1 -1
  445. package/dist/cjs/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  446. package/dist/cjs/components/Panel/Panel.d.ts +5 -5
  447. package/dist/cjs/components/Panel/Panel.js +2 -2
  448. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  449. package/dist/cjs/components/PanelHeader/PanelHeader.d.ts +4 -4
  450. package/dist/cjs/components/PanelHeader/PanelHeader.js +9 -9
  451. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  452. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.d.ts +5 -5
  453. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js +3 -3
  454. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  455. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.d.ts +4 -4
  456. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js +15 -15
  457. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  458. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.d.ts +2 -2
  459. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.js +1 -1
  460. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  461. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.d.ts +2 -2
  462. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js +42 -22
  463. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  464. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.d.ts +2 -2
  465. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js +5 -5
  466. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  467. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +2 -2
  468. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.js +2 -2
  469. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  470. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +2 -2
  471. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.js +1 -1
  472. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  473. package/dist/cjs/components/PanelSpinner/PanelSpinner.d.ts +2 -2
  474. package/dist/cjs/components/PanelSpinner/PanelSpinner.js.map +1 -1
  475. package/dist/cjs/components/Placeholder/Placeholder.d.ts +3 -3
  476. package/dist/cjs/components/Placeholder/Placeholder.js +2 -2
  477. package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
  478. package/dist/cjs/components/PopoutRoot/PopoutRoot.d.ts +4 -4
  479. package/dist/cjs/components/PopoutRoot/PopoutRoot.js +2 -2
  480. package/dist/cjs/components/PopoutRoot/PopoutRoot.js.map +1 -1
  481. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.d.ts +4 -4
  482. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js +9 -9
  483. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  484. package/dist/cjs/components/Popper/Popper.d.ts +9 -4
  485. package/dist/cjs/components/Popper/Popper.js +50 -25
  486. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  487. package/dist/cjs/components/Progress/Progress.d.ts +3 -3
  488. package/dist/cjs/components/Progress/Progress.js +1 -1
  489. package/dist/cjs/components/Progress/Progress.js.map +1 -1
  490. package/dist/cjs/components/PromoBanner/PromoBanner.d.ts +3 -3
  491. package/dist/cjs/components/PromoBanner/PromoBanner.js +4 -4
  492. package/dist/cjs/components/PromoBanner/PromoBanner.js.map +1 -1
  493. package/dist/cjs/components/PullToRefresh/PullToRefresh.d.ts +6 -6
  494. package/dist/cjs/components/PullToRefresh/PullToRefresh.js +9 -9
  495. package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
  496. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.d.ts +3 -3
  497. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js +8 -8
  498. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  499. package/dist/cjs/components/Radio/Radio.d.ts +4 -4
  500. package/dist/cjs/components/Radio/Radio.js +4 -3
  501. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  502. package/dist/cjs/components/RadioGroup/RadioGroup.d.ts +6 -0
  503. package/dist/cjs/components/RadioGroup/RadioGroup.js +36 -0
  504. package/dist/cjs/components/RadioGroup/RadioGroup.js.map +1 -0
  505. package/dist/cjs/components/RangeSlider/RangeSlider.d.ts +2 -2
  506. package/dist/cjs/components/RangeSlider/RangeSlider.js.map +1 -1
  507. package/dist/cjs/components/RangeSlider/UniversalSlider.d.ts +6 -6
  508. package/dist/cjs/components/RangeSlider/UniversalSlider.js +11 -11
  509. package/dist/cjs/components/RangeSlider/UniversalSlider.js.map +1 -1
  510. package/dist/cjs/components/Removable/Removable.d.ts +4 -4
  511. package/dist/cjs/components/Removable/Removable.js +4 -4
  512. package/dist/cjs/components/Removable/Removable.js.map +1 -1
  513. package/dist/cjs/components/RichCell/RichCell.d.ts +3 -3
  514. package/dist/cjs/components/RichCell/RichCell.js +2 -2
  515. package/dist/cjs/components/RichCell/RichCell.js.map +1 -1
  516. package/dist/cjs/components/RichTooltip/RichTooltip.d.ts +3 -3
  517. package/dist/cjs/components/RichTooltip/RichTooltip.js +2 -2
  518. package/dist/cjs/components/RichTooltip/RichTooltip.js.map +1 -1
  519. package/dist/cjs/components/Root/Root.d.ts +3 -3
  520. package/dist/cjs/components/Root/Root.js +11 -11
  521. package/dist/cjs/components/Root/Root.js.map +1 -1
  522. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.d.ts +3 -3
  523. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js +3 -3
  524. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  525. package/dist/cjs/components/Search/Search.d.ts +4 -4
  526. package/dist/cjs/components/Search/Search.js +12 -12
  527. package/dist/cjs/components/Search/Search.js.map +1 -1
  528. package/dist/cjs/components/Select/Select.d.ts +3 -3
  529. package/dist/cjs/components/Select/Select.js.map +1 -1
  530. package/dist/cjs/components/SelectMimicry/SelectMimicry.d.ts +4 -4
  531. package/dist/cjs/components/SelectMimicry/SelectMimicry.js +3 -3
  532. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  533. package/dist/cjs/components/Separator/Separator.d.ts +2 -2
  534. package/dist/cjs/components/Separator/Separator.js +4 -4
  535. package/dist/cjs/components/Separator/Separator.js.map +1 -1
  536. package/dist/cjs/components/SimpleCell/SimpleCell.d.ts +4 -4
  537. package/dist/cjs/components/SimpleCell/SimpleCell.js +3 -3
  538. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  539. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.d.ts +3 -3
  540. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js +7 -7
  541. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  542. package/dist/cjs/components/Slider/Slider.d.ts +1 -1
  543. package/dist/cjs/components/Slider/Slider.js.map +1 -1
  544. package/dist/cjs/components/SliderSwitch/SliderSwitch.d.ts +6 -6
  545. package/dist/cjs/components/SliderSwitch/SliderSwitch.js +7 -7
  546. package/dist/cjs/components/SliderSwitch/SliderSwitch.js.map +1 -1
  547. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.d.ts +3 -3
  548. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js +1 -1
  549. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  550. package/dist/cjs/components/Snackbar/Snackbar.d.ts +5 -5
  551. package/dist/cjs/components/Snackbar/Snackbar.js +8 -8
  552. package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
  553. package/dist/cjs/components/Spacing/Spacing.d.ts +3 -3
  554. package/dist/cjs/components/Spacing/Spacing.js +5 -5
  555. package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
  556. package/dist/cjs/components/Spinner/Spinner.d.ts +3 -3
  557. package/dist/cjs/components/Spinner/Spinner.js +6 -6
  558. package/dist/cjs/components/Spinner/Spinner.js.map +1 -1
  559. package/dist/cjs/components/SplitCol/SplitCol.d.ts +2 -2
  560. package/dist/cjs/components/SplitCol/SplitCol.js +3 -3
  561. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  562. package/dist/cjs/components/SplitLayout/SplitLayout.d.ts +3 -3
  563. package/dist/cjs/components/SplitLayout/SplitLayout.js +3 -3
  564. package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
  565. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.d.ts +5 -5
  566. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js +4 -4
  567. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  568. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.d.ts +5 -5
  569. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js +4 -4
  570. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  571. package/dist/cjs/components/Switch/Switch.d.ts +3 -3
  572. package/dist/cjs/components/Switch/Switch.js +16 -3
  573. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  574. package/dist/cjs/components/Tabbar/Tabbar.d.ts +3 -3
  575. package/dist/cjs/components/Tabbar/Tabbar.js +5 -5
  576. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  577. package/dist/cjs/components/TabbarItem/TabbarItem.d.ts +4 -4
  578. package/dist/cjs/components/TabbarItem/TabbarItem.js +5 -5
  579. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  580. package/dist/cjs/components/Tabs/Tabs.d.ts +5 -5
  581. package/dist/cjs/components/Tabs/Tabs.js +5 -5
  582. package/dist/cjs/components/Tabs/Tabs.js.map +1 -1
  583. package/dist/cjs/components/TabsItem/TabsItem.d.ts +2 -2
  584. package/dist/cjs/components/TabsItem/TabsItem.js +5 -5
  585. package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
  586. package/dist/cjs/components/Tappable/Tappable.d.ts +11 -11
  587. package/dist/cjs/components/Tappable/Tappable.js +36 -28
  588. package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
  589. package/dist/cjs/components/TextTooltip/TextTooltip.d.ts +3 -3
  590. package/dist/cjs/components/TextTooltip/TextTooltip.js +2 -2
  591. package/dist/cjs/components/TextTooltip/TextTooltip.js.map +1 -1
  592. package/dist/cjs/components/Textarea/Textarea.d.ts +4 -4
  593. package/dist/cjs/components/Textarea/Textarea.js +2 -2
  594. package/dist/cjs/components/Textarea/Textarea.js.map +1 -1
  595. package/dist/cjs/components/Tooltip/Tooltip.d.ts +5 -5
  596. package/dist/cjs/components/Tooltip/Tooltip.js +26 -26
  597. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  598. package/dist/cjs/components/Tooltip/TooltipContainer.d.ts +1 -1
  599. package/dist/cjs/components/Tooltip/TooltipContainer.js +2 -2
  600. package/dist/cjs/components/Tooltip/TooltipContainer.js.map +1 -1
  601. package/dist/cjs/components/Touch/Touch.d.ts +3 -3
  602. package/dist/cjs/components/Touch/Touch.js +7 -9
  603. package/dist/cjs/components/Touch/Touch.js.map +1 -1
  604. package/dist/cjs/components/Touch/TouchContext.d.ts +1 -1
  605. package/dist/cjs/components/Touch/TouchContext.js.map +1 -1
  606. package/dist/cjs/components/Typography/Caption/Caption.d.ts +5 -5
  607. package/dist/cjs/components/Typography/Caption/Caption.js +5 -5
  608. package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
  609. package/dist/cjs/components/Typography/Headline/Headline.d.ts +4 -4
  610. package/dist/cjs/components/Typography/Headline/Headline.js +3 -3
  611. package/dist/cjs/components/Typography/Headline/Headline.js.map +1 -1
  612. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts +4 -4
  613. package/dist/cjs/components/Typography/Subhead/Subhead.js +3 -3
  614. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  615. package/dist/cjs/components/Typography/Text/Text.d.ts +4 -4
  616. package/dist/cjs/components/Typography/Text/Text.js +6 -6
  617. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  618. package/dist/cjs/components/Typography/Title/Title.d.ts +5 -5
  619. package/dist/cjs/components/Typography/Title/Title.js +6 -6
  620. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  621. package/dist/cjs/components/UsersStack/UsersStack.d.ts +4 -4
  622. package/dist/cjs/components/UsersStack/UsersStack.js +5 -5
  623. package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
  624. package/dist/cjs/components/UsersStack/masks.js +7 -7
  625. package/dist/cjs/components/UsersStack/masks.js.map +1 -1
  626. package/dist/cjs/components/View/View.d.ts +7 -7
  627. package/dist/cjs/components/View/View.js +17 -17
  628. package/dist/cjs/components/View/View.js.map +1 -1
  629. package/dist/cjs/components/View/ViewInfinite.d.ts +7 -7
  630. package/dist/cjs/components/View/ViewInfinite.js +17 -17
  631. package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
  632. package/dist/cjs/components/View/utils.d.ts +1 -1
  633. package/dist/cjs/components/View/utils.js +1 -1
  634. package/dist/cjs/components/View/utils.js.map +1 -1
  635. package/dist/cjs/components/WriteBar/WriteBar.d.ts +3 -3
  636. package/dist/cjs/components/WriteBar/WriteBar.js +3 -3
  637. package/dist/cjs/components/WriteBar/WriteBar.js.map +1 -1
  638. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.d.ts +3 -3
  639. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js +11 -11
  640. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  641. package/dist/cjs/helpers/avatar.d.ts +5 -0
  642. package/dist/cjs/helpers/avatar.js +14 -0
  643. package/dist/cjs/helpers/avatar.js.map +1 -0
  644. package/dist/cjs/helpers/getClassName.d.ts +1 -1
  645. package/dist/cjs/helpers/getClassName.js.map +1 -1
  646. package/dist/cjs/helpers/math.js +1 -1
  647. package/dist/cjs/helpers/math.js.map +1 -1
  648. package/dist/cjs/hoc/withAdaptivity.d.ts +1 -1
  649. package/dist/cjs/hoc/withAdaptivity.js.map +1 -1
  650. package/dist/cjs/hoc/withContext.d.ts +1 -1
  651. package/dist/cjs/hoc/withContext.js.map +1 -1
  652. package/dist/cjs/hoc/withInsets.js.map +1 -1
  653. package/dist/cjs/hoc/withPlatform.js.map +1 -1
  654. package/dist/cjs/hooks/useAdaptivity.d.ts +1 -1
  655. package/dist/cjs/hooks/useAdaptivity.js.map +1 -1
  656. package/dist/cjs/hooks/useAppearance.js.map +1 -1
  657. package/dist/cjs/hooks/useBrowserInfo.d.ts +1 -1
  658. package/dist/cjs/hooks/useBrowserInfo.js.map +1 -1
  659. package/dist/cjs/hooks/useEffectDev.d.ts +2 -0
  660. package/dist/cjs/hooks/useEffectDev.js +14 -0
  661. package/dist/cjs/hooks/useEffectDev.js.map +1 -0
  662. package/dist/cjs/hooks/useEnsuredControl.js +1 -1
  663. package/dist/cjs/hooks/useEnsuredControl.js.map +1 -1
  664. package/dist/cjs/hooks/useEventListener.js.map +1 -1
  665. package/dist/cjs/hooks/useExternRef.d.ts +1 -1
  666. package/dist/cjs/hooks/useExternRef.js.map +1 -1
  667. package/dist/cjs/hooks/useFocusVisible.d.ts +6 -0
  668. package/dist/cjs/hooks/useFocusVisible.js +40 -0
  669. package/dist/cjs/hooks/useFocusVisible.js.map +1 -0
  670. package/dist/cjs/hooks/useGlobalEventListener.js.map +1 -1
  671. package/dist/cjs/hooks/useInsets.d.ts +1 -1
  672. package/dist/cjs/hooks/useInsets.js +2 -2
  673. package/dist/cjs/hooks/useInsets.js.map +1 -1
  674. package/dist/cjs/hooks/useKeyboard.js +3 -3
  675. package/dist/cjs/hooks/useKeyboard.js.map +1 -1
  676. package/dist/cjs/hooks/useKeyboardInputTracker.js +3 -3
  677. package/dist/cjs/hooks/useKeyboardInputTracker.js.map +1 -1
  678. package/dist/cjs/hooks/useObjectMemo.js.map +1 -1
  679. package/dist/cjs/hooks/usePatchChildrenRef.d.ts +1 -1
  680. package/dist/cjs/hooks/usePatchChildrenRef.js +5 -5
  681. package/dist/cjs/hooks/usePatchChildrenRef.js.map +1 -1
  682. package/dist/cjs/hooks/usePlatform.d.ts +1 -1
  683. package/dist/cjs/hooks/usePlatform.js.map +1 -1
  684. package/dist/cjs/hooks/useTimeout.js +1 -1
  685. package/dist/cjs/hooks/useTimeout.js.map +1 -1
  686. package/dist/cjs/hooks/useWaitTransitionFinish.js.map +1 -1
  687. package/dist/cjs/index.d.ts +236 -232
  688. package/dist/cjs/index.js +24 -0
  689. package/dist/cjs/index.js.map +1 -1
  690. package/dist/cjs/lib/SSR.d.ts +3 -3
  691. package/dist/cjs/lib/SSR.js +1 -1
  692. package/dist/cjs/lib/SSR.js.map +1 -1
  693. package/dist/cjs/lib/accessibility.d.ts +1 -1
  694. package/dist/cjs/lib/accessibility.js +9 -11
  695. package/dist/cjs/lib/accessibility.js.map +1 -1
  696. package/dist/cjs/lib/animate.d.ts +1 -1
  697. package/dist/cjs/lib/animate.js.map +1 -1
  698. package/dist/cjs/lib/browser.d.ts +1 -1
  699. package/dist/cjs/lib/browser.js +1 -1
  700. package/dist/cjs/lib/browser.js.map +1 -1
  701. package/dist/cjs/lib/callMultiple.d.ts +1 -0
  702. package/dist/cjs/lib/callMultiple.js +27 -0
  703. package/dist/cjs/lib/callMultiple.js.map +1 -0
  704. package/dist/cjs/lib/classNames.js +4 -4
  705. package/dist/cjs/lib/classNames.js.map +1 -1
  706. package/dist/cjs/lib/classScopingMode.js +1 -1
  707. package/dist/cjs/lib/classScopingMode.js.map +1 -1
  708. package/dist/cjs/lib/dom.d.ts +2 -2
  709. package/dist/cjs/lib/dom.js.map +1 -1
  710. package/dist/cjs/lib/getNavId.js +1 -1
  711. package/dist/cjs/lib/getNavId.js.map +1 -1
  712. package/dist/cjs/lib/is.js +1 -2
  713. package/dist/cjs/lib/is.js.map +1 -1
  714. package/dist/cjs/lib/isRefObject.d.ts +2 -0
  715. package/dist/cjs/lib/isRefObject.js +17 -0
  716. package/dist/cjs/lib/isRefObject.js.map +1 -0
  717. package/dist/cjs/lib/jsxRuntime.d.ts +1 -1
  718. package/dist/cjs/lib/jsxRuntime.js +3 -3
  719. package/dist/cjs/lib/jsxRuntime.js.map +1 -1
  720. package/dist/cjs/lib/platform.d.ts +1 -1
  721. package/dist/cjs/lib/platform.js +1 -1
  722. package/dist/cjs/lib/platform.js.map +1 -1
  723. package/dist/cjs/lib/polyfills.js +6 -6
  724. package/dist/cjs/lib/polyfills.js.map +1 -1
  725. package/dist/cjs/lib/prefixClass.js +5 -5
  726. package/dist/cjs/lib/prefixClass.js.map +1 -1
  727. package/dist/cjs/lib/removeObjectKeys.js.map +1 -1
  728. package/dist/cjs/lib/select.js +4 -4
  729. package/dist/cjs/lib/select.js.map +1 -1
  730. package/dist/cjs/lib/styles.d.ts +1 -1
  731. package/dist/cjs/lib/styles.js +4 -2
  732. package/dist/cjs/lib/styles.js.map +1 -1
  733. package/dist/cjs/lib/supportEvents.js +6 -6
  734. package/dist/cjs/lib/supportEvents.js.map +1 -1
  735. package/dist/cjs/lib/taptic.d.ts +1 -1
  736. package/dist/cjs/lib/taptic.js +2 -2
  737. package/dist/cjs/lib/taptic.js.map +1 -1
  738. package/dist/cjs/lib/testing.js.map +1 -1
  739. package/dist/cjs/lib/touch.js +3 -3
  740. package/dist/cjs/lib/touch.js.map +1 -1
  741. package/dist/cjs/lib/useIsomorphicLayoutEffect.d.ts +1 -1
  742. package/dist/cjs/lib/useIsomorphicLayoutEffect.js +2 -2
  743. package/dist/cjs/lib/useIsomorphicLayoutEffect.js.map +1 -1
  744. package/dist/cjs/lib/utils.d.ts +2 -2
  745. package/dist/cjs/lib/utils.js +7 -7
  746. package/dist/cjs/lib/utils.js.map +1 -1
  747. package/dist/cjs/types.d.ts +4 -4
  748. package/dist/cjs/unstable/index.d.ts +14 -14
  749. package/dist/cjs/unstable/index.js.map +1 -1
  750. package/dist/components/ActionSheet/ActionSheet.d.ts +3 -3
  751. package/dist/components/ActionSheet/ActionSheet.js +25 -17
  752. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  753. package/dist/components/ActionSheet/ActionSheetContext.d.ts +1 -1
  754. package/dist/components/ActionSheet/ActionSheetContext.js +1 -1
  755. package/dist/components/ActionSheet/ActionSheetContext.js.map +1 -1
  756. package/dist/components/ActionSheet/ActionSheetDropdown.d.ts +3 -3
  757. package/dist/components/ActionSheet/ActionSheetDropdown.js +2 -2
  758. package/dist/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  759. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.d.ts +3 -3
  760. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js +32 -38
  761. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  762. package/dist/components/ActionSheet/types.d.ts +3 -3
  763. package/dist/components/ActionSheetItem/ActionSheetItem.d.ts +5 -5
  764. package/dist/components/ActionSheetItem/ActionSheetItem.js +13 -13
  765. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  766. package/dist/components/AdaptivityProvider/AdaptivityContext.d.ts +1 -1
  767. package/dist/components/AdaptivityProvider/AdaptivityContext.js +2 -2
  768. package/dist/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  769. package/dist/components/AdaptivityProvider/AdaptivityProvider.d.ts +2 -2
  770. package/dist/components/AdaptivityProvider/AdaptivityProvider.js +4 -4
  771. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  772. package/dist/components/Alert/Alert.d.ts +9 -9
  773. package/dist/components/Alert/Alert.js +18 -18
  774. package/dist/components/Alert/Alert.js.map +1 -1
  775. package/dist/components/AppRoot/AppRoot.d.ts +6 -6
  776. package/dist/components/AppRoot/AppRoot.js +27 -28
  777. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  778. package/dist/components/AppRoot/AppRootContext.d.ts +2 -2
  779. package/dist/components/AppRoot/AppRootContext.js +1 -1
  780. package/dist/components/AppRoot/AppRootContext.js.map +1 -1
  781. package/dist/components/AppRoot/AppRootPortal.d.ts +1 -1
  782. package/dist/components/AppRoot/AppRootPortal.js +3 -3
  783. package/dist/components/AppRoot/AppRootPortal.js.map +1 -1
  784. package/dist/components/AppRoot/ScrollContext.d.ts +1 -1
  785. package/dist/components/AppRoot/ScrollContext.js +1 -1
  786. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  787. package/dist/components/Avatar/Avatar.d.ts +11 -4
  788. package/dist/components/Avatar/Avatar.js +54 -13
  789. package/dist/components/Avatar/Avatar.js.map +1 -1
  790. package/dist/components/Badge/Badge.d.ts +3 -3
  791. package/dist/components/Badge/Badge.js +2 -2
  792. package/dist/components/Badge/Badge.js.map +1 -1
  793. package/dist/components/Banner/Banner.d.ts +6 -6
  794. package/dist/components/Banner/Banner.js +16 -16
  795. package/dist/components/Banner/Banner.js.map +1 -1
  796. package/dist/components/Button/Button.d.ts +11 -7
  797. package/dist/components/Button/Button.js +68 -12
  798. package/dist/components/Button/Button.js.map +1 -1
  799. package/dist/components/Card/Card.d.ts +4 -4
  800. package/dist/components/Card/Card.js +2 -2
  801. package/dist/components/Card/Card.js.map +1 -1
  802. package/dist/components/CardGrid/CardGrid.d.ts +4 -4
  803. package/dist/components/CardGrid/CardGrid.js +2 -2
  804. package/dist/components/CardGrid/CardGrid.js.map +1 -1
  805. package/dist/components/CardScroll/CardScroll.d.ts +4 -4
  806. package/dist/components/CardScroll/CardScroll.js +3 -3
  807. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  808. package/dist/components/Cell/Cell.d.ts +6 -6
  809. package/dist/components/Cell/Cell.js +17 -15
  810. package/dist/components/Cell/Cell.js.map +1 -1
  811. package/dist/components/Cell/CellCheckbox/CellCheckbox.d.ts +4 -4
  812. package/dist/components/Cell/CellCheckbox/CellCheckbox.js +2 -2
  813. package/dist/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  814. package/dist/components/Cell/CellDragger/CellDragger.d.ts +3 -3
  815. package/dist/components/Cell/CellDragger/CellDragger.js +3 -3
  816. package/dist/components/Cell/CellDragger/CellDragger.js.map +1 -1
  817. package/dist/components/Cell/useDraggable.d.ts +3 -3
  818. package/dist/components/Cell/useDraggable.js +10 -10
  819. package/dist/components/Cell/useDraggable.js.map +1 -1
  820. package/dist/components/CellButton/CellButton.d.ts +4 -4
  821. package/dist/components/CellButton/CellButton.js +2 -2
  822. package/dist/components/CellButton/CellButton.js.map +1 -1
  823. package/dist/components/Checkbox/Checkbox.d.ts +5 -4
  824. package/dist/components/Checkbox/Checkbox.js +16 -5
  825. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  826. package/dist/components/Chip/Chip.d.ts +2 -2
  827. package/dist/components/Chip/Chip.js +6 -6
  828. package/dist/components/Chip/Chip.js.map +1 -1
  829. package/dist/components/ChipsInput/ChipsInput.d.ts +6 -6
  830. package/dist/components/ChipsInput/ChipsInput.js +10 -10
  831. package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
  832. package/dist/components/ChipsInput/useChipsInput.d.ts +2 -2
  833. package/dist/components/ChipsInput/useChipsInput.js +4 -4
  834. package/dist/components/ChipsInput/useChipsInput.js.map +1 -1
  835. package/dist/components/ChipsSelect/ChipsSelect.d.ts +7 -7
  836. package/dist/components/ChipsSelect/ChipsSelect.js +38 -29
  837. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  838. package/dist/components/ChipsSelect/useChipsSelect.d.ts +3 -3
  839. package/dist/components/ChipsSelect/useChipsSelect.js +1 -1
  840. package/dist/components/ChipsSelect/useChipsSelect.js.map +1 -1
  841. package/dist/components/ClickPopper/ClickPopper.d.ts +2 -2
  842. package/dist/components/ClickPopper/ClickPopper.js +6 -6
  843. package/dist/components/ClickPopper/ClickPopper.js.map +1 -1
  844. package/dist/components/ConfigProvider/ConfigProvider.d.ts +2 -2
  845. package/dist/components/ConfigProvider/ConfigProvider.js +14 -14
  846. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  847. package/dist/components/ConfigProvider/ConfigProviderContext.d.ts +6 -4
  848. package/dist/components/ConfigProvider/ConfigProviderContext.js +4 -3
  849. package/dist/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  850. package/dist/components/ContentCard/ContentCard.d.ts +7 -21
  851. package/dist/components/ContentCard/ContentCard.js +8 -4
  852. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  853. package/dist/components/Counter/Counter.d.ts +4 -4
  854. package/dist/components/Counter/Counter.js +6 -6
  855. package/dist/components/Counter/Counter.js.map +1 -1
  856. package/dist/components/CustomScrollView/CustomScrollView.d.ts +4 -3
  857. package/dist/components/CustomScrollView/CustomScrollView.js +21 -17
  858. package/dist/components/CustomScrollView/CustomScrollView.js.map +1 -1
  859. package/dist/components/CustomSelect/CustomSelect.d.ts +13 -9
  860. package/dist/components/CustomSelect/CustomSelect.js +71 -64
  861. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  862. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +12 -0
  863. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js +55 -0
  864. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -0
  865. package/dist/components/CustomSelectOption/CustomSelectOption.d.ts +3 -3
  866. package/dist/components/CustomSelectOption/CustomSelectOption.js +9 -9
  867. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  868. package/dist/components/DatePicker/DatePicker.d.ts +6 -6
  869. package/dist/components/DatePicker/DatePicker.js +3 -3
  870. package/dist/components/DatePicker/DatePicker.js.map +1 -1
  871. package/dist/components/Div/Div.d.ts +3 -3
  872. package/dist/components/Div/Div.js +1 -1
  873. package/dist/components/Div/Div.js.map +1 -1
  874. package/dist/components/Dropdown/Dropdown.d.ts +7 -7
  875. package/dist/components/Dropdown/Dropdown.js +4 -4
  876. package/dist/components/Dropdown/Dropdown.js.map +1 -1
  877. package/dist/components/DropdownIcon/DropdownIcon.d.ts +2 -2
  878. package/dist/components/DropdownIcon/DropdownIcon.js +2 -2
  879. package/dist/components/DropdownIcon/DropdownIcon.js.map +1 -1
  880. package/dist/components/Epic/Epic.d.ts +3 -3
  881. package/dist/components/Epic/Epic.js +5 -5
  882. package/dist/components/Epic/Epic.js.map +1 -1
  883. package/dist/components/Epic/ScrollSaver.d.ts +1 -1
  884. package/dist/components/Epic/ScrollSaver.js +2 -2
  885. package/dist/components/Epic/ScrollSaver.js.map +1 -1
  886. package/dist/components/File/File.d.ts +6 -6
  887. package/dist/components/File/File.js +6 -4
  888. package/dist/components/File/File.js.map +1 -1
  889. package/dist/components/FixedLayout/FixedLayout.d.ts +5 -5
  890. package/dist/components/FixedLayout/FixedLayout.js +4 -4
  891. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  892. package/dist/components/FocusTrap/FocusTrap.d.ts +2 -2
  893. package/dist/components/FocusTrap/FocusTrap.js +8 -10
  894. package/dist/components/FocusTrap/FocusTrap.js.map +1 -1
  895. package/dist/components/FocusVisible/FocusVisible.d.ts +3 -3
  896. package/dist/components/FocusVisible/FocusVisible.js +1 -1
  897. package/dist/components/FocusVisible/FocusVisible.js.map +1 -1
  898. package/dist/components/Footer/Footer.d.ts +3 -3
  899. package/dist/components/Footer/Footer.js.map +1 -1
  900. package/dist/components/FormField/FormField.d.ts +3 -3
  901. package/dist/components/FormField/FormField.js +6 -6
  902. package/dist/components/FormField/FormField.js.map +1 -1
  903. package/dist/components/FormItem/FormItem.d.ts +5 -5
  904. package/dist/components/FormItem/FormItem.js +10 -9
  905. package/dist/components/FormItem/FormItem.js.map +1 -1
  906. package/dist/components/FormLayout/FormLayout.d.ts +3 -3
  907. package/dist/components/FormLayout/FormLayout.js +3 -3
  908. package/dist/components/FormLayout/FormLayout.js.map +1 -1
  909. package/dist/components/FormLayoutGroup/FormLayoutGroup.d.ts +5 -5
  910. package/dist/components/FormLayoutGroup/FormLayoutGroup.js +8 -6
  911. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  912. package/dist/components/FormStatus/FormStatus.d.ts +3 -3
  913. package/dist/components/FormStatus/FormStatus.js +1 -1
  914. package/dist/components/FormStatus/FormStatus.js.map +1 -1
  915. package/dist/components/Gallery/Gallery.d.ts +6 -6
  916. package/dist/components/Gallery/Gallery.js +22 -24
  917. package/dist/components/Gallery/Gallery.js.map +1 -1
  918. package/dist/components/Gradient/Gradient.d.ts +4 -4
  919. package/dist/components/Gradient/Gradient.js +3 -3
  920. package/dist/components/Gradient/Gradient.js.map +1 -1
  921. package/dist/components/GridAvatar/GridAvatar.d.ts +5 -6
  922. package/dist/components/GridAvatar/GridAvatar.js +5 -11
  923. package/dist/components/GridAvatar/GridAvatar.js.map +1 -1
  924. package/dist/components/Group/Group.d.ts +6 -6
  925. package/dist/components/Group/Group.js +8 -8
  926. package/dist/components/Group/Group.js.map +1 -1
  927. package/dist/components/Header/Header.d.ts +4 -4
  928. package/dist/components/Header/Header.js +16 -16
  929. package/dist/components/Header/Header.js.map +1 -1
  930. package/dist/components/HorizontalCell/HorizontalCell.d.ts +4 -4
  931. package/dist/components/HorizontalCell/HorizontalCell.js +3 -3
  932. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  933. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +4 -4
  934. package/dist/components/HorizontalScroll/HorizontalScroll.js +3 -3
  935. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  936. package/dist/components/HorizontalScroll/HorizontalScrollArrow.d.ts +3 -3
  937. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js +2 -2
  938. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  939. package/dist/components/HoverPopper/HoverPopper.d.ts +2 -2
  940. package/dist/components/HoverPopper/HoverPopper.js +6 -6
  941. package/dist/components/HoverPopper/HoverPopper.js.map +1 -1
  942. package/dist/components/IconButton/IconButton.d.ts +3 -3
  943. package/dist/components/IconButton/IconButton.js +4 -4
  944. package/dist/components/IconButton/IconButton.js.map +1 -1
  945. package/dist/components/InfoRow/InfoRow.d.ts +2 -2
  946. package/dist/components/InfoRow/InfoRow.js +1 -1
  947. package/dist/components/InfoRow/InfoRow.js.map +1 -1
  948. package/dist/components/InitialsAvatar/InitialsAvatar.d.ts +6 -7
  949. package/dist/components/InitialsAvatar/InitialsAvatar.js +10 -13
  950. package/dist/components/InitialsAvatar/InitialsAvatar.js.map +1 -1
  951. package/dist/components/Input/Input.d.ts +5 -5
  952. package/dist/components/Input/Input.js +2 -2
  953. package/dist/components/Input/Input.js.map +1 -1
  954. package/dist/components/Link/Link.d.ts +3 -3
  955. package/dist/components/Link/Link.js +2 -2
  956. package/dist/components/Link/Link.js.map +1 -1
  957. package/dist/components/List/List.d.ts +2 -2
  958. package/dist/components/List/List.js +3 -3
  959. package/dist/components/List/List.js.map +1 -1
  960. package/dist/components/List/ListContext.d.ts +1 -1
  961. package/dist/components/List/ListContext.js +1 -1
  962. package/dist/components/List/ListContext.js.map +1 -1
  963. package/dist/components/MiniInfoCell/MiniInfoCell.d.ts +5 -5
  964. package/dist/components/MiniInfoCell/MiniInfoCell.js +6 -6
  965. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  966. package/dist/components/ModalCard/ModalCard.d.ts +6 -6
  967. package/dist/components/ModalCard/ModalCard.js +5 -5
  968. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  969. package/dist/components/ModalCardBase/ModalCardBase.d.ts +4 -4
  970. package/dist/components/ModalCardBase/ModalCardBase.js +7 -7
  971. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  972. package/dist/components/ModalDismissButton/ModalDismissButton.d.ts +2 -2
  973. package/dist/components/ModalDismissButton/ModalDismissButton.js +3 -3
  974. package/dist/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  975. package/dist/components/ModalPage/ModalPage.d.ts +4 -4
  976. package/dist/components/ModalPage/ModalPage.js +4 -4
  977. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  978. package/dist/components/ModalPageHeader/ModalPageHeader.d.ts +3 -3
  979. package/dist/components/ModalPageHeader/ModalPageHeader.js +1 -1
  980. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  981. package/dist/components/ModalRoot/ModalRoot.d.ts +4 -4
  982. package/dist/components/ModalRoot/ModalRoot.js +24 -24
  983. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  984. package/dist/components/ModalRoot/ModalRootAdaptive.d.ts +2 -2
  985. package/dist/components/ModalRoot/ModalRootAdaptive.js +1 -1
  986. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  987. package/dist/components/ModalRoot/ModalRootContext.d.ts +3 -3
  988. package/dist/components/ModalRoot/ModalRootContext.js +1 -1
  989. package/dist/components/ModalRoot/ModalRootContext.js.map +1 -1
  990. package/dist/components/ModalRoot/ModalRootDesktop.d.ts +4 -4
  991. package/dist/components/ModalRoot/ModalRootDesktop.js +13 -13
  992. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  993. package/dist/components/ModalRoot/types.js.map +1 -1
  994. package/dist/components/ModalRoot/useModalManager.d.ts +3 -3
  995. package/dist/components/ModalRoot/useModalManager.js +14 -14
  996. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  997. package/dist/components/ModalRoot/withModalRootContext.d.ts +3 -3
  998. package/dist/components/ModalRoot/withModalRootContext.js +1 -1
  999. package/dist/components/ModalRoot/withModalRootContext.js.map +1 -1
  1000. package/dist/components/NativeSelect/NativeSelect.d.ts +5 -5
  1001. package/dist/components/NativeSelect/NativeSelect.js +5 -5
  1002. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  1003. package/dist/components/NavTransitionContext/NavTransitionContext.d.ts +1 -1
  1004. package/dist/components/NavTransitionContext/NavTransitionContext.js +1 -1
  1005. package/dist/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  1006. package/dist/components/Panel/Panel.d.ts +5 -5
  1007. package/dist/components/Panel/Panel.js +2 -2
  1008. package/dist/components/Panel/Panel.js.map +1 -1
  1009. package/dist/components/PanelHeader/PanelHeader.d.ts +4 -4
  1010. package/dist/components/PanelHeader/PanelHeader.js +10 -10
  1011. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  1012. package/dist/components/PanelHeaderBack/PanelHeaderBack.d.ts +5 -5
  1013. package/dist/components/PanelHeaderBack/PanelHeaderBack.js +5 -5
  1014. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  1015. package/dist/components/PanelHeaderButton/PanelHeaderButton.d.ts +4 -4
  1016. package/dist/components/PanelHeaderButton/PanelHeaderButton.js +15 -15
  1017. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  1018. package/dist/components/PanelHeaderClose/PanelHeaderClose.d.ts +2 -2
  1019. package/dist/components/PanelHeaderClose/PanelHeaderClose.js +2 -2
  1020. package/dist/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  1021. package/dist/components/PanelHeaderContent/PanelHeaderContent.d.ts +2 -2
  1022. package/dist/components/PanelHeaderContent/PanelHeaderContent.js +40 -21
  1023. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  1024. package/dist/components/PanelHeaderContext/PanelHeaderContext.d.ts +2 -2
  1025. package/dist/components/PanelHeaderContext/PanelHeaderContext.js +6 -6
  1026. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  1027. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +2 -2
  1028. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js +3 -3
  1029. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  1030. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +2 -2
  1031. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.js +2 -2
  1032. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  1033. package/dist/components/PanelSpinner/PanelSpinner.d.ts +2 -2
  1034. package/dist/components/PanelSpinner/PanelSpinner.js +1 -1
  1035. package/dist/components/PanelSpinner/PanelSpinner.js.map +1 -1
  1036. package/dist/components/Placeholder/Placeholder.d.ts +3 -3
  1037. package/dist/components/Placeholder/Placeholder.js +2 -2
  1038. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  1039. package/dist/components/PopoutRoot/PopoutRoot.d.ts +4 -4
  1040. package/dist/components/PopoutRoot/PopoutRoot.js +3 -3
  1041. package/dist/components/PopoutRoot/PopoutRoot.js.map +1 -1
  1042. package/dist/components/PopoutWrapper/PopoutWrapper.d.ts +4 -4
  1043. package/dist/components/PopoutWrapper/PopoutWrapper.js +10 -10
  1044. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  1045. package/dist/components/Popper/Popper.d.ts +9 -4
  1046. package/dist/components/Popper/Popper.js +52 -27
  1047. package/dist/components/Popper/Popper.js.map +1 -1
  1048. package/dist/components/Progress/Progress.d.ts +3 -3
  1049. package/dist/components/Progress/Progress.js +1 -1
  1050. package/dist/components/Progress/Progress.js.map +1 -1
  1051. package/dist/components/PromoBanner/PromoBanner.d.ts +3 -3
  1052. package/dist/components/PromoBanner/PromoBanner.js +6 -6
  1053. package/dist/components/PromoBanner/PromoBanner.js.map +1 -1
  1054. package/dist/components/PullToRefresh/PullToRefresh.d.ts +6 -6
  1055. package/dist/components/PullToRefresh/PullToRefresh.js +10 -10
  1056. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  1057. package/dist/components/PullToRefresh/PullToRefreshSpinner.d.ts +3 -3
  1058. package/dist/components/PullToRefresh/PullToRefreshSpinner.js +9 -9
  1059. package/dist/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  1060. package/dist/components/Radio/Radio.d.ts +4 -4
  1061. package/dist/components/Radio/Radio.js +4 -3
  1062. package/dist/components/Radio/Radio.js.map +1 -1
  1063. package/dist/components/RadioGroup/RadioGroup.d.ts +6 -0
  1064. package/dist/components/RadioGroup/RadioGroup.js +19 -0
  1065. package/dist/components/RadioGroup/RadioGroup.js.map +1 -0
  1066. package/dist/components/RangeSlider/RangeSlider.d.ts +2 -2
  1067. package/dist/components/RangeSlider/RangeSlider.js +1 -1
  1068. package/dist/components/RangeSlider/RangeSlider.js.map +1 -1
  1069. package/dist/components/RangeSlider/UniversalSlider.d.ts +6 -6
  1070. package/dist/components/RangeSlider/UniversalSlider.js +12 -12
  1071. package/dist/components/RangeSlider/UniversalSlider.js.map +1 -1
  1072. package/dist/components/Removable/Removable.d.ts +4 -4
  1073. package/dist/components/Removable/Removable.js +6 -6
  1074. package/dist/components/Removable/Removable.js.map +1 -1
  1075. package/dist/components/RichCell/RichCell.d.ts +3 -3
  1076. package/dist/components/RichCell/RichCell.js +2 -2
  1077. package/dist/components/RichCell/RichCell.js.map +1 -1
  1078. package/dist/components/RichTooltip/RichTooltip.d.ts +3 -3
  1079. package/dist/components/RichTooltip/RichTooltip.js +2 -2
  1080. package/dist/components/RichTooltip/RichTooltip.js.map +1 -1
  1081. package/dist/components/Root/Root.d.ts +3 -3
  1082. package/dist/components/Root/Root.js +12 -12
  1083. package/dist/components/Root/Root.js.map +1 -1
  1084. package/dist/components/ScreenSpinner/ScreenSpinner.d.ts +3 -3
  1085. package/dist/components/ScreenSpinner/ScreenSpinner.js +3 -3
  1086. package/dist/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  1087. package/dist/components/Search/Search.d.ts +4 -4
  1088. package/dist/components/Search/Search.js +14 -14
  1089. package/dist/components/Search/Search.js.map +1 -1
  1090. package/dist/components/Select/Select.d.ts +3 -3
  1091. package/dist/components/Select/Select.js.map +1 -1
  1092. package/dist/components/SelectMimicry/SelectMimicry.d.ts +4 -4
  1093. package/dist/components/SelectMimicry/SelectMimicry.js +3 -3
  1094. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  1095. package/dist/components/Separator/Separator.d.ts +2 -2
  1096. package/dist/components/Separator/Separator.js +5 -5
  1097. package/dist/components/Separator/Separator.js.map +1 -1
  1098. package/dist/components/SimpleCell/SimpleCell.d.ts +4 -4
  1099. package/dist/components/SimpleCell/SimpleCell.js +4 -4
  1100. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  1101. package/dist/components/SimpleCheckbox/SimpleCheckbox.d.ts +3 -3
  1102. package/dist/components/SimpleCheckbox/SimpleCheckbox.js +9 -9
  1103. package/dist/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  1104. package/dist/components/Slider/Slider.d.ts +1 -1
  1105. package/dist/components/Slider/Slider.js +1 -1
  1106. package/dist/components/Slider/Slider.js.map +1 -1
  1107. package/dist/components/SliderSwitch/SliderSwitch.d.ts +6 -6
  1108. package/dist/components/SliderSwitch/SliderSwitch.js +8 -8
  1109. package/dist/components/SliderSwitch/SliderSwitch.js.map +1 -1
  1110. package/dist/components/SliderSwitch/SliderSwitchButton.d.ts +3 -3
  1111. package/dist/components/SliderSwitch/SliderSwitchButton.js +2 -2
  1112. package/dist/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  1113. package/dist/components/Snackbar/Snackbar.d.ts +5 -5
  1114. package/dist/components/Snackbar/Snackbar.js +9 -9
  1115. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  1116. package/dist/components/Spacing/Spacing.d.ts +3 -3
  1117. package/dist/components/Spacing/Spacing.js +5 -5
  1118. package/dist/components/Spacing/Spacing.js.map +1 -1
  1119. package/dist/components/Spinner/Spinner.d.ts +3 -3
  1120. package/dist/components/Spinner/Spinner.js +8 -8
  1121. package/dist/components/Spinner/Spinner.js.map +1 -1
  1122. package/dist/components/SplitCol/SplitCol.d.ts +2 -2
  1123. package/dist/components/SplitCol/SplitCol.js +4 -4
  1124. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  1125. package/dist/components/SplitLayout/SplitLayout.d.ts +3 -3
  1126. package/dist/components/SplitLayout/SplitLayout.js +3 -3
  1127. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  1128. package/dist/components/SubnavigationBar/SubnavigationBar.d.ts +5 -5
  1129. package/dist/components/SubnavigationBar/SubnavigationBar.js +4 -4
  1130. package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  1131. package/dist/components/SubnavigationButton/SubnavigationButton.d.ts +5 -5
  1132. package/dist/components/SubnavigationButton/SubnavigationButton.js +5 -5
  1133. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  1134. package/dist/components/Switch/Switch.d.ts +3 -3
  1135. package/dist/components/Switch/Switch.js +14 -3
  1136. package/dist/components/Switch/Switch.js.map +1 -1
  1137. package/dist/components/Tabbar/Tabbar.d.ts +3 -3
  1138. package/dist/components/Tabbar/Tabbar.js +6 -6
  1139. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  1140. package/dist/components/TabbarItem/TabbarItem.d.ts +4 -4
  1141. package/dist/components/TabbarItem/TabbarItem.js +5 -5
  1142. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  1143. package/dist/components/Tabs/Tabs.d.ts +5 -5
  1144. package/dist/components/Tabs/Tabs.js +6 -6
  1145. package/dist/components/Tabs/Tabs.js.map +1 -1
  1146. package/dist/components/TabsItem/TabsItem.d.ts +2 -2
  1147. package/dist/components/TabsItem/TabsItem.js +6 -6
  1148. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  1149. package/dist/components/Tappable/Tappable.d.ts +11 -11
  1150. package/dist/components/Tappable/Tappable.js +37 -31
  1151. package/dist/components/Tappable/Tappable.js.map +1 -1
  1152. package/dist/components/TextTooltip/TextTooltip.d.ts +3 -3
  1153. package/dist/components/TextTooltip/TextTooltip.js +3 -3
  1154. package/dist/components/TextTooltip/TextTooltip.js.map +1 -1
  1155. package/dist/components/Textarea/Textarea.d.ts +4 -4
  1156. package/dist/components/Textarea/Textarea.js +3 -3
  1157. package/dist/components/Textarea/Textarea.js.map +1 -1
  1158. package/dist/components/Tooltip/Tooltip.d.ts +5 -5
  1159. package/dist/components/Tooltip/Tooltip.js +29 -29
  1160. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  1161. package/dist/components/Tooltip/TooltipContainer.d.ts +1 -1
  1162. package/dist/components/Tooltip/TooltipContainer.js +3 -3
  1163. package/dist/components/Tooltip/TooltipContainer.js.map +1 -1
  1164. package/dist/components/Touch/Touch.d.ts +3 -3
  1165. package/dist/components/Touch/Touch.js +8 -10
  1166. package/dist/components/Touch/Touch.js.map +1 -1
  1167. package/dist/components/Touch/TouchContext.d.ts +1 -1
  1168. package/dist/components/Touch/TouchContext.js +1 -1
  1169. package/dist/components/Touch/TouchContext.js.map +1 -1
  1170. package/dist/components/Typography/Caption/Caption.d.ts +5 -5
  1171. package/dist/components/Typography/Caption/Caption.js +5 -5
  1172. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  1173. package/dist/components/Typography/Headline/Headline.d.ts +4 -4
  1174. package/dist/components/Typography/Headline/Headline.js +3 -3
  1175. package/dist/components/Typography/Headline/Headline.js.map +1 -1
  1176. package/dist/components/Typography/Subhead/Subhead.d.ts +4 -4
  1177. package/dist/components/Typography/Subhead/Subhead.js +3 -3
  1178. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  1179. package/dist/components/Typography/Text/Text.d.ts +4 -4
  1180. package/dist/components/Typography/Text/Text.js +6 -6
  1181. package/dist/components/Typography/Text/Text.js.map +1 -1
  1182. package/dist/components/Typography/Title/Title.d.ts +5 -5
  1183. package/dist/components/Typography/Title/Title.js +6 -6
  1184. package/dist/components/Typography/Title/Title.js.map +1 -1
  1185. package/dist/components/UsersStack/UsersStack.d.ts +4 -4
  1186. package/dist/components/UsersStack/UsersStack.js +6 -6
  1187. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  1188. package/dist/components/UsersStack/masks.js +7 -7
  1189. package/dist/components/UsersStack/masks.js.map +1 -1
  1190. package/dist/components/View/View.d.ts +7 -7
  1191. package/dist/components/View/View.js +18 -18
  1192. package/dist/components/View/View.js.map +1 -1
  1193. package/dist/components/View/ViewInfinite.d.ts +7 -7
  1194. package/dist/components/View/ViewInfinite.js +18 -18
  1195. package/dist/components/View/ViewInfinite.js.map +1 -1
  1196. package/dist/components/View/utils.d.ts +1 -1
  1197. package/dist/components/View/utils.js +1 -1
  1198. package/dist/components/View/utils.js.map +1 -1
  1199. package/dist/components/WriteBar/WriteBar.d.ts +3 -3
  1200. package/dist/components/WriteBar/WriteBar.js +4 -4
  1201. package/dist/components/WriteBar/WriteBar.js.map +1 -1
  1202. package/dist/components/WriteBarIcon/WriteBarIcon.d.ts +3 -3
  1203. package/dist/components/WriteBarIcon/WriteBarIcon.js +12 -12
  1204. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1205. package/dist/components.css +43 -1
  1206. package/dist/components.css.map +1 -1
  1207. package/dist/cssm/components/ActionSheet/ActionSheet.css +1 -1
  1208. package/dist/cssm/components/ActionSheet/ActionSheet.js +25 -17
  1209. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  1210. package/dist/cssm/components/ActionSheet/ActionSheetContext.js +1 -1
  1211. package/dist/cssm/components/ActionSheet/ActionSheetContext.js.map +1 -1
  1212. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js +2 -2
  1213. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  1214. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js +32 -38
  1215. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  1216. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.css +1 -1
  1217. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js +13 -13
  1218. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  1219. package/dist/cssm/components/AdaptivityProvider/AdaptivityContext.js +2 -2
  1220. package/dist/cssm/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  1221. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js +4 -4
  1222. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  1223. package/dist/cssm/components/Alert/Alert.css +1 -1
  1224. package/dist/cssm/components/Alert/Alert.js +18 -18
  1225. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  1226. package/dist/cssm/components/AppRoot/AppRoot.js +27 -28
  1227. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  1228. package/dist/cssm/components/AppRoot/AppRootContext.js +1 -1
  1229. package/dist/cssm/components/AppRoot/AppRootContext.js.map +1 -1
  1230. package/dist/cssm/components/AppRoot/AppRootPortal.js +3 -3
  1231. package/dist/cssm/components/AppRoot/AppRootPortal.js.map +1 -1
  1232. package/dist/cssm/components/AppRoot/ScrollContext.js +1 -1
  1233. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  1234. package/dist/cssm/components/Avatar/Avatar.css +1 -1
  1235. package/dist/cssm/components/Avatar/Avatar.js +54 -13
  1236. package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
  1237. package/dist/cssm/components/Badge/Badge.js +2 -2
  1238. package/dist/cssm/components/Badge/Badge.js.map +1 -1
  1239. package/dist/cssm/components/Banner/Banner.css +1 -1
  1240. package/dist/cssm/components/Banner/Banner.js +16 -16
  1241. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  1242. package/dist/cssm/components/Button/Button.css +19 -1
  1243. package/dist/cssm/components/Button/Button.js +68 -12
  1244. package/dist/cssm/components/Button/Button.js.map +1 -1
  1245. package/dist/cssm/components/Card/Card.css +1 -1
  1246. package/dist/cssm/components/Card/Card.js +2 -2
  1247. package/dist/cssm/components/Card/Card.js.map +1 -1
  1248. package/dist/cssm/components/CardGrid/CardGrid.js +2 -2
  1249. package/dist/cssm/components/CardGrid/CardGrid.js.map +1 -1
  1250. package/dist/cssm/components/CardScroll/CardScroll.js +3 -3
  1251. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  1252. package/dist/cssm/components/Cell/Cell.js +17 -15
  1253. package/dist/cssm/components/Cell/Cell.js.map +1 -1
  1254. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js +2 -2
  1255. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  1256. package/dist/cssm/components/Cell/CellDragger/CellDragger.js +3 -3
  1257. package/dist/cssm/components/Cell/CellDragger/CellDragger.js.map +1 -1
  1258. package/dist/cssm/components/Cell/useDraggable.js +10 -10
  1259. package/dist/cssm/components/Cell/useDraggable.js.map +1 -1
  1260. package/dist/cssm/components/CellButton/CellButton.js +2 -2
  1261. package/dist/cssm/components/CellButton/CellButton.js.map +1 -1
  1262. package/dist/cssm/components/Checkbox/Checkbox.css +1 -1
  1263. package/dist/cssm/components/Checkbox/Checkbox.js +16 -5
  1264. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  1265. package/dist/cssm/components/Chip/Chip.js +6 -6
  1266. package/dist/cssm/components/Chip/Chip.js.map +1 -1
  1267. package/dist/cssm/components/ChipsInput/ChipsInput.js +10 -10
  1268. package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
  1269. package/dist/cssm/components/ChipsInput/useChipsInput.js +4 -4
  1270. package/dist/cssm/components/ChipsInput/useChipsInput.js.map +1 -1
  1271. package/dist/cssm/components/ChipsSelect/ChipsSelect.css +1 -1
  1272. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +38 -29
  1273. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  1274. package/dist/cssm/components/ChipsSelect/useChipsSelect.js +1 -1
  1275. package/dist/cssm/components/ChipsSelect/useChipsSelect.js.map +1 -1
  1276. package/dist/cssm/components/ClickPopper/ClickPopper.js +6 -6
  1277. package/dist/cssm/components/ClickPopper/ClickPopper.js.map +1 -1
  1278. package/dist/cssm/components/ConfigProvider/ConfigProvider.js +14 -14
  1279. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  1280. package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js +4 -3
  1281. package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  1282. package/dist/cssm/components/ContentCard/ContentCard.css +1 -1
  1283. package/dist/cssm/components/ContentCard/ContentCard.js +8 -4
  1284. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  1285. package/dist/cssm/components/Counter/Counter.css +23 -1
  1286. package/dist/cssm/components/Counter/Counter.js +6 -6
  1287. package/dist/cssm/components/Counter/Counter.js.map +1 -1
  1288. package/dist/cssm/components/CustomScrollView/CustomScrollView.css +1 -1
  1289. package/dist/cssm/components/CustomScrollView/CustomScrollView.js +21 -17
  1290. package/dist/cssm/components/CustomScrollView/CustomScrollView.js.map +1 -1
  1291. package/dist/cssm/components/CustomSelect/CustomSelect.css +1 -1
  1292. package/dist/cssm/components/CustomSelect/CustomSelect.js +71 -64
  1293. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  1294. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.css +1 -0
  1295. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js +56 -0
  1296. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -0
  1297. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js +9 -9
  1298. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  1299. package/dist/cssm/components/DatePicker/DatePicker.js +3 -3
  1300. package/dist/cssm/components/DatePicker/DatePicker.js.map +1 -1
  1301. package/dist/cssm/components/Div/Div.js +1 -1
  1302. package/dist/cssm/components/Div/Div.js.map +1 -1
  1303. package/dist/cssm/components/Dropdown/Dropdown.js +4 -4
  1304. package/dist/cssm/components/Dropdown/Dropdown.js.map +1 -1
  1305. package/dist/cssm/components/DropdownIcon/DropdownIcon.js +2 -2
  1306. package/dist/cssm/components/DropdownIcon/DropdownIcon.js.map +1 -1
  1307. package/dist/cssm/components/Epic/Epic.js +5 -5
  1308. package/dist/cssm/components/Epic/Epic.js.map +1 -1
  1309. package/dist/cssm/components/Epic/ScrollSaver.js +2 -2
  1310. package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
  1311. package/dist/cssm/components/File/File.js +6 -4
  1312. package/dist/cssm/components/File/File.js.map +1 -1
  1313. package/dist/cssm/components/FixedLayout/FixedLayout.js +4 -4
  1314. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  1315. package/dist/cssm/components/FocusTrap/FocusTrap.js +8 -10
  1316. package/dist/cssm/components/FocusTrap/FocusTrap.js.map +1 -1
  1317. package/dist/cssm/components/FocusVisible/FocusVisible.css +1 -1
  1318. package/dist/cssm/components/FocusVisible/FocusVisible.js +1 -1
  1319. package/dist/cssm/components/FocusVisible/FocusVisible.js.map +1 -1
  1320. package/dist/cssm/components/Footer/Footer.js.map +1 -1
  1321. package/dist/cssm/components/FormField/FormField.css +1 -1
  1322. package/dist/cssm/components/FormField/FormField.js +6 -6
  1323. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  1324. package/dist/cssm/components/FormItem/FormItem.js +10 -9
  1325. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  1326. package/dist/cssm/components/FormLayout/FormLayout.js +3 -3
  1327. package/dist/cssm/components/FormLayout/FormLayout.js.map +1 -1
  1328. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js +8 -6
  1329. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  1330. package/dist/cssm/components/FormStatus/FormStatus.js +1 -1
  1331. package/dist/cssm/components/FormStatus/FormStatus.js.map +1 -1
  1332. package/dist/cssm/components/Gallery/Gallery.css +1 -1
  1333. package/dist/cssm/components/Gallery/Gallery.js +22 -24
  1334. package/dist/cssm/components/Gallery/Gallery.js.map +1 -1
  1335. package/dist/cssm/components/Gradient/Gradient.js +3 -3
  1336. package/dist/cssm/components/Gradient/Gradient.js.map +1 -1
  1337. package/dist/cssm/components/GridAvatar/GridAvatar.js +5 -11
  1338. package/dist/cssm/components/GridAvatar/GridAvatar.js.map +1 -1
  1339. package/dist/cssm/components/Group/Group.js +8 -8
  1340. package/dist/cssm/components/Group/Group.js.map +1 -1
  1341. package/dist/cssm/components/Header/Header.js +16 -16
  1342. package/dist/cssm/components/Header/Header.js.map +1 -1
  1343. package/dist/cssm/components/HorizontalCell/HorizontalCell.js +3 -3
  1344. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  1345. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +3 -3
  1346. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  1347. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js +2 -2
  1348. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  1349. package/dist/cssm/components/HoverPopper/HoverPopper.js +6 -6
  1350. package/dist/cssm/components/HoverPopper/HoverPopper.js.map +1 -1
  1351. package/dist/cssm/components/IconButton/IconButton.js +4 -4
  1352. package/dist/cssm/components/IconButton/IconButton.js.map +1 -1
  1353. package/dist/cssm/components/InfoRow/InfoRow.js +1 -1
  1354. package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
  1355. package/dist/cssm/components/InitialsAvatar/InitialsAvatar.css +1 -1
  1356. package/dist/cssm/components/InitialsAvatar/InitialsAvatar.js +10 -13
  1357. package/dist/cssm/components/InitialsAvatar/InitialsAvatar.js.map +1 -1
  1358. package/dist/cssm/components/Input/Input.js +2 -2
  1359. package/dist/cssm/components/Input/Input.js.map +1 -1
  1360. package/dist/cssm/components/Link/Link.js +2 -2
  1361. package/dist/cssm/components/Link/Link.js.map +1 -1
  1362. package/dist/cssm/components/List/List.js +3 -3
  1363. package/dist/cssm/components/List/List.js.map +1 -1
  1364. package/dist/cssm/components/List/ListContext.js +1 -1
  1365. package/dist/cssm/components/List/ListContext.js.map +1 -1
  1366. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js +6 -6
  1367. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  1368. package/dist/cssm/components/ModalCard/ModalCard.js +5 -5
  1369. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  1370. package/dist/cssm/components/ModalCardBase/ModalCardBase.js +7 -7
  1371. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  1372. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js +3 -3
  1373. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  1374. package/dist/cssm/components/ModalPage/ModalPage.js +4 -4
  1375. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  1376. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.css +1 -1
  1377. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js +1 -1
  1378. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  1379. package/dist/cssm/components/ModalRoot/ModalRoot.js +24 -24
  1380. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  1381. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js +1 -1
  1382. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  1383. package/dist/cssm/components/ModalRoot/ModalRootContext.js +1 -1
  1384. package/dist/cssm/components/ModalRoot/ModalRootContext.js.map +1 -1
  1385. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +13 -13
  1386. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  1387. package/dist/cssm/components/ModalRoot/types.js.map +1 -1
  1388. package/dist/cssm/components/ModalRoot/useModalManager.js +14 -14
  1389. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  1390. package/dist/cssm/components/ModalRoot/withModalRootContext.js +1 -1
  1391. package/dist/cssm/components/ModalRoot/withModalRootContext.js.map +1 -1
  1392. package/dist/cssm/components/NativeSelect/NativeSelect.js +5 -5
  1393. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  1394. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js +1 -1
  1395. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  1396. package/dist/cssm/components/Panel/Panel.css +1 -1
  1397. package/dist/cssm/components/Panel/Panel.js +2 -2
  1398. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  1399. package/dist/cssm/components/PanelHeader/PanelHeader.css +1 -1
  1400. package/dist/cssm/components/PanelHeader/PanelHeader.js +10 -10
  1401. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  1402. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js +5 -5
  1403. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  1404. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js +15 -15
  1405. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  1406. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.js +2 -2
  1407. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  1408. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.css +1 -1
  1409. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js +40 -21
  1410. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  1411. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js +6 -6
  1412. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  1413. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js +3 -3
  1414. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  1415. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.js +2 -2
  1416. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  1417. package/dist/cssm/components/PanelSpinner/PanelSpinner.js +1 -1
  1418. package/dist/cssm/components/PanelSpinner/PanelSpinner.js.map +1 -1
  1419. package/dist/cssm/components/Placeholder/Placeholder.js +2 -2
  1420. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  1421. package/dist/cssm/components/PopoutRoot/PopoutRoot.js +3 -3
  1422. package/dist/cssm/components/PopoutRoot/PopoutRoot.js.map +1 -1
  1423. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +10 -10
  1424. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  1425. package/dist/cssm/components/Popper/Popper.css +1 -1
  1426. package/dist/cssm/components/Popper/Popper.js +52 -27
  1427. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  1428. package/dist/cssm/components/Progress/Progress.js +1 -1
  1429. package/dist/cssm/components/Progress/Progress.js.map +1 -1
  1430. package/dist/cssm/components/PromoBanner/PromoBanner.js +6 -6
  1431. package/dist/cssm/components/PromoBanner/PromoBanner.js.map +1 -1
  1432. package/dist/cssm/components/PullToRefresh/PullToRefresh.js +10 -10
  1433. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  1434. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js +9 -9
  1435. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  1436. package/dist/cssm/components/Radio/Radio.css +1 -1
  1437. package/dist/cssm/components/Radio/Radio.js +4 -3
  1438. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  1439. package/dist/cssm/components/RadioGroup/RadioGroup.css +1 -0
  1440. package/dist/cssm/components/RadioGroup/RadioGroup.js +20 -0
  1441. package/dist/cssm/components/RadioGroup/RadioGroup.js.map +1 -0
  1442. package/dist/cssm/components/RangeSlider/RangeSlider.js +1 -1
  1443. package/dist/cssm/components/RangeSlider/RangeSlider.js.map +1 -1
  1444. package/dist/cssm/components/RangeSlider/UniversalSlider.js +12 -12
  1445. package/dist/cssm/components/RangeSlider/UniversalSlider.js.map +1 -1
  1446. package/dist/cssm/components/Removable/Removable.js +6 -6
  1447. package/dist/cssm/components/Removable/Removable.js.map +1 -1
  1448. package/dist/cssm/components/RichCell/RichCell.js +2 -2
  1449. package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
  1450. package/dist/cssm/components/RichTooltip/RichTooltip.js +2 -2
  1451. package/dist/cssm/components/RichTooltip/RichTooltip.js.map +1 -1
  1452. package/dist/cssm/components/Root/Root.css +1 -1
  1453. package/dist/cssm/components/Root/Root.js +12 -12
  1454. package/dist/cssm/components/Root/Root.js.map +1 -1
  1455. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js +3 -3
  1456. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  1457. package/dist/cssm/components/Search/Search.css +1 -1
  1458. package/dist/cssm/components/Search/Search.js +14 -14
  1459. package/dist/cssm/components/Search/Search.js.map +1 -1
  1460. package/dist/cssm/components/Select/Select.js.map +1 -1
  1461. package/dist/cssm/components/SelectMimicry/SelectMimicry.js +3 -3
  1462. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  1463. package/dist/cssm/components/Separator/Separator.js +5 -5
  1464. package/dist/cssm/components/Separator/Separator.js.map +1 -1
  1465. package/dist/cssm/components/SimpleCell/SimpleCell.js +4 -4
  1466. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  1467. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js +9 -9
  1468. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  1469. package/dist/cssm/components/Slider/Slider.css +1 -1
  1470. package/dist/cssm/components/Slider/Slider.js +1 -1
  1471. package/dist/cssm/components/Slider/Slider.js.map +1 -1
  1472. package/dist/cssm/components/SliderSwitch/SliderSwitch.js +8 -8
  1473. package/dist/cssm/components/SliderSwitch/SliderSwitch.js.map +1 -1
  1474. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js +2 -2
  1475. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  1476. package/dist/cssm/components/Snackbar/Snackbar.js +9 -9
  1477. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  1478. package/dist/cssm/components/Spacing/Spacing.js +5 -5
  1479. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  1480. package/dist/cssm/components/Spinner/Spinner.js +8 -8
  1481. package/dist/cssm/components/Spinner/Spinner.js.map +1 -1
  1482. package/dist/cssm/components/SplitCol/SplitCol.js +4 -4
  1483. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  1484. package/dist/cssm/components/SplitLayout/SplitLayout.js +3 -3
  1485. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  1486. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.css +1 -1
  1487. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js +4 -4
  1488. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  1489. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +5 -5
  1490. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  1491. package/dist/cssm/components/Switch/Switch.css +1 -1
  1492. package/dist/cssm/components/Switch/Switch.js +14 -3
  1493. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  1494. package/dist/cssm/components/Tabbar/Tabbar.css +1 -1
  1495. package/dist/cssm/components/Tabbar/Tabbar.js +6 -6
  1496. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  1497. package/dist/cssm/components/TabbarItem/TabbarItem.js +5 -5
  1498. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  1499. package/dist/cssm/components/Tabs/Tabs.css +1 -1
  1500. package/dist/cssm/components/Tabs/Tabs.js +6 -6
  1501. package/dist/cssm/components/Tabs/Tabs.js.map +1 -1
  1502. package/dist/cssm/components/TabsItem/TabsItem.css +1 -1
  1503. package/dist/cssm/components/TabsItem/TabsItem.js +6 -6
  1504. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  1505. package/dist/cssm/components/Tappable/Tappable.css +1 -1
  1506. package/dist/cssm/components/Tappable/Tappable.js +37 -31
  1507. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  1508. package/dist/cssm/components/TextTooltip/TextTooltip.js +3 -3
  1509. package/dist/cssm/components/TextTooltip/TextTooltip.js.map +1 -1
  1510. package/dist/cssm/components/Textarea/Textarea.js +3 -3
  1511. package/dist/cssm/components/Textarea/Textarea.js.map +1 -1
  1512. package/dist/cssm/components/Tooltip/Tooltip.css +1 -1
  1513. package/dist/cssm/components/Tooltip/Tooltip.js +29 -29
  1514. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  1515. package/dist/cssm/components/Tooltip/TooltipContainer.js +3 -3
  1516. package/dist/cssm/components/Tooltip/TooltipContainer.js.map +1 -1
  1517. package/dist/cssm/components/Touch/Touch.js +8 -10
  1518. package/dist/cssm/components/Touch/Touch.js.map +1 -1
  1519. package/dist/cssm/components/Touch/TouchContext.js +1 -1
  1520. package/dist/cssm/components/Touch/TouchContext.js.map +1 -1
  1521. package/dist/cssm/components/Typography/Caption/Caption.js +5 -5
  1522. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  1523. package/dist/cssm/components/Typography/Headline/Headline.js +3 -3
  1524. package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
  1525. package/dist/cssm/components/Typography/Subhead/Subhead.js +3 -3
  1526. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  1527. package/dist/cssm/components/Typography/Text/Text.js +6 -6
  1528. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  1529. package/dist/cssm/components/Typography/Title/Title.js +6 -6
  1530. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  1531. package/dist/cssm/components/UsersStack/UsersStack.js +6 -6
  1532. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  1533. package/dist/cssm/components/UsersStack/masks.js +7 -7
  1534. package/dist/cssm/components/UsersStack/masks.js.map +1 -1
  1535. package/dist/cssm/components/View/View.js +18 -18
  1536. package/dist/cssm/components/View/View.js.map +1 -1
  1537. package/dist/cssm/components/View/ViewInfinite.js +18 -18
  1538. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  1539. package/dist/cssm/components/View/utils.js +1 -1
  1540. package/dist/cssm/components/View/utils.js.map +1 -1
  1541. package/dist/cssm/components/WriteBar/WriteBar.js +4 -4
  1542. package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
  1543. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +12 -12
  1544. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1545. package/dist/cssm/fonts/fonts.css +1 -0
  1546. package/dist/cssm/helpers/avatar.js +7 -0
  1547. package/dist/cssm/helpers/avatar.js.map +1 -0
  1548. package/dist/cssm/helpers/getClassName.js.map +1 -1
  1549. package/dist/cssm/helpers/math.js +1 -1
  1550. package/dist/cssm/helpers/math.js.map +1 -1
  1551. package/dist/cssm/hoc/withAdaptivity.js +1 -1
  1552. package/dist/cssm/hoc/withAdaptivity.js.map +1 -1
  1553. package/dist/cssm/hoc/withContext.js +1 -1
  1554. package/dist/cssm/hoc/withContext.js.map +1 -1
  1555. package/dist/cssm/hoc/withInsets.js.map +1 -1
  1556. package/dist/cssm/hoc/withPlatform.js +1 -1
  1557. package/dist/cssm/hoc/withPlatform.js.map +1 -1
  1558. package/dist/cssm/hooks/useAdaptivity.js +1 -1
  1559. package/dist/cssm/hooks/useAdaptivity.js.map +1 -1
  1560. package/dist/cssm/hooks/useAppearance.js +1 -1
  1561. package/dist/cssm/hooks/useAppearance.js.map +1 -1
  1562. package/dist/cssm/hooks/useBrowserInfo.js +1 -1
  1563. package/dist/cssm/hooks/useBrowserInfo.js.map +1 -1
  1564. package/dist/cssm/hooks/useEffectDev.js +4 -0
  1565. package/dist/cssm/hooks/useEffectDev.js.map +1 -0
  1566. package/dist/cssm/hooks/useEnsuredControl.js +2 -2
  1567. package/dist/cssm/hooks/useEnsuredControl.js.map +1 -1
  1568. package/dist/cssm/hooks/useEventListener.js +1 -1
  1569. package/dist/cssm/hooks/useEventListener.js.map +1 -1
  1570. package/dist/cssm/hooks/useExternRef.js +1 -1
  1571. package/dist/cssm/hooks/useExternRef.js.map +1 -1
  1572. package/dist/cssm/hooks/useFocusVisible.js +28 -0
  1573. package/dist/cssm/hooks/useFocusVisible.js.map +1 -0
  1574. package/dist/cssm/hooks/useGlobalEventListener.js.map +1 -1
  1575. package/dist/cssm/hooks/useInsets.js +4 -4
  1576. package/dist/cssm/hooks/useInsets.js.map +1 -1
  1577. package/dist/cssm/hooks/useKeyboard.js +4 -4
  1578. package/dist/cssm/hooks/useKeyboard.js.map +1 -1
  1579. package/dist/cssm/hooks/useKeyboardInputTracker.js +4 -4
  1580. package/dist/cssm/hooks/useKeyboardInputTracker.js.map +1 -1
  1581. package/dist/cssm/hooks/useObjectMemo.js +1 -1
  1582. package/dist/cssm/hooks/useObjectMemo.js.map +1 -1
  1583. package/dist/cssm/hooks/usePatchChildrenRef.js +6 -6
  1584. package/dist/cssm/hooks/usePatchChildrenRef.js.map +1 -1
  1585. package/dist/cssm/hooks/usePlatform.js +1 -1
  1586. package/dist/cssm/hooks/usePlatform.js.map +1 -1
  1587. package/dist/cssm/hooks/useTimeout.js +2 -2
  1588. package/dist/cssm/hooks/useTimeout.js.map +1 -1
  1589. package/dist/cssm/hooks/useWaitTransitionFinish.js +1 -1
  1590. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  1591. package/dist/cssm/index.js +3 -0
  1592. package/dist/cssm/index.js.map +1 -1
  1593. package/dist/cssm/lib/SSR.js +2 -2
  1594. package/dist/cssm/lib/SSR.js.map +1 -1
  1595. package/dist/cssm/lib/accessibility.js +9 -11
  1596. package/dist/cssm/lib/accessibility.js.map +1 -1
  1597. package/dist/cssm/lib/animate.js +1 -1
  1598. package/dist/cssm/lib/animate.js.map +1 -1
  1599. package/dist/cssm/lib/browser.js +2 -2
  1600. package/dist/cssm/lib/browser.js.map +1 -1
  1601. package/dist/cssm/lib/callMultiple.js +18 -0
  1602. package/dist/cssm/lib/callMultiple.js.map +1 -0
  1603. package/dist/cssm/lib/classNames.js +4 -4
  1604. package/dist/cssm/lib/classNames.js.map +1 -1
  1605. package/dist/cssm/lib/classScopingMode.js +1 -1
  1606. package/dist/cssm/lib/classScopingMode.js.map +1 -1
  1607. package/dist/cssm/lib/dom.js +3 -3
  1608. package/dist/cssm/lib/dom.js.map +1 -1
  1609. package/dist/cssm/lib/getNavId.js +1 -1
  1610. package/dist/cssm/lib/getNavId.js.map +1 -1
  1611. package/dist/cssm/lib/is.js +1 -2
  1612. package/dist/cssm/lib/is.js.map +1 -1
  1613. package/dist/cssm/lib/isRefObject.js +5 -0
  1614. package/dist/cssm/lib/isRefObject.js.map +1 -0
  1615. package/dist/cssm/lib/jsxRuntime.js +4 -4
  1616. package/dist/cssm/lib/jsxRuntime.js.map +1 -1
  1617. package/dist/cssm/lib/platform.js +1 -1
  1618. package/dist/cssm/lib/platform.js.map +1 -1
  1619. package/dist/cssm/lib/polyfills.js +6 -6
  1620. package/dist/cssm/lib/polyfills.js.map +1 -1
  1621. package/dist/cssm/lib/prefixClass.js +5 -5
  1622. package/dist/cssm/lib/prefixClass.js.map +1 -1
  1623. package/dist/cssm/lib/removeObjectKeys.js.map +1 -1
  1624. package/dist/cssm/lib/select.js +4 -4
  1625. package/dist/cssm/lib/select.js.map +1 -1
  1626. package/dist/cssm/lib/styles.js +4 -2
  1627. package/dist/cssm/lib/styles.js.map +1 -1
  1628. package/dist/cssm/lib/supportEvents.js +6 -6
  1629. package/dist/cssm/lib/supportEvents.js.map +1 -1
  1630. package/dist/cssm/lib/taptic.js +3 -3
  1631. package/dist/cssm/lib/taptic.js.map +1 -1
  1632. package/dist/cssm/lib/testing.js +1 -1
  1633. package/dist/cssm/lib/testing.js.map +1 -1
  1634. package/dist/cssm/lib/touch.js +4 -4
  1635. package/dist/cssm/lib/touch.js.map +1 -1
  1636. package/dist/cssm/lib/useIsomorphicLayoutEffect.js +4 -4
  1637. package/dist/cssm/lib/useIsomorphicLayoutEffect.js.map +1 -1
  1638. package/dist/cssm/lib/utils.js +8 -8
  1639. package/dist/cssm/lib/utils.js.map +1 -1
  1640. package/dist/cssm/styles/bright_light.css +1 -1
  1641. package/dist/cssm/styles/components.css +43 -1
  1642. package/dist/cssm/styles/constants.css +3 -1
  1643. package/dist/cssm/styles/space_gray.css +1 -1
  1644. package/dist/cssm/styles/themes.css +16 -1
  1645. package/dist/cssm/styles/unstable.css +1 -1
  1646. package/dist/cssm/styles/vkcom_dark.css +6 -1
  1647. package/dist/cssm/styles/vkcom_light.css +11 -1
  1648. package/dist/cssm/unstable/index.js.map +1 -1
  1649. package/dist/default_scheme.css +1 -1
  1650. package/dist/default_scheme.css.map +1 -1
  1651. package/dist/fonts.css +3 -0
  1652. package/dist/fonts.css.map +1 -0
  1653. package/dist/helpers/avatar.d.ts +5 -0
  1654. package/dist/helpers/avatar.js +7 -0
  1655. package/dist/helpers/avatar.js.map +1 -0
  1656. package/dist/helpers/getClassName.d.ts +1 -1
  1657. package/dist/helpers/getClassName.js.map +1 -1
  1658. package/dist/helpers/math.js +1 -1
  1659. package/dist/helpers/math.js.map +1 -1
  1660. package/dist/hoc/withAdaptivity.d.ts +1 -1
  1661. package/dist/hoc/withAdaptivity.js +1 -1
  1662. package/dist/hoc/withAdaptivity.js.map +1 -1
  1663. package/dist/hoc/withContext.d.ts +1 -1
  1664. package/dist/hoc/withContext.js +1 -1
  1665. package/dist/hoc/withContext.js.map +1 -1
  1666. package/dist/hoc/withInsets.js.map +1 -1
  1667. package/dist/hoc/withPlatform.js +1 -1
  1668. package/dist/hoc/withPlatform.js.map +1 -1
  1669. package/dist/hooks/useAdaptivity.d.ts +1 -1
  1670. package/dist/hooks/useAdaptivity.js +1 -1
  1671. package/dist/hooks/useAdaptivity.js.map +1 -1
  1672. package/dist/hooks/useAppearance.js +1 -1
  1673. package/dist/hooks/useAppearance.js.map +1 -1
  1674. package/dist/hooks/useBrowserInfo.d.ts +1 -1
  1675. package/dist/hooks/useBrowserInfo.js +1 -1
  1676. package/dist/hooks/useBrowserInfo.js.map +1 -1
  1677. package/dist/hooks/useEffectDev.d.ts +2 -0
  1678. package/dist/hooks/useEffectDev.js +4 -0
  1679. package/dist/hooks/useEffectDev.js.map +1 -0
  1680. package/dist/hooks/useEnsuredControl.js +2 -2
  1681. package/dist/hooks/useEnsuredControl.js.map +1 -1
  1682. package/dist/hooks/useEventListener.js +1 -1
  1683. package/dist/hooks/useEventListener.js.map +1 -1
  1684. package/dist/hooks/useExternRef.d.ts +1 -1
  1685. package/dist/hooks/useExternRef.js +1 -1
  1686. package/dist/hooks/useExternRef.js.map +1 -1
  1687. package/dist/hooks/useFocusVisible.d.ts +6 -0
  1688. package/dist/hooks/useFocusVisible.js +28 -0
  1689. package/dist/hooks/useFocusVisible.js.map +1 -0
  1690. package/dist/hooks/useGlobalEventListener.js.map +1 -1
  1691. package/dist/hooks/useInsets.d.ts +1 -1
  1692. package/dist/hooks/useInsets.js +4 -4
  1693. package/dist/hooks/useInsets.js.map +1 -1
  1694. package/dist/hooks/useKeyboard.js +4 -4
  1695. package/dist/hooks/useKeyboard.js.map +1 -1
  1696. package/dist/hooks/useKeyboardInputTracker.js +4 -4
  1697. package/dist/hooks/useKeyboardInputTracker.js.map +1 -1
  1698. package/dist/hooks/useObjectMemo.js +1 -1
  1699. package/dist/hooks/useObjectMemo.js.map +1 -1
  1700. package/dist/hooks/usePatchChildrenRef.d.ts +1 -1
  1701. package/dist/hooks/usePatchChildrenRef.js +6 -6
  1702. package/dist/hooks/usePatchChildrenRef.js.map +1 -1
  1703. package/dist/hooks/usePlatform.d.ts +1 -1
  1704. package/dist/hooks/usePlatform.js +1 -1
  1705. package/dist/hooks/usePlatform.js.map +1 -1
  1706. package/dist/hooks/useTimeout.js +2 -2
  1707. package/dist/hooks/useTimeout.js.map +1 -1
  1708. package/dist/hooks/useWaitTransitionFinish.js +1 -1
  1709. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  1710. package/dist/index.d.ts +236 -232
  1711. package/dist/index.js +3 -0
  1712. package/dist/index.js.map +1 -1
  1713. package/dist/lib/SSR.d.ts +3 -3
  1714. package/dist/lib/SSR.js +2 -2
  1715. package/dist/lib/SSR.js.map +1 -1
  1716. package/dist/lib/accessibility.d.ts +1 -1
  1717. package/dist/lib/accessibility.js +9 -11
  1718. package/dist/lib/accessibility.js.map +1 -1
  1719. package/dist/lib/animate.d.ts +1 -1
  1720. package/dist/lib/animate.js +1 -1
  1721. package/dist/lib/animate.js.map +1 -1
  1722. package/dist/lib/browser.d.ts +1 -1
  1723. package/dist/lib/browser.js +2 -2
  1724. package/dist/lib/browser.js.map +1 -1
  1725. package/dist/lib/callMultiple.d.ts +1 -0
  1726. package/dist/lib/callMultiple.js +18 -0
  1727. package/dist/lib/callMultiple.js.map +1 -0
  1728. package/dist/lib/classNames.js +4 -4
  1729. package/dist/lib/classNames.js.map +1 -1
  1730. package/dist/lib/classScopingMode.js +1 -1
  1731. package/dist/lib/classScopingMode.js.map +1 -1
  1732. package/dist/lib/dom.d.ts +2 -2
  1733. package/dist/lib/dom.js +3 -3
  1734. package/dist/lib/dom.js.map +1 -1
  1735. package/dist/lib/getNavId.js +1 -1
  1736. package/dist/lib/getNavId.js.map +1 -1
  1737. package/dist/lib/is.js +1 -2
  1738. package/dist/lib/is.js.map +1 -1
  1739. package/dist/lib/isRefObject.d.ts +2 -0
  1740. package/dist/lib/isRefObject.js +5 -0
  1741. package/dist/lib/isRefObject.js.map +1 -0
  1742. package/dist/lib/jsxRuntime.d.ts +1 -1
  1743. package/dist/lib/jsxRuntime.js +4 -4
  1744. package/dist/lib/jsxRuntime.js.map +1 -1
  1745. package/dist/lib/platform.d.ts +1 -1
  1746. package/dist/lib/platform.js +1 -1
  1747. package/dist/lib/platform.js.map +1 -1
  1748. package/dist/lib/polyfills.js +6 -6
  1749. package/dist/lib/polyfills.js.map +1 -1
  1750. package/dist/lib/prefixClass.js +5 -5
  1751. package/dist/lib/prefixClass.js.map +1 -1
  1752. package/dist/lib/removeObjectKeys.js.map +1 -1
  1753. package/dist/lib/select.js +4 -4
  1754. package/dist/lib/select.js.map +1 -1
  1755. package/dist/lib/styles.d.ts +1 -1
  1756. package/dist/lib/styles.js +4 -2
  1757. package/dist/lib/styles.js.map +1 -1
  1758. package/dist/lib/supportEvents.js +6 -6
  1759. package/dist/lib/supportEvents.js.map +1 -1
  1760. package/dist/lib/taptic.d.ts +1 -1
  1761. package/dist/lib/taptic.js +3 -3
  1762. package/dist/lib/taptic.js.map +1 -1
  1763. package/dist/lib/testing.js +1 -1
  1764. package/dist/lib/testing.js.map +1 -1
  1765. package/dist/lib/touch.js +4 -4
  1766. package/dist/lib/touch.js.map +1 -1
  1767. package/dist/lib/useIsomorphicLayoutEffect.d.ts +1 -1
  1768. package/dist/lib/useIsomorphicLayoutEffect.js +4 -4
  1769. package/dist/lib/useIsomorphicLayoutEffect.js.map +1 -1
  1770. package/dist/lib/utils.d.ts +2 -2
  1771. package/dist/lib/utils.js +8 -8
  1772. package/dist/lib/utils.js.map +1 -1
  1773. package/dist/types.d.ts +4 -4
  1774. package/dist/unstable/index.d.ts +14 -14
  1775. package/dist/unstable/index.js.map +1 -1
  1776. package/dist/unstable.css +1 -1
  1777. package/dist/unstable.css.map +1 -1
  1778. package/dist/vkui.css +59 -2
  1779. package/dist/vkui.css.map +1 -1
  1780. package/jest.unit.config.js +9 -9
  1781. package/package.json +35 -15
  1782. package/postcss.config.js +23 -21
  1783. package/src/components/ActionSheet/ActionSheet.css +9 -13
  1784. package/src/components/ActionSheet/ActionSheet.tsx +78 -55
  1785. package/src/components/ActionSheet/ActionSheetContext.ts +6 -2
  1786. package/src/components/ActionSheet/ActionSheetDropdown.tsx +9 -9
  1787. package/src/components/ActionSheet/ActionSheetDropdownDesktop.tsx +57 -46
  1788. package/src/components/ActionSheet/Readme.md +224 -180
  1789. package/src/components/ActionSheet/types.ts +9 -4
  1790. package/src/components/ActionSheetItem/ActionSheetItem.css +11 -7
  1791. package/src/components/ActionSheetItem/ActionSheetItem.tsx +85 -61
  1792. package/src/components/AdaptivityProvider/AdaptivityContext.tsx +12 -11
  1793. package/src/components/AdaptivityProvider/AdaptivityProvider.tsx +37 -12
  1794. package/src/components/Alert/Alert.css +17 -16
  1795. package/src/components/Alert/Alert.tsx +119 -56
  1796. package/src/components/Alert/Readme.md +67 -52
  1797. package/src/components/AppRoot/AppRoot.tsx +177 -132
  1798. package/src/components/AppRoot/AppRootContext.ts +2 -2
  1799. package/src/components/AppRoot/AppRootPortal.tsx +12 -8
  1800. package/src/components/AppRoot/Readme.md +2 -1
  1801. package/src/components/AppRoot/ScrollContext.ts +18 -8
  1802. package/src/components/Avatar/Avatar.css +65 -1
  1803. package/src/components/Avatar/Avatar.tsx +91 -20
  1804. package/src/components/Avatar/Readme.md +834 -72
  1805. package/src/components/Badge/Badge.tsx +10 -13
  1806. package/src/components/Badge/Readme.md +26 -5
  1807. package/src/components/Banner/Banner.css +2 -2
  1808. package/src/components/Banner/Banner.tsx +98 -49
  1809. package/src/components/Banner/Readme.md +99 -46
  1810. package/src/components/Button/Button.css +394 -49
  1811. package/src/components/Button/Button.tsx +129 -45
  1812. package/src/components/Button/Readme.md +185 -132
  1813. package/src/components/Card/Card.css +2 -2
  1814. package/src/components/Card/Card.tsx +19 -14
  1815. package/src/components/Card/Readme.md +19 -10
  1816. package/src/components/CardGrid/CardGrid.tsx +19 -12
  1817. package/src/components/CardGrid/Readme.md +27 -26
  1818. package/src/components/CardScroll/CardScroll.tsx +41 -21
  1819. package/src/components/CardScroll/Readme.md +14 -13
  1820. package/src/components/Cell/Cell.css +3 -3
  1821. package/src/components/Cell/Cell.tsx +63 -39
  1822. package/src/components/Cell/CellCheckbox/CellCheckbox.tsx +20 -21
  1823. package/src/components/Cell/CellDragger/CellDragger.tsx +11 -14
  1824. package/src/components/Cell/Readme.md +117 -50
  1825. package/src/components/Cell/useDraggable.tsx +22 -16
  1826. package/src/components/CellButton/CellButton.css +1 -1
  1827. package/src/components/CellButton/CellButton.tsx +11 -11
  1828. package/src/components/CellButton/Readme.md +36 -6
  1829. package/src/components/Checkbox/Checkbox.css +50 -31
  1830. package/src/components/Checkbox/Checkbox.tsx +70 -29
  1831. package/src/components/Checkbox/Readme.md +16 -12
  1832. package/src/components/Chip/Chip.tsx +27 -16
  1833. package/src/components/Chip/Readme.md +67 -36
  1834. package/src/components/ChipsInput/ChipsInput.css +1 -1
  1835. package/src/components/ChipsInput/ChipsInput.tsx +91 -35
  1836. package/src/components/ChipsInput/Readme.md +47 -15
  1837. package/src/components/ChipsInput/useChipsInput.ts +56 -24
  1838. package/src/components/ChipsSelect/ChipsSelect.css +2 -28
  1839. package/src/components/ChipsSelect/ChipsSelect.tsx +204 -115
  1840. package/src/components/ChipsSelect/Readme.md +60 -28
  1841. package/src/components/ChipsSelect/useChipsSelect.ts +27 -10
  1842. package/src/components/ClickPopper/ClickPopper.tsx +20 -20
  1843. package/src/components/ConfigProvider/ConfigProvider.tsx +53 -28
  1844. package/src/components/ConfigProvider/ConfigProviderContext.tsx +29 -16
  1845. package/src/components/ContentCard/ContentCard.css +7 -0
  1846. package/src/components/ContentCard/ContentCard.tsx +63 -37
  1847. package/src/components/ContentCard/Readme.md +23 -24
  1848. package/src/components/Counter/Counter.css +90 -19
  1849. package/src/components/Counter/Counter.tsx +42 -22
  1850. package/src/components/Counter/Readme.md +66 -25
  1851. package/src/components/CustomScrollView/CustomScrollView.css +3 -11
  1852. package/src/components/CustomScrollView/CustomScrollView.tsx +55 -31
  1853. package/src/components/CustomSelect/CustomSelect.css +3 -24
  1854. package/src/components/CustomSelect/CustomSelect.tsx +223 -132
  1855. package/src/components/CustomSelect/Readme.md +219 -153
  1856. package/src/components/CustomSelectDropdown/CustomSelectDropdown.css +26 -0
  1857. package/src/components/CustomSelectDropdown/CustomSelectDropdown.tsx +66 -0
  1858. package/src/components/CustomSelectOption/CustomSelectOption.css +1 -1
  1859. package/src/components/CustomSelectOption/CustomSelectOption.tsx +44 -26
  1860. package/src/components/CustomSelectOption/Readme.md +23 -6
  1861. package/src/components/DatePicker/DatePicker.tsx +91 -37
  1862. package/src/components/DatePicker/Readme.md +21 -19
  1863. package/src/components/Div/Div.css +0 -1
  1864. package/src/components/Div/Div.tsx +18 -8
  1865. package/src/components/Dropdown/Dropdown.css +4 -4
  1866. package/src/components/Dropdown/Dropdown.tsx +23 -14
  1867. package/src/components/Dropdown/Readme.md +16 -6
  1868. package/src/components/DropdownIcon/DropdownIcon.tsx +12 -14
  1869. package/src/components/Epic/Epic.tsx +31 -17
  1870. package/src/components/Epic/Readme.md +218 -175
  1871. package/src/components/Epic/ScrollSaver.tsx +9 -5
  1872. package/src/components/File/File.css +2 -1
  1873. package/src/components/File/File.tsx +39 -20
  1874. package/src/components/File/Readme.md +15 -17
  1875. package/src/components/FixedLayout/FixedLayout.tsx +35 -23
  1876. package/src/components/FixedLayout/Readme.md +88 -39
  1877. package/src/components/FocusTrap/FocusTrap.tsx +37 -23
  1878. package/src/components/FocusVisible/FocusVisible.css +14 -20
  1879. package/src/components/FocusVisible/FocusVisible.tsx +11 -6
  1880. package/src/components/Footer/Footer.tsx +11 -5
  1881. package/src/components/Footer/Readme.md +10 -6
  1882. package/src/components/FormField/FormField.css +4 -4
  1883. package/src/components/FormField/FormField.tsx +23 -20
  1884. package/src/components/FormField/Readme.md +12 -12
  1885. package/src/components/FormItem/FormItem.css +2 -1
  1886. package/src/components/FormItem/FormItem.tsx +45 -29
  1887. package/src/components/FormItem/Readme.md +121 -82
  1888. package/src/components/FormLayout/FormLayout.tsx +17 -21
  1889. package/src/components/FormLayoutGroup/FormLayoutGroup.tsx +38 -33
  1890. package/src/components/FormLayoutGroup/Readme.md +23 -18
  1891. package/src/components/FormStatus/FormStatus.css +2 -1
  1892. package/src/components/FormStatus/FormStatus.tsx +30 -15
  1893. package/src/components/FormStatus/Readme.md +1 -3
  1894. package/src/components/Gallery/Gallery.css +2 -1
  1895. package/src/components/Gallery/Gallery.tsx +180 -95
  1896. package/src/components/Gallery/Readme.md +45 -39
  1897. package/src/components/Gradient/Gradient.css +74 -6
  1898. package/src/components/Gradient/Gradient.tsx +18 -9
  1899. package/src/components/Gradient/Readme.md +36 -17
  1900. package/src/components/GridAvatar/GridAvatar.tsx +21 -23
  1901. package/src/components/GridAvatar/Readme.md +18 -6
  1902. package/src/components/Group/Group.tsx +46 -25
  1903. package/src/components/Group/Readme.md +102 -67
  1904. package/src/components/Header/Header.tsx +93 -43
  1905. package/src/components/Header/Readme.md +95 -13
  1906. package/src/components/HorizontalCell/HorizontalCell.tsx +52 -27
  1907. package/src/components/HorizontalCell/Readme.md +225 -160
  1908. package/src/components/HorizontalScroll/HorizontalScroll.css +7 -3
  1909. package/src/components/HorizontalScroll/HorizontalScroll.tsx +51 -43
  1910. package/src/components/HorizontalScroll/HorizontalScrollArrow.css +3 -3
  1911. package/src/components/HorizontalScroll/HorizontalScrollArrow.tsx +14 -11
  1912. package/src/components/HorizontalScroll/Readme.md +27 -19
  1913. package/src/components/HoverPopper/HoverPopper.tsx +13 -13
  1914. package/src/components/IconButton/IconButton.css +1 -1
  1915. package/src/components/IconButton/IconButton.tsx +13 -13
  1916. package/src/components/InfoRow/InfoRow.tsx +22 -12
  1917. package/src/components/InfoRow/Readme.md +22 -32
  1918. package/src/components/InitialsAvatar/InitialsAvatar.css +5 -3
  1919. package/src/components/InitialsAvatar/InitialsAvatar.tsx +33 -28
  1920. package/src/components/InitialsAvatar/Readme.md +12 -6
  1921. package/src/components/Input/Input.css +1 -1
  1922. package/src/components/Input/Input.tsx +21 -17
  1923. package/src/components/Input/Readme.md +23 -8
  1924. package/src/components/Link/Link.tsx +8 -11
  1925. package/src/components/List/List.css +2 -1
  1926. package/src/components/List/List.tsx +8 -8
  1927. package/src/components/List/ListContext.ts +2 -2
  1928. package/src/components/List/Readme.md +10 -6
  1929. package/src/components/MiniInfoCell/MiniInfoCell.tsx +37 -32
  1930. package/src/components/MiniInfoCell/Readme.md +83 -77
  1931. package/src/components/ModalCard/ModalCard.tsx +34 -18
  1932. package/src/components/ModalCardBase/ModalCardBase.css +2 -5
  1933. package/src/components/ModalCardBase/ModalCardBase.tsx +102 -72
  1934. package/src/components/ModalCardBase/Readme.md +4 -1
  1935. package/src/components/ModalDismissButton/ModalDismissButton.css +3 -3
  1936. package/src/components/ModalDismissButton/ModalDismissButton.tsx +11 -9
  1937. package/src/components/ModalDismissButton/Readme.md +37 -31
  1938. package/src/components/ModalPage/ModalPage.css +1 -3
  1939. package/src/components/ModalPage/ModalPage.tsx +46 -23
  1940. package/src/components/ModalPageHeader/ModalPageHeader.css +20 -10
  1941. package/src/components/ModalPageHeader/ModalPageHeader.tsx +26 -21
  1942. package/src/components/ModalPageHeader/Readme.md +22 -12
  1943. package/src/components/ModalRoot/ModalRoot.css +6 -4
  1944. package/src/components/ModalRoot/ModalRoot.tsx +217 -97
  1945. package/src/components/ModalRoot/ModalRootAdaptive.tsx +17 -10
  1946. package/src/components/ModalRoot/ModalRootContext.tsx +11 -9
  1947. package/src/components/ModalRoot/ModalRootDesktop.tsx +91 -45
  1948. package/src/components/ModalRoot/Readme.md +514 -388
  1949. package/src/components/ModalRoot/types.ts +2 -2
  1950. package/src/components/ModalRoot/useModalManager.tsx +52 -35
  1951. package/src/components/ModalRoot/withModalRootContext.tsx +6 -4
  1952. package/src/components/NativeSelect/NativeSelect.tsx +52 -32
  1953. package/src/components/NativeSelect/Readme.md +1 -3
  1954. package/src/components/NavTransitionContext/NavTransitionContext.tsx +11 -4
  1955. package/src/components/Panel/Panel.css +17 -5
  1956. package/src/components/Panel/Panel.tsx +56 -42
  1957. package/src/components/Panel/Readme.md +49 -12
  1958. package/src/components/PanelHeader/PanelHeader.css +17 -10
  1959. package/src/components/PanelHeader/PanelHeader.tsx +74 -52
  1960. package/src/components/PanelHeader/Readme.md +141 -32
  1961. package/src/components/PanelHeaderBack/PanelHeaderBack.tsx +39 -20
  1962. package/src/components/PanelHeaderBack/Readme.md +2 -2
  1963. package/src/components/PanelHeaderButton/PanelHeaderButton.css +3 -3
  1964. package/src/components/PanelHeaderButton/PanelHeaderButton.tsx +46 -42
  1965. package/src/components/PanelHeaderButton/Readme.md +22 -10
  1966. package/src/components/PanelHeaderClose/PanelHeaderClose.tsx +23 -10
  1967. package/src/components/PanelHeaderClose/Readme.md +2 -2
  1968. package/src/components/PanelHeaderContent/PanelHeaderContent.css +26 -4
  1969. package/src/components/PanelHeaderContent/PanelHeaderContent.tsx +76 -35
  1970. package/src/components/PanelHeaderContent/Readme.md +5 -5
  1971. package/src/components/PanelHeaderContext/PanelHeaderContext.css +38 -17
  1972. package/src/components/PanelHeaderContext/PanelHeaderContext.tsx +51 -29
  1973. package/src/components/PanelHeaderContext/Readme.md +101 -74
  1974. package/src/components/PanelHeaderEdit/PanelHeaderEdit.tsx +11 -11
  1975. package/src/components/PanelHeaderEdit/Readme.md +1 -1
  1976. package/src/components/PanelHeaderSubmit/PanelHeaderSubmit.tsx +20 -12
  1977. package/src/components/PanelHeaderSubmit/Readme.md +7 -3
  1978. package/src/components/PanelSpinner/PanelSpinner.tsx +8 -6
  1979. package/src/components/PanelSpinner/Readme.md +7 -3
  1980. package/src/components/Placeholder/Placeholder.tsx +25 -13
  1981. package/src/components/Placeholder/Readme.md +30 -16
  1982. package/src/components/PopoutRoot/PopoutRoot.tsx +42 -17
  1983. package/src/components/PopoutRoot/Readme.md +10 -6
  1984. package/src/components/PopoutWrapper/PopoutWrapper.css +5 -5
  1985. package/src/components/PopoutWrapper/PopoutWrapper.tsx +37 -30
  1986. package/src/components/PopoutWrapper/Readme.md +2 -2
  1987. package/src/components/Popper/Popper.css +2 -2
  1988. package/src/components/Popper/Popper.tsx +140 -60
  1989. package/src/components/Popper/Readme.md +18 -8
  1990. package/src/components/Progress/Progress.css +1 -1
  1991. package/src/components/Progress/Progress.tsx +23 -10
  1992. package/src/components/PromoBanner/PromoBanner.css +1 -1
  1993. package/src/components/PromoBanner/PromoBanner.tsx +40 -23
  1994. package/src/components/PromoBanner/Readme.md +12 -11
  1995. package/src/components/PullToRefresh/PullToRefresh.css +4 -3
  1996. package/src/components/PullToRefresh/PullToRefresh.tsx +78 -35
  1997. package/src/components/PullToRefresh/PullToRefreshSpinner.tsx +17 -14
  1998. package/src/components/PullToRefresh/Readme.md +17 -18
  1999. package/src/components/Radio/Radio.css +66 -102
  2000. package/src/components/Radio/Radio.tsx +59 -24
  2001. package/src/components/Radio/Readme.md +25 -16
  2002. package/src/components/RadioGroup/RadioGroup.css +12 -0
  2003. package/src/components/RadioGroup/RadioGroup.tsx +29 -0
  2004. package/src/components/RadioGroup/Readme.md +56 -0
  2005. package/src/components/RangeSlider/RangeSlider.tsx +28 -13
  2006. package/src/components/RangeSlider/Readme.md +25 -31
  2007. package/src/components/RangeSlider/UniversalSlider.tsx +53 -36
  2008. package/src/components/Removable/Removable.css +12 -5
  2009. package/src/components/Removable/Removable.tsx +29 -24
  2010. package/src/components/RichCell/Readme.md +11 -11
  2011. package/src/components/RichCell/RichCell.tsx +37 -23
  2012. package/src/components/RichTooltip/Readme.md +5 -1
  2013. package/src/components/RichTooltip/RichTooltip.css +2 -2
  2014. package/src/components/RichTooltip/RichTooltip.tsx +16 -12
  2015. package/src/components/Root/Readme.md +4 -4
  2016. package/src/components/Root/Root.css +9 -9
  2017. package/src/components/Root/Root.tsx +82 -49
  2018. package/src/components/ScreenSpinner/Readme.md +20 -18
  2019. package/src/components/ScreenSpinner/ScreenSpinner.css +3 -3
  2020. package/src/components/ScreenSpinner/ScreenSpinner.tsx +14 -11
  2021. package/src/components/Search/Readme.md +220 -167
  2022. package/src/components/Search/Search.css +3 -3
  2023. package/src/components/Search/Search.tsx +77 -51
  2024. package/src/components/Select/Readme.md +11 -6
  2025. package/src/components/Select/Select.tsx +14 -9
  2026. package/src/components/SelectMimicry/Readme.md +78 -66
  2027. package/src/components/SelectMimicry/SelectMimicry.tsx +39 -26
  2028. package/src/components/Separator/Readme.md +3 -5
  2029. package/src/components/Separator/Separator.css +2 -2
  2030. package/src/components/Separator/Separator.tsx +17 -11
  2031. package/src/components/SimpleCell/Readme.md +131 -53
  2032. package/src/components/SimpleCell/SimpleCell.css +25 -7
  2033. package/src/components/SimpleCell/SimpleCell.tsx +59 -43
  2034. package/src/components/SimpleCheckbox/Readme.md +17 -9
  2035. package/src/components/SimpleCheckbox/SimpleCheckbox.css +23 -9
  2036. package/src/components/SimpleCheckbox/SimpleCheckbox.tsx +87 -48
  2037. package/src/components/Slider/Readme.md +75 -72
  2038. package/src/components/Slider/Slider.css +5 -5
  2039. package/src/components/Slider/Slider.tsx +33 -14
  2040. package/src/components/SliderSwitch/Readme.md +21 -23
  2041. package/src/components/SliderSwitch/SliderSwitch.css +1 -1
  2042. package/src/components/SliderSwitch/SliderSwitch.tsx +59 -33
  2043. package/src/components/SliderSwitch/SliderSwitchButton.tsx +36 -34
  2044. package/src/components/Snackbar/Readme.md +67 -39
  2045. package/src/components/Snackbar/Snackbar.css +1 -1
  2046. package/src/components/Snackbar/Snackbar.tsx +90 -55
  2047. package/src/components/Spacing/Readme.md +26 -10
  2048. package/src/components/Spacing/Spacing.css +2 -2
  2049. package/src/components/Spacing/Spacing.tsx +18 -12
  2050. package/src/components/Spinner/Readme.md +5 -5
  2051. package/src/components/Spinner/Spinner.tsx +25 -13
  2052. package/src/components/SplitCol/SplitCol.tsx +22 -8
  2053. package/src/components/SplitLayout/Readme.md +33 -19
  2054. package/src/components/SplitLayout/SplitLayout.css +3 -1
  2055. package/src/components/SplitLayout/SplitLayout.tsx +19 -15
  2056. package/src/components/SubnavigationBar/Readme.md +141 -95
  2057. package/src/components/SubnavigationBar/SubnavigationBar.css +1 -1
  2058. package/src/components/SubnavigationBar/SubnavigationBar.tsx +27 -17
  2059. package/src/components/SubnavigationButton/Readme.md +30 -38
  2060. package/src/components/SubnavigationButton/SubnavigationButton.css +1 -1
  2061. package/src/components/SubnavigationButton/SubnavigationButton.tsx +36 -24
  2062. package/src/components/Switch/Readme.md +47 -25
  2063. package/src/components/Switch/Switch.css +19 -15
  2064. package/src/components/Switch/Switch.tsx +32 -15
  2065. package/src/components/Tabbar/Readme.md +3 -3
  2066. package/src/components/Tabbar/Tabbar.css +4 -4
  2067. package/src/components/Tabbar/Tabbar.tsx +17 -15
  2068. package/src/components/TabbarItem/Readme.md +61 -32
  2069. package/src/components/TabbarItem/TabbarItem.css +2 -2
  2070. package/src/components/TabbarItem/TabbarItem.tsx +51 -41
  2071. package/src/components/Tabs/Readme.md +248 -188
  2072. package/src/components/Tabs/Tabs.css +3 -3
  2073. package/src/components/Tabs/Tabs.tsx +23 -15
  2074. package/src/components/TabsItem/TabsItem.css +5 -3
  2075. package/src/components/TabsItem/TabsItem.tsx +27 -20
  2076. package/src/components/Tappable/Tappable.css +15 -13
  2077. package/src/components/Tappable/Tappable.tsx +123 -64
  2078. package/src/components/TextTooltip/Readme.md +7 -3
  2079. package/src/components/TextTooltip/TextTooltip.css +10 -4
  2080. package/src/components/TextTooltip/TextTooltip.tsx +35 -14
  2081. package/src/components/Textarea/Readme.md +20 -18
  2082. package/src/components/Textarea/Textarea.css +1 -1
  2083. package/src/components/Textarea/Textarea.tsx +66 -61
  2084. package/src/components/Tooltip/Readme.md +171 -117
  2085. package/src/components/Tooltip/Tooltip.css +9 -9
  2086. package/src/components/Tooltip/Tooltip.tsx +138 -80
  2087. package/src/components/Tooltip/TooltipContainer.tsx +5 -5
  2088. package/src/components/Touch/Readme.md +96 -79
  2089. package/src/components/Touch/Touch.tsx +55 -30
  2090. package/src/components/Touch/TouchContext.ts +3 -2
  2091. package/src/components/Typography/Caption/Caption.tsx +22 -22
  2092. package/src/components/Typography/Caption/Readme.md +38 -13
  2093. package/src/components/Typography/Headline/Headline.tsx +16 -11
  2094. package/src/components/Typography/Headline/Readme.md +11 -4
  2095. package/src/components/Typography/Subhead/Readme.md +14 -5
  2096. package/src/components/Typography/Subhead/Subhead.tsx +16 -11
  2097. package/src/components/Typography/Text/Readme.md +8 -3
  2098. package/src/components/Typography/Text/Text.tsx +25 -15
  2099. package/src/components/Typography/Title/Readme.md +31 -12
  2100. package/src/components/Typography/Title/Title.tsx +25 -28
  2101. package/src/components/UsersStack/Readme.md +42 -37
  2102. package/src/components/UsersStack/UsersStack.tsx +37 -30
  2103. package/src/components/UsersStack/masks.tsx +11 -8
  2104. package/src/components/View/Readme.md +22 -21
  2105. package/src/components/View/View.css +3 -3
  2106. package/src/components/View/View.tsx +245 -109
  2107. package/src/components/View/ViewIOS.css +15 -14
  2108. package/src/components/View/ViewInfinite.tsx +279 -121
  2109. package/src/components/View/utils.ts +3 -2
  2110. package/src/components/WriteBar/Readme.md +81 -101
  2111. package/src/components/WriteBar/WriteBar.tsx +27 -29
  2112. package/src/components/WriteBarIcon/WriteBarIcon.css +2 -2
  2113. package/src/components/WriteBarIcon/WriteBarIcon.tsx +40 -27
  2114. package/src/fonts/VK_Sans_Display_Medium.woff +0 -0
  2115. package/src/fonts/VK_Sans_Display_Medium.woff2 +0 -0
  2116. package/src/fonts/fonts.css +7 -0
  2117. package/src/helpers/avatar.ts +10 -0
  2118. package/src/helpers/getClassName.ts +5 -2
  2119. package/src/helpers/math.ts +14 -6
  2120. package/src/hoc/withAdaptivity.tsx +24 -11
  2121. package/src/hoc/withContext.tsx +6 -2
  2122. package/src/hoc/withInsets.tsx +1 -1
  2123. package/src/hoc/withPlatform.tsx +3 -3
  2124. package/src/hooks/useAdaptivity.ts +5 -2
  2125. package/src/hooks/useAppearance.ts +4 -3
  2126. package/src/hooks/useBrowserInfo.ts +5 -5
  2127. package/src/hooks/useEffectDev.ts +5 -0
  2128. package/src/hooks/useEnsuredControl.ts +10 -7
  2129. package/src/hooks/useEventListener.ts +19 -8
  2130. package/src/hooks/useExternRef.ts +17 -12
  2131. package/src/hooks/useFocusVisible.ts +31 -0
  2132. package/src/hooks/useGlobalEventListener.ts +17 -7
  2133. package/src/hooks/useInsets.ts +5 -5
  2134. package/src/hooks/useKeyboard.ts +20 -15
  2135. package/src/hooks/useKeyboardInputTracker.ts +24 -8
  2136. package/src/hooks/useObjectMemo.ts +5 -3
  2137. package/src/hooks/usePatchChildrenRef.ts +29 -14
  2138. package/src/hooks/usePlatform.ts +4 -4
  2139. package/src/hooks/useTimeout.ts +8 -5
  2140. package/src/hooks/useWaitTransitionFinish.ts +7 -3
  2141. package/src/index.ts +260 -232
  2142. package/src/lib/SSR.tsx +6 -8
  2143. package/src/lib/accessibility.ts +41 -32
  2144. package/src/lib/animate.ts +6 -2
  2145. package/src/lib/browser.ts +5 -5
  2146. package/src/lib/callMultiple.ts +4 -0
  2147. package/src/lib/classNames.ts +11 -5
  2148. package/src/lib/classScopingMode.ts +3 -1
  2149. package/src/lib/dom.tsx +6 -4
  2150. package/src/lib/getNavId.ts +1 -1
  2151. package/src/lib/is.ts +4 -4
  2152. package/src/lib/isRefObject.ts +11 -0
  2153. package/src/lib/jsxRuntime.d.ts +1 -1
  2154. package/src/lib/jsxRuntime.ts +11 -6
  2155. package/src/lib/platform.ts +5 -5
  2156. package/src/lib/polyfills.ts +22 -15
  2157. package/src/lib/prefixClass.ts +9 -6
  2158. package/src/lib/removeObjectKeys.ts +4 -1
  2159. package/src/lib/select.ts +6 -5
  2160. package/src/lib/styles.ts +8 -3
  2161. package/src/lib/supportEvents.ts +8 -8
  2162. package/src/lib/taptic.ts +5 -3
  2163. package/src/lib/testing.ts +1 -1
  2164. package/src/lib/touch.ts +11 -6
  2165. package/src/lib/useIsomorphicLayoutEffect.ts +6 -4
  2166. package/src/lib/utils.ts +19 -11
  2167. package/src/styles/animations.css +7 -2
  2168. package/src/styles/bright_light.css +16 -14
  2169. package/src/styles/components.css +109 -106
  2170. package/src/styles/constants.css +13 -6
  2171. package/src/styles/space_gray.css +15 -14
  2172. package/src/styles/themes.css +4 -4
  2173. package/src/styles/unstable.css +5 -6
  2174. package/src/styles/vkcom_dark.css +19 -13
  2175. package/src/styles/vkcom_light.css +24 -13
  2176. package/src/testing/setup.ts +1 -1
  2177. package/src/testing/utils.tsx +92 -57
  2178. package/src/types.ts +4 -4
  2179. package/src/unstable/index.ts +14 -14
  2180. package/src/vkui.js +1 -1
  2181. package/stylelint.config.js +32 -16
  2182. package/tasks/generate_scheme.js +8 -8
  2183. package/tasks/postcss-check-keyframes.js +11 -9
  2184. package/tasks/postcss-scope-root.js +2 -2
  2185. package/tasks/styleint-atomic.js +48 -50
  2186. package/tsconfig.dist.json +7 -7
  2187. package/tsconfig.json +10 -1
  2188. package/types/global.d.ts +2 -2
  2189. package/unstable/index.d.ts +1 -1
  2190. package/unstable/package.json +1 -1
  2191. package/webpack.config.js +24 -24
  2192. package/webpack.styles.config.js +26 -23
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRoot.tsx"],"names":["React","Touch","TouchRootContext","getClassName","classNames","setTransformStyle","rubber","ANDROID","IOS","VKCOM","transitionEvent","withPlatform","withContext","ModalRootContext","ConfigProviderContext","WebviewType","ModalType","MODAL_PAGE_DEFAULT_PERCENT_HEIGHT","withDOM","getNavId","warnOnce","FocusTrap","withModalManager","warn","IS_DEV","process","env","NODE_ENV","numberInRange","number","range","rangeTranslate","Math","max","min","ModalRootTouchComponent","props","createRef","event","originalEvent","preventDefault","modalState","getModalState","activeModal","animateTranslate","translateY","type","PAGE","dynamicContentHeight","enteringModal","waitTransitionFinish","requestAnimationFrame","checkPageContentHeight","e","exitingModal","onPageTouchMove","CARD","onCardTouchMove","onPageTouchEnd","onCardTouchEnd","target","contentElement","contains","contentScrolled","clearTimeout","contentScrollStopTimeout","setTimeout","state","touchDown","dragging","maskElementRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","onClose","closeActiveModal","isInsideModal","frameIds","platform","document","window","Children","toArray","children","addEventListener","updateModalTranslate","toggleDocumentScrolling","removeEventListener","prevProps","closeModal","enteringState","innerElement","style","transitionDelay","onEnter","delayEnter","timeout","restoreFocusTo","activeElement","focus","enabled","documentScrolling","preventTouch","passive","modalElement","prevModalState","initPageModal","currentModalState","needAnimate","expandable","translateYFrom","setState","nextModalState","nextIsPage","prevIsPage","onExit","exitTranslate","isBack","setMaskOpacity","shiftY","isY","viewportRef","current","stopPropagation","collapsed","expanded","touchStartContentScrollTop","scrollTop","touchMovePositive","headerElement","shiftYPercent","innerHeight","shiftYCurrent","touchShiftYPercent","translateYCurrent","offsetHeight","startY","setStateCallback","shiftYEndPercent","expectTranslateY","duration","settlingHeight","expandedRange","collapsedRange","hiddenRange","hidden","eventHandler","supported","onceHandler","name","percent","frameId","cancelAnimationFrame","forceOpacity","history","maskAnimationFrame","opacity","toString","configProvider","webviewType","VKAPPS","onTouchMove","onTouchEnd","onScroll","getModals","map","Modal","modalId","isPage","key","Component","ModalRootTouch","initModal","initCardModal","contentHeight","firstElementChild","prevTranslateY","clientHeight","shiftHalf","visiblePart","headerHeight","height","parentElement"],"mappings":"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","sourcesContent":["import * as React from 'react';\nimport { Touch, TouchEvent } from '../Touch/Touch';\nimport TouchRootContext from '../Touch/TouchContext';\nimport { getClassName } from '../../helpers/getClassName';\nimport { classNames } from '../../lib/classNames';\nimport { setTransformStyle } from '../../lib/styles';\nimport { rubber } from '../../lib/touch';\nimport { ANDROID, IOS, VKCOM } from '../../lib/platform';\nimport { transitionEvent } from '../../lib/supportEvents';\nimport { HasPlatform } from '../../types';\nimport { withPlatform } from '../../hoc/withPlatform';\nimport { withContext } from '../../hoc/withContext';\nimport ModalRootContext, { ModalRootContextInterface } from './ModalRootContext';\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n WebviewType,\n} from '../ConfigProvider/ConfigProviderContext';\nimport { ModalsStateEntry, ModalType, TranslateRange } from './types';\nimport { MODAL_PAGE_DEFAULT_PERCENT_HEIGHT } from './constants';\nimport { DOMProps, withDOM } from '../../lib/dom';\nimport { getNavId } from '../../lib/getNavId';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { FocusTrap } from '../FocusTrap/FocusTrap';\nimport { ModalTransitionProps, withModalManager } from './useModalManager';\nimport './ModalRoot.css';\n\nconst warn = warnOnce('ModalRoot');\nconst IS_DEV = process.env.NODE_ENV === 'development';\n\nfunction numberInRange(number: number, range: TranslateRange) {\n return number >= range[0] && number <= range[1];\n}\n\nfunction rangeTranslate(number: number) {\n return Math.max(0, Math.min(98, number));\n}\n\nexport interface ModalRootProps extends HasPlatform {\n activeModal?: string | null;\n\n /**\n * Будет вызвано при закрытии активной модалки с её id\n */\n onClose?(modalId: string): void;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n}\n\ninterface ModalRootState {\n touchDown?: boolean;\n dragging?: boolean;\n}\n\nclass ModalRootTouchComponent extends React.Component<ModalRootProps & DOMProps & ModalTransitionProps, ModalRootState> {\n constructor(props: ModalRootProps & ModalTransitionProps) {\n super(props);\n this.state = {\n touchDown: false,\n dragging: false,\n };\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: this.updateModalHeight,\n registerModal: ({ id, ...data }) => Object.assign(this.getModalState(id), data),\n onClose: () => this.props.closeActiveModal(),\n isInsideModal: true,\n };\n\n this.frameIds = {};\n }\n\n private documentScrolling: boolean;\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private readonly viewportRef = React.createRef<HTMLDivElement>();\n private maskAnimationFrame: number;\n private readonly modalRootContext: ModalRootContextInterface;\n private readonly frameIds: {\n [index: string]: number;\n };\n private restoreFocusTo: HTMLElement;\n\n get timeout(): number {\n return this.props.platform === ANDROID || this.props.platform === VKCOM ? 320 : 400;\n }\n\n get document(): Document {\n return this.props.document;\n }\n\n get window(): Window {\n return this.props.window;\n }\n\n getModalState(id: string) {\n return this.props.getModalState(id);\n }\n\n getModals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n componentDidMount() {\n // Отслеживаем изменение размеров viewport (Необходимо для iOS)\n if (this.props.platform === IOS) {\n this.window.addEventListener('resize', this.updateModalTranslate, false);\n }\n }\n\n componentWillUnmount() {\n this.toggleDocumentScrolling(true);\n this.window.removeEventListener('resize', this.updateModalTranslate, false);\n }\n\n componentDidUpdate(prevProps: ModalRootProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (this.props.exitingModal && this.props.exitingModal !== prevProps.exitingModal) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (this.props.enteringModal && this.props.enteringModal !== prevProps.enteringModal) {\n const { enteringModal } = this.props;\n const enteringState = this.getModalState(enteringModal);\n this.waitTransitionFinish(enteringState, () => {\n enteringState.innerElement.style.transitionDelay = null;\n this.props.onEnter(enteringModal);\n });\n enteringState.innerElement.style.transitionDelay = this.props.delayEnter ? `${this.timeout}ms` : null;\n this.animateTranslate(enteringState, enteringState.translateY);\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = this.document.activeElement as HTMLElement;\n }\n if (!this.props.activeModal && !this.props.exitingModal && this.restoreFocusTo) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = null;\n }\n\n this.toggleDocumentScrolling(!this.props.activeModal && !this.props.exitingModal);\n }\n\n /* Отключает скролл документа */\n toggleDocumentScrolling(enabled: boolean) {\n if (this.documentScrolling === enabled) {\n return;\n }\n this.documentScrolling = enabled;\n\n if (enabled) {\n // Здесь нужен последний аргумент с такими же параметрами, потому что\n // некоторые браузеры на странных вендорах типа Meizu не удаляют обработчик.\n // https://github.com/VKCOM/VKUI/issues/444\n // @ts-ignore (В интерфейсе EventListenerOptions нет поля passive)\n this.window.removeEventListener('touchmove', this.preventTouch, { passive: false });\n } else {\n this.window.addEventListener('touchmove', this.preventTouch, { passive: false });\n }\n }\n\n preventTouch = (event: any) => {\n if (!event) {\n return false;\n }\n while (event.originalEvent) {\n event = event.originalEvent;\n }\n if (event.preventDefault) {\n event.preventDefault();\n }\n return false;\n };\n\n updateModalTranslate = () => {\n const modalState = this.getModalState(this.props.activeModal);\n modalState && this.animateTranslate(modalState, modalState.translateY);\n };\n\n checkPageContentHeight() {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState?.type === ModalType.PAGE && modalState?.modalElement) {\n const prevModalState = { ...modalState };\n initPageModal(modalState);\n const currentModalState = { ...modalState };\n\n let needAnimate = false;\n\n if (prevModalState.expandable === currentModalState.expandable) {\n if (prevModalState.translateYFrom !== currentModalState.translateYFrom) {\n needAnimate = true;\n }\n } else {\n needAnimate = true;\n }\n\n if (needAnimate) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n }\n }\n\n updateModalHeight = () => {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState && modalState.type === ModalType.PAGE && modalState.dynamicContentHeight) {\n if (this.props.enteringModal) {\n this.waitTransitionFinish(modalState, () => {\n requestAnimationFrame(() => this.checkPageContentHeight());\n });\n } else {\n requestAnimationFrame(() => this.checkPageContentHeight());\n }\n }\n };\n\n closeModal(id: string) {\n // Сбрасываем состояния, которые могут помешать закрытию модального окна\n this.setState({ touchDown: false });\n\n const prevModalState = this.getModalState(id);\n\n if (!prevModalState) {\n id && warn(`[closeActiveModal] Modal ${id} does not exist - not closing`);\n return;\n }\n\n const nextModalState = this.getModalState(this.props.activeModal);\n const nextIsPage = !!nextModalState && nextModalState.type === ModalType.PAGE;\n\n const prevIsPage = !!prevModalState && prevModalState.type === ModalType.PAGE;\n this.waitTransitionFinish(prevModalState, () => this.props.onExit(id));\n const exitTranslate = prevIsPage && nextIsPage && prevModalState.translateY <= nextModalState.translateYFrom && !this.props.isBack\n ? nextModalState.translateYFrom + 10\n : 100;\n this.animateTranslate(prevModalState, exitTranslate);\n\n if (!nextModalState) {\n // NOTE: was only for clean exit\n this.setMaskOpacity(prevModalState, 0);\n }\n }\n\n onTouchMove = (e: TouchEvent) => {\n if (this.props.exitingModal) {\n return;\n }\n const modalState = this.getModalState(this.props.activeModal);\n if (!modalState) {\n return;\n }\n\n if (modalState.type === ModalType.PAGE) {\n return this.onPageTouchMove(e, modalState);\n }\n\n if (modalState.type === ModalType.CARD) {\n return this.onCardTouchMove(e, modalState);\n }\n };\n\n onPageTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { shiftY, originalEvent } = event;\n const target = originalEvent.target as HTMLElement;\n\n if (!event.isY) {\n if (this.viewportRef.current.contains(target)) {\n originalEvent.preventDefault();\n }\n return;\n }\n\n if (!modalState.innerElement.contains(target)) {\n return originalEvent.preventDefault();\n }\n\n originalEvent.stopPropagation();\n\n const { expandable, contentScrolled, collapsed, expanded } = modalState;\n\n if (!this.state.touchDown) {\n modalState.touchStartContentScrollTop = modalState.contentElement.scrollTop;\n this.setState({ touchDown: true });\n }\n\n if (contentScrolled) {\n return;\n }\n\n if (modalState.touchMovePositive === null) {\n modalState.touchMovePositive = shiftY > 0;\n }\n\n if (\n !modalState.expandable ||\n collapsed ||\n expanded && modalState.touchMovePositive && modalState.touchStartContentScrollTop === 0 ||\n modalState.headerElement.contains(target)\n ) {\n originalEvent.preventDefault();\n\n if (!expandable && shiftY < 0) {\n return;\n }\n\n !this.state.dragging && this.setState({ dragging: true });\n\n const shiftYPercent = shiftY / this.window.innerHeight * 100;\n const shiftYCurrent = rubber(shiftYPercent, 72, 0.8, this.props.platform === ANDROID || this.props.platform === VKCOM);\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = rangeTranslate(modalState.translateY + shiftYCurrent);\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onCardTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { originalEvent, shiftY } = event;\n const target = originalEvent.target as HTMLElement;\n if (modalState.innerElement.contains(target)) {\n if (!this.state.touchDown) {\n this.setState({ touchDown: true, dragging: true });\n }\n\n const shiftYPercent = shiftY / modalState.innerElement.offsetHeight * 100;\n const shiftYCurrent = rubber(shiftYPercent, 72, 1.2, this.props.platform === ANDROID || this.props.platform === VKCOM);\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = Math.max(0, modalState.translateY + shiftYCurrent);\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onTouchEnd = (e: TouchEvent) => {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState.type === ModalType.PAGE) {\n return this.onPageTouchEnd(e, modalState);\n }\n\n if (modalState.type === ModalType.CARD) {\n return this.onCardTouchEnd(e, modalState);\n }\n };\n\n onPageTouchEnd(event: TouchEvent, modalState: ModalsStateEntry) {\n const { startY, shiftY } = event;\n\n modalState.contentScrolled = false;\n modalState.touchMovePositive = null;\n\n let setStateCallback;\n\n if (this.state.dragging) {\n const shiftYEndPercent = (startY + shiftY) / this.window.innerHeight * 100;\n\n let translateY = modalState.translateYCurrent;\n const expectTranslateY = translateY / event.duration * 240 * 0.6 * (modalState.touchShiftYPercent < 0 ? -1 : 1);\n translateY = rangeTranslate(translateY + expectTranslateY);\n\n if (modalState.settlingHeight !== 100) {\n if (numberInRange(translateY, modalState.expandedRange)) {\n translateY = modalState.expandedRange[0];\n } else if (numberInRange(translateY, modalState.collapsedRange)) {\n translateY = modalState.translateYFrom;\n } else if (numberInRange(translateY, modalState.hiddenRange)) {\n translateY = 100;\n } else {\n translateY = modalState.translateYFrom;\n }\n } else {\n if (numberInRange(translateY, [0, 25])) {\n translateY = 0;\n } else {\n translateY = 100;\n }\n }\n\n if (translateY !== 100 && shiftYEndPercent >= 75) {\n translateY = 100;\n }\n\n modalState.translateY = translateY;\n modalState.translateYCurrent = translateY;\n modalState.collapsed = translateY > 0 && translateY < shiftYEndPercent;\n modalState.expanded = translateY === 0;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.closeActiveModal();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState({\n touchDown: false,\n dragging: false,\n }, setStateCallback);\n }\n\n onCardTouchEnd({ duration }: TouchEvent, modalState: ModalsStateEntry) {\n let setStateCallback;\n\n if (this.state.dragging) {\n let translateY = modalState.translateYCurrent;\n\n const expectTranslateY = translateY / duration * 240 * 0.6 * (modalState.touchShiftYPercent < 0 ? -1 : 1);\n translateY = Math.max(0, translateY + expectTranslateY);\n\n if (translateY >= 30) {\n translateY = 100;\n } else {\n translateY = 0;\n }\n\n modalState.translateY = translateY;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.closeActiveModal();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState({\n touchDown: false,\n dragging: false,\n }, setStateCallback);\n }\n\n onScroll = (e: React.SyntheticEvent) => {\n const activeModal = this.props.activeModal;\n\n const target = e.target as HTMLElement;\n\n if (!activeModal) {\n return;\n }\n const modalState = this.getModalState(activeModal);\n if (modalState.type === ModalType.PAGE && modalState.contentElement.contains(target)) {\n modalState.contentScrolled = true;\n\n clearTimeout(modalState.contentScrollStopTimeout);\n\n modalState.contentScrollStopTimeout = setTimeout(() => {\n if (modalState.contentScrolled) {\n modalState.contentScrolled = false;\n }\n }, 250);\n }\n };\n\n waitTransitionFinish(modalState: ModalsStateEntry, eventHandler: () => void) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState.innerElement.removeEventListener(transitionEvent.name, onceHandler);\n eventHandler();\n };\n\n modalState.innerElement.addEventListener(transitionEvent.name, onceHandler);\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /**\n * Анимирует сдвиг модалки\n *\n * @param {ModalsStateEntry} modalState\n * @param {number} percent Процент сдвига: 0 – полностью открыта, 100 – полностью закрыта\n */\n animateTranslate(modalState: ModalsStateEntry, percent: number) {\n const frameId = `animateTranslateFrame${modalState.id}`;\n\n cancelAnimationFrame(this.frameIds[frameId]);\n\n this.frameIds[frameId] = requestAnimationFrame(() => {\n setTransformStyle(modalState.innerElement, `translate3d(0, ${percent}%, 0)`);\n });\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(modalState: ModalsStateEntry, forceOpacity: number = null) {\n if (forceOpacity === null && this.props.history[0] !== modalState.id) {\n return;\n }\n\n cancelAnimationFrame(this.maskAnimationFrame);\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY, translateYCurrent } = modalState;\n\n const opacity = forceOpacity === null ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0 : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(0, Math.min(100, opacity)).toString();\n }\n });\n }\n\n render() {\n const { activeModal, exitingModal, enteringModal } = this.props;\n const { touchDown, dragging } = this.state;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <TouchRootContext.Provider value={true}>\n <ModalRootContext.Provider value={this.modalRootContext}>\n <Touch\n vkuiClass={classNames(getClassName('ModalRoot', this.props.platform), {\n 'ModalRoot--vkapps': this.props.configProvider.webviewType === WebviewType.VKAPPS,\n 'ModalRoot--touched': touchDown,\n 'ModalRoot--switching': !!(enteringModal || exitingModal),\n })}\n onMove={this.onTouchMove}\n onEnd={this.onTouchEnd}\n onScroll={this.onScroll}\n >\n <div\n vkuiClass=\"ModalRoot__mask\"\n onClick={this.props.closeActiveModal}\n ref={this.maskElementRef}\n />\n <div vkuiClass=\"ModalRoot__viewport\" ref={this.viewportRef}>\n {this.getModals().map((Modal) => {\n const modalId = getNavId(Modal.props, warn);\n if (modalId !== activeModal && modalId !== exitingModal) {\n return null;\n }\n const modalState = { ...this.getModalState(modalId) };\n\n const isPage = modalState.type === ModalType.PAGE;\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n key={key}\n getRootRef={(e) => this.getModalState(modalId).modalElement = e}\n onClose={this.props.closeActiveModal}\n timeout={this.timeout}\n vkuiClass={classNames('ModalRoot__modal', {\n 'ModalRoot__modal--active': modalId === activeModal,\n 'ModalRoot__modal--prev': modalId === exitingModal,\n 'ModalRoot__modal--next': exitingModal && modalId === activeModal || modalId === enteringModal,\n\n 'ModalRoot__modal--dragging': dragging,\n\n 'ModalRoot__modal--expandable': isPage && modalState.expandable,\n 'ModalRoot__modal--expanded': isPage && modalState.expanded,\n 'ModalRoot__modal--collapsed': isPage && modalState.collapsed,\n })}\n restoreFocus={false}\n >{Modal}</FocusTrap>\n );\n })}\n </div>\n </Touch>\n </ModalRootContext.Provider>\n </TouchRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootTouch = withContext(withPlatform(withDOM<ModalRootProps>(\n withModalManager(initModal)(ModalRootTouchComponent),\n)), ConfigProviderContext, 'configProvider');\n\n/**\n * Инициализирует модалку перед анимацией открытия\n */\nfunction initModal(modalState: ModalsStateEntry) {\n switch (modalState.type) {\n case ModalType.PAGE:\n modalState.settlingHeight = modalState.settlingHeight || MODAL_PAGE_DEFAULT_PERCENT_HEIGHT;\n return initPageModal(modalState);\n case ModalType.CARD:\n return initCardModal(modalState);\n default:\n IS_DEV && warn('[initActiveModal] modalState.type is unknown');\n }\n}\n\nfunction initPageModal(modalState: ModalsStateEntry) {\n const { contentElement } = modalState;\n const contentHeight = (contentElement.firstElementChild as HTMLElement).offsetHeight;\n\n let prevTranslateY = modalState.translateY;\n\n modalState.expandable = contentHeight > contentElement.clientHeight || modalState.settlingHeight === 100;\n\n let collapsed = false;\n let expanded = false;\n let translateYFrom;\n let translateY;\n let expandedRange: TranslateRange;\n let collapsedRange: TranslateRange;\n let hiddenRange: TranslateRange;\n\n if (modalState.expandable) {\n translateYFrom = 100 - modalState.settlingHeight;\n\n const shiftHalf = translateYFrom / 2;\n const visiblePart = 100 - translateYFrom;\n\n expandedRange = [0, shiftHalf];\n collapsedRange = [shiftHalf, translateYFrom + visiblePart / 4];\n hiddenRange = [translateYFrom + visiblePart / 4, 100];\n\n collapsed = translateYFrom > 0;\n expanded = translateYFrom <= 0;\n translateY = translateYFrom;\n } else {\n const headerHeight = modalState.headerElement.offsetHeight;\n const height = contentHeight + headerHeight;\n\n translateYFrom = 100 - height / modalState.innerElement.parentElement.offsetHeight * 100;\n translateY = translateYFrom;\n\n expandedRange = [translateY, translateY + 25];\n collapsedRange = [translateY + 25, translateY + 25];\n hiddenRange = [translateY + 25, translateY + 100];\n }\n\n // Если модалка может открываться на весь экран, и новый сдвиг больше предыдущего, то откроем её на весь экран\n if (modalState.expandable && translateY > prevTranslateY || modalState.settlingHeight === 100) {\n translateY = 0;\n }\n\n modalState.expandedRange = expandedRange;\n modalState.collapsedRange = collapsedRange;\n modalState.hiddenRange = hiddenRange;\n modalState.translateY = translateY;\n modalState.translateYFrom = translateYFrom;\n modalState.collapsed = collapsed;\n modalState.expanded = expanded;\n}\n\nfunction initCardModal(modalState: ModalsStateEntry) {\n modalState.translateY = 0;\n}\n"],"file":"ModalRoot.js"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRoot.tsx"],"names":["React","Touch","TouchRootContext","getClassName","classNames","setTransformStyle","rubber","ANDROID","IOS","VKCOM","transitionEvent","withPlatform","withContext","ModalRootContext","ConfigProviderContext","WebviewType","ModalType","MODAL_PAGE_DEFAULT_PERCENT_HEIGHT","withDOM","getNavId","warnOnce","FocusTrap","withModalManager","warn","IS_DEV","process","env","NODE_ENV","numberInRange","number","range","rangeTranslate","Math","max","min","ModalRootTouchComponent","props","createRef","event","originalEvent","preventDefault","modalState","getModalState","activeModal","animateTranslate","translateY","type","PAGE","dynamicContentHeight","enteringModal","waitTransitionFinish","requestAnimationFrame","checkPageContentHeight","e","exitingModal","onPageTouchMove","CARD","onCardTouchMove","onPageTouchEnd","onCardTouchEnd","target","contentElement","contains","contentScrolled","clearTimeout","contentScrollStopTimeout","setTimeout","state","touchDown","dragging","maskElementRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","onClose","closeActiveModal","isInsideModal","frameIds","platform","document","window","Children","toArray","children","addEventListener","updateModalTranslate","toggleDocumentScrolling","removeEventListener","prevProps","closeModal","enteringState","innerElement","style","transitionDelay","onEnter","delayEnter","timeout","restoreFocusTo","activeElement","focus","enabled","documentScrolling","preventTouch","passive","modalElement","prevModalState","initPageModal","currentModalState","needAnimate","expandable","translateYFrom","setState","nextModalState","nextIsPage","prevIsPage","onExit","exitTranslate","isBack","setMaskOpacity","shiftY","isY","viewportRef","current","stopPropagation","collapsed","expanded","touchStartContentScrollTop","scrollTop","touchMovePositive","headerElement","shiftYPercent","innerHeight","shiftYCurrent","touchShiftYPercent","translateYCurrent","offsetHeight","startY","setStateCallback","shiftYEndPercent","expectTranslateY","duration","settlingHeight","expandedRange","collapsedRange","hiddenRange","hidden","eventHandler","supported","onceHandler","name","percent","frameId","cancelAnimationFrame","forceOpacity","history","maskAnimationFrame","opacity","toString","configProvider","webviewType","VKAPPS","onTouchMove","onTouchEnd","onScroll","getModals","map","Modal","modalId","isPage","key","Component","ModalRootTouch","initModal","initCardModal","contentHeight","firstElementChild","prevTranslateY","clientHeight","shiftHalf","visiblePart","headerHeight","height","parentElement"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { Touch, TouchEvent } from \"../Touch/Touch\";\nimport TouchRootContext from \"../Touch/TouchContext\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport { setTransformStyle } from \"../../lib/styles\";\nimport { rubber } from \"../../lib/touch\";\nimport { ANDROID, IOS, VKCOM } from \"../../lib/platform\";\nimport { transitionEvent } from \"../../lib/supportEvents\";\nimport { HasPlatform } from \"../../types\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport { withContext } from \"../../hoc/withContext\";\nimport ModalRootContext, {\n ModalRootContextInterface,\n} from \"./ModalRootContext\";\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n WebviewType,\n} from \"../ConfigProvider/ConfigProviderContext\";\nimport { ModalsStateEntry, ModalType, TranslateRange } from \"./types\";\nimport { MODAL_PAGE_DEFAULT_PERCENT_HEIGHT } from \"./constants\";\nimport { DOMProps, withDOM } from \"../../lib/dom\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { FocusTrap } from \"../FocusTrap/FocusTrap\";\nimport { ModalTransitionProps, withModalManager } from \"./useModalManager\";\nimport \"./ModalRoot.css\";\n\nconst warn = warnOnce(\"ModalRoot\");\nconst IS_DEV = process.env.NODE_ENV === \"development\";\n\nfunction numberInRange(number: number, range: TranslateRange) {\n return number >= range[0] && number <= range[1];\n}\n\nfunction rangeTranslate(number: number) {\n return Math.max(0, Math.min(98, number));\n}\n\nexport interface ModalRootProps extends HasPlatform {\n activeModal?: string | null;\n\n /**\n * Будет вызвано при закрытии активной модалки с её id\n */\n onClose?(modalId: string): void;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n}\n\ninterface ModalRootState {\n touchDown?: boolean;\n dragging?: boolean;\n}\n\nclass ModalRootTouchComponent extends React.Component<\n ModalRootProps & DOMProps & ModalTransitionProps,\n ModalRootState\n> {\n constructor(props: ModalRootProps & ModalTransitionProps) {\n super(props);\n this.state = {\n touchDown: false,\n dragging: false,\n };\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: this.updateModalHeight,\n registerModal: ({ id, ...data }) =>\n Object.assign(this.getModalState(id), data),\n onClose: () => this.props.closeActiveModal(),\n isInsideModal: true,\n };\n\n this.frameIds = {};\n }\n\n private documentScrolling: boolean;\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private readonly viewportRef = React.createRef<HTMLDivElement>();\n private maskAnimationFrame: number;\n private readonly modalRootContext: ModalRootContextInterface;\n private readonly frameIds: {\n [index: string]: number;\n };\n private restoreFocusTo: HTMLElement;\n\n get timeout(): number {\n return this.props.platform === ANDROID || this.props.platform === VKCOM\n ? 320\n : 400;\n }\n\n get document(): Document {\n return this.props.document;\n }\n\n get window(): Window {\n return this.props.window;\n }\n\n getModalState(id: string) {\n return this.props.getModalState(id);\n }\n\n getModals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n componentDidMount() {\n // Отслеживаем изменение размеров viewport (Необходимо для iOS)\n if (this.props.platform === IOS) {\n this.window.addEventListener(\"resize\", this.updateModalTranslate, false);\n }\n }\n\n componentWillUnmount() {\n this.toggleDocumentScrolling(true);\n this.window.removeEventListener(\"resize\", this.updateModalTranslate, false);\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.waitTransitionFinish(enteringState, () => {\n enteringState.innerElement.style.transitionDelay = null;\n this.props.onEnter(enteringModal);\n });\n enteringState.innerElement.style.transitionDelay = this.props.delayEnter\n ? `${this.timeout}ms`\n : null;\n this.animateTranslate(enteringState, enteringState.translateY);\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = this.document.activeElement as HTMLElement;\n }\n if (\n !this.props.activeModal &&\n !this.props.exitingModal &&\n this.restoreFocusTo\n ) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = null;\n }\n\n this.toggleDocumentScrolling(\n !this.props.activeModal && !this.props.exitingModal\n );\n }\n\n /* Отключает скролл документа */\n toggleDocumentScrolling(enabled: boolean) {\n if (this.documentScrolling === enabled) {\n return;\n }\n this.documentScrolling = enabled;\n\n if (enabled) {\n // Здесь нужен последний аргумент с такими же параметрами, потому что\n // некоторые браузеры на странных вендорах типа Meizu не удаляют обработчик.\n // https://github.com/VKCOM/VKUI/issues/444\n this.window.removeEventListener(\"touchmove\", this.preventTouch, {\n // @ts-ignore (В интерфейсе EventListenerOptions нет поля passive)\n passive: false,\n });\n } else {\n this.window.addEventListener(\"touchmove\", this.preventTouch, {\n passive: false,\n });\n }\n }\n\n preventTouch = (event: any) => {\n if (!event) {\n return false;\n }\n while (event.originalEvent) {\n event = event.originalEvent;\n }\n if (event.preventDefault) {\n event.preventDefault();\n }\n return false;\n };\n\n updateModalTranslate = () => {\n const modalState = this.getModalState(this.props.activeModal);\n modalState && this.animateTranslate(modalState, modalState.translateY);\n };\n\n checkPageContentHeight() {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState?.type === ModalType.PAGE && modalState?.modalElement) {\n const prevModalState = { ...modalState };\n initPageModal(modalState);\n const currentModalState = { ...modalState };\n\n let needAnimate = false;\n\n if (prevModalState.expandable === currentModalState.expandable) {\n if (\n prevModalState.translateYFrom !== currentModalState.translateYFrom\n ) {\n needAnimate = true;\n }\n } else {\n needAnimate = true;\n }\n\n if (needAnimate) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n }\n }\n\n updateModalHeight = () => {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (\n modalState &&\n modalState.type === ModalType.PAGE &&\n modalState.dynamicContentHeight\n ) {\n if (this.props.enteringModal) {\n this.waitTransitionFinish(modalState, () => {\n requestAnimationFrame(() => this.checkPageContentHeight());\n });\n } else {\n requestAnimationFrame(() => this.checkPageContentHeight());\n }\n }\n };\n\n closeModal(id: string) {\n // Сбрасываем состояния, которые могут помешать закрытию модального окна\n this.setState({ touchDown: false });\n\n const prevModalState = this.getModalState(id);\n\n if (!prevModalState) {\n id && warn(`[closeActiveModal] Modal ${id} does not exist - not closing`);\n return;\n }\n\n const nextModalState = this.getModalState(this.props.activeModal);\n const nextIsPage =\n !!nextModalState && nextModalState.type === ModalType.PAGE;\n\n const prevIsPage =\n !!prevModalState && prevModalState.type === ModalType.PAGE;\n this.waitTransitionFinish(prevModalState, () => this.props.onExit(id));\n const exitTranslate =\n prevIsPage &&\n nextIsPage &&\n prevModalState.translateY <= nextModalState.translateYFrom &&\n !this.props.isBack\n ? nextModalState.translateYFrom + 10\n : 100;\n this.animateTranslate(prevModalState, exitTranslate);\n\n if (!nextModalState) {\n // NOTE: was only for clean exit\n this.setMaskOpacity(prevModalState, 0);\n }\n }\n\n onTouchMove = (e: TouchEvent) => {\n if (this.props.exitingModal) {\n return;\n }\n const modalState = this.getModalState(this.props.activeModal);\n if (!modalState) {\n return;\n }\n\n if (modalState.type === ModalType.PAGE) {\n return this.onPageTouchMove(e, modalState);\n }\n\n if (modalState.type === ModalType.CARD) {\n return this.onCardTouchMove(e, modalState);\n }\n };\n\n onPageTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { shiftY, originalEvent } = event;\n const target = originalEvent.target as HTMLElement;\n\n if (!event.isY) {\n if (this.viewportRef.current.contains(target)) {\n originalEvent.preventDefault();\n }\n return;\n }\n\n if (!modalState.innerElement.contains(target)) {\n return originalEvent.preventDefault();\n }\n\n originalEvent.stopPropagation();\n\n const { expandable, contentScrolled, collapsed, expanded } = modalState;\n\n if (!this.state.touchDown) {\n modalState.touchStartContentScrollTop =\n modalState.contentElement.scrollTop;\n this.setState({ touchDown: true });\n }\n\n if (contentScrolled) {\n return;\n }\n\n if (modalState.touchMovePositive === null) {\n modalState.touchMovePositive = shiftY > 0;\n }\n\n if (\n !modalState.expandable ||\n collapsed ||\n (expanded &&\n modalState.touchMovePositive &&\n modalState.touchStartContentScrollTop === 0) ||\n modalState.headerElement.contains(target)\n ) {\n originalEvent.preventDefault();\n\n if (!expandable && shiftY < 0) {\n return;\n }\n\n !this.state.dragging && this.setState({ dragging: true });\n\n const shiftYPercent = (shiftY / this.window.innerHeight) * 100;\n const shiftYCurrent = rubber(\n shiftYPercent,\n 72,\n 0.8,\n this.props.platform === ANDROID || this.props.platform === VKCOM\n );\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = rangeTranslate(\n modalState.translateY + shiftYCurrent\n );\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onCardTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { originalEvent, shiftY } = event;\n const target = originalEvent.target as HTMLElement;\n if (modalState.innerElement.contains(target)) {\n if (!this.state.touchDown) {\n this.setState({ touchDown: true, dragging: true });\n }\n\n const shiftYPercent =\n (shiftY / modalState.innerElement.offsetHeight) * 100;\n const shiftYCurrent = rubber(\n shiftYPercent,\n 72,\n 1.2,\n this.props.platform === ANDROID || this.props.platform === VKCOM\n );\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = Math.max(\n 0,\n modalState.translateY + shiftYCurrent\n );\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onTouchEnd = (e: TouchEvent) => {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState.type === ModalType.PAGE) {\n return this.onPageTouchEnd(e, modalState);\n }\n\n if (modalState.type === ModalType.CARD) {\n return this.onCardTouchEnd(e, modalState);\n }\n };\n\n onPageTouchEnd(event: TouchEvent, modalState: ModalsStateEntry) {\n const { startY, shiftY } = event;\n\n modalState.contentScrolled = false;\n modalState.touchMovePositive = null;\n\n let setStateCallback;\n\n if (this.state.dragging) {\n const shiftYEndPercent =\n ((startY + shiftY) / this.window.innerHeight) * 100;\n\n let translateY = modalState.translateYCurrent;\n const expectTranslateY =\n (translateY / event.duration) *\n 240 *\n 0.6 *\n (modalState.touchShiftYPercent < 0 ? -1 : 1);\n translateY = rangeTranslate(translateY + expectTranslateY);\n\n if (modalState.settlingHeight !== 100) {\n if (numberInRange(translateY, modalState.expandedRange)) {\n translateY = modalState.expandedRange[0];\n } else if (numberInRange(translateY, modalState.collapsedRange)) {\n translateY = modalState.translateYFrom;\n } else if (numberInRange(translateY, modalState.hiddenRange)) {\n translateY = 100;\n } else {\n translateY = modalState.translateYFrom;\n }\n } else {\n if (numberInRange(translateY, [0, 25])) {\n translateY = 0;\n } else {\n translateY = 100;\n }\n }\n\n if (translateY !== 100 && shiftYEndPercent >= 75) {\n translateY = 100;\n }\n\n modalState.translateY = translateY;\n modalState.translateYCurrent = translateY;\n modalState.collapsed = translateY > 0 && translateY < shiftYEndPercent;\n modalState.expanded = translateY === 0;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.closeActiveModal();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback\n );\n }\n\n onCardTouchEnd({ duration }: TouchEvent, modalState: ModalsStateEntry) {\n let setStateCallback;\n\n if (this.state.dragging) {\n let translateY = modalState.translateYCurrent;\n\n const expectTranslateY =\n (translateY / duration) *\n 240 *\n 0.6 *\n (modalState.touchShiftYPercent < 0 ? -1 : 1);\n translateY = Math.max(0, translateY + expectTranslateY);\n\n if (translateY >= 30) {\n translateY = 100;\n } else {\n translateY = 0;\n }\n\n modalState.translateY = translateY;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.closeActiveModal();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback\n );\n }\n\n onScroll = (e: React.SyntheticEvent) => {\n const activeModal = this.props.activeModal;\n\n const target = e.target as HTMLElement;\n\n if (!activeModal) {\n return;\n }\n const modalState = this.getModalState(activeModal);\n if (\n modalState.type === ModalType.PAGE &&\n modalState.contentElement.contains(target)\n ) {\n modalState.contentScrolled = true;\n\n clearTimeout(modalState.contentScrollStopTimeout);\n\n modalState.contentScrollStopTimeout = setTimeout(() => {\n if (modalState.contentScrolled) {\n modalState.contentScrolled = false;\n }\n }, 250);\n }\n };\n\n waitTransitionFinish(\n modalState: ModalsStateEntry | undefined,\n eventHandler: () => void\n ) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState?.innerElement.removeEventListener(\n transitionEvent.name,\n onceHandler\n );\n eventHandler();\n };\n\n modalState?.innerElement.addEventListener(\n transitionEvent.name,\n onceHandler\n );\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /**\n * Анимирует сдвиг модалки\n *\n * @param {ModalsStateEntry} modalState\n * @param {number} percent Процент сдвига: 0 – полностью открыта, 100 – полностью закрыта\n */\n animateTranslate(modalState: ModalsStateEntry, percent: number) {\n const frameId = `animateTranslateFrame${modalState.id}`;\n\n cancelAnimationFrame(this.frameIds[frameId]);\n\n this.frameIds[frameId] = requestAnimationFrame(() => {\n setTransformStyle(\n modalState.innerElement,\n `translate3d(0, ${percent}%, 0)`\n );\n });\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(modalState: ModalsStateEntry, forceOpacity: number = null) {\n if (forceOpacity === null && this.props.history[0] !== modalState.id) {\n return;\n }\n\n cancelAnimationFrame(this.maskAnimationFrame);\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY, translateYCurrent } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(\n 0,\n Math.min(100, opacity)\n ).toString();\n }\n });\n }\n\n render() {\n const { activeModal, exitingModal, enteringModal } = this.props;\n const { touchDown, dragging } = this.state;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <TouchRootContext.Provider value={true}>\n <ModalRootContext.Provider value={this.modalRootContext}>\n <Touch\n vkuiClass={classNames(\n getClassName(\"ModalRoot\", this.props.platform),\n {\n \"ModalRoot--vkapps\":\n this.props.configProvider.webviewType === WebviewType.VKAPPS,\n \"ModalRoot--touched\": touchDown,\n \"ModalRoot--switching\": !!(enteringModal || exitingModal),\n }\n )}\n onMove={this.onTouchMove}\n onEnd={this.onTouchEnd}\n onScroll={this.onScroll}\n >\n <div\n vkuiClass=\"ModalRoot__mask\"\n onClick={this.props.closeActiveModal}\n ref={this.maskElementRef}\n />\n <div vkuiClass=\"ModalRoot__viewport\" ref={this.viewportRef}>\n {this.getModals().map((Modal) => {\n const modalId = getNavId(Modal.props, warn);\n if (modalId !== activeModal && modalId !== exitingModal) {\n return null;\n }\n const modalState = { ...this.getModalState(modalId) };\n\n const isPage = modalState.type === ModalType.PAGE;\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n key={key}\n getRootRef={(e) =>\n (this.getModalState(modalId).modalElement = e)\n }\n onClose={this.props.closeActiveModal}\n timeout={this.timeout}\n vkuiClass={classNames(\"ModalRoot__modal\", {\n \"ModalRoot__modal--active\": modalId === activeModal,\n \"ModalRoot__modal--prev\": modalId === exitingModal,\n \"ModalRoot__modal--next\":\n (exitingModal && modalId === activeModal) ||\n modalId === enteringModal,\n\n \"ModalRoot__modal--dragging\": dragging,\n\n \"ModalRoot__modal--expandable\":\n isPage && modalState.expandable,\n \"ModalRoot__modal--expanded\":\n isPage && modalState.expanded,\n \"ModalRoot__modal--collapsed\":\n isPage && modalState.collapsed,\n })}\n restoreFocus={false}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </Touch>\n </ModalRootContext.Provider>\n </TouchRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootTouch = withContext(\n withPlatform(\n withDOM<ModalRootProps>(\n withModalManager(initModal)(ModalRootTouchComponent)\n )\n ),\n ConfigProviderContext,\n \"configProvider\"\n);\n\n/**\n * Инициализирует модалку перед анимацией открытия\n */\nfunction initModal(modalState: ModalsStateEntry) {\n switch (modalState.type) {\n case ModalType.PAGE:\n modalState.settlingHeight =\n modalState.settlingHeight || MODAL_PAGE_DEFAULT_PERCENT_HEIGHT;\n return initPageModal(modalState);\n case ModalType.CARD:\n return initCardModal(modalState);\n default:\n IS_DEV && warn(\"[initActiveModal] modalState.type is unknown\");\n }\n}\n\nfunction initPageModal(modalState: ModalsStateEntry) {\n const { contentElement } = modalState;\n const contentHeight = (contentElement.firstElementChild as HTMLElement)\n .offsetHeight;\n\n let prevTranslateY = modalState.translateY;\n\n modalState.expandable =\n contentHeight > contentElement.clientHeight ||\n modalState.settlingHeight === 100;\n\n let collapsed = false;\n let expanded = false;\n let translateYFrom;\n let translateY;\n let expandedRange: TranslateRange;\n let collapsedRange: TranslateRange;\n let hiddenRange: TranslateRange;\n\n if (modalState.expandable) {\n translateYFrom = 100 - modalState.settlingHeight;\n\n const shiftHalf = translateYFrom / 2;\n const visiblePart = 100 - translateYFrom;\n\n expandedRange = [0, shiftHalf];\n collapsedRange = [shiftHalf, translateYFrom + visiblePart / 4];\n hiddenRange = [translateYFrom + visiblePart / 4, 100];\n\n collapsed = translateYFrom > 0;\n expanded = translateYFrom <= 0;\n translateY = translateYFrom;\n } else {\n const headerHeight = modalState.headerElement.offsetHeight;\n const height = contentHeight + headerHeight;\n\n translateYFrom =\n 100 - (height / modalState.innerElement.parentElement.offsetHeight) * 100;\n translateY = translateYFrom;\n\n expandedRange = [translateY, translateY + 25];\n collapsedRange = [translateY + 25, translateY + 25];\n hiddenRange = [translateY + 25, translateY + 100];\n }\n\n // Если модалка может открываться на весь экран, и новый сдвиг больше предыдущего, то откроем её на весь экран\n if (\n (modalState.expandable && translateY > prevTranslateY) ||\n modalState.settlingHeight === 100\n ) {\n translateY = 0;\n }\n\n modalState.expandedRange = expandedRange;\n modalState.collapsedRange = collapsedRange;\n modalState.hiddenRange = hiddenRange;\n modalState.translateY = translateY;\n modalState.translateYFrom = translateYFrom;\n modalState.collapsed = collapsed;\n modalState.expanded = expanded;\n}\n\nfunction initCardModal(modalState: ModalsStateEntry) {\n modalState.translateY = 0;\n}\n"],"file":"ModalRoot.js"}
@@ -12,7 +12,7 @@ var ModalRootComponent = function ModalRootComponent(props) {
12
12
  return createScopedElement(RootComponent, props);
13
13
  };
14
14
 
15
- ModalRootComponent.displayName = 'ModalRoot';
15
+ ModalRootComponent.displayName = "ModalRoot";
16
16
  export var ModalRoot = withAdaptivity(ModalRootComponent, {
17
17
  viewWidth: true,
18
18
  viewHeight: true,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootAdaptive.tsx"],"names":["withAdaptivity","ViewHeight","ViewWidth","ModalRootTouch","ModalRootDesktop","ModalRootComponent","props","viewWidth","viewHeight","hasMouse","isDesktop","SMALL_TABLET","MEDIUM","RootComponent","displayName","ModalRoot"],"mappings":";AACA,SAASA,cAAT,EAA0CC,UAA1C,EAAsDC,SAAtD;AACA,SAASC,cAAT;AACA,SAASC,gBAAT;;AAWA,IAAMC,kBAA4C,GAAG,SAA/CA,kBAA+C,CAACC,KAAD,EAA2B;AAC9E,MAAQC,SAAR,GAA4CD,KAA5C,CAAQC,SAAR;AAAA,MAAmBC,UAAnB,GAA4CF,KAA5C,CAAmBE,UAAnB;AAAA,MAA+BC,QAA/B,GAA4CH,KAA5C,CAA+BG,QAA/B;AACA,MAAMC,SAAS,GAAGH,SAAS,IAAIL,SAAS,CAACS,YAAvB,KAAwCF,QAAQ,IAAID,UAAU,IAAIP,UAAU,CAACW,MAA7E,CAAlB;AAEA,MAAMC,aAAa,GAAGH,SAAS,GAAGN,gBAAH,GAAsBD,cAArD;AAEA,SACE,oBAAC,aAAD,EAAmBG,KAAnB,CADF;AAGD,CATD;;AAWAD,kBAAkB,CAACS,WAAnB,GAAiC,WAAjC;AAEA,OAAO,IAAMC,SAAS,GAAGf,cAAc,CAACK,kBAAD,EAAqB;AAC1DE,EAAAA,SAAS,EAAE,IAD+C;AAE1DC,EAAAA,UAAU,EAAE,IAF8C;AAG1DC,EAAAA,QAAQ,EAAE;AAHgD,CAArB,CAAhC","sourcesContent":["import * as React from 'react';\nimport { withAdaptivity, AdaptivityProps, ViewHeight, ViewWidth } from '../../hoc/withAdaptivity';\nimport { ModalRootTouch } from './ModalRoot';\nimport { ModalRootDesktop } from './ModalRootDesktop';\n\nexport interface ModalRootProps extends AdaptivityProps {\n activeModal?: string | null;\n\n /**\n * Будет вызвано при закрытии активной модалки с её id\n */\n onClose?: (modalId: string) => void;\n}\n\nconst ModalRootComponent: React.FC<ModalRootProps> = (props: ModalRootProps) => {\n const { viewWidth, viewHeight, hasMouse } = props;\n const isDesktop = viewWidth >= ViewWidth.SMALL_TABLET && (hasMouse || viewHeight >= ViewHeight.MEDIUM);\n\n const RootComponent = isDesktop ? ModalRootDesktop : ModalRootTouch;\n\n return (\n <RootComponent {...props} />\n );\n};\n\nModalRootComponent.displayName = 'ModalRoot';\n\nexport const ModalRoot = withAdaptivity(ModalRootComponent, {\n viewWidth: true,\n viewHeight: true,\n hasMouse: true,\n});\n"],"file":"ModalRootAdaptive.js"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootAdaptive.tsx"],"names":["withAdaptivity","ViewHeight","ViewWidth","ModalRootTouch","ModalRootDesktop","ModalRootComponent","props","viewWidth","viewHeight","hasMouse","isDesktop","SMALL_TABLET","MEDIUM","RootComponent","displayName","ModalRoot"],"mappings":";AACA,SACEA,cADF,EAGEC,UAHF,EAIEC,SAJF;AAMA,SAASC,cAAT;AACA,SAASC,gBAAT;;AAWA,IAAMC,kBAA4C,GAAG,SAA/CA,kBAA+C,CACnDC,KADmD,EAEhD;AACH,MAAQC,SAAR,GAA4CD,KAA5C,CAAQC,SAAR;AAAA,MAAmBC,UAAnB,GAA4CF,KAA5C,CAAmBE,UAAnB;AAAA,MAA+BC,QAA/B,GAA4CH,KAA5C,CAA+BG,QAA/B;AACA,MAAMC,SAAS,GACbH,SAAS,IAAIL,SAAS,CAACS,YAAvB,KACCF,QAAQ,IAAID,UAAU,IAAIP,UAAU,CAACW,MADtC,CADF;AAIA,MAAMC,aAAa,GAAGH,SAAS,GAAGN,gBAAH,GAAsBD,cAArD;AAEA,SAAO,oBAAC,aAAD,EAAmBG,KAAnB,CAAP;AACD,CAXD;;AAaAD,kBAAkB,CAACS,WAAnB,GAAiC,WAAjC;AAEA,OAAO,IAAMC,SAAS,GAAGf,cAAc,CAACK,kBAAD,EAAqB;AAC1DE,EAAAA,SAAS,EAAE,IAD+C;AAE1DC,EAAAA,UAAU,EAAE,IAF8C;AAG1DC,EAAAA,QAAQ,EAAE;AAHgD,CAArB,CAAhC","sourcesContent":["import * as React from \"react\";\nimport {\n withAdaptivity,\n AdaptivityProps,\n ViewHeight,\n ViewWidth,\n} from \"../../hoc/withAdaptivity\";\nimport { ModalRootTouch } from \"./ModalRoot\";\nimport { ModalRootDesktop } from \"./ModalRootDesktop\";\n\nexport interface ModalRootProps extends AdaptivityProps {\n activeModal?: string | null;\n\n /**\n * Будет вызвано при закрытии активной модалки с её id\n */\n onClose?: (modalId: string) => void;\n}\n\nconst ModalRootComponent: React.FC<ModalRootProps> = (\n props: ModalRootProps\n) => {\n const { viewWidth, viewHeight, hasMouse } = props;\n const isDesktop =\n viewWidth >= ViewWidth.SMALL_TABLET &&\n (hasMouse || viewHeight >= ViewHeight.MEDIUM);\n\n const RootComponent = isDesktop ? ModalRootDesktop : ModalRootTouch;\n\n return <RootComponent {...props} />;\n};\n\nModalRootComponent.displayName = \"ModalRoot\";\n\nexport const ModalRoot = withAdaptivity(ModalRootComponent, {\n viewWidth: true,\n viewHeight: true,\n hasMouse: true,\n});\n"],"file":"ModalRootAdaptive.js"}
@@ -1,6 +1,6 @@
1
1
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
2
  import _objectSpread from "@babel/runtime/helpers/objectSpread2";
3
- import * as React from 'react';
3
+ import * as React from "react";
4
4
  import { useIsomorphicLayoutEffect } from "../../lib/useIsomorphicLayoutEffect";
5
5
  export var ModalRootContext = /*#__PURE__*/React.createContext({
6
6
  updateModalHeight: function updateModalHeight() {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootContext.tsx"],"names":["React","useIsomorphicLayoutEffect","ModalRootContext","createContext","updateModalHeight","undefined","registerModal","isInsideModal","useModalRegistry","id","type","modalContext","useContext","elements","useRef","current","reset","Object","keys","reduce","acc","k","refs","modalElement","e","innerElement","headerElement","contentElement"],"mappings":";;AAAA,OAAO,KAAKA,KAAZ,MAAuB,OAAvB;AACA,SAASC,yBAAT;AAaA,OAAO,IAAMC,gBAAgB,gBAAGF,KAAK,CAACG,aAAN,CAA+C;AAC7EC,EAAAA,iBAAiB,EAAE;AAAA,WAAMC,SAAN;AAAA,GAD0D;AAE7EC,EAAAA,aAAa,EAAE;AAAA,WAAMD,SAAN;AAAA,GAF8D;AAG7EE,EAAAA,aAAa,EAAE;AAH8D,CAA/C,CAAzB;AAMP;AACA;AACA;;AACA,OAAO,SAASC,gBAAT,CAA0BC,EAA1B,EAAsCC,IAAtC,EAAuD;AAC5D,MAAMC,YAAY,GAAGX,KAAK,CAACY,UAAN,CAAiBV,gBAAjB,CAArB;AACA,MAAMW,QAAQ,GAAGb,KAAK,CAACc,MAAN,CAA4B,EAA5B,EAAgCC,OAAjD;AACAd,EAAAA,yBAAyB,CAAC,YAAM;AAC9BU,IAAAA,YAAY,CAACL,aAAb,iCAAgCO,QAAhC;AAA0CH,MAAAA,IAAI,EAAJA,IAA1C;AAAgDD,MAAAA,EAAE,EAAFA;AAAhD,QAD8B,CAE9B;;AACA,QAAMO,KAAK,GAAGC,MAAM,CAACC,IAAP,CAAYL,QAAZ,EAAsBM,MAAtB,CACZ,UAACC,GAAD,EAAMC,CAAN;AAAA,6CAAuCD,GAAvC,2BAA6CC,CAA7C,EAAiD,IAAjD;AAAA,KADY,EAEZ;AAAEX,MAAAA,IAAI,EAAJA,IAAF;AAAQD,MAAAA,EAAE,EAAFA;AAAR,KAFY,CAAd;AAGA,WAAO;AAAA,aAAME,YAAY,CAACL,aAAb,CAA2BU,KAA3B,CAAN;AAAA,KAAP;AACD,GAPwB,EAOtB,EAPsB,CAAzB;AASA,MAAMM,IAAI,GAAGtB,KAAK,CAACc,MAAN,CAAkC;AAC7CS,IAAAA,YAAY,EAAE,sBAACC,CAAD;AAAA,aAAOX,QAAQ,CAACU,YAAT,GAAwBC,CAA/B;AAAA,KAD+B;AAE7CC,IAAAA,YAAY,EAAE,sBAACD,CAAD;AAAA,aAAOX,QAAQ,CAACY,YAAT,GAAwBD,CAA/B;AAAA,KAF+B;AAG7CE,IAAAA,aAAa,EAAE,uBAACF,CAAD;AAAA,aAAOX,QAAQ,CAACa,aAAT,GAAyBF,CAAhC;AAAA,KAH8B;AAI7CG,IAAAA,cAAc,EAAE,wBAACH,CAAD;AAAA,aAAOX,QAAQ,CAACc,cAAT,GAA0BH,CAAjC;AAAA;AAJ6B,GAAlC,EAKVT,OALH;AAMA,SAAO;AAAEO,IAAAA,IAAI,EAAJA;AAAF,GAAP;AACD;AAED,eAAepB,gBAAf","sourcesContent":["import * as React from 'react';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { ModalElements, ModalsStateEntry, ModalType } from './types';\n\nexport type ModalRegistryEntry = ModalElements & Required<Pick<ModalsStateEntry, 'type' | 'id'>>;\ntype ModalRefs = { [k in keyof ModalElements]: (e: ModalElements[k]) => void };\n\nexport interface ModalRootContextInterface {\n updateModalHeight: VoidFunction;\n registerModal(data: ModalRegistryEntry): void;\n onClose?: VoidFunction;\n isInsideModal: boolean;\n}\n\nexport const ModalRootContext = React.createContext<ModalRootContextInterface>({\n updateModalHeight: () => undefined,\n registerModal: () => undefined,\n isInsideModal: false,\n});\n\n/**\n * All referenced elements must be static\n */\nexport function useModalRegistry(id: string, type: ModalType) {\n const modalContext = React.useContext(ModalRootContext);\n const elements = React.useRef<ModalElements>({}).current;\n useIsomorphicLayoutEffect(() => {\n modalContext.registerModal({ ...elements, type, id });\n // unset refs on unmount to prevent leak\n const reset = Object.keys(elements).reduce<ModalRegistryEntry>(\n (acc, k: keyof ModalElements) => ({ ...acc, [k]: null }),\n { type, id });\n return () => modalContext.registerModal(reset);\n }, []);\n\n const refs = React.useRef<Required<ModalRefs>>({\n modalElement: (e) => elements.modalElement = e,\n innerElement: (e) => elements.innerElement = e,\n headerElement: (e) => elements.headerElement = e,\n contentElement: (e) => elements.contentElement = e,\n }).current;\n return { refs };\n}\n\nexport default ModalRootContext;\n"],"file":"ModalRootContext.js"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootContext.tsx"],"names":["React","useIsomorphicLayoutEffect","ModalRootContext","createContext","updateModalHeight","undefined","registerModal","isInsideModal","useModalRegistry","id","type","modalContext","useContext","elements","useRef","current","reset","Object","keys","reduce","acc","k","refs","modalElement","e","innerElement","headerElement","contentElement"],"mappings":";;AAAA,OAAO,KAAKA,KAAZ,MAAuB,OAAvB;AACA,SAASC,yBAAT;AAcA,OAAO,IAAMC,gBAAgB,gBAAGF,KAAK,CAACG,aAAN,CAA+C;AAC7EC,EAAAA,iBAAiB,EAAE;AAAA,WAAMC,SAAN;AAAA,GAD0D;AAE7EC,EAAAA,aAAa,EAAE;AAAA,WAAMD,SAAN;AAAA,GAF8D;AAG7EE,EAAAA,aAAa,EAAE;AAH8D,CAA/C,CAAzB;AAMP;AACA;AACA;;AACA,OAAO,SAASC,gBAAT,CAA0BC,EAA1B,EAAsCC,IAAtC,EAAuD;AAC5D,MAAMC,YAAY,GAAGX,KAAK,CAACY,UAAN,CAAiBV,gBAAjB,CAArB;AACA,MAAMW,QAAQ,GAAGb,KAAK,CAACc,MAAN,CAA4B,EAA5B,EAAgCC,OAAjD;AACAd,EAAAA,yBAAyB,CAAC,YAAM;AAC9BU,IAAAA,YAAY,CAACL,aAAb,iCAAgCO,QAAhC;AAA0CH,MAAAA,IAAI,EAAJA,IAA1C;AAAgDD,MAAAA,EAAE,EAAFA;AAAhD,QAD8B,CAE9B;;AACA,QAAMO,KAAK,GAAGC,MAAM,CAACC,IAAP,CAAYL,QAAZ,EAAsBM,MAAtB,CACZ,UAACC,GAAD,EAAMC,CAAN;AAAA,6CAAuCD,GAAvC,2BAA6CC,CAA7C,EAAiD,IAAjD;AAAA,KADY,EAEZ;AAAEX,MAAAA,IAAI,EAAJA,IAAF;AAAQD,MAAAA,EAAE,EAAFA;AAAR,KAFY,CAAd;AAIA,WAAO;AAAA,aAAME,YAAY,CAACL,aAAb,CAA2BU,KAA3B,CAAN;AAAA,KAAP;AACD,GARwB,EAQtB,EARsB,CAAzB;AAUA,MAAMM,IAAI,GAAGtB,KAAK,CAACc,MAAN,CAAkC;AAC7CS,IAAAA,YAAY,EAAE,sBAACC,CAAD;AAAA,aAAQX,QAAQ,CAACU,YAAT,GAAwBC,CAAhC;AAAA,KAD+B;AAE7CC,IAAAA,YAAY,EAAE,sBAACD,CAAD;AAAA,aAAQX,QAAQ,CAACY,YAAT,GAAwBD,CAAhC;AAAA,KAF+B;AAG7CE,IAAAA,aAAa,EAAE,uBAACF,CAAD;AAAA,aAAQX,QAAQ,CAACa,aAAT,GAAyBF,CAAjC;AAAA,KAH8B;AAI7CG,IAAAA,cAAc,EAAE,wBAACH,CAAD;AAAA,aAAQX,QAAQ,CAACc,cAAT,GAA0BH,CAAlC;AAAA;AAJ6B,GAAlC,EAKVT,OALH;AAMA,SAAO;AAAEO,IAAAA,IAAI,EAAJA;AAAF,GAAP;AACD;AAED,eAAepB,gBAAf","sourcesContent":["import * as React from \"react\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { ModalElements, ModalsStateEntry, ModalType } from \"./types\";\n\nexport type ModalRegistryEntry = ModalElements &\n Required<Pick<ModalsStateEntry, \"type\" | \"id\">>;\ntype ModalRefs = { [k in keyof ModalElements]: (e: ModalElements[k]) => void };\n\nexport interface ModalRootContextInterface {\n updateModalHeight: VoidFunction;\n registerModal(data: ModalRegistryEntry): void;\n onClose?: VoidFunction;\n isInsideModal: boolean;\n}\n\nexport const ModalRootContext = React.createContext<ModalRootContextInterface>({\n updateModalHeight: () => undefined,\n registerModal: () => undefined,\n isInsideModal: false,\n});\n\n/**\n * All referenced elements must be static\n */\nexport function useModalRegistry(id: string, type: ModalType) {\n const modalContext = React.useContext(ModalRootContext);\n const elements = React.useRef<ModalElements>({}).current;\n useIsomorphicLayoutEffect(() => {\n modalContext.registerModal({ ...elements, type, id });\n // unset refs on unmount to prevent leak\n const reset = Object.keys(elements).reduce<ModalRegistryEntry>(\n (acc, k: keyof ModalElements) => ({ ...acc, [k]: null }),\n { type, id }\n );\n return () => modalContext.registerModal(reset);\n }, []);\n\n const refs = React.useRef<Required<ModalRefs>>({\n modalElement: (e) => (elements.modalElement = e),\n innerElement: (e) => (elements.innerElement = e),\n headerElement: (e) => (elements.headerElement = e),\n contentElement: (e) => (elements.contentElement = e),\n }).current;\n return { refs };\n}\n\nexport default ModalRootContext;\n"],"file":"ModalRootContext.js"}
@@ -7,7 +7,7 @@ import _createSuper from "@babel/runtime/helpers/createSuper";
7
7
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
8
8
  var _excluded = ["id"];
9
9
  import { createScopedElement } from "../../lib/jsxRuntime";
10
- import * as React from 'react';
10
+ import * as React from "react";
11
11
  import { classNames } from "../../lib/classNames";
12
12
  import { transitionEvent } from "../../lib/supportEvents";
13
13
  import { withPlatform } from "../../hoc/withPlatform";
@@ -22,7 +22,7 @@ import { warnOnce } from "../../lib/warnOnce";
22
22
  import { FocusTrap } from "../FocusTrap/FocusTrap";
23
23
  import { withModalManager } from "./useModalManager";
24
24
  import "./ModalRoot.css";
25
- var warn = warnOnce('ModalRoot');
25
+ var warn = warnOnce("ModalRoot");
26
26
 
27
27
  var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
28
28
  _inherits(ModalRootDesktopComponent, _React$Component);
@@ -138,11 +138,11 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
138
138
  value: function waitTransitionFinish(modalState, eventHandler) {
139
139
  if (transitionEvent.supported) {
140
140
  var onceHandler = function onceHandler() {
141
- modalState.innerElement.removeEventListener(transitionEvent.name, onceHandler);
141
+ modalState === null || modalState === void 0 ? void 0 : modalState.innerElement.removeEventListener(transitionEvent.name, onceHandler);
142
142
  eventHandler();
143
143
  };
144
144
 
145
- modalState.innerElement.addEventListener(transitionEvent.name, onceHandler);
145
+ modalState === null || modalState === void 0 ? void 0 : modalState.innerElement.addEventListener(transitionEvent.name, onceHandler);
146
146
  } else {
147
147
  setTimeout(eventHandler, this.timeout);
148
148
  }
@@ -153,7 +153,7 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
153
153
  key: "animateModalOpacity",
154
154
  value: function animateModalOpacity(modalState, display) {
155
155
  modalState.innerElement.style.transitionDelay = display && this.props.delayEnter ? "".concat(this.timeout, "ms") : null;
156
- modalState.innerElement.style.opacity = display ? '1' : '0';
156
+ modalState.innerElement.style.opacity = display ? "1" : "0";
157
157
  }
158
158
  /* Устанавливает прозрачность для полупрозрачной подложки */
159
159
 
@@ -195,9 +195,9 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
195
195
  return createScopedElement(ModalRootContext.Provider, {
196
196
  value: this.modalRootContext
197
197
  }, createScopedElement("div", {
198
- vkuiClass: classNames(getClassName('ModalRoot', this.props.platform), {
199
- 'ModalRoot--vkapps': this.props.configProvider.webviewType === WebviewType.VKAPPS
200
- }, 'ModalRoot--desktop')
198
+ vkuiClass: classNames(getClassName("ModalRoot", this.props.platform), {
199
+ "ModalRoot--vkapps": this.props.configProvider.webviewType === WebviewType.VKAPPS
200
+ }, "ModalRoot--desktop")
201
201
  }, createScopedElement("div", {
202
202
  vkuiClass: "ModalRoot__mask",
203
203
  ref: this.maskElementRef,
@@ -217,10 +217,10 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
217
217
  onClose: _this5.props.closeActiveModal,
218
218
  timeout: _this5.timeout,
219
219
  key: key,
220
- vkuiClass: classNames('ModalRoot__modal', {
221
- 'ModalRoot__modal--active': !exitingModal && !enteringModal && modalId === activeModal,
222
- 'ModalRoot__modal--prev': modalId === exitingModal,
223
- 'ModalRoot__modal--next': exitingModal && modalId === activeModal
220
+ vkuiClass: classNames("ModalRoot__modal", {
221
+ "ModalRoot__modal--active": !exitingModal && !enteringModal && modalId === activeModal,
222
+ "ModalRoot__modal--prev": modalId === exitingModal,
223
+ "ModalRoot__modal--next": exitingModal && modalId === activeModal
224
224
  })
225
225
  }, Modal);
226
226
  }))));
@@ -230,5 +230,5 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
230
230
  return ModalRootDesktopComponent;
231
231
  }(React.Component);
232
232
 
233
- export var ModalRootDesktop = withContext(withPlatform(withDOM(withModalManager()(ModalRootDesktopComponent))), ConfigProviderContext, 'configProvider');
233
+ export var ModalRootDesktop = withContext(withPlatform(withDOM(withModalManager()(ModalRootDesktopComponent))), ConfigProviderContext, "configProvider");
234
234
  //# sourceMappingURL=ModalRootDesktop.js.map
@@ -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","maskElementRef","createRef","modalRootContext","updateModalHeight","undefined","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","cancelAnimationFrame","maskAnimationFrame","current","translateY","translateYCurrent","Math","max","min","toString","configProvider","webviewType","VKAPPS","modals","map","Modal","modalId","key","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, { ModalRootContextInterface } 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<ModalRootProps & DOMProps & ModalTransitionProps> {\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 }) => 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;\n private readonly modalRootContext: ModalRootContextInterface;\n private restoreFocusTo: HTMLElement;\n\n private get timeout() {\n return this.props.platform === ANDROID || this.props.platform === VKCOM ? 320 : 400;\n }\n\n private get modals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n getModalState(id: string) {\n return this.props.getModalState(id);\n }\n\n componentDidUpdate(prevProps: ModalRootProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (this.props.exitingModal && this.props.exitingModal !== prevProps.exitingModal) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (this.props.enteringModal && this.props.enteringModal !== prevProps.enteringModal) {\n const { enteringModal } = this.props;\n const enteringState = this.getModalState(enteringModal);\n requestAnimationFrame(() => {\n if (this.props.enteringModal === enteringModal) {\n this.waitTransitionFinish(enteringState, () => this.props.onEnter(enteringModal));\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 as HTMLElement;\n }\n if (!this.props.activeModal && !this.props.exitingModal && this.restoreFocusTo) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = null;\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(modalState: ModalsStateEntry, eventHandler: () => void) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState.innerElement.removeEventListener(transitionEvent.name, onceHandler);\n eventHandler();\n };\n\n modalState.innerElement.addEventListener(transitionEvent.name, onceHandler);\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /* Анимирует сдивг модалки */\n animateModalOpacity(modalState: ModalsStateEntry, display: boolean) {\n modalState.innerElement.style.transitionDelay = display && this.props.delayEnter ? `${this.timeout}ms` : null;\n modalState.innerElement.style.opacity = display ? '1' : '0';\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(modalState: ModalsStateEntry, forceOpacity: number = null) {\n if (forceOpacity === null && this.props.history[0] !== modalState.id) {\n return;\n }\n\n cancelAnimationFrame(this.maskAnimationFrame);\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY, translateYCurrent } = modalState;\n\n const opacity = forceOpacity === null ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0 : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(0, Math.min(100, opacity)).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(getClassName('ModalRoot', this.props.platform), {\n 'ModalRoot--vkapps': this.props.configProvider.webviewType === WebviewType.VKAPPS,\n }, 'ModalRoot--desktop')}\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': !exitingModal && !enteringModal && modalId === activeModal,\n 'ModalRoot__modal--prev': modalId === exitingModal,\n 'ModalRoot__modal--next': exitingModal && modalId === activeModal,\n })}\n >{Modal}</FocusTrap>\n );\n })}\n </div>\n </div>\n </ModalRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootDesktop = withContext(\n withPlatform(\n withDOM<ModalRootProps>(\n withModalManager()(ModalRootDesktopComponent),\n ),\n ),\n ConfigProviderContext, 'configProvider');\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","maskElementRef","createRef","modalRootContext","updateModalHeight","undefined","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","cancelAnimationFrame","maskAnimationFrame","current","translateY","translateYCurrent","Math","max","min","toString","configProvider","webviewType","VKAPPS","modals","map","Modal","modalId","key","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 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;\n private readonly modalRootContext: ModalRootContextInterface;\n private restoreFocusTo: HTMLElement;\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) {\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 as HTMLElement;\n }\n if (\n !this.props.activeModal &&\n !this.props.exitingModal &&\n this.restoreFocusTo\n ) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = null;\n }\n }\n\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,\n onceHandler\n );\n eventHandler();\n };\n\n modalState?.innerElement.addEventListener(\n transitionEvent.name,\n onceHandler\n );\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /* Анимирует сдивг модалки */\n animateModalOpacity(modalState: ModalsStateEntry, display: boolean) {\n modalState.innerElement.style.transitionDelay =\n display && this.props.delayEnter ? `${this.timeout}ms` : null;\n modalState.innerElement.style.opacity = display ? \"1\" : \"0\";\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(modalState: ModalsStateEntry, forceOpacity: number = null) {\n if (forceOpacity === null && this.props.history[0] !== modalState.id) {\n return;\n }\n\n cancelAnimationFrame(this.maskAnimationFrame);\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY, translateYCurrent } = 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 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 +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;\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;\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"}
@@ -3,7 +3,7 @@ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
3
3
  import _objectSpread from "@babel/runtime/helpers/objectSpread2";
4
4
  import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
5
5
  import { createScopedElement } from "../../lib/jsxRuntime";
6
- import * as React from 'react';
6
+ import * as React from "react";
7
7
  import { ModalType } from "./types";
8
8
  import { warnOnce } from "../../lib/warnOnce";
9
9
  import { getNavId } from "../../lib/getNavId";
@@ -14,9 +14,9 @@ function getModals(children) {
14
14
  return React.Children.toArray(children);
15
15
  }
16
16
 
17
- var warn = warnOnce('ModalRoot');
17
+ var warn = warnOnce("ModalRoot");
18
18
  export function modalTransitionReducer(state, action) {
19
- if (action.type === 'setActive' && action.id !== state.activeModal) {
19
+ if (action.type === "setActive" && action.id !== state.activeModal) {
20
20
  var nextModal = action.id; // preserve exiting modal if switching mid-transition
21
21
 
22
22
  var prevModal = state.exitingModal || state.activeModal;
@@ -43,19 +43,19 @@ export function modalTransitionReducer(state, action) {
43
43
  };
44
44
  }
45
45
 
46
- if (action.type === 'entered' && action.id === state.enteringModal) {
46
+ if (action.type === "entered" && action.id === state.enteringModal) {
47
47
  return _objectSpread(_objectSpread({}, state), {}, {
48
48
  enteringModal: null
49
49
  });
50
50
  }
51
51
 
52
- if (action.type === 'exited' && action.id === state.exitingModal) {
52
+ if (action.type === "exited" && action.id === state.exitingModal) {
53
53
  return _objectSpread(_objectSpread({}, state), {}, {
54
54
  exitingModal: null
55
55
  });
56
56
  }
57
57
 
58
- if (action.type === 'inited' && action.id === state.activeModal) {
58
+ if (action.type === "inited" && action.id === state.activeModal) {
59
59
  return _objectSpread(_objectSpread({}, state), {}, {
60
60
  enteringModal: action.id
61
61
  });
@@ -88,7 +88,7 @@ export function useModalManager(activeModal, children, onClose) {
88
88
  state.onClose = Modal.props.onClose;
89
89
  state.dynamicContentHeight = !!modalProps.dynamicContentHeight; // ModalPage props
90
90
 
91
- if (typeof modalProps.settlingHeight === 'number') {
91
+ if (typeof modalProps.settlingHeight === "number") {
92
92
  state.settlingHeight = modalProps.settlingHeight;
93
93
  }
94
94
 
@@ -111,12 +111,12 @@ export function useModalManager(activeModal, children, onClose) {
111
111
 
112
112
  useIsomorphicLayoutEffect(function () {
113
113
  // ignore non-existent activeModal
114
- if (process.env.NODE_ENV === 'development' && isMissing) {
114
+ if (process.env.NODE_ENV === "development" && isMissing) {
115
115
  warn("Can't transition - modal ".concat(activeModal, " not found"));
116
116
  }
117
117
 
118
118
  dispatchTransition({
119
- type: 'setActive',
119
+ type: "setActive",
120
120
  id: safeActiveModal
121
121
  });
122
122
  }, [activeModal]); // Init activeModal & set enteringModal
@@ -125,7 +125,7 @@ export function useModalManager(activeModal, children, onClose) {
125
125
  if (transitionState.activeModal) {
126
126
  initModal(modalsState[transitionState.activeModal]);
127
127
  dispatchTransition({
128
- type: 'inited',
128
+ type: "inited",
129
129
  id: transitionState.activeModal
130
130
  });
131
131
  }
@@ -139,13 +139,13 @@ export function useModalManager(activeModal, children, onClose) {
139
139
 
140
140
  var onEnter = React.useCallback(function (id) {
141
141
  return dispatchTransition({
142
- type: 'entered',
142
+ type: "entered",
143
143
  id: id
144
144
  });
145
145
  }, []);
146
146
  var onExit = React.useCallback(function (id) {
147
147
  return dispatchTransition({
148
- type: 'exited',
148
+ type: "exited",
149
149
  id: id
150
150
  });
151
151
  }, []);
@@ -162,8 +162,8 @@ export function useModalManager(activeModal, children, onClose) {
162
162
  modalState.onClose();
163
163
  } else if (isFunction(onClose)) {
164
164
  onClose(modalState.id);
165
- } else if (process.env.NODE_ENV === 'development') {
166
- warn('onClose is undefined');
165
+ } else if (process.env.NODE_ENV === "development") {
166
+ warn("onClose is undefined");
167
167
  }
168
168
  }
169
169
  }