rsuite 6.0.0-canary-2025032014 → 6.0.0-canary-20250416

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 (484) hide show
  1. package/AutoComplete/styles/index.css +112 -62
  2. package/AutoComplete/styles/index.less +1 -1
  3. package/Box/styles/index.css +12 -0
  4. package/CHANGELOG.md +24 -0
  5. package/Calendar/styles/index.css +11 -9
  6. package/Calendar/styles/index.less +3 -1
  7. package/Cascader/styles/index.css +112 -62
  8. package/CheckPicker/styles/index.css +112 -62
  9. package/CheckPicker/styles/index.less +1 -1
  10. package/CheckTree/styles/index.css +113 -63
  11. package/CheckTree/styles/index.less +1 -1
  12. package/CheckTreePicker/styles/index.css +113 -63
  13. package/DateInput/styles/index.css +0 -7
  14. package/DatePicker/styles/index.css +122 -74
  15. package/DatePicker/styles/index.less +5 -11
  16. package/DateRangeInput/styles/index.css +0 -7
  17. package/DateRangePicker/styles/index.css +132 -78
  18. package/DateRangePicker/styles/index.less +10 -4
  19. package/Divider/styles/index.css +2 -2
  20. package/Divider/styles/index.less +2 -2
  21. package/Grid/styles/columns.less +1 -2
  22. package/Grid/styles/grid-framework.less +1 -0
  23. package/Grid/styles/index.css +9 -4
  24. package/Grid/styles/row.less +2 -2
  25. package/Input/styles/index.css +0 -7
  26. package/Input/styles/index.less +0 -6
  27. package/Input/styles/mixin.less +0 -4
  28. package/InputGroup/styles/index.css +1 -1
  29. package/InputGroup/styles/index.less +1 -1
  30. package/InputNumber/styles/index.css +1 -8
  31. package/InputPicker/styles/index.css +121 -70
  32. package/InputPicker/styles/index.less +4 -4
  33. package/Link/package.json +7 -0
  34. package/Link/styles/index.css +32 -0
  35. package/Link/styles/index.less +39 -0
  36. package/Message/styles/index.css +9 -0
  37. package/Message/styles/index.less +11 -0
  38. package/MultiCascadeTree/styles/index.css +112 -62
  39. package/MultiCascader/styles/index.css +112 -62
  40. package/Nav/styles/index.css +1 -0
  41. package/Nav/styles/index.less +1 -0
  42. package/Pagination/styles/index.css +114 -64
  43. package/PasswordInput/package.json +7 -0
  44. package/PasswordInput/styles/index.css +172 -0
  45. package/PasswordInput/styles/index.less +1 -0
  46. package/PasswordStrengthMeter/package.json +7 -0
  47. package/PasswordStrengthMeter/styles/index.css +33 -0
  48. package/PasswordStrengthMeter/styles/index.less +39 -0
  49. package/README.md +3 -3
  50. package/RadioGroup/styles/index.css +1 -0
  51. package/RadioGroup/styles/index.less +1 -0
  52. package/RangeSlider/styles/index.css +76 -43
  53. package/Rate/styles/index.css +48 -34
  54. package/Rate/styles/index.less +32 -21
  55. package/SelectPicker/styles/index.css +112 -62
  56. package/SelectPicker/styles/index.less +1 -1
  57. package/Slider/styles/index.css +76 -43
  58. package/Slider/styles/index.less +95 -48
  59. package/Tabs/styles/index.css +1 -0
  60. package/TagInput/styles/index.css +152 -91
  61. package/TagInput/styles/index.less +1 -1
  62. package/TagPicker/styles/index.css +151 -90
  63. package/TagPicker/styles/index.less +52 -41
  64. package/Textarea/package.json +7 -0
  65. package/Textarea/styles/index.css +6 -0
  66. package/Textarea/styles/index.less +7 -0
  67. package/TimePicker/styles/index.css +122 -74
  68. package/TimeRangePicker/styles/index.css +132 -78
  69. package/Toggle/styles/index.css +146 -87
  70. package/Toggle/styles/index.less +66 -38
  71. package/Tree/styles/index.css +113 -63
  72. package/Tree/styles/index.less +1 -1
  73. package/TreePicker/styles/index.css +113 -63
  74. package/cjs/AutoComplete/AutoComplete.d.ts +1 -1
  75. package/cjs/AutoComplete/AutoComplete.js +13 -11
  76. package/cjs/Avatar/Avatar.d.ts +3 -4
  77. package/cjs/Breadcrumb/Breadcrumb.js +2 -2
  78. package/cjs/Breadcrumb/BreadcrumbItem.js +1 -1
  79. package/cjs/Button/Button.js +9 -10
  80. package/cjs/Calendar/CalendarProvider.js +0 -0
  81. package/cjs/Calendar/hooks/useCalendar.js +0 -0
  82. package/cjs/Carousel/Carousel.js +2 -2
  83. package/cjs/Cascader/Cascader.js +42 -45
  84. package/cjs/Cascader/useActive.d.ts +6 -4
  85. package/cjs/Cascader/useActive.js +10 -8
  86. package/cjs/CheckPicker/CheckPicker.js +38 -41
  87. package/cjs/CheckTreePicker/CheckTreePicker.js +20 -22
  88. package/cjs/CustomProvider/CustomProvider.d.ts +1 -4
  89. package/cjs/CustomProvider/types.d.ts +10 -2
  90. package/cjs/DatePicker/DatePicker.d.ts +1 -1
  91. package/cjs/DatePicker/DatePicker.js +28 -25
  92. package/cjs/DatePicker/utils.d.ts +3 -3
  93. package/cjs/DatePicker/utils.js +3 -3
  94. package/cjs/DateRangePicker/DateRangePicker.js +39 -33
  95. package/cjs/DateRangePicker/utils.js +0 -0
  96. package/cjs/Divider/Divider.d.ts +3 -2
  97. package/cjs/Divider/Divider.js +2 -2
  98. package/cjs/Form/hooks/useFormValidate.js +0 -0
  99. package/cjs/Form/hooks/useSchemaModel.js +2 -54
  100. package/cjs/Form/utils/constructFlatSchema.d.ts +4 -0
  101. package/cjs/Form/utils/constructFlatSchema.js +41 -0
  102. package/cjs/FormControl/hooks/useField.js +0 -0
  103. package/cjs/FormControl/utils.js +0 -0
  104. package/cjs/Grid/Row.d.ts +2 -2
  105. package/cjs/Grid/Row.js +2 -20
  106. package/cjs/Grid/types.d.ts +1 -0
  107. package/cjs/Grid/utils/styles.d.ts +6 -0
  108. package/cjs/Grid/utils/styles.js +43 -0
  109. package/cjs/Image/Image.js +12 -11
  110. package/cjs/Image/hooks/useImage.d.ts +2 -0
  111. package/cjs/Image/hooks/useImage.js +19 -43
  112. package/cjs/InlineEdit/InlineEdit.js +3 -1
  113. package/cjs/InlineEdit/useEditState.d.ts +2 -0
  114. package/cjs/InlineEdit/useEditState.js +8 -0
  115. package/cjs/Input/Input.d.ts +3 -12
  116. package/cjs/Input/Input.js +12 -73
  117. package/cjs/InputPicker/InputPicker.js +27 -28
  118. package/cjs/Link/ExternalLinkIcon.d.ts +3 -0
  119. package/cjs/Link/ExternalLinkIcon.js +23 -0
  120. package/cjs/Link/Link.d.ts +14 -0
  121. package/cjs/Link/Link.js +52 -0
  122. package/cjs/Link/index.d.ts +4 -0
  123. package/cjs/Link/index.js +11 -0
  124. package/cjs/List/List.js +6 -2
  125. package/cjs/List/helper/useSortHelper.d.ts +7 -5
  126. package/cjs/List/helper/useSortHelper.js +109 -16
  127. package/cjs/List/helper/utils.js +14 -6
  128. package/cjs/MultiCascader/MultiCascader.js +40 -43
  129. package/cjs/Nav/NavItem.js +1 -1
  130. package/cjs/Nav/NavMegaMenu.d.ts +5 -0
  131. package/cjs/Nav/NavMegaMenu.js +5 -0
  132. package/cjs/Navbar/NavbarItem.js +1 -1
  133. package/cjs/Navbar/NavbarMegaMenu.js +1 -1
  134. package/cjs/PasswordInput/PasswordInput.d.ts +14 -0
  135. package/cjs/PasswordInput/PasswordInput.js +71 -0
  136. package/cjs/PasswordInput/index.d.ts +4 -0
  137. package/cjs/PasswordInput/index.js +11 -0
  138. package/cjs/PasswordStrengthMeter/PasswordStrengthMeter.d.ts +12 -0
  139. package/cjs/PasswordStrengthMeter/PasswordStrengthMeter.js +50 -0
  140. package/cjs/PasswordStrengthMeter/index.d.ts +4 -0
  141. package/cjs/PasswordStrengthMeter/index.js +11 -0
  142. package/cjs/RangeSlider/RangeSlider.js +18 -3
  143. package/cjs/Rate/Character.d.ts +4 -3
  144. package/cjs/Rate/Character.js +19 -15
  145. package/cjs/Rate/Rate.d.ts +10 -2
  146. package/cjs/Rate/Rate.js +47 -42
  147. package/cjs/Rate/types.d.ts +8 -0
  148. package/cjs/Rate/types.js +4 -0
  149. package/cjs/Rate/useRatingStates.d.ts +20 -0
  150. package/cjs/Rate/useRatingStates.js +48 -0
  151. package/cjs/Rate/utils.d.ts +14 -3
  152. package/cjs/Rate/utils.js +50 -9
  153. package/cjs/SelectPicker/SelectPicker.js +45 -46
  154. package/cjs/Sidenav/ExpandedSidenavDropdownItem.js +1 -1
  155. package/cjs/Sidenav/SidenavItem.js +1 -1
  156. package/cjs/Slider/Graduated.d.ts +4 -0
  157. package/cjs/Slider/Graduated.js +43 -20
  158. package/cjs/Slider/Handle.d.ts +1 -1
  159. package/cjs/Slider/Handle.js +12 -12
  160. package/cjs/Slider/Slider.d.ts +16 -1
  161. package/cjs/Slider/Slider.js +7 -2
  162. package/cjs/Slider/useDrag.d.ts +1 -0
  163. package/cjs/Slider/useDrag.js +8 -3
  164. package/cjs/Steps/Steps.js +2 -2
  165. package/cjs/Tabs/Tabs.js +2 -2
  166. package/cjs/Textarea/Textarea.d.ts +32 -0
  167. package/cjs/Textarea/Textarea.js +51 -0
  168. package/cjs/Textarea/index.d.ts +4 -0
  169. package/cjs/Textarea/index.js +11 -0
  170. package/cjs/Timeline/Timeline.js +2 -2
  171. package/cjs/Toggle/Toggle.d.ts +10 -1
  172. package/cjs/Toggle/Toggle.js +12 -9
  173. package/cjs/TreePicker/TreePicker.js +18 -19
  174. package/cjs/index.d.ts +4 -1
  175. package/cjs/index.js +24 -6
  176. package/cjs/internals/Box/Box.d.ts +4 -0
  177. package/cjs/internals/Box/Box.js +1 -1
  178. package/cjs/internals/Box/utils.js +5 -1
  179. package/cjs/internals/InputBase/InputBase.d.ts +45 -0
  180. package/cjs/internals/InputBase/InputBase.js +96 -0
  181. package/cjs/internals/InputBase/index.d.ts +3 -0
  182. package/cjs/internals/InputBase/index.js +8 -0
  183. package/cjs/internals/Overlay/Modal.d.ts +1 -1
  184. package/cjs/internals/Overlay/OverlayTrigger.d.ts +4 -3
  185. package/cjs/internals/Overlay/OverlayTrigger.js +8 -3
  186. package/cjs/internals/Picker/Listbox.js +7 -9
  187. package/cjs/internals/Picker/PickerDrawer.d.ts +8 -0
  188. package/cjs/internals/Picker/PickerDrawer.js +31 -0
  189. package/cjs/internals/Picker/PickerPopup.js +5 -3
  190. package/cjs/internals/Picker/PickerToggle.d.ts +1 -0
  191. package/cjs/internals/Picker/PickerToggle.js +10 -3
  192. package/cjs/internals/Picker/PickerToggleTrigger.d.ts +51 -11
  193. package/cjs/internals/Picker/PickerToggleTrigger.js +59 -13
  194. package/cjs/internals/Picker/hooks/index.d.ts +0 -1
  195. package/cjs/internals/Picker/hooks/index.js +2 -4
  196. package/cjs/internals/Picker/hooks/useCombobox.d.ts +1 -0
  197. package/cjs/internals/Picker/hooks/useCombobox.js +3 -1
  198. package/cjs/internals/Picker/index.d.ts +1 -2
  199. package/cjs/internals/Picker/index.js +10 -12
  200. package/{esm → cjs/internals}/SafeAnchor/SafeAnchor.d.ts +2 -2
  201. package/cjs/{SafeAnchor → internals/SafeAnchor}/SafeAnchor.js +3 -3
  202. package/cjs/internals/Tree/TreeView.js +3 -4
  203. package/cjs/internals/hooks/useRootClose.js +4 -4
  204. package/cjs/internals/index.d.ts +4 -0
  205. package/cjs/internals/index.js +13 -1
  206. package/cjs/internals/types/html.d.ts +2 -0
  207. package/cjs/internals/utils/{dom.d.ts → html/dom.d.ts} +1 -0
  208. package/cjs/internals/utils/{dom.js → html/dom.js} +8 -0
  209. package/cjs/internals/utils/{events.js → html/events.js} +0 -0
  210. package/cjs/internals/utils/{htmlPropsUtils.js → html/htmlPropsUtils.js} +0 -0
  211. package/cjs/internals/utils/html/index.d.ts +4 -0
  212. package/cjs/internals/utils/html/index.js +28 -0
  213. package/cjs/internals/utils/{safeSetSelection.js → html/safeSetSelection.js} +1 -1
  214. package/cjs/internals/utils/index.d.ts +3 -15
  215. package/cjs/internals/utils/index.js +20 -49
  216. package/cjs/internals/utils/{ReactChildren.d.ts → react/ReactChildren.d.ts} +2 -8
  217. package/cjs/internals/utils/{ReactChildren.js → react/ReactChildren.js} +5 -25
  218. package/cjs/internals/utils/react/ReactIs.d.ts +7 -0
  219. package/cjs/internals/utils/react/ReactIs.js +26 -0
  220. package/{esm/internals/utils → cjs/internals/utils/react}/createComponent.d.ts +2 -2
  221. package/cjs/internals/utils/{createComponent.js → react/createComponent.js} +3 -3
  222. package/cjs/internals/utils/{deprecateComponent.js → react/deprecateComponent.js} +1 -1
  223. package/cjs/internals/utils/{forwardRef.d.ts → react/forwardRef.d.ts} +1 -1
  224. package/cjs/internals/utils/react/index.d.ts +7 -0
  225. package/cjs/internals/utils/react/index.js +46 -0
  226. package/cjs/internals/utils/{mergeRefs.js → react/mergeRefs.js} +0 -0
  227. package/cjs/internals/utils/{getStringLength.d.ts → string/getStringLength.d.ts} +0 -1
  228. package/cjs/internals/utils/{getStringLength.js → string/getStringLength.js} +1 -3
  229. package/cjs/internals/utils/string/index.d.ts +4 -0
  230. package/cjs/internals/utils/string/index.js +28 -0
  231. package/cjs/internals/utils/{stringifyReactNode.js → string/stringifyReactNode.js} +0 -0
  232. package/cjs/internals/utils/{tplTransform.js → string/tplTransform.js} +0 -0
  233. package/cjs/locales/en_GB.js +2 -2
  234. package/cjs/locales/en_US.js +2 -2
  235. package/cjs/locales/index.js +0 -0
  236. package/cjs/locales/pl_PL.js +2 -3
  237. package/cjs/useBreakpointValue/useBreakpointValue.d.ts +6 -2
  238. package/cjs/useBreakpointValue/useBreakpointValue.js +9 -4
  239. package/cjs/useMediaQuery/breakpoints.d.ts +24 -0
  240. package/cjs/useMediaQuery/breakpoints.js +248 -0
  241. package/cjs/useMediaQuery/index.d.ts +1 -1
  242. package/cjs/useMediaQuery/types.d.ts +45 -0
  243. package/cjs/useMediaQuery/types.js +4 -0
  244. package/cjs/useMediaQuery/useMediaQuery.d.ts +4 -13
  245. package/cjs/useMediaQuery/useMediaQuery.js +30 -12
  246. package/cjs/useToaster/useToaster.d.ts +1 -1
  247. package/cjs/useToaster/useToaster.js +1 -1
  248. package/dist/rsuite-no-reset-rtl.css +565 -276
  249. package/dist/rsuite-no-reset-rtl.min.css +1 -1
  250. package/dist/rsuite-no-reset-rtl.min.css.map +1 -1
  251. package/dist/rsuite-no-reset.css +565 -276
  252. package/dist/rsuite-no-reset.min.css +1 -1
  253. package/dist/rsuite-no-reset.min.css.map +1 -1
  254. package/dist/rsuite-rtl.css +565 -276
  255. package/dist/rsuite-rtl.min.css +1 -1
  256. package/dist/rsuite-rtl.min.css.map +1 -1
  257. package/dist/rsuite.css +565 -276
  258. package/dist/rsuite.js +508 -211
  259. package/dist/rsuite.js.map +1 -1
  260. package/dist/rsuite.min.css +1 -1
  261. package/dist/rsuite.min.css.map +1 -1
  262. package/dist/rsuite.min.js +1 -1
  263. package/dist/rsuite.min.js.map +1 -1
  264. package/esm/AutoComplete/AutoComplete.d.ts +1 -1
  265. package/esm/AutoComplete/AutoComplete.js +13 -11
  266. package/esm/Avatar/Avatar.d.ts +3 -4
  267. package/esm/Breadcrumb/Breadcrumb.js +3 -3
  268. package/esm/Breadcrumb/BreadcrumbItem.js +1 -1
  269. package/esm/Button/Button.js +10 -11
  270. package/esm/Calendar/CalendarProvider.js +0 -0
  271. package/esm/Calendar/hooks/useCalendar.js +0 -0
  272. package/esm/Carousel/Carousel.js +3 -3
  273. package/esm/Cascader/Cascader.js +43 -46
  274. package/esm/Cascader/useActive.d.ts +6 -4
  275. package/esm/Cascader/useActive.js +10 -8
  276. package/esm/CheckPicker/CheckPicker.js +39 -42
  277. package/esm/CheckTreePicker/CheckTreePicker.js +21 -23
  278. package/esm/CustomProvider/CustomProvider.d.ts +1 -4
  279. package/esm/CustomProvider/types.d.ts +10 -2
  280. package/esm/DatePicker/DatePicker.d.ts +1 -1
  281. package/esm/DatePicker/DatePicker.js +29 -26
  282. package/esm/DatePicker/utils.d.ts +3 -3
  283. package/esm/DatePicker/utils.js +4 -4
  284. package/esm/DateRangePicker/DateRangePicker.js +35 -29
  285. package/esm/DateRangePicker/utils.js +0 -0
  286. package/esm/Divider/Divider.d.ts +3 -2
  287. package/esm/Divider/Divider.js +2 -2
  288. package/esm/Form/hooks/useFormValidate.js +0 -0
  289. package/esm/Form/hooks/useSchemaModel.js +3 -55
  290. package/esm/Form/utils/constructFlatSchema.d.ts +4 -0
  291. package/esm/Form/utils/constructFlatSchema.js +37 -0
  292. package/esm/FormControl/hooks/useField.js +0 -0
  293. package/esm/FormControl/utils.js +0 -0
  294. package/esm/Grid/Row.d.ts +2 -2
  295. package/esm/Grid/Row.js +2 -20
  296. package/esm/Grid/types.d.ts +1 -0
  297. package/esm/Grid/utils/styles.d.ts +6 -0
  298. package/esm/Grid/utils/styles.js +37 -0
  299. package/esm/Image/Image.js +12 -11
  300. package/esm/Image/hooks/useImage.d.ts +2 -0
  301. package/esm/Image/hooks/useImage.js +20 -43
  302. package/esm/InlineEdit/InlineEdit.js +3 -1
  303. package/esm/InlineEdit/useEditState.d.ts +2 -0
  304. package/esm/InlineEdit/useEditState.js +8 -0
  305. package/esm/Input/Input.d.ts +3 -12
  306. package/esm/Input/Input.js +12 -74
  307. package/esm/InputPicker/InputPicker.js +28 -29
  308. package/esm/Link/ExternalLinkIcon.d.ts +3 -0
  309. package/esm/Link/ExternalLinkIcon.js +18 -0
  310. package/esm/Link/Link.d.ts +14 -0
  311. package/esm/Link/Link.js +47 -0
  312. package/esm/Link/index.d.ts +4 -0
  313. package/esm/Link/index.js +8 -0
  314. package/esm/List/List.js +6 -2
  315. package/esm/List/helper/useSortHelper.d.ts +7 -5
  316. package/esm/List/helper/useSortHelper.js +109 -16
  317. package/esm/List/helper/utils.js +14 -6
  318. package/esm/MultiCascader/MultiCascader.js +41 -44
  319. package/esm/Nav/NavItem.js +1 -1
  320. package/esm/Nav/NavMegaMenu.d.ts +5 -0
  321. package/esm/Nav/NavMegaMenu.js +5 -0
  322. package/esm/Navbar/NavbarItem.js +1 -1
  323. package/esm/Navbar/NavbarMegaMenu.js +1 -1
  324. package/esm/PasswordInput/PasswordInput.d.ts +14 -0
  325. package/esm/PasswordInput/PasswordInput.js +66 -0
  326. package/esm/PasswordInput/index.d.ts +4 -0
  327. package/esm/PasswordInput/index.js +8 -0
  328. package/esm/PasswordStrengthMeter/PasswordStrengthMeter.d.ts +12 -0
  329. package/esm/PasswordStrengthMeter/PasswordStrengthMeter.js +45 -0
  330. package/esm/PasswordStrengthMeter/index.d.ts +4 -0
  331. package/esm/PasswordStrengthMeter/index.js +8 -0
  332. package/esm/RangeSlider/RangeSlider.js +18 -3
  333. package/esm/Rate/Character.d.ts +4 -3
  334. package/esm/Rate/Character.js +20 -16
  335. package/esm/Rate/Rate.d.ts +10 -2
  336. package/esm/Rate/Rate.js +49 -42
  337. package/esm/Rate/types.d.ts +8 -0
  338. package/esm/Rate/types.js +2 -0
  339. package/esm/Rate/useRatingStates.d.ts +20 -0
  340. package/esm/Rate/useRatingStates.js +43 -0
  341. package/esm/Rate/utils.d.ts +14 -3
  342. package/esm/Rate/utils.js +46 -7
  343. package/esm/SelectPicker/SelectPicker.js +46 -47
  344. package/esm/Sidenav/ExpandedSidenavDropdownItem.js +1 -1
  345. package/esm/Sidenav/SidenavItem.js +1 -1
  346. package/esm/Slider/Graduated.d.ts +4 -0
  347. package/esm/Slider/Graduated.js +43 -20
  348. package/esm/Slider/Handle.d.ts +1 -1
  349. package/esm/Slider/Handle.js +12 -12
  350. package/esm/Slider/Slider.d.ts +16 -1
  351. package/esm/Slider/Slider.js +7 -2
  352. package/esm/Slider/useDrag.d.ts +1 -0
  353. package/esm/Slider/useDrag.js +8 -3
  354. package/esm/Steps/Steps.js +3 -3
  355. package/esm/Tabs/Tabs.js +3 -3
  356. package/esm/Textarea/Textarea.d.ts +32 -0
  357. package/esm/Textarea/Textarea.js +46 -0
  358. package/esm/Textarea/index.d.ts +4 -0
  359. package/esm/Textarea/index.js +8 -0
  360. package/esm/Timeline/Timeline.js +3 -3
  361. package/esm/Toggle/Toggle.d.ts +10 -1
  362. package/esm/Toggle/Toggle.js +12 -9
  363. package/esm/TreePicker/TreePicker.js +19 -20
  364. package/esm/index.d.ts +4 -1
  365. package/esm/index.js +4 -1
  366. package/esm/internals/Box/Box.d.ts +4 -0
  367. package/esm/internals/Box/Box.js +1 -1
  368. package/esm/internals/Box/utils.js +5 -1
  369. package/esm/internals/InputBase/InputBase.d.ts +45 -0
  370. package/esm/internals/InputBase/InputBase.js +89 -0
  371. package/esm/internals/InputBase/index.d.ts +3 -0
  372. package/esm/internals/InputBase/index.js +3 -0
  373. package/esm/internals/Overlay/Modal.d.ts +1 -1
  374. package/esm/internals/Overlay/OverlayTrigger.d.ts +4 -3
  375. package/esm/internals/Overlay/OverlayTrigger.js +8 -2
  376. package/esm/internals/Picker/Listbox.js +8 -10
  377. package/esm/internals/Picker/PickerDrawer.d.ts +8 -0
  378. package/esm/internals/Picker/PickerDrawer.js +26 -0
  379. package/esm/internals/Picker/PickerPopup.js +5 -3
  380. package/esm/internals/Picker/PickerToggle.d.ts +1 -0
  381. package/esm/internals/Picker/PickerToggle.js +10 -3
  382. package/esm/internals/Picker/PickerToggleTrigger.d.ts +51 -11
  383. package/esm/internals/Picker/PickerToggleTrigger.js +59 -12
  384. package/esm/internals/Picker/hooks/index.d.ts +0 -1
  385. package/esm/internals/Picker/hooks/index.js +1 -2
  386. package/esm/internals/Picker/hooks/useCombobox.d.ts +1 -0
  387. package/esm/internals/Picker/hooks/useCombobox.js +3 -1
  388. package/esm/internals/Picker/index.d.ts +1 -2
  389. package/esm/internals/Picker/index.js +1 -2
  390. package/{cjs → esm/internals}/SafeAnchor/SafeAnchor.d.ts +2 -2
  391. package/esm/{SafeAnchor → internals/SafeAnchor}/SafeAnchor.js +3 -3
  392. package/esm/internals/Tree/TreeView.js +4 -5
  393. package/esm/internals/hooks/useRootClose.js +1 -1
  394. package/esm/internals/index.d.ts +4 -0
  395. package/esm/internals/index.js +5 -0
  396. package/esm/internals/types/html.d.ts +2 -0
  397. package/esm/internals/utils/{dom.d.ts → html/dom.d.ts} +1 -0
  398. package/esm/internals/utils/{dom.js → html/dom.js} +7 -0
  399. package/esm/internals/utils/{events.js → html/events.js} +0 -0
  400. package/esm/internals/utils/{htmlPropsUtils.js → html/htmlPropsUtils.js} +0 -0
  401. package/esm/internals/utils/html/index.d.ts +4 -0
  402. package/esm/internals/utils/html/index.js +5 -0
  403. package/esm/internals/utils/{safeSetSelection.js → html/safeSetSelection.js} +1 -1
  404. package/esm/internals/utils/index.d.ts +3 -15
  405. package/esm/internals/utils/index.js +3 -14
  406. package/esm/internals/utils/{ReactChildren.d.ts → react/ReactChildren.d.ts} +2 -8
  407. package/esm/internals/utils/{ReactChildren.js → react/ReactChildren.js} +3 -21
  408. package/esm/internals/utils/react/ReactIs.d.ts +7 -0
  409. package/esm/internals/utils/react/ReactIs.js +22 -0
  410. package/{cjs/internals/utils → esm/internals/utils/react}/createComponent.d.ts +2 -2
  411. package/esm/internals/utils/{createComponent.js → react/createComponent.js} +3 -3
  412. package/esm/internals/utils/{deprecateComponent.js → react/deprecateComponent.js} +1 -1
  413. package/esm/internals/utils/{forwardRef.d.ts → react/forwardRef.d.ts} +1 -1
  414. package/esm/internals/utils/react/index.d.ts +7 -0
  415. package/esm/internals/utils/react/index.js +8 -0
  416. package/esm/internals/utils/{mergeRefs.js → react/mergeRefs.js} +0 -0
  417. package/esm/internals/utils/{getStringLength.d.ts → string/getStringLength.d.ts} +0 -1
  418. package/esm/internals/utils/{getStringLength.js → string/getStringLength.js} +1 -2
  419. package/esm/internals/utils/string/index.d.ts +4 -0
  420. package/esm/internals/utils/string/index.js +5 -0
  421. package/esm/internals/utils/{stringifyReactNode.js → string/stringifyReactNode.js} +0 -0
  422. package/esm/internals/utils/{tplTransform.js → string/tplTransform.js} +0 -0
  423. package/esm/locales/en_GB.js +2 -2
  424. package/esm/locales/en_US.js +2 -2
  425. package/esm/locales/index.js +0 -0
  426. package/esm/locales/pl_PL.js +1 -1
  427. package/esm/useBreakpointValue/useBreakpointValue.d.ts +6 -2
  428. package/esm/useBreakpointValue/useBreakpointValue.js +9 -4
  429. package/esm/useMediaQuery/breakpoints.d.ts +24 -0
  430. package/esm/useMediaQuery/breakpoints.js +244 -0
  431. package/esm/useMediaQuery/index.d.ts +1 -1
  432. package/esm/useMediaQuery/types.d.ts +45 -0
  433. package/esm/useMediaQuery/types.js +2 -0
  434. package/esm/useMediaQuery/useMediaQuery.d.ts +4 -13
  435. package/esm/useMediaQuery/useMediaQuery.js +29 -11
  436. package/esm/useToaster/useToaster.d.ts +1 -1
  437. package/esm/useToaster/useToaster.js +1 -1
  438. package/internals/Box/styles/index.less +4 -0
  439. package/internals/Picker/styles/index.less +105 -23
  440. package/internals/Picker/styles/mixin.less +6 -6
  441. package/package.json +3 -2
  442. package/styles/color-modes/dark.less +2 -2
  443. package/styles/color-modes/high-contrast.less +2 -2
  444. package/styles/color-modes/light.less +2 -2
  445. package/styles/index.less +3 -0
  446. package/styles/root.less +2 -0
  447. package/styles/variables.less +0 -24
  448. package/SafeAnchor/package.json +0 -7
  449. package/cjs/Form/hooks/useFormClassNames.d.ts +0 -5
  450. package/cjs/Form/hooks/useFormClassNames.js +0 -29
  451. package/cjs/internals/Picker/hooks/usePickerClassName.d.ts +0 -19
  452. package/cjs/internals/Picker/hooks/usePickerClassName.js +0 -45
  453. package/esm/Form/hooks/useFormClassNames.d.ts +0 -5
  454. package/esm/Form/hooks/useFormClassNames.js +0 -25
  455. package/esm/internals/Picker/hooks/usePickerClassName.d.ts +0 -19
  456. package/esm/internals/Picker/hooks/usePickerClassName.js +0 -40
  457. /package/cjs/{SafeAnchor → internals/SafeAnchor}/index.d.ts +0 -0
  458. /package/cjs/{SafeAnchor → internals/SafeAnchor}/index.js +0 -0
  459. /package/cjs/internals/utils/{events.d.ts → html/events.d.ts} +0 -0
  460. /package/cjs/internals/utils/{htmlPropsUtils.d.ts → html/htmlPropsUtils.d.ts} +0 -0
  461. /package/cjs/internals/utils/{safeSetSelection.d.ts → html/safeSetSelection.d.ts} +0 -0
  462. /package/cjs/internals/utils/{deprecateComponent.d.ts → react/deprecateComponent.d.ts} +0 -0
  463. /package/cjs/internals/utils/{forwardRef.js → react/forwardRef.js} +0 -0
  464. /package/cjs/internals/utils/{getDOMNode.d.ts → react/getDOMNode.d.ts} +0 -0
  465. /package/cjs/internals/utils/{getDOMNode.js → react/getDOMNode.js} +0 -0
  466. /package/cjs/internals/utils/{mergeRefs.d.ts → react/mergeRefs.d.ts} +0 -0
  467. /package/cjs/internals/utils/{getSafeRegExpString.d.ts → string/getSafeRegExpString.d.ts} +0 -0
  468. /package/cjs/internals/utils/{getSafeRegExpString.js → string/getSafeRegExpString.js} +0 -0
  469. /package/cjs/internals/utils/{stringifyReactNode.d.ts → string/stringifyReactNode.d.ts} +0 -0
  470. /package/cjs/internals/utils/{tplTransform.d.ts → string/tplTransform.d.ts} +0 -0
  471. /package/esm/{SafeAnchor → internals/SafeAnchor}/index.d.ts +0 -0
  472. /package/esm/{SafeAnchor → internals/SafeAnchor}/index.js +0 -0
  473. /package/esm/internals/utils/{events.d.ts → html/events.d.ts} +0 -0
  474. /package/esm/internals/utils/{htmlPropsUtils.d.ts → html/htmlPropsUtils.d.ts} +0 -0
  475. /package/esm/internals/utils/{safeSetSelection.d.ts → html/safeSetSelection.d.ts} +0 -0
  476. /package/esm/internals/utils/{deprecateComponent.d.ts → react/deprecateComponent.d.ts} +0 -0
  477. /package/esm/internals/utils/{forwardRef.js → react/forwardRef.js} +0 -0
  478. /package/esm/internals/utils/{getDOMNode.d.ts → react/getDOMNode.d.ts} +0 -0
  479. /package/esm/internals/utils/{getDOMNode.js → react/getDOMNode.js} +0 -0
  480. /package/esm/internals/utils/{mergeRefs.d.ts → react/mergeRefs.d.ts} +0 -0
  481. /package/esm/internals/utils/{getSafeRegExpString.d.ts → string/getSafeRegExpString.d.ts} +0 -0
  482. /package/esm/internals/utils/{getSafeRegExpString.js → string/getSafeRegExpString.js} +0 -0
  483. /package/esm/internals/utils/{stringifyReactNode.d.ts → string/stringifyReactNode.d.ts} +0 -0
  484. /package/esm/internals/utils/{tplTransform.d.ts → string/tplTransform.d.ts} +0 -0
