rsuite 5.2.3 → 5.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (495) hide show
  1. package/Avatar/styles/index.less +2 -2
  2. package/AvatarGroup/package.json +7 -0
  3. package/AvatarGroup/styles/index.less +19 -0
  4. package/ButtonGroup/styles/index.less +0 -18
  5. package/CHANGELOG.md +63 -0
  6. package/CheckTreePicker/styles/index.less +14 -1
  7. package/Dropdown/styles/index.less +4 -3
  8. package/Nav/styles/index.less +1 -0
  9. package/Navbar/styles/index.less +7 -0
  10. package/Radio/styles/index.less +6 -0
  11. package/Sidenav/styles/index.less +2 -2
  12. package/Stack/package.json +7 -0
  13. package/Stack/styles/index.less +5 -0
  14. package/Table/styles/index.less +0 -4
  15. package/TreePicker/styles/index.less +10 -14
  16. package/cjs/@types/common.d.ts +13 -12
  17. package/cjs/@types/utils.d.ts +12 -0
  18. package/cjs/Affix/Affix.js +5 -5
  19. package/cjs/Animation/Transition.d.ts +21 -12
  20. package/cjs/Animation/Transition.js +4 -1
  21. package/cjs/AutoComplete/AutoComplete.js +1 -1
  22. package/cjs/AutoComplete/utils.d.ts +1 -1
  23. package/cjs/Avatar/Avatar.js +10 -3
  24. package/cjs/AvatarGroup/AvatarGroup.d.ts +15 -0
  25. package/cjs/AvatarGroup/AvatarGroup.js +76 -0
  26. package/cjs/AvatarGroup/index.d.ts +3 -0
  27. package/cjs/AvatarGroup/index.js +11 -0
  28. package/cjs/Breadcrumb/Breadcrumb.js +1 -1
  29. package/cjs/Button/Button.js +8 -2
  30. package/cjs/ButtonGroup/ButtonGroup.js +14 -3
  31. package/cjs/ButtonGroup/ButtonGroupContext.d.ts +7 -0
  32. package/cjs/ButtonGroup/ButtonGroupContext.js +13 -0
  33. package/cjs/ButtonGroup/index.d.ts +2 -0
  34. package/cjs/ButtonGroup/index.js +3 -0
  35. package/cjs/Calendar/Calendar.d.ts +4 -4
  36. package/cjs/Calendar/Calendar.js +26 -22
  37. package/cjs/Calendar/CalendarContext.js +1 -1
  38. package/cjs/Calendar/Header.js +1 -3
  39. package/cjs/Calendar/Table.js +1 -1
  40. package/cjs/Calendar/TableRow.js +13 -8
  41. package/cjs/Calendar/TimeDropdown.js +6 -5
  42. package/cjs/Calendar/View.js +9 -5
  43. package/cjs/Calendar/types.d.ts +2 -2
  44. package/cjs/Calendar/useCalendarDate.d.ts +2 -2
  45. package/cjs/Carousel/Carousel.d.ts +2 -2
  46. package/cjs/Carousel/Carousel.js +1 -1
  47. package/cjs/Cascader/Cascader.d.ts +1 -1
  48. package/cjs/Cascader/Cascader.js +10 -10
  49. package/cjs/Cascader/DropdownMenu.d.ts +5 -4
  50. package/cjs/Cascader/utils.d.ts +10 -10
  51. package/cjs/CheckPicker/CheckPicker.d.ts +9 -4
  52. package/cjs/CheckPicker/CheckPicker.js +4 -4
  53. package/cjs/CheckPicker/test/CheckPicker.test.d.ts +1 -0
  54. package/cjs/CheckPicker/test/CheckPicker.test.js +76 -0
  55. package/cjs/CheckTree/index.js +6 -5
  56. package/cjs/CheckTreePicker/CheckTreeNode.d.ts +1 -1
  57. package/cjs/CheckTreePicker/CheckTreeNode.js +7 -9
  58. package/cjs/CheckTreePicker/CheckTreePicker.js +34 -27
  59. package/cjs/CheckTreePicker/utils.d.ts +3 -1
  60. package/cjs/CheckTreePicker/utils.js +12 -10
  61. package/cjs/Checkbox/Checkbox.d.ts +1 -1
  62. package/cjs/Container/Container.js +6 -3
  63. package/cjs/CustomProvider/CustomProvider.d.ts +31 -57
  64. package/cjs/DOMHelper/index.d.ts +12 -12
  65. package/cjs/DatePicker/DatePicker.d.ts +1 -1
  66. package/cjs/DatePicker/DatePicker.js +19 -11
  67. package/cjs/DatePicker/Toolbar.d.ts +12 -9
  68. package/cjs/DatePicker/Toolbar.js +6 -8
  69. package/cjs/DatePicker/types.d.ts +4 -4
  70. package/cjs/DatePicker/utils.d.ts +4 -3
  71. package/cjs/DateRangePicker/Calendar.d.ts +9 -7
  72. package/cjs/DateRangePicker/Calendar.js +27 -6
  73. package/cjs/DateRangePicker/DateRangePicker.d.ts +8 -6
  74. package/cjs/DateRangePicker/DateRangePicker.js +133 -110
  75. package/cjs/DateRangePicker/types.d.ts +2 -1
  76. package/cjs/DateRangePicker/utils.d.ts +6 -6
  77. package/cjs/DateRangePicker/utils.js +7 -2
  78. package/cjs/Disclosure/Disclosure.js +6 -4
  79. package/cjs/Disclosure/DisclosureButton.js +9 -7
  80. package/cjs/Disclosure/DisclosureContent.js +4 -6
  81. package/cjs/Disclosure/DisclosureContext.d.ts +2 -2
  82. package/cjs/Disclosure/useDisclosureContext.d.ts +2 -0
  83. package/cjs/Disclosure/useDisclosureContext.js +20 -0
  84. package/cjs/Dropdown/Dropdown.d.ts +1 -1
  85. package/cjs/Dropdown/DropdownContext.d.ts +2 -2
  86. package/cjs/Dropdown/DropdownItem.js +1 -1
  87. package/cjs/Dropdown/DropdownMenu.d.ts +3 -3
  88. package/cjs/Dropdown/DropdownMenu.js +9 -6
  89. package/cjs/Dropdown/DropdownState.d.ts +1 -1
  90. package/cjs/Dropdown/DropdownToggle.js +10 -2
  91. package/cjs/Dropdown/useRenderDropdownItem.d.ts +1 -1
  92. package/cjs/Form/Form.js +1 -1
  93. package/cjs/Form/FormContext.d.ts +1 -1
  94. package/cjs/FormControl/FormControl.d.ts +1 -1
  95. package/cjs/FormControl/FormControl.js +5 -4
  96. package/cjs/FormGroup/FormGroup.d.ts +1 -1
  97. package/cjs/FormGroup/FormGroup.js +9 -4
  98. package/cjs/Input/Input.d.ts +3 -2
  99. package/cjs/InputGroup/InputGroup.d.ts +1 -1
  100. package/cjs/InputNumber/InputNumber.js +6 -2
  101. package/cjs/InputPicker/InputAutosize.js +4 -4
  102. package/cjs/InputPicker/InputPicker.d.ts +2 -2
  103. package/cjs/InputPicker/InputPicker.js +15 -10
  104. package/cjs/List/ListContext.d.ts +1 -1
  105. package/cjs/List/ListContext.js +8 -1
  106. package/cjs/List/helper/AutoScroller.js +4 -2
  107. package/cjs/List/helper/useManager.d.ts +3 -3
  108. package/cjs/List/helper/useManager.js +1 -1
  109. package/cjs/List/helper/useSortHelper.d.ts +3 -3
  110. package/cjs/List/helper/useSortHelper.js +6 -4
  111. package/cjs/List/helper/utils.d.ts +2 -2
  112. package/cjs/MaskedInput/TextMask.d.ts +5 -5
  113. package/cjs/MaskedInput/adjustCaretPosition.d.ts +6 -6
  114. package/cjs/MaskedInput/conformToMask.js +5 -4
  115. package/cjs/MaskedInput/createTextMaskInputElement.d.ts +2 -2
  116. package/cjs/MaskedInput/utilities.d.ts +1 -1
  117. package/cjs/Menu/Menu.js +14 -7
  118. package/cjs/Menu/MenuContext.d.ts +1 -1
  119. package/cjs/Menu/MenuItem.d.ts +1 -1
  120. package/cjs/Menu/MenuItem.js +19 -15
  121. package/cjs/Menu/Menubar.js +8 -8
  122. package/cjs/Menu/useMenu.js +17 -7
  123. package/cjs/Modal/Modal.js +12 -6
  124. package/cjs/Modal/ModalContext.d.ts +2 -2
  125. package/cjs/Modal/utils.d.ts +1 -1
  126. package/cjs/Modal/utils.js +3 -5
  127. package/cjs/MultiCascader/DropdownMenu.d.ts +4 -4
  128. package/cjs/MultiCascader/MultiCascader.js +6 -6
  129. package/cjs/MultiCascader/utils.d.ts +17 -17
  130. package/cjs/Nav/Nav.d.ts +1 -1
  131. package/cjs/Nav/Nav.js +10 -12
  132. package/cjs/Nav/NavContext.d.ts +7 -1
  133. package/cjs/Nav/NavContext.js +1 -0
  134. package/cjs/Nav/NavItem.d.ts +1 -1
  135. package/cjs/Navbar/Navbar.js +1 -1
  136. package/cjs/Navbar/NavbarItem.d.ts +1 -1
  137. package/cjs/Overlay/Modal.d.ts +2 -2
  138. package/cjs/Overlay/Modal.js +70 -45
  139. package/cjs/Overlay/ModalManager.d.ts +17 -8
  140. package/cjs/Overlay/ModalManager.js +11 -20
  141. package/cjs/Overlay/Overlay.d.ts +3 -3
  142. package/cjs/Overlay/Overlay.js +8 -2
  143. package/cjs/Overlay/OverlayContext.d.ts +6 -0
  144. package/cjs/Overlay/OverlayContext.js +14 -0
  145. package/cjs/Overlay/OverlayTrigger.d.ts +11 -11
  146. package/cjs/Overlay/OverlayTrigger.js +21 -7
  147. package/cjs/Overlay/Position.d.ts +4 -4
  148. package/cjs/Overlay/Position.js +14 -8
  149. package/cjs/Overlay/positionUtils.d.ts +1 -1
  150. package/cjs/Overlay/positionUtils.js +8 -8
  151. package/cjs/Pagination/Pagination.d.ts +1 -1
  152. package/cjs/Pagination/PaginationButton.d.ts +3 -3
  153. package/cjs/Pagination/PaginationGroup.js +5 -3
  154. package/cjs/Panel/Panel.d.ts +1 -1
  155. package/cjs/Panel/Panel.js +2 -2
  156. package/cjs/PanelGroup/PanelGroup.d.ts +2 -2
  157. package/cjs/PanelGroup/PanelGroup.js +8 -5
  158. package/cjs/Picker/DropdownMenu.d.ts +8 -5
  159. package/cjs/Picker/DropdownMenu.js +5 -5
  160. package/cjs/Picker/PickerOverlay.js +4 -3
  161. package/cjs/Picker/PickerToggle.js +4 -3
  162. package/cjs/Picker/PickerToggleTrigger.d.ts +2 -6
  163. package/cjs/Picker/SearchBar.d.ts +1 -1
  164. package/cjs/Picker/SelectedElement.js +2 -1
  165. package/cjs/Picker/VirtualizedList.d.ts +29 -2
  166. package/cjs/Picker/propTypes.d.ts +5 -7
  167. package/cjs/Picker/propTypes.js +4 -3
  168. package/cjs/Picker/utils.d.ts +15 -23
  169. package/cjs/Picker/utils.js +71 -46
  170. package/cjs/Placeholder/PlaceholderGrid.js +1 -1
  171. package/cjs/Plaintext/Plaintext.js +2 -1
  172. package/cjs/Radio/Radio.d.ts +1 -1
  173. package/cjs/RadioGroup/RadioGroup.d.ts +2 -2
  174. package/cjs/RadioGroup/RadioGroup.js +1 -1
  175. package/cjs/RangeSlider/RangeSlider.d.ts +2 -2
  176. package/cjs/RangeSlider/RangeSlider.js +6 -4
  177. package/cjs/Rate/Character.js +4 -2
  178. package/cjs/Rate/Rate.js +2 -1
  179. package/cjs/Ripple/Ripple.js +1 -1
  180. package/cjs/SelectPicker/SelectPicker.d.ts +12 -5
  181. package/cjs/SelectPicker/SelectPicker.js +8 -8
  182. package/cjs/SelectPicker/index.d.ts +1 -1
  183. package/cjs/SelectPicker/test/SelectPicker.test.d.ts +1 -0
  184. package/cjs/SelectPicker/test/SelectPicker.test.js +62 -0
  185. package/cjs/Sidenav/Node.d.ts +1 -1
  186. package/cjs/Sidenav/Sidenav.d.ts +4 -4
  187. package/cjs/Sidenav/Sidenav.js +5 -2
  188. package/cjs/Sidenav/SidenavDropdown.js +11 -8
  189. package/cjs/Sidenav/SidenavDropdownItem.js +10 -5
  190. package/cjs/Sidenav/SidenavDropdownMenu.js +9 -5
  191. package/cjs/Sidenav/SidenavItem.d.ts +1 -1
  192. package/cjs/Sidenav/SidenavItem.js +4 -0
  193. package/cjs/Slider/Graduated.d.ts +5 -5
  194. package/cjs/Slider/Handle.d.ts +1 -1
  195. package/cjs/Slider/Handle.js +10 -6
  196. package/cjs/Slider/Mark.d.ts +1 -1
  197. package/cjs/Slider/Slider.d.ts +1 -1
  198. package/cjs/Slider/Slider.js +2 -2
  199. package/cjs/Slider/utils.d.ts +2 -1
  200. package/cjs/Slider/utils.js +4 -5
  201. package/cjs/Stack/Stack.d.ts +26 -0
  202. package/cjs/Stack/Stack.js +86 -0
  203. package/cjs/Stack/index.d.ts +3 -0
  204. package/cjs/Stack/index.js +11 -0
  205. package/cjs/Steps/StepItem.js +1 -1
  206. package/cjs/TagInput/index.js +1 -1
  207. package/cjs/Toggle/Toggle.js +5 -4
  208. package/cjs/Tree/Tree.d.ts +3 -2
  209. package/cjs/Tree/Tree.js +6 -5
  210. package/cjs/Tree/TreeContext.d.ts +0 -1
  211. package/cjs/TreePicker/TreeNode.js +7 -22
  212. package/cjs/TreePicker/TreePicker.js +37 -54
  213. package/cjs/Uploader/UploadFileItem.d.ts +1 -1
  214. package/cjs/Uploader/UploadFileItem.js +2 -2
  215. package/cjs/Uploader/UploadTrigger.d.ts +1 -1
  216. package/cjs/Uploader/UploadTrigger.js +2 -3
  217. package/cjs/Uploader/Uploader.d.ts +5 -5
  218. package/cjs/Uploader/Uploader.js +1 -2
  219. package/cjs/index.d.ts +6 -2
  220. package/cjs/index.js +13 -5
  221. package/cjs/locales/index.d.ts +3 -3
  222. package/cjs/toaster/ToastContainer.d.ts +1 -1
  223. package/cjs/toaster/ToastContainer.js +1 -1
  224. package/cjs/toaster/toaster.js +3 -1
  225. package/cjs/utils/BrowserDetection.js +1 -1
  226. package/cjs/utils/ReactChildren.d.ts +2 -2
  227. package/cjs/utils/ajaxUpload.d.ts +1 -1
  228. package/cjs/utils/ajaxUpload.js +5 -4
  229. package/cjs/utils/appendTooltip.d.ts +1 -1
  230. package/cjs/utils/constants.d.ts +4 -4
  231. package/cjs/utils/createChainedFunction.d.ts +1 -1
  232. package/cjs/utils/getDataGroupBy.d.ts +1 -1
  233. package/cjs/utils/mergeRefs.d.ts +2 -2
  234. package/cjs/utils/previewFile.d.ts +1 -1
  235. package/cjs/utils/propTypeChecker.d.ts +6 -2
  236. package/cjs/utils/propTypeChecker.js +7 -6
  237. package/cjs/utils/reactToString.d.ts +2 -1
  238. package/cjs/utils/statusIcons.d.ts +1 -1
  239. package/cjs/utils/stringToObject.d.ts +1 -1
  240. package/cjs/utils/treeUtils.d.ts +35 -32
  241. package/cjs/utils/treeUtils.js +46 -23
  242. package/cjs/utils/useControlled.d.ts +6 -1
  243. package/cjs/utils/useControlled.js +0 -8
  244. package/cjs/utils/useCustom.js +6 -4
  245. package/cjs/utils/useFocus.d.ts +2 -2
  246. package/cjs/utils/usePortal.d.ts +2 -2
  247. package/cjs/utils/useRootClose.d.ts +2 -2
  248. package/cjs/utils/useTimeout.d.ts +1 -1
  249. package/cjs/utils/useTimeout.js +5 -3
  250. package/dist/rsuite-rtl.css +63 -193
  251. package/dist/rsuite-rtl.min.css +1 -1
  252. package/dist/rsuite-rtl.min.css.map +1 -1
  253. package/dist/rsuite.css +63 -193
  254. package/dist/rsuite.js +194 -117
  255. package/dist/rsuite.js.map +1 -1
  256. package/dist/rsuite.min.css +1 -1
  257. package/dist/rsuite.min.css.map +1 -1
  258. package/dist/rsuite.min.js +1 -1
  259. package/dist/rsuite.min.js.map +1 -1
  260. package/esm/@types/common.d.ts +13 -12
  261. package/esm/@types/utils.d.ts +12 -0
  262. package/esm/Affix/Affix.js +5 -5
  263. package/esm/Animation/Transition.d.ts +21 -12
  264. package/esm/Animation/Transition.js +4 -1
  265. package/esm/AutoComplete/AutoComplete.js +1 -1
  266. package/esm/AutoComplete/utils.d.ts +1 -1
  267. package/esm/Avatar/Avatar.js +7 -3
  268. package/esm/AvatarGroup/AvatarGroup.d.ts +15 -0
  269. package/esm/AvatarGroup/AvatarGroup.js +57 -0
  270. package/esm/AvatarGroup/index.d.ts +3 -0
  271. package/esm/AvatarGroup/index.js +2 -0
  272. package/esm/Breadcrumb/Breadcrumb.js +1 -1
  273. package/esm/Button/Button.js +6 -2
  274. package/esm/ButtonGroup/ButtonGroup.js +11 -3
  275. package/esm/ButtonGroup/ButtonGroupContext.d.ts +7 -0
  276. package/esm/ButtonGroup/ButtonGroupContext.js +3 -0
  277. package/esm/ButtonGroup/index.d.ts +2 -0
  278. package/esm/ButtonGroup/index.js +2 -0
  279. package/esm/Calendar/Calendar.d.ts +4 -4
  280. package/esm/Calendar/Calendar.js +27 -23
  281. package/esm/Calendar/CalendarContext.js +1 -1
  282. package/esm/Calendar/Header.js +1 -3
  283. package/esm/Calendar/Table.js +1 -1
  284. package/esm/Calendar/TableRow.js +14 -9
  285. package/esm/Calendar/TimeDropdown.js +5 -4
  286. package/esm/Calendar/View.js +10 -6
  287. package/esm/Calendar/types.d.ts +2 -2
  288. package/esm/Calendar/useCalendarDate.d.ts +2 -2
  289. package/esm/Carousel/Carousel.d.ts +2 -2
  290. package/esm/Carousel/Carousel.js +1 -1
  291. package/esm/Cascader/Cascader.d.ts +1 -1
  292. package/esm/Cascader/Cascader.js +10 -10
  293. package/esm/Cascader/DropdownMenu.d.ts +5 -4
  294. package/esm/Cascader/utils.d.ts +10 -10
  295. package/esm/CheckPicker/CheckPicker.d.ts +9 -4
  296. package/esm/CheckPicker/CheckPicker.js +4 -4
  297. package/esm/CheckPicker/test/CheckPicker.test.d.ts +1 -0
  298. package/esm/CheckPicker/test/CheckPicker.test.js +64 -0
  299. package/esm/CheckTree/index.js +7 -6
  300. package/esm/CheckTreePicker/CheckTreeNode.d.ts +1 -1
  301. package/esm/CheckTreePicker/CheckTreeNode.js +4 -7
  302. package/esm/CheckTreePicker/CheckTreePicker.js +33 -25
  303. package/esm/CheckTreePicker/utils.d.ts +3 -1
  304. package/esm/CheckTreePicker/utils.js +12 -10
  305. package/esm/Checkbox/Checkbox.d.ts +1 -1
  306. package/esm/Container/Container.js +7 -4
  307. package/esm/CustomProvider/CustomProvider.d.ts +31 -57
  308. package/esm/DOMHelper/index.d.ts +12 -12
  309. package/esm/DatePicker/DatePicker.d.ts +1 -1
  310. package/esm/DatePicker/DatePicker.js +18 -11
  311. package/esm/DatePicker/Toolbar.d.ts +12 -9
  312. package/esm/DatePicker/Toolbar.js +6 -8
  313. package/esm/DatePicker/types.d.ts +4 -4
  314. package/esm/DatePicker/utils.d.ts +4 -3
  315. package/esm/DateRangePicker/Calendar.d.ts +9 -7
  316. package/esm/DateRangePicker/Calendar.js +28 -6
  317. package/esm/DateRangePicker/DateRangePicker.d.ts +8 -6
  318. package/esm/DateRangePicker/DateRangePicker.js +131 -110
  319. package/esm/DateRangePicker/types.d.ts +2 -1
  320. package/esm/DateRangePicker/utils.d.ts +6 -6
  321. package/esm/DateRangePicker/utils.js +6 -2
  322. package/esm/Disclosure/Disclosure.js +6 -4
  323. package/esm/Disclosure/DisclosureButton.js +8 -7
  324. package/esm/Disclosure/DisclosureContent.js +5 -7
  325. package/esm/Disclosure/DisclosureContext.d.ts +2 -2
  326. package/esm/Disclosure/useDisclosureContext.d.ts +2 -0
  327. package/esm/Disclosure/useDisclosureContext.js +11 -0
  328. package/esm/Dropdown/Dropdown.d.ts +1 -1
  329. package/esm/Dropdown/DropdownContext.d.ts +2 -2
  330. package/esm/Dropdown/DropdownItem.js +1 -1
  331. package/esm/Dropdown/DropdownMenu.d.ts +3 -3
  332. package/esm/Dropdown/DropdownMenu.js +10 -7
  333. package/esm/Dropdown/DropdownState.d.ts +1 -1
  334. package/esm/Dropdown/DropdownToggle.js +9 -2
  335. package/esm/Dropdown/useRenderDropdownItem.d.ts +1 -1
  336. package/esm/Form/Form.js +1 -1
  337. package/esm/Form/FormContext.d.ts +1 -1
  338. package/esm/FormControl/FormControl.d.ts +1 -1
  339. package/esm/FormControl/FormControl.js +5 -4
  340. package/esm/FormGroup/FormGroup.d.ts +1 -1
  341. package/esm/FormGroup/FormGroup.js +7 -4
  342. package/esm/Input/Input.d.ts +3 -2
  343. package/esm/InputGroup/InputGroup.d.ts +1 -1
  344. package/esm/InputNumber/InputNumber.js +6 -2
  345. package/esm/InputPicker/InputAutosize.js +4 -4
  346. package/esm/InputPicker/InputPicker.d.ts +2 -2
  347. package/esm/InputPicker/InputPicker.js +15 -10
  348. package/esm/List/ListContext.d.ts +1 -1
  349. package/esm/List/ListContext.js +7 -1
  350. package/esm/List/helper/AutoScroller.js +4 -2
  351. package/esm/List/helper/useManager.d.ts +3 -3
  352. package/esm/List/helper/useManager.js +1 -1
  353. package/esm/List/helper/useSortHelper.d.ts +3 -3
  354. package/esm/List/helper/useSortHelper.js +6 -4
  355. package/esm/List/helper/utils.d.ts +2 -2
  356. package/esm/MaskedInput/TextMask.d.ts +5 -5
  357. package/esm/MaskedInput/adjustCaretPosition.d.ts +6 -6
  358. package/esm/MaskedInput/conformToMask.js +5 -4
  359. package/esm/MaskedInput/createTextMaskInputElement.d.ts +2 -2
  360. package/esm/MaskedInput/utilities.d.ts +1 -1
  361. package/esm/Menu/Menu.js +13 -7
  362. package/esm/Menu/MenuContext.d.ts +1 -1
  363. package/esm/Menu/MenuItem.d.ts +1 -1
  364. package/esm/Menu/MenuItem.js +18 -15
  365. package/esm/Menu/Menubar.js +7 -8
  366. package/esm/Menu/useMenu.js +17 -7
  367. package/esm/Modal/Modal.js +12 -6
  368. package/esm/Modal/ModalContext.d.ts +2 -2
  369. package/esm/Modal/utils.d.ts +1 -1
  370. package/esm/Modal/utils.js +3 -5
  371. package/esm/MultiCascader/DropdownMenu.d.ts +4 -4
  372. package/esm/MultiCascader/MultiCascader.js +6 -6
  373. package/esm/MultiCascader/utils.d.ts +17 -17
  374. package/esm/Nav/Nav.d.ts +1 -1
  375. package/esm/Nav/Nav.js +11 -13
  376. package/esm/Nav/NavContext.d.ts +7 -1
  377. package/esm/Nav/NavContext.js +1 -0
  378. package/esm/Nav/NavItem.d.ts +1 -1
  379. package/esm/Navbar/Navbar.js +1 -1
  380. package/esm/Navbar/NavbarItem.d.ts +1 -1
  381. package/esm/Overlay/Modal.d.ts +2 -2
  382. package/esm/Overlay/Modal.js +71 -46
  383. package/esm/Overlay/ModalManager.d.ts +17 -8
  384. package/esm/Overlay/ModalManager.js +11 -20
  385. package/esm/Overlay/Overlay.d.ts +3 -3
  386. package/esm/Overlay/Overlay.js +8 -3
  387. package/esm/Overlay/OverlayContext.d.ts +6 -0
  388. package/esm/Overlay/OverlayContext.js +4 -0
  389. package/esm/Overlay/OverlayTrigger.d.ts +11 -11
  390. package/esm/Overlay/OverlayTrigger.js +21 -8
  391. package/esm/Overlay/Position.d.ts +4 -4
  392. package/esm/Overlay/Position.js +14 -8
  393. package/esm/Overlay/positionUtils.d.ts +1 -1
  394. package/esm/Overlay/positionUtils.js +6 -6
  395. package/esm/Pagination/Pagination.d.ts +1 -1
  396. package/esm/Pagination/PaginationButton.d.ts +3 -3
  397. package/esm/Pagination/PaginationGroup.js +5 -3
  398. package/esm/Panel/Panel.d.ts +1 -1
  399. package/esm/Panel/Panel.js +2 -2
  400. package/esm/PanelGroup/PanelGroup.d.ts +2 -2
  401. package/esm/PanelGroup/PanelGroup.js +9 -6
  402. package/esm/Picker/DropdownMenu.d.ts +8 -5
  403. package/esm/Picker/DropdownMenu.js +5 -5
  404. package/esm/Picker/PickerOverlay.js +4 -3
  405. package/esm/Picker/PickerToggle.js +4 -3
  406. package/esm/Picker/PickerToggleTrigger.d.ts +2 -6
  407. package/esm/Picker/SearchBar.d.ts +1 -1
  408. package/esm/Picker/SelectedElement.js +2 -1
  409. package/esm/Picker/VirtualizedList.d.ts +29 -2
  410. package/esm/Picker/propTypes.d.ts +5 -7
  411. package/esm/Picker/propTypes.js +4 -3
  412. package/esm/Picker/utils.d.ts +15 -23
  413. package/esm/Picker/utils.js +70 -46
  414. package/esm/Placeholder/PlaceholderGrid.js +1 -1
  415. package/esm/Plaintext/Plaintext.js +2 -1
  416. package/esm/Radio/Radio.d.ts +1 -1
  417. package/esm/RadioGroup/RadioGroup.d.ts +2 -2
  418. package/esm/RadioGroup/RadioGroup.js +1 -1
  419. package/esm/RangeSlider/RangeSlider.d.ts +2 -2
  420. package/esm/RangeSlider/RangeSlider.js +5 -4
  421. package/esm/Rate/Character.js +3 -2
  422. package/esm/Rate/Rate.js +2 -1
  423. package/esm/Ripple/Ripple.js +1 -1
  424. package/esm/SelectPicker/SelectPicker.d.ts +12 -5
  425. package/esm/SelectPicker/SelectPicker.js +8 -8
  426. package/esm/SelectPicker/index.d.ts +1 -1
  427. package/esm/SelectPicker/test/SelectPicker.test.d.ts +1 -0
  428. package/esm/SelectPicker/test/SelectPicker.test.js +52 -0
  429. package/esm/Sidenav/Node.d.ts +1 -1
  430. package/esm/Sidenav/Sidenav.d.ts +4 -4
  431. package/esm/Sidenav/Sidenav.js +5 -2
  432. package/esm/Sidenav/SidenavDropdown.js +11 -7
  433. package/esm/Sidenav/SidenavDropdownItem.js +11 -5
  434. package/esm/Sidenav/SidenavDropdownMenu.js +9 -5
  435. package/esm/Sidenav/SidenavItem.d.ts +1 -1
  436. package/esm/Sidenav/SidenavItem.js +4 -0
  437. package/esm/Slider/Graduated.d.ts +5 -5
  438. package/esm/Slider/Handle.d.ts +1 -1
  439. package/esm/Slider/Handle.js +10 -6
  440. package/esm/Slider/Mark.d.ts +1 -1
  441. package/esm/Slider/Slider.d.ts +1 -1
  442. package/esm/Slider/Slider.js +2 -2
  443. package/esm/Slider/utils.d.ts +2 -1
  444. package/esm/Slider/utils.js +5 -2
  445. package/esm/Stack/Stack.d.ts +26 -0
  446. package/esm/Stack/Stack.js +71 -0
  447. package/esm/Stack/index.d.ts +3 -0
  448. package/esm/Stack/index.js +2 -0
  449. package/esm/Steps/StepItem.js +1 -1
  450. package/esm/TagInput/index.js +1 -1
  451. package/esm/Toggle/Toggle.js +5 -4
  452. package/esm/Tree/Tree.d.ts +3 -2
  453. package/esm/Tree/Tree.js +7 -6
  454. package/esm/Tree/TreeContext.d.ts +0 -1
  455. package/esm/TreePicker/TreeNode.js +6 -21
  456. package/esm/TreePicker/TreePicker.js +36 -52
  457. package/esm/Uploader/UploadFileItem.d.ts +1 -1
  458. package/esm/Uploader/UploadFileItem.js +2 -2
  459. package/esm/Uploader/UploadTrigger.d.ts +1 -1
  460. package/esm/Uploader/UploadTrigger.js +2 -3
  461. package/esm/Uploader/Uploader.d.ts +5 -5
  462. package/esm/Uploader/Uploader.js +1 -2
  463. package/esm/index.d.ts +6 -2
  464. package/esm/index.js +3 -1
  465. package/esm/locales/index.d.ts +3 -3
  466. package/esm/toaster/ToastContainer.d.ts +1 -1
  467. package/esm/toaster/ToastContainer.js +1 -1
  468. package/esm/toaster/toaster.js +3 -1
  469. package/esm/utils/BrowserDetection.js +1 -1
  470. package/esm/utils/ReactChildren.d.ts +2 -2
  471. package/esm/utils/ajaxUpload.d.ts +1 -1
  472. package/esm/utils/ajaxUpload.js +5 -4
  473. package/esm/utils/appendTooltip.d.ts +1 -1
  474. package/esm/utils/constants.d.ts +4 -4
  475. package/esm/utils/createChainedFunction.d.ts +1 -1
  476. package/esm/utils/getDataGroupBy.d.ts +1 -1
  477. package/esm/utils/mergeRefs.d.ts +2 -2
  478. package/esm/utils/previewFile.d.ts +1 -1
  479. package/esm/utils/propTypeChecker.d.ts +6 -2
  480. package/esm/utils/propTypeChecker.js +7 -6
  481. package/esm/utils/reactToString.d.ts +2 -1
  482. package/esm/utils/statusIcons.d.ts +1 -1
  483. package/esm/utils/stringToObject.d.ts +1 -1
  484. package/esm/utils/treeUtils.d.ts +35 -32
  485. package/esm/utils/treeUtils.js +45 -21
  486. package/esm/utils/useControlled.d.ts +6 -1
  487. package/esm/utils/useControlled.js +0 -8
  488. package/esm/utils/useCustom.js +6 -4
  489. package/esm/utils/useFocus.d.ts +2 -2
  490. package/esm/utils/usePortal.d.ts +2 -2
  491. package/esm/utils/useRootClose.d.ts +2 -2
  492. package/esm/utils/useTimeout.d.ts +1 -1
  493. package/esm/utils/useTimeout.js +5 -3
  494. package/package.json +3 -3
  495. package/styles/index.less +2 -0
