@vkontakte/vkui 5.3.2 → 5.4.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 (792) hide show
  1. package/dist/cjs/components/Accordion/Accordion.d.ts +2 -2
  2. package/dist/cjs/components/Accordion/Accordion.js.map +1 -1
  3. package/dist/cjs/components/Accordion/AccordionSummary.d.ts +1 -1
  4. package/dist/cjs/components/Accordion/AccordionSummary.js.map +1 -1
  5. package/dist/cjs/components/ActionSheet/types.d.ts +1 -1
  6. package/dist/cjs/components/ActionSheet/types.js.map +1 -1
  7. package/dist/cjs/components/AdaptiveIconRenderer/AdaptiveIconRenderer.d.ts +14 -0
  8. package/dist/cjs/components/{WriteBarIcon/WriteBarIconRenderer.js → AdaptiveIconRenderer/AdaptiveIconRenderer.js} +4 -4
  9. package/dist/cjs/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -0
  10. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.d.ts +4 -4
  11. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  12. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  13. package/dist/cjs/components/AppRoot/AppRootPortal.d.ts +3 -3
  14. package/dist/cjs/components/AppRoot/AppRootPortal.js.map +1 -1
  15. package/dist/cjs/components/AppRoot/ScrollContext.d.ts +2 -2
  16. package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
  17. package/dist/cjs/components/Button/Button.d.ts +1 -0
  18. package/dist/cjs/components/Button/Button.js +2 -2
  19. package/dist/cjs/components/Button/Button.js.map +1 -1
  20. package/dist/cjs/components/Card/Card.js +1 -3
  21. package/dist/cjs/components/Card/Card.js.map +1 -1
  22. package/dist/cjs/components/CardGrid/CardGrid.js +4 -4
  23. package/dist/cjs/components/CardGrid/CardGrid.js.map +1 -1
  24. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.d.ts +4 -2
  25. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js +10 -6
  26. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  27. package/dist/cjs/components/Checkbox/Checkbox.d.ts +2 -1
  28. package/dist/cjs/components/Checkbox/Checkbox.js +12 -8
  29. package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
  30. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts +4 -0
  31. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +3 -2
  32. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  33. package/dist/cjs/components/Counter/Counter.js +3 -5
  34. package/dist/cjs/components/Counter/Counter.js.map +1 -1
  35. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +3 -0
  36. package/dist/cjs/components/CustomSelect/CustomSelect.js +1 -1
  37. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  38. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js +1 -1
  39. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  40. package/dist/cjs/components/DateRangeInput/DateRangeInput.js +1 -1
  41. package/dist/cjs/components/DateRangeInput/DateRangeInput.js.map +1 -1
  42. package/dist/cjs/components/Epic/ScrollSaver.d.ts +3 -3
  43. package/dist/cjs/components/Epic/ScrollSaver.js.map +1 -1
  44. package/dist/cjs/components/File/File.js +4 -3
  45. package/dist/cjs/components/File/File.js.map +1 -1
  46. package/dist/cjs/components/FixedLayout/FixedLayout.js +1 -1
  47. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  48. package/dist/cjs/components/FocusVisible/FocusVisible.d.ts +4 -2
  49. package/dist/cjs/components/FocusVisible/FocusVisible.js +4 -3
  50. package/dist/cjs/components/FocusVisible/FocusVisible.js.map +1 -1
  51. package/dist/cjs/components/FormField/FormField.js +10 -1
  52. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  53. package/dist/cjs/components/FormItem/FormItem.d.ts +3 -1
  54. package/dist/cjs/components/FormItem/FormItem.js +2 -1
  55. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  56. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.d.ts +3 -1
  57. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  58. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  59. package/dist/cjs/components/Group/Group.d.ts +5 -3
  60. package/dist/cjs/components/Group/Group.js +2 -2
  61. package/dist/cjs/components/Group/Group.js.map +1 -1
  62. package/dist/cjs/components/Header/Header.js +20 -16
  63. package/dist/cjs/components/Header/Header.js.map +1 -1
  64. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.d.ts +5 -1
  65. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js +4 -1
  66. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  67. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.d.ts +2 -1
  68. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.js +6 -2
  69. package/dist/cjs/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  70. package/dist/cjs/components/HoverPopper/HoverPopper.d.ts +1 -1
  71. package/dist/cjs/components/HoverPopper/HoverPopper.js.map +1 -1
  72. package/dist/cjs/components/IconButton/IconButton.d.ts +3 -3
  73. package/dist/cjs/components/IconButton/IconButton.js.map +1 -1
  74. package/dist/cjs/components/LocaleProvider/LocaleProvider.d.ts +2 -2
  75. package/dist/cjs/components/LocaleProvider/LocaleProvider.js.map +1 -1
  76. package/dist/cjs/components/ModalPage/ModalPage.d.ts +1 -1
  77. package/dist/cjs/components/ModalPage/ModalPage.js +19 -3
  78. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  79. package/dist/cjs/components/ModalPage/ModalPageContext.d.ts +5 -0
  80. package/dist/cjs/components/{Typography/types.js → ModalPage/ModalPageContext.js} +8 -1
  81. package/dist/cjs/components/ModalPage/ModalPageContext.js.map +1 -0
  82. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js +6 -1
  83. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  84. package/dist/cjs/components/ModalRoot/ModalRoot.d.ts +2 -27
  85. package/dist/cjs/components/ModalRoot/ModalRoot.js +13 -22
  86. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  87. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.d.ts +2 -21
  88. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  89. package/dist/cjs/components/ModalRoot/ModalRootDesktop.d.ts +3 -28
  90. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +145 -219
  91. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  92. package/dist/cjs/components/ModalRoot/types.d.ts +28 -0
  93. package/dist/cjs/components/ModalRoot/types.js.map +1 -1
  94. package/dist/cjs/components/ModalRoot/useModalManager.d.ts +6 -5
  95. package/dist/cjs/components/ModalRoot/useModalManager.js +3 -3
  96. package/dist/cjs/components/ModalRoot/useModalManager.js.map +1 -1
  97. package/dist/cjs/components/NativeSelect/NativeSelect.d.ts +6 -2
  98. package/dist/cjs/components/NativeSelect/NativeSelect.js +6 -3
  99. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  100. package/dist/cjs/components/Panel/Panel.js +2 -2
  101. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  102. package/dist/cjs/components/PanelHeader/PanelHeader.d.ts +11 -2
  103. package/dist/cjs/components/PanelHeader/PanelHeader.js +17 -7
  104. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  105. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js +1 -1
  106. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  107. package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  108. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js +3 -3
  109. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  110. package/dist/cjs/components/PlatformProvider/PlatformProvider.d.ts +1 -1
  111. package/dist/cjs/components/PlatformProvider/PlatformProvider.js.map +1 -1
  112. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  113. package/dist/cjs/components/Popover/Popover.d.ts +3 -2
  114. package/dist/cjs/components/Popover/Popover.js +5 -3
  115. package/dist/cjs/components/Popover/Popover.js.map +1 -1
  116. package/dist/cjs/components/PromoBanner/PromoBanner.js.map +1 -1
  117. package/dist/cjs/components/PullToRefresh/PullToRefresh.d.ts +3 -4
  118. package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
  119. package/dist/cjs/components/Radio/Radio.d.ts +2 -1
  120. package/dist/cjs/components/Radio/Radio.js +14 -8
  121. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  122. package/dist/cjs/components/Removable/Removable.d.ts +7 -2
  123. package/dist/cjs/components/Removable/Removable.js +4 -3
  124. package/dist/cjs/components/Removable/Removable.js.map +1 -1
  125. package/dist/cjs/components/Root/Root.js.map +1 -1
  126. package/dist/cjs/components/Search/Search.d.ts +3 -1
  127. package/dist/cjs/components/Search/Search.js +42 -57
  128. package/dist/cjs/components/Search/Search.js.map +1 -1
  129. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +5 -3
  130. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +8 -4
  131. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  132. package/dist/cjs/components/SelectMimicry/SelectMimicry.js +1 -1
  133. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  134. package/dist/cjs/components/SelectTypography/SelectTypography.d.ts +2 -3
  135. package/dist/cjs/components/SelectTypography/SelectTypography.js.map +1 -1
  136. package/dist/cjs/components/SimpleCell/SimpleCell.js +8 -5
  137. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  138. package/dist/cjs/components/Spacing/Spacing.d.ts +2 -2
  139. package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
  140. package/dist/cjs/components/SplitCol/SplitCol.js +1 -0
  141. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  142. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js +1 -3
  143. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  144. package/dist/cjs/components/Switch/Switch.d.ts +4 -5
  145. package/dist/cjs/components/Switch/Switch.js +12 -8
  146. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  147. package/dist/cjs/components/Tabbar/Tabbar.js +2 -4
  148. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  149. package/dist/cjs/components/TabbarItem/TabbarItem.js +1 -1
  150. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  151. package/dist/cjs/components/Tappable/Tappable.d.ts +2 -3
  152. package/dist/cjs/components/Tappable/Tappable.js +1 -0
  153. package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
  154. package/dist/cjs/components/Typography/Caption/Caption.d.ts +2 -2
  155. package/dist/cjs/components/Typography/Caption/Caption.js +10 -13
  156. package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
  157. package/dist/cjs/components/Typography/Footnote/Footnote.d.ts +2 -2
  158. package/dist/cjs/components/Typography/Footnote/Footnote.js +10 -13
  159. package/dist/cjs/components/Typography/Footnote/Footnote.js.map +1 -1
  160. package/dist/cjs/components/Typography/Headline/Headline.d.ts +3 -4
  161. package/dist/cjs/components/Typography/Headline/Headline.js +9 -12
  162. package/dist/cjs/components/Typography/Headline/Headline.js.map +1 -1
  163. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts +3 -5
  164. package/dist/cjs/components/Typography/Paragraph/Paragraph.js +8 -13
  165. package/dist/cjs/components/Typography/Paragraph/Paragraph.js.map +1 -1
  166. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts +2 -2
  167. package/dist/cjs/components/Typography/Subhead/Subhead.js +9 -12
  168. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  169. package/dist/cjs/components/Typography/Text/Text.d.ts +3 -5
  170. package/dist/cjs/components/Typography/Text/Text.js +8 -13
  171. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  172. package/dist/cjs/components/Typography/Title/Title.d.ts +2 -2
  173. package/dist/cjs/components/Typography/Title/Title.js +10 -13
  174. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  175. package/dist/cjs/components/Typography/Typography.d.ts +16 -0
  176. package/dist/cjs/components/Typography/Typography.js +35 -0
  177. package/dist/cjs/components/Typography/Typography.js.map +1 -0
  178. package/dist/cjs/components/UsersStack/UsersStack.d.ts +2 -2
  179. package/dist/cjs/components/UsersStack/UsersStack.js +2 -1
  180. package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
  181. package/dist/cjs/components/View/View.js +1 -1
  182. package/dist/cjs/components/View/View.js.map +1 -1
  183. package/dist/cjs/components/View/ViewInfinite.js +1 -1
  184. package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
  185. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.d.ts +14 -0
  186. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.js +29 -0
  187. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.js.map +1 -0
  188. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +4 -4
  189. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.js +5 -0
  190. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -1
  191. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js +2 -2
  192. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  193. package/dist/cjs/helpers/getPlatformClassName.js +1 -1
  194. package/dist/cjs/helpers/getPlatformClassName.js.map +1 -1
  195. package/dist/cjs/hooks/useFocusWithin.d.ts +2 -0
  196. package/dist/cjs/hooks/useFocusWithin.js +38 -0
  197. package/dist/cjs/hooks/useFocusWithin.js.map +1 -0
  198. package/dist/cjs/hooks/useId.js +1 -1
  199. package/dist/cjs/hooks/useId.js.map +1 -1
  200. package/dist/cjs/hooks/useWaitTransitionFinish.d.ts +1 -1
  201. package/dist/cjs/hooks/useWaitTransitionFinish.js.map +1 -1
  202. package/dist/cjs/index.d.ts +4 -2
  203. package/dist/cjs/index.js +8 -0
  204. package/dist/cjs/index.js.map +1 -1
  205. package/dist/cjs/lib/utils.js +2 -2
  206. package/dist/cjs/lib/utils.js.map +1 -1
  207. package/dist/components/Accordion/Accordion.d.ts +2 -2
  208. package/dist/components/Accordion/Accordion.js +2 -2
  209. package/dist/components/Accordion/Accordion.js.map +1 -1
  210. package/dist/components/Accordion/AccordionSummary.d.ts +1 -1
  211. package/dist/components/Accordion/AccordionSummary.js +1 -1
  212. package/dist/components/Accordion/AccordionSummary.js.map +1 -1
  213. package/dist/components/ActionSheet/types.d.ts +1 -1
  214. package/dist/components/ActionSheet/types.js.map +1 -1
  215. package/dist/components/AdaptiveIconRenderer/AdaptiveIconRenderer.d.ts +14 -0
  216. package/dist/components/{WriteBarIcon/WriteBarIconRenderer.js → AdaptiveIconRenderer/AdaptiveIconRenderer.js} +5 -2
  217. package/dist/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -0
  218. package/dist/components/AdaptivityProvider/AdaptivityProvider.d.ts +4 -4
  219. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  220. package/dist/components/Alert/Alert.js.map +1 -1
  221. package/dist/components/AppRoot/AppRootPortal.d.ts +3 -3
  222. package/dist/components/AppRoot/AppRootPortal.js.map +1 -1
  223. package/dist/components/AppRoot/ScrollContext.d.ts +2 -2
  224. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  225. package/dist/components/Button/Button.d.ts +1 -0
  226. package/dist/components/Button/Button.js +2 -2
  227. package/dist/components/Button/Button.js.map +1 -1
  228. package/dist/components/Card/Card.js +1 -3
  229. package/dist/components/Card/Card.js.map +1 -1
  230. package/dist/components/CardGrid/CardGrid.js +4 -4
  231. package/dist/components/CardGrid/CardGrid.js.map +1 -1
  232. package/dist/components/Cell/CellCheckbox/CellCheckbox.d.ts +4 -2
  233. package/dist/components/Cell/CellCheckbox/CellCheckbox.js +10 -6
  234. package/dist/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  235. package/dist/components/Checkbox/Checkbox.d.ts +2 -1
  236. package/dist/components/Checkbox/Checkbox.js +12 -8
  237. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  238. package/dist/components/ChipsSelect/ChipsSelect.d.ts +4 -0
  239. package/dist/components/ChipsSelect/ChipsSelect.js +3 -2
  240. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  241. package/dist/components/Counter/Counter.js +4 -6
  242. package/dist/components/Counter/Counter.js.map +1 -1
  243. package/dist/components/CustomSelect/CustomSelect.d.ts +3 -0
  244. package/dist/components/CustomSelect/CustomSelect.js +1 -1
  245. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  246. package/dist/components/CustomSelectOption/CustomSelectOption.js +1 -1
  247. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  248. package/dist/components/DateRangeInput/DateRangeInput.js +1 -1
  249. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  250. package/dist/components/Epic/ScrollSaver.d.ts +3 -3
  251. package/dist/components/Epic/ScrollSaver.js.map +1 -1
  252. package/dist/components/File/File.js +4 -3
  253. package/dist/components/File/File.js.map +1 -1
  254. package/dist/components/FixedLayout/FixedLayout.js +1 -1
  255. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  256. package/dist/components/FocusVisible/FocusVisible.d.ts +4 -2
  257. package/dist/components/FocusVisible/FocusVisible.js +4 -3
  258. package/dist/components/FocusVisible/FocusVisible.js.map +1 -1
  259. package/dist/components/FormField/FormField.js +10 -1
  260. package/dist/components/FormField/FormField.js.map +1 -1
  261. package/dist/components/FormItem/FormItem.d.ts +3 -1
  262. package/dist/components/FormItem/FormItem.js +2 -1
  263. package/dist/components/FormItem/FormItem.js.map +1 -1
  264. package/dist/components/FormLayoutGroup/FormLayoutGroup.d.ts +3 -1
  265. package/dist/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  266. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  267. package/dist/components/Group/Group.d.ts +5 -3
  268. package/dist/components/Group/Group.js +5 -3
  269. package/dist/components/Group/Group.js.map +1 -1
  270. package/dist/components/Header/Header.js +20 -16
  271. package/dist/components/Header/Header.js.map +1 -1
  272. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +5 -1
  273. package/dist/components/HorizontalScroll/HorizontalScroll.js +4 -1
  274. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  275. package/dist/components/HorizontalScroll/HorizontalScrollArrow.d.ts +2 -1
  276. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js +6 -2
  277. package/dist/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  278. package/dist/components/HoverPopper/HoverPopper.d.ts +1 -1
  279. package/dist/components/HoverPopper/HoverPopper.js.map +1 -1
  280. package/dist/components/IconButton/IconButton.d.ts +3 -3
  281. package/dist/components/IconButton/IconButton.js.map +1 -1
  282. package/dist/components/LocaleProvider/LocaleProvider.d.ts +2 -2
  283. package/dist/components/LocaleProvider/LocaleProvider.js +2 -2
  284. package/dist/components/LocaleProvider/LocaleProvider.js.map +1 -1
  285. package/dist/components/ModalPage/ModalPage.d.ts +1 -1
  286. package/dist/components/ModalPage/ModalPage.js +19 -3
  287. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  288. package/dist/components/ModalPage/ModalPageContext.d.ts +5 -0
  289. package/dist/components/ModalPage/ModalPageContext.js +4 -0
  290. package/dist/components/ModalPage/ModalPageContext.js.map +1 -0
  291. package/dist/components/ModalPageHeader/ModalPageHeader.js +6 -1
  292. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  293. package/dist/components/ModalRoot/ModalRoot.d.ts +2 -27
  294. package/dist/components/ModalRoot/ModalRoot.js +13 -22
  295. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  296. package/dist/components/ModalRoot/ModalRootAdaptive.d.ts +2 -21
  297. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  298. package/dist/components/ModalRoot/ModalRootDesktop.d.ts +3 -28
  299. package/dist/components/ModalRoot/ModalRootDesktop.js +149 -223
  300. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  301. package/dist/components/ModalRoot/types.d.ts +28 -0
  302. package/dist/components/ModalRoot/types.js.map +1 -1
  303. package/dist/components/ModalRoot/useModalManager.d.ts +6 -5
  304. package/dist/components/ModalRoot/useModalManager.js +3 -3
  305. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  306. package/dist/components/NativeSelect/NativeSelect.d.ts +6 -2
  307. package/dist/components/NativeSelect/NativeSelect.js +6 -3
  308. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  309. package/dist/components/Panel/Panel.js +2 -2
  310. package/dist/components/Panel/Panel.js.map +1 -1
  311. package/dist/components/PanelHeader/PanelHeader.d.ts +11 -2
  312. package/dist/components/PanelHeader/PanelHeader.js +17 -7
  313. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  314. package/dist/components/PanelHeaderButton/PanelHeaderButton.js +1 -1
  315. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  316. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  317. package/dist/components/PanelHeaderContext/PanelHeaderContext.js +3 -3
  318. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  319. package/dist/components/PlatformProvider/PlatformProvider.d.ts +1 -1
  320. package/dist/components/PlatformProvider/PlatformProvider.js +1 -1
  321. package/dist/components/PlatformProvider/PlatformProvider.js.map +1 -1
  322. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  323. package/dist/components/Popover/Popover.d.ts +3 -2
  324. package/dist/components/Popover/Popover.js +5 -3
  325. package/dist/components/Popover/Popover.js.map +1 -1
  326. package/dist/components/PromoBanner/PromoBanner.js +1 -0
  327. package/dist/components/PromoBanner/PromoBanner.js.map +1 -1
  328. package/dist/components/PullToRefresh/PullToRefresh.d.ts +3 -4
  329. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  330. package/dist/components/Radio/Radio.d.ts +2 -1
  331. package/dist/components/Radio/Radio.js +14 -8
  332. package/dist/components/Radio/Radio.js.map +1 -1
  333. package/dist/components/Removable/Removable.d.ts +7 -2
  334. package/dist/components/Removable/Removable.js +4 -3
  335. package/dist/components/Removable/Removable.js.map +1 -1
  336. package/dist/components/Root/Root.js.map +1 -1
  337. package/dist/components/Search/Search.d.ts +3 -1
  338. package/dist/components/Search/Search.js +42 -57
  339. package/dist/components/Search/Search.js.map +1 -1
  340. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +5 -3
  341. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +8 -4
  342. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  343. package/dist/components/SelectMimicry/SelectMimicry.js +1 -1
  344. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  345. package/dist/components/SelectTypography/SelectTypography.d.ts +2 -3
  346. package/dist/components/SelectTypography/SelectTypography.js.map +1 -1
  347. package/dist/components/SimpleCell/SimpleCell.js +8 -5
  348. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  349. package/dist/components/Spacing/Spacing.d.ts +2 -2
  350. package/dist/components/Spacing/Spacing.js.map +1 -1
  351. package/dist/components/SplitCol/SplitCol.js +1 -0
  352. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  353. package/dist/components/SubnavigationButton/SubnavigationButton.js +1 -3
  354. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  355. package/dist/components/Switch/Switch.d.ts +4 -5
  356. package/dist/components/Switch/Switch.js +12 -8
  357. package/dist/components/Switch/Switch.js.map +1 -1
  358. package/dist/components/Tabbar/Tabbar.js +2 -4
  359. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  360. package/dist/components/TabbarItem/TabbarItem.js +1 -1
  361. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  362. package/dist/components/Tappable/Tappable.d.ts +2 -3
  363. package/dist/components/Tappable/Tappable.js +1 -0
  364. package/dist/components/Tappable/Tappable.js.map +1 -1
  365. package/dist/components/Typography/Caption/Caption.d.ts +2 -2
  366. package/dist/components/Typography/Caption/Caption.js +10 -13
  367. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  368. package/dist/components/Typography/Footnote/Footnote.d.ts +2 -2
  369. package/dist/components/Typography/Footnote/Footnote.js +10 -13
  370. package/dist/components/Typography/Footnote/Footnote.js.map +1 -1
  371. package/dist/components/Typography/Headline/Headline.d.ts +3 -4
  372. package/dist/components/Typography/Headline/Headline.js +9 -12
  373. package/dist/components/Typography/Headline/Headline.js.map +1 -1
  374. package/dist/components/Typography/Paragraph/Paragraph.d.ts +3 -5
  375. package/dist/components/Typography/Paragraph/Paragraph.js +8 -13
  376. package/dist/components/Typography/Paragraph/Paragraph.js.map +1 -1
  377. package/dist/components/Typography/Subhead/Subhead.d.ts +2 -2
  378. package/dist/components/Typography/Subhead/Subhead.js +9 -12
  379. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  380. package/dist/components/Typography/Text/Text.d.ts +3 -5
  381. package/dist/components/Typography/Text/Text.js +8 -13
  382. package/dist/components/Typography/Text/Text.js.map +1 -1
  383. package/dist/components/Typography/Title/Title.d.ts +2 -2
  384. package/dist/components/Typography/Title/Title.js +10 -13
  385. package/dist/components/Typography/Title/Title.js.map +1 -1
  386. package/dist/components/Typography/Typography.d.ts +16 -0
  387. package/dist/components/Typography/Typography.js +24 -0
  388. package/dist/components/Typography/Typography.js.map +1 -0
  389. package/dist/components/UsersStack/UsersStack.d.ts +2 -2
  390. package/dist/components/UsersStack/UsersStack.js +2 -1
  391. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  392. package/dist/components/View/View.js +1 -1
  393. package/dist/components/View/View.js.map +1 -1
  394. package/dist/components/View/ViewInfinite.js +1 -1
  395. package/dist/components/View/ViewInfinite.js.map +1 -1
  396. package/dist/components/VisuallyHidden/VisuallyHidden.d.ts +14 -0
  397. package/dist/components/VisuallyHidden/VisuallyHidden.js +25 -0
  398. package/dist/components/VisuallyHidden/VisuallyHidden.js.map +1 -0
  399. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +4 -4
  400. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.js +9 -4
  401. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -1
  402. package/dist/components/WriteBarIcon/WriteBarIcon.js +2 -2
  403. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  404. package/dist/components.css +49 -49
  405. package/dist/components.css.map +1 -1
  406. package/dist/components.js.tmp +3803 -3693
  407. package/dist/cssm/components/Accordion/Accordion.d.ts +2 -2
  408. package/dist/cssm/components/Accordion/Accordion.js +2 -2
  409. package/dist/cssm/components/Accordion/Accordion.js.map +1 -1
  410. package/dist/cssm/components/Accordion/Accordion.module.css +13 -1
  411. package/dist/cssm/components/Accordion/AccordionSummary.d.ts +1 -1
  412. package/dist/cssm/components/Accordion/AccordionSummary.js +1 -1
  413. package/dist/cssm/components/Accordion/AccordionSummary.js.map +1 -1
  414. package/dist/cssm/components/ActionSheet/ActionSheet.module.css +115 -1
  415. package/dist/cssm/components/ActionSheet/types.d.ts +1 -1
  416. package/dist/cssm/components/ActionSheet/types.js.map +1 -1
  417. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.module.css +241 -1
  418. package/dist/cssm/components/AdaptiveIconRenderer/AdaptiveIconRenderer.d.ts +14 -0
  419. package/dist/cssm/components/{WriteBarIcon/WriteBarIconRenderer.js → AdaptiveIconRenderer/AdaptiveIconRenderer.js} +5 -2
  420. package/dist/cssm/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -0
  421. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.d.ts +4 -4
  422. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  423. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  424. package/dist/cssm/components/Alert/Alert.module.css +287 -1
  425. package/dist/cssm/components/AppRoot/AppRoot.module.css +23 -1
  426. package/dist/cssm/components/AppRoot/AppRootPortal.d.ts +3 -3
  427. package/dist/cssm/components/AppRoot/AppRootPortal.js.map +1 -1
  428. package/dist/cssm/components/AppRoot/ScrollContext.d.ts +2 -2
  429. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  430. package/dist/cssm/components/Avatar/Avatar.module.css +55 -1
  431. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadge.module.css +29 -1
  432. package/dist/cssm/components/Badge/Badge.module.css +27 -1
  433. package/dist/cssm/components/Banner/Banner.module.css +167 -1
  434. package/dist/cssm/components/BaseGallery/BaseGallery.module.css +82 -1
  435. package/dist/cssm/components/Button/Button.d.ts +1 -0
  436. package/dist/cssm/components/Button/Button.js +2 -1
  437. package/dist/cssm/components/Button/Button.js.map +1 -1
  438. package/dist/cssm/components/Button/Button.module.css +676 -1
  439. package/dist/cssm/components/ButtonGroup/ButtonGroup.module.css +77 -1
  440. package/dist/cssm/components/Calendar/Calendar.module.css +30 -1
  441. package/dist/cssm/components/CalendarDay/CalendarDay.module.css +84 -1
  442. package/dist/cssm/components/CalendarDays/CalendarDays.module.css +31 -1
  443. package/dist/cssm/components/CalendarHeader/CalendarHeader.module.css +41 -1
  444. package/dist/cssm/components/CalendarRange/CalendarRange.module.css +26 -1
  445. package/dist/cssm/components/CalendarTime/CalendarTime.module.css +19 -1
  446. package/dist/cssm/components/Card/Card.js +1 -3
  447. package/dist/cssm/components/Card/Card.js.map +1 -1
  448. package/dist/cssm/components/Card/Card.module.css +131 -3
  449. package/dist/cssm/components/CardGrid/CardGrid.js +4 -4
  450. package/dist/cssm/components/CardGrid/CardGrid.js.map +1 -1
  451. package/dist/cssm/components/CardGrid/CardGrid.module.css +59 -1
  452. package/dist/cssm/components/CardScroll/CardScroll.module.css +64 -1
  453. package/dist/cssm/components/Cell/Cell.module.css +63 -1
  454. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.d.ts +4 -2
  455. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js +7 -5
  456. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  457. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.module.css +13 -1
  458. package/dist/cssm/components/Cell/CellDragger/CellDragger.module.css +4 -1
  459. package/dist/cssm/components/CellButton/CellButton.module.css +57 -1
  460. package/dist/cssm/components/Checkbox/Checkbox.d.ts +2 -1
  461. package/dist/cssm/components/Checkbox/Checkbox.js +10 -7
  462. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  463. package/dist/cssm/components/Checkbox/Checkbox.module.css +172 -1
  464. package/dist/cssm/components/Chip/Chip.module.css +67 -1
  465. package/dist/cssm/components/ChipsInput/ChipsInput.module.css +3 -1
  466. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.module.css +115 -1
  467. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts +4 -0
  468. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +2 -2
  469. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  470. package/dist/cssm/components/ChipsSelect/ChipsSelect.module.css +27 -1
  471. package/dist/cssm/components/ContentCard/ContentCard.module.css +31 -1
  472. package/dist/cssm/components/Counter/Counter.js +4 -6
  473. package/dist/cssm/components/Counter/Counter.js.map +1 -1
  474. package/dist/cssm/components/Counter/Counter.module.css +72 -3
  475. package/dist/cssm/components/CustomScrollView/CustomScrollView.module.css +86 -1
  476. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +3 -0
  477. package/dist/cssm/components/CustomSelect/CustomSelect.js +1 -1
  478. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  479. package/dist/cssm/components/CustomSelect/CustomSelect.module.css +58 -1
  480. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.module.css +43 -1
  481. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js +1 -1
  482. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  483. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.module.css +81 -1
  484. package/dist/cssm/components/DateInput/DateInput.module.css +30 -1
  485. package/dist/cssm/components/DatePicker/DatePicker.module.css +30 -1
  486. package/dist/cssm/components/DateRangeInput/DateRangeInput.js +1 -1
  487. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  488. package/dist/cssm/components/DateRangeInput/DateRangeInput.module.css +26 -1
  489. package/dist/cssm/components/Div/Div.module.css +4 -1
  490. package/dist/cssm/components/Epic/Epic.module.css +4 -1
  491. package/dist/cssm/components/Epic/ScrollSaver.d.ts +3 -3
  492. package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
  493. package/dist/cssm/components/File/File.js +4 -3
  494. package/dist/cssm/components/File/File.js.map +1 -1
  495. package/dist/cssm/components/FixedLayout/FixedLayout.js +1 -1
  496. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  497. package/dist/cssm/components/FixedLayout/FixedLayout.module.css +58 -1
  498. package/dist/cssm/components/FocusVisible/FocusVisible.d.ts +4 -2
  499. package/dist/cssm/components/FocusVisible/FocusVisible.js +4 -3
  500. package/dist/cssm/components/FocusVisible/FocusVisible.js.map +1 -1
  501. package/dist/cssm/components/FocusVisible/FocusVisible.module.css +104 -1
  502. package/dist/cssm/components/Footer/Footer.module.css +9 -1
  503. package/dist/cssm/components/FormField/FormField.js +10 -1
  504. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  505. package/dist/cssm/components/FormField/FormField.module.css +211 -1
  506. package/dist/cssm/components/FormItem/FormItem.d.ts +3 -1
  507. package/dist/cssm/components/FormItem/FormItem.js +2 -1
  508. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  509. package/dist/cssm/components/FormItem/FormItem.module.css +104 -1
  510. package/dist/cssm/components/FormLayout/FormLayout.module.css +18 -1
  511. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.d.ts +3 -1
  512. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  513. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  514. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.module.css +61 -1
  515. package/dist/cssm/components/FormStatus/FormStatus.module.css +3 -1
  516. package/dist/cssm/components/Gradient/Gradient.module.css +23 -1
  517. package/dist/cssm/components/GridAvatar/GridAvatar.module.css +37 -1
  518. package/dist/cssm/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.module.css +9 -1
  519. package/dist/cssm/components/Group/Group.d.ts +5 -3
  520. package/dist/cssm/components/Group/Group.js +5 -3
  521. package/dist/cssm/components/Group/Group.js.map +1 -1
  522. package/dist/cssm/components/Group/Group.module.css +166 -1
  523. package/dist/cssm/components/Header/Header.js +23 -18
  524. package/dist/cssm/components/Header/Header.js.map +1 -1
  525. package/dist/cssm/components/Header/Header.module.css +207 -1
  526. package/dist/cssm/components/HorizontalCell/HorizontalCell.module.css +79 -1
  527. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.d.ts +5 -1
  528. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +3 -1
  529. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  530. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.module.css +59 -1
  531. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.d.ts +2 -1
  532. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js +5 -2
  533. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.js.map +1 -1
  534. package/dist/cssm/components/HorizontalScroll/HorizontalScrollArrow.module.css +67 -1
  535. package/dist/cssm/components/HoverPopper/HoverPopper.d.ts +1 -1
  536. package/dist/cssm/components/HoverPopper/HoverPopper.js.map +1 -1
  537. package/dist/cssm/components/IconButton/IconButton.d.ts +3 -3
  538. package/dist/cssm/components/IconButton/IconButton.js.map +1 -1
  539. package/dist/cssm/components/IconButton/IconButton.module.css +152 -1
  540. package/dist/cssm/components/Image/ImageBadge/ImageBadge.module.css +10 -1
  541. package/dist/cssm/components/ImageBase/ImageBase.module.css +131 -1
  542. package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.module.css +28 -1
  543. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.module.css +36 -1
  544. package/dist/cssm/components/InfoRow/InfoRow.module.css +17 -1
  545. package/dist/cssm/components/Input/Input.module.css +101 -1
  546. package/dist/cssm/components/InputLike/InputLike.module.css +31 -1
  547. package/dist/cssm/components/Link/Link.module.css +43 -1
  548. package/dist/cssm/components/List/List.module.css +3 -1
  549. package/dist/cssm/components/LocaleProvider/LocaleProvider.d.ts +2 -2
  550. package/dist/cssm/components/LocaleProvider/LocaleProvider.js +2 -2
  551. package/dist/cssm/components/LocaleProvider/LocaleProvider.js.map +1 -1
  552. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.module.css +78 -1
  553. package/dist/cssm/components/ModalCard/ModalCard.module.css +62 -1
  554. package/dist/cssm/components/ModalCardBase/ModalCardBase.module.css +102 -1
  555. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.module.css +38 -1
  556. package/dist/cssm/components/ModalPage/ModalPage.d.ts +1 -1
  557. package/dist/cssm/components/ModalPage/ModalPage.js +17 -3
  558. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  559. package/dist/cssm/components/ModalPage/ModalPage.module.css +151 -1
  560. package/dist/cssm/components/ModalPage/ModalPageContext.d.ts +5 -0
  561. package/dist/cssm/components/ModalPage/ModalPageContext.js +4 -0
  562. package/dist/cssm/components/ModalPage/ModalPageContext.js.map +1 -0
  563. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js +6 -1
  564. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  565. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.module.css +18 -1
  566. package/dist/cssm/components/ModalRoot/ModalRoot.d.ts +2 -27
  567. package/dist/cssm/components/ModalRoot/ModalRoot.js +12 -18
  568. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  569. package/dist/cssm/components/ModalRoot/ModalRoot.module.css +65 -1
  570. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.d.ts +2 -21
  571. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  572. package/dist/cssm/components/ModalRoot/ModalRootDesktop.d.ts +3 -28
  573. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +106 -125
  574. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  575. package/dist/cssm/components/ModalRoot/types.d.ts +28 -0
  576. package/dist/cssm/components/ModalRoot/types.js.map +1 -1
  577. package/dist/cssm/components/ModalRoot/useModalManager.d.ts +6 -5
  578. package/dist/cssm/components/ModalRoot/useModalManager.js +3 -3
  579. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  580. package/dist/cssm/components/NativeSelect/NativeSelect.d.ts +6 -2
  581. package/dist/cssm/components/NativeSelect/NativeSelect.js +4 -3
  582. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  583. package/dist/cssm/components/Pagination/Pagination.module.css +83 -1
  584. package/dist/cssm/components/Panel/Panel.js +2 -2
  585. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  586. package/dist/cssm/components/Panel/Panel.module.css +177 -1
  587. package/dist/cssm/components/PanelHeader/PanelHeader.d.ts +11 -2
  588. package/dist/cssm/components/PanelHeader/PanelHeader.js +16 -7
  589. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  590. package/dist/cssm/components/PanelHeader/PanelHeader.module.css +321 -1
  591. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js +1 -1
  592. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  593. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.module.css +111 -1
  594. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  595. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.module.css +96 -1
  596. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js +3 -3
  597. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  598. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.module.css +169 -1
  599. package/dist/cssm/components/Placeholder/Placeholder.module.css +41 -1
  600. package/dist/cssm/components/PlatformProvider/PlatformProvider.d.ts +1 -1
  601. package/dist/cssm/components/PlatformProvider/PlatformProvider.js +1 -1
  602. package/dist/cssm/components/PlatformProvider/PlatformProvider.js.map +1 -1
  603. package/dist/cssm/components/PopoutRoot/PopoutRoot.module.css +32 -1
  604. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +1 -1
  605. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  606. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.module.css +96 -1
  607. package/dist/cssm/components/Popover/Popover.d.ts +3 -2
  608. package/dist/cssm/components/Popover/Popover.js +3 -2
  609. package/dist/cssm/components/Popover/Popover.js.map +1 -1
  610. package/dist/cssm/components/Popover/Popover.module.css +28 -1
  611. package/dist/cssm/components/Popper/Popper.module.css +16 -1
  612. package/dist/cssm/components/PopperArrow/PopperArrow.module.css +23 -1
  613. package/dist/cssm/components/Progress/Progress.module.css +12 -1
  614. package/dist/cssm/components/PromoBanner/PromoBanner.js +1 -0
  615. package/dist/cssm/components/PromoBanner/PromoBanner.js.map +1 -1
  616. package/dist/cssm/components/PromoBanner/PromoBanner.module.css +39 -1
  617. package/dist/cssm/components/PullToRefresh/PullToRefresh.d.ts +3 -4
  618. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  619. package/dist/cssm/components/PullToRefresh/PullToRefresh.module.css +101 -1
  620. package/dist/cssm/components/Radio/Radio.d.ts +2 -1
  621. package/dist/cssm/components/Radio/Radio.js +11 -7
  622. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  623. package/dist/cssm/components/Radio/Radio.module.css +140 -1
  624. package/dist/cssm/components/RadioGroup/RadioGroup.module.css +13 -1
  625. package/dist/cssm/components/Removable/Removable.d.ts +7 -2
  626. package/dist/cssm/components/Removable/Removable.js +2 -2
  627. package/dist/cssm/components/Removable/Removable.js.map +1 -1
  628. package/dist/cssm/components/Removable/Removable.module.css +153 -1
  629. package/dist/cssm/components/RichCell/RichCell.module.css +144 -1
  630. package/dist/cssm/components/RichCell/RichCellIcon/RichCellIcon.module.css +11 -1
  631. package/dist/cssm/components/RichTooltip/RichTooltip.module.css +57 -1
  632. package/dist/cssm/components/Root/Root.js +4 -4
  633. package/dist/cssm/components/Root/Root.js.map +1 -1
  634. package/dist/cssm/components/Root/Root.module.css +136 -1
  635. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.module.css +66 -1
  636. package/dist/cssm/components/Search/Search.d.ts +3 -1
  637. package/dist/cssm/components/Search/Search.js +38 -54
  638. package/dist/cssm/components/Search/Search.js.map +1 -1
  639. package/dist/cssm/components/Search/Search.module.css +156 -1
  640. package/dist/cssm/components/SegmentedControl/SegmentedControl.module.css +64 -1
  641. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +5 -3
  642. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +7 -4
  643. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  644. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.module.css +52 -1
  645. package/dist/cssm/components/Select/Select.module.css +87 -1
  646. package/dist/cssm/components/SelectMimicry/SelectMimicry.js +1 -1
  647. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  648. package/dist/cssm/components/SelectTypography/SelectTypography.d.ts +2 -3
  649. package/dist/cssm/components/SelectTypography/SelectTypography.js.map +1 -1
  650. package/dist/cssm/components/SelectTypography/SelectTypography.module.css +30 -1
  651. package/dist/cssm/components/Separator/Separator.module.css +48 -1
  652. package/dist/cssm/components/SimpleCell/SimpleCell.js +8 -5
  653. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  654. package/dist/cssm/components/SimpleCell/SimpleCell.module.css +223 -1
  655. package/dist/cssm/components/Slider/Slider.module.css +134 -1
  656. package/dist/cssm/components/Snackbar/Snackbar.module.css +165 -1
  657. package/dist/cssm/components/Spacing/Spacing.d.ts +2 -2
  658. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  659. package/dist/cssm/components/Spacing/Spacing.module.css +4 -1
  660. package/dist/cssm/components/Spinner/Spinner.module.css +36 -1
  661. package/dist/cssm/components/SplitCol/SplitCol.js +1 -0
  662. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  663. package/dist/cssm/components/SplitCol/SplitCol.module.css +51 -1
  664. package/dist/cssm/components/SplitLayout/SplitLayout.module.css +29 -1
  665. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.module.css +16 -1
  666. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +1 -3
  667. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  668. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.module.css +166 -1
  669. package/dist/cssm/components/Switch/Switch.d.ts +4 -5
  670. package/dist/cssm/components/Switch/Switch.js +11 -8
  671. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  672. package/dist/cssm/components/Switch/Switch.module.css +200 -1
  673. package/dist/cssm/components/Tabbar/Tabbar.js +2 -4
  674. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  675. package/dist/cssm/components/Tabbar/Tabbar.module.css +34 -1
  676. package/dist/cssm/components/TabbarItem/TabbarItem.js +1 -1
  677. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  678. package/dist/cssm/components/TabbarItem/TabbarItem.module.css +118 -1
  679. package/dist/cssm/components/Tabs/Tabs.module.css +62 -1
  680. package/dist/cssm/components/TabsItem/TabsItem.module.css +229 -1
  681. package/dist/cssm/components/Tappable/Tappable.d.ts +2 -3
  682. package/dist/cssm/components/Tappable/Tappable.js +1 -0
  683. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  684. package/dist/cssm/components/Tappable/Tappable.module.css +142 -1
  685. package/dist/cssm/components/TextTooltip/TextTooltip.module.css +58 -1
  686. package/dist/cssm/components/Textarea/Textarea.module.css +87 -1
  687. package/dist/cssm/components/Tooltip/Tooltip.module.css +57 -1
  688. package/dist/cssm/components/Typography/Caption/Caption.d.ts +2 -2
  689. package/dist/cssm/components/Typography/Caption/Caption.js +9 -10
  690. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  691. package/dist/cssm/components/Typography/Caption/Caption.module.css +45 -1
  692. package/dist/cssm/components/Typography/Footnote/Footnote.d.ts +2 -2
  693. package/dist/cssm/components/Typography/Footnote/Footnote.js +7 -10
  694. package/dist/cssm/components/Typography/Footnote/Footnote.js.map +1 -1
  695. package/dist/cssm/components/Typography/Footnote/Footnote.module.css +14 -1
  696. package/dist/cssm/components/Typography/Headline/Headline.d.ts +3 -4
  697. package/dist/cssm/components/Typography/Headline/Headline.js +9 -10
  698. package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
  699. package/dist/cssm/components/Typography/Headline/Headline.module.css +48 -1
  700. package/dist/cssm/components/Typography/Paragraph/Paragraph.d.ts +3 -5
  701. package/dist/cssm/components/Typography/Paragraph/Paragraph.js +8 -10
  702. package/dist/cssm/components/Typography/Paragraph/Paragraph.js.map +1 -1
  703. package/dist/cssm/components/Typography/Paragraph/Paragraph.module.css +6 -1
  704. package/dist/cssm/components/Typography/Subhead/Subhead.d.ts +2 -2
  705. package/dist/cssm/components/Typography/Subhead/Subhead.js +8 -9
  706. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  707. package/dist/cssm/components/Typography/Subhead/Subhead.module.css +18 -1
  708. package/dist/cssm/components/Typography/Text/Text.d.ts +3 -5
  709. package/dist/cssm/components/Typography/Text/Text.js +8 -10
  710. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  711. package/dist/cssm/components/Typography/Text/Text.module.css +29 -1
  712. package/dist/cssm/components/Typography/Title/Title.d.ts +2 -2
  713. package/dist/cssm/components/Typography/Title/Title.js +9 -10
  714. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  715. package/dist/cssm/components/Typography/Title/Title.module.css +20 -1
  716. package/dist/cssm/components/Typography/Typography.d.ts +16 -0
  717. package/dist/cssm/components/Typography/Typography.js +14 -0
  718. package/dist/cssm/components/Typography/Typography.js.map +1 -0
  719. package/dist/cssm/components/Typography/Typography.module.css +18 -0
  720. package/dist/cssm/components/UsersStack/UsersStack.d.ts +2 -2
  721. package/dist/cssm/components/UsersStack/UsersStack.js +2 -1
  722. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  723. package/dist/cssm/components/UsersStack/UsersStack.module.css +77 -1
  724. package/dist/cssm/components/View/View.js +6 -7
  725. package/dist/cssm/components/View/View.js.map +1 -1
  726. package/dist/cssm/components/View/View.module.css +228 -1
  727. package/dist/cssm/components/View/ViewInfinite.js +6 -7
  728. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  729. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.d.ts +14 -0
  730. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.js +19 -0
  731. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.js.map +1 -0
  732. package/dist/cssm/components/VisuallyHidden/VisuallyHidden.module.css +10 -0
  733. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +4 -4
  734. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.js +9 -4
  735. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -1
  736. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.module.css +10 -1
  737. package/dist/cssm/components/WriteBar/WriteBar.module.css +119 -1
  738. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +2 -2
  739. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  740. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.module.css +66 -1
  741. package/dist/cssm/helpers/getPlatformClassName.js +1 -1
  742. package/dist/cssm/helpers/getPlatformClassName.js.map +1 -1
  743. package/dist/cssm/hooks/useFocusWithin.d.ts +2 -0
  744. package/dist/cssm/hooks/useFocusWithin.js +26 -0
  745. package/dist/cssm/hooks/useFocusWithin.js.map +1 -0
  746. package/dist/cssm/hooks/useId.js +1 -1
  747. package/dist/cssm/hooks/useId.js.map +1 -1
  748. package/dist/cssm/hooks/useWaitTransitionFinish.d.ts +1 -1
  749. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  750. package/dist/cssm/index.d.ts +4 -2
  751. package/dist/cssm/index.js +2 -1
  752. package/dist/cssm/index.js.map +1 -1
  753. package/dist/cssm/lib/utils.js +2 -2
  754. package/dist/cssm/lib/utils.js.map +1 -1
  755. package/dist/cssm/styles/adaptivity.module.css +87 -1
  756. package/dist/cssm/styles/common.css +36 -1
  757. package/dist/cssm/styles/constants.css +86 -1
  758. package/dist/cssm/styles/themes.css +1039 -1
  759. package/dist/helpers/getPlatformClassName.js +1 -1
  760. package/dist/helpers/getPlatformClassName.js.map +1 -1
  761. package/dist/hooks/useFocusWithin.d.ts +2 -0
  762. package/dist/hooks/useFocusWithin.js +27 -0
  763. package/dist/hooks/useFocusWithin.js.map +1 -0
  764. package/dist/hooks/useId.js +1 -1
  765. package/dist/hooks/useId.js.map +1 -1
  766. package/dist/hooks/useWaitTransitionFinish.d.ts +1 -1
  767. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  768. package/dist/index.d.ts +4 -2
  769. package/dist/index.js +2 -0
  770. package/dist/index.js.map +1 -1
  771. package/dist/lib/utils.js +2 -2
  772. package/dist/lib/utils.js.map +1 -1
  773. package/dist/vkui.css +50 -50
  774. package/dist/vkui.css.map +1 -1
  775. package/dist/vkui.js.tmp +3803 -3693
  776. package/package.json +24 -17
  777. package/dist/cjs/components/Typography/types.d.ts +0 -11
  778. package/dist/cjs/components/Typography/types.js.map +0 -1
  779. package/dist/cjs/components/WriteBarIcon/WriteBarIconRenderer.d.ts +0 -10
  780. package/dist/cjs/components/WriteBarIcon/WriteBarIconRenderer.js.map +0 -1
  781. package/dist/components/Typography/types.d.ts +0 -11
  782. package/dist/components/Typography/types.js +0 -3
  783. package/dist/components/Typography/types.js.map +0 -1
  784. package/dist/components/WriteBarIcon/WriteBarIconRenderer.d.ts +0 -10
  785. package/dist/components/WriteBarIcon/WriteBarIconRenderer.js.map +0 -1
  786. package/dist/cssm/components/Typography/types.d.ts +0 -11
  787. package/dist/cssm/components/Typography/types.js +0 -3
  788. package/dist/cssm/components/Typography/types.js.map +0 -1
  789. package/dist/cssm/components/View/ViewIOS.module.css +0 -1
  790. package/dist/cssm/components/WriteBarIcon/WriteBarIconRenderer.d.ts +0 -10
  791. package/dist/cssm/components/WriteBarIcon/WriteBarIconRenderer.js.map +0 -1
  792. package/dist/cssm/styles/animations.css +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/CustomSelect/CustomSelect.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { SizeType } from '../../lib/adaptivity';\nimport type { PlacementWithAuto } from '../../lib/floating';\nimport { defaultFilterFn, getFormFieldModeFromSelectType } from '../../lib/select';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { debounce, getTitleFromChildren } from '../../lib/utils';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { TrackerOptionsProps } from '../CustomScrollView/useTrackerVisibility';\nimport { CustomSelectDropdown } from '../CustomSelectDropdown/CustomSelectDropdown';\nimport {\n CustomSelectOption,\n CustomSelectOptionProps,\n} from '../CustomSelectOption/CustomSelectOption';\nimport { DropdownIcon } from '../DropdownIcon/DropdownIcon';\nimport { FormFieldProps } from '../FormField/FormField';\nimport { Input } from '../Input/Input';\nimport { NativeSelectProps } from '../NativeSelect/NativeSelect';\nimport { SelectType } from '../Select/Select';\nimport { SelectMimicry } from '../SelectMimicry/SelectMimicry';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { CustomSelectClearButton, CustomSelectClearButtonProps } from './CustomSelectClearButton';\nimport styles from './CustomSelect.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelect--sizeY-none'],\n [SizeType.COMPACT]: styles['CustomSelect--sizeY-compact'],\n};\n\nconst findIndexAfter = (options: CustomSelectOptionInterface[] = [], startIndex = -1) => {\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\nfunction defaultRenderOptionFn({ option, ...props }: CustomSelectOptionProps): React.ReactNode {\n return <CustomSelectOption {...props} />;\n}\n\nconst handleOptionDown: MouseEventHandler = (e: React.MouseEvent<HTMLElement>) => {\n e.preventDefault();\n};\n\nfunction findSelectedIndex(\n options: CustomSelectOptionInterface[],\n value: SelectValue,\n withClear: boolean,\n) {\n if (withClear && value === '') {\n return -1;\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\nconst filter = (\n options: SelectProps['options'],\n inputValue: string,\n filterFn: SelectProps['filterFn'],\n) => {\n return typeof filterFn === 'function'\n ? options.filter((option) => filterFn(inputValue, option))\n : options;\n};\n\nconst defaultOptions: CustomSelectOptionInterface[] = [];\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\nexport interface SelectProps extends NativeSelectProps, FormFieldProps, TrackerOptionsProps {\n /**\n * Если `true`, то при клике на селект в нём появится текстовое поле для поиска по `options`. По умолчанию поиск\n * производится по `option.label`.\n */\n searchable?: boolean;\n /**\n * Текст, который будет отображен, если приходит пустой `options`.\n */\n emptyText?: string;\n /**\n * > ⚠️ В v6 из возвращаемых типов будет удалён `CustomSelectOptionInterface[]`. Для кастомной фильтрации используйте\n * > `filterFn`.\n */\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?: (option: Partial<CustomSelectOptionInterface>) => 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 /**\n * Кастомная кнопка для очистки значения.\n * Должна принимать обязательное свойство `onClick`\n */\n ClearButton?: React.ComponentType<CustomSelectClearButtonProps>;\n /**\n * Если `true`, то справа будет отображаться кнопка для очистки значения\n */\n allowClearButton?: boolean;\n dropdownOffsetDistance?: number;\n fixDropdownWidth?: boolean;\n forceDropdownPortal?: boolean;\n selectType?: SelectType;\n}\n\ntype MouseEventHandler = (event: React.MouseEvent<HTMLElement>) => void;\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelect\n */\nexport function CustomSelect(props: SelectProps) {\n const [opened, setOpened] = React.useState(false);\n const {\n before,\n name,\n className,\n getRef,\n getRootRef,\n popupDirection,\n style,\n onChange,\n children,\n onInputChange: onInputChangeProp,\n renderDropdown,\n onOpen,\n onClose,\n fetching,\n forceDropdownPortal,\n selectType = 'default',\n autoHideScrollbar,\n autoHideScrollbarDelay,\n searchable = false,\n renderOption: renderOptionProp = defaultRenderOptionFn,\n options: optionsProp = defaultOptions,\n emptyText = 'Ничего не найдено',\n filterFn = defaultFilterFn,\n icon: iconProp,\n ClearButton = CustomSelectClearButton,\n allowClearButton = false,\n dropdownOffsetDistance = 0,\n fixDropdownWidth = true,\n ...restProps\n } = props;\n\n if (process.env.NODE_ENV === 'development') {\n checkOptionsValueType(optionsProp);\n }\n\n const { sizeY = 'none' } = useAdaptivity();\n\n const containerRef = React.useRef<HTMLLabelElement>(null);\n const handleRootRef = useExternRef(containerRef, getRootRef);\n const scrollBoxRef = React.useRef<HTMLDivElement | null>(null);\n const selectElRef = useExternRef(getRef);\n\n const [focusedOptionIndex, setFocusedOptionIndex] = React.useState<number | undefined>(-1);\n const [isControlledOutside, setIsControlledOutside] = React.useState(props.value !== undefined);\n const [inputValue, setInputValue] = React.useState('');\n const [nativeSelectValue, setNativeSelectValue] = React.useState(\n () => props.value ?? props.defaultValue ?? (allowClearButton ? '' : undefined),\n );\n const [keyboardInput, setKeyboardInput] = React.useState('');\n const [popperPlacement, setPopperPlacement] = React.useState<PlacementWithAuto | undefined>(\n undefined,\n );\n const [options, setOptions] = React.useState(optionsProp);\n const [selectedOptionIndex, setSelectedOptionIndex] = React.useState<number | undefined>(\n findSelectedIndex(optionsProp, props.value ?? props.defaultValue, allowClearButton),\n );\n\n React.useEffect(() => {\n setIsControlledOutside(props.value !== undefined);\n setNativeSelectValue((nativeSelectValue) => props.value ?? nativeSelectValue);\n }, [props.value]);\n\n useIsomorphicLayoutEffect(() => {\n if (\n options.some(({ value }) => nativeSelectValue === value) ||\n (allowClearButton && nativeSelectValue === '')\n ) {\n const event = new Event('change', { bubbles: true });\n\n selectElRef.current?.dispatchEvent(event);\n }\n }, [nativeSelectValue]);\n\n const selected = React.useMemo(() => {\n if (!options.length) {\n return null;\n }\n\n return selectedOptionIndex !== undefined ? options[selectedOptionIndex] : undefined;\n }, [options, selectedOptionIndex]);\n\n const openedClassNames = React.useMemo(\n () =>\n classNames(\n opened &&\n dropdownOffsetDistance === 0 &&\n (popperPlacement?.includes('top')\n ? styles['CustomSelect--pop-up']\n : styles['CustomSelect--pop-down']),\n ),\n [dropdownOffsetDistance, opened, popperPlacement],\n );\n\n const resetKeyboardInput = React.useCallback(() => {\n setKeyboardInput('');\n }, []);\n\n const scrollToElement = React.useCallback((index: number, center = false) => {\n const dropdown = 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 const isValidIndex = React.useCallback(\n (index: number) => {\n return index >= 0 && index < (options.length ?? 0);\n },\n [options.length],\n );\n\n const focusOptionByIndex = React.useCallback(\n (index: number | undefined, scrollTo = true) => {\n if (index === undefined || index < 0 || index > (options.length ?? 0) - 1) {\n return;\n }\n\n const option = options[index];\n\n if (option?.disabled) {\n return;\n }\n\n if (scrollTo) {\n scrollToElement(index);\n }\n\n // Это оптимизация, прежде всего, под `onMouseOver`\n setFocusedOptionIndex((focusedOptionIndex) =>\n focusedOptionIndex !== index ? index : focusedOptionIndex,\n );\n },\n [options, scrollToElement],\n );\n\n const areOptionsShown = React.useCallback(() => {\n return scrollBoxRef.current !== null;\n }, []);\n\n const setScrollBoxRef = React.useCallback(\n (ref: HTMLDivElement | null) => {\n scrollBoxRef.current = ref;\n\n if (ref && selectedOptionIndex !== undefined && isValidIndex(selectedOptionIndex)) {\n {\n scrollToElement(selectedOptionIndex, true);\n }\n }\n },\n [isValidIndex, scrollToElement, selectedOptionIndex],\n );\n\n const onKeyboardInput = React.useCallback(\n (key: string) => {\n const fullInput = keyboardInput + key;\n\n const optionIndex = options.findIndex((option) => {\n return getTitleFromChildren(option.label).toLowerCase().includes(fullInput);\n });\n\n if (optionIndex !== undefined && optionIndex > -1) {\n focusOptionByIndex(optionIndex);\n }\n\n setKeyboardInput(fullInput);\n },\n [focusOptionByIndex, keyboardInput, options],\n );\n\n /**\n * Note: сбрасывать `options` через `setOptions(optionsProp)` не нужно.\n * Сброс происходит в одном из эффекте `updateOptionsAndSelectedOptionIndex()`.\n */\n const close = React.useCallback(() => {\n resetKeyboardInput();\n\n setInputValue('');\n setOpened(false);\n setFocusedOptionIndex(-1);\n onClose?.();\n }, [onClose, resetKeyboardInput]);\n\n const selectFocused = React.useCallback(() => {\n if (focusedOptionIndex !== undefined && isValidIndex(focusedOptionIndex)) {\n const item = options[focusedOptionIndex];\n\n setNativeSelectValue(item?.value);\n close();\n }\n }, [close, focusedOptionIndex, isValidIndex, options]);\n\n const open = React.useCallback(() => {\n setOpened(true);\n setFocusedOptionIndex(selectedOptionIndex);\n\n if (typeof onOpen === 'function') {\n onOpen();\n }\n }, [onOpen, selectedOptionIndex]);\n\n const onBlur = React.useCallback(() => {\n close();\n const event = new Event('blur');\n selectElRef.current?.dispatchEvent(event);\n }, [close, selectElRef]);\n\n const resetFocusedOption = React.useCallback(() => {\n setFocusedOptionIndex(-1);\n }, []);\n\n const onFocus = React.useCallback(() => {\n const event = new Event('focus');\n selectElRef.current?.dispatchEvent(event);\n }, [selectElRef]);\n\n const onClick = React.useCallback(() => {\n if (opened) {\n close();\n } else {\n open();\n }\n }, [close, open, opened]);\n\n const handleKeyUp = React.useMemo(() => debounce(resetKeyboardInput, 1000), [resetKeyboardInput]);\n\n const focusOption = React.useCallback(\n (type: 'next' | 'prev') => {\n let index = focusedOptionIndex;\n\n if (type === 'next') {\n const nextIndex = findIndexAfter(options, index);\n index = nextIndex === -1 ? findIndexAfter(options) : nextIndex; // Следующий за index или первый валидный до index\n } else if (type === 'prev') {\n const beforeIndex = findIndexBefore(options, index);\n index = beforeIndex === -1 ? findIndexBefore(options) : beforeIndex; // Предшествующий index или последний валидный после index\n }\n\n focusOptionByIndex(index);\n },\n [focusOptionByIndex, focusedOptionIndex, options],\n );\n\n React.useEffect(\n function updateOptionsAndSelectedOptionIndex() {\n const value = props.value ?? nativeSelectValue ?? props.defaultValue;\n\n const options =\n searchable && inputValue !== undefined\n ? filter(optionsProp, inputValue, filterFn)\n : optionsProp;\n\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, value, allowClearButton));\n },\n [\n filterFn,\n inputValue,\n nativeSelectValue,\n optionsProp,\n props.defaultValue,\n props.value,\n searchable,\n allowClearButton,\n ],\n );\n\n /**\n * Нужен для правильного поведения обработчика onClick на select. Фильтрует клики, которые были сделаны по\n * выпадающему списку.\n */\n const onLabelClick = React.useCallback((e: React.MouseEvent<HTMLLabelElement>) => {\n if (scrollBoxRef.current?.contains(e.target as Node)) {\n e.preventDefault();\n }\n }, []);\n\n const onNativeSelectChange: React.ChangeEventHandler<HTMLSelectElement> = (e) => {\n const newSelectedOptionIndex = findSelectedIndex(\n options,\n e.currentTarget.value,\n allowClearButton,\n );\n\n if (selectedOptionIndex !== newSelectedOptionIndex) {\n if (!isControlledOutside) {\n setSelectedOptionIndex(newSelectedOptionIndex);\n }\n onChange?.(e);\n }\n };\n\n const onInputKeyDown: React.KeyboardEventHandler<HTMLInputElement> = React.useCallback(\n (event) => {\n ['ArrowUp', 'ArrowDown', 'Escape', 'Enter'].includes(event.key) &&\n areOptionsShown() &&\n event.preventDefault();\n\n switch (event.key) {\n case 'ArrowUp':\n areOptionsShown() && focusOption('prev');\n break;\n case 'ArrowDown':\n areOptionsShown() && focusOption('next');\n break;\n case 'Escape':\n close();\n break;\n case 'Enter':\n areOptionsShown() && selectFocused();\n break;\n }\n },\n [areOptionsShown, close, focusOption, selectFocused],\n );\n\n const onInputChange: React.ChangeEventHandler<HTMLInputElement> = React.useCallback(\n (e) => {\n // TODO v6 удалить `onInputChangeProp`.\n if (onInputChangeProp) {\n const options = onInputChangeProp(e, optionsProp);\n if (options) {\n if (process.env.NODE_ENV === 'development') {\n warn(\n 'Этот метод фильтрации устарел. Возвращаемое значение onInputChange будет ' +\n 'проигнорировано в v6.0.0. Для фильтрации обновляйте props.options самостоятельно или используйте свойство filterFn.',\n );\n }\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, nativeSelectValue, allowClearButton));\n }\n } else {\n const options = filter(optionsProp, e.target.value, filterFn);\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, nativeSelectValue, allowClearButton));\n }\n setInputValue(e.target.value);\n },\n [filterFn, nativeSelectValue, onInputChangeProp, optionsProp, allowClearButton],\n );\n\n const handleKeyDownSelect = React.useCallback(\n (event: React.KeyboardEvent) => {\n if (event.key.length === 1 && event.key !== ' ') {\n onKeyboardInput(event.key);\n return;\n }\n\n ['ArrowUp', 'ArrowDown', 'Escape', 'Enter'].includes(event.key) &&\n areOptionsShown() &&\n event.preventDefault();\n\n switch (event.key) {\n case 'ArrowUp':\n if (opened) {\n areOptionsShown() && focusOption('prev');\n } else {\n open();\n }\n break;\n case 'ArrowDown':\n if (opened) {\n areOptionsShown() && focusOption('next');\n } else {\n open();\n }\n break;\n case 'Escape':\n close();\n break;\n case 'Enter':\n case 'Spacebar':\n case ' ':\n if (opened) {\n areOptionsShown() && selectFocused();\n } else {\n open();\n }\n break;\n }\n },\n [areOptionsShown, close, focusOption, onKeyboardInput, open, opened, selectFocused],\n );\n\n const handleOptionClick = React.useCallback(\n (e: React.MouseEvent<HTMLElement>) => {\n const index = Array.prototype.indexOf.call(\n e.currentTarget.parentNode?.children,\n e.currentTarget,\n );\n const option = options[index];\n\n if (option && !option.disabled) {\n selectFocused();\n }\n },\n [options, selectFocused],\n );\n\n const handleOptionHover = React.useCallback(\n (e: React.MouseEvent<HTMLElement>) => {\n focusOptionByIndex(\n Array.prototype.indexOf.call(e.currentTarget.parentNode?.children, e.currentTarget),\n false,\n );\n },\n [focusOptionByIndex],\n );\n\n const renderOption = React.useCallback(\n (option: CustomSelectOptionInterface, index: number) => {\n const hovered = index === focusedOptionIndex;\n const selected = index === selectedOptionIndex;\n\n return (\n <React.Fragment key={`${option.value}`}>\n {renderOptionProp({\n option,\n hovered,\n children: option.label,\n selected,\n disabled: option.disabled,\n onClick: handleOptionClick,\n onMouseDown: 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: handleOptionHover,\n })}\n </React.Fragment>\n );\n },\n [\n focusedOptionIndex,\n handleOptionClick,\n handleOptionHover,\n renderOptionProp,\n selectedOptionIndex,\n ],\n );\n\n const resolvedContent = React.useMemo(() => {\n const defaultDropdownContent =\n options?.length > 0 ? (\n options.map(renderOption)\n ) : (\n <Footnote className={styles['CustomSelect__empty']}>{emptyText}</Footnote>\n );\n\n if (typeof renderDropdown === 'function') {\n return renderDropdown({ defaultDropdownContent });\n } else {\n return defaultDropdownContent;\n }\n }, [emptyText, options, renderDropdown, renderOption]);\n\n const clearButtonShown = allowClearButton && !opened && nativeSelectValue !== '';\n\n const clearButton = React.useMemo(() => {\n if (!clearButtonShown) {\n return null;\n }\n\n return (\n <ClearButton\n className={iconProp === undefined ? styles['CustomSelect--clear-icon'] : undefined}\n onClick={() => setNativeSelectValue('')}\n />\n );\n }, [clearButtonShown, ClearButton, iconProp]);\n\n const icon = React.useMemo(() => {\n if (iconProp !== undefined) {\n return iconProp;\n }\n\n return (\n <DropdownIcon\n className={clearButtonShown ? styles['CustomSelect__dropdown-icon'] : undefined}\n opened={opened}\n />\n );\n }, [clearButtonShown, iconProp, opened]);\n\n const afterIcons = (icon || clearButtonShown) && (\n <React.Fragment>\n {clearButton}\n {icon}\n </React.Fragment>\n );\n\n return (\n <label\n className={classNames(\n styles['CustomSelect'],\n sizeY !== SizeType.REGULAR && sizeYClassNames[sizeY],\n className,\n )}\n style={style}\n ref={handleRootRef}\n onClick={onLabelClick}\n >\n {opened && searchable ? (\n <Input\n {...restProps}\n autoFocus\n onBlur={onBlur}\n className={openedClassNames}\n value={inputValue}\n onKeyDown={onInputKeyDown}\n onChange={onInputChange}\n // TODO Ожидается, что клик поймает нативный select, но его перехватывает Input. К сожалению, это приводит к конфликтам типизации.\n // TODO Нужно перестать пытаться превратить CustomSelect в select. Тогда эта проблема уйдёт.\n // @ts-expect-error: TS2322 MouseEventHandler<HTMLSelectElement> !== MouseEventHandler<HTMLInputElement>\n onClick={props.onClick}\n before={before}\n after={afterIcons}\n mode={getFormFieldModeFromSelectType(selectType)}\n />\n ) : (\n <SelectMimicry\n {...restProps}\n aria-hidden\n onClick={onClick}\n onKeyDown={handleKeyDownSelect}\n onKeyUp={handleKeyUp}\n onFocus={onFocus}\n onBlur={onBlur}\n className={openedClassNames}\n before={before}\n after={afterIcons}\n selectType={selectType}\n >\n {selected?.label}\n </SelectMimicry>\n )}\n <select\n ref={selectElRef}\n name={name}\n onChange={onNativeSelectChange}\n onBlur={props.onBlur}\n onFocus={props.onFocus}\n onClick={props.onClick}\n value={nativeSelectValue}\n aria-hidden\n className={styles['CustomSelect__control']}\n >\n {allowClearButton && <option key=\"\" value=\"\" />}\n {optionsProp.map((item) => (\n <option key={`${item.value}`} value={item.value} />\n ))}\n </select>\n {opened && (\n <CustomSelectDropdown\n targetRef={containerRef}\n placement={popupDirection}\n scrollBoxRef={setScrollBoxRef}\n onPlacementChange={setPopperPlacement}\n onMouseLeave={resetFocusedOption}\n fetching={fetching}\n offsetDistance={dropdownOffsetDistance}\n sameWidth={fixDropdownWidth}\n forcePortal={forceDropdownPortal}\n autoHideScrollbar={autoHideScrollbar}\n autoHideScrollbarDelay={autoHideScrollbarDelay}\n >\n {resolvedContent}\n </CustomSelectDropdown>\n )}\n </label>\n );\n}\n"],"names":["React","classNames","useAdaptivity","useExternRef","SizeType","defaultFilterFn","getFormFieldModeFromSelectType","useIsomorphicLayoutEffect","debounce","getTitleFromChildren","warnOnce","CustomSelectDropdown","CustomSelectOption","DropdownIcon","Input","SelectMimicry","Footnote","CustomSelectClearButton","styles","sizeYClassNames","none","COMPACT","findIndexAfter","options","startIndex","length","findIndex","option","i","disabled","findIndexBefore","endIndex","result","warn","checkOptionsValueType","Set","map","item","value","size","defaultRenderOptionFn","props","handleOptionDown","e","preventDefault","findSelectedIndex","withClear","Number","filter","inputValue","filterFn","defaultOptions","CustomSelect","opened","setOpened","useState","before","name","className","getRef","getRootRef","popupDirection","style","onChange","children","onInputChange","onInputChangeProp","renderDropdown","onOpen","onClose","fetching","forceDropdownPortal","selectType","autoHideScrollbar","autoHideScrollbarDelay","searchable","renderOption","renderOptionProp","optionsProp","emptyText","icon","iconProp","ClearButton","allowClearButton","dropdownOffsetDistance","fixDropdownWidth","restProps","process","env","NODE_ENV","sizeY","containerRef","useRef","handleRootRef","scrollBoxRef","selectElRef","focusedOptionIndex","setFocusedOptionIndex","isControlledOutside","setIsControlledOutside","undefined","setInputValue","nativeSelectValue","setNativeSelectValue","defaultValue","keyboardInput","setKeyboardInput","popperPlacement","setPopperPlacement","setOptions","selectedOptionIndex","setSelectedOptionIndex","useEffect","some","event","Event","bubbles","current","dispatchEvent","selected","useMemo","openedClassNames","includes","resetKeyboardInput","useCallback","scrollToElement","index","center","dropdown","dropdownHeight","offsetHeight","scrollTop","itemTop","offsetTop","itemHeight","isValidIndex","focusOptionByIndex","scrollTo","areOptionsShown","setScrollBoxRef","ref","onKeyboardInput","key","fullInput","optionIndex","label","toLowerCase","close","selectFocused","open","onBlur","resetFocusedOption","onFocus","onClick","handleKeyUp","focusOption","type","nextIndex","beforeIndex","updateOptionsAndSelectedOptionIndex","onLabelClick","contains","target","onNativeSelectChange","newSelectedOptionIndex","currentTarget","onInputKeyDown","handleKeyDownSelect","handleOptionClick","Array","prototype","indexOf","call","parentNode","handleOptionHover","hovered","Fragment","onMouseDown","onMouseOver","resolvedContent","defaultDropdownContent","clearButtonShown","clearButton","afterIcons","REGULAR","autoFocus","onKeyDown","after","mode","aria-hidden","onKeyUp","select","targetRef","placement","onPlacementChange","onMouseLeave","offsetDistance","sameWidth","forcePortal"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/components/CustomSelect/CustomSelect.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { SizeType } from '../../lib/adaptivity';\nimport type { PlacementWithAuto } from '../../lib/floating';\nimport { defaultFilterFn, getFormFieldModeFromSelectType } from '../../lib/select';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { debounce, getTitleFromChildren } from '../../lib/utils';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { TrackerOptionsProps } from '../CustomScrollView/useTrackerVisibility';\nimport { CustomSelectDropdown } from '../CustomSelectDropdown/CustomSelectDropdown';\nimport {\n CustomSelectOption,\n CustomSelectOptionProps,\n} from '../CustomSelectOption/CustomSelectOption';\nimport { DropdownIcon } from '../DropdownIcon/DropdownIcon';\nimport { FormFieldProps } from '../FormField/FormField';\nimport { Input } from '../Input/Input';\nimport { NativeSelectProps } from '../NativeSelect/NativeSelect';\nimport { SelectType } from '../Select/Select';\nimport { SelectMimicry } from '../SelectMimicry/SelectMimicry';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { CustomSelectClearButton, CustomSelectClearButtonProps } from './CustomSelectClearButton';\nimport styles from './CustomSelect.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelect--sizeY-none'],\n [SizeType.COMPACT]: styles['CustomSelect--sizeY-compact'],\n};\n\nconst findIndexAfter = (options: CustomSelectOptionInterface[] = [], startIndex = -1) => {\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\nfunction defaultRenderOptionFn({ option, ...props }: CustomSelectOptionProps): React.ReactNode {\n return <CustomSelectOption {...props} />;\n}\n\nconst handleOptionDown: MouseEventHandler = (e: React.MouseEvent<HTMLElement>) => {\n e.preventDefault();\n};\n\nfunction findSelectedIndex(\n options: CustomSelectOptionInterface[],\n value: SelectValue,\n withClear: boolean,\n) {\n if (withClear && value === '') {\n return -1;\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\nconst filter = (\n options: SelectProps['options'],\n inputValue: string,\n filterFn: SelectProps['filterFn'],\n) => {\n return typeof filterFn === 'function'\n ? options.filter((option) => filterFn(inputValue, option))\n : options;\n};\n\nconst defaultOptions: CustomSelectOptionInterface[] = [];\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\nexport interface SelectProps extends NativeSelectProps, FormFieldProps, TrackerOptionsProps {\n /**\n * Если `true`, то при клике на селект в нём появится текстовое поле для поиска по `options`. По умолчанию поиск\n * производится по `option.label`.\n */\n searchable?: boolean;\n /**\n * Текст, который будет отображен, если приходит пустой `options`.\n */\n emptyText?: string;\n /**\n * > ⚠️ В v6 из возвращаемых типов будет удалён `CustomSelectOptionInterface[]`. Для кастомной фильтрации используйте\n * > `filterFn`.\n */\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?: (option: Partial<CustomSelectOptionInterface>) => 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 /**\n * Иконка раскрывающегося списка\n */\n icon?: React.ReactNode;\n /**\n * Кастомная кнопка для очистки значения.\n * Должна принимать обязательное свойство `onClick`\n */\n ClearButton?: React.ComponentType<CustomSelectClearButtonProps>;\n /**\n * Если `true`, то справа будет отображаться кнопка для очистки значения\n */\n allowClearButton?: boolean;\n dropdownOffsetDistance?: number;\n fixDropdownWidth?: boolean;\n forceDropdownPortal?: boolean;\n selectType?: SelectType;\n}\n\ntype MouseEventHandler = (event: React.MouseEvent<HTMLElement>) => void;\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelect\n */\nexport function CustomSelect(props: SelectProps) {\n const [opened, setOpened] = React.useState(false);\n const {\n before,\n name,\n className,\n getRef,\n getRootRef,\n popupDirection,\n style,\n onChange,\n children,\n onInputChange: onInputChangeProp,\n renderDropdown,\n onOpen,\n onClose,\n fetching,\n forceDropdownPortal,\n selectType = 'default',\n autoHideScrollbar,\n autoHideScrollbarDelay,\n searchable = false,\n renderOption: renderOptionProp = defaultRenderOptionFn,\n options: optionsProp = defaultOptions,\n emptyText = 'Ничего не найдено',\n filterFn = defaultFilterFn,\n icon: iconProp,\n ClearButton = CustomSelectClearButton,\n allowClearButton = false,\n dropdownOffsetDistance = 0,\n fixDropdownWidth = true,\n ...restProps\n } = props;\n\n if (process.env.NODE_ENV === 'development') {\n checkOptionsValueType(optionsProp);\n }\n\n const { sizeY = 'none' } = useAdaptivity();\n\n const containerRef = React.useRef<HTMLLabelElement>(null);\n const handleRootRef = useExternRef(containerRef, getRootRef);\n const scrollBoxRef = React.useRef<HTMLDivElement | null>(null);\n const selectElRef = useExternRef(getRef);\n\n const [focusedOptionIndex, setFocusedOptionIndex] = React.useState<number | undefined>(-1);\n const [isControlledOutside, setIsControlledOutside] = React.useState(props.value !== undefined);\n const [inputValue, setInputValue] = React.useState('');\n const [nativeSelectValue, setNativeSelectValue] = React.useState(\n () => props.value ?? props.defaultValue ?? (allowClearButton ? '' : undefined),\n );\n const [keyboardInput, setKeyboardInput] = React.useState('');\n const [popperPlacement, setPopperPlacement] = React.useState<PlacementWithAuto | undefined>(\n undefined,\n );\n const [options, setOptions] = React.useState(optionsProp);\n const [selectedOptionIndex, setSelectedOptionIndex] = React.useState<number | undefined>(\n findSelectedIndex(optionsProp, props.value ?? props.defaultValue, allowClearButton),\n );\n\n React.useEffect(() => {\n setIsControlledOutside(props.value !== undefined);\n setNativeSelectValue((nativeSelectValue) => props.value ?? nativeSelectValue);\n }, [props.value]);\n\n useIsomorphicLayoutEffect(() => {\n if (\n options.some(({ value }) => nativeSelectValue === value) ||\n (allowClearButton && nativeSelectValue === '')\n ) {\n const event = new Event('change', { bubbles: true });\n\n selectElRef.current?.dispatchEvent(event);\n }\n }, [nativeSelectValue]);\n\n const selected = React.useMemo(() => {\n if (!options.length) {\n return null;\n }\n\n return selectedOptionIndex !== undefined ? options[selectedOptionIndex] : undefined;\n }, [options, selectedOptionIndex]);\n\n const openedClassNames = React.useMemo(\n () =>\n classNames(\n opened &&\n dropdownOffsetDistance === 0 &&\n (popperPlacement?.includes('top')\n ? styles['CustomSelect--pop-up']\n : styles['CustomSelect--pop-down']),\n ),\n [dropdownOffsetDistance, opened, popperPlacement],\n );\n\n const resetKeyboardInput = React.useCallback(() => {\n setKeyboardInput('');\n }, []);\n\n const scrollToElement = React.useCallback((index: number, center = false) => {\n const dropdown = 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 const isValidIndex = React.useCallback(\n (index: number) => {\n return index >= 0 && index < (options.length ?? 0);\n },\n [options.length],\n );\n\n const focusOptionByIndex = React.useCallback(\n (index: number | undefined, scrollTo = true) => {\n if (index === undefined || index < 0 || index > (options.length ?? 0) - 1) {\n return;\n }\n\n const option = options[index];\n\n if (option?.disabled) {\n return;\n }\n\n if (scrollTo) {\n scrollToElement(index);\n }\n\n // Это оптимизация, прежде всего, под `onMouseOver`\n setFocusedOptionIndex((focusedOptionIndex) =>\n focusedOptionIndex !== index ? index : focusedOptionIndex,\n );\n },\n [options, scrollToElement],\n );\n\n const areOptionsShown = React.useCallback(() => {\n return scrollBoxRef.current !== null;\n }, []);\n\n const setScrollBoxRef = React.useCallback(\n (ref: HTMLDivElement | null) => {\n scrollBoxRef.current = ref;\n\n if (ref && selectedOptionIndex !== undefined && isValidIndex(selectedOptionIndex)) {\n {\n scrollToElement(selectedOptionIndex, true);\n }\n }\n },\n [isValidIndex, scrollToElement, selectedOptionIndex],\n );\n\n const onKeyboardInput = React.useCallback(\n (key: string) => {\n const fullInput = keyboardInput + key;\n\n const optionIndex = options.findIndex((option) => {\n return getTitleFromChildren(option.label).toLowerCase().includes(fullInput);\n });\n\n if (optionIndex !== undefined && optionIndex > -1) {\n focusOptionByIndex(optionIndex);\n }\n\n setKeyboardInput(fullInput);\n },\n [focusOptionByIndex, keyboardInput, options],\n );\n\n /**\n * Note: сбрасывать `options` через `setOptions(optionsProp)` не нужно.\n * Сброс происходит в одном из эффекте `updateOptionsAndSelectedOptionIndex()`.\n */\n const close = React.useCallback(() => {\n resetKeyboardInput();\n\n setInputValue('');\n setOpened(false);\n setFocusedOptionIndex(-1);\n onClose?.();\n }, [onClose, resetKeyboardInput]);\n\n const selectFocused = React.useCallback(() => {\n if (focusedOptionIndex !== undefined && isValidIndex(focusedOptionIndex)) {\n const item = options[focusedOptionIndex];\n\n setNativeSelectValue(item?.value);\n close();\n }\n }, [close, focusedOptionIndex, isValidIndex, options]);\n\n const open = React.useCallback(() => {\n setOpened(true);\n setFocusedOptionIndex(selectedOptionIndex);\n\n if (typeof onOpen === 'function') {\n onOpen();\n }\n }, [onOpen, selectedOptionIndex]);\n\n const onBlur = React.useCallback(() => {\n close();\n const event = new Event('blur');\n selectElRef.current?.dispatchEvent(event);\n }, [close, selectElRef]);\n\n const resetFocusedOption = React.useCallback(() => {\n setFocusedOptionIndex(-1);\n }, []);\n\n const onFocus = React.useCallback(() => {\n const event = new Event('focus');\n selectElRef.current?.dispatchEvent(event);\n }, [selectElRef]);\n\n const onClick = React.useCallback(() => {\n if (opened) {\n close();\n } else {\n open();\n }\n }, [close, open, opened]);\n\n const handleKeyUp = React.useMemo(() => debounce(resetKeyboardInput, 1000), [resetKeyboardInput]);\n\n const focusOption = React.useCallback(\n (type: 'next' | 'prev') => {\n let index = focusedOptionIndex;\n\n if (type === 'next') {\n const nextIndex = findIndexAfter(options, index);\n index = nextIndex === -1 ? findIndexAfter(options) : nextIndex; // Следующий за index или первый валидный до index\n } else if (type === 'prev') {\n const beforeIndex = findIndexBefore(options, index);\n index = beforeIndex === -1 ? findIndexBefore(options) : beforeIndex; // Предшествующий index или последний валидный после index\n }\n\n focusOptionByIndex(index);\n },\n [focusOptionByIndex, focusedOptionIndex, options],\n );\n\n React.useEffect(\n function updateOptionsAndSelectedOptionIndex() {\n const value = props.value ?? nativeSelectValue ?? props.defaultValue;\n\n const options =\n searchable && inputValue !== undefined\n ? filter(optionsProp, inputValue, filterFn)\n : optionsProp;\n\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, value, allowClearButton));\n },\n [\n filterFn,\n inputValue,\n nativeSelectValue,\n optionsProp,\n props.defaultValue,\n props.value,\n searchable,\n allowClearButton,\n ],\n );\n\n /**\n * Нужен для правильного поведения обработчика onClick на select. Фильтрует клики, которые были сделаны по\n * выпадающему списку.\n */\n const onLabelClick = React.useCallback((e: React.MouseEvent<HTMLLabelElement>) => {\n if (scrollBoxRef.current?.contains(e.target as Node)) {\n e.preventDefault();\n }\n }, []);\n\n const onNativeSelectChange: React.ChangeEventHandler<HTMLSelectElement> = (e) => {\n const newSelectedOptionIndex = findSelectedIndex(\n options,\n e.currentTarget.value,\n allowClearButton,\n );\n\n if (selectedOptionIndex !== newSelectedOptionIndex) {\n if (!isControlledOutside) {\n setSelectedOptionIndex(newSelectedOptionIndex);\n }\n onChange?.(e);\n }\n };\n\n const onInputKeyDown: React.KeyboardEventHandler<HTMLInputElement> = React.useCallback(\n (event) => {\n ['ArrowUp', 'ArrowDown', 'Escape', 'Enter'].includes(event.key) &&\n areOptionsShown() &&\n event.preventDefault();\n\n switch (event.key) {\n case 'ArrowUp':\n areOptionsShown() && focusOption('prev');\n break;\n case 'ArrowDown':\n areOptionsShown() && focusOption('next');\n break;\n case 'Escape':\n close();\n break;\n case 'Enter':\n areOptionsShown() && selectFocused();\n break;\n }\n },\n [areOptionsShown, close, focusOption, selectFocused],\n );\n\n const onInputChange: React.ChangeEventHandler<HTMLInputElement> = React.useCallback(\n (e) => {\n // TODO [>=6]: удалить `onInputChangeProp`.\n if (onInputChangeProp) {\n const options = onInputChangeProp(e, optionsProp);\n if (options) {\n if (process.env.NODE_ENV === 'development') {\n warn(\n 'Этот метод фильтрации устарел. Возвращаемое значение onInputChange будет ' +\n 'проигнорировано в v6.0.0. Для фильтрации обновляйте props.options самостоятельно или используйте свойство filterFn.',\n );\n }\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, nativeSelectValue, allowClearButton));\n }\n } else {\n const options = filter(optionsProp, e.target.value, filterFn);\n setOptions(options);\n setSelectedOptionIndex(findSelectedIndex(options, nativeSelectValue, allowClearButton));\n }\n setInputValue(e.target.value);\n },\n [filterFn, nativeSelectValue, onInputChangeProp, optionsProp, allowClearButton],\n );\n\n const handleKeyDownSelect = React.useCallback(\n (event: React.KeyboardEvent) => {\n if (event.key.length === 1 && event.key !== ' ') {\n onKeyboardInput(event.key);\n return;\n }\n\n ['ArrowUp', 'ArrowDown', 'Escape', 'Enter'].includes(event.key) &&\n areOptionsShown() &&\n event.preventDefault();\n\n switch (event.key) {\n case 'ArrowUp':\n if (opened) {\n areOptionsShown() && focusOption('prev');\n } else {\n open();\n }\n break;\n case 'ArrowDown':\n if (opened) {\n areOptionsShown() && focusOption('next');\n } else {\n open();\n }\n break;\n case 'Escape':\n close();\n break;\n case 'Enter':\n case 'Spacebar':\n case ' ':\n if (opened) {\n areOptionsShown() && selectFocused();\n } else {\n open();\n }\n break;\n }\n },\n [areOptionsShown, close, focusOption, onKeyboardInput, open, opened, selectFocused],\n );\n\n const handleOptionClick = React.useCallback(\n (e: React.MouseEvent<HTMLElement>) => {\n const index = Array.prototype.indexOf.call(\n e.currentTarget.parentNode?.children,\n e.currentTarget,\n );\n const option = options[index];\n\n if (option && !option.disabled) {\n selectFocused();\n }\n },\n [options, selectFocused],\n );\n\n const handleOptionHover = React.useCallback(\n (e: React.MouseEvent<HTMLElement>) => {\n focusOptionByIndex(\n Array.prototype.indexOf.call(e.currentTarget.parentNode?.children, e.currentTarget),\n false,\n );\n },\n [focusOptionByIndex],\n );\n\n const renderOption = React.useCallback(\n (option: CustomSelectOptionInterface, index: number) => {\n const hovered = index === focusedOptionIndex;\n const selected = index === selectedOptionIndex;\n\n return (\n <React.Fragment key={`${option.value}`}>\n {renderOptionProp({\n option,\n hovered,\n children: option.label,\n selected,\n disabled: option.disabled,\n onClick: handleOptionClick,\n onMouseDown: 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: handleOptionHover,\n })}\n </React.Fragment>\n );\n },\n [\n focusedOptionIndex,\n handleOptionClick,\n handleOptionHover,\n renderOptionProp,\n selectedOptionIndex,\n ],\n );\n\n const resolvedContent = React.useMemo(() => {\n const defaultDropdownContent =\n options?.length > 0 ? (\n options.map(renderOption)\n ) : (\n <Footnote className={styles['CustomSelect__empty']}>{emptyText}</Footnote>\n );\n\n if (typeof renderDropdown === 'function') {\n return renderDropdown({ defaultDropdownContent });\n } else {\n return defaultDropdownContent;\n }\n }, [emptyText, options, renderDropdown, renderOption]);\n\n const clearButtonShown = allowClearButton && !opened && nativeSelectValue !== '';\n\n const clearButton = React.useMemo(() => {\n if (!clearButtonShown) {\n return null;\n }\n\n return (\n <ClearButton\n className={iconProp === undefined ? styles['CustomSelect--clear-icon'] : undefined}\n onClick={() => setNativeSelectValue('')}\n />\n );\n }, [clearButtonShown, ClearButton, iconProp]);\n\n const icon = React.useMemo(() => {\n if (iconProp !== undefined) {\n return iconProp;\n }\n\n return (\n <DropdownIcon\n className={clearButtonShown ? styles['CustomSelect__dropdown-icon'] : undefined}\n opened={opened}\n />\n );\n }, [clearButtonShown, iconProp, opened]);\n\n const afterIcons = (icon || clearButtonShown) && (\n <React.Fragment>\n {clearButton}\n {icon}\n </React.Fragment>\n );\n\n return (\n <label\n className={classNames(\n styles['CustomSelect'],\n sizeY !== SizeType.REGULAR && sizeYClassNames[sizeY],\n className,\n )}\n style={style}\n ref={handleRootRef}\n onClick={onLabelClick}\n >\n {opened && searchable ? (\n <Input\n {...restProps}\n autoFocus\n onBlur={onBlur}\n className={openedClassNames}\n value={inputValue}\n onKeyDown={onInputKeyDown}\n onChange={onInputChange}\n // TODO Ожидается, что клик поймает нативный select, но его перехватывает Input. К сожалению, это приводит к конфликтам типизации.\n // TODO Нужно перестать пытаться превратить CustomSelect в select. Тогда эта проблема уйдёт.\n // @ts-expect-error: TS2322 MouseEventHandler<HTMLSelectElement> !== MouseEventHandler<HTMLInputElement>\n onClick={props.onClick}\n before={before}\n after={afterIcons}\n mode={getFormFieldModeFromSelectType(selectType)}\n />\n ) : (\n <SelectMimicry\n {...restProps}\n aria-hidden\n onClick={onClick}\n onKeyDown={handleKeyDownSelect}\n onKeyUp={handleKeyUp}\n onFocus={onFocus}\n onBlur={onBlur}\n className={openedClassNames}\n before={before}\n after={afterIcons}\n selectType={selectType}\n >\n {selected?.label}\n </SelectMimicry>\n )}\n <select\n ref={selectElRef}\n name={name}\n onChange={onNativeSelectChange}\n onBlur={props.onBlur}\n onFocus={props.onFocus}\n onClick={props.onClick}\n value={nativeSelectValue}\n aria-hidden\n className={styles['CustomSelect__control']}\n >\n {allowClearButton && <option key=\"\" value=\"\" />}\n {optionsProp.map((item) => (\n <option key={`${item.value}`} value={item.value} />\n ))}\n </select>\n {opened && (\n <CustomSelectDropdown\n targetRef={containerRef}\n placement={popupDirection}\n scrollBoxRef={setScrollBoxRef}\n onPlacementChange={setPopperPlacement}\n onMouseLeave={resetFocusedOption}\n fetching={fetching}\n offsetDistance={dropdownOffsetDistance}\n sameWidth={fixDropdownWidth}\n forcePortal={forceDropdownPortal}\n autoHideScrollbar={autoHideScrollbar}\n autoHideScrollbarDelay={autoHideScrollbarDelay}\n >\n {resolvedContent}\n </CustomSelectDropdown>\n )}\n </label>\n );\n}\n"],"names":["React","classNames","useAdaptivity","useExternRef","SizeType","defaultFilterFn","getFormFieldModeFromSelectType","useIsomorphicLayoutEffect","debounce","getTitleFromChildren","warnOnce","CustomSelectDropdown","CustomSelectOption","DropdownIcon","Input","SelectMimicry","Footnote","CustomSelectClearButton","styles","sizeYClassNames","none","COMPACT","findIndexAfter","options","startIndex","length","findIndex","option","i","disabled","findIndexBefore","endIndex","result","warn","checkOptionsValueType","Set","map","item","value","size","defaultRenderOptionFn","props","handleOptionDown","e","preventDefault","findSelectedIndex","withClear","Number","filter","inputValue","filterFn","defaultOptions","CustomSelect","opened","setOpened","useState","before","name","className","getRef","getRootRef","popupDirection","style","onChange","children","onInputChange","onInputChangeProp","renderDropdown","onOpen","onClose","fetching","forceDropdownPortal","selectType","autoHideScrollbar","autoHideScrollbarDelay","searchable","renderOption","renderOptionProp","optionsProp","emptyText","icon","iconProp","ClearButton","allowClearButton","dropdownOffsetDistance","fixDropdownWidth","restProps","process","env","NODE_ENV","sizeY","containerRef","useRef","handleRootRef","scrollBoxRef","selectElRef","focusedOptionIndex","setFocusedOptionIndex","isControlledOutside","setIsControlledOutside","undefined","setInputValue","nativeSelectValue","setNativeSelectValue","defaultValue","keyboardInput","setKeyboardInput","popperPlacement","setPopperPlacement","setOptions","selectedOptionIndex","setSelectedOptionIndex","useEffect","some","event","Event","bubbles","current","dispatchEvent","selected","useMemo","openedClassNames","includes","resetKeyboardInput","useCallback","scrollToElement","index","center","dropdown","dropdownHeight","offsetHeight","scrollTop","itemTop","offsetTop","itemHeight","isValidIndex","focusOptionByIndex","scrollTo","areOptionsShown","setScrollBoxRef","ref","onKeyboardInput","key","fullInput","optionIndex","label","toLowerCase","close","selectFocused","open","onBlur","resetFocusedOption","onFocus","onClick","handleKeyUp","focusOption","type","nextIndex","beforeIndex","updateOptionsAndSelectedOptionIndex","onLabelClick","contains","target","onNativeSelectChange","newSelectedOptionIndex","currentTarget","onInputKeyDown","handleKeyDownSelect","handleOptionClick","Array","prototype","indexOf","call","parentNode","handleOptionHover","hovered","Fragment","onMouseDown","onMouseOver","resolvedContent","defaultDropdownContent","clearButtonShown","clearButton","afterIcons","REGULAR","autoFocus","onKeyDown","after","mode","aria-hidden","onKeyUp","select","targetRef","placement","onPlacementChange","onMouseLeave","offsetDistance","sameWidth","forcePortal"],"mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,aAAa,QAAQ,4BAA4B;AAC1D,SAASC,YAAY,QAAQ,2BAA2B;AACxD,SAASC,QAAQ,QAAQ,uBAAuB;AAEhD,SAASC,eAAe,EAAEC,8BAA8B,QAAQ,mBAAmB;AACnF,SAASC,yBAAyB,QAAQ,sCAAsC;AAChF,SAASC,QAAQ,EAAEC,oBAAoB,QAAQ,kBAAkB;AACjE,SAASC,QAAQ,QAAQ,qBAAqB;AAE9C,SAASC,oBAAoB,QAAQ,+CAA+C;AACpF,SACEC,kBAAkB,QAEb,2CAA2C;AAClD,SAASC,YAAY,QAAQ,+BAA+B;AAE5D,SAASC,KAAK,QAAQ,iBAAiB;AAGvC,SAASC,aAAa,QAAQ,iCAAiC;AAC/D,SAASC,QAAQ,QAAQ,kCAAkC;AAC3D,SAASC,uBAAuB,QAAsC,4BAA4B;AAClG,OAAOC,YAAY,4BAA4B;AAE/C,MAAMC,kBAAkB;IACtBC,MAAMF,MAAM,CAAC,2BAA2B;IACxC,CAACd,SAASiB,OAAO,CAAC,EAAEH,MAAM,CAAC,8BAA8B;AAC3D;AAEA,MAAMI,iBAAiB,CAACC,UAAyC,EAAE,EAAEC,aAAa,CAAC,CAAC,GAAK;IACvF,IAAIA,cAAcD,QAAQE,MAAM,GAAG,GAAG;QACpC,OAAO,CAAC;IACV,CAAC;IACD,OAAOF,QAAQG,SAAS,CAAC,CAACC,QAAQC,IAAMA,IAAIJ,cAAc,CAACG,OAAOE,QAAQ;AAC5E;AAEA,MAAMC,kBAAkB,CACtBP,UAAyC,EAAE,EAC3CQ,WAAmBR,QAAQE,MAAM,GAC9B;IACH,IAAIO,SAAS,CAAC;IACd,IAAID,YAAY,GAAG;QACjB,OAAOC;IACT,CAAC;IACD,IAAK,IAAIJ,IAAIG,WAAW,GAAGH,KAAK,GAAGA,IAAK;QACtC,IAAID,SAASJ,OAAO,CAACK,EAAE;QAEvB,IAAI,CAACD,OAAOE,QAAQ,EAAE;YACpBG,SAASJ;YACT,KAAM;QACR,CAAC;IACH;IACA,OAAOI;AACT;AAEA,MAAMC,OAAOvB,SAAS;AAEtB,MAAMwB,wBAAwB,CAACX,UAA2C;IACxE,IAAI,IAAIY,IAAIZ,QAAQa,GAAG,CAAC,CAACC,OAAS,OAAOA,KAAKC,KAAK,GAAGC,IAAI,GAAG,GAAG;QAC9DN,KACE,+FACA;IAEJ,CAAC;AACH;AAEA,SAASO,sBAAsB,EAAEb,OAAM,EAAE,GAAGc,OAAgC,EAAmB;IAC7F,qBAAO,oBAAC7B,oBAAuB6B;AACjC;AAEA,MAAMC,mBAAsC,CAACC,IAAqC;IAChFA,EAAEC,cAAc;AAClB;AAEA,SAASC,kBACPtB,OAAsC,EACtCe,KAAkB,EAClBQ,SAAkB,EAClB;IACA,IAAIA,aAAaR,UAAU,IAAI;QAC7B,OAAO,CAAC;IACV,CAAC;IACD,OACEf,QAAQG,SAAS,CAAC,CAACW,OAAS;QAC1BC,QAAQ,OAAOD,KAAKC,KAAK,KAAK,WAAWS,OAAOT,SAASA,KAAK;QAC9D,OAAOD,KAAKC,KAAK,KAAKA;IACxB,MAAM,CAAC;AAEX;AAEA,MAAMU,SAAS,CACbzB,SACA0B,YACAC,WACG;IACH,OAAO,OAAOA,aAAa,aACvB3B,QAAQyB,MAAM,CAAC,CAACrB,SAAWuB,SAASD,YAAYtB,WAChDJ,OAAO;AACb;AAEA,MAAM4B,iBAAgD,EAAE;AAmFxD;;CAEC,GACD,OAAO,SAASC,aAAaX,KAAkB,EAAE;IAC/C,MAAM,CAACY,QAAQC,UAAU,GAAGtD,MAAMuD,QAAQ,CAAC,KAAK;IAChD,MAAM,EACJC,OAAM,EACNC,KAAI,EACJC,UAAS,EACTC,OAAM,EACNC,WAAU,EACVC,eAAc,EACdC,MAAK,EACLC,SAAQ,EACRC,SAAQ,EACRC,eAAeC,kBAAiB,EAChCC,eAAc,EACdC,OAAM,EACNC,QAAO,EACPC,SAAQ,EACRC,oBAAmB,EACnBC,YAAa,UAAS,EACtBC,kBAAiB,EACjBC,uBAAsB,EACtBC,YAAa,KAAK,CAAA,EAClBC,cAAcC,mBAAmBrC,qBAAqB,CAAA,EACtDjB,SAASuD,cAAc3B,cAAc,CAAA,EACrC4B,WAAY,oBAAmB,EAC/B7B,UAAW7C,gBAAe,EAC1B2E,MAAMC,SAAQ,EACdC,aAAcjE,wBAAuB,EACrCkE,kBAAmB,KAAK,CAAA,EACxBC,wBAAyB,EAAC,EAC1BC,kBAAmB,IAAI,CAAA,EACvB,GAAGC,WACJ,GAAG7C;IAEJ,IAAI8C,QAAQC,GAAG,CAACC,QAAQ,KAAK,eAAe;QAC1CvD,sBAAsB4C;IACxB,CAAC;IAED,MAAM,EAAEY,OAAQ,OAAM,EAAE,GAAGxF;IAE3B,MAAMyF,eAAe3F,MAAM4F,MAAM,CAAmB,IAAI;IACxD,MAAMC,gBAAgB1F,aAAawF,cAAc/B;IACjD,MAAMkC,eAAe9F,MAAM4F,MAAM,CAAwB,IAAI;IAC7D,MAAMG,cAAc5F,aAAawD;IAEjC,MAAM,CAACqC,oBAAoBC,sBAAsB,GAAGjG,MAAMuD,QAAQ,CAAqB,CAAC;IACxF,MAAM,CAAC2C,qBAAqBC,uBAAuB,GAAGnG,MAAMuD,QAAQ,CAACd,MAAMH,KAAK,KAAK8D;IACrF,MAAM,CAACnD,YAAYoD,cAAc,GAAGrG,MAAMuD,QAAQ,CAAC;IACnD,MAAM,CAAC+C,mBAAmBC,qBAAqB,GAAGvG,MAAMuD,QAAQ,CAC9D,IAAMd,MAAMH,KAAK,IAAIG,MAAM+D,YAAY,IAAKrB,CAAAA,mBAAmB,KAAKiB,SAAS,AAAD;IAE9E,MAAM,CAACK,eAAeC,iBAAiB,GAAG1G,MAAMuD,QAAQ,CAAC;IACzD,MAAM,CAACoD,iBAAiBC,mBAAmB,GAAG5G,MAAMuD,QAAQ,CAC1D6C;IAEF,MAAM,CAAC7E,SAASsF,WAAW,GAAG7G,MAAMuD,QAAQ,CAACuB;IAC7C,MAAM,CAACgC,qBAAqBC,uBAAuB,GAAG/G,MAAMuD,QAAQ,CAClEV,kBAAkBiC,aAAarC,MAAMH,KAAK,IAAIG,MAAM+D,YAAY,EAAErB;IAGpEnF,MAAMgH,SAAS,CAAC,IAAM;QACpBb,uBAAuB1D,MAAMH,KAAK,KAAK8D;QACvCG,qBAAqB,CAACD,oBAAsB7D,MAAMH,KAAK,IAAIgE;IAC7D,GAAG;QAAC7D,MAAMH,KAAK;KAAC;IAEhB/B,0BAA0B,IAAM;QAC9B,IACEgB,QAAQ0F,IAAI,CAAC,CAAC,EAAE3E,MAAK,EAAE,GAAKgE,sBAAsBhE,UACjD6C,oBAAoBmB,sBAAsB,IAC3C;YACA,MAAMY,QAAQ,IAAIC,MAAM,UAAU;gBAAEC,SAAS,IAAI;YAAC;YAElDrB,YAAYsB,OAAO,EAAEC,cAAcJ;QACrC,CAAC;IACH,GAAG;QAACZ;KAAkB;IAEtB,MAAMiB,WAAWvH,MAAMwH,OAAO,CAAC,IAAM;QACnC,IAAI,CAACjG,QAAQE,MAAM,EAAE;YACnB,OAAO,IAAI;QACb,CAAC;QAED,OAAOqF,wBAAwBV,YAAY7E,OAAO,CAACuF,oBAAoB,GAAGV,SAAS;IACrF,GAAG;QAAC7E;QAASuF;KAAoB;IAEjC,MAAMW,mBAAmBzH,MAAMwH,OAAO,CACpC,IACEvH,WACEoD,UACE+B,2BAA2B,KAC1BuB,CAAAA,iBAAiBe,SAAS,SACvBxG,MAAM,CAAC,uBAAuB,GAC9BA,MAAM,CAAC,yBAAyB,AAAD,IAEzC;QAACkE;QAAwB/B;QAAQsD;KAAgB;IAGnD,MAAMgB,qBAAqB3H,MAAM4H,WAAW,CAAC,IAAM;QACjDlB,iBAAiB;IACnB,GAAG,EAAE;IAEL,MAAMmB,kBAAkB7H,MAAM4H,WAAW,CAAC,CAACE,OAAeC,SAAS,KAAK,GAAK;QAC3E,MAAMC,WAAWlC,aAAauB,OAAO;QACrC,MAAMhF,OAAO2F,WAAYA,SAAShE,QAAQ,CAAC8D,MAAM,GAAmB,IAAI;QAExE,IAAI,CAACzF,QAAQ,CAAC2F,UAAU;YACtB;QACF,CAAC;QAED,MAAMC,iBAAiBD,SAASE,YAAY;QAC5C,MAAMC,YAAYH,SAASG,SAAS;QACpC,MAAMC,UAAU/F,KAAKgG,SAAS;QAC9B,MAAMC,aAAajG,KAAK6F,YAAY;QAEpC,IAAIH,QAAQ;YACVC,SAASG,SAAS,GAAGC,UAAUH,iBAAiB,IAAIK,aAAa;QACnE,OAAO,IAAIF,UAAUE,aAAaL,iBAAiBE,WAAW;YAC5DH,SAASG,SAAS,GAAGC,UAAUH,iBAAiBK;QAClD,OAAO,IAAIF,UAAUD,WAAW;YAC9BH,SAASG,SAAS,GAAGC;QACvB,CAAC;IACH,GAAG,EAAE;IAEL,MAAMG,eAAevI,MAAM4H,WAAW,CACpC,CAACE,QAAkB;QACjB,OAAOA,SAAS,KAAKA,QAASvG,CAAAA,QAAQE,MAAM,IAAI,CAAA;IAClD,GACA;QAACF,QAAQE,MAAM;KAAC;IAGlB,MAAM+G,qBAAqBxI,MAAM4H,WAAW,CAC1C,CAACE,OAA2BW,WAAW,IAAI,GAAK;QAC9C,IAAIX,UAAU1B,aAAa0B,QAAQ,KAAKA,QAAQ,AAACvG,CAAAA,QAAQE,MAAM,IAAI,CAAA,IAAK,GAAG;YACzE;QACF,CAAC;QAED,MAAME,SAASJ,OAAO,CAACuG,MAAM;QAE7B,IAAInG,QAAQE,UAAU;YACpB;QACF,CAAC;QAED,IAAI4G,UAAU;YACZZ,gBAAgBC;QAClB,CAAC;QAED,mDAAmD;QACnD7B,sBAAsB,CAACD,qBACrBA,uBAAuB8B,QAAQA,QAAQ9B,kBAAkB;IAE7D,GACA;QAACzE;QAASsG;KAAgB;IAG5B,MAAMa,kBAAkB1I,MAAM4H,WAAW,CAAC,IAAM;QAC9C,OAAO9B,aAAauB,OAAO,KAAK,IAAI;IACtC,GAAG,EAAE;IAEL,MAAMsB,kBAAkB3I,MAAM4H,WAAW,CACvC,CAACgB,MAA+B;QAC9B9C,aAAauB,OAAO,GAAGuB;QAEvB,IAAIA,OAAO9B,wBAAwBV,aAAamC,aAAazB,sBAAsB;YACjF;gBACEe,gBAAgBf,qBAAqB,IAAI;YAC3C;QACF,CAAC;IACH,GACA;QAACyB;QAAcV;QAAiBf;KAAoB;IAGtD,MAAM+B,kBAAkB7I,MAAM4H,WAAW,CACvC,CAACkB,MAAgB;QACf,MAAMC,YAAYtC,gBAAgBqC;QAElC,MAAME,cAAczH,QAAQG,SAAS,CAAC,CAACC,SAAW;YAChD,OAAOlB,qBAAqBkB,OAAOsH,KAAK,EAAEC,WAAW,GAAGxB,QAAQ,CAACqB;QACnE;QAEA,IAAIC,gBAAgB5C,aAAa4C,cAAc,CAAC,GAAG;YACjDR,mBAAmBQ;QACrB,CAAC;QAEDtC,iBAAiBqC;IACnB,GACA;QAACP;QAAoB/B;QAAelF;KAAQ;IAG9C;;;GAGC,GACD,MAAM4H,QAAQnJ,MAAM4H,WAAW,CAAC,IAAM;QACpCD;QAEAtB,cAAc;QACd/C,UAAU,KAAK;QACf2C,sBAAsB,CAAC;QACvB5B;IACF,GAAG;QAACA;QAASsD;KAAmB;IAEhC,MAAMyB,gBAAgBpJ,MAAM4H,WAAW,CAAC,IAAM;QAC5C,IAAI5B,uBAAuBI,aAAamC,aAAavC,qBAAqB;YACxE,MAAM3D,OAAOd,OAAO,CAACyE,mBAAmB;YAExCO,qBAAqBlE,MAAMC;YAC3B6G;QACF,CAAC;IACH,GAAG;QAACA;QAAOnD;QAAoBuC;QAAchH;KAAQ;IAErD,MAAM8H,OAAOrJ,MAAM4H,WAAW,CAAC,IAAM;QACnCtE,UAAU,IAAI;QACd2C,sBAAsBa;QAEtB,IAAI,OAAO1C,WAAW,YAAY;YAChCA;QACF,CAAC;IACH,GAAG;QAACA;QAAQ0C;KAAoB;IAEhC,MAAMwC,SAAStJ,MAAM4H,WAAW,CAAC,IAAM;QACrCuB;QACA,MAAMjC,QAAQ,IAAIC,MAAM;QACxBpB,YAAYsB,OAAO,EAAEC,cAAcJ;IACrC,GAAG;QAACiC;QAAOpD;KAAY;IAEvB,MAAMwD,qBAAqBvJ,MAAM4H,WAAW,CAAC,IAAM;QACjD3B,sBAAsB,CAAC;IACzB,GAAG,EAAE;IAEL,MAAMuD,UAAUxJ,MAAM4H,WAAW,CAAC,IAAM;QACtC,MAAMV,QAAQ,IAAIC,MAAM;QACxBpB,YAAYsB,OAAO,EAAEC,cAAcJ;IACrC,GAAG;QAACnB;KAAY;IAEhB,MAAM0D,UAAUzJ,MAAM4H,WAAW,CAAC,IAAM;QACtC,IAAIvE,QAAQ;YACV8F;QACF,OAAO;YACLE;QACF,CAAC;IACH,GAAG;QAACF;QAAOE;QAAMhG;KAAO;IAExB,MAAMqG,cAAc1J,MAAMwH,OAAO,CAAC,IAAMhH,SAASmH,oBAAoB,OAAO;QAACA;KAAmB;IAEhG,MAAMgC,cAAc3J,MAAM4H,WAAW,CACnC,CAACgC,OAA0B;QACzB,IAAI9B,QAAQ9B;QAEZ,IAAI4D,SAAS,QAAQ;YACnB,MAAMC,YAAYvI,eAAeC,SAASuG;YAC1CA,QAAQ+B,cAAc,CAAC,IAAIvI,eAAeC,WAAWsI,SAAS,EAAE,kDAAkD;QACpH,OAAO,IAAID,SAAS,QAAQ;YAC1B,MAAME,cAAchI,gBAAgBP,SAASuG;YAC7CA,QAAQgC,gBAAgB,CAAC,IAAIhI,gBAAgBP,WAAWuI,WAAW,EAAE,0DAA0D;QACjI,CAAC;QAEDtB,mBAAmBV;IACrB,GACA;QAACU;QAAoBxC;QAAoBzE;KAAQ;IAGnDvB,MAAMgH,SAAS,CACb,SAAS+C,sCAAsC;QAC7C,MAAMzH,QAAQG,MAAMH,KAAK,IAAIgE,qBAAqB7D,MAAM+D,YAAY;QAEpE,MAAMjF,UACJoD,cAAc1B,eAAemD,YACzBpD,OAAO8B,aAAa7B,YAAYC,YAChC4B,WAAW;QAEjB+B,WAAWtF;QACXwF,uBAAuBlE,kBAAkBtB,SAASe,OAAO6C;IAC3D,GACA;QACEjC;QACAD;QACAqD;QACAxB;QACArC,MAAM+D,YAAY;QAClB/D,MAAMH,KAAK;QACXqC;QACAQ;KACD;IAGH;;;GAGC,GACD,MAAM6E,eAAehK,MAAM4H,WAAW,CAAC,CAACjF,IAA0C;QAChF,IAAImD,aAAauB,OAAO,EAAE4C,SAAStH,EAAEuH,MAAM,GAAW;YACpDvH,EAAEC,cAAc;QAClB,CAAC;IACH,GAAG,EAAE;IAEL,MAAMuH,uBAAoE,CAACxH,IAAM;QAC/E,MAAMyH,yBAAyBvH,kBAC7BtB,SACAoB,EAAE0H,aAAa,CAAC/H,KAAK,EACrB6C;QAGF,IAAI2B,wBAAwBsD,wBAAwB;YAClD,IAAI,CAAClE,qBAAqB;gBACxBa,uBAAuBqD;YACzB,CAAC;YACDrG,WAAWpB;QACb,CAAC;IACH;IAEA,MAAM2H,iBAA+DtK,MAAM4H,WAAW,CACpF,CAACV,QAAU;QACT;YAAC;YAAW;YAAa;YAAU;SAAQ,CAACQ,QAAQ,CAACR,MAAM4B,GAAG,KAC5DJ,qBACAxB,MAAMtE,cAAc;QAEtB,OAAQsE,MAAM4B,GAAG;YACf,KAAK;gBACHJ,qBAAqBiB,YAAY;gBACjC,KAAM;YACR,KAAK;gBACHjB,qBAAqBiB,YAAY;gBACjC,KAAM;YACR,KAAK;gBACHR;gBACA,KAAM;YACR,KAAK;gBACHT,qBAAqBU;gBACrB,KAAM;QACV;IACF,GACA;QAACV;QAAiBS;QAAOQ;QAAaP;KAAc;IAGtD,MAAMnF,gBAA4DjE,MAAM4H,WAAW,CACjF,CAACjF,IAAM;QACL,2CAA2C;QAC3C,IAAIuB,mBAAmB;YACrB,MAAM3C,UAAU2C,kBAAkBvB,GAAGmC;YACrC,IAAIvD,SAAS;gBACX,IAAIgE,QAAQC,GAAG,CAACC,QAAQ,KAAK,eAAe;oBAC1CxD,KACE,8EACE;gBAEN,CAAC;gBACD4E,WAAWtF;gBACXwF,uBAAuBlE,kBAAkBtB,SAAS+E,mBAAmBnB;YACvE,CAAC;QACH,OAAO;YACL,MAAM5D,UAAUyB,OAAO8B,aAAanC,EAAEuH,MAAM,CAAC5H,KAAK,EAAEY;YACpD2D,WAAWtF;YACXwF,uBAAuBlE,kBAAkBtB,SAAS+E,mBAAmBnB;QACvE,CAAC;QACDkB,cAAc1D,EAAEuH,MAAM,CAAC5H,KAAK;IAC9B,GACA;QAACY;QAAUoD;QAAmBpC;QAAmBY;QAAaK;KAAiB;IAGjF,MAAMoF,sBAAsBvK,MAAM4H,WAAW,CAC3C,CAACV,QAA+B;QAC9B,IAAIA,MAAM4B,GAAG,CAACrH,MAAM,KAAK,KAAKyF,MAAM4B,GAAG,KAAK,KAAK;YAC/CD,gBAAgB3B,MAAM4B,GAAG;YACzB;QACF,CAAC;QAED;YAAC;YAAW;YAAa;YAAU;SAAQ,CAACpB,QAAQ,CAACR,MAAM4B,GAAG,KAC5DJ,qBACAxB,MAAMtE,cAAc;QAEtB,OAAQsE,MAAM4B,GAAG;YACf,KAAK;gBACH,IAAIzF,QAAQ;oBACVqF,qBAAqBiB,YAAY;gBACnC,OAAO;oBACLN;gBACF,CAAC;gBACD,KAAM;YACR,KAAK;gBACH,IAAIhG,QAAQ;oBACVqF,qBAAqBiB,YAAY;gBACnC,OAAO;oBACLN;gBACF,CAAC;gBACD,KAAM;YACR,KAAK;gBACHF;gBACA,KAAM;YACR,KAAK;YACL,KAAK;YACL,KAAK;gBACH,IAAI9F,QAAQ;oBACVqF,qBAAqBU;gBACvB,OAAO;oBACLC;gBACF,CAAC;gBACD,KAAM;QACV;IACF,GACA;QAACX;QAAiBS;QAAOQ;QAAad;QAAiBQ;QAAMhG;QAAQ+F;KAAc;IAGrF,MAAMoB,oBAAoBxK,MAAM4H,WAAW,CACzC,CAACjF,IAAqC;QACpC,MAAMmF,QAAQ2C,MAAMC,SAAS,CAACC,OAAO,CAACC,IAAI,CACxCjI,EAAE0H,aAAa,CAACQ,UAAU,EAAE7G,UAC5BrB,EAAE0H,aAAa;QAEjB,MAAM1I,SAASJ,OAAO,CAACuG,MAAM;QAE7B,IAAInG,UAAU,CAACA,OAAOE,QAAQ,EAAE;YAC9BuH;QACF,CAAC;IACH,GACA;QAAC7H;QAAS6H;KAAc;IAG1B,MAAM0B,oBAAoB9K,MAAM4H,WAAW,CACzC,CAACjF,IAAqC;QACpC6F,mBACEiC,MAAMC,SAAS,CAACC,OAAO,CAACC,IAAI,CAACjI,EAAE0H,aAAa,CAACQ,UAAU,EAAE7G,UAAUrB,EAAE0H,aAAa,GAClF,KAAK;IAET,GACA;QAAC7B;KAAmB;IAGtB,MAAM5D,eAAe5E,MAAM4H,WAAW,CACpC,CAACjG,QAAqCmG,QAAkB;QACtD,MAAMiD,UAAUjD,UAAU9B;QAC1B,MAAMuB,WAAWO,UAAUhB;QAE3B,qBACE,oBAAC9G,MAAMgL,QAAQ;YAAClC,KAAK,CAAC,EAAEnH,OAAOW,KAAK,CAAC,CAAC;WACnCuC,iBAAiB;YAChBlD;YACAoJ;YACA/G,UAAUrC,OAAOsH,KAAK;YACtB1B;YACA1F,UAAUF,OAAOE,QAAQ;YACzB4H,SAASe;YACTS,aAAavI;YACb,kDAAkD;YAClD,kHAAkH;YAClH,sGAAsG;YACtG,qHAAqH;YACrH,+BAA+B;YAC/B,0IAA0I;YAC1I,oDAAoD;YACpD,kGAAkG;YAClGwI,aAAaJ;QACf;IAGN,GACA;QACE9E;QACAwE;QACAM;QACAjG;QACAiC;KACD;IAGH,MAAMqE,kBAAkBnL,MAAMwH,OAAO,CAAC,IAAM;QAC1C,MAAM4D,yBACJ7J,SAASE,SAAS,IAChBF,QAAQa,GAAG,CAACwC,8BAEZ,oBAAC5D;YAAS0C,WAAWxC,MAAM,CAAC,sBAAsB;WAAG6D,UACtD;QAEH,IAAI,OAAOZ,mBAAmB,YAAY;YACxC,OAAOA,eAAe;gBAAEiH;YAAuB;QACjD,OAAO;YACL,OAAOA;QACT,CAAC;IACH,GAAG;QAACrG;QAAWxD;QAAS4C;QAAgBS;KAAa;IAErD,MAAMyG,mBAAmBlG,oBAAoB,CAAC9B,UAAUiD,sBAAsB;IAE9E,MAAMgF,cAActL,MAAMwH,OAAO,CAAC,IAAM;QACtC,IAAI,CAAC6D,kBAAkB;YACrB,OAAO,IAAI;QACb,CAAC;QAED,qBACE,oBAACnG;YACCxB,WAAWuB,aAAamB,YAAYlF,MAAM,CAAC,2BAA2B,GAAGkF,SAAS;YAClFqD,SAAS,IAAMlD,qBAAqB;;IAG1C,GAAG;QAAC8E;QAAkBnG;QAAaD;KAAS;IAE5C,MAAMD,OAAOhF,MAAMwH,OAAO,CAAC,IAAM;QAC/B,IAAIvC,aAAamB,WAAW;YAC1B,OAAOnB;QACT,CAAC;QAED,qBACE,oBAACpE;YACC6C,WAAW2H,mBAAmBnK,MAAM,CAAC,8BAA8B,GAAGkF,SAAS;YAC/E/C,QAAQA;;IAGd,GAAG;QAACgI;QAAkBpG;QAAU5B;KAAO;IAEvC,MAAMkI,aAAa,AAACvG,CAAAA,QAAQqG,gBAAe,mBACzC,oBAACrL,MAAMgL,QAAQ,QACZM,aACAtG;IAIL,qBACE,oBAACiE;QACCvF,WAAWzD,WACTiB,MAAM,CAAC,eAAe,EACtBwE,UAAUtF,SAASoL,OAAO,IAAIrK,eAAe,CAACuE,MAAM,EACpDhC;QAEFI,OAAOA;QACP8E,KAAK/C;QACL4D,SAASO;OAER3G,UAAUsB,2BACT,oBAAC7D;QACE,GAAGwE,SAAS;QACbmG,WAAAA,IAAS;QACTnC,QAAQA;QACR5F,WAAW+D;QACXnF,OAAOW;QACPyI,WAAWpB;QACXvG,UAAUE;QACV,kIAAkI;QAClI,4FAA4F;QAC5F,wGAAwG;QACxGwF,SAAShH,MAAMgH,OAAO;QACtBjG,QAAQA;QACRmI,OAAOJ;QACPK,MAAMtL,+BAA+BkE;uBAGvC,oBAACzD;QACE,GAAGuE,SAAS;QACbuG,eAAAA,IAAW;QACXpC,SAASA;QACTiC,WAAWnB;QACXuB,SAASpC;QACTF,SAASA;QACTF,QAAQA;QACR5F,WAAW+D;QACXjE,QAAQA;QACRmI,OAAOJ;QACP/G,YAAYA;OAEX+C,UAAU0B,MAEd,gBACD,oBAAC8C;QACCnD,KAAK7C;QACLtC,MAAMA;QACNM,UAAUoG;QACVb,QAAQ7G,MAAM6G,MAAM;QACpBE,SAAS/G,MAAM+G,OAAO;QACtBC,SAAShH,MAAMgH,OAAO;QACtBnH,OAAOgE;QACPuF,eAAAA,IAAW;QACXnI,WAAWxC,MAAM,CAAC,wBAAwB;OAEzCiE,kCAAoB,oBAACxD;QAAOmH,KAAI;QAAGxG,OAAM;QACzCwC,YAAY1C,GAAG,CAAC,CAACC,qBAChB,oBAACV;YAAOmH,KAAK,CAAC,EAAEzG,KAAKC,KAAK,CAAC,CAAC;YAAEA,OAAOD,KAAKC,KAAK;cAGlDe,wBACC,oBAAC1C;QACCqL,WAAWrG;QACXsG,WAAWpI;QACXiC,cAAc6C;QACduD,mBAAmBtF;QACnBuF,cAAc5C;QACdjF,UAAUA;QACV8H,gBAAgBhH;QAChBiH,WAAWhH;QACXiH,aAAa/H;QACbE,mBAAmBA;QACnBC,wBAAwBA;OAEvByG;AAKX,CAAC"}
@@ -1 +1,58 @@
1
- .vkuiCustomSelect{cursor:pointer;display:block;position:relative;width:100%}.vkuiCustomSelect--pop-down{border-bottom-left-radius:0;border-bottom-right-radius:0}.vkuiCustomSelect--pop-up{border-top-left-radius:0;border-top-right-radius:0}.vkuiCustomSelect__control{display:none}.vkuiCustomSelect__empty{color:#818c99;color:var(--vkui--color_text_secondary);padding:12px 0;text-align:center}.vkuiCustomSelect__fetching{align-items:center;display:flex;justify-content:center}.vkuiCustomSelect__dropdown-icon{margin-right:10px}.vkuiCustomSelect--clear-icon{margin-right:-6px}.vkuiCustomSelect--sizeY-compact .vkuiCustomSelect__dropdown-icon{margin-right:8px}.vkuiCustomSelect--sizeY-compact .vkuiCustomSelect--clear-icon{margin-right:-2px}@media (max-height:414.9px),(pointer:fine) and (min-width:768px){.vkuiCustomSelect--sizeY-none .vkuiCustomSelect__dropdown-icon{margin-right:8px}.vkuiCustomSelect--sizeY-none .vkuiCustomSelect--clear-icon{margin-right:-2px}}
1
+ .CustomSelect {
2
+ width: 100%;
3
+ position: relative;
4
+ display: block;
5
+ cursor: pointer;
6
+ }
7
+
8
+ .CustomSelect--pop-down {
9
+ border-bottom-left-radius: 0;
10
+ border-bottom-right-radius: 0;
11
+ }
12
+
13
+ .CustomSelect--pop-up {
14
+ border-top-left-radius: 0;
15
+ border-top-right-radius: 0;
16
+ }
17
+
18
+ .CustomSelect__control {
19
+ display: none;
20
+ }
21
+
22
+ .CustomSelect__empty {
23
+ padding: 12px 0;
24
+ text-align: center;
25
+ color: var(--vkui--color_text_secondary);
26
+ }
27
+
28
+ .CustomSelect__fetching {
29
+ display: flex;
30
+ align-items: center;
31
+ justify-content: center;
32
+ }
33
+
34
+ .CustomSelect__dropdown-icon {
35
+ margin-right: 10px;
36
+ }
37
+
38
+ .CustomSelect--clear-icon {
39
+ margin-right: -6px;
40
+ }
41
+
42
+ .CustomSelect--sizeY-compact .CustomSelect__dropdown-icon {
43
+ margin-right: 8px;
44
+ }
45
+
46
+ .CustomSelect--sizeY-compact .CustomSelect--clear-icon {
47
+ margin-right: -2px;
48
+ }
49
+
50
+ @media (pointer: fine) and (min-width: 768px),(max-height: 414.9px) {
51
+ .CustomSelect--sizeY-none .CustomSelect__dropdown-icon {
52
+ margin-right: 8px;
53
+ }
54
+
55
+ .CustomSelect--sizeY-none .CustomSelect--clear-icon {
56
+ margin-right: -2px;
57
+ }
58
+ }
@@ -1 +1,43 @@
1
- .vkuiCustomSelectDropdown{background-color:#fff;background-color:var(--vkui--color_background_modal);border:1px solid rgba(0,0,0,.12);border:var(--vkui_internal--thin_border) solid var(--vkui--color_field_border_alpha);border-radius:8px;box-shadow:0 0 2px rgba(0,0,0,.03),0 2px 2px rgba(0,0,0,.06);box-shadow:var(--vkui--elevation1);box-sizing:border-box;overflow:hidden}.vkuiCustomSelectDropdown--wide{width:100%}.vkuiCustomSelectDropdown--bottom{border-top:0;border-top-left-radius:0;border-top-right-radius:0}.vkuiCustomSelectDropdown--top{border-bottom:0;border-bottom-left-radius:0;border-bottom-right-radius:0;bottom:100%;box-shadow:0 0 2px rgba(0,0,0,.03),0 -2px 2px rgba(0,0,0,.06);box-shadow:var(--vkui--elevation1_invert_y)}.vkuiCustomSelectDropdown__fetching{padding:12px 0}.vkuiCustomSelectDropdown__in{max-height:160px}.vkuiInternalCalendarHeader__pickers .vkuiCustomSelectDropdown__in{max-height:184px}
1
+ .CustomSelectDropdown {
2
+ overflow: hidden;
3
+ background-color: var(--vkui--color_background_modal);
4
+ box-sizing: border-box;
5
+ border: var(--vkui_internal--thin_border) solid var(--vkui--color_field_border_alpha);
6
+ box-shadow: var(--vkui--elevation1);
7
+ border-radius: 8px;
8
+ }
9
+
10
+ .CustomSelectDropdown--wide {
11
+ width: 100%;
12
+ }
13
+
14
+ .CustomSelectDropdown--bottom {
15
+ border-top: 0;
16
+ border-top-left-radius: 0;
17
+ border-top-right-radius: 0;
18
+ }
19
+
20
+ .CustomSelectDropdown--top {
21
+ bottom: 100%;
22
+ border-bottom: 0;
23
+ border-bottom-left-radius: 0;
24
+ border-bottom-right-radius: 0;
25
+ box-shadow: var(--vkui--elevation1_invert_y);
26
+ }
27
+
28
+ .CustomSelectDropdown__fetching {
29
+ padding: 12px 0;
30
+ }
31
+
32
+ .CustomSelectDropdown__in {
33
+ max-height: 160px;
34
+ }
35
+
36
+ /**
37
+ * CMP:
38
+ * CalendarHeader
39
+ */
40
+
41
+ :global(.vkuiInternalCalendarHeader__pickers) .CustomSelectDropdown__in {
42
+ max-height: 184px;
43
+ }
@@ -25,7 +25,7 @@ const warn = warnOnce('CustomSelectOption');
25
25
  styleProp
26
26
  ]);
27
27
  if (!!option && process.env.NODE_ENV === 'development') {
28
- // TODO v6.0.0. Удалить св-во `option`
28
+ // TODO [>=6]: Удалить св-во `option`
29
29
  warn('Свойство option было добавлено по ошибке и будет удалено в v6.0.0.');
30
30
  }
31
31
  return /*#__PURE__*/ React.createElement(Paragraph, {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/CustomSelectOption/CustomSelectOption.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Icon16Done } from '@vkontakte/icons';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { SizeType } from '../../lib/adaptivity';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { HasRootRef } from '../../types';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { Paragraph } from '../Typography/Paragraph/Paragraph';\nimport styles from './CustomSelectOption.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelectOption--sizeY-none'],\n [SizeType.REGULAR]: styles['CustomSelectOption--sizeY-regular'],\n};\n\nexport interface CustomSelectOptionProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n /**\n * Вставляет основной контент.\n * @deprecated since v6.0.0\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 className,\n ...restProps\n}: CustomSelectOptionProps) => {\n const title = typeof children === 'string' ? children : undefined;\n const { sizeY = 'none' } = useAdaptivity();\n const style = React.useMemo(\n () =>\n hierarchy > 0\n ? {\n '--vkui_internal--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 // TODO v6.0.0. Удалить св-во `option`\n warn('Свойство option было добавлено по ошибке и будет удалено в v6.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 className={classNames(\n styles['CustomSelectOption'],\n sizeY !== SizeType.COMPACT && sizeYClassNames[sizeY],\n hovered && !disabled && styles['CustomSelectOption--hover'],\n disabled && styles['CustomSelectOption--disabled'],\n hierarchy > 0 && styles['CustomSelectOption--hierarchy'],\n className,\n )}\n style={style}\n >\n {hasReactNode(before) && <div className={styles['CustomSelectOption__before']}>{before}</div>}\n <div className={styles['CustomSelectOption__main']}>\n <div className={styles['CustomSelectOption__children']}>{children}</div>\n {hasReactNode(description) && (\n <Footnote className={styles['CustomSelectOption__description']}>{description}</Footnote>\n )}\n </div>\n <div className={styles['CustomSelectOption__after']}>\n {hasReactNode(after) && <div>{after}</div>}\n {selected && <Icon16Done className={styles['CustomSelectOption__selectedIcon']} />}\n </div>\n </Paragraph>\n );\n};\n"],"names":["React","Icon16Done","classNames","hasReactNode","useAdaptivity","SizeType","warnOnce","Footnote","Paragraph","styles","sizeYClassNames","none","REGULAR","warn","CustomSelectOption","children","hierarchy","hovered","selected","before","after","option","description","disabled","style","styleProp","className","restProps","title","undefined","sizeY","useMemo","process","env","NODE_ENV","Component","role","aria-disabled","aria-selected","COMPACT","div"],"mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,mBAAmB;AAC9C,SAASC,UAAU,EAAEC,YAAY,QAAQ,kBAAkB;AAC3D,SAASC,aAAa,QAAQ,4BAA4B;AAC1D,SAASC,QAAQ,QAAQ,uBAAuB;AAChD,SAASC,QAAQ,QAAQ,qBAAqB;AAE9C,SAASC,QAAQ,QAAQ,kCAAkC;AAC3D,SAASC,SAAS,QAAQ,oCAAoC;AAC9D,OAAOC,YAAY,kCAAkC;AAErD,MAAMC,kBAAkB;IACtBC,MAAMF,MAAM,CAAC,iCAAiC;IAC9C,CAACJ,SAASO,OAAO,CAAC,EAAEH,MAAM,CAAC,oCAAoC;AACjE;AA8CA,MAAMI,OAAOP,SAAS;AAEtB;;CAEC,GACD,OAAO,MAAMQ,qBAAqB,CAAC,EACjCC,SAAQ,EACRC,WAAY,EAAC,EACbC,QAAO,EACPC,SAAQ,EACRC,OAAM,EACNC,MAAK,EACLC,OAAM,EACNC,YAAW,EACXC,SAAQ,EACRC,OAAOC,UAAS,EAChBC,UAAS,EACT,GAAGC,WACqB,GAAK;IAC7B,MAAMC,QAAQ,OAAOb,aAAa,WAAWA,WAAWc,SAAS;IACjE,MAAM,EAAEC,OAAQ,OAAM,EAAE,GAAG1B;IAC3B,MAAMoB,QAAQxB,MAAM+B,OAAO,CACzB,IACEf,YAAY,IACR;YACE,yDAAyDA;YACzD,GAAGS,SAAS;QACd,IACAA,SAAS,EACf;QAACT;QAAWS;KAAU;IAGxB,IAAI,CAAC,CAACJ,UAAUW,QAAQC,GAAG,CAACC,QAAQ,KAAK,eAAe;QACtD,sCAAsC;QACtCrB,KAAK;IACP,CAAC;IAED,qBACE,oBAACL;QACE,GAAGmB,SAAS;QACbQ,WAAU;QACVC,MAAK;QACLR,OAAOA;QACPS,iBAAed;QACfe,iBAAepB;QACfQ,WAAWxB,WACTO,MAAM,CAAC,qBAAqB,EAC5BqB,UAAUzB,SAASkC,OAAO,IAAI7B,eAAe,CAACoB,MAAM,EACpDb,WAAW,CAACM,YAAYd,MAAM,CAAC,4BAA4B,EAC3Dc,YAAYd,MAAM,CAAC,+BAA+B,EAClDO,YAAY,KAAKP,MAAM,CAAC,gCAAgC,EACxDiB;QAEFF,OAAOA;OAENrB,aAAagB,yBAAW,oBAACqB;QAAId,WAAWjB,MAAM,CAAC,6BAA6B;OAAGU,uBAChF,oBAACqB;QAAId,WAAWjB,MAAM,CAAC,2BAA2B;qBAChD,oBAAC+B;QAAId,WAAWjB,MAAM,CAAC,+BAA+B;OAAGM,WACxDZ,aAAamB,8BACZ,oBAACf;QAASmB,WAAWjB,MAAM,CAAC,kCAAkC;OAAGa,6BAGrE,oBAACkB;QAAId,WAAWjB,MAAM,CAAC,4BAA4B;OAChDN,aAAaiB,wBAAU,oBAACoB,aAAKpB,QAC7BF,0BAAY,oBAACjB;QAAWyB,WAAWjB,MAAM,CAAC,mCAAmC;;AAItF,EAAE"}
1
+ {"version":3,"sources":["../../../../src/components/CustomSelectOption/CustomSelectOption.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Icon16Done } from '@vkontakte/icons';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { SizeType } from '../../lib/adaptivity';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { HasRootRef } from '../../types';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { Paragraph } from '../Typography/Paragraph/Paragraph';\nimport styles from './CustomSelectOption.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelectOption--sizeY-none'],\n [SizeType.REGULAR]: styles['CustomSelectOption--sizeY-regular'],\n};\n\nexport interface CustomSelectOptionProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n /**\n * Вставляет основной контент.\n * @deprecated since v6.0.0\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 className,\n ...restProps\n}: CustomSelectOptionProps) => {\n const title = typeof children === 'string' ? children : undefined;\n const { sizeY = 'none' } = useAdaptivity();\n const style = React.useMemo(\n () =>\n hierarchy > 0\n ? {\n '--vkui_internal--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 // TODO [>=6]: Удалить св-во `option`\n warn('Свойство option было добавлено по ошибке и будет удалено в v6.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 className={classNames(\n styles['CustomSelectOption'],\n sizeY !== SizeType.COMPACT && sizeYClassNames[sizeY],\n hovered && !disabled && styles['CustomSelectOption--hover'],\n disabled && styles['CustomSelectOption--disabled'],\n hierarchy > 0 && styles['CustomSelectOption--hierarchy'],\n className,\n )}\n style={style}\n >\n {hasReactNode(before) && <div className={styles['CustomSelectOption__before']}>{before}</div>}\n <div className={styles['CustomSelectOption__main']}>\n <div className={styles['CustomSelectOption__children']}>{children}</div>\n {hasReactNode(description) && (\n <Footnote className={styles['CustomSelectOption__description']}>{description}</Footnote>\n )}\n </div>\n <div className={styles['CustomSelectOption__after']}>\n {hasReactNode(after) && <div>{after}</div>}\n {selected && <Icon16Done className={styles['CustomSelectOption__selectedIcon']} />}\n </div>\n </Paragraph>\n );\n};\n"],"names":["React","Icon16Done","classNames","hasReactNode","useAdaptivity","SizeType","warnOnce","Footnote","Paragraph","styles","sizeYClassNames","none","REGULAR","warn","CustomSelectOption","children","hierarchy","hovered","selected","before","after","option","description","disabled","style","styleProp","className","restProps","title","undefined","sizeY","useMemo","process","env","NODE_ENV","Component","role","aria-disabled","aria-selected","COMPACT","div"],"mappings":"AAAA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,mBAAmB;AAC9C,SAASC,UAAU,EAAEC,YAAY,QAAQ,kBAAkB;AAC3D,SAASC,aAAa,QAAQ,4BAA4B;AAC1D,SAASC,QAAQ,QAAQ,uBAAuB;AAChD,SAASC,QAAQ,QAAQ,qBAAqB;AAE9C,SAASC,QAAQ,QAAQ,kCAAkC;AAC3D,SAASC,SAAS,QAAQ,oCAAoC;AAC9D,OAAOC,YAAY,kCAAkC;AAErD,MAAMC,kBAAkB;IACtBC,MAAMF,MAAM,CAAC,iCAAiC;IAC9C,CAACJ,SAASO,OAAO,CAAC,EAAEH,MAAM,CAAC,oCAAoC;AACjE;AA8CA,MAAMI,OAAOP,SAAS;AAEtB;;CAEC,GACD,OAAO,MAAMQ,qBAAqB,CAAC,EACjCC,SAAQ,EACRC,WAAY,EAAC,EACbC,QAAO,EACPC,SAAQ,EACRC,OAAM,EACNC,MAAK,EACLC,OAAM,EACNC,YAAW,EACXC,SAAQ,EACRC,OAAOC,UAAS,EAChBC,UAAS,EACT,GAAGC,WACqB,GAAK;IAC7B,MAAMC,QAAQ,OAAOb,aAAa,WAAWA,WAAWc,SAAS;IACjE,MAAM,EAAEC,OAAQ,OAAM,EAAE,GAAG1B;IAC3B,MAAMoB,QAAQxB,MAAM+B,OAAO,CACzB,IACEf,YAAY,IACR;YACE,yDAAyDA;YACzD,GAAGS,SAAS;QACd,IACAA,SAAS,EACf;QAACT;QAAWS;KAAU;IAGxB,IAAI,CAAC,CAACJ,UAAUW,QAAQC,GAAG,CAACC,QAAQ,KAAK,eAAe;QACtD,qCAAqC;QACrCrB,KAAK;IACP,CAAC;IAED,qBACE,oBAACL;QACE,GAAGmB,SAAS;QACbQ,WAAU;QACVC,MAAK;QACLR,OAAOA;QACPS,iBAAed;QACfe,iBAAepB;QACfQ,WAAWxB,WACTO,MAAM,CAAC,qBAAqB,EAC5BqB,UAAUzB,SAASkC,OAAO,IAAI7B,eAAe,CAACoB,MAAM,EACpDb,WAAW,CAACM,YAAYd,MAAM,CAAC,4BAA4B,EAC3Dc,YAAYd,MAAM,CAAC,+BAA+B,EAClDO,YAAY,KAAKP,MAAM,CAAC,gCAAgC,EACxDiB;QAEFF,OAAOA;OAENrB,aAAagB,yBAAW,oBAACqB;QAAId,WAAWjB,MAAM,CAAC,6BAA6B;OAAGU,uBAChF,oBAACqB;QAAId,WAAWjB,MAAM,CAAC,2BAA2B;qBAChD,oBAAC+B;QAAId,WAAWjB,MAAM,CAAC,+BAA+B;OAAGM,WACxDZ,aAAamB,8BACZ,oBAACf;QAASmB,WAAWjB,MAAM,CAAC,kCAAkC;OAAGa,6BAGrE,oBAACkB;QAAId,WAAWjB,MAAM,CAAC,4BAA4B;OAChDN,aAAaiB,wBAAU,oBAACoB,aAAKpB,QAC7BF,0BAAY,oBAACjB;QAAWyB,WAAWjB,MAAM,CAAC,mCAAmC;;AAItF,EAAE"}
@@ -1 +1,81 @@
1
- .vkuiCustomSelectOption{align-items:center;box-sizing:border-box;color:#000;color:var(--vkui--color_text_primary);cursor:pointer;display:flex;padding:8px 12px;position:relative;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;white-space:nowrap;width:100%}.vkuiCustomSelectOption--hierarchy{--vkui_internal--custom_select_option_hierarchy_level:0;padding-left:calc(0 * 32px);padding-left:calc(var(--vkui_internal--custom_select_option_hierarchy_level) * var(--vkui--size_option_hierarchy--regular))}.vkuiCustomSelectOption--sizeY-regular{min-height:44px}@media (max-width:767.9px) and (min-height:415px),(pointer:coarse) and (min-height:415px),(pointer:none) and (min-height:415px){.vkuiCustomSelectOption--sizeY-none{min-height:44px}}.vkuiCustomSelectOption--disabled{cursor:default;opacity:.64;opacity:var(--vkui--opacity_disable_accessibility)}.vkuiCustomSelectOption--hover{background-color:rgba(0,16,61,.04);background-color:var(--vkui--color_transparent--hover)}.vkuiCustomSelectOption__before{flex-shrink:0;margin-right:7px}.vkuiCustomSelectOption__main{flex-grow:1;max-width:100%;min-width:0}.vkuiCustomSelectOption__children{min-width:0;overflow:hidden;text-overflow:ellipsis}.vkuiCustomSelectOption__after{align-items:center;display:flex;flex-shrink:0;margin-left:8px}.vkuiCustomSelectOption__description{color:#818c99;color:var(--vkui--color_text_secondary);overflow:hidden;text-overflow:ellipsis}.vkuiCustomSelectOption__selectedIcon{color:#2688eb;color:var(--vkui--color_icon_accent)}.vkuiCustomSelectOption__selectedIcon:not(:first-child){margin-left:8px}
1
+ .CustomSelectOption {
2
+ width: 100%;
3
+ display: flex;
4
+ align-items: center;
5
+ position: relative;
6
+ box-sizing: border-box;
7
+ padding: 8px 12px;
8
+ white-space: nowrap;
9
+ -webkit-user-select: none;
10
+ -moz-user-select: none;
11
+ -ms-user-select: none;
12
+ user-select: none;
13
+ cursor: pointer;
14
+ color: var(--vkui--color_text_primary);
15
+ }
16
+
17
+ .CustomSelectOption--hierarchy {
18
+ --vkui_internal--custom_select_option_hierarchy_level: 0;
19
+
20
+ padding-left: calc(
21
+ var(--vkui_internal--custom_select_option_hierarchy_level) *
22
+ var(--vkui--size_option_hierarchy--regular)
23
+ );
24
+ }
25
+
26
+ .CustomSelectOption--sizeY-regular {
27
+ min-height: 44px;
28
+ }
29
+
30
+ @media (pointer: coarse) and (min-height: 415px),(pointer: none) and (min-height: 415px),(max-width: 767.9px) and (min-height: 415px) {
31
+ .CustomSelectOption--sizeY-none {
32
+ min-height: 44px;
33
+ }
34
+ }
35
+
36
+ .CustomSelectOption--disabled {
37
+ cursor: default;
38
+ opacity: var(--vkui--opacity_disable_accessibility);
39
+ }
40
+
41
+ .CustomSelectOption--hover {
42
+ background-color: var(--vkui--color_transparent--hover);
43
+ }
44
+
45
+ .CustomSelectOption__before {
46
+ flex-shrink: 0;
47
+ margin-right: 7px;
48
+ }
49
+
50
+ .CustomSelectOption__main {
51
+ flex-grow: 1;
52
+ max-width: 100%;
53
+ min-width: 0;
54
+ }
55
+
56
+ .CustomSelectOption__children {
57
+ min-width: 0;
58
+ overflow: hidden;
59
+ text-overflow: ellipsis;
60
+ }
61
+
62
+ .CustomSelectOption__after {
63
+ margin-left: 8px;
64
+ flex-shrink: 0;
65
+ display: flex;
66
+ align-items: center;
67
+ }
68
+
69
+ .CustomSelectOption__description {
70
+ color: var(--vkui--color_text_secondary);
71
+ text-overflow: ellipsis;
72
+ overflow: hidden;
73
+ }
74
+
75
+ .CustomSelectOption__selectedIcon {
76
+ color: var(--vkui--color_icon_accent);
77
+ }
78
+
79
+ .CustomSelectOption__selectedIcon:not(:first-child) {
80
+ margin-left: 8px;
81
+ }
@@ -1 +1,30 @@
1
- .vkuiDateInput__input{cursor:text;flex-grow:1;font-size:16px;font-variant-numeric:tabular-nums;margin-left:10px;margin-right:14px;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text;white-space:nowrap;z-index:1;z-index:var(--vkui_internal--z_index_form_field_element)}.vkuiDateInput__input--time-divider{letter-spacing:6px!important}.vkuiDateInput--sizeY-compact .vkuiDateInput__input{font-size:15px;margin-right:22px}@media (max-height:414.9px),(pointer:fine) and (min-width:768px){.vkuiDateInput--sizeY-none .vkuiDateInput__input{font-size:15px;margin-right:22px}}
1
+ .DateInput__input {
2
+ flex-grow: 1;
3
+ margin-left: 10px;
4
+ margin-right: 14px;
5
+ font-size: 16px;
6
+ z-index: var(--vkui_internal--z_index_form_field_element);
7
+ cursor: text;
8
+ white-space: nowrap;
9
+ -webkit-user-select: text;
10
+ -moz-user-select: text;
11
+ -ms-user-select: text;
12
+ user-select: text;
13
+ font-variant-numeric: tabular-nums;
14
+ }
15
+
16
+ .DateInput__input--time-divider {
17
+ letter-spacing: 6px !important;
18
+ }
19
+
20
+ .DateInput--sizeY-compact .DateInput__input {
21
+ font-size: 15px;
22
+ margin-right: 22px;
23
+ }
24
+
25
+ @media (pointer: fine) and (min-width: 768px),(max-height: 414.9px) {
26
+ .DateInput--sizeY-none .DateInput__input {
27
+ font-size: 15px;
28
+ margin-right: 22px;
29
+ }
30
+ }
@@ -1 +1,30 @@
1
- .vkuiDatePicker{border:0;margin:0;padding:0}.vkuiDatePicker__container{display:flex;flex-direction:row;width:100%}.vkuiDatePicker__day{min-width:72px}.vkuiDatePicker__month{display:flex;flex:1 0 0;min-width:0;padding:0 8px}.vkuiDatePicker__year{min-width:92px}.vkuiDatePicker__monthSelect{width:100%}
1
+ .DatePicker {
2
+ margin: 0;
3
+ padding: 0;
4
+ border: 0;
5
+ }
6
+
7
+ .DatePicker__container {
8
+ width: 100%;
9
+ display: flex;
10
+ flex-direction: row;
11
+ }
12
+
13
+ .DatePicker__day {
14
+ min-width: 72px;
15
+ }
16
+
17
+ .DatePicker__month {
18
+ min-width: 0;
19
+ display: flex;
20
+ flex: 1 0 0;
21
+ padding: 0 8px;
22
+ }
23
+
24
+ .DatePicker__year {
25
+ min-width: 92px;
26
+ }
27
+
28
+ .DatePicker__monthSelect {
29
+ width: 100%;
30
+ }
@@ -90,7 +90,7 @@ const getInternalValue = (value)=>{
90
90
  }
91
91
  const formattedStartValue = `${internalValue[0]}.${internalValue[1]}.${internalValue[2]}`;
92
92
  const formattedEndValue = `${internalValue[3]}.${internalValue[4]}.${internalValue[5]}`;
93
- const mask = 'dd.MM.yyyy';
93
+ const mask = 'DD.MM.YYYY';
94
94
  if (!isMatch(formattedStartValue, mask)) {
95
95
  isStartValid = false;
96
96
  }