@@ -0,0 +1,43 @@
1
+ 'use client';
2
+ "use strict";
3
+
4
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
5
+ exports.__esModule = true;
6
+ exports.getResponsiveGutterStyles = void 0;
7
+ var _isPlainObject = _interopRequireDefault(require("lodash/isPlainObject"));
8
+ var _constants = require("../../internals/constants");
9
+ var _utils = require("../../internals/utils");
10
+ /**
11
+ * Generates CSS variable styles for grid gutters, supporting both single values and arrays [horizontal, vertical]
12
+ */
13
+ const getResponsiveGutterStyles = gutter => {
14
+ if (typeof gutter === 'undefined') {
15
+ return {};
16
+ }
17
+
18
+ // Helper function to process gutter values and generate CSS variables
19
+ const processGutterValue = function (value, prefix) {
20
+ if (prefix === void 0) {
21
+ prefix = '';
22
+ }
23
+ const [h, v] = Array.isArray(value) ? value : [value, value];
24
+ return {
25
+ [`--rs-grid-gutter${prefix}`]: (0, _utils.getCssValue)(h),
26
+ [`--rs-grid-row-gutter${prefix}`]: (0, _utils.getCssValue)(v)
27
+ };
28
+ };
29
+
30
+ // Handle responsive object
31
+ if ((0, _isPlainObject.default)(gutter)) {
32
+ return _constants.BREAKPOINTS.reduce((styles, breakpoint) => {
33
+ const value = gutter[breakpoint];
34
+ if (!value) return styles;
35
+ const prefix = breakpoint === 'xs' ? '' : `-${breakpoint}`;
36
+ return (0, _utils.mergeStyles)(styles, processGutterValue(value, prefix));
37
+ }, {});
38
+ }
39
+
40
+ // Handle non-responsive value
41
+ return processGutterValue(gutter);
42
+ };
43
+ exports.getResponsiveGutterStyles = getResponsiveGutterStyles;
@@ -50,19 +50,14 @@ const Image = (0, _utils.forwardRef)((props, ref) => {
50
50
  shaded,
51
51
  zoomed
52
52
  }));
