@vkontakte/vkui 4.27.2 → 4.29.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 (1346) hide show
  1. package/.cache/.eslintcache +1 -1
  2. package/.cache/.stylelintcache +1 -1
  3. package/.cache/.tsbuildinfo +2781 -245
  4. package/.cache/ts/src/components/Button/Button.d.ts +1 -2
  5. package/.cache/ts/src/components/ButtonGroup/ButtonGroup.d.ts +20 -0
  6. package/.cache/ts/src/components/Calendar/Calendar.d.ts +21 -0
  7. package/.cache/ts/src/components/CalendarDay/CalendarDay.d.ts +22 -0
  8. package/.cache/ts/src/components/CalendarDays/CalendarDays.d.ts +22 -0
  9. package/.cache/ts/src/components/CalendarHeader/CalendarHeader.d.ts +16 -0
  10. package/.cache/ts/src/components/CalendarRange/CalendarRange.d.ts +16 -0
  11. package/.cache/ts/src/components/CalendarTime/CalendarTime.d.ts +11 -0
  12. package/.cache/ts/src/components/Cell/Cell.d.ts +1 -1
  13. package/.cache/ts/src/components/ChipsInput/ChipsInput.d.ts +1 -2
  14. package/.cache/ts/src/components/ChipsSelect/ChipsSelect.d.ts +2 -3
  15. package/.cache/ts/src/components/ClickPopper/ClickPopper.d.ts +1 -1
  16. package/.cache/ts/src/components/ConfigProvider/ConfigProvider.d.ts +4 -0
  17. package/.cache/ts/src/components/CustomScrollView/CustomScrollView.d.ts +1 -1
  18. package/.cache/ts/src/components/CustomSelect/CustomSelect.d.ts +11 -2
  19. package/.cache/ts/src/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +4 -1
  20. package/.cache/ts/src/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  21. package/.cache/ts/src/components/DateInput/DateInput.d.ts +12 -0
  22. package/.cache/ts/src/components/DateRangeInput/DateRangeInput.d.ts +18 -0
  23. package/.cache/ts/src/components/Div/Div.d.ts +1 -2
  24. package/.cache/ts/src/components/Gallery/Gallery.d.ts +9 -1
  25. package/.cache/ts/src/components/GridAvatar/GridAvatar.d.ts +1 -0
  26. package/.cache/ts/src/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  27. package/.cache/ts/src/components/IconButton/IconButton.d.ts +1 -1
  28. package/.cache/ts/src/components/Input/Input.d.ts +1 -2
  29. package/.cache/ts/src/components/InputLike/InputLike.d.ts +10 -0
  30. package/.cache/ts/src/components/InputLike/InputLikeDivider.d.ts +3 -0
  31. package/.cache/ts/src/components/LocaleProviderContext/LocaleProviderContext.d.ts +2 -0
  32. package/.cache/ts/src/components/ModalCard/ModalCard.d.ts +1 -1
  33. package/.cache/ts/src/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  34. package/.cache/ts/src/components/ModalPage/ModalPage.d.ts +16 -1
  35. package/.cache/ts/src/components/ModalRoot/ModalRoot.d.ts +14 -2
  36. package/.cache/ts/src/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  37. package/.cache/ts/src/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  38. package/.cache/ts/src/components/ModalRoot/types.d.ts +16 -1
  39. package/.cache/ts/src/components/ModalRoot/useModalManager.d.ts +6 -5
  40. package/.cache/ts/src/components/Pagination/Pagination.d.ts +42 -0
  41. package/.cache/ts/src/components/PanelHeaderBack/PanelHeaderBack.d.ts +1 -1
  42. package/.cache/ts/src/components/RichCell/RichCell.d.ts +3 -2
  43. package/.cache/ts/src/components/Select/Select.d.ts +1 -2
  44. package/.cache/ts/src/components/SelectMimicry/SelectMimicry.d.ts +5 -1
  45. package/.cache/ts/src/components/SimpleCell/SimpleCell.d.ts +1 -1
  46. package/.cache/ts/src/components/SimpleCheckbox/SimpleCheckbox.d.ts +0 -1
  47. package/.cache/ts/src/components/Tappable/Tappable.d.ts +3 -1
  48. package/.cache/ts/src/components/Touch/TouchContext.d.ts +1 -1
  49. package/.cache/ts/src/components/Typography/Caption/Caption.d.ts +8 -4
  50. package/.cache/ts/src/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  51. package/.cache/ts/src/components/Typography/Subhead/Subhead.d.ts +4 -3
  52. package/.cache/ts/src/components/Typography/Title/Title.d.ts +4 -3
  53. package/.cache/ts/src/components/View/ViewInfinite.d.ts +2 -2
  54. package/.cache/ts/src/hooks/useBooleanState.d.ts +6 -0
  55. package/.cache/ts/src/hooks/useBridgeAdaptivity.d.ts +6 -0
  56. package/.cache/ts/src/hooks/useCalendar.d.ts +18 -0
  57. package/.cache/ts/src/hooks/useDateInput.d.ts +30 -0
  58. package/.cache/ts/src/hooks/useKeyboard.d.ts +1 -1
  59. package/.cache/ts/src/hooks/useKeyboardInputTracker.d.ts +2 -0
  60. package/.cache/ts/src/hooks/useOrientationChange.d.ts +7 -0
  61. package/.cache/ts/src/hooks/usePagination.d.ts +34 -0
  62. package/.cache/ts/src/index.d.ts +32 -11
  63. package/.cache/ts/src/lib/calendar.d.ts +14 -0
  64. package/.cache/ts/src/lib/date.d.ts +29 -0
  65. package/.cache/ts/src/lib/getNavId.d.ts +2 -1
  66. package/.cache/ts/src/lib/utils.d.ts +2 -1
  67. package/.cache/ts/src/lib/warnOnce.d.ts +2 -1
  68. package/.cache/ts/src/testing/utils.d.ts +1 -0
  69. package/.cache/ts/src/tokenized/index.d.ts +32 -4
  70. package/.cache/ts/src/unstable/index.d.ts +6 -6
  71. package/.eslintrc.json +8 -2
  72. package/CONTRIBUTING.md +3 -2
  73. package/dist/cjs/components/ActionSheet/ActionSheet.js +5 -8
  74. package/dist/cjs/components/ActionSheet/ActionSheet.js.map +1 -1
  75. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js +2 -1
  76. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  77. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js +1 -1
  78. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  79. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js +10 -11
  80. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  81. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js +44 -11
  82. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  83. package/dist/cjs/components/Alert/Alert.js +12 -14
  84. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  85. package/dist/cjs/components/AppRoot/AppRoot.js +3 -2
  86. package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
  87. package/dist/cjs/components/Avatar/Avatar.js +4 -1
  88. package/dist/cjs/components/Avatar/Avatar.js.map +1 -1
  89. package/dist/cjs/components/Banner/Banner.js +5 -4
  90. package/dist/cjs/components/Banner/Banner.js.map +1 -1
  91. package/dist/cjs/components/Button/Button.d.ts +1 -2
  92. package/dist/cjs/components/Button/Button.js +40 -49
  93. package/dist/cjs/components/Button/Button.js.map +1 -1
  94. package/dist/cjs/components/ButtonGroup/ButtonGroup.d.ts +20 -0
  95. package/dist/cjs/components/ButtonGroup/ButtonGroup.js +38 -0
  96. package/dist/cjs/components/ButtonGroup/ButtonGroup.js.map +1 -0
  97. package/dist/cjs/components/Calendar/Calendar.d.ts +21 -0
  98. package/dist/cjs/components/Calendar/Calendar.js +160 -0
  99. package/dist/cjs/components/Calendar/Calendar.js.map +1 -0
  100. package/dist/cjs/components/CalendarDay/CalendarDay.d.ts +22 -0
  101. package/dist/cjs/components/CalendarDay/CalendarDay.js +112 -0
  102. package/dist/cjs/components/CalendarDay/CalendarDay.js.map +1 -0
  103. package/dist/cjs/components/CalendarDays/CalendarDays.d.ts +22 -0
  104. package/dist/cjs/components/CalendarDays/CalendarDays.js +118 -0
  105. package/dist/cjs/components/CalendarDays/CalendarDays.js.map +1 -0
  106. package/dist/cjs/components/CalendarHeader/CalendarHeader.d.ts +16 -0
  107. package/dist/cjs/components/CalendarHeader/CalendarHeader.js +143 -0
  108. package/dist/cjs/components/CalendarHeader/CalendarHeader.js.map +1 -0
  109. package/dist/cjs/components/CalendarRange/CalendarRange.d.ts +16 -0
  110. package/dist/cjs/components/CalendarRange/CalendarRange.js +216 -0
  111. package/dist/cjs/components/CalendarRange/CalendarRange.js.map +1 -0
  112. package/dist/cjs/components/CalendarTime/CalendarTime.d.ts +11 -0
  113. package/dist/cjs/components/CalendarTime/CalendarTime.js +90 -0
  114. package/dist/cjs/components/CalendarTime/CalendarTime.js.map +1 -0
  115. package/dist/cjs/components/CardScroll/CardScroll.js +3 -2
  116. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  117. package/dist/cjs/components/Cell/Cell.d.ts +1 -1
  118. package/dist/cjs/components/Cell/Cell.js +4 -3
  119. package/dist/cjs/components/Cell/Cell.js.map +1 -1
  120. package/dist/cjs/components/CellButton/CellButton.js +1 -0
  121. package/dist/cjs/components/CellButton/CellButton.js.map +1 -1
  122. package/dist/cjs/components/Checkbox/Checkbox.js +2 -5
  123. package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
  124. package/dist/cjs/components/Chip/Chip.js +3 -4
  125. package/dist/cjs/components/Chip/Chip.js.map +1 -1
  126. package/dist/cjs/components/ChipsInput/ChipsInput.d.ts +1 -2
  127. package/dist/cjs/components/ChipsInput/ChipsInput.js +4 -9
  128. package/dist/cjs/components/ChipsInput/ChipsInput.js.map +1 -1
  129. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts +2 -3
  130. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +15 -23
  131. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  132. package/dist/cjs/components/ClickPopper/ClickPopper.d.ts +1 -1
  133. package/dist/cjs/components/ClickPopper/ClickPopper.js.map +1 -1
  134. package/dist/cjs/components/ConfigProvider/ConfigProvider.d.ts +4 -0
  135. package/dist/cjs/components/ConfigProvider/ConfigProvider.js +8 -2
  136. package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
  137. package/dist/cjs/components/ContentCard/ContentCard.js +9 -10
  138. package/dist/cjs/components/ContentCard/ContentCard.js.map +1 -1
  139. package/dist/cjs/components/Counter/Counter.js +3 -3
  140. package/dist/cjs/components/Counter/Counter.js.map +1 -1
  141. package/dist/cjs/components/CustomScrollView/CustomScrollView.d.ts +1 -1
  142. package/dist/cjs/components/CustomScrollView/CustomScrollView.js.map +1 -1
  143. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +11 -2
  144. package/dist/cjs/components/CustomSelect/CustomSelect.js +63 -42
  145. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  146. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +4 -1
  147. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js +11 -6
  148. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  149. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  150. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js +27 -19
  151. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  152. package/dist/cjs/components/DateInput/DateInput.d.ts +12 -0
  153. package/dist/cjs/components/DateInput/DateInput.js +290 -0
  154. package/dist/cjs/components/DateInput/DateInput.js.map +1 -0
  155. package/dist/cjs/components/DatePicker/DatePicker.js +6 -6
  156. package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
  157. package/dist/cjs/components/DateRangeInput/DateRangeInput.d.ts +18 -0
  158. package/dist/cjs/components/DateRangeInput/DateRangeInput.js +310 -0
  159. package/dist/cjs/components/DateRangeInput/DateRangeInput.js.map +1 -0
  160. package/dist/cjs/components/Div/Div.d.ts +1 -2
  161. package/dist/cjs/components/Div/Div.js +2 -5
  162. package/dist/cjs/components/Div/Div.js.map +1 -1
  163. package/dist/cjs/components/File/File.js +2 -2
  164. package/dist/cjs/components/File/File.js.map +1 -1
  165. package/dist/cjs/components/FixedLayout/FixedLayout.js +2 -1
  166. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  167. package/dist/cjs/components/Footer/Footer.js +2 -4
  168. package/dist/cjs/components/Footer/Footer.js.map +1 -1
  169. package/dist/cjs/components/FormField/FormField.js +2 -6
  170. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  171. package/dist/cjs/components/FormItem/FormItem.js +6 -7
  172. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  173. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  174. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  175. package/dist/cjs/components/FormStatus/FormStatus.js +3 -8
  176. package/dist/cjs/components/FormStatus/FormStatus.js.map +1 -1
  177. package/dist/cjs/components/Gallery/Gallery.d.ts +9 -1
  178. package/dist/cjs/components/Gallery/Gallery.js +10 -2
  179. package/dist/cjs/components/Gallery/Gallery.js.map +1 -1
  180. package/dist/cjs/components/GridAvatar/GridAvatar.d.ts +1 -0
  181. package/dist/cjs/components/GridAvatar/GridAvatar.js +6 -6
  182. package/dist/cjs/components/GridAvatar/GridAvatar.js.map +1 -1
  183. package/dist/cjs/components/Group/Group.js +5 -6
  184. package/dist/cjs/components/Group/Group.js.map +1 -1
  185. package/dist/cjs/components/Header/Header.js +18 -24
  186. package/dist/cjs/components/Header/Header.js.map +1 -1
  187. package/dist/cjs/components/HorizontalCell/HorizontalCell.js +6 -9
  188. package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
  189. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  190. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js +22 -21
  191. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  192. package/dist/cjs/components/IconButton/IconButton.d.ts +1 -1
  193. package/dist/cjs/components/InfoRow/InfoRow.js +2 -2
  194. package/dist/cjs/components/InfoRow/InfoRow.js.map +1 -1
  195. package/dist/cjs/components/Input/Input.d.ts +1 -2
  196. package/dist/cjs/components/Input/Input.js +11 -15
  197. package/dist/cjs/components/Input/Input.js.map +1 -1
  198. package/dist/cjs/components/InputLike/InputLike.d.ts +10 -0
  199. package/dist/cjs/components/InputLike/InputLike.js +71 -0
  200. package/dist/cjs/components/InputLike/InputLike.js.map +1 -0
  201. package/dist/cjs/components/InputLike/InputLikeDivider.d.ts +3 -0
  202. package/dist/cjs/components/InputLike/InputLikeDivider.js +27 -0
  203. package/dist/cjs/components/InputLike/InputLikeDivider.js.map +1 -0
  204. package/dist/cjs/components/List/List.js +1 -0
  205. package/dist/cjs/components/List/List.js.map +1 -1
  206. package/dist/cjs/components/LocaleProviderContext/LocaleProviderContext.d.ts +2 -0
  207. package/dist/cjs/components/LocaleProviderContext/LocaleProviderContext.js +14 -0
  208. package/dist/cjs/components/LocaleProviderContext/LocaleProviderContext.js.map +1 -0
  209. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js +1 -0
  210. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  211. package/dist/cjs/components/ModalCard/ModalCard.d.ts +1 -1
  212. package/dist/cjs/components/ModalCard/ModalCard.js +1 -0
  213. package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
  214. package/dist/cjs/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  215. package/dist/cjs/components/ModalCardBase/ModalCardBase.js +10 -4
  216. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  217. package/dist/cjs/components/ModalPage/ModalPage.d.ts +16 -1
  218. package/dist/cjs/components/ModalPage/ModalPage.js +10 -6
  219. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  220. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js +1 -0
  221. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  222. package/dist/cjs/components/ModalRoot/ModalRoot.d.ts +14 -2
  223. package/dist/cjs/components/ModalRoot/ModalRoot.js +14 -11
  224. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  225. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  226. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  227. package/dist/cjs/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  228. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +10 -7
  229. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  230. package/dist/cjs/components/ModalRoot/types.d.ts +16 -1
  231. package/dist/cjs/components/ModalRoot/types.js.map +1 -1
  232. package/dist/cjs/components/ModalRoot/useModalManager.d.ts +6 -5
  233. package/dist/cjs/components/ModalRoot/useModalManager.js +54 -16
  234. package/dist/cjs/components/ModalRoot/useModalManager.js.map +1 -1
  235. package/dist/cjs/components/NativeSelect/NativeSelect.js +2 -1
  236. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  237. package/dist/cjs/components/Pagination/Pagination.d.ts +42 -0
  238. package/dist/cjs/components/Pagination/Pagination.js +152 -0
  239. package/dist/cjs/components/Pagination/Pagination.js.map +1 -0
  240. package/dist/cjs/components/Panel/Panel.js +2 -1
  241. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  242. package/dist/cjs/components/PanelHeader/PanelHeader.js +1 -0
  243. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  244. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.d.ts +1 -1
  245. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js +1 -0
  246. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  247. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js +5 -4
  248. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  249. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js +2 -4
  250. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  251. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js +1 -0
  252. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  253. package/dist/cjs/components/Placeholder/Placeholder.js +4 -3
  254. package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
  255. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js +1 -0
  256. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  257. package/dist/cjs/components/Popper/Popper.js +2 -2
  258. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  259. package/dist/cjs/components/PromoBanner/PromoBanner.js +5 -9
  260. package/dist/cjs/components/PromoBanner/PromoBanner.js.map +1 -1
  261. package/dist/cjs/components/PullToRefresh/PullToRefresh.js +2 -1
  262. package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
  263. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js +1 -0
  264. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  265. package/dist/cjs/components/Radio/Radio.js +2 -5
  266. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  267. package/dist/cjs/components/RichCell/RichCell.d.ts +3 -2
  268. package/dist/cjs/components/RichCell/RichCell.js +3 -2
  269. package/dist/cjs/components/RichCell/RichCell.js.map +1 -1
  270. package/dist/cjs/components/RichTooltip/RichTooltip.js +2 -1
  271. package/dist/cjs/components/RichTooltip/RichTooltip.js.map +1 -1
  272. package/dist/cjs/components/Root/Root.js +8 -7
  273. package/dist/cjs/components/Root/Root.js.map +1 -1
  274. package/dist/cjs/components/Search/Search.js +3 -2
  275. package/dist/cjs/components/Search/Search.js.map +1 -1
  276. package/dist/cjs/components/SegmentedControl/SegmentedControl.js +19 -13
  277. package/dist/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
  278. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
  279. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  280. package/dist/cjs/components/Select/Select.d.ts +1 -2
  281. package/dist/cjs/components/Select/Select.js +7 -9
  282. package/dist/cjs/components/Select/Select.js.map +1 -1
  283. package/dist/cjs/components/SelectMimicry/SelectMimicry.d.ts +5 -1
  284. package/dist/cjs/components/SelectMimicry/SelectMimicry.js +13 -6
  285. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  286. package/dist/cjs/components/Separator/Separator.js +3 -1
  287. package/dist/cjs/components/Separator/Separator.js.map +1 -1
  288. package/dist/cjs/components/SimpleCell/SimpleCell.d.ts +1 -1
  289. package/dist/cjs/components/SimpleCell/SimpleCell.js +5 -4
  290. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  291. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.d.ts +0 -1
  292. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js +8 -7
  293. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  294. package/dist/cjs/components/SliderSwitch/SliderSwitch.js +1 -0
  295. package/dist/cjs/components/SliderSwitch/SliderSwitch.js.map +1 -1
  296. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js +1 -0
  297. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  298. package/dist/cjs/components/Snackbar/Snackbar.js +3 -2
  299. package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
  300. package/dist/cjs/components/Spacing/Spacing.js +4 -3
  301. package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
  302. package/dist/cjs/components/SplitCol/SplitCol.js +2 -1
  303. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  304. package/dist/cjs/components/SplitLayout/SplitLayout.js +2 -1
  305. package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
  306. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js +2 -2
  307. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  308. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js +7 -7
  309. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  310. package/dist/cjs/components/Switch/Switch.js +1 -0
  311. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  312. package/dist/cjs/components/Tabbar/Tabbar.js +1 -0
  313. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  314. package/dist/cjs/components/TabbarItem/TabbarItem.js +2 -1
  315. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  316. package/dist/cjs/components/TabsItem/TabsItem.js +3 -2
  317. package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
  318. package/dist/cjs/components/Tappable/Tappable.d.ts +3 -1
  319. package/dist/cjs/components/Tappable/Tappable.js +16 -15
  320. package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
  321. package/dist/cjs/components/TextTooltip/TextTooltip.js +3 -3
  322. package/dist/cjs/components/TextTooltip/TextTooltip.js.map +1 -1
  323. package/dist/cjs/components/Tooltip/Tooltip.js +6 -6
  324. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  325. package/dist/cjs/components/Touch/Touch.js +9 -3
  326. package/dist/cjs/components/Touch/Touch.js.map +1 -1
  327. package/dist/cjs/components/Touch/TouchContext.d.ts +1 -1
  328. package/dist/cjs/components/Touch/TouchContext.js +1 -1
  329. package/dist/cjs/components/Touch/TouchContext.js.map +1 -1
  330. package/dist/cjs/components/Typography/Caption/Caption.d.ts +8 -4
  331. package/dist/cjs/components/Typography/Caption/Caption.js +12 -14
  332. package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
  333. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  334. package/dist/cjs/components/Typography/Paragraph/Paragraph.js +42 -0
  335. package/dist/cjs/components/Typography/Paragraph/Paragraph.js.map +1 -0
  336. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts +4 -3
  337. package/dist/cjs/components/Typography/Subhead/Subhead.js +4 -6
  338. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  339. package/dist/cjs/components/Typography/Text/Text.js +1 -1
  340. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  341. package/dist/cjs/components/Typography/Title/Title.d.ts +4 -3
  342. package/dist/cjs/components/Typography/Title/Title.js +5 -9
  343. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  344. package/dist/cjs/components/UsersStack/UsersStack.js +6 -6
  345. package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
  346. package/dist/cjs/components/View/View.js +5 -0
  347. package/dist/cjs/components/View/View.js.map +1 -1
  348. package/dist/cjs/components/View/ViewInfinite.d.ts +2 -2
  349. package/dist/cjs/components/View/ViewInfinite.js +17 -15
  350. package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
  351. package/dist/cjs/components/View/utils.js +5 -2
  352. package/dist/cjs/components/View/utils.js.map +1 -1
  353. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js +3 -2
  354. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  355. package/dist/cjs/helpers/scheme.js +2 -2
  356. package/dist/cjs/helpers/scheme.js.map +1 -1
  357. package/dist/cjs/hooks/useBooleanState.d.ts +6 -0
  358. package/dist/cjs/hooks/useBooleanState.js +42 -0
  359. package/dist/cjs/hooks/useBooleanState.js.map +1 -0
  360. package/dist/cjs/hooks/useBridgeAdaptivity.d.ts +6 -0
  361. package/dist/cjs/hooks/useBridgeAdaptivity.js +85 -0
  362. package/dist/cjs/hooks/useBridgeAdaptivity.js.map +1 -0
  363. package/dist/cjs/hooks/useCalendar.d.ts +18 -0
  364. package/dist/cjs/hooks/useCalendar.js +78 -0
  365. package/dist/cjs/hooks/useCalendar.js.map +1 -0
  366. package/dist/cjs/hooks/useDateInput.d.ts +30 -0
  367. package/dist/cjs/hooks/useDateInput.js +180 -0
  368. package/dist/cjs/hooks/useDateInput.js.map +1 -0
  369. package/dist/cjs/hooks/useKeyboard.d.ts +1 -1
  370. package/dist/cjs/hooks/useKeyboard.js +1 -1
  371. package/dist/cjs/hooks/useKeyboard.js.map +1 -1
  372. package/dist/cjs/hooks/useKeyboardInputTracker.d.ts +2 -0
  373. package/dist/cjs/hooks/useKeyboardInputTracker.js +15 -4
  374. package/dist/cjs/hooks/useKeyboardInputTracker.js.map +1 -1
  375. package/dist/cjs/hooks/useOrientationChange.d.ts +7 -0
  376. package/dist/cjs/hooks/useOrientationChange.js +56 -0
  377. package/dist/cjs/hooks/useOrientationChange.js.map +1 -0
  378. package/dist/cjs/hooks/usePagination.d.ts +34 -0
  379. package/dist/cjs/hooks/usePagination.js +81 -0
  380. package/dist/cjs/hooks/usePagination.js.map +1 -0
  381. package/dist/cjs/hooks/usePatchChildrenRef.js +1 -1
  382. package/dist/cjs/hooks/usePatchChildrenRef.js.map +1 -1
  383. package/dist/cjs/hooks/useWaitTransitionFinish.js +6 -1
  384. package/dist/cjs/hooks/useWaitTransitionFinish.js.map +1 -1
  385. package/dist/cjs/index.d.ts +32 -11
  386. package/dist/cjs/index.js +94 -22
  387. package/dist/cjs/index.js.map +1 -1
  388. package/dist/cjs/lib/calendar.d.ts +14 -0
  389. package/dist/cjs/lib/calendar.js +131 -0
  390. package/dist/cjs/lib/calendar.js.map +1 -0
  391. package/dist/cjs/lib/date.d.ts +29 -0
  392. package/dist/cjs/lib/date.js +286 -0
  393. package/dist/cjs/lib/date.js.map +1 -0
  394. package/dist/cjs/lib/getNavId.d.ts +2 -1
  395. package/dist/cjs/lib/getNavId.js +1 -1
  396. package/dist/cjs/lib/getNavId.js.map +1 -1
  397. package/dist/cjs/lib/utils.d.ts +2 -1
  398. package/dist/cjs/lib/utils.js +7 -0
  399. package/dist/cjs/lib/utils.js.map +1 -1
  400. package/dist/cjs/lib/warnOnce.d.ts +2 -1
  401. package/dist/cjs/lib/warnOnce.js +3 -1
  402. package/dist/cjs/lib/warnOnce.js.map +1 -1
  403. package/dist/cjs/tokenized/index.d.ts +32 -4
  404. package/dist/cjs/tokenized/index.js +120 -10
  405. package/dist/cjs/tokenized/index.js.map +1 -1
  406. package/dist/cjs/unstable/index.d.ts +6 -6
  407. package/dist/cjs/unstable/index.js +6 -8
  408. package/dist/cjs/unstable/index.js.map +1 -1
  409. package/dist/components/ActionSheet/ActionSheet.js +3 -6
  410. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  411. package/dist/components/ActionSheet/ActionSheetDropdown.js +2 -1
  412. package/dist/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  413. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js +1 -1
  414. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  415. package/dist/components/ActionSheetItem/ActionSheetItem.js +6 -7
  416. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  417. package/dist/components/AdaptivityProvider/AdaptivityProvider.js +43 -11
  418. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  419. package/dist/components/Alert/Alert.js +7 -9
  420. package/dist/components/Alert/Alert.js.map +1 -1
  421. package/dist/components/AppRoot/AppRoot.js +3 -2
  422. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  423. package/dist/components/Avatar/Avatar.js +4 -1
  424. package/dist/components/Avatar/Avatar.js.map +1 -1
  425. package/dist/components/Banner/Banner.js +3 -2
  426. package/dist/components/Banner/Banner.js.map +1 -1
  427. package/dist/components/Button/Button.d.ts +1 -2
  428. package/dist/components/Button/Button.js +32 -40
  429. package/dist/components/Button/Button.js.map +1 -1
  430. package/dist/components/ButtonGroup/ButtonGroup.d.ts +20 -0
  431. package/dist/components/ButtonGroup/ButtonGroup.js +23 -0
  432. package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -0
  433. package/dist/components/Calendar/Calendar.d.ts +21 -0
  434. package/dist/components/Calendar/Calendar.js +133 -0
  435. package/dist/components/Calendar/Calendar.js.map +1 -0
  436. package/dist/components/CalendarDay/CalendarDay.d.ts +22 -0
  437. package/dist/components/CalendarDay/CalendarDay.js +94 -0
  438. package/dist/components/CalendarDay/CalendarDay.js.map +1 -0
  439. package/dist/components/CalendarDays/CalendarDays.d.ts +22 -0
  440. package/dist/components/CalendarDays/CalendarDays.js +94 -0
  441. package/dist/components/CalendarDays/CalendarDays.js.map +1 -0
  442. package/dist/components/CalendarHeader/CalendarHeader.d.ts +16 -0
  443. package/dist/components/CalendarHeader/CalendarHeader.js +118 -0
  444. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -0
  445. package/dist/components/CalendarRange/CalendarRange.d.ts +16 -0
  446. package/dist/components/CalendarRange/CalendarRange.js +193 -0
  447. package/dist/components/CalendarRange/CalendarRange.js.map +1 -0
  448. package/dist/components/CalendarTime/CalendarTime.d.ts +11 -0
  449. package/dist/components/CalendarTime/CalendarTime.js +73 -0
  450. package/dist/components/CalendarTime/CalendarTime.js.map +1 -0
  451. package/dist/components/CardScroll/CardScroll.js +2 -1
  452. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  453. package/dist/components/Cell/Cell.d.ts +1 -1
  454. package/dist/components/Cell/Cell.js +4 -3
  455. package/dist/components/Cell/Cell.js.map +1 -1
  456. package/dist/components/CellButton/CellButton.js +1 -0
  457. package/dist/components/CellButton/CellButton.js.map +1 -1
  458. package/dist/components/Checkbox/Checkbox.js +1 -4
  459. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  460. package/dist/components/Chip/Chip.js +2 -3
  461. package/dist/components/Chip/Chip.js.map +1 -1
  462. package/dist/components/ChipsInput/ChipsInput.d.ts +1 -2
  463. package/dist/components/ChipsInput/ChipsInput.js +3 -10
  464. package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
  465. package/dist/components/ChipsSelect/ChipsSelect.d.ts +2 -3
  466. package/dist/components/ChipsSelect/ChipsSelect.js +7 -13
  467. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  468. package/dist/components/ClickPopper/ClickPopper.d.ts +1 -1
  469. package/dist/components/ClickPopper/ClickPopper.js.map +1 -1
  470. package/dist/components/ConfigProvider/ConfigProvider.d.ts +4 -0
  471. package/dist/components/ConfigProvider/ConfigProvider.js +7 -2
  472. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  473. package/dist/components/ContentCard/ContentCard.js +6 -7
  474. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  475. package/dist/components/Counter/Counter.js +2 -2
  476. package/dist/components/Counter/Counter.js.map +1 -1
  477. package/dist/components/CustomScrollView/CustomScrollView.d.ts +1 -1
  478. package/dist/components/CustomScrollView/CustomScrollView.js.map +1 -1
  479. package/dist/components/CustomSelect/CustomSelect.d.ts +11 -2
  480. package/dist/components/CustomSelect/CustomSelect.js +57 -35
  481. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  482. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +4 -1
  483. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js +11 -6
  484. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  485. package/dist/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  486. package/dist/components/CustomSelectOption/CustomSelectOption.js +21 -19
  487. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  488. package/dist/components/DateInput/DateInput.d.ts +12 -0
  489. package/dist/components/DateInput/DateInput.js +261 -0
  490. package/dist/components/DateInput/DateInput.js.map +1 -0
  491. package/dist/components/DatePicker/DatePicker.js +2 -2
  492. package/dist/components/DatePicker/DatePicker.js.map +1 -1
  493. package/dist/components/DateRangeInput/DateRangeInput.d.ts +18 -0
  494. package/dist/components/DateRangeInput/DateRangeInput.js +281 -0
  495. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -0
  496. package/dist/components/Div/Div.d.ts +1 -2
  497. package/dist/components/Div/Div.js +1 -3
  498. package/dist/components/Div/Div.js.map +1 -1
  499. package/dist/components/File/File.js +1 -1
  500. package/dist/components/File/File.js.map +1 -1
  501. package/dist/components/FixedLayout/FixedLayout.js +2 -1
  502. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  503. package/dist/components/Footer/Footer.js +1 -3
  504. package/dist/components/Footer/Footer.js.map +1 -1
  505. package/dist/components/FormField/FormField.js +2 -6
  506. package/dist/components/FormField/FormField.js.map +1 -1
  507. package/dist/components/FormItem/FormItem.js +4 -5
  508. package/dist/components/FormItem/FormItem.js.map +1 -1
  509. package/dist/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  510. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  511. package/dist/components/FormStatus/FormStatus.js +2 -7
  512. package/dist/components/FormStatus/FormStatus.js.map +1 -1
  513. package/dist/components/Gallery/Gallery.d.ts +9 -1
  514. package/dist/components/Gallery/Gallery.js +10 -2
  515. package/dist/components/Gallery/Gallery.js.map +1 -1
  516. package/dist/components/GridAvatar/GridAvatar.d.ts +1 -0
  517. package/dist/components/GridAvatar/GridAvatar.js +5 -6
  518. package/dist/components/GridAvatar/GridAvatar.js.map +1 -1
  519. package/dist/components/Group/Group.js +4 -5
  520. package/dist/components/Group/Group.js.map +1 -1
  521. package/dist/components/Header/Header.js +13 -19
  522. package/dist/components/Header/Header.js.map +1 -1
  523. package/dist/components/HorizontalCell/HorizontalCell.js +3 -6
  524. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  525. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  526. package/dist/components/HorizontalScroll/HorizontalScroll.js +20 -18
  527. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  528. package/dist/components/IconButton/IconButton.d.ts +1 -1
  529. package/dist/components/InfoRow/InfoRow.js +1 -1
  530. package/dist/components/InfoRow/InfoRow.js.map +1 -1
  531. package/dist/components/Input/Input.d.ts +1 -2
  532. package/dist/components/Input/Input.js +8 -10
  533. package/dist/components/Input/Input.js.map +1 -1
  534. package/dist/components/InputLike/InputLike.d.ts +10 -0
  535. package/dist/components/InputLike/InputLike.js +52 -0
  536. package/dist/components/InputLike/InputLike.js.map +1 -0
  537. package/dist/components/InputLike/InputLikeDivider.d.ts +3 -0
  538. package/dist/components/InputLike/InputLikeDivider.js +13 -0
  539. package/dist/components/InputLike/InputLikeDivider.js.map +1 -0
  540. package/dist/components/List/List.js +1 -0
  541. package/dist/components/List/List.js.map +1 -1
  542. package/dist/components/LocaleProviderContext/LocaleProviderContext.d.ts +2 -0
  543. package/dist/components/LocaleProviderContext/LocaleProviderContext.js +3 -0
  544. package/dist/components/LocaleProviderContext/LocaleProviderContext.js.map +1 -0
  545. package/dist/components/MiniInfoCell/MiniInfoCell.js +1 -0
  546. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  547. package/dist/components/ModalCard/ModalCard.d.ts +1 -1
  548. package/dist/components/ModalCard/ModalCard.js +1 -0
  549. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  550. package/dist/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  551. package/dist/components/ModalCardBase/ModalCardBase.js +9 -3
  552. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  553. package/dist/components/ModalPage/ModalPage.d.ts +16 -1
  554. package/dist/components/ModalPage/ModalPage.js +9 -6
  555. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  556. package/dist/components/ModalPageHeader/ModalPageHeader.js +1 -0
  557. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  558. package/dist/components/ModalRoot/ModalRoot.d.ts +14 -2
  559. package/dist/components/ModalRoot/ModalRoot.js +14 -11
  560. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  561. package/dist/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  562. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  563. package/dist/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  564. package/dist/components/ModalRoot/ModalRootDesktop.js +10 -7
  565. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  566. package/dist/components/ModalRoot/types.d.ts +16 -1
  567. package/dist/components/ModalRoot/types.js.map +1 -1
  568. package/dist/components/ModalRoot/useModalManager.d.ts +6 -5
  569. package/dist/components/ModalRoot/useModalManager.js +54 -16
  570. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  571. package/dist/components/NativeSelect/NativeSelect.js +2 -1
  572. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  573. package/dist/components/Pagination/Pagination.d.ts +42 -0
  574. package/dist/components/Pagination/Pagination.js +129 -0
  575. package/dist/components/Pagination/Pagination.js.map +1 -0
  576. package/dist/components/Panel/Panel.js +2 -1
  577. package/dist/components/Panel/Panel.js.map +1 -1
  578. package/dist/components/PanelHeader/PanelHeader.js +1 -0
  579. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  580. package/dist/components/PanelHeaderBack/PanelHeaderBack.d.ts +1 -1
  581. package/dist/components/PanelHeaderBack/PanelHeaderBack.js +1 -0
  582. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  583. package/dist/components/PanelHeaderButton/PanelHeaderButton.js +4 -3
  584. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  585. package/dist/components/PanelHeaderContent/PanelHeaderContent.js +1 -3
  586. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  587. package/dist/components/PanelHeaderContext/PanelHeaderContext.js +1 -0
  588. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  589. package/dist/components/Placeholder/Placeholder.js +3 -2
  590. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  591. package/dist/components/PopoutWrapper/PopoutWrapper.js +1 -0
  592. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  593. package/dist/components/Popper/Popper.js +2 -2
  594. package/dist/components/Popper/Popper.js.map +1 -1
  595. package/dist/components/PromoBanner/PromoBanner.js +2 -6
  596. package/dist/components/PromoBanner/PromoBanner.js.map +1 -1
  597. package/dist/components/PullToRefresh/PullToRefresh.js +2 -1
  598. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  599. package/dist/components/PullToRefresh/PullToRefreshSpinner.js +1 -0
  600. package/dist/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  601. package/dist/components/Radio/Radio.js +1 -4
  602. package/dist/components/Radio/Radio.js.map +1 -1
  603. package/dist/components/RichCell/RichCell.d.ts +3 -2
  604. package/dist/components/RichCell/RichCell.js +2 -1
  605. package/dist/components/RichCell/RichCell.js.map +1 -1
  606. package/dist/components/RichTooltip/RichTooltip.js +2 -1
  607. package/dist/components/RichTooltip/RichTooltip.js.map +1 -1
  608. package/dist/components/Root/Root.js +8 -7
  609. package/dist/components/Root/Root.js.map +1 -1
  610. package/dist/components/Search/Search.js +2 -1
  611. package/dist/components/Search/Search.js.map +1 -1
  612. package/dist/components/SegmentedControl/SegmentedControl.js +19 -13
  613. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  614. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
  615. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  616. package/dist/components/Select/Select.d.ts +1 -2
  617. package/dist/components/Select/Select.js +4 -5
  618. package/dist/components/Select/Select.js.map +1 -1
  619. package/dist/components/SelectMimicry/SelectMimicry.d.ts +5 -1
  620. package/dist/components/SelectMimicry/SelectMimicry.js +12 -6
  621. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  622. package/dist/components/Separator/Separator.js +3 -1
  623. package/dist/components/Separator/Separator.js.map +1 -1
  624. package/dist/components/SimpleCell/SimpleCell.d.ts +1 -1
  625. package/dist/components/SimpleCell/SimpleCell.js +3 -2
  626. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  627. package/dist/components/SimpleCheckbox/SimpleCheckbox.d.ts +0 -1
  628. package/dist/components/SimpleCheckbox/SimpleCheckbox.js +7 -5
  629. package/dist/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  630. package/dist/components/SliderSwitch/SliderSwitch.js +1 -0
  631. package/dist/components/SliderSwitch/SliderSwitch.js.map +1 -1
  632. package/dist/components/SliderSwitch/SliderSwitchButton.js +1 -0
  633. package/dist/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  634. package/dist/components/Snackbar/Snackbar.js +2 -1
  635. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  636. package/dist/components/Spacing/Spacing.js +4 -3
  637. package/dist/components/Spacing/Spacing.js.map +1 -1
  638. package/dist/components/SplitCol/SplitCol.js +2 -1
  639. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  640. package/dist/components/SplitLayout/SplitLayout.js +2 -1
  641. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  642. package/dist/components/SubnavigationBar/SubnavigationBar.js +1 -1
  643. package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  644. package/dist/components/SubnavigationButton/SubnavigationButton.js +5 -5
  645. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  646. package/dist/components/Switch/Switch.js +1 -0
  647. package/dist/components/Switch/Switch.js.map +1 -1
  648. package/dist/components/Tabbar/Tabbar.js +1 -0
  649. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  650. package/dist/components/TabbarItem/TabbarItem.js +2 -1
  651. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  652. package/dist/components/TabsItem/TabsItem.js +2 -1
  653. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  654. package/dist/components/Tappable/Tappable.d.ts +3 -1
  655. package/dist/components/Tappable/Tappable.js +15 -15
  656. package/dist/components/Tappable/Tappable.js.map +1 -1
  657. package/dist/components/TextTooltip/TextTooltip.js +1 -1
  658. package/dist/components/TextTooltip/TextTooltip.js.map +1 -1
  659. package/dist/components/Tooltip/Tooltip.js +4 -4
  660. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  661. package/dist/components/Touch/Touch.js +9 -3
  662. package/dist/components/Touch/Touch.js.map +1 -1
  663. package/dist/components/Touch/TouchContext.d.ts +1 -1
  664. package/dist/components/Touch/TouchContext.js +1 -1
  665. package/dist/components/Touch/TouchContext.js.map +1 -1
  666. package/dist/components/Typography/Caption/Caption.d.ts +8 -4
  667. package/dist/components/Typography/Caption/Caption.js +10 -14
  668. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  669. package/dist/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  670. package/dist/components/Typography/Paragraph/Paragraph.js +25 -0
  671. package/dist/components/Typography/Paragraph/Paragraph.js.map +1 -0
  672. package/dist/components/Typography/Subhead/Subhead.d.ts +4 -3
  673. package/dist/components/Typography/Subhead/Subhead.js +3 -7
  674. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  675. package/dist/components/Typography/Text/Text.js +1 -1
  676. package/dist/components/Typography/Text/Text.js.map +1 -1
  677. package/dist/components/Typography/Title/Title.d.ts +4 -3
  678. package/dist/components/Typography/Title/Title.js +3 -8
  679. package/dist/components/Typography/Title/Title.js.map +1 -1
  680. package/dist/components/UsersStack/UsersStack.js +4 -4
  681. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  682. package/dist/components/View/View.js +5 -0
  683. package/dist/components/View/View.js.map +1 -1
  684. package/dist/components/View/ViewInfinite.d.ts +2 -2
  685. package/dist/components/View/ViewInfinite.js +15 -11
  686. package/dist/components/View/ViewInfinite.js.map +1 -1
  687. package/dist/components/View/utils.js +5 -2
  688. package/dist/components/View/utils.js.map +1 -1
  689. package/dist/components/WriteBarIcon/WriteBarIcon.js +3 -2
  690. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  691. package/dist/components.css +21 -6
  692. package/dist/components.css.map +1 -1
  693. package/dist/cssm/components/ActionSheet/ActionSheet.js +3 -6
  694. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  695. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js +2 -1
  696. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  697. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js +1 -1
  698. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  699. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js +6 -7
  700. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  701. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js +43 -11
  702. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  703. package/dist/cssm/components/Alert/Alert.css +1 -1
  704. package/dist/cssm/components/Alert/Alert.js +7 -9
  705. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  706. package/dist/cssm/components/AppRoot/AppRoot.js +3 -2
  707. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  708. package/dist/cssm/components/Avatar/Avatar.js +4 -1
  709. package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
  710. package/dist/cssm/components/Banner/Banner.js +3 -2
  711. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  712. package/dist/cssm/components/Button/Button.css +1 -1
  713. package/dist/cssm/components/Button/Button.d.ts +1 -2
  714. package/dist/cssm/components/Button/Button.js +32 -40
  715. package/dist/cssm/components/Button/Button.js.map +1 -1
  716. package/dist/cssm/components/ButtonGroup/ButtonGroup.css +1 -0
  717. package/dist/cssm/components/ButtonGroup/ButtonGroup.d.ts +20 -0
  718. package/dist/cssm/components/ButtonGroup/ButtonGroup.js +24 -0
  719. package/dist/cssm/components/ButtonGroup/ButtonGroup.js.map +1 -0
  720. package/dist/cssm/components/Calendar/Calendar.css +1 -0
  721. package/dist/cssm/components/Calendar/Calendar.d.ts +21 -0
  722. package/dist/cssm/components/Calendar/Calendar.js +134 -0
  723. package/dist/cssm/components/Calendar/Calendar.js.map +1 -0
  724. package/dist/cssm/components/CalendarDay/CalendarDay.css +1 -0
  725. package/dist/cssm/components/CalendarDay/CalendarDay.d.ts +22 -0
  726. package/dist/cssm/components/CalendarDay/CalendarDay.js +95 -0
  727. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -0
  728. package/dist/cssm/components/CalendarDays/CalendarDays.css +1 -0
  729. package/dist/cssm/components/CalendarDays/CalendarDays.d.ts +22 -0
  730. package/dist/cssm/components/CalendarDays/CalendarDays.js +95 -0
  731. package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -0
  732. package/dist/cssm/components/CalendarHeader/CalendarHeader.css +1 -0
  733. package/dist/cssm/components/CalendarHeader/CalendarHeader.d.ts +16 -0
  734. package/dist/cssm/components/CalendarHeader/CalendarHeader.js +119 -0
  735. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -0
  736. package/dist/cssm/components/CalendarRange/CalendarRange.css +1 -0
  737. package/dist/cssm/components/CalendarRange/CalendarRange.d.ts +16 -0
  738. package/dist/cssm/components/CalendarRange/CalendarRange.js +194 -0
  739. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -0
  740. package/dist/cssm/components/CalendarTime/CalendarTime.css +1 -0
  741. package/dist/cssm/components/CalendarTime/CalendarTime.d.ts +11 -0
  742. package/dist/cssm/components/CalendarTime/CalendarTime.js +74 -0
  743. package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -0
  744. package/dist/cssm/components/CardScroll/CardScroll.js +2 -1
  745. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  746. package/dist/cssm/components/Cell/Cell.d.ts +1 -1
  747. package/dist/cssm/components/Cell/Cell.js +4 -3
  748. package/dist/cssm/components/Cell/Cell.js.map +1 -1
  749. package/dist/cssm/components/CellButton/CellButton.js +1 -0
  750. package/dist/cssm/components/CellButton/CellButton.js.map +1 -1
  751. package/dist/cssm/components/Checkbox/Checkbox.js +1 -4
  752. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  753. package/dist/cssm/components/Chip/Chip.js +2 -3
  754. package/dist/cssm/components/Chip/Chip.js.map +1 -1
  755. package/dist/cssm/components/ChipsInput/ChipsInput.css +1 -1
  756. package/dist/cssm/components/ChipsInput/ChipsInput.d.ts +1 -2
  757. package/dist/cssm/components/ChipsInput/ChipsInput.js +3 -10
  758. package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
  759. package/dist/cssm/components/ChipsSelect/ChipsSelect.css +1 -1
  760. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts +2 -3
  761. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +7 -13
  762. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  763. package/dist/cssm/components/ClickPopper/ClickPopper.d.ts +1 -1
  764. package/dist/cssm/components/ClickPopper/ClickPopper.js.map +1 -1
  765. package/dist/cssm/components/ConfigProvider/ConfigProvider.d.ts +4 -0
  766. package/dist/cssm/components/ConfigProvider/ConfigProvider.js +7 -2
  767. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  768. package/dist/cssm/components/ContentCard/ContentCard.js +6 -7
  769. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  770. package/dist/cssm/components/Counter/Counter.js +2 -2
  771. package/dist/cssm/components/Counter/Counter.js.map +1 -1
  772. package/dist/cssm/components/CustomScrollView/CustomScrollView.d.ts +1 -1
  773. package/dist/cssm/components/CustomScrollView/CustomScrollView.js.map +1 -1
  774. package/dist/cssm/components/CustomSelect/CustomSelect.css +1 -1
  775. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +11 -2
  776. package/dist/cssm/components/CustomSelect/CustomSelect.js +57 -35
  777. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  778. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.css +3 -1
  779. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +4 -1
  780. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js +11 -6
  781. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  782. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.css +3 -1
  783. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  784. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js +21 -19
  785. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  786. package/dist/cssm/components/DateInput/DateInput.css +1 -0
  787. package/dist/cssm/components/DateInput/DateInput.d.ts +12 -0
  788. package/dist/cssm/components/DateInput/DateInput.js +262 -0
  789. package/dist/cssm/components/DateInput/DateInput.js.map +1 -0
  790. package/dist/cssm/components/DatePicker/DatePicker.js +2 -2
  791. package/dist/cssm/components/DatePicker/DatePicker.js.map +1 -1
  792. package/dist/cssm/components/DateRangeInput/DateRangeInput.css +1 -0
  793. package/dist/cssm/components/DateRangeInput/DateRangeInput.d.ts +18 -0
  794. package/dist/cssm/components/DateRangeInput/DateRangeInput.js +282 -0
  795. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -0
  796. package/dist/cssm/components/Div/Div.css +1 -1
  797. package/dist/cssm/components/Div/Div.d.ts +1 -2
  798. package/dist/cssm/components/Div/Div.js +1 -3
  799. package/dist/cssm/components/Div/Div.js.map +1 -1
  800. package/dist/cssm/components/File/File.js +1 -1
  801. package/dist/cssm/components/File/File.js.map +1 -1
  802. package/dist/cssm/components/FixedLayout/FixedLayout.js +2 -1
  803. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  804. package/dist/cssm/components/Footer/Footer.js +1 -3
  805. package/dist/cssm/components/Footer/Footer.js.map +1 -1
  806. package/dist/cssm/components/FormField/FormField.css +5 -1
  807. package/dist/cssm/components/FormField/FormField.js +2 -6
  808. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  809. package/dist/cssm/components/FormItem/FormItem.js +4 -5
  810. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  811. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  812. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  813. package/dist/cssm/components/FormStatus/FormStatus.css +1 -1
  814. package/dist/cssm/components/FormStatus/FormStatus.js +2 -7
  815. package/dist/cssm/components/FormStatus/FormStatus.js.map +1 -1
  816. package/dist/cssm/components/Gallery/Gallery.d.ts +9 -1
  817. package/dist/cssm/components/Gallery/Gallery.js +10 -2
  818. package/dist/cssm/components/Gallery/Gallery.js.map +1 -1
  819. package/dist/cssm/components/GridAvatar/GridAvatar.css +1 -1
  820. package/dist/cssm/components/GridAvatar/GridAvatar.d.ts +1 -0
  821. package/dist/cssm/components/GridAvatar/GridAvatar.js +5 -6
  822. package/dist/cssm/components/GridAvatar/GridAvatar.js.map +1 -1
  823. package/dist/cssm/components/Group/Group.js +4 -5
  824. package/dist/cssm/components/Group/Group.js.map +1 -1
  825. package/dist/cssm/components/Header/Header.js +13 -19
  826. package/dist/cssm/components/Header/Header.js.map +1 -1
  827. package/dist/cssm/components/HorizontalCell/HorizontalCell.js +3 -6
  828. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  829. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  830. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +20 -18
  831. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  832. package/dist/cssm/components/IconButton/IconButton.d.ts +1 -1
  833. package/dist/cssm/components/InfoRow/InfoRow.js +1 -1
  834. package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
  835. package/dist/cssm/components/Input/Input.css +1 -1
  836. package/dist/cssm/components/Input/Input.d.ts +1 -2
  837. package/dist/cssm/components/Input/Input.js +8 -10
  838. package/dist/cssm/components/Input/Input.js.map +1 -1
  839. package/dist/cssm/components/InputLike/InputLike.css +1 -0
  840. package/dist/cssm/components/InputLike/InputLike.d.ts +10 -0
  841. package/dist/cssm/components/InputLike/InputLike.js +53 -0
  842. package/dist/cssm/components/InputLike/InputLike.js.map +1 -0
  843. package/dist/cssm/components/InputLike/InputLikeDivider.css +1 -0
  844. package/dist/cssm/components/InputLike/InputLikeDivider.d.ts +3 -0
  845. package/dist/cssm/components/InputLike/InputLikeDivider.js +14 -0
  846. package/dist/cssm/components/InputLike/InputLikeDivider.js.map +1 -0
  847. package/dist/cssm/components/List/List.js +1 -0
  848. package/dist/cssm/components/List/List.js.map +1 -1
  849. package/dist/cssm/components/LocaleProviderContext/LocaleProviderContext.d.ts +2 -0
  850. package/dist/cssm/components/LocaleProviderContext/LocaleProviderContext.js +3 -0
  851. package/dist/cssm/components/LocaleProviderContext/LocaleProviderContext.js.map +1 -0
  852. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js +1 -0
  853. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  854. package/dist/cssm/components/ModalCard/ModalCard.css +1 -1
  855. package/dist/cssm/components/ModalCard/ModalCard.d.ts +1 -1
  856. package/dist/cssm/components/ModalCard/ModalCard.js +1 -0
  857. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  858. package/dist/cssm/components/ModalCardBase/ModalCardBase.css +1 -1
  859. package/dist/cssm/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  860. package/dist/cssm/components/ModalCardBase/ModalCardBase.js +9 -3
  861. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  862. package/dist/cssm/components/ModalPage/ModalPage.d.ts +16 -1
  863. package/dist/cssm/components/ModalPage/ModalPage.js +9 -6
  864. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  865. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js +1 -0
  866. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  867. package/dist/cssm/components/ModalRoot/ModalRoot.d.ts +14 -2
  868. package/dist/cssm/components/ModalRoot/ModalRoot.js +14 -11
  869. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  870. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  871. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  872. package/dist/cssm/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  873. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +10 -7
  874. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  875. package/dist/cssm/components/ModalRoot/types.d.ts +16 -1
  876. package/dist/cssm/components/ModalRoot/types.js.map +1 -1
  877. package/dist/cssm/components/ModalRoot/useModalManager.d.ts +6 -5
  878. package/dist/cssm/components/ModalRoot/useModalManager.js +54 -16
  879. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  880. package/dist/cssm/components/NativeSelect/NativeSelect.js +2 -1
  881. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  882. package/dist/cssm/components/Pagination/Pagination.css +1 -0
  883. package/dist/cssm/components/Pagination/Pagination.d.ts +42 -0
  884. package/dist/cssm/components/Pagination/Pagination.js +130 -0
  885. package/dist/cssm/components/Pagination/Pagination.js.map +1 -0
  886. package/dist/cssm/components/Panel/Panel.js +2 -1
  887. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  888. package/dist/cssm/components/PanelHeader/PanelHeader.css +1 -1
  889. package/dist/cssm/components/PanelHeader/PanelHeader.js +1 -0
  890. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  891. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.d.ts +1 -1
  892. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js +1 -0
  893. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  894. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.css +1 -1
  895. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js +4 -3
  896. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  897. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.css +1 -1
  898. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js +1 -3
  899. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  900. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js +1 -0
  901. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  902. package/dist/cssm/components/Placeholder/Placeholder.js +3 -2
  903. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  904. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +1 -0
  905. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  906. package/dist/cssm/components/Popper/Popper.js +2 -2
  907. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  908. package/dist/cssm/components/PromoBanner/PromoBanner.js +2 -6
  909. package/dist/cssm/components/PromoBanner/PromoBanner.js.map +1 -1
  910. package/dist/cssm/components/PullToRefresh/PullToRefresh.js +2 -1
  911. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  912. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js +1 -0
  913. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  914. package/dist/cssm/components/Radio/Radio.js +1 -4
  915. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  916. package/dist/cssm/components/Removable/Removable.css +1 -1
  917. package/dist/cssm/components/RichCell/RichCell.d.ts +3 -2
  918. package/dist/cssm/components/RichCell/RichCell.js +2 -1
  919. package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
  920. package/dist/cssm/components/RichTooltip/RichTooltip.js +2 -1
  921. package/dist/cssm/components/RichTooltip/RichTooltip.js.map +1 -1
  922. package/dist/cssm/components/Root/Root.css +1 -1
  923. package/dist/cssm/components/Root/Root.js +8 -7
  924. package/dist/cssm/components/Root/Root.js.map +1 -1
  925. package/dist/cssm/components/Search/Search.css +1 -1
  926. package/dist/cssm/components/Search/Search.js +2 -1
  927. package/dist/cssm/components/Search/Search.js.map +1 -1
  928. package/dist/cssm/components/SegmentedControl/SegmentedControl.js +19 -13
  929. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  930. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +1 -1
  931. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
  932. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  933. package/dist/cssm/components/Select/Select.css +1 -1
  934. package/dist/cssm/components/Select/Select.d.ts +1 -2
  935. package/dist/cssm/components/Select/Select.js +4 -5
  936. package/dist/cssm/components/Select/Select.js.map +1 -1
  937. package/dist/cssm/components/SelectMimicry/SelectMimicry.css +1 -0
  938. package/dist/cssm/components/SelectMimicry/SelectMimicry.d.ts +5 -1
  939. package/dist/cssm/components/SelectMimicry/SelectMimicry.js +13 -6
  940. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  941. package/dist/cssm/components/Separator/Separator.js +3 -1
  942. package/dist/cssm/components/Separator/Separator.js.map +1 -1
  943. package/dist/cssm/components/SimpleCell/SimpleCell.css +1 -1
  944. package/dist/cssm/components/SimpleCell/SimpleCell.d.ts +1 -1
  945. package/dist/cssm/components/SimpleCell/SimpleCell.js +3 -2
  946. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  947. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.d.ts +0 -1
  948. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js +7 -5
  949. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  950. package/dist/cssm/components/SliderSwitch/SliderSwitch.js +1 -0
  951. package/dist/cssm/components/SliderSwitch/SliderSwitch.js.map +1 -1
  952. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js +1 -0
  953. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  954. package/dist/cssm/components/Snackbar/Snackbar.js +2 -1
  955. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  956. package/dist/cssm/components/Spacing/Spacing.js +4 -3
  957. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  958. package/dist/cssm/components/SplitCol/SplitCol.js +2 -1
  959. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  960. package/dist/cssm/components/SplitLayout/SplitLayout.css +1 -1
  961. package/dist/cssm/components/SplitLayout/SplitLayout.js +2 -1
  962. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  963. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js +1 -1
  964. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  965. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +5 -5
  966. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  967. package/dist/cssm/components/Switch/Switch.js +1 -0
  968. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  969. package/dist/cssm/components/Tabbar/Tabbar.js +1 -0
  970. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  971. package/dist/cssm/components/TabbarItem/TabbarItem.css +1 -1
  972. package/dist/cssm/components/TabbarItem/TabbarItem.js +2 -1
  973. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  974. package/dist/cssm/components/Tabs/Tabs.css +1 -1
  975. package/dist/cssm/components/TabsItem/TabsItem.js +2 -1
  976. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  977. package/dist/cssm/components/Tappable/Tappable.css +1 -1
  978. package/dist/cssm/components/Tappable/Tappable.d.ts +3 -1
  979. package/dist/cssm/components/Tappable/Tappable.js +15 -15
  980. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  981. package/dist/cssm/components/TextTooltip/TextTooltip.js +1 -1
  982. package/dist/cssm/components/TextTooltip/TextTooltip.js.map +1 -1
  983. package/dist/cssm/components/Textarea/Textarea.css +1 -1
  984. package/dist/cssm/components/Tooltip/Tooltip.js +4 -4
  985. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  986. package/dist/cssm/components/Touch/Touch.js +9 -3
  987. package/dist/cssm/components/Touch/Touch.js.map +1 -1
  988. package/dist/cssm/components/Touch/TouchContext.d.ts +1 -1
  989. package/dist/cssm/components/Touch/TouchContext.js +1 -1
  990. package/dist/cssm/components/Touch/TouchContext.js.map +1 -1
  991. package/dist/cssm/components/Typography/Caption/Caption.css +1 -1
  992. package/dist/cssm/components/Typography/Caption/Caption.d.ts +8 -4
  993. package/dist/cssm/components/Typography/Caption/Caption.js +10 -14
  994. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  995. package/dist/cssm/components/Typography/Headline/Headline.css +1 -1
  996. package/dist/cssm/components/Typography/Paragraph/Paragraph.css +1 -0
  997. package/dist/cssm/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  998. package/dist/cssm/components/Typography/Paragraph/Paragraph.js +26 -0
  999. package/dist/cssm/components/Typography/Paragraph/Paragraph.js.map +1 -0
  1000. package/dist/cssm/components/Typography/Subhead/Subhead.css +1 -1
  1001. package/dist/cssm/components/Typography/Subhead/Subhead.d.ts +4 -3
  1002. package/dist/cssm/components/Typography/Subhead/Subhead.js +3 -7
  1003. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  1004. package/dist/cssm/components/Typography/Text/Text.css +1 -1
  1005. package/dist/cssm/components/Typography/Text/Text.js +1 -1
  1006. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  1007. package/dist/cssm/components/Typography/Title/Title.css +1 -1
  1008. package/dist/cssm/components/Typography/Title/Title.d.ts +4 -3
  1009. package/dist/cssm/components/Typography/Title/Title.js +3 -8
  1010. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  1011. package/dist/cssm/components/UsersStack/UsersStack.js +4 -4
  1012. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  1013. package/dist/cssm/components/View/View.css +1 -1
  1014. package/dist/cssm/components/View/View.js +5 -0
  1015. package/dist/cssm/components/View/View.js.map +1 -1
  1016. package/dist/cssm/components/View/ViewIOS.css +1 -1
  1017. package/dist/cssm/components/View/ViewInfinite.d.ts +2 -2
  1018. package/dist/cssm/components/View/ViewInfinite.js +15 -11
  1019. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  1020. package/dist/cssm/components/View/utils.js +5 -2
  1021. package/dist/cssm/components/View/utils.js.map +1 -1
  1022. package/dist/cssm/components/WriteBar/WriteBar.css +1 -1
  1023. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +3 -2
  1024. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1025. package/dist/cssm/helpers/scheme.js +2 -2
  1026. package/dist/cssm/helpers/scheme.js.map +1 -1
  1027. package/dist/cssm/hooks/useBooleanState.d.ts +6 -0
  1028. package/dist/cssm/hooks/useBooleanState.js +27 -0
  1029. package/dist/cssm/hooks/useBooleanState.js.map +1 -0
  1030. package/dist/cssm/hooks/useBridgeAdaptivity.d.ts +6 -0
  1031. package/dist/cssm/hooks/useBridgeAdaptivity.js +68 -0
  1032. package/dist/cssm/hooks/useBridgeAdaptivity.js.map +1 -0
  1033. package/dist/cssm/hooks/useCalendar.d.ts +18 -0
  1034. package/dist/cssm/hooks/useCalendar.js +64 -0
  1035. package/dist/cssm/hooks/useCalendar.js.map +1 -0
  1036. package/dist/cssm/hooks/useDateInput.d.ts +30 -0
  1037. package/dist/cssm/hooks/useDateInput.js +163 -0
  1038. package/dist/cssm/hooks/useDateInput.js.map +1 -0
  1039. package/dist/cssm/hooks/useKeyboard.d.ts +1 -1
  1040. package/dist/cssm/hooks/useKeyboard.js +1 -1
  1041. package/dist/cssm/hooks/useKeyboard.js.map +1 -1
  1042. package/dist/cssm/hooks/useKeyboardInputTracker.d.ts +2 -0
  1043. package/dist/cssm/hooks/useKeyboardInputTracker.js +11 -4
  1044. package/dist/cssm/hooks/useKeyboardInputTracker.js.map +1 -1
  1045. package/dist/cssm/hooks/useOrientationChange.d.ts +7 -0
  1046. package/dist/cssm/hooks/useOrientationChange.js +42 -0
  1047. package/dist/cssm/hooks/useOrientationChange.js.map +1 -0
  1048. package/dist/cssm/hooks/usePagination.d.ts +34 -0
  1049. package/dist/cssm/hooks/usePagination.js +67 -0
  1050. package/dist/cssm/hooks/usePagination.js.map +1 -0
  1051. package/dist/cssm/hooks/usePatchChildrenRef.js +1 -1
  1052. package/dist/cssm/hooks/usePatchChildrenRef.js.map +1 -1
  1053. package/dist/cssm/hooks/useWaitTransitionFinish.js +5 -1
  1054. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  1055. package/dist/cssm/index.d.ts +32 -11
  1056. package/dist/cssm/index.js +20 -14
  1057. package/dist/cssm/index.js.map +1 -1
  1058. package/dist/cssm/lib/calendar.d.ts +14 -0
  1059. package/dist/cssm/lib/calendar.js +100 -0
  1060. package/dist/cssm/lib/calendar.js.map +1 -0
  1061. package/dist/cssm/lib/date.d.ts +29 -0
  1062. package/dist/cssm/lib/date.js +223 -0
  1063. package/dist/cssm/lib/date.js.map +1 -0
  1064. package/dist/cssm/lib/getNavId.d.ts +2 -1
  1065. package/dist/cssm/lib/getNavId.js +1 -1
  1066. package/dist/cssm/lib/getNavId.js.map +1 -1
  1067. package/dist/cssm/lib/utils.d.ts +2 -1
  1068. package/dist/cssm/lib/utils.js +3 -0
  1069. package/dist/cssm/lib/utils.js.map +1 -1
  1070. package/dist/cssm/lib/warnOnce.d.ts +2 -1
  1071. package/dist/cssm/lib/warnOnce.js +3 -1
  1072. package/dist/cssm/lib/warnOnce.js.map +1 -1
  1073. package/dist/cssm/styles/common.css +1 -1
  1074. package/dist/cssm/styles/components.css +21 -6
  1075. package/dist/cssm/styles/constants.css +8 -1
  1076. package/dist/cssm/styles/themes.css +1 -1
  1077. package/dist/cssm/styles/unstable.css +1 -1
  1078. package/dist/cssm/tokenized/index.d.ts +32 -4
  1079. package/dist/cssm/tokenized/index.js +18 -4
  1080. package/dist/cssm/tokenized/index.js.map +1 -1
  1081. package/dist/cssm/unstable/index.d.ts +6 -6
  1082. package/dist/cssm/unstable/index.js +3 -3
  1083. package/dist/cssm/unstable/index.js.map +1 -1
  1084. package/dist/helpers/scheme.js +2 -2
  1085. package/dist/helpers/scheme.js.map +1 -1
  1086. package/dist/hooks/useBooleanState.d.ts +6 -0
  1087. package/dist/hooks/useBooleanState.js +27 -0
  1088. package/dist/hooks/useBooleanState.js.map +1 -0
  1089. package/dist/hooks/useBridgeAdaptivity.d.ts +6 -0
  1090. package/dist/hooks/useBridgeAdaptivity.js +68 -0
  1091. package/dist/hooks/useBridgeAdaptivity.js.map +1 -0
  1092. package/dist/hooks/useCalendar.d.ts +18 -0
  1093. package/dist/hooks/useCalendar.js +64 -0
  1094. package/dist/hooks/useCalendar.js.map +1 -0
  1095. package/dist/hooks/useDateInput.d.ts +30 -0
  1096. package/dist/hooks/useDateInput.js +163 -0
  1097. package/dist/hooks/useDateInput.js.map +1 -0
  1098. package/dist/hooks/useKeyboard.d.ts +1 -1
  1099. package/dist/hooks/useKeyboard.js +1 -1
  1100. package/dist/hooks/useKeyboard.js.map +1 -1
  1101. package/dist/hooks/useKeyboardInputTracker.d.ts +2 -0
  1102. package/dist/hooks/useKeyboardInputTracker.js +11 -4
  1103. package/dist/hooks/useKeyboardInputTracker.js.map +1 -1
  1104. package/dist/hooks/useOrientationChange.d.ts +7 -0
  1105. package/dist/hooks/useOrientationChange.js +42 -0
  1106. package/dist/hooks/useOrientationChange.js.map +1 -0
  1107. package/dist/hooks/usePagination.d.ts +34 -0
  1108. package/dist/hooks/usePagination.js +67 -0
  1109. package/dist/hooks/usePagination.js.map +1 -0
  1110. package/dist/hooks/usePatchChildrenRef.js +1 -1
  1111. package/dist/hooks/usePatchChildrenRef.js.map +1 -1
  1112. package/dist/hooks/useWaitTransitionFinish.js +5 -1
  1113. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  1114. package/dist/index.d.ts +32 -11
  1115. package/dist/index.js +20 -14
  1116. package/dist/index.js.map +1 -1
  1117. package/dist/lib/calendar.d.ts +14 -0
  1118. package/dist/lib/calendar.js +100 -0
  1119. package/dist/lib/calendar.js.map +1 -0
  1120. package/dist/lib/date.d.ts +29 -0
  1121. package/dist/lib/date.js +223 -0
  1122. package/dist/lib/date.js.map +1 -0
  1123. package/dist/lib/getNavId.d.ts +2 -1
  1124. package/dist/lib/getNavId.js +1 -1
  1125. package/dist/lib/getNavId.js.map +1 -1
  1126. package/dist/lib/utils.d.ts +2 -1
  1127. package/dist/lib/utils.js +3 -0
  1128. package/dist/lib/utils.js.map +1 -1
  1129. package/dist/lib/warnOnce.d.ts +2 -1
  1130. package/dist/lib/warnOnce.js +3 -1
  1131. package/dist/lib/warnOnce.js.map +1 -1
  1132. package/dist/tokenized/index.d.ts +32 -4
  1133. package/dist/tokenized/index.js +18 -4
  1134. package/dist/tokenized/index.js.map +1 -1
  1135. package/dist/unstable/index.d.ts +6 -6
  1136. package/dist/unstable/index.js +3 -3
  1137. package/dist/unstable/index.js.map +1 -1
  1138. package/dist/unstable.css +1 -1
  1139. package/dist/unstable.css.map +1 -1
  1140. package/dist/vkui.css +22 -7
  1141. package/dist/vkui.css.map +1 -1
  1142. package/eslint-plugin-vkui/index.js +64 -0
  1143. package/eslint-plugin-vkui/package.json +5 -0
  1144. package/jest.unit.config.js +4 -1
  1145. package/package.json +15 -11
  1146. package/postcss-plugin-vk-sans/__tests__/custom_properties.css +4 -0
  1147. package/postcss-plugin-vk-sans/index.js +343 -0
  1148. package/src/components/ActionSheet/ActionSheet.tsx +4 -7
  1149. package/src/components/ActionSheet/ActionSheetDropdown.tsx +1 -0
  1150. package/src/components/ActionSheet/ActionSheetDropdownDesktop.tsx +1 -1
  1151. package/src/components/ActionSheetItem/ActionSheetItem.tsx +5 -10
  1152. package/src/components/AdaptivityProvider/AdaptivityProvider.tsx +50 -19
  1153. package/src/components/Alert/Alert.tsx +8 -11
  1154. package/src/components/Alert/Readme.md +4 -4
  1155. package/src/components/AppRoot/AppRoot.tsx +2 -1
  1156. package/src/components/AppRoot/Readme.md +2 -2
  1157. package/src/components/Avatar/Avatar.tsx +3 -0
  1158. package/src/components/Banner/Banner.tsx +3 -2
  1159. package/src/components/Button/Button.css +26 -1
  1160. package/src/components/Button/Button.tsx +28 -39
  1161. package/src/components/ButtonGroup/ButtonGroup.css +52 -0
  1162. package/src/components/ButtonGroup/ButtonGroup.tsx +48 -0
  1163. package/src/components/ButtonGroup/Readme.md +311 -0
  1164. package/src/components/Calendar/Calendar.css +31 -0
  1165. package/src/components/Calendar/Calendar.tsx +185 -0
  1166. package/src/components/Calendar/Readme.md +124 -0
  1167. package/src/components/CalendarDay/CalendarDay.css +85 -0
  1168. package/src/components/CalendarDay/CalendarDay.tsx +117 -0
  1169. package/src/components/CalendarDays/CalendarDays.css +31 -0
  1170. package/src/components/CalendarDays/CalendarDays.tsx +131 -0
  1171. package/src/components/CalendarHeader/CalendarHeader.css +50 -0
  1172. package/src/components/CalendarHeader/CalendarHeader.tsx +168 -0
  1173. package/src/components/CalendarRange/CalendarRange.css +27 -0
  1174. package/src/components/CalendarRange/CalendarRange.tsx +275 -0
  1175. package/src/components/CalendarRange/Readme.md +85 -0
  1176. package/src/components/CalendarTime/CalendarTime.css +18 -0
  1177. package/src/components/CalendarTime/CalendarTime.tsx +88 -0
  1178. package/src/components/CardScroll/CardScroll.tsx +3 -1
  1179. package/src/components/Cell/Cell.tsx +4 -3
  1180. package/src/components/CellButton/CellButton.tsx +1 -0
  1181. package/src/components/Checkbox/Checkbox.tsx +2 -9
  1182. package/src/components/Chip/Chip.tsx +3 -8
  1183. package/src/components/ChipsInput/ChipsInput.css +4 -4
  1184. package/src/components/ChipsInput/ChipsInput.tsx +7 -8
  1185. package/src/components/ChipsSelect/ChipsSelect.css +1 -1
  1186. package/src/components/ChipsSelect/ChipsSelect.tsx +15 -14
  1187. package/src/components/ClickPopper/ClickPopper.tsx +1 -1
  1188. package/src/components/ConfigProvider/ConfigProvider.tsx +11 -3
  1189. package/src/components/ContentCard/ContentCard.tsx +5 -11
  1190. package/src/components/Counter/Counter.tsx +2 -2
  1191. package/src/components/CustomScrollView/CustomScrollView.tsx +1 -1
  1192. package/src/components/CustomSelect/CustomSelect.css +1 -16
  1193. package/src/components/CustomSelect/CustomSelect.tsx +65 -23
  1194. package/src/components/CustomSelectDropdown/CustomSelectDropdown.css +22 -5
  1195. package/src/components/CustomSelectDropdown/CustomSelectDropdown.tsx +16 -6
  1196. package/src/components/CustomSelectOption/CustomSelectOption.css +17 -5
  1197. package/src/components/CustomSelectOption/CustomSelectOption.tsx +58 -24
  1198. package/src/components/CustomSelectOption/Readme.md +48 -29
  1199. package/src/components/DateInput/DateInput.css +20 -0
  1200. package/src/components/DateInput/DateInput.tsx +317 -0
  1201. package/src/components/DateInput/Readme.md +116 -0
  1202. package/src/components/DatePicker/DatePicker.tsx +2 -2
  1203. package/src/components/DateRangeInput/DateRangeInput.css +16 -0
  1204. package/src/components/DateRangeInput/DateRangeInput.tsx +350 -0
  1205. package/src/components/DateRangeInput/Readme.md +96 -0
  1206. package/src/components/Div/Div.css +1 -8
  1207. package/src/components/Div/Div.tsx +2 -5
  1208. package/src/components/Epic/Readme.md +5 -1
  1209. package/src/components/File/File.tsx +1 -1
  1210. package/src/components/FixedLayout/FixedLayout.tsx +1 -0
  1211. package/src/components/Footer/Footer.tsx +2 -8
  1212. package/src/components/Footer/Readme.md +1 -1
  1213. package/src/components/FormField/FormField.css +47 -39
  1214. package/src/components/FormField/FormField.tsx +5 -6
  1215. package/src/components/FormItem/FormItem.tsx +4 -5
  1216. package/src/components/FormLayoutGroup/FormLayoutGroup.tsx +1 -0
  1217. package/src/components/FormStatus/FormStatus.tsx +3 -9
  1218. package/src/components/Gallery/Gallery.tsx +14 -2
  1219. package/src/components/Gallery/Readme.md +1 -1
  1220. package/src/components/GridAvatar/GridAvatar.css +10 -13
  1221. package/src/components/GridAvatar/GridAvatar.tsx +12 -24
  1222. package/src/components/Group/Group.tsx +3 -4
  1223. package/src/components/Header/Header.tsx +15 -12
  1224. package/src/components/HorizontalCell/HorizontalCell.tsx +4 -10
  1225. package/src/components/HorizontalScroll/HorizontalScroll.tsx +41 -39
  1226. package/src/components/InfoRow/InfoRow.tsx +1 -1
  1227. package/src/components/Input/Input.css +4 -4
  1228. package/src/components/Input/Input.tsx +5 -9
  1229. package/src/components/InputLike/InputLike.css +25 -0
  1230. package/src/components/InputLike/InputLike.tsx +72 -0
  1231. package/src/components/InputLike/InputLikeDivider.css +4 -0
  1232. package/src/components/InputLike/InputLikeDivider.tsx +12 -0
  1233. package/src/components/List/List.tsx +1 -0
  1234. package/src/components/LocaleProviderContext/LocaleProviderContext.tsx +5 -0
  1235. package/src/components/MiniInfoCell/MiniInfoCell.tsx +1 -0
  1236. package/src/components/ModalCard/ModalCard.css +0 -10
  1237. package/src/components/ModalCard/ModalCard.tsx +1 -0
  1238. package/src/components/ModalCardBase/ModalCardBase.css +10 -0
  1239. package/src/components/ModalCardBase/ModalCardBase.tsx +15 -2
  1240. package/src/components/ModalPage/ModalPage.tsx +29 -4
  1241. package/src/components/ModalPageHeader/ModalPageHeader.tsx +1 -0
  1242. package/src/components/ModalRoot/ModalRoot.tsx +33 -10
  1243. package/src/components/ModalRoot/ModalRootAdaptive.tsx +17 -2
  1244. package/src/components/ModalRoot/ModalRootDesktop.tsx +25 -7
  1245. package/src/components/ModalRoot/Readme.md +112 -0
  1246. package/src/components/ModalRoot/types.ts +16 -1
  1247. package/src/components/ModalRoot/useModalManager.tsx +60 -15
  1248. package/src/components/NativeSelect/NativeSelect.tsx +1 -0
  1249. package/src/components/Pagination/Pagination.css +62 -0
  1250. package/src/components/Pagination/Pagination.tsx +196 -0
  1251. package/src/components/Pagination/Readme.md +110 -0
  1252. package/src/components/Panel/Panel.tsx +1 -0
  1253. package/src/components/PanelHeader/PanelHeader.tsx +1 -0
  1254. package/src/components/PanelHeaderBack/PanelHeaderBack.tsx +1 -0
  1255. package/src/components/PanelHeaderButton/PanelHeaderButton.tsx +4 -2
  1256. package/src/components/PanelHeaderContent/PanelHeaderContent.tsx +2 -8
  1257. package/src/components/PanelHeaderContext/PanelHeaderContext.tsx +1 -0
  1258. package/src/components/Placeholder/Placeholder.tsx +2 -1
  1259. package/src/components/PopoutWrapper/PopoutWrapper.tsx +1 -0
  1260. package/src/components/PopoutWrapper/Readme.md +1 -1
  1261. package/src/components/Popper/Popper.tsx +2 -2
  1262. package/src/components/Popper/Readme.md +1 -1
  1263. package/src/components/PromoBanner/PromoBanner.tsx +4 -6
  1264. package/src/components/PullToRefresh/PullToRefresh.tsx +1 -0
  1265. package/src/components/PullToRefresh/PullToRefreshSpinner.tsx +1 -0
  1266. package/src/components/Radio/Radio.tsx +2 -9
  1267. package/src/components/RichCell/Readme.md +4 -4
  1268. package/src/components/RichCell/RichCell.tsx +4 -2
  1269. package/src/components/RichTooltip/Readme.md +3 -3
  1270. package/src/components/RichTooltip/RichTooltip.tsx +1 -0
  1271. package/src/components/Root/Root.css +4 -11
  1272. package/src/components/Root/Root.tsx +7 -6
  1273. package/src/components/Search/Search.tsx +2 -1
  1274. package/src/components/SegmentedControl/SegmentedControl.tsx +20 -10
  1275. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +1 -1
  1276. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.tsx +1 -0
  1277. package/src/components/Select/Select.css +7 -2
  1278. package/src/components/Select/Select.tsx +3 -4
  1279. package/src/components/SelectMimicry/SelectMimicry.css +10 -0
  1280. package/src/components/SelectMimicry/SelectMimicry.tsx +14 -3
  1281. package/src/components/Separator/Separator.tsx +2 -0
  1282. package/src/components/SimpleCell/SimpleCell.tsx +3 -2
  1283. package/src/components/SimpleCheckbox/SimpleCheckbox.tsx +7 -5
  1284. package/src/components/SliderSwitch/SliderSwitch.tsx +1 -0
  1285. package/src/components/SliderSwitch/SliderSwitchButton.tsx +1 -0
  1286. package/src/components/Snackbar/Snackbar.tsx +2 -1
  1287. package/src/components/Spacing/Spacing.tsx +3 -2
  1288. package/src/components/SplitCol/SplitCol.tsx +1 -0
  1289. package/src/components/SplitLayout/SplitLayout.tsx +1 -0
  1290. package/src/components/SubnavigationBar/SubnavigationBar.tsx +2 -1
  1291. package/src/components/SubnavigationButton/SubnavigationButton.tsx +4 -9
  1292. package/src/components/Switch/Switch.tsx +1 -0
  1293. package/src/components/Tabbar/Readme.md +1 -1
  1294. package/src/components/Tabbar/Tabbar.tsx +1 -0
  1295. package/src/components/TabbarItem/TabbarItem.css +1 -0
  1296. package/src/components/TabbarItem/TabbarItem.tsx +1 -0
  1297. package/src/components/Tabs/Readme.md +7 -7
  1298. package/src/components/TabsItem/TabsItem.tsx +2 -1
  1299. package/src/components/Tappable/Tappable.css +5 -0
  1300. package/src/components/Tappable/Tappable.tsx +17 -5
  1301. package/src/components/TextTooltip/Readme.md +1 -1
  1302. package/src/components/TextTooltip/TextTooltip.tsx +1 -1
  1303. package/src/components/Tooltip/Tooltip.tsx +5 -4
  1304. package/src/components/Touch/Touch.tsx +6 -3
  1305. package/src/components/Touch/TouchContext.ts +1 -1
  1306. package/src/components/Typography/Caption/Caption.css +61 -19
  1307. package/src/components/Typography/Caption/Caption.tsx +24 -15
  1308. package/src/components/Typography/Caption/Readme.md +26 -48
  1309. package/src/components/Typography/Paragraph/Paragraph.css +17 -0
  1310. package/src/components/Typography/Paragraph/Paragraph.tsx +42 -0
  1311. package/src/components/Typography/Paragraph/Readme.md +19 -0
  1312. package/src/components/Typography/Subhead/Subhead.tsx +6 -8
  1313. package/src/components/Typography/Text/Text.tsx +1 -1
  1314. package/src/components/Typography/Title/Title.tsx +10 -10
  1315. package/src/components/UsersStack/UsersStack.tsx +4 -4
  1316. package/src/components/View/Readme.md +2 -2
  1317. package/src/components/View/View.css +1 -1
  1318. package/src/components/View/View.tsx +4 -0
  1319. package/src/components/View/ViewIOS.css +2 -2
  1320. package/src/components/View/ViewInfinite.tsx +7 -4
  1321. package/src/components/View/utils.ts +2 -1
  1322. package/src/components/WriteBarIcon/WriteBarIcon.tsx +3 -1
  1323. package/src/helpers/scheme.ts +3 -2
  1324. package/src/hooks/useBooleanState.ts +19 -0
  1325. package/src/hooks/useBridgeAdaptivity.ts +83 -0
  1326. package/src/hooks/useCalendar.ts +78 -0
  1327. package/src/hooks/useDateInput.ts +213 -0
  1328. package/src/hooks/useKeyboard.ts +1 -1
  1329. package/src/hooks/useKeyboardInputTracker.ts +25 -8
  1330. package/src/hooks/useOrientationChange.ts +39 -0
  1331. package/src/hooks/usePagination.ts +96 -0
  1332. package/src/hooks/usePatchChildrenRef.ts +2 -2
  1333. package/src/hooks/useWaitTransitionFinish.ts +7 -1
  1334. package/src/index.ts +32 -11
  1335. package/src/lib/calendar.ts +123 -0
  1336. package/src/lib/date.ts +274 -0
  1337. package/src/lib/getNavId.ts +4 -2
  1338. package/src/lib/utils.ts +4 -1
  1339. package/src/lib/warnOnce.ts +9 -3
  1340. package/src/styles/components.css +15 -0
  1341. package/src/styles/constants.css +8 -1
  1342. package/src/testing/utils.tsx +10 -1
  1343. package/src/tokenized/index.ts +46 -4
  1344. package/src/unstable/index.ts +6 -6
  1345. package/tsconfig.json +2 -0
  1346. package/postcss.config.js +0 -54