@@ -1,13 +1,11 @@
1
- import { useContext, useRef } from 'react';
2
- import DisclosureContext from './DisclosureContext';
1
+ import { useRef } from 'react';
2
+ import useDisclosureContext from './useDisclosureContext';
3
3
 
4
4
  function DisclosureContent(props) {
5
5
  var children = props.children;
6
- var elementRef = useRef();
7
-
8
- var _useContext = useContext(DisclosureContext),
9
- open = _useContext[0].open;
10
-
6
+ var elementRef = useRef(null);
7
+ var disclosure = useDisclosureContext(DisclosureContent.displayName);
8
+ var open = disclosure[0].open;
11
9
  return children({
12
10
  open: open
13
11
  }, elementRef);
@@ -13,8 +13,8 @@ export declare type DisclosureContextProps = [
13
13
  DisclosureState,
14
14
  Dispatch<DisclosureAction>,
15
15
  {
16
- onToggle: (open: boolean, event?: React.SyntheticEvent) => void;
16
+ onToggle?: (open: boolean, event: React.SyntheticEvent) => void;
17
17
  }
18
18
  ];
19
- declare const DisclosureContext: React.Context<DisclosureContextProps>;
19
+ declare const DisclosureContext: React.Context<DisclosureContextProps | null>;
20
20
  export default DisclosureContext;
@@ -0,0 +1,2 @@
1
+ import { DisclosureContextProps } from './DisclosureContext';
2
+ export default function useDisclosureContext(component: string): DisclosureContextProps;
@@ -0,0 +1,11 @@
1
+ import { useContext } from 'react';
2
+ import DisclosureContext from './DisclosureContext';
3
+ export default function useDisclosureContext(component) {
4
+ var context = useContext(DisclosureContext);
5
+
6
+ if (!context) {
7
+ throw new Error("<" + component + "> component must be rendered within a <Disclosure>");
8
+ }
9
+
10
+ return context;
11
+ }
@@ -45,7 +45,7 @@ export interface DropdownProps<T = any> extends WithAsProps, Omit<React.HTMLAttr
45
45
  /** Callback function for menu state switching */
46
46
  onToggle?: (open?: boolean) => void;
47
47
  /** Selected callback function */
48
- onSelect?: (eventKey: T, event: React.SyntheticEvent) => void;
48
+ onSelect?: (eventKey: T | undefined, event: React.SyntheticEvent) => void;
49
49
  }
