@vkontakte/vkui 4.30.0 → 4.33.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 (1906) hide show
  1. package/.cache/.eslintcache +1 -1
  2. package/.cache/.stylelintcache +1 -1
  3. package/.cache/.tsbuildinfo +5546 -24989
  4. package/.cache/ts/src/components/ActionSheet/ActionSheet.d.ts +3 -0
  5. package/.cache/ts/src/components/ActionSheetItem/ActionSheetItem.d.ts +3 -0
  6. package/.cache/ts/src/components/AdaptivityProvider/AdaptivityProvider.d.ts +3 -0
  7. package/.cache/ts/src/components/Alert/Alert.d.ts +9 -11
  8. package/.cache/ts/src/components/AppRoot/AppRoot.d.ts +3 -0
  9. package/.cache/ts/src/components/AppRoot/ScrollContext.d.ts +13 -2
  10. package/.cache/ts/src/components/AppearanceProvider/AppearanceProvider.d.ts +3 -0
  11. package/.cache/ts/src/components/Avatar/Avatar.d.ts +4 -2
  12. package/.cache/ts/src/components/Badge/Badge.d.ts +4 -1
  13. package/.cache/ts/src/components/Banner/Banner.d.ts +4 -2
  14. package/.cache/ts/src/components/BaseGallery/BaseGallery.d.ts +4 -0
  15. package/.cache/ts/src/components/BaseGallery/helpers.d.ts +12 -0
  16. package/.cache/ts/src/components/BaseGallery/types.d.ts +43 -0
  17. package/.cache/ts/src/components/Button/Button.d.ts +4 -1
  18. package/.cache/ts/src/components/ButtonGroup/ButtonGroup.d.ts +3 -0
  19. package/.cache/ts/src/components/Calendar/Calendar.d.ts +4 -1
  20. package/.cache/ts/src/components/CalendarHeader/CalendarHeader.d.ts +2 -0
  21. package/.cache/ts/src/components/CalendarRange/CalendarRange.d.ts +4 -1
  22. package/.cache/ts/src/components/Card/Card.d.ts +3 -0
  23. package/.cache/ts/src/components/CardScroll/CardScroll.d.ts +3 -0
  24. package/.cache/ts/src/components/Cell/Cell.d.ts +5 -2
  25. package/.cache/ts/src/components/Cell/useDraggable.d.ts +4 -2
  26. package/.cache/ts/src/components/CellButton/CellButton.d.ts +4 -2
  27. package/.cache/ts/src/components/Checkbox/Checkbox.d.ts +6 -1
  28. package/.cache/ts/src/components/Chip/Chip.d.ts +3 -0
  29. package/.cache/ts/src/components/ChipsInput/ChipsInput.d.ts +3 -0
  30. package/.cache/ts/src/components/ChipsSelect/ChipsSelect.d.ts +4 -1
  31. package/.cache/ts/src/components/ConfigProvider/ConfigProvider.d.ts +4 -2
  32. package/.cache/ts/src/components/ContentCard/ContentCard.d.ts +4 -2
  33. package/.cache/ts/src/components/Counter/Counter.d.ts +5 -3
  34. package/.cache/ts/src/components/CustomScrollView/CustomScrollView.d.ts +4 -4
  35. package/.cache/ts/src/components/CustomSelect/CustomSelect.d.ts +13 -17
  36. package/.cache/ts/src/components/CustomSelectOption/CustomSelectOption.d.ts +3 -0
  37. package/.cache/ts/src/components/DateInput/DateInput.d.ts +4 -1
  38. package/.cache/ts/src/components/DatePicker/DatePicker.d.ts +1 -2
  39. package/.cache/ts/src/components/DateRangeInput/DateRangeInput.d.ts +4 -1
  40. package/.cache/ts/src/components/Div/Div.d.ts +3 -0
  41. package/.cache/ts/src/components/Dropdown/Dropdown.d.ts +3 -0
  42. package/.cache/ts/src/components/Epic/Epic.d.ts +4 -3
  43. package/.cache/ts/src/components/Epic/ScrollSaver.d.ts +3 -0
  44. package/.cache/ts/src/components/File/File.d.ts +8 -4
  45. package/.cache/ts/src/components/FixedLayout/FixedLayout.d.ts +4 -2
  46. package/.cache/ts/src/components/FocusTrap/FocusTrap.d.ts +3 -0
  47. package/.cache/ts/src/components/FocusVisible/FocusVisible.d.ts +6 -4
  48. package/.cache/ts/src/components/Footer/Footer.d.ts +3 -0
  49. package/.cache/ts/src/components/FormField/FormField.d.ts +8 -0
  50. package/.cache/ts/src/components/FormItem/FormItem.d.ts +3 -0
  51. package/.cache/ts/src/components/FormLayout/FormLayout.d.ts +4 -2
  52. package/.cache/ts/src/components/FormLayoutGroup/FormLayoutGroup.d.ts +4 -2
  53. package/.cache/ts/src/components/FormStatus/FormStatus.d.ts +3 -0
  54. package/.cache/ts/src/components/Gallery/Gallery.d.ts +6 -43
  55. package/.cache/ts/src/components/Gradient/Gradient.d.ts +3 -0
  56. package/.cache/ts/src/components/GridAvatar/GridAvatar.d.ts +7 -1
  57. package/.cache/ts/src/components/Group/Group.d.ts +4 -2
  58. package/.cache/ts/src/components/Header/Header.d.ts +4 -2
  59. package/.cache/ts/src/components/HorizontalCell/HorizontalCell.d.ts +3 -0
  60. package/.cache/ts/src/components/HorizontalScroll/HorizontalScroll.d.ts +3 -0
  61. package/.cache/ts/src/components/IconButton/IconButton.d.ts +5 -2
  62. package/.cache/ts/src/components/InfoRow/InfoRow.d.ts +4 -2
  63. package/.cache/ts/src/components/InitialsAvatar/InitialsAvatar.d.ts +4 -1
  64. package/.cache/ts/src/components/Input/Input.d.ts +4 -1
  65. package/.cache/ts/src/components/Link/Link.d.ts +4 -2
  66. package/.cache/ts/src/components/List/List.d.ts +4 -2
  67. package/.cache/ts/src/components/MiniInfoCell/MiniInfoCell.d.ts +3 -0
  68. package/.cache/ts/src/components/ModalCard/ModalCard.d.ts +4 -2
  69. package/.cache/ts/src/components/ModalCardBase/ModalCardBase.d.ts +4 -1
  70. package/.cache/ts/src/components/ModalDismissButton/ModalDismissButton.d.ts +4 -2
  71. package/.cache/ts/src/components/ModalPage/ModalPage.d.ts +4 -2
  72. package/.cache/ts/src/components/ModalPageHeader/ModalPageHeader.d.ts +4 -2
  73. package/.cache/ts/src/components/ModalRoot/ModalRootAdaptive.d.ts +3 -0
  74. package/.cache/ts/src/components/ModalRoot/ModalRootContext.d.ts +1 -1
  75. package/.cache/ts/src/components/NativeSelect/NativeSelect.d.ts +6 -1
  76. package/.cache/ts/src/components/NavTransitionContext/NavTransitionContext.d.ts +1 -2
  77. package/.cache/ts/src/components/Pagination/Pagination.d.ts +3 -0
  78. package/.cache/ts/src/components/Panel/Panel.d.ts +3 -0
  79. package/.cache/ts/src/components/PanelHeader/PanelHeader.d.ts +12 -2
  80. package/.cache/ts/src/components/PanelHeaderBack/PanelHeaderBack.d.ts +5 -2
  81. package/.cache/ts/src/components/PanelHeaderButton/PanelHeaderButton.d.ts +3 -0
  82. package/.cache/ts/src/components/PanelHeaderClose/PanelHeaderClose.d.ts +4 -2
  83. package/.cache/ts/src/components/PanelHeaderContent/PanelHeaderContent.d.ts +4 -2
  84. package/.cache/ts/src/components/PanelHeaderContext/PanelHeaderContext.d.ts +3 -0
  85. package/.cache/ts/src/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +4 -2
  86. package/.cache/ts/src/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +4 -2
  87. package/.cache/ts/src/components/PanelSpinner/PanelSpinner.d.ts +4 -2
  88. package/.cache/ts/src/components/Placeholder/Placeholder.d.ts +4 -2
  89. package/.cache/ts/src/components/PopoutWrapper/PopoutWrapper.d.ts +3 -0
  90. package/.cache/ts/src/components/Popper/Popper.d.ts +3 -0
  91. package/.cache/ts/src/components/Progress/Progress.d.ts +4 -2
  92. package/.cache/ts/src/components/PromoBanner/PromoBanner.d.ts +5 -2
  93. package/.cache/ts/src/components/PullToRefresh/PullToRefresh.d.ts +9 -24
  94. package/.cache/ts/src/components/PullToRefresh/PullToRefreshSpinner.d.ts +1 -2
  95. package/.cache/ts/src/components/Radio/Radio.d.ts +4 -2
  96. package/.cache/ts/src/components/RadioGroup/RadioGroup.d.ts +3 -0
  97. package/.cache/ts/src/components/RangeSlider/RangeSlider.d.ts +4 -2
  98. package/.cache/ts/src/components/Removable/Removable.d.ts +4 -1
  99. package/.cache/ts/src/components/RichCell/RichCell.d.ts +14 -4
  100. package/.cache/ts/src/components/RichTooltip/RichTooltip.d.ts +3 -0
  101. package/.cache/ts/src/components/Root/Root.d.ts +4 -2
  102. package/.cache/ts/src/components/ScreenSpinner/ScreenSpinner.d.ts +4 -2
  103. package/.cache/ts/src/components/Search/Search.d.ts +1 -2
  104. package/.cache/ts/src/components/SegmentedControl/SegmentedControl.d.ts +3 -0
  105. package/.cache/ts/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +3 -0
  106. package/.cache/ts/src/components/Select/Select.d.ts +13 -1
  107. package/.cache/ts/src/components/SelectMimicry/SelectMimicry.d.ts +6 -5
  108. package/.cache/ts/src/components/Separator/Separator.d.ts +7 -2
  109. package/.cache/ts/src/components/SimpleCell/SimpleCell.d.ts +4 -2
  110. package/.cache/ts/src/components/SimpleCheckbox/SimpleCheckbox.d.ts +4 -0
  111. package/.cache/ts/src/components/Slider/Slider.d.ts +4 -2
  112. package/.cache/ts/src/components/SliderSwitch/SliderSwitch.d.ts +1 -0
  113. package/.cache/ts/src/components/Snackbar/Snackbar.d.ts +3 -0
  114. package/.cache/ts/src/components/Spacing/Spacing.d.ts +6 -1
  115. package/.cache/ts/src/components/Spinner/Spinner.d.ts +5 -3
  116. package/.cache/ts/src/components/SplitCol/SplitCol.d.ts +3 -0
  117. package/.cache/ts/src/components/SplitLayout/SplitLayout.d.ts +3 -0
  118. package/.cache/ts/src/components/SubnavigationBar/SubnavigationBar.d.ts +3 -0
  119. package/.cache/ts/src/components/SubnavigationButton/SubnavigationButton.d.ts +3 -0
  120. package/.cache/ts/src/components/Switch/Switch.d.ts +3 -0
  121. package/.cache/ts/src/components/Tabbar/Tabbar.d.ts +4 -2
  122. package/.cache/ts/src/components/TabbarItem/TabbarItem.d.ts +4 -2
  123. package/.cache/ts/src/components/Tabs/Tabs.d.ts +4 -2
  124. package/.cache/ts/src/components/TabsItem/TabsItem.d.ts +4 -2
  125. package/.cache/ts/src/components/Tappable/Tappable.d.ts +7 -4
  126. package/.cache/ts/src/components/TextTooltip/TextTooltip.d.ts +3 -0
  127. package/.cache/ts/src/components/Textarea/Textarea.d.ts +2 -3
  128. package/.cache/ts/src/components/Tooltip/Tooltip.d.ts +4 -2
  129. package/.cache/ts/src/components/Touch/Touch.d.ts +3 -0
  130. package/.cache/ts/src/components/Typography/Caption/Caption.d.ts +3 -0
  131. package/.cache/ts/src/components/Typography/Footnote/Footnote.d.ts +14 -0
  132. package/.cache/ts/src/components/Typography/Headline/Headline.d.ts +11 -3
  133. package/.cache/ts/src/components/Typography/Paragraph/Paragraph.d.ts +3 -0
  134. package/.cache/ts/src/components/Typography/Subhead/Subhead.d.ts +3 -0
  135. package/.cache/ts/src/components/Typography/Text/Text.d.ts +10 -3
  136. package/.cache/ts/src/components/Typography/Title/Title.d.ts +3 -0
  137. package/.cache/ts/src/components/UsersStack/UsersStack.d.ts +4 -2
  138. package/.cache/ts/src/components/View/View.d.ts +6 -3
  139. package/.cache/ts/src/components/WriteBar/WriteBar.d.ts +3 -0
  140. package/.cache/ts/src/components/WriteBarIcon/WriteBarIcon.d.ts +3 -0
  141. package/.cache/ts/src/hooks/useAdaptivity.d.ts +1 -0
  142. package/.cache/ts/src/hooks/useKeyboard.d.ts +0 -1
  143. package/.cache/ts/src/hooks/usePrevious.d.ts +1 -0
  144. package/.cache/ts/src/index.d.ts +67 -62
  145. package/.cache/ts/src/lib/SSR.d.ts +3 -0
  146. package/.cache/ts/src/lib/animate.d.ts +1 -1
  147. package/.cache/ts/src/lib/select.d.ts +3 -1
  148. package/.cache/ts/src/tokenized/index.d.ts +84 -0
  149. package/.prettierignore +2 -1
  150. package/README.md +1 -1
  151. package/VKUI_TOKENS_MIGRATION_GUIDE.md +0 -1
  152. package/dist/cjs/components/ActionSheet/ActionSheet.d.ts +3 -0
  153. package/dist/cjs/components/ActionSheet/ActionSheet.js +5 -9
  154. package/dist/cjs/components/ActionSheet/ActionSheet.js.map +1 -1
  155. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.d.ts +3 -0
  156. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js +15 -12
  157. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  158. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.d.ts +3 -0
  159. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js +4 -0
  160. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  161. package/dist/cjs/components/Alert/Alert.d.ts +9 -11
  162. package/dist/cjs/components/Alert/Alert.js +186 -244
  163. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  164. package/dist/cjs/components/AppRoot/AppRoot.d.ts +3 -0
  165. package/dist/cjs/components/AppRoot/AppRoot.js +9 -6
  166. package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
  167. package/dist/cjs/components/AppRoot/ScrollContext.d.ts +13 -2
  168. package/dist/cjs/components/AppRoot/ScrollContext.js +193 -90
  169. package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
  170. package/dist/cjs/components/AppearanceProvider/AppearanceProvider.d.ts +3 -0
  171. package/dist/cjs/components/AppearanceProvider/AppearanceProvider.js +4 -0
  172. package/dist/cjs/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  173. package/dist/cjs/components/Avatar/Avatar.d.ts +4 -2
  174. package/dist/cjs/components/Avatar/Avatar.js +10 -13
  175. package/dist/cjs/components/Avatar/Avatar.js.map +1 -1
  176. package/dist/cjs/components/Badge/Badge.d.ts +4 -1
  177. package/dist/cjs/components/Badge/Badge.js +6 -10
  178. package/dist/cjs/components/Badge/Badge.js.map +1 -1
  179. package/dist/cjs/components/Banner/Banner.d.ts +4 -2
  180. package/dist/cjs/components/Banner/Banner.js +39 -54
  181. package/dist/cjs/components/Banner/Banner.js.map +1 -1
  182. package/dist/cjs/components/BaseGallery/BaseGallery.d.ts +4 -0
  183. package/dist/cjs/components/BaseGallery/BaseGallery.js +399 -0
  184. package/dist/cjs/components/BaseGallery/BaseGallery.js.map +1 -0
  185. package/dist/cjs/components/BaseGallery/helpers.d.ts +12 -0
  186. package/dist/cjs/components/BaseGallery/helpers.js +62 -0
  187. package/dist/cjs/components/BaseGallery/helpers.js.map +1 -0
  188. package/dist/cjs/components/BaseGallery/types.d.ts +43 -0
  189. package/dist/cjs/components/BaseGallery/types.js +6 -0
  190. package/dist/cjs/components/BaseGallery/types.js.map +1 -0
  191. package/dist/cjs/components/Button/Button.d.ts +3 -0
  192. package/dist/cjs/components/Button/Button.js +21 -15
  193. package/dist/cjs/components/Button/Button.js.map +1 -1
  194. package/dist/cjs/components/ButtonGroup/ButtonGroup.d.ts +3 -0
  195. package/dist/cjs/components/ButtonGroup/ButtonGroup.js +3 -0
  196. package/dist/cjs/components/ButtonGroup/ButtonGroup.js.map +1 -1
  197. package/dist/cjs/components/Calendar/Calendar.d.ts +4 -1
  198. package/dist/cjs/components/Calendar/Calendar.js +9 -2
  199. package/dist/cjs/components/Calendar/Calendar.js.map +1 -1
  200. package/dist/cjs/components/CalendarDay/CalendarDay.js +2 -4
  201. package/dist/cjs/components/CalendarDay/CalendarDay.js.map +1 -1
  202. package/dist/cjs/components/CalendarDays/CalendarDays.js +2 -3
  203. package/dist/cjs/components/CalendarDays/CalendarDays.js.map +1 -1
  204. package/dist/cjs/components/CalendarHeader/CalendarHeader.d.ts +2 -0
  205. package/dist/cjs/components/CalendarHeader/CalendarHeader.js +67 -61
  206. package/dist/cjs/components/CalendarHeader/CalendarHeader.js.map +1 -1
  207. package/dist/cjs/components/CalendarRange/CalendarRange.d.ts +4 -1
  208. package/dist/cjs/components/CalendarRange/CalendarRange.js +11 -3
  209. package/dist/cjs/components/CalendarRange/CalendarRange.js.map +1 -1
  210. package/dist/cjs/components/Card/Card.d.ts +3 -0
  211. package/dist/cjs/components/Card/Card.js +3 -0
  212. package/dist/cjs/components/Card/Card.js.map +1 -1
  213. package/dist/cjs/components/CardGrid/CardGrid.js +3 -0
  214. package/dist/cjs/components/CardGrid/CardGrid.js.map +1 -1
  215. package/dist/cjs/components/CardScroll/CardScroll.d.ts +3 -0
  216. package/dist/cjs/components/CardScroll/CardScroll.js +3 -0
  217. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  218. package/dist/cjs/components/Cell/Cell.d.ts +5 -2
  219. package/dist/cjs/components/Cell/Cell.js +11 -5
  220. package/dist/cjs/components/Cell/Cell.js.map +1 -1
  221. package/dist/cjs/components/Cell/useDraggable.d.ts +4 -2
  222. package/dist/cjs/components/Cell/useDraggable.js +3 -5
  223. package/dist/cjs/components/Cell/useDraggable.js.map +1 -1
  224. package/dist/cjs/components/CellButton/CellButton.d.ts +4 -2
  225. package/dist/cjs/components/CellButton/CellButton.js +7 -12
  226. package/dist/cjs/components/CellButton/CellButton.js.map +1 -1
  227. package/dist/cjs/components/Checkbox/Checkbox.d.ts +6 -1
  228. package/dist/cjs/components/Checkbox/Checkbox.js +73 -17
  229. package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
  230. package/dist/cjs/components/Chip/Chip.d.ts +3 -0
  231. package/dist/cjs/components/Chip/Chip.js +13 -6
  232. package/dist/cjs/components/Chip/Chip.js.map +1 -1
  233. package/dist/cjs/components/ChipsInput/ChipsInput.d.ts +3 -0
  234. package/dist/cjs/components/ChipsInput/ChipsInput.js +4 -0
  235. package/dist/cjs/components/ChipsInput/ChipsInput.js.map +1 -1
  236. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts +4 -1
  237. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +5 -1
  238. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  239. package/dist/cjs/components/ConfigProvider/ConfigProvider.d.ts +4 -2
  240. package/dist/cjs/components/ConfigProvider/ConfigProvider.js +7 -5
  241. package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
  242. package/dist/cjs/components/ContentCard/ContentCard.d.ts +4 -2
  243. package/dist/cjs/components/ContentCard/ContentCard.js +45 -55
  244. package/dist/cjs/components/ContentCard/ContentCard.js.map +1 -1
  245. package/dist/cjs/components/Counter/Counter.d.ts +5 -3
  246. package/dist/cjs/components/Counter/Counter.js +19 -40
  247. package/dist/cjs/components/Counter/Counter.js.map +1 -1
  248. package/dist/cjs/components/CustomScrollView/CustomScrollView.d.ts +4 -4
  249. package/dist/cjs/components/CustomScrollView/CustomScrollView.js +137 -172
  250. package/dist/cjs/components/CustomScrollView/CustomScrollView.js.map +1 -1
  251. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +13 -17
  252. package/dist/cjs/components/CustomSelect/CustomSelect.js +18 -20
  253. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  254. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js +6 -6
  255. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  256. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.d.ts +3 -0
  257. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js +3 -0
  258. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  259. package/dist/cjs/components/DateInput/DateInput.d.ts +4 -1
  260. package/dist/cjs/components/DateInput/DateInput.js +14 -6
  261. package/dist/cjs/components/DateInput/DateInput.js.map +1 -1
  262. package/dist/cjs/components/DatePicker/DatePicker.d.ts +1 -2
  263. package/dist/cjs/components/DatePicker/DatePicker.js +10 -7
  264. package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
  265. package/dist/cjs/components/DateRangeInput/DateRangeInput.d.ts +4 -1
  266. package/dist/cjs/components/DateRangeInput/DateRangeInput.js +13 -5
  267. package/dist/cjs/components/DateRangeInput/DateRangeInput.js.map +1 -1
  268. package/dist/cjs/components/Div/Div.d.ts +3 -0
  269. package/dist/cjs/components/Div/Div.js +4 -6
  270. package/dist/cjs/components/Div/Div.js.map +1 -1
  271. package/dist/cjs/components/Dropdown/Dropdown.d.ts +3 -0
  272. package/dist/cjs/components/Dropdown/Dropdown.js +3 -0
  273. package/dist/cjs/components/Dropdown/Dropdown.js.map +1 -1
  274. package/dist/cjs/components/Epic/Epic.d.ts +4 -3
  275. package/dist/cjs/components/Epic/Epic.js +9 -8
  276. package/dist/cjs/components/Epic/Epic.js.map +1 -1
  277. package/dist/cjs/components/Epic/ScrollSaver.d.ts +3 -0
  278. package/dist/cjs/components/Epic/ScrollSaver.js +3 -0
  279. package/dist/cjs/components/Epic/ScrollSaver.js.map +1 -1
  280. package/dist/cjs/components/File/File.d.ts +8 -4
  281. package/dist/cjs/components/File/File.js +30 -37
  282. package/dist/cjs/components/File/File.js.map +1 -1
  283. package/dist/cjs/components/FixedLayout/FixedLayout.d.ts +4 -2
  284. package/dist/cjs/components/FixedLayout/FixedLayout.js +9 -11
  285. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  286. package/dist/cjs/components/FocusTrap/FocusTrap.d.ts +3 -0
  287. package/dist/cjs/components/FocusTrap/FocusTrap.js +3 -0
  288. package/dist/cjs/components/FocusTrap/FocusTrap.js.map +1 -1
  289. package/dist/cjs/components/FocusVisible/FocusVisible.d.ts +6 -4
  290. package/dist/cjs/components/FocusVisible/FocusVisible.js +3 -0
  291. package/dist/cjs/components/FocusVisible/FocusVisible.js.map +1 -1
  292. package/dist/cjs/components/Footer/Footer.d.ts +3 -0
  293. package/dist/cjs/components/Footer/Footer.js +3 -0
  294. package/dist/cjs/components/Footer/Footer.js.map +1 -1
  295. package/dist/cjs/components/FormField/FormField.d.ts +8 -0
  296. package/dist/cjs/components/FormField/FormField.js +14 -4
  297. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  298. package/dist/cjs/components/FormItem/FormItem.d.ts +3 -0
  299. package/dist/cjs/components/FormItem/FormItem.js +6 -6
  300. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  301. package/dist/cjs/components/FormLayout/FormLayout.d.ts +4 -2
  302. package/dist/cjs/components/FormLayout/FormLayout.js +6 -5
  303. package/dist/cjs/components/FormLayout/FormLayout.js.map +1 -1
  304. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.d.ts +4 -2
  305. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js +9 -10
  306. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  307. package/dist/cjs/components/FormStatus/FormStatus.d.ts +3 -0
  308. package/dist/cjs/components/FormStatus/FormStatus.js +6 -3
  309. package/dist/cjs/components/FormStatus/FormStatus.js.map +1 -1
  310. package/dist/cjs/components/Gallery/Gallery.d.ts +6 -43
  311. package/dist/cjs/components/Gallery/Gallery.js +26 -565
  312. package/dist/cjs/components/Gallery/Gallery.js.map +1 -1
  313. package/dist/cjs/components/Gradient/Gradient.d.ts +3 -0
  314. package/dist/cjs/components/Gradient/Gradient.js +3 -0
  315. package/dist/cjs/components/Gradient/Gradient.js.map +1 -1
  316. package/dist/cjs/components/GridAvatar/GridAvatar.d.ts +7 -1
  317. package/dist/cjs/components/GridAvatar/GridAvatar.js +12 -11
  318. package/dist/cjs/components/GridAvatar/GridAvatar.js.map +1 -1
  319. package/dist/cjs/components/Group/Group.d.ts +4 -2
  320. package/dist/cjs/components/Group/Group.js +14 -13
  321. package/dist/cjs/components/Group/Group.js.map +1 -1
  322. package/dist/cjs/components/Header/Header.d.ts +4 -2
  323. package/dist/cjs/components/Header/Header.js +29 -45
  324. package/dist/cjs/components/Header/Header.js.map +1 -1
  325. package/dist/cjs/components/HorizontalCell/HorizontalCell.d.ts +3 -0
  326. package/dist/cjs/components/HorizontalCell/HorizontalCell.js +7 -4
  327. package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
  328. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.d.ts +3 -0
  329. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js +5 -1
  330. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  331. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.js +2 -4
  332. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  333. package/dist/cjs/components/IconButton/IconButton.d.ts +5 -2
  334. package/dist/cjs/components/IconButton/IconButton.js +14 -15
  335. package/dist/cjs/components/IconButton/IconButton.js.map +1 -1
  336. package/dist/cjs/components/InfoRow/InfoRow.d.ts +4 -2
  337. package/dist/cjs/components/InfoRow/InfoRow.js +10 -14
  338. package/dist/cjs/components/InfoRow/InfoRow.js.map +1 -1
  339. package/dist/cjs/components/InitialsAvatar/InitialsAvatar.d.ts +4 -1
  340. package/dist/cjs/components/InitialsAvatar/InitialsAvatar.js +6 -4
  341. package/dist/cjs/components/InitialsAvatar/InitialsAvatar.js.map +1 -1
  342. package/dist/cjs/components/Input/Input.d.ts +4 -1
  343. package/dist/cjs/components/Input/Input.js +4 -0
  344. package/dist/cjs/components/Input/Input.js.map +1 -1
  345. package/dist/cjs/components/Link/Link.d.ts +4 -2
  346. package/dist/cjs/components/Link/Link.js +8 -7
  347. package/dist/cjs/components/Link/Link.js.map +1 -1
  348. package/dist/cjs/components/List/List.d.ts +4 -2
  349. package/dist/cjs/components/List/List.js +6 -5
  350. package/dist/cjs/components/List/List.js.map +1 -1
  351. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.d.ts +3 -0
  352. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js +8 -5
  353. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  354. package/dist/cjs/components/ModalCard/ModalCard.d.ts +4 -2
  355. package/dist/cjs/components/ModalCard/ModalCard.js +36 -28
  356. package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
  357. package/dist/cjs/components/ModalCardBase/ModalCardBase.d.ts +4 -1
  358. package/dist/cjs/components/ModalCardBase/ModalCardBase.js +12 -7
  359. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  360. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.d.ts +4 -2
  361. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.js +18 -12
  362. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  363. package/dist/cjs/components/ModalPage/ModalPage.d.ts +4 -2
  364. package/dist/cjs/components/ModalPage/ModalPage.js +40 -30
  365. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  366. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.d.ts +4 -2
  367. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js +15 -27
  368. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  369. package/dist/cjs/components/ModalRoot/ModalRoot.js +2 -2
  370. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  371. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.d.ts +3 -0
  372. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js +7 -4
  373. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  374. package/dist/cjs/components/ModalRoot/ModalRootContext.d.ts +1 -1
  375. package/dist/cjs/components/ModalRoot/ModalRootContext.js +2 -6
  376. package/dist/cjs/components/ModalRoot/ModalRootContext.js.map +1 -1
  377. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +2 -2
  378. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  379. package/dist/cjs/components/ModalRoot/withModalRootContext.js +2 -2
  380. package/dist/cjs/components/ModalRoot/withModalRootContext.js.map +1 -1
  381. package/dist/cjs/components/NativeSelect/NativeSelect.d.ts +6 -1
  382. package/dist/cjs/components/NativeSelect/NativeSelect.js +17 -23
  383. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  384. package/dist/cjs/components/NavTransitionContext/NavTransitionContext.d.ts +1 -2
  385. package/dist/cjs/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  386. package/dist/cjs/components/Pagination/Pagination.d.ts +3 -0
  387. package/dist/cjs/components/Pagination/Pagination.js +5 -2
  388. package/dist/cjs/components/Pagination/Pagination.js.map +1 -1
  389. package/dist/cjs/components/Panel/Panel.d.ts +3 -0
  390. package/dist/cjs/components/Panel/Panel.js +4 -0
  391. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  392. package/dist/cjs/components/PanelHeader/PanelHeader.d.ts +12 -2
  393. package/dist/cjs/components/PanelHeader/PanelHeader.js +74 -48
  394. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  395. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.d.ts +5 -2
  396. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js +14 -11
  397. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  398. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.d.ts +3 -0
  399. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js +8 -5
  400. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  401. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.d.ts +4 -2
  402. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.js +7 -8
  403. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  404. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.d.ts +4 -2
  405. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js +15 -13
  406. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  407. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.d.ts +3 -0
  408. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js +5 -2
  409. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  410. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +4 -2
  411. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.js +11 -12
  412. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  413. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +4 -2
  414. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.js +7 -8
  415. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  416. package/dist/cjs/components/PanelSpinner/PanelSpinner.d.ts +4 -2
  417. package/dist/cjs/components/PanelSpinner/PanelSpinner.js +12 -14
  418. package/dist/cjs/components/PanelSpinner/PanelSpinner.js.map +1 -1
  419. package/dist/cjs/components/Placeholder/Placeholder.d.ts +4 -2
  420. package/dist/cjs/components/Placeholder/Placeholder.js +9 -8
  421. package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
  422. package/dist/cjs/components/PopoutRoot/PopoutRoot.js +3 -1
  423. package/dist/cjs/components/PopoutRoot/PopoutRoot.js.map +1 -1
  424. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.d.ts +3 -0
  425. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js +4 -10
  426. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  427. package/dist/cjs/components/Popper/Popper.d.ts +3 -0
  428. package/dist/cjs/components/Popper/Popper.js +3 -0
  429. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  430. package/dist/cjs/components/Progress/Progress.d.ts +4 -2
  431. package/dist/cjs/components/Progress/Progress.js +8 -15
  432. package/dist/cjs/components/Progress/Progress.js.map +1 -1
  433. package/dist/cjs/components/PromoBanner/PromoBanner.d.ts +5 -2
  434. package/dist/cjs/components/PromoBanner/PromoBanner.js +10 -9
  435. package/dist/cjs/components/PromoBanner/PromoBanner.js.map +1 -1
  436. package/dist/cjs/components/PullToRefresh/PullToRefresh.d.ts +9 -24
  437. package/dist/cjs/components/PullToRefresh/PullToRefresh.js +217 -271
  438. package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
  439. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.d.ts +1 -2
  440. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js +4 -14
  441. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  442. package/dist/cjs/components/Radio/Radio.d.ts +4 -2
  443. package/dist/cjs/components/Radio/Radio.js +48 -31
  444. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  445. package/dist/cjs/components/RadioGroup/RadioGroup.d.ts +3 -0
  446. package/dist/cjs/components/RadioGroup/RadioGroup.js +4 -6
  447. package/dist/cjs/components/RadioGroup/RadioGroup.js.map +1 -1
  448. package/dist/cjs/components/RangeSlider/RangeSlider.d.ts +4 -2
  449. package/dist/cjs/components/RangeSlider/RangeSlider.js +6 -5
  450. package/dist/cjs/components/RangeSlider/RangeSlider.js.map +1 -1
  451. package/dist/cjs/components/RangeSlider/UniversalSlider.js +1 -6
  452. package/dist/cjs/components/RangeSlider/UniversalSlider.js.map +1 -1
  453. package/dist/cjs/components/Removable/Removable.d.ts +4 -1
  454. package/dist/cjs/components/Removable/Removable.js +16 -7
  455. package/dist/cjs/components/Removable/Removable.js.map +1 -1
  456. package/dist/cjs/components/RichCell/RichCell.d.ts +14 -4
  457. package/dist/cjs/components/RichCell/RichCell.js +18 -16
  458. package/dist/cjs/components/RichCell/RichCell.js.map +1 -1
  459. package/dist/cjs/components/RichTooltip/RichTooltip.d.ts +3 -0
  460. package/dist/cjs/components/RichTooltip/RichTooltip.js +3 -0
  461. package/dist/cjs/components/RichTooltip/RichTooltip.js.map +1 -1
  462. package/dist/cjs/components/Root/Root.d.ts +4 -2
  463. package/dist/cjs/components/Root/Root.js +9 -20
  464. package/dist/cjs/components/Root/Root.js.map +1 -1
  465. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.d.ts +4 -2
  466. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js +20 -17
  467. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  468. package/dist/cjs/components/Search/Search.d.ts +1 -2
  469. package/dist/cjs/components/Search/Search.js +29 -27
  470. package/dist/cjs/components/Search/Search.js.map +1 -1
  471. package/dist/cjs/components/SegmentedControl/SegmentedControl.d.ts +3 -0
  472. package/dist/cjs/components/SegmentedControl/SegmentedControl.js +11 -1
  473. package/dist/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
  474. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +3 -0
  475. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +21 -9
  476. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  477. package/dist/cjs/components/Select/Select.d.ts +13 -1
  478. package/dist/cjs/components/Select/Select.js +68 -12
  479. package/dist/cjs/components/Select/Select.js.map +1 -1
  480. package/dist/cjs/components/SelectMimicry/SelectMimicry.d.ts +6 -5
  481. package/dist/cjs/components/SelectMimicry/SelectMimicry.js +23 -35
  482. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  483. package/dist/cjs/components/Separator/Separator.d.ts +7 -2
  484. package/dist/cjs/components/Separator/Separator.js +10 -24
  485. package/dist/cjs/components/Separator/Separator.js.map +1 -1
  486. package/dist/cjs/components/SimpleCell/SimpleCell.d.ts +4 -2
  487. package/dist/cjs/components/SimpleCell/SimpleCell.js +17 -18
  488. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  489. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.d.ts +4 -0
  490. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js +6 -2
  491. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  492. package/dist/cjs/components/Slider/Slider.d.ts +4 -2
  493. package/dist/cjs/components/Slider/Slider.js +6 -5
  494. package/dist/cjs/components/Slider/Slider.js.map +1 -1
  495. package/dist/cjs/components/SliderSwitch/SliderSwitch.d.ts +1 -0
  496. package/dist/cjs/components/SliderSwitch/SliderSwitch.js +1 -0
  497. package/dist/cjs/components/SliderSwitch/SliderSwitch.js.map +1 -1
  498. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js +5 -5
  499. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  500. package/dist/cjs/components/Snackbar/Snackbar.d.ts +3 -0
  501. package/dist/cjs/components/Snackbar/Snackbar.js +6 -3
  502. package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
  503. package/dist/cjs/components/Spacing/Spacing.d.ts +6 -1
  504. package/dist/cjs/components/Spacing/Spacing.js +7 -17
  505. package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
  506. package/dist/cjs/components/Spinner/Spinner.d.ts +5 -3
  507. package/dist/cjs/components/Spinner/Spinner.js +22 -35
  508. package/dist/cjs/components/Spinner/Spinner.js.map +1 -1
  509. package/dist/cjs/components/SplitCol/SplitCol.d.ts +3 -0
  510. package/dist/cjs/components/SplitCol/SplitCol.js +23 -6
  511. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  512. package/dist/cjs/components/SplitLayout/SplitLayout.d.ts +3 -0
  513. package/dist/cjs/components/SplitLayout/SplitLayout.js +3 -0
  514. package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
  515. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.d.ts +3 -0
  516. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js +4 -0
  517. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  518. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.d.ts +3 -0
  519. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js +6 -2
  520. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  521. package/dist/cjs/components/Switch/Switch.d.ts +3 -0
  522. package/dist/cjs/components/Switch/Switch.js +4 -5
  523. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  524. package/dist/cjs/components/Tabbar/Tabbar.d.ts +4 -2
  525. package/dist/cjs/components/Tabbar/Tabbar.js +11 -12
  526. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  527. package/dist/cjs/components/TabbarItem/TabbarItem.d.ts +4 -2
  528. package/dist/cjs/components/TabbarItem/TabbarItem.js +10 -9
  529. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  530. package/dist/cjs/components/Tabs/Tabs.d.ts +4 -2
  531. package/dist/cjs/components/Tabs/Tabs.js +10 -9
  532. package/dist/cjs/components/Tabs/Tabs.js.map +1 -1
  533. package/dist/cjs/components/TabsItem/TabsItem.d.ts +4 -2
  534. package/dist/cjs/components/TabsItem/TabsItem.js +15 -16
  535. package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
  536. package/dist/cjs/components/Tappable/Tappable.d.ts +7 -4
  537. package/dist/cjs/components/Tappable/Tappable.js +39 -40
  538. package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
  539. package/dist/cjs/components/TextTooltip/TextTooltip.d.ts +3 -0
  540. package/dist/cjs/components/TextTooltip/TextTooltip.js +3 -0
  541. package/dist/cjs/components/TextTooltip/TextTooltip.js.map +1 -1
  542. package/dist/cjs/components/Textarea/Textarea.d.ts +2 -3
  543. package/dist/cjs/components/Textarea/Textarea.js +17 -13
  544. package/dist/cjs/components/Textarea/Textarea.js.map +1 -1
  545. package/dist/cjs/components/Tooltip/Tooltip.d.ts +4 -2
  546. package/dist/cjs/components/Tooltip/Tooltip.js +12 -13
  547. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  548. package/dist/cjs/components/Touch/Touch.d.ts +3 -0
  549. package/dist/cjs/components/Touch/Touch.js +3 -0
  550. package/dist/cjs/components/Touch/Touch.js.map +1 -1
  551. package/dist/cjs/components/Typography/Caption/Caption.d.ts +3 -0
  552. package/dist/cjs/components/Typography/Caption/Caption.js +3 -0
  553. package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
  554. package/dist/cjs/components/Typography/Footnote/Footnote.d.ts +14 -0
  555. package/dist/cjs/components/Typography/Footnote/Footnote.js +36 -0
  556. package/dist/cjs/components/Typography/Footnote/Footnote.js.map +1 -0
  557. package/dist/cjs/components/Typography/Headline/Headline.d.ts +11 -3
  558. package/dist/cjs/components/Typography/Headline/Headline.js +19 -8
  559. package/dist/cjs/components/Typography/Headline/Headline.js.map +1 -1
  560. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts +3 -0
  561. package/dist/cjs/components/Typography/Paragraph/Paragraph.js +3 -0
  562. package/dist/cjs/components/Typography/Paragraph/Paragraph.js.map +1 -1
  563. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts +3 -0
  564. package/dist/cjs/components/Typography/Subhead/Subhead.js +3 -0
  565. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  566. package/dist/cjs/components/Typography/Text/Text.d.ts +10 -3
  567. package/dist/cjs/components/Typography/Text/Text.js +17 -12
  568. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  569. package/dist/cjs/components/Typography/Title/Title.d.ts +3 -0
  570. package/dist/cjs/components/Typography/Title/Title.js +3 -0
  571. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  572. package/dist/cjs/components/UsersStack/UsersStack.d.ts +4 -2
  573. package/dist/cjs/components/UsersStack/UsersStack.js +54 -46
  574. package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
  575. package/dist/cjs/components/UsersStack/masks.js +1 -1
  576. package/dist/cjs/components/UsersStack/masks.js.map +1 -1
  577. package/dist/cjs/components/View/View.d.ts +6 -3
  578. package/dist/cjs/components/View/View.js +26 -40
  579. package/dist/cjs/components/View/View.js.map +1 -1
  580. package/dist/cjs/components/WriteBar/WriteBar.d.ts +3 -0
  581. package/dist/cjs/components/WriteBar/WriteBar.js +3 -0
  582. package/dist/cjs/components/WriteBar/WriteBar.js.map +1 -1
  583. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.d.ts +3 -0
  584. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js +7 -4
  585. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  586. package/dist/cjs/hooks/useAdaptivity.d.ts +1 -0
  587. package/dist/cjs/hooks/useAdaptivity.js +18 -1
  588. package/dist/cjs/hooks/useAdaptivity.js.map +1 -1
  589. package/dist/cjs/hooks/useKeyboard.d.ts +0 -1
  590. package/dist/cjs/hooks/useKeyboard.js +2 -20
  591. package/dist/cjs/hooks/useKeyboard.js.map +1 -1
  592. package/dist/cjs/hooks/usePrevious.d.ts +1 -0
  593. package/dist/cjs/hooks/usePrevious.js +19 -0
  594. package/dist/cjs/hooks/usePrevious.js.map +1 -0
  595. package/dist/cjs/hooks/useWaitTransitionFinish.js +2 -3
  596. package/dist/cjs/hooks/useWaitTransitionFinish.js.map +1 -1
  597. package/dist/cjs/index.d.ts +67 -62
  598. package/dist/cjs/index.js +142 -118
  599. package/dist/cjs/index.js.map +1 -1
  600. package/dist/cjs/lib/SSR.d.ts +3 -0
  601. package/dist/cjs/lib/SSR.js +3 -0
  602. package/dist/cjs/lib/SSR.js.map +1 -1
  603. package/dist/cjs/lib/animate.d.ts +1 -1
  604. package/dist/cjs/lib/animate.js +1 -2
  605. package/dist/cjs/lib/animate.js.map +1 -1
  606. package/dist/cjs/lib/select.d.ts +3 -1
  607. package/dist/cjs/lib/select.js +21 -6
  608. package/dist/cjs/lib/select.js.map +1 -1
  609. package/dist/cjs/tokenized/index.d.ts +84 -0
  610. package/dist/cjs/tokenized/index.js +336 -0
  611. package/dist/cjs/tokenized/index.js.map +1 -1
  612. package/dist/components/ActionSheet/ActionSheet.d.ts +3 -0
  613. package/dist/components/ActionSheet/ActionSheet.js +6 -8
  614. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  615. package/dist/components/ActionSheetItem/ActionSheetItem.d.ts +3 -0
  616. package/dist/components/ActionSheetItem/ActionSheetItem.js +10 -7
  617. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  618. package/dist/components/AdaptivityProvider/AdaptivityProvider.d.ts +3 -0
  619. package/dist/components/AdaptivityProvider/AdaptivityProvider.js +3 -0
  620. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  621. package/dist/components/Alert/Alert.d.ts +9 -11
  622. package/dist/components/Alert/Alert.js +193 -256
  623. package/dist/components/Alert/Alert.js.map +1 -1
  624. package/dist/components/AppRoot/AppRoot.d.ts +3 -0
  625. package/dist/components/AppRoot/AppRoot.js +10 -7
  626. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  627. package/dist/components/AppRoot/ScrollContext.d.ts +13 -2
  628. package/dist/components/AppRoot/ScrollContext.js +181 -86
  629. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  630. package/dist/components/AppearanceProvider/AppearanceProvider.d.ts +3 -0
  631. package/dist/components/AppearanceProvider/AppearanceProvider.js +4 -0
  632. package/dist/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  633. package/dist/components/Avatar/Avatar.d.ts +4 -2
  634. package/dist/components/Avatar/Avatar.js +7 -11
  635. package/dist/components/Avatar/Avatar.js.map +1 -1
  636. package/dist/components/Badge/Badge.d.ts +4 -1
  637. package/dist/components/Badge/Badge.js +7 -8
  638. package/dist/components/Badge/Badge.js.map +1 -1
  639. package/dist/components/Banner/Banner.d.ts +4 -2
  640. package/dist/components/Banner/Banner.js +33 -50
  641. package/dist/components/Banner/Banner.js.map +1 -1
  642. package/dist/components/BaseGallery/BaseGallery.d.ts +4 -0
  643. package/dist/components/BaseGallery/BaseGallery.js +371 -0
  644. package/dist/components/BaseGallery/BaseGallery.js.map +1 -0
  645. package/dist/components/BaseGallery/helpers.d.ts +12 -0
  646. package/dist/components/BaseGallery/helpers.js +50 -0
  647. package/dist/components/BaseGallery/helpers.js.map +1 -0
  648. package/dist/components/BaseGallery/types.d.ts +43 -0
  649. package/dist/components/BaseGallery/types.js +2 -0
  650. package/dist/components/BaseGallery/types.js.map +1 -0
  651. package/dist/components/Button/Button.d.ts +3 -0
  652. package/dist/components/Button/Button.js +16 -10
  653. package/dist/components/Button/Button.js.map +1 -1
  654. package/dist/components/ButtonGroup/ButtonGroup.d.ts +3 -0
  655. package/dist/components/ButtonGroup/ButtonGroup.js +4 -0
  656. package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -1
  657. package/dist/components/Calendar/Calendar.d.ts +4 -1
  658. package/dist/components/Calendar/Calendar.js +10 -2
  659. package/dist/components/Calendar/Calendar.js.map +1 -1
  660. package/dist/components/CalendarDay/CalendarDay.js +1 -1
  661. package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
  662. package/dist/components/CalendarDays/CalendarDays.js +2 -3
  663. package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
  664. package/dist/components/CalendarHeader/CalendarHeader.d.ts +2 -0
  665. package/dist/components/CalendarHeader/CalendarHeader.js +66 -59
  666. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
  667. package/dist/components/CalendarRange/CalendarRange.d.ts +4 -1
  668. package/dist/components/CalendarRange/CalendarRange.js +11 -3
  669. package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
  670. package/dist/components/Card/Card.d.ts +3 -0
  671. package/dist/components/Card/Card.js +4 -0
  672. package/dist/components/Card/Card.js.map +1 -1
  673. package/dist/components/CardGrid/CardGrid.js +3 -0
  674. package/dist/components/CardGrid/CardGrid.js.map +1 -1
  675. package/dist/components/CardScroll/CardScroll.d.ts +3 -0
  676. package/dist/components/CardScroll/CardScroll.js +4 -0
  677. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  678. package/dist/components/Cell/Cell.d.ts +5 -2
  679. package/dist/components/Cell/Cell.js +10 -4
  680. package/dist/components/Cell/Cell.js.map +1 -1
  681. package/dist/components/Cell/useDraggable.d.ts +4 -2
  682. package/dist/components/Cell/useDraggable.js +3 -5
  683. package/dist/components/Cell/useDraggable.js.map +1 -1
  684. package/dist/components/CellButton/CellButton.d.ts +4 -2
  685. package/dist/components/CellButton/CellButton.js +6 -10
  686. package/dist/components/CellButton/CellButton.js.map +1 -1
  687. package/dist/components/Checkbox/Checkbox.d.ts +6 -1
  688. package/dist/components/Checkbox/Checkbox.js +71 -16
  689. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  690. package/dist/components/Chip/Chip.d.ts +3 -0
  691. package/dist/components/Chip/Chip.js +11 -5
  692. package/dist/components/Chip/Chip.js.map +1 -1
  693. package/dist/components/ChipsInput/ChipsInput.d.ts +3 -0
  694. package/dist/components/ChipsInput/ChipsInput.js +4 -0
  695. package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
  696. package/dist/components/ChipsSelect/ChipsSelect.d.ts +4 -1
  697. package/dist/components/ChipsSelect/ChipsSelect.js +5 -1
  698. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  699. package/dist/components/ConfigProvider/ConfigProvider.d.ts +4 -2
  700. package/dist/components/ConfigProvider/ConfigProvider.js +6 -5
  701. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  702. package/dist/components/ContentCard/ContentCard.d.ts +4 -2
  703. package/dist/components/ContentCard/ContentCard.js +40 -49
  704. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  705. package/dist/components/Counter/Counter.d.ts +5 -3
  706. package/dist/components/Counter/Counter.js +16 -36
  707. package/dist/components/Counter/Counter.js.map +1 -1
  708. package/dist/components/CustomScrollView/CustomScrollView.d.ts +4 -4
  709. package/dist/components/CustomScrollView/CustomScrollView.js +137 -185
  710. package/dist/components/CustomScrollView/CustomScrollView.js.map +1 -1
  711. package/dist/components/CustomSelect/CustomSelect.d.ts +13 -17
  712. package/dist/components/CustomSelect/CustomSelect.js +17 -19
  713. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  714. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js +4 -4
  715. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  716. package/dist/components/CustomSelectOption/CustomSelectOption.d.ts +3 -0
  717. package/dist/components/CustomSelectOption/CustomSelectOption.js +4 -0
  718. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  719. package/dist/components/DateInput/DateInput.d.ts +4 -1
  720. package/dist/components/DateInput/DateInput.js +12 -4
  721. package/dist/components/DateInput/DateInput.js.map +1 -1
  722. package/dist/components/DatePicker/DatePicker.d.ts +1 -2
  723. package/dist/components/DatePicker/DatePicker.js +8 -4
  724. package/dist/components/DatePicker/DatePicker.js.map +1 -1
  725. package/dist/components/DateRangeInput/DateRangeInput.d.ts +4 -1
  726. package/dist/components/DateRangeInput/DateRangeInput.js +11 -3
  727. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  728. package/dist/components/Div/Div.d.ts +3 -0
  729. package/dist/components/Div/Div.js +5 -4
  730. package/dist/components/Div/Div.js.map +1 -1
  731. package/dist/components/Dropdown/Dropdown.d.ts +3 -0
  732. package/dist/components/Dropdown/Dropdown.js +4 -0
  733. package/dist/components/Dropdown/Dropdown.js.map +1 -1
  734. package/dist/components/Epic/Epic.d.ts +4 -3
  735. package/dist/components/Epic/Epic.js +9 -3
  736. package/dist/components/Epic/Epic.js.map +1 -1
  737. package/dist/components/Epic/ScrollSaver.d.ts +3 -0
  738. package/dist/components/Epic/ScrollSaver.js +4 -0
  739. package/dist/components/Epic/ScrollSaver.js.map +1 -1
  740. package/dist/components/File/File.d.ts +8 -4
  741. package/dist/components/File/File.js +28 -36
  742. package/dist/components/File/File.js.map +1 -1
  743. package/dist/components/FixedLayout/FixedLayout.d.ts +4 -2
  744. package/dist/components/FixedLayout/FixedLayout.js +8 -11
  745. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  746. package/dist/components/FocusTrap/FocusTrap.d.ts +3 -0
  747. package/dist/components/FocusTrap/FocusTrap.js +4 -0
  748. package/dist/components/FocusTrap/FocusTrap.js.map +1 -1
  749. package/dist/components/FocusVisible/FocusVisible.d.ts +6 -4
  750. package/dist/components/FocusVisible/FocusVisible.js +4 -0
  751. package/dist/components/FocusVisible/FocusVisible.js.map +1 -1
  752. package/dist/components/Footer/Footer.d.ts +3 -0
  753. package/dist/components/Footer/Footer.js +4 -0
  754. package/dist/components/Footer/Footer.js.map +1 -1
  755. package/dist/components/FormField/FormField.d.ts +8 -0
  756. package/dist/components/FormField/FormField.js +13 -3
  757. package/dist/components/FormField/FormField.js.map +1 -1
  758. package/dist/components/FormItem/FormItem.d.ts +3 -0
  759. package/dist/components/FormItem/FormItem.js +7 -6
  760. package/dist/components/FormItem/FormItem.js.map +1 -1
  761. package/dist/components/FormLayout/FormLayout.d.ts +4 -2
  762. package/dist/components/FormLayout/FormLayout.js +5 -5
  763. package/dist/components/FormLayout/FormLayout.js.map +1 -1
  764. package/dist/components/FormLayoutGroup/FormLayoutGroup.d.ts +4 -2
  765. package/dist/components/FormLayoutGroup/FormLayoutGroup.js +8 -10
  766. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  767. package/dist/components/FormStatus/FormStatus.d.ts +3 -0
  768. package/dist/components/FormStatus/FormStatus.js +6 -2
  769. package/dist/components/FormStatus/FormStatus.js.map +1 -1
  770. package/dist/components/Gallery/Gallery.d.ts +6 -43
  771. package/dist/components/Gallery/Gallery.js +23 -567
  772. package/dist/components/Gallery/Gallery.js.map +1 -1
  773. package/dist/components/Gradient/Gradient.d.ts +3 -0
  774. package/dist/components/Gradient/Gradient.js +4 -0
  775. package/dist/components/Gradient/Gradient.js.map +1 -1
  776. package/dist/components/GridAvatar/GridAvatar.d.ts +7 -1
  777. package/dist/components/GridAvatar/GridAvatar.js +12 -9
  778. package/dist/components/GridAvatar/GridAvatar.js.map +1 -1
  779. package/dist/components/Group/Group.d.ts +4 -2
  780. package/dist/components/Group/Group.js +10 -8
  781. package/dist/components/Group/Group.js.map +1 -1
  782. package/dist/components/Header/Header.d.ts +4 -2
  783. package/dist/components/Header/Header.js +25 -44
  784. package/dist/components/Header/Header.js.map +1 -1
  785. package/dist/components/HorizontalCell/HorizontalCell.d.ts +3 -0
  786. package/dist/components/HorizontalCell/HorizontalCell.js +5 -2
  787. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  788. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +3 -0
  789. package/dist/components/HorizontalScroll/HorizontalScroll.js +5 -1
  790. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  791. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js +1 -1
  792. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  793. package/dist/components/IconButton/IconButton.d.ts +5 -2
  794. package/dist/components/IconButton/IconButton.js +11 -10
  795. package/dist/components/IconButton/IconButton.js.map +1 -1
  796. package/dist/components/InfoRow/InfoRow.d.ts +4 -2
  797. package/dist/components/InfoRow/InfoRow.js +8 -11
  798. package/dist/components/InfoRow/InfoRow.js.map +1 -1
  799. package/dist/components/InitialsAvatar/InitialsAvatar.d.ts +4 -1
  800. package/dist/components/InitialsAvatar/InitialsAvatar.js +5 -1
  801. package/dist/components/InitialsAvatar/InitialsAvatar.js.map +1 -1
  802. package/dist/components/Input/Input.d.ts +4 -1
  803. package/dist/components/Input/Input.js +4 -0
  804. package/dist/components/Input/Input.js.map +1 -1
  805. package/dist/components/Link/Link.d.ts +4 -2
  806. package/dist/components/Link/Link.js +6 -6
  807. package/dist/components/Link/Link.js.map +1 -1
  808. package/dist/components/List/List.d.ts +4 -2
  809. package/dist/components/List/List.js +5 -5
  810. package/dist/components/List/List.js.map +1 -1
  811. package/dist/components/MiniInfoCell/MiniInfoCell.d.ts +3 -0
  812. package/dist/components/MiniInfoCell/MiniInfoCell.js +7 -3
  813. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  814. package/dist/components/ModalCard/ModalCard.d.ts +4 -2
  815. package/dist/components/ModalCard/ModalCard.js +32 -24
  816. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  817. package/dist/components/ModalCardBase/ModalCardBase.d.ts +4 -1
  818. package/dist/components/ModalCardBase/ModalCardBase.js +12 -8
  819. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  820. package/dist/components/ModalDismissButton/ModalDismissButton.d.ts +4 -2
  821. package/dist/components/ModalDismissButton/ModalDismissButton.js +13 -9
  822. package/dist/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  823. package/dist/components/ModalPage/ModalPage.d.ts +4 -2
  824. package/dist/components/ModalPage/ModalPage.js +36 -28
  825. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  826. package/dist/components/ModalPageHeader/ModalPageHeader.d.ts +4 -2
  827. package/dist/components/ModalPageHeader/ModalPageHeader.js +11 -23
  828. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  829. package/dist/components/ModalRoot/ModalRoot.js +1 -1
  830. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  831. package/dist/components/ModalRoot/ModalRootAdaptive.d.ts +3 -0
  832. package/dist/components/ModalRoot/ModalRootAdaptive.js +7 -5
  833. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  834. package/dist/components/ModalRoot/ModalRootContext.d.ts +1 -1
  835. package/dist/components/ModalRoot/ModalRootContext.js +1 -3
  836. package/dist/components/ModalRoot/ModalRootContext.js.map +1 -1
  837. package/dist/components/ModalRoot/ModalRootDesktop.js +1 -1
  838. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  839. package/dist/components/ModalRoot/withModalRootContext.js +1 -1
  840. package/dist/components/ModalRoot/withModalRootContext.js.map +1 -1
  841. package/dist/components/NativeSelect/NativeSelect.d.ts +6 -1
  842. package/dist/components/NativeSelect/NativeSelect.js +16 -19
  843. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  844. package/dist/components/NavTransitionContext/NavTransitionContext.d.ts +1 -2
  845. package/dist/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  846. package/dist/components/Pagination/Pagination.d.ts +3 -0
  847. package/dist/components/Pagination/Pagination.js +4 -1
  848. package/dist/components/Pagination/Pagination.js.map +1 -1
  849. package/dist/components/Panel/Panel.d.ts +3 -0
  850. package/dist/components/Panel/Panel.js +4 -0
  851. package/dist/components/Panel/Panel.js.map +1 -1
  852. package/dist/components/PanelHeader/PanelHeader.d.ts +12 -2
  853. package/dist/components/PanelHeader/PanelHeader.js +66 -41
  854. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  855. package/dist/components/PanelHeaderBack/PanelHeaderBack.d.ts +5 -2
  856. package/dist/components/PanelHeaderBack/PanelHeaderBack.js +11 -9
  857. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  858. package/dist/components/PanelHeaderButton/PanelHeaderButton.d.ts +3 -0
  859. package/dist/components/PanelHeaderButton/PanelHeaderButton.js +7 -3
  860. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  861. package/dist/components/PanelHeaderClose/PanelHeaderClose.d.ts +4 -2
  862. package/dist/components/PanelHeaderClose/PanelHeaderClose.js +6 -8
  863. package/dist/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  864. package/dist/components/PanelHeaderContent/PanelHeaderContent.d.ts +4 -2
  865. package/dist/components/PanelHeaderContent/PanelHeaderContent.js +11 -10
  866. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  867. package/dist/components/PanelHeaderContext/PanelHeaderContext.d.ts +3 -0
  868. package/dist/components/PanelHeaderContext/PanelHeaderContext.js +5 -1
  869. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  870. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +4 -2
  871. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js +10 -12
  872. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  873. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +4 -2
  874. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.js +6 -8
  875. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  876. package/dist/components/PanelSpinner/PanelSpinner.d.ts +4 -2
  877. package/dist/components/PanelSpinner/PanelSpinner.js +9 -10
  878. package/dist/components/PanelSpinner/PanelSpinner.js.map +1 -1
  879. package/dist/components/Placeholder/Placeholder.d.ts +4 -2
  880. package/dist/components/Placeholder/Placeholder.js +7 -7
  881. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  882. package/dist/components/PopoutRoot/PopoutRoot.js +3 -2
  883. package/dist/components/PopoutRoot/PopoutRoot.js.map +1 -1
  884. package/dist/components/PopoutWrapper/PopoutWrapper.d.ts +3 -0
  885. package/dist/components/PopoutWrapper/PopoutWrapper.js +5 -9
  886. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  887. package/dist/components/Popper/Popper.d.ts +3 -0
  888. package/dist/components/Popper/Popper.js +4 -0
  889. package/dist/components/Popper/Popper.js.map +1 -1
  890. package/dist/components/Progress/Progress.d.ts +4 -2
  891. package/dist/components/Progress/Progress.js +7 -13
  892. package/dist/components/Progress/Progress.js.map +1 -1
  893. package/dist/components/PromoBanner/PromoBanner.d.ts +5 -2
  894. package/dist/components/PromoBanner/PromoBanner.js +7 -7
  895. package/dist/components/PromoBanner/PromoBanner.js.map +1 -1
  896. package/dist/components/PullToRefresh/PullToRefresh.d.ts +9 -24
  897. package/dist/components/PullToRefresh/PullToRefresh.js +210 -272
  898. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  899. package/dist/components/PullToRefresh/PullToRefreshSpinner.d.ts +1 -2
  900. package/dist/components/PullToRefresh/PullToRefreshSpinner.js +3 -10
  901. package/dist/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  902. package/dist/components/Radio/Radio.d.ts +4 -2
  903. package/dist/components/Radio/Radio.js +40 -20
  904. package/dist/components/Radio/Radio.js.map +1 -1
  905. package/dist/components/RadioGroup/RadioGroup.d.ts +3 -0
  906. package/dist/components/RadioGroup/RadioGroup.js +5 -4
  907. package/dist/components/RadioGroup/RadioGroup.js.map +1 -1
  908. package/dist/components/RangeSlider/RangeSlider.d.ts +4 -2
  909. package/dist/components/RangeSlider/RangeSlider.js +5 -5
  910. package/dist/components/RangeSlider/RangeSlider.js.map +1 -1
  911. package/dist/components/RangeSlider/UniversalSlider.js +1 -5
  912. package/dist/components/RangeSlider/UniversalSlider.js.map +1 -1
  913. package/dist/components/Removable/Removable.d.ts +4 -1
  914. package/dist/components/Removable/Removable.js +13 -4
  915. package/dist/components/Removable/Removable.js.map +1 -1
  916. package/dist/components/RichCell/RichCell.d.ts +14 -4
  917. package/dist/components/RichCell/RichCell.js +15 -12
  918. package/dist/components/RichCell/RichCell.js.map +1 -1
  919. package/dist/components/RichTooltip/RichTooltip.d.ts +3 -0
  920. package/dist/components/RichTooltip/RichTooltip.js +4 -0
  921. package/dist/components/RichTooltip/RichTooltip.js.map +1 -1
  922. package/dist/components/Root/Root.d.ts +4 -2
  923. package/dist/components/Root/Root.js +8 -19
  924. package/dist/components/Root/Root.js.map +1 -1
  925. package/dist/components/ScreenSpinner/ScreenSpinner.d.ts +4 -2
  926. package/dist/components/ScreenSpinner/ScreenSpinner.js +16 -14
  927. package/dist/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  928. package/dist/components/Search/Search.d.ts +1 -2
  929. package/dist/components/Search/Search.js +25 -22
  930. package/dist/components/Search/Search.js.map +1 -1
  931. package/dist/components/SegmentedControl/SegmentedControl.d.ts +3 -0
  932. package/dist/components/SegmentedControl/SegmentedControl.js +10 -1
  933. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  934. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +3 -0
  935. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +19 -9
  936. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  937. package/dist/components/Select/Select.d.ts +13 -1
  938. package/dist/components/Select/Select.js +56 -11
  939. package/dist/components/Select/Select.js.map +1 -1
  940. package/dist/components/SelectMimicry/SelectMimicry.d.ts +6 -5
  941. package/dist/components/SelectMimicry/SelectMimicry.js +21 -29
  942. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  943. package/dist/components/Separator/Separator.d.ts +7 -2
  944. package/dist/components/Separator/Separator.js +9 -18
  945. package/dist/components/Separator/Separator.js.map +1 -1
  946. package/dist/components/SimpleCell/SimpleCell.d.ts +4 -2
  947. package/dist/components/SimpleCell/SimpleCell.js +11 -11
  948. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  949. package/dist/components/SimpleCheckbox/SimpleCheckbox.d.ts +4 -0
  950. package/dist/components/SimpleCheckbox/SimpleCheckbox.js +6 -1
  951. package/dist/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  952. package/dist/components/Slider/Slider.d.ts +4 -2
  953. package/dist/components/Slider/Slider.js +5 -5
  954. package/dist/components/Slider/Slider.js.map +1 -1
  955. package/dist/components/SliderSwitch/SliderSwitch.d.ts +1 -0
  956. package/dist/components/SliderSwitch/SliderSwitch.js +1 -0
  957. package/dist/components/SliderSwitch/SliderSwitch.js.map +1 -1
  958. package/dist/components/SliderSwitch/SliderSwitchButton.js +3 -3
  959. package/dist/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  960. package/dist/components/Snackbar/Snackbar.d.ts +3 -0
  961. package/dist/components/Snackbar/Snackbar.js +5 -2
  962. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  963. package/dist/components/Spacing/Spacing.d.ts +6 -1
  964. package/dist/components/Spacing/Spacing.js +8 -16
  965. package/dist/components/Spacing/Spacing.js.map +1 -1
  966. package/dist/components/Spinner/Spinner.d.ts +5 -3
  967. package/dist/components/Spinner/Spinner.js +20 -30
  968. package/dist/components/Spinner/Spinner.js.map +1 -1
  969. package/dist/components/SplitCol/SplitCol.d.ts +3 -0
  970. package/dist/components/SplitCol/SplitCol.js +22 -6
  971. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  972. package/dist/components/SplitLayout/SplitLayout.d.ts +3 -0
  973. package/dist/components/SplitLayout/SplitLayout.js +4 -0
  974. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  975. package/dist/components/SubnavigationBar/SubnavigationBar.d.ts +3 -0
  976. package/dist/components/SubnavigationBar/SubnavigationBar.js +4 -0
  977. package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  978. package/dist/components/SubnavigationButton/SubnavigationButton.d.ts +3 -0
  979. package/dist/components/SubnavigationButton/SubnavigationButton.js +5 -1
  980. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  981. package/dist/components/Switch/Switch.d.ts +3 -0
  982. package/dist/components/Switch/Switch.js +5 -5
  983. package/dist/components/Switch/Switch.js.map +1 -1
  984. package/dist/components/Tabbar/Tabbar.d.ts +4 -2
  985. package/dist/components/Tabbar/Tabbar.js +9 -11
  986. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  987. package/dist/components/TabbarItem/TabbarItem.d.ts +4 -2
  988. package/dist/components/TabbarItem/TabbarItem.js +7 -7
  989. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  990. package/dist/components/Tabs/Tabs.d.ts +4 -2
  991. package/dist/components/Tabs/Tabs.js +8 -6
  992. package/dist/components/Tabs/Tabs.js.map +1 -1
  993. package/dist/components/TabsItem/TabsItem.d.ts +4 -2
  994. package/dist/components/TabsItem/TabsItem.js +13 -15
  995. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  996. package/dist/components/Tappable/Tappable.d.ts +7 -4
  997. package/dist/components/Tappable/Tappable.js +38 -37
  998. package/dist/components/Tappable/Tappable.js.map +1 -1
  999. package/dist/components/TextTooltip/TextTooltip.d.ts +3 -0
  1000. package/dist/components/TextTooltip/TextTooltip.js +4 -0
  1001. package/dist/components/TextTooltip/TextTooltip.js.map +1 -1
  1002. package/dist/components/Textarea/Textarea.d.ts +2 -3
  1003. package/dist/components/Textarea/Textarea.js +16 -9
  1004. package/dist/components/Textarea/Textarea.js.map +1 -1
  1005. package/dist/components/Tooltip/Tooltip.d.ts +4 -2
  1006. package/dist/components/Tooltip/Tooltip.js +11 -13
  1007. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  1008. package/dist/components/Touch/Touch.d.ts +3 -0
  1009. package/dist/components/Touch/Touch.js +4 -0
  1010. package/dist/components/Touch/Touch.js.map +1 -1
  1011. package/dist/components/Typography/Caption/Caption.d.ts +3 -0
  1012. package/dist/components/Typography/Caption/Caption.js +4 -0
  1013. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  1014. package/dist/components/Typography/Footnote/Footnote.d.ts +14 -0
  1015. package/dist/components/Typography/Footnote/Footnote.js +22 -0
  1016. package/dist/components/Typography/Footnote/Footnote.js.map +1 -0
  1017. package/dist/components/Typography/Headline/Headline.d.ts +11 -3
  1018. package/dist/components/Typography/Headline/Headline.js +17 -8
  1019. package/dist/components/Typography/Headline/Headline.js.map +1 -1
  1020. package/dist/components/Typography/Paragraph/Paragraph.d.ts +3 -0
  1021. package/dist/components/Typography/Paragraph/Paragraph.js +4 -0
  1022. package/dist/components/Typography/Paragraph/Paragraph.js.map +1 -1
  1023. package/dist/components/Typography/Subhead/Subhead.d.ts +3 -0
  1024. package/dist/components/Typography/Subhead/Subhead.js +4 -0
  1025. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  1026. package/dist/components/Typography/Text/Text.d.ts +10 -3
  1027. package/dist/components/Typography/Text/Text.js +16 -12
  1028. package/dist/components/Typography/Text/Text.js.map +1 -1
  1029. package/dist/components/Typography/Title/Title.d.ts +3 -0
  1030. package/dist/components/Typography/Title/Title.js +4 -0
  1031. package/dist/components/Typography/Title/Title.js.map +1 -1
  1032. package/dist/components/UsersStack/UsersStack.d.ts +4 -2
  1033. package/dist/components/UsersStack/UsersStack.js +51 -39
  1034. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  1035. package/dist/components/UsersStack/masks.js +1 -1
  1036. package/dist/components/UsersStack/masks.js.map +1 -1
  1037. package/dist/components/View/View.d.ts +6 -3
  1038. package/dist/components/View/View.js +25 -36
  1039. package/dist/components/View/View.js.map +1 -1
  1040. package/dist/components/WriteBar/WriteBar.d.ts +3 -0
  1041. package/dist/components/WriteBar/WriteBar.js +4 -0
  1042. package/dist/components/WriteBar/WriteBar.js.map +1 -1
  1043. package/dist/components/WriteBarIcon/WriteBarIcon.d.ts +3 -0
  1044. package/dist/components/WriteBarIcon/WriteBarIcon.js +6 -2
  1045. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1046. package/dist/components.css +54 -18
  1047. package/dist/components.css.map +1 -1
  1048. package/dist/cssm/components/ActionSheet/ActionSheet.d.ts +3 -0
  1049. package/dist/cssm/components/ActionSheet/ActionSheet.js +6 -8
  1050. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  1051. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.d.ts +3 -0
  1052. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js +10 -7
  1053. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  1054. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.d.ts +3 -0
  1055. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js +3 -0
  1056. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  1057. package/dist/cssm/components/Alert/Alert.css +1 -1
  1058. package/dist/cssm/components/Alert/Alert.d.ts +9 -11
  1059. package/dist/cssm/components/Alert/Alert.js +192 -255
  1060. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  1061. package/dist/cssm/components/AppRoot/AppRoot.d.ts +3 -0
  1062. package/dist/cssm/components/AppRoot/AppRoot.js +10 -7
  1063. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  1064. package/dist/cssm/components/AppRoot/ScrollContext.d.ts +13 -2
  1065. package/dist/cssm/components/AppRoot/ScrollContext.js +181 -86
  1066. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  1067. package/dist/cssm/components/AppearanceProvider/AppearanceProvider.d.ts +3 -0
  1068. package/dist/cssm/components/AppearanceProvider/AppearanceProvider.js +4 -0
  1069. package/dist/cssm/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  1070. package/dist/cssm/components/Avatar/Avatar.css +5 -1
  1071. package/dist/cssm/components/Avatar/Avatar.d.ts +4 -2
  1072. package/dist/cssm/components/Avatar/Avatar.js +7 -11
  1073. package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
  1074. package/dist/cssm/components/Badge/Badge.css +3 -1
  1075. package/dist/cssm/components/Badge/Badge.d.ts +4 -1
  1076. package/dist/cssm/components/Badge/Badge.js +7 -8
  1077. package/dist/cssm/components/Badge/Badge.js.map +1 -1
  1078. package/dist/cssm/components/Banner/Banner.css +5 -1
  1079. package/dist/cssm/components/Banner/Banner.d.ts +4 -2
  1080. package/dist/cssm/components/Banner/Banner.js +33 -50
  1081. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  1082. package/dist/cssm/components/BaseGallery/BaseGallery.css +1 -0
  1083. package/dist/cssm/components/BaseGallery/BaseGallery.d.ts +4 -0
  1084. package/dist/cssm/components/BaseGallery/BaseGallery.js +372 -0
  1085. package/dist/cssm/components/BaseGallery/BaseGallery.js.map +1 -0
  1086. package/dist/cssm/components/BaseGallery/helpers.d.ts +12 -0
  1087. package/dist/cssm/components/BaseGallery/helpers.js +50 -0
  1088. package/dist/cssm/components/BaseGallery/helpers.js.map +1 -0
  1089. package/dist/cssm/components/BaseGallery/types.d.ts +43 -0
  1090. package/dist/cssm/components/BaseGallery/types.js +2 -0
  1091. package/dist/cssm/components/BaseGallery/types.js.map +1 -0
  1092. package/dist/cssm/components/Button/Button.css +9 -9
  1093. package/dist/cssm/components/Button/Button.d.ts +3 -0
  1094. package/dist/cssm/components/Button/Button.js +16 -10
  1095. package/dist/cssm/components/Button/Button.js.map +1 -1
  1096. package/dist/cssm/components/ButtonGroup/ButtonGroup.css +1 -1
  1097. package/dist/cssm/components/ButtonGroup/ButtonGroup.d.ts +3 -0
  1098. package/dist/cssm/components/ButtonGroup/ButtonGroup.js +4 -0
  1099. package/dist/cssm/components/ButtonGroup/ButtonGroup.js.map +1 -1
  1100. package/dist/cssm/components/Calendar/Calendar.css +1 -1
  1101. package/dist/cssm/components/Calendar/Calendar.d.ts +4 -1
  1102. package/dist/cssm/components/Calendar/Calendar.js +10 -2
  1103. package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
  1104. package/dist/cssm/components/CalendarDay/CalendarDay.css +1 -1
  1105. package/dist/cssm/components/CalendarDay/CalendarDay.js +1 -1
  1106. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
  1107. package/dist/cssm/components/CalendarDays/CalendarDays.css +1 -1
  1108. package/dist/cssm/components/CalendarDays/CalendarDays.js +2 -3
  1109. package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
  1110. package/dist/cssm/components/CalendarHeader/CalendarHeader.css +1 -1
  1111. package/dist/cssm/components/CalendarHeader/CalendarHeader.d.ts +2 -0
  1112. package/dist/cssm/components/CalendarHeader/CalendarHeader.js +66 -59
  1113. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
  1114. package/dist/cssm/components/CalendarRange/CalendarRange.css +1 -1
  1115. package/dist/cssm/components/CalendarRange/CalendarRange.d.ts +4 -1
  1116. package/dist/cssm/components/CalendarRange/CalendarRange.js +11 -3
  1117. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
  1118. package/dist/cssm/components/CalendarTime/CalendarTime.css +1 -1
  1119. package/dist/cssm/components/Card/Card.css +2 -2
  1120. package/dist/cssm/components/Card/Card.d.ts +3 -0
  1121. package/dist/cssm/components/Card/Card.js +4 -0
  1122. package/dist/cssm/components/Card/Card.js.map +1 -1
  1123. package/dist/cssm/components/CardGrid/CardGrid.js +3 -0
  1124. package/dist/cssm/components/CardGrid/CardGrid.js.map +1 -1
  1125. package/dist/cssm/components/CardScroll/CardScroll.css +1 -1
  1126. package/dist/cssm/components/CardScroll/CardScroll.d.ts +3 -0
  1127. package/dist/cssm/components/CardScroll/CardScroll.js +4 -0
  1128. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  1129. package/dist/cssm/components/Cell/Cell.css +1 -1
  1130. package/dist/cssm/components/Cell/Cell.d.ts +5 -2
  1131. package/dist/cssm/components/Cell/Cell.js +10 -4
  1132. package/dist/cssm/components/Cell/Cell.js.map +1 -1
  1133. package/dist/cssm/components/Cell/useDraggable.d.ts +4 -2
  1134. package/dist/cssm/components/Cell/useDraggable.js +3 -5
  1135. package/dist/cssm/components/Cell/useDraggable.js.map +1 -1
  1136. package/dist/cssm/components/CellButton/CellButton.css +1 -1
  1137. package/dist/cssm/components/CellButton/CellButton.d.ts +4 -2
  1138. package/dist/cssm/components/CellButton/CellButton.js +6 -10
  1139. package/dist/cssm/components/CellButton/CellButton.js.map +1 -1
  1140. package/dist/cssm/components/Checkbox/Checkbox.css +1 -1
  1141. package/dist/cssm/components/Checkbox/Checkbox.d.ts +6 -1
  1142. package/dist/cssm/components/Checkbox/Checkbox.js +71 -16
  1143. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  1144. package/dist/cssm/components/Chip/Chip.css +1 -1
  1145. package/dist/cssm/components/Chip/Chip.d.ts +3 -0
  1146. package/dist/cssm/components/Chip/Chip.js +11 -5
  1147. package/dist/cssm/components/Chip/Chip.js.map +1 -1
  1148. package/dist/cssm/components/ChipsInput/ChipsInput.css +1 -1
  1149. package/dist/cssm/components/ChipsInput/ChipsInput.d.ts +3 -0
  1150. package/dist/cssm/components/ChipsInput/ChipsInput.js +4 -0
  1151. package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
  1152. package/dist/cssm/components/ChipsSelect/ChipsSelect.css +1 -1
  1153. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts +4 -1
  1154. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +5 -1
  1155. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  1156. package/dist/cssm/components/ConfigProvider/ConfigProvider.d.ts +4 -2
  1157. package/dist/cssm/components/ConfigProvider/ConfigProvider.js +6 -5
  1158. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  1159. package/dist/cssm/components/ContentCard/ContentCard.css +1 -1
  1160. package/dist/cssm/components/ContentCard/ContentCard.d.ts +4 -2
  1161. package/dist/cssm/components/ContentCard/ContentCard.js +40 -49
  1162. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  1163. package/dist/cssm/components/Counter/Counter.css +10 -2
  1164. package/dist/cssm/components/Counter/Counter.d.ts +5 -3
  1165. package/dist/cssm/components/Counter/Counter.js +16 -36
  1166. package/dist/cssm/components/Counter/Counter.js.map +1 -1
  1167. package/dist/cssm/components/CustomScrollView/CustomScrollView.css +1 -1
  1168. package/dist/cssm/components/CustomScrollView/CustomScrollView.d.ts +4 -4
  1169. package/dist/cssm/components/CustomScrollView/CustomScrollView.js +137 -185
  1170. package/dist/cssm/components/CustomScrollView/CustomScrollView.js.map +1 -1
  1171. package/dist/cssm/components/CustomSelect/CustomSelect.css +1 -1
  1172. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +13 -17
  1173. package/dist/cssm/components/CustomSelect/CustomSelect.js +17 -19
  1174. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  1175. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.css +2 -2
  1176. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js +4 -4
  1177. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  1178. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.css +1 -1
  1179. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.d.ts +3 -0
  1180. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js +4 -0
  1181. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  1182. package/dist/cssm/components/DateInput/DateInput.css +1 -1
  1183. package/dist/cssm/components/DateInput/DateInput.d.ts +4 -1
  1184. package/dist/cssm/components/DateInput/DateInput.js +12 -4
  1185. package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
  1186. package/dist/cssm/components/DatePicker/DatePicker.d.ts +1 -2
  1187. package/dist/cssm/components/DatePicker/DatePicker.js +8 -4
  1188. package/dist/cssm/components/DatePicker/DatePicker.js.map +1 -1
  1189. package/dist/cssm/components/DateRangeInput/DateRangeInput.css +1 -1
  1190. package/dist/cssm/components/DateRangeInput/DateRangeInput.d.ts +4 -1
  1191. package/dist/cssm/components/DateRangeInput/DateRangeInput.js +11 -3
  1192. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  1193. package/dist/cssm/components/Div/Div.css +1 -1
  1194. package/dist/cssm/components/Div/Div.d.ts +3 -0
  1195. package/dist/cssm/components/Div/Div.js +5 -4
  1196. package/dist/cssm/components/Div/Div.js.map +1 -1
  1197. package/dist/cssm/components/Dropdown/Dropdown.d.ts +3 -0
  1198. package/dist/cssm/components/Dropdown/Dropdown.js +4 -0
  1199. package/dist/cssm/components/Dropdown/Dropdown.js.map +1 -1
  1200. package/dist/cssm/components/Epic/Epic.d.ts +4 -3
  1201. package/dist/cssm/components/Epic/Epic.js +9 -3
  1202. package/dist/cssm/components/Epic/Epic.js.map +1 -1
  1203. package/dist/cssm/components/Epic/ScrollSaver.d.ts +3 -0
  1204. package/dist/cssm/components/Epic/ScrollSaver.js +4 -0
  1205. package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
  1206. package/dist/cssm/components/File/File.d.ts +8 -4
  1207. package/dist/cssm/components/File/File.js +28 -37
  1208. package/dist/cssm/components/File/File.js.map +1 -1
  1209. package/dist/cssm/components/FixedLayout/FixedLayout.css +1 -1
  1210. package/dist/cssm/components/FixedLayout/FixedLayout.d.ts +4 -2
  1211. package/dist/cssm/components/FixedLayout/FixedLayout.js +8 -11
  1212. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  1213. package/dist/cssm/components/FocusTrap/FocusTrap.d.ts +3 -0
  1214. package/dist/cssm/components/FocusTrap/FocusTrap.js +4 -0
  1215. package/dist/cssm/components/FocusTrap/FocusTrap.js.map +1 -1
  1216. package/dist/cssm/components/FocusVisible/FocusVisible.css +1 -1
  1217. package/dist/cssm/components/FocusVisible/FocusVisible.d.ts +6 -4
  1218. package/dist/cssm/components/FocusVisible/FocusVisible.js +4 -0
  1219. package/dist/cssm/components/FocusVisible/FocusVisible.js.map +1 -1
  1220. package/dist/cssm/components/Footer/Footer.css +1 -1
  1221. package/dist/cssm/components/Footer/Footer.d.ts +3 -0
  1222. package/dist/cssm/components/Footer/Footer.js +4 -0
  1223. package/dist/cssm/components/Footer/Footer.js.map +1 -1
  1224. package/dist/cssm/components/FormField/FormField.css +7 -3
  1225. package/dist/cssm/components/FormField/FormField.d.ts +8 -0
  1226. package/dist/cssm/components/FormField/FormField.js +13 -3
  1227. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  1228. package/dist/cssm/components/FormItem/FormItem.css +1 -1
  1229. package/dist/cssm/components/FormItem/FormItem.d.ts +3 -0
  1230. package/dist/cssm/components/FormItem/FormItem.js +7 -6
  1231. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  1232. package/dist/cssm/components/FormLayout/FormLayout.d.ts +4 -2
  1233. package/dist/cssm/components/FormLayout/FormLayout.js +5 -5
  1234. package/dist/cssm/components/FormLayout/FormLayout.js.map +1 -1
  1235. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.css +1 -1
  1236. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.d.ts +4 -2
  1237. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js +8 -10
  1238. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  1239. package/dist/cssm/components/FormStatus/FormStatus.css +1 -1
  1240. package/dist/cssm/components/FormStatus/FormStatus.d.ts +3 -0
  1241. package/dist/cssm/components/FormStatus/FormStatus.js +6 -2
  1242. package/dist/cssm/components/FormStatus/FormStatus.js.map +1 -1
  1243. package/dist/cssm/components/Gallery/Gallery.d.ts +6 -43
  1244. package/dist/cssm/components/Gallery/Gallery.js +23 -568
  1245. package/dist/cssm/components/Gallery/Gallery.js.map +1 -1
  1246. package/dist/cssm/components/Gradient/Gradient.d.ts +3 -0
  1247. package/dist/cssm/components/Gradient/Gradient.js +4 -0
  1248. package/dist/cssm/components/Gradient/Gradient.js.map +1 -1
  1249. package/dist/cssm/components/GridAvatar/GridAvatar.d.ts +7 -1
  1250. package/dist/cssm/components/GridAvatar/GridAvatar.js +12 -9
  1251. package/dist/cssm/components/GridAvatar/GridAvatar.js.map +1 -1
  1252. package/dist/cssm/components/Group/Group.d.ts +4 -2
  1253. package/dist/cssm/components/Group/Group.js +10 -8
  1254. package/dist/cssm/components/Group/Group.js.map +1 -1
  1255. package/dist/cssm/components/Header/Header.d.ts +4 -2
  1256. package/dist/cssm/components/Header/Header.js +25 -44
  1257. package/dist/cssm/components/Header/Header.js.map +1 -1
  1258. package/dist/cssm/components/HorizontalCell/HorizontalCell.d.ts +3 -0
  1259. package/dist/cssm/components/HorizontalCell/HorizontalCell.js +5 -2
  1260. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  1261. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.d.ts +3 -0
  1262. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +5 -1
  1263. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  1264. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.css +1 -1
  1265. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js +1 -1
  1266. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  1267. package/dist/cssm/components/IconButton/IconButton.css +1 -1
  1268. package/dist/cssm/components/IconButton/IconButton.d.ts +5 -2
  1269. package/dist/cssm/components/IconButton/IconButton.js +11 -10
  1270. package/dist/cssm/components/IconButton/IconButton.js.map +1 -1
  1271. package/dist/cssm/components/InfoRow/InfoRow.css +1 -1
  1272. package/dist/cssm/components/InfoRow/InfoRow.d.ts +4 -2
  1273. package/dist/cssm/components/InfoRow/InfoRow.js +8 -11
  1274. package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
  1275. package/dist/cssm/components/InitialsAvatar/InitialsAvatar.css +1 -1
  1276. package/dist/cssm/components/InitialsAvatar/InitialsAvatar.d.ts +4 -1
  1277. package/dist/cssm/components/InitialsAvatar/InitialsAvatar.js +5 -1
  1278. package/dist/cssm/components/InitialsAvatar/InitialsAvatar.js.map +1 -1
  1279. package/dist/cssm/components/Input/Input.css +1 -1
  1280. package/dist/cssm/components/Input/Input.d.ts +4 -1
  1281. package/dist/cssm/components/Input/Input.js +4 -0
  1282. package/dist/cssm/components/Input/Input.js.map +1 -1
  1283. package/dist/cssm/components/InputLike/InputLike.css +1 -1
  1284. package/dist/cssm/components/InputLike/InputLikeDivider.css +1 -1
  1285. package/dist/cssm/components/Link/Link.d.ts +4 -2
  1286. package/dist/cssm/components/Link/Link.js +6 -6
  1287. package/dist/cssm/components/Link/Link.js.map +1 -1
  1288. package/dist/cssm/components/List/List.d.ts +4 -2
  1289. package/dist/cssm/components/List/List.js +5 -5
  1290. package/dist/cssm/components/List/List.js.map +1 -1
  1291. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.d.ts +3 -0
  1292. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js +7 -3
  1293. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  1294. package/dist/cssm/components/ModalCard/ModalCard.d.ts +4 -2
  1295. package/dist/cssm/components/ModalCard/ModalCard.js +32 -24
  1296. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  1297. package/dist/cssm/components/ModalCardBase/ModalCardBase.d.ts +4 -1
  1298. package/dist/cssm/components/ModalCardBase/ModalCardBase.js +12 -8
  1299. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  1300. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.d.ts +4 -2
  1301. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js +13 -9
  1302. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  1303. package/dist/cssm/components/ModalPage/ModalPage.d.ts +4 -2
  1304. package/dist/cssm/components/ModalPage/ModalPage.js +36 -28
  1305. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  1306. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.d.ts +4 -2
  1307. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js +11 -23
  1308. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  1309. package/dist/cssm/components/ModalRoot/ModalRoot.css +1 -1
  1310. package/dist/cssm/components/ModalRoot/ModalRoot.js +1 -1
  1311. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  1312. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.d.ts +3 -0
  1313. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js +7 -5
  1314. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  1315. package/dist/cssm/components/ModalRoot/ModalRootContext.d.ts +1 -1
  1316. package/dist/cssm/components/ModalRoot/ModalRootContext.js +1 -3
  1317. package/dist/cssm/components/ModalRoot/ModalRootContext.js.map +1 -1
  1318. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +1 -1
  1319. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  1320. package/dist/cssm/components/ModalRoot/withModalRootContext.js +1 -1
  1321. package/dist/cssm/components/ModalRoot/withModalRootContext.js.map +1 -1
  1322. package/dist/cssm/components/NativeSelect/NativeSelect.d.ts +6 -1
  1323. package/dist/cssm/components/NativeSelect/NativeSelect.js +16 -19
  1324. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  1325. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.d.ts +1 -2
  1326. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  1327. package/dist/cssm/components/Pagination/Pagination.css +1 -1
  1328. package/dist/cssm/components/Pagination/Pagination.d.ts +3 -0
  1329. package/dist/cssm/components/Pagination/Pagination.js +4 -1
  1330. package/dist/cssm/components/Pagination/Pagination.js.map +1 -1
  1331. package/dist/cssm/components/Panel/Panel.css +1 -1
  1332. package/dist/cssm/components/Panel/Panel.d.ts +3 -0
  1333. package/dist/cssm/components/Panel/Panel.js +4 -0
  1334. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  1335. package/dist/cssm/components/PanelHeader/PanelHeader.css +1 -1
  1336. package/dist/cssm/components/PanelHeader/PanelHeader.d.ts +12 -2
  1337. package/dist/cssm/components/PanelHeader/PanelHeader.js +66 -41
  1338. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  1339. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.d.ts +5 -2
  1340. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js +11 -9
  1341. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  1342. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.css +1 -1
  1343. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.d.ts +3 -0
  1344. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js +7 -3
  1345. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  1346. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.d.ts +4 -2
  1347. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.js +6 -8
  1348. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  1349. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.css +1 -1
  1350. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.d.ts +4 -2
  1351. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js +11 -10
  1352. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  1353. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.d.ts +3 -0
  1354. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js +5 -1
  1355. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  1356. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +4 -2
  1357. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js +10 -12
  1358. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  1359. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +4 -2
  1360. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.js +6 -8
  1361. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  1362. package/dist/cssm/components/PanelSpinner/PanelSpinner.d.ts +4 -2
  1363. package/dist/cssm/components/PanelSpinner/PanelSpinner.js +9 -10
  1364. package/dist/cssm/components/PanelSpinner/PanelSpinner.js.map +1 -1
  1365. package/dist/cssm/components/Placeholder/Placeholder.d.ts +4 -2
  1366. package/dist/cssm/components/Placeholder/Placeholder.js +7 -7
  1367. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  1368. package/dist/cssm/components/PopoutRoot/PopoutRoot.js +3 -2
  1369. package/dist/cssm/components/PopoutRoot/PopoutRoot.js.map +1 -1
  1370. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.css +1 -1
  1371. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.d.ts +3 -0
  1372. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +5 -9
  1373. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  1374. package/dist/cssm/components/Popper/Popper.css +1 -1
  1375. package/dist/cssm/components/Popper/Popper.d.ts +3 -0
  1376. package/dist/cssm/components/Popper/Popper.js +4 -0
  1377. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  1378. package/dist/cssm/components/Progress/Progress.css +1 -1
  1379. package/dist/cssm/components/Progress/Progress.d.ts +4 -2
  1380. package/dist/cssm/components/Progress/Progress.js +7 -13
  1381. package/dist/cssm/components/Progress/Progress.js.map +1 -1
  1382. package/dist/cssm/components/PromoBanner/PromoBanner.d.ts +5 -2
  1383. package/dist/cssm/components/PromoBanner/PromoBanner.js +7 -7
  1384. package/dist/cssm/components/PromoBanner/PromoBanner.js.map +1 -1
  1385. package/dist/cssm/components/PullToRefresh/PullToRefresh.css +3 -1
  1386. package/dist/cssm/components/PullToRefresh/PullToRefresh.d.ts +9 -24
  1387. package/dist/cssm/components/PullToRefresh/PullToRefresh.js +210 -273
  1388. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  1389. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.d.ts +1 -2
  1390. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js +3 -10
  1391. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  1392. package/dist/cssm/components/Radio/Radio.css +1 -1
  1393. package/dist/cssm/components/Radio/Radio.d.ts +4 -2
  1394. package/dist/cssm/components/Radio/Radio.js +40 -20
  1395. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  1396. package/dist/cssm/components/RadioGroup/RadioGroup.css +1 -1
  1397. package/dist/cssm/components/RadioGroup/RadioGroup.d.ts +3 -0
  1398. package/dist/cssm/components/RadioGroup/RadioGroup.js +5 -4
  1399. package/dist/cssm/components/RadioGroup/RadioGroup.js.map +1 -1
  1400. package/dist/cssm/components/RangeSlider/RangeSlider.d.ts +4 -2
  1401. package/dist/cssm/components/RangeSlider/RangeSlider.js +5 -5
  1402. package/dist/cssm/components/RangeSlider/RangeSlider.js.map +1 -1
  1403. package/dist/cssm/components/RangeSlider/UniversalSlider.js +1 -5
  1404. package/dist/cssm/components/RangeSlider/UniversalSlider.js.map +1 -1
  1405. package/dist/cssm/components/Removable/Removable.css +1 -1
  1406. package/dist/cssm/components/Removable/Removable.d.ts +4 -1
  1407. package/dist/cssm/components/Removable/Removable.js +13 -4
  1408. package/dist/cssm/components/Removable/Removable.js.map +1 -1
  1409. package/dist/cssm/components/RichCell/RichCell.css +1 -1
  1410. package/dist/cssm/components/RichCell/RichCell.d.ts +14 -4
  1411. package/dist/cssm/components/RichCell/RichCell.js +15 -12
  1412. package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
  1413. package/dist/cssm/components/RichTooltip/RichTooltip.d.ts +3 -0
  1414. package/dist/cssm/components/RichTooltip/RichTooltip.js +4 -0
  1415. package/dist/cssm/components/RichTooltip/RichTooltip.js.map +1 -1
  1416. package/dist/cssm/components/Root/Root.css +1 -1
  1417. package/dist/cssm/components/Root/Root.d.ts +4 -2
  1418. package/dist/cssm/components/Root/Root.js +8 -19
  1419. package/dist/cssm/components/Root/Root.js.map +1 -1
  1420. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.d.ts +4 -2
  1421. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js +16 -14
  1422. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  1423. package/dist/cssm/components/Search/Search.css +1 -1
  1424. package/dist/cssm/components/Search/Search.d.ts +1 -2
  1425. package/dist/cssm/components/Search/Search.js +25 -22
  1426. package/dist/cssm/components/Search/Search.js.map +1 -1
  1427. package/dist/cssm/components/SegmentedControl/SegmentedControl.css +1 -1
  1428. package/dist/cssm/components/SegmentedControl/SegmentedControl.d.ts +3 -0
  1429. package/dist/cssm/components/SegmentedControl/SegmentedControl.js +10 -1
  1430. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  1431. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +1 -1
  1432. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +3 -0
  1433. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +19 -9
  1434. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  1435. package/dist/cssm/components/Select/Select.css +1 -1
  1436. package/dist/cssm/components/Select/Select.d.ts +13 -1
  1437. package/dist/cssm/components/Select/Select.js +56 -11
  1438. package/dist/cssm/components/Select/Select.js.map +1 -1
  1439. package/dist/cssm/components/SelectMimicry/SelectMimicry.d.ts +6 -5
  1440. package/dist/cssm/components/SelectMimicry/SelectMimicry.js +21 -30
  1441. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  1442. package/dist/cssm/components/Separator/Separator.css +1 -1
  1443. package/dist/cssm/components/Separator/Separator.d.ts +7 -2
  1444. package/dist/cssm/components/Separator/Separator.js +9 -18
  1445. package/dist/cssm/components/Separator/Separator.js.map +1 -1
  1446. package/dist/cssm/components/SimpleCell/SimpleCell.css +1 -1
  1447. package/dist/cssm/components/SimpleCell/SimpleCell.d.ts +4 -2
  1448. package/dist/cssm/components/SimpleCell/SimpleCell.js +11 -11
  1449. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  1450. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.d.ts +4 -0
  1451. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js +6 -1
  1452. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  1453. package/dist/cssm/components/Slider/Slider.css +3 -1
  1454. package/dist/cssm/components/Slider/Slider.d.ts +4 -2
  1455. package/dist/cssm/components/Slider/Slider.js +5 -5
  1456. package/dist/cssm/components/Slider/Slider.js.map +1 -1
  1457. package/dist/cssm/components/SliderSwitch/SliderSwitch.d.ts +1 -0
  1458. package/dist/cssm/components/SliderSwitch/SliderSwitch.js +1 -0
  1459. package/dist/cssm/components/SliderSwitch/SliderSwitch.js.map +1 -1
  1460. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js +3 -3
  1461. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  1462. package/dist/cssm/components/Snackbar/Snackbar.css +1 -1
  1463. package/dist/cssm/components/Snackbar/Snackbar.d.ts +3 -0
  1464. package/dist/cssm/components/Snackbar/Snackbar.js +5 -2
  1465. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  1466. package/dist/cssm/components/Spacing/Spacing.css +1 -1
  1467. package/dist/cssm/components/Spacing/Spacing.d.ts +6 -1
  1468. package/dist/cssm/components/Spacing/Spacing.js +8 -16
  1469. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  1470. package/dist/cssm/components/Spinner/Spinner.css +1 -1
  1471. package/dist/cssm/components/Spinner/Spinner.d.ts +5 -3
  1472. package/dist/cssm/components/Spinner/Spinner.js +20 -30
  1473. package/dist/cssm/components/Spinner/Spinner.js.map +1 -1
  1474. package/dist/cssm/components/SplitCol/SplitCol.css +1 -1
  1475. package/dist/cssm/components/SplitCol/SplitCol.d.ts +3 -0
  1476. package/dist/cssm/components/SplitCol/SplitCol.js +22 -6
  1477. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  1478. package/dist/cssm/components/SplitLayout/SplitLayout.css +1 -1
  1479. package/dist/cssm/components/SplitLayout/SplitLayout.d.ts +3 -0
  1480. package/dist/cssm/components/SplitLayout/SplitLayout.js +4 -0
  1481. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  1482. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.d.ts +3 -0
  1483. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js +4 -0
  1484. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  1485. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.d.ts +3 -0
  1486. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +5 -1
  1487. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  1488. package/dist/cssm/components/Switch/Switch.css +3 -1
  1489. package/dist/cssm/components/Switch/Switch.d.ts +3 -0
  1490. package/dist/cssm/components/Switch/Switch.js +5 -5
  1491. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  1492. package/dist/cssm/components/Tabbar/Tabbar.d.ts +4 -2
  1493. package/dist/cssm/components/Tabbar/Tabbar.js +9 -11
  1494. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  1495. package/dist/cssm/components/TabbarItem/TabbarItem.css +1 -1
  1496. package/dist/cssm/components/TabbarItem/TabbarItem.d.ts +4 -2
  1497. package/dist/cssm/components/TabbarItem/TabbarItem.js +7 -7
  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.d.ts +4 -2
  1501. package/dist/cssm/components/Tabs/Tabs.js +8 -6
  1502. package/dist/cssm/components/Tabs/Tabs.js.map +1 -1
  1503. package/dist/cssm/components/TabsItem/TabsItem.d.ts +4 -2
  1504. package/dist/cssm/components/TabsItem/TabsItem.js +13 -15
  1505. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  1506. package/dist/cssm/components/Tappable/Tappable.css +5 -1
  1507. package/dist/cssm/components/Tappable/Tappable.d.ts +7 -4
  1508. package/dist/cssm/components/Tappable/Tappable.js +38 -37
  1509. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  1510. package/dist/cssm/components/TextTooltip/TextTooltip.d.ts +3 -0
  1511. package/dist/cssm/components/TextTooltip/TextTooltip.js +4 -0
  1512. package/dist/cssm/components/TextTooltip/TextTooltip.js.map +1 -1
  1513. package/dist/cssm/components/Textarea/Textarea.css +1 -1
  1514. package/dist/cssm/components/Textarea/Textarea.d.ts +2 -3
  1515. package/dist/cssm/components/Textarea/Textarea.js +16 -9
  1516. package/dist/cssm/components/Textarea/Textarea.js.map +1 -1
  1517. package/dist/cssm/components/Tooltip/Tooltip.d.ts +4 -2
  1518. package/dist/cssm/components/Tooltip/Tooltip.js +11 -13
  1519. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  1520. package/dist/cssm/components/Touch/Touch.d.ts +3 -0
  1521. package/dist/cssm/components/Touch/Touch.js +4 -0
  1522. package/dist/cssm/components/Touch/Touch.js.map +1 -1
  1523. package/dist/cssm/components/Typography/Caption/Caption.css +1 -1
  1524. package/dist/cssm/components/Typography/Caption/Caption.d.ts +3 -0
  1525. package/dist/cssm/components/Typography/Caption/Caption.js +4 -0
  1526. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  1527. package/dist/cssm/components/Typography/Footnote/Footnote.css +1 -0
  1528. package/dist/cssm/components/Typography/Footnote/Footnote.d.ts +14 -0
  1529. package/dist/cssm/components/Typography/Footnote/Footnote.js +23 -0
  1530. package/dist/cssm/components/Typography/Footnote/Footnote.js.map +1 -0
  1531. package/dist/cssm/components/Typography/Headline/Headline.css +1 -1
  1532. package/dist/cssm/components/Typography/Headline/Headline.d.ts +11 -3
  1533. package/dist/cssm/components/Typography/Headline/Headline.js +17 -8
  1534. package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
  1535. package/dist/cssm/components/Typography/Paragraph/Paragraph.css +1 -1
  1536. package/dist/cssm/components/Typography/Paragraph/Paragraph.d.ts +3 -0
  1537. package/dist/cssm/components/Typography/Paragraph/Paragraph.js +4 -0
  1538. package/dist/cssm/components/Typography/Paragraph/Paragraph.js.map +1 -1
  1539. package/dist/cssm/components/Typography/Subhead/Subhead.css +1 -1
  1540. package/dist/cssm/components/Typography/Subhead/Subhead.d.ts +3 -0
  1541. package/dist/cssm/components/Typography/Subhead/Subhead.js +4 -0
  1542. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  1543. package/dist/cssm/components/Typography/Text/Text.css +1 -1
  1544. package/dist/cssm/components/Typography/Text/Text.d.ts +10 -3
  1545. package/dist/cssm/components/Typography/Text/Text.js +16 -12
  1546. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  1547. package/dist/cssm/components/Typography/Title/Title.css +1 -1
  1548. package/dist/cssm/components/Typography/Title/Title.d.ts +3 -0
  1549. package/dist/cssm/components/Typography/Title/Title.js +4 -0
  1550. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  1551. package/dist/cssm/components/UsersStack/UsersStack.css +5 -1
  1552. package/dist/cssm/components/UsersStack/UsersStack.d.ts +4 -2
  1553. package/dist/cssm/components/UsersStack/UsersStack.js +51 -39
  1554. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  1555. package/dist/cssm/components/UsersStack/masks.js +1 -1
  1556. package/dist/cssm/components/UsersStack/masks.js.map +1 -1
  1557. package/dist/cssm/components/View/View.css +1 -1
  1558. package/dist/cssm/components/View/View.d.ts +6 -3
  1559. package/dist/cssm/components/View/View.js +25 -36
  1560. package/dist/cssm/components/View/View.js.map +1 -1
  1561. package/dist/cssm/components/WriteBar/WriteBar.css +1 -1
  1562. package/dist/cssm/components/WriteBar/WriteBar.d.ts +3 -0
  1563. package/dist/cssm/components/WriteBar/WriteBar.js +4 -0
  1564. package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
  1565. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.d.ts +3 -0
  1566. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +6 -2
  1567. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1568. package/dist/cssm/hooks/useAdaptivity.d.ts +1 -0
  1569. package/dist/cssm/hooks/useAdaptivity.js +13 -1
  1570. package/dist/cssm/hooks/useAdaptivity.js.map +1 -1
  1571. package/dist/cssm/hooks/useKeyboard.d.ts +0 -1
  1572. package/dist/cssm/hooks/useKeyboard.js +2 -20
  1573. package/dist/cssm/hooks/useKeyboard.js.map +1 -1
  1574. package/dist/cssm/hooks/usePrevious.d.ts +1 -0
  1575. package/dist/cssm/hooks/usePrevious.js +9 -0
  1576. package/dist/cssm/hooks/usePrevious.js.map +1 -0
  1577. package/dist/cssm/hooks/useWaitTransitionFinish.js +2 -3
  1578. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  1579. package/dist/cssm/index.d.ts +67 -62
  1580. package/dist/cssm/index.js +63 -60
  1581. package/dist/cssm/index.js.map +1 -1
  1582. package/dist/cssm/lib/SSR.d.ts +3 -0
  1583. package/dist/cssm/lib/SSR.js +4 -0
  1584. package/dist/cssm/lib/SSR.js.map +1 -1
  1585. package/dist/cssm/lib/animate.d.ts +1 -1
  1586. package/dist/cssm/lib/animate.js +1 -2
  1587. package/dist/cssm/lib/animate.js.map +1 -1
  1588. package/dist/cssm/lib/select.d.ts +3 -1
  1589. package/dist/cssm/lib/select.js +14 -5
  1590. package/dist/cssm/lib/select.js.map +1 -1
  1591. package/dist/cssm/styles/common.css +1 -1
  1592. package/dist/cssm/styles/components.css +54 -18
  1593. package/dist/cssm/styles/constants.css +1 -1
  1594. package/dist/cssm/styles/themes.css +4 -4
  1595. package/dist/cssm/styles/unstable.css +1 -1
  1596. package/dist/cssm/tokenized/index.d.ts +84 -0
  1597. package/dist/cssm/tokenized/index.js +42 -0
  1598. package/dist/cssm/tokenized/index.js.map +1 -1
  1599. package/dist/default_scheme.css.map +1 -1
  1600. package/dist/hooks/useAdaptivity.d.ts +1 -0
  1601. package/dist/hooks/useAdaptivity.js +13 -1
  1602. package/dist/hooks/useAdaptivity.js.map +1 -1
  1603. package/dist/hooks/useKeyboard.d.ts +0 -1
  1604. package/dist/hooks/useKeyboard.js +2 -20
  1605. package/dist/hooks/useKeyboard.js.map +1 -1
  1606. package/dist/hooks/usePrevious.d.ts +1 -0
  1607. package/dist/hooks/usePrevious.js +9 -0
  1608. package/dist/hooks/usePrevious.js.map +1 -0
  1609. package/dist/hooks/useWaitTransitionFinish.js +2 -3
  1610. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  1611. package/dist/index.d.ts +67 -62
  1612. package/dist/index.js +63 -60
  1613. package/dist/index.js.map +1 -1
  1614. package/dist/lib/SSR.d.ts +3 -0
  1615. package/dist/lib/SSR.js +4 -0
  1616. package/dist/lib/SSR.js.map +1 -1
  1617. package/dist/lib/animate.d.ts +1 -1
  1618. package/dist/lib/animate.js +1 -2
  1619. package/dist/lib/animate.js.map +1 -1
  1620. package/dist/lib/select.d.ts +3 -1
  1621. package/dist/lib/select.js +14 -5
  1622. package/dist/lib/select.js.map +1 -1
  1623. package/dist/tokenized/index.d.ts +84 -0
  1624. package/dist/tokenized/index.js +42 -0
  1625. package/dist/tokenized/index.js.map +1 -1
  1626. package/dist/unstable.css +1 -1
  1627. package/dist/unstable.css.map +1 -1
  1628. package/dist/vkui.css +58 -22
  1629. package/dist/vkui.css.map +1 -1
  1630. package/jest.unit.config.js +2 -0
  1631. package/package.json +30 -6
  1632. package/postcss-custom-properties-fallback/__tests__/custom_properties.css +5 -0
  1633. package/postcss-custom-properties-fallback/index.js +83 -0
  1634. package/src/components/ActionSheet/ActionSheet.tsx +5 -6
  1635. package/src/components/ActionSheetItem/ActionSheetItem.tsx +10 -9
  1636. package/src/components/AdaptivityProvider/AdaptivityProvider.tsx +3 -0
  1637. package/src/components/Alert/Alert.tsx +201 -256
  1638. package/src/components/AppRoot/AppRoot.tsx +12 -12
  1639. package/src/components/AppRoot/ScrollContext.tsx +261 -0
  1640. package/src/components/AppearanceProvider/AppearanceProvider.tsx +3 -0
  1641. package/src/components/Avatar/Avatar.css +29 -22
  1642. package/src/components/Avatar/Avatar.tsx +6 -9
  1643. package/src/components/Avatar/Readme.md +43 -304
  1644. package/src/components/Badge/Badge.css +5 -2
  1645. package/src/components/Badge/Badge.tsx +6 -19
  1646. package/src/components/Banner/Banner.css +24 -25
  1647. package/src/components/Banner/Banner.tsx +38 -66
  1648. package/src/components/{Gallery/Gallery.css → BaseGallery/BaseGallery.css} +7 -3
  1649. package/src/components/BaseGallery/BaseGallery.tsx +394 -0
  1650. package/src/components/BaseGallery/helpers.ts +51 -0
  1651. package/src/components/BaseGallery/types.ts +52 -0
  1652. package/src/components/Button/Button.css +164 -29
  1653. package/src/components/Button/Button.tsx +22 -10
  1654. package/src/components/Button/Readme.md +5 -5
  1655. package/src/components/ButtonGroup/ButtonGroup.css +15 -3
  1656. package/src/components/ButtonGroup/ButtonGroup.tsx +3 -0
  1657. package/src/components/Calendar/Calendar.tsx +9 -0
  1658. package/src/components/CalendarDay/CalendarDay.tsx +1 -1
  1659. package/src/components/CalendarDays/CalendarDays.tsx +1 -6
  1660. package/src/components/CalendarHeader/CalendarHeader.css +6 -16
  1661. package/src/components/CalendarHeader/CalendarHeader.tsx +98 -94
  1662. package/src/components/CalendarRange/CalendarRange.tsx +9 -0
  1663. package/src/components/Card/Card.tsx +3 -0
  1664. package/src/components/CardGrid/CardGrid.tsx +3 -0
  1665. package/src/components/CardGrid/Readme.md +1 -1
  1666. package/src/components/CardScroll/CardScroll.tsx +3 -0
  1667. package/src/components/Cell/Cell.css +1 -1
  1668. package/src/components/Cell/Cell.tsx +15 -6
  1669. package/src/components/Cell/useDraggable.tsx +5 -5
  1670. package/src/components/CellButton/CellButton.css +11 -5
  1671. package/src/components/CellButton/CellButton.tsx +7 -13
  1672. package/src/components/Checkbox/Checkbox.css +42 -56
  1673. package/src/components/Checkbox/Checkbox.tsx +93 -35
  1674. package/src/components/Checkbox/Readme.md +19 -0
  1675. package/src/components/Chip/Chip.css +12 -6
  1676. package/src/components/Chip/Chip.tsx +11 -3
  1677. package/src/components/ChipsInput/ChipsInput.tsx +3 -0
  1678. package/src/components/ChipsSelect/ChipsSelect.css +0 -14
  1679. package/src/components/ChipsSelect/ChipsSelect.tsx +6 -2
  1680. package/src/components/ConfigProvider/ConfigProvider.tsx +4 -4
  1681. package/src/components/ContentCard/ContentCard.css +10 -18
  1682. package/src/components/ContentCard/ContentCard.tsx +49 -52
  1683. package/src/components/ContentCard/Readme.md +6 -0
  1684. package/src/components/Counter/Counter.css +25 -19
  1685. package/src/components/Counter/Counter.tsx +14 -43
  1686. package/src/components/CustomScrollView/CustomScrollView.css +12 -0
  1687. package/src/components/CustomScrollView/CustomScrollView.tsx +132 -125
  1688. package/src/components/CustomSelect/CustomSelect.css +2 -5
  1689. package/src/components/CustomSelect/CustomSelect.tsx +38 -37
  1690. package/src/components/CustomSelect/Readme.md +237 -228
  1691. package/src/components/CustomSelectDropdown/CustomSelectDropdown.css +19 -16
  1692. package/src/components/CustomSelectDropdown/CustomSelectDropdown.tsx +9 -7
  1693. package/src/components/CustomSelectOption/CustomSelectOption.tsx +3 -0
  1694. package/src/components/DateInput/DateInput.tsx +11 -2
  1695. package/src/components/DatePicker/DatePicker.tsx +7 -3
  1696. package/src/components/DateRangeInput/DateRangeInput.tsx +10 -1
  1697. package/src/components/Div/Div.css +2 -5
  1698. package/src/components/Div/Div.tsx +4 -8
  1699. package/src/components/Dropdown/Dropdown.tsx +3 -0
  1700. package/src/components/Epic/Epic.tsx +7 -3
  1701. package/src/components/Epic/Readme.md +7 -5
  1702. package/src/components/Epic/ScrollSaver.tsx +3 -0
  1703. package/src/components/File/File.tsx +30 -39
  1704. package/src/components/File/Readme.md +7 -4
  1705. package/src/components/FixedLayout/FixedLayout.css +24 -3
  1706. package/src/components/FixedLayout/FixedLayout.tsx +8 -10
  1707. package/src/components/FocusTrap/FocusTrap.tsx +3 -0
  1708. package/src/components/FocusVisible/FocusVisible.css +1 -1
  1709. package/src/components/FocusVisible/FocusVisible.tsx +5 -5
  1710. package/src/components/Footer/Footer.css +1 -1
  1711. package/src/components/Footer/Footer.tsx +3 -0
  1712. package/src/components/FormField/FormField.css +38 -31
  1713. package/src/components/FormField/FormField.tsx +14 -8
  1714. package/src/components/FormItem/FormItem.css +23 -13
  1715. package/src/components/FormItem/FormItem.tsx +6 -6
  1716. package/src/components/FormLayout/FormLayout.tsx +6 -4
  1717. package/src/components/FormLayoutGroup/FormLayoutGroup.css +3 -1
  1718. package/src/components/FormLayoutGroup/FormLayoutGroup.tsx +6 -9
  1719. package/src/components/FormStatus/FormStatus.tsx +5 -2
  1720. package/src/components/Gallery/Gallery.tsx +13 -512
  1721. package/src/components/Gradient/Gradient.tsx +3 -0
  1722. package/src/components/GridAvatar/GridAvatar.tsx +21 -15
  1723. package/src/components/Group/Group.tsx +9 -9
  1724. package/src/components/Group/Readme.md +129 -134
  1725. package/src/components/Header/Header.tsx +16 -52
  1726. package/src/components/HorizontalCell/HorizontalCell.tsx +5 -2
  1727. package/src/components/HorizontalScroll/HorizontalScroll.tsx +7 -1
  1728. package/src/components/HorizontalScroll/HorizontalScrollArrow.tsx +1 -1
  1729. package/src/components/IconButton/IconButton.css +14 -19
  1730. package/src/components/IconButton/IconButton.tsx +15 -13
  1731. package/src/components/IconButton/Readme.md +51 -0
  1732. package/src/components/InfoRow/InfoRow.css +1 -1
  1733. package/src/components/InfoRow/InfoRow.tsx +15 -25
  1734. package/src/components/InitialsAvatar/InitialsAvatar.css +26 -29
  1735. package/src/components/InitialsAvatar/InitialsAvatar.tsx +5 -2
  1736. package/src/components/Input/Input.tsx +3 -0
  1737. package/src/components/Link/Link.tsx +8 -5
  1738. package/src/components/List/List.tsx +6 -7
  1739. package/src/components/MiniInfoCell/MiniInfoCell.tsx +6 -3
  1740. package/src/components/MiniInfoCell/Readme.md +2 -2
  1741. package/src/components/ModalCard/ModalCard.tsx +33 -34
  1742. package/src/components/ModalCardBase/ModalCardBase.tsx +12 -15
  1743. package/src/components/ModalDismissButton/ModalDismissButton.tsx +10 -12
  1744. package/src/components/ModalPage/ModalPage.tsx +39 -38
  1745. package/src/components/ModalPageHeader/ModalPageHeader.tsx +13 -21
  1746. package/src/components/ModalPageHeader/Readme.md +3 -3
  1747. package/src/components/ModalRoot/ModalRoot.css +1 -1
  1748. package/src/components/ModalRoot/ModalRoot.tsx +2 -1
  1749. package/src/components/ModalRoot/ModalRootAdaptive.tsx +6 -9
  1750. package/src/components/ModalRoot/ModalRootContext.tsx +0 -3
  1751. package/src/components/ModalRoot/ModalRootDesktop.tsx +2 -1
  1752. package/src/components/ModalRoot/Readme.md +18 -18
  1753. package/src/components/ModalRoot/withModalRootContext.tsx +2 -1
  1754. package/src/components/NativeSelect/NativeSelect.tsx +22 -24
  1755. package/src/components/NavTransitionContext/NavTransitionContext.tsx +2 -1
  1756. package/src/components/Pagination/Pagination.tsx +4 -1
  1757. package/src/components/Panel/Panel.css +3 -3
  1758. package/src/components/Panel/Panel.tsx +3 -0
  1759. package/src/components/Panel/Readme.md +2 -2
  1760. package/src/components/PanelHeader/PanelHeader.css +45 -68
  1761. package/src/components/PanelHeader/PanelHeader.tsx +83 -53
  1762. package/src/components/PanelHeader/Readme.md +13 -13
  1763. package/src/components/PanelHeaderBack/PanelHeaderBack.tsx +12 -8
  1764. package/src/components/PanelHeaderBack/Readme.md +1 -1
  1765. package/src/components/PanelHeaderButton/PanelHeaderButton.tsx +7 -5
  1766. package/src/components/PanelHeaderButton/Readme.md +3 -3
  1767. package/src/components/PanelHeaderClose/PanelHeaderClose.tsx +6 -11
  1768. package/src/components/PanelHeaderClose/Readme.md +1 -1
  1769. package/src/components/PanelHeaderContent/PanelHeaderContent.css +1 -1
  1770. package/src/components/PanelHeaderContent/PanelHeaderContent.tsx +11 -9
  1771. package/src/components/PanelHeaderContent/Readme.md +2 -2
  1772. package/src/components/PanelHeaderContext/PanelHeaderContext.tsx +4 -1
  1773. package/src/components/PanelHeaderContext/Readme.md +2 -2
  1774. package/src/components/PanelHeaderEdit/PanelHeaderEdit.tsx +7 -13
  1775. package/src/components/PanelHeaderSubmit/PanelHeaderSubmit.tsx +6 -11
  1776. package/src/components/PanelHeaderSubmit/Readme.md +1 -1
  1777. package/src/components/PanelSpinner/PanelSpinner.tsx +10 -14
  1778. package/src/components/PanelSpinner/Readme.md +1 -1
  1779. package/src/components/Placeholder/Placeholder.tsx +8 -6
  1780. package/src/components/Placeholder/Readme.md +2 -2
  1781. package/src/components/PopoutRoot/PopoutRoot.tsx +3 -8
  1782. package/src/components/PopoutWrapper/PopoutWrapper.css +4 -15
  1783. package/src/components/PopoutWrapper/PopoutWrapper.tsx +8 -11
  1784. package/src/components/Popper/Popper.css +14 -2
  1785. package/src/components/Popper/Popper.tsx +3 -0
  1786. package/src/components/Progress/Progress.css +2 -2
  1787. package/src/components/Progress/Progress.tsx +6 -11
  1788. package/src/components/Progress/Readme.md +11 -13
  1789. package/src/components/PromoBanner/PromoBanner.tsx +7 -6
  1790. package/src/components/PullToRefresh/PullToRefresh.css +11 -9
  1791. package/src/components/PullToRefresh/PullToRefresh.tsx +210 -281
  1792. package/src/components/PullToRefresh/PullToRefreshSpinner.tsx +5 -10
  1793. package/src/components/PullToRefresh/Readme.md +37 -56
  1794. package/src/components/Radio/Radio.css +13 -99
  1795. package/src/components/Radio/Radio.tsx +43 -23
  1796. package/src/components/RadioGroup/RadioGroup.css +1 -1
  1797. package/src/components/RadioGroup/RadioGroup.tsx +11 -17
  1798. package/src/components/RangeSlider/RangeSlider.tsx +4 -4
  1799. package/src/components/RangeSlider/Readme.md +19 -27
  1800. package/src/components/RangeSlider/UniversalSlider.tsx +1 -4
  1801. package/src/components/Removable/Removable.css +17 -21
  1802. package/src/components/Removable/Removable.tsx +12 -4
  1803. package/src/components/RichCell/Readme.md +14 -6
  1804. package/src/components/RichCell/RichCell.css +2 -10
  1805. package/src/components/RichCell/RichCell.tsx +27 -19
  1806. package/src/components/RichTooltip/Readme.md +1 -1
  1807. package/src/components/RichTooltip/RichTooltip.tsx +3 -0
  1808. package/src/components/Root/Root.css +9 -14
  1809. package/src/components/Root/Root.tsx +30 -21
  1810. package/src/components/ScreenSpinner/ScreenSpinner.tsx +17 -14
  1811. package/src/components/Search/Readme.md +4 -4
  1812. package/src/components/Search/Search.tsx +17 -23
  1813. package/src/components/SegmentedControl/SegmentedControl.css +14 -2
  1814. package/src/components/SegmentedControl/SegmentedControl.tsx +12 -1
  1815. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.tsx +27 -9
  1816. package/src/components/Select/Select.css +12 -8
  1817. package/src/components/Select/Select.tsx +47 -0
  1818. package/src/components/SelectMimicry/SelectMimicry.tsx +26 -44
  1819. package/src/components/Separator/Readme.md +3 -5
  1820. package/src/components/Separator/Separator.css +4 -12
  1821. package/src/components/Separator/Separator.tsx +25 -26
  1822. package/src/components/SimpleCell/Readme.md +1 -1
  1823. package/src/components/SimpleCell/SimpleCell.css +4 -53
  1824. package/src/components/SimpleCell/SimpleCell.tsx +10 -8
  1825. package/src/components/SimpleCheckbox/Readme.md +4 -0
  1826. package/src/components/SimpleCheckbox/SimpleCheckbox.tsx +5 -1
  1827. package/src/components/Slider/Readme.md +68 -76
  1828. package/src/components/Slider/Slider.css +9 -49
  1829. package/src/components/Slider/Slider.tsx +4 -4
  1830. package/src/components/SliderSwitch/SliderSwitch.tsx +2 -0
  1831. package/src/components/SliderSwitch/SliderSwitchButton.tsx +3 -3
  1832. package/src/components/Snackbar/Snackbar.css +6 -2
  1833. package/src/components/Snackbar/Snackbar.tsx +5 -4
  1834. package/src/components/Spacing/Readme.md +14 -6
  1835. package/src/components/Spacing/Spacing.css +7 -12
  1836. package/src/components/Spacing/Spacing.tsx +15 -17
  1837. package/src/components/Spinner/Spinner.css +1 -1
  1838. package/src/components/Spinner/Spinner.tsx +29 -39
  1839. package/src/components/SplitCol/SplitCol.css +1 -1
  1840. package/src/components/SplitCol/SplitCol.tsx +28 -6
  1841. package/src/components/SplitLayout/Readme.md +3 -3
  1842. package/src/components/SplitLayout/SplitLayout.css +2 -2
  1843. package/src/components/SplitLayout/SplitLayout.tsx +3 -0
  1844. package/src/components/SubnavigationBar/Readme.md +5 -3
  1845. package/src/components/SubnavigationBar/SubnavigationBar.tsx +3 -0
  1846. package/src/components/SubnavigationButton/SubnavigationButton.tsx +4 -1
  1847. package/src/components/Switch/Switch.css +111 -121
  1848. package/src/components/Switch/Switch.tsx +5 -5
  1849. package/src/components/Tabbar/Tabbar.tsx +9 -9
  1850. package/src/components/TabbarItem/TabbarItem.tsx +7 -6
  1851. package/src/components/Tabs/Readme.md +6 -6
  1852. package/src/components/Tabs/Tabs.tsx +7 -7
  1853. package/src/components/TabsItem/TabsItem.tsx +12 -20
  1854. package/src/components/Tappable/Readme.md +53 -0
  1855. package/src/components/Tappable/Tappable.css +12 -27
  1856. package/src/components/Tappable/Tappable.tsx +50 -33
  1857. package/src/components/TextTooltip/TextTooltip.tsx +3 -0
  1858. package/src/components/Textarea/Readme.md +1 -2
  1859. package/src/components/Textarea/Textarea.css +12 -8
  1860. package/src/components/Textarea/Textarea.tsx +57 -55
  1861. package/src/components/Tooltip/Readme.md +36 -48
  1862. package/src/components/Tooltip/Tooltip.tsx +7 -12
  1863. package/src/components/Touch/Touch.tsx +3 -0
  1864. package/src/components/Typography/Caption/Caption.tsx +3 -0
  1865. package/src/components/Typography/Footnote/Footnote.css +26 -0
  1866. package/src/components/Typography/Footnote/Footnote.tsx +38 -0
  1867. package/src/components/Typography/Footnote/Readme.md +18 -0
  1868. package/src/components/Typography/Headline/Headline.css +39 -2
  1869. package/src/components/Typography/Headline/Headline.tsx +19 -8
  1870. package/src/components/Typography/Headline/Readme.md +23 -21
  1871. package/src/components/Typography/Paragraph/Paragraph.tsx +4 -0
  1872. package/src/components/Typography/Subhead/Subhead.tsx +4 -0
  1873. package/src/components/Typography/Text/Readme.md +16 -19
  1874. package/src/components/Typography/Text/Text.css +22 -7
  1875. package/src/components/Typography/Text/Text.tsx +28 -12
  1876. package/src/components/Typography/Title/Title.tsx +4 -0
  1877. package/src/components/UsersStack/Readme.md +0 -1
  1878. package/src/components/UsersStack/UsersStack.css +12 -30
  1879. package/src/components/UsersStack/UsersStack.tsx +52 -43
  1880. package/src/components/UsersStack/masks.tsx +28 -5
  1881. package/src/components/View/View.css +1 -13
  1882. package/src/components/View/View.tsx +40 -40
  1883. package/src/components/WriteBar/WriteBar.tsx +3 -0
  1884. package/src/components/WriteBarIcon/WriteBarIcon.tsx +5 -2
  1885. package/src/hooks/useAdaptivity.ts +15 -0
  1886. package/src/hooks/useKeyboard.ts +3 -20
  1887. package/src/hooks/usePrevious.ts +11 -0
  1888. package/src/hooks/useWaitTransitionFinish.ts +22 -19
  1889. package/src/index.ts +67 -62
  1890. package/src/lib/SSR.tsx +3 -0
  1891. package/src/lib/animate.ts +1 -2
  1892. package/src/lib/select.ts +20 -4
  1893. package/src/styles/components.css +4 -5
  1894. package/src/styles/constants.css +2 -3
  1895. package/src/styles/themes.css +1 -0
  1896. package/src/testing/utils.tsx +8 -1
  1897. package/src/tokenized/index.ts +126 -0
  1898. package/tasks/postcss-restructure-variable.js +226 -0
  1899. package/tasks/postcss-scope-root.js +5 -1
  1900. package/tsconfig.json +1 -0
  1901. package/dist/cssm/components/File/File.css +0 -1
  1902. package/dist/cssm/components/Gallery/Gallery.css +0 -1
  1903. package/dist/cssm/components/SelectMimicry/SelectMimicry.css +0 -1
  1904. package/src/components/AppRoot/ScrollContext.ts +0 -132
  1905. package/src/components/File/File.css +0 -6
  1906. package/src/components/SelectMimicry/SelectMimicry.css +0 -10
