@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
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/WriteBarIcon/WriteBarIcon.tsx"],"names":["warn","IS_DEV","process","env","NODE_ENV","WriteBarIcon","mode","children","count","restProps","platform","icon","ariaLabel","undefined","IOS"],"mappings":";;;;;;;;;;;;;;;;;AACA;;AAQA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;AAoBA,IAAMA,IAAI,GAAG,wBAAS,cAAT,CAAb;AACA,IAAMC,MAAM,GAAGC,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAAxC;;AAEO,IAAMC,YAAyC,GAAG,SAA5CA,YAA4C,OAKhC;AAAA,MAJvBC,IAIuB,QAJvBA,IAIuB;AAAA,MAHvBC,QAGuB,QAHvBA,QAGuB;AAAA,MAFvBC,KAEuB,QAFvBA,KAEuB;AAAA,MADpBC,SACoB;AACvB,MAAMC,QAAQ,GAAG,+BAAjB;AAEA,MAAIC,IAAJ;AACA,MAAIC,SAA6B,GAAGC,SAApC;;AAEA,UAAQP,IAAR;AACE,SAAK,QAAL;AACEK,MAAAA,IAAI,GACFD,QAAQ,KAAKI,aAAb,GAAmB,qCAAC,6BAAD,OAAnB,GAAgD,qCAAC,0BAAD,OADlD;AAEAF,MAAAA,SAAS,GAAG,iBAAZ;AACA;;AAEF,SAAK,MAAL;AACED,MAAAA,IAAI,GAAGD,QAAQ,KAAKI,aAAb,GAAmB,qCAAC,yBAAD,OAAnB,GAA4C,qCAAC,iBAAD,OAAnD;AACAF,MAAAA,SAAS,GAAG,WAAZ;AACA;;AAEF,SAAK,MAAL;AACED,MAAAA,IAAI,GACFD,QAAQ,KAAKI,aAAb,GACE,qCAAC,yBAAD,OADF,GAGE,qCAAC,+BAAD,OAJJ;AAMAF,MAAAA,SAAS,GAAG,QAAZ;AACA;;AAEF;AACE;AAvBJ;;AA0BA,MAAIX,MAAM,IAAI,CAACQ,SAAS,CAAC,YAAD,CAApB,IAAsC,CAACG,SAA3C,EAAsD;AACpDZ,IAAAA,IAAI,CACF,sGADE,CAAJ;AAGD;;AAED,SACE,qCAAC,iBAAD;AACE,kBAAYY;AADd,KAEMH,SAFN;AAGE,IAAA,SAAS,EAAC,QAHZ;AAIE,IAAA,QAAQ,EAAE,KAJZ;AAKE,IAAA,UAAU,EAAC,sBALb;AAME,IAAA,SAAS,EAAE,6BAAW,gCAAa,cAAb,EAA6BC,QAA7B,CAAX,4DACSJ,IADT,GACkB,CAAC,CAACA,IADpB;AANb,MAUE;AAAM,IAAA,SAAS,EAAC;AAAhB,KACGK,IAAI,IAAIJ,QADX,EAEG,yBAAaC,KAAb,KACC,qCAAC,gBAAD;AAAS,IAAA,SAAS,EAAC,uBAAnB;AAA2C,IAAA,IAAI,EAAC;AAAhD,KACGA,KADH,CAHJ,CAVF,CADF;AAqBD,CAhEM","sourcesContent":["import * as React from \"react\";\nimport {\n Icon24Send,\n Icon28AddCircleOutline,\n Icon28AttachOutline,\n Icon28CheckCircleOutline,\n Icon48WritebarDone,\n Icon48WritebarSend,\n} from \"@vkontakte/icons\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { classNames } from \"../../lib/classNames\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { IOS } from \"../../lib/platform\";\nimport Counter from \"../Counter/Counter\";\nimport Tappable from \"../Tappable/Tappable\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport \"./WriteBarIcon.css\";\n\nexport interface WriteBarIconProps\n extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n /**\n * Предустановленные типы кнопок в WriteBar для отрисовки иконки в зависимости от платформы.\n * Если передать валидное значение для этого свойства, `children` игнорируется.\n *\n * - `attach` – иконка прикрепления.\n * - `send` – иконка отправки.\n * - `done` – иконка отправки в режиме редактирования.\n */\n mode?: \"attach\" | \"send\" | \"done\";\n /**\n * Значение счётчика для кнопки. Например, для количества прикреплённых файлов.\n */\n count?: number;\n}\n\nconst warn = warnOnce(\"WriteBarIcon\");\nconst IS_DEV = process.env.NODE_ENV === \"development\";\n\nexport const WriteBarIcon: React.FC<WriteBarIconProps> = ({\n mode,\n children,\n count,\n ...restProps\n}: WriteBarIconProps) => {\n const platform = usePlatform();\n\n let icon: React.ReactNode;\n let ariaLabel: string | undefined = undefined;\n\n switch (mode) {\n case \"attach\":\n icon =\n platform === IOS ? <Icon28AddCircleOutline /> : <Icon28AttachOutline />;\n ariaLabel = \"Прикрепить файл\";\n break;\n\n case \"send\":\n icon = platform === IOS ? <Icon48WritebarSend /> : <Icon24Send />;\n ariaLabel = \"Отправить\";\n break;\n\n case \"done\":\n icon =\n platform === IOS ? (\n <Icon48WritebarDone />\n ) : (\n <Icon28CheckCircleOutline />\n );\n ariaLabel = \"Готово\";\n break;\n\n default:\n break;\n }\n\n if (IS_DEV && !restProps[\"aria-label\"] && !ariaLabel) {\n warn(\n \"[WriteBarIcon/a11y] У WriteBarIcon нет aria-label. Кнопка будет недоступной для части пользователей.\"\n );\n }\n\n return (\n <Tappable\n aria-label={ariaLabel}\n {...restProps}\n Component=\"button\"\n hasHover={false}\n activeMode=\"WriteBarIcon__active\"\n vkuiClass={classNames(getClassName(\"WriteBarIcon\", platform), {\n [`WriteBarIcon--${mode}`]: !!mode,\n })}\n >\n <span vkuiClass=\"WriteBarIcon__in\">\n {icon || children}\n {hasReactNode(count) && (\n <Counter vkuiClass=\"WriteBarIcon__counter\" size=\"s\">\n {count}\n </Counter>\n )}\n </span>\n </Tappable>\n );\n};\n"],"file":"WriteBarIcon.js"}
1
+ {"version":3,"sources":["../../../../src/components/WriteBarIcon/WriteBarIcon.tsx"],"names":["warn","IS_DEV","process","env","NODE_ENV","WriteBarIcon","mode","children","count","restProps","platform","icon","ariaLabel","undefined","IOS"],"mappings":";;;;;;;;;;;;;;;;;AACA;;AAQA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;AAoBA,IAAMA,IAAI,GAAG,wBAAS,cAAT,CAAb;AACA,IAAMC,MAAM,GAAGC,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAAxC;;AAEO,IAAMC,YAAyC,GAAG,SAA5CA,YAA4C,OAKhC;AAAA,MAJvBC,IAIuB,QAJvBA,IAIuB;AAAA,MAHvBC,QAGuB,QAHvBA,QAGuB;AAAA,MAFvBC,KAEuB,QAFvBA,KAEuB;AAAA,MADpBC,SACoB;AACvB,MAAMC,QAAQ,GAAG,+BAAjB;AAEA,MAAIC,IAAJ;AACA,MAAIC,SAA6B,GAAGC,SAApC;;AAEA,UAAQP,IAAR;AACE,SAAK,QAAL;AACEK,MAAAA,IAAI,GACFD,QAAQ,KAAKI,aAAb,GAAmB,qCAAC,6BAAD,OAAnB,GAAgD,qCAAC,0BAAD,OADlD;AAEAF,MAAAA,SAAS,GAAG,iBAAZ;AACA;;AAEF,SAAK,MAAL;AACED,MAAAA,IAAI,GAAGD,QAAQ,KAAKI,aAAb,GAAmB,qCAAC,yBAAD,OAAnB,GAA4C,qCAAC,iBAAD,OAAnD;AACAF,MAAAA,SAAS,GAAG,WAAZ;AACA;;AAEF,SAAK,MAAL;AACED,MAAAA,IAAI,GACFD,QAAQ,KAAKI,aAAb,GACE,qCAAC,yBAAD,OADF,GAGE,qCAAC,+BAAD,OAJJ;AAMAF,MAAAA,SAAS,GAAG,QAAZ;AACA;;AAEF;AACE;AAvBJ;;AA0BA,MAAIX,MAAM,IAAI,CAACQ,SAAS,CAAC,YAAD,CAApB,IAAsC,CAACG,SAA3C,EAAsD;AACpDZ,IAAAA,IAAI,CACF,wFADE,EAEF,OAFE,CAAJ;AAID;;AAED,SACE,qCAAC,iBAAD;AACE,kBAAYY;AADd,KAEMH,SAFN;AAGE,IAAA,SAAS,EAAC,QAHZ;AAIE,IAAA,QAAQ,EAAE,KAJZ;AAKE,IAAA,UAAU,EAAC,sBALb,CAME;AANF;AAOE,IAAA,SAAS,EAAE,6BAAW,gCAAa,cAAb,EAA6BC,QAA7B,CAAX,4DACSJ,IADT,GACkB,CAAC,CAACA,IADpB;AAPb,MAWE;AAAM,IAAA,SAAS,EAAC;AAAhB,KACGK,IAAI,IAAIJ,QADX,EAEG,yBAAaC,KAAb,KACC,qCAAC,gBAAD;AAAS,IAAA,SAAS,EAAC,uBAAnB;AAA2C,IAAA,IAAI,EAAC;AAAhD,KACGA,KADH,CAHJ,CAXF,CADF;AAsBD,CAlEM","sourcesContent":["import * as React from \"react\";\nimport {\n Icon24Send,\n Icon28AddCircleOutline,\n Icon28AttachOutline,\n Icon28CheckCircleOutline,\n Icon48WritebarDone,\n Icon48WritebarSend,\n} from \"@vkontakte/icons\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { classNames } from \"../../lib/classNames\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { IOS } from \"../../lib/platform\";\nimport Counter from \"../Counter/Counter\";\nimport Tappable from \"../Tappable/Tappable\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport \"./WriteBarIcon.css\";\n\nexport interface WriteBarIconProps\n extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n /**\n * Предустановленные типы кнопок в WriteBar для отрисовки иконки в зависимости от платформы.\n * Если передать валидное значение для этого свойства, `children` игнорируется.\n *\n * - `attach` – иконка прикрепления.\n * - `send` – иконка отправки.\n * - `done` – иконка отправки в режиме редактирования.\n */\n mode?: \"attach\" | \"send\" | \"done\";\n /**\n * Значение счётчика для кнопки. Например, для количества прикреплённых файлов.\n */\n count?: number;\n}\n\nconst warn = warnOnce(\"WriteBarIcon\");\nconst IS_DEV = process.env.NODE_ENV === \"development\";\n\nexport const WriteBarIcon: React.FC<WriteBarIconProps> = ({\n mode,\n children,\n count,\n ...restProps\n}: WriteBarIconProps) => {\n const platform = usePlatform();\n\n let icon: React.ReactNode;\n let ariaLabel: string | undefined = undefined;\n\n switch (mode) {\n case \"attach\":\n icon =\n platform === IOS ? <Icon28AddCircleOutline /> : <Icon28AttachOutline />;\n ariaLabel = \"Прикрепить файл\";\n break;\n\n case \"send\":\n icon = platform === IOS ? <Icon48WritebarSend /> : <Icon24Send />;\n ariaLabel = \"Отправить\";\n break;\n\n case \"done\":\n icon =\n platform === IOS ? (\n <Icon48WritebarDone />\n ) : (\n <Icon28CheckCircleOutline />\n );\n ariaLabel = \"Готово\";\n break;\n\n default:\n break;\n }\n\n if (IS_DEV && !restProps[\"aria-label\"] && !ariaLabel) {\n warn(\n \"a11y: У WriteBarIcon нет aria-label. Кнопка будет недоступной для части пользователей.\",\n \"error\"\n );\n }\n\n return (\n <Tappable\n aria-label={ariaLabel}\n {...restProps}\n Component=\"button\"\n hasHover={false}\n activeMode=\"WriteBarIcon__active\"\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(getClassName(\"WriteBarIcon\", platform), {\n [`WriteBarIcon--${mode}`]: !!mode,\n })}\n >\n <span vkuiClass=\"WriteBarIcon__in\">\n {icon || children}\n {hasReactNode(count) && (\n <Counter vkuiClass=\"WriteBarIcon__counter\" size=\"s\">\n {count}\n </Counter>\n )}\n </span>\n </Tappable>\n );\n};\n"],"file":"WriteBarIcon.js"}
@@ -52,12 +52,12 @@ function normalizeScheme(_ref) {
52
52
  }
