@vkontakte/vkui 7.2.0 → 7.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1679) hide show
  1. package/dist/components/Accordion/Accordion.d.ts +6 -0
  2. package/dist/components/Accordion/Accordion.d.ts.map +1 -1
  3. package/dist/components/Accordion/Accordion.js +5 -3
  4. package/dist/components/Accordion/Accordion.js.map +1 -1
  5. package/dist/components/Accordion/AccordionContent.d.ts +1 -1
  6. package/dist/components/Accordion/AccordionContent.d.ts.map +1 -1
  7. package/dist/components/Accordion/AccordionContent.js +0 -1
  8. package/dist/components/Accordion/AccordionContent.js.map +1 -1
  9. package/dist/components/Accordion/AccordionContext.d.ts +13 -0
  10. package/dist/components/Accordion/AccordionContext.d.ts.map +1 -1
  11. package/dist/components/Accordion/AccordionContext.js.map +1 -1
  12. package/dist/components/Accordion/AccordionSummary.d.ts +1 -1
  13. package/dist/components/Accordion/AccordionSummary.d.ts.map +1 -1
  14. package/dist/components/Accordion/AccordionSummary.js +0 -1
  15. package/dist/components/Accordion/AccordionSummary.js.map +1 -1
  16. package/dist/components/ActionSheet/ActionSheet.d.ts +29 -2
  17. package/dist/components/ActionSheet/ActionSheet.d.ts.map +1 -1
  18. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  19. package/dist/components/ActionSheet/ActionSheetContext.d.ts +23 -0
  20. package/dist/components/ActionSheet/ActionSheetContext.d.ts.map +1 -1
  21. package/dist/components/ActionSheet/ActionSheetContext.js.map +1 -1
  22. package/dist/components/ActionSheet/ActionSheetDefaultIosCloseItem.d.ts +1 -1
  23. package/dist/components/ActionSheet/ActionSheetDefaultIosCloseItem.d.ts.map +1 -1
  24. package/dist/components/ActionSheet/ActionSheetDefaultIosCloseItem.js +7 -3
  25. package/dist/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -1
  26. package/dist/components/ActionSheet/types.d.ts +8 -5
  27. package/dist/components/ActionSheet/types.d.ts.map +1 -1
  28. package/dist/components/ActionSheet/types.js.map +1 -1
  29. package/dist/components/ActionSheetItem/ActionSheetItem.d.ts +40 -8
  30. package/dist/components/ActionSheetItem/ActionSheetItem.d.ts.map +1 -1
  31. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  32. package/dist/components/ActionSheetItem/helpers.d.ts +2 -2
  33. package/dist/components/ActionSheetItem/helpers.js +2 -2
  34. package/dist/components/ActionSheetItem/helpers.js.map +1 -1
  35. package/dist/components/AdaptiveIconRenderer/AdaptiveIconRenderer.d.ts +6 -0
  36. package/dist/components/AdaptiveIconRenderer/AdaptiveIconRenderer.d.ts.map +1 -1
  37. package/dist/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -1
  38. package/dist/components/AdaptivityProvider/AdaptivityContext.d.ts +12 -4
  39. package/dist/components/AdaptivityProvider/AdaptivityContext.d.ts.map +1 -1
  40. package/dist/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  41. package/dist/components/Alert/Alert.d.ts +40 -12
  42. package/dist/components/Alert/Alert.d.ts.map +1 -1
  43. package/dist/components/Alert/Alert.js.map +1 -1
  44. package/dist/components/Alert/AlertAction.d.ts +6 -0
  45. package/dist/components/Alert/AlertAction.d.ts.map +1 -1
  46. package/dist/components/Alert/AlertAction.js.map +1 -1
  47. package/dist/components/Alert/AlertActions.d.ts +3 -0
  48. package/dist/components/Alert/AlertActions.d.ts.map +1 -1
  49. package/dist/components/Alert/AlertActions.js.map +1 -1
  50. package/dist/components/Alert/AlertBase.d.ts +8 -0
  51. package/dist/components/Alert/AlertBase.d.ts.map +1 -1
  52. package/dist/components/Alert/AlertBase.js.map +1 -1
  53. package/dist/components/Alert/AlertTypography.d.ts.map +1 -1
  54. package/dist/components/Alert/AlertTypography.js +1 -1
  55. package/dist/components/Alert/AlertTypography.js.map +1 -1
  56. package/dist/components/AppRoot/AppRoot.d.ts +15 -4
  57. package/dist/components/AppRoot/AppRoot.d.ts.map +1 -1
  58. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  59. package/dist/components/AppRoot/AppRootContext.d.ts +1 -1
  60. package/dist/components/AppRoot/AppRootContext.d.ts.map +1 -1
  61. package/dist/components/AppRoot/AppRootContext.js +2 -2
  62. package/dist/components/AppRoot/AppRootContext.js.map +1 -1
  63. package/dist/components/AppRoot/AppRootPortal.d.ts +11 -4
  64. package/dist/components/AppRoot/AppRootPortal.d.ts.map +1 -1
  65. package/dist/components/AppRoot/AppRootPortal.js.map +1 -1
  66. package/dist/components/AppRoot/ScrollContext.d.ts +4 -4
  67. package/dist/components/AppRoot/ScrollContext.d.ts.map +1 -1
  68. package/dist/components/AppRoot/ScrollContext.js +4 -4
  69. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  70. package/dist/components/AppRoot/types.d.ts.map +1 -1
  71. package/dist/components/AppRoot/types.js +1 -1
  72. package/dist/components/AppRoot/types.js.map +1 -1
  73. package/dist/components/AspectRatio/AspectRatio.d.ts +4 -1
  74. package/dist/components/AspectRatio/AspectRatio.d.ts.map +1 -1
  75. package/dist/components/AspectRatio/AspectRatio.js.map +1 -1
  76. package/dist/components/Avatar/Avatar.d.ts +1 -1
  77. package/dist/components/Avatar/Avatar.d.ts.map +1 -1
  78. package/dist/components/Avatar/Avatar.js +6 -4
  79. package/dist/components/Avatar/Avatar.js.map +1 -1
  80. package/dist/components/Avatar/AvatarBadge/AvatarBadge.d.ts +1 -2
  81. package/dist/components/Avatar/AvatarBadge/AvatarBadge.d.ts.map +1 -1
  82. package/dist/components/Avatar/AvatarBadge/AvatarBadge.js +0 -1
  83. package/dist/components/Avatar/AvatarBadge/AvatarBadge.js.map +1 -1
  84. package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.d.ts +1 -2
  85. package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.d.ts.map +1 -1
  86. package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js +0 -1
  87. package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  88. package/dist/components/Avatar/AvatarBadge/icons.d.ts.map +1 -1
  89. package/dist/components/Avatar/AvatarBadge/icons.js +1 -1
  90. package/dist/components/Avatar/AvatarBadge/icons.js.map +1 -1
  91. package/dist/components/Badge/Badge.d.ts +3 -0
  92. package/dist/components/Badge/Badge.d.ts.map +1 -1
  93. package/dist/components/Badge/Badge.js.map +1 -1
  94. package/dist/components/Banner/Banner.d.ts +8 -5
  95. package/dist/components/Banner/Banner.d.ts.map +1 -1
  96. package/dist/components/Banner/Banner.js.map +1 -1
  97. package/dist/components/Button/Button.d.ts +27 -0
  98. package/dist/components/Button/Button.d.ts.map +1 -1
  99. package/dist/components/Button/Button.js.map +1 -1
  100. package/dist/components/ButtonGroup/ButtonGroup.d.ts +1 -4
  101. package/dist/components/ButtonGroup/ButtonGroup.d.ts.map +1 -1
  102. package/dist/components/ButtonGroup/ButtonGroup.js +0 -1
  103. package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -1
  104. package/dist/components/Calendar/Calendar.d.ts +39 -7
  105. package/dist/components/Calendar/Calendar.d.ts.map +1 -1
  106. package/dist/components/Calendar/Calendar.js +78 -18
  107. package/dist/components/Calendar/Calendar.js.map +1 -1
  108. package/dist/components/CalendarDay/CalendarDay.d.ts +61 -3
  109. package/dist/components/CalendarDay/CalendarDay.d.ts.map +1 -1
  110. package/dist/components/CalendarDay/CalendarDay.js +36 -12
  111. package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
  112. package/dist/components/CalendarDays/CalendarDays.d.ts +68 -3
  113. package/dist/components/CalendarDays/CalendarDays.d.ts.map +1 -1
  114. package/dist/components/CalendarDays/CalendarDays.js +76 -46
  115. package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
  116. package/dist/components/CalendarHeader/CalendarHeader.d.ts +45 -6
  117. package/dist/components/CalendarHeader/CalendarHeader.d.ts.map +1 -1
  118. package/dist/components/CalendarHeader/CalendarHeader.js +9 -2
  119. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
  120. package/dist/components/CalendarRange/CalendarRange.d.ts +37 -5
  121. package/dist/components/CalendarRange/CalendarRange.d.ts.map +1 -1
  122. package/dist/components/CalendarRange/CalendarRange.js +21 -8
  123. package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
  124. package/dist/components/CalendarTime/CalendarTime.d.ts +31 -4
  125. package/dist/components/CalendarTime/CalendarTime.d.ts.map +1 -1
  126. package/dist/components/CalendarTime/CalendarTime.js +25 -15
  127. package/dist/components/CalendarTime/CalendarTime.js.map +1 -1
  128. package/dist/components/Card/Card.d.ts +3 -0
  129. package/dist/components/Card/Card.d.ts.map +1 -1
  130. package/dist/components/Card/Card.js.map +1 -1
  131. package/dist/components/CardGrid/CardGrid.d.ts +4 -1
  132. package/dist/components/CardGrid/CardGrid.d.ts.map +1 -1
  133. package/dist/components/CardGrid/CardGrid.js.map +1 -1
  134. package/dist/components/CardScroll/CardScroll.d.ts +2 -2
  135. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  136. package/dist/components/CarouselBase/Bullets.d.ts +2 -3
  137. package/dist/components/CarouselBase/Bullets.d.ts.map +1 -1
  138. package/dist/components/CarouselBase/Bullets.js +1 -2
  139. package/dist/components/CarouselBase/Bullets.js.map +1 -1
  140. package/dist/components/CarouselBase/CarouselBase.js +6 -6
  141. package/dist/components/CarouselBase/CarouselBase.js.map +1 -1
  142. package/dist/components/CarouselBase/CarouselViewPort.d.ts +1 -1
  143. package/dist/components/CarouselBase/CarouselViewPort.d.ts.map +1 -1
  144. package/dist/components/CarouselBase/CarouselViewPort.js +1 -1
  145. package/dist/components/CarouselBase/CarouselViewPort.js.map +1 -1
  146. package/dist/components/CarouselBase/ScrollArrows.d.ts +3 -3
  147. package/dist/components/CarouselBase/ScrollArrows.d.ts.map +1 -1
  148. package/dist/components/CarouselBase/ScrollArrows.js +1 -1
  149. package/dist/components/CarouselBase/ScrollArrows.js.map +1 -1
  150. package/dist/components/CarouselBase/helpers.d.ts +2 -2
  151. package/dist/components/CarouselBase/helpers.d.ts.map +1 -1
  152. package/dist/components/CarouselBase/helpers.js +3 -3
  153. package/dist/components/CarouselBase/helpers.js.map +1 -1
  154. package/dist/components/CarouselBase/types.d.ts +21 -20
  155. package/dist/components/CarouselBase/types.d.ts.map +1 -1
  156. package/dist/components/CarouselBase/types.js +1 -1
  157. package/dist/components/CarouselBase/types.js.map +1 -1
  158. package/dist/components/Cell/Cell.d.ts +13 -7
  159. package/dist/components/Cell/Cell.d.ts.map +1 -1
  160. package/dist/components/Cell/Cell.js +1 -1
  161. package/dist/components/Cell/Cell.js.map +1 -1
  162. package/dist/components/Cell/CellDragger/CellDragger.d.ts.map +1 -1
  163. package/dist/components/Cell/CellDragger/CellDragger.js +1 -1
  164. package/dist/components/Cell/CellDragger/CellDragger.js.map +1 -1
  165. package/dist/components/CellButton/CellButton.d.ts +3 -0
  166. package/dist/components/CellButton/CellButton.d.ts.map +1 -1
  167. package/dist/components/CellButton/CellButton.js.map +1 -1
  168. package/dist/components/CellButtonGroup/CellButtonGroup.d.ts +284 -288
  169. package/dist/components/CellButtonGroup/CellButtonGroup.d.ts.map +1 -1
  170. package/dist/components/CellButtonGroup/CellButtonGroup.js +4 -2
  171. package/dist/components/CellButtonGroup/CellButtonGroup.js.map +1 -1
  172. package/dist/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.d.ts +1 -4
  173. package/dist/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.d.ts.map +1 -1
  174. package/dist/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.js +0 -1
  175. package/dist/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.js.map +1 -1
  176. package/dist/components/Checkbox/Checkbox.d.ts +6 -0
  177. package/dist/components/Checkbox/Checkbox.d.ts.map +1 -1
  178. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  179. package/dist/components/Checkbox/CheckboxInput/CheckboxInput.d.ts +21 -0
  180. package/dist/components/Checkbox/CheckboxInput/CheckboxInput.d.ts.map +1 -1
  181. package/dist/components/Checkbox/CheckboxInput/CheckboxInput.js.map +1 -1
  182. package/dist/components/ChipsInput/ChipsInput.d.ts +2 -2
  183. package/dist/components/ChipsInput/ChipsInput.d.ts.map +1 -1
  184. package/dist/components/ChipsInput/ChipsInput.js +5 -3
  185. package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
  186. package/dist/components/ChipsInput/useChipsInput.d.ts +2 -2
  187. package/dist/components/ChipsInput/useChipsInput.d.ts.map +1 -1
  188. package/dist/components/ChipsInput/useChipsInput.js +40 -12
  189. package/dist/components/ChipsInput/useChipsInput.js.map +1 -1
  190. package/dist/components/ChipsInputBase/ChipsInputBase.d.ts.map +1 -1
  191. package/dist/components/ChipsInputBase/ChipsInputBase.js +1 -0
  192. package/dist/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
  193. package/dist/components/ChipsInputBase/helpers.d.ts +1 -1
  194. package/dist/components/ChipsInputBase/helpers.d.ts.map +1 -1
  195. package/dist/components/ChipsInputBase/helpers.js +4 -0
  196. package/dist/components/ChipsInputBase/helpers.js.map +1 -1
  197. package/dist/components/ChipsInputBase/types.d.ts +87 -5
  198. package/dist/components/ChipsInputBase/types.d.ts.map +1 -1
  199. package/dist/components/ChipsInputBase/types.js.map +1 -1
  200. package/dist/components/ChipsSelect/ChipsSelect.d.ts +16 -10
  201. package/dist/components/ChipsSelect/ChipsSelect.d.ts.map +1 -1
  202. package/dist/components/ChipsSelect/ChipsSelect.js +11 -4
  203. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  204. package/dist/components/ChipsSelect/types.d.ts.map +1 -1
  205. package/dist/components/ChipsSelect/types.js +1 -1
  206. package/dist/components/ChipsSelect/types.js.map +1 -1
  207. package/dist/components/ChipsSelect/useChipsSelect.d.ts +14 -5
  208. package/dist/components/ChipsSelect/useChipsSelect.d.ts.map +1 -1
  209. package/dist/components/ChipsSelect/useChipsSelect.js +5 -3
  210. package/dist/components/ChipsSelect/useChipsSelect.js.map +1 -1
  211. package/dist/components/Clickable/Clickable.d.ts +2 -2
  212. package/dist/components/Clickable/Clickable.d.ts.map +1 -1
  213. package/dist/components/Clickable/Clickable.js +3 -3
  214. package/dist/components/Clickable/Clickable.js.map +1 -1
  215. package/dist/components/Clickable/RealClickable.d.ts +1 -1
  216. package/dist/components/Clickable/RealClickable.js +1 -1
  217. package/dist/components/Clickable/RealClickable.js.map +1 -1
  218. package/dist/components/Clickable/useState.d.ts +9 -9
  219. package/dist/components/Clickable/useState.d.ts.map +1 -1
  220. package/dist/components/Clickable/useState.js +5 -5
  221. package/dist/components/Clickable/useState.js.map +1 -1
  222. package/dist/components/Clickable/useStateWithDelay.d.ts +1 -1
  223. package/dist/components/Clickable/useStateWithDelay.js +1 -1
  224. package/dist/components/Clickable/useStateWithDelay.js.map +1 -1
  225. package/dist/components/ColorSchemeProvider/ColorSchemeProvider.d.ts +6 -0
  226. package/dist/components/ColorSchemeProvider/ColorSchemeProvider.d.ts.map +1 -1
  227. package/dist/components/ColorSchemeProvider/ColorSchemeProvider.js +0 -2
  228. package/dist/components/ColorSchemeProvider/ColorSchemeProvider.js.map +1 -1
  229. package/dist/components/ConfigProvider/ConfigProvider.d.ts +3 -0
  230. package/dist/components/ConfigProvider/ConfigProvider.d.ts.map +1 -1
  231. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  232. package/dist/components/ConfigProvider/ConfigProviderContext.d.ts +7 -7
  233. package/dist/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  234. package/dist/components/ConfigProvider/ConfigProviderOverride.d.ts +4 -1
  235. package/dist/components/ConfigProvider/ConfigProviderOverride.d.ts.map +1 -1
  236. package/dist/components/ConfigProvider/ConfigProviderOverride.js +1 -1
  237. package/dist/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  238. package/dist/components/ContentBadge/ContentBadge.d.ts +2 -2
  239. package/dist/components/ContentBadge/ContentBadge.d.ts.map +1 -1
  240. package/dist/components/ContentBadge/ContentBadge.js +4 -2
  241. package/dist/components/ContentBadge/ContentBadge.js.map +1 -1
  242. package/dist/components/ContentBadge/ContentBadgeContext.d.ts.map +1 -1
  243. package/dist/components/ContentBadge/ContentBadgeContext.js +1 -1
  244. package/dist/components/ContentBadge/ContentBadgeContext.js.map +1 -1
  245. package/dist/components/ContentBadge/ContentBadgeSlotIcon.d.ts +1 -2
  246. package/dist/components/ContentBadge/ContentBadgeSlotIcon.d.ts.map +1 -1
  247. package/dist/components/ContentBadge/ContentBadgeSlotIcon.js +0 -1
  248. package/dist/components/ContentBadge/ContentBadgeSlotIcon.js.map +1 -1
  249. package/dist/components/ContentCard/ContentCard.d.ts +10 -7
  250. package/dist/components/ContentCard/ContentCard.d.ts.map +1 -1
  251. package/dist/components/ContentCard/ContentCard.js +4 -3
  252. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  253. package/dist/components/Counter/Counter.d.ts +6 -3
  254. package/dist/components/Counter/Counter.d.ts.map +1 -1
  255. package/dist/components/Counter/Counter.js.map +1 -1
  256. package/dist/components/CustomScrollView/CustomScrollView.d.ts +14 -5
  257. package/dist/components/CustomScrollView/CustomScrollView.d.ts.map +1 -1
  258. package/dist/components/CustomScrollView/CustomScrollView.js.map +1 -1
  259. package/dist/components/CustomSelect/CustomSelect.d.ts +45 -12
  260. package/dist/components/CustomSelect/CustomSelect.d.ts.map +1 -1
  261. package/dist/components/CustomSelect/CustomSelect.js +12 -4
  262. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  263. package/dist/components/CustomSelect/CustomSelectClearButton.d.ts +9 -0
  264. package/dist/components/CustomSelect/CustomSelectClearButton.d.ts.map +1 -1
  265. package/dist/components/CustomSelect/CustomSelectClearButton.js.map +1 -1
  266. package/dist/components/CustomSelect/CustomSelectInput/CustomSelectInput.d.ts.map +1 -1
  267. package/dist/components/CustomSelect/CustomSelectInput/CustomSelectInput.js +1 -1
  268. package/dist/components/CustomSelect/CustomSelectInput/CustomSelectInput.js.map +1 -1
  269. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +2 -2
  270. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts.map +1 -1
  271. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js +2 -1
  272. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  273. package/dist/components/DateInput/DateInput.d.ts +62 -10
  274. package/dist/components/DateInput/DateInput.d.ts.map +1 -1
  275. package/dist/components/DateInput/DateInput.js +154 -63
  276. package/dist/components/DateInput/DateInput.js.map +1 -1
  277. package/dist/components/DateInput/hooks.d.ts +7 -6
  278. package/dist/components/DateInput/hooks.d.ts.map +1 -1
  279. package/dist/components/DateInput/hooks.js +15 -8
  280. package/dist/components/DateInput/hooks.js.map +1 -1
  281. package/dist/components/DateRangeInput/DateRangeInput.d.ts +51 -7
  282. package/dist/components/DateRangeInput/DateRangeInput.d.ts.map +1 -1
  283. package/dist/components/DateRangeInput/DateRangeInput.js +13 -3
  284. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  285. package/dist/components/DirectionProvider/DirectionProvider.d.ts +7 -1
  286. package/dist/components/DirectionProvider/DirectionProvider.d.ts.map +1 -1
  287. package/dist/components/DirectionProvider/DirectionProvider.js +1 -1
  288. package/dist/components/DirectionProvider/DirectionProvider.js.map +1 -1
  289. package/dist/components/DropZone/DropZone.d.ts +6 -0
  290. package/dist/components/DropZone/DropZone.d.ts.map +1 -1
  291. package/dist/components/DropZone/DropZone.js +4 -2
  292. package/dist/components/DropZone/DropZone.js.map +1 -1
  293. package/dist/components/DropZone/components/DropZoneGrid.d.ts +4 -1
  294. package/dist/components/DropZone/components/DropZoneGrid.d.ts.map +1 -1
  295. package/dist/components/DropZone/components/DropZoneGrid.js +0 -1
  296. package/dist/components/DropZone/components/DropZoneGrid.js.map +1 -1
  297. package/dist/components/DropdownIcon/DropdownIcon.d.ts.map +1 -1
  298. package/dist/components/DropdownIcon/DropdownIcon.js +1 -1
  299. package/dist/components/DropdownIcon/DropdownIcon.js.map +1 -1
  300. package/dist/components/Epic/Epic.d.ts +10 -0
  301. package/dist/components/Epic/Epic.d.ts.map +1 -1
  302. package/dist/components/Epic/Epic.js.map +1 -1
  303. package/dist/components/Epic/ScrollSaver.d.ts.map +1 -1
  304. package/dist/components/Epic/ScrollSaver.js +1 -1
  305. package/dist/components/Epic/ScrollSaver.js.map +1 -1
  306. package/dist/components/FixedLayout/FixedLayout.d.ts +3 -6
  307. package/dist/components/FixedLayout/FixedLayout.d.ts.map +1 -1
  308. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  309. package/dist/components/Flex/FlexItem/FlexItem.d.ts +3 -3
  310. package/dist/components/Flex/FlexItem/FlexItem.js.map +1 -1
  311. package/dist/components/FloatingArrow/DefaultIcon.d.ts +1 -1
  312. package/dist/components/FloatingArrow/DefaultIcon.js +1 -1
  313. package/dist/components/FloatingArrow/DefaultIcon.js.map +1 -1
  314. package/dist/components/FloatingArrow/FloatingArrow.d.ts +17 -0
  315. package/dist/components/FloatingArrow/FloatingArrow.d.ts.map +1 -1
  316. package/dist/components/FloatingArrow/FloatingArrow.js.map +1 -1
  317. package/dist/components/FocusTrap/FocusTrap.d.ts +1 -1
  318. package/dist/components/FocusTrap/FocusTrap.d.ts.map +1 -1
  319. package/dist/components/FocusTrap/FocusTrap.js +5 -3
  320. package/dist/components/FocusTrap/FocusTrap.js.map +1 -1
  321. package/dist/components/FormField/FormField.d.ts +11 -5
  322. package/dist/components/FormField/FormField.d.ts.map +1 -1
  323. package/dist/components/FormField/FormField.js.map +1 -1
  324. package/dist/components/FormFieldClearButton/FormFieldClearButton.d.ts +9 -0
  325. package/dist/components/FormFieldClearButton/FormFieldClearButton.d.ts.map +1 -1
  326. package/dist/components/FormFieldClearButton/FormFieldClearButton.js.map +1 -1
  327. package/dist/components/FormItem/FormItem.d.ts +17 -3
  328. package/dist/components/FormItem/FormItem.d.ts.map +1 -1
  329. package/dist/components/FormItem/FormItem.js +6 -4
  330. package/dist/components/FormItem/FormItem.js.map +1 -1
  331. package/dist/components/FormItem/FormItemTop/FormItemTop.d.ts +1 -1
  332. package/dist/components/FormItem/FormItemTop/FormItemTop.d.ts.map +1 -1
  333. package/dist/components/FormItem/FormItemTop/FormItemTop.js +0 -1
  334. package/dist/components/FormItem/FormItemTop/FormItemTop.js.map +1 -1
  335. package/dist/components/FormItem/FormItemTop/FormItemTopAside.d.ts +1 -1
  336. package/dist/components/FormItem/FormItemTop/FormItemTopAside.d.ts.map +1 -1
  337. package/dist/components/FormItem/FormItemTop/FormItemTopAside.js +0 -1
  338. package/dist/components/FormItem/FormItemTop/FormItemTopAside.js.map +1 -1
  339. package/dist/components/FormItem/FormItemTop/FormItemTopLabel.d.ts +1 -1
  340. package/dist/components/FormItem/FormItemTop/FormItemTopLabel.d.ts.map +1 -1
  341. package/dist/components/FormItem/FormItemTop/FormItemTopLabel.js +0 -1
  342. package/dist/components/FormItem/FormItemTop/FormItemTopLabel.js.map +1 -1
  343. package/dist/components/FormItem/context.d.ts.map +1 -1
  344. package/dist/components/FormItem/context.js +1 -1
  345. package/dist/components/FormItem/context.js.map +1 -1
  346. package/dist/components/FormLayoutGroup/FormLayoutGroup.d.ts +3 -0
  347. package/dist/components/FormLayoutGroup/FormLayoutGroup.d.ts.map +1 -1
  348. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  349. package/dist/components/FormStatus/FormStatus.d.ts +6 -0
  350. package/dist/components/FormStatus/FormStatus.d.ts.map +1 -1
  351. package/dist/components/FormStatus/FormStatus.js.map +1 -1
  352. package/dist/components/Gallery/Gallery.d.ts +6 -0
  353. package/dist/components/Gallery/Gallery.d.ts.map +1 -1
  354. package/dist/components/Gallery/Gallery.js.map +1 -1
  355. package/dist/components/Gallery/hooks.d.ts.map +1 -1
  356. package/dist/components/Gallery/hooks.js +1 -1
  357. package/dist/components/Gallery/hooks.js.map +1 -1
  358. package/dist/components/Gradient/Gradient.d.ts +2 -2
  359. package/dist/components/Gradient/Gradient.js.map +1 -1
  360. package/dist/components/Group/Group.d.ts +6 -0
  361. package/dist/components/Group/Group.d.ts.map +1 -1
  362. package/dist/components/Group/Group.js +7 -5
  363. package/dist/components/Group/Group.js.map +1 -1
  364. package/dist/components/Group/GroupContainer.d.ts +1 -2
  365. package/dist/components/Group/GroupContainer.d.ts.map +1 -1
  366. package/dist/components/Group/GroupContainer.js +0 -1
  367. package/dist/components/Group/GroupContainer.js.map +1 -1
  368. package/dist/components/Group/GroupDescription.d.ts +1 -2
  369. package/dist/components/Group/GroupDescription.d.ts.map +1 -1
  370. package/dist/components/Group/GroupDescription.js +0 -2
  371. package/dist/components/Group/GroupDescription.js.map +1 -1
  372. package/dist/components/Group/GroupExpandedContent.d.ts +4 -2
  373. package/dist/components/Group/GroupExpandedContent.d.ts.map +1 -1
  374. package/dist/components/Group/GroupExpandedContent.js +1 -3
  375. package/dist/components/Group/GroupExpandedContent.js.map +1 -1
  376. package/dist/components/Group/GroupHeader.d.ts +1 -2
  377. package/dist/components/Group/GroupHeader.d.ts.map +1 -1
  378. package/dist/components/Group/GroupHeader.js +0 -2
  379. package/dist/components/Group/GroupHeader.js.map +1 -1
  380. package/dist/components/Header/Header.d.ts +19 -7
  381. package/dist/components/Header/Header.d.ts.map +1 -1
  382. package/dist/components/Header/Header.js.map +1 -1
  383. package/dist/components/HorizontalCell/HorizontalCell.d.ts +5 -5
  384. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  385. package/dist/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.d.ts +2 -2
  386. package/dist/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.js +1 -2
  387. package/dist/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.js.map +1 -1
  388. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +16 -7
  389. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts.map +1 -1
  390. package/dist/components/HorizontalScroll/HorizontalScroll.js +7 -7
  391. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  392. package/dist/components/IconButton/IconButton.d.ts +1 -1
  393. package/dist/components/IconButton/IconButton.js.map +1 -1
  394. package/dist/components/Image/Image.d.ts +4 -4
  395. package/dist/components/Image/Image.d.ts.map +1 -1
  396. package/dist/components/Image/Image.js +6 -4
  397. package/dist/components/Image/Image.js.map +1 -1
  398. package/dist/components/Image/ImageBadge/ImageBadge.d.ts +1 -2
  399. package/dist/components/Image/ImageBadge/ImageBadge.d.ts.map +1 -1
  400. package/dist/components/Image/ImageBadge/ImageBadge.js +0 -1
  401. package/dist/components/Image/ImageBadge/ImageBadge.js.map +1 -1
  402. package/dist/components/ImageBase/ImageBase.d.ts +7 -7
  403. package/dist/components/ImageBase/ImageBase.d.ts.map +1 -1
  404. package/dist/components/ImageBase/ImageBase.js +6 -4
  405. package/dist/components/ImageBase/ImageBase.js.map +1 -1
  406. package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.d.ts +2 -2
  407. package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.d.ts.map +1 -1
  408. package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js +1 -2
  409. package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
  410. package/dist/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.d.ts +5 -8
  411. package/dist/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.d.ts.map +1 -1
  412. package/dist/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js +0 -1
  413. package/dist/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js.map +1 -1
  414. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.d.ts +1 -2
  415. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.d.ts.map +1 -1
  416. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js +0 -1
  417. package/dist/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  418. package/dist/components/ImageBase/ImageBaseOverlay/types.d.ts +6 -0
  419. package/dist/components/ImageBase/ImageBaseOverlay/types.d.ts.map +1 -1
  420. package/dist/components/ImageBase/ImageBaseOverlay/types.js.map +1 -1
  421. package/dist/components/ImageBase/helpers.d.ts +3 -3
  422. package/dist/components/ImageBase/helpers.js +3 -3
  423. package/dist/components/ImageBase/helpers.js.map +1 -1
  424. package/dist/components/ImageBase/types.d.ts +18 -0
  425. package/dist/components/ImageBase/types.d.ts.map +1 -1
  426. package/dist/components/ImageBase/types.js.map +1 -1
  427. package/dist/components/ImageBase/validators.d.ts.map +1 -1
  428. package/dist/components/ImageBase/validators.js +4 -5
  429. package/dist/components/ImageBase/validators.js.map +1 -1
  430. package/dist/components/InfoRow/InfoRow.d.ts +3 -0
  431. package/dist/components/InfoRow/InfoRow.d.ts.map +1 -1
  432. package/dist/components/InfoRow/InfoRow.js.map +1 -1
  433. package/dist/components/InputLike/InputLike.d.ts +1 -2
  434. package/dist/components/InputLike/InputLike.d.ts.map +1 -1
  435. package/dist/components/InputLike/InputLike.js +4 -5
  436. package/dist/components/InputLike/InputLike.js.map +1 -1
  437. package/dist/components/Link/Link.d.ts.map +1 -1
  438. package/dist/components/Link/Link.js +4 -6
  439. package/dist/components/Link/Link.js.map +1 -1
  440. package/dist/components/List/List.d.ts +1 -1
  441. package/dist/components/List/List.js.map +1 -1
  442. package/dist/components/LocaleProvider/LocaleProvider.d.ts +5 -2
  443. package/dist/components/LocaleProvider/LocaleProvider.d.ts.map +1 -1
  444. package/dist/components/LocaleProvider/LocaleProvider.js +1 -1
  445. package/dist/components/LocaleProvider/LocaleProvider.js.map +1 -1
  446. package/dist/components/MiniInfoCell/MiniInfoCell.d.ts +3 -3
  447. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  448. package/dist/components/ModalCard/ModalCard.d.ts.map +1 -1
  449. package/dist/components/ModalCard/ModalCard.js +4 -12
  450. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  451. package/dist/components/ModalCard/ModalCardInternal.d.ts.map +1 -1
  452. package/dist/components/ModalCard/ModalCardInternal.js +1 -1
  453. package/dist/components/ModalCard/ModalCardInternal.js.map +1 -1
  454. package/dist/components/ModalCard/types.d.ts +1 -1
  455. package/dist/components/ModalCard/types.js.map +1 -1
  456. package/dist/components/ModalCardBase/ModalCardBase.d.ts +26 -14
  457. package/dist/components/ModalCardBase/ModalCardBase.d.ts.map +1 -1
  458. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  459. package/dist/components/ModalDismissButton/ModalDismissButton.d.ts +3 -0
  460. package/dist/components/ModalDismissButton/ModalDismissButton.d.ts.map +1 -1
  461. package/dist/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  462. package/dist/components/ModalOutlet/ModalOutlet.d.ts.map +1 -1
  463. package/dist/components/ModalOutlet/ModalOutlet.js +1 -1
  464. package/dist/components/ModalOutlet/ModalOutlet.js.map +1 -1
  465. package/dist/components/ModalOutsideButton/ModalOutsideButton.d.ts +2 -2
  466. package/dist/components/ModalOutsideButton/ModalOutsideButton.js.map +1 -1
  467. package/dist/components/ModalOverlay/ModalOverlay.d.ts.map +1 -1
  468. package/dist/components/ModalOverlay/ModalOverlay.js.map +1 -1
  469. package/dist/components/ModalPage/ModalPage.d.ts.map +1 -1
  470. package/dist/components/ModalPage/ModalPage.js +5 -12
  471. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  472. package/dist/components/ModalPage/ModalPageBase.d.ts +1 -1
  473. package/dist/components/ModalPage/ModalPageBase.d.ts.map +1 -1
  474. package/dist/components/ModalPage/ModalPageBase.js +1 -1
  475. package/dist/components/ModalPage/ModalPageBase.js.map +1 -1
  476. package/dist/components/ModalPage/ModalPageInternal.d.ts.map +1 -1
  477. package/dist/components/ModalPage/ModalPageInternal.js +1 -1
  478. package/dist/components/ModalPage/ModalPageInternal.js.map +1 -1
  479. package/dist/components/ModalPage/types.d.ts +11 -8
  480. package/dist/components/ModalPage/types.d.ts.map +1 -1
  481. package/dist/components/ModalPage/types.js.map +1 -1
  482. package/dist/components/ModalPageFooter/ModalPageFooter.d.ts +6 -0
  483. package/dist/components/ModalPageFooter/ModalPageFooter.d.ts.map +1 -1
  484. package/dist/components/ModalPageFooter/ModalPageFooter.js.map +1 -1
  485. package/dist/components/ModalPageHeader/ModalPageHeader.d.ts +3 -0
  486. package/dist/components/ModalPageHeader/ModalPageHeader.d.ts.map +1 -1
  487. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  488. package/dist/components/ModalRoot/types.d.ts +20 -16
  489. package/dist/components/ModalRoot/types.d.ts.map +1 -1
  490. package/dist/components/ModalRoot/types.js +1 -1
  491. package/dist/components/ModalRoot/types.js.map +1 -1
  492. package/dist/components/ModalRoot/useModalManager.d.ts +4 -2
  493. package/dist/components/ModalRoot/useModalManager.d.ts.map +1 -1
  494. package/dist/components/ModalRoot/useModalManager.js +12 -3
  495. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  496. package/dist/components/ModalRoot/useModalRootContext.js +1 -0
  497. package/dist/components/ModalRoot/useModalRootContext.js.map +1 -1
  498. package/dist/components/ModalRoot/withModalRootContext.d.ts +2 -2
  499. package/dist/components/ModalRoot/withModalRootContext.d.ts.map +1 -1
  500. package/dist/components/ModalRoot/withModalRootContext.js +2 -2
  501. package/dist/components/ModalRoot/withModalRootContext.js.map +1 -1
  502. package/dist/components/NativeSelect/NativeSelect.d.ts +15 -6
  503. package/dist/components/NativeSelect/NativeSelect.d.ts.map +1 -1
  504. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  505. package/dist/components/NavTransitionContext/NavTransitionContext.d.ts.map +1 -1
  506. package/dist/components/NavTransitionContext/NavTransitionContext.js +1 -1
  507. package/dist/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  508. package/dist/components/OnboardingTooltip/OnboardingTooltip.d.ts +2 -2
  509. package/dist/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  510. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts +3 -0
  511. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts.map +1 -1
  512. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.js +4 -1
  513. package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.js.map +1 -1
  514. package/dist/components/OnboardingTooltip/OnboardingTooltipContext.d.ts.map +1 -1
  515. package/dist/components/OnboardingTooltip/OnboardingTooltipContext.js +1 -1
  516. package/dist/components/OnboardingTooltip/OnboardingTooltipContext.js.map +1 -1
  517. package/dist/components/Pagination/Pagination.d.ts +10 -4
  518. package/dist/components/Pagination/Pagination.d.ts.map +1 -1
  519. package/dist/components/Pagination/Pagination.js.map +1 -1
  520. package/dist/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.d.ts.map +1 -1
  521. package/dist/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.js +1 -1
  522. package/dist/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.js.map +1 -1
  523. package/dist/components/Pagination/PaginationPage/PaginationPageButton.d.ts.map +1 -1
  524. package/dist/components/Pagination/PaginationPage/PaginationPageButton.js +1 -1
  525. package/dist/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -1
  526. package/dist/components/Pagination/PaginationPage/PaginationPageEllipsis.d.ts.map +1 -1
  527. package/dist/components/Pagination/PaginationPage/PaginationPageEllipsis.js +1 -1
  528. package/dist/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -1
  529. package/dist/components/Pagination/PaginationPage/usePaginationPageClasses.d.ts.map +1 -1
  530. package/dist/components/Pagination/PaginationPage/usePaginationPageClasses.js +1 -1
  531. package/dist/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -1
  532. package/dist/components/Panel/Panel.d.ts +4 -1
  533. package/dist/components/Panel/Panel.d.ts.map +1 -1
  534. package/dist/components/Panel/Panel.js.map +1 -1
  535. package/dist/components/PanelHeader/PanelHeader.d.ts +13 -2
  536. package/dist/components/PanelHeader/PanelHeader.d.ts.map +1 -1
  537. package/dist/components/PanelHeader/PanelHeader.js +1 -1
  538. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  539. package/dist/components/PanelHeaderBack/PanelHeaderBack.d.ts +6 -0
  540. package/dist/components/PanelHeaderBack/PanelHeaderBack.d.ts.map +1 -1
  541. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  542. package/dist/components/PanelHeaderButton/PanelHeaderButton.d.ts +7 -0
  543. package/dist/components/PanelHeaderButton/PanelHeaderButton.d.ts.map +1 -1
  544. package/dist/components/PanelHeaderButton/PanelHeaderButton.js +3 -3
  545. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  546. package/dist/components/PanelHeaderContent/PanelHeaderContent.d.ts +9 -0
  547. package/dist/components/PanelHeaderContent/PanelHeaderContent.d.ts.map +1 -1
  548. package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  549. package/dist/components/PanelHeaderContext/PanelHeaderContext.d.ts +7 -0
  550. package/dist/components/PanelHeaderContext/PanelHeaderContext.d.ts.map +1 -1
  551. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  552. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +3 -3
  553. package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  554. package/dist/components/PanelSpinner/PanelSpinner.d.ts +4 -1
  555. package/dist/components/PanelSpinner/PanelSpinner.d.ts.map +1 -1
  556. package/dist/components/PanelSpinner/PanelSpinner.js +6 -2
  557. package/dist/components/PanelSpinner/PanelSpinner.js.map +1 -1
  558. package/dist/components/Placeholder/Placeholder.d.ts +5 -5
  559. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  560. package/dist/components/PlatformProvider/PlatformProvider.d.ts +5 -2
  561. package/dist/components/PlatformProvider/PlatformProvider.d.ts.map +1 -1
  562. package/dist/components/PlatformProvider/PlatformProvider.js +1 -1
  563. package/dist/components/PlatformProvider/PlatformProvider.js.map +1 -1
  564. package/dist/components/PopoutWrapper/PopoutWrapper.d.ts +4 -4
  565. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  566. package/dist/components/Popover/Popover.d.ts +7 -4
  567. package/dist/components/Popover/Popover.d.ts.map +1 -1
  568. package/dist/components/Popover/Popover.js.map +1 -1
  569. package/dist/components/Popover/usePopover.d.ts +9 -0
  570. package/dist/components/Popover/usePopover.d.ts.map +1 -1
  571. package/dist/components/Popover/usePopover.js.map +1 -1
  572. package/dist/components/Popper/Popper.d.ts +4 -1
  573. package/dist/components/Popper/Popper.d.ts.map +1 -1
  574. package/dist/components/Popper/Popper.js.map +1 -1
  575. package/dist/components/Progress/Progress.d.ts +6 -3
  576. package/dist/components/Progress/Progress.d.ts.map +1 -1
  577. package/dist/components/Progress/Progress.js.map +1 -1
  578. package/dist/components/PullToRefresh/PullToRefresh.d.ts +2 -2
  579. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  580. package/dist/components/PullToRefresh/PullToRefreshSpinner.d.ts.map +1 -1
  581. package/dist/components/PullToRefresh/PullToRefreshSpinner.js +1 -1
  582. package/dist/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  583. package/dist/components/Radio/Radio.d.ts +7 -1
  584. package/dist/components/Radio/Radio.d.ts.map +1 -1
  585. package/dist/components/Radio/Radio.js.map +1 -1
  586. package/dist/components/RadioGroup/RadioGroup.d.ts +3 -0
  587. package/dist/components/RadioGroup/RadioGroup.d.ts.map +1 -1
  588. package/dist/components/RadioGroup/RadioGroup.js.map +1 -1
  589. package/dist/components/Removable/Removable.d.ts +10 -7
  590. package/dist/components/Removable/Removable.d.ts.map +1 -1
  591. package/dist/components/Removable/Removable.js +1 -1
  592. package/dist/components/Removable/Removable.js.map +1 -1
  593. package/dist/components/RichCell/RichCell.d.ts +6 -6
  594. package/dist/components/RichCell/RichCell.js.map +1 -1
  595. package/dist/components/Root/Root.d.ts +9 -0
  596. package/dist/components/Root/Root.d.ts.map +1 -1
  597. package/dist/components/Root/Root.js +1 -1
  598. package/dist/components/Root/Root.js.map +1 -1
  599. package/dist/components/RootComponent/RootComponent.d.ts +10 -0
  600. package/dist/components/RootComponent/RootComponent.d.ts.map +1 -1
  601. package/dist/components/RootComponent/RootComponent.js.map +1 -1
  602. package/dist/components/ScreenSpinner/ScreenSpinner.d.ts.map +1 -1
  603. package/dist/components/ScreenSpinner/ScreenSpinner.js +6 -4
  604. package/dist/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  605. package/dist/components/ScreenSpinner/ScreenSpinnerContainer.d.ts +1 -2
  606. package/dist/components/ScreenSpinner/ScreenSpinnerContainer.d.ts.map +1 -1
  607. package/dist/components/ScreenSpinner/ScreenSpinnerContainer.js +0 -2
  608. package/dist/components/ScreenSpinner/ScreenSpinnerContainer.js.map +1 -1
  609. package/dist/components/ScreenSpinner/ScreenSpinnerLoader.d.ts +3 -2
  610. package/dist/components/ScreenSpinner/ScreenSpinnerLoader.d.ts.map +1 -1
  611. package/dist/components/ScreenSpinner/ScreenSpinnerLoader.js +0 -1
  612. package/dist/components/ScreenSpinner/ScreenSpinnerLoader.js.map +1 -1
  613. package/dist/components/ScreenSpinner/ScreenSpinnerSwapIcon.d.ts +1 -2
  614. package/dist/components/ScreenSpinner/ScreenSpinnerSwapIcon.d.ts.map +1 -1
  615. package/dist/components/ScreenSpinner/ScreenSpinnerSwapIcon.js +1 -3
  616. package/dist/components/ScreenSpinner/ScreenSpinnerSwapIcon.js.map +1 -1
  617. package/dist/components/ScreenSpinner/context.d.ts +9 -0
  618. package/dist/components/ScreenSpinner/context.d.ts.map +1 -1
  619. package/dist/components/ScreenSpinner/context.js.map +1 -1
  620. package/dist/components/ScreenSpinner/types.d.ts +12 -4
  621. package/dist/components/ScreenSpinner/types.d.ts.map +1 -1
  622. package/dist/components/ScreenSpinner/types.js.map +1 -1
  623. package/dist/components/ScrollArrow/ScrollArrow.d.ts +5 -2
  624. package/dist/components/ScrollArrow/ScrollArrow.d.ts.map +1 -1
  625. package/dist/components/ScrollArrow/ScrollArrow.js.map +1 -1
  626. package/dist/components/Search/Search.d.ts +24 -6
  627. package/dist/components/Search/Search.d.ts.map +1 -1
  628. package/dist/components/Search/Search.js.map +1 -1
  629. package/dist/components/SegmentedControl/SegmentedControl.d.ts +25 -1
  630. package/dist/components/SegmentedControl/SegmentedControl.d.ts.map +1 -1
  631. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  632. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts.map +1 -1
  633. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +1 -1
  634. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  635. package/dist/components/SelectMimicry/SelectMimicry.d.ts +9 -0
  636. package/dist/components/SelectMimicry/SelectMimicry.d.ts.map +1 -1
  637. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  638. package/dist/components/SelectTypography/SelectTypography.d.ts.map +1 -1
  639. package/dist/components/SelectTypography/SelectTypography.js +1 -1
  640. package/dist/components/SelectTypography/SelectTypography.js.map +1 -1
  641. package/dist/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.d.ts.map +1 -1
  642. package/dist/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.js +1 -1
  643. package/dist/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.js.map +1 -1
  644. package/dist/components/Separator/Separator.d.ts +6 -6
  645. package/dist/components/Separator/Separator.js.map +1 -1
  646. package/dist/components/SimpleCell/Chevron/Chevron.d.ts.map +1 -1
  647. package/dist/components/SimpleCell/Chevron/Chevron.js +1 -1
  648. package/dist/components/SimpleCell/Chevron/Chevron.js.map +1 -1
  649. package/dist/components/SimpleCell/SimpleCell.d.ts +5 -5
  650. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  651. package/dist/components/SimpleGrid/SimpleGrid.d.ts +4 -4
  652. package/dist/components/SimpleGrid/SimpleGrid.js.map +1 -1
  653. package/dist/components/Skeleton/Skeleton.d.ts +4 -4
  654. package/dist/components/Skeleton/Skeleton.js +5 -5
  655. package/dist/components/Skeleton/Skeleton.js.map +1 -1
  656. package/dist/components/Slider/Slider.d.ts +41 -2
  657. package/dist/components/Slider/Slider.d.ts.map +1 -1
  658. package/dist/components/Slider/Slider.js.map +1 -1
  659. package/dist/components/Slider/SliderThumb/SliderThumb.d.ts.map +1 -1
  660. package/dist/components/Slider/SliderThumb/SliderThumb.js +1 -1
  661. package/dist/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
  662. package/dist/components/Slider/types.d.ts.map +1 -1
  663. package/dist/components/Slider/types.js +1 -1
  664. package/dist/components/Slider/types.js.map +1 -1
  665. package/dist/components/Snackbar/Snackbar.d.ts +4 -4
  666. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  667. package/dist/components/Snackbar/subcomponents/Basic/Basic.d.ts +6 -6
  668. package/dist/components/Snackbar/subcomponents/Basic/Basic.js.map +1 -1
  669. package/dist/components/Snackbar/types.d.ts.map +1 -1
  670. package/dist/components/Snackbar/types.js +1 -1
  671. package/dist/components/Snackbar/types.js.map +1 -1
  672. package/dist/components/Spacing/Spacing.d.ts +3 -3
  673. package/dist/components/Spacing/Spacing.js.map +1 -1
  674. package/dist/components/Spinner/Spinner.d.ts +8 -2
  675. package/dist/components/Spinner/Spinner.d.ts.map +1 -1
  676. package/dist/components/Spinner/Spinner.js +7 -3
  677. package/dist/components/Spinner/Spinner.js.map +1 -1
  678. package/dist/components/Spinner/SpinnerAnimation.d.ts.map +1 -1
  679. package/dist/components/Spinner/SpinnerAnimation.js +1 -1
  680. package/dist/components/Spinner/SpinnerAnimation.js.map +1 -1
  681. package/dist/components/Spinner/icons.d.ts +6 -0
  682. package/dist/components/Spinner/icons.d.ts.map +1 -0
  683. package/dist/components/Spinner/icons.js +52 -0
  684. package/dist/components/Spinner/icons.js.map +1 -0
  685. package/dist/components/SplitCol/SplitCol.d.ts +15 -3
  686. package/dist/components/SplitCol/SplitCol.d.ts.map +1 -1
  687. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  688. package/dist/components/SplitCol/SplitColContext.d.ts.map +1 -1
  689. package/dist/components/SplitCol/SplitColContext.js +1 -1
  690. package/dist/components/SplitCol/SplitColContext.js.map +1 -1
  691. package/dist/components/SplitLayout/SplitLayout.d.ts +5 -2
  692. package/dist/components/SplitLayout/SplitLayout.d.ts.map +1 -1
  693. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  694. package/dist/components/SubnavigationBar/SubnavigationBar.d.ts +3 -0
  695. package/dist/components/SubnavigationBar/SubnavigationBar.d.ts.map +1 -1
  696. package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  697. package/dist/components/SubnavigationButton/SubnavigationButton.d.ts +18 -3
  698. package/dist/components/SubnavigationButton/SubnavigationButton.d.ts.map +1 -1
  699. package/dist/components/SubnavigationButton/SubnavigationButton.js +3 -2
  700. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  701. package/dist/components/Tabbar/Tabbar.d.ts +2 -2
  702. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  703. package/dist/components/TabbarItem/TabbarItem.d.ts +5 -2
  704. package/dist/components/TabbarItem/TabbarItem.d.ts.map +1 -1
  705. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  706. package/dist/components/Tabs/Tabs.d.ts +6 -6
  707. package/dist/components/Tabs/Tabs.d.ts.map +1 -1
  708. package/dist/components/Tabs/Tabs.js +1 -4
  709. package/dist/components/Tabs/Tabs.js.map +1 -1
  710. package/dist/components/TabsItem/TabsItem.d.ts +9 -3
  711. package/dist/components/TabsItem/TabsItem.d.ts.map +1 -1
  712. package/dist/components/TabsItem/TabsItem.js +4 -9
  713. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  714. package/dist/components/Tappable/Ripple.d.ts +1 -1
  715. package/dist/components/Tappable/Ripple.d.ts.map +1 -1
  716. package/dist/components/Tappable/Ripple.js +3 -3
  717. package/dist/components/Tappable/Ripple.js.map +1 -1
  718. package/dist/components/Tappable/Tappable.d.ts +13 -1
  719. package/dist/components/Tappable/Tappable.d.ts.map +1 -1
  720. package/dist/components/Tappable/Tappable.js.map +1 -1
  721. package/dist/components/Tappable/state.d.ts +5 -5
  722. package/dist/components/Tappable/state.js +3 -3
  723. package/dist/components/Tappable/state.js.map +1 -1
  724. package/dist/components/Textarea/Textarea.d.ts +9 -0
  725. package/dist/components/Textarea/Textarea.d.ts.map +1 -1
  726. package/dist/components/Textarea/Textarea.js.map +1 -1
  727. package/dist/components/ToolButton/ToolButton.d.ts +9 -0
  728. package/dist/components/ToolButton/ToolButton.d.ts.map +1 -1
  729. package/dist/components/ToolButton/ToolButton.js.map +1 -1
  730. package/dist/components/Tooltip/Tooltip.d.ts +1 -1
  731. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  732. package/dist/components/Tooltip/useTooltip.d.ts +9 -0
  733. package/dist/components/Tooltip/useTooltip.d.ts.map +1 -1
  734. package/dist/components/Tooltip/useTooltip.js.map +1 -1
  735. package/dist/components/TooltipBase/TooltipBase.d.ts +5 -5
  736. package/dist/components/TooltipBase/TooltipBase.js +1 -1
  737. package/dist/components/TooltipBase/TooltipBase.js.map +1 -1
  738. package/dist/components/Touch/Touch.d.ts +100 -2
  739. package/dist/components/Touch/Touch.d.ts.map +1 -1
  740. package/dist/components/Touch/Touch.js +4 -4
  741. package/dist/components/Touch/Touch.js.map +1 -1
  742. package/dist/components/Touch/TouchContext.d.ts +1 -1
  743. package/dist/components/Touch/TouchContext.js +1 -1
  744. package/dist/components/Touch/TouchContext.js.map +1 -1
  745. package/dist/components/Typography/Caption/Caption.d.ts +3 -0
  746. package/dist/components/Typography/Caption/Caption.d.ts.map +1 -1
  747. package/dist/components/Typography/Caption/Caption.js.map +1 -1
  748. package/dist/components/Typography/DisplayTitle/DisplayTitle.d.ts +3 -0
  749. package/dist/components/Typography/DisplayTitle/DisplayTitle.d.ts.map +1 -1
  750. package/dist/components/Typography/DisplayTitle/DisplayTitle.js.map +1 -1
  751. package/dist/components/Typography/EllipsisText/EllipsisText.d.ts +3 -3
  752. package/dist/components/Typography/EllipsisText/EllipsisText.js.map +1 -1
  753. package/dist/components/Typography/Headline/Headline.d.ts +3 -0
  754. package/dist/components/Typography/Headline/Headline.d.ts.map +1 -1
  755. package/dist/components/Typography/Headline/Headline.js.map +1 -1
  756. package/dist/components/Typography/Title/Title.d.ts +3 -0
  757. package/dist/components/Typography/Title/Title.d.ts.map +1 -1
  758. package/dist/components/Typography/Title/Title.js.map +1 -1
  759. package/dist/components/Typography/Typography.d.ts +6 -3
  760. package/dist/components/Typography/Typography.d.ts.map +1 -1
  761. package/dist/components/Typography/Typography.js.map +1 -1
  762. package/dist/components/UnstyledTextField/UnstyledTextField.d.ts +6 -0
  763. package/dist/components/UnstyledTextField/UnstyledTextField.d.ts.map +1 -1
  764. package/dist/components/UnstyledTextField/UnstyledTextField.js.map +1 -1
  765. package/dist/components/UsersStack/UsersStack.d.ts +16 -4
  766. package/dist/components/UsersStack/UsersStack.d.ts.map +1 -1
  767. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  768. package/dist/components/View/View.d.ts +15 -3
  769. package/dist/components/View/View.d.ts.map +1 -1
  770. package/dist/components/View/View.js.map +1 -1
  771. package/dist/components/View/ViewInfinite.d.ts +15 -3
  772. package/dist/components/View/ViewInfinite.d.ts.map +1 -1
  773. package/dist/components/View/ViewInfinite.js +1 -1
  774. package/dist/components/View/ViewInfinite.js.map +1 -1
  775. package/dist/components/View/useLayoutEffectCall.d.ts +1 -1
  776. package/dist/components/View/useLayoutEffectCall.js +1 -1
  777. package/dist/components/View/useLayoutEffectCall.js.map +1 -1
  778. package/dist/components/WriteBar/WriteBar.d.ts +7 -4
  779. package/dist/components/WriteBar/WriteBar.d.ts.map +1 -1
  780. package/dist/components/WriteBar/WriteBar.js.map +1 -1
  781. package/dist/components/WriteBarIcon/WriteBarIcon.d.ts +1 -1
  782. package/dist/components/WriteBarIcon/WriteBarIcon.js +3 -2
  783. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  784. package/dist/components.css +1 -1
  785. package/dist/components.css.map +1 -1
  786. package/dist/cssm/components/Accordion/Accordion.js +5 -3
  787. package/dist/cssm/components/Accordion/Accordion.js.map +1 -1
  788. package/dist/cssm/components/Accordion/AccordionContent.js +0 -1
  789. package/dist/cssm/components/Accordion/AccordionContent.js.map +1 -1
  790. package/dist/cssm/components/Accordion/AccordionContext.js.map +1 -1
  791. package/dist/cssm/components/Accordion/AccordionSummary.js +0 -1
  792. package/dist/cssm/components/Accordion/AccordionSummary.js.map +1 -1
  793. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  794. package/dist/cssm/components/ActionSheet/ActionSheetContext.js.map +1 -1
  795. package/dist/cssm/components/ActionSheet/ActionSheetDefaultIosCloseItem.js +3 -3
  796. package/dist/cssm/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -1
  797. package/dist/cssm/components/ActionSheet/types.js.map +1 -1
  798. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  799. package/dist/cssm/components/ActionSheetItem/helpers.js +2 -2
  800. package/dist/cssm/components/ActionSheetItem/helpers.js.map +1 -1
  801. package/dist/cssm/components/AdaptiveIconRenderer/AdaptiveIconRenderer.js.map +1 -1
  802. package/dist/cssm/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  803. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  804. package/dist/cssm/components/Alert/Alert.module.css +2 -2
  805. package/dist/cssm/components/Alert/AlertAction.js.map +1 -1
  806. package/dist/cssm/components/Alert/AlertActions.js.map +1 -1
  807. package/dist/cssm/components/Alert/AlertBase.js.map +1 -1
  808. package/dist/cssm/components/Alert/AlertTypography.js +1 -1
  809. package/dist/cssm/components/Alert/AlertTypography.js.map +1 -1
  810. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  811. package/dist/cssm/components/AppRoot/AppRootContext.js +2 -2
  812. package/dist/cssm/components/AppRoot/AppRootContext.js.map +1 -1
  813. package/dist/cssm/components/AppRoot/AppRootPortal.js.map +1 -1
  814. package/dist/cssm/components/AppRoot/ScrollContext.js +4 -4
  815. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  816. package/dist/cssm/components/AppRoot/types.js +1 -1
  817. package/dist/cssm/components/AppRoot/types.js.map +1 -1
  818. package/dist/cssm/components/AspectRatio/AspectRatio.js.map +1 -1
  819. package/dist/cssm/components/Avatar/Avatar.js +6 -4
  820. package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
  821. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadge.js +0 -1
  822. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadge.js.map +1 -1
  823. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js +0 -1
  824. package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
  825. package/dist/cssm/components/Avatar/AvatarBadge/icons.js +1 -1
  826. package/dist/cssm/components/Avatar/AvatarBadge/icons.js.map +1 -1
  827. package/dist/cssm/components/Badge/Badge.js.map +1 -1
  828. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  829. package/dist/cssm/components/Button/Button.js.map +1 -1
  830. package/dist/cssm/components/ButtonGroup/ButtonGroup.js +0 -1
  831. package/dist/cssm/components/ButtonGroup/ButtonGroup.js.map +1 -1
  832. package/dist/cssm/components/Calendar/Calendar.js +72 -14
  833. package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
  834. package/dist/cssm/components/CalendarDay/CalendarDay.js +29 -10
  835. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
  836. package/dist/cssm/components/CalendarDays/CalendarDays.js +73 -45
  837. package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
  838. package/dist/cssm/components/CalendarHeader/CalendarHeader.js +9 -2
  839. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
  840. package/dist/cssm/components/CalendarRange/CalendarRange.js +20 -7
  841. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
  842. package/dist/cssm/components/CalendarTime/CalendarTime.js +25 -15
  843. package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -1
  844. package/dist/cssm/components/Card/Card.js.map +1 -1
  845. package/dist/cssm/components/Card/Card.module.css +2 -2
  846. package/dist/cssm/components/CardGrid/CardGrid.js.map +1 -1
  847. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  848. package/dist/cssm/components/CarouselBase/Bullets.js +1 -2
  849. package/dist/cssm/components/CarouselBase/Bullets.js.map +1 -1
  850. package/dist/cssm/components/CarouselBase/CarouselBase.js +6 -6
  851. package/dist/cssm/components/CarouselBase/CarouselBase.js.map +1 -1
  852. package/dist/cssm/components/CarouselBase/CarouselViewPort.js +1 -1
  853. package/dist/cssm/components/CarouselBase/CarouselViewPort.js.map +1 -1
  854. package/dist/cssm/components/CarouselBase/ScrollArrows.js +1 -1
  855. package/dist/cssm/components/CarouselBase/ScrollArrows.js.map +1 -1
  856. package/dist/cssm/components/CarouselBase/helpers.js +3 -3
  857. package/dist/cssm/components/CarouselBase/helpers.js.map +1 -1
  858. package/dist/cssm/components/CarouselBase/types.js +1 -1
  859. package/dist/cssm/components/CarouselBase/types.js.map +1 -1
  860. package/dist/cssm/components/Cell/Cell.js +1 -1
  861. package/dist/cssm/components/Cell/Cell.js.map +1 -1
  862. package/dist/cssm/components/Cell/CellDragger/CellDragger.js +1 -1
  863. package/dist/cssm/components/Cell/CellDragger/CellDragger.js.map +1 -1
  864. package/dist/cssm/components/CellButton/CellButton.js.map +1 -1
  865. package/dist/cssm/components/CellButtonGroup/CellButtonGroup.js +4 -2
  866. package/dist/cssm/components/CellButtonGroup/CellButtonGroup.js.map +1 -1
  867. package/dist/cssm/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.js +0 -1
  868. package/dist/cssm/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.js.map +1 -1
  869. package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
  870. package/dist/cssm/components/Checkbox/CheckboxInput/CheckboxInput.js.map +1 -1
  871. package/dist/cssm/components/ChipsInput/ChipsInput.js +3 -2
  872. package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
  873. package/dist/cssm/components/ChipsInput/useChipsInput.js +40 -15
  874. package/dist/cssm/components/ChipsInput/useChipsInput.js.map +1 -1
  875. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.js +1 -0
  876. package/dist/cssm/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
  877. package/dist/cssm/components/ChipsInputBase/helpers.js +4 -0
  878. package/dist/cssm/components/ChipsInputBase/helpers.js.map +1 -1
  879. package/dist/cssm/components/ChipsInputBase/types.js.map +1 -1
  880. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +9 -3
  881. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  882. package/dist/cssm/components/ChipsSelect/types.js +1 -1
  883. package/dist/cssm/components/ChipsSelect/types.js.map +1 -1
  884. package/dist/cssm/components/ChipsSelect/useChipsSelect.js +5 -3
  885. package/dist/cssm/components/ChipsSelect/useChipsSelect.js.map +1 -1
  886. package/dist/cssm/components/Clickable/Clickable.js +6 -5
  887. package/dist/cssm/components/Clickable/Clickable.js.map +1 -1
  888. package/dist/cssm/components/Clickable/RealClickable.js +1 -1
  889. package/dist/cssm/components/Clickable/RealClickable.js.map +1 -1
  890. package/dist/cssm/components/Clickable/useState.js +5 -5
  891. package/dist/cssm/components/Clickable/useState.js.map +1 -1
  892. package/dist/cssm/components/Clickable/useStateWithDelay.js +1 -1
  893. package/dist/cssm/components/Clickable/useStateWithDelay.js.map +1 -1
  894. package/dist/cssm/components/ColorSchemeProvider/ColorSchemeProvider.js +0 -2
  895. package/dist/cssm/components/ColorSchemeProvider/ColorSchemeProvider.js.map +1 -1
  896. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  897. package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  898. package/dist/cssm/components/ConfigProvider/ConfigProviderOverride.js +1 -1
  899. package/dist/cssm/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  900. package/dist/cssm/components/ContentBadge/ContentBadge.js +4 -2
  901. package/dist/cssm/components/ContentBadge/ContentBadge.js.map +1 -1
  902. package/dist/cssm/components/ContentBadge/ContentBadgeContext.js +1 -1
  903. package/dist/cssm/components/ContentBadge/ContentBadgeContext.js.map +1 -1
  904. package/dist/cssm/components/ContentBadge/ContentBadgeSlotIcon.js +0 -1
  905. package/dist/cssm/components/ContentBadge/ContentBadgeSlotIcon.js.map +1 -1
  906. package/dist/cssm/components/ContentCard/ContentCard.js +2 -2
  907. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  908. package/dist/cssm/components/Counter/Counter.js.map +1 -1
  909. package/dist/cssm/components/CustomScrollView/CustomScrollView.js.map +1 -1
  910. package/dist/cssm/components/CustomSelect/CustomSelect.js +12 -3
  911. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  912. package/dist/cssm/components/CustomSelect/CustomSelectClearButton.js.map +1 -1
  913. package/dist/cssm/components/CustomSelect/CustomSelectInput/CustomSelectInput.js +1 -1
  914. package/dist/cssm/components/CustomSelect/CustomSelectInput/CustomSelectInput.js.map +1 -1
  915. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js +2 -1
  916. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  917. package/dist/cssm/components/DateInput/DateInput.js +141 -57
  918. package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
  919. package/dist/cssm/components/DateInput/hooks.js +15 -8
  920. package/dist/cssm/components/DateInput/hooks.js.map +1 -1
  921. package/dist/cssm/components/DateRangeInput/DateRangeInput.js +11 -3
  922. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  923. package/dist/cssm/components/DirectionProvider/DirectionProvider.js +1 -1
  924. package/dist/cssm/components/DirectionProvider/DirectionProvider.js.map +1 -1
  925. package/dist/cssm/components/DropZone/DropZone.js +4 -2
  926. package/dist/cssm/components/DropZone/DropZone.js.map +1 -1
  927. package/dist/cssm/components/DropZone/components/DropZoneGrid.js +0 -1
  928. package/dist/cssm/components/DropZone/components/DropZoneGrid.js.map +1 -1
  929. package/dist/cssm/components/DropdownIcon/DropdownIcon.js +1 -1
  930. package/dist/cssm/components/DropdownIcon/DropdownIcon.js.map +1 -1
  931. package/dist/cssm/components/Epic/Epic.js.map +1 -1
  932. package/dist/cssm/components/Epic/ScrollSaver.js +1 -1
  933. package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
  934. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  935. package/dist/cssm/components/Flex/FlexItem/FlexItem.js.map +1 -1
  936. package/dist/cssm/components/FloatingArrow/DefaultIcon.js +1 -1
  937. package/dist/cssm/components/FloatingArrow/DefaultIcon.js.map +1 -1
  938. package/dist/cssm/components/FloatingArrow/FloatingArrow.js.map +1 -1
  939. package/dist/cssm/components/FocusTrap/FocusTrap.js +3 -2
  940. package/dist/cssm/components/FocusTrap/FocusTrap.js.map +1 -1
  941. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  942. package/dist/cssm/components/FormFieldClearButton/FormFieldClearButton.js.map +1 -1
  943. package/dist/cssm/components/FormItem/FormItem.js +6 -4
  944. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  945. package/dist/cssm/components/FormItem/FormItem.module.css +1 -0
  946. package/dist/cssm/components/FormItem/FormItemTop/FormItemTop.js +0 -1
  947. package/dist/cssm/components/FormItem/FormItemTop/FormItemTop.js.map +1 -1
  948. package/dist/cssm/components/FormItem/FormItemTop/FormItemTopAside.js +0 -1
  949. package/dist/cssm/components/FormItem/FormItemTop/FormItemTopAside.js.map +1 -1
  950. package/dist/cssm/components/FormItem/FormItemTop/FormItemTopLabel.js +0 -1
  951. package/dist/cssm/components/FormItem/FormItemTop/FormItemTopLabel.js.map +1 -1
  952. package/dist/cssm/components/FormItem/context.js +1 -1
  953. package/dist/cssm/components/FormItem/context.js.map +1 -1
  954. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  955. package/dist/cssm/components/FormStatus/FormStatus.js.map +1 -1
  956. package/dist/cssm/components/Gallery/Gallery.js.map +1 -1
  957. package/dist/cssm/components/Gallery/hooks.js +1 -1
  958. package/dist/cssm/components/Gallery/hooks.js.map +1 -1
  959. package/dist/cssm/components/Gradient/Gradient.js.map +1 -1
  960. package/dist/cssm/components/Group/Group.js +7 -5
  961. package/dist/cssm/components/Group/Group.js.map +1 -1
  962. package/dist/cssm/components/Group/GroupContainer.js +0 -1
  963. package/dist/cssm/components/Group/GroupContainer.js.map +1 -1
  964. package/dist/cssm/components/Group/GroupDescription.js +0 -2
  965. package/dist/cssm/components/Group/GroupDescription.js.map +1 -1
  966. package/dist/cssm/components/Group/GroupExpandedContent.js +1 -3
  967. package/dist/cssm/components/Group/GroupExpandedContent.js.map +1 -1
  968. package/dist/cssm/components/Group/GroupHeader.js +0 -2
  969. package/dist/cssm/components/Group/GroupHeader.js.map +1 -1
  970. package/dist/cssm/components/Header/Header.js.map +1 -1
  971. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  972. package/dist/cssm/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.js +1 -2
  973. package/dist/cssm/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.js.map +1 -1
  974. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +7 -7
  975. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  976. package/dist/cssm/components/IconButton/IconButton.js.map +1 -1
  977. package/dist/cssm/components/Image/Image.js +6 -4
  978. package/dist/cssm/components/Image/Image.js.map +1 -1
  979. package/dist/cssm/components/Image/ImageBadge/ImageBadge.js +0 -1
  980. package/dist/cssm/components/Image/ImageBadge/ImageBadge.js.map +1 -1
  981. package/dist/cssm/components/ImageBase/ImageBase.js +6 -4
  982. package/dist/cssm/components/ImageBase/ImageBase.js.map +1 -1
  983. package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js +1 -2
  984. package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
  985. package/dist/cssm/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js +0 -1
  986. package/dist/cssm/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js.map +1 -1
  987. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js +0 -1
  988. package/dist/cssm/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.js.map +1 -1
  989. package/dist/cssm/components/ImageBase/ImageBaseOverlay/types.js.map +1 -1
  990. package/dist/cssm/components/ImageBase/helpers.js +3 -3
  991. package/dist/cssm/components/ImageBase/helpers.js.map +1 -1
  992. package/dist/cssm/components/ImageBase/types.js.map +1 -1
  993. package/dist/cssm/components/ImageBase/validators.js +3 -4
  994. package/dist/cssm/components/ImageBase/validators.js.map +1 -1
  995. package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
  996. package/dist/cssm/components/InputLike/InputLike.js +4 -5
  997. package/dist/cssm/components/InputLike/InputLike.js.map +1 -1
  998. package/dist/cssm/components/InputLike/InputLike.module.css +1 -1
  999. package/dist/cssm/components/Link/Link.js +3 -5
  1000. package/dist/cssm/components/Link/Link.js.map +1 -1
  1001. package/dist/cssm/components/Link/Link.module.css +2 -4
  1002. package/dist/cssm/components/List/List.js.map +1 -1
  1003. package/dist/cssm/components/LocaleProvider/LocaleProvider.js +1 -1
  1004. package/dist/cssm/components/LocaleProvider/LocaleProvider.js.map +1 -1
  1005. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  1006. package/dist/cssm/components/ModalCard/ModalCard.js +2 -11
  1007. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  1008. package/dist/cssm/components/ModalCard/ModalCardInternal.js +1 -1
  1009. package/dist/cssm/components/ModalCard/ModalCardInternal.js.map +1 -1
  1010. package/dist/cssm/components/ModalCard/types.js.map +1 -1
  1011. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  1012. package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
  1013. package/dist/cssm/components/ModalOutlet/ModalOutlet.js +1 -1
  1014. package/dist/cssm/components/ModalOutlet/ModalOutlet.js.map +1 -1
  1015. package/dist/cssm/components/ModalOutsideButton/ModalOutsideButton.js.map +1 -1
  1016. package/dist/cssm/components/ModalOverlay/ModalOverlay.js.map +1 -1
  1017. package/dist/cssm/components/ModalOverlay/ModalOverlay.module.css +1 -1
  1018. package/dist/cssm/components/ModalPage/ModalPage.js +3 -11
  1019. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  1020. package/dist/cssm/components/ModalPage/ModalPageBase.js +1 -1
  1021. package/dist/cssm/components/ModalPage/ModalPageBase.js.map +1 -1
  1022. package/dist/cssm/components/ModalPage/ModalPageInternal.js +1 -1
  1023. package/dist/cssm/components/ModalPage/ModalPageInternal.js.map +1 -1
  1024. package/dist/cssm/components/ModalPage/types.js.map +1 -1
  1025. package/dist/cssm/components/ModalPageFooter/ModalPageFooter.js.map +1 -1
  1026. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  1027. package/dist/cssm/components/ModalRoot/types.js +1 -1
  1028. package/dist/cssm/components/ModalRoot/types.js.map +1 -1
  1029. package/dist/cssm/components/ModalRoot/useModalManager.js +12 -3
  1030. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  1031. package/dist/cssm/components/ModalRoot/useModalRootContext.js +1 -0
  1032. package/dist/cssm/components/ModalRoot/useModalRootContext.js.map +1 -1
  1033. package/dist/cssm/components/ModalRoot/withModalRootContext.js +2 -2
  1034. package/dist/cssm/components/ModalRoot/withModalRootContext.js.map +1 -1
  1035. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  1036. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js +1 -1
  1037. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  1038. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  1039. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContainer.js +4 -1
  1040. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContainer.js.map +1 -1
  1041. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContext.js +1 -1
  1042. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContext.js.map +1 -1
  1043. package/dist/cssm/components/Pagination/Pagination.js.map +1 -1
  1044. package/dist/cssm/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.js +1 -1
  1045. package/dist/cssm/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.js.map +1 -1
  1046. package/dist/cssm/components/Pagination/PaginationPage/PaginationPageButton.js +1 -1
  1047. package/dist/cssm/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -1
  1048. package/dist/cssm/components/Pagination/PaginationPage/PaginationPageEllipsis.js +1 -1
  1049. package/dist/cssm/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -1
  1050. package/dist/cssm/components/Pagination/PaginationPage/usePaginationPageClasses.js +1 -1
  1051. package/dist/cssm/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -1
  1052. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  1053. package/dist/cssm/components/PanelHeader/PanelHeader.js +1 -1
  1054. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  1055. package/dist/cssm/components/PanelHeader/PanelHeader.module.css +2 -2
  1056. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  1057. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js +1 -1
  1058. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  1059. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
  1060. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  1061. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.module.css +5 -5
  1062. package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
  1063. package/dist/cssm/components/PanelSpinner/PanelSpinner.js +6 -2
  1064. package/dist/cssm/components/PanelSpinner/PanelSpinner.js.map +1 -1
  1065. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  1066. package/dist/cssm/components/PlatformProvider/PlatformProvider.js +1 -1
  1067. package/dist/cssm/components/PlatformProvider/PlatformProvider.js.map +1 -1
  1068. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  1069. package/dist/cssm/components/Popover/Popover.js.map +1 -1
  1070. package/dist/cssm/components/Popover/usePopover.js.map +1 -1
  1071. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  1072. package/dist/cssm/components/Progress/Progress.js.map +1 -1
  1073. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  1074. package/dist/cssm/components/PullToRefresh/PullToRefresh.module.css +1 -1
  1075. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js +1 -1
  1076. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  1077. package/dist/cssm/components/Radio/Radio.js.map +1 -1
  1078. package/dist/cssm/components/RadioGroup/RadioGroup.js.map +1 -1
  1079. package/dist/cssm/components/Removable/Removable.js +1 -1
  1080. package/dist/cssm/components/Removable/Removable.js.map +1 -1
  1081. package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
  1082. package/dist/cssm/components/Root/Root.js +1 -1
  1083. package/dist/cssm/components/Root/Root.js.map +1 -1
  1084. package/dist/cssm/components/RootComponent/RootComponent.js.map +1 -1
  1085. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js +6 -4
  1086. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  1087. package/dist/cssm/components/ScreenSpinner/ScreenSpinnerContainer.js +0 -2
  1088. package/dist/cssm/components/ScreenSpinner/ScreenSpinnerContainer.js.map +1 -1
  1089. package/dist/cssm/components/ScreenSpinner/ScreenSpinnerLoader.js +0 -1
  1090. package/dist/cssm/components/ScreenSpinner/ScreenSpinnerLoader.js.map +1 -1
  1091. package/dist/cssm/components/ScreenSpinner/ScreenSpinnerSwapIcon.js +1 -3
  1092. package/dist/cssm/components/ScreenSpinner/ScreenSpinnerSwapIcon.js.map +1 -1
  1093. package/dist/cssm/components/ScreenSpinner/context.js.map +1 -1
  1094. package/dist/cssm/components/ScreenSpinner/types.js.map +1 -1
  1095. package/dist/cssm/components/ScrollArrow/ScrollArrow.js.map +1 -1
  1096. package/dist/cssm/components/Search/Search.js.map +1 -1
  1097. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  1098. package/dist/cssm/components/SegmentedControl/SegmentedControl.module.css +2 -2
  1099. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +1 -1
  1100. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  1101. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  1102. package/dist/cssm/components/SelectTypography/SelectTypography.js +1 -1
  1103. package/dist/cssm/components/SelectTypography/SelectTypography.js.map +1 -1
  1104. package/dist/cssm/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.js +1 -1
  1105. package/dist/cssm/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.js.map +1 -1
  1106. package/dist/cssm/components/Separator/Separator.js.map +1 -1
  1107. package/dist/cssm/components/SimpleCell/Chevron/Chevron.js +1 -1
  1108. package/dist/cssm/components/SimpleCell/Chevron/Chevron.js.map +1 -1
  1109. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  1110. package/dist/cssm/components/SimpleGrid/SimpleGrid.js.map +1 -1
  1111. package/dist/cssm/components/Skeleton/Skeleton.js +5 -5
  1112. package/dist/cssm/components/Skeleton/Skeleton.js.map +1 -1
  1113. package/dist/cssm/components/Slider/Slider.js.map +1 -1
  1114. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.js +1 -1
  1115. package/dist/cssm/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
  1116. package/dist/cssm/components/Slider/types.js +1 -1
  1117. package/dist/cssm/components/Slider/types.js.map +1 -1
  1118. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  1119. package/dist/cssm/components/Snackbar/subcomponents/Basic/Basic.js.map +1 -1
  1120. package/dist/cssm/components/Snackbar/types.js +1 -1
  1121. package/dist/cssm/components/Snackbar/types.js.map +1 -1
  1122. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  1123. package/dist/cssm/components/Spinner/Spinner.js +7 -3
  1124. package/dist/cssm/components/Spinner/Spinner.js.map +1 -1
  1125. package/dist/cssm/components/Spinner/SpinnerAnimation.js +1 -1
  1126. package/dist/cssm/components/Spinner/SpinnerAnimation.js.map +1 -1
  1127. package/dist/cssm/components/Spinner/icons.js +52 -0
  1128. package/dist/cssm/components/Spinner/icons.js.map +1 -0
  1129. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  1130. package/dist/cssm/components/SplitCol/SplitColContext.js +1 -1
  1131. package/dist/cssm/components/SplitCol/SplitColContext.js.map +1 -1
  1132. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  1133. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  1134. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +1 -1
  1135. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  1136. package/dist/cssm/components/Switch/Switch.module.css +3 -3
  1137. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  1138. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  1139. package/dist/cssm/components/Tabs/Tabs.js +1 -4
  1140. package/dist/cssm/components/Tabs/Tabs.js.map +1 -1
  1141. package/dist/cssm/components/TabsItem/TabsItem.js +3 -6
  1142. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  1143. package/dist/cssm/components/Tappable/Ripple.js +3 -3
  1144. package/dist/cssm/components/Tappable/Ripple.js.map +1 -1
  1145. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  1146. package/dist/cssm/components/Tappable/Tappable.module.css +1 -1
  1147. package/dist/cssm/components/Tappable/state.js +3 -3
  1148. package/dist/cssm/components/Tappable/state.js.map +1 -1
  1149. package/dist/cssm/components/Textarea/Textarea.js.map +1 -1
  1150. package/dist/cssm/components/ToolButton/ToolButton.js.map +1 -1
  1151. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  1152. package/dist/cssm/components/Tooltip/useTooltip.js.map +1 -1
  1153. package/dist/cssm/components/TooltipBase/TooltipBase.js +1 -1
  1154. package/dist/cssm/components/TooltipBase/TooltipBase.js.map +1 -1
  1155. package/dist/cssm/components/Touch/Touch.js +4 -4
  1156. package/dist/cssm/components/Touch/Touch.js.map +1 -1
  1157. package/dist/cssm/components/Touch/TouchContext.js +1 -1
  1158. package/dist/cssm/components/Touch/TouchContext.js.map +1 -1
  1159. package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
  1160. package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.js.map +1 -1
  1161. package/dist/cssm/components/Typography/EllipsisText/EllipsisText.js.map +1 -1
  1162. package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
  1163. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  1164. package/dist/cssm/components/Typography/Typography.js.map +1 -1
  1165. package/dist/cssm/components/UnstyledTextField/UnstyledTextField.js.map +1 -1
  1166. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  1167. package/dist/cssm/components/View/View.js.map +1 -1
  1168. package/dist/cssm/components/View/View.module.css +1 -1
  1169. package/dist/cssm/components/View/ViewInfinite.js +1 -1
  1170. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  1171. package/dist/cssm/components/View/useLayoutEffectCall.js +1 -1
  1172. package/dist/cssm/components/View/useLayoutEffectCall.js.map +1 -1
  1173. package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
  1174. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +1 -1
  1175. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  1176. package/dist/cssm/hooks/useCalendar.js +6 -0
  1177. package/dist/cssm/hooks/useCalendar.js.map +1 -1
  1178. package/dist/cssm/hooks/useDateInput.js +64 -28
  1179. package/dist/cssm/hooks/useDateInput.js.map +1 -1
  1180. package/dist/cssm/hooks/useFocusTrap.js +18 -8
  1181. package/dist/cssm/hooks/useFocusTrap.js.map +1 -1
  1182. package/dist/cssm/hooks/useLocale.js +7 -0
  1183. package/dist/cssm/hooks/useLocale.js.map +1 -0
  1184. package/dist/cssm/index.js +1 -0
  1185. package/dist/cssm/index.js.map +1 -1
  1186. package/dist/cssm/lib/calendar.js +25 -3
  1187. package/dist/cssm/lib/calendar.js.map +1 -1
  1188. package/dist/cssm/lib/date.js +6 -0
  1189. package/dist/cssm/lib/date.js.map +1 -1
  1190. package/dist/cssm/lib/dom.js +6 -0
  1191. package/dist/cssm/lib/dom.js.map +1 -1
  1192. package/dist/cssm/lib/platform.js +5 -1
  1193. package/dist/cssm/lib/platform.js.map +1 -1
  1194. package/dist/cssm/lib/react/defineComponentDisplayNames.js +8 -0
  1195. package/dist/cssm/lib/react/defineComponentDisplayNames.js.map +1 -0
  1196. package/dist/cssm/styles/constants.css +2 -2
  1197. package/dist/hooks/useCalendar.d.ts +3 -1
  1198. package/dist/hooks/useCalendar.d.ts.map +1 -1
  1199. package/dist/hooks/useCalendar.js +6 -0
  1200. package/dist/hooks/useCalendar.js.map +1 -1
  1201. package/dist/hooks/useDateInput.d.ts +6 -4
  1202. package/dist/hooks/useDateInput.d.ts.map +1 -1
  1203. package/dist/hooks/useDateInput.js +65 -29
  1204. package/dist/hooks/useDateInput.js.map +1 -1
  1205. package/dist/hooks/useFocusTrap.d.ts +9 -1
  1206. package/dist/hooks/useFocusTrap.d.ts.map +1 -1
  1207. package/dist/hooks/useFocusTrap.js +18 -8
  1208. package/dist/hooks/useFocusTrap.js.map +1 -1
  1209. package/dist/hooks/useLocale.d.ts +2 -0
  1210. package/dist/hooks/useLocale.d.ts.map +1 -0
  1211. package/dist/hooks/useLocale.js +7 -0
  1212. package/dist/hooks/useLocale.js.map +1 -0
  1213. package/dist/index.d.ts +1 -0
  1214. package/dist/index.d.ts.map +1 -1
  1215. package/dist/index.js +1 -0
  1216. package/dist/index.js.map +1 -1
  1217. package/dist/lib/calendar.d.ts +4 -1
  1218. package/dist/lib/calendar.d.ts.map +1 -1
  1219. package/dist/lib/calendar.js +25 -3
  1220. package/dist/lib/calendar.js.map +1 -1
  1221. package/dist/lib/date.d.ts.map +1 -1
  1222. package/dist/lib/date.js +6 -0
  1223. package/dist/lib/date.js.map +1 -1
  1224. package/dist/lib/dom.d.ts +1 -0
  1225. package/dist/lib/dom.d.ts.map +1 -1
  1226. package/dist/lib/dom.js +6 -0
  1227. package/dist/lib/dom.js.map +1 -1
  1228. package/dist/lib/platform.d.ts +5 -3
  1229. package/dist/lib/platform.d.ts.map +1 -1
  1230. package/dist/lib/platform.js +5 -1
  1231. package/dist/lib/platform.js.map +1 -1
  1232. package/dist/lib/react/defineComponentDisplayNames.d.ts +2 -0
  1233. package/dist/lib/react/defineComponentDisplayNames.d.ts.map +1 -0
  1234. package/dist/lib/react/defineComponentDisplayNames.js +8 -0
  1235. package/dist/lib/react/defineComponentDisplayNames.js.map +1 -0
  1236. package/dist/vkui.css +1 -1
  1237. package/dist/vkui.css.map +1 -1
  1238. package/package.json +13 -9
  1239. package/src/components/Accordion/Accordion.module.css.d.ts.map +1 -0
  1240. package/src/components/Accordion/Accordion.tsx +12 -5
  1241. package/src/components/Accordion/AccordionContent.tsx +2 -4
  1242. package/src/components/Accordion/AccordionContext.tsx +13 -0
  1243. package/src/components/Accordion/AccordionSummary.tsx +1 -3
  1244. package/src/components/ActionSheet/ActionSheet.module.css.d.ts.map +1 -0
  1245. package/src/components/ActionSheet/ActionSheet.tsx +29 -2
  1246. package/src/components/ActionSheet/ActionSheetContext.ts +23 -0
  1247. package/src/components/ActionSheet/ActionSheetDefaultIosCloseItem.tsx +6 -3
  1248. package/src/components/ActionSheet/types.ts +8 -5
  1249. package/src/components/ActionSheetItem/ActionSheetItem.module.css.d.ts.map +1 -0
  1250. package/src/components/ActionSheetItem/ActionSheetItem.tsx +40 -8
  1251. package/src/components/ActionSheetItem/helpers.ts +2 -2
  1252. package/src/components/ActionSheetItem/subcomponents/Radio/Radio.module.css.d.ts.map +1 -0
  1253. package/src/components/AdaptiveIconRenderer/AdaptiveIconRenderer.tsx +6 -0
  1254. package/src/components/AdaptivityProvider/AdaptivityContext.tsx +12 -4
  1255. package/src/components/Alert/Alert.module.css +2 -2
  1256. package/src/components/Alert/Alert.module.css.d.ts.map +1 -0
  1257. package/src/components/Alert/Alert.tsx +42 -13
  1258. package/src/components/Alert/AlertAction.tsx +6 -0
  1259. package/src/components/Alert/AlertActions.tsx +3 -0
  1260. package/src/components/Alert/AlertBase.tsx +8 -0
  1261. package/src/components/Alert/AlertTypography.tsx +1 -0
  1262. package/src/components/AppRoot/AppRoot.module.css.d.ts.map +1 -0
  1263. package/src/components/AppRoot/AppRoot.tsx +7 -5
  1264. package/src/components/AppRoot/AppRootContext.ts +3 -1
  1265. package/src/components/AppRoot/AppRootPortal.tsx +11 -4
  1266. package/src/components/AppRoot/AppRootStyleContainer/AppRootStyleContainer.module.css.d.ts.map +1 -0
  1267. package/src/components/AppRoot/ScrollContext.tsx +6 -5
  1268. package/src/components/AppRoot/types.ts +2 -0
  1269. package/src/components/AspectRatio/AspectRatio.module.css.d.ts.map +1 -0
  1270. package/src/components/AspectRatio/AspectRatio.tsx +4 -1
  1271. package/src/components/Avatar/Avatar.module.css.d.ts.map +1 -0
  1272. package/src/components/Avatar/Avatar.tsx +8 -9
  1273. package/src/components/Avatar/AvatarBadge/AvatarBadge.module.css.d.ts.map +1 -0
  1274. package/src/components/Avatar/AvatarBadge/AvatarBadge.tsx +1 -6
  1275. package/src/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.tsx +1 -3
  1276. package/src/components/Avatar/AvatarBadge/icons.tsx +2 -0
  1277. package/src/components/Badge/Badge.module.css.d.ts.map +1 -0
  1278. package/src/components/Badge/Badge.tsx +3 -0
  1279. package/src/components/Banner/Banner.module.css.d.ts.map +1 -0
  1280. package/src/components/Banner/Banner.tsx +8 -5
  1281. package/src/components/Button/Button.module.css.d.ts.map +1 -0
  1282. package/src/components/Button/Button.tsx +27 -0
  1283. package/src/components/ButtonGroup/ButtonGroup.module.css.d.ts.map +1 -0
  1284. package/src/components/ButtonGroup/ButtonGroup.tsx +0 -2
  1285. package/src/components/Calendar/Calendar.module.css.d.ts.map +1 -0
  1286. package/src/components/Calendar/Calendar.tsx +135 -27
  1287. package/src/components/CalendarDay/CalendarDay.module.css.d.ts.map +1 -0
  1288. package/src/components/CalendarDay/CalendarDay.tsx +93 -11
  1289. package/src/components/CalendarDays/CalendarDays.module.css.d.ts.map +1 -0
  1290. package/src/components/CalendarDays/CalendarDays.tsx +166 -49
  1291. package/src/components/CalendarHeader/CalendarHeader.module.css.d.ts.map +1 -0
  1292. package/src/components/CalendarHeader/CalendarHeader.tsx +56 -6
  1293. package/src/components/CalendarRange/CalendarRange.module.css.d.ts.map +1 -0
  1294. package/src/components/CalendarRange/CalendarRange.tsx +73 -19
  1295. package/src/components/CalendarTime/CalendarTime.module.css.d.ts.map +1 -0
  1296. package/src/components/CalendarTime/CalendarTime.tsx +65 -15
  1297. package/src/components/Card/Card.module.css +2 -2
  1298. package/src/components/Card/Card.module.css.d.ts.map +1 -0
  1299. package/src/components/Card/Card.tsx +3 -0
  1300. package/src/components/CardGrid/CardGrid.module.css.d.ts.map +1 -0
  1301. package/src/components/CardGrid/CardGrid.tsx +4 -1
  1302. package/src/components/CardScroll/CardScroll.module.css.d.ts.map +1 -0
  1303. package/src/components/CardScroll/CardScroll.tsx +2 -2
  1304. package/src/components/CarouselBase/Bullets.tsx +4 -3
  1305. package/src/components/CarouselBase/CarouselBase.module.css.d.ts.map +1 -0
  1306. package/src/components/CarouselBase/CarouselBase.tsx +6 -6
  1307. package/src/components/CarouselBase/CarouselViewPort.tsx +3 -2
  1308. package/src/components/CarouselBase/ScrollArrows.tsx +5 -4
  1309. package/src/components/CarouselBase/helpers.ts +3 -2
  1310. package/src/components/CarouselBase/types.ts +22 -20
  1311. package/src/components/Cell/Cell.module.css.d.ts.map +1 -0
  1312. package/src/components/Cell/Cell.tsx +13 -8
  1313. package/src/components/Cell/CellCheckbox/CellCheckbox.module.css.d.ts.map +1 -0
  1314. package/src/components/Cell/CellDragger/CellDragger.module.css.d.ts.map +1 -0
  1315. package/src/components/Cell/CellDragger/CellDragger.tsx +1 -0
  1316. package/src/components/CellButton/CellButton.module.css.d.ts.map +1 -0
  1317. package/src/components/CellButton/CellButton.tsx +3 -0
  1318. package/src/components/CellButtonGroup/CellButtonGroup.tsx +5 -3
  1319. package/src/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.module.css.d.ts.map +1 -0
  1320. package/src/components/CellButtonGroup/CellButtonGroupSeparator/CellButtonGroupSeparator.tsx +0 -2
  1321. package/src/components/Checkbox/Checkbox.tsx +6 -0
  1322. package/src/components/Checkbox/CheckboxInput/CheckboxInput.module.css.d.ts.map +1 -0
  1323. package/src/components/Checkbox/CheckboxInput/CheckboxInput.tsx +21 -0
  1324. package/src/components/Checkbox/CheckboxSimple/CheckboxSimple.module.css.d.ts.map +1 -0
  1325. package/src/components/ChipsInput/ChipsInput.tsx +3 -1
  1326. package/src/components/ChipsInput/useChipsInput.ts +53 -19
  1327. package/src/components/ChipsInputBase/Chip/Chip.module.css.d.ts.map +1 -0
  1328. package/src/components/ChipsInputBase/ChipsInputBase.module.css.d.ts.map +1 -0
  1329. package/src/components/ChipsInputBase/ChipsInputBase.tsx +1 -0
  1330. package/src/components/ChipsInputBase/helpers.ts +5 -1
  1331. package/src/components/ChipsInputBase/types.ts +87 -7
  1332. package/src/components/ChipsSelect/ChipsSelect.module.css.d.ts.map +1 -0
  1333. package/src/components/ChipsSelect/ChipsSelect.tsx +23 -11
  1334. package/src/components/ChipsSelect/types.ts +2 -0
  1335. package/src/components/ChipsSelect/useChipsSelect.ts +17 -6
  1336. package/src/components/Clickable/Clickable.module.css.d.ts.map +1 -0
  1337. package/src/components/Clickable/Clickable.tsx +6 -5
  1338. package/src/components/Clickable/RealClickable.tsx +1 -1
  1339. package/src/components/Clickable/useState.tsx +16 -14
  1340. package/src/components/Clickable/useStateWithDelay.tsx +1 -1
  1341. package/src/components/ColorSchemeProvider/ColorSchemeProvider.tsx +6 -4
  1342. package/src/components/ConfigProvider/ConfigProvider.tsx +3 -0
  1343. package/src/components/ConfigProvider/ConfigProviderContext.tsx +7 -7
  1344. package/src/components/ConfigProvider/ConfigProviderOverride.tsx +4 -1
  1345. package/src/components/ContentBadge/ContentBadge.module.css.d.ts.map +1 -0
  1346. package/src/components/ContentBadge/ContentBadge.tsx +7 -5
  1347. package/src/components/ContentBadge/ContentBadgeContext.tsx +1 -0
  1348. package/src/components/ContentBadge/ContentBadgeSlotIcon.tsx +1 -3
  1349. package/src/components/ContentCard/ContentCard.module.css.d.ts.map +1 -0
  1350. package/src/components/ContentCard/ContentCard.tsx +12 -9
  1351. package/src/components/Counter/Counter.module.css.d.ts.map +1 -0
  1352. package/src/components/Counter/Counter.tsx +6 -4
  1353. package/src/components/CustomScrollView/CustomScrollView.module.css.d.ts.map +1 -0
  1354. package/src/components/CustomScrollView/CustomScrollView.tsx +14 -5
  1355. package/src/components/CustomSelect/CustomSelect.module.css.d.ts.map +1 -0
  1356. package/src/components/CustomSelect/CustomSelect.tsx +59 -13
  1357. package/src/components/CustomSelect/CustomSelectClearButton.tsx +9 -0
  1358. package/src/components/CustomSelect/CustomSelectInput/CustomSelectInput.module.css.d.ts.map +1 -0
  1359. package/src/components/CustomSelect/CustomSelectInput/CustomSelectInput.tsx +1 -0
  1360. package/src/components/CustomSelectDropdown/CustomSelectDropdown.module.css.d.ts.map +1 -0
  1361. package/src/components/CustomSelectDropdown/CustomSelectDropdown.tsx +5 -2
  1362. package/src/components/CustomSelectOption/CustomSelectOption.module.css.d.ts.map +1 -0
  1363. package/src/components/DateInput/DateInput.module.css.d.ts.map +1 -0
  1364. package/src/components/DateInput/DateInput.tsx +221 -72
  1365. package/src/components/DateInput/hooks.ts +34 -23
  1366. package/src/components/DateRangeInput/DateRangeInput.module.css.d.ts.map +1 -0
  1367. package/src/components/DateRangeInput/DateRangeInput.tsx +68 -11
  1368. package/src/components/DirectionProvider/DirectionProvider.tsx +7 -1
  1369. package/src/components/Div/Div.module.css.d.ts.map +1 -0
  1370. package/src/components/DropZone/DropZone.module.css.d.ts.map +1 -0
  1371. package/src/components/DropZone/DropZone.tsx +11 -3
  1372. package/src/components/DropZone/components/DropZoneGrid.module.css.d.ts.map +1 -0
  1373. package/src/components/DropZone/components/DropZoneGrid.tsx +4 -6
  1374. package/src/components/DropdownIcon/DropdownIcon.tsx +1 -0
  1375. package/src/components/Epic/Epic.module.css.d.ts.map +1 -0
  1376. package/src/components/Epic/Epic.tsx +10 -0
  1377. package/src/components/Epic/ScrollSaver.tsx +1 -0
  1378. package/src/components/FixedLayout/FixedLayout.module.css.d.ts.map +1 -0
  1379. package/src/components/FixedLayout/FixedLayout.tsx +3 -7
  1380. package/src/components/Flex/Flex.module.css.d.ts.map +1 -0
  1381. package/src/components/Flex/FlexItem/FlexItem.module.css.d.ts.map +1 -0
  1382. package/src/components/Flex/FlexItem/FlexItem.tsx +3 -3
  1383. package/src/components/FloatingArrow/DefaultIcon.tsx +1 -1
  1384. package/src/components/FloatingArrow/FloatingArrow.module.css.d.ts.map +1 -0
  1385. package/src/components/FloatingArrow/FloatingArrow.tsx +17 -0
  1386. package/src/components/FocusTrap/FocusTrap.tsx +2 -0
  1387. package/src/components/Footer/Footer.module.css.d.ts.map +1 -0
  1388. package/src/components/FormField/FormField.module.css.d.ts.map +1 -0
  1389. package/src/components/FormField/FormField.tsx +11 -5
  1390. package/src/components/FormFieldClearButton/FormFieldClearButton.tsx +9 -0
  1391. package/src/components/FormItem/FormItem.module.css +1 -0
  1392. package/src/components/FormItem/FormItem.module.css.d.ts.map +1 -0
  1393. package/src/components/FormItem/FormItem.tsx +24 -10
  1394. package/src/components/FormItem/FormItemTop/FormItemTop.tsx +1 -3
  1395. package/src/components/FormItem/FormItemTop/FormItemTopAside.tsx +1 -6
  1396. package/src/components/FormItem/FormItemTop/FormItemTopLabel.tsx +1 -3
  1397. package/src/components/FormItem/context.ts +2 -0
  1398. package/src/components/FormLayoutGroup/FormLayoutGroup.module.css.d.ts.map +1 -0
  1399. package/src/components/FormLayoutGroup/FormLayoutGroup.tsx +3 -0
  1400. package/src/components/FormStatus/FormStatus.module.css.d.ts.map +1 -0
  1401. package/src/components/FormStatus/FormStatus.tsx +6 -0
  1402. package/src/components/Gallery/Gallery.tsx +6 -0
  1403. package/src/components/Gallery/hooks.ts +2 -0
  1404. package/src/components/Gradient/Gradient.module.css.d.ts.map +1 -0
  1405. package/src/components/Gradient/Gradient.tsx +2 -2
  1406. package/src/components/GridAvatar/GridAvatar.module.css.d.ts.map +1 -0
  1407. package/src/components/GridAvatar/GridAvatarBadge/GridAvatarBadge.module.css.d.ts.map +1 -0
  1408. package/src/components/Group/Group.module.css.d.ts.map +1 -0
  1409. package/src/components/Group/Group.tsx +14 -5
  1410. package/src/components/Group/GroupContainer.tsx +1 -2
  1411. package/src/components/Group/GroupDescription.tsx +2 -6
  1412. package/src/components/Group/GroupExpandedContent.tsx +5 -8
  1413. package/src/components/Group/GroupHeader.tsx +1 -6
  1414. package/src/components/Header/Header.module.css.d.ts.map +1 -0
  1415. package/src/components/Header/Header.tsx +19 -8
  1416. package/src/components/HorizontalCell/HorizontalCell.module.css.d.ts.map +1 -0
  1417. package/src/components/HorizontalCell/HorizontalCell.tsx +5 -5
  1418. package/src/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.module.css.d.ts.map +1 -0
  1419. package/src/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.tsx +3 -3
  1420. package/src/components/HorizontalScroll/HorizontalScroll.module.css.d.ts.map +1 -0
  1421. package/src/components/HorizontalScroll/HorizontalScroll.tsx +26 -15
  1422. package/src/components/IconButton/IconButton.module.css.d.ts.map +1 -0
  1423. package/src/components/IconButton/IconButton.tsx +1 -1
  1424. package/src/components/Image/Image.module.css.d.ts.map +1 -0
  1425. package/src/components/Image/Image.tsx +11 -11
  1426. package/src/components/Image/ImageBadge/ImageBadge.module.css.d.ts.map +1 -0
  1427. package/src/components/Image/ImageBadge/ImageBadge.tsx +1 -6
  1428. package/src/components/ImageBase/ImageBase.module.css.d.ts.map +1 -0
  1429. package/src/components/ImageBase/ImageBase.tsx +14 -15
  1430. package/src/components/ImageBase/ImageBaseBadge/ImageBaseBadge.module.css.d.ts.map +1 -0
  1431. package/src/components/ImageBase/ImageBaseBadge/ImageBaseBadge.tsx +2 -7
  1432. package/src/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.module.css.d.ts.map +1 -0
  1433. package/src/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.tsx +4 -6
  1434. package/src/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.module.css.d.ts.map +1 -0
  1435. package/src/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.tsx +1 -3
  1436. package/src/components/ImageBase/ImageBaseOverlay/types.ts +6 -0
  1437. package/src/components/ImageBase/helpers.ts +3 -3
  1438. package/src/components/ImageBase/types.ts +18 -0
  1439. package/src/components/ImageBase/validators.ts +4 -3
  1440. package/src/components/InfoRow/InfoRow.module.css.d.ts.map +1 -0
  1441. package/src/components/InfoRow/InfoRow.tsx +3 -0
  1442. package/src/components/Input/Input.module.css.d.ts.map +1 -0
  1443. package/src/components/InputLike/InputLike.module.css +1 -1
  1444. package/src/components/InputLike/InputLike.module.css.d.ts.map +1 -0
  1445. package/src/components/InputLike/InputLike.tsx +5 -6
  1446. package/src/components/Link/Link.module.css +2 -4
  1447. package/src/components/Link/Link.module.css.d.ts.map +1 -0
  1448. package/src/components/Link/Link.tsx +4 -6
  1449. package/src/components/List/List.module.css.d.ts.map +1 -0
  1450. package/src/components/List/List.tsx +1 -1
  1451. package/src/components/LocaleProvider/LocaleProvider.tsx +5 -2
  1452. package/src/components/Mark/Mark.module.css.d.ts.map +1 -0
  1453. package/src/components/MiniInfoCell/MiniInfoCell.module.css.d.ts.map +1 -0
  1454. package/src/components/MiniInfoCell/MiniInfoCell.tsx +3 -3
  1455. package/src/components/ModalCard/ModalCard.module.css.d.ts.map +1 -0
  1456. package/src/components/ModalCard/ModalCard.tsx +2 -9
  1457. package/src/components/ModalCard/ModalCardInternal.tsx +1 -0
  1458. package/src/components/ModalCard/types.ts +1 -1
  1459. package/src/components/ModalCardBase/ModalCardBase.module.css.d.ts.map +1 -0
  1460. package/src/components/ModalCardBase/ModalCardBase.tsx +26 -18
  1461. package/src/components/ModalDismissButton/ModalDismissButton.module.css.d.ts.map +1 -0
  1462. package/src/components/ModalDismissButton/ModalDismissButton.tsx +3 -0
  1463. package/src/components/ModalOutlet/ModalOutlet.module.css.d.ts.map +1 -0
  1464. package/src/components/ModalOutlet/ModalOutlet.tsx +2 -0
  1465. package/src/components/ModalOutsideButton/ModalOutsideButton.module.css.d.ts.map +1 -0
  1466. package/src/components/ModalOutsideButton/ModalOutsideButton.tsx +2 -2
  1467. package/src/components/ModalOutsideButtons/ModalOutsideButtons.module.css.d.ts.map +1 -0
  1468. package/src/components/ModalOverlay/ModalOverlay.module.css +1 -1
  1469. package/src/components/ModalOverlay/ModalOverlay.module.css.d.ts.map +1 -0
  1470. package/src/components/ModalOverlay/ModalOverlay.tsx +1 -0
  1471. package/src/components/ModalPage/ModalPage.module.css.d.ts.map +1 -0
  1472. package/src/components/ModalPage/ModalPage.tsx +3 -10
  1473. package/src/components/ModalPage/ModalPageBase.tsx +3 -2
  1474. package/src/components/ModalPage/ModalPageInternal.tsx +1 -0
  1475. package/src/components/ModalPage/types.ts +11 -8
  1476. package/src/components/ModalPageContent/ModalPageContent.module.css.d.ts.map +1 -0
  1477. package/src/components/ModalPageFooter/ModalPageFooter.module.css.d.ts.map +1 -0
  1478. package/src/components/ModalPageFooter/ModalPageFooter.tsx +6 -0
  1479. package/src/components/ModalPageHeader/ModalPageHeader.module.css.d.ts.map +1 -0
  1480. package/src/components/ModalPageHeader/ModalPageHeader.tsx +3 -0
  1481. package/src/components/ModalRoot/VisuallyHiddenModalOverlay/VisuallyHiddenModalOverlay.module.css.d.ts.map +1 -0
  1482. package/src/components/ModalRoot/types.ts +22 -16
  1483. package/src/components/ModalRoot/useModalManager.tsx +14 -5
  1484. package/src/components/ModalRoot/useModalRootContext.ts +1 -1
  1485. package/src/components/ModalRoot/withModalRootContext.tsx +2 -2
  1486. package/src/components/NativeSelect/NativeSelect.tsx +15 -6
  1487. package/src/components/NavTransitionContext/NavTransitionContext.tsx +1 -0
  1488. package/src/components/OnboardingTooltip/OnboardingTooltip.module.css.d.ts.map +1 -0
  1489. package/src/components/OnboardingTooltip/OnboardingTooltip.tsx +2 -2
  1490. package/src/components/OnboardingTooltip/OnboardingTooltipContainer.tsx +8 -1
  1491. package/src/components/OnboardingTooltip/OnboardingTooltipContext.tsx +2 -0
  1492. package/src/components/Pagination/Pagination.module.css.d.ts.map +1 -0
  1493. package/src/components/Pagination/Pagination.tsx +10 -4
  1494. package/src/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.tsx +2 -0
  1495. package/src/components/Pagination/PaginationPage/PaginationPage.module.css.d.ts.map +1 -0
  1496. package/src/components/Pagination/PaginationPage/PaginationPageButton.tsx +2 -0
  1497. package/src/components/Pagination/PaginationPage/PaginationPageEllipsis.tsx +1 -0
  1498. package/src/components/Pagination/PaginationPage/usePaginationPageClasses.ts +2 -0
  1499. package/src/components/Panel/Panel.module.css.d.ts.map +1 -0
  1500. package/src/components/Panel/Panel.tsx +4 -1
  1501. package/src/components/PanelHeader/PanelHeader.module.css +2 -2
  1502. package/src/components/PanelHeader/PanelHeader.module.css.d.ts.map +1 -0
  1503. package/src/components/PanelHeader/PanelHeader.tsx +15 -2
  1504. package/src/components/PanelHeaderBack/PanelHeaderBack.tsx +6 -0
  1505. package/src/components/PanelHeaderButton/PanelHeaderButton.module.css.d.ts.map +1 -0
  1506. package/src/components/PanelHeaderButton/PanelHeaderButton.tsx +13 -3
  1507. package/src/components/PanelHeaderContent/PanelHeaderContent.module.css.d.ts.map +1 -0
  1508. package/src/components/PanelHeaderContent/PanelHeaderContent.tsx +15 -0
  1509. package/src/components/PanelHeaderContext/PanelHeaderContext.module.css +5 -5
  1510. package/src/components/PanelHeaderContext/PanelHeaderContext.module.css.d.ts.map +1 -0
  1511. package/src/components/PanelHeaderContext/PanelHeaderContext.tsx +8 -0
  1512. package/src/components/PanelHeaderEdit/PanelHeaderEdit.tsx +3 -3
  1513. package/src/components/PanelSpinner/PanelSpinner.tsx +9 -2
  1514. package/src/components/Placeholder/Placeholder.module.css.d.ts.map +1 -0
  1515. package/src/components/Placeholder/Placeholder.tsx +5 -5
  1516. package/src/components/PlatformProvider/PlatformProvider.tsx +5 -2
  1517. package/src/components/PopoutWrapper/PopoutWrapper.module.css.d.ts.map +1 -0
  1518. package/src/components/PopoutWrapper/PopoutWrapper.tsx +4 -4
  1519. package/src/components/Popover/Popover.module.css.d.ts.map +1 -0
  1520. package/src/components/Popover/Popover.tsx +7 -4
  1521. package/src/components/Popover/usePopover.tsx +9 -0
  1522. package/src/components/Popper/Popper.module.css.d.ts.map +1 -0
  1523. package/src/components/Popper/Popper.tsx +4 -1
  1524. package/src/components/Progress/Progress.module.css.d.ts.map +1 -0
  1525. package/src/components/Progress/Progress.tsx +6 -3
  1526. package/src/components/PullToRefresh/PullToRefresh.module.css +1 -1
  1527. package/src/components/PullToRefresh/PullToRefresh.module.css.d.ts.map +1 -0
  1528. package/src/components/PullToRefresh/PullToRefresh.tsx +2 -2
  1529. package/src/components/PullToRefresh/PullToRefreshSpinner.tsx +2 -0
  1530. package/src/components/Radio/Radio.module.css.d.ts.map +1 -0
  1531. package/src/components/Radio/Radio.tsx +7 -1
  1532. package/src/components/Radio/RadioInput/RadioInput.module.css.d.ts.map +1 -0
  1533. package/src/components/RadioGroup/RadioGroup.module.css.d.ts.map +1 -0
  1534. package/src/components/RadioGroup/RadioGroup.tsx +3 -0
  1535. package/src/components/Removable/Removable.module.css.d.ts.map +1 -0
  1536. package/src/components/Removable/Removable.tsx +12 -8
  1537. package/src/components/RichCell/RichCell.module.css.d.ts.map +1 -0
  1538. package/src/components/RichCell/RichCell.tsx +6 -6
  1539. package/src/components/RichCell/RichCellIcon/RichCellIcon.module.css.d.ts.map +1 -0
  1540. package/src/components/Root/Root.module.css.d.ts.map +1 -0
  1541. package/src/components/Root/Root.tsx +11 -0
  1542. package/src/components/RootComponent/RootComponent.module.css.d.ts.map +1 -0
  1543. package/src/components/RootComponent/RootComponent.tsx +12 -2
  1544. package/src/components/ScreenSpinner/ScreenSpinner.module.css.d.ts.map +1 -0
  1545. package/src/components/ScreenSpinner/ScreenSpinner.tsx +7 -7
  1546. package/src/components/ScreenSpinner/ScreenSpinnerContainer.tsx +1 -4
  1547. package/src/components/ScreenSpinner/ScreenSpinnerLoader.tsx +3 -6
  1548. package/src/components/ScreenSpinner/ScreenSpinnerSwapIcon.tsx +3 -6
  1549. package/src/components/ScreenSpinner/context.ts +9 -0
  1550. package/src/components/ScreenSpinner/types.tsx +23 -14
  1551. package/src/components/ScrollArrow/ScrollArrow.module.css.d.ts.map +1 -0
  1552. package/src/components/ScrollArrow/ScrollArrow.tsx +5 -2
  1553. package/src/components/Search/Search.module.css.d.ts.map +1 -0
  1554. package/src/components/Search/Search.tsx +24 -6
  1555. package/src/components/SegmentedControl/SegmentedControl.module.css +2 -2
  1556. package/src/components/SegmentedControl/SegmentedControl.module.css.d.ts.map +1 -0
  1557. package/src/components/SegmentedControl/SegmentedControl.tsx +25 -1
  1558. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.module.css.d.ts.map +1 -0
  1559. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.tsx +1 -0
  1560. package/src/components/Select/Select.module.css.d.ts.map +1 -0
  1561. package/src/components/SelectMimicry/SelectMimicry.tsx +9 -0
  1562. package/src/components/SelectTypography/SelectTypography.tsx +2 -0
  1563. package/src/components/SelectionControl/SelectionControl.module.css.d.ts.map +1 -0
  1564. package/src/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.module.css.d.ts.map +1 -0
  1565. package/src/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.tsx +1 -0
  1566. package/src/components/Separator/Separator.module.css.d.ts.map +1 -0
  1567. package/src/components/Separator/Separator.tsx +6 -6
  1568. package/src/components/SimpleCell/Chevron/Chevron.tsx +2 -0
  1569. package/src/components/SimpleCell/SimpleCell.module.css.d.ts.map +1 -0
  1570. package/src/components/SimpleCell/SimpleCell.tsx +5 -5
  1571. package/src/components/SimpleGrid/SimpleGrid.module.css.d.ts.map +1 -0
  1572. package/src/components/SimpleGrid/SimpleGrid.tsx +4 -4
  1573. package/src/components/Skeleton/Skeleton.module.css.d.ts.map +1 -0
  1574. package/src/components/Skeleton/Skeleton.tsx +9 -9
  1575. package/src/components/Slider/Slider.module.css.d.ts.map +1 -0
  1576. package/src/components/Slider/Slider.tsx +41 -2
  1577. package/src/components/Slider/SliderThumb/SliderThumb.module.css.d.ts.map +1 -0
  1578. package/src/components/Slider/SliderThumb/SliderThumb.tsx +1 -0
  1579. package/src/components/Slider/types.ts +2 -0
  1580. package/src/components/Snackbar/Snackbar.module.css.d.ts.map +1 -0
  1581. package/src/components/Snackbar/Snackbar.tsx +4 -4
  1582. package/src/components/Snackbar/subcomponents/Basic/Basic.module.css.d.ts.map +1 -0
  1583. package/src/components/Snackbar/subcomponents/Basic/Basic.tsx +6 -6
  1584. package/src/components/Snackbar/types.ts +2 -0
  1585. package/src/components/Spacing/Spacing.module.css.d.ts.map +1 -0
  1586. package/src/components/Spacing/Spacing.tsx +3 -3
  1587. package/src/components/Spinner/Spinner.module.css.d.ts.map +1 -0
  1588. package/src/components/Spinner/Spinner.tsx +14 -4
  1589. package/src/components/Spinner/SpinnerAnimation.tsx +1 -0
  1590. package/src/components/Spinner/icons.tsx +53 -0
  1591. package/src/components/SplitCol/SplitCol.module.css.d.ts.map +1 -0
  1592. package/src/components/SplitCol/SplitCol.tsx +15 -3
  1593. package/src/components/SplitCol/SplitColContext.tsx +2 -0
  1594. package/src/components/SplitLayout/SplitLayout.module.css.d.ts.map +1 -0
  1595. package/src/components/SplitLayout/SplitLayout.tsx +5 -2
  1596. package/src/components/SubnavigationBar/SubnavigationBar.module.css.d.ts.map +1 -0
  1597. package/src/components/SubnavigationBar/SubnavigationBar.tsx +3 -0
  1598. package/src/components/SubnavigationButton/SubnavigationButton.module.css.d.ts.map +1 -0
  1599. package/src/components/SubnavigationButton/SubnavigationButton.tsx +19 -4
  1600. package/src/components/Switch/Switch.module.css +3 -3
  1601. package/src/components/Switch/Switch.module.css.d.ts.map +1 -0
  1602. package/src/components/Tabbar/Tabbar.module.css.d.ts.map +1 -0
  1603. package/src/components/Tabbar/Tabbar.tsx +2 -2
  1604. package/src/components/TabbarItem/TabbarItem.module.css.d.ts.map +1 -0
  1605. package/src/components/TabbarItem/TabbarItem.tsx +5 -2
  1606. package/src/components/Tabs/Tabs.module.css.d.ts.map +1 -0
  1607. package/src/components/Tabs/Tabs.tsx +7 -6
  1608. package/src/components/TabsItem/TabsItem.module.css.d.ts.map +1 -0
  1609. package/src/components/TabsItem/TabsItem.tsx +16 -16
  1610. package/src/components/Tappable/Ripple.tsx +4 -2
  1611. package/src/components/Tappable/Tappable.module.css +1 -1
  1612. package/src/components/Tappable/Tappable.module.css.d.ts.map +1 -0
  1613. package/src/components/Tappable/Tappable.tsx +13 -1
  1614. package/src/components/Tappable/state.tsx +5 -5
  1615. package/src/components/Textarea/Textarea.module.css.d.ts.map +1 -0
  1616. package/src/components/Textarea/Textarea.tsx +9 -0
  1617. package/src/components/ToolButton/ToolButton.module.css.d.ts.map +1 -0
  1618. package/src/components/ToolButton/ToolButton.tsx +9 -0
  1619. package/src/components/Tooltip/Tooltip.tsx +1 -1
  1620. package/src/components/Tooltip/useTooltip.tsx +9 -0
  1621. package/src/components/TooltipBase/TooltipBase.module.css.d.ts.map +1 -0
  1622. package/src/components/TooltipBase/TooltipBase.tsx +5 -5
  1623. package/src/components/Touch/Touch.tsx +152 -7
  1624. package/src/components/Touch/TouchContext.ts +1 -1
  1625. package/src/components/Typography/Caption/Caption.module.css.d.ts.map +1 -0
  1626. package/src/components/Typography/Caption/Caption.tsx +3 -0
  1627. package/src/components/Typography/DisplayTitle/DisplayTitle.module.css.d.ts.map +1 -0
  1628. package/src/components/Typography/DisplayTitle/DisplayTitle.tsx +3 -0
  1629. package/src/components/Typography/EllipsisText/EllipsisText.module.css.d.ts.map +1 -0
  1630. package/src/components/Typography/EllipsisText/EllipsisText.tsx +3 -3
  1631. package/src/components/Typography/Footnote/Footnote.module.css.d.ts.map +1 -0
  1632. package/src/components/Typography/Headline/Headline.module.css.d.ts.map +1 -0
  1633. package/src/components/Typography/Headline/Headline.tsx +3 -0
  1634. package/src/components/Typography/Paragraph/Paragraph.module.css.d.ts.map +1 -0
  1635. package/src/components/Typography/Subhead/Subhead.module.css.d.ts.map +1 -0
  1636. package/src/components/Typography/Text/Text.module.css.d.ts.map +1 -0
  1637. package/src/components/Typography/Title/Title.module.css.d.ts.map +1 -0
  1638. package/src/components/Typography/Title/Title.tsx +3 -0
  1639. package/src/components/Typography/Typography.module.css.d.ts.map +1 -0
  1640. package/src/components/Typography/Typography.tsx +6 -3
  1641. package/src/components/UnstyledTextField/UnstyledTextField.module.css.d.ts.map +1 -0
  1642. package/src/components/UnstyledTextField/UnstyledTextField.tsx +6 -0
  1643. package/src/components/UsersStack/UsersStack.module.css.d.ts.map +1 -0
  1644. package/src/components/UsersStack/UsersStack.tsx +22 -4
  1645. package/src/components/View/View.module.css +1 -1
  1646. package/src/components/View/View.module.css.d.ts.map +1 -0
  1647. package/src/components/View/View.tsx +15 -4
  1648. package/src/components/View/ViewInfinite.tsx +18 -3
  1649. package/src/components/View/useLayoutEffectCall.tsx +1 -1
  1650. package/src/components/VisuallyHidden/VisuallyHidden.module.css.d.ts.map +1 -0
  1651. package/src/components/WriteBar/WriteBar.module.css.d.ts.map +1 -0
  1652. package/src/components/WriteBar/WriteBar.tsx +7 -5
  1653. package/src/components/WriteBarIcon/WriteBarIcon.module.css.d.ts.map +1 -0
  1654. package/src/components/WriteBarIcon/WriteBarIcon.tsx +2 -2
  1655. package/src/hooks/useCalendar.ts +9 -1
  1656. package/src/hooks/useDateInput.ts +66 -33
  1657. package/src/hooks/useFocusTrap.ts +29 -5
  1658. package/src/hooks/useLocale.ts +7 -0
  1659. package/src/index.ts +1 -0
  1660. package/src/lib/animation/useCSSTransition.stories.module.css.d.ts.map +1 -0
  1661. package/src/lib/calendar.ts +20 -3
  1662. package/src/lib/date.ts +6 -0
  1663. package/src/lib/dom.tsx +8 -0
  1664. package/src/lib/platform.ts +6 -3
  1665. package/src/lib/react/defineComponentDisplayNames.ts +6 -0
  1666. package/src/lib/tokens/TokensClassProvider.module.css.d.ts.map +1 -0
  1667. package/src/styles/adaptivity.module.css.d.ts.map +1 -0
  1668. package/src/styles/animationFades.module.css.d.ts.map +1 -0
  1669. package/src/styles/common.css.d.ts.map +1 -0
  1670. package/src/styles/constants.css +2 -2
  1671. package/src/styles/constants.css.d.ts.map +1 -0
  1672. package/src/styles/customMedias.generated.css.d.ts.map +1 -0
  1673. package/src/styles/dynamicTokens.css.d.ts.map +1 -0
  1674. package/src/styles/focusVisible.module.css.d.ts.map +1 -0
  1675. package/src/styles/gaps.module.css.d.ts.map +1 -0
  1676. package/src/styles/missedThemeTokens.css.d.ts.map +1 -0
  1677. package/src/styles/spacings.module.css.d.ts.map +1 -0
  1678. package/src/styles/themes.css.d.ts.map +1 -0
  1679. package/src/styles/transformOriginByPlacement.module.css.d.ts.map +1 -0
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/components/Checkbox/CheckboxInput/CheckboxInput.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport {\n Icon20CheckBoxIndetermanate,\n Icon20CheckBoxOff,\n Icon20CheckBoxOn,\n Icon24CheckBoxOff,\n Icon24CheckBoxOn,\n} from '@vkontakte/icons';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivityConditionalRender } from '../../../hooks/useAdaptivityConditionalRender';\nimport { useExternRef } from '../../../hooks/useExternRef';\nimport { usePlatform } from '../../../hooks/usePlatform';\nimport { warnOnce } from '../../../lib/warnOnce';\nimport type { HasRef, HasRootRef } from '../../../types';\nimport { RootComponent } from '../../RootComponent/RootComponent';\nimport { VisuallyHidden } from '../../VisuallyHidden/VisuallyHidden';\nimport styles from './CheckboxInput.module.css';\n\ntype VendorIconType = typeof Icon20CheckBoxOn;\n\nexport type CheckboxInputIconType =\n | React.ComponentType<React.SVGProps<SVGSVGElement>>\n | VendorIconType;\n\nfunction setIndeterminate(el: HTMLInputElement, indeterminate: boolean) {\n el.indeterminate = indeterminate;\n}\n\nexport interface CheckboxInputProps\n extends React.ComponentProps<'input'>,\n HasRootRef<HTMLDivElement>,\n HasRef<HTMLInputElement> {\n indeterminate?: boolean;\n defaultIndeterminate?: boolean;\n IconOnCompact?: CheckboxInputIconType;\n IconOnRegular?: CheckboxInputIconType;\n IconOffCompact?: CheckboxInputIconType;\n IconOffRegular?: CheckboxInputIconType;\n IconIndeterminate?: CheckboxInputIconType;\n}\n\nconst warn = warnOnce('Checkbox');\n\nexport function CheckboxInput({\n className,\n style,\n getRootRef,\n getRef,\n indeterminate,\n defaultIndeterminate,\n onChange,\n IconOnCompact = Icon20CheckBoxOn,\n IconOnRegular = Icon24CheckBoxOn,\n IconOffCompact = Icon20CheckBoxOff,\n IconOffRegular = Icon24CheckBoxOff,\n IconIndeterminate = Icon20CheckBoxIndetermanate,\n ...restProps\n}: CheckboxInputProps) {\n const inputRef = useExternRef(getRef);\n const platform = usePlatform();\n const { sizeY: adaptiveSizeY } = useAdaptivityConditionalRender();\n\n React.useEffect(() => {\n const indeterminateValue = indeterminate === undefined ? defaultIndeterminate : indeterminate;\n\n if (inputRef.current) {\n setIndeterminate(inputRef.current, Boolean(indeterminateValue));\n }\n }, [defaultIndeterminate, indeterminate, inputRef]);\n\n const handleChange = React.useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n if (\n defaultIndeterminate !== undefined &&\n indeterminate === undefined &&\n restProps.checked === undefined &&\n inputRef.current\n ) {\n setIndeterminate(inputRef.current, false);\n }\n if (indeterminate !== undefined && inputRef.current) {\n setIndeterminate(inputRef.current, Boolean(indeterminate));\n }\n onChange && onChange(event);\n },\n [defaultIndeterminate, indeterminate, restProps.checked, onChange, inputRef],\n );\n\n if (process.env.NODE_ENV === 'development') {\n if (defaultIndeterminate && restProps.defaultChecked) {\n warn('defaultIndeterminate и defaultChecked не могут быть true одновременно', 'error');\n }\n\n if (indeterminate && restProps.checked) {\n warn('indeterminate и checked не могут быть true одновременно', 'error');\n }\n\n if (restProps.defaultChecked && restProps.checked) {\n warn('defaultChecked и checked не могут быть true одновременно', 'error');\n }\n }\n\n return (\n <RootComponent\n baseClassName={styles.host}\n className={className}\n style={style}\n getRootRef={getRootRef}\n >\n <VisuallyHidden\n {...restProps}\n Component=\"input\"\n type=\"checkbox\"\n onChange={handleChange}\n className={styles.input}\n getRootRef={inputRef}\n />\n {platform === 'vkcom' ? (\n <IconOnCompact className={styles.iconOn} />\n ) : (\n <React.Fragment>\n {adaptiveSizeY.compact && (\n <IconOnCompact className={classNames(styles.iconOn, adaptiveSizeY.compact.className)} />\n )}\n {adaptiveSizeY.regular && (\n <IconOnRegular className={classNames(styles.iconOn, adaptiveSizeY.regular.className)} />\n )}\n </React.Fragment>\n )}\n {platform === 'vkcom' ? (\n <IconOffCompact className={styles.iconOff} />\n ) : (\n <React.Fragment>\n {adaptiveSizeY.compact && (\n <IconOffCompact\n className={classNames(styles.iconOff, adaptiveSizeY.compact.className)}\n />\n )}\n {adaptiveSizeY.regular && (\n <IconOffRegular\n className={classNames(styles.iconOff, adaptiveSizeY.regular.className)}\n />\n )}\n </React.Fragment>\n )}\n {platform === 'vkcom' ? (\n <IconIndeterminate width={20} height={20} className={styles.iconIndeterminate} />\n ) : (\n <React.Fragment>\n {adaptiveSizeY.compact && (\n <IconIndeterminate\n className={classNames(styles.iconIndeterminate, adaptiveSizeY.compact.className)}\n width={20}\n height={20}\n />\n )}\n {adaptiveSizeY.regular && (\n <IconIndeterminate\n className={classNames(styles.iconIndeterminate, adaptiveSizeY.regular.className)}\n width={24}\n height={24}\n />\n )}\n </React.Fragment>\n )}\n </RootComponent>\n );\n}\n"],"names":["React","Icon20CheckBoxIndetermanate","Icon20CheckBoxOff","Icon20CheckBoxOn","Icon24CheckBoxOff","Icon24CheckBoxOn","classNames","useAdaptivityConditionalRender","useExternRef","usePlatform","warnOnce","RootComponent","VisuallyHidden","styles","setIndeterminate","el","indeterminate","warn","CheckboxInput","className","style","getRootRef","getRef","defaultIndeterminate","onChange","IconOnCompact","IconOnRegular","IconOffCompact","IconOffRegular","IconIndeterminate","restProps","inputRef","platform","sizeY","adaptiveSizeY","useEffect","indeterminateValue","undefined","current","Boolean","handleChange","useCallback","event","checked","process","env","NODE_ENV","defaultChecked","baseClassName","host","Component","type","input","iconOn","Fragment","compact","regular","iconOff","width","height","iconIndeterminate"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../../../src/components/Checkbox/CheckboxInput/CheckboxInput.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport {\n Icon20CheckBoxIndetermanate,\n Icon20CheckBoxOff,\n Icon20CheckBoxOn,\n Icon24CheckBoxOff,\n Icon24CheckBoxOn,\n} from '@vkontakte/icons';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivityConditionalRender } from '../../../hooks/useAdaptivityConditionalRender';\nimport { useExternRef } from '../../../hooks/useExternRef';\nimport { usePlatform } from '../../../hooks/usePlatform';\nimport { warnOnce } from '../../../lib/warnOnce';\nimport type { HasRef, HasRootRef } from '../../../types';\nimport { RootComponent } from '../../RootComponent/RootComponent';\nimport { VisuallyHidden } from '../../VisuallyHidden/VisuallyHidden';\nimport styles from './CheckboxInput.module.css';\n\ntype VendorIconType = typeof Icon20CheckBoxOn;\n\nexport type CheckboxInputIconType =\n | React.ComponentType<React.SVGProps<SVGSVGElement>>\n | VendorIconType;\n\nfunction setIndeterminate(el: HTMLInputElement, indeterminate: boolean) {\n el.indeterminate = indeterminate;\n}\n\nexport interface CheckboxInputProps\n extends React.ComponentProps<'input'>,\n HasRootRef<HTMLDivElement>,\n HasRef<HTMLInputElement> {\n /**\n * Неопределенное состояние чекбокса.\n */\n indeterminate?: boolean;\n /**\n * Неопределенное состояние чекбокса по умолчанию.\n */\n defaultIndeterminate?: boolean;\n /**\n * Иконка для включенного состояния в компактном режиме.\n */\n IconOnCompact?: CheckboxInputIconType;\n /**\n * Иконка для включенного состояния в обычном режиме.\n */\n IconOnRegular?: CheckboxInputIconType;\n /**\n * Иконка для выключенного состояния в компактном режиме.\n */\n IconOffCompact?: CheckboxInputIconType;\n /**\n * Иконка для выключенного состояния в обычном режиме.\n */\n IconOffRegular?: CheckboxInputIconType;\n /**\n * Иконка для неопределенного состояния.\n */\n IconIndeterminate?: CheckboxInputIconType;\n}\n\nconst warn = warnOnce('Checkbox');\n\nexport function CheckboxInput({\n className,\n style,\n getRootRef,\n getRef,\n indeterminate,\n defaultIndeterminate,\n onChange,\n IconOnCompact = Icon20CheckBoxOn,\n IconOnRegular = Icon24CheckBoxOn,\n IconOffCompact = Icon20CheckBoxOff,\n IconOffRegular = Icon24CheckBoxOff,\n IconIndeterminate = Icon20CheckBoxIndetermanate,\n ...restProps\n}: CheckboxInputProps) {\n const inputRef = useExternRef(getRef);\n const platform = usePlatform();\n const { sizeY: adaptiveSizeY } = useAdaptivityConditionalRender();\n\n React.useEffect(() => {\n const indeterminateValue = indeterminate === undefined ? defaultIndeterminate : indeterminate;\n\n if (inputRef.current) {\n setIndeterminate(inputRef.current, Boolean(indeterminateValue));\n }\n }, [defaultIndeterminate, indeterminate, inputRef]);\n\n const handleChange = React.useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n if (\n defaultIndeterminate !== undefined &&\n indeterminate === undefined &&\n restProps.checked === undefined &&\n inputRef.current\n ) {\n setIndeterminate(inputRef.current, false);\n }\n if (indeterminate !== undefined && inputRef.current) {\n setIndeterminate(inputRef.current, Boolean(indeterminate));\n }\n onChange && onChange(event);\n },\n [defaultIndeterminate, indeterminate, restProps.checked, onChange, inputRef],\n );\n\n if (process.env.NODE_ENV === 'development') {\n if (defaultIndeterminate && restProps.defaultChecked) {\n warn('defaultIndeterminate и defaultChecked не могут быть true одновременно', 'error');\n }\n\n if (indeterminate && restProps.checked) {\n warn('indeterminate и checked не могут быть true одновременно', 'error');\n }\n\n if (restProps.defaultChecked && restProps.checked) {\n warn('defaultChecked и checked не могут быть true одновременно', 'error');\n }\n }\n\n return (\n <RootComponent\n baseClassName={styles.host}\n className={className}\n style={style}\n getRootRef={getRootRef}\n >\n <VisuallyHidden\n {...restProps}\n Component=\"input\"\n type=\"checkbox\"\n onChange={handleChange}\n className={styles.input}\n getRootRef={inputRef}\n />\n {platform === 'vkcom' ? (\n <IconOnCompact className={styles.iconOn} />\n ) : (\n <React.Fragment>\n {adaptiveSizeY.compact && (\n <IconOnCompact className={classNames(styles.iconOn, adaptiveSizeY.compact.className)} />\n )}\n {adaptiveSizeY.regular && (\n <IconOnRegular className={classNames(styles.iconOn, adaptiveSizeY.regular.className)} />\n )}\n </React.Fragment>\n )}\n {platform === 'vkcom' ? (\n <IconOffCompact className={styles.iconOff} />\n ) : (\n <React.Fragment>\n {adaptiveSizeY.compact && (\n <IconOffCompact\n className={classNames(styles.iconOff, adaptiveSizeY.compact.className)}\n />\n )}\n {adaptiveSizeY.regular && (\n <IconOffRegular\n className={classNames(styles.iconOff, adaptiveSizeY.regular.className)}\n />\n )}\n </React.Fragment>\n )}\n {platform === 'vkcom' ? (\n <IconIndeterminate width={20} height={20} className={styles.iconIndeterminate} />\n ) : (\n <React.Fragment>\n {adaptiveSizeY.compact && (\n <IconIndeterminate\n className={classNames(styles.iconIndeterminate, adaptiveSizeY.compact.className)}\n width={20}\n height={20}\n />\n )}\n {adaptiveSizeY.regular && (\n <IconIndeterminate\n className={classNames(styles.iconIndeterminate, adaptiveSizeY.regular.className)}\n width={24}\n height={24}\n />\n )}\n </React.Fragment>\n )}\n </RootComponent>\n );\n}\n"],"names":["React","Icon20CheckBoxIndetermanate","Icon20CheckBoxOff","Icon20CheckBoxOn","Icon24CheckBoxOff","Icon24CheckBoxOn","classNames","useAdaptivityConditionalRender","useExternRef","usePlatform","warnOnce","RootComponent","VisuallyHidden","styles","setIndeterminate","el","indeterminate","warn","CheckboxInput","className","style","getRootRef","getRef","defaultIndeterminate","onChange","IconOnCompact","IconOnRegular","IconOffCompact","IconOffRegular","IconIndeterminate","restProps","inputRef","platform","sizeY","adaptiveSizeY","useEffect","indeterminateValue","undefined","current","Boolean","handleChange","useCallback","event","checked","process","env","NODE_ENV","defaultChecked","baseClassName","host","Component","type","input","iconOn","Fragment","compact","regular","iconOff","width","height","iconIndeterminate"],"mappings":"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"}
@@ -8,7 +8,7 @@ import { useChipsInput } from "./useChipsInput.js";
8
8
  */ export const ChipsInput = ({ // option
9
9
  value: valueProp, defaultValue, onChange, // input
10
10
  getRef, inputValue: inputValueProp, defaultInputValue: inputDefaultValueProp, onInputChange: onInputChangeProp, getOptionValue, getOptionLabel, getNewOptionData, // other
11
- disabled, allowClearButton, ...restProps })=>{
11
+ disabled, allowClearButton, delimiter, ...restProps })=>{
12
12
  const { value, addOptionFromInput, removeOption, clearOptions, // input
13
13
  inputRef: inputRefHook, inputValue, onInputChange } = useChipsInput({
14
14
  // option
@@ -23,7 +23,8 @@ disabled, allowClearButton, ...restProps })=>{
23
23
  defaultInputValue: inputDefaultValueProp,
24
24
  onInputChange: onInputChangeProp,
25
25
  // other
26
- disabled
26
+ disabled,
27
+ delimiter
27
28
  });