@@ -33,5 +33,7 @@ export interface ModalPageProps extends React.HTMLAttributes<HTMLDivElement>, Ad
33
33
  dynamicContentHeight?: boolean;
34
34
  getModalContentRef?: React.Ref<HTMLDivElement>;
35
35
  }
36
- declare const _default: React.FC<Pick<ModalPageProps & AdaptivityContextInterface, "hidden" | "dir" | "header" | "nav" | "slot" | "style" | "title" | "color" | "translate" | "prefix" | "children" | "className" | "id" | "lang" | "role" | "tabIndex" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "draggable" | "placeholder" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "onOpen" | "onOpened" | "onClose" | "onClosed" | "settlingHeight" | "dynamicContentHeight" | "getModalContentRef"> & import("../AdaptivityProvider/AdaptivityContext").SizeProps>;
37
- export default _default;
36
+ /**
37
+ * @see https://vkcom.github.io/VKUI/#/ModalPage
38
+ */
39
+ export declare const ModalPage: React.FC<Pick<ModalPageProps & AdaptivityContextInterface, "hidden" | "dir" | "header" | "nav" | "slot" | "style" | "title" | "color" | "translate" | "prefix" | "children" | "className" | "id" | "lang" | "role" | "tabIndex" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "draggable" | "placeholder" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "onOpen" | "onOpened" | "onClose" | "onClosed" | "settlingHeight" | "dynamicContentHeight" | "getModalContentRef"> & import("../AdaptivityProvider/AdaptivityContext").SizeProps>;
@@ -7,7 +7,7 @@ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWild
7
7
  Object.defineProperty(exports, "__esModule", {
8
8
  value: true
9
9
  });