53
53
 
54
54
  if (scheme === Scheme.VKCOM) {
55
- process.env.NODE_ENV === "development" && warn("\u0421\u0445\u0435\u043C\u0430 \"".concat(Scheme.VKCOM, "\" \u0443\u0441\u0442\u0430\u0440\u0435\u043B\u0430 \u0438 \u0431\u0443\u0434\u0435\u0442 \u0443\u0434\u0430\u043B\u0435\u043D\u0430 5.0.0. \u0412\u043C\u0435\u0441\u0442\u043E \u043D\u0435\u0451 \u0438\u0441\u043F\u043E\u043B\u044C\u0437\u0443\u0439\u0442\u0435 \"").concat(Scheme.VKCOM_LIGHT, "\""));
55
+ process.env.NODE_ENV === "development" && warn("\u0421\u0445\u0435\u043C\u0430 \"".concat(Scheme.VKCOM, "\" \u0443\u0441\u0442\u0430\u0440\u0435\u043B\u0430 \u0438 \u0431\u0443\u0434\u0435\u0442 \u0443\u0434\u0430\u043B\u0435\u043D\u0430 \u0432 v5.0.0. \u0412\u043C\u0435\u0441\u0442\u043E \u043D\u0435\u0451 \u0438\u0441\u043F\u043E\u043B\u044C\u0437\u0443\u0439\u0442\u0435 \"").concat(Scheme.VKCOM_LIGHT, "\""));
56
56
  return Scheme.VKCOM_LIGHT;
57
57
  }
58
58
 
59
59
  if (platform === _platform.VKCOM && (scheme === Scheme.BRIGHT_LIGHT || scheme === Scheme.SPACE_GRAY)) {
60
- process.env.NODE_ENV === "development" && warn("\u041F\u043B\u0430\u0442\u0444\u043E\u0440\u043C\u0430 \"vkcom\" \u0438 \u0441\u0445\u0435\u043C\u0430 \"".concat(scheme, "\" \u043D\u0435\u0441\u043E\u0432\u043C\u0435\u0441\u0442\u0438\u043C\u044B. \u0421 \u044D\u0442\u043E\u0439 \u043F\u043B\u0430\u0442\u0444\u043E\u0440\u043C\u043E\u0439 \u043C\u043E\u0436\u043D\u043E \u0438\u0441\u043F\u043E\u043B\u044C\u0437\u043E\u0432\u0430\u0442\u044C \u0441\u0445\u0435\u043C\u044B \"").concat(Scheme.VKCOM_LIGHT, "\" \u0438\u043B\u0438 \"").concat(Scheme.VKCOM_DARK, "\""));
60
+ process.env.NODE_ENV === "development" && warn("\u041F\u043B\u0430\u0442\u0444\u043E\u0440\u043C\u0430 \"vkcom\" \u0438 \u0441\u0445\u0435\u043C\u0430 \"".concat(scheme, "\" \u043D\u0435\u0441\u043E\u0432\u043C\u0435\u0441\u0442\u0438\u043C\u044B. \u0421 \u044D\u0442\u043E\u0439 \u043F\u043B\u0430\u0442\u0444\u043E\u0440\u043C\u043E\u0439 \u043C\u043E\u0436\u043D\u043E \u0438\u0441\u043F\u043E\u043B\u044C\u0437\u043E\u0432\u0430\u0442\u044C \u0441\u0445\u0435\u043C\u044B \"").concat(Scheme.VKCOM_LIGHT, "\" \u0438\u043B\u0438 \"").concat(Scheme.VKCOM_DARK, "\""), "error");
61
61
  return Scheme.VKCOM_LIGHT;
62
62
  }
