@vkontakte/vkui 4.33.3 → 4.34.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1552) hide show
  1. package/.cache/.eslintcache +1 -1
  2. package/.cache/.stylelintcache +1 -1
  3. package/.cache/.tsbuildinfo +547 -481
  4. package/.cache/ts/src/components/ActionSheet/ActionSheet.d.ts +1 -1
  5. package/.cache/ts/src/components/ActionSheet/ActionSheetDropdown.d.ts +2 -2
  6. package/.cache/ts/src/components/ActionSheet/ActionSheetDropdownDesktop.d.ts +2 -2
  7. package/.cache/ts/src/components/AdaptivityProvider/AdaptivityProvider.d.ts +3 -1
  8. package/.cache/ts/src/components/Alert/Alert.d.ts +1 -1
  9. package/.cache/ts/src/components/AppRoot/AppRoot.d.ts +7 -1
  10. package/.cache/ts/src/components/AppRoot/AppRootContext.d.ts +1 -0
  11. package/.cache/ts/src/components/AppRoot/AppRootPortal.d.ts +4 -2
  12. package/.cache/ts/src/components/AppRoot/ScrollContext.d.ts +7 -6
  13. package/.cache/ts/src/components/AppearanceProvider/AppearanceProvider.d.ts +2 -1
  14. package/.cache/ts/src/components/Avatar/Avatar.d.ts +1 -1
  15. package/.cache/ts/src/components/Badge/Badge.d.ts +1 -1
  16. package/.cache/ts/src/components/BaseGallery/helpers.d.ts +2 -2
  17. package/.cache/ts/src/components/BaseGallery/types.d.ts +1 -1
  18. package/.cache/ts/src/components/ButtonGroup/ButtonGroup.d.ts +3 -3
  19. package/.cache/ts/src/components/Calendar/Calendar.d.ts +1 -1
  20. package/.cache/ts/src/components/CalendarDay/CalendarDay.d.ts +1 -1
  21. package/.cache/ts/src/components/CalendarDays/CalendarDays.d.ts +1 -1
  22. package/.cache/ts/src/components/CalendarHeader/CalendarHeader.d.ts +1 -1
  23. package/.cache/ts/src/components/CalendarRange/CalendarRange.d.ts +1 -1
  24. package/.cache/ts/src/components/CalendarTime/CalendarTime.d.ts +2 -2
  25. package/.cache/ts/src/components/Card/Card.d.ts +1 -1
  26. package/.cache/ts/src/components/CardGrid/CardGrid.d.ts +8 -2
  27. package/.cache/ts/src/components/CardScroll/CardScroll.d.ts +1 -1
  28. package/.cache/ts/src/components/Cell/Cell.d.ts +2 -2
  29. package/.cache/ts/src/components/Cell/CellCheckbox/CellCheckbox.d.ts +1 -1
  30. package/.cache/ts/src/components/Cell/CellDragger/CellDragger.d.ts +1 -1
  31. package/.cache/ts/src/components/CellButton/CellButton.d.ts +2 -2
  32. package/.cache/ts/src/components/Checkbox/Checkbox.d.ts +1 -1
  33. package/.cache/ts/src/components/Chip/Chip.d.ts +1 -1
  34. package/.cache/ts/src/components/ChipsSelect/ChipsSelect.d.ts +1 -1
  35. package/.cache/ts/src/components/ClickPopper/ClickPopper.d.ts +1 -1
  36. package/.cache/ts/src/components/ConfigProvider/ConfigProvider.d.ts +2 -1
  37. package/.cache/ts/src/components/CustomScrollView/CustomScrollView.d.ts +4 -3
  38. package/.cache/ts/src/components/CustomScrollView/useTrackerVisibility.d.ts +43 -0
  39. package/.cache/ts/src/components/CustomSelect/CustomSelect.d.ts +4 -3
  40. package/.cache/ts/src/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +4 -2
  41. package/.cache/ts/src/components/CustomSelectOption/CustomSelectOption.d.ts +1 -1
  42. package/.cache/ts/src/components/DateInput/DateInput.d.ts +1 -1
  43. package/.cache/ts/src/components/DateRangeInput/DateRangeInput.d.ts +1 -1
  44. package/.cache/ts/src/components/Div/Div.d.ts +1 -1
  45. package/.cache/ts/src/components/Dropdown/Dropdown.d.ts +2 -2
  46. package/.cache/ts/src/components/DropdownIcon/DropdownIcon.d.ts +1 -1
  47. package/.cache/ts/src/components/Epic/Epic.d.ts +1 -1
  48. package/.cache/ts/src/components/Epic/ScrollSaver.d.ts +2 -1
  49. package/.cache/ts/src/components/File/File.d.ts +1 -1
  50. package/.cache/ts/src/components/FixedLayout/FixedLayout.d.ts +1 -1
  51. package/.cache/ts/src/components/FocusTrap/FocusTrap.d.ts +1 -1
  52. package/.cache/ts/src/components/Footer/Footer.d.ts +1 -1
  53. package/.cache/ts/src/components/FormField/FormField.d.ts +3 -3
  54. package/.cache/ts/src/components/FormItem/FormItem.d.ts +1 -1
  55. package/.cache/ts/src/components/FormLayout/FormLayout.d.ts +1 -1
  56. package/.cache/ts/src/components/FormLayoutGroup/FormLayoutGroup.d.ts +1 -1
  57. package/.cache/ts/src/components/FormStatus/FormStatus.d.ts +1 -1
  58. package/.cache/ts/src/components/Gradient/Gradient.d.ts +7 -1
  59. package/.cache/ts/src/components/Group/Group.d.ts +1 -0
  60. package/.cache/ts/src/components/Header/Header.d.ts +1 -1
  61. package/.cache/ts/src/components/HorizontalCell/HorizontalCell.d.ts +1 -1
  62. package/.cache/ts/src/components/HorizontalScroll/HorizontalScroll.d.ts +2 -1
  63. package/.cache/ts/src/components/HorizontalScroll/HorizontalScrollArrow.d.ts +4 -4
  64. package/.cache/ts/src/components/HoverPopper/HoverPopper.d.ts +1 -1
  65. package/.cache/ts/src/components/InfoRow/InfoRow.d.ts +1 -1
  66. package/.cache/ts/src/components/InputLike/InputLike.d.ts +4 -1
  67. package/.cache/ts/src/components/InputLike/InputLikeDivider.d.ts +1 -1
  68. package/.cache/ts/src/components/Link/Link.d.ts +8 -3
  69. package/.cache/ts/src/components/List/List.d.ts +1 -1
  70. package/.cache/ts/src/components/MiniInfoCell/MiniInfoCell.d.ts +1 -1
  71. package/.cache/ts/src/components/ModalDismissButton/ModalDismissButton.d.ts +1 -1
  72. package/.cache/ts/src/components/ModalRoot/ModalRoot.d.ts +2 -1
  73. package/.cache/ts/src/components/ModalRoot/ModalRootAdaptive.d.ts +2 -1
  74. package/.cache/ts/src/components/ModalRoot/ModalRootDesktop.d.ts +2 -1
  75. package/.cache/ts/src/components/ModalRoot/useModalManager.d.ts +2 -1
  76. package/.cache/ts/src/components/NavTransitionContext/NavTransitionContext.d.ts +1 -1
  77. package/.cache/ts/src/components/Pagination/Pagination.d.ts +1 -1
  78. package/.cache/ts/src/components/PanelHeaderBack/PanelHeaderBack.d.ts +2 -2
  79. package/.cache/ts/src/components/PanelHeaderButton/PanelHeaderButton.d.ts +1 -1
  80. package/.cache/ts/src/components/PanelHeaderClose/PanelHeaderClose.d.ts +2 -2
  81. package/.cache/ts/src/components/PanelHeaderContent/PanelHeaderContent.d.ts +1 -1
  82. package/.cache/ts/src/components/PanelHeaderContext/PanelHeaderContext.d.ts +1 -1
  83. package/.cache/ts/src/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +2 -2
  84. package/.cache/ts/src/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +2 -2
  85. package/.cache/ts/src/components/Placeholder/Placeholder.d.ts +1 -1
  86. package/.cache/ts/src/components/PopoutRoot/PopoutRoot.d.ts +4 -1
  87. package/.cache/ts/src/components/PopoutWrapper/PopoutWrapper.d.ts +1 -1
  88. package/.cache/ts/src/components/Popper/Popper.d.ts +1 -1
  89. package/.cache/ts/src/components/Progress/Progress.d.ts +1 -1
  90. package/.cache/ts/src/components/PromoBanner/PromoBanner.d.ts +1 -1
  91. package/.cache/ts/src/components/RadioGroup/RadioGroup.d.ts +1 -1
  92. package/.cache/ts/src/components/RangeSlider/RangeSlider.d.ts +2 -2
  93. package/.cache/ts/src/components/Removable/Removable.d.ts +1 -1
  94. package/.cache/ts/src/components/RichCell/RichCell.d.ts +18 -9
  95. package/.cache/ts/src/components/RichTooltip/RichTooltip.d.ts +2 -2
  96. package/.cache/ts/src/components/Root/Root.d.ts +1 -1
  97. package/.cache/ts/src/components/ScreenSpinner/Icon48CancelCircle.d.ts +3 -0
  98. package/.cache/ts/src/components/ScreenSpinner/Icon48DoneOutline.d.ts +3 -0
  99. package/.cache/ts/src/components/ScreenSpinner/ScreenSpinner.d.ts +5 -3
  100. package/.cache/ts/src/components/SegmentedControl/SegmentedControl.d.ts +1 -1
  101. package/.cache/ts/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +2 -2
  102. package/.cache/ts/src/components/Select/Select.d.ts +2 -2
  103. package/.cache/ts/src/components/Separator/Separator.d.ts +2 -2
  104. package/.cache/ts/src/components/SimpleCheckbox/SimpleCheckbox.d.ts +2 -2
  105. package/.cache/ts/src/components/SliderSwitch/SliderSwitch.d.ts +1 -1
  106. package/.cache/ts/src/components/SliderSwitch/SliderSwitchButton.d.ts +1 -1
  107. package/.cache/ts/src/components/Snackbar/Snackbar.d.ts +1 -1
  108. package/.cache/ts/src/components/Spacing/Spacing.d.ts +1 -1
  109. package/.cache/ts/src/components/SplitCol/SplitCol.d.ts +1 -1
  110. package/.cache/ts/src/components/SplitLayout/SplitLayout.d.ts +1 -1
  111. package/.cache/ts/src/components/SubnavigationBar/SubnavigationBar.d.ts +1 -1
  112. package/.cache/ts/src/components/SubnavigationButton/SubnavigationButton.d.ts +1 -1
  113. package/.cache/ts/src/components/Switch/Switch.d.ts +2 -2
  114. package/.cache/ts/src/components/Tabbar/Tabbar.d.ts +1 -1
  115. package/.cache/ts/src/components/TabbarItem/TabbarItem.d.ts +1 -1
  116. package/.cache/ts/src/components/TabsItem/TabsItem.d.ts +1 -1
  117. package/.cache/ts/src/components/TextTooltip/TextTooltip.d.ts +1 -1
  118. package/.cache/ts/src/components/Tooltip/Tooltip.d.ts +3 -2
  119. package/.cache/ts/src/components/Touch/Touch.d.ts +1 -1
  120. package/.cache/ts/src/components/Typography/Caption/Caption.d.ts +1 -1
  121. package/.cache/ts/src/components/Typography/Headline/Headline.d.ts +1 -1
  122. package/.cache/ts/src/components/Typography/Paragraph/Paragraph.d.ts +1 -1
  123. package/.cache/ts/src/components/Typography/Subhead/Subhead.d.ts +1 -1
  124. package/.cache/ts/src/components/Typography/Text/Text.d.ts +1 -1
  125. package/.cache/ts/src/components/Typography/Title/Title.d.ts +1 -1
  126. package/.cache/ts/src/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +1 -1
  127. package/.cache/ts/src/components/WriteBar/WriteBar.d.ts +1 -1
  128. package/.cache/ts/src/components/WriteBarIcon/WriteBarIcon.d.ts +1 -1
  129. package/.cache/ts/src/helpers/getScheme.d.ts +1 -1
  130. package/.cache/ts/src/hoc/withInsets.d.ts +1 -1
  131. package/.cache/ts/src/hooks/useEnsuredControl.d.ts +2 -1
  132. package/.cache/ts/src/index.d.ts +1 -1
  133. package/.cache/ts/src/lib/SSR.d.ts +2 -1
  134. package/.cache/ts/src/testing/utils.d.ts +3 -2
  135. package/.cache/ts/src/tokenized/index.d.ts +28 -0
  136. package/.cache/ts/src/types.d.ts +3 -0
  137. package/.eslintignore +1 -0
  138. package/.eslintrc.json +4 -1
  139. package/.prettierignore +1 -1
  140. package/README.md +3 -4
  141. package/dist/cjs/components/ActionSheet/ActionSheet.js +4 -4
  142. package/dist/cjs/components/ActionSheet/ActionSheet.js.map +1 -1
  143. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  144. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  145. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  146. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  147. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  148. package/dist/cjs/components/AppRoot/AppRoot.js +39 -23
  149. package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
  150. package/dist/cjs/components/AppRoot/AppRootContext.js.map +1 -1
  151. package/dist/cjs/components/AppRoot/AppRootPortal.js +3 -2
  152. package/dist/cjs/components/AppRoot/AppRootPortal.js.map +1 -1
  153. package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
  154. package/dist/cjs/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  155. package/dist/cjs/components/Avatar/Avatar.js.map +1 -1
  156. package/dist/cjs/components/Badge/Badge.js.map +1 -1
  157. package/dist/cjs/components/Banner/Banner.js.map +1 -1
  158. package/dist/cjs/components/BaseGallery/BaseGallery.js +9 -9
  159. package/dist/cjs/components/BaseGallery/BaseGallery.js.map +1 -1
  160. package/dist/cjs/components/BaseGallery/helpers.js +8 -8
  161. package/dist/cjs/components/BaseGallery/helpers.js.map +1 -1
  162. package/dist/cjs/components/Button/Button.js +27 -27
  163. package/dist/cjs/components/Button/Button.js.map +1 -1
  164. package/dist/cjs/components/ButtonGroup/ButtonGroup.js +4 -2
  165. package/dist/cjs/components/ButtonGroup/ButtonGroup.js.map +1 -1
  166. package/dist/cjs/components/Calendar/Calendar.js.map +1 -1
  167. package/dist/cjs/components/CalendarDay/CalendarDay.js.map +1 -1
  168. package/dist/cjs/components/CalendarDays/CalendarDays.js.map +1 -1
  169. package/dist/cjs/components/CalendarHeader/CalendarHeader.js.map +1 -1
  170. package/dist/cjs/components/CalendarRange/CalendarRange.js.map +1 -1
  171. package/dist/cjs/components/CalendarTime/CalendarTime.js.map +1 -1
  172. package/dist/cjs/components/Card/Card.js.map +1 -1
  173. package/dist/cjs/components/CardGrid/CardGrid.js +15 -19
  174. package/dist/cjs/components/CardGrid/CardGrid.js.map +1 -1
  175. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  176. package/dist/cjs/components/Cell/Cell.js +3 -11
  177. package/dist/cjs/components/Cell/Cell.js.map +1 -1
  178. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  179. package/dist/cjs/components/Cell/CellDragger/CellDragger.js.map +1 -1
  180. package/dist/cjs/components/CellButton/CellButton.js.map +1 -1
  181. package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
  182. package/dist/cjs/components/Chip/Chip.js.map +1 -1
  183. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +4 -0
  184. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  185. package/dist/cjs/components/ClickPopper/ClickPopper.js.map +1 -1
  186. package/dist/cjs/components/ConfigProvider/ConfigProvider.js +24 -22
  187. package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
  188. package/dist/cjs/components/CustomScrollView/CustomScrollView.js +36 -5
  189. package/dist/cjs/components/CustomScrollView/CustomScrollView.js.map +1 -1
  190. package/dist/cjs/components/CustomScrollView/useTrackerVisibility.js +90 -0
  191. package/dist/cjs/components/CustomScrollView/useTrackerVisibility.js.map +1 -0
  192. package/dist/cjs/components/CustomSelect/CustomSelect.js +8 -3
  193. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  194. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js +76 -34
  195. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  196. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  197. package/dist/cjs/components/DateInput/DateInput.js.map +1 -1
  198. package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
  199. package/dist/cjs/components/DateRangeInput/DateRangeInput.js.map +1 -1
  200. package/dist/cjs/components/Div/Div.js.map +1 -1
  201. package/dist/cjs/components/Dropdown/Dropdown.js +1 -6
  202. package/dist/cjs/components/Dropdown/Dropdown.js.map +1 -1
  203. package/dist/cjs/components/DropdownIcon/DropdownIcon.js.map +1 -1
  204. package/dist/cjs/components/Epic/Epic.js +12 -10
  205. package/dist/cjs/components/Epic/Epic.js.map +1 -1
  206. package/dist/cjs/components/Epic/ScrollSaver.js.map +1 -1
  207. package/dist/cjs/components/File/File.js.map +1 -1
  208. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  209. package/dist/cjs/components/FocusTrap/FocusTrap.js.map +1 -1
  210. package/dist/cjs/components/Footer/Footer.js.map +1 -1
  211. package/dist/cjs/components/FormField/FormField.js +4 -10
  212. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  213. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  214. package/dist/cjs/components/FormLayout/FormLayout.js +8 -8
  215. package/dist/cjs/components/FormLayout/FormLayout.js.map +1 -1
  216. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  217. package/dist/cjs/components/FormStatus/FormStatus.js.map +1 -1
  218. package/dist/cjs/components/Gallery/Gallery.js.map +1 -1
  219. package/dist/cjs/components/Gradient/Gradient.js.map +1 -1
  220. package/dist/cjs/components/Group/Group.js +28 -19
  221. package/dist/cjs/components/Group/Group.js.map +1 -1
  222. package/dist/cjs/components/Header/Header.js.map +1 -1
  223. package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
  224. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js +12 -9
  225. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  226. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.js +33 -11
  227. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  228. package/dist/cjs/components/HoverPopper/HoverPopper.js.map +1 -1
  229. package/dist/cjs/components/InfoRow/InfoRow.js.map +1 -1
  230. package/dist/cjs/components/Input/Input.js +2 -6
  231. package/dist/cjs/components/Input/Input.js.map +1 -1
  232. package/dist/cjs/components/InputLike/InputLike.js.map +1 -1
  233. package/dist/cjs/components/InputLike/InputLikeDivider.js.map +1 -1
  234. package/dist/cjs/components/Link/Link.js +8 -10
  235. package/dist/cjs/components/Link/Link.js.map +1 -1
  236. package/dist/cjs/components/List/List.js +1 -9
  237. package/dist/cjs/components/List/List.js.map +1 -1
  238. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js +14 -26
  239. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  240. package/dist/cjs/components/ModalCard/ModalCard.js +2 -5
  241. package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
  242. package/dist/cjs/components/ModalCardBase/ModalCardBase.js +4 -13
  243. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  244. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  245. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  246. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  247. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  248. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  249. package/dist/cjs/components/ModalRoot/useModalManager.js.map +1 -1
  250. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  251. package/dist/cjs/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  252. package/dist/cjs/components/Pagination/Pagination.js.map +1 -1
  253. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  254. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  255. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  256. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  257. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  258. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  259. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  260. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  261. package/dist/cjs/components/Placeholder/Placeholder.js +10 -13
  262. package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
  263. package/dist/cjs/components/PopoutRoot/PopoutRoot.js +9 -9
  264. package/dist/cjs/components/PopoutRoot/PopoutRoot.js.map +1 -1
  265. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  266. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  267. package/dist/cjs/components/Progress/Progress.js.map +1 -1
  268. package/dist/cjs/components/PromoBanner/PromoBanner.js +9 -8
  269. package/dist/cjs/components/PromoBanner/PromoBanner.js.map +1 -1
  270. package/dist/cjs/components/Radio/Radio.js +8 -8
  271. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  272. package/dist/cjs/components/RadioGroup/RadioGroup.js.map +1 -1
  273. package/dist/cjs/components/RangeSlider/RangeSlider.js.map +1 -1
  274. package/dist/cjs/components/RangeSlider/UniversalSlider.js.map +1 -1
  275. package/dist/cjs/components/Removable/Removable.js +2 -4
  276. package/dist/cjs/components/Removable/Removable.js.map +1 -1
  277. package/dist/cjs/components/RichCell/RichCell.js +25 -25
  278. package/dist/cjs/components/RichCell/RichCell.js.map +1 -1
  279. package/dist/cjs/components/RichTooltip/RichTooltip.js.map +1 -1
  280. package/dist/cjs/components/Root/Root.js.map +1 -1
  281. package/dist/cjs/components/ScreenSpinner/Icon48CancelCircle.js +31 -0
  282. package/dist/cjs/components/ScreenSpinner/Icon48CancelCircle.js.map +1 -0
  283. package/dist/cjs/components/ScreenSpinner/Icon48DoneOutline.js +32 -0
  284. package/dist/cjs/components/ScreenSpinner/Icon48DoneOutline.js.map +1 -0
  285. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js +28 -8
  286. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  287. package/dist/cjs/components/Search/Search.js.map +1 -1
  288. package/dist/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
  289. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  290. package/dist/cjs/components/Select/Select.js.map +1 -1
  291. package/dist/cjs/components/SelectMimicry/SelectMimicry.js +3 -1
  292. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  293. package/dist/cjs/components/Separator/Separator.js +2 -1
  294. package/dist/cjs/components/Separator/Separator.js.map +1 -1
  295. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  296. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js +10 -10
  297. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  298. package/dist/cjs/components/Slider/Slider.js.map +1 -1
  299. package/dist/cjs/components/SliderSwitch/SliderSwitch.js +1 -1
  300. package/dist/cjs/components/SliderSwitch/SliderSwitch.js.map +1 -1
  301. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js +6 -6
  302. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  303. package/dist/cjs/components/Snackbar/Snackbar.js +13 -16
  304. package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
  305. package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
  306. package/dist/cjs/components/SplitCol/SplitCol.js +11 -11
  307. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  308. package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
  309. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  310. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js +11 -13
  311. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  312. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  313. package/dist/cjs/components/Tabbar/Tabbar.js +3 -6
  314. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  315. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  316. package/dist/cjs/components/Tabs/Tabs.js.map +1 -1
  317. package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
  318. package/dist/cjs/components/TextTooltip/TextTooltip.js.map +1 -1
  319. package/dist/cjs/components/Textarea/Textarea.js.map +1 -1
  320. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  321. package/dist/cjs/components/Touch/Touch.js.map +1 -1
  322. package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
  323. package/dist/cjs/components/Typography/Headline/Headline.js.map +1 -1
  324. package/dist/cjs/components/Typography/Paragraph/Paragraph.js.map +1 -1
  325. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  326. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  327. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  328. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -1
  329. package/dist/cjs/components/WriteBar/WriteBar.js +12 -12
  330. package/dist/cjs/components/WriteBar/WriteBar.js.map +1 -1
  331. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  332. package/dist/cjs/helpers/getScheme.js +1 -1
  333. package/dist/cjs/helpers/getScheme.js.map +1 -1
  334. package/dist/cjs/helpers/scheme.js +5 -5
  335. package/dist/cjs/helpers/scheme.js.map +1 -1
  336. package/dist/cjs/hoc/withAdaptivity.js.map +1 -1
  337. package/dist/cjs/hoc/withInsets.js.map +1 -1
  338. package/dist/cjs/hooks/useEnsuredControl.js.map +1 -1
  339. package/dist/cjs/hooks/useEventListener.js.map +1 -1
  340. package/dist/cjs/index.js +2 -4
  341. package/dist/cjs/index.js.map +1 -1
  342. package/dist/cjs/lib/SSR.js +4 -4
  343. package/dist/cjs/lib/SSR.js.map +1 -1
  344. package/dist/cjs/lib/classScopingMode.js +1 -0
  345. package/dist/cjs/lib/classScopingMode.js.map +1 -1
  346. package/dist/cjs/lib/dom.js.map +1 -1
  347. package/dist/cjs/tokenized/index.js +112 -0
  348. package/dist/cjs/tokenized/index.js.map +1 -1
  349. package/dist/components/ActionSheet/ActionSheet.d.ts +1 -1
  350. package/dist/components/ActionSheet/ActionSheet.js +4 -4
  351. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  352. package/dist/components/ActionSheet/ActionSheetDropdown.d.ts +2 -2
  353. package/dist/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  354. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.d.ts +2 -2
  355. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  356. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  357. package/dist/components/AdaptivityProvider/AdaptivityProvider.d.ts +3 -1
  358. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  359. package/dist/components/Alert/Alert.d.ts +1 -1
  360. package/dist/components/Alert/Alert.js.map +1 -1
  361. package/dist/components/AppRoot/AppRoot.d.ts +7 -1
  362. package/dist/components/AppRoot/AppRoot.js +38 -23
  363. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  364. package/dist/components/AppRoot/AppRootContext.d.ts +1 -0
  365. package/dist/components/AppRoot/AppRootContext.js.map +1 -1
  366. package/dist/components/AppRoot/AppRootPortal.d.ts +4 -2
  367. package/dist/components/AppRoot/AppRootPortal.js +3 -2
  368. package/dist/components/AppRoot/AppRootPortal.js.map +1 -1
  369. package/dist/components/AppRoot/ScrollContext.d.ts +7 -6
  370. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  371. package/dist/components/AppearanceProvider/AppearanceProvider.d.ts +2 -1
  372. package/dist/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  373. package/dist/components/Avatar/Avatar.d.ts +1 -1
  374. package/dist/components/Avatar/Avatar.js.map +1 -1
  375. package/dist/components/Badge/Badge.d.ts +1 -1
  376. package/dist/components/Badge/Badge.js.map +1 -1
  377. package/dist/components/Banner/Banner.js.map +1 -1
  378. package/dist/components/BaseGallery/BaseGallery.js +7 -7
  379. package/dist/components/BaseGallery/BaseGallery.js.map +1 -1
  380. package/dist/components/BaseGallery/helpers.d.ts +2 -2
  381. package/dist/components/BaseGallery/helpers.js +8 -8
  382. package/dist/components/BaseGallery/helpers.js.map +1 -1
  383. package/dist/components/BaseGallery/types.d.ts +1 -1
  384. package/dist/components/Button/Button.js +27 -27
  385. package/dist/components/Button/Button.js.map +1 -1
  386. package/dist/components/ButtonGroup/ButtonGroup.d.ts +3 -3
  387. package/dist/components/ButtonGroup/ButtonGroup.js +4 -2
  388. package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -1
  389. package/dist/components/Calendar/Calendar.d.ts +1 -1
  390. package/dist/components/Calendar/Calendar.js.map +1 -1
  391. package/dist/components/CalendarDay/CalendarDay.d.ts +1 -1
  392. package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
  393. package/dist/components/CalendarDays/CalendarDays.d.ts +1 -1
  394. package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
  395. package/dist/components/CalendarHeader/CalendarHeader.d.ts +1 -1
  396. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
  397. package/dist/components/CalendarRange/CalendarRange.d.ts +1 -1
  398. package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
  399. package/dist/components/CalendarTime/CalendarTime.d.ts +2 -2
  400. package/dist/components/CalendarTime/CalendarTime.js.map +1 -1
  401. package/dist/components/Card/Card.d.ts +1 -1
  402. package/dist/components/Card/Card.js.map +1 -1
  403. package/dist/components/CardGrid/CardGrid.d.ts +8 -2
  404. package/dist/components/CardGrid/CardGrid.js +13 -14
  405. package/dist/components/CardGrid/CardGrid.js.map +1 -1
  406. package/dist/components/CardScroll/CardScroll.d.ts +1 -1
  407. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  408. package/dist/components/Cell/Cell.d.ts +2 -2
  409. package/dist/components/Cell/Cell.js +4 -11
  410. package/dist/components/Cell/Cell.js.map +1 -1
  411. package/dist/components/Cell/CellCheckbox/CellCheckbox.d.ts +1 -1
  412. package/dist/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  413. package/dist/components/Cell/CellDragger/CellDragger.d.ts +1 -1
  414. package/dist/components/Cell/CellDragger/CellDragger.js.map +1 -1
  415. package/dist/components/CellButton/CellButton.d.ts +2 -2
  416. package/dist/components/CellButton/CellButton.js.map +1 -1
  417. package/dist/components/Checkbox/Checkbox.d.ts +1 -1
  418. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  419. package/dist/components/Chip/Chip.d.ts +1 -1
  420. package/dist/components/Chip/Chip.js.map +1 -1
  421. package/dist/components/ChipsSelect/ChipsSelect.d.ts +1 -1
  422. package/dist/components/ChipsSelect/ChipsSelect.js +4 -0
  423. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  424. package/dist/components/ClickPopper/ClickPopper.d.ts +1 -1
  425. package/dist/components/ClickPopper/ClickPopper.js.map +1 -1
  426. package/dist/components/ConfigProvider/ConfigProvider.d.ts +2 -1
  427. package/dist/components/ConfigProvider/ConfigProvider.js +25 -21
  428. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  429. package/dist/components/CustomScrollView/CustomScrollView.d.ts +4 -3
  430. package/dist/components/CustomScrollView/CustomScrollView.js +33 -4
  431. package/dist/components/CustomScrollView/CustomScrollView.js.map +1 -1
  432. package/dist/components/CustomScrollView/useTrackerVisibility.d.ts +43 -0
  433. package/dist/components/CustomScrollView/useTrackerVisibility.js +75 -0
  434. package/dist/components/CustomScrollView/useTrackerVisibility.js.map +1 -0
  435. package/dist/components/CustomSelect/CustomSelect.d.ts +4 -3
  436. package/dist/components/CustomSelect/CustomSelect.js +8 -3
  437. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  438. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +4 -2
  439. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js +74 -34
  440. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  441. package/dist/components/CustomSelectOption/CustomSelectOption.d.ts +1 -1
  442. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  443. package/dist/components/DateInput/DateInput.d.ts +1 -1
  444. package/dist/components/DateInput/DateInput.js.map +1 -1
  445. package/dist/components/DatePicker/DatePicker.js.map +1 -1
  446. package/dist/components/DateRangeInput/DateRangeInput.d.ts +1 -1
  447. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  448. package/dist/components/Div/Div.d.ts +1 -1
  449. package/dist/components/Div/Div.js.map +1 -1
  450. package/dist/components/Dropdown/Dropdown.d.ts +2 -2
  451. package/dist/components/Dropdown/Dropdown.js +1 -4
  452. package/dist/components/Dropdown/Dropdown.js.map +1 -1
  453. package/dist/components/DropdownIcon/DropdownIcon.d.ts +1 -1
  454. package/dist/components/DropdownIcon/DropdownIcon.js.map +1 -1
  455. package/dist/components/Epic/Epic.d.ts +1 -1
  456. package/dist/components/Epic/Epic.js +12 -11
  457. package/dist/components/Epic/Epic.js.map +1 -1
  458. package/dist/components/Epic/ScrollSaver.d.ts +2 -1
  459. package/dist/components/Epic/ScrollSaver.js.map +1 -1
  460. package/dist/components/File/File.d.ts +1 -1
  461. package/dist/components/File/File.js.map +1 -1
  462. package/dist/components/FixedLayout/FixedLayout.d.ts +1 -1
  463. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  464. package/dist/components/FocusTrap/FocusTrap.d.ts +1 -1
  465. package/dist/components/FocusTrap/FocusTrap.js.map +1 -1
  466. package/dist/components/Footer/Footer.d.ts +1 -1
  467. package/dist/components/Footer/Footer.js.map +1 -1
  468. package/dist/components/FormField/FormField.d.ts +3 -3
  469. package/dist/components/FormField/FormField.js +4 -8
  470. package/dist/components/FormField/FormField.js.map +1 -1
  471. package/dist/components/FormItem/FormItem.d.ts +1 -1
  472. package/dist/components/FormItem/FormItem.js.map +1 -1
  473. package/dist/components/FormLayout/FormLayout.d.ts +1 -1
  474. package/dist/components/FormLayout/FormLayout.js +8 -8
  475. package/dist/components/FormLayout/FormLayout.js.map +1 -1
  476. package/dist/components/FormLayoutGroup/FormLayoutGroup.d.ts +1 -1
  477. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  478. package/dist/components/FormStatus/FormStatus.d.ts +1 -1
  479. package/dist/components/FormStatus/FormStatus.js.map +1 -1
  480. package/dist/components/Gallery/Gallery.js.map +1 -1
  481. package/dist/components/Gradient/Gradient.d.ts +7 -1
  482. package/dist/components/Gradient/Gradient.js.map +1 -1
  483. package/dist/components/Group/Group.d.ts +1 -0
  484. package/dist/components/Group/Group.js +27 -19
  485. package/dist/components/Group/Group.js.map +1 -1
  486. package/dist/components/Header/Header.d.ts +1 -1
  487. package/dist/components/Header/Header.js.map +1 -1
  488. package/dist/components/HorizontalCell/HorizontalCell.d.ts +1 -1
  489. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  490. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +2 -1
  491. package/dist/components/HorizontalScroll/HorizontalScroll.js +9 -5
  492. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  493. package/dist/components/HorizontalScroll/HorizontalScrollArrow.d.ts +4 -4
  494. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js +26 -12
  495. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  496. package/dist/components/HoverPopper/HoverPopper.d.ts +1 -1
  497. package/dist/components/HoverPopper/HoverPopper.js.map +1 -1
  498. package/dist/components/InfoRow/InfoRow.d.ts +1 -1
  499. package/dist/components/InfoRow/InfoRow.js.map +1 -1
  500. package/dist/components/Input/Input.js +2 -4
  501. package/dist/components/Input/Input.js.map +1 -1
  502. package/dist/components/InputLike/InputLike.d.ts +4 -1
  503. package/dist/components/InputLike/InputLike.js.map +1 -1
  504. package/dist/components/InputLike/InputLikeDivider.d.ts +1 -1
  505. package/dist/components/InputLike/InputLikeDivider.js.map +1 -1
  506. package/dist/components/Link/Link.d.ts +8 -3
  507. package/dist/components/Link/Link.js +8 -9
  508. package/dist/components/Link/Link.js.map +1 -1
  509. package/dist/components/List/List.d.ts +1 -1
  510. package/dist/components/List/List.js +1 -8
  511. package/dist/components/List/List.js.map +1 -1
  512. package/dist/components/MiniInfoCell/MiniInfoCell.d.ts +1 -1
  513. package/dist/components/MiniInfoCell/MiniInfoCell.js +13 -23
  514. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  515. package/dist/components/ModalCard/ModalCard.js +2 -5
  516. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  517. package/dist/components/ModalCardBase/ModalCardBase.js +5 -14
  518. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  519. package/dist/components/ModalDismissButton/ModalDismissButton.d.ts +1 -1
  520. package/dist/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  521. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  522. package/dist/components/ModalRoot/ModalRoot.d.ts +2 -1
  523. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  524. package/dist/components/ModalRoot/ModalRootAdaptive.d.ts +2 -1
  525. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  526. package/dist/components/ModalRoot/ModalRootDesktop.d.ts +2 -1
  527. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  528. package/dist/components/ModalRoot/useModalManager.d.ts +2 -1
  529. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  530. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  531. package/dist/components/NavTransitionContext/NavTransitionContext.d.ts +1 -1
  532. package/dist/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  533. package/dist/components/Pagination/Pagination.d.ts +1 -1
  534. package/dist/components/Pagination/Pagination.js.map +1 -1
  535. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  536. package/dist/components/PanelHeaderBack/PanelHeaderBack.d.ts +2 -2
  537. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  538. package/dist/components/PanelHeaderButton/PanelHeaderButton.d.ts +1 -1
  539. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  540. package/dist/components/PanelHeaderClose/PanelHeaderClose.d.ts +2 -2
  541. package/dist/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  542. package/dist/components/PanelHeaderContent/PanelHeaderContent.d.ts +1 -1
  543. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  544. package/dist/components/PanelHeaderContext/PanelHeaderContext.d.ts +1 -1
  545. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  546. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +2 -2
  547. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  548. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +2 -2
  549. package/dist/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  550. package/dist/components/Placeholder/Placeholder.d.ts +1 -1
  551. package/dist/components/Placeholder/Placeholder.js +10 -13
  552. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  553. package/dist/components/PopoutRoot/PopoutRoot.d.ts +4 -1
  554. package/dist/components/PopoutRoot/PopoutRoot.js +9 -9
  555. package/dist/components/PopoutRoot/PopoutRoot.js.map +1 -1
  556. package/dist/components/PopoutWrapper/PopoutWrapper.d.ts +1 -1
  557. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  558. package/dist/components/Popper/Popper.d.ts +1 -1
  559. package/dist/components/Popper/Popper.js.map +1 -1
  560. package/dist/components/Progress/Progress.d.ts +1 -1
  561. package/dist/components/Progress/Progress.js.map +1 -1
  562. package/dist/components/PromoBanner/PromoBanner.d.ts +1 -1
  563. package/dist/components/PromoBanner/PromoBanner.js +10 -10
  564. package/dist/components/PromoBanner/PromoBanner.js.map +1 -1
  565. package/dist/components/Radio/Radio.js +8 -8
  566. package/dist/components/Radio/Radio.js.map +1 -1
  567. package/dist/components/RadioGroup/RadioGroup.d.ts +1 -1
  568. package/dist/components/RadioGroup/RadioGroup.js.map +1 -1
  569. package/dist/components/RangeSlider/RangeSlider.d.ts +2 -2
  570. package/dist/components/RangeSlider/RangeSlider.js.map +1 -1
  571. package/dist/components/RangeSlider/UniversalSlider.js.map +1 -1
  572. package/dist/components/Removable/Removable.d.ts +1 -1
  573. package/dist/components/Removable/Removable.js +3 -4
  574. package/dist/components/Removable/Removable.js.map +1 -1
  575. package/dist/components/RichCell/RichCell.d.ts +18 -9
  576. package/dist/components/RichCell/RichCell.js +25 -21
  577. package/dist/components/RichCell/RichCell.js.map +1 -1
  578. package/dist/components/RichTooltip/RichTooltip.d.ts +2 -2
  579. package/dist/components/RichTooltip/RichTooltip.js.map +1 -1
  580. package/dist/components/Root/Root.d.ts +1 -1
  581. package/dist/components/Root/Root.js.map +1 -1
  582. package/dist/components/ScreenSpinner/Icon48CancelCircle.d.ts +3 -0
  583. package/dist/components/ScreenSpinner/Icon48CancelCircle.js +18 -0
  584. package/dist/components/ScreenSpinner/Icon48CancelCircle.js.map +1 -0
  585. package/dist/components/ScreenSpinner/Icon48DoneOutline.d.ts +3 -0
  586. package/dist/components/ScreenSpinner/Icon48DoneOutline.js +19 -0
  587. package/dist/components/ScreenSpinner/Icon48DoneOutline.js.map +1 -0
  588. package/dist/components/ScreenSpinner/ScreenSpinner.d.ts +5 -3
  589. package/dist/components/ScreenSpinner/ScreenSpinner.js +25 -7
  590. package/dist/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  591. package/dist/components/Search/Search.js.map +1 -1
  592. package/dist/components/SegmentedControl/SegmentedControl.d.ts +1 -1
  593. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  594. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +2 -2
  595. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  596. package/dist/components/Select/Select.d.ts +2 -2
  597. package/dist/components/Select/Select.js.map +1 -1
  598. package/dist/components/SelectMimicry/SelectMimicry.js +3 -1
  599. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  600. package/dist/components/Separator/Separator.d.ts +2 -2
  601. package/dist/components/Separator/Separator.js +2 -1
  602. package/dist/components/Separator/Separator.js.map +1 -1
  603. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  604. package/dist/components/SimpleCheckbox/SimpleCheckbox.d.ts +2 -2
  605. package/dist/components/SimpleCheckbox/SimpleCheckbox.js +10 -10
  606. package/dist/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  607. package/dist/components/Slider/Slider.js.map +1 -1
  608. package/dist/components/SliderSwitch/SliderSwitch.d.ts +1 -1
  609. package/dist/components/SliderSwitch/SliderSwitch.js +1 -1
  610. package/dist/components/SliderSwitch/SliderSwitch.js.map +1 -1
  611. package/dist/components/SliderSwitch/SliderSwitchButton.d.ts +1 -1
  612. package/dist/components/SliderSwitch/SliderSwitchButton.js +6 -6
  613. package/dist/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  614. package/dist/components/Snackbar/Snackbar.d.ts +1 -1
  615. package/dist/components/Snackbar/Snackbar.js +13 -16
  616. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  617. package/dist/components/Spacing/Spacing.d.ts +1 -1
  618. package/dist/components/Spacing/Spacing.js.map +1 -1
  619. package/dist/components/SplitCol/SplitCol.d.ts +1 -1
  620. package/dist/components/SplitCol/SplitCol.js +11 -11
  621. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  622. package/dist/components/SplitLayout/SplitLayout.d.ts +1 -1
  623. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  624. package/dist/components/SubnavigationBar/SubnavigationBar.d.ts +1 -1
  625. package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  626. package/dist/components/SubnavigationButton/SubnavigationButton.d.ts +1 -1
  627. package/dist/components/SubnavigationButton/SubnavigationButton.js +12 -15
  628. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  629. package/dist/components/Switch/Switch.d.ts +2 -2
  630. package/dist/components/Switch/Switch.js.map +1 -1
  631. package/dist/components/Tabbar/Tabbar.d.ts +1 -1
  632. package/dist/components/Tabbar/Tabbar.js +2 -5
  633. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  634. package/dist/components/TabbarItem/TabbarItem.d.ts +1 -1
  635. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  636. package/dist/components/Tabs/Tabs.js.map +1 -1
  637. package/dist/components/TabsItem/TabsItem.d.ts +1 -1
  638. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  639. package/dist/components/TextTooltip/TextTooltip.d.ts +1 -1
  640. package/dist/components/TextTooltip/TextTooltip.js.map +1 -1
  641. package/dist/components/Textarea/Textarea.js.map +1 -1
  642. package/dist/components/Tooltip/Tooltip.d.ts +3 -2
  643. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  644. package/dist/components/Touch/Touch.d.ts +1 -1
  645. package/dist/components/Touch/Touch.js.map +1 -1
  646. package/dist/components/Typography/Caption/Caption.d.ts +1 -1
  647. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  648. package/dist/components/Typography/Headline/Headline.d.ts +1 -1
  649. package/dist/components/Typography/Headline/Headline.js.map +1 -1
  650. package/dist/components/Typography/Paragraph/Paragraph.d.ts +1 -1
  651. package/dist/components/Typography/Paragraph/Paragraph.js.map +1 -1
  652. package/dist/components/Typography/Subhead/Subhead.d.ts +1 -1
  653. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  654. package/dist/components/Typography/Text/Text.d.ts +1 -1
  655. package/dist/components/Typography/Text/Text.js.map +1 -1
  656. package/dist/components/Typography/Title/Title.d.ts +1 -1
  657. package/dist/components/Typography/Title/Title.js.map +1 -1
  658. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +1 -1
  659. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -1
  660. package/dist/components/WriteBar/WriteBar.d.ts +1 -1
  661. package/dist/components/WriteBar/WriteBar.js +13 -14
  662. package/dist/components/WriteBar/WriteBar.js.map +1 -1
  663. package/dist/components/WriteBarIcon/WriteBarIcon.d.ts +1 -1
  664. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  665. package/dist/components.css +22 -15
  666. package/dist/components.css.map +1 -1
  667. package/dist/cssm/components/ActionSheet/ActionSheet.d.ts +1 -1
  668. package/dist/cssm/components/ActionSheet/ActionSheet.js +4 -4
  669. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  670. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.d.ts +2 -2
  671. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  672. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.d.ts +2 -2
  673. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  674. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  675. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.d.ts +3 -1
  676. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  677. package/dist/cssm/components/Alert/Alert.d.ts +1 -1
  678. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  679. package/dist/cssm/components/AppRoot/AppRoot.d.ts +7 -1
  680. package/dist/cssm/components/AppRoot/AppRoot.js +38 -23
  681. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  682. package/dist/cssm/components/AppRoot/AppRootContext.d.ts +1 -0
  683. package/dist/cssm/components/AppRoot/AppRootContext.js.map +1 -1
  684. package/dist/cssm/components/AppRoot/AppRootPortal.d.ts +4 -2
  685. package/dist/cssm/components/AppRoot/AppRootPortal.js +3 -2
  686. package/dist/cssm/components/AppRoot/AppRootPortal.js.map +1 -1
  687. package/dist/cssm/components/AppRoot/ScrollContext.d.ts +7 -6
  688. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  689. package/dist/cssm/components/AppearanceProvider/AppearanceProvider.d.ts +2 -1
  690. package/dist/cssm/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  691. package/dist/cssm/components/Avatar/Avatar.css +2 -2
  692. package/dist/cssm/components/Avatar/Avatar.d.ts +1 -1
  693. package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
  694. package/dist/cssm/components/Badge/Badge.d.ts +1 -1
  695. package/dist/cssm/components/Badge/Badge.js.map +1 -1
  696. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  697. package/dist/cssm/components/BaseGallery/BaseGallery.js +7 -7
  698. package/dist/cssm/components/BaseGallery/BaseGallery.js.map +1 -1
  699. package/dist/cssm/components/BaseGallery/helpers.d.ts +2 -2
  700. package/dist/cssm/components/BaseGallery/helpers.js +8 -8
  701. package/dist/cssm/components/BaseGallery/helpers.js.map +1 -1
  702. package/dist/cssm/components/BaseGallery/types.d.ts +1 -1
  703. package/dist/cssm/components/Button/Button.css +2 -2
  704. package/dist/cssm/components/Button/Button.js +27 -27
  705. package/dist/cssm/components/Button/Button.js.map +1 -1
  706. package/dist/cssm/components/ButtonGroup/ButtonGroup.css +1 -1
  707. package/dist/cssm/components/ButtonGroup/ButtonGroup.d.ts +3 -3
  708. package/dist/cssm/components/ButtonGroup/ButtonGroup.js +4 -2
  709. package/dist/cssm/components/ButtonGroup/ButtonGroup.js.map +1 -1
  710. package/dist/cssm/components/Calendar/Calendar.css +1 -1
  711. package/dist/cssm/components/Calendar/Calendar.d.ts +1 -1
  712. package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
  713. package/dist/cssm/components/CalendarDay/CalendarDay.d.ts +1 -1
  714. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
  715. package/dist/cssm/components/CalendarDays/CalendarDays.d.ts +1 -1
  716. package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
  717. package/dist/cssm/components/CalendarHeader/CalendarHeader.d.ts +1 -1
  718. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
  719. package/dist/cssm/components/CalendarRange/CalendarRange.d.ts +1 -1
  720. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
  721. package/dist/cssm/components/CalendarTime/CalendarTime.d.ts +2 -2
  722. package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -1
  723. package/dist/cssm/components/Card/Card.d.ts +1 -1
  724. package/dist/cssm/components/Card/Card.js.map +1 -1
  725. package/dist/cssm/components/CardGrid/CardGrid.css +1 -1
  726. package/dist/cssm/components/CardGrid/CardGrid.d.ts +8 -2
  727. package/dist/cssm/components/CardGrid/CardGrid.js +13 -14
  728. package/dist/cssm/components/CardGrid/CardGrid.js.map +1 -1
  729. package/dist/cssm/components/CardScroll/CardScroll.d.ts +1 -1
  730. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  731. package/dist/cssm/components/Cell/Cell.css +3 -1
  732. package/dist/cssm/components/Cell/Cell.d.ts +2 -2
  733. package/dist/cssm/components/Cell/Cell.js +4 -11
  734. package/dist/cssm/components/Cell/Cell.js.map +1 -1
  735. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.d.ts +1 -1
  736. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  737. package/dist/cssm/components/Cell/CellDragger/CellDragger.d.ts +1 -1
  738. package/dist/cssm/components/Cell/CellDragger/CellDragger.js.map +1 -1
  739. package/dist/cssm/components/CellButton/CellButton.d.ts +2 -2
  740. package/dist/cssm/components/CellButton/CellButton.js.map +1 -1
  741. package/dist/cssm/components/Checkbox/Checkbox.d.ts +1 -1
  742. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  743. package/dist/cssm/components/Chip/Chip.d.ts +1 -1
  744. package/dist/cssm/components/Chip/Chip.js.map +1 -1
  745. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts +1 -1
  746. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +4 -0
  747. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  748. package/dist/cssm/components/ClickPopper/ClickPopper.d.ts +1 -1
  749. package/dist/cssm/components/ClickPopper/ClickPopper.js.map +1 -1
  750. package/dist/cssm/components/ConfigProvider/ConfigProvider.d.ts +2 -1
  751. package/dist/cssm/components/ConfigProvider/ConfigProvider.js +25 -21
  752. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  753. package/dist/cssm/components/CustomScrollView/CustomScrollView.css +1 -1
  754. package/dist/cssm/components/CustomScrollView/CustomScrollView.d.ts +4 -3
  755. package/dist/cssm/components/CustomScrollView/CustomScrollView.js +33 -4
  756. package/dist/cssm/components/CustomScrollView/CustomScrollView.js.map +1 -1
  757. package/dist/cssm/components/CustomScrollView/useTrackerVisibility.d.ts +43 -0
  758. package/dist/cssm/components/CustomScrollView/useTrackerVisibility.js +75 -0
  759. package/dist/cssm/components/CustomScrollView/useTrackerVisibility.js.map +1 -0
  760. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +4 -3
  761. package/dist/cssm/components/CustomSelect/CustomSelect.js +8 -3
  762. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  763. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +4 -2
  764. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js +74 -34
  765. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  766. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.d.ts +1 -1
  767. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  768. package/dist/cssm/components/DateInput/DateInput.d.ts +1 -1
  769. package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
  770. package/dist/cssm/components/DatePicker/DatePicker.js.map +1 -1
  771. package/dist/cssm/components/DateRangeInput/DateRangeInput.d.ts +1 -1
  772. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  773. package/dist/cssm/components/Div/Div.d.ts +1 -1
  774. package/dist/cssm/components/Div/Div.js.map +1 -1
  775. package/dist/cssm/components/Dropdown/Dropdown.css +1 -1
  776. package/dist/cssm/components/Dropdown/Dropdown.d.ts +2 -2
  777. package/dist/cssm/components/Dropdown/Dropdown.js +1 -4
  778. package/dist/cssm/components/Dropdown/Dropdown.js.map +1 -1
  779. package/dist/cssm/components/DropdownIcon/DropdownIcon.d.ts +1 -1
  780. package/dist/cssm/components/DropdownIcon/DropdownIcon.js.map +1 -1
  781. package/dist/cssm/components/Epic/Epic.d.ts +1 -1
  782. package/dist/cssm/components/Epic/Epic.js +12 -11
  783. package/dist/cssm/components/Epic/Epic.js.map +1 -1
  784. package/dist/cssm/components/Epic/ScrollSaver.d.ts +2 -1
  785. package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
  786. package/dist/cssm/components/File/File.d.ts +1 -1
  787. package/dist/cssm/components/File/File.js.map +1 -1
  788. package/dist/cssm/components/FixedLayout/FixedLayout.d.ts +1 -1
  789. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  790. package/dist/cssm/components/FocusTrap/FocusTrap.d.ts +1 -1
  791. package/dist/cssm/components/FocusTrap/FocusTrap.js.map +1 -1
  792. package/dist/cssm/components/Footer/Footer.d.ts +1 -1
  793. package/dist/cssm/components/Footer/Footer.js.map +1 -1
  794. package/dist/cssm/components/FormField/FormField.css +2 -2
  795. package/dist/cssm/components/FormField/FormField.d.ts +3 -3
  796. package/dist/cssm/components/FormField/FormField.js +4 -8
  797. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  798. package/dist/cssm/components/FormItem/FormItem.d.ts +1 -1
  799. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  800. package/dist/cssm/components/FormLayout/FormLayout.d.ts +1 -1
  801. package/dist/cssm/components/FormLayout/FormLayout.js +8 -8
  802. package/dist/cssm/components/FormLayout/FormLayout.js.map +1 -1
  803. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.d.ts +1 -1
  804. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  805. package/dist/cssm/components/FormStatus/FormStatus.d.ts +1 -1
  806. package/dist/cssm/components/FormStatus/FormStatus.js.map +1 -1
  807. package/dist/cssm/components/Gallery/Gallery.js.map +1 -1
  808. package/dist/cssm/components/Gradient/Gradient.css +1 -1
  809. package/dist/cssm/components/Gradient/Gradient.d.ts +7 -1
  810. package/dist/cssm/components/Gradient/Gradient.js.map +1 -1
  811. package/dist/cssm/components/Group/Group.css +1 -1
  812. package/dist/cssm/components/Group/Group.d.ts +1 -0
  813. package/dist/cssm/components/Group/Group.js +27 -19
  814. package/dist/cssm/components/Group/Group.js.map +1 -1
  815. package/dist/cssm/components/Header/Header.d.ts +1 -1
  816. package/dist/cssm/components/Header/Header.js.map +1 -1
  817. package/dist/cssm/components/HorizontalCell/HorizontalCell.css +1 -1
  818. package/dist/cssm/components/HorizontalCell/HorizontalCell.d.ts +1 -1
  819. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  820. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.css +1 -1
  821. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.d.ts +2 -1
  822. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +9 -5
  823. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  824. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.css +2 -5
  825. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.d.ts +4 -4
  826. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js +26 -12
  827. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  828. package/dist/cssm/components/HoverPopper/HoverPopper.d.ts +1 -1
  829. package/dist/cssm/components/HoverPopper/HoverPopper.js.map +1 -1
  830. package/dist/cssm/components/IconButton/IconButton.css +1 -1
  831. package/dist/cssm/components/InfoRow/InfoRow.d.ts +1 -1
  832. package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
  833. package/dist/cssm/components/Input/Input.css +1 -1
  834. package/dist/cssm/components/Input/Input.js +2 -4
  835. package/dist/cssm/components/Input/Input.js.map +1 -1
  836. package/dist/cssm/components/InputLike/InputLike.d.ts +4 -1
  837. package/dist/cssm/components/InputLike/InputLike.js.map +1 -1
  838. package/dist/cssm/components/InputLike/InputLikeDivider.d.ts +1 -1
  839. package/dist/cssm/components/InputLike/InputLikeDivider.js.map +1 -1
  840. package/dist/cssm/components/Link/Link.css +1 -1
  841. package/dist/cssm/components/Link/Link.d.ts +8 -3
  842. package/dist/cssm/components/Link/Link.js +8 -9
  843. package/dist/cssm/components/Link/Link.js.map +1 -1
  844. package/dist/cssm/components/List/List.d.ts +1 -1
  845. package/dist/cssm/components/List/List.js +1 -8
  846. package/dist/cssm/components/List/List.js.map +1 -1
  847. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.css +1 -1
  848. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.d.ts +1 -1
  849. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js +13 -23
  850. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  851. package/dist/cssm/components/ModalCard/ModalCard.js +2 -5
  852. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  853. package/dist/cssm/components/ModalCardBase/ModalCardBase.css +3 -1
  854. package/dist/cssm/components/ModalCardBase/ModalCardBase.js +5 -14
  855. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  856. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.d.ts +1 -1
  857. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  858. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  859. package/dist/cssm/components/ModalRoot/ModalRoot.d.ts +2 -1
  860. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  861. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.d.ts +2 -1
  862. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  863. package/dist/cssm/components/ModalRoot/ModalRootDesktop.d.ts +2 -1
  864. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  865. package/dist/cssm/components/ModalRoot/useModalManager.d.ts +2 -1
  866. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  867. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  868. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.d.ts +1 -1
  869. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  870. package/dist/cssm/components/Pagination/Pagination.d.ts +1 -1
  871. package/dist/cssm/components/Pagination/Pagination.js.map +1 -1
  872. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  873. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.d.ts +2 -2
  874. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  875. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.d.ts +1 -1
  876. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  877. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.d.ts +2 -2
  878. package/dist/cssm/components/PanelHeaderClose/PanelHeaderClose.js.map +1 -1
  879. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.d.ts +1 -1
  880. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  881. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.d.ts +1 -1
  882. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  883. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +2 -2
  884. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  885. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +2 -2
  886. package/dist/cssm/components/PanelHeaderSubmit/PanelHeaderSubmit.js.map +1 -1
  887. package/dist/cssm/components/Placeholder/Placeholder.css +3 -1
  888. package/dist/cssm/components/Placeholder/Placeholder.d.ts +1 -1
  889. package/dist/cssm/components/Placeholder/Placeholder.js +10 -13
  890. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  891. package/dist/cssm/components/PopoutRoot/PopoutRoot.d.ts +4 -1
  892. package/dist/cssm/components/PopoutRoot/PopoutRoot.js +9 -9
  893. package/dist/cssm/components/PopoutRoot/PopoutRoot.js.map +1 -1
  894. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.d.ts +1 -1
  895. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  896. package/dist/cssm/components/Popper/Popper.d.ts +1 -1
  897. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  898. package/dist/cssm/components/Progress/Progress.d.ts +1 -1
  899. package/dist/cssm/components/Progress/Progress.js.map +1 -1
  900. package/dist/cssm/components/PromoBanner/PromoBanner.d.ts +1 -1
  901. package/dist/cssm/components/PromoBanner/PromoBanner.js +10 -10
  902. package/dist/cssm/components/PromoBanner/PromoBanner.js.map +1 -1
  903. package/dist/cssm/components/Radio/Radio.js +8 -8
  904. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  905. package/dist/cssm/components/RadioGroup/RadioGroup.d.ts +1 -1
  906. package/dist/cssm/components/RadioGroup/RadioGroup.js.map +1 -1
  907. package/dist/cssm/components/RangeSlider/RangeSlider.d.ts +2 -2
  908. package/dist/cssm/components/RangeSlider/RangeSlider.js.map +1 -1
  909. package/dist/cssm/components/RangeSlider/UniversalSlider.js.map +1 -1
  910. package/dist/cssm/components/Removable/Removable.css +1 -1
  911. package/dist/cssm/components/Removable/Removable.d.ts +1 -1
  912. package/dist/cssm/components/Removable/Removable.js +3 -4
  913. package/dist/cssm/components/Removable/Removable.js.map +1 -1
  914. package/dist/cssm/components/RichCell/RichCell.css +3 -1
  915. package/dist/cssm/components/RichCell/RichCell.d.ts +18 -9
  916. package/dist/cssm/components/RichCell/RichCell.js +25 -21
  917. package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
  918. package/dist/cssm/components/RichTooltip/RichTooltip.d.ts +2 -2
  919. package/dist/cssm/components/RichTooltip/RichTooltip.js.map +1 -1
  920. package/dist/cssm/components/Root/Root.d.ts +1 -1
  921. package/dist/cssm/components/Root/Root.js.map +1 -1
  922. package/dist/cssm/components/ScreenSpinner/Icon48CancelCircle.d.ts +3 -0
  923. package/dist/cssm/components/ScreenSpinner/Icon48CancelCircle.js +18 -0
  924. package/dist/cssm/components/ScreenSpinner/Icon48CancelCircle.js.map +1 -0
  925. package/dist/cssm/components/ScreenSpinner/Icon48DoneOutline.d.ts +3 -0
  926. package/dist/cssm/components/ScreenSpinner/Icon48DoneOutline.js +19 -0
  927. package/dist/cssm/components/ScreenSpinner/Icon48DoneOutline.js.map +1 -0
  928. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.css +1 -1
  929. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.d.ts +5 -3
  930. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js +25 -7
  931. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  932. package/dist/cssm/components/Search/Search.css +1 -1
  933. package/dist/cssm/components/Search/Search.js.map +1 -1
  934. package/dist/cssm/components/SegmentedControl/SegmentedControl.css +1 -1
  935. package/dist/cssm/components/SegmentedControl/SegmentedControl.d.ts +1 -1
  936. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  937. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +1 -1
  938. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +2 -2
  939. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  940. package/dist/cssm/components/Select/Select.css +1 -1
  941. package/dist/cssm/components/Select/Select.d.ts +2 -2
  942. package/dist/cssm/components/Select/Select.js.map +1 -1
  943. package/dist/cssm/components/SelectMimicry/SelectMimicry.js +3 -1
  944. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  945. package/dist/cssm/components/Separator/Separator.css +1 -1
  946. package/dist/cssm/components/Separator/Separator.d.ts +2 -2
  947. package/dist/cssm/components/Separator/Separator.js +2 -1
  948. package/dist/cssm/components/Separator/Separator.js.map +1 -1
  949. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  950. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.d.ts +2 -2
  951. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js +10 -10
  952. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  953. package/dist/cssm/components/Slider/Slider.js.map +1 -1
  954. package/dist/cssm/components/SliderSwitch/SliderSwitch.d.ts +1 -1
  955. package/dist/cssm/components/SliderSwitch/SliderSwitch.js +1 -1
  956. package/dist/cssm/components/SliderSwitch/SliderSwitch.js.map +1 -1
  957. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.d.ts +1 -1
  958. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js +6 -6
  959. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  960. package/dist/cssm/components/Snackbar/Snackbar.d.ts +1 -1
  961. package/dist/cssm/components/Snackbar/Snackbar.js +13 -16
  962. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  963. package/dist/cssm/components/Spacing/Spacing.d.ts +1 -1
  964. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  965. package/dist/cssm/components/SplitCol/SplitCol.css +1 -1
  966. package/dist/cssm/components/SplitCol/SplitCol.d.ts +1 -1
  967. package/dist/cssm/components/SplitCol/SplitCol.js +11 -11
  968. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  969. package/dist/cssm/components/SplitLayout/SplitLayout.d.ts +1 -1
  970. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  971. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.d.ts +1 -1
  972. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  973. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.d.ts +1 -1
  974. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +12 -15
  975. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  976. package/dist/cssm/components/Switch/Switch.css +1 -1
  977. package/dist/cssm/components/Switch/Switch.d.ts +2 -2
  978. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  979. package/dist/cssm/components/Tabbar/Tabbar.css +3 -1
  980. package/dist/cssm/components/Tabbar/Tabbar.d.ts +1 -1
  981. package/dist/cssm/components/Tabbar/Tabbar.js +2 -5
  982. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  983. package/dist/cssm/components/TabbarItem/TabbarItem.d.ts +1 -1
  984. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  985. package/dist/cssm/components/Tabs/Tabs.css +1 -1
  986. package/dist/cssm/components/Tabs/Tabs.js.map +1 -1
  987. package/dist/cssm/components/TabsItem/TabsItem.d.ts +1 -1
  988. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  989. package/dist/cssm/components/TextTooltip/TextTooltip.d.ts +1 -1
  990. package/dist/cssm/components/TextTooltip/TextTooltip.js.map +1 -1
  991. package/dist/cssm/components/Textarea/Textarea.css +1 -1
  992. package/dist/cssm/components/Textarea/Textarea.js.map +1 -1
  993. package/dist/cssm/components/Tooltip/Tooltip.d.ts +3 -2
  994. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  995. package/dist/cssm/components/Touch/Touch.d.ts +1 -1
  996. package/dist/cssm/components/Touch/Touch.js.map +1 -1
  997. package/dist/cssm/components/Typography/Caption/Caption.d.ts +1 -1
  998. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  999. package/dist/cssm/components/Typography/Headline/Headline.d.ts +1 -1
  1000. package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
  1001. package/dist/cssm/components/Typography/Paragraph/Paragraph.d.ts +1 -1
  1002. package/dist/cssm/components/Typography/Paragraph/Paragraph.js.map +1 -1
  1003. package/dist/cssm/components/Typography/Subhead/Subhead.d.ts +1 -1
  1004. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  1005. package/dist/cssm/components/Typography/Text/Text.d.ts +1 -1
  1006. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  1007. package/dist/cssm/components/Typography/Title/Title.d.ts +1 -1
  1008. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  1009. package/dist/cssm/components/UsersStack/UsersStack.css +1 -1
  1010. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +1 -1
  1011. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -1
  1012. package/dist/cssm/components/WriteBar/WriteBar.d.ts +1 -1
  1013. package/dist/cssm/components/WriteBar/WriteBar.js +13 -14
  1014. package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
  1015. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.d.ts +1 -1
  1016. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1017. package/dist/cssm/helpers/getScheme.d.ts +1 -1
  1018. package/dist/cssm/helpers/getScheme.js +1 -1
  1019. package/dist/cssm/helpers/getScheme.js.map +1 -1
  1020. package/dist/cssm/helpers/scheme.js +5 -5
  1021. package/dist/cssm/helpers/scheme.js.map +1 -1
  1022. package/dist/cssm/hoc/withAdaptivity.js.map +1 -1
  1023. package/dist/cssm/hoc/withInsets.d.ts +1 -1
  1024. package/dist/cssm/hoc/withInsets.js.map +1 -1
  1025. package/dist/cssm/hooks/useEnsuredControl.d.ts +2 -1
  1026. package/dist/cssm/hooks/useEnsuredControl.js.map +1 -1
  1027. package/dist/cssm/hooks/useEventListener.js.map +1 -1
  1028. package/dist/cssm/index.d.ts +1 -1
  1029. package/dist/cssm/index.js +1 -1
  1030. package/dist/cssm/index.js.map +1 -1
  1031. package/dist/cssm/lib/SSR.d.ts +2 -1
  1032. package/dist/cssm/lib/SSR.js +4 -4
  1033. package/dist/cssm/lib/SSR.js.map +1 -1
  1034. package/dist/cssm/lib/classScopingMode.js +1 -0
  1035. package/dist/cssm/lib/classScopingMode.js.map +1 -1
  1036. package/dist/cssm/lib/dom.js.map +1 -1
  1037. package/dist/cssm/styles/components.css +22 -15
  1038. package/dist/cssm/styles/themes.css +1 -1
  1039. package/dist/cssm/styles/unstable.css +1 -1
  1040. package/dist/cssm/tokenized/index.d.ts +28 -0
  1041. package/dist/cssm/tokenized/index.js +14 -0
  1042. package/dist/cssm/tokenized/index.js.map +1 -1
  1043. package/dist/cssm/types.d.ts +3 -0
  1044. package/dist/helpers/getScheme.d.ts +1 -1
  1045. package/dist/helpers/getScheme.js +1 -1
  1046. package/dist/helpers/getScheme.js.map +1 -1
  1047. package/dist/helpers/scheme.js +5 -5
  1048. package/dist/helpers/scheme.js.map +1 -1
  1049. package/dist/hoc/withAdaptivity.js.map +1 -1
  1050. package/dist/hoc/withInsets.d.ts +1 -1
  1051. package/dist/hoc/withInsets.js.map +1 -1
  1052. package/dist/hooks/useEnsuredControl.d.ts +2 -1
  1053. package/dist/hooks/useEnsuredControl.js.map +1 -1
  1054. package/dist/hooks/useEventListener.js.map +1 -1
  1055. package/dist/index.d.ts +1 -1
  1056. package/dist/index.js +1 -1
  1057. package/dist/index.js.map +1 -1
  1058. package/dist/lib/SSR.d.ts +2 -1
  1059. package/dist/lib/SSR.js +4 -4
  1060. package/dist/lib/SSR.js.map +1 -1
  1061. package/dist/lib/classScopingMode.js +1 -0
  1062. package/dist/lib/classScopingMode.js.map +1 -1
  1063. package/dist/lib/dom.js.map +1 -1
  1064. package/dist/tokenized/index.d.ts +28 -0
  1065. package/dist/tokenized/index.js +14 -0
  1066. package/dist/tokenized/index.js.map +1 -1
  1067. package/dist/types.d.ts +3 -0
  1068. package/dist/unstable.css +1 -1
  1069. package/dist/unstable.css.map +1 -1
  1070. package/dist/vkui.css +23 -16
  1071. package/dist/vkui.css.map +1 -1
  1072. package/package.json +16 -15
  1073. package/src/components/ActionSheet/ActionSheet.tsx +4 -6
  1074. package/src/components/ActionSheet/ActionSheetDropdown.tsx +2 -2
  1075. package/src/components/ActionSheet/ActionSheetDropdownDesktop.tsx +6 -3
  1076. package/src/components/ActionSheet/Readme.md +1 -1
  1077. package/src/components/ActionSheetItem/ActionSheetItem.tsx +1 -1
  1078. package/src/components/AdaptivityProvider/AdaptivityProvider.tsx +3 -1
  1079. package/src/components/Alert/Alert.tsx +7 -6
  1080. package/src/components/Alert/Readme.md +1 -1
  1081. package/src/components/AppRoot/AppRoot.tsx +40 -17
  1082. package/src/components/AppRoot/AppRootContext.ts +1 -0
  1083. package/src/components/AppRoot/AppRootPortal.tsx +13 -5
  1084. package/src/components/AppRoot/Readme.md +1 -1
  1085. package/src/components/AppRoot/ScrollContext.tsx +8 -9
  1086. package/src/components/AppearanceProvider/AppearanceProvider.tsx +3 -2
  1087. package/src/components/Avatar/Avatar.css +1 -14
  1088. package/src/components/Avatar/Avatar.tsx +1 -1
  1089. package/src/components/Badge/Badge.tsx +1 -1
  1090. package/src/components/Banner/Banner.tsx +5 -6
  1091. package/src/components/BaseGallery/BaseGallery.tsx +7 -7
  1092. package/src/components/BaseGallery/helpers.ts +7 -7
  1093. package/src/components/BaseGallery/types.ts +1 -1
  1094. package/src/components/Button/Button.css +0 -8
  1095. package/src/components/Button/Button.tsx +8 -6
  1096. package/src/components/ButtonGroup/ButtonGroup.css +12 -1
  1097. package/src/components/ButtonGroup/ButtonGroup.tsx +8 -5
  1098. package/src/components/ButtonGroup/Readme.md +15 -1
  1099. package/src/components/Calendar/Calendar.css +2 -2
  1100. package/src/components/Calendar/Calendar.tsx +2 -2
  1101. package/src/components/CalendarDay/CalendarDay.tsx +2 -2
  1102. package/src/components/CalendarDays/CalendarDays.tsx +2 -2
  1103. package/src/components/CalendarHeader/CalendarHeader.tsx +2 -2
  1104. package/src/components/CalendarRange/CalendarRange.tsx +2 -2
  1105. package/src/components/CalendarTime/CalendarTime.tsx +2 -2
  1106. package/src/components/Card/Card.tsx +1 -1
  1107. package/src/components/CardGrid/CardGrid.css +12 -20
  1108. package/src/components/CardGrid/CardGrid.tsx +15 -16
  1109. package/src/components/CardGrid/Readme.md +5 -0
  1110. package/src/components/CardScroll/CardScroll.tsx +1 -1
  1111. package/src/components/Cell/Cell.css +10 -3
  1112. package/src/components/Cell/Cell.tsx +11 -11
  1113. package/src/components/Cell/CellCheckbox/CellCheckbox.tsx +2 -2
  1114. package/src/components/Cell/CellDragger/CellDragger.tsx +2 -2
  1115. package/src/components/CellButton/CellButton.tsx +1 -2
  1116. package/src/components/Checkbox/Checkbox.tsx +2 -2
  1117. package/src/components/Chip/Chip.tsx +1 -1
  1118. package/src/components/ChipsSelect/ChipsSelect.tsx +10 -4
  1119. package/src/components/ChipsSelect/Readme.md +1 -1
  1120. package/src/components/ClickPopper/ClickPopper.tsx +1 -1
  1121. package/src/components/ConfigProvider/ConfigProvider.tsx +22 -15
  1122. package/src/components/ConfigProvider/Readme.md +1 -1
  1123. package/src/components/CustomScrollView/CustomScrollView.css +5 -0
  1124. package/src/components/CustomScrollView/CustomScrollView.tsx +38 -4
  1125. package/src/components/CustomScrollView/useTrackerVisibility.ts +109 -0
  1126. package/src/components/CustomSelect/CustomSelect.tsx +10 -3
  1127. package/src/components/CustomSelect/Readme.md +228 -170
  1128. package/src/components/CustomSelectDropdown/CustomSelectDropdown.tsx +54 -25
  1129. package/src/components/CustomSelectOption/CustomSelectOption.tsx +1 -1
  1130. package/src/components/DateInput/DateInput.tsx +2 -2
  1131. package/src/components/DatePicker/DatePicker.tsx +6 -10
  1132. package/src/components/DateRangeInput/DateRangeInput.tsx +2 -2
  1133. package/src/components/Div/Div.tsx +1 -5
  1134. package/src/components/Dropdown/Dropdown.css +3 -16
  1135. package/src/components/Dropdown/Dropdown.tsx +2 -11
  1136. package/src/components/Dropdown/Readme.md +1 -1
  1137. package/src/components/DropdownIcon/DropdownIcon.tsx +1 -3
  1138. package/src/components/Epic/Epic.tsx +9 -5
  1139. package/src/components/Epic/ScrollSaver.tsx +3 -2
  1140. package/src/components/File/File.tsx +2 -2
  1141. package/src/components/FixedLayout/FixedLayout.tsx +1 -1
  1142. package/src/components/FocusTrap/FocusTrap.tsx +2 -2
  1143. package/src/components/Footer/Footer.tsx +1 -4
  1144. package/src/components/FormField/FormField.css +31 -22
  1145. package/src/components/FormField/FormField.tsx +7 -11
  1146. package/src/components/FormField/Readme.md +10 -83
  1147. package/src/components/FormItem/FormItem.tsx +1 -1
  1148. package/src/components/FormLayout/FormLayout.tsx +7 -11
  1149. package/src/components/FormLayoutGroup/FormLayoutGroup.tsx +1 -1
  1150. package/src/components/FormStatus/FormStatus.tsx +1 -1
  1151. package/src/components/Gallery/Gallery.tsx +1 -1
  1152. package/src/components/Gradient/Gradient.css +14 -76
  1153. package/src/components/Gradient/Gradient.tsx +8 -2
  1154. package/src/components/Gradient/Readme.md +53 -15
  1155. package/src/components/Group/Group.css +10 -14
  1156. package/src/components/Group/Group.tsx +32 -23
  1157. package/src/components/Header/Header.tsx +3 -3
  1158. package/src/components/HorizontalCell/HorizontalCell.css +2 -2
  1159. package/src/components/HorizontalCell/HorizontalCell.tsx +2 -2
  1160. package/src/components/HorizontalScroll/HorizontalScroll.css +14 -5
  1161. package/src/components/HorizontalScroll/HorizontalScroll.tsx +21 -9
  1162. package/src/components/HorizontalScroll/HorizontalScrollArrow.css +28 -24
  1163. package/src/components/HorizontalScroll/HorizontalScrollArrow.tsx +28 -9
  1164. package/src/components/HorizontalScroll/Readme.md +1 -0
  1165. package/src/components/HoverPopper/HoverPopper.tsx +1 -1
  1166. package/src/components/IconButton/IconButton.css +46 -25
  1167. package/src/components/InfoRow/InfoRow.tsx +1 -5
  1168. package/src/components/InitialsAvatar/Readme.md +1 -1
  1169. package/src/components/Input/Input.css +18 -9
  1170. package/src/components/Input/Input.tsx +5 -6
  1171. package/src/components/Input/Readme.md +128 -24
  1172. package/src/components/InputLike/InputLike.tsx +2 -2
  1173. package/src/components/InputLike/InputLikeDivider.tsx +4 -3
  1174. package/src/components/Link/Link.css +21 -1
  1175. package/src/components/Link/Link.tsx +12 -14
  1176. package/src/components/Link/Readme.md +36 -4
  1177. package/src/components/List/List.tsx +5 -10
  1178. package/src/components/MiniInfoCell/MiniInfoCell.css +6 -14
  1179. package/src/components/MiniInfoCell/MiniInfoCell.tsx +13 -22
  1180. package/src/components/ModalCard/ModalCard.tsx +6 -8
  1181. package/src/components/ModalCardBase/ModalCardBase.css +13 -9
  1182. package/src/components/ModalCardBase/ModalCardBase.tsx +15 -19
  1183. package/src/components/ModalCardBase/Readme.md +1 -1
  1184. package/src/components/ModalDismissButton/ModalDismissButton.tsx +1 -1
  1185. package/src/components/ModalPage/ModalPage.tsx +2 -4
  1186. package/src/components/ModalRoot/ModalRoot.tsx +1 -0
  1187. package/src/components/ModalRoot/ModalRootAdaptive.tsx +4 -3
  1188. package/src/components/ModalRoot/ModalRootDesktop.tsx +1 -0
  1189. package/src/components/ModalRoot/Readme.md +1 -1
  1190. package/src/components/ModalRoot/useModalManager.tsx +5 -2
  1191. package/src/components/NativeSelect/NativeSelect.tsx +2 -4
  1192. package/src/components/NavTransitionContext/NavTransitionContext.tsx +2 -2
  1193. package/src/components/Pagination/Pagination.tsx +2 -2
  1194. package/src/components/PanelHeader/PanelHeader.tsx +2 -2
  1195. package/src/components/PanelHeader/Readme.md +1 -1
  1196. package/src/components/PanelHeaderBack/PanelHeaderBack.tsx +1 -3
  1197. package/src/components/PanelHeaderButton/PanelHeaderButton.tsx +2 -5
  1198. package/src/components/PanelHeaderButton/Readme.md +1 -1
  1199. package/src/components/PanelHeaderClose/PanelHeaderClose.tsx +4 -4
  1200. package/src/components/PanelHeaderContent/PanelHeaderContent.tsx +4 -5
  1201. package/src/components/PanelHeaderContext/PanelHeaderContext.tsx +2 -2
  1202. package/src/components/PanelHeaderEdit/PanelHeaderEdit.tsx +1 -2
  1203. package/src/components/PanelHeaderSubmit/PanelHeaderSubmit.tsx +4 -4
  1204. package/src/components/Placeholder/Placeholder.css +7 -8
  1205. package/src/components/Placeholder/Placeholder.tsx +31 -40
  1206. package/src/components/Placeholder/Readme.md +77 -90
  1207. package/src/components/PopoutRoot/PopoutRoot.tsx +10 -13
  1208. package/src/components/PopoutWrapper/PopoutWrapper.tsx +1 -1
  1209. package/src/components/PopoutWrapper/Readme.md +1 -1
  1210. package/src/components/Popper/Popper.tsx +1 -1
  1211. package/src/components/Popper/Readme.md +2 -2
  1212. package/src/components/Progress/Progress.tsx +1 -1
  1213. package/src/components/PromoBanner/PromoBanner.tsx +8 -4
  1214. package/src/components/Radio/Radio.tsx +9 -10
  1215. package/src/components/RadioGroup/RadioGroup.tsx +2 -2
  1216. package/src/components/RangeSlider/RangeSlider.tsx +3 -2
  1217. package/src/components/RangeSlider/UniversalSlider.tsx +2 -2
  1218. package/src/components/Removable/Removable.css +2 -2
  1219. package/src/components/Removable/Removable.tsx +8 -7
  1220. package/src/components/RichCell/Readme.md +78 -19
  1221. package/src/components/RichCell/RichCell.css +76 -59
  1222. package/src/components/RichCell/RichCell.tsx +49 -43
  1223. package/src/components/RichTooltip/Readme.md +2 -2
  1224. package/src/components/RichTooltip/RichTooltip.tsx +1 -2
  1225. package/src/components/Root/Root.tsx +1 -1
  1226. package/src/components/ScreenSpinner/Icon48CancelCircle.tsx +18 -0
  1227. package/src/components/ScreenSpinner/Icon48DoneOutline.tsx +19 -0
  1228. package/src/components/ScreenSpinner/Readme.md +57 -36
  1229. package/src/components/ScreenSpinner/ScreenSpinner.css +44 -9
  1230. package/src/components/ScreenSpinner/ScreenSpinner.tsx +27 -9
  1231. package/src/components/Search/Search.css +6 -2
  1232. package/src/components/Search/Search.tsx +7 -5
  1233. package/src/components/SegmentedControl/SegmentedControl.css +1 -1
  1234. package/src/components/SegmentedControl/SegmentedControl.tsx +2 -2
  1235. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +1 -1
  1236. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.tsx +2 -3
  1237. package/src/components/Select/Select.css +23 -9
  1238. package/src/components/Select/Select.tsx +7 -5
  1239. package/src/components/SelectMimicry/SelectMimicry.tsx +6 -4
  1240. package/src/components/Separator/Separator.css +11 -11
  1241. package/src/components/Separator/Separator.tsx +3 -6
  1242. package/src/components/SimpleCell/SimpleCell.tsx +2 -4
  1243. package/src/components/SimpleCheckbox/Readme.md +2 -2
  1244. package/src/components/SimpleCheckbox/SimpleCheckbox.tsx +12 -15
  1245. package/src/components/Slider/Slider.tsx +2 -1
  1246. package/src/components/SliderSwitch/Readme.md +1 -1
  1247. package/src/components/SliderSwitch/SliderSwitch.tsx +1 -1
  1248. package/src/components/SliderSwitch/SliderSwitchButton.tsx +7 -4
  1249. package/src/components/Snackbar/Snackbar.tsx +13 -22
  1250. package/src/components/Spacing/Spacing.tsx +1 -1
  1251. package/src/components/SplitCol/SplitCol.css +1 -1
  1252. package/src/components/SplitCol/SplitCol.tsx +11 -12
  1253. package/src/components/SplitLayout/SplitLayout.tsx +1 -1
  1254. package/src/components/SubnavigationBar/SubnavigationBar.tsx +1 -1
  1255. package/src/components/SubnavigationButton/Readme.md +1 -1
  1256. package/src/components/SubnavigationButton/SubnavigationButton.tsx +14 -21
  1257. package/src/components/Switch/Switch.css +3 -3
  1258. package/src/components/Switch/Switch.tsx +1 -2
  1259. package/src/components/Tabbar/Tabbar.css +12 -10
  1260. package/src/components/Tabbar/Tabbar.tsx +5 -7
  1261. package/src/components/TabbarItem/TabbarItem.tsx +1 -1
  1262. package/src/components/Tabs/Tabs.css +12 -0
  1263. package/src/components/Tabs/Tabs.tsx +1 -1
  1264. package/src/components/TabsItem/TabsItem.tsx +1 -1
  1265. package/src/components/Tappable/Readme.md +1 -1
  1266. package/src/components/TextTooltip/Readme.md +1 -1
  1267. package/src/components/TextTooltip/TextTooltip.tsx +1 -1
  1268. package/src/components/Textarea/Textarea.css +5 -3
  1269. package/src/components/Textarea/Textarea.tsx +1 -1
  1270. package/src/components/Tooltip/Readme.md +1 -1
  1271. package/src/components/Tooltip/Tooltip.css +2 -2
  1272. package/src/components/Tooltip/Tooltip.tsx +6 -3
  1273. package/src/components/Touch/Touch.tsx +1 -1
  1274. package/src/components/Typography/Caption/Caption.tsx +1 -1
  1275. package/src/components/Typography/Headline/Headline.tsx +1 -1
  1276. package/src/components/Typography/Paragraph/Paragraph.tsx +2 -2
  1277. package/src/components/Typography/Subhead/Subhead.tsx +2 -2
  1278. package/src/components/Typography/Text/Text.tsx +1 -1
  1279. package/src/components/Typography/Title/Title.tsx +2 -2
  1280. package/src/components/UsersStack/UsersStack.css +0 -8
  1281. package/src/components/View/Readme.md +1 -1
  1282. package/src/components/VisuallyHiddenInput/VisuallyHiddenInput.tsx +2 -2
  1283. package/src/components/WriteBar/WriteBar.css +1 -0
  1284. package/src/components/WriteBar/WriteBar.tsx +13 -17
  1285. package/src/components/WriteBarIcon/WriteBarIcon.tsx +1 -1
  1286. package/src/helpers/getScheme.ts +2 -2
  1287. package/src/helpers/scheme.ts +5 -4
  1288. package/src/hoc/withAdaptivity.tsx +3 -3
  1289. package/src/hoc/withInsets.tsx +1 -1
  1290. package/src/hooks/useEnsuredControl.ts +2 -2
  1291. package/src/hooks/useEventListener.ts +4 -1
  1292. package/src/index.ts +1 -1
  1293. package/src/lib/SSR.tsx +6 -3
  1294. package/src/lib/classScopingMode.ts +1 -0
  1295. package/src/lib/dom.tsx +1 -1
  1296. package/src/lib/jsxRuntime.d.ts +2 -2
  1297. package/src/testing/setup.ts +3 -0
  1298. package/src/testing/utils.tsx +3 -5
  1299. package/src/tokenized/index.ts +42 -0
  1300. package/src/types.ts +4 -0
  1301. package/stylelint.config.js +22 -1
  1302. package/tasks/{styleint-atomic.js → stylelint-atomic.js} +1 -1
  1303. package/tasks/stylelint-bad-multiplication.js +69 -0
  1304. package/CONTRIBUTING.md +0 -66
  1305. package/CSS_GUIDE.md +0 -145
  1306. package/TESTING.md +0 -58
  1307. package/VKUI_TOKENS_MIGRATION_GUIDE.md +0 -76
  1308. package/dist/cjs/appearance/constants.d.ts +0 -1
  1309. package/dist/cjs/components/ActionSheet/ActionSheet.d.ts +0 -29
  1310. package/dist/cjs/components/ActionSheet/ActionSheetContext.d.ts +0 -8
  1311. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.d.ts +0 -4
  1312. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.d.ts +0 -4
  1313. package/dist/cjs/components/ActionSheet/types.d.ts +0 -9
  1314. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.d.ts +0 -23
  1315. package/dist/cjs/components/AdaptivityProvider/AdaptivityContext.d.ts +0 -46
  1316. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.d.ts +0 -13
  1317. package/dist/cjs/components/Alert/Alert.d.ts +0 -25
  1318. package/dist/cjs/components/AppRoot/AppRoot.d.ts +0 -17
  1319. package/dist/cjs/components/AppRoot/AppRootContext.d.ts +0 -9
  1320. package/dist/cjs/components/AppRoot/AppRootPortal.d.ts +0 -5
  1321. package/dist/cjs/components/AppRoot/ScrollContext.d.ts +0 -26
  1322. package/dist/cjs/components/AppearanceProvider/AppearanceProvider.d.ts +0 -10
  1323. package/dist/cjs/components/AppearanceProvider/AppearanceProviderContext.d.ts +0 -3
  1324. package/dist/cjs/components/Avatar/Avatar.d.ts +0 -24
  1325. package/dist/cjs/components/Badge/Badge.d.ts +0 -9
  1326. package/dist/cjs/components/Banner/Banner.d.ts +0 -67
  1327. package/dist/cjs/components/BaseGallery/BaseGallery.d.ts +0 -4
  1328. package/dist/cjs/components/BaseGallery/helpers.d.ts +0 -12
  1329. package/dist/cjs/components/BaseGallery/types.d.ts +0 -43
  1330. package/dist/cjs/components/Button/Button.d.ts +0 -22
  1331. package/dist/cjs/components/ButtonGroup/ButtonGroup.d.ts +0 -23
  1332. package/dist/cjs/components/Calendar/Calendar.d.ts +0 -33
  1333. package/dist/cjs/components/CalendarDay/CalendarDay.d.ts +0 -22
  1334. package/dist/cjs/components/CalendarDays/CalendarDays.d.ts +0 -22
  1335. package/dist/cjs/components/CalendarHeader/CalendarHeader.d.ts +0 -24
  1336. package/dist/cjs/components/CalendarRange/CalendarRange.d.ts +0 -19
  1337. package/dist/cjs/components/CalendarTime/CalendarTime.d.ts +0 -11
  1338. package/dist/cjs/components/Card/Card.d.ts +0 -10
  1339. package/dist/cjs/components/CardGrid/CardGrid.d.ts +0 -8
  1340. package/dist/cjs/components/CardScroll/CardScroll.d.ts +0 -15
  1341. package/dist/cjs/components/Cell/Cell.d.ts +0 -50
  1342. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.d.ts +0 -5
  1343. package/dist/cjs/components/Cell/CellDragger/CellDragger.d.ts +0 -6
  1344. package/dist/cjs/components/Cell/useDraggable.d.ts +0 -15
  1345. package/dist/cjs/components/CellButton/CellButton.d.ts +0 -11
  1346. package/dist/cjs/components/Checkbox/Checkbox.d.ts +0 -15
  1347. package/dist/cjs/components/Chip/Chip.d.ts +0 -19
  1348. package/dist/cjs/components/ChipsInput/ChipsInput.d.ts +0 -32
  1349. package/dist/cjs/components/ChipsInput/useChipsInput.d.ts +0 -14
  1350. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts +0 -43
  1351. package/dist/cjs/components/ChipsSelect/useChipsSelect.d.ts +0 -22
  1352. package/dist/cjs/components/ClickPopper/ClickPopper.d.ts +0 -21
  1353. package/dist/cjs/components/ConfigProvider/ConfigProvider.d.ts +0 -18
  1354. package/dist/cjs/components/ConfigProvider/ConfigProviderContext.d.ts +0 -36
  1355. package/dist/cjs/components/ContentCard/ContentCard.d.ts +0 -36
  1356. package/dist/cjs/components/Counter/Counter.d.ts +0 -13
  1357. package/dist/cjs/components/CustomScrollView/CustomScrollView.d.ts +0 -10
  1358. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +0 -61
  1359. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +0 -15
  1360. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.d.ts +0 -47
  1361. package/dist/cjs/components/DateInput/DateInput.d.ts +0 -15
  1362. package/dist/cjs/components/DatePicker/DatePicker.d.ts +0 -23
  1363. package/dist/cjs/components/DateRangeInput/DateRangeInput.d.ts +0 -21
  1364. package/dist/cjs/components/Div/Div.d.ts +0 -9
  1365. package/dist/cjs/components/Dropdown/Dropdown.d.ts +0 -11
  1366. package/dist/cjs/components/DropdownIcon/DropdownIcon.d.ts +0 -3
  1367. package/dist/cjs/components/Epic/Epic.d.ts +0 -11
  1368. package/dist/cjs/components/Epic/ScrollSaver.d.ts +0 -9
  1369. package/dist/cjs/components/File/File.d.ts +0 -13
  1370. package/dist/cjs/components/FixedLayout/FixedLayout.d.ts +0 -21
  1371. package/dist/cjs/components/FocusTrap/FocusTrap.d.ts +0 -11
  1372. package/dist/cjs/components/FocusVisible/FocusVisible.d.ts +0 -10
  1373. package/dist/cjs/components/Footer/Footer.d.ts +0 -8
  1374. package/dist/cjs/components/FormField/FormField.d.ts +0 -36
  1375. package/dist/cjs/components/FormItem/FormItem.d.ts +0 -17
  1376. package/dist/cjs/components/FormLayout/FormLayout.d.ts +0 -8
  1377. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.d.ts +0 -15
  1378. package/dist/cjs/components/FormStatus/FormStatus.d.ts +0 -10
  1379. package/dist/cjs/components/Gallery/Gallery.d.ts +0 -10
  1380. package/dist/cjs/components/Gradient/Gradient.d.ts +0 -10
  1381. package/dist/cjs/components/GridAvatar/GridAvatar.d.ts +0 -15
  1382. package/dist/cjs/components/Group/Group.d.ts +0 -25
  1383. package/dist/cjs/components/Header/Header.d.ts +0 -20
  1384. package/dist/cjs/components/HorizontalCell/HorizontalCell.d.ts +0 -13
  1385. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.d.ts +0 -21
  1386. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.d.ts +0 -8
  1387. package/dist/cjs/components/HoverPopper/HoverPopper.d.ts +0 -29
  1388. package/dist/cjs/components/IconButton/IconButton.d.ts +0 -14
  1389. package/dist/cjs/components/InfoRow/InfoRow.d.ts +0 -9
  1390. package/dist/cjs/components/InitialsAvatar/InitialsAvatar.d.ts +0 -35
  1391. package/dist/cjs/components/Input/Input.d.ts +0 -11
  1392. package/dist/cjs/components/InputLike/InputLike.d.ts +0 -10
  1393. package/dist/cjs/components/InputLike/InputLikeDivider.d.ts +0 -3
  1394. package/dist/cjs/components/Link/Link.d.ts +0 -8
  1395. package/dist/cjs/components/List/List.d.ts +0 -6
  1396. package/dist/cjs/components/List/ListContext.d.ts +0 -4
  1397. package/dist/cjs/components/LocaleProviderContext/LocaleProviderContext.d.ts +0 -2
  1398. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.d.ts +0 -42
  1399. package/dist/cjs/components/ModalCard/ModalCard.d.ts +0 -12
  1400. package/dist/cjs/components/ModalCardBase/ModalCardBase.d.ts +0 -39
  1401. package/dist/cjs/components/ModalDismissButton/ModalDismissButton.d.ts +0 -7
  1402. package/dist/cjs/components/ModalPage/ModalPage.d.ts +0 -39
  1403. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.d.ts +0 -10
  1404. package/dist/cjs/components/ModalRoot/ModalRoot.d.ts +0 -28
  1405. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.d.ts +0 -25
  1406. package/dist/cjs/components/ModalRoot/ModalRootContext.d.ts +0 -20
  1407. package/dist/cjs/components/ModalRoot/ModalRootDesktop.d.ts +0 -28
  1408. package/dist/cjs/components/ModalRoot/constants.d.ts +0 -3
  1409. package/dist/cjs/components/ModalRoot/types.d.ts +0 -60
  1410. package/dist/cjs/components/ModalRoot/useModalManager.d.ts +0 -38
  1411. package/dist/cjs/components/ModalRoot/withModalRootContext.d.ts +0 -5
  1412. package/dist/cjs/components/NativeSelect/NativeSelect.d.ts +0 -19
  1413. package/dist/cjs/components/NavTransitionContext/NavTransitionContext.d.ts +0 -6
  1414. package/dist/cjs/components/Pagination/Pagination.d.ts +0 -45
  1415. package/dist/cjs/components/Panel/Panel.d.ts +0 -12
  1416. package/dist/cjs/components/PanelHeader/PanelHeader.d.ts +0 -31
  1417. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.d.ts +0 -12
  1418. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.d.ts +0 -11
  1419. package/dist/cjs/components/PanelHeaderClose/PanelHeaderClose.d.ts +0 -6
  1420. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.d.ts +0 -11
  1421. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.d.ts +0 -10
  1422. package/dist/cjs/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +0 -20
  1423. package/dist/cjs/components/PanelHeaderSubmit/PanelHeaderSubmit.d.ts +0 -6
  1424. package/dist/cjs/components/PanelSpinner/PanelSpinner.d.ts +0 -9
  1425. package/dist/cjs/components/Placeholder/Placeholder.d.ts +0 -25
  1426. package/dist/cjs/components/PopoutRoot/PopoutRoot.d.ts +0 -10
  1427. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.d.ts +0 -13
  1428. package/dist/cjs/components/Popper/Popper.d.ts +0 -40
  1429. package/dist/cjs/components/Progress/Progress.d.ts +0 -10
  1430. package/dist/cjs/components/PromoBanner/PromoBanner.d.ts +0 -43
  1431. package/dist/cjs/components/PullToRefresh/PullToRefresh.d.ts +0 -22
  1432. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.d.ts +0 -10
  1433. package/dist/cjs/components/Radio/Radio.d.ts +0 -11
  1434. package/dist/cjs/components/RadioGroup/RadioGroup.d.ts +0 -9
  1435. package/dist/cjs/components/RangeSlider/RangeSlider.d.ts +0 -8
  1436. package/dist/cjs/components/RangeSlider/UniversalSlider.d.ts +0 -16
  1437. package/dist/cjs/components/Removable/Removable.d.ts +0 -24
  1438. package/dist/cjs/components/RichCell/RichCell.d.ts +0 -47
  1439. package/dist/cjs/components/RichTooltip/RichTooltip.d.ts +0 -8
  1440. package/dist/cjs/components/Root/Root.d.ts +0 -33
  1441. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.d.ts +0 -8
  1442. package/dist/cjs/components/Search/Search.d.ts +0 -16
  1443. package/dist/cjs/components/SegmentedControl/SegmentedControl.d.ts +0 -20
  1444. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +0 -7
  1445. package/dist/cjs/components/Select/Select.d.ts +0 -18
  1446. package/dist/cjs/components/SelectMimicry/SelectMimicry.d.ts +0 -15
  1447. package/dist/cjs/components/Separator/Separator.d.ts +0 -16
  1448. package/dist/cjs/components/SimpleCell/SimpleCell.d.ts +0 -41
  1449. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.d.ts +0 -12
  1450. package/dist/cjs/components/Slider/Slider.d.ts +0 -7
  1451. package/dist/cjs/components/SliderSwitch/SliderSwitch.d.ts +0 -48
  1452. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.d.ts +0 -11
  1453. package/dist/cjs/components/Snackbar/Snackbar.d.ts +0 -38
  1454. package/dist/cjs/components/Spacing/Spacing.d.ts +0 -23
  1455. package/dist/cjs/components/Spinner/Spinner.d.ts +0 -9
  1456. package/dist/cjs/components/SplitCol/SplitCol.d.ts +0 -25
  1457. package/dist/cjs/components/SplitLayout/SplitLayout.d.ts +0 -18
  1458. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.d.ts +0 -10
  1459. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.d.ts +0 -24
  1460. package/dist/cjs/components/Switch/Switch.d.ts +0 -10
  1461. package/dist/cjs/components/Tabbar/Tabbar.d.ts +0 -13
  1462. package/dist/cjs/components/TabbarItem/TabbarItem.d.ts +0 -23
  1463. package/dist/cjs/components/Tabs/Tabs.d.ts +0 -12
  1464. package/dist/cjs/components/TabsItem/TabsItem.d.ts +0 -10
  1465. package/dist/cjs/components/Tappable/Tappable.d.ts +0 -45
  1466. package/dist/cjs/components/TextTooltip/TextTooltip.d.ts +0 -17
  1467. package/dist/cjs/components/Textarea/Textarea.d.ts +0 -10
  1468. package/dist/cjs/components/Tooltip/Tooltip.d.ts +0 -57
  1469. package/dist/cjs/components/Tooltip/TooltipContainer.d.ts +0 -5
  1470. package/dist/cjs/components/Touch/Touch.d.ts +0 -52
  1471. package/dist/cjs/components/Touch/TouchContext.d.ts +0 -7
  1472. package/dist/cjs/components/Typography/Caption/Caption.d.ts +0 -17
  1473. package/dist/cjs/components/Typography/Footnote/Footnote.d.ts +0 -14
  1474. package/dist/cjs/components/Typography/Headline/Headline.d.ts +0 -16
  1475. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts +0 -13
  1476. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts +0 -15
  1477. package/dist/cjs/components/Typography/Text/Text.d.ts +0 -15
  1478. package/dist/cjs/components/Typography/Title/Title.d.ts +0 -16
  1479. package/dist/cjs/components/UsersStack/UsersStack.d.ts +0 -25
  1480. package/dist/cjs/components/UsersStack/masks.d.ts +0 -1
  1481. package/dist/cjs/components/View/View.d.ts +0 -83
  1482. package/dist/cjs/components/View/ViewInfinite.d.ts +0 -66
  1483. package/dist/cjs/components/View/utils.d.ts +0 -2
  1484. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +0 -12
  1485. package/dist/cjs/components/WriteBar/WriteBar.d.ts +0 -26
  1486. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.d.ts +0 -21
  1487. package/dist/cjs/helpers/avatar.d.ts +0 -5
  1488. package/dist/cjs/helpers/getClassName.d.ts +0 -2
  1489. package/dist/cjs/helpers/getScheme.d.ts +0 -8
  1490. package/dist/cjs/helpers/math.d.ts +0 -5
  1491. package/dist/cjs/helpers/scheme.d.ts +0 -34
  1492. package/dist/cjs/hoc/withAdaptivity.d.ts +0 -13
  1493. package/dist/cjs/hoc/withContext.d.ts +0 -2
  1494. package/dist/cjs/hoc/withInsets.d.ts +0 -3
  1495. package/dist/cjs/hoc/withPlatform.d.ts +0 -3
  1496. package/dist/cjs/hooks/useAdaptivity.d.ts +0 -4
  1497. package/dist/cjs/hooks/useAppearance.d.ts +0 -1
  1498. package/dist/cjs/hooks/useBooleanState.d.ts +0 -6
  1499. package/dist/cjs/hooks/useBridgeAdaptivity.d.ts +0 -6
  1500. package/dist/cjs/hooks/useBrowserInfo.d.ts +0 -2
  1501. package/dist/cjs/hooks/useCalendar.d.ts +0 -19
  1502. package/dist/cjs/hooks/useDateInput.d.ts +0 -30
  1503. package/dist/cjs/hooks/useEffectDev.d.ts +0 -2
  1504. package/dist/cjs/hooks/useEnsuredControl.d.ts +0 -6
  1505. package/dist/cjs/hooks/useEventListener.d.ts +0 -7
  1506. package/dist/cjs/hooks/useExternRef.d.ts +0 -2
  1507. package/dist/cjs/hooks/useFocusVisible.d.ts +0 -6
  1508. package/dist/cjs/hooks/useGlobalEventListener.d.ts +0 -2
  1509. package/dist/cjs/hooks/useInsets.d.ts +0 -8
  1510. package/dist/cjs/hooks/useKeyboard.d.ts +0 -10
  1511. package/dist/cjs/hooks/useKeyboardInputTracker.d.ts +0 -3
  1512. package/dist/cjs/hooks/useObjectMemo.d.ts +0 -2
  1513. package/dist/cjs/hooks/useOrientationChange.d.ts +0 -7
  1514. package/dist/cjs/hooks/usePagination.d.ts +0 -34
  1515. package/dist/cjs/hooks/usePatchChildrenRef.d.ts +0 -6
  1516. package/dist/cjs/hooks/usePlatform.d.ts +0 -2
  1517. package/dist/cjs/hooks/usePrevious.d.ts +0 -1
  1518. package/dist/cjs/hooks/useTimeout.d.ts +0 -4
  1519. package/dist/cjs/hooks/useWaitTransitionFinish.d.ts +0 -3
  1520. package/dist/cjs/index.d.ts +0 -305
  1521. package/dist/cjs/lib/SSR.d.ts +0 -17
  1522. package/dist/cjs/lib/accessibility.d.ts +0 -10
  1523. package/dist/cjs/lib/animate.d.ts +0 -15
  1524. package/dist/cjs/lib/browser.d.ts +0 -11
  1525. package/dist/cjs/lib/calendar.d.ts +0 -14
  1526. package/dist/cjs/lib/callMultiple.d.ts +0 -1
  1527. package/dist/cjs/lib/classNames.d.ts +0 -6
  1528. package/dist/cjs/lib/classScopingMode.d.ts +0 -8
  1529. package/dist/cjs/lib/date.d.ts +0 -29
  1530. package/dist/cjs/lib/dom.d.ts +0 -21
  1531. package/dist/cjs/lib/fx.d.ts +0 -5
  1532. package/dist/cjs/lib/getNavId.d.ts +0 -7
  1533. package/dist/cjs/lib/is.d.ts +0 -1
  1534. package/dist/cjs/lib/isRefObject.d.ts +0 -2
  1535. package/dist/cjs/lib/jsxRuntime.d.ts +0 -8
  1536. package/dist/cjs/lib/offset.d.ts +0 -7
  1537. package/dist/cjs/lib/platform.d.ts +0 -19
  1538. package/dist/cjs/lib/polyfills.d.ts +0 -6
  1539. package/dist/cjs/lib/prefixClass.d.ts +0 -1
  1540. package/dist/cjs/lib/removeObjectKeys.d.ts +0 -1
  1541. package/dist/cjs/lib/select.d.ts +0 -9
  1542. package/dist/cjs/lib/styles.d.ts +0 -1
  1543. package/dist/cjs/lib/supportEvents.d.ts +0 -9
  1544. package/dist/cjs/lib/taptic.d.ts +0 -2
  1545. package/dist/cjs/lib/testing.d.ts +0 -1
  1546. package/dist/cjs/lib/touch.d.ts +0 -9
  1547. package/dist/cjs/lib/useIsomorphicLayoutEffect.d.ts +0 -2
  1548. package/dist/cjs/lib/utils.d.ts +0 -16
  1549. package/dist/cjs/lib/warnOnce.d.ts +0 -2
  1550. package/dist/cjs/tokenized/index.d.ts +0 -126
  1551. package/dist/cjs/types.d.ts +0 -34
  1552. package/dist/cjs/unstable/index.d.ts +0 -17
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/CustomSelect/CustomSelect.tsx"],"names":["React","SelectMimicry","debounce","setRef","multiRef","getTitleFromChildren","classNames","withAdaptivity","withPlatform","CustomSelectOption","getClassName","Input","DropdownIcon","Caption","warnOnce","defaultFilterFn","getFormFieldModeFromSelectType","is","CustomSelectDropdown","SelectType","findIndexAfter","options","startIndex","length","findIndex","option","i","disabled","findIndexBefore","endIndex","result","undefined","warn","checkOptionsValueType","Set","map","item","value","size","CustomSelectComponent","props","createRef","keyboardInput","state","selectedOptionIndex","inputValue","filterFn","filter","setState","opened","focusedOptionIndex","isValidIndex","scrollToElement","onOpen","resetKeyboardInput","onClose","select","index","nativeSelectValue","event","Event","bubbles","selectEl","dispatchEvent","close","open","scrollTo","prevState","type","nextIndex","beforeIndex","focusOptionByIndex","e","Array","prototype","indexOf","call","currentTarget","parentNode","children","preventDefault","selectFocused","key","fullInput","optionIndex","label","toLowerCase","includes","scrollBoxRef","current","contains","target","newSelectedOptionIndex","findSelectedIndex","isControlledOutside","onChange","onInputChange","process","env","NODE_ENV","areOptionsShown","focusOption","onKeyboardInput","renderOption","hovered","selected","onClick","handleOptionClick","onMouseDown","handleOptionDown","onMouseOver","handleOptionHover","element","getRef","placement","popperPlacement","defaultValue","initialValue","Number","center","dropdown","dropdownHeight","offsetHeight","scrollTop","itemTop","offsetTop","itemHeight","prevProps","searchable","stateOptions","before","name","className","getRootRef","popupDirection","sizeY","platform","style","onBlur","onFocus","emptyText","renderDropdown","fetching","icon","dropdownOffsetDistance","fixDropdownWidth","forceDropdownPortal","selectType","default","restProps","getSelectedItem","defaultDropdownContent","resolvedContent","openedClassNames","containerRef","onLabelClick","onInputKeyDown","placeholder","handleKeyDownSelect","handleKeyUp","selectRef","onNativeSelectChange","onPlacementChange","resetFocusedOption","Component","CustomSelect"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { SelectMimicry } from \"../SelectMimicry/SelectMimicry\";\nimport {\n debounce,\n setRef,\n multiRef,\n getTitleFromChildren,\n} from \"../../lib/utils\";\nimport { classNames } from \"../../lib/classNames\";\nimport { NativeSelectProps } from \"../NativeSelect/NativeSelect\";\nimport { withAdaptivity } from \"../../hoc/withAdaptivity\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport {\n CustomSelectOption,\n CustomSelectOptionProps,\n} from \"../CustomSelectOption/CustomSelectOption\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { FormFieldProps } from \"../FormField/FormField\";\nimport { HasPlatform } from \"../../types\";\nimport { Input } from \"../Input/Input\";\nimport { DropdownIcon } from \"../DropdownIcon/DropdownIcon\";\nimport { Caption } from \"../Typography/Caption/Caption\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport {\n defaultFilterFn,\n getFormFieldModeFromSelectType,\n} from \"../../lib/select\";\nimport { is } from \"../../lib/is\";\nimport { Placement } from \"../Popper/Popper\";\nimport { CustomSelectDropdown } from \"../CustomSelectDropdown/CustomSelectDropdown\";\nimport { SelectType } from \"../Select/Select\";\nimport \"./CustomSelect.css\";\n\nconst findIndexAfter = (\n options: CustomSelectOptionInterface[] = [],\n startIndex = -1\n) => {\n if (startIndex >= options.length - 1) {\n return -1;\n }\n return options.findIndex((option, i) => i > startIndex && !option.disabled);\n};\n\nconst findIndexBefore = (\n options: CustomSelectOptionInterface[] = [],\n endIndex: number = options.length\n) => {\n let result = -1;\n if (options === undefined || endIndex <= 0) {\n return result;\n }\n for (let i = endIndex - 1; i >= 0; i--) {\n let option = options[i];\n\n if (!option.disabled) {\n result = i;\n break;\n }\n }\n return result;\n};\n\nconst warn = warnOnce(\"CustomSelect\");\n\nconst checkOptionsValueType = (options: CustomSelectOptionInterface[]) => {\n if (new Set(options.map((item) => typeof item.value)).size > 1) {\n warn(\n \"Некоторые значения ваших опций имеют разные типы. onChange всегда возвращает строковый тип.\",\n \"error\"\n );\n }\n};\n\ntype SelectValue = React.SelectHTMLAttributes<HTMLSelectElement>[\"value\"];\n\nexport interface CustomSelectOptionInterface {\n value: SelectValue;\n label: React.ReactElement | string;\n disabled?: boolean;\n [index: string]: any;\n}\n\ninterface CustomSelectState {\n inputValue?: string;\n opened?: boolean;\n focusedOptionIndex?: number;\n selectedOptionIndex?: number;\n nativeSelectValue?: SelectValue;\n options?: CustomSelectOptionInterface[];\n popperPlacement?: Placement;\n}\n\nexport interface CustomSelectProps\n extends NativeSelectProps,\n HasPlatform,\n FormFieldProps {\n /**\n * Если `true`, то при клике на селект в нём появится текстовое поле для поиска по `options`. По умолчанию поиск\n * производится по `option.label`.\n */\n searchable?: boolean;\n /**\n * Текст, который будет отображен, если приходит пустой `options`.\n */\n emptyText?: string;\n onInputChange?: (\n e: React.ChangeEvent,\n options: CustomSelectOptionInterface[]\n ) => void | CustomSelectOptionInterface[];\n options: CustomSelectOptionInterface[];\n /**\n * Функция для кастомной фильтрации. По умолчанию поиск производится по `option.label`.\n */\n filterFn?:\n | false\n | ((\n value: string,\n option: CustomSelectOptionInterface,\n getOptionLabel?: (\n option: Partial<CustomSelectOptionInterface>\n ) => string\n ) => boolean);\n popupDirection?: \"top\" | \"bottom\";\n /**\n * Рендер-проп для кастомного рендера опции.\n * В объекте аргумента приходят [свойства опции](#/CustomSelectOption?id=props)\n */\n renderOption?: (props: CustomSelectOptionProps) => React.ReactNode;\n /**\n * Рендер-проп для кастомного рендера содержимого дропдауна.\n * В `defaultDropdownContent` содержится список опций в виде скроллящегося блока.\n */\n renderDropdown?: ({\n defaultDropdownContent,\n }: {\n defaultDropdownContent: React.ReactNode;\n }) => React.ReactNode;\n /**\n * Если `true`, то в дропдауне вместо списка опций рисуется спиннер. При переданных `renderDropdown` и `fetching: true`\n * \"победит\" `renderDropdown`.\n */\n fetching?: boolean;\n onClose?: VoidFunction;\n onOpen?: VoidFunction;\n icon?: React.ReactNode;\n dropdownOffsetDistance?: number;\n fixDropdownWidth?: boolean;\n forceDropdownPortal?: boolean;\n selectType?: keyof typeof SelectType;\n}\n\ntype MouseEventHandler = (event: React.MouseEvent<HTMLElement>) => void;\n\nclass CustomSelectComponent extends React.Component<\n CustomSelectProps,\n CustomSelectState\n> {\n static defaultProps: Partial<CustomSelectProps> = {\n searchable: false,\n renderOption({ option, ...props }): React.ReactNode {\n return <CustomSelectOption {...props} />;\n },\n options: [],\n emptyText: \"Ничего не найдено\",\n filterFn: defaultFilterFn,\n icon: <DropdownIcon />,\n dropdownOffsetDistance: 0,\n fixDropdownWidth: true,\n };\n\n public constructor(props: CustomSelectProps) {\n super(props);\n\n const { value, defaultValue } = props;\n\n const initialValue = value !== undefined ? value : defaultValue;\n\n this.keyboardInput = \"\";\n\n if (process.env.NODE_ENV === \"development\") {\n checkOptionsValueType(props.options);\n }\n\n this.state = {\n opened: false,\n focusedOptionIndex: -1,\n selectedOptionIndex: this.findSelectedIndex(props.options, initialValue),\n nativeSelectValue: initialValue,\n options: props.options,\n inputValue: \"\",\n };\n\n if (props.value !== undefined) {\n this.isControlledOutside = true;\n }\n }\n\n private keyboardInput: string;\n private isControlledOutside = false;\n private selectEl: HTMLSelectElement | null = null;\n private readonly scrollBoxRef = React.createRef<HTMLDivElement>();\n private readonly containerRef = React.createRef<HTMLLabelElement>();\n\n private readonly resetKeyboardInput = () => {\n this.keyboardInput = \"\";\n };\n\n private readonly getSelectedItem = () => {\n const { selectedOptionIndex, options } = this.state;\n\n if (!options?.length) {\n return null;\n }\n\n return selectedOptionIndex !== undefined\n ? options[selectedOptionIndex]\n : undefined;\n };\n\n get areOptionsShown() {\n return this.scrollBoxRef.current !== null;\n }\n\n filter = (\n options: CustomSelectProps[\"options\"],\n inputValue: string,\n filterFn: CustomSelectProps[\"filterFn\"]\n ) => {\n return typeof filterFn === \"function\"\n ? options.filter((option) => filterFn(inputValue, option))\n : options;\n };\n\n findSelectedIndex(\n options: CustomSelectOptionInterface[] | undefined,\n value: SelectValue\n ) {\n return (\n options?.findIndex((item) => {\n value = typeof item.value === \"number\" ? Number(value) : value;\n return item.value === value;\n }) ?? -1\n );\n }\n\n open = () => {\n this.setState(\n ({ selectedOptionIndex }) => ({\n opened: true,\n focusedOptionIndex: selectedOptionIndex,\n }),\n () => {\n const { selectedOptionIndex } = this.state;\n\n if (\n selectedOptionIndex !== undefined &&\n this.isValidIndex(selectedOptionIndex)\n ) {\n this.scrollToElement(selectedOptionIndex, true);\n }\n }\n );\n typeof this.props.onOpen === \"function\" && this.props.onOpen();\n };\n\n close = () => {\n this.resetKeyboardInput();\n\n this.setState(() => ({\n inputValue: \"\",\n opened: false,\n focusedOptionIndex: -1,\n options: this.props.options,\n }));\n typeof this.props.onClose === \"function\" && this.props.onClose();\n };\n\n private isValidIndex(index: number) {\n return index >= 0 && index < (this.state.options?.length ?? 0);\n }\n\n selectFocused = () => {\n const { focusedOptionIndex } = this.state;\n\n if (focusedOptionIndex !== undefined) {\n this.select(focusedOptionIndex);\n }\n };\n\n select = (index: number) => {\n if (!this.isValidIndex(index)) {\n return;\n }\n\n const item = this.state.options?.[index];\n\n this.setState(\n {\n nativeSelectValue: item?.value,\n },\n () => {\n const event = new Event(\"change\", { bubbles: true });\n this.selectEl?.dispatchEvent(event);\n }\n );\n this.close();\n };\n\n onClick = () => {\n this.state.opened ? this.close() : this.open();\n };\n\n onFocus = () => {\n const event = new Event(\"focus\");\n this.selectEl?.dispatchEvent(event);\n };\n\n onBlur = () => {\n this.close();\n const event = new Event(\"blur\");\n this.selectEl?.dispatchEvent(event);\n };\n\n private scrollToElement(index: number, center = false) {\n const dropdown = this.scrollBoxRef.current;\n const item = dropdown ? (dropdown.children[index] as HTMLElement) : null;\n\n if (!item || !dropdown) {\n return;\n }\n\n const dropdownHeight = dropdown.offsetHeight;\n const scrollTop = dropdown.scrollTop;\n const itemTop = item.offsetTop;\n const itemHeight = item.offsetHeight;\n\n if (center) {\n dropdown.scrollTop = itemTop - dropdownHeight / 2 + itemHeight / 2;\n } else if (itemTop + itemHeight > dropdownHeight + scrollTop) {\n dropdown.scrollTop = itemTop - dropdownHeight + itemHeight;\n } else if (itemTop < scrollTop) {\n dropdown.scrollTop = itemTop;\n }\n }\n\n focusOptionByIndex = (index: number | undefined, scrollTo = true) => {\n if (\n index === undefined ||\n index < 0 ||\n index > (this.state.options?.length ?? 0) - 1\n ) {\n return;\n }\n\n const option = this.state.options?.[index];\n\n if (option?.disabled) {\n return;\n }\n\n scrollTo && this.scrollToElement(index);\n\n this.setState((prevState) =>\n // Это оптимизация, прежде всего, под `onMouseOver`\n prevState.focusedOptionIndex !== index\n ? {\n focusedOptionIndex: index,\n }\n : null\n );\n };\n\n focusOption = (type: \"next\" | \"prev\") => {\n const { focusedOptionIndex } = this.state;\n let index = focusedOptionIndex;\n\n if (type === \"next\") {\n const nextIndex = findIndexAfter(this.state.options, index);\n index = nextIndex === -1 ? findIndexAfter(this.state.options) : nextIndex; // Следующий за index или первый валидный до index\n } else if (type === \"prev\") {\n const beforeIndex = findIndexBefore(this.state.options, index);\n index =\n beforeIndex === -1 ? findIndexBefore(this.state.options) : beforeIndex; // Предшествующий index или последний валидный после index\n }\n\n this.focusOptionByIndex(index);\n };\n\n handleOptionHover: MouseEventHandler = (e: React.MouseEvent<HTMLElement>) => {\n this.focusOptionByIndex(\n Array.prototype.indexOf.call(\n e.currentTarget.parentNode?.children,\n e.currentTarget\n ),\n false\n );\n };\n\n handleOptionDown: MouseEventHandler = (e: React.MouseEvent<HTMLElement>) => {\n e.preventDefault();\n };\n\n handleOptionClick: MouseEventHandler = (e: React.MouseEvent<HTMLElement>) => {\n const index = Array.prototype.indexOf.call(\n e.currentTarget.parentNode?.children,\n e.currentTarget\n );\n const option = this.state.options?.[index];\n\n if (option && !option.disabled) {\n this.selectFocused();\n }\n };\n\n resetFocusedOption = () => {\n this.setState({ focusedOptionIndex: -1 });\n };\n\n onKeyboardInput = (key: string) => {\n const fullInput = this.keyboardInput + key;\n\n const optionIndex = this.state.options?.findIndex((option) => {\n return getTitleFromChildren(option.label)\n .toLowerCase()\n .includes(fullInput);\n });\n\n if (optionIndex !== undefined && optionIndex > -1) {\n this.focusOptionByIndex(optionIndex);\n }\n\n this.keyboardInput = fullInput;\n };\n\n /**\n * Нужен для правильного поведения обработчика onClick на select. Фильтрует клики, которые были сделаны по\n * выпадающему списку.\n */\n onLabelClick = (e: React.MouseEvent<HTMLLabelElement>) => {\n if (this.scrollBoxRef.current?.contains(e.target as Node)) {\n e.preventDefault();\n }\n };\n\n onNativeSelectChange: React.ChangeEventHandler<HTMLSelectElement> = (e) => {\n const newSelectedOptionIndex = this.findSelectedIndex(\n this.state.options,\n e.currentTarget.value\n );\n\n if (this.state.selectedOptionIndex !== newSelectedOptionIndex) {\n if (!this.isControlledOutside) {\n this.setState({\n selectedOptionIndex: newSelectedOptionIndex,\n });\n }\n this.props.onChange?.(e);\n }\n };\n\n onInputChange: React.ChangeEventHandler<HTMLInputElement> = (e) => {\n if (this.props.onInputChange) {\n const options = this.props.onInputChange(e, this.props.options);\n if (options) {\n if (process.env.NODE_ENV === \"development\") {\n warn(\n \"Этот метод фильтрации устарел. Возвращаемое значение onInputChange будет \" +\n \"проигнорировано в v5.0.0. Для фильтрации обновляйте props.options самостоятельно или используйте свойство filterFn.\"\n );\n }\n this.setState({\n options,\n selectedOptionIndex: this.findSelectedIndex(\n options,\n this.state.nativeSelectValue\n ),\n inputValue: e.target.value,\n });\n } else {\n this.setState({ inputValue: e.target.value });\n }\n } else {\n const options = this.filter(\n this.props.options,\n e.target.value,\n this.props.filterFn\n );\n this.setState({\n options,\n selectedOptionIndex: this.findSelectedIndex(\n options,\n this.state.nativeSelectValue\n ),\n inputValue: e.target.value,\n });\n }\n };\n\n onInputKeyDown: React.KeyboardEventHandler<HTMLInputElement> = (event) => {\n [\"ArrowUp\", \"ArrowDown\", \"Escape\", \"Enter\"].includes(event.key) &&\n this.areOptionsShown &&\n event.preventDefault();\n\n switch (event.key) {\n case \"ArrowUp\":\n this.areOptionsShown && this.focusOption(\"prev\");\n break;\n case \"ArrowDown\":\n this.areOptionsShown && this.focusOption(\"next\");\n break;\n case \"Escape\":\n this.close();\n break;\n case \"Enter\":\n this.areOptionsShown && this.selectFocused();\n break;\n }\n };\n\n handleKeyDownSelect = (event: React.KeyboardEvent) => {\n const { opened } = this.state;\n\n if (event.key.length === 1 && event.key !== \" \") {\n this.onKeyboardInput(event.key);\n return;\n }\n\n [\"ArrowUp\", \"ArrowDown\", \"Escape\", \"Enter\"].includes(event.key) &&\n this.areOptionsShown &&\n event.preventDefault();\n\n switch (event.key) {\n case \"ArrowUp\":\n if (opened) {\n this.areOptionsShown && this.focusOption(\"prev\");\n } else {\n this.open();\n }\n break;\n case \"ArrowDown\":\n if (opened) {\n this.areOptionsShown && this.focusOption(\"next\");\n } else {\n this.open();\n }\n break;\n case \"Escape\":\n this.close();\n break;\n case \"Enter\":\n case \"Spacebar\":\n case \" \":\n if (opened) {\n this.areOptionsShown && this.selectFocused();\n } else {\n this.open();\n }\n break;\n }\n };\n\n handleKeyUp = debounce(this.resetKeyboardInput, 1000);\n\n componentDidUpdate(prevProps: CustomSelectProps) {\n // Внутри useEffect и так is, можно убрать\n if (\n !is(prevProps.value, this.props.value) ||\n prevProps.options !== this.props.options\n ) {\n if (process.env.NODE_ENV === \"development\") {\n checkOptionsValueType(this.props.options);\n }\n\n this.isControlledOutside = this.props.value !== undefined;\n const value =\n this.props.value === undefined\n ? this.state.nativeSelectValue\n : this.props.value;\n const options =\n this.props.searchable && this.state.inputValue !== undefined\n ? this.filter(\n this.props.options,\n this.state.inputValue,\n this.props.filterFn\n )\n : this.props.options;\n this.setState({\n nativeSelectValue: value,\n selectedOptionIndex: this.findSelectedIndex(options, value),\n options,\n });\n }\n }\n\n renderOption = (option: CustomSelectOptionInterface, index: number) => {\n const { focusedOptionIndex, selectedOptionIndex } = this.state;\n const { renderOption } = this.props;\n const hovered = index === focusedOptionIndex;\n const selected = index === selectedOptionIndex;\n\n return (\n <React.Fragment key={`${option.value}`}>\n {renderOption!({\n option,\n hovered,\n children: option.label,\n selected,\n disabled: option.disabled,\n onClick: this.handleOptionClick,\n onMouseDown: this.handleOptionDown,\n // Используем `onMouseOver` вместо `onMouseEnter`.\n // При параметре `searchable`, обновляется \"ребёнок\", из-за чего `onMouseEnter` не срабатывает в следующих кейсах:\n // 1. До загрузки выпадающего списка, курсор мышки находится над произвольным элементом этого списка.\n // > Лечение: только увод курсора мыши и возвращении его обратно вызывает событие `onMouseEnter` на этот элемент.\n // 2. Если это тач-устройство.\n // > Лечение: нужно нажать на какой-нибудь произвольный элемент списка, после чего `onMouseEnter` будет работать на соседние элементы,\n // но не на тот, на который нажали в первый раз.\n // Более подробно по ссылке https://github.com/facebook/react/issues/13956#issuecomment-1082055744\n onMouseOver: this.handleOptionHover,\n })}\n </React.Fragment>\n );\n };\n\n selectRef = (element: HTMLSelectElement) => {\n this.selectEl = element;\n if (this.props.getRef) {\n setRef(element, this.props.getRef);\n }\n };\n\n onPlacementChange = (placement?: Placement) => {\n this.setState(() => ({\n popperPlacement: placement,\n }));\n };\n\n render() {\n const { opened, nativeSelectValue, options: stateOptions } = this.state;\n const {\n before,\n searchable,\n name,\n className,\n getRef,\n getRootRef,\n popupDirection,\n options,\n sizeY,\n platform,\n style,\n onChange,\n onBlur,\n onFocus,\n onClick,\n renderOption,\n children,\n emptyText,\n onInputChange,\n filterFn,\n renderDropdown,\n onOpen,\n onClose,\n fetching,\n icon,\n dropdownOffsetDistance,\n fixDropdownWidth,\n forceDropdownPortal,\n selectType = SelectType.default,\n ...restProps\n } = this.props;\n const selected = this.getSelectedItem();\n const label = selected ? selected.label : undefined;\n\n const defaultDropdownContent =\n stateOptions !== undefined && stateOptions.length > 0 ? (\n stateOptions.map(this.renderOption)\n ) : (\n <Caption vkuiClass=\"CustomSelect__empty\">\n {this.props.emptyText}\n </Caption>\n );\n\n let resolvedContent;\n\n if (typeof renderDropdown === \"function\") {\n resolvedContent = renderDropdown({ defaultDropdownContent });\n } else {\n resolvedContent = defaultDropdownContent;\n }\n\n const openedClassNames = classNames(\n opened && \"Select--open\",\n opened &&\n (dropdownOffsetDistance as number) === 0 &&\n (this.state.popperPlacement?.includes(\"top\")\n ? \"Select--pop-up\"\n : \"Select--pop-down\")\n );\n\n return (\n <label\n vkuiClass={getClassName(\"CustomSelect\", platform)}\n className={className}\n style={style}\n ref={multiRef(this.containerRef, getRootRef)}\n onClick={this.onLabelClick}\n >\n {opened && searchable ? (\n <Input\n {...restProps}\n autoFocus\n onBlur={this.onBlur}\n vkuiClass={openedClassNames}\n value={this.state.inputValue}\n onKeyDown={this.onInputKeyDown}\n onChange={this.onInputChange}\n // TODO Ожидается, что клик поймает нативный select, но его перехватывает Input. К сожалению, это приводит к конфликтам типизации.\n // TODO Нужно перестать пытаться превратить CustomSelect в select. Тогда эта проблема уйдёт.\n // @ts-ignore\n onClick={onClick}\n before={before}\n after={icon}\n placeholder={restProps.placeholder}\n mode={getFormFieldModeFromSelectType(selectType)}\n />\n ) : (\n <SelectMimicry\n {...restProps}\n aria-hidden={true}\n onClick={this.onClick}\n onKeyDown={this.handleKeyDownSelect}\n onKeyUp={this.handleKeyUp}\n onFocus={this.onFocus}\n onBlur={this.onBlur}\n vkuiClass={openedClassNames}\n after={icon}\n selectType={selectType}\n >\n {label}\n </SelectMimicry>\n )}\n <select\n ref={this.selectRef}\n name={name}\n onChange={this.onNativeSelectChange}\n onBlur={onBlur}\n onFocus={onFocus}\n onClick={onClick}\n value={nativeSelectValue}\n aria-hidden={true}\n vkuiClass=\"CustomSelect__control\"\n >\n {options.map((item) => (\n <option key={`${item.value}`} value={item.value} />\n ))}\n </select>\n {opened && (\n <CustomSelectDropdown\n targetRef={this.containerRef}\n placement={popupDirection}\n scrollBoxRef={this.scrollBoxRef}\n onPlacementChange={this.onPlacementChange}\n onMouseLeave={this.resetFocusedOption}\n fetching={fetching}\n offsetDistance={dropdownOffsetDistance}\n sameWidth={fixDropdownWidth}\n forcePortal={forceDropdownPortal}\n >\n {resolvedContent}\n </CustomSelectDropdown>\n )}\n </label>\n );\n }\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelect\n */\nexport const CustomSelect = withPlatform(\n withAdaptivity(CustomSelectComponent, {\n sizeY: true,\n })\n);\n"],"file":"CustomSelect.js"}
1
+ {"version":3,"sources":["../../../src/components/CustomSelect/CustomSelect.tsx"],"names":["React","SelectMimicry","debounce","setRef","multiRef","getTitleFromChildren","classNames","withAdaptivity","withPlatform","CustomSelectOption","getClassName","Input","DropdownIcon","Caption","warnOnce","defaultFilterFn","getFormFieldModeFromSelectType","is","CustomSelectDropdown","SelectType","findIndexAfter","options","startIndex","length","findIndex","option","i","disabled","findIndexBefore","endIndex","result","warn","checkOptionsValueType","Set","map","item","value","size","CustomSelectComponent","props","createRef","keyboardInput","state","selectedOptionIndex","undefined","inputValue","filterFn","filter","setState","opened","focusedOptionIndex","isValidIndex","scrollToElement","onOpen","resetKeyboardInput","onClose","select","index","nativeSelectValue","event","Event","bubbles","selectEl","dispatchEvent","close","open","scrollTo","prevState","type","nextIndex","beforeIndex","focusOptionByIndex","e","Array","prototype","indexOf","call","currentTarget","parentNode","children","preventDefault","selectFocused","key","fullInput","optionIndex","label","toLowerCase","includes","scrollBoxRef","current","contains","target","newSelectedOptionIndex","findSelectedIndex","isControlledOutside","onChange","onInputChange","process","env","NODE_ENV","areOptionsShown","focusOption","onKeyboardInput","renderOption","hovered","selected","onClick","handleOptionClick","onMouseDown","handleOptionDown","onMouseOver","handleOptionHover","element","getRef","placement","popperPlacement","defaultValue","initialValue","Number","center","dropdown","dropdownHeight","offsetHeight","scrollTop","itemTop","offsetTop","itemHeight","prevProps","searchable","stateOptions","before","name","className","getRootRef","popupDirection","sizeY","platform","style","onBlur","onFocus","emptyText","renderDropdown","fetching","icon","dropdownOffsetDistance","fixDropdownWidth","forceDropdownPortal","selectType","default","autoHideScrollbar","autoHideScrollbarDelay","restProps","getSelectedItem","defaultDropdownContent","resolvedContent","openedClassNames","containerRef","onLabelClick","onInputKeyDown","placeholder","handleKeyDownSelect","handleKeyUp","selectRef","onNativeSelectChange","onPlacementChange","resetFocusedOption","Component","CustomSelect"],"mappings":";;;;;;;;;;;;AAAA,OAAO,KAAKA,KAAZ,MAAuB,OAAvB;AACA,SAASC,aAAT;AACA,SACEC,QADF,EAEEC,MAFF,EAGEC,QAHF,EAIEC,oBAJF;AAMA,SAASC,UAAT;AAEA,SAASC,cAAT;AACA,SAASC,YAAT;AACA,SACEC,kBADF;AAIA,SAASC,YAAT;AAGA,SAASC,KAAT;AACA,SAASC,YAAT;AACA,SAASC,OAAT;AACA,SAASC,QAAT;AACA,SACEC,eADF,EAEEC,8BAFF;AAIA,SAASC,EAAT;AAEA,SAASC,oBAAT;AAEA,SAASC,UAAT;;AAGA,IAAMC,cAAc,GAAG,SAAjBA,cAAiB,GAGlB;AAAA,MAFHC,OAEG,uEAFsC,EAEtC;AAAA,MADHC,UACG,uEADU,CAAC,CACX;;AACH,MAAIA,UAAU,IAAID,OAAO,CAACE,MAAR,GAAiB,CAAnC,EAAsC;AACpC,WAAO,CAAC,CAAR;AACD;;AACD,SAAOF,OAAO,CAACG,SAAR,CAAkB,UAACC,MAAD,EAASC,CAAT;AAAA,WAAeA,CAAC,GAAGJ,UAAJ,IAAkB,CAACG,MAAM,CAACE,QAAzC;AAAA,GAAlB,CAAP;AACD,CARD;;AAUA,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,GAGnB;AAAA,MAFHP,OAEG,uEAFsC,EAEtC;AAAA,MADHQ,QACG,uEADgBR,OAAO,CAACE,MACxB;AACH,MAAIO,MAAM,GAAG,CAAC,CAAd;;AACA,MAAID,QAAQ,IAAI,CAAhB,EAAmB;AACjB,WAAOC,MAAP;AACD;;AACD,OAAK,IAAIJ,CAAC,GAAGG,QAAQ,GAAG,CAAxB,EAA2BH,CAAC,IAAI,CAAhC,EAAmCA,CAAC,EAApC,EAAwC;AACtC,QAAID,OAAM,GAAGJ,OAAO,CAACK,CAAD,CAApB;;AAEA,QAAI,CAACD,OAAM,CAACE,QAAZ,EAAsB;AACpBG,MAAAA,MAAM,GAAGJ,CAAT;AACA;AACD;AACF;;AACD,SAAOI,MAAP;AACD,CAjBD;;AAmBA,IAAMC,IAAI,GAAGjB,QAAQ,CAAC,cAAD,CAArB;;AAEA,IAAMkB,qBAAqB,GAAG,SAAxBA,qBAAwB,CAACX,OAAD,EAA4C;AACxE,MAAI,IAAIY,GAAJ,CAAQZ,OAAO,CAACa,GAAR,CAAY,UAACC,IAAD;AAAA,mBAAiBA,IAAI,CAACC,KAAtB;AAAA,GAAZ,CAAR,EAAkDC,IAAlD,GAAyD,CAA7D,EAAgE;AAC9DN,IAAAA,IAAI,CACF,6FADE,EAEF,OAFE,CAAJ;AAID;AACF,CAPD;;IA0FMO,qB;;;;;AAiBJ,iCAAmBC,KAAnB,EAA6C;AAAA;;AAAA;;AAC3C,8BAAMA,KAAN;;AAD2C;;AAAA,0EA4Bf,KA5Be;;AAAA,+DA6BA,IA7BA;;AAAA,gFA8BbvC,KAAK,CAACwC,SAAN,EA9Ba;;AAAA,gFA+BbxC,KAAK,CAACwC,SAAN,EA/Ba;;AAAA,yEAiCP,YAAM;AAC1C,YAAKC,aAAL,GAAqB,EAArB;AACD,KAnC4C;;AAAA,sEAqCV,YAAM;AACvC,wBAAyC,MAAKC,KAA9C;AAAA,UAAQC,mBAAR,eAAQA,mBAAR;AAAA,UAA6BtB,OAA7B,eAA6BA,OAA7B;;AAEA,UAAI,EAACA,OAAD,aAACA,OAAD,eAACA,OAAO,CAAEE,MAAV,CAAJ,EAAsB;AACpB,eAAO,IAAP;AACD;;AAED,aAAOoB,mBAAmB,KAAKC,SAAxB,GACHvB,OAAO,CAACsB,mBAAD,CADJ,GAEHC,SAFJ;AAGD,KA/C4C;;AAAA,6DAqDpC,UACPvB,OADO,EAEPwB,UAFO,EAGPC,QAHO,EAIJ;AACH,aAAO,OAAOA,QAAP,KAAoB,UAApB,GACHzB,OAAO,CAAC0B,MAAR,CAAe,UAACtB,MAAD;AAAA,eAAYqB,QAAQ,CAACD,UAAD,EAAapB,MAAb,CAApB;AAAA,OAAf,CADG,GAEHJ,OAFJ;AAGD,KA7D4C;;AAAA,2DA2EtC,YAAM;AACX,YAAK2B,QAAL,CACE;AAAA,YAAGL,mBAAH,QAAGA,mBAAH;AAAA,eAA8B;AAC5BM,UAAAA,MAAM,EAAE,IADoB;AAE5BC,UAAAA,kBAAkB,EAAEP;AAFQ,SAA9B;AAAA,OADF,EAKE,YAAM;AACJ,YAAQA,mBAAR,GAAgC,MAAKD,KAArC,CAAQC,mBAAR;;AAEA,YACEA,mBAAmB,KAAKC,SAAxB,IACA,MAAKO,YAAL,CAAkBR,mBAAlB,CAFF,EAGE;AACA,gBAAKS,eAAL,CAAqBT,mBAArB,EAA0C,IAA1C;AACD;AACF,OAdH;;AAgBA,aAAO,MAAKJ,KAAL,CAAWc,MAAlB,KAA6B,UAA7B,IAA2C,MAAKd,KAAL,CAAWc,MAAX,EAA3C;AACD,KA7F4C;;AAAA,4DA+FrC,YAAM;AACZ,YAAKC,kBAAL;;AAEA,YAAKN,QAAL,CAAc;AAAA,eAAO;AACnBH,UAAAA,UAAU,EAAE,EADO;AAEnBI,UAAAA,MAAM,EAAE,KAFW;AAGnBC,UAAAA,kBAAkB,EAAE,CAAC,CAHF;AAInB7B,UAAAA,OAAO,EAAE,MAAKkB,KAAL,CAAWlB;AAJD,SAAP;AAAA,OAAd;;AAMA,aAAO,MAAKkB,KAAL,CAAWgB,OAAlB,KAA8B,UAA9B,IAA4C,MAAKhB,KAAL,CAAWgB,OAAX,EAA5C;AACD,KAzG4C;;AAAA,oEA+G7B,YAAM;AACpB,UAAQL,kBAAR,GAA+B,MAAKR,KAApC,CAAQQ,kBAAR;;AAEA,UAAIA,kBAAkB,KAAKN,SAA3B,EAAsC;AACpC,cAAKY,MAAL,CAAYN,kBAAZ;AACD;AACF,KArH4C;;AAAA,6DAuHpC,UAACO,KAAD,EAAmB;AAAA;;AAC1B,UAAI,CAAC,MAAKN,YAAL,CAAkBM,KAAlB,CAAL,EAA+B;AAC7B;AACD;;AAED,UAAMtB,IAAI,0BAAG,MAAKO,KAAL,CAAWrB,OAAd,wDAAG,oBAAqBoC,KAArB,CAAb;;AAEA,YAAKT,QAAL,CACE;AACEU,QAAAA,iBAAiB,EAAEvB,IAAF,aAAEA,IAAF,uBAAEA,IAAI,CAAEC;AAD3B,OADF,EAIE,YAAM;AAAA;;AACJ,YAAMuB,KAAK,GAAG,IAAIC,KAAJ,CAAU,QAAV,EAAoB;AAAEC,UAAAA,OAAO,EAAE;AAAX,SAApB,CAAd;AACA,gCAAKC,QAAL,kEAAeC,aAAf,CAA6BJ,KAA7B;AACD,OAPH;;AASA,YAAKK,KAAL;AACD,KAxI4C;;AAAA,8DA0InC,YAAM;AACd,YAAKtB,KAAL,CAAWO,MAAX,GAAoB,MAAKe,KAAL,EAApB,GAAmC,MAAKC,IAAL,EAAnC;AACD,KA5I4C;;AAAA,8DA8InC,YAAM;AAAA;;AACd,UAAMN,KAAK,GAAG,IAAIC,KAAJ,CAAU,OAAV,CAAd;AACA,+BAAKE,QAAL,oEAAeC,aAAf,CAA6BJ,KAA7B;AACD,KAjJ4C;;AAAA,6DAmJpC,YAAM;AAAA;;AACb,YAAKK,KAAL;;AACA,UAAML,KAAK,GAAG,IAAIC,KAAJ,CAAU,MAAV,CAAd;AACA,+BAAKE,QAAL,oEAAeC,aAAf,CAA6BJ,KAA7B;AACD,KAvJ4C;;AAAA,yEA+KxB,UAACF,KAAD,EAAgD;AAAA;;AAAA,UAApBS,QAAoB,uEAAT,IAAS;;AACnE,UACET,KAAK,KAAKb,SAAV,IACAa,KAAK,GAAG,CADR,IAEAA,KAAK,GAAG,kDAAC,MAAKf,KAAL,CAAWrB,OAAZ,yDAAC,qBAAoBE,MAArB,yEAA+B,CAA/B,IAAoC,CAH9C,EAIE;AACA;AACD;;AAED,UAAME,MAAM,2BAAG,MAAKiB,KAAL,CAAWrB,OAAd,yDAAG,qBAAqBoC,KAArB,CAAf;;AAEA,UAAIhC,MAAJ,aAAIA,MAAJ,eAAIA,MAAM,CAAEE,QAAZ,EAAsB;AACpB;AACD;;AAEDuC,MAAAA,QAAQ,IAAI,MAAKd,eAAL,CAAqBK,KAArB,CAAZ;;AAEA,YAAKT,QAAL,CAAc,UAACmB,SAAD;AAAA,eACZ;AACAA,UAAAA,SAAS,CAACjB,kBAAV,KAAiCO,KAAjC,GACI;AACEP,YAAAA,kBAAkB,EAAEO;AADtB,WADJ,GAII;AANQ;AAAA,OAAd;AAQD,KAxM4C;;AAAA,kEA0M/B,UAACW,IAAD,EAA2B;AACvC,UAAQlB,kBAAR,GAA+B,MAAKR,KAApC,CAAQQ,kBAAR;AACA,UAAIO,KAAK,GAAGP,kBAAZ;;AAEA,UAAIkB,IAAI,KAAK,MAAb,EAAqB;AACnB,YAAMC,SAAS,GAAGjD,cAAc,CAAC,MAAKsB,KAAL,CAAWrB,OAAZ,EAAqBoC,KAArB,CAAhC;AACAA,QAAAA,KAAK,GAAGY,SAAS,KAAK,CAAC,CAAf,GAAmBjD,cAAc,CAAC,MAAKsB,KAAL,CAAWrB,OAAZ,CAAjC,GAAwDgD,SAAhE,CAFmB,CAEwD;AAC5E,OAHD,MAGO,IAAID,IAAI,KAAK,MAAb,EAAqB;AAC1B,YAAME,WAAW,GAAG1C,eAAe,CAAC,MAAKc,KAAL,CAAWrB,OAAZ,EAAqBoC,KAArB,CAAnC;AACAA,QAAAA,KAAK,GACHa,WAAW,KAAK,CAAC,CAAjB,GAAqB1C,eAAe,CAAC,MAAKc,KAAL,CAAWrB,OAAZ,CAApC,GAA2DiD,WAD7D,CAF0B,CAGgD;AAC3E;;AAED,YAAKC,kBAAL,CAAwBd,KAAxB;AACD,KAxN4C;;AAAA,wEA0NN,UAACe,CAAD,EAAsC;AAAA;;AAC3E,YAAKD,kBAAL,CACEE,KAAK,CAACC,SAAN,CAAgBC,OAAhB,CAAwBC,IAAxB,0BACEJ,CAAC,CAACK,aAAF,CAAgBC,UADlB,0DACE,sBAA4BC,QAD9B,EAEEP,CAAC,CAACK,aAFJ,CADF,EAKE,KALF;AAOD,KAlO4C;;AAAA,uEAoOP,UAACL,CAAD,EAAsC;AAC1EA,MAAAA,CAAC,CAACQ,cAAF;AACD,KAtO4C;;AAAA,wEAwON,UAACR,CAAD,EAAsC;AAAA;;AAC3E,UAAMf,KAAK,GAAGgB,KAAK,CAACC,SAAN,CAAgBC,OAAhB,CAAwBC,IAAxB,2BACZJ,CAAC,CAACK,aAAF,CAAgBC,UADJ,2DACZ,uBAA4BC,QADhB,EAEZP,CAAC,CAACK,aAFU,CAAd;AAIA,UAAMpD,MAAM,2BAAG,MAAKiB,KAAL,CAAWrB,OAAd,yDAAG,qBAAqBoC,KAArB,CAAf;;AAEA,UAAIhC,MAAM,IAAI,CAACA,MAAM,CAACE,QAAtB,EAAgC;AAC9B,cAAKsD,aAAL;AACD;AACF,KAlP4C;;AAAA,yEAoPxB,YAAM;AACzB,YAAKjC,QAAL,CAAc;AAAEE,QAAAA,kBAAkB,EAAE,CAAC;AAAvB,OAAd;AACD,KAtP4C;;AAAA,sEAwP3B,UAACgC,GAAD,EAAiB;AAAA;;AACjC,UAAMC,SAAS,GAAG,MAAK1C,aAAL,GAAqByC,GAAvC;AAEA,UAAME,WAAW,2BAAG,MAAK1C,KAAL,CAAWrB,OAAd,yDAAG,qBAAoBG,SAApB,CAA8B,UAACC,MAAD,EAAY;AAC5D,eAAOpB,oBAAoB,CAACoB,MAAM,CAAC4D,KAAR,CAApB,CACJC,WADI,GAEJC,QAFI,CAEKJ,SAFL,CAAP;AAGD,OAJmB,CAApB;;AAMA,UAAIC,WAAW,KAAKxC,SAAhB,IAA6BwC,WAAW,GAAG,CAAC,CAAhD,EAAmD;AACjD,cAAKb,kBAAL,CAAwBa,WAAxB;AACD;;AAED,YAAK3C,aAAL,GAAqB0C,SAArB;AACD,KAtQ4C;;AAAA,mEA4Q9B,UAACX,CAAD,EAA2C;AAAA;;AACxD,mCAAI,MAAKgB,YAAL,CAAkBC,OAAtB,kDAAI,sBAA2BC,QAA3B,CAAoClB,CAAC,CAACmB,MAAtC,CAAJ,EAA2D;AACzDnB,QAAAA,CAAC,CAACQ,cAAF;AACD;AACF,KAhR4C;;AAAA,2EAkRuB,UAACR,CAAD,EAAO;AACzE,UAAMoB,sBAAsB,GAAG,MAAKC,iBAAL,CAC7B,MAAKnD,KAAL,CAAWrB,OADkB,EAE7BmD,CAAC,CAACK,aAAF,CAAgBzC,KAFa,CAA/B;;AAKA,UAAI,MAAKM,KAAL,CAAWC,mBAAX,KAAmCiD,sBAAvC,EAA+D;AAAA;;AAC7D,YAAI,CAAC,MAAKE,mBAAV,EAA+B;AAC7B,gBAAK9C,QAAL,CAAc;AACZL,YAAAA,mBAAmB,EAAEiD;AADT,WAAd;AAGD;;AACD,qDAAKrD,KAAL,EAAWwD,QAAX,gGAAsBvB,CAAtB;AACD;AACF,KAhS4C;;AAAA,oEAkSe,UAACA,CAAD,EAAO;AACjE,UAAI,MAAKjC,KAAL,CAAWyD,aAAf,EAA8B;AAC5B,YAAM3E,QAAO,GAAG,MAAKkB,KAAL,CAAWyD,aAAX,CAAyBxB,CAAzB,EAA4B,MAAKjC,KAAL,CAAWlB,OAAvC,CAAhB;;AACA,YAAIA,QAAJ,EAAa;AACX,cAAI4E,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAA7B,EAA4C;AAC1CpE,YAAAA,IAAI,CACF,8EACE,qHAFA,CAAJ;AAID;;AACD,gBAAKiB,QAAL,CAAc;AACZ3B,YAAAA,OAAO,EAAPA,QADY;AAEZsB,YAAAA,mBAAmB,EAAE,MAAKkD,iBAAL,CACnBxE,QADmB,EAEnB,MAAKqB,KAAL,CAAWgB,iBAFQ,CAFT;AAMZb,YAAAA,UAAU,EAAE2B,CAAC,CAACmB,MAAF,CAASvD;AANT,WAAd;AAQD,SAfD,MAeO;AACL,gBAAKY,QAAL,CAAc;AAAEH,YAAAA,UAAU,EAAE2B,CAAC,CAACmB,MAAF,CAASvD;AAAvB,WAAd;AACD;AACF,OApBD,MAoBO;AACL,YAAMf,SAAO,GAAG,MAAK0B,MAAL,CACd,MAAKR,KAAL,CAAWlB,OADG,EAEdmD,CAAC,CAACmB,MAAF,CAASvD,KAFK,EAGd,MAAKG,KAAL,CAAWO,QAHG,CAAhB;;AAKA,cAAKE,QAAL,CAAc;AACZ3B,UAAAA,OAAO,EAAPA,SADY;AAEZsB,UAAAA,mBAAmB,EAAE,MAAKkD,iBAAL,CACnBxE,SADmB,EAEnB,MAAKqB,KAAL,CAAWgB,iBAFQ,CAFT;AAMZb,UAAAA,UAAU,EAAE2B,CAAC,CAACmB,MAAF,CAASvD;AANT,SAAd;AAQD;AACF,KAtU4C;;AAAA,qEAwUkB,UAACuB,KAAD,EAAW;AACxE,OAAC,SAAD,EAAY,WAAZ,EAAyB,QAAzB,EAAmC,OAAnC,EAA4C4B,QAA5C,CAAqD5B,KAAK,CAACuB,GAA3D,KACE,MAAKkB,eADP,IAEEzC,KAAK,CAACqB,cAAN,EAFF;;AAIA,cAAQrB,KAAK,CAACuB,GAAd;AACE,aAAK,SAAL;AACE,gBAAKkB,eAAL,IAAwB,MAAKC,WAAL,CAAiB,MAAjB,CAAxB;AACA;;AACF,aAAK,WAAL;AACE,gBAAKD,eAAL,IAAwB,MAAKC,WAAL,CAAiB,MAAjB,CAAxB;AACA;;AACF,aAAK,QAAL;AACE,gBAAKrC,KAAL;;AACA;;AACF,aAAK,OAAL;AACE,gBAAKoC,eAAL,IAAwB,MAAKnB,aAAL,EAAxB;AACA;AAZJ;AAcD,KA3V4C;;AAAA,0EA6VvB,UAACtB,KAAD,EAAgC;AACpD,UAAQV,MAAR,GAAmB,MAAKP,KAAxB,CAAQO,MAAR;;AAEA,UAAIU,KAAK,CAACuB,GAAN,CAAU3D,MAAV,KAAqB,CAArB,IAA0BoC,KAAK,CAACuB,GAAN,KAAc,GAA5C,EAAiD;AAC/C,cAAKoB,eAAL,CAAqB3C,KAAK,CAACuB,GAA3B;;AACA;AACD;;AAED,OAAC,SAAD,EAAY,WAAZ,EAAyB,QAAzB,EAAmC,OAAnC,EAA4CK,QAA5C,CAAqD5B,KAAK,CAACuB,GAA3D,KACE,MAAKkB,eADP,IAEEzC,KAAK,CAACqB,cAAN,EAFF;;AAIA,cAAQrB,KAAK,CAACuB,GAAd;AACE,aAAK,SAAL;AACE,cAAIjC,MAAJ,EAAY;AACV,kBAAKmD,eAAL,IAAwB,MAAKC,WAAL,CAAiB,MAAjB,CAAxB;AACD,WAFD,MAEO;AACL,kBAAKpC,IAAL;AACD;;AACD;;AACF,aAAK,WAAL;AACE,cAAIhB,MAAJ,EAAY;AACV,kBAAKmD,eAAL,IAAwB,MAAKC,WAAL,CAAiB,MAAjB,CAAxB;AACD,WAFD,MAEO;AACL,kBAAKpC,IAAL;AACD;;AACD;;AACF,aAAK,QAAL;AACE,gBAAKD,KAAL;;AACA;;AACF,aAAK,OAAL;AACA,aAAK,UAAL;AACA,aAAK,GAAL;AACE,cAAIf,MAAJ,EAAY;AACV,kBAAKmD,eAAL,IAAwB,MAAKnB,aAAL,EAAxB;AACD,WAFD,MAEO;AACL,kBAAKhB,IAAL;AACD;;AACD;AA1BJ;AA4BD,KArY4C;;AAAA,kEAuY/B/D,QAAQ,CAAC,MAAKoD,kBAAN,EAA0B,IAA1B,CAvYuB;;AAAA,mEAwa9B,UAAC7B,MAAD,EAAsCgC,KAAtC,EAAwD;AACrE,yBAAoD,MAAKf,KAAzD;AAAA,UAAQQ,kBAAR,gBAAQA,kBAAR;AAAA,UAA4BP,mBAA5B,gBAA4BA,mBAA5B;AACA,UAAQ4D,YAAR,GAAyB,MAAKhE,KAA9B,CAAQgE,YAAR;AACA,UAAMC,OAAO,GAAG/C,KAAK,KAAKP,kBAA1B;AACA,UAAMuD,QAAQ,GAAGhD,KAAK,KAAKd,mBAA3B;AAEA,aACE,oBAAC,KAAD,CAAO,QAAP;AAAgB,QAAA,GAAG,YAAKlB,MAAM,CAACW,KAAZ;AAAnB,SACGmE,YAAY,CAAE;AACb9E,QAAAA,MAAM,EAANA,MADa;AAEb+E,QAAAA,OAAO,EAAPA,OAFa;AAGbzB,QAAAA,QAAQ,EAAEtD,MAAM,CAAC4D,KAHJ;AAIboB,QAAAA,QAAQ,EAARA,QAJa;AAKb9E,QAAAA,QAAQ,EAAEF,MAAM,CAACE,QALJ;AAMb+E,QAAAA,OAAO,EAAE,MAAKC,iBAND;AAObC,QAAAA,WAAW,EAAE,MAAKC,gBAPL;AAQb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACAC,QAAAA,WAAW,EAAE,MAAKC;AAhBL,OAAF,CADf,CADF;AAsBD,KApc4C;;AAAA,gEAscjC,UAACC,OAAD,EAAgC;AAC1C,YAAKlD,QAAL,GAAgBkD,OAAhB;;AACA,UAAI,MAAKzE,KAAL,CAAW0E,MAAf,EAAuB;AACrB9G,QAAAA,MAAM,CAAC6G,OAAD,EAAU,MAAKzE,KAAL,CAAW0E,MAArB,CAAN;AACD;AACF,KA3c4C;;AAAA,wEA6czB,UAACC,SAAD,EAA2B;AAC7C,YAAKlE,QAAL,CAAc;AAAA,eAAO;AACnBmE,UAAAA,eAAe,EAAED;AADE,SAAP;AAAA,OAAd;AAGD,KAjd4C;;AAG3C,QAAQ9E,KAAR,GAAgCG,KAAhC,CAAQH,KAAR;AAAA,QAAegF,YAAf,GAAgC7E,KAAhC,CAAe6E,YAAf;AAEA,QAAMC,YAAY,GAAGjF,KAAK,KAAKQ,SAAV,GAAsBR,KAAtB,GAA8BgF,YAAnD;AAEA,UAAK3E,aAAL,GAAqB,EAArB;;AAEA,QAAIwD,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAA7B,EAA4C;AAC1CnE,MAAAA,qBAAqB,CAACO,KAAK,CAAClB,OAAP,CAArB;AACD;;AAED,UAAKqB,KAAL,GAAa;AACXO,MAAAA,MAAM,EAAE,KADG;AAEXC,MAAAA,kBAAkB,EAAE,CAAC,CAFV;AAGXP,MAAAA,mBAAmB,EAAE,MAAKkD,iBAAL,CAAuBtD,KAAK,CAAClB,OAA7B,EAAsCgG,YAAtC,CAHV;AAIX3D,MAAAA,iBAAiB,EAAE2D,YAJR;AAKXhG,MAAAA,OAAO,EAAEkB,KAAK,CAAClB,OALJ;AAMXwB,MAAAA,UAAU,EAAE;AAND,KAAb;;AASA,QAAIN,KAAK,CAACH,KAAN,KAAgBQ,SAApB,EAA+B;AAC7B,YAAKkD,mBAAL,GAA2B,IAA3B;AACD;;AAxB0C;AAyB5C;;;;SAwBD,eAAsB;AACpB,aAAO,KAAKN,YAAL,CAAkBC,OAAlB,KAA8B,IAArC;AACD;;;WAYD,2BACEpE,OADF,EAEEe,KAFF,EAGE;AAAA;;AACA,mCACEf,OADF,aACEA,OADF,uBACEA,OAAO,CAAEG,SAAT,CAAmB,UAACW,IAAD,EAAU;AAC3BC,QAAAA,KAAK,GAAG,OAAOD,IAAI,CAACC,KAAZ,KAAsB,QAAtB,GAAiCkF,MAAM,CAAClF,KAAD,CAAvC,GAAiDA,KAAzD;AACA,eAAOD,IAAI,CAACC,KAAL,KAAeA,KAAtB;AACD,OAHD,CADF,mEAIQ,CAAC,CAJT;AAMD;;;WAkCD,sBAAqBqB,KAArB,EAAoC;AAAA;;AAClC,aAAOA,KAAK,IAAI,CAAT,IAAcA,KAAK,sDAAI,KAAKf,KAAL,CAAWrB,OAAf,yDAAI,qBAAoBE,MAAxB,2EAAkC,CAAlC,CAA1B;AACD;;;WA4CD,yBAAwBkC,KAAxB,EAAuD;AAAA,UAAhB8D,MAAgB,uEAAP,KAAO;AACrD,UAAMC,QAAQ,GAAG,KAAKhC,YAAL,CAAkBC,OAAnC;AACA,UAAMtD,IAAI,GAAGqF,QAAQ,GAAIA,QAAQ,CAACzC,QAAT,CAAkBtB,KAAlB,CAAJ,GAA+C,IAApE;;AAEA,UAAI,CAACtB,IAAD,IAAS,CAACqF,QAAd,EAAwB;AACtB;AACD;;AAED,UAAMC,cAAc,GAAGD,QAAQ,CAACE,YAAhC;AACA,UAAMC,SAAS,GAAGH,QAAQ,CAACG,SAA3B;AACA,UAAMC,OAAO,GAAGzF,IAAI,CAAC0F,SAArB;AACA,UAAMC,UAAU,GAAG3F,IAAI,CAACuF,YAAxB;;AAEA,UAAIH,MAAJ,EAAY;AACVC,QAAAA,QAAQ,CAACG,SAAT,GAAqBC,OAAO,GAAGH,cAAc,GAAG,CAA3B,GAA+BK,UAAU,GAAG,CAAjE;AACD,OAFD,MAEO,IAAIF,OAAO,GAAGE,UAAV,GAAuBL,cAAc,GAAGE,SAA5C,EAAuD;AAC5DH,QAAAA,QAAQ,CAACG,SAAT,GAAqBC,OAAO,GAAGH,cAAV,GAA2BK,UAAhD;AACD,OAFM,MAEA,IAAIF,OAAO,GAAGD,SAAd,EAAyB;AAC9BH,QAAAA,QAAQ,CAACG,SAAT,GAAqBC,OAArB;AACD;AACF;;;WA4ND,4BAAmBG,SAAnB,EAAiD;AAC/C;AACA,UACE,CAAC9G,EAAE,CAAC8G,SAAS,CAAC3F,KAAX,EAAkB,KAAKG,KAAL,CAAWH,KAA7B,CAAH,IACA2F,SAAS,CAAC1G,OAAV,KAAsB,KAAKkB,KAAL,CAAWlB,OAFnC,EAGE;AACA,YAAI4E,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAA7B,EAA4C;AAC1CnE,UAAAA,qBAAqB,CAAC,KAAKO,KAAL,CAAWlB,OAAZ,CAArB;AACD;;AAED,aAAKyE,mBAAL,GAA2B,KAAKvD,KAAL,CAAWH,KAAX,KAAqBQ,SAAhD;;AACA,YAAMR,MAAK,GACT,KAAKG,KAAL,CAAWH,KAAX,KAAqBQ,SAArB,GACI,KAAKF,KAAL,CAAWgB,iBADf,GAEI,KAAKnB,KAAL,CAAWH,KAHjB;;AAIA,YAAMf,SAAO,GACX,KAAKkB,KAAL,CAAWyF,UAAX,IAAyB,KAAKtF,KAAL,CAAWG,UAAX,KAA0BD,SAAnD,GACI,KAAKG,MAAL,CACE,KAAKR,KAAL,CAAWlB,OADb,EAEE,KAAKqB,KAAL,CAAWG,UAFb,EAGE,KAAKN,KAAL,CAAWO,QAHb,CADJ,GAMI,KAAKP,KAAL,CAAWlB,OAPjB;;AAQA,aAAK2B,QAAL,CAAc;AACZU,UAAAA,iBAAiB,EAAEtB,MADP;AAEZO,UAAAA,mBAAmB,EAAE,KAAKkD,iBAAL,CAAuBxE,SAAvB,EAAgCe,MAAhC,CAFT;AAGZf,UAAAA,OAAO,EAAPA;AAHY,SAAd;AAKD;AACF;;;WA6CD,kBAAS;AAAA;;AACP,yBAA6D,KAAKqB,KAAlE;AAAA,UAAQO,MAAR,gBAAQA,MAAR;AAAA,UAAgBS,iBAAhB,gBAAgBA,iBAAhB;AAAA,UAA4CuE,YAA5C,gBAAmC5G,OAAnC;;AACA,yBAiCI,KAAKkB,KAjCT;AAAA,UACE2F,MADF,gBACEA,MADF;AAAA,UAEEF,UAFF,gBAEEA,UAFF;AAAA,UAGEG,IAHF,gBAGEA,IAHF;AAAA,UAIEC,SAJF,gBAIEA,SAJF;AAAA,UAKEnB,MALF,gBAKEA,MALF;AAAA,UAMEoB,UANF,gBAMEA,UANF;AAAA,UAOEC,cAPF,gBAOEA,cAPF;AAAA,UAQEjH,OARF,gBAQEA,OARF;AAAA,UASEkH,KATF,gBASEA,KATF;AAAA,UAUEC,QAVF,gBAUEA,QAVF;AAAA,UAWEC,KAXF,gBAWEA,KAXF;AAAA,UAYE1C,QAZF,gBAYEA,QAZF;AAAA,UAaE2C,MAbF,gBAaEA,MAbF;AAAA,UAcEC,OAdF,gBAcEA,OAdF;AAAA,UAeEjC,OAfF,gBAeEA,OAfF;AAAA,UAgBEH,YAhBF,gBAgBEA,YAhBF;AAAA,UAiBExB,QAjBF,gBAiBEA,QAjBF;AAAA,UAkBE6D,SAlBF,gBAkBEA,SAlBF;AAAA,UAmBE5C,aAnBF,gBAmBEA,aAnBF;AAAA,UAoBElD,QApBF,gBAoBEA,QApBF;AAAA,UAqBE+F,cArBF,gBAqBEA,cArBF;AAAA,UAsBExF,MAtBF,gBAsBEA,MAtBF;AAAA,UAuBEE,OAvBF,gBAuBEA,OAvBF;AAAA,UAwBEuF,QAxBF,gBAwBEA,QAxBF;AAAA,UAyBEC,IAzBF,gBAyBEA,IAzBF;AAAA,UA0BEC,sBA1BF,gBA0BEA,sBA1BF;AAAA,UA2BEC,gBA3BF,gBA2BEA,gBA3BF;AAAA,UA4BEC,mBA5BF,gBA4BEA,mBA5BF;AAAA,+CA6BEC,UA7BF;AAAA,UA6BEA,UA7BF,sCA6BehI,UAAU,CAACiI,OA7B1B;AAAA,UA8BEC,iBA9BF,gBA8BEA,iBA9BF;AAAA,UA+BEC,sBA/BF,gBA+BEA,sBA/BF;AAAA,UAgCKC,SAhCL;;AAkCA,UAAM9C,QAAQ,GAAG,KAAK+C,eAAL,EAAjB;AACA,UAAMnE,KAAK,GAAGoB,QAAQ,GAAGA,QAAQ,CAACpB,KAAZ,GAAoBzC,SAA1C;AAEA,UAAM6G,sBAAsB,GAC1BxB,YAAY,KAAKrF,SAAjB,IAA8BqF,YAAY,CAAC1G,MAAb,GAAsB,CAApD,GACE0G,YAAY,CAAC/F,GAAb,CAAiB,KAAKqE,YAAtB,CADF,GAGE,oBAAC,OAAD;AAAS,QAAA,SAAS,EAAC;AAAnB,SACG,KAAKhE,KAAL,CAAWqG,SADd,CAJJ;AASA,UAAIc,eAAJ;;AAEA,UAAI,OAAOb,cAAP,KAA0B,UAA9B,EAA0C;AACxCa,QAAAA,eAAe,GAAGb,cAAc,CAAC;AAAEY,UAAAA,sBAAsB,EAAtBA;AAAF,SAAD,CAAhC;AACD,OAFD,MAEO;AACLC,QAAAA,eAAe,GAAGD,sBAAlB;AACD;;AAED,UAAME,gBAAgB,GAAGrJ,UAAU,CACjC2C,MAAM,IAAI,cADuB,EAEjCA,MAAM,IACH+F,sBAAD,KAAuC,CADzC,KAEG,8BAAKtG,KAAL,CAAWyE,eAAX,wEAA4B5B,QAA5B,CAAqC,KAArC,IACG,gBADH,GAEG,kBAJN,CAFiC,CAAnC;AASA,aACE;AACE,QAAA,SAAS,EAAE7E,YAAY,CAAC,cAAD,EAAiB8H,QAAjB,CADzB;AAEE,QAAA,SAAS,EAAEJ,SAFb;AAGE,QAAA,KAAK,EAAEK,KAHT;AAIE,QAAA,GAAG,EAAErI,QAAQ,CAAC,KAAKwJ,YAAN,EAAoBvB,UAApB,CAJf;AAKE,QAAA,OAAO,EAAE,KAAKwB;AALhB,SAOG5G,MAAM,IAAI+E,UAAV,GACC,oBAAC,KAAD,eACMuB,SADN;AAEE,QAAA,SAAS,MAFX;AAGE,QAAA,MAAM,EAAE,KAAKb,MAHf;AAIE,QAAA,SAAS,EAAEiB,gBAJb;AAKE,QAAA,KAAK,EAAE,KAAKjH,KAAL,CAAWG,UALpB;AAME,QAAA,SAAS,EAAE,KAAKiH,cANlB;AAOE,QAAA,QAAQ,EAAE,KAAK9D,aAPjB,CAQE;AACA;AACA;AAVF;AAWE,QAAA,OAAO,EAAEU,OAXX;AAYE,QAAA,MAAM,EAAEwB,MAZV;AAaE,QAAA,KAAK,EAAEa,IAbT;AAcE,QAAA,WAAW,EAAEQ,SAAS,CAACQ,WAdzB;AAeE,QAAA,IAAI,EAAE/I,8BAA8B,CAACmI,UAAD;AAftC,SADD,GAmBC,oBAAC,aAAD,eACMI,SADN;AAEE,uBAAa,IAFf;AAGE,QAAA,OAAO,EAAE,KAAK7C,OAHhB;AAIE,QAAA,SAAS,EAAE,KAAKsD,mBAJlB;AAKE,QAAA,OAAO,EAAE,KAAKC,WALhB;AAME,QAAA,OAAO,EAAE,KAAKtB,OANhB;AAOE,QAAA,MAAM,EAAE,KAAKD,MAPf;AAQE,QAAA,SAAS,EAAEiB,gBARb;AASE,QAAA,KAAK,EAAEZ,IATT;AAUE,QAAA,UAAU,EAAEI;AAVd,UAYG9D,KAZH,CA1BJ,EAyCE;AACE,QAAA,GAAG,EAAE,KAAK6E,SADZ;AAEE,QAAA,IAAI,EAAE/B,IAFR;AAGE,QAAA,QAAQ,EAAE,KAAKgC,oBAHjB;AAIE,QAAA,MAAM,EAAEzB,MAJV;AAKE,QAAA,OAAO,EAAEC,OALX;AAME,QAAA,OAAO,EAAEjC,OANX;AAOE,QAAA,KAAK,EAAEhD,iBAPT;AAQE,uBAAa,IARf;AASE,QAAA,SAAS,EAAC;AATZ,SAWGrC,OAAO,CAACa,GAAR,CAAY,UAACC,IAAD;AAAA,eACX;AAAQ,UAAA,GAAG,YAAKA,IAAI,CAACC,KAAV,CAAX;AAA8B,UAAA,KAAK,EAAED,IAAI,CAACC;AAA1C,UADW;AAAA,OAAZ,CAXH,CAzCF,EAwDGa,MAAM,IACL,oBAAC,oBAAD;AACE,QAAA,SAAS,EAAE,KAAK2G,YADlB;AAEE,QAAA,SAAS,EAAEtB,cAFb;AAGE,QAAA,YAAY,EAAE,KAAK9C,YAHrB;AAIE,QAAA,iBAAiB,EAAE,KAAK4E,iBAJ1B;AAKE,QAAA,YAAY,EAAE,KAAKC,kBALrB;AAME,QAAA,QAAQ,EAAEvB,QANZ;AAOE,QAAA,cAAc,EAAEE,sBAPlB;AAQE,QAAA,SAAS,EAAEC,gBARb;AASE,QAAA,WAAW,EAAEC,mBATf;AAUE,QAAA,iBAAiB,EAAEG,iBAVrB;AAWE,QAAA,sBAAsB,EAAEC,sBAX1B;AAYE,QAAA,cAAc,EAAE,KAAK9D;AAZvB,SAcGkE,eAdH,CAzDJ,CADF;AA6ED;;;;EAlnBiC1J,KAAK,CAACsK,S;AAqnB1C;AACA;AACA;;;gBAvnBMhI,qB,kBAI8C;AAChD0F,EAAAA,UAAU,EAAE,KADoC;AAEhDzB,EAAAA,YAFgD,+BAEI;AAAA,QAArC9E,MAAqC,SAArCA,MAAqC;AAAA,QAA1Bc,KAA0B;;AAClD,WAAO,oBAAC,kBAAD,EAAwBA,KAAxB,CAAP;AACD,GAJ+C;AAKhDlB,EAAAA,OAAO,EAAE,EALuC;AAMhDuH,EAAAA,SAAS,EAAE,mBANqC;AAOhD9F,EAAAA,QAAQ,EAAE/B,eAPsC;AAQhDgI,EAAAA,IAAI,EAAE,oBAAC,YAAD,OAR0C;AAShDC,EAAAA,sBAAsB,EAAE,CATwB;AAUhDC,EAAAA,gBAAgB,EAAE;AAV8B,C;;AAonBpD,OAAO,IAAMsB,YAAY,GAAG/J,YAAY,CACtCD,cAAc,CAAC+B,qBAAD,EAAwB;AACpCiG,EAAAA,KAAK,EAAE;AAD6B,CAAxB,CADwB,CAAjC","sourcesContent":["import * as React from \"react\";\nimport { SelectMimicry } from \"../SelectMimicry/SelectMimicry\";\nimport {\n debounce,\n setRef,\n multiRef,\n getTitleFromChildren,\n} from \"../../lib/utils\";\nimport { classNames } from \"../../lib/classNames\";\nimport { NativeSelectProps } from \"../NativeSelect/NativeSelect\";\nimport { withAdaptivity } from \"../../hoc/withAdaptivity\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport {\n CustomSelectOption,\n CustomSelectOptionProps,\n} from \"../CustomSelectOption/CustomSelectOption\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { FormFieldProps } from \"../FormField/FormField\";\nimport { HasPlatform } from \"../../types\";\nimport { Input } from \"../Input/Input\";\nimport { DropdownIcon } from \"../DropdownIcon/DropdownIcon\";\nimport { Caption } from \"../Typography/Caption/Caption\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport {\n defaultFilterFn,\n getFormFieldModeFromSelectType,\n} from \"../../lib/select\";\nimport { is } from \"../../lib/is\";\nimport { Placement } from \"../Popper/Popper\";\nimport { CustomSelectDropdown } from \"../CustomSelectDropdown/CustomSelectDropdown\";\nimport { TrackerOptionsProps } from \"../CustomScrollView/useTrackerVisibility\";\nimport { SelectType } from \"../Select/Select\";\nimport \"./CustomSelect.css\";\n\nconst findIndexAfter = (\n options: CustomSelectOptionInterface[] = [],\n startIndex = -1\n) => {\n if (startIndex >= options.length - 1) {\n return -1;\n }\n return options.findIndex((option, i) => i > startIndex && !option.disabled);\n};\n\nconst findIndexBefore = (\n options: CustomSelectOptionInterface[] = [],\n endIndex: number = options.length\n) => {\n let result = -1;\n if (endIndex <= 0) {\n return result;\n }\n for (let i = endIndex - 1; i >= 0; i--) {\n let option = options[i];\n\n if (!option.disabled) {\n result = i;\n break;\n }\n }\n return result;\n};\n\nconst warn = warnOnce(\"CustomSelect\");\n\nconst checkOptionsValueType = (options: CustomSelectOptionInterface[]) => {\n if (new Set(options.map((item) => typeof item.value)).size > 1) {\n warn(\n \"Некоторые значения ваших опций имеют разные типы. onChange всегда возвращает строковый тип.\",\n \"error\"\n );\n }\n};\n\ntype SelectValue = React.SelectHTMLAttributes<HTMLSelectElement>[\"value\"];\n\nexport interface CustomSelectOptionInterface {\n value: SelectValue;\n label: React.ReactElement | string;\n disabled?: boolean;\n [index: string]: any;\n}\n\ninterface CustomSelectState {\n inputValue?: string;\n opened?: boolean;\n focusedOptionIndex?: number;\n selectedOptionIndex?: number;\n nativeSelectValue?: SelectValue;\n options?: CustomSelectOptionInterface[];\n popperPlacement?: Placement;\n}\n\nexport interface CustomSelectProps\n extends NativeSelectProps,\n HasPlatform,\n FormFieldProps,\n TrackerOptionsProps {\n /**\n * Если `true`, то при клике на селект в нём появится текстовое поле для поиска по `options`. По умолчанию поиск\n * производится по `option.label`.\n */\n searchable?: boolean;\n /**\n * Текст, который будет отображен, если приходит пустой `options`.\n */\n emptyText?: string;\n onInputChange?: (\n e: React.ChangeEvent,\n options: CustomSelectOptionInterface[]\n ) => void | CustomSelectOptionInterface[];\n options: CustomSelectOptionInterface[];\n /**\n * Функция для кастомной фильтрации. По умолчанию поиск производится по `option.label`.\n */\n filterFn?:\n | false\n | ((\n value: string,\n option: CustomSelectOptionInterface,\n getOptionLabel?: (\n option: Partial<CustomSelectOptionInterface>\n ) => string\n ) => boolean);\n popupDirection?: \"top\" | \"bottom\";\n /**\n * Рендер-проп для кастомного рендера опции.\n * В объекте аргумента приходят [свойства опции](https://vkcom.github.io/VKUI/#/CustomSelectOption?id=props)\n */\n renderOption?: (props: CustomSelectOptionProps) => React.ReactNode;\n /**\n * Рендер-проп для кастомного рендера содержимого дропдауна.\n * В `defaultDropdownContent` содержится список опций в виде скроллящегося блока.\n */\n renderDropdown?: ({\n defaultDropdownContent,\n }: {\n defaultDropdownContent: React.ReactNode;\n }) => React.ReactNode;\n /**\n * Если `true`, то в дропдауне вместо списка опций рисуется спиннер. При переданных `renderDropdown` и `fetching: true`\n * \"победит\" `renderDropdown`.\n */\n fetching?: boolean;\n onClose?: VoidFunction;\n onOpen?: VoidFunction;\n icon?: React.ReactNode;\n dropdownOffsetDistance?: number;\n fixDropdownWidth?: boolean;\n forceDropdownPortal?: boolean;\n selectType?: keyof typeof SelectType;\n}\n\ntype MouseEventHandler = (event: React.MouseEvent<HTMLElement>) => void;\n\nclass CustomSelectComponent extends React.Component<\n CustomSelectProps,\n CustomSelectState\n> {\n static defaultProps: Partial<CustomSelectProps> = {\n searchable: false,\n renderOption({ option, ...props }): React.ReactNode {\n return <CustomSelectOption {...props} />;\n },\n options: [],\n emptyText: \"Ничего не найдено\",\n filterFn: defaultFilterFn,\n icon: <DropdownIcon />,\n dropdownOffsetDistance: 0,\n fixDropdownWidth: true,\n };\n\n public constructor(props: CustomSelectProps) {\n super(props);\n\n const { value, defaultValue } = props;\n\n const initialValue = value !== undefined ? value : defaultValue;\n\n this.keyboardInput = \"\";\n\n if (process.env.NODE_ENV === \"development\") {\n checkOptionsValueType(props.options);\n }\n\n this.state = {\n opened: false,\n focusedOptionIndex: -1,\n selectedOptionIndex: this.findSelectedIndex(props.options, initialValue),\n nativeSelectValue: initialValue,\n options: props.options,\n inputValue: \"\",\n };\n\n if (props.value !== undefined) {\n this.isControlledOutside = true;\n }\n }\n\n private keyboardInput: string;\n private isControlledOutside = false;\n private selectEl: HTMLSelectElement | null = null;\n private readonly scrollBoxRef = React.createRef<HTMLDivElement>();\n private readonly containerRef = React.createRef<HTMLLabelElement>();\n\n private readonly resetKeyboardInput = () => {\n this.keyboardInput = \"\";\n };\n\n private readonly getSelectedItem = () => {\n const { selectedOptionIndex, options } = this.state;\n\n if (!options?.length) {\n return null;\n }\n\n return selectedOptionIndex !== undefined\n ? options[selectedOptionIndex]\n : undefined;\n };\n\n get areOptionsShown() {\n return this.scrollBoxRef.current !== null;\n }\n\n filter = (\n options: CustomSelectProps[\"options\"],\n inputValue: string,\n filterFn: CustomSelectProps[\"filterFn\"]\n ) => {\n return typeof filterFn === \"function\"\n ? options.filter((option) => filterFn(inputValue, option))\n : options;\n };\n\n findSelectedIndex(\n options: CustomSelectOptionInterface[] | undefined,\n value: SelectValue\n ) {\n return (\n options?.findIndex((item) => {\n value = typeof item.value === \"number\" ? Number(value) : value;\n return item.value === value;\n }) ?? -1\n );\n }\n\n open = () => {\n this.setState(\n ({ selectedOptionIndex }) => ({\n opened: true,\n focusedOptionIndex: selectedOptionIndex,\n }),\n () => {\n const { selectedOptionIndex } = this.state;\n\n if (\n selectedOptionIndex !== undefined &&\n this.isValidIndex(selectedOptionIndex)\n ) {\n this.scrollToElement(selectedOptionIndex, true);\n }\n }\n );\n typeof this.props.onOpen === \"function\" && this.props.onOpen();\n };\n\n close = () => {\n this.resetKeyboardInput();\n\n this.setState(() => ({\n inputValue: \"\",\n opened: false,\n focusedOptionIndex: -1,\n options: this.props.options,\n }));\n typeof this.props.onClose === \"function\" && this.props.onClose();\n };\n\n private isValidIndex(index: number) {\n return index >= 0 && index < (this.state.options?.length ?? 0);\n }\n\n selectFocused = () => {\n const { focusedOptionIndex } = this.state;\n\n if (focusedOptionIndex !== undefined) {\n this.select(focusedOptionIndex);\n }\n };\n\n select = (index: number) => {\n if (!this.isValidIndex(index)) {\n return;\n }\n\n const item = this.state.options?.[index];\n\n this.setState(\n {\n nativeSelectValue: item?.value,\n },\n () => {\n const event = new Event(\"change\", { bubbles: true });\n this.selectEl?.dispatchEvent(event);\n }\n );\n this.close();\n };\n\n onClick = () => {\n this.state.opened ? this.close() : this.open();\n };\n\n onFocus = () => {\n const event = new Event(\"focus\");\n this.selectEl?.dispatchEvent(event);\n };\n\n onBlur = () => {\n this.close();\n const event = new Event(\"blur\");\n this.selectEl?.dispatchEvent(event);\n };\n\n private scrollToElement(index: number, center = false) {\n const dropdown = this.scrollBoxRef.current;\n const item = dropdown ? (dropdown.children[index] as HTMLElement) : null;\n\n if (!item || !dropdown) {\n return;\n }\n\n const dropdownHeight = dropdown.offsetHeight;\n const scrollTop = dropdown.scrollTop;\n const itemTop = item.offsetTop;\n const itemHeight = item.offsetHeight;\n\n if (center) {\n dropdown.scrollTop = itemTop - dropdownHeight / 2 + itemHeight / 2;\n } else if (itemTop + itemHeight > dropdownHeight + scrollTop) {\n dropdown.scrollTop = itemTop - dropdownHeight + itemHeight;\n } else if (itemTop < scrollTop) {\n dropdown.scrollTop = itemTop;\n }\n }\n\n focusOptionByIndex = (index: number | undefined, scrollTo = true) => {\n if (\n index === undefined ||\n index < 0 ||\n index > (this.state.options?.length ?? 0) - 1\n ) {\n return;\n }\n\n const option = this.state.options?.[index];\n\n if (option?.disabled) {\n return;\n }\n\n scrollTo && this.scrollToElement(index);\n\n this.setState((prevState) =>\n // Это оптимизация, прежде всего, под `onMouseOver`\n prevState.focusedOptionIndex !== index\n ? {\n focusedOptionIndex: index,\n }\n : null\n );\n };\n\n focusOption = (type: \"next\" | \"prev\") => {\n const { focusedOptionIndex } = this.state;\n let index = focusedOptionIndex;\n\n if (type === \"next\") {\n const nextIndex = findIndexAfter(this.state.options, index);\n index = nextIndex === -1 ? findIndexAfter(this.state.options) : nextIndex; // Следующий за index или первый валидный до index\n } else if (type === \"prev\") {\n const beforeIndex = findIndexBefore(this.state.options, index);\n index =\n beforeIndex === -1 ? findIndexBefore(this.state.options) : beforeIndex; // Предшествующий index или последний валидный после index\n }\n\n this.focusOptionByIndex(index);\n };\n\n handleOptionHover: MouseEventHandler = (e: React.MouseEvent<HTMLElement>) => {\n this.focusOptionByIndex(\n Array.prototype.indexOf.call(\n e.currentTarget.parentNode?.children,\n e.currentTarget\n ),\n false\n );\n };\n\n handleOptionDown: MouseEventHandler = (e: React.MouseEvent<HTMLElement>) => {\n e.preventDefault();\n };\n\n handleOptionClick: MouseEventHandler = (e: React.MouseEvent<HTMLElement>) => {\n const index = Array.prototype.indexOf.call(\n e.currentTarget.parentNode?.children,\n e.currentTarget\n );\n const option = this.state.options?.[index];\n\n if (option && !option.disabled) {\n this.selectFocused();\n }\n };\n\n resetFocusedOption = () => {\n this.setState({ focusedOptionIndex: -1 });\n };\n\n onKeyboardInput = (key: string) => {\n const fullInput = this.keyboardInput + key;\n\n const optionIndex = this.state.options?.findIndex((option) => {\n return getTitleFromChildren(option.label)\n .toLowerCase()\n .includes(fullInput);\n });\n\n if (optionIndex !== undefined && optionIndex > -1) {\n this.focusOptionByIndex(optionIndex);\n }\n\n this.keyboardInput = fullInput;\n };\n\n /**\n * Нужен для правильного поведения обработчика onClick на select. Фильтрует клики, которые были сделаны по\n * выпадающему списку.\n */\n onLabelClick = (e: React.MouseEvent<HTMLLabelElement>) => {\n if (this.scrollBoxRef.current?.contains(e.target as Node)) {\n e.preventDefault();\n }\n };\n\n onNativeSelectChange: React.ChangeEventHandler<HTMLSelectElement> = (e) => {\n const newSelectedOptionIndex = this.findSelectedIndex(\n this.state.options,\n e.currentTarget.value\n );\n\n if (this.state.selectedOptionIndex !== newSelectedOptionIndex) {\n if (!this.isControlledOutside) {\n this.setState({\n selectedOptionIndex: newSelectedOptionIndex,\n });\n }\n this.props.onChange?.(e);\n }\n };\n\n onInputChange: React.ChangeEventHandler<HTMLInputElement> = (e) => {\n if (this.props.onInputChange) {\n const options = this.props.onInputChange(e, this.props.options);\n if (options) {\n if (process.env.NODE_ENV === \"development\") {\n warn(\n \"Этот метод фильтрации устарел. Возвращаемое значение onInputChange будет \" +\n \"проигнорировано в v5.0.0. Для фильтрации обновляйте props.options самостоятельно или используйте свойство filterFn.\"\n );\n }\n this.setState({\n options,\n selectedOptionIndex: this.findSelectedIndex(\n options,\n this.state.nativeSelectValue\n ),\n inputValue: e.target.value,\n });\n } else {\n this.setState({ inputValue: e.target.value });\n }\n } else {\n const options = this.filter(\n this.props.options,\n e.target.value,\n this.props.filterFn\n );\n this.setState({\n options,\n selectedOptionIndex: this.findSelectedIndex(\n options,\n this.state.nativeSelectValue\n ),\n inputValue: e.target.value,\n });\n }\n };\n\n onInputKeyDown: React.KeyboardEventHandler<HTMLInputElement> = (event) => {\n [\"ArrowUp\", \"ArrowDown\", \"Escape\", \"Enter\"].includes(event.key) &&\n this.areOptionsShown &&\n event.preventDefault();\n\n switch (event.key) {\n case \"ArrowUp\":\n this.areOptionsShown && this.focusOption(\"prev\");\n break;\n case \"ArrowDown\":\n this.areOptionsShown && this.focusOption(\"next\");\n break;\n case \"Escape\":\n this.close();\n break;\n case \"Enter\":\n this.areOptionsShown && this.selectFocused();\n break;\n }\n };\n\n handleKeyDownSelect = (event: React.KeyboardEvent) => {\n const { opened } = this.state;\n\n if (event.key.length === 1 && event.key !== \" \") {\n this.onKeyboardInput(event.key);\n return;\n }\n\n [\"ArrowUp\", \"ArrowDown\", \"Escape\", \"Enter\"].includes(event.key) &&\n this.areOptionsShown &&\n event.preventDefault();\n\n switch (event.key) {\n case \"ArrowUp\":\n if (opened) {\n this.areOptionsShown && this.focusOption(\"prev\");\n } else {\n this.open();\n }\n break;\n case \"ArrowDown\":\n if (opened) {\n this.areOptionsShown && this.focusOption(\"next\");\n } else {\n this.open();\n }\n break;\n case \"Escape\":\n this.close();\n break;\n case \"Enter\":\n case \"Spacebar\":\n case \" \":\n if (opened) {\n this.areOptionsShown && this.selectFocused();\n } else {\n this.open();\n }\n break;\n }\n };\n\n handleKeyUp = debounce(this.resetKeyboardInput, 1000);\n\n componentDidUpdate(prevProps: CustomSelectProps) {\n // Внутри useEffect и так is, можно убрать\n if (\n !is(prevProps.value, this.props.value) ||\n prevProps.options !== this.props.options\n ) {\n if (process.env.NODE_ENV === \"development\") {\n checkOptionsValueType(this.props.options);\n }\n\n this.isControlledOutside = this.props.value !== undefined;\n const value =\n this.props.value === undefined\n ? this.state.nativeSelectValue\n : this.props.value;\n const options =\n this.props.searchable && this.state.inputValue !== undefined\n ? this.filter(\n this.props.options,\n this.state.inputValue,\n this.props.filterFn\n )\n : this.props.options;\n this.setState({\n nativeSelectValue: value,\n selectedOptionIndex: this.findSelectedIndex(options, value),\n options,\n });\n }\n }\n\n renderOption = (option: CustomSelectOptionInterface, index: number) => {\n const { focusedOptionIndex, selectedOptionIndex } = this.state;\n const { renderOption } = this.props;\n const hovered = index === focusedOptionIndex;\n const selected = index === selectedOptionIndex;\n\n return (\n <React.Fragment key={`${option.value}`}>\n {renderOption!({\n option,\n hovered,\n children: option.label,\n selected,\n disabled: option.disabled,\n onClick: this.handleOptionClick,\n onMouseDown: this.handleOptionDown,\n // Используем `onMouseOver` вместо `onMouseEnter`.\n // При параметре `searchable`, обновляется \"ребёнок\", из-за чего `onMouseEnter` не срабатывает в следующих кейсах:\n // 1. До загрузки выпадающего списка, курсор мышки находится над произвольным элементом этого списка.\n // > Лечение: только увод курсора мыши и возвращении его обратно вызывает событие `onMouseEnter` на этот элемент.\n // 2. Если это тач-устройство.\n // > Лечение: нужно нажать на какой-нибудь произвольный элемент списка, после чего `onMouseEnter` будет работать на соседние элементы,\n // но не на тот, на который нажали в первый раз.\n // Более подробно по ссылке https://github.com/facebook/react/issues/13956#issuecomment-1082055744\n onMouseOver: this.handleOptionHover,\n })}\n </React.Fragment>\n );\n };\n\n selectRef = (element: HTMLSelectElement) => {\n this.selectEl = element;\n if (this.props.getRef) {\n setRef(element, this.props.getRef);\n }\n };\n\n onPlacementChange = (placement?: Placement) => {\n this.setState(() => ({\n popperPlacement: placement,\n }));\n };\n\n render() {\n const { opened, nativeSelectValue, options: stateOptions } = this.state;\n const {\n before,\n searchable,\n name,\n className,\n getRef,\n getRootRef,\n popupDirection,\n options,\n sizeY,\n platform,\n style,\n onChange,\n onBlur,\n onFocus,\n onClick,\n renderOption,\n children,\n emptyText,\n onInputChange,\n filterFn,\n renderDropdown,\n onOpen,\n onClose,\n fetching,\n icon,\n dropdownOffsetDistance,\n fixDropdownWidth,\n forceDropdownPortal,\n selectType = SelectType.default,\n autoHideScrollbar,\n autoHideScrollbarDelay,\n ...restProps\n } = this.props;\n const selected = this.getSelectedItem();\n const label = selected ? selected.label : undefined;\n\n const defaultDropdownContent =\n stateOptions !== undefined && stateOptions.length > 0 ? (\n stateOptions.map(this.renderOption)\n ) : (\n <Caption vkuiClass=\"CustomSelect__empty\">\n {this.props.emptyText}\n </Caption>\n );\n\n let resolvedContent;\n\n if (typeof renderDropdown === \"function\") {\n resolvedContent = renderDropdown({ defaultDropdownContent });\n } else {\n resolvedContent = defaultDropdownContent;\n }\n\n const openedClassNames = classNames(\n opened && \"Select--open\",\n opened &&\n (dropdownOffsetDistance as number) === 0 &&\n (this.state.popperPlacement?.includes(\"top\")\n ? \"Select--pop-up\"\n : \"Select--pop-down\")\n );\n\n return (\n <label\n vkuiClass={getClassName(\"CustomSelect\", platform)}\n className={className}\n style={style}\n ref={multiRef(this.containerRef, getRootRef)}\n onClick={this.onLabelClick}\n >\n {opened && searchable ? (\n <Input\n {...restProps}\n autoFocus\n onBlur={this.onBlur}\n vkuiClass={openedClassNames}\n value={this.state.inputValue}\n onKeyDown={this.onInputKeyDown}\n onChange={this.onInputChange}\n // TODO Ожидается, что клик поймает нативный select, но его перехватывает Input. К сожалению, это приводит к конфликтам типизации.\n // TODO Нужно перестать пытаться превратить CustomSelect в select. Тогда эта проблема уйдёт.\n // @ts-ignore\n onClick={onClick}\n before={before}\n after={icon}\n placeholder={restProps.placeholder}\n mode={getFormFieldModeFromSelectType(selectType)}\n />\n ) : (\n <SelectMimicry\n {...restProps}\n aria-hidden={true}\n onClick={this.onClick}\n onKeyDown={this.handleKeyDownSelect}\n onKeyUp={this.handleKeyUp}\n onFocus={this.onFocus}\n onBlur={this.onBlur}\n vkuiClass={openedClassNames}\n after={icon}\n selectType={selectType}\n >\n {label}\n </SelectMimicry>\n )}\n <select\n ref={this.selectRef}\n name={name}\n onChange={this.onNativeSelectChange}\n onBlur={onBlur}\n onFocus={onFocus}\n onClick={onClick}\n value={nativeSelectValue}\n aria-hidden={true}\n vkuiClass=\"CustomSelect__control\"\n >\n {options.map((item) => (\n <option key={`${item.value}`} value={item.value} />\n ))}\n </select>\n {opened && (\n <CustomSelectDropdown\n targetRef={this.containerRef}\n placement={popupDirection}\n scrollBoxRef={this.scrollBoxRef}\n onPlacementChange={this.onPlacementChange}\n onMouseLeave={this.resetFocusedOption}\n fetching={fetching}\n offsetDistance={dropdownOffsetDistance}\n sameWidth={fixDropdownWidth}\n forcePortal={forceDropdownPortal}\n autoHideScrollbar={autoHideScrollbar}\n autoHideScrollbarDelay={autoHideScrollbarDelay}\n observableRefs={this.scrollBoxRef}\n >\n {resolvedContent}\n </CustomSelectDropdown>\n )}\n </label>\n );\n }\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelect\n */\nexport const CustomSelect = withPlatform(\n withAdaptivity(CustomSelectComponent, {\n sizeY: true,\n })\n);\n"],"file":"CustomSelect.js"}
@@ -1,15 +1,17 @@
1
1
  import * as React from "react";