10
- exports.default = void 0;
10
+ exports.ModalPage = void 0;
11
11
 
12
12
  var _jsxRuntime = require("../../lib/jsxRuntime");
13
13
 
@@ -29,7 +29,7 @@ var _useOrientationChange = require("../../hooks/useOrientationChange");
29
29
 
30
30
  var _withAdaptivity = require("../../hoc/withAdaptivity");
31
31
 
32
- var _ModalDismissButton = _interopRequireDefault(require("../ModalDismissButton/ModalDismissButton"));
32
+ var _ModalDismissButton = require("../ModalDismissButton/ModalDismissButton");
33
33
 
34
34
  var _utils = require("../../lib/utils");
35
35
 
@@ -39,40 +39,50 @@ var _getNavId = require("../../lib/getNavId");
39
39
 
40
40
  var _warnOnce = require("../../lib/warnOnce");
41
41
 
42
- var _excluded = ["children", "header", "viewWidth", "viewHeight", "sizeX", "hasMouse", "onOpen", "onOpened", "onClose", "onClosed", "settlingHeight", "dynamicContentHeight", "getModalContentRef", "nav"];
42
+ var _platform = require("../../lib/platform");
43
+
44
+ var _useAdaptivity = require("../../hooks/useAdaptivity");
45
+
46
+ var _excluded = ["children", "header", "viewWidth", "viewHeight", "sizeX", "hasMouse", "onOpen", "onOpened", "onClose", "onClosed", "settlingHeight", "dynamicContentHeight", "getModalContentRef", "nav", "id"];
43
47
  var warn = (0, _warnOnce.warnOnce)("ModalPage");