63
63
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/helpers/scheme.ts"],"names":["Scheme","Appearance","warn","normalizeScheme","platform","scheme","appearance","VKCOM","process","env","NODE_ENV","VKCOM_LIGHT","BRIGHT_LIGHT","SPACE_GRAY","VKCOM_DARK","DEPRECATED_CLIENT_LIGHT","DEPRECATED_CLIENT_DARK"],"mappings":";;;;;;;;AACA;;AACA;;AACA;;IAEYA,M;;;WAAAA,M;AAAAA,EAAAA,M;AAAAA,EAAAA,M;AAAAA,EAAAA,M;AAAAA,EAAAA,M;AAAAA,EAAAA,M;AAAAA,EAAAA,M;AAAAA,EAAAA,M;GAAAA,M,sBAAAA,M;;IA8BAC,U;;;WAAAA,U;AAAAA,EAAAA,U;AAAAA,EAAAA,U;GAAAA,U,0BAAAA,U;;AAKZ,IAAMC,IAAI,GAAG,wBAAS,QAAT,CAAb;;AAQO,SAASC,eAAT,OAIsC;AAAA,MAH3CC,QAG2C,QAH3CA,QAG2C;AAAA,MAF3CC,MAE2C,QAF3CA,MAE2C;AAAA,MAD3CC,UAC2C,QAD3CA,UAC2C;;AAC3C,MAAIA,UAAJ,EAAgB;AACd,WAAO,0BAAU;AAAEF,MAAAA,QAAQ,EAARA,QAAF;AAAYE,MAAAA,UAAU,EAAVA;AAAZ,KAAV,CAAP;AACD;;AAED,MAAID,MAAM,KAAK,SAAf,EAA0B;AACxB,WAAOA,MAAP;AACD;;AACD,MAAIA,MAAM,KAAKL,MAAM,CAACO,KAAtB,EAA6B;AAC3BC,IAAAA,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAAzB,IACER,IAAI,4CACQF,MAAM,CAACO,KADf,sRACiFP,MAAM,CAACW,WADxF,QADN;AAIA,WAAOX,MAAM,CAACW,WAAd;AACD;;AACD,MACEP,QAAQ,KAAKG,eAAb,KACCF,MAAM,KAAKL,MAAM,CAACY,YAAlB,IAAkCP,MAAM,KAAKL,MAAM,CAACa,UADrD,CADF,EAGE;AACAL,IAAAA,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAAzB,IACER,IAAI,oHAC4BG,MAD5B,gUACiGL,MAAM,CAACW,WADxG,qCAC6HX,MAAM,CAACc,UADpI,QADN;AAIA,WAAOd,MAAM,CAACW,WAAd;AACD;;AACD,UAAQN,MAAR;AACE,SAAKL,MAAM,CAACe,uBAAZ;AACE,aAAOf,MAAM,CAACY,YAAd;;AACF,SAAKZ,MAAM,CAACgB,sBAAZ;AACE,aAAOhB,MAAM,CAACa,UAAd;;AACF;AACE,aAAOR,MAAP;AANJ;AAQD","sourcesContent":["import { AppearanceSchemeType, AppearanceType } from \"@vkontakte/vk-bridge\";\nimport { PlatformType, VKCOM } from \"../lib/platform\";\nimport { warnOnce } from \"../lib/warnOnce\";\nimport { getScheme } from \"./getScheme\";\n\nexport enum Scheme {\n /**\n * @deprecated будет удалено в 5.0.0\n * версия оставлена для совместимости со старыми версиями клиентов\n */\n DEPRECATED_CLIENT_LIGHT = \"client_light\",\n /**\n * @deprecated будет удалено в 5.0.0\n * версия оставлена для совместимости со старыми версиями клиентов\n */\n DEPRECATED_CLIENT_DARK = \"client_dark\",\n /**\n * @deprecated будет удалено в 5.0.0\n * версия оставлена для совместимости с vkcom, когда там была только одна схема\n */\n VKCOM = \"vkcom\",\n\n BRIGHT_LIGHT = \"bright_light\",\n SPACE_GRAY = \"space_gray\",\n VKCOM_LIGHT = \"vkcom_light\",\n VKCOM_DARK = \"vkcom_dark\",\n}\n\nexport type AppearanceScheme =\n | AppearanceSchemeType\n | Scheme.VKCOM\n | Scheme.VKCOM_DARK\n | Scheme.VKCOM_LIGHT\n | \"inherit\";\n\nexport enum Appearance {\n DARK = \"dark\",\n LIGHT = \"light\",\n}\n\nconst warn = warnOnce(\"scheme\");\n\nexport interface NormalizeSchemeProps {\n platform: PlatformType;\n scheme?: AppearanceScheme;\n appearance?: AppearanceType;\n}\n\nexport function normalizeScheme({\n platform,\n scheme,\n appearance,\n}: NormalizeSchemeProps): Scheme | \"inherit\" {\n if (appearance) {\n return getScheme({ platform, appearance });\n }\n\n if (scheme === \"inherit\") {\n return scheme;\n }\n if (scheme === Scheme.VKCOM) {\n process.env.NODE_ENV === \"development\" &&\n warn(\n `Схема \"${Scheme.VKCOM}\" устарела и будет удалена 5.0.0. Вместо неё используйте \"${Scheme.VKCOM_LIGHT}\"`\n );\n return Scheme.VKCOM_LIGHT;\n }\n if (\n platform === VKCOM &&\n (scheme === Scheme.BRIGHT_LIGHT || scheme === Scheme.SPACE_GRAY)\n ) {\n process.env.NODE_ENV === \"development\" &&\n warn(\n `Платформа \"vkcom\" и схема \"${scheme}\" несовместимы. С этой платформой можно использовать схемы \"${Scheme.VKCOM_LIGHT}\" или \"${Scheme.VKCOM_DARK}\"`\n );\n return Scheme.VKCOM_LIGHT;\n }\n switch (scheme) {\n case Scheme.DEPRECATED_CLIENT_LIGHT:\n return Scheme.BRIGHT_LIGHT;\n case Scheme.DEPRECATED_CLIENT_DARK:\n return Scheme.SPACE_GRAY;\n default:\n return scheme as Scheme;\n }\n}\n"],"file":"scheme.js"}
1
+ {"version":3,"sources":["../../../src/helpers/scheme.ts"],"names":["Scheme","Appearance","warn","normalizeScheme","platform","scheme","appearance","VKCOM","process","env","NODE_ENV","VKCOM_LIGHT","BRIGHT_LIGHT","SPACE_GRAY","VKCOM_DARK","DEPRECATED_CLIENT_LIGHT","DEPRECATED_CLIENT_DARK"],"mappings":";;;;;;;;AACA;;AACA;;AACA;;IAEYA,M;;;WAAAA,M;AAAAA,EAAAA,M;AAAAA,EAAAA,M;AAAAA,EAAAA,M;AAAAA,EAAAA,M;AAAAA,EAAAA,M;AAAAA,EAAAA,M;AAAAA,EAAAA,M;GAAAA,M,sBAAAA,M;;IA8BAC,U;;;WAAAA,U;AAAAA,EAAAA,U;AAAAA,EAAAA,U;GAAAA,U,0BAAAA,U;;AAKZ,IAAMC,IAAI,GAAG,wBAAS,QAAT,CAAb;;AAQO,SAASC,eAAT,OAIsC;AAAA,MAH3CC,QAG2C,QAH3CA,QAG2C;AAAA,MAF3CC,MAE2C,QAF3CA,MAE2C;AAAA,MAD3CC,UAC2C,QAD3CA,UAC2C;;AAC3C,MAAIA,UAAJ,EAAgB;AACd,WAAO,0BAAU;AAAEF,MAAAA,QAAQ,EAARA,QAAF;AAAYE,MAAAA,UAAU,EAAVA;AAAZ,KAAV,CAAP;AACD;;AAED,MAAID,MAAM,KAAK,SAAf,EAA0B;AACxB,WAAOA,MAAP;AACD;;AACD,MAAIA,MAAM,KAAKL,MAAM,CAACO,KAAtB,EAA6B;AAC3BC,IAAAA,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAAzB,IACER,IAAI,4CACQF,MAAM,CAACO,KADf,8RACoFP,MAAM,CAACW,WAD3F,QADN;AAIA,WAAOX,MAAM,CAACW,WAAd;AACD;;AACD,MACEP,QAAQ,KAAKG,eAAb,KACCF,MAAM,KAAKL,MAAM,CAACY,YAAlB,IAAkCP,MAAM,KAAKL,MAAM,CAACa,UADrD,CADF,EAGE;AACAL,IAAAA,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAAzB,IACER,IAAI,oHAC4BG,MAD5B,gUACiGL,MAAM,CAACW,WADxG,qCAC6HX,MAAM,CAACc,UADpI,SAEF,OAFE,CADN;AAKA,WAAOd,MAAM,CAACW,WAAd;AACD;;AACD,UAAQN,MAAR;AACE,SAAKL,MAAM,CAACe,uBAAZ;AACE,aAAOf,MAAM,CAACY,YAAd;;AACF,SAAKZ,MAAM,CAACgB,sBAAZ;AACE,aAAOhB,MAAM,CAACa,UAAd;;AACF;AACE,aAAOR,MAAP;AANJ;AAQD","sourcesContent":["import { AppearanceSchemeType, AppearanceType } from \"@vkontakte/vk-bridge\";\nimport { PlatformType, VKCOM } from \"../lib/platform\";\nimport { warnOnce } from \"../lib/warnOnce\";\nimport { getScheme } from \"./getScheme\";\n\nexport enum Scheme {\n /**\n * @deprecated будет удалено в 5.0.0\n * версия оставлена для совместимости со старыми версиями клиентов\n */\n DEPRECATED_CLIENT_LIGHT = \"client_light\",\n /**\n * @deprecated будет удалено в 5.0.0\n * версия оставлена для совместимости со старыми версиями клиентов\n */\n DEPRECATED_CLIENT_DARK = \"client_dark\",\n /**\n * @deprecated будет удалено в 5.0.0\n * версия оставлена для совместимости с vkcom, когда там была только одна схема\n */\n VKCOM = \"vkcom\",\n\n BRIGHT_LIGHT = \"bright_light\",\n SPACE_GRAY = \"space_gray\",\n VKCOM_LIGHT = \"vkcom_light\",\n VKCOM_DARK = \"vkcom_dark\",\n}\n\nexport type AppearanceScheme =\n | AppearanceSchemeType\n | Scheme.VKCOM\n | Scheme.VKCOM_DARK\n | Scheme.VKCOM_LIGHT\n | \"inherit\";\n\nexport enum Appearance {\n DARK = \"dark\",\n LIGHT = \"light\",\n}\n\nconst warn = warnOnce(\"scheme\");\n\nexport interface NormalizeSchemeProps {\n platform: PlatformType;\n scheme?: AppearanceScheme;\n appearance?: AppearanceType;\n}\n\nexport function normalizeScheme({\n platform,\n scheme,\n appearance,\n}: NormalizeSchemeProps): Scheme | \"inherit\" {\n if (appearance) {\n return getScheme({ platform, appearance });\n }\n\n if (scheme === \"inherit\") {\n return scheme;\n }\n if (scheme === Scheme.VKCOM) {\n process.env.NODE_ENV === \"development\" &&\n warn(\n `Схема \"${Scheme.VKCOM}\" устарела и будет удалена в v5.0.0. Вместо неё используйте \"${Scheme.VKCOM_LIGHT}\"`\n );\n return Scheme.VKCOM_LIGHT;\n }\n if (\n platform === VKCOM &&\n (scheme === Scheme.BRIGHT_LIGHT || scheme === Scheme.SPACE_GRAY)\n ) {\n process.env.NODE_ENV === \"development\" &&\n warn(\n `Платформа \"vkcom\" и схема \"${scheme}\" несовместимы. С этой платформой можно использовать схемы \"${Scheme.VKCOM_LIGHT}\" или \"${Scheme.VKCOM_DARK}\"`,\n \"error\"\n );\n return Scheme.VKCOM_LIGHT;\n }\n switch (scheme) {\n case Scheme.DEPRECATED_CLIENT_LIGHT:\n return Scheme.BRIGHT_LIGHT;\n case Scheme.DEPRECATED_CLIENT_DARK:\n return Scheme.SPACE_GRAY;\n default:\n return scheme as Scheme;\n }\n}\n"],"file":"scheme.js"}
@@ -0,0 +1,6 @@
1
+ export declare const useBooleanState: (defaultValue?: boolean) => {
2
+ value: boolean;
3
+ setTrue: () => void;
4
+ setFalse: () => void;
5
+ toggle: () => void;
6
+ };
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
4
+
5
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.useBooleanState = void 0;
11
+
12
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
+
14
+ var React = _interopRequireWildcard(require("react"));
15
+
16
+ var useBooleanState = function useBooleanState() {
17
+ var defaultValue = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
18
+
19
+ var _React$useState = React.useState(defaultValue),
20
+ _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
21
+ value = _React$useState2[0],
22
+ setValue = _React$useState2[1];
23
+
24
+ var setTrue = React.useCallback(function () {
25
+ setValue(true);
26
+ }, []);
27
+ var setFalse = React.useCallback(function () {
28
+ setValue(false);
29
+ }, []);
30
+ var toggle = React.useCallback(function () {
31
+ setValue(!value);
32
+ }, [value]);
33
+ return {
34
+ value: value,
35
+ setTrue: setTrue,
36
+ setFalse: setFalse,
37
+ toggle: toggle
38
+ };
39
+ };
40
+
41
+ exports.useBooleanState = useBooleanState;
42
+ //# sourceMappingURL=useBooleanState.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/hooks/useBooleanState.ts"],"names":["useBooleanState","defaultValue","React","useState","value","setValue","setTrue","useCallback","setFalse","toggle"],"mappings":";;;;;;;;;;;;;AAAA;;AAEO,IAAMA,eAAe,GAAG,SAAlBA,eAAkB,GAA0B;AAAA,MAAzBC,YAAyB,uEAAV,KAAU;;AACvD,wBAA0BC,KAAK,CAACC,QAAN,CAAeF,YAAf,CAA1B;AAAA;AAAA,MAAOG,KAAP;AAAA,MAAcC,QAAd;;AAEA,MAAMC,OAAO,GAAGJ,KAAK,CAACK,WAAN,CAAkB,YAAM;AACtCF,IAAAA,QAAQ,CAAC,IAAD,CAAR;AACD,GAFe,EAEb,EAFa,CAAhB;AAIA,MAAMG,QAAQ,GAAGN,KAAK,CAACK,WAAN,CAAkB,YAAM;AACvCF,IAAAA,QAAQ,CAAC,KAAD,CAAR;AACD,GAFgB,EAEd,EAFc,CAAjB;AAIA,MAAMI,MAAM,GAAGP,KAAK,CAACK,WAAN,CAAkB,YAAM;AACrCF,IAAAA,QAAQ,CAAC,CAACD,KAAF,CAAR;AACD,GAFc,EAEZ,CAACA,KAAD,CAFY,CAAf;AAIA,SAAO;AAAEA,IAAAA,KAAK,EAALA,KAAF;AAASE,IAAAA,OAAO,EAAPA,OAAT;AAAkBE,IAAAA,QAAQ,EAARA,QAAlB;AAA4BC,IAAAA,MAAM,EAANA;AAA5B,GAAP;AACD,CAhBM","sourcesContent":["import * as React from \"react\";\n\nexport const useBooleanState = (defaultValue = false) => {\n const [value, setValue] = React.useState(defaultValue);\n\n const setTrue = React.useCallback(() => {\n setValue(true);\n }, []);\n\n const setFalse = React.useCallback(() => {\n setValue(false);\n }, []);\n\n const toggle = React.useCallback(() => {\n setValue(!value);\n }, [value]);\n\n return { value, setTrue, setFalse, toggle };\n};\n"],"file":"useBooleanState.js"}
@@ -0,0 +1,6 @@
1
+ export interface BridgeAdaptivity {
2
+ type: "" | "force_mobile" | "force_mobile_compact" | "adaptive";
3
+ viewportWidth: number;
4
+ viewportHeight: number;
5
+ }
6
+ export declare function useBridgeAdaptivity(): BridgeAdaptivity;
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
4
+
5
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.useBridgeAdaptivity = useBridgeAdaptivity;
11
+
12
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
+
14
+ var React = _interopRequireWildcard(require("react"));
15
+
16
+ var _vkBridge = _interopRequireDefault(require("@vkontakte/vk-bridge"));
17
+
18
+ var _useIsomorphicLayoutEffect = require("../lib/useIsomorphicLayoutEffect");
19
+
20
+ var initialState = {
21
+ type: "",
22
+ viewportWidth: 0,
23
+ viewportHeight: 0
24
+ };
25
+
26
+ function resolveAdaptivity(e) {
27
+ var _e$detail = e.detail,
28
+ type = _e$detail.type,
29
+ data = _e$detail.data;
30
+
31
+ if (type !== "VKWebAppUpdateConfig" || !data) {
32
+ return null;
33
+ }
34
+
35
+ var adaptivity = data.adaptivity,
36
+ viewportWidth = data.viewport_width,
37
+ viewportHeight = data.viewport_height;
38
+ var bridgeAdaptivity = {
39
+ type: "",
40
+ viewportWidth: isFinite(viewportWidth) ? +viewportWidth : 0,
41
+ viewportHeight: isFinite(viewportHeight) ? +viewportHeight : 0
42
+ };
43
+
44
+ switch (adaptivity) {
45
+ case "force_mobile":
46
+ case "force_mobile_compact":
47
+ case "adaptive":
48
+ bridgeAdaptivity.type = adaptivity;
49
+ }
50
+
51
+ return bridgeAdaptivity;
52
+ }
53
+
54
+ _vkBridge.default.subscribe(function (e) {
55
+ var bridgeAdaptivity = resolveAdaptivity(e);
56
+
57
+ if (bridgeAdaptivity) {
58
+ initialState = bridgeAdaptivity;
59
+ }
60
+ });
61
+
62
+ function useBridgeAdaptivity() {
63
+ var _React$useState = React.useState(initialState),
64
+ _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
65
+ bridgeAdaptivity = _React$useState2[0],
66
+ setBridgeAdaptivity = _React$useState2[1];
67
+
68
+ (0, _useIsomorphicLayoutEffect.useIsomorphicLayoutEffect)(function () {
69
+ function bridgeListener(e) {
70
+ var newBridgeAdaptivity = resolveAdaptivity(e);
71
+
72
+ if (newBridgeAdaptivity) {
73
+ setBridgeAdaptivity(newBridgeAdaptivity);
74
+ }
75
+ }
76
+
77
+ _vkBridge.default.subscribe(bridgeListener);
78
+
79
+ return function () {
80
+ _vkBridge.default.unsubscribe(bridgeListener);
81
+ };
82
+ }, []);
83
+ return bridgeAdaptivity;
84
+ }
85
+ //# sourceMappingURL=useBridgeAdaptivity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/hooks/useBridgeAdaptivity.ts"],"names":["initialState","type","viewportWidth","viewportHeight","resolveAdaptivity","e","detail","data","adaptivity","viewport_width","viewport_height","bridgeAdaptivity","isFinite","vkBridge","subscribe","useBridgeAdaptivity","React","useState","setBridgeAdaptivity","bridgeListener","newBridgeAdaptivity","unsubscribe"],"mappings":";;;;;;;;;;;;;AAAA;;AACA;;AACA;;AAiBA,IAAIA,YAA8B,GAAG;AACnCC,EAAAA,IAAI,EAAE,EAD6B;AAEnCC,EAAAA,aAAa,EAAE,CAFoB;AAGnCC,EAAAA,cAAc,EAAE;AAHmB,CAArC;;AAMA,SAASC,iBAAT,CAA2BC,CAA3B,EAAoE;AAClE,kBAAuBA,CAAC,CAACC,MAAzB;AAAA,MAAQL,IAAR,aAAQA,IAAR;AAAA,MAAcM,IAAd,aAAcA,IAAd;;AAEA,MAAIN,IAAI,KAAK,sBAAT,IAAmC,CAACM,IAAxC,EAA8C;AAC5C,WAAO,IAAP;AACD;;AAED,MACEC,UADF,GAIID,IAJJ,CACEC,UADF;AAAA,MAEkBN,aAFlB,GAIIK,IAJJ,CAEEE,cAFF;AAAA,MAGmBN,cAHnB,GAIII,IAJJ,CAGEG,eAHF;AAMA,MAAMC,gBAAkC,GAAG;AACzCV,IAAAA,IAAI,EAAE,EADmC;AAEzCC,IAAAA,aAAa,EAAEU,QAAQ,CAACV,aAAD,CAAR,GAA0B,CAACA,aAA3B,GAA2C,CAFjB;AAGzCC,IAAAA,cAAc,EAAES,QAAQ,CAACT,cAAD,CAAR,GAA2B,CAACA,cAA5B,GAA6C;AAHpB,GAA3C;;AAMA,UAAQK,UAAR;AACE,SAAK,cAAL;AACA,SAAK,sBAAL;AACA,SAAK,UAAL;AACEG,MAAAA,gBAAgB,CAACV,IAAjB,GAAwBO,UAAxB;AAJJ;;AAOA,SAAOG,gBAAP;AACD;;AAEDE,kBAASC,SAAT,CAAmB,UAACT,CAAD,EAAoB;AACrC,MAAMM,gBAAgB,GAAGP,iBAAiB,CAACC,CAAD,CAA1C;;AAEA,MAAIM,gBAAJ,EAAsB;AACpBX,IAAAA,YAAY,GAAGW,gBAAf;AACD;AACF,CAND;;AAQO,SAASI,mBAAT,GAAiD;AACtD,wBACEC,KAAK,CAACC,QAAN,CAAiCjB,YAAjC,CADF;AAAA;AAAA,MAAOW,gBAAP;AAAA,MAAyBO,mBAAzB;;AAGA,4DAA0B,YAAM;AAC9B,aAASC,cAAT,CAAwBd,CAAxB,EAAwC;AACtC,UAAMe,mBAAmB,GAAGhB,iBAAiB,CAACC,CAAD,CAA7C;;AAEA,UAAIe,mBAAJ,EAAyB;AACvBF,QAAAA,mBAAmB,CAACE,mBAAD,CAAnB;AACD;AACF;;AAEDP,sBAASC,SAAT,CAAmBK,cAAnB;;AACA,WAAO,YAAM;AACXN,wBAASQ,WAAT,CAAqBF,cAArB;AACD,KAFD;AAGD,GAbD,EAaG,EAbH;AAeA,SAAOR,gBAAP;AACD","sourcesContent":["import * as React from \"react\";\nimport vkBridge from \"@vkontakte/vk-bridge\";\nimport { useIsomorphicLayoutEffect } from \"../lib/useIsomorphicLayoutEffect\";\n\nexport interface BridgeAdaptivity {\n type: \"\" | \"force_mobile\" | \"force_mobile_compact\" | \"adaptive\";\n viewportWidth: number;\n viewportHeight: number;\n}\n\ninterface BridgeEvent {\n detail: {\n type: string;\n data: {\n [index: string]: any;\n };\n };\n}\n\nlet initialState: BridgeAdaptivity = {\n type: \"\",\n viewportWidth: 0,\n viewportHeight: 0,\n};\n\nfunction resolveAdaptivity(e: BridgeEvent): BridgeAdaptivity | null {\n const { type, data } = e.detail;\n\n if (type !== \"VKWebAppUpdateConfig\" || !data) {\n return null;\n }\n\n const {\n adaptivity,\n viewport_width: viewportWidth,\n viewport_height: viewportHeight,\n } = data;\n\n const bridgeAdaptivity: BridgeAdaptivity = {\n type: \"\",\n viewportWidth: isFinite(viewportWidth) ? +viewportWidth : 0,\n viewportHeight: isFinite(viewportHeight) ? +viewportHeight : 0,\n };\n\n switch (adaptivity) {\n case \"force_mobile\":\n case \"force_mobile_compact\":\n case \"adaptive\":\n bridgeAdaptivity.type = adaptivity;\n }\n\n return bridgeAdaptivity;\n}\n\nvkBridge.subscribe((e: BridgeEvent) => {\n const bridgeAdaptivity = resolveAdaptivity(e);\n\n if (bridgeAdaptivity) {\n initialState = bridgeAdaptivity;\n }\n});\n\nexport function useBridgeAdaptivity(): BridgeAdaptivity {\n const [bridgeAdaptivity, setBridgeAdaptivity] =\n React.useState<BridgeAdaptivity>(initialState);\n\n useIsomorphicLayoutEffect(() => {\n function bridgeListener(e: BridgeEvent) {\n const newBridgeAdaptivity = resolveAdaptivity(e);\n\n if (newBridgeAdaptivity) {\n setBridgeAdaptivity(newBridgeAdaptivity);\n }\n }\n\n vkBridge.subscribe(bridgeListener);\n return () => {\n vkBridge.unsubscribe(bridgeListener);\n };\n }, []);\n\n return bridgeAdaptivity;\n}\n"],"file":"useBridgeAdaptivity.js"}
@@ -0,0 +1,18 @@
1
+ import * as React from "react";
2
+ export interface UseCalendarDependencies {
3
+ value?: Array<Date | null> | Date;
4
+ disablePast?: boolean;
5
+ disableFuture?: boolean;
6
+ shouldDisableDate?(value: Date): boolean;
7
+ }
8
+ export declare function useCalendar({ value, disablePast, disableFuture, shouldDisableDate, }: UseCalendarDependencies): {
9
+ viewDate: Date;
10
+ setViewDate: React.Dispatch<React.SetStateAction<Date>>;
11
+ setPrevMonth: () => void;
12
+ setNextMonth: () => void;
13
+ focusedDay: Date | undefined;
14
+ setFocusedDay: React.Dispatch<React.SetStateAction<Date | undefined>>;
15
+ isDayFocused: (day: Date) => boolean;
16
+ isDayDisabled: (day: Date) => boolean;
17
+ resetSelectedDay: () => void;
18
+ };
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
4
+
5
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.useCalendar = useCalendar;
11
+
12
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
+
14
+ var React = _interopRequireWildcard(require("react"));
15
+
16
+ var _date = require("../lib/date");
17
+
18
+ function useCalendar(_ref) {
19
+ var _ref2;
20
+
21
+ var value = _ref.value,
22
+ disablePast = _ref.disablePast,
23
+ disableFuture = _ref.disableFuture,
24
+ shouldDisableDate = _ref.shouldDisableDate;
25
+
26
+ var _React$useState = React.useState((_ref2 = Array.isArray(value) ? value[0] : value) !== null && _ref2 !== void 0 ? _ref2 : new Date()),
27
+ _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
28
+ viewDate = _React$useState2[0],
29
+ setViewDate = _React$useState2[1];
30
+
31
+ var _React$useState3 = React.useState(),
32
+ _React$useState4 = (0, _slicedToArray2.default)(_React$useState3, 2),
33
+ focusedDay = _React$useState4[0],
34
+ setFocusedDay = _React$useState4[1];
35
+
36
+ var setPrevMonth = React.useCallback(function () {
37
+ return setViewDate((0, _date.subMonths)(viewDate, 1));
38
+ }, [viewDate]);
39
+ var setNextMonth = React.useCallback(function () {
40
+ return setViewDate((0, _date.addMonths)(viewDate, 1));
41
+ }, [viewDate]);
42
+ var isDayFocused = React.useCallback(function (day) {
43
+ return Boolean(focusedDay && (0, _date.isSameDay)(day, focusedDay));
44
+ }, [focusedDay]);
45
+ var isDayDisabled = React.useCallback(function (day) {
46
+ var now = new Date();
47
+ var disabled = false;
48
+
49
+ if (disablePast) {
50
+ disabled = (0, _date.isBefore)((0, _date.endOfDay)(day), now);
51
+ }
52
+
53
+ if (disableFuture) {
54
+ disabled = (0, _date.isAfter)((0, _date.startOfDay)(day), now);
55
+ }
56
+
57
+ if (shouldDisableDate) {
58
+ disabled = shouldDisableDate(day);
59
+ }
60
+
61
+ return disabled;
62
+ }, [disableFuture, disablePast, shouldDisableDate]);
63
+ var resetSelectedDay = React.useCallback(function () {
64
+ setFocusedDay(undefined);
65
+ }, [setFocusedDay]);
66
+ return {
67
+ viewDate: viewDate,
68
+ setViewDate: setViewDate,
69
+ setPrevMonth: setPrevMonth,
70
+ setNextMonth: setNextMonth,
71
+ focusedDay: focusedDay,
72
+ setFocusedDay: setFocusedDay,
73
+ isDayFocused: isDayFocused,
74
+ isDayDisabled: isDayDisabled,
75
+ resetSelectedDay: resetSelectedDay
76
+ };
77
+ }
78
+ //# sourceMappingURL=useCalendar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/hooks/useCalendar.ts"],"names":["useCalendar","value","disablePast","disableFuture","shouldDisableDate","React","useState","Array","isArray","Date","viewDate","setViewDate","focusedDay","setFocusedDay","setPrevMonth","useCallback","setNextMonth","isDayFocused","day","Boolean","isDayDisabled","now","disabled","resetSelectedDay","undefined"],"mappings":";;;;;;;;;;;;;AAAA;;AACA;;AAiBO,SAASA,WAAT,OAKqB;AAAA;;AAAA,MAJ1BC,KAI0B,QAJ1BA,KAI0B;AAAA,MAH1BC,WAG0B,QAH1BA,WAG0B;AAAA,MAF1BC,aAE0B,QAF1BA,aAE0B;AAAA,MAD1BC,iBAC0B,QAD1BA,iBAC0B;;AAC1B,wBAAgCC,KAAK,CAACC,QAAN,UAC7BC,KAAK,CAACC,OAAN,CAAcP,KAAd,IAAuBA,KAAK,CAAC,CAAD,CAA5B,GAAkCA,KADL,yCACe,IAAIQ,IAAJ,EADf,CAAhC;AAAA;AAAA,MAAOC,QAAP;AAAA,MAAiBC,WAAjB;;AAGA,yBAAoCN,KAAK,CAACC,QAAN,EAApC;AAAA;AAAA,MAAOM,UAAP;AAAA,MAAmBC,aAAnB;;AAEA,MAAMC,YAAY,GAAGT,KAAK,CAACU,WAAN,CACnB;AAAA,WAAMJ,WAAW,CAAC,qBAAUD,QAAV,EAAoB,CAApB,CAAD,CAAjB;AAAA,GADmB,EAEnB,CAACA,QAAD,CAFmB,CAArB;AAIA,MAAMM,YAAY,GAAGX,KAAK,CAACU,WAAN,CACnB;AAAA,WAAMJ,WAAW,CAAC,qBAAUD,QAAV,EAAoB,CAApB,CAAD,CAAjB;AAAA,GADmB,EAEnB,CAACA,QAAD,CAFmB,CAArB;AAKA,MAAMO,YAAY,GAAGZ,KAAK,CAACU,WAAN,CACnB,UAACG,GAAD;AAAA,WAAeC,OAAO,CAACP,UAAU,IAAI,qBAAUM,GAAV,EAAeN,UAAf,CAAf,CAAtB;AAAA,GADmB,EAEnB,CAACA,UAAD,CAFmB,CAArB;AAKA,MAAMQ,aAAa,GAAGf,KAAK,CAACU,WAAN,CACpB,UAACG,GAAD,EAAe;AACb,QAAMG,GAAG,GAAG,IAAIZ,IAAJ,EAAZ;AACA,QAAIa,QAAQ,GAAG,KAAf;;AACA,QAAIpB,WAAJ,EAAiB;AACfoB,MAAAA,QAAQ,GAAG,oBAAS,oBAASJ,GAAT,CAAT,EAAwBG,GAAxB,CAAX;AACD;;AACD,QAAIlB,aAAJ,EAAmB;AACjBmB,MAAAA,QAAQ,GAAG,mBAAQ,sBAAWJ,GAAX,CAAR,EAAyBG,GAAzB,CAAX;AACD;;AACD,QAAIjB,iBAAJ,EAAuB;AACrBkB,MAAAA,QAAQ,GAAGlB,iBAAiB,CAACc,GAAD,CAA5B;AACD;;AAED,WAAOI,QAAP;AACD,GAfmB,EAgBpB,CAACnB,aAAD,EAAgBD,WAAhB,EAA6BE,iBAA7B,CAhBoB,CAAtB;AAmBA,MAAMmB,gBAAgB,GAAGlB,KAAK,CAACU,WAAN,CAAkB,YAAM;AAC/CF,IAAAA,aAAa,CAACW,SAAD,CAAb;AACD,GAFwB,EAEtB,CAACX,aAAD,CAFsB,CAAzB;AAIA,SAAO;AACLH,IAAAA,QAAQ,EAARA,QADK;AAELC,IAAAA,WAAW,EAAXA,WAFK;AAGLG,IAAAA,YAAY,EAAZA,YAHK;AAILE,IAAAA,YAAY,EAAZA,YAJK;AAKLJ,IAAAA,UAAU,EAAVA,UALK;AAMLC,IAAAA,aAAa,EAAbA,aANK;AAOLI,IAAAA,YAAY,EAAZA,YAPK;AAQLG,IAAAA,aAAa,EAAbA,aARK;AASLG,IAAAA,gBAAgB,EAAhBA;AATK,GAAP;AAWD","sourcesContent":["import * as React from \"react\";\nimport {\n subMonths,\n addMonths,\n isSameDay,\n isBefore,\n endOfDay,\n isAfter,\n startOfDay,\n} from \"../lib/date\";\n\nexport interface UseCalendarDependencies {\n value?: Array<Date | null> | Date;\n disablePast?: boolean;\n disableFuture?: boolean;\n shouldDisableDate?(value: Date): boolean;\n}\n\nexport function useCalendar({\n value,\n disablePast,\n disableFuture,\n shouldDisableDate,\n}: UseCalendarDependencies) {\n const [viewDate, setViewDate] = React.useState(\n (Array.isArray(value) ? value[0] : value) ?? new Date()\n );\n const [focusedDay, setFocusedDay] = React.useState<Date>();\n\n const setPrevMonth = React.useCallback(\n () => setViewDate(subMonths(viewDate, 1)),\n [viewDate]\n );\n const setNextMonth = React.useCallback(\n () => setViewDate(addMonths(viewDate, 1)),\n [viewDate]\n );\n\n const isDayFocused = React.useCallback(\n (day: Date) => Boolean(focusedDay && isSameDay(day, focusedDay)),\n [focusedDay]\n );\n\n const isDayDisabled = React.useCallback(\n (day: Date) => {\n const now = new Date();\n let disabled = false;\n if (disablePast) {\n disabled = isBefore(endOfDay(day), now);\n }\n if (disableFuture) {\n disabled = isAfter(startOfDay(day), now);\n }\n if (shouldDisableDate) {\n disabled = shouldDisableDate(day);\n }\n\n return disabled;\n },\n [disableFuture, disablePast, shouldDisableDate]\n );\n\n const resetSelectedDay = React.useCallback(() => {\n setFocusedDay(undefined);\n }, [setFocusedDay]);\n\n return {\n viewDate,\n setViewDate,\n setPrevMonth,\n setNextMonth,\n focusedDay,\n setFocusedDay,\n isDayFocused,\n isDayDisabled,\n resetSelectedDay,\n };\n}\n"],"file":"useCalendar.js"}
@@ -0,0 +1,30 @@
1
+ import * as React from "react";
2
+ export interface UseDateInputDependencies<T, D> {
3
+ maxElement: number;
4
+ refs: Array<React.RefObject<T>>;
5
+ autoFocus?: boolean;
6
+ disabled?: boolean;
7
+ value?: D;
8
+ elementsConfig(index: number): {
9
+ length: number;
10
+ min: number;
11
+ max: number;
12
+ };
13
+ onInternalValueChange(value: string[]): void;
14
+ getInternalValue(value?: D | undefined): string[];
15
+ onChange?(value?: D | undefined): void;
16
+ }
17
+ export declare function useDateInput<T extends HTMLElement, D>({ maxElement, refs, autoFocus, disabled, elementsConfig, onChange, onInternalValueChange, getInternalValue, value, }: UseDateInputDependencies<T, D>): {
18
+ rootRef: React.RefObject<HTMLDivElement>;
19
+ calendarRef: React.RefObject<HTMLDivElement>;
20
+ open: boolean;
21
+ openCalendar: () => void;
22
+ closeCalendar: () => void;
23
+ internalValue: string[];
24
+ focusedElement: number | null;
25
+ setFocusedElement: React.Dispatch<React.SetStateAction<number | null>>;
26
+ handleKeyDown: (e: React.KeyboardEvent<HTMLSpanElement>) => void;
27
+ clear: () => void;
28
+ handleFieldEnter: () => void;
29
+ removeFocusFromField: () => void;
30
+ };
@@ -0,0 +1,180 @@
1
+ "use strict";
2
+
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
4
+
5
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.useDateInput = useDateInput;
11
+
12
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
+
14
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
+
16
+ var React = _interopRequireWildcard(require("react"));
17
+
18
+ var _useBooleanState2 = require("./useBooleanState");
19
+
20
+ var _useGlobalEventListener = require("./useGlobalEventListener");
21
+
22
+ var _dom = require("../lib/dom");
23
+
24
+ function useDateInput(_ref) {
25
+ var maxElement = _ref.maxElement,
26
+ refs = _ref.refs,
27
+ autoFocus = _ref.autoFocus,
28
+ disabled = _ref.disabled,
29
+ elementsConfig = _ref.elementsConfig,
30
+ onChange = _ref.onChange,
31
+ onInternalValueChange = _ref.onInternalValueChange,
32
+ getInternalValue = _ref.getInternalValue,
33
+ value = _ref.value;
34
+
35
+ var _useDOM = (0, _dom.useDOM)(),
36
+ document = _useDOM.document;
37
+
38
+ var _useBooleanState = (0, _useBooleanState2.useBooleanState)(false),
39
+ open = _useBooleanState.value,
40
+ openCalendar = _useBooleanState.setTrue,
41
+ closeCalendar = _useBooleanState.setFalse;
42
+
43
+ var rootRef = React.useRef(null);
44
+ var calendarRef = React.useRef(null);
45
+
46
+ var _React$useState = React.useState([]),
47
+ _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
48
+ internalValue = _React$useState2[0],
49
+ setInternalValue = _React$useState2[1];
50
+
51
+ var _React$useState3 = React.useState(null),
52
+ _React$useState4 = (0, _slicedToArray2.default)(_React$useState3, 2),
53
+ focusedElement = _React$useState4[0],
54
+ setFocusedElement = _React$useState4[1];
55
+
56
+ var _useDOM2 = (0, _dom.useDOM)(),
57
+ window = _useDOM2.window;
58
+
59
+ var removeFocusFromField = React.useCallback(function () {
60
+ if (open) {
61
+ var _getSelection;
62
+
63
+ setFocusedElement(null);
64
+ closeCalendar();
65
+ (_getSelection = window.getSelection()) === null || _getSelection === void 0 ? void 0 : _getSelection.removeAllRanges();
66
+ setInternalValue(getInternalValue(value));
67
+ }
68
+ }, [closeCalendar, getInternalValue, open, value, window]);
69
+ var handleClickOutside = React.useCallback(function (e) {
70
+ var _rootRef$current, _calendarRef$current;
71
+
72
+ if (!((_rootRef$current = rootRef.current) !== null && _rootRef$current !== void 0 && _rootRef$current.contains(e.target)) && !((_calendarRef$current = calendarRef.current) !== null && _calendarRef$current !== void 0 && _calendarRef$current.contains(e.target))) {
73
+ removeFocusFromField();
74
+ }
75
+ }, [removeFocusFromField]);
76
+ var selectFirst = React.useCallback(function () {
77
+ setFocusedElement(0);
78
+ }, []);
79
+ (0, _useGlobalEventListener.useGlobalEventListener)(document, "click", handleClickOutside, {
80
+ capture: true
81
+ });
82
+ React.useEffect(function () {
83
+ setInternalValue(getInternalValue(value));
84
+ }, [getInternalValue, value]);
85
+ React.useEffect(function () {
86
+ if (autoFocus) {
87
+ selectFirst();
88
+ }
89
+ }, [autoFocus, selectFirst]);
90
+ React.useEffect(function () {
91
+ if (disabled || focusedElement === null) {
92
+ return;
93
+ }
94
+
95
+ var range = window.document.createRange();
96
+ var element = refs[focusedElement].current;
97
+
98
+ if (element) {
99
+ element.focus();
100
+ openCalendar();
101
+ range.selectNodeContents(element);
102
+ var selection = window.getSelection();
103
+ selection === null || selection === void 0 ? void 0 : selection.removeAllRanges();
104
+ selection === null || selection === void 0 ? void 0 : selection.addRange(range);
105
+ }
106
+ }, [disabled, focusedElement, openCalendar, refs, window]);
107
+ var clear = React.useCallback(function () {
108
+ onChange === null || onChange === void 0 ? void 0 : onChange(undefined);
109
+ selectFirst();
110
+ }, [onChange, selectFirst]);
111
+ var handleFieldEnter = React.useCallback(function () {
112
+ if (!open) {
113
+ selectFirst();
114
+ }
115
+ }, [open, selectFirst]);
116
+ var handleKeyDown = React.useCallback(function (e) {
117
+ if (focusedElement === null) {
118
+ return;
119
+ }
120
+
121
+ var _value = (0, _toConsumableArray2.default)(internalValue);
122
+
123
+ var config = elementsConfig(focusedElement);
124
+
125
+ if (/^\d+$/.test(e.key)) {
126
+ if (_value[focusedElement].length >= config.length) {
127
+ _value[focusedElement] = e.key;
128
+ } else {
129
+ _value[focusedElement] += e.key;
130
+
131
+ if (_value[focusedElement].length >= config.length && focusedElement < maxElement) {
132
+ setFocusedElement(focusedElement + 1);
133
+ }
134
+ }
135
+ } else if (e.key === "Backspace") {
136
+ if (!_value[focusedElement]) {
137
+ setFocusedElement(focusedElement <= 0 ? maxElement : focusedElement - 1);
138
+ } else {
139
+ _value[focusedElement] = _value[focusedElement].slice(0, -1);
140
+ }
141
+ } else if (e.key === "ArrowDown" || e.key === "Down") {
142
+ var currentValue = Number(_value[focusedElement]);
143
+ _value[focusedElement] = String(currentValue <= config.min ? config.max : currentValue - 1).padStart(config.length, "0");
144
+ } else if (e.key === "ArrowUp" || e.key === "Up") {
145
+ var _currentValue = Number(_value[focusedElement]);
146
+
147
+ _value[focusedElement] = String(_currentValue >= config.max ? config.min : _currentValue + 1).padStart(config.length, "0");
148
+ } else if (e.key === "Enter" || e.key === "Tab" && focusedElement === maxElement || e.key === "Tab" && e.shiftKey && focusedElement === 0) {
149
+ removeFocusFromField();
150
+ return;
151
+ } else if (e.key === "ArrowLeft" || e.key === "Left" || e.key === "Tab" && e.shiftKey) {
152
+ setFocusedElement(focusedElement <= 0 ? maxElement : focusedElement - 1);
153
+ } else if (e.key === "ArrowRight" || e.key === "Right" || e.key === "Tab") {
154
+ setFocusedElement(focusedElement >= maxElement ? 0 : focusedElement + 1);
155
+ } else if (e.key === "Delete" || e.key === "Del") {
156
+ _value[focusedElement] = "";
157
+ } else {
158
+ return;
159
+ }
160
+
161
+ e.preventDefault();
162
+ setInternalValue(_value);
163
+ onInternalValueChange(_value);
164
+ }, [elementsConfig, focusedElement, internalValue, maxElement, onInternalValueChange, removeFocusFromField]);
165
+ return {
166
+ rootRef: rootRef,
167
+ calendarRef: calendarRef,
168
+ open: open,
169
+ openCalendar: openCalendar,
170
+ closeCalendar: closeCalendar,
171
+ internalValue: internalValue,
172
+ focusedElement: focusedElement,
173
+ setFocusedElement: setFocusedElement,
174
+ handleKeyDown: handleKeyDown,
175
+ clear: clear,
176
+ handleFieldEnter: handleFieldEnter,
177
+ removeFocusFromField: removeFocusFromField
178
+ };
179
+ }
180
+ //# sourceMappingURL=useDateInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/hooks/useDateInput.ts"],"names":["useDateInput","maxElement","refs","autoFocus","disabled","elementsConfig","onChange","onInternalValueChange","getInternalValue","value","document","open","openCalendar","setTrue","closeCalendar","setFalse","rootRef","React","useRef","calendarRef","useState","internalValue","setInternalValue","focusedElement","setFocusedElement","window","removeFocusFromField","useCallback","getSelection","removeAllRanges","handleClickOutside","e","current","contains","target","selectFirst","capture","useEffect","range","createRange","element","focus","selectNodeContents","selection","addRange","clear","undefined","handleFieldEnter","handleKeyDown","_value","config","test","key","length","slice","currentValue","Number","String","min","max","padStart","shiftKey","preventDefault"],"mappings":";;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AAkBO,SAASA,YAAT,OAU4B;AAAA,MATjCC,UASiC,QATjCA,UASiC;AAAA,MARjCC,IAQiC,QARjCA,IAQiC;AAAA,MAPjCC,SAOiC,QAPjCA,SAOiC;AAAA,MANjCC,QAMiC,QANjCA,QAMiC;AAAA,MALjCC,cAKiC,QALjCA,cAKiC;AAAA,MAJjCC,QAIiC,QAJjCA,QAIiC;AAAA,MAHjCC,qBAGiC,QAHjCA,qBAGiC;AAAA,MAFjCC,gBAEiC,QAFjCA,gBAEiC;AAAA,MADjCC,KACiC,QADjCA,KACiC;;AACjC,gBAAqB,kBAArB;AAAA,MAAQC,QAAR,WAAQA,QAAR;;AACA,yBAII,uCAAgB,KAAhB,CAJJ;AAAA,MACSC,IADT,oBACEF,KADF;AAAA,MAEWG,YAFX,oBAEEC,OAFF;AAAA,MAGYC,aAHZ,oBAGEC,QAHF;;AAKA,MAAMC,OAAO,GAAGC,KAAK,CAACC,MAAN,CAA6B,IAA7B,CAAhB;AACA,MAAMC,WAAW,GAAGF,KAAK,CAACC,MAAN,CAA6B,IAA7B,CAApB;;AACA,wBAA0CD,KAAK,CAACG,QAAN,CAAyB,EAAzB,CAA1C;AAAA;AAAA,MAAOC,aAAP;AAAA,MAAsBC,gBAAtB;;AACA,yBAA4CL,KAAK,CAACG,QAAN,CAC1C,IAD0C,CAA5C;AAAA;AAAA,MAAOG,cAAP;AAAA,MAAuBC,iBAAvB;;AAGA,iBAAmB,kBAAnB;AAAA,MAAQC,MAAR,YAAQA,MAAR;;AAEA,MAAMC,oBAAoB,GAAGT,KAAK,CAACU,WAAN,CAAkB,YAAM;AACnD,QAAIhB,IAAJ,EAAU;AAAA;;AACRa,MAAAA,iBAAiB,CAAC,IAAD,CAAjB;AACAV,MAAAA,aAAa;AACb,uBAAAW,MAAM,CAAEG,YAAR,kEAAwBC,eAAxB;AACAP,MAAAA,gBAAgB,CAACd,gBAAgB,CAACC,KAAD,CAAjB,CAAhB;AACD;AACF,GAP4B,EAO1B,CAACK,aAAD,EAAgBN,gBAAhB,EAAkCG,IAAlC,EAAwCF,KAAxC,EAA+CgB,MAA/C,CAP0B,CAA7B;AASA,MAAMK,kBAAkB,GAAGb,KAAK,CAACU,WAAN,CACzB,UAACI,CAAD,EAAmB;AAAA;;AACjB,QACE,sBAACf,OAAO,CAACgB,OAAT,6CAAC,iBAAiBC,QAAjB,CAA0BF,CAAC,CAACG,MAA5B,CAAD,KACA,0BAACf,WAAW,CAACa,OAAb,iDAAC,qBAAqBC,QAArB,CAA8BF,CAAC,CAACG,MAAhC,CAAD,CAFF,EAGE;AACAR,MAAAA,oBAAoB;AACrB;AACF,GARwB,EASzB,CAACA,oBAAD,CATyB,CAA3B;AAYA,MAAMS,WAAW,GAAGlB,KAAK,CAACU,WAAN,CAAkB,YAAM;AAC1CH,IAAAA,iBAAiB,CAAC,CAAD,CAAjB;AACD,GAFmB,EAEjB,EAFiB,CAApB;AAIA,sDAAuBd,QAAvB,EAAiC,OAAjC,EAA0CoB,kBAA1C,EAA8D;AAC5DM,IAAAA,OAAO,EAAE;AADmD,GAA9D;AAIAnB,EAAAA,KAAK,CAACoB,SAAN,CAAgB,YAAM;AACpBf,IAAAA,gBAAgB,CAACd,gBAAgB,CAACC,KAAD,CAAjB,CAAhB;AACD,GAFD,EAEG,CAACD,gBAAD,EAAmBC,KAAnB,CAFH;AAIAQ,EAAAA,KAAK,CAACoB,SAAN,CAAgB,YAAM;AACpB,QAAIlC,SAAJ,EAAe;AACbgC,MAAAA,WAAW;AACZ;AACF,GAJD,EAIG,CAAChC,SAAD,EAAYgC,WAAZ,CAJH;AAMAlB,EAAAA,KAAK,CAACoB,SAAN,CAAgB,YAAM;AACpB,QAAIjC,QAAQ,IAAImB,cAAc,KAAK,IAAnC,EAAyC;AACvC;AACD;;AAED,QAAMe,KAAK,GAAGb,MAAM,CAAEf,QAAR,CAAiB6B,WAAjB,EAAd;AAEA,QAAIC,OAAO,GAAGtC,IAAI,CAACqB,cAAD,CAAJ,CAAqBS,OAAnC;;AAEA,QAAIQ,OAAJ,EAAa;AACXA,MAAAA,OAAO,CAACC,KAAR;AACA7B,MAAAA,YAAY;AACZ0B,MAAAA,KAAK,CAACI,kBAAN,CAAyBF,OAAzB;AAEA,UAAMG,SAAS,GAAGlB,MAAM,CAAEG,YAAR,EAAlB;AACAe,MAAAA,SAAS,SAAT,IAAAA,SAAS,WAAT,YAAAA,SAAS,CAAEd,eAAX;AACAc,MAAAA,SAAS,SAAT,IAAAA,SAAS,WAAT,YAAAA,SAAS,CAAEC,QAAX,CAAoBN,KAApB;AACD;AACF,GAlBD,EAkBG,CAAClC,QAAD,EAAWmB,cAAX,EAA2BX,YAA3B,EAAyCV,IAAzC,EAA+CuB,MAA/C,CAlBH;AAoBA,MAAMoB,KAAK,GAAG5B,KAAK,CAACU,WAAN,CAAkB,YAAM;AACpCrB,IAAAA,QAAQ,SAAR,IAAAA,QAAQ,WAAR,YAAAA,QAAQ,CAAGwC,SAAH,CAAR;AACAX,IAAAA,WAAW;AACZ,GAHa,EAGX,CAAC7B,QAAD,EAAW6B,WAAX,CAHW,CAAd;AAKA,MAAMY,gBAAgB,GAAG9B,KAAK,CAACU,WAAN,CAAkB,YAAM;AAC/C,QAAI,CAAChB,IAAL,EAAW;AACTwB,MAAAA,WAAW;AACZ;AACF,GAJwB,EAItB,CAACxB,IAAD,EAAOwB,WAAP,CAJsB,CAAzB;AAMA,MAAMa,aAAa,GAAG/B,KAAK,CAACU,WAAN,CACpB,UAACI,CAAD,EAA6C;AAC3C,QAAIR,cAAc,KAAK,IAAvB,EAA6B;AAC3B;AACD;;AAED,QAAM0B,MAAM,oCAAO5B,aAAP,CAAZ;;AACA,QAAM6B,MAAM,GAAG7C,cAAc,CAACkB,cAAD,CAA7B;;AAEA,QAAI,QAAQ4B,IAAR,CAAapB,CAAC,CAACqB,GAAf,CAAJ,EAAyB;AACvB,UAAIH,MAAM,CAAC1B,cAAD,CAAN,CAAuB8B,MAAvB,IAAiCH,MAAM,CAACG,MAA5C,EAAoD;AAClDJ,QAAAA,MAAM,CAAC1B,cAAD,CAAN,GAAyBQ,CAAC,CAACqB,GAA3B;AACD,OAFD,MAEO;AACLH,QAAAA,MAAM,CAAC1B,cAAD,CAAN,IAA0BQ,CAAC,CAACqB,GAA5B;;AACA,YACEH,MAAM,CAAC1B,cAAD,CAAN,CAAuB8B,MAAvB,IAAiCH,MAAM,CAACG,MAAxC,IACA9B,cAAc,GAAGtB,UAFnB,EAGE;AACAuB,UAAAA,iBAAiB,CAACD,cAAc,GAAG,CAAlB,CAAjB;AACD;AACF;AACF,KAZD,MAYO,IAAIQ,CAAC,CAACqB,GAAF,KAAU,WAAd,EAA2B;AAChC,UAAI,CAACH,MAAM,CAAC1B,cAAD,CAAX,EAA6B;AAC3BC,QAAAA,iBAAiB,CACfD,cAAc,IAAI,CAAlB,GAAsBtB,UAAtB,GAAmCsB,cAAc,GAAG,CADrC,CAAjB;AAGD,OAJD,MAIO;AACL0B,QAAAA,MAAM,CAAC1B,cAAD,CAAN,GAAyB0B,MAAM,CAAC1B,cAAD,CAAN,CAAuB+B,KAAvB,CAA6B,CAA7B,EAAgC,CAAC,CAAjC,CAAzB;AACD;AACF,KARM,MAQA,IAAIvB,CAAC,CAACqB,GAAF,KAAU,WAAV,IAAyBrB,CAAC,CAACqB,GAAF,KAAU,MAAvC,EAA+C;AACpD,UAAIG,YAAY,GAAGC,MAAM,CAACP,MAAM,CAAC1B,cAAD,CAAP,CAAzB;AACA0B,MAAAA,MAAM,CAAC1B,cAAD,CAAN,GAAyBkC,MAAM,CAC7BF,YAAY,IAAIL,MAAM,CAACQ,GAAvB,GAA6BR,MAAM,CAACS,GAApC,GAA0CJ,YAAY,GAAG,CAD5B,CAAN,CAEvBK,QAFuB,CAEdV,MAAM,CAACG,MAFO,EAEC,GAFD,CAAzB;AAGD,KALM,MAKA,IAAItB,CAAC,CAACqB,GAAF,KAAU,SAAV,IAAuBrB,CAAC,CAACqB,GAAF,KAAU,IAArC,EAA2C;AAChD,UAAIG,aAAY,GAAGC,MAAM,CAACP,MAAM,CAAC1B,cAAD,CAAP,CAAzB;;AACA0B,MAAAA,MAAM,CAAC1B,cAAD,CAAN,GAAyBkC,MAAM,CAC7BF,aAAY,IAAIL,MAAM,CAACS,GAAvB,GAA6BT,MAAM,CAACQ,GAApC,GAA0CH,aAAY,GAAG,CAD5B,CAAN,CAEvBK,QAFuB,CAEdV,MAAM,CAACG,MAFO,EAEC,GAFD,CAAzB;AAGD,KALM,MAKA,IACLtB,CAAC,CAACqB,GAAF,KAAU,OAAV,IACCrB,CAAC,CAACqB,GAAF,KAAU,KAAV,IAAmB7B,cAAc,KAAKtB,UADvC,IAEC8B,CAAC,CAACqB,GAAF,KAAU,KAAV,IAAmBrB,CAAC,CAAC8B,QAArB,IAAiCtC,cAAc,KAAK,CAHhD,EAIL;AACAG,MAAAA,oBAAoB;AACpB;AACD,KAPM,MAOA,IACLK,CAAC,CAACqB,GAAF,KAAU,WAAV,IACArB,CAAC,CAACqB,GAAF,KAAU,MADV,IAECrB,CAAC,CAACqB,GAAF,KAAU,KAAV,IAAmBrB,CAAC,CAAC8B,QAHjB,EAIL;AACArC,MAAAA,iBAAiB,CACfD,cAAc,IAAI,CAAlB,GAAsBtB,UAAtB,GAAmCsB,cAAc,GAAG,CADrC,CAAjB;AAGD,KARM,MAQA,IACLQ,CAAC,CAACqB,GAAF,KAAU,YAAV,IACArB,CAAC,CAACqB,GAAF,KAAU,OADV,IAEArB,CAAC,CAACqB,GAAF,KAAU,KAHL,EAIL;AACA5B,MAAAA,iBAAiB,CACfD,cAAc,IAAItB,UAAlB,GAA+B,CAA/B,GAAmCsB,cAAc,GAAG,CADrC,CAAjB;AAGD,KARM,MAQA,IAAIQ,CAAC,CAACqB,GAAF,KAAU,QAAV,IAAsBrB,CAAC,CAACqB,GAAF,KAAU,KAApC,EAA2C;AAChDH,MAAAA,MAAM,CAAC1B,cAAD,CAAN,GAAyB,EAAzB;AACD,KAFM,MAEA;AACL;AACD;;AAEDQ,IAAAA,CAAC,CAAC+B,cAAF;AACAxC,IAAAA,gBAAgB,CAAC2B,MAAD,CAAhB;AACA1C,IAAAA,qBAAqB,CAAC0C,MAAD,CAArB;AACD,GAvEmB,EAwEpB,CACE5C,cADF,EAEEkB,cAFF,EAGEF,aAHF,EAIEpB,UAJF,EAKEM,qBALF,EAMEmB,oBANF,CAxEoB,CAAtB;AAkFA,SAAO;AACLV,IAAAA,OAAO,EAAPA,OADK;AAELG,IAAAA,WAAW,EAAXA,WAFK;AAGLR,IAAAA,IAAI,EAAJA,IAHK;AAILC,IAAAA,YAAY,EAAZA,YAJK;AAKLE,IAAAA,aAAa,EAAbA,aALK;AAMLO,IAAAA,aAAa,EAAbA,aANK;AAOLE,IAAAA,cAAc,EAAdA,cAPK;AAQLC,IAAAA,iBAAiB,EAAjBA,iBARK;AASLwB,IAAAA,aAAa,EAAbA,aATK;AAULH,IAAAA,KAAK,EAALA,KAVK;AAWLE,IAAAA,gBAAgB,EAAhBA,gBAXK;AAYLrB,IAAAA,oBAAoB,EAApBA;AAZK,GAAP;AAcD","sourcesContent":["import * as React from \"react\";\nimport { useBooleanState } from \"./useBooleanState\";\nimport { useGlobalEventListener } from \"./useGlobalEventListener\";\nimport { useDOM } from \"../lib/dom\";\n\nexport interface UseDateInputDependencies<T, D> {\n maxElement: number;\n refs: Array<React.RefObject<T>>;\n autoFocus?: boolean;\n disabled?: boolean;\n value?: D;\n elementsConfig(index: number): {\n length: number;\n min: number;\n max: number;\n };\n onInternalValueChange(value: string[]): void;\n getInternalValue(value?: D | undefined): string[];\n onChange?(value?: D | undefined): void;\n}\n\nexport function useDateInput<T extends HTMLElement, D>({\n maxElement,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange,\n onInternalValueChange,\n getInternalValue,\n value,\n}: UseDateInputDependencies<T, D>) {\n const { document } = useDOM();\n const {\n value: open,\n setTrue: openCalendar,\n setFalse: closeCalendar,\n } = useBooleanState(false);\n const rootRef = React.useRef<HTMLDivElement>(null);\n const calendarRef = React.useRef<HTMLDivElement>(null);\n const [internalValue, setInternalValue] = React.useState<string[]>([]);\n const [focusedElement, setFocusedElement] = React.useState<number | null>(\n null\n );\n const { window } = useDOM();\n\n const removeFocusFromField = React.useCallback(() => {\n if (open) {\n setFocusedElement(null);\n closeCalendar();\n window!.getSelection()?.removeAllRanges();\n setInternalValue(getInternalValue(value));\n }\n }, [closeCalendar, getInternalValue, open, value, window]);\n\n const handleClickOutside = React.useCallback(\n (e: MouseEvent) => {\n if (\n !rootRef.current?.contains(e.target as Node | null) &&\n !calendarRef.current?.contains(e.target as Node | null)\n ) {\n removeFocusFromField();\n }\n },\n [removeFocusFromField]\n );\n\n const selectFirst = React.useCallback(() => {\n setFocusedElement(0);\n }, []);\n\n useGlobalEventListener(document, \"click\", handleClickOutside, {\n capture: true,\n });\n\n React.useEffect(() => {\n setInternalValue(getInternalValue(value));\n }, [getInternalValue, value]);\n\n React.useEffect(() => {\n if (autoFocus) {\n selectFirst();\n }\n }, [autoFocus, selectFirst]);\n\n React.useEffect(() => {\n if (disabled || focusedElement === null) {\n return;\n }\n\n const range = window!.document.createRange();\n\n let element = refs[focusedElement].current;\n\n if (element) {\n element.focus();\n openCalendar();\n range.selectNodeContents(element as Node);\n\n const selection = window!.getSelection();\n selection?.removeAllRanges();\n selection?.addRange(range);\n }\n }, [disabled, focusedElement, openCalendar, refs, window]);\n\n const clear = React.useCallback(() => {\n onChange?.(undefined);\n selectFirst();\n }, [onChange, selectFirst]);\n\n const handleFieldEnter = React.useCallback(() => {\n if (!open) {\n selectFirst();\n }\n }, [open, selectFirst]);\n\n const handleKeyDown = React.useCallback(\n (e: React.KeyboardEvent<HTMLSpanElement>) => {\n if (focusedElement === null) {\n return;\n }\n\n const _value = [...internalValue];\n const config = elementsConfig(focusedElement);\n\n if (/^\\d+$/.test(e.key)) {\n if (_value[focusedElement].length >= config.length) {\n _value[focusedElement] = e.key;\n } else {\n _value[focusedElement] += e.key;\n if (\n _value[focusedElement].length >= config.length &&\n focusedElement < maxElement\n ) {\n setFocusedElement(focusedElement + 1);\n }\n }\n } else if (e.key === \"Backspace\") {\n if (!_value[focusedElement]) {\n setFocusedElement(\n focusedElement <= 0 ? maxElement : focusedElement - 1\n );\n } else {\n _value[focusedElement] = _value[focusedElement].slice(0, -1);\n }\n } else if (e.key === \"ArrowDown\" || e.key === \"Down\") {\n let currentValue = Number(_value[focusedElement]);\n _value[focusedElement] = String(\n currentValue <= config.min ? config.max : currentValue - 1\n ).padStart(config.length, \"0\");\n } else if (e.key === \"ArrowUp\" || e.key === \"Up\") {\n let currentValue = Number(_value[focusedElement]);\n _value[focusedElement] = String(\n currentValue >= config.max ? config.min : currentValue + 1\n ).padStart(config.length, \"0\");\n } else if (\n e.key === \"Enter\" ||\n (e.key === \"Tab\" && focusedElement === maxElement) ||\n (e.key === \"Tab\" && e.shiftKey && focusedElement === 0)\n ) {\n removeFocusFromField();\n return;\n } else if (\n e.key === \"ArrowLeft\" ||\n e.key === \"Left\" ||\n (e.key === \"Tab\" && e.shiftKey)\n ) {\n setFocusedElement(\n focusedElement <= 0 ? maxElement : focusedElement - 1\n );\n } else if (\n e.key === \"ArrowRight\" ||\n e.key === \"Right\" ||\n e.key === \"Tab\"\n ) {\n setFocusedElement(\n focusedElement >= maxElement ? 0 : focusedElement + 1\n );\n } else if (e.key === \"Delete\" || e.key === \"Del\") {\n _value[focusedElement] = \"\";\n } else {\n return;\n }\n\n e.preventDefault();\n setInternalValue(_value);\n onInternalValueChange(_value);\n },\n [\n elementsConfig,\n focusedElement,\n internalValue,\n maxElement,\n onInternalValueChange,\n removeFocusFromField,\n ]\n );\n\n return {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n closeCalendar,\n internalValue,\n focusedElement,\n setFocusedElement,\n handleKeyDown,\n clear,\n handleFieldEnter,\n removeFocusFromField,\n };\n}\n"],"file":"useDateInput.js"}
@@ -3,7 +3,7 @@ interface SoftwareKeyboardState {
3
3
  isPrecise: boolean;
4
4
  }