2
+ import { TrackerOptionsProps } from "../CustomScrollView/useTrackerVisibility";
2
3
  import { Placement } from "../Popper/Popper";
3
4
  import { HasRef } from "../../types";
4
5
  import "./CustomSelectDropdown.css";
5
- export interface CustomSelectDropdownProps extends React.HTMLAttributes<HTMLElement>, HasRef<HTMLDivElement> {
6
+ export interface CustomSelectDropdownProps extends React.HTMLAttributes<HTMLElement>, HasRef<HTMLDivElement>, TrackerOptionsProps {
6
7
  targetRef: React.RefObject<HTMLElement>;
7
8
  placement?: Placement;
8
9
  scrollBoxRef?: React.RefObject<HTMLDivElement>;
10
+ observableRefs?: Array<React.RefObject<HTMLElement>> | React.RefObject<HTMLElement>;
9
11
  fetching?: boolean;
10
12
  offsetDistance?: number;
11
13
  sameWidth?: boolean;
12
14
  forcePortal?: boolean;
13
15
  onPlacementChange?: (placement?: Placement) => void;
14
16
  }
15
- export declare const CustomSelectDropdown: React.FC<CustomSelectDropdownProps>;
17
+ export declare const CustomSelectDropdown: ({ children, targetRef, scrollBoxRef, placement, fetching, onPlacementChange: parentOnPlacementChange, offsetDistance, sameWidth, forcePortal, autoHideScrollbar, autoHideScrollbarDelay, observableRefs, ...restProps }: CustomSelectDropdownProps) => JSX.Element;
@@ -1,32 +1,56 @@
1
1
  import _extends from "@babel/runtime/helpers/extends";
2
+ import _createForOfIteratorHelper from "@babel/runtime/helpers/createForOfIteratorHelper";
2
3
  import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
3
4
  import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
4
- var _excluded = ["children", "targetRef", "scrollBoxRef", "placement", "fetching", "onPlacementChange", "offsetDistance", "sameWidth", "forcePortal"];
5
+ var _excluded = ["children", "targetRef", "scrollBoxRef", "placement", "fetching", "onPlacementChange", "offsetDistance", "sameWidth", "forcePortal", "autoHideScrollbar", "autoHideScrollbarDelay", "observableRefs"];
5
6
  import { createScopedElement } from "../../lib/jsxRuntime";
6
7
  import * as React from "react";
7
8
  import { CustomScrollView } from "../CustomScrollView/CustomScrollView";
8
9
  import { classNames } from "../../lib/classNames";
9
10
  import { Popper } from "../Popper/Popper";
10
11
  import { Spinner } from "../Spinner/Spinner";
12
+ import { useIsomorphicLayoutEffect } from "../../lib/useIsomorphicLayoutEffect";
11
13
 
12
14
  var calcIsTop = function calcIsTop(placement) {
13
15
  return placement === null || placement === void 0 ? void 0 : placement.includes("top");
14
16
  };
15
17
 
16
- export var CustomSelectDropdown = function CustomSelectDropdown(_ref) {
17
- var children = _ref.children,
18
- targetRef = _ref.targetRef,
19
- scrollBoxRef = _ref.scrollBoxRef,
20
- placement = _ref.placement,
21
- fetching = _ref.fetching,
22
- parentOnPlacementChange = _ref.onPlacementChange,
23
- _ref$offsetDistance = _ref.offsetDistance,
24
- offsetDistance = _ref$offsetDistance === void 0 ? 0 : _ref$offsetDistance,
25
- _ref$sameWidth = _ref.sameWidth,
26
- sameWidth = _ref$sameWidth === void 0 ? true : _ref$sameWidth,
27
- _ref$forcePortal = _ref.forcePortal,
28
- forcePortal = _ref$forcePortal === void 0 ? true : _ref$forcePortal,
29
- restProps = _objectWithoutProperties(_ref, _excluded);
18
+ function getObserverModifier(element) {
19
+ return {
20
+ name: "customSelectChildrenChange",
21
+ enabled: true,
22
+ phase: "main",
23
+ effect: function effect(_ref) {
24
+ var instance = _ref.instance;
25
+ var observer = new MutationObserver(instance.forceUpdate);
26
+ observer.observe(element, {
27
+ childList: true,
28
+ subtree: true
29
+ });
30
+ return function () {
31
+ observer.disconnect();
32
+ };
33
+ }
34
+ };
35
+ }
36
+
37
+ export var CustomSelectDropdown = function CustomSelectDropdown(_ref2) {
38
+ var children = _ref2.children,
39
+ targetRef = _ref2.targetRef,
40
+ scrollBoxRef = _ref2.scrollBoxRef,
41
+ placement = _ref2.placement,
42
+ fetching = _ref2.fetching,
43
+ parentOnPlacementChange = _ref2.onPlacementChange,
44
+ _ref2$offsetDistance = _ref2.offsetDistance,
45
+ offsetDistance = _ref2$offsetDistance === void 0 ? 0 : _ref2$offsetDistance,
46
+ _ref2$sameWidth = _ref2.sameWidth,
47
+ sameWidth = _ref2$sameWidth === void 0 ? true : _ref2$sameWidth,
48
+ _ref2$forcePortal = _ref2.forcePortal,
49
+ forcePortal = _ref2$forcePortal === void 0 ? true : _ref2$forcePortal,
50
+ autoHideScrollbar = _ref2.autoHideScrollbar,
51
+ autoHideScrollbarDelay = _ref2.autoHideScrollbarDelay,
52
+ observableRefs = _ref2.observableRefs,
53
+ restProps = _objectWithoutProperties(_ref2, _excluded);
30
54
 
31
55
  var _React$useState = React.useState(function () {
32
56
  return calcIsTop(placement);
@@ -35,27 +59,41 @@ export var CustomSelectDropdown = function CustomSelectDropdown(_ref) {
35
59
  isTop = _React$useState2[0],
36
60
  setIsTop = _React$useState2[1];
37
61
 
38
- var customModifiers = React.useMemo(function () {
39
- if (!(scrollBoxRef !== null && scrollBoxRef !== void 0 && scrollBoxRef.current)) {
40
- return [];
62
+ var _React$useState3 = React.useState([]),
63
+ _React$useState4 = _slicedToArray(_React$useState3, 2),
64
+ customModifiers = _React$useState4[0],
65
+ setCustomModifiers = _React$useState4[1];
66
+
67
+ useIsomorphicLayoutEffect(function () {
68
+ if (!observableRefs) {
69
+ return;
41
70
  }
42
71
 
43
- return [{
44
- name: "customSelectChildrenChange",
45
- enabled: true,
46
- phase: "main",
47
- effect: function effect(_ref2) {
48
- var instance = _ref2.instance;
49
- var observer = new MutationObserver(instance.forceUpdate);
50
- observer.observe(scrollBoxRef.current, {
51
- childList: true
52
- });
53
- return function () {
54
- observer.disconnect();
55
- };
72
+ var customModifiers = [];
73
+
74
+ if (Array.isArray(observableRefs)) {
75
+ var _iterator = _createForOfIteratorHelper(observableRefs),
76
+ _step;
77
+
78
+ try {
79
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
80
+ var ref = _step.value;
81
+
82
+ if (ref !== null && ref !== void 0 && ref.current) {
83
+ customModifiers.push(getObserverModifier(ref.current));
84
+ }
85
+ }
86
+ } catch (err) {
87
+ _iterator.e(err);
88
+ } finally {
89
+ _iterator.f();
56
90
  }
57
- }]; // eslint-disable-next-line react-hooks/exhaustive-deps
58
- }, [scrollBoxRef === null || scrollBoxRef === void 0 ? void 0 : scrollBoxRef.current]);
91
+ } else if (observableRefs.current) {
92
+ customModifiers.push(getObserverModifier(observableRefs.current));
93
+ }
94
+
95
+ setCustomModifiers(customModifiers);
96
+ }, [observableRefs]);
59
97
  var onPlacementChange = React.useCallback(function (_ref3) {
60
98
  var placement = _ref3.placement;
61
99
  setIsTop(calcIsTop(placement));
@@ -72,7 +110,9 @@ export var CustomSelectDropdown = function CustomSelectDropdown(_ref) {
72
110
  customModifiers: customModifiers
73
111
  }, restProps), createScopedElement(CustomScrollView, {
74
112
  boxRef: scrollBoxRef,
75
- vkuiClass: "CustomSelectDropdown__in"
113
+ vkuiClass: "CustomSelectDropdown__in",
114
+ autoHideScrollbar: autoHideScrollbar,
115
+ autoHideScrollbarDelay: autoHideScrollbarDelay
76
116
  }, fetching ? createScopedElement("div", {
77
117
  vkuiClass: "CustomSelectDropdown__fetching"
78
118
  }, createScopedElement(Spinner, {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/CustomSelectDropdown/CustomSelectDropdown.tsx"],"names":["React","CustomScrollView","classNames","Popper","Spinner","calcIsTop","placement","includes","CustomSelectDropdown","children","targetRef","scrollBoxRef","fetching","parentOnPlacementChange","onPlacementChange","offsetDistance","sameWidth","forcePortal","restProps","useState","isTop","setIsTop","customModifiers","useMemo","current","name","enabled","phase","effect","instance","observer","MutationObserver","forceUpdate","observe","childList","disconnect","useCallback"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { Modifier } from \"react-popper\";\nimport { CustomScrollView } from \"../CustomScrollView/CustomScrollView\";\nimport { classNames } from \"../../lib/classNames\";\nimport { Popper, Placement } from \"../Popper/Popper\";\nimport { Spinner } from \"../Spinner/Spinner\";\nimport { HasRef } from \"../../types\";\nimport \"./CustomSelectDropdown.css\";\n\nexport interface CustomSelectDropdownProps\n extends React.HTMLAttributes<HTMLElement>,\n HasRef<HTMLDivElement> {\n targetRef: React.RefObject<HTMLElement>;\n placement?: Placement;\n scrollBoxRef?: React.RefObject<HTMLDivElement>;\n fetching?: boolean;\n offsetDistance?: number;\n sameWidth?: boolean;\n forcePortal?: boolean;\n onPlacementChange?: (placement?: Placement) => void;\n}\n\nconst calcIsTop = (placement?: Placement) => placement?.includes(\"top\");\n\nexport const CustomSelectDropdown: React.FC<CustomSelectDropdownProps> = ({\n children,\n targetRef,\n scrollBoxRef,\n placement,\n fetching,\n onPlacementChange: parentOnPlacementChange,\n offsetDistance = 0,\n sameWidth = true,\n forcePortal = true,\n ...restProps\n}) => {\n const [isTop, setIsTop] = React.useState(() => calcIsTop(placement));\n\n const customModifiers = React.useMemo<Array<Modifier<string>>>(() => {\n if (!scrollBoxRef?.current) {\n return [];\n }\n\n return [\n {\n name: \"customSelectChildrenChange\",\n enabled: true,\n phase: \"main\",\n effect: ({ instance }) => {\n const observer = new MutationObserver(instance.forceUpdate);\n\n observer.observe(scrollBoxRef.current as Element, {\n childList: true,\n });\n\n return () => {\n observer.disconnect();\n };\n },\n },\n ];\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [scrollBoxRef?.current]);\n\n const onPlacementChange = React.useCallback(\n ({ placement }: { placement?: Placement }) => {\n setIsTop(calcIsTop(placement));\n parentOnPlacementChange?.(placement);\n },\n [parentOnPlacementChange, setIsTop]\n );\n\n return (\n <Popper\n targetRef={targetRef}\n offsetDistance={offsetDistance}\n sameWidth={sameWidth}\n onPlacementChange={onPlacementChange}\n placement={placement}\n vkuiClass={classNames(\n \"CustomSelectDropdown\",\n offsetDistance === 0 &&\n (isTop\n ? \"CustomSelectDropdown--top\"\n : \"CustomSelectDropdown--bottom\"),\n sameWidth && \"CustomSelectDropdown--wide\"\n )}\n forcePortal={forcePortal}\n customModifiers={customModifiers}\n {...restProps}\n >\n <CustomScrollView\n boxRef={scrollBoxRef}\n vkuiClass=\"CustomSelectDropdown__in\"\n >\n {fetching ? (\n <div vkuiClass=\"CustomSelectDropdown__fetching\">\n <Spinner size=\"small\" />\n </div>\n ) : (\n children\n )}\n </CustomScrollView>\n </Popper>\n );\n};\n"],"file":"CustomSelectDropdown.js"}
1
+ {"version":3,"sources":["../../../src/components/CustomSelectDropdown/CustomSelectDropdown.tsx"],"names":["React","CustomScrollView","classNames","Popper","Spinner","useIsomorphicLayoutEffect","calcIsTop","placement","includes","getObserverModifier","element","name","enabled","phase","effect","instance","observer","MutationObserver","forceUpdate","observe","childList","subtree","disconnect","CustomSelectDropdown","children","targetRef","scrollBoxRef","fetching","parentOnPlacementChange","onPlacementChange","offsetDistance","sameWidth","forcePortal","autoHideScrollbar","autoHideScrollbarDelay","observableRefs","restProps","useState","isTop","setIsTop","customModifiers","setCustomModifiers","Array","isArray","ref","current","push","useCallback"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { Modifier } from \"react-popper\";\nimport { CustomScrollView } from \"../CustomScrollView/CustomScrollView\";\nimport { TrackerOptionsProps } from \"../CustomScrollView/useTrackerVisibility\";\nimport { classNames } from \"../../lib/classNames\";\nimport { Popper, Placement } from \"../Popper/Popper\";\nimport { Spinner } from \"../Spinner/Spinner\";\nimport { HasRef } from \"../../types\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport \"./CustomSelectDropdown.css\";\n\nexport interface CustomSelectDropdownProps\n extends React.HTMLAttributes<HTMLElement>,\n HasRef<HTMLDivElement>,\n TrackerOptionsProps {\n targetRef: React.RefObject<HTMLElement>;\n placement?: Placement;\n scrollBoxRef?: React.RefObject<HTMLDivElement>;\n observableRefs?:\n | Array<React.RefObject<HTMLElement>>\n | React.RefObject<HTMLElement>;\n fetching?: boolean;\n offsetDistance?: number;\n sameWidth?: boolean;\n forcePortal?: boolean;\n onPlacementChange?: (placement?: Placement) => void;\n}\n\nconst calcIsTop = (placement?: Placement) => placement?.includes(\"top\");\n\nfunction getObserverModifier<T extends HTMLElement>(\n element: T\n): Modifier<string> {\n return {\n name: \"customSelectChildrenChange\",\n enabled: true,\n phase: \"main\",\n effect: ({ instance }) => {\n const observer = new MutationObserver(instance.forceUpdate);\n\n observer.observe(element, {\n childList: true,\n subtree: true,\n });\n\n return () => {\n observer.disconnect();\n };\n },\n };\n}\n\nexport const CustomSelectDropdown = ({\n children,\n targetRef,\n scrollBoxRef,\n placement,\n fetching,\n onPlacementChange: parentOnPlacementChange,\n offsetDistance = 0,\n sameWidth = true,\n forcePortal = true,\n autoHideScrollbar,\n autoHideScrollbarDelay,\n observableRefs,\n ...restProps\n}: CustomSelectDropdownProps) => {\n const [isTop, setIsTop] = React.useState(() => calcIsTop(placement));\n const [customModifiers, setCustomModifiers] = React.useState<\n Array<Modifier<string>>\n >([]);\n\n useIsomorphicLayoutEffect(() => {\n if (!observableRefs) {\n return;\n }\n const customModifiers: Array<Modifier<string>> = [];\n\n if (Array.isArray(observableRefs)) {\n for (const ref of observableRefs) {\n if (ref?.current) {\n customModifiers.push(getObserverModifier(ref.current));\n }\n }\n } else if (observableRefs.current) {\n customModifiers.push(getObserverModifier(observableRefs.current));\n }\n\n setCustomModifiers(customModifiers);\n }, [observableRefs]);\n\n const onPlacementChange = React.useCallback(\n ({ placement }: { placement?: Placement }) => {\n setIsTop(calcIsTop(placement));\n parentOnPlacementChange?.(placement);\n },\n [parentOnPlacementChange, setIsTop]\n );\n\n return (\n <Popper\n targetRef={targetRef}\n offsetDistance={offsetDistance}\n sameWidth={sameWidth}\n onPlacementChange={onPlacementChange}\n placement={placement}\n vkuiClass={classNames(\n \"CustomSelectDropdown\",\n offsetDistance === 0 &&\n (isTop\n ? \"CustomSelectDropdown--top\"\n : \"CustomSelectDropdown--bottom\"),\n sameWidth && \"CustomSelectDropdown--wide\"\n )}\n forcePortal={forcePortal}\n customModifiers={customModifiers}\n {...restProps}\n >\n <CustomScrollView\n boxRef={scrollBoxRef}\n vkuiClass=\"CustomSelectDropdown__in\"\n autoHideScrollbar={autoHideScrollbar}\n autoHideScrollbarDelay={autoHideScrollbarDelay}\n >\n {fetching ? (\n <div vkuiClass=\"CustomSelectDropdown__fetching\">\n <Spinner size=\"small\" />\n </div>\n ) : (\n children\n )}\n </CustomScrollView>\n </Popper>\n );\n};\n"],"file":"CustomSelectDropdown.js"}
@@ -44,4 +44,4 @@ export interface CustomSelectOptionProps extends React.HTMLAttributes<HTMLDivEle
44
44
  /**
45
45
  * @see https://vkcom.github.io/VKUI/#/CustomSelectOption
46
46
  */
47
- export declare const CustomSelectOption: React.FC<CustomSelectOptionProps>;
47
+ export declare const CustomSelectOption: ({ children, hierarchy, hovered, selected, before, after, option, description, disabled, style: styleProp, ...restProps }: CustomSelectOptionProps) => JSX.Element;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/CustomSelectOption/CustomSelectOption.tsx"],"names":["React","Icon16Done","classNames","hasReactNode","Paragraph","Caption","useAdaptivity","warnOnce","warn","CustomSelectOption","children","hierarchy","hovered","selected","before","after","option","description","disabled","styleProp","style","restProps","title","undefined","sizeY","useMemo","process","env","NODE_ENV"],"mappings":";;;;;AAAA,OAAO,KAAKA,KAAZ,MAAuB,OAAvB;AACA,SAASC,UAAT,QAA2B,kBAA3B;AACA,SAASC,UAAT;AACA,SAASC,YAAT;AACA,SAASC,SAAT;AACA,SAASC,OAAT;AAEA,SAASC,aAAT;AACA,SAASC,QAAT;AA8CA,IAAMC,IAAI,GAAGD,QAAQ,CAAC,oBAAD,CAArB;AAEA;AACA;AACA;;AACA,OAAO,IAAME,kBAAqD,GAAG,SAAxDA,kBAAwD,OAYtC;AAAA,MAX7BC,QAW6B,QAX7BA,QAW6B;AAAA,4BAV7BC,SAU6B;AAAA,MAV7BA,SAU6B,+BAVjB,CAUiB;AAAA,MAT7BC,OAS6B,QAT7BA,OAS6B;AAAA,MAR7BC,QAQ6B,QAR7BA,QAQ6B;AAAA,MAP7BC,MAO6B,QAP7BA,MAO6B;AAAA,MAN7BC,KAM6B,QAN7BA,KAM6B;AAAA,MAL7BC,MAK6B,QAL7BA,MAK6B;AAAA,MAJ7BC,WAI6B,QAJ7BA,WAI6B;AAAA,MAH7BC,QAG6B,QAH7BA,QAG6B;AAAA,MAFtBC,SAEsB,QAF7BC,KAE6B;AAAA,MAD1BC,SAC0B;;AAC7B,MAAMC,KAAK,GAAG,OAAOZ,QAAP,KAAoB,QAApB,GAA+BA,QAA/B,GAA0Ca,SAAxD;;AACA,uBAAkBjB,aAAa,EAA/B;AAAA,MAAQkB,KAAR,kBAAQA,KAAR;;AACA,MAAMJ,KAAK,GAAGpB,KAAK,CAACyB,OAAN,CACZ;AAAA,WACEd,SAAS,GAAG,CAAZ;AAEM,gDAA0CA;AAFhD,OAGSQ,SAHT,IAKIA,SANN;AAAA,GADY,EAQZ,CAACR,SAAD,EAAYQ,SAAZ,CARY,CAAd;;AAWA,MAAI,CAAC,CAACH,MAAF,IAAYU,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAAzC,EAAwD;AACtDpB,IAAAA,IAAI,CAAC,mEAAD,CAAJ;AACD;;AAED,SACE,oBAAC,SAAD,eACMa,SADN;AAEE,IAAA,SAAS,EAAC,KAFZ;AAGE,IAAA,IAAI,EAAC,QAHP;AAIE,IAAA,KAAK,EAAEC,KAJT;AAKE,qBAAeJ,QALjB;AAME,qBAAeL,QANjB;AAOE,IAAA,SAAS,EAAEX,UAAU,CACnB,oBADmB,sCAEUsB,KAFV,GAGnBZ,OAAO,IAAI,CAACM,QAAZ,IAAwB,2BAHL,EAInBL,QAAQ,IAAI,8BAJO,EAIyB;AAC5CK,IAAAA,QAAQ,IAAI,8BALO,EAMnBP,SAAS,GAAG,CAAZ,IAAiB,+BANE,CAPvB;AAeE,IAAA,KAAK,EAAES;AAfT,MAiBGjB,YAAY,CAACW,MAAD,CAAZ,IACC;AAAK,IAAA,SAAS,EAAC;AAAf,KAA6CA,MAA7C,CAlBJ,EAoBE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE;AAAK,IAAA,SAAS,EAAC;AAAf,KAA+CJ,QAA/C,CADF,EAEGP,YAAY,CAACc,WAAD,CAAZ,IACC,oBAAC,OAAD;AAAS,IAAA,SAAS,EAAC;AAAnB,KACGA,WADH,CAHJ,CApBF,EA4BE;AAAK,IAAA,SAAS,EAAC;AAAf,KACGd,YAAY,CAACY,KAAD,CAAZ,IACC;AAAK,IAAA,SAAS,EAAC;AAAf,KAA8CA,KAA9C,CAFJ,EAIGF,QAAQ,IACP,oBAAC,UAAD;AAAY,IAAA,SAAS,EAAC;AAAtB,IALJ,CA5BF,CADF;AAuCD,CArEM","sourcesContent":["import * as React from \"react\";\nimport { Icon16Done } from \"@vkontakte/icons\";\nimport { classNames } from \"../../lib/classNames\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport { Paragraph } from \"../Typography/Paragraph/Paragraph\";\nimport { Caption } from \"../Typography/Caption/Caption\";\nimport { HasRootRef } from \"../../types\";\nimport { useAdaptivity } from \"../../hooks/useAdaptivity\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport \"./CustomSelectOption.css\";\n\nexport interface CustomSelectOptionProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n /**\n * Вставляет основной контент.\n */\n option?: any;\n /**\n * Добавляет описание под основным блоком.\n */\n description?: React.ReactNode;\n /**\n * Вставляет элемент в начало блока перед основным контентом.\n * Например, можно передать компонент `Avatar`, `Icon<Name>` или другие изображения.\n */\n before?: React.ReactNode;\n /**\n * Вставляет элемент в конец блока после основного контента.\n * Например, можно передать компонент `Avatar`, `Icon<Name>` или другие изображения.\n */\n after?: React.ReactNode;\n /**\n * Позволяет создавать вложенность.\n */\n hierarchy?: number;\n /**\n * Включает состояние выбранного элемента списка.\n */\n selected?: boolean;\n /**\n * Включает состояние наведения.\n */\n hovered?: boolean;\n /**\n * Включает состояние фокуса.\n */\n focused?: boolean;\n /**\n * Блокирует весь блок.\n */\n disabled?: boolean;\n}\n\nconst warn = warnOnce(\"CustomSelectOption\");\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelectOption\n */\nexport const CustomSelectOption: React.FC<CustomSelectOptionProps> = ({\n children,\n hierarchy = 0,\n hovered,\n selected,\n before,\n after,\n option,\n description,\n disabled,\n style: styleProp,\n ...restProps\n}: CustomSelectOptionProps) => {\n const title = typeof children === \"string\" ? children : undefined;\n const { sizeY } = useAdaptivity();\n const style = React.useMemo(\n () =>\n hierarchy > 0\n ? {\n \"--custom-select-option-hierarchy-level\": hierarchy,\n ...styleProp,\n }\n : styleProp,\n [hierarchy, styleProp]\n );\n\n if (!!option && process.env.NODE_ENV === \"development\") {\n warn(\"Свойство option было добавлено по ошибке и будет удалено в 5.0.0.\");\n }\n\n return (\n <Paragraph\n {...restProps}\n Component=\"div\"\n role=\"option\"\n title={title}\n aria-disabled={disabled}\n aria-selected={selected}\n vkuiClass={classNames(\n \"CustomSelectOption\",\n `CustomSelectOption--sizeY-${sizeY}`,\n hovered && !disabled && \"CustomSelectOption--hover\",\n selected && \"CustomSelectOption--selected\", // Note: пустой класс\n disabled && \"CustomSelectOption--disabled\",\n hierarchy > 0 && \"CustomSelectOption--hierarchy\"\n )}\n style={style}\n >\n {hasReactNode(before) && (\n <div vkuiClass=\"CustomSelectOption__before\">{before}</div>\n )}\n <div vkuiClass=\"CustomSelectOption__main\">\n <div vkuiClass=\"CustomSelectOption__children\">{children}</div>\n {hasReactNode(description) && (\n <Caption vkuiClass=\"CustomSelectOption__description\">\n {description}\n </Caption>\n )}\n </div>\n <div vkuiClass=\"CustomSelectOption__after\">\n {hasReactNode(after) && (\n <div vkuiClass=\"CustomSelectOption__afterIn\">{after}</div>\n )}\n {selected && (\n <Icon16Done vkuiClass=\"CustomSelectOption__selectedIcon\" />\n )}\n </div>\n </Paragraph>\n );\n};\n"],"file":"CustomSelectOption.js"}
1
+ {"version":3,"sources":["../../../src/components/CustomSelectOption/CustomSelectOption.tsx"],"names":["React","Icon16Done","classNames","hasReactNode","Paragraph","Caption","useAdaptivity","warnOnce","warn","CustomSelectOption","children","hierarchy","hovered","selected","before","after","option","description","disabled","styleProp","style","restProps","title","undefined","sizeY","useMemo","process","env","NODE_ENV"],"mappings":";;;;;AAAA,OAAO,KAAKA,KAAZ,MAAuB,OAAvB;AACA,SAASC,UAAT,QAA2B,kBAA3B;AACA,SAASC,UAAT;AACA,SAASC,YAAT;AACA,SAASC,SAAT;AACA,SAASC,OAAT;AAEA,SAASC,aAAT;AACA,SAASC,QAAT;AA8CA,IAAMC,IAAI,GAAGD,QAAQ,CAAC,oBAAD,CAArB;AAEA;AACA;AACA;;AACA,OAAO,IAAME,kBAAkB,GAAG,SAArBA,kBAAqB,OAYH;AAAA,MAX7BC,QAW6B,QAX7BA,QAW6B;AAAA,4BAV7BC,SAU6B;AAAA,MAV7BA,SAU6B,+BAVjB,CAUiB;AAAA,MAT7BC,OAS6B,QAT7BA,OAS6B;AAAA,MAR7BC,QAQ6B,QAR7BA,QAQ6B;AAAA,MAP7BC,MAO6B,QAP7BA,MAO6B;AAAA,MAN7BC,KAM6B,QAN7BA,KAM6B;AAAA,MAL7BC,MAK6B,QAL7BA,MAK6B;AAAA,MAJ7BC,WAI6B,QAJ7BA,WAI6B;AAAA,MAH7BC,QAG6B,QAH7BA,QAG6B;AAAA,MAFtBC,SAEsB,QAF7BC,KAE6B;AAAA,MAD1BC,SAC0B;;AAC7B,MAAMC,KAAK,GAAG,OAAOZ,QAAP,KAAoB,QAApB,GAA+BA,QAA/B,GAA0Ca,SAAxD;;AACA,uBAAkBjB,aAAa,EAA/B;AAAA,MAAQkB,KAAR,kBAAQA,KAAR;;AACA,MAAMJ,KAAK,GAAGpB,KAAK,CAACyB,OAAN,CACZ;AAAA,WACEd,SAAS,GAAG,CAAZ;AAEM,gDAA0CA;AAFhD,OAGSQ,SAHT,IAKIA,SANN;AAAA,GADY,EAQZ,CAACR,SAAD,EAAYQ,SAAZ,CARY,CAAd;;AAWA,MAAI,CAAC,CAACH,MAAF,IAAYU,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAAzC,EAAwD;AACtDpB,IAAAA,IAAI,CAAC,mEAAD,CAAJ;AACD;;AAED,SACE,oBAAC,SAAD,eACMa,SADN;AAEE,IAAA,SAAS,EAAC,KAFZ;AAGE,IAAA,IAAI,EAAC,QAHP;AAIE,IAAA,KAAK,EAAEC,KAJT;AAKE,qBAAeJ,QALjB;AAME,qBAAeL,QANjB;AAOE,IAAA,SAAS,EAAEX,UAAU,CACnB,oBADmB,sCAEUsB,KAFV,GAGnBZ,OAAO,IAAI,CAACM,QAAZ,IAAwB,2BAHL,EAInBL,QAAQ,IAAI,8BAJO,EAIyB;AAC5CK,IAAAA,QAAQ,IAAI,8BALO,EAMnBP,SAAS,GAAG,CAAZ,IAAiB,+BANE,CAPvB;AAeE,IAAA,KAAK,EAAES;AAfT,MAiBGjB,YAAY,CAACW,MAAD,CAAZ,IACC;AAAK,IAAA,SAAS,EAAC;AAAf,KAA6CA,MAA7C,CAlBJ,EAoBE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE;AAAK,IAAA,SAAS,EAAC;AAAf,KAA+CJ,QAA/C,CADF,EAEGP,YAAY,CAACc,WAAD,CAAZ,IACC,oBAAC,OAAD;AAAS,IAAA,SAAS,EAAC;AAAnB,KACGA,WADH,CAHJ,CApBF,EA4BE;AAAK,IAAA,SAAS,EAAC;AAAf,KACGd,YAAY,CAACY,KAAD,CAAZ,IACC;AAAK,IAAA,SAAS,EAAC;AAAf,KAA8CA,KAA9C,CAFJ,EAIGF,QAAQ,IACP,oBAAC,UAAD;AAAY,IAAA,SAAS,EAAC;AAAtB,IALJ,CA5BF,CADF;AAuCD,CArEM","sourcesContent":["import * as React from \"react\";\nimport { Icon16Done } from \"@vkontakte/icons\";\nimport { classNames } from \"../../lib/classNames\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport { Paragraph } from \"../Typography/Paragraph/Paragraph\";\nimport { Caption } from \"../Typography/Caption/Caption\";\nimport { HasRootRef } from \"../../types\";\nimport { useAdaptivity } from \"../../hooks/useAdaptivity\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport \"./CustomSelectOption.css\";\n\nexport interface CustomSelectOptionProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n /**\n * Вставляет основной контент.\n */\n option?: any;\n /**\n * Добавляет описание под основным блоком.\n */\n description?: React.ReactNode;\n /**\n * Вставляет элемент в начало блока перед основным контентом.\n * Например, можно передать компонент `Avatar`, `Icon<Name>` или другие изображения.\n */\n before?: React.ReactNode;\n /**\n * Вставляет элемент в конец блока после основного контента.\n * Например, можно передать компонент `Avatar`, `Icon<Name>` или другие изображения.\n */\n after?: React.ReactNode;\n /**\n * Позволяет создавать вложенность.\n */\n hierarchy?: number;\n /**\n * Включает состояние выбранного элемента списка.\n */\n selected?: boolean;\n /**\n * Включает состояние наведения.\n */\n hovered?: boolean;\n /**\n * Включает состояние фокуса.\n */\n focused?: boolean;\n /**\n * Блокирует весь блок.\n */\n disabled?: boolean;\n}\n\nconst warn = warnOnce(\"CustomSelectOption\");\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelectOption\n */\nexport const CustomSelectOption = ({\n children,\n hierarchy = 0,\n hovered,\n selected,\n before,\n after,\n option,\n description,\n disabled,\n style: styleProp,\n ...restProps\n}: CustomSelectOptionProps) => {\n const title = typeof children === \"string\" ? children : undefined;\n const { sizeY } = useAdaptivity();\n const style = React.useMemo(\n () =>\n hierarchy > 0\n ? {\n \"--custom-select-option-hierarchy-level\": hierarchy,\n ...styleProp,\n }\n : styleProp,\n [hierarchy, styleProp]\n );\n\n if (!!option && process.env.NODE_ENV === \"development\") {\n warn(\"Свойство option было добавлено по ошибке и будет удалено в 5.0.0.\");\n }\n\n return (\n <Paragraph\n {...restProps}\n Component=\"div\"\n role=\"option\"\n title={title}\n aria-disabled={disabled}\n aria-selected={selected}\n vkuiClass={classNames(\n \"CustomSelectOption\",\n `CustomSelectOption--sizeY-${sizeY}`,\n hovered && !disabled && \"CustomSelectOption--hover\",\n selected && \"CustomSelectOption--selected\", // Note: пустой класс\n disabled && \"CustomSelectOption--disabled\",\n hierarchy > 0 && \"CustomSelectOption--hierarchy\"\n )}\n style={style}\n >\n {hasReactNode(before) && (\n <div vkuiClass=\"CustomSelectOption__before\">{before}</div>\n )}\n <div vkuiClass=\"CustomSelectOption__main\">\n <div vkuiClass=\"CustomSelectOption__children\">{children}</div>\n {hasReactNode(description) && (\n <Caption vkuiClass=\"CustomSelectOption__description\">\n {description}\n </Caption>\n )}\n </div>\n <div vkuiClass=\"CustomSelectOption__after\">\n {hasReactNode(after) && (\n <div vkuiClass=\"CustomSelectOption__afterIn\">{after}</div>\n )}\n {selected && (\n <Icon16Done vkuiClass=\"CustomSelectOption__selectedIcon\" />\n )}\n </div>\n </Paragraph>\n );\n};\n"],"file":"CustomSelectOption.js"}
@@ -12,4 +12,4 @@ export interface DateInputProps extends Omit<React.InputHTMLAttributes<HTMLDivEl
12
12
  /**
13
13
  * @see https://vkcom.github.io/VKUI/#/DateInput
14
14
  */
15
- export declare const DateInput: React.FC<DateInputProps>;
15
+ export declare const DateInput: ({ enableTime, shouldDisableDate, disableFuture, disablePast, value, onChange, calendarPlacement, style, className, doneButtonText, closeOnChange, disablePickers, getRootRef, name, autoFocus, disabled, onClick, onFocus, prevMonthAriaLabel, nextMonthAriaLabel, showNeighboringMonth, size, changeMonthAriaLabel, changeYearAriaLabel, changeDayAriaLabel, changeHoursAriaLabel, changeMinutesAriaLabel, clearFieldAriaLabel, showCalendarAriaLabel, viewDate, onHeaderChange, onNextMonth, onPrevMonth, prevMonthIcon, nextMonthIcon, ...props }: DateInputProps) => JSX.Element;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/DateInput/DateInput.tsx"],"names":["React","format","isMatch","parse","Icon16Clear","Icon20CalendarOutline","Calendar","Popper","multiRef","IconButton","classNames","FormField","useDateInput","InputLike","InputLikeDivider","useAdaptivity","callMultiple","elementsConfig","index","length","min","max","getInternalValue","value","newValue","String","getDate","padStart","getMonth","getFullYear","getHours","getMinutes","DateInput","enableTime","shouldDisableDate","disableFuture","disablePast","onChange","calendarPlacement","style","className","doneButtonText","closeOnChange","disablePickers","getRootRef","name","autoFocus","disabled","onClick","onFocus","prevMonthAriaLabel","nextMonthAriaLabel","showNeighboringMonth","size","changeMonthAriaLabel","changeYearAriaLabel","changeDayAriaLabel","changeHoursAriaLabel","changeMinutesAriaLabel","clearFieldAriaLabel","showCalendarAriaLabel","viewDate","onHeaderChange","onNextMonth","onPrevMonth","prevMonthIcon","nextMonthIcon","props","daysRef","useRef","monthsRef","yearsRef","hoursRef","minutesRef","maxElement","onInternalValueChange","useCallback","internalValue","i","formattedValue","mask","Date","refs","useMemo","rootRef","calendarRef","open","openCalendar","closeCalendar","handleKeyDown","setFocusedElement","handleFieldEnter","clear","removeFocusFromField","sizeY","onCalendarChange"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { format, isMatch, parse } from \"../../lib/date\";\nimport { Icon16Clear, Icon20CalendarOutline } from \"@vkontakte/icons\";\nimport { Calendar, CalendarProps } from \"../Calendar/Calendar\";\nimport { Popper, Placement } from \"../Popper/Popper\";\nimport { multiRef } from \"../../lib/utils\";\nimport { IconButton } from \"../IconButton/IconButton\";\nimport { classNames } from \"../../lib/classNames\";\nimport { FormField } from \"../FormField/FormField\";\nimport { HasRootRef } from \"../../types\";\nimport { useDateInput } from \"../../hooks/useDateInput\";\nimport { InputLike } from \"../InputLike/InputLike\";\nimport { InputLikeDivider } from \"../InputLike/InputLikeDivider\";\nimport { useAdaptivity } from \"../../hooks/useAdaptivity\";\nimport { callMultiple } from \"../../lib/callMultiple\";\nimport \"./DateInput.css\";\n\nexport interface DateInputProps\n extends Omit<\n React.InputHTMLAttributes<HTMLDivElement>,\n \"value\" | \"onChange\" | \"size\"\n >,\n Pick<\n CalendarProps,\n | \"disablePast\"\n | \"disableFuture\"\n | \"enableTime\"\n | \"shouldDisableDate\"\n | \"onChange\"\n | \"value\"\n | \"doneButtonText\"\n | \"weekStartsOn\"\n | \"disablePickers\"\n | \"changeHoursAriaLabel\"\n | \"changeMinutesAriaLabel\"\n | \"prevMonthAriaLabel\"\n | \"nextMonthAriaLabel\"\n | \"changeMonthAriaLabel\"\n | \"changeYearAriaLabel\"\n | \"changeDayAriaLabel\"\n | \"showNeighboringMonth\"\n | \"size\"\n | \"viewDate\"\n | \"onHeaderChange\"\n | \"onNextMonth\"\n | \"onPrevMonth\"\n | \"prevMonthIcon\"\n | \"nextMonthIcon\"\n >,\n HasRootRef<HTMLDivElement> {\n calendarPlacement?: Placement;\n closeOnChange?: boolean;\n clearFieldAriaLabel?: string;\n showCalendarAriaLabel?: string;\n}\n\nconst elementsConfig = (index: number) => {\n let length = 2;\n let min = 1;\n let max = 0;\n\n switch (index) {\n case 0:\n max = 31;\n break;\n case 1:\n max = 12;\n break;\n case 2:\n max = 2100;\n min = 1900;\n length = 4;\n break;\n case 3:\n max = 23;\n break;\n case 4:\n max = 59;\n break;\n }\n\n return { length, min, max };\n};\n\nconst getInternalValue = (value: CalendarProps[\"value\"]) => {\n const newValue = [\"\", \"\", \"\", \"\", \"\"];\n if (value) {\n newValue[0] = String(value.getDate()).padStart(2, \"0\");\n newValue[1] = String(value.getMonth() + 1).padStart(2, \"0\");\n newValue[2] = String(value.getFullYear()).padStart(4, \"0\");\n newValue[3] = String(value.getHours()).padStart(2, \"0\");\n newValue[4] = String(value.getMinutes()).padStart(2, \"0\");\n }\n return newValue;\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/DateInput\n */\nexport const DateInput: React.FC<DateInputProps> = ({\n enableTime,\n shouldDisableDate,\n disableFuture,\n disablePast,\n value,\n onChange,\n calendarPlacement = \"bottom-start\",\n style,\n className,\n doneButtonText,\n closeOnChange = true,\n disablePickers,\n getRootRef,\n name,\n autoFocus,\n disabled,\n onClick,\n onFocus,\n prevMonthAriaLabel,\n nextMonthAriaLabel,\n showNeighboringMonth,\n size,\n changeMonthAriaLabel = \"Изменить месяц\",\n changeYearAriaLabel = \"Изменить год\",\n changeDayAriaLabel = \"Изменить день\",\n changeHoursAriaLabel = \"Изменить час\",\n changeMinutesAriaLabel = \"Изменить минуту\",\n clearFieldAriaLabel = \"Очистить поле\",\n showCalendarAriaLabel = \"Показать календарь\",\n viewDate,\n onHeaderChange,\n onNextMonth,\n onPrevMonth,\n prevMonthIcon,\n nextMonthIcon,\n ...props\n}) => {\n const daysRef = React.useRef<HTMLSpanElement>(null);\n const monthsRef = React.useRef<HTMLSpanElement>(null);\n const yearsRef = React.useRef<HTMLSpanElement>(null);\n const hoursRef = React.useRef<HTMLSpanElement>(null);\n const minutesRef = React.useRef<HTMLSpanElement>(null);\n\n const maxElement = enableTime ? 4 : 2;\n\n const onInternalValueChange = React.useCallback(\n (internalValue: string[]) => {\n for (let i = 0; i <= maxElement; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n return;\n }\n }\n\n let formattedValue = `${internalValue[0]}.${internalValue[1]}.${internalValue[2]}`;\n let mask = \"DD.MM.YYYY\";\n if (enableTime) {\n formattedValue += ` ${internalValue[3]}:${internalValue[4]}`;\n mask += \" HH:mm\";\n }\n\n if (isMatch(formattedValue, mask)) {\n onChange?.(parse(formattedValue, mask, value ?? new Date()));\n }\n },\n [enableTime, maxElement, onChange, value]\n );\n\n const refs = React.useMemo(\n () => [daysRef, monthsRef, yearsRef, hoursRef, minutesRef],\n [daysRef, monthsRef, yearsRef, hoursRef, minutesRef]\n );\n\n const {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n closeCalendar,\n internalValue,\n handleKeyDown,\n setFocusedElement,\n handleFieldEnter,\n clear,\n removeFocusFromField,\n } = useDateInput({\n maxElement,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange,\n onInternalValueChange,\n getInternalValue,\n value,\n });\n\n const { sizeY } = useAdaptivity();\n\n const onCalendarChange = React.useCallback(\n (value?: Date | undefined) => {\n onChange?.(value);\n if (closeOnChange && !enableTime) {\n removeFocusFromField();\n }\n },\n [onChange, removeFocusFromField, closeOnChange, enableTime]\n );\n\n return (\n <FormField\n vkuiClass={classNames(\"DateInput\", `DateInput--sizeY-${sizeY}`)}\n style={style}\n className={className}\n getRootRef={multiRef(rootRef, getRootRef)}\n after={\n value ? (\n <IconButton\n hoverMode=\"opacity\"\n aria-label={clearFieldAriaLabel}\n onClick={clear}\n >\n <Icon16Clear />\n </IconButton>\n ) : (\n <IconButton\n hoverMode=\"opacity\"\n aria-label={showCalendarAriaLabel}\n onClick={openCalendar}\n >\n <Icon20CalendarOutline />\n </IconButton>\n )\n }\n disabled={disabled}\n onClick={callMultiple(handleFieldEnter, onClick)}\n onFocus={callMultiple(handleFieldEnter, onFocus)}\n {...props}\n >\n <input\n type=\"hidden\"\n name={name}\n value={\n value\n ? format(value, enableTime ? \"DD.MM.YYYYTHH:mm\" : \"DD.MM.YYYY\")\n : \"\"\n }\n />\n <span vkuiClass=\"DateInput__input\" onKeyDown={handleKeyDown}>\n <InputLike\n tabIndex={1}\n length={2}\n getRootRef={daysRef}\n index={0}\n onElementSelect={setFocusedElement}\n value={internalValue[0]}\n aria-label={changeDayAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsRef}\n index={1}\n onElementSelect={setFocusedElement}\n value={internalValue[1]}\n aria-label={changeMonthAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsRef}\n index={2}\n onElementSelect={setFocusedElement}\n value={internalValue[2]}\n aria-label={changeYearAriaLabel}\n />\n {enableTime && (\n <React.Fragment>\n <InputLikeDivider vkuiClass=\"DateInput__input-time-divider\">\n {\" \"}\n </InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={hoursRef}\n index={3}\n onElementSelect={setFocusedElement}\n value={internalValue[3]}\n aria-label={changeHoursAriaLabel}\n />\n <InputLikeDivider>:</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={minutesRef}\n index={4}\n onElementSelect={setFocusedElement}\n value={internalValue[4]}\n aria-label={changeMinutesAriaLabel}\n />\n </React.Fragment>\n )}\n </span>\n {open && (\n <Popper\n targetRef={rootRef}\n offsetDistance={8}\n placement={calendarPlacement}\n >\n <Calendar\n value={value}\n onChange={onCalendarChange}\n enableTime={enableTime}\n disablePast={disablePast}\n disableFuture={disableFuture}\n shouldDisableDate={shouldDisableDate}\n onClose={closeCalendar}\n getRootRef={calendarRef}\n doneButtonText={doneButtonText}\n disablePickers={disablePickers}\n changeHoursAriaLabel={changeHoursAriaLabel}\n changeMinutesAriaLabel={changeMinutesAriaLabel}\n prevMonthAriaLabel={prevMonthAriaLabel}\n nextMonthAriaLabel={nextMonthAriaLabel}\n changeMonthAriaLabel={changeMonthAriaLabel}\n changeYearAriaLabel={changeYearAriaLabel}\n changeDayAriaLabel={changeDayAriaLabel}\n showNeighboringMonth={showNeighboringMonth}\n size={size}\n viewDate={viewDate}\n onHeaderChange={onHeaderChange}\n onNextMonth={onNextMonth}\n onPrevMonth={onPrevMonth}\n prevMonthIcon={prevMonthIcon}\n nextMonthIcon={nextMonthIcon}\n />\n </Popper>\n )}\n </FormField>\n );\n};\n"],"file":"DateInput.js"}
1
+ {"version":3,"sources":["../../../src/components/DateInput/DateInput.tsx"],"names":["React","format","isMatch","parse","Icon16Clear","Icon20CalendarOutline","Calendar","Popper","multiRef","IconButton","classNames","FormField","useDateInput","InputLike","InputLikeDivider","useAdaptivity","callMultiple","elementsConfig","index","length","min","max","getInternalValue","value","newValue","String","getDate","padStart","getMonth","getFullYear","getHours","getMinutes","DateInput","enableTime","shouldDisableDate","disableFuture","disablePast","onChange","calendarPlacement","style","className","doneButtonText","closeOnChange","disablePickers","getRootRef","name","autoFocus","disabled","onClick","onFocus","prevMonthAriaLabel","nextMonthAriaLabel","showNeighboringMonth","size","changeMonthAriaLabel","changeYearAriaLabel","changeDayAriaLabel","changeHoursAriaLabel","changeMinutesAriaLabel","clearFieldAriaLabel","showCalendarAriaLabel","viewDate","onHeaderChange","onNextMonth","onPrevMonth","prevMonthIcon","nextMonthIcon","props","daysRef","useRef","monthsRef","yearsRef","hoursRef","minutesRef","maxElement","onInternalValueChange","useCallback","internalValue","i","formattedValue","mask","Date","refs","useMemo","rootRef","calendarRef","open","openCalendar","closeCalendar","handleKeyDown","setFocusedElement","handleFieldEnter","clear","removeFocusFromField","sizeY","onCalendarChange"],"mappings":";;;;AAAA,OAAO,KAAKA,KAAZ,MAAuB,OAAvB;AACA,SAASC,MAAT,EAAiBC,OAAjB,EAA0BC,KAA1B;AACA,SAASC,WAAT,EAAsBC,qBAAtB,QAAmD,kBAAnD;AACA,SAASC,QAAT;AACA,SAASC,MAAT;AACA,SAASC,QAAT;AACA,SAASC,UAAT;AACA,SAASC,UAAT;AACA,SAASC,SAAT;AAEA,SAASC,YAAT;AACA,SAASC,SAAT;AACA,SAASC,gBAAT;AACA,SAASC,aAAT;AACA,SAASC,YAAT;;AA0CA,IAAMC,cAAc,GAAG,SAAjBA,cAAiB,CAACC,KAAD,EAAmB;AACxC,MAAIC,MAAM,GAAG,CAAb;AACA,MAAIC,GAAG,GAAG,CAAV;AACA,MAAIC,GAAG,GAAG,CAAV;;AAEA,UAAQH,KAAR;AACE,SAAK,CAAL;AACEG,MAAAA,GAAG,GAAG,EAAN;AACA;;AACF,SAAK,CAAL;AACEA,MAAAA,GAAG,GAAG,EAAN;AACA;;AACF,SAAK,CAAL;AACEA,MAAAA,GAAG,GAAG,IAAN;AACAD,MAAAA,GAAG,GAAG,IAAN;AACAD,MAAAA,MAAM,GAAG,CAAT;AACA;;AACF,SAAK,CAAL;AACEE,MAAAA,GAAG,GAAG,EAAN;AACA;;AACF,SAAK,CAAL;AACEA,MAAAA,GAAG,GAAG,EAAN;AACA;AAjBJ;;AAoBA,SAAO;AAAEF,IAAAA,MAAM,EAANA,MAAF;AAAUC,IAAAA,GAAG,EAAHA,GAAV;AAAeC,IAAAA,GAAG,EAAHA;AAAf,GAAP;AACD,CA1BD;;AA4BA,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACC,KAAD,EAAmC;AAC1D,MAAMC,QAAQ,GAAG,CAAC,EAAD,EAAK,EAAL,EAAS,EAAT,EAAa,EAAb,EAAiB,EAAjB,CAAjB;;AACA,MAAID,KAAJ,EAAW;AACTC,IAAAA,QAAQ,CAAC,CAAD,CAAR,GAAcC,MAAM,CAACF,KAAK,CAACG,OAAN,EAAD,CAAN,CAAwBC,QAAxB,CAAiC,CAAjC,EAAoC,GAApC,CAAd;AACAH,IAAAA,QAAQ,CAAC,CAAD,CAAR,GAAcC,MAAM,CAACF,KAAK,CAACK,QAAN,KAAmB,CAApB,CAAN,CAA6BD,QAA7B,CAAsC,CAAtC,EAAyC,GAAzC,CAAd;AACAH,IAAAA,QAAQ,CAAC,CAAD,CAAR,GAAcC,MAAM,CAACF,KAAK,CAACM,WAAN,EAAD,CAAN,CAA4BF,QAA5B,CAAqC,CAArC,EAAwC,GAAxC,CAAd;AACAH,IAAAA,QAAQ,CAAC,CAAD,CAAR,GAAcC,MAAM,CAACF,KAAK,CAACO,QAAN,EAAD,CAAN,CAAyBH,QAAzB,CAAkC,CAAlC,EAAqC,GAArC,CAAd;AACAH,IAAAA,QAAQ,CAAC,CAAD,CAAR,GAAcC,MAAM,CAACF,KAAK,CAACQ,UAAN,EAAD,CAAN,CAA2BJ,QAA3B,CAAoC,CAApC,EAAuC,GAAvC,CAAd;AACD;;AACD,SAAOH,QAAP;AACD,CAVD;AAYA;AACA;AACA;;;AACA,OAAO,IAAMQ,SAAS,GAAG,SAAZA,SAAY,OAqCH;AAAA,MApCpBC,UAoCoB,QApCpBA,UAoCoB;AAAA,MAnCpBC,iBAmCoB,QAnCpBA,iBAmCoB;AAAA,MAlCpBC,aAkCoB,QAlCpBA,aAkCoB;AAAA,MAjCpBC,WAiCoB,QAjCpBA,WAiCoB;AAAA,MAhCpBb,KAgCoB,QAhCpBA,KAgCoB;AAAA,MA/BpBc,QA+BoB,QA/BpBA,QA+BoB;AAAA,mCA9BpBC,iBA8BoB;AAAA,MA9BpBA,iBA8BoB,sCA9BA,cA8BA;AAAA,MA7BpBC,KA6BoB,QA7BpBA,KA6BoB;AAAA,MA5BpBC,SA4BoB,QA5BpBA,SA4BoB;AAAA,MA3BpBC,cA2BoB,QA3BpBA,cA2BoB;AAAA,gCA1BpBC,aA0BoB;AAAA,MA1BpBA,aA0BoB,mCA1BJ,IA0BI;AAAA,MAzBpBC,cAyBoB,QAzBpBA,cAyBoB;AAAA,MAxBpBC,UAwBoB,QAxBpBA,UAwBoB;AAAA,MAvBpBC,IAuBoB,QAvBpBA,IAuBoB;AAAA,MAtBpBC,SAsBoB,QAtBpBA,SAsBoB;AAAA,MArBpBC,QAqBoB,QArBpBA,QAqBoB;AAAA,MApBpBC,OAoBoB,QApBpBA,OAoBoB;AAAA,MAnBpBC,OAmBoB,QAnBpBA,OAmBoB;AAAA,MAlBpBC,kBAkBoB,QAlBpBA,kBAkBoB;AAAA,MAjBpBC,kBAiBoB,QAjBpBA,kBAiBoB;AAAA,MAhBpBC,oBAgBoB,QAhBpBA,oBAgBoB;AAAA,MAfpBC,IAeoB,QAfpBA,IAeoB;AAAA,mCAdpBC,oBAcoB;AAAA,MAdpBA,oBAcoB,sCAdG,gBAcH;AAAA,mCAbpBC,mBAaoB;AAAA,MAbpBA,mBAaoB,sCAbE,cAaF;AAAA,mCAZpBC,kBAYoB;AAAA,MAZpBA,kBAYoB,sCAZC,eAYD;AAAA,mCAXpBC,oBAWoB;AAAA,MAXpBA,oBAWoB,sCAXG,cAWH;AAAA,mCAVpBC,sBAUoB;AAAA,MAVpBA,sBAUoB,sCAVK,iBAUL;AAAA,mCATpBC,mBASoB;AAAA,MATpBA,mBASoB,sCATE,eASF;AAAA,mCARpBC,qBAQoB;AAAA,MARpBA,qBAQoB,sCARI,oBAQJ;AAAA,MAPpBC,QAOoB,QAPpBA,QAOoB;AAAA,MANpBC,cAMoB,QANpBA,cAMoB;AAAA,MALpBC,WAKoB,QALpBA,WAKoB;AAAA,MAJpBC,WAIoB,QAJpBA,WAIoB;AAAA,MAHpBC,aAGoB,QAHpBA,aAGoB;AAAA,MAFpBC,aAEoB,QAFpBA,aAEoB;AAAA,MADjBC,KACiB;;AACpB,MAAMC,OAAO,GAAGpE,KAAK,CAACqE,MAAN,CAA8B,IAA9B,CAAhB;AACA,MAAMC,SAAS,GAAGtE,KAAK,CAACqE,MAAN,CAA8B,IAA9B,CAAlB;AACA,MAAME,QAAQ,GAAGvE,KAAK,CAACqE,MAAN,CAA8B,IAA9B,CAAjB;AACA,MAAMG,QAAQ,GAAGxE,KAAK,CAACqE,MAAN,CAA8B,IAA9B,CAAjB;AACA,MAAMI,UAAU,GAAGzE,KAAK,CAACqE,MAAN,CAA8B,IAA9B,CAAnB;AAEA,MAAMK,UAAU,GAAGzC,UAAU,GAAG,CAAH,GAAO,CAApC;AAEA,MAAM0C,qBAAqB,GAAG3E,KAAK,CAAC4E,WAAN,CAC5B,UAACC,aAAD,EAA6B;AAC3B,SAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,IAAIJ,UAArB,EAAiCI,CAAC,IAAI,CAAtC,EAAyC;AACvC,UAAID,aAAa,CAACC,CAAD,CAAb,CAAiB3D,MAAjB,GAA0BF,cAAc,CAAC6D,CAAD,CAAd,CAAkB3D,MAAhD,EAAwD;AACtD;AACD;AACF;;AAED,QAAI4D,cAAc,aAAMF,aAAa,CAAC,CAAD,CAAnB,cAA0BA,aAAa,CAAC,CAAD,CAAvC,cAA8CA,aAAa,CAAC,CAAD,CAA3D,CAAlB;AACA,QAAIG,IAAI,GAAG,YAAX;;AACA,QAAI/C,UAAJ,EAAgB;AACd8C,MAAAA,cAAc,eAAQF,aAAa,CAAC,CAAD,CAArB,cAA4BA,aAAa,CAAC,CAAD,CAAzC,CAAd;AACAG,MAAAA,IAAI,IAAI,QAAR;AACD;;AAED,QAAI9E,OAAO,CAAC6E,cAAD,EAAiBC,IAAjB,CAAX,EAAmC;AACjC3C,MAAAA,QAAQ,SAAR,IAAAA,QAAQ,WAAR,YAAAA,QAAQ,CAAGlC,KAAK,CAAC4E,cAAD,EAAiBC,IAAjB,EAAuBzD,KAAvB,aAAuBA,KAAvB,cAAuBA,KAAvB,GAAgC,IAAI0D,IAAJ,EAAhC,CAAR,CAAR;AACD;AACF,GAlB2B,EAmB5B,CAAChD,UAAD,EAAayC,UAAb,EAAyBrC,QAAzB,EAAmCd,KAAnC,CAnB4B,CAA9B;AAsBA,MAAM2D,IAAI,GAAGlF,KAAK,CAACmF,OAAN,CACX;AAAA,WAAM,CAACf,OAAD,EAAUE,SAAV,EAAqBC,QAArB,EAA+BC,QAA/B,EAAyCC,UAAzC,CAAN;AAAA,GADW,EAEX,CAACL,OAAD,EAAUE,SAAV,EAAqBC,QAArB,EAA+BC,QAA/B,EAAyCC,UAAzC,CAFW,CAAb;;AAKA,sBAYI7D,YAAY,CAAC;AACf8D,IAAAA,UAAU,EAAVA,UADe;AAEfQ,IAAAA,IAAI,EAAJA,IAFe;AAGfpC,IAAAA,SAAS,EAATA,SAHe;AAIfC,IAAAA,QAAQ,EAARA,QAJe;AAKf9B,IAAAA,cAAc,EAAdA,cALe;AAMfoB,IAAAA,QAAQ,EAARA,QANe;AAOfsC,IAAAA,qBAAqB,EAArBA,qBAPe;AAQfrD,IAAAA,gBAAgB,EAAhBA,gBARe;AASfC,IAAAA,KAAK,EAALA;AATe,GAAD,CAZhB;AAAA,MACE6D,OADF,iBACEA,OADF;AAAA,MAEEC,WAFF,iBAEEA,WAFF;AAAA,MAGEC,IAHF,iBAGEA,IAHF;AAAA,MAIEC,YAJF,iBAIEA,YAJF;AAAA,MAKEC,aALF,iBAKEA,aALF;AAAA,MAMEX,aANF,iBAMEA,aANF;AAAA,MAOEY,aAPF,iBAOEA,aAPF;AAAA,MAQEC,iBARF,iBAQEA,iBARF;AAAA,MASEC,gBATF,iBASEA,gBATF;AAAA,MAUEC,KAVF,iBAUEA,KAVF;AAAA,MAWEC,oBAXF,iBAWEA,oBAXF;;AAwBA,uBAAkB9E,aAAa,EAA/B;AAAA,MAAQ+E,KAAR,kBAAQA,KAAR;;AAEA,MAAMC,gBAAgB,GAAG/F,KAAK,CAAC4E,WAAN,CACvB,UAACrD,KAAD,EAA8B;AAC5Bc,IAAAA,QAAQ,SAAR,IAAAA,QAAQ,WAAR,YAAAA,QAAQ,CAAGd,KAAH,CAAR;;AACA,QAAImB,aAAa,IAAI,CAACT,UAAtB,EAAkC;AAChC4D,MAAAA,oBAAoB;AACrB;AACF,GANsB,EAOvB,CAACxD,QAAD,EAAWwD,oBAAX,EAAiCnD,aAAjC,EAAgDT,UAAhD,CAPuB,CAAzB;AAUA,SACE,oBAAC,SAAD;AACE,IAAA,SAAS,EAAEvB,UAAU,CAAC,WAAD,6BAAkCoF,KAAlC,EADvB;AAEE,IAAA,KAAK,EAAEvD,KAFT;AAGE,IAAA,SAAS,EAAEC,SAHb;AAIE,IAAA,UAAU,EAAEhC,QAAQ,CAAC4E,OAAD,EAAUxC,UAAV,CAJtB;AAKE,IAAA,KAAK,EACHrB,KAAK,GACH,oBAAC,UAAD;AACE,MAAA,SAAS,EAAC,SADZ;AAEE,oBAAYoC,mBAFd;AAGE,MAAA,OAAO,EAAEiC;AAHX,OAKE,oBAAC,WAAD,OALF,CADG,GASH,oBAAC,UAAD;AACE,MAAA,SAAS,EAAC,SADZ;AAEE,oBAAYhC,qBAFd;AAGE,MAAA,OAAO,EAAE2B;AAHX,OAKE,oBAAC,qBAAD,OALF,CAfN;AAwBE,IAAA,QAAQ,EAAExC,QAxBZ;AAyBE,IAAA,OAAO,EAAE/B,YAAY,CAAC2E,gBAAD,EAAmB3C,OAAnB,CAzBvB;AA0BE,IAAA,OAAO,EAAEhC,YAAY,CAAC2E,gBAAD,EAAmB1C,OAAnB;AA1BvB,KA2BMkB,KA3BN,GA6BE;AACE,IAAA,IAAI,EAAC,QADP;AAEE,IAAA,IAAI,EAAEtB,IAFR;AAGE,IAAA,KAAK,EACHtB,KAAK,GACDtB,MAAM,CAACsB,KAAD,EAAQU,UAAU,GAAG,kBAAH,GAAwB,YAA1C,CADL,GAED;AANR,IA7BF,EAsCE;AAAM,IAAA,SAAS,EAAC,kBAAhB;AAAmC,IAAA,SAAS,EAAEwD;AAA9C,KACE,oBAAC,SAAD;AACE,IAAA,QAAQ,EAAE,CADZ;AAEE,IAAA,MAAM,EAAE,CAFV;AAGE,IAAA,UAAU,EAAErB,OAHd;AAIE,IAAA,KAAK,EAAE,CAJT;AAKE,IAAA,eAAe,EAAEsB,iBALnB;AAME,IAAA,KAAK,EAAEb,aAAa,CAAC,CAAD,CANtB;AAOE,kBAAYrB;AAPd,IADF,EAUE,oBAAC,gBAAD,YAVF,EAWE,oBAAC,SAAD;AACE,IAAA,MAAM,EAAE,CADV;AAEE,IAAA,UAAU,EAAEc,SAFd;AAGE,IAAA,KAAK,EAAE,CAHT;AAIE,IAAA,eAAe,EAAEoB,iBAJnB;AAKE,IAAA,KAAK,EAAEb,aAAa,CAAC,CAAD,CALtB;AAME,kBAAYvB;AANd,IAXF,EAmBE,oBAAC,gBAAD,YAnBF,EAoBE,oBAAC,SAAD;AACE,IAAA,MAAM,EAAE,CADV;AAEE,IAAA,UAAU,EAAEiB,QAFd;AAGE,IAAA,KAAK,EAAE,CAHT;AAIE,IAAA,eAAe,EAAEmB,iBAJnB;AAKE,IAAA,KAAK,EAAEb,aAAa,CAAC,CAAD,CALtB;AAME,kBAAYtB;AANd,IApBF,EA4BGtB,UAAU,IACT,oBAAC,KAAD,CAAO,QAAP,QACE,oBAAC,gBAAD;AAAkB,IAAA,SAAS,EAAC;AAA5B,KACG,GADH,CADF,EAIE,oBAAC,SAAD;AACE,IAAA,MAAM,EAAE,CADV;AAEE,IAAA,UAAU,EAAEuC,QAFd;AAGE,IAAA,KAAK,EAAE,CAHT;AAIE,IAAA,eAAe,EAAEkB,iBAJnB;AAKE,IAAA,KAAK,EAAEb,aAAa,CAAC,CAAD,CALtB;AAME,kBAAYpB;AANd,IAJF,EAYE,oBAAC,gBAAD,YAZF,EAaE,oBAAC,SAAD;AACE,IAAA,MAAM,EAAE,CADV;AAEE,IAAA,UAAU,EAAEgB,UAFd;AAGE,IAAA,KAAK,EAAE,CAHT;AAIE,IAAA,eAAe,EAAEiB,iBAJnB;AAKE,IAAA,KAAK,EAAEb,aAAa,CAAC,CAAD,CALtB;AAME,kBAAYnB;AANd,IAbF,CA7BJ,CAtCF,EA2FG4B,IAAI,IACH,oBAAC,MAAD;AACE,IAAA,SAAS,EAAEF,OADb;AAEE,IAAA,cAAc,EAAE,CAFlB;AAGE,IAAA,SAAS,EAAE9C;AAHb,KAKE,oBAAC,QAAD;AACE,IAAA,KAAK,EAAEf,KADT;AAEE,IAAA,QAAQ,EAAEwE,gBAFZ;AAGE,IAAA,UAAU,EAAE9D,UAHd;AAIE,IAAA,WAAW,EAAEG,WAJf;AAKE,IAAA,aAAa,EAAED,aALjB;AAME,IAAA,iBAAiB,EAAED,iBANrB;AAOE,IAAA,OAAO,EAAEsD,aAPX;AAQE,IAAA,UAAU,EAAEH,WARd;AASE,IAAA,cAAc,EAAE5C,cATlB;AAUE,IAAA,cAAc,EAAEE,cAVlB;AAWE,IAAA,oBAAoB,EAAEc,oBAXxB;AAYE,IAAA,sBAAsB,EAAEC,sBAZ1B;AAaE,IAAA,kBAAkB,EAAER,kBAbtB;AAcE,IAAA,kBAAkB,EAAEC,kBAdtB;AAeE,IAAA,oBAAoB,EAAEG,oBAfxB;AAgBE,IAAA,mBAAmB,EAAEC,mBAhBvB;AAiBE,IAAA,kBAAkB,EAAEC,kBAjBtB;AAkBE,IAAA,oBAAoB,EAAEJ,oBAlBxB;AAmBE,IAAA,IAAI,EAAEC,IAnBR;AAoBE,IAAA,QAAQ,EAAEQ,QApBZ;AAqBE,IAAA,cAAc,EAAEC,cArBlB;AAsBE,IAAA,WAAW,EAAEC,WAtBf;AAuBE,IAAA,WAAW,EAAEC,WAvBf;AAwBE,IAAA,aAAa,EAAEC,aAxBjB;AAyBE,IAAA,aAAa,EAAEC;AAzBjB,IALF,CA5FJ,CADF;AAiID,CA9OM","sourcesContent":["import * as React from \"react\";\nimport { format, isMatch, parse } from \"../../lib/date\";\nimport { Icon16Clear, Icon20CalendarOutline } from \"@vkontakte/icons\";\nimport { Calendar, CalendarProps } from \"../Calendar/Calendar\";\nimport { Popper, Placement } from \"../Popper/Popper\";\nimport { multiRef } from \"../../lib/utils\";\nimport { IconButton } from \"../IconButton/IconButton\";\nimport { classNames } from \"../../lib/classNames\";\nimport { FormField } from \"../FormField/FormField\";\nimport { HasRootRef } from \"../../types\";\nimport { useDateInput } from \"../../hooks/useDateInput\";\nimport { InputLike } from \"../InputLike/InputLike\";\nimport { InputLikeDivider } from \"../InputLike/InputLikeDivider\";\nimport { useAdaptivity } from \"../../hooks/useAdaptivity\";\nimport { callMultiple } from \"../../lib/callMultiple\";\nimport \"./DateInput.css\";\n\nexport interface DateInputProps\n extends Omit<\n React.InputHTMLAttributes<HTMLDivElement>,\n \"value\" | \"onChange\" | \"size\"\n >,\n Pick<\n CalendarProps,\n | \"disablePast\"\n | \"disableFuture\"\n | \"enableTime\"\n | \"shouldDisableDate\"\n | \"onChange\"\n | \"value\"\n | \"doneButtonText\"\n | \"weekStartsOn\"\n | \"disablePickers\"\n | \"changeHoursAriaLabel\"\n | \"changeMinutesAriaLabel\"\n | \"prevMonthAriaLabel\"\n | \"nextMonthAriaLabel\"\n | \"changeMonthAriaLabel\"\n | \"changeYearAriaLabel\"\n | \"changeDayAriaLabel\"\n | \"showNeighboringMonth\"\n | \"size\"\n | \"viewDate\"\n | \"onHeaderChange\"\n | \"onNextMonth\"\n | \"onPrevMonth\"\n | \"prevMonthIcon\"\n | \"nextMonthIcon\"\n >,\n HasRootRef<HTMLDivElement> {\n calendarPlacement?: Placement;\n closeOnChange?: boolean;\n clearFieldAriaLabel?: string;\n showCalendarAriaLabel?: string;\n}\n\nconst elementsConfig = (index: number) => {\n let length = 2;\n let min = 1;\n let max = 0;\n\n switch (index) {\n case 0:\n max = 31;\n break;\n case 1:\n max = 12;\n break;\n case 2:\n max = 2100;\n min = 1900;\n length = 4;\n break;\n case 3:\n max = 23;\n break;\n case 4:\n max = 59;\n break;\n }\n\n return { length, min, max };\n};\n\nconst getInternalValue = (value: CalendarProps[\"value\"]) => {\n const newValue = [\"\", \"\", \"\", \"\", \"\"];\n if (value) {\n newValue[0] = String(value.getDate()).padStart(2, \"0\");\n newValue[1] = String(value.getMonth() + 1).padStart(2, \"0\");\n newValue[2] = String(value.getFullYear()).padStart(4, \"0\");\n newValue[3] = String(value.getHours()).padStart(2, \"0\");\n newValue[4] = String(value.getMinutes()).padStart(2, \"0\");\n }\n return newValue;\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/DateInput\n */\nexport const DateInput = ({\n enableTime,\n shouldDisableDate,\n disableFuture,\n disablePast,\n value,\n onChange,\n calendarPlacement = \"bottom-start\",\n style,\n className,\n doneButtonText,\n closeOnChange = true,\n disablePickers,\n getRootRef,\n name,\n autoFocus,\n disabled,\n onClick,\n onFocus,\n prevMonthAriaLabel,\n nextMonthAriaLabel,\n showNeighboringMonth,\n size,\n changeMonthAriaLabel = \"Изменить месяц\",\n changeYearAriaLabel = \"Изменить год\",\n changeDayAriaLabel = \"Изменить день\",\n changeHoursAriaLabel = \"Изменить час\",\n changeMinutesAriaLabel = \"Изменить минуту\",\n clearFieldAriaLabel = \"Очистить поле\",\n showCalendarAriaLabel = \"Показать календарь\",\n viewDate,\n onHeaderChange,\n onNextMonth,\n onPrevMonth,\n prevMonthIcon,\n nextMonthIcon,\n ...props\n}: DateInputProps) => {\n const daysRef = React.useRef<HTMLSpanElement>(null);\n const monthsRef = React.useRef<HTMLSpanElement>(null);\n const yearsRef = React.useRef<HTMLSpanElement>(null);\n const hoursRef = React.useRef<HTMLSpanElement>(null);\n const minutesRef = React.useRef<HTMLSpanElement>(null);\n\n const maxElement = enableTime ? 4 : 2;\n\n const onInternalValueChange = React.useCallback(\n (internalValue: string[]) => {\n for (let i = 0; i <= maxElement; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n return;\n }\n }\n\n let formattedValue = `${internalValue[0]}.${internalValue[1]}.${internalValue[2]}`;\n let mask = \"DD.MM.YYYY\";\n if (enableTime) {\n formattedValue += ` ${internalValue[3]}:${internalValue[4]}`;\n mask += \" HH:mm\";\n }\n\n if (isMatch(formattedValue, mask)) {\n onChange?.(parse(formattedValue, mask, value ?? new Date()));\n }\n },\n [enableTime, maxElement, onChange, value]\n );\n\n const refs = React.useMemo(\n () => [daysRef, monthsRef, yearsRef, hoursRef, minutesRef],\n [daysRef, monthsRef, yearsRef, hoursRef, minutesRef]\n );\n\n const {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n closeCalendar,\n internalValue,\n handleKeyDown,\n setFocusedElement,\n handleFieldEnter,\n clear,\n removeFocusFromField,\n } = useDateInput({\n maxElement,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange,\n onInternalValueChange,\n getInternalValue,\n value,\n });\n\n const { sizeY } = useAdaptivity();\n\n const onCalendarChange = React.useCallback(\n (value?: Date | undefined) => {\n onChange?.(value);\n if (closeOnChange && !enableTime) {\n removeFocusFromField();\n }\n },\n [onChange, removeFocusFromField, closeOnChange, enableTime]\n );\n\n return (\n <FormField\n vkuiClass={classNames(\"DateInput\", `DateInput--sizeY-${sizeY}`)}\n style={style}\n className={className}\n getRootRef={multiRef(rootRef, getRootRef)}\n after={\n value ? (\n <IconButton\n hoverMode=\"opacity\"\n aria-label={clearFieldAriaLabel}\n onClick={clear}\n >\n <Icon16Clear />\n </IconButton>\n ) : (\n <IconButton\n hoverMode=\"opacity\"\n aria-label={showCalendarAriaLabel}\n onClick={openCalendar}\n >\n <Icon20CalendarOutline />\n </IconButton>\n )\n }\n disabled={disabled}\n onClick={callMultiple(handleFieldEnter, onClick)}\n onFocus={callMultiple(handleFieldEnter, onFocus)}\n {...props}\n >\n <input\n type=\"hidden\"\n name={name}\n value={\n value\n ? format(value, enableTime ? \"DD.MM.YYYYTHH:mm\" : \"DD.MM.YYYY\")\n : \"\"\n }\n />\n <span vkuiClass=\"DateInput__input\" onKeyDown={handleKeyDown}>\n <InputLike\n tabIndex={1}\n length={2}\n getRootRef={daysRef}\n index={0}\n onElementSelect={setFocusedElement}\n value={internalValue[0]}\n aria-label={changeDayAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsRef}\n index={1}\n onElementSelect={setFocusedElement}\n value={internalValue[1]}\n aria-label={changeMonthAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsRef}\n index={2}\n onElementSelect={setFocusedElement}\n value={internalValue[2]}\n aria-label={changeYearAriaLabel}\n />\n {enableTime && (\n <React.Fragment>\n <InputLikeDivider vkuiClass=\"DateInput__input-time-divider\">\n {\" \"}\n </InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={hoursRef}\n index={3}\n onElementSelect={setFocusedElement}\n value={internalValue[3]}\n aria-label={changeHoursAriaLabel}\n />\n <InputLikeDivider>:</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={minutesRef}\n index={4}\n onElementSelect={setFocusedElement}\n value={internalValue[4]}\n aria-label={changeMinutesAriaLabel}\n />\n </React.Fragment>\n )}\n </span>\n {open && (\n <Popper\n targetRef={rootRef}\n offsetDistance={8}\n placement={calendarPlacement}\n >\n <Calendar\n value={value}\n onChange={onCalendarChange}\n enableTime={enableTime}\n disablePast={disablePast}\n disableFuture={disableFuture}\n shouldDisableDate={shouldDisableDate}\n onClose={closeCalendar}\n getRootRef={calendarRef}\n doneButtonText={doneButtonText}\n disablePickers={disablePickers}\n changeHoursAriaLabel={changeHoursAriaLabel}\n changeMinutesAriaLabel={changeMinutesAriaLabel}\n prevMonthAriaLabel={prevMonthAriaLabel}\n nextMonthAriaLabel={nextMonthAriaLabel}\n changeMonthAriaLabel={changeMonthAriaLabel}\n changeYearAriaLabel={changeYearAriaLabel}\n changeDayAriaLabel={changeDayAriaLabel}\n showNeighboringMonth={showNeighboringMonth}\n size={size}\n viewDate={viewDate}\n onHeaderChange={onHeaderChange}\n onNextMonth={onNextMonth}\n onPrevMonth={onPrevMonth}\n prevMonthIcon={prevMonthIcon}\n nextMonthIcon={nextMonthIcon}\n />\n </Popper>\n )}\n </FormField>\n );\n};\n"],"file":"DateInput.js"}