28
29
  const inputRef = useExternRef(getRef, inputRefHook);
29
30
  return /*#__PURE__*/ _jsx(ChipsInputBase, {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ChipsInput/ChipsInput.tsx"],"sourcesContent":["'use client';\n\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { ChipsInputBase } from '../ChipsInputBase/ChipsInputBase';\nimport type { ChipOption, ChipsInputBaseProps } from '../ChipsInputBase/types';\nimport type { FormFieldProps } from '../FormField/FormField';\nimport { useChipsInput, type UseChipsInputProps } from './useChipsInput';\n\nexport interface ChipsInputProps<Option extends ChipOption>\n extends ChipsInputBaseProps<Option>,\n UseChipsInputProps<Option>,\n Pick<FormFieldProps, 'status' | 'mode' | 'before' | 'after' | 'maxHeight'> {\n /**\n * Если `true`, то справа будет отображаться кнопка для очистки значения\n */\n allowClearButton?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ChipsInput\n */\nexport const ChipsInput = <Option extends ChipOption>({\n // option\n value: valueProp,\n defaultValue,\n onChange,\n\n // input\n getRef,\n inputValue: inputValueProp,\n defaultInputValue: inputDefaultValueProp,\n onInputChange: onInputChangeProp,\n getOptionValue,\n getOptionLabel,\n getNewOptionData,\n\n // other\n disabled,\n allowClearButton,\n ...restProps\n}: ChipsInputProps<Option>): React.ReactNode => {\n const {\n value,\n addOptionFromInput,\n removeOption,\n clearOptions,\n\n // input\n inputRef: inputRefHook,\n inputValue,\n onInputChange,\n } = useChipsInput({\n // option\n value: valueProp,\n defaultValue,\n onChange,\n getOptionLabel,\n getOptionValue,\n getNewOptionData,\n\n // input\n inputValue: inputValueProp,\n defaultInputValue: inputDefaultValueProp,\n onInputChange: onInputChangeProp,\n\n // other\n disabled,\n });\n const inputRef = useExternRef(getRef, inputRefHook);\n\n return (\n <ChipsInputBase\n {...restProps}\n disabled={disabled}\n value={value}\n clearButtonShown={allowClearButton && (!!value.length || !!inputValue.length)}\n onAddChipOption={addOptionFromInput}\n onRemoveChipOption={removeOption}\n onClear={clearOptions}\n getRef={inputRef}\n inputValue={inputValue}\n onInputChange={onInputChange}\n />\n );\n};\n"],"names":["useExternRef","ChipsInputBase","useChipsInput","ChipsInput","value","valueProp","defaultValue","onChange","getRef","inputValue","inputValueProp","defaultInputValue","inputDefaultValueProp","onInputChange","onInputChangeProp","getOptionValue","getOptionLabel","getNewOptionData","disabled","allowClearButton","restProps","addOptionFromInput","removeOption","clearOptions","inputRef","inputRefHook","clearButtonShown","length","onAddChipOption","onRemoveChipOption","onClear"],"mappings":"AAAA;;AAEA,SAASA,YAAY,QAAQ,8BAA2B;AACxD,SAASC,cAAc,QAAQ,sCAAmC;AAGlE,SAASC,aAAa,QAAiC,qBAAkB;AAYzE;;CAEC,GACD,OAAO,MAAMC,aAAa,CAA4B,EACpD,SAAS;AACTC,OAAOC,SAAS,EAChBC,YAAY,EACZC,QAAQ,EAER,QAAQ;AACRC,MAAM,EACNC,YAAYC,cAAc,EAC1BC,mBAAmBC,qBAAqB,EACxCC,eAAeC,iBAAiB,EAChCC,cAAc,EACdC,cAAc,EACdC,gBAAgB,EAEhB,QAAQ;AACRC,QAAQ,EACRC,gBAAgB,EAChB,GAAGC,WACqB;IACxB,MAAM,EACJhB,KAAK,EACLiB,kBAAkB,EAClBC,YAAY,EACZC,YAAY,EAEZ,QAAQ;IACRC,UAAUC,YAAY,EACtBhB,UAAU,EACVI,aAAa,EACd,GAAGX,cAAc;QAChB,SAAS;QACTE,OAAOC;QACPC;QACAC;QACAS;QACAD;QACAE;QAEA,QAAQ;QACRR,YAAYC;QACZC,mBAAmBC;QACnBC,eAAeC;QAEf,QAAQ;QACRI;IACF;IACA,MAAMM,WAAWxB,aAAaQ,QAAQiB;IAEtC,qBACE,KAACxB;QACE,GAAGmB,SAAS;QACbF,UAAUA;QACVd,OAAOA;QACPsB,kBAAkBP,oBAAqB,CAAA,CAAC,CAACf,MAAMuB,MAAM,IAAI,CAAC,CAAClB,WAAWkB,MAAM,AAAD;QAC3EC,iBAAiBP;QACjBQ,oBAAoBP;QACpBQ,SAASP;QACTf,QAAQgB;QACRf,YAAYA;QACZI,eAAeA;;AAGrB,EAAE"}
1
+ {"version":3,"sources":["../../../../src/components/ChipsInput/ChipsInput.tsx"],"sourcesContent":["'use client';\n\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { ChipsInputBase } from '../ChipsInputBase/ChipsInputBase';\nimport type { ChipOption, ChipsInputBaseProps } from '../ChipsInputBase/types';\nimport type { FormFieldProps } from '../FormField/FormField';\nimport { useChipsInput, type UseChipsInputProps } from './useChipsInput';\n\nexport interface ChipsInputProps<Option extends ChipOption>\n extends ChipsInputBaseProps<Option>,\n UseChipsInputProps<Option>,\n Pick<FormFieldProps, 'status' | 'mode' | 'before' | 'after' | 'maxHeight'> {\n /**\n * Если `true`, то справа будет отображаться кнопка для очистки значения.\n */\n allowClearButton?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ChipsInput\n */\nexport const ChipsInput = <Option extends ChipOption>({\n // option\n value: valueProp,\n defaultValue,\n onChange,\n\n // input\n getRef,\n inputValue: inputValueProp,\n defaultInputValue: inputDefaultValueProp,\n onInputChange: onInputChangeProp,\n getOptionValue,\n getOptionLabel,\n getNewOptionData,\n\n // other\n disabled,\n allowClearButton,\n delimiter,\n ...restProps\n}: ChipsInputProps<Option>): React.ReactNode => {\n const {\n value,\n addOptionFromInput,\n removeOption,\n clearOptions,\n\n // input\n inputRef: inputRefHook,\n inputValue,\n onInputChange,\n } = useChipsInput({\n // option\n value: valueProp,\n defaultValue,\n onChange,\n getOptionLabel,\n getOptionValue,\n getNewOptionData,\n\n // input\n inputValue: inputValueProp,\n defaultInputValue: inputDefaultValueProp,\n onInputChange: onInputChangeProp,\n\n // other\n disabled,\n delimiter,\n });\n const inputRef = useExternRef(getRef, inputRefHook);\n\n return (\n <ChipsInputBase\n {...restProps}\n disabled={disabled}\n value={value}\n clearButtonShown={allowClearButton && (!!value.length || !!inputValue.length)}\n onAddChipOption={addOptionFromInput}\n onRemoveChipOption={removeOption}\n onClear={clearOptions}\n getRef={inputRef}\n inputValue={inputValue}\n onInputChange={onInputChange}\n />\n );\n};\n"],"names":["useExternRef","ChipsInputBase","useChipsInput","ChipsInput","value","valueProp","defaultValue","onChange","getRef","inputValue","inputValueProp","defaultInputValue","inputDefaultValueProp","onInputChange","onInputChangeProp","getOptionValue","getOptionLabel","getNewOptionData","disabled","allowClearButton","delimiter","restProps","addOptionFromInput","removeOption","clearOptions","inputRef","inputRefHook","clearButtonShown","length","onAddChipOption","onRemoveChipOption","onClear"],"mappings":"AAAA;;AAEA,SAASA,YAAY,QAAQ,8BAA2B;AACxD,SAASC,cAAc,QAAQ,sCAAmC;AAGlE,SAASC,aAAa,QAAiC,qBAAkB;AAYzE;;CAEC,GACD,OAAO,MAAMC,aAAa,CAA4B,EACpD,SAAS;AACTC,OAAOC,SAAS,EAChBC,YAAY,EACZC,QAAQ,EAER,QAAQ;AACRC,MAAM,EACNC,YAAYC,cAAc,EAC1BC,mBAAmBC,qBAAqB,EACxCC,eAAeC,iBAAiB,EAChCC,cAAc,EACdC,cAAc,EACdC,gBAAgB,EAEhB,QAAQ;AACRC,QAAQ,EACRC,gBAAgB,EAChBC,SAAS,EACT,GAAGC,WACqB;IACxB,MAAM,EACJjB,KAAK,EACLkB,kBAAkB,EAClBC,YAAY,EACZC,YAAY,EAEZ,QAAQ;IACRC,UAAUC,YAAY,EACtBjB,UAAU,EACVI,aAAa,EACd,GAAGX,cAAc;QAChB,SAAS;QACTE,OAAOC;QACPC;QACAC;QACAS;QACAD;QACAE;QAEA,QAAQ;QACRR,YAAYC;QACZC,mBAAmBC;QACnBC,eAAeC;QAEf,QAAQ;QACRI;QACAE;IACF;IACA,MAAMK,WAAWzB,aAAaQ,QAAQkB;IAEtC,qBACE,KAACzB;QACE,GAAGoB,SAAS;QACbH,UAAUA;QACVd,OAAOA;QACPuB,kBAAkBR,oBAAqB,CAAA,CAAC,CAACf,MAAMwB,MAAM,IAAI,CAAC,CAACnB,WAAWmB,MAAM,AAAD;QAC3EC,iBAAiBP;QACjBQ,oBAAoBP;QACpBQ,SAASP;QACThB,QAAQiB;QACRhB,YAAYA;QACZI,eAAeA;;AAGrB,EAAE"}
@@ -11,8 +11,8 @@ export const transformValue = (value, getOptionValue, getOptionLabel)=>value.map
11
11
  }));
12
12
  export const useChipsInput = ({ // option
13
13
  value: valueProp, defaultValue = DEFAULT_VALUE, onChange, getOptionLabel = getOptionLabelDefault, getOptionValue = getOptionValueDefault, getNewOptionData = getNewOptionDataDefault, // input
14
- inputValue: inputValueProp, defaultInputValue = DEFAULT_INPUT_VALUE, onInputChange, // other
15
- disabled })=>{
14
+ inputValue: inputValueProp, defaultInputValue = DEFAULT_INPUT_VALUE, onInputChange: onInputChangeProp, // other
15
+ disabled, delimiter })=>{
16
16
  const [value, setValue] = useCustomEnsuredControl({
17
17
  disabled,
18
18
  value: valueProp ? transformValue(valueProp, getOptionValue, getOptionLabel) : undefined,
@@ -24,18 +24,20 @@ disabled })=>{
24
24
  disabled,
25
25
  value: inputValueProp,
26
26
  defaultValue: defaultInputValue,
27
- onChange: onInputChange
27
+ onChange: onInputChangeProp
28
28
  });
29
- const toggleOption = React.useCallback((nextValueProp, isNewValue)=>{
29
+ const toggleOption = React.useCallback((nextValuesProp, isNewValue)=>{
30
30
  setValue((prevValue)=>{
31
- const isLikeObjectOption = isValueLikeChipOptionObject(nextValueProp);
32
- const resolvedOption = isLikeObjectOption ? getNewOptionData(nextValueProp.value, nextValueProp.label) : getNewOptionData(nextValueProp, typeof nextValueProp === 'string' ? nextValueProp : '');
33
- const nextValue = prevValue.filter((option)=>resolvedOption.value !== option.value);
34
- if (isNewValue === true) {
35
- nextValue.push(isLikeObjectOption ? {
36
- ...nextValueProp,
37
- ...resolvedOption
38
- } : resolvedOption);
31
+ const resolvedNextOptionsSet = new Set();
32
+ const resolvedNextOptions = nextValuesProp.map((option)=>{
33
+ const isLikeObjectOption = isValueLikeChipOptionObject(option);
34
+ const resolvedOption = isLikeObjectOption ? getNewOptionData(option.value, option.label) : getNewOptionData(option, typeof option === 'string' ? option : '');
35
+ resolvedNextOptionsSet.add(resolvedOption.value);
36
+ return resolvedOption;
37
+ });
38
+ const nextValue = prevValue.filter((option)=>!resolvedNextOptionsSet.has(option.value));
39
+ if (isNewValue) {
40
+ nextValue.push(...resolvedNextOptions);
39
41
  }
40
42
  return nextValue;
41
43
  });
@@ -51,10 +53,17 @@ disabled })=>{
51
53
  }, [
52
54
  inputRef
53
55
  ]);
54
- const addOption = React.useCallback((newValue)=>toggleOption(newValue, true), [
56
+ const addOption = React.useCallback((newValue)=>toggleOption([
57
+ newValue
58
+ ], true), [
55
59
  toggleOption
56
60
  ]);
57
- const removeOption = React.useCallback((newValue)=>toggleOption(newValue, false), [
61
+ const addOptions = React.useCallback((newValues)=>toggleOption(newValues, true), [
62
+ toggleOption
63
+ ]);
64
+ const removeOption = React.useCallback((newValue)=>toggleOption([
65
+ newValue
66
+ ], false), [
58
67
  toggleOption
59
68
  ]);
60
69
  const addOptionFromInput = React.useCallback((inputValue)=>{
@@ -80,6 +89,22 @@ disabled })=>{
80
89
  clearInput,
81
90
  setValue
82
91
  ]);
92
+ const onInputChange = React.useCallback((e, canCreate = true)=>{
93
+ const newInputValue = e.target.value;
94
+ if (!delimiter || !newInputValue.includes(delimiter) || !canCreate) {
95
+ setInputChange(e);
96
+ return;
97
+ }
98
+ const values = newInputValue.trim().split(delimiter).map((v)=>v.trim()).filter(Boolean);
99
+ e.target.value = '';
100
+ e.currentTarget.value = '';
101
+ setInputChange(e);
102
+ addOptions(values);
103
+ }, [
104
+ addOptions,
105
+ delimiter,
106
+ setInputChange
107
+ ]);
83
108
  useNativeFormResetListener(inputRef, reset);
84
109
  return {
85
110
  value,
@@ -88,7 +113,7 @@ disabled })=>{
88
113
  removeOption,
89
114
  inputRef,
90
115
  inputValue,
91
- onInputChange: setInputChange,
116
+ onInputChange,
92
117
  clearInput,
93
118
  clearOptions
94
119
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ChipsInput/useChipsInput.ts"],"sourcesContent":["import * as React from 'react';\nimport { useCustomEnsuredControl, useEnsuredControl } from '../../hooks/useEnsuredControl';\nimport { useNativeFormResetListener } from '../../hooks/useNativeFormResetListener';\nimport { simulateReactInput, type SimulateReactInputTargetState } from '../../lib/react';\nimport {\n DEFAULT_INPUT_VALUE,\n DEFAULT_VALUE,\n getNewOptionDataDefault,\n getOptionLabelDefault,\n getOptionValueDefault,\n} from '../ChipsInputBase/constants';\nimport { isValueLikeChipOptionObject } from '../ChipsInputBase/helpers';\nimport type {\n ChipOption,\n ChipOptionLabel,\n ChipOptionValue,\n GetNewOptionData,\n GetOptionLabel,\n GetOptionValue,\n UseChipsInputBaseProps,\n} from '../ChipsInputBase/types';\n\nexport const transformValue = <O extends ChipOption>(\n value: O[],\n getOptionValue: GetOptionValue<O>,\n getOptionLabel: GetOptionLabel<O>,\n): Array<\n O & {\n label: ChipOptionLabel;\n value: ChipOptionValue;\n }\n> =>\n value.map((option) => ({\n ...option,\n label: getOptionLabel(option),\n value: getOptionValue(option),\n }));\n\ninterface ToggleOption<O extends ChipOption> {\n (optionForAdd: O | string, isNewValue: true): void;\n (optionForRemove: O | ChipOptionValue, isNewValue: false): void;\n}\n\nexport interface UseChipsInputProps<O extends ChipOption = ChipOption>\n extends UseChipsInputBaseProps<O> {\n /**\n * Селектор значения.\n */\n getOptionValue?: GetOptionValue<O>;\n /**\n * Селектор пользовательского представления.\n */\n getOptionLabel?: GetOptionLabel<O>;\n /**\n * Функция для создания новой опции.\n */\n getNewOptionData?: GetNewOptionData<O>;\n}\n\nexport const useChipsInput = <O extends ChipOption>({\n // option\n value: valueProp,\n defaultValue = DEFAULT_VALUE,\n onChange,\n getOptionLabel = getOptionLabelDefault,\n getOptionValue = getOptionValueDefault,\n getNewOptionData = getNewOptionDataDefault,\n\n // input\n inputValue: inputValueProp,\n defaultInputValue = DEFAULT_INPUT_VALUE,\n onInputChange,\n\n // other\n disabled,\n}: UseChipsInputProps<O>): {\n value: Array<\n O & {\n label: ChipOptionLabel;\n value: ChipOptionValue;\n }\n >;\n addOption: (newValue: O | string) => void;\n addOptionFromInput: (inputValue: string) => void;\n removeOption: (newValue: O | ChipOptionValue) => void;\n clearOptions: () => void;\n inputRef: React.RefObject<(HTMLInputElement & SimulateReactInputTargetState) | null>;\n inputValue: string;\n onInputChange: (e: React.ChangeEvent<HTMLInputElement>) => any;\n clearInput: () => void;\n} => {\n const [value, setValue] = useCustomEnsuredControl({\n disabled,\n value: valueProp ? transformValue(valueProp, getOptionValue, getOptionLabel) : undefined,\n defaultValue: transformValue(defaultValue, getOptionValue, getOptionLabel),\n onChange,\n });\n\n const inputRef = React.useRef<(HTMLInputElement & SimulateReactInputTargetState) | null>(null);\n const [inputValue, setInputChange] = useEnsuredControl({\n disabled,\n value: inputValueProp,\n defaultValue: defaultInputValue,\n onChange: onInputChange,\n });\n\n const toggleOption: ToggleOption<O> = React.useCallback(\n (nextValueProp: O | ChipOptionValue, isNewValue: boolean) => {\n setValue((prevValue) => {\n const isLikeObjectOption = isValueLikeChipOptionObject(nextValueProp);\n const resolvedOption = isLikeObjectOption\n ? getNewOptionData(nextValueProp.value, nextValueProp.label)\n : getNewOptionData(nextValueProp, typeof nextValueProp === 'string' ? nextValueProp : '');\n const nextValue = prevValue.filter((option: O) => resolvedOption.value !== option.value);\n\n if (isNewValue === true) {\n nextValue.push(\n isLikeObjectOption ? { ...nextValueProp, ...resolvedOption } : resolvedOption,\n );\n }\n\n return nextValue;\n });\n },\n [setValue, getNewOptionData],\n );\n\n const clearInput = React.useCallback(() => {\n /* istanbul ignore if */\n if (!inputRef.current) {\n return;\n }\n simulateReactInput(inputRef.current, '');\n }, [inputRef]);\n\n const addOption = React.useCallback(\n (newValue: O | string) => toggleOption(newValue, true),\n [toggleOption],\n );\n\n const removeOption = React.useCallback(\n (newValue: O | ChipOptionValue) => toggleOption(newValue, false),\n [toggleOption],\n );\n\n const addOptionFromInput = React.useCallback(\n (inputValue: string) => {\n const label = inputValue.trim();\n if (label) {\n addOption(label);\n clearInput();\n }\n },\n [addOption, clearInput],\n );\n\n const reset = React.useCallback(() => {\n setValue(defaultValue);\n }, [defaultValue, setValue]);\n\n const clearOptions = React.useCallback(() => {\n setValue(DEFAULT_VALUE);\n clearInput();\n }, [clearInput, setValue]);\n\n useNativeFormResetListener(inputRef, reset);\n\n return {\n value,\n addOption,\n addOptionFromInput,\n removeOption,\n\n inputRef,\n inputValue,\n onInputChange: setInputChange,\n clearInput,\n clearOptions,\n };\n};\n"],"names":["React","useCustomEnsuredControl","useEnsuredControl","useNativeFormResetListener","simulateReactInput","DEFAULT_INPUT_VALUE","DEFAULT_VALUE","getNewOptionDataDefault","getOptionLabelDefault","getOptionValueDefault","isValueLikeChipOptionObject","transformValue","value","getOptionValue","getOptionLabel","map","option","label","useChipsInput","valueProp","defaultValue","onChange","getNewOptionData","inputValue","inputValueProp","defaultInputValue","onInputChange","disabled","setValue","undefined","inputRef","useRef","setInputChange","toggleOption","useCallback","nextValueProp","isNewValue","prevValue","isLikeObjectOption","resolvedOption","nextValue","filter","push","clearInput","current","addOption","newValue","removeOption","addOptionFromInput","trim","reset","clearOptions"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/components/ChipsInput/useChipsInput.ts"],"sourcesContent":["import * as React from 'react';\nimport { useCustomEnsuredControl, useEnsuredControl } from '../../hooks/useEnsuredControl';\nimport { useNativeFormResetListener } from '../../hooks/useNativeFormResetListener';\nimport { simulateReactInput, type SimulateReactInputTargetState } from '../../lib/react';\nimport {\n DEFAULT_INPUT_VALUE,\n DEFAULT_VALUE,\n getNewOptionDataDefault,\n getOptionLabelDefault,\n getOptionValueDefault,\n} from '../ChipsInputBase/constants';\nimport { isValueLikeChipOptionObject } from '../ChipsInputBase/helpers';\nimport type {\n ChipOption,\n ChipOptionLabel,\n ChipOptionValue,\n GetNewOptionData,\n GetOptionLabel,\n GetOptionValue,\n UseChipsInputBaseProps,\n} from '../ChipsInputBase/types';\n\nexport const transformValue = <O extends ChipOption>(\n value: O[],\n getOptionValue: GetOptionValue<O>,\n getOptionLabel: GetOptionLabel<O>,\n): Array<\n O & {\n label: ChipOptionLabel;\n value: ChipOptionValue;\n }\n> =>\n value.map((option) => ({\n ...option,\n label: getOptionLabel(option),\n value: getOptionValue(option),\n }));\n\ninterface ToggleOption<O extends ChipOption> {\n (optionsForAdd: Array<O | string>, isNewValue: true): void;\n (optionsForRemove: Array<O | ChipOptionValue>, isNewValue: false): void;\n}\n\nexport interface UseChipsInputProps<O extends ChipOption = ChipOption>\n extends UseChipsInputBaseProps<O> {\n /**\n * Селектор значения.\n */\n getOptionValue?: GetOptionValue<O>;\n /**\n * Селектор пользовательского представления.\n */\n getOptionLabel?: GetOptionLabel<O>;\n /**\n * Функция для создания новой опции.\n */\n getNewOptionData?: GetNewOptionData<O>;\n}\n\nexport const useChipsInput = <O extends ChipOption>({\n // option\n value: valueProp,\n defaultValue = DEFAULT_VALUE,\n onChange,\n getOptionLabel = getOptionLabelDefault,\n getOptionValue = getOptionValueDefault,\n getNewOptionData = getNewOptionDataDefault,\n\n // input\n inputValue: inputValueProp,\n defaultInputValue = DEFAULT_INPUT_VALUE,\n onInputChange: onInputChangeProp,\n\n // other\n disabled,\n delimiter,\n}: UseChipsInputProps<O>): {\n value: Array<\n O & {\n label: ChipOptionLabel;\n value: ChipOptionValue;\n }\n >;\n addOption: (newValue: O | string) => void;\n addOptionFromInput: (inputValue: string) => void;\n removeOption: (newValue: O | ChipOptionValue) => void;\n clearOptions: () => void;\n inputRef: React.RefObject<(HTMLInputElement & SimulateReactInputTargetState) | null>;\n inputValue: string;\n onInputChange: (e: React.ChangeEvent<HTMLInputElement>, canCreate?: boolean) => any;\n clearInput: () => void;\n} => {\n const [value, setValue] = useCustomEnsuredControl({\n disabled,\n value: valueProp ? transformValue(valueProp, getOptionValue, getOptionLabel) : undefined,\n defaultValue: transformValue(defaultValue, getOptionValue, getOptionLabel),\n onChange,\n });\n\n const inputRef = React.useRef<(HTMLInputElement & SimulateReactInputTargetState) | null>(null);\n const [inputValue, setInputChange] = useEnsuredControl({\n disabled,\n value: inputValueProp,\n defaultValue: defaultInputValue,\n onChange: onInputChangeProp,\n });\n\n const toggleOption: ToggleOption<O> = React.useCallback(\n (nextValuesProp: Array<O | ChipOptionValue>, isNewValue: boolean) => {\n setValue((prevValue) => {\n const resolvedNextOptionsSet = new Set<ChipOptionValue>();\n const resolvedNextOptions = nextValuesProp.map((option) => {\n const isLikeObjectOption = isValueLikeChipOptionObject(option);\n const resolvedOption = isLikeObjectOption\n ? getNewOptionData(option.value, option.label)\n : getNewOptionData(option, typeof option === 'string' ? option : '');\n resolvedNextOptionsSet.add(resolvedOption.value);\n return resolvedOption;\n });\n\n const nextValue = prevValue.filter(\n (option: O) => !resolvedNextOptionsSet.has(option.value),\n );\n\n if (isNewValue) {\n nextValue.push(...resolvedNextOptions);\n }\n\n return nextValue;\n });\n },\n [setValue, getNewOptionData],\n );\n\n const clearInput = React.useCallback(() => {\n /* istanbul ignore if */\n if (!inputRef.current) {\n return;\n }\n simulateReactInput(inputRef.current, '');\n }, [inputRef]);\n\n const addOption = React.useCallback(\n (newValue: O | string) => toggleOption([newValue], true),\n [toggleOption],\n );\n\n const addOptions = React.useCallback(\n (newValues: Array<O | string>) => toggleOption(newValues, true),\n [toggleOption],\n );\n\n const removeOption = React.useCallback(\n (newValue: O | ChipOptionValue) => toggleOption([newValue], false),\n [toggleOption],\n );\n\n const addOptionFromInput = React.useCallback(\n (inputValue: string) => {\n const label = inputValue.trim();\n if (label) {\n addOption(label);\n clearInput();\n }\n },\n [addOption, clearInput],\n );\n\n const reset = React.useCallback(() => {\n setValue(defaultValue);\n }, [defaultValue, setValue]);\n\n const clearOptions = React.useCallback(() => {\n setValue(DEFAULT_VALUE);\n clearInput();\n }, [clearInput, setValue]);\n\n const onInputChange = React.useCallback(\n (e: React.ChangeEvent<HTMLInputElement>, canCreate = true) => {\n const newInputValue = e.target.value;\n if (!delimiter || !newInputValue.includes(delimiter) || !canCreate) {\n setInputChange(e);\n return;\n }\n const values = newInputValue\n .trim()\n .split(delimiter)\n .map((v) => v.trim())\n .filter(Boolean);\n\n e.target.value = '';\n e.currentTarget.value = '';\n setInputChange(e);\n\n addOptions(values);\n },\n [addOptions, delimiter, setInputChange],\n );\n\n useNativeFormResetListener(inputRef, reset);\n\n return {\n value,\n addOption,\n addOptionFromInput,\n removeOption,\n\n inputRef,\n inputValue,\n onInputChange,\n clearInput,\n clearOptions,\n };\n};\n"],"names":["React","useCustomEnsuredControl","useEnsuredControl","useNativeFormResetListener","simulateReactInput","DEFAULT_INPUT_VALUE","DEFAULT_VALUE","getNewOptionDataDefault","getOptionLabelDefault","getOptionValueDefault","isValueLikeChipOptionObject","transformValue","value","getOptionValue","getOptionLabel","map","option","label","useChipsInput","valueProp","defaultValue","onChange","getNewOptionData","inputValue","inputValueProp","defaultInputValue","onInputChange","onInputChangeProp","disabled","delimiter","setValue","undefined","inputRef","useRef","setInputChange","toggleOption","useCallback","nextValuesProp","isNewValue","prevValue","resolvedNextOptionsSet","Set","resolvedNextOptions","isLikeObjectOption","resolvedOption","add","nextValue","filter","has","push","clearInput","current","addOption","newValue","addOptions","newValues","removeOption","addOptionFromInput","trim","reset","clearOptions","e","canCreate","newInputValue","target","includes","values","split","v","Boolean","currentTarget"],"mappings":"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"}
@@ -183,6 +183,7 @@ ClearButton = FormFieldClearButton, clearButtonShown, clearButtonTestId, onClear
183
183
  // чтобы можно было легче найти этот чип в DOM
184
184
  'data-index': index,
185
185
  'data-value': option.value,
186
+ 'data-value-type': typeof option.value,
186
187
  // для a11y
187
188
  'tabIndex': lastFocusedChipOptionIndex === index ? 0 : -1,
188
189
  'role': 'option',
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ChipsInputBase/ChipsInputBase.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { isHTMLElement } from '@vkontakte/vkui-floating-ui/utils/dom';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { getHorizontalFocusGoTo, Keys } from '../../lib/accessibility';\nimport {\n contains as checkTargetIsInputEl,\n contains,\n getActiveElementByAnotherElement,\n} from '../../lib/dom';\nimport { FormField } from '../FormField/FormField';\nimport { FormFieldClearButton } from '../FormFieldClearButton/FormFieldClearButton';\nimport { Text } from '../Typography/Text/Text';\nimport { DEFAULT_INPUT_VALUE, DEFAULT_VALUE, renderChipDefault } from './constants';\nimport {\n getChipOptionIndexByHTMLElement,\n getChipOptionIndexByValueProp,\n getChipOptionValueByHTMLElement,\n getNextChipOptionIndexByNavigateToProp,\n isInputValueEmpty,\n} from './helpers';\nimport type { ChipOption, ChipOptionValue, ChipsInputBasePrivateProps, NavigateTo } from './types';\nimport styles from './ChipsInputBase.module.css';\n\nconst sizeYClassNames = {\n none: styles.sizeYNone,\n compact: styles.sizeYCompact,\n} as const;\n\nexport const ChipsInputBase = <O extends ChipOption>({\n // FormFieldProps\n getRootRef,\n style,\n className,\n before,\n after,\n status,\n mode,\n maxHeight,\n\n // option\n value = DEFAULT_VALUE,\n onAddChipOption,\n onRemoveChipOption: onRemoveChipOptionProp,\n renderChip = renderChipDefault,\n\n // input\n getRef,\n id: idProp,\n inputValue = DEFAULT_INPUT_VALUE,\n placeholder,\n disabled,\n readOnly,\n addOnBlur,\n onBlur,\n onInputChange,\n\n // clear\n ClearButton = FormFieldClearButton,\n clearButtonShown,\n clearButtonTestId,\n onClear,\n ...restProps\n}: ChipsInputBasePrivateProps<O>): React.ReactNode => {\n const { sizeY = 'none' } = useAdaptivity();\n const idGenerated = React.useId();\n const inputRef = useExternRef(getRef);\n const listboxRef = React.useRef<HTMLDivElement>(null);\n\n const valueLength = value.length;\n const withPlaceholder = valueLength === 0;\n const [lastFocusedChipOptionIndex, setLastFocusedChipOptionIndex] = React.useState(0);\n\n const resetChipOptionFocusToInputEl = (inputEl: HTMLInputElement) => {\n setLastFocusedChipOptionIndex(0);\n inputEl.focus();\n };\n\n const moveFocusToChipOption = (\n currentIndex: number,\n navigateTo: NavigateTo,\n listboxEl: HTMLElement,\n ) => {\n const index = getNextChipOptionIndexByNavigateToProp(currentIndex, navigateTo, valueLength);\n // eslint-disable-next-line no-restricted-properties\n const foundEl = listboxEl.querySelector<HTMLElement>(`[data-index=\"${index}\"]`);\n\n if (foundEl) {\n setLastFocusedChipOptionIndex(index);\n foundEl.focus();\n }\n };\n\n const removeChipOption = (o: O | ChipOptionValue, index: number) => {\n /* istanbul ignore if: невозможный кейс (в SSR вызова этой функции не будет) */\n if (!inputRef.current || !listboxRef.current) {\n return;\n }\n\n if (valueLength > 1) {\n if (index === valueLength - 1) {\n moveFocusToChipOption(index, 'prev', listboxRef.current);\n } else {\n moveFocusToChipOption(index, 'next', listboxRef.current);\n }\n } else {\n resetChipOptionFocusToInputEl(inputRef.current);\n }\n\n onRemoveChipOptionProp(o);\n };\n\n const handleListboxKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n const targetEl = event.target;\n /* istanbul ignore if: невозможный кейс (в SSR вызова этой функции не будет) */\n if (event.defaultPrevented || !listboxRef.current || !isHTMLElement(targetEl)) {\n return;\n }\n\n switch (event.key) {\n case Keys.ENTER: {\n if (\n !readOnly &&\n checkTargetIsInputEl(targetEl, inputRef.current) &&\n inputRef.current &&\n !isInputValueEmpty(inputRef.current)\n ) {\n event.preventDefault();\n onAddChipOption(inputRef.current.value);\n }\n break;\n }\n case Keys.DELETE:\n case Keys.BACKSPACE: {\n if (!readOnly && valueLength > 0) {\n if (!checkTargetIsInputEl(targetEl, inputRef.current)) {\n event.preventDefault();\n removeChipOption(\n getChipOptionValueByHTMLElement(targetEl),\n getChipOptionIndexByHTMLElement(targetEl),\n );\n } else if (event.key === Keys.BACKSPACE && isInputValueEmpty(inputRef.current)) {\n event.preventDefault();\n moveFocusToChipOption(\n getChipOptionIndexByHTMLElement(targetEl),\n 'last',\n listboxRef.current,\n );\n }\n }\n break;\n }\n case Keys.ARROW_UP:\n case Keys.ARROW_LEFT:\n case Keys.ARROW_DOWN:\n case Keys.ARROW_RIGHT: {\n if (valueLength !== 0 && !checkTargetIsInputEl(targetEl, inputRef.current)) {\n event.preventDefault();\n moveFocusToChipOption(\n getChipOptionIndexByHTMLElement(targetEl),\n getHorizontalFocusGoTo(event.key),\n listboxRef.current,\n );\n }\n break;\n }\n }\n };\n\n const handleInputBlur = (event: React.FocusEvent<HTMLInputElement>) => {\n if (onBlur) {\n onBlur(event);\n }\n\n if (addOnBlur && !event.defaultPrevented && inputRef.current) {\n onAddChipOption(inputRef.current.value);\n }\n };\n\n const handleChipRemove = (event: React.MouseEvent, v: ChipOptionValue) => {\n event.preventDefault();\n event.stopPropagation();\n removeChipOption(v, getChipOptionIndexByValueProp(v, value));\n };\n\n const handleRootClick = (event: React.MouseEvent<HTMLDivElement>) => {\n if (\n event.defaultPrevented ||\n contains(event.currentTarget, getActiveElementByAnotherElement(event.currentTarget))\n ) {\n return;\n }\n\n if (inputRef.current) {\n inputRef.current.focus();\n }\n };\n\n const clearButton = React.useMemo(() => {\n if (clearButtonShown) {\n return <ClearButton onClick={onClear} disabled={disabled} data-testid={clearButtonTestId} />;\n }\n return undefined;\n }, [ClearButton, clearButtonShown, clearButtonTestId, disabled, onClear]);\n\n const afterItems = React.useMemo(() => {\n if (clearButton || after) {\n return (\n <>\n {clearButton}\n {after}\n </>\n );\n }\n return undefined;\n }, [after, clearButton]);\n\n return (\n <FormField\n Component=\"div\"\n getRootRef={getRootRef}\n style={style}\n disabled={disabled}\n before={before}\n after={afterItems}\n status={status}\n mode={mode}\n className={className}\n maxHeight={maxHeight}\n onClick={disabled ? undefined : handleRootClick}\n >\n <div\n className={classNames(\n styles.host,\n sizeY !== 'regular' && sizeYClassNames[sizeY],\n withPlaceholder && styles.hasPlaceholder,\n )}\n // для a11y\n ref={listboxRef}\n role=\"listbox\"\n aria-orientation=\"horizontal\"\n aria-disabled={disabled}\n aria-readonly={readOnly}\n onKeyDown={disabled ? undefined : handleListboxKeyDown}\n >\n {value.map((option, index) => (\n <React.Fragment key={`${typeof option.value}-${option.value}`}>\n {renderChip(\n {\n 'Component': 'div',\n 'value': option.value,\n 'label': option.label,\n 'disabled': option.disabled || disabled,\n 'readOnly': option.readOnly || readOnly,\n 'className': styles.chip,\n 'onRemove': handleChipRemove,\n // чтобы можно было легче найти этот чип в DOM\n 'data-index': index,\n 'data-value': option.value,\n // для a11y\n 'tabIndex': lastFocusedChipOptionIndex === index ? 0 : -1,\n 'role': 'option',\n 'aria-selected': true,\n 'aria-posinset': index + 1,\n 'aria-setsize': valueLength,\n },\n option,\n )}\n </React.Fragment>\n ))}\n <Text\n autoCapitalize=\"none\"\n autoComplete=\"off\"\n autoCorrect=\"off\"\n spellCheck={false}\n {...restProps}\n Component=\"input\"\n type=\"text\"\n id={idProp || `chips-input-base-generated-id-${idGenerated}`}\n getRootRef={inputRef}\n className={styles.el}\n disabled={disabled}\n readOnly={readOnly}\n placeholder={withPlaceholder ? placeholder : undefined}\n value={inputValue}\n onChange={onInputChange}\n onBlur={handleInputBlur}\n />\n </div>\n </FormField>\n );\n};\n"],"names":["React","classNames","isHTMLElement","useAdaptivity","useExternRef","getHorizontalFocusGoTo","Keys","contains","checkTargetIsInputEl","getActiveElementByAnotherElement","FormField","FormFieldClearButton","Text","DEFAULT_INPUT_VALUE","DEFAULT_VALUE","renderChipDefault","getChipOptionIndexByHTMLElement","getChipOptionIndexByValueProp","getChipOptionValueByHTMLElement","getNextChipOptionIndexByNavigateToProp","isInputValueEmpty","styles","sizeYClassNames","none","sizeYNone","compact","sizeYCompact","ChipsInputBase","getRootRef","style","className","before","after","status","mode","maxHeight","value","onAddChipOption","onRemoveChipOption","onRemoveChipOptionProp","renderChip","getRef","id","idProp","inputValue","placeholder","disabled","readOnly","addOnBlur","onBlur","onInputChange","ClearButton","clearButtonShown","clearButtonTestId","onClear","restProps","sizeY","idGenerated","useId","inputRef","listboxRef","useRef","valueLength","length","withPlaceholder","lastFocusedChipOptionIndex","setLastFocusedChipOptionIndex","useState","resetChipOptionFocusToInputEl","inputEl","focus","moveFocusToChipOption","currentIndex","navigateTo","listboxEl","index","foundEl","querySelector","removeChipOption","o","current","handleListboxKeyDown","event","targetEl","target","defaultPrevented","key","ENTER","preventDefault","DELETE","BACKSPACE","ARROW_UP","ARROW_LEFT","ARROW_DOWN","ARROW_RIGHT","handleInputBlur","handleChipRemove","v","stopPropagation","handleRootClick","currentTarget","clearButton","useMemo","onClick","data-testid","undefined","afterItems","Component","div","host","hasPlaceholder","ref","role","aria-orientation","aria-disabled","aria-readonly","onKeyDown","map","option","Fragment","label","chip","autoCapitalize","autoComplete","autoCorrect","spellCheck","type","el","onChange"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/components/ChipsInputBase/ChipsInputBase.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { isHTMLElement } from '@vkontakte/vkui-floating-ui/utils/dom';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { getHorizontalFocusGoTo, Keys } from '../../lib/accessibility';\nimport {\n contains as checkTargetIsInputEl,\n contains,\n getActiveElementByAnotherElement,\n} from '../../lib/dom';\nimport { FormField } from '../FormField/FormField';\nimport { FormFieldClearButton } from '../FormFieldClearButton/FormFieldClearButton';\nimport { Text } from '../Typography/Text/Text';\nimport { DEFAULT_INPUT_VALUE, DEFAULT_VALUE, renderChipDefault } from './constants';\nimport {\n getChipOptionIndexByHTMLElement,\n getChipOptionIndexByValueProp,\n getChipOptionValueByHTMLElement,\n getNextChipOptionIndexByNavigateToProp,\n isInputValueEmpty,\n} from './helpers';\nimport type { ChipOption, ChipOptionValue, ChipsInputBasePrivateProps, NavigateTo } from './types';\nimport styles from './ChipsInputBase.module.css';\n\nconst sizeYClassNames = {\n none: styles.sizeYNone,\n compact: styles.sizeYCompact,\n} as const;\n\nexport const ChipsInputBase = <O extends ChipOption>({\n // FormFieldProps\n getRootRef,\n style,\n className,\n before,\n after,\n status,\n mode,\n maxHeight,\n\n // option\n value = DEFAULT_VALUE,\n onAddChipOption,\n onRemoveChipOption: onRemoveChipOptionProp,\n renderChip = renderChipDefault,\n\n // input\n getRef,\n id: idProp,\n inputValue = DEFAULT_INPUT_VALUE,\n placeholder,\n disabled,\n readOnly,\n addOnBlur,\n onBlur,\n onInputChange,\n\n // clear\n ClearButton = FormFieldClearButton,\n clearButtonShown,\n clearButtonTestId,\n onClear,\n ...restProps\n}: ChipsInputBasePrivateProps<O>): React.ReactNode => {\n const { sizeY = 'none' } = useAdaptivity();\n const idGenerated = React.useId();\n const inputRef = useExternRef(getRef);\n const listboxRef = React.useRef<HTMLDivElement>(null);\n\n const valueLength = value.length;\n const withPlaceholder = valueLength === 0;\n const [lastFocusedChipOptionIndex, setLastFocusedChipOptionIndex] = React.useState(0);\n\n const resetChipOptionFocusToInputEl = (inputEl: HTMLInputElement) => {\n setLastFocusedChipOptionIndex(0);\n inputEl.focus();\n };\n\n const moveFocusToChipOption = (\n currentIndex: number,\n navigateTo: NavigateTo,\n listboxEl: HTMLElement,\n ) => {\n const index = getNextChipOptionIndexByNavigateToProp(currentIndex, navigateTo, valueLength);\n // eslint-disable-next-line no-restricted-properties\n const foundEl = listboxEl.querySelector<HTMLElement>(`[data-index=\"${index}\"]`);\n\n if (foundEl) {\n setLastFocusedChipOptionIndex(index);\n foundEl.focus();\n }\n };\n\n const removeChipOption = (o: O | ChipOptionValue, index: number) => {\n /* istanbul ignore if: невозможный кейс (в SSR вызова этой функции не будет) */\n if (!inputRef.current || !listboxRef.current) {\n return;\n }\n\n if (valueLength > 1) {\n if (index === valueLength - 1) {\n moveFocusToChipOption(index, 'prev', listboxRef.current);\n } else {\n moveFocusToChipOption(index, 'next', listboxRef.current);\n }\n } else {\n resetChipOptionFocusToInputEl(inputRef.current);\n }\n\n onRemoveChipOptionProp(o);\n };\n\n const handleListboxKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n const targetEl = event.target;\n /* istanbul ignore if: невозможный кейс (в SSR вызова этой функции не будет) */\n if (event.defaultPrevented || !listboxRef.current || !isHTMLElement(targetEl)) {\n return;\n }\n\n switch (event.key) {\n case Keys.ENTER: {\n if (\n !readOnly &&\n checkTargetIsInputEl(targetEl, inputRef.current) &&\n inputRef.current &&\n !isInputValueEmpty(inputRef.current)\n ) {\n event.preventDefault();\n onAddChipOption(inputRef.current.value);\n }\n break;\n }\n case Keys.DELETE:\n case Keys.BACKSPACE: {\n if (!readOnly && valueLength > 0) {\n if (!checkTargetIsInputEl(targetEl, inputRef.current)) {\n event.preventDefault();\n removeChipOption(\n getChipOptionValueByHTMLElement(targetEl),\n getChipOptionIndexByHTMLElement(targetEl),\n );\n } else if (event.key === Keys.BACKSPACE && isInputValueEmpty(inputRef.current)) {\n event.preventDefault();\n moveFocusToChipOption(\n getChipOptionIndexByHTMLElement(targetEl),\n 'last',\n listboxRef.current,\n );\n }\n }\n break;\n }\n case Keys.ARROW_UP:\n case Keys.ARROW_LEFT:\n case Keys.ARROW_DOWN:\n case Keys.ARROW_RIGHT: {\n if (valueLength !== 0 && !checkTargetIsInputEl(targetEl, inputRef.current)) {\n event.preventDefault();\n moveFocusToChipOption(\n getChipOptionIndexByHTMLElement(targetEl),\n getHorizontalFocusGoTo(event.key),\n listboxRef.current,\n );\n }\n break;\n }\n }\n };\n\n const handleInputBlur = (event: React.FocusEvent<HTMLInputElement>) => {\n if (onBlur) {\n onBlur(event);\n }\n\n if (addOnBlur && !event.defaultPrevented && inputRef.current) {\n onAddChipOption(inputRef.current.value);\n }\n };\n\n const handleChipRemove = (event: React.MouseEvent, v: ChipOptionValue) => {\n event.preventDefault();\n event.stopPropagation();\n removeChipOption(v, getChipOptionIndexByValueProp(v, value));\n };\n\n const handleRootClick = (event: React.MouseEvent<HTMLDivElement>) => {\n if (\n event.defaultPrevented ||\n contains(event.currentTarget, getActiveElementByAnotherElement(event.currentTarget))\n ) {\n return;\n }\n\n if (inputRef.current) {\n inputRef.current.focus();\n }\n };\n\n const clearButton = React.useMemo(() => {\n if (clearButtonShown) {\n return <ClearButton onClick={onClear} disabled={disabled} data-testid={clearButtonTestId} />;\n }\n return undefined;\n }, [ClearButton, clearButtonShown, clearButtonTestId, disabled, onClear]);\n\n const afterItems = React.useMemo(() => {\n if (clearButton || after) {\n return (\n <>\n {clearButton}\n {after}\n </>\n );\n }\n return undefined;\n }, [after, clearButton]);\n\n return (\n <FormField\n Component=\"div\"\n getRootRef={getRootRef}\n style={style}\n disabled={disabled}\n before={before}\n after={afterItems}\n status={status}\n mode={mode}\n className={className}\n maxHeight={maxHeight}\n onClick={disabled ? undefined : handleRootClick}\n >\n <div\n className={classNames(\n styles.host,\n sizeY !== 'regular' && sizeYClassNames[sizeY],\n withPlaceholder && styles.hasPlaceholder,\n )}\n // для a11y\n ref={listboxRef}\n role=\"listbox\"\n aria-orientation=\"horizontal\"\n aria-disabled={disabled}\n aria-readonly={readOnly}\n onKeyDown={disabled ? undefined : handleListboxKeyDown}\n >\n {value.map((option, index) => (\n <React.Fragment key={`${typeof option.value}-${option.value}`}>\n {renderChip(\n {\n 'Component': 'div',\n 'value': option.value,\n 'label': option.label,\n 'disabled': option.disabled || disabled,\n 'readOnly': option.readOnly || readOnly,\n 'className': styles.chip,\n 'onRemove': handleChipRemove,\n // чтобы можно было легче найти этот чип в DOM\n 'data-index': index,\n 'data-value': option.value,\n 'data-value-type': typeof option.value,\n // для a11y\n 'tabIndex': lastFocusedChipOptionIndex === index ? 0 : -1,\n 'role': 'option',\n 'aria-selected': true,\n 'aria-posinset': index + 1,\n 'aria-setsize': valueLength,\n },\n option,\n )}\n </React.Fragment>\n ))}\n <Text\n autoCapitalize=\"none\"\n autoComplete=\"off\"\n autoCorrect=\"off\"\n spellCheck={false}\n {...restProps}\n Component=\"input\"\n type=\"text\"\n id={idProp || `chips-input-base-generated-id-${idGenerated}`}\n getRootRef={inputRef}\n className={styles.el}\n disabled={disabled}\n readOnly={readOnly}\n placeholder={withPlaceholder ? placeholder : undefined}\n value={inputValue}\n onChange={onInputChange}\n onBlur={handleInputBlur}\n />\n </div>\n </FormField>\n );\n};\n"],"names":["React","classNames","isHTMLElement","useAdaptivity","useExternRef","getHorizontalFocusGoTo","Keys","contains","checkTargetIsInputEl","getActiveElementByAnotherElement","FormField","FormFieldClearButton","Text","DEFAULT_INPUT_VALUE","DEFAULT_VALUE","renderChipDefault","getChipOptionIndexByHTMLElement","getChipOptionIndexByValueProp","getChipOptionValueByHTMLElement","getNextChipOptionIndexByNavigateToProp","isInputValueEmpty","styles","sizeYClassNames","none","sizeYNone","compact","sizeYCompact","ChipsInputBase","getRootRef","style","className","before","after","status","mode","maxHeight","value","onAddChipOption","onRemoveChipOption","onRemoveChipOptionProp","renderChip","getRef","id","idProp","inputValue","placeholder","disabled","readOnly","addOnBlur","onBlur","onInputChange","ClearButton","clearButtonShown","clearButtonTestId","onClear","restProps","sizeY","idGenerated","useId","inputRef","listboxRef","useRef","valueLength","length","withPlaceholder","lastFocusedChipOptionIndex","setLastFocusedChipOptionIndex","useState","resetChipOptionFocusToInputEl","inputEl","focus","moveFocusToChipOption","currentIndex","navigateTo","listboxEl","index","foundEl","querySelector","removeChipOption","o","current","handleListboxKeyDown","event","targetEl","target","defaultPrevented","key","ENTER","preventDefault","DELETE","BACKSPACE","ARROW_UP","ARROW_LEFT","ARROW_DOWN","ARROW_RIGHT","handleInputBlur","handleChipRemove","v","stopPropagation","handleRootClick","currentTarget","clearButton","useMemo","onClick","data-testid","undefined","afterItems","Component","div","host","hasPlaceholder","ref","role","aria-orientation","aria-disabled","aria-readonly","onKeyDown","map","option","Fragment","label","chip","autoCapitalize","autoComplete","autoCorrect","spellCheck","type","el","onChange"],"mappings":"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"}
@@ -21,6 +21,10 @@ import { DEFAULT_INPUT_VALUE } from "./constants.js";
21
21
  * @private
22
22
  */ export const getChipOptionValueByHTMLElement = (el)=>{
23
23
  const value = el && el.dataset.value;
24
+ const valueType = el && el.dataset.valueType;
25
+ if (valueType === 'number') {
26
+ return Number(value);
27
+ }
24
28
  return typeof value === 'string' ? value : -1;
25
29
  };
26
30
  /**
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ChipsInputBase/helpers.ts"],"sourcesContent":["import { DEFAULT_INPUT_VALUE } from './constants';\nimport type { ChipOption, ChipOptionValue, NavigateTo } from './types';\n\n/**\n * @private\n */\nexport const isValueLikeChipOptionObject = <O extends ChipOption>(v: O | ChipOptionValue): v is O =>\n typeof v === 'object' && 'value' in v;\n\n/**\n * @private\n */\nexport const isInputValueEmpty = (input: HTMLInputElement | null): boolean =>\n input ? input.value === DEFAULT_INPUT_VALUE : true;\n\n/**\n * @private\n */\nexport const getChipOptionIndexByValueProp = <O extends ChipOption>(\n optionProp: O | ChipOptionValue,\n valueProp: O[],\n): number => {\n const value = isValueLikeChipOptionObject(optionProp) ? optionProp.value : optionProp;\n return valueProp.findIndex((option) => option.value === value);\n};\n\n/**\n * @private\n */\nexport const getChipOptionIndexByHTMLElement = (el: HTMLElement | null): number => {\n const value = el && el.dataset.index;\n return typeof value === 'string' ? Number(value) : -1;\n};\n\n/**\n * @private\n */\nexport const getChipOptionValueByHTMLElement = (el: HTMLElement | null): string | -1 => {\n const value = el && el.dataset.value;\n return typeof value === 'string' ? value : -1;\n};\n\n/**\n * @private\n */\nexport const getNextChipOptionIndexByNavigateToProp = (\n currentIndex: number,\n navigateTo: NavigateTo,\n length: number,\n): number => {\n const LAST_INDEX = length - 1;\n switch (navigateTo) {\n case 'prev':\n const prevIndex = currentIndex - 1;\n return prevIndex < 0 ? LAST_INDEX : prevIndex;\n case 'next':\n const nextIndex = currentIndex + 1;\n return nextIndex > LAST_INDEX ? 0 : nextIndex;\n case 'last':\n return LAST_INDEX;\n default:\n /* istanbul ignore next */\n return -1;\n }\n};\n"],"names":["DEFAULT_INPUT_VALUE","isValueLikeChipOptionObject","v","isInputValueEmpty","input","value","getChipOptionIndexByValueProp","optionProp","valueProp","findIndex","option","getChipOptionIndexByHTMLElement","el","dataset","index","Number","getChipOptionValueByHTMLElement","getNextChipOptionIndexByNavigateToProp","currentIndex","navigateTo","length","LAST_INDEX","prevIndex","nextIndex"],"mappings":"AAAA,SAASA,mBAAmB,QAAQ,iBAAc;AAGlD;;CAEC,GACD,OAAO,MAAMC,8BAA8B,CAAuBC,IAChE,OAAOA,MAAM,YAAY,WAAWA,EAAE;AAExC;;CAEC,GACD,OAAO,MAAMC,oBAAoB,CAACC,QAChCA,QAAQA,MAAMC,KAAK,KAAKL,sBAAsB,KAAK;AAErD;;CAEC,GACD,OAAO,MAAMM,gCAAgC,CAC3CC,YACAC;IAEA,MAAMH,QAAQJ,4BAA4BM,cAAcA,WAAWF,KAAK,GAAGE;IAC3E,OAAOC,UAAUC,SAAS,CAAC,CAACC,SAAWA,OAAOL,KAAK,KAAKA;AAC1D,EAAE;AAEF;;CAEC,GACD,OAAO,MAAMM,kCAAkC,CAACC;IAC9C,MAAMP,QAAQO,MAAMA,GAAGC,OAAO,CAACC,KAAK;IACpC,OAAO,OAAOT,UAAU,WAAWU,OAAOV,SAAS,CAAC;AACtD,EAAE;AAEF;;CAEC,GACD,OAAO,MAAMW,kCAAkC,CAACJ;IAC9C,MAAMP,QAAQO,MAAMA,GAAGC,OAAO,CAACR,KAAK;IACpC,OAAO,OAAOA,UAAU,WAAWA,QAAQ,CAAC;AAC9C,EAAE;AAEF;;CAEC,GACD,OAAO,MAAMY,yCAAyC,CACpDC,cACAC,YACAC;IAEA,MAAMC,aAAaD,SAAS;IAC5B,OAAQD;QACN,KAAK;YACH,MAAMG,YAAYJ,eAAe;YACjC,OAAOI,YAAY,IAAID,aAAaC;QACtC,KAAK;YACH,MAAMC,YAAYL,eAAe;YACjC,OAAOK,YAAYF,aAAa,IAAIE;QACtC,KAAK;YACH,OAAOF;QACT;YACE,wBAAwB,GACxB,OAAO,CAAC;IACZ;AACF,EAAE"}
1
+ {"version":3,"sources":["../../../../src/components/ChipsInputBase/helpers.ts"],"sourcesContent":["import { DEFAULT_INPUT_VALUE } from './constants';\nimport type { ChipOption, ChipOptionValue, NavigateTo } from './types';\n\n/**\n * @private\n */\nexport const isValueLikeChipOptionObject = <O extends ChipOption>(v: O | ChipOptionValue): v is O =>\n typeof v === 'object' && 'value' in v;\n\n/**\n * @private\n */\nexport const isInputValueEmpty = (input: HTMLInputElement | null): boolean =>\n input ? input.value === DEFAULT_INPUT_VALUE : true;\n\n/**\n * @private\n */\nexport const getChipOptionIndexByValueProp = <O extends ChipOption>(\n optionProp: O | ChipOptionValue,\n valueProp: O[],\n): number => {\n const value = isValueLikeChipOptionObject(optionProp) ? optionProp.value : optionProp;\n return valueProp.findIndex((option) => option.value === value);\n};\n\n/**\n * @private\n */\nexport const getChipOptionIndexByHTMLElement = (el: HTMLElement | null): number => {\n const value = el && el.dataset.index;\n return typeof value === 'string' ? Number(value) : -1;\n};\n\n/**\n * @private\n */\nexport const getChipOptionValueByHTMLElement = (el: HTMLElement | null): ChipOptionValue | -1 => {\n const value = el && el.dataset.value;\n const valueType = el && el.dataset.valueType;\n if (valueType === 'number') {\n return Number(value);\n }\n return typeof value === 'string' ? value : -1;\n};\n\n/**\n * @private\n */\nexport const getNextChipOptionIndexByNavigateToProp = (\n currentIndex: number,\n navigateTo: NavigateTo,\n length: number,\n): number => {\n const LAST_INDEX = length - 1;\n switch (navigateTo) {\n case 'prev':\n const prevIndex = currentIndex - 1;\n return prevIndex < 0 ? LAST_INDEX : prevIndex;\n case 'next':\n const nextIndex = currentIndex + 1;\n return nextIndex > LAST_INDEX ? 0 : nextIndex;\n case 'last':\n return LAST_INDEX;\n default:\n /* istanbul ignore next */\n return -1;\n }\n};\n"],"names":["DEFAULT_INPUT_VALUE","isValueLikeChipOptionObject","v","isInputValueEmpty","input","value","getChipOptionIndexByValueProp","optionProp","valueProp","findIndex","option","getChipOptionIndexByHTMLElement","el","dataset","index","Number","getChipOptionValueByHTMLElement","valueType","getNextChipOptionIndexByNavigateToProp","currentIndex","navigateTo","length","LAST_INDEX","prevIndex","nextIndex"],"mappings":"AAAA,SAASA,mBAAmB,QAAQ,iBAAc;AAGlD;;CAEC,GACD,OAAO,MAAMC,8BAA8B,CAAuBC,IAChE,OAAOA,MAAM,YAAY,WAAWA,EAAE;AAExC;;CAEC,GACD,OAAO,MAAMC,oBAAoB,CAACC,QAChCA,QAAQA,MAAMC,KAAK,KAAKL,sBAAsB,KAAK;AAErD;;CAEC,GACD,OAAO,MAAMM,gCAAgC,CAC3CC,YACAC;IAEA,MAAMH,QAAQJ,4BAA4BM,cAAcA,WAAWF,KAAK,GAAGE;IAC3E,OAAOC,UAAUC,SAAS,CAAC,CAACC,SAAWA,OAAOL,KAAK,KAAKA;AAC1D,EAAE;AAEF;;CAEC,GACD,OAAO,MAAMM,kCAAkC,CAACC;IAC9C,MAAMP,QAAQO,MAAMA,GAAGC,OAAO,CAACC,KAAK;IACpC,OAAO,OAAOT,UAAU,WAAWU,OAAOV,SAAS,CAAC;AACtD,EAAE;AAEF;;CAEC,GACD,OAAO,MAAMW,kCAAkC,CAACJ;IAC9C,MAAMP,QAAQO,MAAMA,GAAGC,OAAO,CAACR,KAAK;IACpC,MAAMY,YAAYL,MAAMA,GAAGC,OAAO,CAACI,SAAS;IAC5C,IAAIA,cAAc,UAAU;QAC1B,OAAOF,OAAOV;IAChB;IACA,OAAO,OAAOA,UAAU,WAAWA,QAAQ,CAAC;AAC9C,EAAE;AAEF;;CAEC,GACD,OAAO,MAAMa,yCAAyC,CACpDC,cACAC,YACAC;IAEA,MAAMC,aAAaD,SAAS;IAC5B,OAAQD;QACN,KAAK;YACH,MAAMG,YAAYJ,eAAe;YACjC,OAAOI,YAAY,IAAID,aAAaC;QACtC,KAAK;YACH,MAAMC,YAAYL,eAAe;YACjC,OAAOK,YAAYF,aAAa,IAAIE;QACtC,KAAK;YACH,OAAOF;QACT;YACE,wBAAwB,GACxB,OAAO,CAAC;IACZ;AACF,EAAE"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ChipsInputBase/types.ts"],"sourcesContent":["import type * as React from 'react';\nimport type {\n HasAlign,\n HasComponent,\n HasDataAttribute,\n HasRef,\n HTMLAttributesWithRootRef,\n} from '../../types';\nimport { type FormFieldProps } from '../FormField/FormField';\nimport { type FormFieldClearButtonProps } from '../FormFieldClearButton/FormFieldClearButton';\n\nexport type NavigateTo = 'prev' | 'next' | 'last';\n\nexport type ChipOptionValue = string | number;\n\nexport type ChipOptionLabel = React.ReactElement | string | number;\n\nexport type ChipOption = {\n value: ChipOptionValue;\n label: ChipOptionLabel;\n disabled?: boolean;\n [index: string]: any;\n};\n\nexport interface ChipProps\n extends HasComponent,\n HasDataAttribute,\n HTMLAttributesWithRootRef<HTMLElement> {\n value?: ChipOptionValue;\n removable?: boolean;\n disabled?: boolean;\n readOnly?: boolean;\n removeLabel?: string;\n before?: React.ReactNode;\n after?: React.ReactNode;\n onRemove?: (event: React.MouseEvent, value: ChipOptionValue) => void;\n}\n\nexport interface RenderChipProps extends ChipProps {\n label: ChipOptionLabel;\n}\n\nexport type RenderChip<O extends ChipOption = ChipOption> = (\n props: RenderChipProps,\n option: O,\n) => React.ReactNode;\n\nexport type GetOptionValue<O extends ChipOption = ChipOption> = (option: O) => ChipOptionValue;\n\nexport type GetOptionLabel<O extends ChipOption = ChipOption> = (option: O) => ChipOptionLabel;\n\nexport type GetNewOptionData<O extends ChipOption = ChipOption> = (\n value: ChipOptionValue,\n label: ChipOptionLabel,\n) => O;\n\nexport type OnChange<O extends ChipOption = ChipOption> = (value: O[]) => void;\n\nexport type OnInputChange = (event: React.ChangeEvent<HTMLInputElement>) => void;\n\n/**\n * @public\n */\nexport interface UseChipsInputBaseProps<O extends ChipOption = ChipOption> {\n disabled?: boolean;\n\n value?: O[];\n defaultValue?: O[];\n onChange?: OnChange<O>;\n\n inputValue?: string;\n defaultInputValue?: string;\n onInputChange?: OnInputChange;\n}\n\n/**\n * @private\n */\ntype UseChipsInputBaseOnlyNeededProps<O extends ChipOption = ChipOption> = Omit<\n UseChipsInputBaseProps<O>,\n 'onChange' | 'defaultValue' | 'defaultInputValue'\n>;\n\n/**\n * @public\n */\nexport interface ChipsInputBaseProps<O extends ChipOption = ChipOption>\n extends UseChipsInputBaseOnlyNeededProps<O>,\n Omit<\n React.InputHTMLAttributes<HTMLInputElement>,\n keyof UseChipsInputBaseProps<O> | 'defaultChecked'\n >,\n HasRef<HTMLInputElement>,\n HasAlign {\n getRootRef?: React.Ref<HTMLDivElement>;\n /**\n * Добавляет значение в список на событие `onBlur`\n */\n addOnBlur?: boolean;\n /**\n * Render prop функция для возврата своего компонента.\n *\n * @default Используется [Chip](#/Chip)\n */\n renderChip?: RenderChip;\n /**\n * Показывать ли кнопку для очистки значения\n */\n clearButtonShown?: boolean;\n /**\n * (e2e) testId кнопки очистки\n */\n clearButtonTestId?: string;\n /**\n * Кастомная кнопка для очистки значения.\n * Должна принимать обязательное свойство `onClick`\n */\n ClearButton?: React.ComponentType<FormFieldClearButtonProps>;\n}\n\n/**\n * @private\n */\nexport interface ChipsInputBasePrivateProps<O extends ChipOption = ChipOption>\n extends ChipsInputBaseProps<O>,\n Pick<FormFieldProps, 'mode' | 'status' | 'before' | 'after' | 'maxHeight'> {\n onClear: () => void;\n onAddChipOption: (value: string) => void;\n onRemoveChipOption: (value: O | ChipOptionValue) => void;\n}\n"],"names":[],"mappings":"AAwHA;;CAEC,GACD,WAMC"}
1
+ {"version":3,"sources":["../../../../src/components/ChipsInputBase/types.ts"],"sourcesContent":["import type * as React from 'react';\nimport type {\n HasAlign,\n HasComponent,\n HasDataAttribute,\n HasRef,\n HTMLAttributesWithRootRef,\n} from '../../types';\nimport { type FormFieldProps } from '../FormField/FormField';\nimport { type FormFieldClearButtonProps } from '../FormFieldClearButton/FormFieldClearButton';\n\nexport type NavigateTo = 'prev' | 'next' | 'last';\n\nexport type ChipOptionValue = string | number;\n\nexport type ChipOptionLabel = React.ReactElement | string | number;\n\nexport type ChipOption = {\n /**\n * Значение опции.\n */\n value: ChipOptionValue;\n /**\n * Отображаемый текст опции.\n */\n label: ChipOptionLabel;\n /**\n * Блокировка взаимодействия с оцией.\n */\n disabled?: boolean;\n [index: string]: any;\n};\n\nexport interface ChipProps\n extends HasComponent,\n HasDataAttribute,\n HTMLAttributesWithRootRef<HTMLElement> {\n /**\n * Значение чипа.\n */\n value?: ChipOptionValue;\n /**\n * Можно ли удалить чип.\n */\n removable?: boolean;\n /**\n * Блокировка взаимодействия с чипом.\n */\n disabled?: boolean;\n /**\n * Режим только для чтения.\n */\n readOnly?: boolean;\n /**\n * Текст для кнопки удаления.\n */\n removeLabel?: string;\n /**\n * Контент перед основным содержимым.\n */\n before?: React.ReactNode;\n /**\n * Контент после основного содержимого.\n */\n after?: React.ReactNode;\n /**\n * Обработчик удаления чипа.\n */\n onRemove?: (event: React.MouseEvent, value: ChipOptionValue) => void;\n}\n\nexport interface RenderChipProps extends ChipProps {\n /**\n * Отображаемый текст чипа.\n */\n label: ChipOptionLabel;\n}\n\nexport type RenderChip<O extends ChipOption = ChipOption> = (\n props: RenderChipProps,\n option: O,\n) => React.ReactNode;\n\nexport type GetOptionValue<O extends ChipOption = ChipOption> = (option: O) => ChipOptionValue;\n\nexport type GetOptionLabel<O extends ChipOption = ChipOption> = (option: O) => ChipOptionLabel;\n\nexport type GetNewOptionData<O extends ChipOption = ChipOption> = (\n value: ChipOptionValue,\n label: ChipOptionLabel,\n) => O;\n\nexport type OnChange<O extends ChipOption = ChipOption> = (value: O[]) => void;\n\nexport type OnInputChange = (event: React.ChangeEvent<HTMLInputElement>) => void;\n\n/**\n * @public\n */\nexport interface UseChipsInputBaseProps<O extends ChipOption = ChipOption> {\n /**\n * Блокировка взаимодействия с компонентом.\n */\n disabled?: boolean;\n /**\n * Выбранные опции.\n */\n value?: O[];\n /**\n * Выбранные опции по умолчанию.\n */\n defaultValue?: O[];\n /**\n * Обработчик изменения выбранных опций.\n */\n onChange?: OnChange<O>;\n /**\n * Значение поля ввода.\n */\n inputValue?: string;\n /**\n * Значение поля ввода по умолчанию.\n */\n defaultInputValue?: string;\n /**\n * Обработчик изменения значения в поле ввода.\n */\n onInputChange?: OnInputChange;\n /**\n * Символ или строка, которая будет использоваться как разделитель для автоматического создания опций из текста, введенного в поле ввода.\n *\n * Работает в двух сценариях:\n * 1. При вводе разделителя - текст до разделителя автоматически преобразуется в новую опцию.\n * Например, при `delimiter=\",\"` ввод \"опция1,\" создаст опцию \"опция1\".\n *\n * 2. При вставке из буфера обмена - если вставляемый текст содержит разделители,\n * он будет автоматически разбит на несколько опций.\n * Например, при `delimiter=\",\"` вставка \"опция1,опция2,опция3\" создаст\n * три отдельные опции: \"опция1\", \"опция2\" и \"опция3\".\n */\n delimiter?: string;\n}\n\n/**\n * @private\n */\ntype UseChipsInputBaseOnlyNeededProps<O extends ChipOption = ChipOption> = Omit<\n UseChipsInputBaseProps<O>,\n 'onChange' | 'defaultValue' | 'defaultInputValue'\n>;\n\n/**\n * @public\n */\nexport interface ChipsInputBaseProps<O extends ChipOption = ChipOption>\n extends UseChipsInputBaseOnlyNeededProps<O>,\n Omit<\n React.InputHTMLAttributes<HTMLInputElement>,\n keyof UseChipsInputBaseProps<O> | 'defaultChecked'\n >,\n HasRef<HTMLInputElement>,\n HasAlign {\n /**\n * Ссылка на корневой элемент.\n */\n getRootRef?: React.Ref<HTMLDivElement>;\n /**\n * Добавляет значение в список на событие `onBlur`.\n */\n addOnBlur?: boolean;\n /**\n * Render prop функция для возврата своего компонента.\n *\n * @default Используется [Chip](#/Chip)\n */\n renderChip?: RenderChip<O>;\n /**\n * Показывать ли кнопку для очистки значения.\n */\n clearButtonShown?: boolean;\n /**\n * (e2e) testId кнопки очистки.\n */\n clearButtonTestId?: string;\n /**\n * Кастомная кнопка для очистки значения.\n * Должна принимать обязательное свойство `onClick`.\n */\n ClearButton?: React.ComponentType<FormFieldClearButtonProps>;\n}\n\n/**\n * @private\n */\nexport interface ChipsInputBasePrivateProps<O extends ChipOption = ChipOption>\n extends ChipsInputBaseProps<O>,\n Pick<FormFieldProps, 'mode' | 'status' | 'before' | 'after' | 'maxHeight'> {\n /**\n * Обработчик очистки всех выбранных опций.\n */\n onClear: () => void;\n /**\n * Обработчик добавления новой опции чипа.\n */\n onAddChipOption: (value: string) => void;\n /**\n * Обработчик удаления опции чипа.\n */\n onRemoveChipOption: (value: O | ChipOptionValue) => void;\n}\n"],"names":[],"mappings":"AA+LA;;CAEC,GACD,WAeC"}
@@ -40,7 +40,7 @@ const findIndexBefore = (options = [], endIndex = options.length)=>{
40
40
  */ export const ChipsSelect = ({ // FormFieldProps
41
41
  id: labelledbyId, getRootRef, className, status = 'default', icon: dropdownIconProp, onChangeStart, // CustomSelectDropdownProps
42
42
  options: optionsProp, placement: placementProp = 'bottom', closeAfterSelect = true, selectedBehavior = DEFAULT_SELECTED_BEHAVIOR, emptyText = DEFAULT_EMPTY_TEXT, creatable = false, fetching = false, dropdownAutoWidth, forceDropdownPortal, noMaxHeight = false, filterFn = defaultFilterFn, sortFn = false, dropdownTestId, onClose, onOpen, overscrollBehavior, renderDropdown, // ChipsInputProps
43
- getRef, value: valueProp, defaultValue, inputValue: inputValueProp, defaultInputValue, disabled, readOnly, getOptionValue = getOptionValueDefault, getOptionLabel = getOptionLabelDefault, getNewOptionData = getNewOptionDataDefault, renderChip = renderChipDefault, renderOption = renderOptionDefault, onChange, onFocus: onFocusProp, onInputChange: onInputChangeProp, onBlur: onBlurProp, onKeyDown: onKeyDownProp, dropdownOffsetDistance = 0, allowClearButton, clearButtonTestId, ...restProps })=>{
43
+ getRef, value: valueProp, defaultValue, inputValue: inputValueProp, defaultInputValue, disabled, readOnly, getOptionValue = getOptionValueDefault, getOptionLabel = getOptionLabelDefault, getNewOptionData = getNewOptionDataDefault, renderChip = renderChipDefault, renderOption = renderOptionDefault, onChange, onFocus: onFocusProp, onInputChange: onInputChangeProp, onBlur: onBlurProp, onKeyDown: onKeyDownProp, dropdownOffsetDistance = 0, allowClearButton, clearButtonTestId, delimiter, ...restProps })=>{
44
44
  const { // Связано с ChipsInputProps
45
45
  // option
46
46
  value, addOptionFromInput, addOption, removeOption, clearOptions, // input
@@ -67,11 +67,13 @@ getRef, value: valueProp, defaultValue, inputValue: inputValueProp, defaultInput
67
67
  onClose,
68
68
  onOpen,
69
69
  // other
70
- disabled
70
+ disabled,
71
+ delimiter
71
72
  });
72
73
  // Связано с ChipsInputProps
73
74
  const rootRef = useExternRef(getRootRef);
74
75
  const inputRef = useExternRef(getRef, inputRefHook);
76
+ const forbidCloseByOutsideClick = React.useRef(false);
75
77
  // Связано с CustomSelectDropdownProps
76
78
  const [dropdownVerticalPlacement, setDropdownVerticalPlacement] = React.useState(placementProp);
77
79
  const onDropdownPlacementChange = React.useCallback((placement)=>{
@@ -214,7 +216,10 @@ getRef, value: valueProp, defaultValue, inputValue: inputValueProp, defaultInput
214
216
  setFocusedOptionIndex
215
217
  ]);
216
218
  const handleClickOutside = React.useCallback(()=>{
217
- setOpened(false);
219
+ if (!forbidCloseByOutsideClick.current) {
220
+ setOpened(false);
221
+ }
222
+ forbidCloseByOutsideClick.current = false;
218
223
  }, [
219
224
  setOpened
220
225
  ]);
@@ -268,6 +273,7 @@ getRef, value: valueProp, defaultValue, inputValue: inputValueProp, defaultInput
268
273
  if (!event.defaultPrevented) {
269
274
  closeAfterSelect && setOpened(false);
270
275
  addOption(option);
276
+ forbidCloseByOutsideClick.current = true;
271
277
  clearInput();
272
278
  }
273
279
  },
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ChipsSelect/ChipsSelect.tsx"],"sourcesContent":["'use client';\n\nimport { type MouseEventHandler } from 'react';\nimport * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useGlobalOnClickOutside } from '../../hooks/useGlobalOnClickOutside';\nimport { Keys } from '../../lib/accessibility';\nimport type { Placement } from '../../lib/floating';\nimport { defaultFilterFn } from '../../lib/select';\nimport { ChipsInputBase } from '../ChipsInputBase/ChipsInputBase';\nimport {\n getNewOptionDataDefault,\n getOptionLabelDefault,\n getOptionValueDefault,\n renderChipDefault,\n} from '../ChipsInputBase/constants';\nimport type { ChipOption, ChipsInputBaseProps } from '../ChipsInputBase/types';\nimport {\n CustomSelectDropdown,\n type CustomSelectDropdownProps,\n} from '../CustomSelectDropdown/CustomSelectDropdown';\nimport {\n CustomSelectOption,\n type CustomSelectOptionProps,\n} from '../CustomSelectOption/CustomSelectOption';\nimport { DropdownIcon } from '../DropdownIcon/DropdownIcon';\nimport type { FormFieldProps } from '../FormField/FormField';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport {\n DEFAULT_EMPTY_TEXT,\n DEFAULT_SELECTED_BEHAVIOR,\n FOCUS_ACTION_NEXT,\n FOCUS_ACTION_PREV,\n isCreateNewOptionPreset,\n isEmptyOptionPreset,\n isNotServicePreset,\n renderOptionDefault,\n} from './constants';\nimport type { FocusActionType, OptionPreset } from './types';\nimport { useChipsSelect, type UseChipsSelectProps } from './useChipsSelect';\nimport styles from './ChipsSelect.module.css';\n\nconst findIndexAfter = <O extends ChipOption>(\n options: Array<OptionPreset<O>> = [],\n startIndex = -1,\n) => {\n if (startIndex >= options.length - 1) {\n return -1;\n }\n return options.findIndex(\n (option, i) => i > startIndex && (!isNotServicePreset(option) || !option.disabled),\n );\n};\n\nconst findIndexBefore = <O extends ChipOption>(\n options: Array<OptionPreset<O>> = [],\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 (!isNotServicePreset(option) || !option.disabled) {\n result = i;\n break;\n }\n }\n return result;\n};\n\nexport interface ChipsSelectProps<O extends ChipOption>\n extends ChipsInputBaseProps<O>,\n UseChipsSelectProps<O>,\n Pick<FormFieldProps, 'status' | 'mode' | 'before'>,\n Pick<CustomSelectDropdownProps, 'overscrollBehavior'> {\n placement?: 'top' | 'bottom';\n /**\n * Отрисовка Spinner вместо списка опций в выпадающем списке\n */\n fetching?: boolean;\n /**\n * Закрытие выпадающего списка после выбора элемента\n */\n closeAfterSelect?: boolean;\n /**\n * Ширина раскрывающегося списка зависит от контента\n */\n dropdownAutoWidth?: boolean;\n /**\n * Принудительно использовать портал.\n */\n forceDropdownPortal?: boolean;\n /**\n * Передает атрибут `data-testid` для дропдауна.\n */\n dropdownTestId?: string;\n /**\n * Иконка раскрывающегося списка\n */\n icon?: React.ReactNode;\n /**\n * Добавляет значение в список на событие `onBlur` (использовать вместе с `creatable`)\n */\n addOnBlur?: boolean;\n /**\n * Отключает максимальную высоту по умолчанию\n */\n noMaxHeight?: boolean;\n\n renderOption?: (props: CustomSelectOptionProps, option: O) => React.ReactNode;\n /**\n * Рендер-проп для кастомного рендера содержимого дропдауна.\n * В `defaultDropdownContent` содержится список опций.\n */\n renderDropdown?: ({\n defaultDropdownContent,\n }: {\n defaultDropdownContent: React.ReactNode;\n }) => React.ReactNode;\n /**\n * Событие срабатывающее перед onChange\n */\n onChangeStart?: (event: React.MouseEvent | React.KeyboardEvent, option: O) => void;\n\n /**\n * Отступ от выпадающего списка\n */\n dropdownOffsetDistance?: number;\n\n /**\n * Если `true`, то справа будет отображаться кнопка для очистки значения\n */\n allowClearButton?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ChipsSelect\n */\nexport const ChipsSelect = <Option extends ChipOption>({\n // FormFieldProps\n id: labelledbyId,\n getRootRef,\n className,\n status = 'default',\n icon: dropdownIconProp,\n onChangeStart,\n\n // CustomSelectDropdownProps\n options: optionsProp,\n placement: placementProp = 'bottom',\n closeAfterSelect = true,\n selectedBehavior = DEFAULT_SELECTED_BEHAVIOR,\n emptyText = DEFAULT_EMPTY_TEXT,\n creatable = false,\n fetching = false,\n dropdownAutoWidth,\n forceDropdownPortal,\n noMaxHeight = false,\n filterFn = defaultFilterFn,\n sortFn = false,\n dropdownTestId,\n onClose,\n onOpen,\n overscrollBehavior,\n renderDropdown,\n\n // ChipsInputProps\n getRef,\n value: valueProp,\n defaultValue,\n inputValue: inputValueProp,\n defaultInputValue,\n disabled,\n readOnly,\n getOptionValue = getOptionValueDefault,\n getOptionLabel = getOptionLabelDefault,\n getNewOptionData = getNewOptionDataDefault,\n renderChip = renderChipDefault,\n renderOption = renderOptionDefault,\n onChange,\n onFocus: onFocusProp,\n onInputChange: onInputChangeProp,\n onBlur: onBlurProp,\n onKeyDown: onKeyDownProp,\n dropdownOffsetDistance = 0,\n allowClearButton,\n clearButtonTestId,\n ...restProps\n}: ChipsSelectProps<Option>): React.ReactNode => {\n const {\n // Связано с ChipsInputProps\n // option\n value,\n addOptionFromInput,\n addOption,\n removeOption,\n clearOptions,\n // input\n inputRef: inputRefHook,\n inputValue,\n clearInput,\n onInputChange,\n\n // Связано с CustomSelectDropdownProps\n options,\n opened,\n setOpened,\n focusedOption,\n focusedOptionIndex,\n setFocusedOption,\n setFocusedOptionIndex,\n } = useChipsSelect({\n // option\n value: valueProp,\n defaultValue,\n onChange,\n getOptionValue,\n getOptionLabel,\n getNewOptionData,\n\n // input\n inputValue: inputValueProp,\n defaultInputValue,\n onInputChange: onInputChangeProp,\n\n // dropdown\n options: optionsProp,\n emptyText,\n creatable,\n filterFn,\n sortFn,\n selectedBehavior,\n onClose,\n onOpen,\n\n // other\n disabled,\n });\n\n // Связано с ChipsInputProps\n const rootRef = useExternRef(getRootRef);\n const inputRef = useExternRef(getRef, inputRefHook);\n\n // Связано с CustomSelectDropdownProps\n const [dropdownVerticalPlacement, setDropdownVerticalPlacement] = React.useState<\n 'top' | 'bottom'\n >(placementProp);\n\n const onDropdownPlacementChange = React.useCallback((placement: Placement) => {\n if (placement.startsWith('top')) {\n setDropdownVerticalPlacement('top');\n } else if (placement.startsWith('bottom')) {\n setDropdownVerticalPlacement('bottom');\n }\n }, []);\n\n const dropdownId = React.useId();\n const dropdownCurrentItemId =\n focusedOptionIndex !== null ? `${dropdownId}-${focusedOptionIndex}` : undefined;\n const dropdownScrollBoxRef = React.useRef<HTMLDivElement>(null);\n\n const handleFocus = (event: React.FocusEvent<HTMLInputElement>) => {\n if (onFocusProp) {\n onFocusProp(event);\n }\n\n if (!readOnly) {\n setOpened(true);\n setFocusedOptionIndex(null);\n }\n };\n\n const handleBlur = (event: React.FocusEvent<HTMLInputElement>) => {\n if (onBlurProp) {\n onBlurProp(event);\n }\n\n // Не добавляем значение, если его нужно выбрать строго из списка\n if (!readOnly && !event.defaultPrevented && !creatable) {\n event.preventDefault();\n }\n };\n\n const chipsSelectOptions = React.useRef<HTMLElement[]>([]).current;\n\n const scrollToElement = (index: number, center = false) => {\n const dropdown = dropdownScrollBoxRef.current;\n const item = chipsSelectOptions[index];\n\n /* istanbul ignore if: невозможный кейс (в SSR вызова этой функции не будет) */\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 /* istanbul ignore next: нет представления как воспроизвести */\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 focusOptionByIndex = (index: number, oldIndex: number | null) => {\n if (index === oldIndex) {\n /* istanbul ignore next: нет представления как воспроизвести */\n return;\n }\n\n const option = options[index];\n\n if (isNotServicePreset(option) && option.disabled) {\n return;\n }\n\n scrollToElement(index);\n setFocusedOptionIndex(index);\n };\n\n const focusOption = (nextIndex: number | null, type: FocusActionType) => {\n let index = nextIndex === null ? -1 : nextIndex;\n\n if (type === FOCUS_ACTION_NEXT) {\n const nextIndex = findIndexAfter(options, index);\n index = nextIndex === -1 ? findIndexAfter(options) : nextIndex; // Следующий за index или первый валидный до index\n } else if (type === FOCUS_ACTION_PREV) {\n const beforeIndex = findIndexBefore(options, index);\n index = beforeIndex === -1 ? findIndexBefore(options) : beforeIndex; // Предшествующий index или последний валидный после index\n }\n\n focusOptionByIndex(index, focusedOptionIndex);\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (onKeyDownProp) {\n onKeyDownProp(event);\n }\n\n if (event.defaultPrevented || readOnly) {\n return;\n }\n\n switch (event.key) {\n case Keys.ARROW_UP:\n case Keys.ARROW_DOWN:\n event.preventDefault();\n\n if (!opened) {\n setOpened(true);\n focusOption(null, FOCUS_ACTION_NEXT);\n } else {\n focusOption(\n focusedOptionIndex,\n event.key === Keys.ARROW_UP ? FOCUS_ACTION_PREV : FOCUS_ACTION_NEXT,\n );\n }\n break;\n case Keys.ENTER: {\n if (!opened) {\n break;\n }\n if (focusedOptionIndex != null) {\n const foundOption = options[focusedOptionIndex];\n if (foundOption && isNotServicePreset(foundOption)) {\n event.preventDefault();\n\n if (onChangeStart) {\n onChangeStart(event, foundOption);\n }\n\n addOption(foundOption);\n setFocusedOptionIndex(null);\n clearInput();\n if (closeAfterSelect) {\n setOpened(false);\n }\n\n break;\n }\n }\n\n if (!creatable) {\n event.preventDefault();\n }\n break;\n }\n case Keys.ESCAPE:\n case Keys.TAB:\n if (opened) {\n setOpened(false);\n }\n }\n };\n\n React.useEffect(() => {\n if (focusedOptionIndex === null) {\n setFocusedOption(null);\n } else {\n const foundFocusedOptionIndex = options[focusedOptionIndex];\n\n if (foundFocusedOptionIndex && isNotServicePreset(foundFocusedOptionIndex)) {\n setFocusedOption(foundFocusedOptionIndex);\n }\n }\n }, [options, focusedOptionIndex, setFocusedOption]);\n\n const onDropdownMouseLeave = React.useCallback(() => {\n setFocusedOptionIndex(null);\n }, [setFocusedOptionIndex]);\n\n const handleClickOutside = React.useCallback(() => {\n setOpened(false);\n }, [setOpened]);\n\n useGlobalOnClickOutside(\n handleClickOutside,\n opened ? rootRef : null,\n opened ? dropdownScrollBoxRef : null,\n );\n\n const onDropdownIconClick: MouseEventHandler<SVGSVGElement> = React.useCallback(\n (e) => {\n if (opened) {\n e.preventDefault();\n setOpened(false);\n }\n },\n [opened, setOpened],\n );\n\n const dropdownContent = React.useMemo(() => {\n const defaultDropdownContent = options.map((option, index) => {\n const dropdownItemId = `${dropdownId}-${index}`;\n\n if (isEmptyOptionPreset(option)) {\n return (\n <Footnote key=\"empty-text\" className={styles.empty}>\n {option.placeholder}\n </Footnote>\n );\n }\n if (isCreateNewOptionPreset(option)) {\n return (\n <CustomSelectOption\n key=\"create-new-option\"\n id={dropdownItemId}\n hovered={focusedOptionIndex === index}\n onMouseDown={() => addOptionFromInput(inputValue)}\n onMouseEnter={() => setFocusedOptionIndex(index)}\n >\n {option.actionText}\n </CustomSelectOption>\n );\n }\n return (\n <React.Fragment key={`${typeof option.value}-${option.value}`}>\n {renderOption(\n {\n id: dropdownItemId,\n disabled: option.disabled,\n hovered: focusedOption\n ? getOptionValue(option) === getOptionValue(focusedOption)\n : false,\n children: option.label,\n selected: !!value.find(\n (selectedOption: Option) =>\n getOptionValue(selectedOption) === getOptionValue(option),\n ),\n getRootRef(node) {\n if (node) {\n chipsSelectOptions[index] = node;\n }\n },\n onMouseDown(event: React.MouseEvent<HTMLDivElement>) {\n if (option.disabled) {\n return;\n }\n if (onChangeStart) {\n onChangeStart(event, option);\n }\n\n if (!event.defaultPrevented) {\n closeAfterSelect && setOpened(false);\n addOption(option);\n clearInput();\n }\n },\n onMouseEnter() {\n setFocusedOptionIndex(index);\n },\n },\n option,\n )}\n </React.Fragment>\n );\n });\n\n if (renderDropdown) {\n return renderDropdown({\n defaultDropdownContent,\n });\n }\n return defaultDropdownContent;\n }, [\n addOption,\n addOptionFromInput,\n chipsSelectOptions,\n clearInput,\n closeAfterSelect,\n dropdownId,\n focusedOption,\n focusedOptionIndex,\n getOptionValue,\n inputValue,\n onChangeStart,\n options,\n renderDropdown,\n renderOption,\n setFocusedOptionIndex,\n setOpened,\n value,\n ]);\n\n const openedClassNames = React.useMemo(\n () =>\n (opened &&\n dropdownOffsetDistance === 0 &&\n (dropdownVerticalPlacement.includes('top') ? styles.popUp : styles.popDown)) ||\n undefined,\n [dropdownOffsetDistance, opened, dropdownVerticalPlacement],\n );\n\n const clearButtonShown = allowClearButton && (!!value.length || !!inputValue.length);\n\n return (\n <>\n <ChipsInputBase\n {...restProps}\n disabled={disabled}\n readOnly={readOnly}\n clearButtonShown={clearButtonShown}\n clearButtonTestId={clearButtonTestId}\n // FormFieldProps\n id={labelledbyId}\n getRootRef={rootRef}\n className={classNames(styles.host, openedClassNames, className)}\n status={status}\n after={\n dropdownIconProp || (\n <DropdownIcon\n opened={opened}\n onClick={onDropdownIconClick}\n className={classNames(\n styles.dropdownIcon,\n clearButtonShown && styles.dropdownIconWithOffset,\n )}\n />\n )\n }\n // option\n value={value}\n onAddChipOption={addOptionFromInput}\n onRemoveChipOption={removeOption}\n renderChip={renderChip}\n onClear={clearOptions}\n // input\n getRef={inputRef}\n inputValue={inputValue}\n onInputChange={onInputChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n onKeyDown={handleKeyDown}\n // a11y\n role=\"combobox\"\n aria-expanded={opened}\n aria-autocomplete=\"list\"\n aria-controls={opened ? dropdownId : undefined}\n aria-activedescendant={opened ? dropdownCurrentItemId : undefined}\n aria-haspopup=\"listbox\"\n />\n {opened && (\n <CustomSelectDropdown\n data-testid={dropdownTestId}\n targetRef={rootRef}\n placement={dropdownVerticalPlacement}\n scrollBoxRef={dropdownScrollBoxRef}\n onPlacementChange={onDropdownPlacementChange}\n onMouseLeave={onDropdownMouseLeave}\n fetching={fetching}\n autoWidth={dropdownAutoWidth}\n forcePortal={forceDropdownPortal}\n noMaxHeight={noMaxHeight}\n offsetDistance={dropdownOffsetDistance}\n overscrollBehavior={overscrollBehavior}\n // a11y\n id={dropdownId}\n role=\"listbox\"\n aria-labelledby={labelledbyId}\n >\n {dropdownContent}\n </CustomSelectDropdown>\n )}\n </>\n );\n};\n"],"names":["React","classNames","useExternRef","useGlobalOnClickOutside","Keys","defaultFilterFn","ChipsInputBase","getNewOptionDataDefault","getOptionLabelDefault","getOptionValueDefault","renderChipDefault","CustomSelectDropdown","CustomSelectOption","DropdownIcon","Footnote","DEFAULT_EMPTY_TEXT","DEFAULT_SELECTED_BEHAVIOR","FOCUS_ACTION_NEXT","FOCUS_ACTION_PREV","isCreateNewOptionPreset","isEmptyOptionPreset","isNotServicePreset","renderOptionDefault","useChipsSelect","styles","findIndexAfter","options","startIndex","length","findIndex","option","i","disabled","findIndexBefore","endIndex","result","ChipsSelect","id","labelledbyId","getRootRef","className","status","icon","dropdownIconProp","onChangeStart","optionsProp","placement","placementProp","closeAfterSelect","selectedBehavior","emptyText","creatable","fetching","dropdownAutoWidth","forceDropdownPortal","noMaxHeight","filterFn","sortFn","dropdownTestId","onClose","onOpen","overscrollBehavior","renderDropdown","getRef","value","valueProp","defaultValue","inputValue","inputValueProp","defaultInputValue","readOnly","getOptionValue","getOptionLabel","getNewOptionData","renderChip","renderOption","onChange","onFocus","onFocusProp","onInputChange","onInputChangeProp","onBlur","onBlurProp","onKeyDown","onKeyDownProp","dropdownOffsetDistance","allowClearButton","clearButtonTestId","restProps","addOptionFromInput","addOption","removeOption","clearOptions","inputRef","inputRefHook","clearInput","opened","setOpened","focusedOption","focusedOptionIndex","setFocusedOption","setFocusedOptionIndex","rootRef","dropdownVerticalPlacement","setDropdownVerticalPlacement","useState","onDropdownPlacementChange","useCallback","startsWith","dropdownId","useId","dropdownCurrentItemId","undefined","dropdownScrollBoxRef","useRef","handleFocus","event","handleBlur","defaultPrevented","preventDefault","chipsSelectOptions","current","scrollToElement","index","center","dropdown","item","dropdownHeight","offsetHeight","scrollTop","itemTop","offsetTop","itemHeight","focusOptionByIndex","oldIndex","focusOption","nextIndex","type","beforeIndex","handleKeyDown","key","ARROW_UP","ARROW_DOWN","ENTER","foundOption","ESCAPE","TAB","useEffect","foundFocusedOptionIndex","onDropdownMouseLeave","handleClickOutside","onDropdownIconClick","e","dropdownContent","useMemo","defaultDropdownContent","map","dropdownItemId","empty","placeholder","hovered","onMouseDown","onMouseEnter","actionText","Fragment","children","label","selected","find","selectedOption","node","openedClassNames","includes","popUp","popDown","clearButtonShown","host","after","onClick","dropdownIcon","dropdownIconWithOffset","onAddChipOption","onRemoveChipOption","onClear","role","aria-expanded","aria-autocomplete","aria-controls","aria-activedescendant","aria-haspopup","data-testid","targetRef","scrollBoxRef","onPlacementChange","onMouseLeave","autoWidth","forcePortal","offsetDistance","aria-labelledby"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/components/ChipsSelect/ChipsSelect.tsx"],"sourcesContent":["'use client';\n\nimport { type MouseEventHandler } from 'react';\nimport * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useGlobalOnClickOutside } from '../../hooks/useGlobalOnClickOutside';\nimport { Keys } from '../../lib/accessibility';\nimport type { Placement } from '../../lib/floating';\nimport { defaultFilterFn } from '../../lib/select';\nimport { ChipsInputBase } from '../ChipsInputBase/ChipsInputBase';\nimport {\n getNewOptionDataDefault,\n getOptionLabelDefault,\n getOptionValueDefault,\n renderChipDefault,\n} from '../ChipsInputBase/constants';\nimport type { ChipOption, ChipsInputBaseProps } from '../ChipsInputBase/types';\nimport {\n CustomSelectDropdown,\n type CustomSelectDropdownProps,\n} from '../CustomSelectDropdown/CustomSelectDropdown';\nimport {\n CustomSelectOption,\n type CustomSelectOptionProps,\n} from '../CustomSelectOption/CustomSelectOption';\nimport { DropdownIcon } from '../DropdownIcon/DropdownIcon';\nimport type { FormFieldProps } from '../FormField/FormField';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport {\n DEFAULT_EMPTY_TEXT,\n DEFAULT_SELECTED_BEHAVIOR,\n FOCUS_ACTION_NEXT,\n FOCUS_ACTION_PREV,\n isCreateNewOptionPreset,\n isEmptyOptionPreset,\n isNotServicePreset,\n renderOptionDefault,\n} from './constants';\nimport type { FocusActionType, OptionPreset } from './types';\nimport { useChipsSelect, type UseChipsSelectProps } from './useChipsSelect';\nimport styles from './ChipsSelect.module.css';\n\nconst findIndexAfter = <O extends ChipOption>(\n options: Array<OptionPreset<O>> = [],\n startIndex = -1,\n) => {\n if (startIndex >= options.length - 1) {\n return -1;\n }\n return options.findIndex(\n (option, i) => i > startIndex && (!isNotServicePreset(option) || !option.disabled),\n );\n};\n\nconst findIndexBefore = <O extends ChipOption>(\n options: Array<OptionPreset<O>> = [],\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 (!isNotServicePreset(option) || !option.disabled) {\n result = i;\n break;\n }\n }\n return result;\n};\n\nexport interface ChipsSelectProps<O extends ChipOption>\n extends ChipsInputBaseProps<O>,\n UseChipsSelectProps<O>,\n Pick<FormFieldProps, 'status' | 'mode' | 'before'>,\n Pick<CustomSelectDropdownProps, 'overscrollBehavior'> {\n /**\n * Расположение выпадающего списка.\n */\n placement?: 'top' | 'bottom';\n /**\n * Отрисовка Spinner вместо списка опций в выпадающем списке.\n */\n fetching?: boolean;\n /**\n * Закрытие выпадающего списка после выбора элемента.\n */\n closeAfterSelect?: boolean;\n /**\n * Ширина раскрывающегося списка зависит от контента.\n */\n dropdownAutoWidth?: boolean;\n /**\n * Принудительно использовать портал.\n */\n forceDropdownPortal?: boolean;\n /**\n * Передает атрибут `data-testid` для дропдауна.\n */\n dropdownTestId?: string;\n /**\n * Иконка раскрывающегося списка.\n */\n icon?: React.ReactNode;\n /**\n * Добавляет значение в список на событие `onBlur` (использовать вместе с `creatable`).\n */\n addOnBlur?: boolean;\n /**\n * Отключает максимальную высоту по умолчанию.\n */\n noMaxHeight?: boolean;\n /**\n * Функция для отрисовки кастомной опции в выпадающем списке.\n */\n renderOption?: (props: CustomSelectOptionProps, option: O) => React.ReactNode;\n /**\n * Рендер-проп для кастомного рендера содержимого дропдауна.\n * В `defaultDropdownContent` содержится список опций.\n */\n renderDropdown?: ({\n defaultDropdownContent,\n }: {\n defaultDropdownContent: React.ReactNode;\n }) => React.ReactNode;\n /**\n * Событие срабатывающее перед `onChange`.\n */\n onChangeStart?: (event: React.MouseEvent | React.KeyboardEvent, option: O) => void;\n\n /**\n * Отступ от выпадающего списка.\n */\n dropdownOffsetDistance?: number;\n\n /**\n * Если `true`, то справа будет отображаться кнопка для очистки значения.\n */\n allowClearButton?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ChipsSelect\n */\nexport const ChipsSelect = <Option extends ChipOption>({\n // FormFieldProps\n id: labelledbyId,\n getRootRef,\n className,\n status = 'default',\n icon: dropdownIconProp,\n onChangeStart,\n\n // CustomSelectDropdownProps\n options: optionsProp,\n placement: placementProp = 'bottom',\n closeAfterSelect = true,\n selectedBehavior = DEFAULT_SELECTED_BEHAVIOR,\n emptyText = DEFAULT_EMPTY_TEXT,\n creatable = false,\n fetching = false,\n dropdownAutoWidth,\n forceDropdownPortal,\n noMaxHeight = false,\n filterFn = defaultFilterFn,\n sortFn = false,\n dropdownTestId,\n onClose,\n onOpen,\n overscrollBehavior,\n renderDropdown,\n\n // ChipsInputProps\n getRef,\n value: valueProp,\n defaultValue,\n inputValue: inputValueProp,\n defaultInputValue,\n disabled,\n readOnly,\n getOptionValue = getOptionValueDefault,\n getOptionLabel = getOptionLabelDefault,\n getNewOptionData = getNewOptionDataDefault,\n renderChip = renderChipDefault,\n renderOption = renderOptionDefault,\n onChange,\n onFocus: onFocusProp,\n onInputChange: onInputChangeProp,\n onBlur: onBlurProp,\n onKeyDown: onKeyDownProp,\n dropdownOffsetDistance = 0,\n allowClearButton,\n clearButtonTestId,\n delimiter,\n ...restProps\n}: ChipsSelectProps<Option>): React.ReactNode => {\n const {\n // Связано с ChipsInputProps\n // option\n value,\n addOptionFromInput,\n addOption,\n removeOption,\n clearOptions,\n // input\n inputRef: inputRefHook,\n inputValue,\n clearInput,\n onInputChange,\n\n // Связано с CustomSelectDropdownProps\n options,\n opened,\n setOpened,\n focusedOption,\n focusedOptionIndex,\n setFocusedOption,\n setFocusedOptionIndex,\n } = useChipsSelect({\n // option\n value: valueProp,\n defaultValue,\n onChange,\n getOptionValue,\n getOptionLabel,\n getNewOptionData,\n\n // input\n inputValue: inputValueProp,\n defaultInputValue,\n onInputChange: onInputChangeProp,\n\n // dropdown\n options: optionsProp,\n emptyText,\n creatable,\n filterFn,\n sortFn,\n selectedBehavior,\n onClose,\n onOpen,\n\n // other\n disabled,\n delimiter,\n });\n\n // Связано с ChipsInputProps\n const rootRef = useExternRef(getRootRef);\n const inputRef = useExternRef(getRef, inputRefHook);\n const forbidCloseByOutsideClick = React.useRef(false);\n\n // Связано с CustomSelectDropdownProps\n const [dropdownVerticalPlacement, setDropdownVerticalPlacement] = React.useState<\n 'top' | 'bottom'\n >(placementProp);\n\n const onDropdownPlacementChange = React.useCallback((placement: Placement) => {\n if (placement.startsWith('top')) {\n setDropdownVerticalPlacement('top');\n } else if (placement.startsWith('bottom')) {\n setDropdownVerticalPlacement('bottom');\n }\n }, []);\n\n const dropdownId = React.useId();\n const dropdownCurrentItemId =\n focusedOptionIndex !== null ? `${dropdownId}-${focusedOptionIndex}` : undefined;\n const dropdownScrollBoxRef = React.useRef<HTMLDivElement>(null);\n\n const handleFocus = (event: React.FocusEvent<HTMLInputElement>) => {\n if (onFocusProp) {\n onFocusProp(event);\n }\n\n if (!readOnly) {\n setOpened(true);\n setFocusedOptionIndex(null);\n }\n };\n\n const handleBlur = (event: React.FocusEvent<HTMLInputElement>) => {\n if (onBlurProp) {\n onBlurProp(event);\n }\n\n // Не добавляем значение, если его нужно выбрать строго из списка\n if (!readOnly && !event.defaultPrevented && !creatable) {\n event.preventDefault();\n }\n };\n\n const chipsSelectOptions = React.useRef<HTMLElement[]>([]).current;\n\n const scrollToElement = (index: number, center = false) => {\n const dropdown = dropdownScrollBoxRef.current;\n const item = chipsSelectOptions[index];\n\n /* istanbul ignore if: невозможный кейс (в SSR вызова этой функции не будет) */\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 /* istanbul ignore next: нет представления как воспроизвести */\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 focusOptionByIndex = (index: number, oldIndex: number | null) => {\n if (index === oldIndex) {\n /* istanbul ignore next: нет представления как воспроизвести */\n return;\n }\n\n const option = options[index];\n\n if (isNotServicePreset(option) && option.disabled) {\n return;\n }\n\n scrollToElement(index);\n setFocusedOptionIndex(index);\n };\n\n const focusOption = (nextIndex: number | null, type: FocusActionType) => {\n let index = nextIndex === null ? -1 : nextIndex;\n\n if (type === FOCUS_ACTION_NEXT) {\n const nextIndex = findIndexAfter(options, index);\n index = nextIndex === -1 ? findIndexAfter(options) : nextIndex; // Следующий за index или первый валидный до index\n } else if (type === FOCUS_ACTION_PREV) {\n const beforeIndex = findIndexBefore(options, index);\n index = beforeIndex === -1 ? findIndexBefore(options) : beforeIndex; // Предшествующий index или последний валидный после index\n }\n\n focusOptionByIndex(index, focusedOptionIndex);\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (onKeyDownProp) {\n onKeyDownProp(event);\n }\n\n if (event.defaultPrevented || readOnly) {\n return;\n }\n\n switch (event.key) {\n case Keys.ARROW_UP:\n case Keys.ARROW_DOWN:\n event.preventDefault();\n\n if (!opened) {\n setOpened(true);\n focusOption(null, FOCUS_ACTION_NEXT);\n } else {\n focusOption(\n focusedOptionIndex,\n event.key === Keys.ARROW_UP ? FOCUS_ACTION_PREV : FOCUS_ACTION_NEXT,\n );\n }\n break;\n case Keys.ENTER: {\n if (!opened) {\n break;\n }\n if (focusedOptionIndex != null) {\n const foundOption = options[focusedOptionIndex];\n if (foundOption && isNotServicePreset(foundOption)) {\n event.preventDefault();\n\n if (onChangeStart) {\n onChangeStart(event, foundOption);\n }\n\n addOption(foundOption);\n setFocusedOptionIndex(null);\n clearInput();\n if (closeAfterSelect) {\n setOpened(false);\n }\n\n break;\n }\n }\n\n if (!creatable) {\n event.preventDefault();\n }\n break;\n }\n case Keys.ESCAPE:\n case Keys.TAB:\n if (opened) {\n setOpened(false);\n }\n }\n };\n\n React.useEffect(() => {\n if (focusedOptionIndex === null) {\n setFocusedOption(null);\n } else {\n const foundFocusedOptionIndex = options[focusedOptionIndex];\n\n if (foundFocusedOptionIndex && isNotServicePreset(foundFocusedOptionIndex)) {\n setFocusedOption(foundFocusedOptionIndex);\n }\n }\n }, [options, focusedOptionIndex, setFocusedOption]);\n\n const onDropdownMouseLeave = React.useCallback(() => {\n setFocusedOptionIndex(null);\n }, [setFocusedOptionIndex]);\n\n const handleClickOutside = React.useCallback(() => {\n if (!forbidCloseByOutsideClick.current) {\n setOpened(false);\n }\n forbidCloseByOutsideClick.current = false;\n }, [setOpened]);\n\n useGlobalOnClickOutside(\n handleClickOutside,\n opened ? rootRef : null,\n opened ? dropdownScrollBoxRef : null,\n );\n\n const onDropdownIconClick: MouseEventHandler<SVGSVGElement> = React.useCallback(\n (e) => {\n if (opened) {\n e.preventDefault();\n setOpened(false);\n }\n },\n [opened, setOpened],\n );\n\n const dropdownContent = React.useMemo(() => {\n const defaultDropdownContent = options.map((option, index) => {\n const dropdownItemId = `${dropdownId}-${index}`;\n\n if (isEmptyOptionPreset(option)) {\n return (\n <Footnote key=\"empty-text\" className={styles.empty}>\n {option.placeholder}\n </Footnote>\n );\n }\n if (isCreateNewOptionPreset(option)) {\n return (\n <CustomSelectOption\n key=\"create-new-option\"\n id={dropdownItemId}\n hovered={focusedOptionIndex === index}\n onMouseDown={() => addOptionFromInput(inputValue)}\n onMouseEnter={() => setFocusedOptionIndex(index)}\n >\n {option.actionText}\n </CustomSelectOption>\n );\n }\n return (\n <React.Fragment key={`${typeof option.value}-${option.value}`}>\n {renderOption(\n {\n id: dropdownItemId,\n disabled: option.disabled,\n hovered: focusedOption\n ? getOptionValue(option) === getOptionValue(focusedOption)\n : false,\n children: option.label,\n selected: !!value.find(\n (selectedOption: Option) =>\n getOptionValue(selectedOption) === getOptionValue(option),\n ),\n getRootRef(node) {\n if (node) {\n chipsSelectOptions[index] = node;\n }\n },\n onMouseDown(event: React.MouseEvent<HTMLDivElement>) {\n if (option.disabled) {\n return;\n }\n if (onChangeStart) {\n onChangeStart(event, option);\n }\n\n if (!event.defaultPrevented) {\n closeAfterSelect && setOpened(false);\n addOption(option);\n forbidCloseByOutsideClick.current = true;\n clearInput();\n }\n },\n onMouseEnter() {\n setFocusedOptionIndex(index);\n },\n },\n option,\n )}\n </React.Fragment>\n );\n });\n\n if (renderDropdown) {\n return renderDropdown({\n defaultDropdownContent,\n });\n }\n return defaultDropdownContent;\n }, [\n addOption,\n addOptionFromInput,\n chipsSelectOptions,\n clearInput,\n closeAfterSelect,\n dropdownId,\n focusedOption,\n focusedOptionIndex,\n getOptionValue,\n inputValue,\n onChangeStart,\n options,\n renderDropdown,\n renderOption,\n setFocusedOptionIndex,\n setOpened,\n value,\n ]);\n\n const openedClassNames = React.useMemo(\n () =>\n (opened &&\n dropdownOffsetDistance === 0 &&\n (dropdownVerticalPlacement.includes('top') ? styles.popUp : styles.popDown)) ||\n undefined,\n [dropdownOffsetDistance, opened, dropdownVerticalPlacement],\n );\n\n const clearButtonShown = allowClearButton && (!!value.length || !!inputValue.length);\n\n return (\n <>\n <ChipsInputBase\n {...restProps}\n disabled={disabled}\n readOnly={readOnly}\n clearButtonShown={clearButtonShown}\n clearButtonTestId={clearButtonTestId}\n // FormFieldProps\n id={labelledbyId}\n getRootRef={rootRef}\n className={classNames(styles.host, openedClassNames, className)}\n status={status}\n after={\n dropdownIconProp || (\n <DropdownIcon\n opened={opened}\n onClick={onDropdownIconClick}\n className={classNames(\n styles.dropdownIcon,\n clearButtonShown && styles.dropdownIconWithOffset,\n )}\n />\n )\n }\n // option\n value={value}\n onAddChipOption={addOptionFromInput}\n onRemoveChipOption={removeOption}\n renderChip={renderChip}\n onClear={clearOptions}\n // input\n getRef={inputRef}\n inputValue={inputValue}\n onInputChange={onInputChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n onKeyDown={handleKeyDown}\n // a11y\n role=\"combobox\"\n aria-expanded={opened}\n aria-autocomplete=\"list\"\n aria-controls={opened ? dropdownId : undefined}\n aria-activedescendant={opened ? dropdownCurrentItemId : undefined}\n aria-haspopup=\"listbox\"\n />\n {opened && (\n <CustomSelectDropdown\n data-testid={dropdownTestId}\n targetRef={rootRef}\n placement={dropdownVerticalPlacement}\n scrollBoxRef={dropdownScrollBoxRef}\n onPlacementChange={onDropdownPlacementChange}\n onMouseLeave={onDropdownMouseLeave}\n fetching={fetching}\n autoWidth={dropdownAutoWidth}\n forcePortal={forceDropdownPortal}\n noMaxHeight={noMaxHeight}\n offsetDistance={dropdownOffsetDistance}\n overscrollBehavior={overscrollBehavior}\n // a11y\n id={dropdownId}\n role=\"listbox\"\n aria-labelledby={labelledbyId}\n >\n {dropdownContent}\n </CustomSelectDropdown>\n )}\n </>\n );\n};\n"],"names":["React","classNames","useExternRef","useGlobalOnClickOutside","Keys","defaultFilterFn","ChipsInputBase","getNewOptionDataDefault","getOptionLabelDefault","getOptionValueDefault","renderChipDefault","CustomSelectDropdown","CustomSelectOption","DropdownIcon","Footnote","DEFAULT_EMPTY_TEXT","DEFAULT_SELECTED_BEHAVIOR","FOCUS_ACTION_NEXT","FOCUS_ACTION_PREV","isCreateNewOptionPreset","isEmptyOptionPreset","isNotServicePreset","renderOptionDefault","useChipsSelect","styles","findIndexAfter","options","startIndex","length","findIndex","option","i","disabled","findIndexBefore","endIndex","result","ChipsSelect","id","labelledbyId","getRootRef","className","status","icon","dropdownIconProp","onChangeStart","optionsProp","placement","placementProp","closeAfterSelect","selectedBehavior","emptyText","creatable","fetching","dropdownAutoWidth","forceDropdownPortal","noMaxHeight","filterFn","sortFn","dropdownTestId","onClose","onOpen","overscrollBehavior","renderDropdown","getRef","value","valueProp","defaultValue","inputValue","inputValueProp","defaultInputValue","readOnly","getOptionValue","getOptionLabel","getNewOptionData","renderChip","renderOption","onChange","onFocus","onFocusProp","onInputChange","onInputChangeProp","onBlur","onBlurProp","onKeyDown","onKeyDownProp","dropdownOffsetDistance","allowClearButton","clearButtonTestId","delimiter","restProps","addOptionFromInput","addOption","removeOption","clearOptions","inputRef","inputRefHook","clearInput","opened","setOpened","focusedOption","focusedOptionIndex","setFocusedOption","setFocusedOptionIndex","rootRef","forbidCloseByOutsideClick","useRef","dropdownVerticalPlacement","setDropdownVerticalPlacement","useState","onDropdownPlacementChange","useCallback","startsWith","dropdownId","useId","dropdownCurrentItemId","undefined","dropdownScrollBoxRef","handleFocus","event","handleBlur","defaultPrevented","preventDefault","chipsSelectOptions","current","scrollToElement","index","center","dropdown","item","dropdownHeight","offsetHeight","scrollTop","itemTop","offsetTop","itemHeight","focusOptionByIndex","oldIndex","focusOption","nextIndex","type","beforeIndex","handleKeyDown","key","ARROW_UP","ARROW_DOWN","ENTER","foundOption","ESCAPE","TAB","useEffect","foundFocusedOptionIndex","onDropdownMouseLeave","handleClickOutside","onDropdownIconClick","e","dropdownContent","useMemo","defaultDropdownContent","map","dropdownItemId","empty","placeholder","hovered","onMouseDown","onMouseEnter","actionText","Fragment","children","label","selected","find","selectedOption","node","openedClassNames","includes","popUp","popDown","clearButtonShown","host","after","onClick","dropdownIcon","dropdownIconWithOffset","onAddChipOption","onRemoveChipOption","onClear","role","aria-expanded","aria-autocomplete","aria-controls","aria-activedescendant","aria-haspopup","data-testid","targetRef","scrollBoxRef","onPlacementChange","onMouseLeave","autoWidth","forcePortal","offsetDistance","aria-labelledby"],"mappings":"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"}