5
5
  /**
6
- Проверяет, закрыла ли клавиатура часть экрана, 24% подошло к большиству устройств
6
+ Проверяет, закрыла ли клавиатура часть экрана, 24% подошло к большинству устройств
7
7
  Работает на iOS и Android, где софт-клавиатура ресайзит viewport в браузерах
8
8
  */
9
9
  export declare function getPreciseKeyboardState(window: any): boolean;
@@ -19,7 +19,7 @@ var _dom = require("../lib/dom");
19
19
  var _useGlobalEventListener = require("./useGlobalEventListener");
20
20
 
21
21
  /**
22
- Проверяет, закрыла ли клавиатура часть экрана, 24% подошло к большиству устройств
22
+ Проверяет, закрыла ли клавиатура часть экрана, 24% подошло к большинству устройств
23
23
  Работает на iOS и Android, где софт-клавиатура ресайзит viewport в браузерах
24
24
  */
25
25
  function getPreciseKeyboardState(window) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/hooks/useKeyboard.ts"],"names":["getPreciseKeyboardState","window","innerHeight","availHeight","screen","coveredViewportPercentage","Math","round","eventOptions","passive","capture","useKeyboard","document","React","useState","isOpened","setIsOpened","isPrecise","setIsPrecise","transitionalTimeout","useRef","onFocus","useCallback","event","current","clearTimeout","type","activeElement","tagName","setTimeout","useEffect"],"mappings":";;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AAOA;AACA;AACA;AACA;AACO,SAASA,uBAAT,CAAiCC,MAAjC,EAAuD;AAC5D,MACEC,WADF,GAGID,MAHJ,CACEC,WADF;AAAA,MAEYC,WAFZ,GAGIF,MAHJ,CAEEG,MAFF,CAEYD,WAFZ;AAKA,MAAME,yBAAyB,GAAGC,IAAI,CAACC,KAAL,CAChC,CAAC,IAAIL,WAAW,GAAGC,WAAnB,IAAkC,GADF,CAAlC;AAGA,SAAOE,yBAAyB,GAAG,EAAnC;AACD;;AAED,IAAMG,YAAY,GAAG;AACnBC,EAAAA,OAAO,EAAE,IADU;AAEnBC,EAAAA,OAAO,EAAE;AAFU,CAArB;;AAKO,SAASC,WAAT,GAA8C;AAAA;;AACnD,gBAA6B,kBAA7B;AAAA,MAAQV,MAAR,WAAQA,MAAR;AAAA,MAAgBW,QAAhB,WAAgBA,QAAhB;;AAEA,wBAAgCC,KAAK,CAACC,QAAN,CAAe,KAAf,CAAhC;AAAA;AAAA,MAAOC,QAAP;AAAA,MAAiBC,WAAjB;;AACA,yBAAkCH,KAAK,CAACC,QAAN,CAAe,KAAf,CAAlC;AAAA;AAAA,MAAOG,SAAP;AAAA,MAAkBC,YAAlB;;AAEA,MAAMC,mBAAmB,GAAGN,KAAK,CAACO,MAAN,CAElB,IAFkB,CAA5B;AAIA,MAAMC,OAAO,GAAGR,KAAK,CAACS,WAAN,CACd,UAACC,KAAD,EAA8B;AAAA;;AAC5B,QAAIJ,mBAAmB,CAACK,OAAxB,EAAiC;AAC/BC,MAAAA,YAAY,CAACN,mBAAmB,CAACK,OAArB,CAAZ;AACD;;AAED,QAAMT,QAAQ,GACZ,CAACQ,KAAK,KAAK,IAAV,IAAkBA,KAAK,CAACG,IAAN,KAAe,SAAlC,MACC,CAAAd,QAAQ,SAAR,IAAAA,QAAQ,WAAR,qCAAAA,QAAQ,CAAEe,aAAV,gFAAyBC,OAAzB,MAAqC,OAArC,IACC,CAAAhB,QAAQ,SAAR,IAAAA,QAAQ,WAAR,sCAAAA,QAAQ,CAAEe,aAAV,kFAAyBC,OAAzB,MAAqC,UAFvC,CADF;AAIAZ,IAAAA,WAAW,CAACD,QAAD,CAAX;AACAG,IAAAA,YAAY,CAAC,KAAD,CAAZ,CAV4B,CAY5B;;AACAC,IAAAA,mBAAmB,CAACK,OAApB,GAA8BK,UAAU,CAAC,YAAM;AAC7Cb,MAAAA,WAAW,CAACD,QAAD,CAAX;AACAG,MAAAA,YAAY,CAAClB,uBAAuB,CAACC,MAAD,CAAxB,CAAZ;AACD,KAHuC,EAGrC,GAHqC,CAAxC;AAID,GAlBa,EAmBd,CAACW,QAAD,aAACA,QAAD,iDAACA,QAAQ,CAAEe,aAAX,2DAAC,uBAAyBC,OAA1B,EAAmC3B,MAAnC,CAnBc,CAAhB;AAsBA;AACF;AACA;AACA;;AACEY,EAAAA,KAAK,CAACiB,SAAN,CAAgB,YAAM;AACpBT,IAAAA,OAAO,CAAC,IAAD,CAAP;AACD,GAFD,EAEG,CAACA,OAAD,CAFH;AAIA,sDAAuBT,QAAvB,EAAiC,UAAjC,EAA6CS,OAA7C,EAAsDb,YAAtD;AACA,sDAAuBI,QAAvB,EAAiC,SAAjC,EAA4CS,OAA5C,EAAqDb,YAArD;AAEA,SAAO;AAAEO,IAAAA,QAAQ,EAARA,QAAF;AAAYE,IAAAA,SAAS,EAATA;AAAZ,GAAP;AACD","sourcesContent":["import * as React from \"react\";\nimport { useDOM } from \"../lib/dom\";\nimport { useGlobalEventListener } from \"./useGlobalEventListener\";\n\ninterface SoftwareKeyboardState {\n isOpened: boolean;\n isPrecise: boolean;\n}\n\n/**\n Проверяет, закрыла ли клавиатура часть экрана, 24% подошло к большиству устройств\n Работает на iOS и Android, где софт-клавиатура ресайзит viewport в браузерах\n */\nexport function getPreciseKeyboardState(window: any): boolean {\n const {\n innerHeight,\n screen: { availHeight },\n } = window;\n\n const coveredViewportPercentage = Math.round(\n (1 - innerHeight / availHeight) * 100\n );\n return coveredViewportPercentage > 24;\n}\n\nconst eventOptions = {\n passive: true,\n capture: false,\n};\n\nexport function useKeyboard(): SoftwareKeyboardState {\n const { window, document } = useDOM();\n\n const [isOpened, setIsOpened] = React.useState(false);\n const [isPrecise, setIsPrecise] = React.useState(false);\n\n const transitionalTimeout = React.useRef<ReturnType<\n typeof setTimeout\n > | null>(null);\n\n const onFocus = React.useCallback(\n (event: FocusEvent | true) => {\n if (transitionalTimeout.current) {\n clearTimeout(transitionalTimeout.current);\n }\n\n const isOpened =\n (event === true || event.type === \"focusin\") &&\n (document?.activeElement?.tagName === \"INPUT\" ||\n document?.activeElement?.tagName === \"TEXTAREA\");\n setIsOpened(isOpened);\n setIsPrecise(false);\n\n // Ожидаем прохождение анимации раскрытия клавиатуры\n transitionalTimeout.current = setTimeout(() => {\n setIsOpened(isOpened);\n setIsPrecise(getPreciseKeyboardState(window));\n }, 300);\n },\n [document?.activeElement?.tagName, window]\n );\n\n /**\n У полей с autoFocus не отлавливаются события focus, для этого вызываем вручную,\n чтобы иметь хоть какое-то понимание происходящего.\n */\n React.useEffect(() => {\n onFocus(true);\n }, [onFocus]);\n\n useGlobalEventListener(document, \"focusout\", onFocus, eventOptions);\n useGlobalEventListener(document, \"focusin\", onFocus, eventOptions);\n\n return { isOpened, isPrecise };\n}\n"],"file":"useKeyboard.js"}