44
48
 
45
- var ModalPage = function ModalPage(props) {
49
+ var ModalPageComponent = function ModalPageComponent(_ref) {
50
+ var children = _ref.children,
51
+ header = _ref.header,
52
+ viewWidth = _ref.viewWidth,
53
+ viewHeight = _ref.viewHeight,
54
+ sizeX = _ref.sizeX,
55
+ hasMouse = _ref.hasMouse,
56
+ onOpen = _ref.onOpen,
57
+ onOpened = _ref.onOpened,
58
+ onClose = _ref.onClose,
59
+ onClosed = _ref.onClosed,
60
+ settlingHeight = _ref.settlingHeight,
61
+ dynamicContentHeight = _ref.dynamicContentHeight,
62
+ getModalContentRef = _ref.getModalContentRef,
63
+ nav = _ref.nav,
64
+ id = _ref.id,
65
+ restProps = (0, _objectWithoutProperties2.default)(_ref, _excluded);
66
+
46
67
  var _React$useContext = React.useContext(_ModalRootContext.ModalRootContext),
47
68
  updateModalHeight = _React$useContext.updateModalHeight;
48
69
 
49
- var children = props.children,
50
- header = props.header,
51
- viewWidth = props.viewWidth,
52
- viewHeight = props.viewHeight,
53
- sizeX = props.sizeX,
54
- hasMouse = props.hasMouse,
55
- onOpen = props.onOpen,
56
- onOpened = props.onOpened,
57
- onClose = props.onClose,
58
- onClosed = props.onClosed,
59
- settlingHeight = props.settlingHeight,
60
- dynamicContentHeight = props.dynamicContentHeight,
61
- getModalContentRef = props.getModalContentRef,
62
- nav = props.nav,
63
- restProps = (0, _objectWithoutProperties2.default)(props, _excluded);
64
70
  var platform = (0, _usePlatform.usePlatform)();
65
71
  var orientation = (0, _useOrientationChange.useOrientationChange)();
66
72
  React.useEffect(updateModalHeight, [children, orientation, updateModalHeight]);
67
- var isDesktop = viewWidth >= _withAdaptivity.ViewWidth.SMALL_TABLET && (hasMouse || viewHeight >= _withAdaptivity.ViewHeight.MEDIUM);
68
- var canShowCloseBtn = viewWidth >= _withAdaptivity.ViewWidth.SMALL_TABLET;
73
+ var isDesktop = (0, _useAdaptivity.useAdaptivityIsDesktop)();
74
+ var canShowCloseBtn = viewWidth >= _withAdaptivity.ViewWidth.SMALL_TABLET || platform === _platform.Platform.VKCOM;
69
75
  var modalContext = React.useContext(_ModalRootContext.ModalRootContext);
70
76
 
71
- var _useModalRegistry = (0, _ModalRootContext.useModalRegistry)((0, _getNavId.getNavId)(props, warn), _types.ModalType.PAGE),
77
+ var _useModalRegistry = (0, _ModalRootContext.useModalRegistry)((0, _getNavId.getNavId)({
78
+ nav: nav,
79
+ id: id
80
+ }, warn), _types.ModalType.PAGE),
72
81
  refs = _useModalRegistry.refs;
73
82
 
74
83
  return (0, _jsxRuntime.createScopedElement)("div", (0, _extends2.default)({}, restProps, {
75
- // eslint-disable-next-line vkui/no-object-expression-in-arguments
84
+ id: id // eslint-disable-next-line vkui/no-object-expression-in-arguments
85
+ ,
76
86
  vkuiClass: (0, _classNames.classNames)((0, _getClassName.getClassName)("ModalPage", platform), "ModalPage--sizeX-".concat(sizeX), {
77
87
  "ModalPage--desktop": isDesktop
78
88
  })
@@ -91,21 +101,21 @@ var ModalPage = function ModalPage(props) {
91
101
  ref: (0, _utils.multiRef)(refs.contentElement, getModalContentRef)
92
102
  }, (0, _jsxRuntime.createScopedElement)("div", {
93
103
  vkuiClass: "ModalPage__content-in"
94
- }, children))), canShowCloseBtn && (0, _jsxRuntime.createScopedElement)(_ModalDismissButton.default, {
104
+ }, children))), canShowCloseBtn && (0, _jsxRuntime.createScopedElement)(_ModalDismissButton.ModalDismissButton, {
95
105
  onClick: onClose || modalContext.onClose
96
106
  }))));