50
50
  export interface DropdownComponent extends RsRefForwardingComponent<'div', DropdownProps> {
51
51
  Item: typeof DropdownItem;
@@ -2,9 +2,9 @@ import React, { Dispatch } from 'react';
2
2
  import { DropdownAction } from './DropdownState';
3
3
  export interface DropdownContextProps {
4
4
  activeKey?: string;
5
- onSelect: (eventKey: string, event: React.SyntheticEvent) => void;
5
+ onSelect?: (eventKey: string | undefined, event: React.SyntheticEvent) => void;
6
6
  hasSelectedItem?: boolean;
7
7
  dispatch?: Dispatch<DropdownAction>;
8
8
  }
9
- declare const DropdownContext: React.Context<DropdownContextProps>;
9
+ declare const DropdownContext: React.Context<DropdownContextProps | null>;
10
10
  export default DropdownContext;
@@ -61,7 +61,7 @@ var DropdownItem = /*#__PURE__*/React.forwardRef(function (props, ref) {
61
61
  dispatchDisclosure = _ref[1];
62
62
 
63
63
  var handleClickNavbarDropdownItem = useCallback(function (event) {
64
- dispatchDisclosure({
64
+ dispatchDisclosure === null || dispatchDisclosure === void 0 ? void 0 : dispatchDisclosure({
65
65
  type: DisclosureActionTypes.Hide
66
66
  });
67
67
  handleSelectItem === null || handleSelectItem === void 0 ? void 0 : handleSelectItem(event);
@@ -19,8 +19,8 @@ export interface DropdownMenuProps<T = string> extends StandardProps {
19
19
  disabled?: boolean;
20
20
  activeKey?: T;
21
21
  trigger?: 'hover' | 'click';
22
- onSelect?: (eventKey: T, event: React.SyntheticEvent) => void;
23
- onToggle?: (eventKey: T, event: React.SyntheticEvent) => void;
22
+ onSelect?: (eventKey: T | undefined, event: React.SyntheticEvent) => void;
23
+ onToggle?: (eventKey: T | undefined, event: React.SyntheticEvent) => void;
24
24
  }
25
25
  /**
26
26
  * The <Dropdown.Menu> API
@@ -40,5 +40,5 @@ export interface DropdownMenuProps<T = string> extends StandardProps {
40
40
  * </Dropdown.Menu>
41
41
  * </Dropdown>
42
42
  */
43
- declare const DropdownMenu: React.ForwardRefExoticComponent<DropdownMenuProps<string> & Omit<React.HTMLAttributes<HTMLUListElement>, "title" | "onSelect"> & React.RefAttributes<unknown>>;
43
+ declare const DropdownMenu: React.ForwardRefExoticComponent<DropdownMenuProps<string> & Omit<React.HTMLAttributes<HTMLUListElement>, "title" | "onSelect"> & React.RefAttributes<HTMLElement>>;
44
44
  export default DropdownMenu;
@@ -4,7 +4,7 @@ import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWith
4
4
 
5
5
  var _templateObject, _templateObject2;
6
6
 
7
- import React, { useCallback, useContext } from 'react';
7
+ import React, { useCallback, useContext, useMemo } from 'react';
8
8
  import omit from 'lodash/omit';
9
9
  import Menu from '../Menu/Menu';
10
10
  import MenuItem from '../Menu/MenuItem';
@@ -69,17 +69,20 @@ var DropdownMenu = /*#__PURE__*/React.forwardRef(function (props, ref) {
69
69
  var _useClassNames3 = useClassNames('dropdown-item'),
70
70
  mergeItemClassNames = _useClassNames3.merge,
71
71
  withItemClassPrefix = _useClassNames3.withClassPrefix,
72
- prefixItemClassName = _useClassNames3.prefix; // <Dropdown.Menu> is used outside of <Dropdown>
72
+ prefixItemClassName = _useClassNames3.prefix;
73
+
74
+ var contextValue = useMemo(function () {
75
+ return {
76
+ activeKey: activeKey,
77
+ onSelect: onSelect
78
+ };
79
+ }, [activeKey, onSelect]); // <Dropdown.Menu> is used outside of <Dropdown>
73
80
  // renders a vertical `menubar`
74
81
 
75
-
76
82
  if (!dropdown) {
77
83
  var classes = merge(props.className, withClassPrefix());
78
84
  return /*#__PURE__*/React.createElement(DropdownContext.Provider, {
79
- value: {
80
- activeKey: activeKey,
81
- onSelect: onSelect
82
- }
85
+ value: contextValue
83
86
  }, /*#__PURE__*/React.createElement(Menubar, {
84
87
  vertical: true,
85
88
  onActivateItem: function onActivateItem(event) {
@@ -33,5 +33,5 @@ export declare type DropdownAction = {
33
33
  id: string;
34
34
  };
35
35
  };
36
- export declare function reducer(state: DropdownState, action: DropdownAction): DropdownState;
36
+ export declare function reducer(state: DropdownState | undefined, action: DropdownAction): DropdownState;
37
37
  export {};
@@ -6,6 +6,7 @@ import Button from '../Button';
6
6
  import { useClassNames } from '../utils';
7
7
  import useToggleCaret from '../utils/useToggleCaret';
8
8
  import { SidenavContext } from '../Sidenav/Sidenav';
9
+ import NavContext from '../Nav/NavContext';
9
10
  var DropdownToggle = /*#__PURE__*/React.forwardRef(function (props, ref) {
10
11
  var _props$as = props.as,
11
12
  Component = _props$as === void 0 ? Button : _props$as,
@@ -16,11 +17,15 @@ var DropdownToggle = /*#__PURE__*/React.forwardRef(function (props, ref) {
16
17
  children = props.children,
17
18
  icon = props.icon,
18
19
  noCaret = props.noCaret,
19
- placement = props.placement,
20
+ _props$placement = props.placement,
21
+ placement = _props$placement === void 0 ? 'bottomStart' : _props$placement,
20
22
  rest = _objectWithoutPropertiesLoose(props, ["as", "className", "classPrefix", "renderToggle", "children", "icon", "noCaret", "placement"]);
21
23
 
22
24
  var sidenav = useContext(SidenavContext);
23
25
 
26
+ var _useContext = useContext(NavContext),
27
+ withinNav = _useContext.withinNav;
28
+
24
29
  var _useClassNames = useClassNames(classPrefix),
25
30
  prefix = _useClassNames.prefix,
26
31
  withClassPrefix = _useClassNames.withClassPrefix,
@@ -32,7 +37,9 @@ var DropdownToggle = /*#__PURE__*/React.forwardRef(function (props, ref) {
32
37
  var inSidenav = !!sidenav; // Caret icon is down by default, when Dropdown is used in Sidenav.
33
38
 
34
39
  var Caret = useToggleCaret(inSidenav ? 'bottomStart' : placement);
35
- var toggle = /*#__PURE__*/React.createElement(Component, _extends({}, rest, {
40
+ var toggle = /*#__PURE__*/React.createElement(Component, _extends({
41
+ appearance: withinNav ? 'subtle' : undefined
42
+ }, rest, {
36
43
  ref: ref,
37
44
  className: classes
38
45
  }), icon && /*#__PURE__*/React.cloneElement(icon, {
@@ -1,2 +1,2 @@
1
1
  import React from 'react';
2
- export declare function useRenderDropdownItem(Component: React.ElementType): (props: any, OverrideComponent?: React.ElementType) => JSX.Element;
2
+ export declare function useRenderDropdownItem(Component: React.ElementType): (props: any, OverrideComponent?: React.ElementType<any> | undefined) => JSX.Element;
package/esm/Form/Form.js CHANGED
@@ -233,7 +233,7 @@ var Form = /*#__PURE__*/React.forwardRef(function (props, ref) {
233
233
  setFormValue(nextFormValue);
234
234
  onChange === null || onChange === void 0 ? void 0 : onChange(nextFormValue, event);
235
235
  }, [onChange, getFormValue]);
236
- var rootRef = useRef();
236
+ var rootRef = useRef(null);
237
237
  var formContextValue = useMemo(function () {
238
238
  return {
239
239
  model: model,
@@ -19,6 +19,6 @@ export interface FormContextValue<T = Record<string, any>, errorMsgType = any, E
19
19
  export declare const FormContext: React.Context<FormContextValue<Record<string, any>, any, {
20
20
  [x: string]: any;
21
21
  }>>;
22
- export declare const FormValueContext: React.Context<Record<string, any>>;
22
+ export declare const FormValueContext: React.Context<Record<string, any> | undefined>;
23
23
  export declare const FormPlaintextContext: React.Context<boolean>;
24
24
  export default FormContext;
@@ -32,7 +32,7 @@ export interface FormControlProps<P = any, ValueType = any> extends WithAsProps,
32
32
  interface FormControlComponent extends React.FC<FormControlProps> {
33
33
  <Accepter extends React.ElementType = typeof Input>(props: FormControlProps & {
34
34
  accepter?: Accepter;
35
- } & React.ComponentPropsWithRef<Accepter>): React.ReactElement;
35
+ } & React.ComponentPropsWithRef<Accepter>): React.ReactElement | null;
36
36
  }
37
37
  declare const FormControl: FormControlComponent;
38
38
  export default FormControl;
@@ -53,7 +53,8 @@ var FormControl = /*#__PURE__*/React.forwardRef(function (props, ref) {
53
53
  disabled = _props$disabled === void 0 ? disabledContext : _props$disabled,
54
54
  onChange = props.onChange,
55
55
  onBlur = props.onBlur,
56
- rest = _objectWithoutPropertiesLoose(props, ["as", "accepter", "classPrefix", "className", "checkAsync", "checkTrigger", "errorPlacement", "errorMessage", "name", "value", "readOnly", "plaintext", "disabled", "onChange", "onBlur"]);
56
+ defaultValue = props.defaultValue,
57
+ rest = _objectWithoutPropertiesLoose(props, ["as", "accepter", "classPrefix", "className", "checkAsync", "checkTrigger", "errorPlacement", "errorMessage", "name", "value", "readOnly", "plaintext", "disabled", "onChange", "onBlur", "defaultValue"]);
57
58
 
58
59
  var _useContext2 = useContext(FormGroupContext),
59
60
  controlId = _useContext2.controlId;
@@ -103,12 +104,12 @@ var FormControl = /*#__PURE__*/React.forwardRef(function (props, ref) {
103
104
  var nextFormValue = _extends({}, formValue, (_extends2 = {}, _extends2[name] = value, _extends2));
104
105
 
105
106
  if (checkAsync) {
106
- return model.checkForFieldAsync(name, nextFormValue).then(function (checkResult) {
107
+ return model === null || model === void 0 ? void 0 : model.checkForFieldAsync(name, nextFormValue).then(function (checkResult) {
107
108
  return callbackEvents(checkResult);
108
109
  });
109
110
  }
110
111
 
111
- return Promise.resolve(callbackEvents(model.checkForField(name, nextFormValue)));
112
+ return Promise.resolve(callbackEvents(model === null || model === void 0 ? void 0 : model.checkForField(name, nextFormValue)));
112
113
  };
113
114
 
114
115
  var messageNode = null;
@@ -142,7 +143,7 @@ var FormControl = /*#__PURE__*/React.forwardRef(function (props, ref) {
142
143
  name: name,
143
144
  onChange: handleFieldChange,
144
145
  onBlur: handleFieldBlur,
145
- defaultValue: formDefaultValue[name],
146
+ defaultValue: defaultValue !== null && defaultValue !== void 0 ? defaultValue : formDefaultValue[name],
146
147
  value: val
147
148
  })), /*#__PURE__*/React.createElement(FormErrorMessage, {
148
149
  id: controlId + "-error-message",
@@ -8,7 +8,7 @@ export interface FormGroupProps extends WithAsProps {
8
8
  controlId?: string;
9
9
  }
10
10
  export declare const FormGroupContext: React.Context<{
11
- controlId?: string;
11
+ controlId?: string | undefined;
12
12
  }>;
13
13
  declare const FormGroup: RsRefForwardingComponent<'div', FormGroupProps>;
14
14
  export default FormGroup;
@@ -1,6 +1,6 @@
1
1
  import _extends from "@babel/runtime/helpers/esm/extends";
2
2
  import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
3
- import React from 'react';
3
+ import React, { useMemo } from 'react';
4
4
  import PropTypes from 'prop-types';
5
5
  import { useClassNames } from '../utils';
6
6
  export var FormGroupContext = /*#__PURE__*/React.createContext({});
@@ -18,10 +18,13 @@ var FormGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
18
18
  merge = _useClassNames.merge;
19
19
 
20
20
  var classes = merge(className, withClassPrefix());
21
- return /*#__PURE__*/React.createElement(FormGroupContext.Provider, {
22
- value: {
21
+ var contextValue = useMemo(function () {
22
+ return {
23
23
  controlId: controlId
24
- }
24
+ };
25
+ }, [controlId]);
26
+ return /*#__PURE__*/React.createElement(FormGroupContext.Provider, {
27
+ value: contextValue
25
28
  }, /*#__PURE__*/React.createElement(Component, _extends({}, rest, {
26
29
  ref: ref,
27
30
  className: classes,
@@ -1,9 +1,10 @@
1
1
  import React from 'react';
2
2
  import { WithAsProps, RsRefForwardingComponent, TypeAttributes, FormControlBaseProps } from '../@types/common';
3
+ import { PrependParameters } from '../@types/utils';
3
4
  export interface LocaleType {
4
5
  unfilled: string;
5
6
  }
6
- export interface InputProps extends WithAsProps, Omit<React.InputHTMLAttributes<HTMLInputElement>, 'onChange' | 'size'>, FormControlBaseProps {
7
+ export interface InputProps extends WithAsProps, Omit<React.InputHTMLAttributes<HTMLInputElement>, 'onChange' | 'size'>, Omit<FormControlBaseProps, 'onChange'> {
7
8
  /** The HTML input type */
8
9
  type?: string;
9
10
  /** The HTML input id */
@@ -12,7 +13,7 @@ export interface InputProps extends WithAsProps, Omit<React.InputHTMLAttributes<
12
13
  size?: TypeAttributes.Size;
13
14
  /** Ref of input element */
14
15
  inputRef?: React.Ref<any>;
15
- onChange?: (value: string, event: React.ChangeEvent<HTMLInputElement>) => void;
16
+ onChange?: PrependParameters<React.ChangeEventHandler<HTMLInputElement>, [value: string]>;
16
17
  /** Called on press enter */
17
18
  onPressEnter?: React.KeyboardEventHandler<HTMLInputElement>;
18
19
  }
@@ -5,7 +5,7 @@ import { WithAsProps, TypeAttributes, RsRefForwardingComponent } from '../@types
5
5
  export declare const InputGroupContext: React.Context<{
6
6
  onFocus: () => void;
7
7
  onBlur: () => void;
8
- }>;
8
+ } | null>;
9
9
  export interface InputGroupProps extends WithAsProps {
10
10
  /** Sets the composition content internally */
11
11
  inside?: boolean;
@@ -107,11 +107,15 @@ var InputNumber = /*#__PURE__*/React.forwardRef(function (props, ref) {
107
107
  value = _useControlled[0],
108
108
  setValue = _useControlled[1];
109
109
 
110
- var _useState = useState(disableMaxValue(value, max)),
110
+ var _useState = useState(function () {
111
+ return disableMaxValue(value, max);
112
+ }),
111
113
  disabledUpButton = _useState[0],
112
114
  setDisabledUpButton = _useState[1];
113
115
 
114
- var _useState2 = useState(disableMinValue(value, min)),
116
+ var _useState2 = useState(function () {
117
+ return disableMinValue(value, min);
118
+ }),
115
119
  disabledDownButton = _useState2[0],
116
120
  setDisabledDownButton = _useState2[1];
117
121
 
@@ -78,10 +78,10 @@ var InputAutosize = /*#__PURE__*/React.forwardRef(function (props, ref) {
78
78
  _props$inputId = props.inputId,
79
79
  inputId = _props$inputId === void 0 ? uniqueId : _props$inputId,
80
80
  tabIndex = props.tabIndex;
81
- var rootRef = useRef();
82
- var inputRef = useRef();
83
- var sizerRef = useRef();
84
- var placeholderRef = useRef();
81
+ var rootRef = useRef(null);
82
+ var inputRef = useRef(null);
83
+ var sizerRef = useRef(null);
84
+ var placeholderRef = useRef(null);
85
85
  useImperativeHandle(ref, function () {
86
86
  return {
87
87
  root: rootRef.current,
@@ -9,11 +9,11 @@ export interface InputPickerContextProps {
9
9
  /** Multiple selections are allowed */
10
10
  multi?: boolean;
11
11
  /** Tag related props. */
12
- tagProps?: TagProps;
12
+ tagProps: TagProps;
13
13
  /**
14
14
  * Set the trigger for creating tags. only valid when creatable
15
15
  */
16
- trigger?: TriggerType | TriggerType[];
16
+ trigger: TriggerType | TriggerType[];
17
17
  /**
18
18
  * No overlay provides options
19
19
  */
@@ -23,7 +23,10 @@ import { DropdownMenu, DropdownMenuItem, DropdownMenuCheckItem, PickerToggle, Pi
23
23
  import Tag from '../Tag';
24
24
  import InputAutosize from './InputAutosize';
25
25
  import InputSearch from './InputSearch';
26
- export var InputPickerContext = /*#__PURE__*/React.createContext({});
26
+ export var InputPickerContext = /*#__PURE__*/React.createContext({
27
+ tagProps: {},
28
+ trigger: 'Enter'
29
+ });
27
30
  var InputPicker = /*#__PURE__*/React.forwardRef(function (props, ref) {
28
31
  var _merge;
29
32
 
@@ -43,7 +46,8 @@ var InputPicker = /*#__PURE__*/React.forwardRef(function (props, ref) {
43
46
  readOnly = props.readOnly,
44
47
  plaintext = props.plaintext,
45
48
  defaultValue = props.defaultValue,
46
- defaultOpen = props.defaultOpen,
49
+ _props$defaultOpen = props.defaultOpen,
50
+ defaultOpen = _props$defaultOpen === void 0 ? false : _props$defaultOpen,
47
51
  _props$disabledItemVa = props.disabledItemValues,
48
52
  disabledItemValues = _props$disabledItemVa === void 0 ? [] : _props$disabledItemVa,
49
53
  overrideLocale = props.locale,
@@ -104,9 +108,9 @@ var InputPicker = /*#__PURE__*/React.forwardRef(function (props, ref) {
104
108
  throw Error('`groupBy` can not be equal to `valueKey` and `labelKey`');
105
109
  }
106
110
 
107
- var overlayRef = useRef();
108
- var targetRef = useRef();
109
- var triggerRef = useRef();
111
+ var overlayRef = useRef(null);
112
+ var targetRef = useRef(null);
113
+ var triggerRef = useRef(null);
110
114
  var inputRef = useRef();
111
115
 
112
116
  var _useCustom = useCustom(['Picker', 'InputPicker'], overrideLocale),
@@ -433,8 +437,8 @@ var InputPicker = /*#__PURE__*/React.forwardRef(function (props, ref) {
433
437
  var events = {
434
438
  onMenuPressBackspace: multi ? removeLastItem : handleClean,
435
439
  onMenuKeyDown: onKeyDown,
436
- onMenuPressEnter: null,
437
- onKeyDown: null
440
+ onMenuPressEnter: undefined,
441
+ onKeyDown: undefined
438
442
  };
439
443
  var handleKeyPress = useCallback(function (event) {
440
444
  // When typing a space, create a tag.
@@ -494,7 +498,7 @@ var InputPicker = /*#__PURE__*/React.forwardRef(function (props, ref) {
494
498
 
495
499
  var renderDropdownMenuItem = function renderDropdownMenuItem(label, item) {
496
500
  // 'Create option "{0}"' => Create option "xxxxx"
497
- var newLabel = item.create ? /*#__PURE__*/React.createElement("span", null, tplTransform(locale === null || locale === void 0 ? void 0 : locale.createOption, label)) : label;
501
+ var newLabel = item.create ? /*#__PURE__*/React.createElement("span", null, tplTransform(locale.createOption, label)) : label;
498
502
  return renderMenuItem ? renderMenuItem(newLabel, item) : newLabel;
499
503
  };
500
504
 
@@ -608,7 +612,8 @@ var InputPicker = /*#__PURE__*/React.forwardRef(function (props, ref) {
608
612
  maxHeight: menuMaxHeight,
609
613
  data: items,
610
614
  group: !isUndefined(groupBy),
611
- onSelect: multi ? handleCheckTag : handleSelectItem,
615
+ onSelect: multi ? handleCheckTag : handleSelectItem // fixme don't use any
616
+ ,
612
617
  renderMenuGroup: renderMenuGroup,
613
618
  renderMenuItem: renderDropdownMenuItem,
614
619
  virtualized: virtualized
@@ -701,7 +706,7 @@ var InputPicker = /*#__PURE__*/React.forwardRef(function (props, ref) {
701
706
  plaintext: plaintext,
702
707
  ref: targetRef,
703
708
  as: toggleAs,
704
- tabIndex: null,
709
+ tabIndex: undefined,
705
710
  onClean: handleClean,
706
711
  cleanable: cleanable && !disabled,
707
712
  hasValue: hasValue,
@@ -4,7 +4,7 @@ import useManager from './helper/useManager';
4
4
  export declare type ListContextType = {
5
5
  bordered?: boolean;
6
6
  size?: ListProps['size'];
7
- register?: ReturnType<typeof useManager>['listItemRegister'];
7
+ register: ReturnType<typeof useManager>['listItemRegister'];
8
8
  };
9
9
  declare const ListContext: React.Context<ListContextType>;
10
10
  export default ListContext;
@@ -1,6 +1,12 @@
1
1
  import React from 'react';
2
+ import noop from 'lodash/noop';
2
3
  var ListContext = /*#__PURE__*/React.createContext({
3
4
  bordered: false,
4
- size: 'md'
5
+ size: 'md',
6
+ register: function register() {
7
+ return {
8
+ unregister: noop
9
+ };
10
+ }
5
11
  });
6
12
  export default ListContext;
@@ -17,8 +17,10 @@ var AutoScroller = /*#__PURE__*/function () {
17
17
  var _proto = AutoScroller.prototype;
18
18
 
19
19
  _proto.clear = function clear() {
20
- clearInterval(this.interval);
21
- this.interval = null;
20
+ if (this.interval !== null) {
21
+ clearInterval(this.interval);
22
+ this.interval = null;
23
+ }
22
24
  };
23
25
 
24
26
  _proto.update = function update(_ref) {
@@ -2,10 +2,10 @@ import { Offset } from '../../@types/common';
2
2
  export declare type Collection = string | number;
3
3
  export interface ManagedItem {
4
4
  node: HTMLElement;
5
- edgeOffset: Offset;
5
+ edgeOffset: Offset | null;
6
6
  info: {
7
7
  collection: Collection;
8
- index: number;
8
+ index?: number;
9
9
  disabled?: boolean;
10
10
  };
11
11
  }
@@ -13,7 +13,7 @@ declare const useManager: () => {
13
13
  listItemRegister: (item: ManagedItem) => {
14
14
  unregister: () => void;
15
15
  };
16
- getManagedItem: (node: HTMLElement) => ManagedItem;
16
+ getManagedItem: (node: HTMLElement) => ManagedItem | undefined;
17
17
  getOrderedItems: (collection: any) => ManagedItem[];
18
18
  };
19
19
  export default useManager;
@@ -31,7 +31,7 @@ var useManager = function useManager() {
31
31
  }, []);
32
32
  var getOrderedItems = useCallback(function (collection) {
33
33
  return collection != null ? [].concat(collectionMapRef.current[collection]).sort(function (nodeInfo1, nodeInfo2) {
34
- return nodeInfo1.info.index - nodeInfo2.info.index;
34
+ return Number(nodeInfo1.info.index) - Number(nodeInfo2.info.index);
35
35
  }) : [];
36
36
  }, []);
37
37
  return {
@@ -1,5 +1,5 @@
1
1
  import { MouseEventHandler } from 'react';
2
- import { Collection } from './useManager';
2
+ import { Collection, ManagedItem } from './useManager';
3
3
  interface MovedItemInfo {
4
4
  collection: Collection;
5
5
  node: HTMLElement;
@@ -18,9 +18,9 @@ export declare type SortConfig = {
18
18
  declare const useSortHelper: (config: SortConfig) => {
19
19
  handleStart: MouseEventHandler<Element>;
20
20
  handleEnd: MouseEventHandler<Element>;
21
- containerRef: import("react").MutableRefObject<HTMLDivElement>;
21
+ containerRef: import("react").RefObject<HTMLDivElement>;
22
22
  sorting: boolean;
23
- register: (item: import("./useManager").ManagedItem) => {
23
+ register: (item: ManagedItem) => {
24
24
  unregister: () => void;
25
25
  };
26
26
  };
@@ -38,7 +38,7 @@ var useSortHelper = function useSortHelper(config) {
38
38
  * */
39
39
 
40
40
  var handlePress = useCallback(function (mouseDownEvent, targetNode, curManagedItem) {
41
- var _activeNodeHelper;
41
+ var _curManagedItem$info$, _curManagedItem$info$2, _activeNodeHelper;
42
42
 
43
43
  if (!isMounted()) return;
44
44
  var listItemBaseClassName = targetNode.classList[0]; // get list item base className
@@ -48,8 +48,8 @@ var useSortHelper = function useSortHelper(config) {
48
48
 
49
49
  var containerElement = containerRef.current;
50
50
  var activeNode = curManagedItem.node;
51
- var activeNodeOldIndex = curManagedItem.info.index;
52
- var activeNodeNextIndex = curManagedItem.info.index;
51
+ var activeNodeOldIndex = (_curManagedItem$info$ = curManagedItem.info.index) !== null && _curManagedItem$info$ !== void 0 ? _curManagedItem$info$ : 0;
52
+ var activeNodeNextIndex = (_curManagedItem$info$2 = curManagedItem.info.index) !== null && _curManagedItem$info$2 !== void 0 ? _curManagedItem$info$2 : 0;
53
53
  var activeNodeHolderTranslate = {
54
54
  x: 0,
55
55
  y: 0
@@ -120,8 +120,10 @@ var useSortHelper = function useSortHelper(config) {
120
120
  var activeNodeHeight = parseFloat(activeNodeStyle.height) || 0;
121
121
 
122
122
  for (var i = 0, len = listItemManagerRefs.length; i < len; i++) {
123
+ var _listItemManagerRefs$;
124
+
123
125
  var currentNode = listItemManagerRefs[i].node;
124
- var currentNodeIndex = listItemManagerRefs[i].info.index;
126
+ var currentNodeIndex = (_listItemManagerRefs$ = listItemManagerRefs[i].info.index) !== null && _listItemManagerRefs$ !== void 0 ? _listItemManagerRefs$ : 0;
125
127
  var offsetY = activeNodeBoundingClientRect.height > currentNode.offsetHeight ? currentNode.offsetHeight / 2 : activeNodeBoundingClientRect.height / 2;
126
128
  var translate = {
127
129
  x: 0,
@@ -11,6 +11,6 @@ export declare function setTransitionDuration(node: HTMLElement, duration?: numb
11
11
  /**
12
12
  * find closest target node from source node
13
13
  * */
14
- export declare function closestNode(sourceNode: HTMLElement, judge: (target: HTMLElement) => boolean): HTMLElement;
14
+ export declare function closestNode(sourceNode: HTMLElement, judge: (target: HTMLElement) => boolean): HTMLElement | null;
15
15
  export declare function getEdgeOffset(node: HTMLElement, parent: HTMLElement, offset?: Offset): Offset;
16
- export declare function getScrollingParent(el: HTMLElement): HTMLElement;
16
+ export declare function getScrollingParent(el: HTMLElement): HTMLElement | null;
@@ -34,10 +34,10 @@ export declare type TextMaskProps = TextMaskBaseProps & React.HTMLAttributes<HTM
34
34
  };
35
35
  declare const TextMask: React.ForwardRefExoticComponent<TextMaskBaseProps & React.HTMLAttributes<HTMLInputElement> & {
36
36
  /** Custom rendering DOM */
37
- render?: (ref: React.Ref<HTMLInputElement>, props: React.HTMLAttributes<HTMLInputElement>) => any;
38
- onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void;
39
- value?: string | number;
40
- readOnly?: boolean;
41
- disabled?: boolean;
37
+ render?: ((ref: React.Ref<HTMLInputElement>, props: React.HTMLAttributes<HTMLInputElement>) => any) | undefined;
38
+ onChange?: ((event: React.ChangeEvent<HTMLInputElement>) => void) | undefined;
39
+ value?: string | number | undefined;
40
+ readOnly?: boolean | undefined;
41
+ disabled?: boolean | undefined;
42
42
  } & React.RefAttributes<HTMLInputElement>>;
43
43
  export default TextMask;
@@ -1,11 +1,11 @@
1
1
  export default function adjustCaretPosition({ previousConformedValue, previousPlaceholder, currentCaretPosition, conformedValue, rawValue, placeholderChar, placeholder, indexesOfPipedChars, caretTrapIndexes }: {
2
- previousConformedValue?: string;
3
- previousPlaceholder?: string;
4
- currentCaretPosition?: number;
2
+ previousConformedValue?: string | undefined;
3
+ previousPlaceholder?: string | undefined;
4
+ currentCaretPosition?: number | undefined;
5
5
  conformedValue: any;
6
6
  rawValue: any;
7
7
  placeholderChar: any;
8
8
  placeholder: any;
9
- indexesOfPipedChars?: any[];
10
- caretTrapIndexes?: any[];
11
- }): number;
9
+ indexesOfPipedChars?: string[] | undefined;
10
+ caretTrapIndexes?: number[] | undefined;
11
+ }): number | undefined;
@@ -41,7 +41,8 @@ export default function conformToMask(rawValue, mask, config) {
41
41
  placeholderChar = _config$placeholderCh === void 0 ? defaultPlaceholderChar : _config$placeholderCh,
42
42
  _config$placeholder = _config.placeholder,
43
43
  placeholder = _config$placeholder === void 0 ? convertMaskToPlaceholder(mask, placeholderChar) : _config$placeholder,
44
- currentCaretPosition = _config.currentCaretPosition,
44
+ _config$currentCaretP = _config.currentCaretPosition,
45
+ currentCaretPosition = _config$currentCaretP === void 0 ? 0 : _config$currentCaretP,
45
46
  keepCharPositions = _config.keepCharPositions; // The configs below indicate that the user wants the algorithm to work in *no guide* mode
46
47
 
47
48
  var suppressGuide = guide === false && previousConformedValue !== undefined; // Calculate lengths once for performance
@@ -122,9 +123,9 @@ export default function conformToMask(rawValue, mask, config) {
122
123
  // or we find at least one character that we can map.
123
124
  while (rawValueArr.length > 0) {
124
125
  // Let's retrieve the first user character in the queue of characters we have left
125
- var _rawValueArr$shift = rawValueArr.shift(),
126
- rawValueChar = _rawValueArr$shift.char,
127
- isNew = _rawValueArr$shift.isNew; // If the character we got from the user input is a placeholder character (which happens
126
+ var _ref = rawValueArr.shift(),
127
+ rawValueChar = _ref.char,
128
+ isNew = _ref.isNew; // If the character we got from the user input is a placeholder character (which happens
128
129
  // regularly because user input could be something like (540) 90_-____, which includes
129
130
  // a bunch of `_` which are placeholder characters) and we are not in *no guide* mode,
130
131
  // then we map this placeholder character to the current spot in the placeholder