1
+ {"version":3,"sources":["../../../src/hooks/useKeyboard.ts"],"names":["getPreciseKeyboardState","window","innerHeight","availHeight","screen","coveredViewportPercentage","Math","round","eventOptions","passive","capture","useKeyboard","document","React","useState","isOpened","setIsOpened","isPrecise","setIsPrecise","transitionalTimeout","useRef","onFocus","useCallback","event","current","clearTimeout","type","activeElement","tagName","setTimeout","useEffect"],"mappings":";;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AAOA;AACA;AACA;AACA;AACO,SAASA,uBAAT,CAAiCC,MAAjC,EAAuD;AAC5D,MACEC,WADF,GAGID,MAHJ,CACEC,WADF;AAAA,MAEYC,WAFZ,GAGIF,MAHJ,CAEEG,MAFF,CAEYD,WAFZ;AAKA,MAAME,yBAAyB,GAAGC,IAAI,CAACC,KAAL,CAChC,CAAC,IAAIL,WAAW,GAAGC,WAAnB,IAAkC,GADF,CAAlC;AAGA,SAAOE,yBAAyB,GAAG,EAAnC;AACD;;AAED,IAAMG,YAAY,GAAG;AACnBC,EAAAA,OAAO,EAAE,IADU;AAEnBC,EAAAA,OAAO,EAAE;AAFU,CAArB;;AAKO,SAASC,WAAT,GAA8C;AAAA;;AACnD,gBAA6B,kBAA7B;AAAA,MAAQV,MAAR,WAAQA,MAAR;AAAA,MAAgBW,QAAhB,WAAgBA,QAAhB;;AAEA,wBAAgCC,KAAK,CAACC,QAAN,CAAe,KAAf,CAAhC;AAAA;AAAA,MAAOC,QAAP;AAAA,MAAiBC,WAAjB;;AACA,yBAAkCH,KAAK,CAACC,QAAN,CAAe,KAAf,CAAlC;AAAA;AAAA,MAAOG,SAAP;AAAA,MAAkBC,YAAlB;;AAEA,MAAMC,mBAAmB,GAAGN,KAAK,CAACO,MAAN,CAElB,IAFkB,CAA5B;AAIA,MAAMC,OAAO,GAAGR,KAAK,CAACS,WAAN,CACd,UAACC,KAAD,EAA8B;AAAA;;AAC5B,QAAIJ,mBAAmB,CAACK,OAAxB,EAAiC;AAC/BC,MAAAA,YAAY,CAACN,mBAAmB,CAACK,OAArB,CAAZ;AACD;;AAED,QAAMT,QAAQ,GACZ,CAACQ,KAAK,KAAK,IAAV,IAAkBA,KAAK,CAACG,IAAN,KAAe,SAAlC,MACC,CAAAd,QAAQ,SAAR,IAAAA,QAAQ,WAAR,qCAAAA,QAAQ,CAAEe,aAAV,gFAAyBC,OAAzB,MAAqC,OAArC,IACC,CAAAhB,QAAQ,SAAR,IAAAA,QAAQ,WAAR,sCAAAA,QAAQ,CAAEe,aAAV,kFAAyBC,OAAzB,MAAqC,UAFvC,CADF;AAIAZ,IAAAA,WAAW,CAACD,QAAD,CAAX;AACAG,IAAAA,YAAY,CAAC,KAAD,CAAZ,CAV4B,CAY5B;;AACAC,IAAAA,mBAAmB,CAACK,OAApB,GAA8BK,UAAU,CAAC,YAAM;AAC7Cb,MAAAA,WAAW,CAACD,QAAD,CAAX;AACAG,MAAAA,YAAY,CAAClB,uBAAuB,CAACC,MAAD,CAAxB,CAAZ;AACD,KAHuC,EAGrC,GAHqC,CAAxC;AAID,GAlBa,EAmBd,CAACW,QAAD,aAACA,QAAD,iDAACA,QAAQ,CAAEe,aAAX,2DAAC,uBAAyBC,OAA1B,EAAmC3B,MAAnC,CAnBc,CAAhB;AAsBA;AACF;AACA;AACA;;AACEY,EAAAA,KAAK,CAACiB,SAAN,CAAgB,YAAM;AACpBT,IAAAA,OAAO,CAAC,IAAD,CAAP;AACD,GAFD,EAEG,CAACA,OAAD,CAFH;AAIA,sDAAuBT,QAAvB,EAAiC,UAAjC,EAA6CS,OAA7C,EAAsDb,YAAtD;AACA,sDAAuBI,QAAvB,EAAiC,SAAjC,EAA4CS,OAA5C,EAAqDb,YAArD;AAEA,SAAO;AAAEO,IAAAA,QAAQ,EAARA,QAAF;AAAYE,IAAAA,SAAS,EAATA;AAAZ,GAAP;AACD","sourcesContent":["import * as React from \"react\";\nimport { useDOM } from \"../lib/dom\";\nimport { useGlobalEventListener } from \"./useGlobalEventListener\";\n\ninterface SoftwareKeyboardState {\n isOpened: boolean;\n isPrecise: boolean;\n}\n\n/**\n Проверяет, закрыла ли клавиатура часть экрана, 24% подошло к большинству устройств\n Работает на iOS и Android, где софт-клавиатура ресайзит viewport в браузерах\n */\nexport function getPreciseKeyboardState(window: any): boolean {\n const {\n innerHeight,\n screen: { availHeight },\n } = window;\n\n const coveredViewportPercentage = Math.round(\n (1 - innerHeight / availHeight) * 100\n );\n return coveredViewportPercentage > 24;\n}\n\nconst eventOptions = {\n passive: true,\n capture: false,\n};\n\nexport function useKeyboard(): SoftwareKeyboardState {\n const { window, document } = useDOM();\n\n const [isOpened, setIsOpened] = React.useState(false);\n const [isPrecise, setIsPrecise] = React.useState(false);\n\n const transitionalTimeout = React.useRef<ReturnType<\n typeof setTimeout\n > | null>(null);\n\n const onFocus = React.useCallback(\n (event: FocusEvent | true) => {\n if (transitionalTimeout.current) {\n clearTimeout(transitionalTimeout.current);\n }\n\n const isOpened =\n (event === true || event.type === \"focusin\") &&\n (document?.activeElement?.tagName === \"INPUT\" ||\n document?.activeElement?.tagName === \"TEXTAREA\");\n setIsOpened(isOpened);\n setIsPrecise(false);\n\n // Ожидаем прохождение анимации раскрытия клавиатуры\n transitionalTimeout.current = setTimeout(() => {\n setIsOpened(isOpened);\n setIsPrecise(getPreciseKeyboardState(window));\n }, 300);\n },\n [document?.activeElement?.tagName, window]\n );\n\n /**\n У полей с autoFocus не отлавливаются события focus, для этого вызываем вручную,\n чтобы иметь хоть какое-то понимание происходящего.\n */\n React.useEffect(() => {\n onFocus(true);\n }, [onFocus]);\n\n useGlobalEventListener(document, \"focusout\", onFocus, eventOptions);\n useGlobalEventListener(document, \"focusin\", onFocus, eventOptions);\n\n return { isOpened, isPrecise };\n}\n"],"file":"useKeyboard.js"}
@@ -1 +1,3 @@
1
+ export declare const ENABLE_KEYBOARD_INPUT_EVENT_NAME = "enableKeyboardInput";
2
+ export declare const DISABLE_KEYBOARD_INPUT_EVENT_NAME = "disableKeyboardInput";
1
3
  export declare function useKeyboardInputTracker(): boolean;