97
107
  };
108
+ /**
109
+ * @see https://vkcom.github.io/VKUI/#/ModalPage
110
+ */
98
111
 
99
- ModalPage.defaultProps = {
100
- settlingHeight: 75
101
- }; // eslint-disable-next-line import/no-default-export
102
112
 
103
- var _default = (0, _withAdaptivity.withAdaptivity)(ModalPage, {
113
+ var ModalPage = (0, _withAdaptivity.withAdaptivity)(ModalPageComponent, {
104
114
  viewWidth: true,
105
115
  viewHeight: true,
106
116
  sizeX: true,
107
117
  hasMouse: true
108
118
  });
109
-
110
- exports.default = _default;
119
+ exports.ModalPage = ModalPage;
120
+ ModalPage.displayName = "ModalPage";
111
121
  //# sourceMappingURL=ModalPage.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalPage/ModalPage.tsx"],"names":["warn","ModalPage","props","React","useContext","ModalRootContext","updateModalHeight","children","header","viewWidth","viewHeight","sizeX","hasMouse","onOpen","onOpened","onClose","onClosed","settlingHeight","dynamicContentHeight","getModalContentRef","nav","restProps","platform","orientation","useEffect","isDesktop","ViewWidth","SMALL_TABLET","ViewHeight","MEDIUM","canShowCloseBtn","modalContext","ModalType","PAGE","refs","innerElement","headerElement","contentElement","defaultProps"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport {\n ModalRootContext,\n useModalRegistry,\n} from \"../ModalRoot/ModalRootContext\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useOrientationChange } from \"../../hooks/useOrientationChange\";\nimport {\n withAdaptivity,\n ViewHeight,\n ViewWidth,\n} from \"../../hoc/withAdaptivity\";\nimport {\n AdaptivityContextInterface,\n AdaptivityProps,\n} from \"../AdaptivityProvider/AdaptivityContext\";\nimport ModalDismissButton from \"../ModalDismissButton/ModalDismissButton\";\nimport { multiRef } from \"../../lib/utils\";\nimport { ModalType } from \"../ModalRoot/types\";\nimport { getNavId, NavIdProps } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport \"./ModalPage.css\";\n\nexport interface ModalPageProps\n extends React.HTMLAttributes<HTMLDivElement>,\n AdaptivityProps,\n NavIdProps {\n /**\n * Шапка модальной страницы, `<ModalPageHeader />`\n */\n header?: React.ReactNode;\n /**\n * Будет вызвано при начале открытия модалки.\n */\n onOpen?: VoidFunction;\n /**\n * Будет вызвано при окончательном открытии модалки.\n */\n onOpened?: VoidFunction;\n /**\n * Будет вызвано при начале закрытия модалки.\n */\n onClose?: VoidFunction;\n /**\n * Будет вызвано при окончательном закрытии модалки.\n */\n onClosed?: VoidFunction;\n /**\n * Процент, на который изначально будет открыта модальная страница. При `settlingHeight={100}` модальная страница раскрывается на всю высоту.\n */\n settlingHeight?: number;\n /**\n * Если высота контента в модальной странице может поменяться, нужно установить это свойство\n */\n dynamicContentHeight?: boolean;\n getModalContentRef?: React.Ref<HTMLDivElement>;\n}\n\nconst warn = warnOnce(\"ModalPage\");\nconst ModalPage: React.FC<ModalPageProps & AdaptivityContextInterface> = (\n props\n) => {\n const { updateModalHeight } = React.useContext(ModalRootContext);\n\n const {\n children,\n header,\n viewWidth,\n viewHeight,\n sizeX,\n hasMouse,\n onOpen,\n onOpened,\n onClose,\n onClosed,\n settlingHeight,\n dynamicContentHeight,\n getModalContentRef,\n nav,\n ...restProps\n } = props;\n\n const platform = usePlatform();\n const orientation = useOrientationChange();\n\n React.useEffect(updateModalHeight, [\n children,\n orientation,\n updateModalHeight,\n ]);\n\n const isDesktop =\n viewWidth >= ViewWidth.SMALL_TABLET &&\n (hasMouse || viewHeight >= ViewHeight.MEDIUM);\n const canShowCloseBtn = viewWidth >= ViewWidth.SMALL_TABLET;\n\n const modalContext = React.useContext(ModalRootContext);\n const { refs } = useModalRegistry(getNavId(props, warn), ModalType.PAGE);\n\n return (\n <div\n {...restProps}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"ModalPage\", platform),\n `ModalPage--sizeX-${sizeX}`,\n {\n \"ModalPage--desktop\": isDesktop,\n }\n )}\n >\n <div vkuiClass=\"ModalPage__in-wrap\" ref={refs.innerElement}>\n <div vkuiClass=\"ModalPage__in\">\n <div vkuiClass=\"ModalPage__header\" ref={refs.headerElement}>\n {header}\n </div>\n\n <div vkuiClass=\"ModalPage__content-wrap\">\n <div\n vkuiClass=\"ModalPage__content\"\n ref={multiRef<HTMLDivElement>(\n refs.contentElement,\n getModalContentRef\n )}\n >\n <div vkuiClass=\"ModalPage__content-in\">{children}</div>\n </div>\n </div>\n {canShowCloseBtn && (\n <ModalDismissButton onClick={onClose || modalContext.onClose} />\n )}\n </div>\n </div>\n </div>\n );\n};\n\nModalPage.defaultProps = {\n settlingHeight: 75,\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default withAdaptivity(ModalPage, {\n viewWidth: true,\n viewHeight: true,\n sizeX: true,\n hasMouse: true,\n});\n"],"file":"ModalPage.js"}
1
+ {"version":3,"sources":["../../../../src/components/ModalPage/ModalPage.tsx"],"names":["warn","ModalPageComponent","children","header","viewWidth","viewHeight","sizeX","hasMouse","onOpen","onOpened","onClose","onClosed","settlingHeight","dynamicContentHeight","getModalContentRef","nav","id","restProps","React","useContext","ModalRootContext","updateModalHeight","platform","orientation","useEffect","isDesktop","canShowCloseBtn","ViewWidth","SMALL_TABLET","Platform","VKCOM","modalContext","ModalType","PAGE","refs","innerElement","headerElement","contentElement","ModalPage","displayName"],"mappings":";;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AAIA;;AACA;;AACA;;AAKA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;AAsCA,IAAMA,IAAI,GAAG,wBAAS,WAAT,CAAb;;AAEA,IAAMC,kBAEL,GAAG,SAFEA,kBAEF,OAiBE;AAAA,MAhBJC,QAgBI,QAhBJA,QAgBI;AAAA,MAfJC,MAeI,QAfJA,MAeI;AAAA,MAdJC,SAcI,QAdJA,SAcI;AAAA,MAbJC,UAaI,QAbJA,UAaI;AAAA,MAZJC,KAYI,QAZJA,KAYI;AAAA,MAXJC,QAWI,QAXJA,QAWI;AAAA,MAVJC,MAUI,QAVJA,MAUI;AAAA,MATJC,QASI,QATJA,QASI;AAAA,MARJC,OAQI,QARJA,OAQI;AAAA,MAPJC,QAOI,QAPJA,QAOI;AAAA,MANJC,cAMI,QANJA,cAMI;AAAA,MALJC,oBAKI,QALJA,oBAKI;AAAA,MAJJC,kBAII,QAJJA,kBAII;AAAA,MAHJC,GAGI,QAHJA,GAGI;AAAA,MAFJC,EAEI,QAFJA,EAEI;AAAA,MADDC,SACC;;AACJ,0BAA8BC,KAAK,CAACC,UAAN,CAAiBC,kCAAjB,CAA9B;AAAA,MAAQC,iBAAR,qBAAQA,iBAAR;;AAEA,MAAMC,QAAQ,GAAG,+BAAjB;AACA,MAAMC,WAAW,GAAG,iDAApB;AAEAL,EAAAA,KAAK,CAACM,SAAN,CAAgBH,iBAAhB,EAAmC,CACjCnB,QADiC,EAEjCqB,WAFiC,EAGjCF,iBAHiC,CAAnC;AAMA,MAAMI,SAAS,GAAG,4CAAlB;AACA,MAAMC,eAAe,GACnBtB,SAAS,IAAIuB,0BAAUC,YAAvB,IAAuCN,QAAQ,KAAKO,mBAASC,KAD/D;AAGA,MAAMC,YAAY,GAAGb,KAAK,CAACC,UAAN,CAAiBC,kCAAjB,CAArB;;AACA,0BAAiB,wCACf,wBAAS;AAAEL,IAAAA,GAAG,EAAHA,GAAF;AAAOC,IAAAA,EAAE,EAAFA;AAAP,GAAT,EAAsBhB,IAAtB,CADe,EAEfgC,iBAAUC,IAFK,CAAjB;AAAA,MAAQC,IAAR,qBAAQA,IAAR;;AAKA,SACE,uEACMjB,SADN;AAEE,IAAA,EAAE,EAAED,EAFN,CAGE;AAHF;AAIE,IAAA,SAAS,EAAE,4BACT,gCAAa,WAAb,EAA0BM,QAA1B,CADS,6BAEWhB,KAFX,GAGT;AACE,4BAAsBmB;AADxB,KAHS;AAJb,MAYE;AAAK,IAAA,SAAS,EAAC,oBAAf;AAAoC,IAAA,GAAG,EAAES,IAAI,CAACC;AAA9C,KACE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE;AAAK,IAAA,SAAS,EAAC,mBAAf;AAAmC,IAAA,GAAG,EAAED,IAAI,CAACE;AAA7C,KACGjC,MADH,CADF,EAKE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE;AACE,IAAA,SAAS,EAAC,oBADZ;AAEE,IAAA,GAAG,EAAE,qBACH+B,IAAI,CAACG,cADF,EAEHvB,kBAFG;AAFP,KAOE;AAAK,IAAA,SAAS,EAAC;AAAf,KAAwCZ,QAAxC,CAPF,CADF,CALF,EAgBGwB,eAAe,IACd,qCAAC,sCAAD;AAAoB,IAAA,OAAO,EAAEhB,OAAO,IAAIqB,YAAY,CAACrB;AAArD,IAjBJ,CADF,CAZF,CADF;AAqCD,CA9ED;AAgFA;AACA;AACA;;;AACO,IAAM4B,SAAS,GAAG,oCAAerC,kBAAf,EAAmC;AAC1DG,EAAAA,SAAS,EAAE,IAD+C;AAE1DC,EAAAA,UAAU,EAAE,IAF8C;AAG1DC,EAAAA,KAAK,EAAE,IAHmD;AAI1DC,EAAAA,QAAQ,EAAE;AAJgD,CAAnC,CAAlB;;AAOP+B,SAAS,CAACC,WAAV,GAAwB,WAAxB","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport {\n ModalRootContext,\n useModalRegistry,\n} from \"../ModalRoot/ModalRootContext\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useOrientationChange } from \"../../hooks/useOrientationChange\";\nimport { withAdaptivity, ViewWidth } from \"../../hoc/withAdaptivity\";\nimport {\n AdaptivityContextInterface,\n AdaptivityProps,\n} from \"../AdaptivityProvider/AdaptivityContext\";\nimport { ModalDismissButton } from \"../ModalDismissButton/ModalDismissButton\";\nimport { multiRef } from \"../../lib/utils\";\nimport { ModalType } from \"../ModalRoot/types\";\nimport { getNavId, NavIdProps } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { Platform } from \"../../lib/platform\";\nimport { useAdaptivityIsDesktop } from \"../../hooks/useAdaptivity\";\nimport \"./ModalPage.css\";\n\nexport interface ModalPageProps\n extends React.HTMLAttributes<HTMLDivElement>,\n AdaptivityProps,\n NavIdProps {\n /**\n * Шапка модальной страницы, `<ModalPageHeader />`\n */\n header?: React.ReactNode;\n /**\n * Будет вызвано при начале открытия модалки.\n */\n onOpen?: VoidFunction;\n /**\n * Будет вызвано при окончательном открытии модалки.\n */\n onOpened?: VoidFunction;\n /**\n * Будет вызвано при начале закрытия модалки.\n */\n onClose?: VoidFunction;\n /**\n * Будет вызвано при окончательном закрытии модалки.\n */\n onClosed?: VoidFunction;\n /**\n * Процент, на который изначально будет открыта модальная страница. При `settlingHeight={100}` модальная страница раскрывается на всю высоту.\n */\n settlingHeight?: number;\n /**\n * Если высота контента в модальной странице может поменяться, нужно установить это свойство\n */\n dynamicContentHeight?: boolean;\n getModalContentRef?: React.Ref<HTMLDivElement>;\n}\n\nconst warn = warnOnce(\"ModalPage\");\n\nconst ModalPageComponent: React.FC<\n ModalPageProps & AdaptivityContextInterface\n> = ({\n children,\n header,\n viewWidth,\n viewHeight,\n sizeX,\n hasMouse,\n onOpen,\n onOpened,\n onClose,\n onClosed,\n settlingHeight, // 75\n dynamicContentHeight,\n getModalContentRef,\n nav,\n id,\n ...restProps\n}) => {\n const { updateModalHeight } = React.useContext(ModalRootContext);\n\n const platform = usePlatform();\n const orientation = useOrientationChange();\n\n React.useEffect(updateModalHeight, [\n children,\n orientation,\n updateModalHeight,\n ]);\n\n const isDesktop = useAdaptivityIsDesktop();\n const canShowCloseBtn =\n viewWidth >= ViewWidth.SMALL_TABLET || platform === Platform.VKCOM;\n\n const modalContext = React.useContext(ModalRootContext);\n const { refs } = useModalRegistry(\n getNavId({ nav, id }, warn),\n ModalType.PAGE\n );\n\n return (\n <div\n {...restProps}\n id={id}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"ModalPage\", platform),\n `ModalPage--sizeX-${sizeX}`,\n {\n \"ModalPage--desktop\": isDesktop,\n }\n )}\n >\n <div vkuiClass=\"ModalPage__in-wrap\" ref={refs.innerElement}>\n <div vkuiClass=\"ModalPage__in\">\n <div vkuiClass=\"ModalPage__header\" ref={refs.headerElement}>\n {header}\n </div>\n\n <div vkuiClass=\"ModalPage__content-wrap\">\n <div\n vkuiClass=\"ModalPage__content\"\n ref={multiRef<HTMLDivElement>(\n refs.contentElement,\n getModalContentRef\n )}\n >\n <div vkuiClass=\"ModalPage__content-in\">{children}</div>\n </div>\n </div>\n {canShowCloseBtn && (\n <ModalDismissButton onClick={onClose || modalContext.onClose} />\n )}\n </div>\n </div>\n </div>\n );\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalPage\n */\nexport const ModalPage = withAdaptivity(ModalPageComponent, {\n viewWidth: true,\n viewHeight: true,\n sizeX: true,\n hasMouse: true,\n});\n\nModalPage.displayName = \"ModalPage\";\n"],"file":"ModalPage.js"}
@@ -4,5 +4,7 @@ import { PanelHeaderProps } from "../PanelHeader/PanelHeader";
4
4
  import "./ModalPageHeader.css";
5
5
  export interface ModalPageHeaderProps extends React.HTMLAttributes<HTMLDivElement>, Omit<PanelHeaderProps, "fixed" | "shadow">, HasRef<HTMLDivElement> {
6
6
  }
7
- declare const ModalPageHeader: React.FunctionComponent<ModalPageHeaderProps>;
8
- export default ModalPageHeader;
7
+ /**
8
+ * @see https://vkcom.github.io/VKUI/#/ModalPageHeader
9
+ */
10
+ export declare const ModalPageHeader: ({ children, separator, getRef, ...restProps }: ModalPageHeaderProps) => JSX.Element;
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.default = void 0;
8
+ exports.ModalPageHeader = void 0;
9
9
 
10
10
  var _jsxRuntime = require("../../lib/jsxRuntime");
11
11
 
@@ -15,57 +15,45 @@ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/h
15
15
 
16
16
  var _usePlatform = require("../../hooks/usePlatform");
17
17
 
18
- var _platform = require("../../lib/platform");
18
+ var _useAdaptivity = require("../../hooks/useAdaptivity");
19
19
 
20
- var _PanelHeader = _interopRequireDefault(require("../PanelHeader/PanelHeader"));
20
+ var _platform = require("../../lib/platform");
21
21
 
22
- var _Separator = _interopRequireDefault(require("../Separator/Separator"));
22
+ var _Separator = require("../Separator/Separator");
23
23
 
24
- var _useAdaptivity2 = require("../../hooks/useAdaptivity");
24
+ var _PanelHeader = require("../PanelHeader/PanelHeader");
25
25
 
26
26
  var _classNames = require("../../lib/classNames");
27
27
 
28
28
  var _getClassName = require("../../helpers/getClassName");
29
29
 
30
- var _AdaptivityContext = require("../AdaptivityProvider/AdaptivityContext");
31
-
32
30
  var _excluded = ["children", "separator", "getRef"];
33
31
 
32
+ /**
33
+ * @see https://vkcom.github.io/VKUI/#/ModalPageHeader
34
+ */
34
35
  var ModalPageHeader = function ModalPageHeader(_ref) {
35
36
  var children = _ref.children,
36
- separator = _ref.separator,
37
+ _ref$separator = _ref.separator,
38
+ separator = _ref$separator === void 0 ? true : _ref$separator,
37
39
  getRef = _ref.getRef,
38
40
  restProps = (0, _objectWithoutProperties2.default)(_ref, _excluded);
39
41
  var platform = (0, _usePlatform.usePlatform)();
40
-
41
- var _useAdaptivity = (0, _useAdaptivity2.useAdaptivity)(),
42
- viewWidth = _useAdaptivity.viewWidth,
43
- viewHeight = _useAdaptivity.viewHeight,
44
- hasMouse = _useAdaptivity.hasMouse;
45
-
46
42
  var hasSeparator = separator && platform === _platform.VKCOM;
47
- var isDesktop = viewWidth >= _AdaptivityContext.ViewWidth.SMALL_TABLET && (hasMouse || viewHeight >= _AdaptivityContext.ViewHeight.MEDIUM);
43
+ var isDesktop = (0, _useAdaptivity.useAdaptivityIsDesktop)();
48
44
  return (0, _jsxRuntime.createScopedElement)("div", {
49
- // eslint-disable-next-line vkui/no-object-expression-in-arguments
50
- vkuiClass: (0, _classNames.classNames)((0, _getClassName.getClassName)("ModalPageHeader", platform), {
51
- "ModalPageHeader--desktop": isDesktop
52
- }),
45
+ vkuiClass: (0, _classNames.classNames)((0, _getClassName.getClassName)("ModalPageHeader", platform), isDesktop && "ModalPageHeader--desktop"),
53
46
  ref: getRef
54
- }, (0, _jsxRuntime.createScopedElement)(_PanelHeader.default, (0, _extends2.default)({
47
+ }, (0, _jsxRuntime.createScopedElement)(_PanelHeader.PanelHeader, (0, _extends2.default)({
55
48
  vkuiClass: "ModalPageHeader__in"
56
49
  }, restProps, {
57
50
  fixed: false,
58
51
  separator: false,
59
52
  transparent: true
60
- }), children), hasSeparator && (0, _jsxRuntime.createScopedElement)(_Separator.default, {
53
+ }), children), hasSeparator && (0, _jsxRuntime.createScopedElement)(_Separator.Separator, {
61
54
  wide: true
62
55
  }));
63
56
  };
64
57
 
65
- ModalPageHeader.defaultProps = {
66
- separator: true
67
- }; // eslint-disable-next-line import/no-default-export
68
-
69
- var _default = ModalPageHeader;
70
- exports.default = _default;
58
+ exports.ModalPageHeader = ModalPageHeader;
71
59
  //# sourceMappingURL=ModalPageHeader.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalPageHeader/ModalPageHeader.tsx"],"names":["ModalPageHeader","children","separator","getRef","restProps","platform","viewWidth","viewHeight","hasMouse","hasSeparator","VKCOM","isDesktop","ViewWidth","SMALL_TABLET","ViewHeight","MEDIUM","defaultProps"],"mappings":";;;;;;;;;;;;;;;AACA;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAQA,IAAMA,eAA8D,GAAG,SAAjEA,eAAiE,OAK3C;AAAA,MAJ1BC,QAI0B,QAJ1BA,QAI0B;AAAA,MAH1BC,SAG0B,QAH1BA,SAG0B;AAAA,MAF1BC,MAE0B,QAF1BA,MAE0B;AAAA,MADvBC,SACuB;AAC1B,MAAMC,QAAQ,GAAG,+BAAjB;;AACA,uBAA4C,oCAA5C;AAAA,MAAQC,SAAR,kBAAQA,SAAR;AAAA,MAAmBC,UAAnB,kBAAmBA,UAAnB;AAAA,MAA+BC,QAA/B,kBAA+BA,QAA/B;;AACA,MAAMC,YAAY,GAAGP,SAAS,IAAIG,QAAQ,KAAKK,eAA/C;AACA,MAAMC,SAAS,GACbL,SAAS,IAAIM,6BAAUC,YAAvB,KACCL,QAAQ,IAAID,UAAU,IAAIO,8BAAWC,MADtC,CADF;AAIA,SACE;AACE;AACA,IAAA,SAAS,EAAE,4BAAW,gCAAa,iBAAb,EAAgCV,QAAhC,CAAX,EAAsD;AAC/D,kCAA4BM;AADmC,KAAtD,CAFb;AAKE,IAAA,GAAG,EAAER;AALP,KAOE,qCAAC,oBAAD;AACE,IAAA,SAAS,EAAC;AADZ,KAEMC,SAFN;AAGE,IAAA,KAAK,EAAE,KAHT;AAIE,IAAA,SAAS,EAAE,KAJb;AAKE,IAAA,WAAW;AALb,MAOGH,QAPH,CAPF,EAgBGQ,YAAY,IAAI,qCAAC,kBAAD;AAAW,IAAA,IAAI;AAAf,IAhBnB,CADF;AAoBD,CAjCD;;AAmCAT,eAAe,CAACgB,YAAhB,GAA+B;AAC7Bd,EAAAA,SAAS,EAAE;AADkB,CAA/B,C,CAIA;;eACeF,e","sourcesContent":["import * as React from \"react\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { HasRef } from \"../../types\";\nimport { VKCOM } from \"../../lib/platform\";\nimport PanelHeader, { PanelHeaderProps } from \"../PanelHeader/PanelHeader\";\nimport Separator from \"../Separator/Separator\";\nimport { useAdaptivity } from \"../../hooks/useAdaptivity\";\nimport { classNames } from \"../../lib/classNames\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { ViewHeight, ViewWidth } from \"../AdaptivityProvider/AdaptivityContext\";\nimport \"./ModalPageHeader.css\";\n\nexport interface ModalPageHeaderProps\n extends React.HTMLAttributes<HTMLDivElement>,\n Omit<PanelHeaderProps, \"fixed\" | \"shadow\">,\n HasRef<HTMLDivElement> {}\n\nconst ModalPageHeader: React.FunctionComponent<ModalPageHeaderProps> = ({\n children,\n separator,\n getRef,\n ...restProps\n}: ModalPageHeaderProps) => {\n const platform = usePlatform();\n const { viewWidth, viewHeight, hasMouse } = useAdaptivity();\n const hasSeparator = separator && platform === VKCOM;\n const isDesktop =\n viewWidth >= ViewWidth.SMALL_TABLET &&\n (hasMouse || viewHeight >= ViewHeight.MEDIUM);\n\n return (\n <div\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(getClassName(\"ModalPageHeader\", platform), {\n \"ModalPageHeader--desktop\": isDesktop,\n })}\n ref={getRef}\n >\n <PanelHeader\n vkuiClass=\"ModalPageHeader__in\"\n {...restProps}\n fixed={false}\n separator={false}\n transparent\n >\n {children}\n </PanelHeader>\n {hasSeparator && <Separator wide />}\n </div>\n );\n};\n\nModalPageHeader.defaultProps = {\n separator: true,\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default ModalPageHeader;\n"],"file":"ModalPageHeader.js"}
1
+ {"version":3,"sources":["../../../../src/components/ModalPageHeader/ModalPageHeader.tsx"],"names":["ModalPageHeader","children","separator","getRef","restProps","platform","hasSeparator","VKCOM","isDesktop"],"mappings":";;;;;;;;;;;;;;;AACA;;AACA;;AAEA;;AACA;;AACA;;AACA;;AACA;;;;AAQA;AACA;AACA;AACO,IAAMA,eAAe,GAAG,SAAlBA,eAAkB,OAKH;AAAA,MAJ1BC,QAI0B,QAJ1BA,QAI0B;AAAA,4BAH1BC,SAG0B;AAAA,MAH1BA,SAG0B,+BAHd,IAGc;AAAA,MAF1BC,MAE0B,QAF1BA,MAE0B;AAAA,MADvBC,SACuB;AAC1B,MAAMC,QAAQ,GAAG,+BAAjB;AACA,MAAMC,YAAY,GAAGJ,SAAS,IAAIG,QAAQ,KAAKE,eAA/C;AACA,MAAMC,SAAS,GAAG,4CAAlB;AAEA,SACE;AACE,IAAA,SAAS,EAAE,4BACT,gCAAa,iBAAb,EAAgCH,QAAhC,CADS,EAETG,SAAS,IAAI,0BAFJ,CADb;AAKE,IAAA,GAAG,EAAEL;AALP,KAOE,qCAAC,wBAAD;AACE,IAAA,SAAS,EAAC;AADZ,KAEMC,SAFN;AAGE,IAAA,KAAK,EAAE,KAHT;AAIE,IAAA,SAAS,EAAE,KAJb;AAKE,IAAA,WAAW;AALb,MAOGH,QAPH,CAPF,EAgBGK,YAAY,IAAI,qCAAC,oBAAD;AAAW,IAAA,IAAI;AAAf,IAhBnB,CADF;AAoBD,CA9BM","sourcesContent":["import * as React from \"react\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useAdaptivityIsDesktop } from \"../../hooks/useAdaptivity\";\nimport { HasRef } from \"../../types\";\nimport { VKCOM } from \"../../lib/platform\";\nimport { Separator } from \"../Separator/Separator\";\nimport { PanelHeader, PanelHeaderProps } from \"../PanelHeader/PanelHeader\";\nimport { classNames } from \"../../lib/classNames\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport \"./ModalPageHeader.css\";\n\nexport interface ModalPageHeaderProps\n extends React.HTMLAttributes<HTMLDivElement>,\n Omit<PanelHeaderProps, \"fixed\" | \"shadow\">,\n HasRef<HTMLDivElement> {}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ModalPageHeader\n */\nexport const ModalPageHeader = ({\n children,\n separator = true,\n getRef,\n ...restProps\n}: ModalPageHeaderProps) => {\n const platform = usePlatform();\n const hasSeparator = separator && platform === VKCOM;\n const isDesktop = useAdaptivityIsDesktop();\n\n return (\n <div\n vkuiClass={classNames(\n getClassName(\"ModalPageHeader\", platform),\n isDesktop && \"ModalPageHeader--desktop\"\n )}\n ref={getRef}\n >\n <PanelHeader\n vkuiClass=\"ModalPageHeader__in\"\n {...restProps}\n fixed={false}\n separator={false}\n transparent\n >\n {children}\n </PanelHeader>\n {hasSeparator && <Separator wide />}\n </div>\n );\n};\n"],"file":"ModalPageHeader.js"}
@@ -49,7 +49,7 @@ var _withPlatform = require("../../hoc/withPlatform");
49
49
 
50
50
  var _withContext = require("../../hoc/withContext");
51
51
 
52
- var _ModalRootContext = _interopRequireDefault(require("./ModalRootContext"));
52
+ var _ModalRootContext = require("./ModalRootContext");
53
53
 
54
54
  var _ConfigProviderContext = require("../ConfigProvider/ConfigProviderContext");
55
55
 
@@ -671,7 +671,7 @@ var ModalRootTouchComponent = /*#__PURE__*/function (_React$Component) {
671
671
 
672
672
  return (0, _jsxRuntime.createScopedElement)(_TouchContext.default.Provider, {
673
673
  value: true
674
- }, (0, _jsxRuntime.createScopedElement)(_ModalRootContext.default.Provider, {
674
+ }, (0, _jsxRuntime.createScopedElement)(_ModalRootContext.ModalRootContext.Provider, {
675
675
  value: this.modalRootContext
676
676
  }, (0, _jsxRuntime.createScopedElement)(_Touch.Touch // eslint-disable-next-line vkui/no-object-expression-in-arguments
677
677
  , {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRoot.tsx"],"names":["warn","IS_DEV","process","env","NODE_ENV","numberInRange","number","range","rangeTranslate","Math","max","min","ModalRootTouchComponent","props","React","createRef","undefined","event","originalEvent","preventDefault","modalState","getModalState","activeModal","animateTranslate","translateY","type","ModalType","PAGE","dynamicContentHeight","enteringModal","waitTransitionFinish","requestAnimationFrame","checkPageContentHeight","e","exitingModal","onPageTouchMove","CARD","onCardTouchMove","onPageTouchEnd","onCardTouchEnd","target","contentElement","contains","contentScrolled","contentScrollStopTimeout","clearTimeout","setTimeout","state","touchDown","dragging","maskElementRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","onClose","onExit","isInsideModal","frameIds","platform","ANDROID","VKCOM","document","window","Children","toArray","children","IOS","addEventListener","updateModalTranslate","toggleDocumentScrolling","removeEventListener","prevProps","closeModal","enteringState","onEnter","innerElement","style","transitionDelay","onEntered","delayEnter","timeout","restoreFocusTo","activeElement","focus","enabled","documentScrolling","preventTouch","passive","modalElement","prevModalState","initPageModal","currentModalState","needAnimate","expandable","translateYFrom","setState","nextModalState","nextIsPage","prevIsPage","onExited","exitTranslate","isBack","setMaskOpacity","shiftY","isY","viewportRef","current","stopPropagation","collapsed","expanded","touchStartContentScrollTop","scrollTop","touchMovePositive","headerElement","shiftYPercent","innerHeight","shiftYCurrent","touchShiftYPercent","translateYCurrent","offsetHeight","startY","setStateCallback","shiftYEndPercent","expectTranslateY","duration","settlingHeight","expandedRange","collapsedRange","hiddenRange","hidden","eventHandler","transitionEvent","supported","onceHandler","name","percent","frameId","cancelAnimationFrame","forceOpacity","history","maskAnimationFrame","opacity","toString","configProvider","webviewType","WebviewType","VKAPPS","onTouchMove","onTouchEnd","onScroll","getModals","map","Modal","modalId","_modalState","isPage","key","Component","ModalRootTouch","initModal","ConfigProviderContext","MODAL_PAGE_DEFAULT_PERCENT_HEIGHT","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 | undefined) {\n if (!range) {\n return false;\n }\n return number >= range[0] && number <= range[1];\n}\n\nfunction rangeTranslate(number: number) {\n return Math.max(0, Math.min(98, number));\n}\n\nexport interface ModalRootProps extends HasPlatform {\n activeModal?: string | null;\n\n /**\n * Будет вызвано при начале открытия активной модалки с её id\n */\n onOpen?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном открытии активной модалки с её id\n */\n onOpened?(modalId: string): void;\n\n /**\n * Будет вызвано при начале закрытия активной модалки с её id\n */\n onClose?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном закрытии активной модалки с её id\n */\n onClosed?(modalId: string): void;\n\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n}\n\ninterface ModalRootState {\n touchDown?: boolean;\n dragging?: boolean;\n}\n\nclass ModalRootTouchComponent extends React.Component<\n ModalRootProps & DOMProps & ModalTransitionProps,\n ModalRootState\n> {\n constructor(props: ModalRootProps & ModalTransitionProps) {\n super(props);\n this.state = {\n touchDown: false,\n dragging: false,\n };\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: this.updateModalHeight,\n registerModal: ({ id, ...data }) =>\n Object.assign(this.getModalState(id), data),\n onClose: () => this.props.onExit(),\n isInsideModal: true,\n };\n\n this.frameIds = {};\n }\n\n private documentScrolling = false;\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private readonly viewportRef = React.createRef<HTMLDivElement>();\n private maskAnimationFrame: number | undefined = undefined;\n private readonly modalRootContext: ModalRootContextInterface;\n private readonly frameIds: {\n [index: string]: number;\n };\n private restoreFocusTo: HTMLElement | undefined | null = undefined;\n\n get timeout(): number {\n return this.props.platform === ANDROID || this.props.platform === VKCOM\n ? 320\n : 400;\n }\n\n get document() {\n return this.props.document;\n }\n\n get window() {\n return this.props.window;\n }\n\n getModalState(id: string | undefined | null) {\n if (!id) {\n return undefined;\n }\n return this.props.getModalState(id);\n }\n\n getModals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n componentDidMount() {\n // Отслеживаем изменение размеров viewport (Необходимо для iOS)\n if (this.props.platform === IOS) {\n this.window?.addEventListener(\"resize\", this.updateModalTranslate, false);\n }\n }\n\n componentWillUnmount() {\n this.toggleDocumentScrolling(true);\n this.window!.removeEventListener(\n \"resize\",\n this.updateModalTranslate,\n false\n );\n }\n\n componentDidUpdate(prevProps: ModalRootProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (\n this.props.exitingModal &&\n this.props.exitingModal !== prevProps.exitingModal\n ) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (\n this.props.enteringModal &&\n this.props.enteringModal !== prevProps.enteringModal\n ) {\n const { enteringModal } = this.props;\n const enteringState = this.getModalState(enteringModal);\n this.props.onEnter();\n this.waitTransitionFinish(enteringState, () => {\n if (enteringState?.innerElement) {\n enteringState.innerElement.style.transitionDelay = \"\";\n }\n this.props.onEntered(enteringModal);\n });\n\n if (enteringState?.innerElement) {\n enteringState.innerElement.style.transitionDelay = this.props.delayEnter\n ? `${this.timeout}ms`\n : \"\";\n this.animateTranslate(enteringState, enteringState.translateY);\n }\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = this.document!.activeElement as HTMLElement;\n }\n if (\n !this.props.activeModal &&\n !this.props.exitingModal &&\n this.restoreFocusTo\n ) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = null;\n }\n\n this.toggleDocumentScrolling(\n !this.props.activeModal && !this.props.exitingModal\n );\n }\n\n /* Отключает скролл документа */\n toggleDocumentScrolling(enabled: boolean) {\n if (this.documentScrolling === enabled) {\n return;\n }\n this.documentScrolling = enabled;\n\n if (enabled) {\n // Здесь нужен последний аргумент с такими же параметрами, потому что\n // некоторые браузеры на странных вендорах типа Meizu не удаляют обработчик.\n // https://github.com/VKCOM/VKUI/issues/444\n this.window!.removeEventListener(\"touchmove\", this.preventTouch, {\n // @ts-ignore (В интерфейсе EventListenerOptions нет поля passive)\n passive: false,\n });\n } else {\n this.window!.addEventListener(\"touchmove\", this.preventTouch, {\n passive: false,\n });\n }\n }\n\n preventTouch = (event: any) => {\n if (!event) {\n return false;\n }\n while (event.originalEvent) {\n event = event.originalEvent;\n }\n if (event.preventDefault) {\n event.preventDefault();\n }\n return false;\n };\n\n updateModalTranslate = () => {\n const modalState = this.getModalState(this.props.activeModal);\n modalState && this.animateTranslate(modalState, modalState.translateY);\n };\n\n checkPageContentHeight() {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState?.type === ModalType.PAGE && modalState?.modalElement) {\n const prevModalState = { ...modalState };\n initPageModal(modalState);\n const currentModalState = { ...modalState };\n\n let needAnimate = false;\n\n if (prevModalState.expandable === currentModalState.expandable) {\n if (\n prevModalState.translateYFrom !== currentModalState.translateYFrom\n ) {\n needAnimate = true;\n }\n } else {\n needAnimate = true;\n }\n\n if (needAnimate) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n }\n }\n\n updateModalHeight = () => {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (\n modalState &&\n modalState.type === ModalType.PAGE &&\n modalState.dynamicContentHeight\n ) {\n if (this.props.enteringModal) {\n this.waitTransitionFinish(modalState, () => {\n requestAnimationFrame(() => this.checkPageContentHeight());\n });\n } else {\n requestAnimationFrame(() => this.checkPageContentHeight());\n }\n }\n };\n\n closeModal(id: string) {\n // Сбрасываем состояния, которые могут помешать закрытию модального окна\n this.setState({ touchDown: false });\n\n const prevModalState = this.getModalState(id);\n\n if (!prevModalState) {\n id &&\n warn(\n `closeActiveModal: модальное окно (страница) ${id} не существует`,\n \"error\"\n );\n return;\n }\n\n const nextModalState = this.getModalState(this.props.activeModal);\n const nextIsPage =\n !!nextModalState && nextModalState.type === ModalType.PAGE;\n\n const prevIsPage =\n !!prevModalState && prevModalState.type === ModalType.PAGE;\n this.waitTransitionFinish(prevModalState, () => this.props.onExited(id));\n const exitTranslate =\n prevIsPage &&\n nextIsPage &&\n (prevModalState.translateY ?? 0) <=\n (nextModalState?.translateYFrom ?? 0) &&\n !this.props.isBack\n ? (nextModalState?.translateYFrom ?? 0) + 10\n : 100;\n this.animateTranslate(prevModalState, exitTranslate);\n\n if (!nextModalState) {\n // NOTE: was only for clean exit\n this.setMaskOpacity(prevModalState, 0);\n }\n }\n\n onTouchMove = (e: TouchEvent) => {\n if (this.props.exitingModal) {\n return;\n }\n const modalState = this.getModalState(this.props.activeModal);\n if (!modalState) {\n return;\n }\n\n if (modalState.type === ModalType.PAGE) {\n return this.onPageTouchMove(e, modalState);\n }\n\n if (modalState.type === ModalType.CARD) {\n return this.onCardTouchMove(e, modalState);\n }\n };\n\n onPageTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { shiftY, originalEvent } = event;\n const target = originalEvent.target as HTMLElement;\n\n if (!event.isY) {\n if (this.viewportRef.current?.contains(target)) {\n originalEvent.preventDefault();\n }\n return;\n }\n\n if (!modalState.innerElement?.contains(target)) {\n return originalEvent.preventDefault();\n }\n\n originalEvent.stopPropagation();\n\n const { expandable, contentScrolled, collapsed, expanded } = modalState;\n\n if (!this.state.touchDown) {\n modalState.touchStartContentScrollTop =\n modalState.contentElement?.scrollTop;\n this.setState({ touchDown: true });\n }\n\n if (contentScrolled) {\n return;\n }\n\n if (modalState.touchMovePositive === null) {\n modalState.touchMovePositive = shiftY > 0;\n }\n\n if (\n !modalState.expandable ||\n collapsed ||\n (expanded &&\n modalState.touchMovePositive &&\n modalState.touchStartContentScrollTop === 0) ||\n modalState.headerElement?.contains(target)\n ) {\n originalEvent.preventDefault();\n\n if ((!expandable && shiftY < 0) || !this.window) {\n return;\n }\n\n !this.state.dragging && this.setState({ dragging: true });\n\n const shiftYPercent = (shiftY / this.window.innerHeight) * 100;\n const shiftYCurrent = rubber(\n shiftYPercent,\n 72,\n 0.8,\n this.props.platform === ANDROID || this.props.platform === VKCOM\n );\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = rangeTranslate(\n (modalState.translateY ?? 0) + shiftYCurrent\n );\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onCardTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { originalEvent, shiftY } = event;\n const target = originalEvent.target as HTMLElement;\n if (modalState.innerElement?.contains(target)) {\n if (!this.state.touchDown) {\n this.setState({ touchDown: true, dragging: true });\n }\n\n const shiftYPercent =\n (shiftY / modalState.innerElement.offsetHeight) * 100;\n const shiftYCurrent = rubber(\n shiftYPercent,\n 72,\n 1.2,\n this.props.platform === ANDROID || this.props.platform === VKCOM\n );\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = Math.max(\n 0,\n (modalState.translateY ?? 0) + shiftYCurrent\n );\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onTouchEnd = (e: TouchEvent) => {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState?.type === ModalType.PAGE) {\n return this.onPageTouchEnd(e, modalState);\n }\n\n if (modalState?.type === ModalType.CARD) {\n return this.onCardTouchEnd(e, modalState);\n }\n };\n\n onPageTouchEnd(event: TouchEvent, modalState: ModalsStateEntry) {\n const { startY, shiftY } = event;\n\n modalState.contentScrolled = false;\n modalState.touchMovePositive = null;\n\n let setStateCallback;\n\n if (this.state.dragging && this.window) {\n const shiftYEndPercent =\n ((startY + shiftY) / this.window.innerHeight) * 100;\n\n let translateY = modalState.translateYCurrent ?? 0;\n const expectTranslateY =\n (translateY / event.duration) *\n 240 *\n 0.6 *\n ((modalState.touchShiftYPercent ?? 0) < 0 ? -1 : 1);\n translateY = rangeTranslate(translateY + expectTranslateY);\n\n if (modalState.settlingHeight !== 100) {\n if (numberInRange(translateY, modalState.expandedRange)) {\n translateY = modalState.expandedRange?.[0] ?? 0;\n } else if (numberInRange(translateY, modalState.collapsedRange)) {\n translateY = modalState.translateYFrom ?? 0;\n } else if (numberInRange(translateY, modalState.hiddenRange)) {\n translateY = 100;\n } else {\n translateY = modalState.translateYFrom ?? 0;\n }\n } else {\n if (numberInRange(translateY, [0, 25])) {\n translateY = 0;\n } else {\n translateY = 100;\n }\n }\n\n if (translateY !== 100 && shiftYEndPercent >= 75) {\n translateY = 100;\n }\n\n modalState.translateY = translateY;\n modalState.translateYCurrent = translateY;\n modalState.collapsed = translateY > 0 && translateY < shiftYEndPercent;\n modalState.expanded = translateY === 0;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.onExit();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback\n );\n }\n\n onCardTouchEnd({ duration }: TouchEvent, modalState: ModalsStateEntry) {\n let setStateCallback;\n\n if (this.state.dragging) {\n let translateY = modalState.translateYCurrent ?? 0;\n\n const expectTranslateY =\n (translateY / duration) *\n 240 *\n 0.6 *\n ((modalState.touchShiftYPercent ?? 0) < 0 ? -1 : 1);\n translateY = Math.max(0, translateY + expectTranslateY);\n\n if (translateY >= 30) {\n translateY = 100;\n } else {\n translateY = 0;\n }\n\n modalState.translateY = translateY;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.onExit();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback\n );\n }\n\n onScroll = (e: React.SyntheticEvent) => {\n const activeModal = this.props.activeModal;\n\n const target = e.target as HTMLElement;\n\n if (!activeModal) {\n return;\n }\n const modalState = this.getModalState(activeModal);\n if (\n modalState?.type === ModalType.PAGE &&\n modalState?.contentElement?.contains(target)\n ) {\n modalState.contentScrolled = true;\n\n if (modalState.contentScrollStopTimeout) {\n clearTimeout(modalState.contentScrollStopTimeout);\n }\n\n modalState.contentScrollStopTimeout = setTimeout(() => {\n if (modalState.contentScrolled) {\n modalState.contentScrolled = false;\n }\n }, 250);\n }\n };\n\n waitTransitionFinish(\n modalState: ModalsStateEntry | undefined,\n eventHandler: () => void\n ) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState?.innerElement?.removeEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n eventHandler();\n };\n\n modalState?.innerElement?.addEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /**\n * Анимирует сдвиг модалки\n *\n * @param {ModalsStateEntry} modalState\n * @param {number} percent Процент сдвига: 0 – полностью открыта, 100 – полностью закрыта\n */\n animateTranslate(modalState: ModalsStateEntry, percent: number | undefined) {\n const frameId = `animateTranslateFrame${modalState.id}`;\n\n cancelAnimationFrame(this.frameIds[frameId]);\n\n this.frameIds[frameId] = requestAnimationFrame(() => {\n setTransformStyle(\n modalState.innerElement,\n `translate3d(0, ${percent}%, 0)`\n );\n });\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(\n modalState: ModalsStateEntry,\n forceOpacity: number | null = null\n ) {\n if (forceOpacity === null && this.props.history?.[0] !== modalState.id) {\n return;\n }\n if (this.maskAnimationFrame) {\n cancelAnimationFrame(this.maskAnimationFrame);\n }\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(\n 0,\n Math.min(100, opacity)\n ).toString();\n }\n });\n }\n\n render() {\n const { activeModal, exitingModal, enteringModal } = this.props;\n const { touchDown, dragging } = this.state;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <TouchRootContext.Provider value={true}>\n <ModalRootContext.Provider value={this.modalRootContext}>\n <Touch\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"ModalRoot\", this.props.platform),\n {\n \"ModalRoot--vkapps\":\n this.props.configProvider?.webviewType === WebviewType.VKAPPS,\n \"ModalRoot--touched\": touchDown,\n \"ModalRoot--switching\": !!(enteringModal || exitingModal),\n }\n )}\n onMove={this.onTouchMove}\n onEnd={this.onTouchEnd}\n onScroll={this.onScroll}\n >\n <div\n vkuiClass=\"ModalRoot__mask\"\n onClick={this.props.onExit}\n ref={this.maskElementRef}\n />\n <div vkuiClass=\"ModalRoot__viewport\" ref={this.viewportRef}>\n {this.getModals().map((Modal) => {\n const modalId = getNavId(Modal.props, warn);\n const _modalState = this.getModalState(modalId);\n if (\n (modalId !== activeModal && modalId !== exitingModal) ||\n !_modalState\n ) {\n return null;\n }\n const modalState = { ..._modalState };\n\n const isPage = modalState.type === ModalType.PAGE;\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n key={key}\n getRootRef={(e) => {\n const modalState = this.getModalState(modalId);\n if (modalState) {\n modalState.modalElement = e;\n }\n }}\n onClose={this.props.onExit}\n timeout={this.timeout}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\"ModalRoot__modal\", {\n \"ModalRoot__modal--active\": modalId === activeModal,\n \"ModalRoot__modal--prev\": modalId === exitingModal,\n \"ModalRoot__modal--next\":\n (exitingModal && modalId === activeModal) ||\n modalId === enteringModal,\n\n \"ModalRoot__modal--dragging\": dragging,\n\n \"ModalRoot__modal--expandable\":\n isPage && modalState.expandable,\n \"ModalRoot__modal--expanded\":\n isPage && modalState.expanded,\n \"ModalRoot__modal--collapsed\":\n isPage && modalState.collapsed,\n })}\n restoreFocus={false}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </Touch>\n </ModalRootContext.Provider>\n </TouchRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootTouch = withContext(\n withPlatform(\n withDOM<ModalRootProps>(\n withModalManager(initModal)(ModalRootTouchComponent)\n )\n ),\n ConfigProviderContext,\n \"configProvider\"\n);\n\n/**\n * Инициализирует модалку перед анимацией открытия\n */\nfunction initModal(modalState: ModalsStateEntry) {\n switch (modalState.type) {\n case ModalType.PAGE:\n modalState.settlingHeight =\n modalState.settlingHeight || MODAL_PAGE_DEFAULT_PERCENT_HEIGHT;\n return initPageModal(modalState);\n case ModalType.CARD:\n return initCardModal(modalState);\n default:\n IS_DEV &&\n warn(\n `initActiveModal: modalState.type=\"${modalState.type}\" не поддерживается`,\n \"error\"\n );\n }\n}\n\nfunction initPageModal(modalState: ModalsStateEntry) {\n const { contentElement } = modalState;\n const contentHeight = (contentElement?.firstElementChild as HTMLElement)\n .offsetHeight;\n\n let prevTranslateY = modalState.translateY;\n\n modalState.expandable =\n contentHeight > (contentElement?.clientHeight ?? 0) ||\n modalState.settlingHeight === 100;\n\n let collapsed = false;\n let expanded = false;\n let translateYFrom;\n let translateY;\n let expandedRange: TranslateRange;\n let collapsedRange: TranslateRange;\n let hiddenRange: TranslateRange;\n\n if (modalState.expandable) {\n translateYFrom = 100 - (modalState.settlingHeight ?? 0);\n\n const shiftHalf = translateYFrom / 2;\n const visiblePart = 100 - translateYFrom;\n\n expandedRange = [0, shiftHalf];\n collapsedRange = [shiftHalf, translateYFrom + visiblePart / 4];\n hiddenRange = [translateYFrom + visiblePart / 4, 100];\n\n collapsed = translateYFrom > 0;\n expanded = translateYFrom <= 0;\n translateY = translateYFrom;\n } else {\n const headerHeight = modalState.headerElement?.offsetHeight ?? 0;\n const height = contentHeight + headerHeight;\n\n translateYFrom =\n 100 -\n (height / (modalState.innerElement?.parentElement?.offsetHeight ?? 0)) *\n 100;\n translateY = translateYFrom;\n\n expandedRange = [translateY, translateY + 25];\n collapsedRange = [translateY + 25, translateY + 25];\n hiddenRange = [translateY + 25, translateY + 100];\n }\n\n // Если модалка может открываться на весь экран, и новый сдвиг больше предыдущего, то откроем её на весь экран\n if (\n (modalState.expandable && translateY > (prevTranslateY ?? 0)) ||\n modalState.settlingHeight === 100\n ) {\n translateY = 0;\n }\n\n 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":["warn","IS_DEV","process","env","NODE_ENV","numberInRange","number","range","rangeTranslate","Math","max","min","ModalRootTouchComponent","props","React","createRef","undefined","event","originalEvent","preventDefault","modalState","getModalState","activeModal","animateTranslate","translateY","type","ModalType","PAGE","dynamicContentHeight","enteringModal","waitTransitionFinish","requestAnimationFrame","checkPageContentHeight","e","exitingModal","onPageTouchMove","CARD","onCardTouchMove","onPageTouchEnd","onCardTouchEnd","target","contentElement","contains","contentScrolled","contentScrollStopTimeout","clearTimeout","setTimeout","state","touchDown","dragging","maskElementRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","onClose","onExit","isInsideModal","frameIds","platform","ANDROID","VKCOM","document","window","Children","toArray","children","IOS","addEventListener","updateModalTranslate","toggleDocumentScrolling","removeEventListener","prevProps","closeModal","enteringState","onEnter","innerElement","style","transitionDelay","onEntered","delayEnter","timeout","restoreFocusTo","activeElement","focus","enabled","documentScrolling","preventTouch","passive","modalElement","prevModalState","initPageModal","currentModalState","needAnimate","expandable","translateYFrom","setState","nextModalState","nextIsPage","prevIsPage","onExited","exitTranslate","isBack","setMaskOpacity","shiftY","isY","viewportRef","current","stopPropagation","collapsed","expanded","touchStartContentScrollTop","scrollTop","touchMovePositive","headerElement","shiftYPercent","innerHeight","shiftYCurrent","touchShiftYPercent","translateYCurrent","offsetHeight","startY","setStateCallback","shiftYEndPercent","expectTranslateY","duration","settlingHeight","expandedRange","collapsedRange","hiddenRange","hidden","eventHandler","transitionEvent","supported","onceHandler","name","percent","frameId","cancelAnimationFrame","forceOpacity","history","maskAnimationFrame","opacity","toString","configProvider","webviewType","WebviewType","VKAPPS","onTouchMove","onTouchEnd","onScroll","getModals","map","Modal","modalId","_modalState","isPage","key","Component","ModalRootTouch","initModal","ConfigProviderContext","MODAL_PAGE_DEFAULT_PERCENT_HEIGHT","initCardModal","contentHeight","firstElementChild","prevTranslateY","clientHeight","shiftHalf","visiblePart","headerHeight","height","parentElement"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { Touch, TouchEvent } from \"../Touch/Touch\";\nimport TouchRootContext from \"../Touch/TouchContext\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport { setTransformStyle } from \"../../lib/styles\";\nimport { rubber } from \"../../lib/touch\";\nimport { ANDROID, IOS, VKCOM } from \"../../lib/platform\";\nimport { transitionEvent } from \"../../lib/supportEvents\";\nimport { HasPlatform } from \"../../types\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport { withContext } from \"../../hoc/withContext\";\nimport {\n ModalRootContext,\n ModalRootContextInterface,\n} from \"./ModalRootContext\";\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n WebviewType,\n} from \"../ConfigProvider/ConfigProviderContext\";\nimport { ModalsStateEntry, ModalType, TranslateRange } from \"./types\";\nimport { MODAL_PAGE_DEFAULT_PERCENT_HEIGHT } from \"./constants\";\nimport { DOMProps, withDOM } from \"../../lib/dom\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { FocusTrap } from \"../FocusTrap/FocusTrap\";\nimport { ModalTransitionProps, withModalManager } from \"./useModalManager\";\nimport \"./ModalRoot.css\";\n\nconst warn = warnOnce(\"ModalRoot\");\nconst IS_DEV = process.env.NODE_ENV === \"development\";\n\nfunction numberInRange(number: number, range: TranslateRange | undefined) {\n if (!range) {\n return false;\n }\n return number >= range[0] && number <= range[1];\n}\n\nfunction rangeTranslate(number: number) {\n return Math.max(0, Math.min(98, number));\n}\n\nexport interface ModalRootProps extends HasPlatform {\n activeModal?: string | null;\n\n /**\n * Будет вызвано при начале открытия активной модалки с её id\n */\n onOpen?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном открытии активной модалки с её id\n */\n onOpened?(modalId: string): void;\n\n /**\n * Будет вызвано при начале закрытия активной модалки с её id\n */\n onClose?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном закрытии активной модалки с её id\n */\n onClosed?(modalId: string): void;\n\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n}\n\ninterface ModalRootState {\n touchDown?: boolean;\n dragging?: boolean;\n}\n\nclass ModalRootTouchComponent extends React.Component<\n ModalRootProps & DOMProps & ModalTransitionProps,\n ModalRootState\n> {\n constructor(props: ModalRootProps & ModalTransitionProps) {\n super(props);\n this.state = {\n touchDown: false,\n dragging: false,\n };\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: this.updateModalHeight,\n registerModal: ({ id, ...data }) =>\n Object.assign(this.getModalState(id), data),\n onClose: () => this.props.onExit(),\n isInsideModal: true,\n };\n\n this.frameIds = {};\n }\n\n private documentScrolling = false;\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private readonly viewportRef = React.createRef<HTMLDivElement>();\n private maskAnimationFrame: number | undefined = undefined;\n private readonly modalRootContext: ModalRootContextInterface;\n private readonly frameIds: {\n [index: string]: number;\n };\n private restoreFocusTo: HTMLElement | undefined | null = undefined;\n\n get timeout(): number {\n return this.props.platform === ANDROID || this.props.platform === VKCOM\n ? 320\n : 400;\n }\n\n get document() {\n return this.props.document;\n }\n\n get window() {\n return this.props.window;\n }\n\n getModalState(id: string | undefined | null) {\n if (!id) {\n return undefined;\n }\n return this.props.getModalState(id);\n }\n\n getModals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n componentDidMount() {\n // Отслеживаем изменение размеров viewport (Необходимо для iOS)\n if (this.props.platform === IOS) {\n this.window?.addEventListener(\"resize\", this.updateModalTranslate, false);\n }\n }\n\n componentWillUnmount() {\n this.toggleDocumentScrolling(true);\n this.window!.removeEventListener(\n \"resize\",\n this.updateModalTranslate,\n false\n );\n }\n\n componentDidUpdate(prevProps: ModalRootProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (\n this.props.exitingModal &&\n this.props.exitingModal !== prevProps.exitingModal\n ) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (\n this.props.enteringModal &&\n this.props.enteringModal !== prevProps.enteringModal\n ) {\n const { enteringModal } = this.props;\n const enteringState = this.getModalState(enteringModal);\n this.props.onEnter();\n this.waitTransitionFinish(enteringState, () => {\n if (enteringState?.innerElement) {\n enteringState.innerElement.style.transitionDelay = \"\";\n }\n this.props.onEntered(enteringModal);\n });\n\n if (enteringState?.innerElement) {\n enteringState.innerElement.style.transitionDelay = this.props.delayEnter\n ? `${this.timeout}ms`\n : \"\";\n this.animateTranslate(enteringState, enteringState.translateY);\n }\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = this.document!.activeElement as HTMLElement;\n }\n if (\n !this.props.activeModal &&\n !this.props.exitingModal &&\n this.restoreFocusTo\n ) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = null;\n }\n\n this.toggleDocumentScrolling(\n !this.props.activeModal && !this.props.exitingModal\n );\n }\n\n /* Отключает скролл документа */\n toggleDocumentScrolling(enabled: boolean) {\n if (this.documentScrolling === enabled) {\n return;\n }\n this.documentScrolling = enabled;\n\n if (enabled) {\n // Здесь нужен последний аргумент с такими же параметрами, потому что\n // некоторые браузеры на странных вендорах типа Meizu не удаляют обработчик.\n // https://github.com/VKCOM/VKUI/issues/444\n this.window!.removeEventListener(\"touchmove\", this.preventTouch, {\n // @ts-ignore (В интерфейсе EventListenerOptions нет поля passive)\n passive: false,\n });\n } else {\n this.window!.addEventListener(\"touchmove\", this.preventTouch, {\n passive: false,\n });\n }\n }\n\n preventTouch = (event: any) => {\n if (!event) {\n return false;\n }\n while (event.originalEvent) {\n event = event.originalEvent;\n }\n if (event.preventDefault) {\n event.preventDefault();\n }\n return false;\n };\n\n updateModalTranslate = () => {\n const modalState = this.getModalState(this.props.activeModal);\n modalState && this.animateTranslate(modalState, modalState.translateY);\n };\n\n checkPageContentHeight() {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState?.type === ModalType.PAGE && modalState?.modalElement) {\n const prevModalState = { ...modalState };\n initPageModal(modalState);\n const currentModalState = { ...modalState };\n\n let needAnimate = false;\n\n if (prevModalState.expandable === currentModalState.expandable) {\n if (\n prevModalState.translateYFrom !== currentModalState.translateYFrom\n ) {\n needAnimate = true;\n }\n } else {\n needAnimate = true;\n }\n\n if (needAnimate) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n }\n }\n\n updateModalHeight = () => {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (\n modalState &&\n modalState.type === ModalType.PAGE &&\n modalState.dynamicContentHeight\n ) {\n if (this.props.enteringModal) {\n this.waitTransitionFinish(modalState, () => {\n requestAnimationFrame(() => this.checkPageContentHeight());\n });\n } else {\n requestAnimationFrame(() => this.checkPageContentHeight());\n }\n }\n };\n\n closeModal(id: string) {\n // Сбрасываем состояния, которые могут помешать закрытию модального окна\n this.setState({ touchDown: false });\n\n const prevModalState = this.getModalState(id);\n\n if (!prevModalState) {\n id &&\n warn(\n `closeActiveModal: модальное окно (страница) ${id} не существует`,\n \"error\"\n );\n return;\n }\n\n const nextModalState = this.getModalState(this.props.activeModal);\n const nextIsPage =\n !!nextModalState && nextModalState.type === ModalType.PAGE;\n\n const prevIsPage =\n !!prevModalState && prevModalState.type === ModalType.PAGE;\n this.waitTransitionFinish(prevModalState, () => this.props.onExited(id));\n const exitTranslate =\n prevIsPage &&\n nextIsPage &&\n (prevModalState.translateY ?? 0) <=\n (nextModalState?.translateYFrom ?? 0) &&\n !this.props.isBack\n ? (nextModalState?.translateYFrom ?? 0) + 10\n : 100;\n this.animateTranslate(prevModalState, exitTranslate);\n\n if (!nextModalState) {\n // NOTE: was only for clean exit\n this.setMaskOpacity(prevModalState, 0);\n }\n }\n\n onTouchMove = (e: TouchEvent) => {\n if (this.props.exitingModal) {\n return;\n }\n const modalState = this.getModalState(this.props.activeModal);\n if (!modalState) {\n return;\n }\n\n if (modalState.type === ModalType.PAGE) {\n return this.onPageTouchMove(e, modalState);\n }\n\n if (modalState.type === ModalType.CARD) {\n return this.onCardTouchMove(e, modalState);\n }\n };\n\n onPageTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { shiftY, originalEvent } = event;\n const target = originalEvent.target as HTMLElement;\n\n if (!event.isY) {\n if (this.viewportRef.current?.contains(target)) {\n originalEvent.preventDefault();\n }\n return;\n }\n\n if (!modalState.innerElement?.contains(target)) {\n return originalEvent.preventDefault();\n }\n\n originalEvent.stopPropagation();\n\n const { expandable, contentScrolled, collapsed, expanded } = modalState;\n\n if (!this.state.touchDown) {\n modalState.touchStartContentScrollTop =\n modalState.contentElement?.scrollTop;\n this.setState({ touchDown: true });\n }\n\n if (contentScrolled) {\n return;\n }\n\n if (modalState.touchMovePositive === null) {\n modalState.touchMovePositive = shiftY > 0;\n }\n\n if (\n !modalState.expandable ||\n collapsed ||\n (expanded &&\n modalState.touchMovePositive &&\n modalState.touchStartContentScrollTop === 0) ||\n modalState.headerElement?.contains(target)\n ) {\n originalEvent.preventDefault();\n\n if ((!expandable && shiftY < 0) || !this.window) {\n return;\n }\n\n !this.state.dragging && this.setState({ dragging: true });\n\n const shiftYPercent = (shiftY / this.window.innerHeight) * 100;\n const shiftYCurrent = rubber(\n shiftYPercent,\n 72,\n 0.8,\n this.props.platform === ANDROID || this.props.platform === VKCOM\n );\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = rangeTranslate(\n (modalState.translateY ?? 0) + shiftYCurrent\n );\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onCardTouchMove(event: TouchEvent, modalState: ModalsStateEntry) {\n const { originalEvent, shiftY } = event;\n const target = originalEvent.target as HTMLElement;\n if (modalState.innerElement?.contains(target)) {\n if (!this.state.touchDown) {\n this.setState({ touchDown: true, dragging: true });\n }\n\n const shiftYPercent =\n (shiftY / modalState.innerElement.offsetHeight) * 100;\n const shiftYCurrent = rubber(\n shiftYPercent,\n 72,\n 1.2,\n this.props.platform === ANDROID || this.props.platform === VKCOM\n );\n\n modalState.touchShiftYPercent = shiftYPercent;\n modalState.translateYCurrent = Math.max(\n 0,\n (modalState.translateY ?? 0) + shiftYCurrent\n );\n\n this.animateTranslate(modalState, modalState.translateYCurrent);\n this.setMaskOpacity(modalState);\n }\n }\n\n onTouchEnd = (e: TouchEvent) => {\n const modalState = this.getModalState(this.props.activeModal);\n\n if (modalState?.type === ModalType.PAGE) {\n return this.onPageTouchEnd(e, modalState);\n }\n\n if (modalState?.type === ModalType.CARD) {\n return this.onCardTouchEnd(e, modalState);\n }\n };\n\n onPageTouchEnd(event: TouchEvent, modalState: ModalsStateEntry) {\n const { startY, shiftY } = event;\n\n modalState.contentScrolled = false;\n modalState.touchMovePositive = null;\n\n let setStateCallback;\n\n if (this.state.dragging && this.window) {\n const shiftYEndPercent =\n ((startY + shiftY) / this.window.innerHeight) * 100;\n\n let translateY = modalState.translateYCurrent ?? 0;\n const expectTranslateY =\n (translateY / event.duration) *\n 240 *\n 0.6 *\n ((modalState.touchShiftYPercent ?? 0) < 0 ? -1 : 1);\n translateY = rangeTranslate(translateY + expectTranslateY);\n\n if (modalState.settlingHeight !== 100) {\n if (numberInRange(translateY, modalState.expandedRange)) {\n translateY = modalState.expandedRange?.[0] ?? 0;\n } else if (numberInRange(translateY, modalState.collapsedRange)) {\n translateY = modalState.translateYFrom ?? 0;\n } else if (numberInRange(translateY, modalState.hiddenRange)) {\n translateY = 100;\n } else {\n translateY = modalState.translateYFrom ?? 0;\n }\n } else {\n if (numberInRange(translateY, [0, 25])) {\n translateY = 0;\n } else {\n translateY = 100;\n }\n }\n\n if (translateY !== 100 && shiftYEndPercent >= 75) {\n translateY = 100;\n }\n\n modalState.translateY = translateY;\n modalState.translateYCurrent = translateY;\n modalState.collapsed = translateY > 0 && translateY < shiftYEndPercent;\n modalState.expanded = translateY === 0;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.onExit();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback\n );\n }\n\n onCardTouchEnd({ duration }: TouchEvent, modalState: ModalsStateEntry) {\n let setStateCallback;\n\n if (this.state.dragging) {\n let translateY = modalState.translateYCurrent ?? 0;\n\n const expectTranslateY =\n (translateY / duration) *\n 240 *\n 0.6 *\n ((modalState.touchShiftYPercent ?? 0) < 0 ? -1 : 1);\n translateY = Math.max(0, translateY + expectTranslateY);\n\n if (translateY >= 30) {\n translateY = 100;\n } else {\n translateY = 0;\n }\n\n modalState.translateY = translateY;\n modalState.hidden = translateY === 100;\n\n if (modalState.hidden) {\n this.props.onExit();\n }\n\n setStateCallback = () => {\n if (!modalState.hidden) {\n this.animateTranslate(modalState, modalState.translateY);\n }\n\n this.setMaskOpacity(modalState);\n };\n }\n\n this.setState(\n {\n touchDown: false,\n dragging: false,\n },\n setStateCallback\n );\n }\n\n onScroll = (e: React.SyntheticEvent) => {\n const activeModal = this.props.activeModal;\n\n const target = e.target as HTMLElement;\n\n if (!activeModal) {\n return;\n }\n const modalState = this.getModalState(activeModal);\n if (\n modalState?.type === ModalType.PAGE &&\n modalState?.contentElement?.contains(target)\n ) {\n modalState.contentScrolled = true;\n\n if (modalState.contentScrollStopTimeout) {\n clearTimeout(modalState.contentScrollStopTimeout);\n }\n\n modalState.contentScrollStopTimeout = setTimeout(() => {\n if (modalState.contentScrolled) {\n modalState.contentScrolled = false;\n }\n }, 250);\n }\n };\n\n waitTransitionFinish(\n modalState: ModalsStateEntry | undefined,\n eventHandler: () => void\n ) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState?.innerElement?.removeEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n eventHandler();\n };\n\n modalState?.innerElement?.addEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /**\n * Анимирует сдвиг модалки\n *\n * @param {ModalsStateEntry} modalState\n * @param {number} percent Процент сдвига: 0 – полностью открыта, 100 – полностью закрыта\n */\n animateTranslate(modalState: ModalsStateEntry, percent: number | undefined) {\n const frameId = `animateTranslateFrame${modalState.id}`;\n\n cancelAnimationFrame(this.frameIds[frameId]);\n\n this.frameIds[frameId] = requestAnimationFrame(() => {\n setTransformStyle(\n modalState.innerElement,\n `translate3d(0, ${percent}%, 0)`\n );\n });\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(\n modalState: ModalsStateEntry,\n forceOpacity: number | null = null\n ) {\n if (forceOpacity === null && this.props.history?.[0] !== modalState.id) {\n return;\n }\n if (this.maskAnimationFrame) {\n cancelAnimationFrame(this.maskAnimationFrame);\n }\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(\n 0,\n Math.min(100, opacity)\n ).toString();\n }\n });\n }\n\n render() {\n const { activeModal, exitingModal, enteringModal } = this.props;\n const { touchDown, dragging } = this.state;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <TouchRootContext.Provider value={true}>\n <ModalRootContext.Provider value={this.modalRootContext}>\n <Touch\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"ModalRoot\", this.props.platform),\n {\n \"ModalRoot--vkapps\":\n this.props.configProvider?.webviewType === WebviewType.VKAPPS,\n \"ModalRoot--touched\": touchDown,\n \"ModalRoot--switching\": !!(enteringModal || exitingModal),\n }\n )}\n onMove={this.onTouchMove}\n onEnd={this.onTouchEnd}\n onScroll={this.onScroll}\n >\n <div\n vkuiClass=\"ModalRoot__mask\"\n onClick={this.props.onExit}\n ref={this.maskElementRef}\n />\n <div vkuiClass=\"ModalRoot__viewport\" ref={this.viewportRef}>\n {this.getModals().map((Modal) => {\n const modalId = getNavId(Modal.props, warn);\n const _modalState = this.getModalState(modalId);\n if (\n (modalId !== activeModal && modalId !== exitingModal) ||\n !_modalState\n ) {\n return null;\n }\n const modalState = { ..._modalState };\n\n const isPage = modalState.type === ModalType.PAGE;\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n key={key}\n getRootRef={(e) => {\n const modalState = this.getModalState(modalId);\n if (modalState) {\n modalState.modalElement = e;\n }\n }}\n onClose={this.props.onExit}\n timeout={this.timeout}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\"ModalRoot__modal\", {\n \"ModalRoot__modal--active\": modalId === activeModal,\n \"ModalRoot__modal--prev\": modalId === exitingModal,\n \"ModalRoot__modal--next\":\n (exitingModal && modalId === activeModal) ||\n modalId === enteringModal,\n\n \"ModalRoot__modal--dragging\": dragging,\n\n \"ModalRoot__modal--expandable\":\n isPage && modalState.expandable,\n \"ModalRoot__modal--expanded\":\n isPage && modalState.expanded,\n \"ModalRoot__modal--collapsed\":\n isPage && modalState.collapsed,\n })}\n restoreFocus={false}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </Touch>\n </ModalRootContext.Provider>\n </TouchRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootTouch = withContext(\n withPlatform(\n withDOM<ModalRootProps>(\n withModalManager(initModal)(ModalRootTouchComponent)\n )\n ),\n ConfigProviderContext,\n \"configProvider\"\n);\n\n/**\n * Инициализирует модалку перед анимацией открытия\n */\nfunction initModal(modalState: ModalsStateEntry) {\n switch (modalState.type) {\n case ModalType.PAGE:\n modalState.settlingHeight =\n modalState.settlingHeight || MODAL_PAGE_DEFAULT_PERCENT_HEIGHT;\n return initPageModal(modalState);\n case ModalType.CARD:\n return initCardModal(modalState);\n default:\n IS_DEV &&\n warn(\n `initActiveModal: modalState.type=\"${modalState.type}\" не поддерживается`,\n \"error\"\n );\n }\n}\n\nfunction initPageModal(modalState: ModalsStateEntry) {\n const { contentElement } = modalState;\n const contentHeight = (contentElement?.firstElementChild as HTMLElement)\n .offsetHeight;\n\n let prevTranslateY = modalState.translateY;\n\n modalState.expandable =\n contentHeight > (contentElement?.clientHeight ?? 0) ||\n modalState.settlingHeight === 100;\n\n let collapsed = false;\n let expanded = false;\n let translateYFrom;\n let translateY;\n let expandedRange: TranslateRange;\n let collapsedRange: TranslateRange;\n let hiddenRange: TranslateRange;\n\n if (modalState.expandable) {\n translateYFrom = 100 - (modalState.settlingHeight ?? 0);\n\n const shiftHalf = translateYFrom / 2;\n const visiblePart = 100 - translateYFrom;\n\n expandedRange = [0, shiftHalf];\n collapsedRange = [shiftHalf, translateYFrom + visiblePart / 4];\n hiddenRange = [translateYFrom + visiblePart / 4, 100];\n\n collapsed = translateYFrom > 0;\n expanded = translateYFrom <= 0;\n translateY = translateYFrom;\n } else {\n const headerHeight = modalState.headerElement?.offsetHeight ?? 0;\n const height = contentHeight + headerHeight;\n\n translateYFrom =\n 100 -\n (height / (modalState.innerElement?.parentElement?.offsetHeight ?? 0)) *\n 100;\n translateY = translateYFrom;\n\n expandedRange = [translateY, translateY + 25];\n collapsedRange = [translateY + 25, translateY + 25];\n hiddenRange = [translateY + 25, translateY + 100];\n }\n\n // Если модалка может открываться на весь экран, и новый сдвиг больше предыдущего, то откроем её на весь экран\n if (\n (modalState.expandable && translateY > (prevTranslateY ?? 0)) ||\n modalState.settlingHeight === 100\n ) {\n translateY = 0;\n }\n\n 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"}
@@ -19,4 +19,7 @@ export interface ModalRootProps extends AdaptivityProps {
19
19
  */
20
20
  onClosed?(modalId: string): void;
21
21
  }
22
+ /**
23
+ * @see https://vkcom.github.io/VKUI/#/ModalRoot
24
+ */
22
25
  export declare const ModalRoot: React.FC<Pick<ModalRootProps & AdaptivityContextInterface, "onOpen" | "onOpened" | "onClose" | "onClosed" | "activeModal"> & import("../AdaptivityProvider/AdaptivityContext").SizeProps>;