53
- const imgProps = {
54
- crossOrigin,
55
- srcSet,
56
- sizes,
57
- loading
58
- };
59
53
  const {
60
54
  imgSrc,
61
- isLoading
55
+ isLoading,
56
+ onLoad,
57
+ onError
62
58
  } = (0, _useImage.useImage)({
63
59
  src,
64
- fallbackSrc,
65
- ...imgProps
60
+ fallbackSrc
66
61
  });
67
62
  const styles = {
68
63
  ...style,
@@ -76,8 +71,14 @@ const Image = (0, _utils.forwardRef)((props, ref) => {
76
71
  className: classes,
77
72
  style: styles,
78
73
  width: width,
79
- height: height
80
- }, imgProps, rest));
74
+ height: height,
75
+ loading: loading,
76
+ onLoad: onLoad,
77
+ onError: onError,
78
+ crossOrigin: crossOrigin,
79
+ srcSet: srcSet,
80
+ sizes: sizes
81
+ }, rest));
81
82
  if (zoomed) {
82
83
  return /*#__PURE__*/_react.default.createElement(_ImageWrapper.ImageWrapper, {
83
84
  w: width,
@@ -10,5 +10,7 @@ export declare const useImage: (props: UseImageProps) => {
10
10
  imgSrc: string | null;
11
11
  isLoading: boolean;
12
12
  error: boolean;
13
+ onLoad: () => void;
14
+ onError: () => void;
13
15
  };
14
16
  export {};
@@ -1,65 +1,41 @@
1
1
  'use client';
2
2
  "use strict";
3
3
 
4
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
5
4
  exports.__esModule = true;
6
5
  exports.useImage = void 0;
7
6
  var _react = require("react");
8
- var _useIsomorphicLayoutEffect = _interopRequireDefault(require("../../internals/hooks/useIsomorphicLayoutEffect"));
9
7
  const useImage = props => {
10
8
  const {
11
9
  src,
12
- fallbackSrc,
13
- crossOrigin,
14
- srcSet,
15
- sizes,
16
- loading
10
+ fallbackSrc
17
11
  } = props;
18
12
  const [imgSrc, setImgSrc] = (0, _react.useState)(src || fallbackSrc || null);
19
13
  const [isLoading, setIsLoading] = (0, _react.useState)(!!src);
20
14
  const [error, setError] = (0, _react.useState)(false);
21
- const imageRef = (0, _react.useRef)(null);
22
15
  (0, _react.useEffect)(() => {
23
- setIsLoading(!!src); // true if src exists, false otherwise
24
- }, [src]);
25
- const flush = () => {
26
- if (imageRef.current) {
27
- imageRef.current.onload = null;
28
- imageRef.current.onerror = null;
16
+ if (!src) {
17
+ setIsLoading(false);
18
+ return;
29
19
  }
20
+ setImgSrc(src);
21
+ setIsLoading(true);
22
+ setError(false);
23
+ }, [src]);
24
+ const handleLoad = () => {
25
+ setIsLoading(false);
26
+ setError(false);
27
+ };
28
+ const handleError = () => {
29
+ setIsLoading(false);
30
+ setError(true);
31
+ setImgSrc(fallbackSrc || null);
30
32
  };
31
- const loadImage = (0, _react.useCallback)(() => {
32
- if (!src) return;
33
- flush();
34
- const image = new Image();
35
- image.src = src;
36
- if (crossOrigin) image.crossOrigin = crossOrigin;
37
- if (srcSet) image.srcset = srcSet;
38
- if (sizes) image.sizes = sizes;
39
- if (loading) image.loading = loading;
40
- image.onload = () => {
41
- flush();
42
- setImgSrc(src);
43
- setIsLoading(false);
44
- };
45
- image.onerror = () => {
46
- flush();
47
- setError(true);
48
- setImgSrc(fallbackSrc || null);
49
- setIsLoading(false);
50
- };
51
- imageRef.current = image;
52
- }, [crossOrigin, fallbackSrc, loading, sizes, src, srcSet]);
53
- (0, _useIsomorphicLayoutEffect.default)(() => {
54
- loadImage();
55
- return () => {
56
- flush();
57
- };
58
- }, [loadImage]);
59
33
  return {
60
34
  imgSrc,
61
35
  isLoading,
62
- error
36
+ error,
37
+ onLoad: handleLoad,
38
+ onError: handleError
63
39
  };
64
40
  };
65
41
  exports.useImage = useImage;
@@ -43,6 +43,7 @@ const InlineEdit = (0, _utils.forwardRef)((props, ref) => {
43
43
  onChange,
44
44
  onKeyDown,
45
45
  onClick,
46
+ onFocus,
46
47
  htmlProps
47
48
  } = (0, _useEditState.default)({
48
49
  ...rest,
@@ -75,7 +76,8 @@ const InlineEdit = (0, _utils.forwardRef)((props, ref) => {
75
76
  disabled
76
77
  })),
77
78
  onClick: onClick,
78
- onKeyDown: onKeyDown
79
+ onKeyDown: onKeyDown,
80
+ onFocus: onFocus
79
81
  }, htmlProps), (0, _renderChildren.renderChildren)(children, childrenProps, target), showControls && isEditing && /*#__PURE__*/_react.default.createElement(_EditableControls.default, {
80
82
  className: prefix('controls'),
81
83
  onSave: onSave,
@@ -8,12 +8,14 @@ interface EditStateProps {
8
8
  onCancel?: (event?: React.MouseEvent) => void;
9
9
  onSave?: (event?: React.MouseEvent) => void;
10
10
  onClick?: (event: React.SyntheticEvent) => void;
11
+ onFocus?: (event?: React.FocusEvent) => void;
11
12
  }
12
13
  declare const useEditState: (props: EditStateProps) => {
13
14
  isEditing: boolean;
14
15
  value: any;
15
16
  onClick: (...args: any[]) => any;
16
17
  onChange: (...args: any[]) => any;
18
+ onFocus: (...args: any[]) => any;
17
19
  onCancel: (...args: any[]) => any;
18
20
  onSave: (...args: any[]) => any;
19
21
  onKeyDown: (...args: any[]) => any;
@@ -15,6 +15,7 @@ const useEditState = props => {
15
15
  onCancel,
16
16
  onSave,
17
17
  onClick,
18
+ onFocus,
18
19
  ...htmlProps
19
20
  } = props;
20
21
  const [isEditing, setIsEditing] = (0, _react.useState)(false);
@@ -31,6 +32,12 @@ const useEditState = props => {
31
32
  setIsEditing(true);
32
33
  setResetValue(value);
33
34
  });
35
+ const handleFocus = (0, _hooks.useEventCallback)(event => {
36
+ if (disabled) return;
37
+ onFocus === null || onFocus === void 0 || onFocus(event);
38
+ setIsEditing(true);
39
+ setResetValue(value);
40
+ });
34
41
  const handleChange = (0, _hooks.useEventCallback)((value, event) => {
35
42
  setValue(value);
36
43
  onChange === null || onChange === void 0 || onChange(value, event);
@@ -68,6 +75,7 @@ const useEditState = props => {
68
75
  value,
69
76
  onClick: handleClick,
70
77
  onChange: handleChange,
78
+ onFocus: handleFocus,
71
79
  onCancel: handleCancel,
72
80
  onSave: handleSave,
73
81
  onKeyDown: handleKeyDown,
@@ -1,19 +1,10 @@
1
1
  import React from 'react';
2
- import { BoxProps } from '../internals/Box';
2
+ import { InputBaseCommonProps } from '../internals/InputBase';
3
3
  import { PrependParameters } from '../internals/types/utils';
4
- import type { PropsWithoutChange, SanitizedInputProps, FormControlBaseProps, Size } from '../internals/types';
5
- export interface LocaleType {
6
- unfilled: string;
7
- }
8
- export interface InputProps extends BoxProps, SanitizedInputProps, PropsWithoutChange<FormControlBaseProps> {
4
+ import type { SanitizedInputProps, PropsWithoutChange, FormControlBaseProps } from '../internals/types';
5
+ export interface InputProps extends InputBaseCommonProps, SanitizedInputProps, PropsWithoutChange<FormControlBaseProps> {
9
6
  /** The HTML input type */
10
7
  type?: string;
11
- /** The HTML input id */
12
- id?: string;
13
- /** A component can have different sizes */
14
- size?: Size;
15
- /** Ref of input element */
16
- inputRef?: React.Ref<any>;
17
8
  /**
18
9
  * The htmlSize attribute defines the width of the <input> element.
19
10
  *
@@ -6,13 +6,9 @@ exports.__esModule = true;
6
6
  exports.default = void 0;
7
7
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
8
8
  var _react = _interopRequireWildcard(require("react"));
9
- var _Plaintext = _interopRequireDefault(require("../internals/Plaintext"));
10
- var _Box = _interopRequireDefault(require("../internals/Box"));
11
9
  var _utils = require("../internals/utils");
12
- var _FormGroup = require("../FormGroup");
10
+ var _InputBase = _interopRequireDefault(require("../internals/InputBase"));
13
11
  var _InputGroup = require("../InputGroup/InputGroup");
14
- var _constants = require("../internals/constants");
15
- var _hooks = require("../internals/hooks");
16
12
  var _CustomProvider = require("../CustomProvider");
17
13
  function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
18
14
  function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
@@ -27,79 +23,22 @@ const Input = (0, _utils.forwardRef)((props, ref) => {
27
23
  } = (0, _CustomProvider.useCustom)('Input', props);
28
24
  const inputGroup = (0, _react.useContext)(_InputGroup.InputGroupContext);
29
25
  const {
30
- as = 'input',
31
- className,
32
- classPrefix = 'input',
33
26
  type = 'text',
34
- disabled,
35
- value,
36
- defaultValue,
37
- inputRef,
38
- id,
39
- size = (inputGroup === null || inputGroup === void 0 ? void 0 : inputGroup.size) || 'md',
40
27
  htmlSize,
41
- plaintext,
42
- placeholder,
43
- readOnly,
44
- onPressEnter,
45
- onFocus,
46
- onBlur,
47
- onKeyDown,
48
- onChange,
28
+ size = (inputGroup === null || inputGroup === void 0 ? void 0 : inputGroup.size) || 'md',
29
+ classPrefix = 'input',
49
30
  ...rest
50
31
  } = propsWithDefaults;
51
- const handleKeyDown = event => {
52
- if (event.key === _constants.KEY_VALUES.ENTER) {
53
- onPressEnter === null || onPressEnter === void 0 || onPressEnter(event);
54
- }
55
- onKeyDown === null || onKeyDown === void 0 || onKeyDown(event);
56
- };
57
- const handleChange = event => {
58
- var _event$target;
59
- onChange === null || onChange === void 0 || onChange((_event$target = event.target) === null || _event$target === void 0 ? void 0 : _event$target.value, event);
60
- };
61
- const {
62
- withPrefix,
63
- merge
64
- } = (0, _hooks.useStyles)(classPrefix);
65
- const classes = merge(className, withPrefix(size, {
66
- plaintext
67
- }));
68
- const {
69
- controlId
70
- } = (0, _FormGroup.useFormGroup)();
71
-
72
- // Make the Input component display in plain text,
73
- // and display default characters when there is no value.
74
- if (plaintext) {
75
- return /*#__PURE__*/_react.default.createElement(_Plaintext.default, {
76
- ref: ref,
77
- localeKey: "unfilled",
78
- placeholder: placeholder
79
- }, typeof value === 'undefined' ? defaultValue : value);
80
- }
81
- const inputable = !disabled && !readOnly;
82
- const eventProps = {};
83
- if (inputable) {
84
- eventProps.onChange = handleChange;
85
- eventProps.onKeyDown = handleKeyDown;
86
- eventProps.onFocus = (0, _utils.createChainedFunction)(onFocus, inputGroup === null || inputGroup === void 0 ? void 0 : inputGroup.onFocus);
87
- eventProps.onBlur = (0, _utils.createChainedFunction)(onBlur, inputGroup === null || inputGroup === void 0 ? void 0 : inputGroup.onBlur);
88
- }
89
- return /*#__PURE__*/_react.default.createElement(_Box.default, (0, _extends2.default)({
90
- as: as
91
- }, rest, eventProps, {
92
- ref: (0, _utils.mergeRefs)(ref, inputRef),
93
- className: classes,
32
+ return /*#__PURE__*/_react.default.createElement(_InputBase.default, (0, _extends2.default)({
33
+ as: "input",
34
+ ref: ref,
35
+ classPrefix: classPrefix,
36
+ size: size,
94
37
  type: type,
95
- id: id || controlId,
96
- value: value,
97
- defaultValue: defaultValue,
98
- disabled: disabled,
99
- readOnly: readOnly,
100
- size: htmlSize,
101
- placeholder: placeholder
102
- }));
38
+ inputProps: {
39
+ size: htmlSize
40
+ }
41
+ }, rest));
103
42
  });
104
43
  Input.displayName = 'Input';
105
44
  var _default = exports.default = Input;
@@ -11,7 +11,6 @@ var _isFunction = _interopRequireDefault(require("lodash/isFunction"));
11
11
  var _remove = _interopRequireDefault(require("lodash/remove"));
12
12
  var _clone = _interopRequireDefault(require("lodash/clone"));
13
13
  var _isArray = _interopRequireDefault(require("lodash/isArray"));
14
- var _omit = _interopRequireDefault(require("lodash/omit"));
15
14
  var _pick = _interopRequireDefault(require("lodash/pick"));
16
15
  var _Tag = _interopRequireDefault(require("../Tag"));
17
16
  var _TextBox = _interopRequireDefault(require("./TextBox"));
@@ -19,7 +18,6 @@ var _Stack = _interopRequireDefault(require("../Stack"));
19
18
  var _useInput = _interopRequireDefault(require("./hooks/useInput"));
20
19
  var _useData = _interopRequireDefault(require("./hooks/useData"));
21
20
  var _Plaintext = _interopRequireDefault(require("../internals/Plaintext"));
22
- var _Box = _interopRequireDefault(require("../internals/Box"));
23
21
  var _utils = require("../internals/Tree/utils");
24
22
  var _hooks = require("../internals/hooks");
25
23
  var _constants = require("../internals/constants");
@@ -43,8 +41,10 @@ const InputPicker = (0, _utils3.forwardRef)((props, ref) => {
43
41
  const {
44
42
  as,
45
43
  appearance = 'default',
44
+ block,
46
45
  cleanable = true,
47
46
  cacheData = [],
47
+ className,
48
48
  classPrefix = 'picker',
49
49
  caretAs,
50
50
  data: controlledData = [],
@@ -571,19 +571,8 @@ const InputPicker = (0, _utils3.forwardRef)((props, ref) => {
571
571
  const hasSingleValue = !(0, _isNil.default)(value) && (0, _isFunction.default)(renderValue) && !(0, _isNil.default)(itemNode);
572
572
  const hasMultiValue = (0, _isArray.default)(value) && value.length > 0 && (0, _isFunction.default)(renderValue) && !(0, _isNil.default)(tagElements);
573
573
  const hasValue = multi ? !!(tagElements !== null && tagElements !== void 0 && tagElements.length) || hasMultiValue : isValid || hasSingleValue;
574
- const [pickerClasses, usedClassNamePropKeys] = (0, _Picker.usePickerClassName)({
575
- ...props,
576
- classPrefix,
577
- appearance,
578
- hasValue,
579
- name: 'input',
580
- cleanable
581
- });
582
- const classes = merge(pickerClasses, {
583
- [prefix`tag`]: multi,
584
- [prefix(`${multi ? 'tag' : 'input'}-${size}`)]: size,
585
- [prefix`focused`]: open,
586
- [prefix`disabled-options`]: disabledOptions
574
+ const classes = merge(className, {
575
+ [prefix`focused`]: open
587
576
  });
588
577
  const searching = !!searchKeyword && open;
589
578
  const editable = searchable && !disabled && !loading;
@@ -602,26 +591,36 @@ const InputPicker = (0, _utils3.forwardRef)((props, ref) => {
602
591
  }, plaintextProps), itemNode || (tagElements !== null && tagElements !== void 0 && tagElements.length ? tagElements : null) || placeholder);
603
592
  }
604
593
  const placeholderNode = placeholder || (disabledOptions ? null : locale === null || locale === void 0 ? void 0 : locale.placeholder);
605
- return /*#__PURE__*/_react.default.createElement(_Picker.PickerToggleTrigger, {
594
+ const triggerProps = {
595
+ ...(0, _pick.default)(props, _Picker.triggerPropKeys),
596
+ onEnter: (0, _utils3.createChainedFunction)(handleEnter, onEnter),
597
+ onEntered: onEntered,
598
+ onExit: (0, _utils3.createChainedFunction)(handleExit, onExit),
599
+ onExited: (0, _utils3.createChainedFunction)(handleExited, onExited)
600
+ };
601
+ return /*#__PURE__*/_react.default.createElement(_Picker.PickerToggleTrigger, (0, _extends2.default)({
606
602
  id: id,
607
603
  multiple: multi,
608
- pickerProps: (0, _pick.default)(props, _Picker.pickTriggerPropKeys),
604
+ name: multi ? 'tag' : 'input',
605
+ block: block,
606
+ disabled: disabled,
607
+ appearance: appearance,
608
+ as: as,
609
+ triggerProps: triggerProps,
609
610
  ref: triggerRef,
610
611
  trigger: "active",
611
- onEnter: (0, _utils3.createChainedFunction)(handleEnter, onEnter),
612
- onEntered: onEntered,
613
- onExit: (0, _utils3.createChainedFunction)(handleExit, onExit),
614
- onExited: (0, _utils3.createChainedFunction)(handleExited, onExited),
615
612
  speaker: renderPopup,
616
- placement: placement
617
- }, /*#__PURE__*/_react.default.createElement(_Box.default, (0, _extends2.default)({
618
- as: as,
619
- className: classes,
613
+ placement: placement,
614
+ rootRef: root,
620
615
  style: style,
616
+ size: size,
617
+ classPrefix: classPrefix,
618
+ className: classes,
619
+ responsive: searchable === false,
621
620
  onClick: focus,
622
621
  onKeyDown: onPickerKeyDown,
623
- ref: root
624
- }, (0, _omit.default)(rest, [..._Picker.omitTriggerPropKeys, ...usedClassNamePropKeys])), /*#__PURE__*/_react.default.createElement(_Picker.PickerToggle, {
622
+ "data-disabled-options": disabledOptions
623
+ }, rest), /*#__PURE__*/_react.default.createElement(_Picker.PickerToggle, {
625
624
  loading: loading,
626
625
  label: label,
627
626
  appearance: appearance,
@@ -654,7 +653,7 @@ const InputPicker = (0, _utils3.forwardRef)((props, ref) => {
654
653
  onBlur: onBlur,
655
654
  onFocus: handleFocus,
656
655
  onChange: handleSearch
657
- })));
656
+ }));
658
657
  });
659
658
  InputPicker.displayName = 'InputPicker';
660
659
  var _default = exports.default = InputPicker;
@@ -0,0 +1,3 @@
1
+ import React from 'react';
2
+ declare const ExternalLinkIcon: (props: React.HTMLAttributes<SVGElement>) => React.JSX.Element;
3
+ export default ExternalLinkIcon;
@@ -0,0 +1,23 @@
1
+ 'use client';
2
+ "use strict";
3
+
4
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
5
+ exports.__esModule = true;
6
+ exports.default = void 0;
7
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
8
+ var _react = _interopRequireDefault(require("react"));
9
+ const ExternalLinkIcon = props => /*#__PURE__*/_react.default.createElement("svg", (0, _extends2.default)({
10
+ stroke: "currentColor",
11
+ fill: "currentColor",
12
+ strokeWidth: "0",
13
+ viewBox: "0 0 24 24",
14
+ height: "1em",
15
+ width: "1em",
16
+ xmlns: "http://www.w3.org/2000/svg"
17
+ }, props), /*#__PURE__*/_react.default.createElement("path", {
18
+ fill: "none",
19
+ d: "M0 0h24v24H0V0z"
20
+ }), /*#__PURE__*/_react.default.createElement("path", {
21
+ d: "M19 19H5V5h7V3H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14c1.1 0 2-.9 2-2v-7h-2v7zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3h-7z"
22
+ }));
23
+ var _default = exports.default = ExternalLinkIcon;
@@ -0,0 +1,14 @@
1
+ import React from 'react';
2
+ import { SafeAnchorProps } from '../internals/SafeAnchor';
3
+ export interface LinkProps extends SafeAnchorProps {
4
+ /** The icon to be displayed after the link */
5
+ anchorIcon?: React.ReactNode;
6
+ /** Determines in which cases link should have text-decoration: underline styles, hover by default */
7
+ underline?: 'always' | 'hover' | 'not-hover' | 'never';
8
+ /** Whether the link is external */
9
+ external?: boolean;
10
+ /** Whether to show the anchor icon */
11
+ showAnchorIcon?: boolean;
12
+ }
13
+ declare const Link: import("../internals/types").InternalRefForwardingComponent<"a", LinkProps, never> & Record<string, never>;
14
+ export default Link;
@@ -0,0 +1,52 @@
1
+ 'use client';
2
+ "use strict";
3
+
4
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
5
+ exports.__esModule = true;
6
+ exports.default = void 0;
7
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _utils = require("../internals/utils");
10
+ var _hooks = require("../internals/hooks");
11
+ var _CustomProvider = require("../CustomProvider");
12
+ var _SafeAnchor = _interopRequireDefault(require("../internals/SafeAnchor"));
13
+ var _ExternalLinkIcon = _interopRequireDefault(require("./ExternalLinkIcon"));
14
+ const Link = (0, _utils.forwardRef)((props, ref) => {
15
+ const {
16
+ propsWithDefaults
17
+ } = (0, _CustomProvider.useCustom)('Link', props);
18
+ const {
19
+ as,
20
+ anchorIcon,
21
+ classPrefix = 'link',
22
+ className,
23
+ children,
24
+ disabled,
25
+ underline,
26
+ showAnchorIcon,
27
+ external,
28
+ ...rest
29
+ } = propsWithDefaults;
30
+ const {
31
+ merge,
32
+ prefix,
33
+ withPrefix
34
+ } = (0, _hooks.useStyles)(classPrefix);
35
+ const classes = merge(className, withPrefix());
36
+ const icon = anchorIcon || /*#__PURE__*/_react.default.createElement(_ExternalLinkIcon.default, {
37
+ className: prefix('icon')
38
+ });
39
+ return /*#__PURE__*/_react.default.createElement(_SafeAnchor.default, (0, _extends2.default)({
40
+ as: as,
41
+ ref: ref,
42
+ role: "link",
43
+ className: classes,
44
+ disabled: disabled,
45
+ target: external ? '_blank' : undefined,
46
+ rel: external ? 'noopener noreferrer' : undefined,
47
+ "data-underline": underline,
48
+ "data-disabled": disabled
49
+ }, rest), children, showAnchorIcon && icon);
50
+ });
51
+ Link.displayName = 'Link';
52
+ var _default = exports.default = Link;
@@ -0,0 +1,4 @@
1
+ import Link from './Link';
2
+ export type { LinkProps } from './Link';
3
+ export { Link };
4
+ export default Link;
@@ -0,0 +1,11 @@
1
+ 'use client';
2
+ "use strict";
3
+
4
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
5
+ exports.__esModule = true;
6
+ exports.default = void 0;
7
+ var _Link = _interopRequireDefault(require("./Link"));
8
+ exports.Link = _Link.default;
9
+ // export types
10
+ // export components
11
+ var _default = exports.default = _Link.default;
package/cjs/List/List.js CHANGED
@@ -55,7 +55,9 @@ const List = (0, _utils.forwardRef)((props, ref) => {
55
55
  register,
56
56
  sorting,
57
57
  handleEnd,
58
- handleStart
58
+ handleStart,
59
+ handleTouchStart,
60
+ handleTouchEnd
59
61
  } = (0, _useSortHelper.default)({
60
62
  autoScroll,
61
63
  onSort,
@@ -83,7 +85,9 @@ const List = (0, _utils.forwardRef)((props, ref) => {
83
85
  ref: (0, _utils.mergeRefs)(containerRef, ref),
84
86
  className: classes,
85
87
  onMouseDown: sortable ? handleStart : undefined,
86
- onMouseUp: sortable ? handleEnd : undefined
88
+ onMouseUp: sortable ? handleEnd : undefined,
89
+ onTouchStart: sortable ? handleTouchStart : undefined,
90
+ onTouchEnd: sortable ? handleTouchEnd : undefined
87
91
  }, rest), /*#__PURE__*/_react.default.createElement(_ListContext.default.Provider, {
88
92
  value: contextValue
89
93
  }, children));
@@ -1,4 +1,4 @@
1
- import { MouseEventHandler } from 'react';
1
+ import { MouseEventHandler, TouchEventHandler } from 'react';
2
2
  import { Collection, ManagedItem } from './useManager';
3
3
  export interface MovedItemInfo {
4
4
  collection: Collection;
@@ -10,14 +10,16 @@ export type SortConfig = {
10
10
  autoScroll?: boolean;
11
11
  pressDelay?: number;
12
12
  transitionDuration?: number;
13
- onSortStart?(payload?: MovedItemInfo, event?: MouseEvent): void;
14
- onSortMove?(payload?: MovedItemInfo, event?: MouseEvent): void;
15
- onSortEnd?(payload?: MovedItemInfo, event?: MouseEvent): void;
16
- onSort?(payload?: MovedItemInfo, event?: MouseEvent): void;
13
+ onSortStart?(payload?: MovedItemInfo, event?: MouseEvent | TouchEvent): void;
14
+ onSortMove?(payload?: MovedItemInfo, event?: MouseEvent | TouchEvent): void;
15
+ onSortEnd?(payload?: MovedItemInfo, event?: MouseEvent | TouchEvent): void;
16
+ onSort?(payload?: MovedItemInfo, event?: MouseEvent | TouchEvent): void;
17
17
  };
18
18
  declare const useSortHelper: (config: SortConfig) => {
19
19
  handleStart: MouseEventHandler<Element>;
20
20
  handleEnd: MouseEventHandler<Element>;
21
+ handleTouchStart: TouchEventHandler<Element>;
22
+ handleTouchEnd: TouchEventHandler<Element>;
21
23
  containerRef: import("react").RefObject<HTMLDivElement | null>;
22
24
  sorting: boolean;
23
25
  register: (item: ManagedItem) => {