@@ -81,7 +81,7 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
81
81
  return Object.assign(_this.getModalState(id), data);
82
82
  },
83
83
  onClose: function onClose() {
84
- return _this.props.closeActiveModal();
84
+ return _this.props.onExit();
85
85
  },
86
86
  isInsideModal: true
87
87
  };
@@ -121,10 +121,11 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
121
121
  if (this.props.enteringModal && this.props.enteringModal !== prevProps.enteringModal) {
122
122
  var enteringModal = this.props.enteringModal;
123
123
  var enteringState = this.getModalState(enteringModal);
124
+ this.props.onEnter();
124
125
  requestAnimationFrame(function () {
125
126
  if (_this2.props.enteringModal === enteringModal) {
126
127
  _this2.waitTransitionFinish(enteringState, function () {
127
- return _this2.props.onEnter(enteringModal);
128
+ return _this2.props.onEntered(enteringModal);
128
129
  });
129
130
 
130
131
  _this2.animateModalOpacity(enteringState, true);
@@ -156,7 +157,7 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
156
157
  }
157
158
 
158
159
  this.waitTransitionFinish(prevModalState, function () {
159
- return _this3.props.onExit(id);
160
+ return _this3.props.onExited(id);
160
161
  });
161
162
  this.animateModalOpacity(prevModalState, false);
162
163
 
@@ -182,7 +183,7 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
182
183
  setTimeout(eventHandler, this.timeout);
183
184
  }
184
185
  }
185
- /* Анимирует сдивг модалки */
186
+ /* Анимирует сдвиг модалки */
186
187
 
187
188
  }, {
188
189
  key: "animateModalOpacity",
@@ -239,13 +240,14 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
239
240
  return (0, _jsxRuntime.createScopedElement)(_ModalRootContext.default.Provider, {
240
241
  value: this.modalRootContext
241
242
  }, (0, _jsxRuntime.createScopedElement)("div", {
243
+ // eslint-disable-next-line vkui/no-object-expression-in-arguments
242
244
  vkuiClass: (0, _classNames.classNames)((0, _getClassName.getClassName)("ModalRoot", this.props.platform), {
243
245
  "ModalRoot--vkapps": ((_this$props$configPro = this.props.configProvider) === null || _this$props$configPro === void 0 ? void 0 : _this$props$configPro.webviewType) === _ConfigProviderContext.WebviewType.VKAPPS
244
246
  }, "ModalRoot--desktop")
245
247
  }, (0, _jsxRuntime.createScopedElement)("div", {
246
248
  vkuiClass: "ModalRoot__mask",
247
249
  ref: this.maskElementRef,
248
- onClick: this.props.closeActiveModal
250
+ onClick: this.props.onExit
249
251
  }), (0, _jsxRuntime.createScopedElement)("div", {
250
252
  vkuiClass: "ModalRoot__viewport"
251
253
  }, this.modals.map(function (Modal) {
@@ -258,9 +260,10 @@ var ModalRootDesktopComponent = /*#__PURE__*/function (_React$Component) {
258
260
  var key = "modal-".concat(modalId);
259
261
  return (0, _jsxRuntime.createScopedElement)(_FocusTrap.FocusTrap, {
260
262
  restoreFocus: false,
261
- onClose: _this5.props.closeActiveModal,
263
+ onClose: _this5.props.onExit,
262
264
  timeout: _this5.timeout,
263
- key: key,
265
+ key: key // eslint-disable-next-line vkui/no-object-expression-in-arguments
266
+ ,
264
267
  vkuiClass: (0, _classNames.classNames)("ModalRoot__modal", {
265
268
  "ModalRoot__modal--active": !exitingModal && !enteringModal && modalId === activeModal,
266
269
  "ModalRoot__modal--prev": modalId === exitingModal,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootDesktop.tsx"],"names":["warn","ModalRootDesktopComponent","props","undefined","maskElementRef","React","createRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","getModalState","onClose","closeActiveModal","isInsideModal","platform","ANDROID","VKCOM","Children","toArray","children","prevProps","exitingModal","closeModal","enteringModal","enteringState","requestAnimationFrame","waitTransitionFinish","onEnter","animateModalOpacity","activeModal","restoreFocusTo","document","activeElement","focus","prevModalState","onExit","setMaskOpacity","modalState","eventHandler","transitionEvent","supported","onceHandler","innerElement","removeEventListener","name","addEventListener","setTimeout","timeout","display","style","transitionDelay","delayEnter","opacity","forceOpacity","history","maskAnimationFrame","cancelAnimationFrame","current","translateY","translateYCurrent","Math","max","min","toString","configProvider","webviewType","WebviewType","VKAPPS","modals","map","Modal","modalId","key","Boolean","Component","ModalRootDesktop","ConfigProviderContext"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { transitionEvent } from \"../../lib/supportEvents\";\nimport { HasPlatform } from \"../../types\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport { withContext } from \"../../hoc/withContext\";\nimport ModalRootContext, {\n ModalRootContextInterface,\n} from \"./ModalRootContext\";\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n WebviewType,\n} from \"../ConfigProvider/ConfigProviderContext\";\nimport { ModalsStateEntry } from \"./types\";\nimport { ANDROID, VKCOM } from \"../../lib/platform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { DOMProps, withDOM } from \"../../lib/dom\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { FocusTrap } from \"../FocusTrap/FocusTrap\";\nimport { ModalTransitionProps, withModalManager } from \"./useModalManager\";\nimport \"./ModalRoot.css\";\n\nconst warn = warnOnce(\"ModalRoot\");\n\nexport interface ModalRootProps extends HasPlatform {\n activeModal?: string | null;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n\n /**\n * Будет вызвано при закрытии активной модалки с её id\n */\n onClose?(modalId: string): void;\n}\n\nclass ModalRootDesktopComponent extends React.Component<\n ModalRootProps & DOMProps & ModalTransitionProps\n> {\n constructor(props: ModalRootProps & ModalTransitionProps) {\n super(props);\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: () => undefined,\n registerModal: ({ id, ...data }) =>\n Object.assign(this.getModalState(id), data),\n onClose: () => this.props.closeActiveModal(),\n isInsideModal: true,\n };\n }\n\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private maskAnimationFrame: number | undefined = undefined;\n private readonly modalRootContext: ModalRootContextInterface;\n private restoreFocusTo: HTMLElement | undefined = undefined;\n\n private get timeout() {\n return this.props.platform === ANDROID || this.props.platform === VKCOM\n ? 320\n : 400;\n }\n\n private get modals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n getModalState(id: string | null) {\n if (id === null) {\n return undefined;\n }\n return this.props.getModalState(id);\n }\n\n componentDidUpdate(prevProps: ModalRootProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (\n this.props.exitingModal &&\n this.props.exitingModal !== prevProps.exitingModal\n ) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (\n this.props.enteringModal &&\n this.props.enteringModal !== prevProps.enteringModal\n ) {\n const { enteringModal } = this.props;\n const enteringState = this.getModalState(enteringModal);\n requestAnimationFrame(() => {\n if (this.props.enteringModal === enteringModal) {\n this.waitTransitionFinish(enteringState, () =>\n this.props.onEnter(enteringModal)\n );\n this.animateModalOpacity(enteringState, true);\n }\n });\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = (this.props.document?.activeElement ??\n undefined) as HTMLElement | undefined;\n }\n if (\n !this.props.activeModal &&\n !this.props.exitingModal &&\n this.restoreFocusTo\n ) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = undefined;\n }\n }\n\n closeModal(id: string) {\n const prevModalState = this.getModalState(id);\n if (!prevModalState) {\n return;\n }\n\n this.waitTransitionFinish(prevModalState, () => this.props.onExit(id));\n this.animateModalOpacity(prevModalState, false);\n if (!this.props.activeModal) {\n this.setMaskOpacity(prevModalState, 0);\n }\n }\n\n waitTransitionFinish(\n modalState: ModalsStateEntry | undefined,\n eventHandler: () => void\n ) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState?.innerElement?.removeEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n eventHandler();\n };\n\n modalState?.innerElement?.addEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /* Анимирует сдивг модалки */\n animateModalOpacity(\n modalState: ModalsStateEntry | undefined,\n display: boolean\n ) {\n if (modalState?.innerElement) {\n modalState.innerElement.style.transitionDelay =\n display && this.props.delayEnter ? `${this.timeout}ms` : \"\";\n modalState.innerElement.style.opacity = display ? \"1\" : \"0\";\n }\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(\n modalState: ModalsStateEntry,\n forceOpacity: number | null = null\n ) {\n if (forceOpacity === null && this.props.history?.[0] !== modalState.id) {\n return;\n }\n\n if (this.maskAnimationFrame) {\n cancelAnimationFrame(this.maskAnimationFrame);\n }\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(\n 0,\n Math.min(100, opacity)\n ).toString();\n }\n });\n }\n\n render() {\n const { exitingModal, activeModal, enteringModal } = this.props;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <ModalRootContext.Provider value={this.modalRootContext}>\n <div\n vkuiClass={classNames(\n getClassName(\"ModalRoot\", this.props.platform),\n {\n \"ModalRoot--vkapps\":\n this.props.configProvider?.webviewType === WebviewType.VKAPPS,\n },\n \"ModalRoot--desktop\"\n )}\n >\n <div\n vkuiClass=\"ModalRoot__mask\"\n ref={this.maskElementRef}\n onClick={this.props.closeActiveModal}\n />\n <div vkuiClass=\"ModalRoot__viewport\">\n {this.modals.map((Modal: React.ReactElement) => {\n const modalId = getNavId(Modal.props, warn);\n if (modalId !== activeModal && modalId !== exitingModal) {\n return null;\n }\n\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n restoreFocus={false}\n onClose={this.props.closeActiveModal}\n timeout={this.timeout}\n key={key}\n vkuiClass={classNames(\"ModalRoot__modal\", {\n \"ModalRoot__modal--active\":\n !exitingModal &&\n !enteringModal &&\n modalId === activeModal,\n \"ModalRoot__modal--prev\": modalId === exitingModal,\n \"ModalRoot__modal--next\":\n Boolean(exitingModal) && modalId === activeModal,\n })}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </div>\n </ModalRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootDesktop = withContext(\n withPlatform(\n withDOM<ModalRootProps>(withModalManager()(ModalRootDesktopComponent))\n ),\n ConfigProviderContext,\n \"configProvider\"\n);\n"],"file":"ModalRootDesktop.js"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/ModalRootDesktop.tsx"],"names":["warn","ModalRootDesktopComponent","props","undefined","maskElementRef","React","createRef","modalRootContext","updateModalHeight","registerModal","id","data","Object","assign","getModalState","onClose","onExit","isInsideModal","platform","ANDROID","VKCOM","Children","toArray","children","prevProps","exitingModal","closeModal","enteringModal","enteringState","onEnter","requestAnimationFrame","waitTransitionFinish","onEntered","animateModalOpacity","activeModal","restoreFocusTo","document","activeElement","focus","prevModalState","onExited","setMaskOpacity","modalState","eventHandler","transitionEvent","supported","onceHandler","innerElement","removeEventListener","name","addEventListener","setTimeout","timeout","display","style","transitionDelay","delayEnter","opacity","forceOpacity","history","maskAnimationFrame","cancelAnimationFrame","current","translateY","translateYCurrent","Math","max","min","toString","configProvider","webviewType","WebviewType","VKAPPS","modals","map","Modal","modalId","key","Boolean","Component","ModalRootDesktop","ConfigProviderContext"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { transitionEvent } from \"../../lib/supportEvents\";\nimport { HasPlatform } from \"../../types\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport { withContext } from \"../../hoc/withContext\";\nimport ModalRootContext, {\n ModalRootContextInterface,\n} from \"./ModalRootContext\";\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n WebviewType,\n} from \"../ConfigProvider/ConfigProviderContext\";\nimport { ModalsStateEntry } from \"./types\";\nimport { ANDROID, VKCOM } from \"../../lib/platform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { DOMProps, withDOM } from \"../../lib/dom\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { FocusTrap } from \"../FocusTrap/FocusTrap\";\nimport { ModalTransitionProps, withModalManager } from \"./useModalManager\";\nimport \"./ModalRoot.css\";\n\nconst warn = warnOnce(\"ModalRoot\");\n\nexport interface ModalRootProps extends HasPlatform {\n activeModal?: string | null;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n\n /**\n * Будет вызвано при начале открытия активной модалки с её id\n */\n onOpen?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном открытии активной модалки с её id\n */\n onOpened?(modalId: string): void;\n\n /**\n * Будет вызвано при начале закрытия активной модалки с её id\n */\n onClose?(modalId: string): void;\n\n /**\n * Будет вызвано при окончательном закрытии активной модалки с её id\n */\n onClosed?(modalId: string): void;\n}\n\nclass ModalRootDesktopComponent extends React.Component<\n ModalRootProps & DOMProps & ModalTransitionProps\n> {\n constructor(props: ModalRootProps & ModalTransitionProps) {\n super(props);\n\n this.maskElementRef = React.createRef();\n\n this.modalRootContext = {\n updateModalHeight: () => undefined,\n registerModal: ({ id, ...data }) =>\n Object.assign(this.getModalState(id), data),\n onClose: () => this.props.onExit(),\n isInsideModal: true,\n };\n }\n\n private readonly maskElementRef: React.RefObject<HTMLDivElement>;\n private maskAnimationFrame: number | undefined = undefined;\n private readonly modalRootContext: ModalRootContextInterface;\n private restoreFocusTo: HTMLElement | undefined = undefined;\n\n private get timeout() {\n return this.props.platform === ANDROID || this.props.platform === VKCOM\n ? 320\n : 400;\n }\n\n private get modals() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n getModalState(id: string | null) {\n if (id === null) {\n return undefined;\n }\n return this.props.getModalState(id);\n }\n\n componentDidUpdate(prevProps: ModalRootProps & ModalTransitionProps) {\n // transition phase 2: animate exiting modal\n if (\n this.props.exitingModal &&\n this.props.exitingModal !== prevProps.exitingModal\n ) {\n this.closeModal(this.props.exitingModal);\n }\n\n // transition phase 3: animate entering modal\n if (\n this.props.enteringModal &&\n this.props.enteringModal !== prevProps.enteringModal\n ) {\n const { enteringModal } = this.props;\n const enteringState = this.getModalState(enteringModal);\n this.props.onEnter();\n requestAnimationFrame(() => {\n if (this.props.enteringModal === enteringModal) {\n this.waitTransitionFinish(enteringState, () =>\n this.props.onEntered(enteringModal)\n );\n this.animateModalOpacity(enteringState, true);\n }\n });\n }\n\n // focus restoration\n if (this.props.activeModal && !prevProps.activeModal) {\n this.restoreFocusTo = (this.props.document?.activeElement ??\n undefined) as HTMLElement | undefined;\n }\n if (\n !this.props.activeModal &&\n !this.props.exitingModal &&\n this.restoreFocusTo\n ) {\n this.restoreFocusTo.focus();\n this.restoreFocusTo = undefined;\n }\n }\n\n closeModal(id: string) {\n const prevModalState = this.getModalState(id);\n if (!prevModalState) {\n return;\n }\n\n this.waitTransitionFinish(prevModalState, () => this.props.onExited(id));\n this.animateModalOpacity(prevModalState, false);\n if (!this.props.activeModal) {\n this.setMaskOpacity(prevModalState, 0);\n }\n }\n\n waitTransitionFinish(\n modalState: ModalsStateEntry | undefined,\n eventHandler: () => void\n ) {\n if (transitionEvent.supported) {\n const onceHandler = () => {\n modalState?.innerElement?.removeEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n eventHandler();\n };\n\n modalState?.innerElement?.addEventListener(\n transitionEvent.name as string,\n onceHandler\n );\n } else {\n setTimeout(eventHandler, this.timeout);\n }\n }\n\n /* Анимирует сдвиг модалки */\n animateModalOpacity(\n modalState: ModalsStateEntry | undefined,\n display: boolean\n ) {\n if (modalState?.innerElement) {\n modalState.innerElement.style.transitionDelay =\n display && this.props.delayEnter ? `${this.timeout}ms` : \"\";\n modalState.innerElement.style.opacity = display ? \"1\" : \"0\";\n }\n }\n\n /* Устанавливает прозрачность для полупрозрачной подложки */\n setMaskOpacity(\n modalState: ModalsStateEntry,\n forceOpacity: number | null = null\n ) {\n if (forceOpacity === null && this.props.history?.[0] !== modalState.id) {\n return;\n }\n\n if (this.maskAnimationFrame) {\n cancelAnimationFrame(this.maskAnimationFrame);\n }\n this.maskAnimationFrame = requestAnimationFrame(() => {\n if (this.maskElementRef.current) {\n const { translateY = 0, translateYCurrent = 0 } = modalState;\n\n const opacity =\n forceOpacity === null\n ? 1 - (translateYCurrent - translateY) / (100 - translateY) || 0\n : forceOpacity;\n this.maskElementRef.current.style.opacity = Math.max(\n 0,\n Math.min(100, opacity)\n ).toString();\n }\n });\n }\n\n render() {\n const { exitingModal, activeModal, enteringModal } = this.props;\n\n if (!activeModal && !exitingModal) {\n return null;\n }\n\n return (\n <ModalRootContext.Provider value={this.modalRootContext}>\n <div\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"ModalRoot\", this.props.platform),\n {\n \"ModalRoot--vkapps\":\n this.props.configProvider?.webviewType === WebviewType.VKAPPS,\n },\n \"ModalRoot--desktop\"\n )}\n >\n <div\n vkuiClass=\"ModalRoot__mask\"\n ref={this.maskElementRef}\n onClick={this.props.onExit}\n />\n <div vkuiClass=\"ModalRoot__viewport\">\n {this.modals.map((Modal: React.ReactElement) => {\n const modalId = getNavId(Modal.props, warn);\n if (modalId !== activeModal && modalId !== exitingModal) {\n return null;\n }\n\n const key = `modal-${modalId}`;\n\n return (\n <FocusTrap\n restoreFocus={false}\n onClose={this.props.onExit}\n timeout={this.timeout}\n key={key}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\"ModalRoot__modal\", {\n \"ModalRoot__modal--active\":\n !exitingModal &&\n !enteringModal &&\n modalId === activeModal,\n \"ModalRoot__modal--prev\": modalId === exitingModal,\n \"ModalRoot__modal--next\":\n Boolean(exitingModal) && modalId === activeModal,\n })}\n >\n {Modal}\n </FocusTrap>\n );\n })}\n </div>\n </div>\n </ModalRootContext.Provider>\n );\n }\n}\n\nexport const ModalRootDesktop = withContext(\n withPlatform(\n withDOM<ModalRootProps>(withModalManager()(ModalRootDesktopComponent))\n ),\n ConfigProviderContext,\n \"configProvider\"\n);\n"],"file":"ModalRootDesktop.js"}
@@ -14,7 +14,22 @@ export interface ModalElements {
14
14
  }
15
15
  export interface ModalsStateEntry extends ModalElements {
16
16
  id: string | null;
17
- onClose?: () => any;
17
+ /**
18
+ * Событие начала открытия модалки.
19
+ */
20
+ onOpen?: VoidFunction;
21
+ /**
22
+ * Событие открытия модалки.
23
+ */
24
+ onOpened?: VoidFunction;
25
+ /**
26
+ * Событие начала закрытия модалки.
27
+ */
28
+ onClose?: VoidFunction;
29
+ /**
30
+ * Событие закрытия модалки.
31
+ */
32
+ onClosed?: VoidFunction;
18
33
  type?: ModalType;
19
34
  settlingHeight?: number;
20
35
  dynamicContentHeight?: boolean;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/types.ts"],"names":["ModalType"],"mappings":";;;;;;IAAYA,S;;;WAAAA,S;AAAAA,EAAAA,S;AAAAA,EAAAA,S;GAAAA,S,yBAAAA,S","sourcesContent":["export enum ModalType {\n PAGE = \"page\",\n CARD = \"card\",\n}\n\nexport type TranslateRange = [number, number];\n\nexport type ModalsState = { [index: string]: ModalsStateEntry };\n\nexport interface ModalElements {\n modalElement?: HTMLElement | null;\n innerElement?: HTMLElement | null;\n headerElement?: HTMLElement | null;\n contentElement?: HTMLElement | null;\n}\n\nexport interface ModalsStateEntry extends ModalElements {\n id: string | null;\n onClose?: () => any;\n type?: ModalType;\n\n settlingHeight?: number;\n dynamicContentHeight?: boolean;\n expandable?: boolean;\n\n /**\n * Процент текущего сдвига модалки\n */\n translateY?: number;\n /**\n * Процент сдвига модалки в изначальном состоянии\n */\n translateYFrom?: number;\n /**\n * Процент сдвига модалки во время взаимодействия с ней (потянуть, чтобы открыть или закрыть)\n */\n translateYCurrent?: number;\n\n touchStartContentScrollTop?: number;\n touchMovePositive?: boolean | null;\n touchShiftYPercent?: number;\n\n expanded?: boolean;\n collapsed?: boolean;\n hidden?: boolean;\n\n contentScrolled?: boolean;\n contentScrollStopTimeout?: ReturnType<typeof setTimeout>;\n\n expandedRange?: TranslateRange;\n collapsedRange?: TranslateRange;\n hiddenRange?: TranslateRange;\n}\n"],"file":"types.js"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/types.ts"],"names":["ModalType"],"mappings":";;;;;;IAAYA,S;;;WAAAA,S;AAAAA,EAAAA,S;AAAAA,EAAAA,S;GAAAA,S,yBAAAA,S","sourcesContent":["export enum ModalType {\n PAGE = \"page\",\n CARD = \"card\",\n}\n\nexport type TranslateRange = [number, number];\n\nexport type ModalsState = { [index: string]: ModalsStateEntry };\n\nexport interface ModalElements {\n modalElement?: HTMLElement | null;\n innerElement?: HTMLElement | null;\n headerElement?: HTMLElement | null;\n contentElement?: HTMLElement | null;\n}\n\nexport interface ModalsStateEntry extends ModalElements {\n id: string | null;\n /**\n * Событие начала открытия модалки.\n */\n onOpen?: VoidFunction;\n /**\n * Событие открытия модалки.\n */\n onOpened?: VoidFunction;\n /**\n * Событие начала закрытия модалки.\n */\n onClose?: VoidFunction;\n /**\n * Событие закрытия модалки.\n */\n onClosed?: VoidFunction;\n type?: ModalType;\n\n settlingHeight?: number;\n dynamicContentHeight?: boolean;\n expandable?: boolean;\n\n /**\n * Процент текущего сдвига модалки\n */\n translateY?: number;\n /**\n * Процент сдвига модалки в изначальном состоянии\n */\n translateYFrom?: number;\n /**\n * Процент сдвига модалки во время взаимодействия с ней (потянуть, чтобы открыть или закрыть)\n */\n translateYCurrent?: number;\n\n touchStartContentScrollTop?: number;\n touchMovePositive?: boolean | null;\n touchShiftYPercent?: number;\n\n expanded?: boolean;\n collapsed?: boolean;\n hidden?: boolean;\n\n contentScrolled?: boolean;\n contentScrollStopTimeout?: ReturnType<typeof setTimeout>;\n\n expandedRange?: TranslateRange;\n collapsedRange?: TranslateRange;\n hiddenRange?: TranslateRange;\n}\n"],"file":"types.js"}
@@ -8,10 +8,11 @@ interface ModalTransitionState {
8
8
  isBack?: boolean | null;
9
9
  }
10
10
  export interface ModalTransitionProps extends ModalTransitionState {
11
- onEnter: (id: string | null) => void;
12
- onExit: (id: string | null) => void;
11
+ onEnter: VoidFunction;
12
+ onEntered: (id: string | null) => void;
13
+ onExit: VoidFunction;
14
+ onExited: (id: string | null) => void;
13
15
  getModalState: (id: string) => ModalsStateEntry;
14
- closeActiveModal: VoidFunction;
15
16
  delayEnter: boolean;
16
17
  }
17
18
  export declare function modalTransitionReducer(state: ModalTransitionState, action: {
@@ -30,8 +31,8 @@ export declare function modalTransitionReducer(state: ModalTransitionState, acti
30
31
  * 4b. enteringModal переходит в null после завершения анимации
31
32
  * 5. activeModal: m2, exitingModal: null, enteringModal: null, переход закончен
32
33
  */
33
- export declare function useModalManager(activeModal: string | null | undefined, children: React.ReactNode | React.ReactNode[], onClose: (id: string) => void, initModal?: (state: ModalsStateEntry) => void): ModalTransitionProps;
34
- export declare function withModalManager(initModal?: (a: ModalsStateEntry) => void): <Props extends ModalTransitionProps>(Wrapped: React.ComponentType<Props>) => React.FC<Pick<Props, Exclude<keyof Props, "isBack" | "onEnter" | "history" | "onExit" | "getModalState" | "closeActiveModal" | "delayEnter" | "activeModal" | "enteringModal" | "exitingModal">> & {
34
+ export declare function useModalManager(activeModal: string | null | undefined, children: React.ReactNode | React.ReactNode[], onOpen?: (id: string) => void, onOpened?: (id: string) => void, onClose?: (id: string) => void, onClosed?: (id: string) => void, initModal?: (state: ModalsStateEntry) => void): ModalTransitionProps;
35
+ export declare function withModalManager(initModal?: (a: ModalsStateEntry) => void): <Props extends ModalTransitionProps>(Wrapped: React.ComponentType<Props>) => React.FC<Pick<Props, Exclude<keyof Props, "isBack" | "onEnter" | "history" | "onEntered" | "onExit" | "onExited" | "getModalState" | "delayEnter" | "activeModal" | "enteringModal" | "exitingModal">> & {
35
36
  activeModal?: string | null | undefined;
36
37
  }>;
37
38
  export {};
@@ -99,8 +99,12 @@ function modalTransitionReducer(state, action) {
99
99
  */
100
100
 
101
101
 
102
- function useModalManager(activeModal, children, onClose) {
103
- var initModal = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : _utils.noop;
102
+ function useModalManager(activeModal, children) {
103
+ var onOpen = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _utils.noop;
104
+ var onOpened = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : _utils.noop;
105
+ var onClose = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : _utils.noop;
106
+ var onClosed = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : _utils.noop;
107
+ var initModal = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : _utils.noop;
104
108
  var modalsState = React.useRef({}).current;
105
109
  getModals(children).forEach(function (Modal) {
106
110
  var modalProps = Modal.props;
@@ -108,7 +112,10 @@ function useModalManager(activeModal, children, onClose) {
108
112
  var state = id !== undefined && modalsState[id] || {
109
113
  id: id !== null && id !== void 0 ? id : null
110
114
  };
115
+ state.onOpen = Modal.props.onOpen;
116
+ state.onOpened = Modal.props.onOpened;
111
117
  state.onClose = Modal.props.onClose;
118
+ state.onClosed = Modal.props.onClosed;
112
119
  state.dynamicContentHeight = !!modalProps.dynamicContentHeight; // ModalPage props
113
120
 
114
121
  if (typeof modalProps.settlingHeight === "number") {
@@ -137,7 +144,7 @@ function useModalManager(activeModal, children, onClose) {
137
144
  (0, _useIsomorphicLayoutEffect.useIsomorphicLayoutEffect)(function () {
138
145
  // ignore non-existent activeModal
139
146
  if (process.env.NODE_ENV === "development" && isMissing) {
140
- warn("Can't transition - modal ".concat(activeModal, " not found"));
147
+ warn("Can't transition - modal ".concat(activeModal, " not found"), "error");
141
148
  }
142
149
 
143
150
  dispatchTransition({
@@ -162,24 +169,56 @@ function useModalManager(activeModal, children, onClose) {
162
169
  return id != null && ((_modalsState$id = modalsState[id]) === null || _modalsState$id === void 0 ? void 0 : _modalsState$id.type) === _types.ModalType.CARD;
163
170
  };
164
171
 
165
- var onEnter = React.useCallback(function (id) {
166
- return dispatchTransition({
172
+ var onEntered = React.useCallback(function (id) {
173
+ if (id) {
174
+ var modalState = modalsState[id];
175
+
176
+ if ((0, _utils.isFunction)(modalState.onOpened)) {
177
+ modalState.onOpened();
178
+ } else if ((0, _utils.isFunction)(onOpened)) {
179
+ onOpened(id);
180
+ }
181
+ }
182
+
183
+ dispatchTransition({
167
184
  type: "entered",
168
185
  id: id
169
186
  });
170
- }, []);
171
- var onExit = React.useCallback(function (id) {
172
- return dispatchTransition({
187
+ }, [modalsState, onOpened]);
188
+ var onExited = React.useCallback(function (id) {
189
+ if (id) {
190
+ var modalState = modalsState[id];
191
+
192
+ if ((0, _utils.isFunction)(modalState.onClosed)) {
193
+ modalState.onClosed();
194
+ } else if ((0, _utils.isFunction)(onClosed)) {
195
+ onClosed(id);
196
+ }
197
+ }
198
+
199
+ dispatchTransition({
173
200
  type: "exited",
174
201
  id: id
175
202
  });
176
- }, []);
203
+ }, [modalsState, onClosed]);
177
204
  var delayEnter = Boolean(transitionState.exitingModal && (isCard(activeModal) || isCard(transitionState.exitingModal)));
178
205
  var getModalState = React.useCallback(function (id) {
179
206
  return modalsState[id];
180
207
  }, [modalsState]);
181
208
 
182
- function closeActiveModal() {
209
+ function onEnter() {
210
+ var modalState = transitionState.activeModal && modalsState[transitionState.activeModal];
211
+
212
+ if (modalState) {
213
+ if ((0, _utils.isFunction)(modalState.onOpen)) {
214
+ modalState.onOpen();
215
+ } else if ((0, _utils.isFunction)(onOpen)) {
216
+ onOpen(modalState.id);
217
+ }
218
+ }
219
+ }
220
+
221
+ function onExit() {
183
222
  var modalState = transitionState.activeModal && modalsState[transitionState.activeModal];
184
223
 
185
224
  if (modalState) {
@@ -187,19 +226,18 @@ function useModalManager(activeModal, children, onClose) {
187
226
  modalState.onClose();
188
227
  } else if ((0, _utils.isFunction)(onClose)) {
189
228
  onClose(modalState.id);
190
- } else if (process.env.NODE_ENV === "development") {
191
- warn("onClose is undefined");
192
229
  }
193
230
  }
194
231
  }
195
232
 
196
233
  return (0, _objectSpread2.default)((0, _objectSpread2.default)({
197
234
  onEnter: onEnter,
198
- onExit: onExit
235
+ onEntered: onEntered,
236
+ onExit: onExit,
237
+ onExited: onExited
199
238
  }, transitionState), {}, {
200
239
  delayEnter: delayEnter,
201
- getModalState: getModalState,
202
- closeActiveModal: closeActiveModal
240
+ getModalState: getModalState
203
241
  });
204
242
  }
205
243
 
@@ -207,7 +245,7 @@ function withModalManager() {
207
245
  var initModal = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _utils.noop;
208
246
  return function (Wrapped) {
209
247
  return function WithModalManager(props) {
210
- var transitionManager = useModalManager(props.activeModal, props.children, props.onClose, initModal);
248
+ var transitionManager = useModalManager(props.activeModal, props.children, props.onOpen, props.onOpened, props.onClose, props.onClosed, initModal);
211
249
  return (0, _jsxRuntime.createScopedElement)(Wrapped, (0, _extends2.default)({}, props, transitionManager));
212
250
  };
213
251
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ModalRoot/useModalManager.tsx"],"names":["getModals","children","React","Children","toArray","warn","modalTransitionReducer","state","action","type","id","activeModal","nextModal","prevModal","exitingModal","history","isBack","Boolean","includes","splice","indexOf","push","enteringModal","useModalManager","onClose","initModal","noop","modalsState","useRef","current","forEach","Modal","modalProps","props","undefined","dynamicContentHeight","settlingHeight","isMissing","safeActiveModal","useReducer","transitionState","dispatchTransition","process","env","NODE_ENV","isCard","ModalType","CARD","onEnter","useCallback","onExit","delayEnter","getModalState","closeActiveModal","modalState","withModalManager","Wrapped","WithModalManager","transitionManager"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { ModalsState, ModalsStateEntry, ModalType } from \"./types\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { noop, isFunction } from \"../../lib/utils\";\n\ninterface ModalTransitionState {\n activeModal?: string | null;\n enteringModal?: string | null;\n exitingModal?: string | null;\n\n history?: string[];\n isBack?: boolean | null;\n}\n\nexport interface ModalTransitionProps extends ModalTransitionState {\n onEnter: (id: string | null) => void;\n onExit: (id: string | null) => void;\n getModalState: (id: string) => ModalsStateEntry;\n closeActiveModal: VoidFunction;\n delayEnter: boolean;\n}\n\nfunction getModals(children: React.ReactNode | React.ReactNode[]) {\n return React.Children.toArray(children) as React.ReactElement[];\n}\n\nconst warn = warnOnce(\"ModalRoot\");\n\nexport function modalTransitionReducer(\n state: ModalTransitionState,\n action: {\n type: \"setActive\" | \"entered\" | \"exited\" | \"inited\";\n id: string | null;\n }\n): ModalTransitionState {\n if (action.type === \"setActive\" && action.id !== state.activeModal) {\n const nextModal = action.id;\n // preserve exiting modal if switching mid-transition\n const prevModal = state.exitingModal || state.activeModal;\n let history = state.history ? [...state.history] : [];\n const isBack = Boolean(nextModal && history.includes(nextModal));\n\n if (nextModal === null) {\n history = [];\n } else if (isBack) {\n history = history.splice(0, history.indexOf(nextModal) + 1);\n } else {\n history.push(nextModal);\n }\n\n return {\n activeModal: nextModal,\n // not entering yet\n enteringModal: null,\n exitingModal: prevModal,\n history,\n isBack,\n };\n }\n if (action.type === \"entered\" && action.id === state.enteringModal) {\n return { ...state, enteringModal: null };\n }\n if (action.type === \"exited\" && action.id === state.exitingModal) {\n return { ...state, exitingModal: null };\n }\n if (action.type === \"inited\" && action.id === state.activeModal) {\n return { ...state, enteringModal: action.id };\n }\n return state;\n}\n\n/**\n * Реализует переход модалок. При смене activeModal m1 -> m2:\n * 1. activeModal: m1, exitingModal: null, enteringModal: null, триггер перехода\n * 2. activeModal: m2, exitingModal: m1, enteringModal: null, рендерим m2 чтобы прошел init, начинаем анимацию выхода\n * одновременный переход между ModalPage:\n * 3a. activeModal: m2, exitingModal: m1, enteringModal: m2\n * 4a. exitingModal и enteringModal переходят в null в порядке завершения анимации\n * ИЛИ дожидаемся скрытия ModalCard\n * 3b. activeModal: m2, exitingModal: null, enteringModal: m2\n * 4b. enteringModal переходит в null после завершения анимации\n * 5. activeModal: m2, exitingModal: null, enteringModal: null, переход закончен\n */\nexport function useModalManager(\n activeModal: string | null | undefined,\n children: React.ReactNode | React.ReactNode[],\n onClose: (id: string) => void,\n initModal: (state: ModalsStateEntry) => void = noop\n): ModalTransitionProps {\n const modalsState = React.useRef<ModalsState>({}).current;\n getModals(children).forEach((Modal) => {\n const modalProps = Modal.props;\n const id = getNavId(modalProps, warn);\n const state: ModalsStateEntry = (id !== undefined && modalsState[id]) || {\n id: id ?? null,\n };\n\n state.onClose = Modal.props.onClose;\n state.dynamicContentHeight = !!modalProps.dynamicContentHeight;\n // ModalPage props\n if (typeof modalProps.settlingHeight === \"number\") {\n state.settlingHeight = modalProps.settlingHeight;\n }\n\n if (state.id !== null) {\n modalsState[state.id] = state;\n }\n });\n\n const isMissing = activeModal && !modalsState[activeModal];\n const safeActiveModal = isMissing ? null : activeModal;\n const [transitionState, dispatchTransition] = React.useReducer(\n modalTransitionReducer,\n {\n activeModal: safeActiveModal,\n enteringModal: null,\n exitingModal: null,\n history: safeActiveModal ? [safeActiveModal] : [],\n isBack: false,\n }\n );\n\n // Map props to state, render activeModal for init\n useIsomorphicLayoutEffect(() => {\n // ignore non-existent activeModal\n if (process.env.NODE_ENV === \"development\" && isMissing) {\n warn(`Can't transition - modal ${activeModal} not found`);\n }\n dispatchTransition({ type: \"setActive\", id: safeActiveModal ?? null });\n }, [activeModal]);\n\n // Init activeModal & set enteringModal\n useIsomorphicLayoutEffect(() => {\n if (transitionState.activeModal) {\n initModal(modalsState[transitionState.activeModal]);\n dispatchTransition({ type: \"inited\", id: transitionState.activeModal });\n }\n }, [transitionState.activeModal]);\n\n const isCard = (id: string | null | undefined) =>\n id != null && modalsState[id]?.type === ModalType.CARD;\n const onEnter = React.useCallback(\n (id: string | null) => dispatchTransition({ type: \"entered\", id }),\n []\n );\n const onExit = React.useCallback(\n (id: string | null) => dispatchTransition({ type: \"exited\", id }),\n []\n );\n const delayEnter = Boolean(\n transitionState.exitingModal &&\n (isCard(activeModal) || isCard(transitionState.exitingModal))\n );\n const getModalState = React.useCallback(\n (id: string) => modalsState[id],\n [modalsState]\n );\n\n function closeActiveModal() {\n const modalState =\n transitionState.activeModal && modalsState[transitionState.activeModal];\n if (modalState) {\n if (isFunction(modalState.onClose)) {\n modalState.onClose();\n } else if (isFunction(onClose)) {\n onClose(modalState.id);\n } else if (process.env.NODE_ENV === \"development\") {\n warn(\"onClose is undefined\");\n }\n }\n }\n\n return {\n onEnter,\n onExit,\n ...transitionState,\n delayEnter,\n getModalState,\n closeActiveModal,\n };\n}\n\nexport function withModalManager(\n initModal: (a: ModalsStateEntry) => void = noop\n) {\n return function <Props extends ModalTransitionProps>(\n Wrapped: React.ComponentType<Props>\n ): React.FC<\n Omit<Props, keyof ModalTransitionProps> & { activeModal?: string | null }\n > {\n return function WithModalManager(props) {\n const transitionManager = useModalManager(\n props.activeModal,\n props.children,\n (props as any).onClose,\n initModal\n );\n return <Wrapped {...(props as any)} {...transitionManager} />;\n };\n };\n}\n"],"file":"useModalManager.js"}
1
+ {"version":3,"sources":["../../../../src/components/ModalRoot/useModalManager.tsx"],"names":["getModals","children","React","Children","toArray","warn","modalTransitionReducer","state","action","type","id","activeModal","nextModal","prevModal","exitingModal","history","isBack","Boolean","includes","splice","indexOf","push","enteringModal","useModalManager","onOpen","noop","onOpened","onClose","onClosed","initModal","modalsState","useRef","current","forEach","Modal","modalProps","props","undefined","dynamicContentHeight","settlingHeight","isMissing","safeActiveModal","useReducer","transitionState","dispatchTransition","process","env","NODE_ENV","isCard","ModalType","CARD","onEntered","useCallback","modalState","onExited","delayEnter","getModalState","onEnter","onExit","withModalManager","Wrapped","WithModalManager","transitionManager"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { ModalsState, ModalsStateEntry, ModalType } from \"./types\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { getNavId } from \"../../lib/getNavId\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { noop, isFunction } from \"../../lib/utils\";\n\ninterface ModalTransitionState {\n activeModal?: string | null;\n enteringModal?: string | null;\n exitingModal?: string | null;\n\n history?: string[];\n isBack?: boolean | null;\n}\n\nexport interface ModalTransitionProps extends ModalTransitionState {\n onEnter: VoidFunction;\n onEntered: (id: string | null) => void;\n onExit: VoidFunction;\n onExited: (id: string | null) => void;\n getModalState: (id: string) => ModalsStateEntry;\n delayEnter: boolean;\n}\n\nfunction getModals(children: React.ReactNode | React.ReactNode[]) {\n return React.Children.toArray(children) as React.ReactElement[];\n}\n\nconst warn = warnOnce(\"ModalRoot\");\n\nexport function modalTransitionReducer(\n state: ModalTransitionState,\n action: {\n type: \"setActive\" | \"entered\" | \"exited\" | \"inited\";\n id: string | null;\n }\n): ModalTransitionState {\n if (action.type === \"setActive\" && action.id !== state.activeModal) {\n const nextModal = action.id;\n // preserve exiting modal if switching mid-transition\n const prevModal = state.exitingModal || state.activeModal;\n let history = state.history ? [...state.history] : [];\n const isBack = Boolean(nextModal && history.includes(nextModal));\n\n if (nextModal === null) {\n history = [];\n } else if (isBack) {\n history = history.splice(0, history.indexOf(nextModal) + 1);\n } else {\n history.push(nextModal);\n }\n\n return {\n activeModal: nextModal,\n // not entering yet\n enteringModal: null,\n exitingModal: prevModal,\n history,\n isBack,\n };\n }\n if (action.type === \"entered\" && action.id === state.enteringModal) {\n return { ...state, enteringModal: null };\n }\n if (action.type === \"exited\" && action.id === state.exitingModal) {\n return { ...state, exitingModal: null };\n }\n if (action.type === \"inited\" && action.id === state.activeModal) {\n return { ...state, enteringModal: action.id };\n }\n return state;\n}\n\n/**\n * Реализует переход модалок. При смене activeModal m1 -> m2:\n * 1. activeModal: m1, exitingModal: null, enteringModal: null, триггер перехода\n * 2. activeModal: m2, exitingModal: m1, enteringModal: null, рендерим m2 чтобы прошел init, начинаем анимацию выхода\n * одновременный переход между ModalPage:\n * 3a. activeModal: m2, exitingModal: m1, enteringModal: m2\n * 4a. exitingModal и enteringModal переходят в null в порядке завершения анимации\n * ИЛИ дожидаемся скрытия ModalCard\n * 3b. activeModal: m2, exitingModal: null, enteringModal: m2\n * 4b. enteringModal переходит в null после завершения анимации\n * 5. activeModal: m2, exitingModal: null, enteringModal: null, переход закончен\n */\nexport function useModalManager(\n activeModal: string | null | undefined,\n children: React.ReactNode | React.ReactNode[],\n onOpen: (id: string) => void = noop,\n onOpened: (id: string) => void = noop,\n onClose: (id: string) => void = noop,\n onClosed: (id: string) => void = noop,\n initModal: (state: ModalsStateEntry) => void = noop\n): ModalTransitionProps {\n const modalsState = React.useRef<ModalsState>({}).current;\n getModals(children).forEach((Modal) => {\n const modalProps = Modal.props;\n const id = getNavId(modalProps, warn);\n const state: ModalsStateEntry = (id !== undefined && modalsState[id]) || {\n id: id ?? null,\n };\n\n state.onOpen = Modal.props.onOpen;\n state.onOpened = Modal.props.onOpened;\n state.onClose = Modal.props.onClose;\n state.onClosed = Modal.props.onClosed;\n state.dynamicContentHeight = !!modalProps.dynamicContentHeight;\n // ModalPage props\n if (typeof modalProps.settlingHeight === \"number\") {\n state.settlingHeight = modalProps.settlingHeight;\n }\n\n if (state.id !== null) {\n modalsState[state.id] = state;\n }\n });\n\n const isMissing = activeModal && !modalsState[activeModal];\n const safeActiveModal = isMissing ? null : activeModal;\n const [transitionState, dispatchTransition] = React.useReducer(\n modalTransitionReducer,\n {\n activeModal: safeActiveModal,\n enteringModal: null,\n exitingModal: null,\n history: safeActiveModal ? [safeActiveModal] : [],\n isBack: false,\n }\n );\n\n // Map props to state, render activeModal for init\n useIsomorphicLayoutEffect(() => {\n // ignore non-existent activeModal\n if (process.env.NODE_ENV === \"development\" && isMissing) {\n warn(`Can't transition - modal ${activeModal} not found`, \"error\");\n }\n dispatchTransition({ type: \"setActive\", id: safeActiveModal ?? null });\n }, [activeModal]);\n\n // Init activeModal & set enteringModal\n useIsomorphicLayoutEffect(() => {\n if (transitionState.activeModal) {\n initModal(modalsState[transitionState.activeModal]);\n dispatchTransition({ type: \"inited\", id: transitionState.activeModal });\n }\n }, [transitionState.activeModal]);\n\n const isCard = (id: string | null | undefined) =>\n id != null && modalsState[id]?.type === ModalType.CARD;\n const onEntered = React.useCallback(\n (id: string | null) => {\n if (id) {\n const modalState = modalsState[id];\n\n if (isFunction(modalState.onOpened)) {\n modalState.onOpened();\n } else if (isFunction(onOpened)) {\n onOpened(id);\n }\n }\n\n dispatchTransition({ type: \"entered\", id });\n },\n [modalsState, onOpened]\n );\n const onExited = React.useCallback(\n (id: string | null) => {\n if (id) {\n const modalState = modalsState[id];\n\n if (isFunction(modalState.onClosed)) {\n modalState.onClosed();\n } else if (isFunction(onClosed)) {\n onClosed(id);\n }\n }\n\n dispatchTransition({ type: \"exited\", id });\n },\n [modalsState, onClosed]\n );\n const delayEnter = Boolean(\n transitionState.exitingModal &&\n (isCard(activeModal) || isCard(transitionState.exitingModal))\n );\n const getModalState = React.useCallback(\n (id: string) => modalsState[id],\n [modalsState]\n );\n\n function onEnter() {\n const modalState =\n transitionState.activeModal && modalsState[transitionState.activeModal];\n if (modalState) {\n if (isFunction(modalState.onOpen)) {\n modalState.onOpen();\n } else if (isFunction(onOpen)) {\n onOpen(modalState.id);\n }\n }\n }\n\n function onExit() {\n const modalState =\n transitionState.activeModal && modalsState[transitionState.activeModal];\n if (modalState) {\n if (isFunction(modalState.onClose)) {\n modalState.onClose();\n } else if (isFunction(onClose)) {\n onClose(modalState.id);\n }\n }\n }\n\n return {\n onEnter,\n onEntered,\n onExit,\n onExited,\n ...transitionState,\n delayEnter,\n getModalState,\n };\n}\n\nexport function withModalManager(\n initModal: (a: ModalsStateEntry) => void = noop\n) {\n return function <Props extends ModalTransitionProps>(\n Wrapped: React.ComponentType<Props>\n ): React.FC<\n Omit<Props, keyof ModalTransitionProps> & { activeModal?: string | null }\n > {\n return function WithModalManager(props) {\n const transitionManager = useModalManager(\n props.activeModal,\n props.children,\n (props as any).onOpen,\n (props as any).onOpened,\n (props as any).onClose,\n (props as any).onClosed,\n initModal\n );\n return <Wrapped {...(props as any)} {...transitionManager} />;\n };\n };\n}\n"],"file":"useModalManager.js"}
@@ -96,7 +96,8 @@ var NativeSelect = function NativeSelect(_ref) {
96
96
  }, [value, children]);
97
97
  var TypographyComponent = platform === _platform.VKCOM || sizeY === _withAdaptivity.SizeType.COMPACT ? _Text.default : _Headline.default;
98
98
  return (0, _jsxRuntime.createScopedElement)(_FormField.FormField, {
99
- Component: "label",
99
+ Component: "label" // eslint-disable-next-line vkui/no-object-expression-in-arguments
100
+ ,
100
101
  vkuiClass: (0, _classNames2.classNames)((0, _getClassName.getClassName)("Select", platform), (_classNames = {}, (0, _defineProperty2.default)(_classNames, "Select--not-selected", notSelected), (0, _defineProperty2.default)(_classNames, "Select--align-".concat(align), !!align), (0, _defineProperty2.default)(_classNames, "Select--sizeX--".concat(sizeX), !!sizeX), (0, _defineProperty2.default)(_classNames, "Select--sizeY--".concat(sizeY), !!sizeY), (0, _defineProperty2.default)(_classNames, "Select--multiline", multiline), _classNames)),
101
102
  className: className,
102
103
  style: style,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/NativeSelect/NativeSelect.tsx"],"names":["NativeSelect","style","defaultValue","align","placeholder","children","className","getRef","getRootRef","disabled","sizeX","sizeY","multiline","restProps","platform","React","useState","title","setTitle","notSelected","setNotSelected","value","onChange","selectRef","selectedOption","current","options","selectedIndex","text","TypographyComponent","VKCOM","SizeType","COMPACT","Text","Headline"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { DropdownIcon } from \"../DropdownIcon/DropdownIcon\";\nimport { FormField } from \"../FormField/FormField\";\nimport { HasAlign, HasRef, HasRootRef } from \"../../types\";\nimport { withAdaptivity, SizeType } from \"../../hoc/withAdaptivity\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport Headline from \"../Typography/Headline/Headline\";\nimport Text from \"../Typography/Text/Text\";\nimport { VKCOM } from \"../../lib/platform\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { useEnsuredControl } from \"../../hooks/useEnsuredControl\";\nimport { useExternRef } from \"../../hooks/useExternRef\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport {\n AdaptivityContextInterface,\n AdaptivityProps,\n} from \"../AdaptivityProvider/AdaptivityContext\";\nimport \"../Select/Select.css\";\n\nexport interface NativeSelectProps\n extends React.SelectHTMLAttributes<HTMLSelectElement>,\n HasRef<HTMLSelectElement>,\n HasRootRef<HTMLLabelElement>,\n HasAlign,\n AdaptivityProps {\n placeholder?: string;\n multiline?: boolean;\n}\n\nexport interface SelectState {\n value?: React.SelectHTMLAttributes<HTMLSelectElement>[\"value\"];\n title?: string;\n notSelected?: boolean;\n}\n\nconst NativeSelect: React.FC<\n NativeSelectProps & AdaptivityContextInterface\n> = ({\n style,\n defaultValue = \"\",\n align,\n placeholder,\n children,\n className,\n getRef,\n getRootRef,\n disabled,\n sizeX,\n sizeY,\n multiline,\n ...restProps\n}) => {\n const platform = usePlatform();\n const [title, setTitle] = React.useState(\"\");\n const [notSelected, setNotSelected] = React.useState(false);\n const [value, onChange] = useEnsuredControl(restProps, { defaultValue });\n const selectRef = useExternRef(getRef);\n useIsomorphicLayoutEffect(() => {\n const selectedOption =\n selectRef.current?.options[selectRef.current.selectedIndex];\n if (selectedOption) {\n setTitle(selectedOption.text);\n setNotSelected(selectedOption.value === \"\" && placeholder != null);\n }\n }, [value, children]);\n\n const TypographyComponent =\n platform === VKCOM || sizeY === SizeType.COMPACT ? Text : Headline;\n\n return (\n <FormField\n Component=\"label\"\n vkuiClass={classNames(getClassName(\"Select\", platform), {\n [\"Select--not-selected\"]: notSelected,\n [`Select--align-${align}`]: !!align,\n [`Select--sizeX--${sizeX}`]: !!sizeX,\n [`Select--sizeY--${sizeY}`]: !!sizeY,\n \"Select--multiline\": multiline,\n })}\n className={className}\n style={style}\n getRootRef={getRootRef}\n disabled={disabled}\n after={<DropdownIcon />}\n >\n <select\n {...restProps}\n disabled={disabled}\n vkuiClass=\"Select__el\"\n onChange={onChange}\n value={value}\n ref={selectRef}\n >\n {placeholder && <option value=\"\">{placeholder}</option>}\n {children}\n </select>\n <TypographyComponent\n Component=\"div\"\n weight=\"regular\"\n vkuiClass=\"Select__container\"\n >\n <span vkuiClass=\"Select__title\">{title}</span>\n </TypographyComponent>\n </FormField>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default withAdaptivity(NativeSelect, {\n sizeX: true,\n sizeY: true,\n});\n"],"file":"NativeSelect.js"}
1
+ {"version":3,"sources":["../../../../src/components/NativeSelect/NativeSelect.tsx"],"names":["NativeSelect","style","defaultValue","align","placeholder","children","className","getRef","getRootRef","disabled","sizeX","sizeY","multiline","restProps","platform","React","useState","title","setTitle","notSelected","setNotSelected","value","onChange","selectRef","selectedOption","current","options","selectedIndex","text","TypographyComponent","VKCOM","SizeType","COMPACT","Text","Headline"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { DropdownIcon } from \"../DropdownIcon/DropdownIcon\";\nimport { FormField } from \"../FormField/FormField\";\nimport { HasAlign, HasRef, HasRootRef } from \"../../types\";\nimport { withAdaptivity, SizeType } from \"../../hoc/withAdaptivity\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport Headline from \"../Typography/Headline/Headline\";\nimport Text from \"../Typography/Text/Text\";\nimport { VKCOM } from \"../../lib/platform\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { useEnsuredControl } from \"../../hooks/useEnsuredControl\";\nimport { useExternRef } from \"../../hooks/useExternRef\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport {\n AdaptivityContextInterface,\n AdaptivityProps,\n} from \"../AdaptivityProvider/AdaptivityContext\";\nimport \"../Select/Select.css\";\n\nexport interface NativeSelectProps\n extends React.SelectHTMLAttributes<HTMLSelectElement>,\n HasRef<HTMLSelectElement>,\n HasRootRef<HTMLLabelElement>,\n HasAlign,\n AdaptivityProps {\n placeholder?: string;\n multiline?: boolean;\n}\n\nexport interface SelectState {\n value?: React.SelectHTMLAttributes<HTMLSelectElement>[\"value\"];\n title?: string;\n notSelected?: boolean;\n}\n\nconst NativeSelect: React.FC<\n NativeSelectProps & AdaptivityContextInterface\n> = ({\n style,\n defaultValue = \"\",\n align,\n placeholder,\n children,\n className,\n getRef,\n getRootRef,\n disabled,\n sizeX,\n sizeY,\n multiline,\n ...restProps\n}) => {\n const platform = usePlatform();\n const [title, setTitle] = React.useState(\"\");\n const [notSelected, setNotSelected] = React.useState(false);\n const [value, onChange] = useEnsuredControl(restProps, { defaultValue });\n const selectRef = useExternRef(getRef);\n useIsomorphicLayoutEffect(() => {\n const selectedOption =\n selectRef.current?.options[selectRef.current.selectedIndex];\n if (selectedOption) {\n setTitle(selectedOption.text);\n setNotSelected(selectedOption.value === \"\" && placeholder != null);\n }\n }, [value, children]);\n\n const TypographyComponent =\n platform === VKCOM || sizeY === SizeType.COMPACT ? Text : Headline;\n\n return (\n <FormField\n Component=\"label\"\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(getClassName(\"Select\", platform), {\n [\"Select--not-selected\"]: notSelected,\n [`Select--align-${align}`]: !!align,\n [`Select--sizeX--${sizeX}`]: !!sizeX,\n [`Select--sizeY--${sizeY}`]: !!sizeY,\n \"Select--multiline\": multiline,\n })}\n className={className}\n style={style}\n getRootRef={getRootRef}\n disabled={disabled}\n after={<DropdownIcon />}\n >\n <select\n {...restProps}\n disabled={disabled}\n vkuiClass=\"Select__el\"\n onChange={onChange}\n value={value}\n ref={selectRef}\n >\n {placeholder && <option value=\"\">{placeholder}</option>}\n {children}\n </select>\n <TypographyComponent\n Component=\"div\"\n weight=\"regular\"\n vkuiClass=\"Select__container\"\n >\n <span vkuiClass=\"Select__title\">{title}</span>\n </TypographyComponent>\n </FormField>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default withAdaptivity(NativeSelect, {\n sizeX: true,\n sizeY: true,\n});\n"],"file":"NativeSelect.js"}
@@ -0,0 +1,42 @@
1
+ import * as React from "react";
2
+ import type { HasRootRef } from "../../types";
3
+ import "./Pagination.css";
4
+ export interface PaginationProps extends Omit<React.HTMLAttributes<HTMLElement>, "onChange">, HasRootRef<HTMLElement> {
5
+ /**
6
+ * Текущая страница.
7
+ */
8
+ currentPage?: number;
9
+ /**
10
+ * Кол-во всегда видимых страниц по краям текущей страницы.
11
+ */
12
+ siblingCount?: number;
13
+ /**
14
+ * Кол-во всегда видимых страниц в начале и в конце.
15
+ */
16
+ boundaryCount?: number;
17
+ /**
18
+ * Общее кол-во страниц.
19
+ */
20
+ totalPages?: number;
21
+ /**
22
+ * Блокировка всех кнопок.
23
+ */
24
+ disabled?: boolean;
25
+ /**
26
+ * Переопределение `aria-label` для кнопки навигации назад.
27
+ * По умолчанию используется текст на "ru_RU".
28
+ */
29
+ prevButtonAriaLabel?: string;
30
+ /**
31
+ * Переопределение `aria-label` для кнопки навигации вперёд.
32
+ * По умолчанию используется текст на "ru_RU".
33
+ */
34
+ nextButtonAriaLabel?: string;
35
+ /**
36
+ * Функция для переопределения и/или локализации `aria-label` атрибута.
37
+ * По умолчанию используется текст на "ru_RU".
38
+ */
39
+ getPageAriaLabel?(page: number, isCurrent: boolean): string;
40
+ onChange?(page: number): void;
41
+ }
42
+ export declare const Pagination: React.FC<PaginationProps>;