rsuite 5.0.1 → 5.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (257) hide show
  1. package/Button/styles/index.less +1 -1
  2. package/CHANGELOG.md +50 -0
  3. package/MaskedInput/package.json +7 -0
  4. package/Navbar/styles/index.less +8 -0
  5. package/Picker/styles/index.less +1 -1
  6. package/Picker/styles/mixin.less +1 -1
  7. package/README.md +1 -2
  8. package/Sidenav/styles/index.less +13 -16
  9. package/Slider/styles/index.less +20 -14
  10. package/Toggle/styles/index.less +53 -12
  11. package/Toggle/styles/mixin.less +25 -11
  12. package/Uploader/styles/index.less +10 -1
  13. package/cjs/@types/common.d.ts +8 -2
  14. package/cjs/Affix/Affix.js +3 -3
  15. package/cjs/Animation/Collapse.js +9 -7
  16. package/cjs/Animation/Transition.js +4 -2
  17. package/cjs/AutoComplete/AutoComplete.d.ts +2 -2
  18. package/cjs/AutoComplete/AutoComplete.js +7 -4
  19. package/cjs/Calendar/TimeDropdown.js +5 -3
  20. package/cjs/Cascader/Cascader.d.ts +1 -1
  21. package/cjs/Cascader/Cascader.js +3 -1
  22. package/cjs/Cascader/DropdownMenu.js +6 -5
  23. package/cjs/CheckTreePicker/CheckTreeNode.d.ts +1 -1
  24. package/cjs/CheckTreePicker/CheckTreePicker.d.ts +1 -1
  25. package/cjs/Checkbox/Checkbox.d.ts +3 -3
  26. package/cjs/CheckboxGroup/CheckboxGroupContext.d.ts +1 -1
  27. package/cjs/DOMHelper/index.d.ts +13 -28
  28. package/cjs/DOMHelper/index.js +4 -3
  29. package/cjs/DOMHelper/isElement.d.ts +2 -0
  30. package/cjs/DOMHelper/isElement.js +11 -0
  31. package/cjs/DatePicker/DatePicker.d.ts +3 -3
  32. package/cjs/DatePicker/DatePicker.js +6 -3
  33. package/cjs/DateRangePicker/Calendar.d.ts +1 -1
  34. package/cjs/DateRangePicker/DateRangePicker.d.ts +2 -2
  35. package/cjs/DateRangePicker/DateRangePicker.js +15 -7
  36. package/cjs/Disclosure/Disclosure.d.ts +1 -1
  37. package/cjs/Disclosure/DisclosureContext.d.ts +1 -1
  38. package/cjs/Dropdown/DropdownItem.d.ts +1 -1
  39. package/cjs/Dropdown/DropdownItem.js +23 -16
  40. package/cjs/Dropdown/DropdownMenu.d.ts +2 -2
  41. package/cjs/Form/Form.d.ts +1 -1
  42. package/cjs/FormControl/FormControl.d.ts +9 -3
  43. package/cjs/FormControl/FormControl.js +6 -2
  44. package/cjs/Input/Input.d.ts +2 -1
  45. package/cjs/InputNumber/InputNumber.js +2 -2
  46. package/cjs/InputPicker/InputPicker.js +4 -3
  47. package/cjs/List/helper/useSortHelper.js +11 -6
  48. package/cjs/MaskedInput/MaskedInput.d.ts +43 -0
  49. package/cjs/MaskedInput/MaskedInput.js +80 -0
  50. package/cjs/MaskedInput/adjustCaretPosition.d.ts +11 -0
  51. package/cjs/MaskedInput/adjustCaretPosition.js +218 -0
  52. package/cjs/MaskedInput/conformToMask.d.ts +8 -0
  53. package/cjs/MaskedInput/conformToMask.js +247 -0
  54. package/cjs/MaskedInput/createTextMaskInputElement.d.ts +7 -0
  55. package/cjs/MaskedInput/createTextMaskInputElement.js +226 -0
  56. package/cjs/MaskedInput/index.d.ts +3 -0
  57. package/cjs/MaskedInput/index.js +11 -0
  58. package/cjs/MaskedInput/types.d.ts +10 -0
  59. package/cjs/{@types/icons.js → MaskedInput/types.js} +0 -0
  60. package/cjs/MaskedInput/utilities.d.ts +7 -0
  61. package/cjs/MaskedInput/utilities.js +47 -0
  62. package/cjs/Menu/MenuItem.d.ts +1 -1
  63. package/cjs/Menu/Menubar.d.ts +1 -1
  64. package/cjs/Message/Message.js +13 -11
  65. package/cjs/Modal/Modal.js +5 -3
  66. package/cjs/Modal/utils.js +7 -5
  67. package/cjs/MultiCascader/MultiCascader.js +3 -1
  68. package/cjs/Notification/Notification.js +6 -3
  69. package/cjs/Overlay/Modal.js +14 -11
  70. package/cjs/Overlay/ModalManager.js +19 -7
  71. package/cjs/Overlay/OverlayTrigger.js +2 -2
  72. package/cjs/Overlay/Position.js +20 -13
  73. package/cjs/Overlay/positionUtils.js +16 -8
  74. package/cjs/Panel/Panel.d.ts +1 -1
  75. package/cjs/Picker/DropdownMenu.js +10 -6
  76. package/cjs/Picker/DropdownMenuCheckItem.d.ts +3 -3
  77. package/cjs/Picker/PickerOverlay.js +5 -3
  78. package/cjs/Picker/PickerToggle.d.ts +6 -0
  79. package/cjs/Picker/PickerToggle.js +17 -8
  80. package/cjs/Picker/SearchBar.d.ts +1 -1
  81. package/cjs/Picker/utils.d.ts +2 -2
  82. package/cjs/Picker/utils.js +1 -1
  83. package/cjs/Radio/Radio.d.ts +1 -1
  84. package/cjs/RadioGroup/RadioGroup.d.ts +1 -1
  85. package/cjs/RangeSlider/RangeSlider.js +9 -5
  86. package/cjs/Rate/Character.js +2 -2
  87. package/cjs/Ripple/Ripple.js +6 -7
  88. package/cjs/SelectPicker/SelectPicker.js +2 -1
  89. package/cjs/Sidenav/SidenavDropdownItem.d.ts +1 -1
  90. package/cjs/Sidenav/SidenavDropdownMenu.d.ts +1 -1
  91. package/cjs/Slider/Graduated.js +1 -1
  92. package/cjs/Slider/Handle.js +10 -5
  93. package/cjs/Slider/ProgressBar.js +1 -1
  94. package/cjs/Slider/Slider.js +9 -5
  95. package/cjs/Table/Table.d.ts +7 -7
  96. package/cjs/TagPicker/index.d.ts +1 -1
  97. package/cjs/Toggle/Toggle.d.ts +5 -6
  98. package/cjs/Toggle/Toggle.js +42 -19
  99. package/cjs/Tree/Tree.d.ts +3 -3
  100. package/cjs/TreePicker/TreeNode.d.ts +1 -1
  101. package/cjs/TreePicker/TreeNode.js +2 -2
  102. package/cjs/TreePicker/TreePicker.d.ts +1 -1
  103. package/cjs/TreePicker/TreePicker.js +2 -1
  104. package/cjs/Uploader/UploadFileItem.d.ts +1 -0
  105. package/cjs/Uploader/UploadFileItem.js +30 -17
  106. package/cjs/Uploader/Uploader.d.ts +6 -4
  107. package/cjs/Uploader/Uploader.js +4 -1
  108. package/cjs/index.d.ts +2 -0
  109. package/cjs/index.js +5 -1
  110. package/cjs/locales/fa_IR.d.ts +105 -0
  111. package/cjs/locales/fa_IR.js +84 -0
  112. package/cjs/locales/index.d.ts +1 -0
  113. package/cjs/locales/index.js +6 -2
  114. package/cjs/utils/BrowserDetection.js +1 -1
  115. package/cjs/utils/index.d.ts +1 -0
  116. package/cjs/utils/index.js +7 -2
  117. package/cjs/utils/previewFile.d.ts +1 -0
  118. package/cjs/utils/previewFile.js +11 -0
  119. package/cjs/utils/scrollTopAnimation.js +5 -5
  120. package/cjs/utils/treeUtils.d.ts +2 -2
  121. package/cjs/utils/useEventListener.js +4 -2
  122. package/cjs/utils/useIsMounted.d.ts +2 -0
  123. package/cjs/utils/useIsMounted.js +22 -0
  124. package/cjs/utils/usePortal.js +2 -2
  125. package/cjs/utils/useRootClose.js +10 -10
  126. package/dist/rsuite-rtl.css +225 -124
  127. package/dist/rsuite-rtl.min.css +1 -1
  128. package/dist/rsuite-rtl.min.css.map +1 -1
  129. package/dist/rsuite.css +225 -124
  130. package/dist/rsuite.js +773 -508
  131. package/dist/rsuite.js.map +1 -1
  132. package/dist/rsuite.min.css +1 -1
  133. package/dist/rsuite.min.css.map +1 -1
  134. package/dist/rsuite.min.js +1 -1
  135. package/dist/rsuite.min.js.map +1 -1
  136. package/esm/@types/common.d.ts +8 -2
  137. package/esm/Affix/Affix.js +1 -1
  138. package/esm/Animation/Collapse.js +2 -1
  139. package/esm/Animation/Transition.js +3 -2
  140. package/esm/AutoComplete/AutoComplete.d.ts +2 -2
  141. package/esm/AutoComplete/AutoComplete.js +8 -5
  142. package/esm/Calendar/TimeDropdown.js +2 -1
  143. package/esm/Cascader/Cascader.d.ts +1 -1
  144. package/esm/Cascader/Cascader.js +3 -1
  145. package/esm/Cascader/DropdownMenu.js +4 -3
  146. package/esm/CheckTreePicker/CheckTreeNode.d.ts +1 -1
  147. package/esm/CheckTreePicker/CheckTreePicker.d.ts +1 -1
  148. package/esm/Checkbox/Checkbox.d.ts +3 -3
  149. package/esm/CheckboxGroup/CheckboxGroupContext.d.ts +1 -1
  150. package/esm/DOMHelper/index.d.ts +13 -28
  151. package/esm/DOMHelper/index.js +2 -3
  152. package/esm/DOMHelper/isElement.d.ts +2 -0
  153. package/esm/DOMHelper/isElement.js +5 -0
  154. package/esm/DatePicker/DatePicker.d.ts +3 -3
  155. package/esm/DatePicker/DatePicker.js +6 -3
  156. package/esm/DateRangePicker/Calendar.d.ts +1 -1
  157. package/esm/DateRangePicker/DateRangePicker.d.ts +2 -2
  158. package/esm/DateRangePicker/DateRangePicker.js +15 -7
  159. package/esm/Disclosure/Disclosure.d.ts +1 -1
  160. package/esm/Disclosure/DisclosureContext.d.ts +1 -1
  161. package/esm/Dropdown/DropdownItem.d.ts +1 -1
  162. package/esm/Dropdown/DropdownItem.js +23 -16
  163. package/esm/Dropdown/DropdownMenu.d.ts +2 -2
  164. package/esm/Form/Form.d.ts +1 -1
  165. package/esm/FormControl/FormControl.d.ts +9 -3
  166. package/esm/FormControl/FormControl.js +6 -2
  167. package/esm/Input/Input.d.ts +2 -1
  168. package/esm/InputNumber/InputNumber.js +2 -2
  169. package/esm/InputPicker/InputPicker.js +3 -2
  170. package/esm/List/helper/useSortHelper.js +8 -4
  171. package/esm/MaskedInput/MaskedInput.d.ts +43 -0
  172. package/esm/MaskedInput/MaskedInput.js +67 -0
  173. package/esm/MaskedInput/adjustCaretPosition.d.ts +11 -0
  174. package/esm/MaskedInput/adjustCaretPosition.js +213 -0
  175. package/esm/MaskedInput/conformToMask.d.ts +8 -0
  176. package/esm/MaskedInput/conformToMask.js +239 -0
  177. package/esm/MaskedInput/createTextMaskInputElement.d.ts +7 -0
  178. package/esm/MaskedInput/createTextMaskInputElement.js +212 -0
  179. package/esm/MaskedInput/index.d.ts +3 -0
  180. package/esm/MaskedInput/index.js +2 -0
  181. package/esm/MaskedInput/types.d.ts +10 -0
  182. package/esm/{@types/icons.js → MaskedInput/types.js} +0 -0
  183. package/esm/MaskedInput/utilities.d.ts +7 -0
  184. package/esm/MaskedInput/utilities.js +38 -0
  185. package/esm/Menu/MenuItem.d.ts +1 -1
  186. package/esm/Menu/Menubar.d.ts +1 -1
  187. package/esm/Message/Message.js +15 -13
  188. package/esm/Modal/Modal.js +3 -2
  189. package/esm/Modal/utils.js +6 -5
  190. package/esm/MultiCascader/MultiCascader.js +3 -1
  191. package/esm/Notification/Notification.js +7 -4
  192. package/esm/Overlay/Modal.js +11 -8
  193. package/esm/Overlay/ModalManager.js +6 -1
  194. package/esm/Overlay/OverlayTrigger.js +1 -1
  195. package/esm/Overlay/Position.js +14 -8
  196. package/esm/Overlay/positionUtils.js +6 -2
  197. package/esm/Panel/Panel.d.ts +1 -1
  198. package/esm/Picker/DropdownMenu.js +3 -1
  199. package/esm/Picker/DropdownMenuCheckItem.d.ts +3 -3
  200. package/esm/Picker/PickerOverlay.js +2 -1
  201. package/esm/Picker/PickerToggle.d.ts +6 -0
  202. package/esm/Picker/PickerToggle.js +14 -6
  203. package/esm/Picker/SearchBar.d.ts +1 -1
  204. package/esm/Picker/utils.d.ts +2 -2
  205. package/esm/Picker/utils.js +1 -1
  206. package/esm/Radio/Radio.d.ts +1 -1
  207. package/esm/RadioGroup/RadioGroup.d.ts +1 -1
  208. package/esm/RangeSlider/RangeSlider.js +4 -2
  209. package/esm/Rate/Character.js +2 -2
  210. package/esm/Ripple/Ripple.js +4 -3
  211. package/esm/SelectPicker/SelectPicker.js +2 -1
  212. package/esm/Sidenav/SidenavDropdownItem.d.ts +1 -1
  213. package/esm/Sidenav/SidenavDropdownMenu.d.ts +1 -1
  214. package/esm/Slider/Graduated.js +1 -1
  215. package/esm/Slider/Handle.js +5 -2
  216. package/esm/Slider/ProgressBar.js +1 -1
  217. package/esm/Slider/Slider.js +4 -2
  218. package/esm/Table/Table.d.ts +7 -7
  219. package/esm/TagPicker/index.d.ts +1 -1
  220. package/esm/Toggle/Toggle.d.ts +5 -6
  221. package/esm/Toggle/Toggle.js +43 -21
  222. package/esm/Tree/Tree.d.ts +3 -3
  223. package/esm/TreePicker/TreeNode.d.ts +1 -1
  224. package/esm/TreePicker/TreeNode.js +1 -1
  225. package/esm/TreePicker/TreePicker.d.ts +1 -1
  226. package/esm/TreePicker/TreePicker.js +2 -1
  227. package/esm/Uploader/UploadFileItem.d.ts +1 -0
  228. package/esm/Uploader/UploadFileItem.js +30 -17
  229. package/esm/Uploader/Uploader.d.ts +6 -4
  230. package/esm/Uploader/Uploader.js +4 -1
  231. package/esm/index.d.ts +2 -0
  232. package/esm/index.js +1 -0
  233. package/esm/locales/fa_IR.d.ts +105 -0
  234. package/esm/locales/fa_IR.js +74 -0
  235. package/esm/locales/index.d.ts +1 -0
  236. package/esm/locales/index.js +2 -1
  237. package/esm/utils/BrowserDetection.js +1 -1
  238. package/esm/utils/index.d.ts +1 -0
  239. package/esm/utils/index.js +2 -1
  240. package/esm/utils/previewFile.d.ts +1 -0
  241. package/esm/utils/previewFile.js +9 -0
  242. package/esm/utils/scrollTopAnimation.js +2 -2
  243. package/esm/utils/treeUtils.d.ts +2 -2
  244. package/esm/utils/useEventListener.js +1 -1
  245. package/esm/utils/useIsMounted.d.ts +2 -0
  246. package/esm/utils/useIsMounted.js +16 -0
  247. package/esm/utils/usePortal.js +2 -2
  248. package/esm/utils/useRootClose.js +8 -6
  249. package/locales/fa_IR/package.json +7 -0
  250. package/package.json +6 -8
  251. package/styles/color-modes/dark.less +1 -0
  252. package/styles/color-modes/high-contrast.less +1 -0
  253. package/styles/color-modes/light.less +3 -0
  254. package/styles/plugins/palette.js +10 -1
  255. package/styles/variables.less +3 -1
  256. package/cjs/@types/icons.d.ts +0 -1
  257. package/esm/@types/icons.d.ts +0 -1
@@ -17,7 +17,9 @@ var _react = _interopRequireWildcard(require("react"));
17
17
 
18
18
  var _propTypes = _interopRequireDefault(require("prop-types"));
19
19
 
20
- var _domLib = require("dom-lib");
20
+ var _getPosition2 = _interopRequireDefault(require("dom-lib/getPosition"));
21
+
22
+ var _scrollTop = _interopRequireDefault(require("dom-lib/scrollTop"));
21
23
 
22
24
  var _partial = _interopRequireDefault(require("lodash/partial"));
23
25
 
@@ -99,10 +101,10 @@ var scrollTo = function scrollTo(time, row) {
99
101
  var node = container === null || container === void 0 ? void 0 : container.querySelector("[data-key=\"" + type + "-" + value + "\"]");
100
102
 
101
103
  if (node && container) {
102
- var _getPosition = (0, _domLib.getPosition)(node, container),
104
+ var _getPosition = (0, _getPosition2.default)(node, container),
103
105
  top = _getPosition.top;
104
106
 
105
- (0, _utils.scrollTopAnimation)(container, top, (0, _domLib.scrollTop)(container) !== 0);
107
+ (0, _utils.scrollTopAnimation)(container, top, (0, _scrollTop.default)(container) !== 0);
106
108
  }
107
109
  });
108
110
  };
@@ -25,7 +25,7 @@ export interface CascaderProps<T = ValueType> extends FormControlPickerProps<T,
25
25
  /** Called when clean */
26
26
  onClean?: (event: React.SyntheticEvent) => void;
27
27
  /** Called when searching */
28
- onSearch?: (searchKeyword: string, event: React.SyntheticEvent<HTMLElement>) => void;
28
+ onSearch?: (searchKeyword: string, event: React.SyntheticEvent) => void;
29
29
  /** Asynchronously load the children of the tree node. */
30
30
  getChildren?: (node: ItemDataType) => ItemDataType[] | Promise<ItemDataType[]>;
31
31
  }
@@ -473,7 +473,9 @@ var Cascader = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
473
473
  var _usePickerClassName = (0, _Picker.usePickerClassName)((0, _extends3.default)({}, props, {
474
474
  classPrefix: classPrefix,
475
475
  hasValue: hasValue,
476
- name: 'cascader'
476
+ name: 'cascader',
477
+ appearance: appearance,
478
+ cleanable: cleanable
477
479
  })),
478
480
  classes = _usePickerClassName[0],
479
481
  usedClassNamePropKeys = _usePickerClassName[1]; // TODO: bad api design
@@ -17,8 +17,6 @@ var _propTypes = _interopRequireDefault(require("prop-types"));
17
17
 
18
18
  var _Spinner = _interopRequireDefault(require("@rsuite/icons/legacy/Spinner"));
19
19
 
20
- var _DOMHelper = _interopRequireDefault(require("../DOMHelper"));
21
-
22
20
  var _isUndefined = _interopRequireDefault(require("lodash/isUndefined"));
23
21
 
24
22
  var _isNil = _interopRequireDefault(require("lodash/isNil"));
@@ -31,6 +29,10 @@ var _AngleLeft = _interopRequireDefault(require("@rsuite/icons/legacy/AngleLeft"
31
29
 
32
30
  var _AngleRight = _interopRequireDefault(require("@rsuite/icons/legacy/AngleRight"));
33
31
 
32
+ var _getPosition = _interopRequireDefault(require("dom-lib/getPosition"));
33
+
34
+ var _scrollTop = _interopRequireDefault(require("dom-lib/scrollTop"));
35
+
34
36
  var emptyArray = [];
35
37
 
36
38
  var DropdownMenu = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
@@ -83,10 +85,9 @@ var DropdownMenu = /*#__PURE__*/_react.default.forwardRef(function (props, ref)
83
85
  }
84
86
 
85
87
  if (activeItem) {
86
- var position = _DOMHelper.default.getPosition(activeItem, column); // Let the active option scroll into view.
87
-
88
+ var position = (0, _getPosition.default)(activeItem, column); // Let the active option scroll into view.
88
89
 
89
- _DOMHelper.default.scrollTop(column, position.top);
90
+ (0, _scrollTop.default)(column, position.top);
90
91
  }
91
92
  });
92
93
  }, [prefix]);
@@ -20,7 +20,7 @@ export interface CheckTreeNodeProps extends WithAsProps {
20
20
  uncheckable?: boolean;
21
21
  allUncheckable?: boolean;
22
22
  onExpand?: (nodeData: any) => void;
23
- onSelect?: (nodeData: any, event: React.SyntheticEvent<any>) => void;
23
+ onSelect?: (nodeData: any, event: React.SyntheticEvent) => void;
24
24
  onRenderTreeIcon?: (nodeData: any, expandIcon?: React.ReactNode) => React.ReactNode;
25
25
  onRenderTreeNode?: (nodeData: any) => React.ReactNode;
26
26
  }
@@ -14,7 +14,7 @@ export interface CheckTreePickerProps<T = ValueType> extends TreeBaseProps<T, It
14
14
  /** Custom render selected items */
15
15
  renderValue?: (value: any[], selectedItems: any[], selectedElement: React.ReactNode) => React.ReactNode;
16
16
  /** Called when scrolling */
17
- onScroll?: (event: React.SyntheticEvent<HTMLElement>) => void;
17
+ onScroll?: (event: React.SyntheticEvent) => void;
18
18
  }
19
19
  declare const CheckTreePicker: PickerComponent<CheckTreePickerProps>;
20
20
  export default CheckTreePicker;
@@ -31,11 +31,11 @@ export interface CheckboxProps<V = ValueType> extends WithAsProps {
31
31
  /** Used for the name of the form */
32
32
  name?: string;
33
33
  /** Called when the user attempts to change the checked state. */
34
- onChange?: (value: V, checked: boolean, event: React.SyntheticEvent<HTMLInputElement>) => void;
34
+ onChange?: (value: V, checked: boolean, event: React.ChangeEvent<HTMLInputElement>) => void;
35
35
  /** Called when the checkbox or label is clicked. */
36
- onClick?: (event: React.SyntheticEvent<HTMLElement>) => void;
36
+ onClick?: (event: React.SyntheticEvent) => void;
37
37
  /** Called when the checkbox is clicked. */
38
- onCheckboxClick?: (event: React.SyntheticEvent<HTMLElement>) => void;
38
+ onCheckboxClick?: (event: React.SyntheticEvent) => void;
39
39
  }
40
40
  declare const Checkbox: RsRefForwardingComponent<'div', CheckboxProps>;
41
41
  export default Checkbox;
@@ -8,6 +8,6 @@ export interface CheckboxGroupContextValue {
8
8
  disabled?: boolean;
9
9
  readOnly?: boolean;
10
10
  plaintext?: boolean;
11
- onChange?: (value: any, checked: boolean, event: React.SyntheticEvent<HTMLInputElement>) => void;
11
+ onChange?: (value: any, checked: boolean, event: React.ChangeEvent<HTMLInputElement>) => void;
12
12
  }
13
13
  export declare const CheckboxGroupContext: React.Context<CheckboxGroupContextValue>;
@@ -2,34 +2,17 @@ import * as helpers from 'dom-lib';
2
2
  export * from 'dom-lib';
3
3
  declare const DOMHelper: {
4
4
  isElement: (node: HTMLElement) => boolean;
5
- animation: typeof helpers.animation;
6
- transition: () => {
7
- end: any;
8
- backfaceVisibility: string;
9
- transform: string;
10
- property: string;
11
- timing: string;
12
- delay: string;
13
- duration: string;
14
- };
15
- translateDOMPositionXY: (style: CSSStyleDeclaration, x?: number, y?: number) => CSSStyleDeclaration;
16
- getVendorPrefixedName: typeof helpers.getVendorPrefixedName;
17
- BrowserSupportCore: {
18
- hasCSSAnimations: () => boolean;
19
- hasCSSTransforms: () => boolean;
20
- hasCSS3DTransforms: () => boolean;
21
- hasCSSTransitions: () => boolean;
22
- };
23
- DOMMouseMoveTracker: typeof helpers.DOMMouseMoveTracker;
5
+ on: typeof helpers.on;
6
+ off: typeof helpers.off;
24
7
  WheelHandler: typeof helpers.WheelHandler;
8
+ DOMMouseMoveTracker: typeof helpers.DOMMouseMoveTracker;
25
9
  addClass: (target: Element, className: string) => Element;
26
- hasClass: (target: Element, className: string) => boolean;
27
10
  removeClass: (target: Element, className: string) => Element;
11
+ hasClass: (target: Element, className: string) => boolean;
28
12
  toggleClass: (target: Element, className: string) => Element;
29
- getStyle: (node: Element, property?: string) => string | CSSStyleDeclaration;
30
- removeStyle: (node: Element, keys: string | string[]) => void;
31
- addStyle: (node: Element, property: string | import("dom-lib/lib/style/addStyle").CSSProperty, value?: string | number) => void;
32
- getComputedStyle: (node: Element) => CSSStyleDeclaration;
13
+ cancelAnimationFramePolyfill: typeof clearTimeout;
14
+ requestAnimationFramePolyfill: typeof requestAnimationFrame;
15
+ getAnimationEnd: typeof helpers.getAnimationEnd;
33
16
  ownerDocument: (node: Element) => Document;
34
17
  ownerWindow: (componentOrElement: Element) => Window;
35
18
  getWindow: (node: any) => Window;
@@ -46,18 +29,20 @@ declare const DOMHelper: {
46
29
  } | DOMRect;
47
30
  nodeName: (node: Element) => string;
48
31
  getOffsetParent: (node: Element) => Element;
49
- getPosition: (node: Element, offsetParent?: Element) => DOMRect | {
32
+ getPosition: (node: Element, offsetParent?: Element, calcMargin?: boolean) => DOMRect | {
50
33
  top: number;
51
34
  left: number;
52
35
  height: number;
53
36
  width: number;
54
37
  };
55
38
  isOverflowing: (container: Element) => boolean;
56
- activeElement: (doc?: Document) => Element;
57
39
  getScrollbarSize: (recalc?: boolean) => number | void;
58
40
  getHeight: (node: Element | Window, client?: Element) => number;
59
41
  getWidth: (node: Element | Window, client?: Element) => number;
60
- on: typeof helpers.on;
61
- off: typeof helpers.off;
42
+ isFocusable: typeof helpers.isFocusable;
43
+ getStyle: (node: Element, property?: string) => string | CSSStyleDeclaration;
44
+ removeStyle: (node: Element, keys: string | string[]) => void;
45
+ addStyle: (node: Element, property: string | import("dom-lib/esm/addStyle").CSSProperty, value?: string | number) => void;
46
+ translateDOMPositionXY: (style: CSSStyleDeclaration, x?: number, y?: number) => CSSStyleDeclaration;
62
47
  };
63
48
  export default DOMHelper;
@@ -18,10 +18,11 @@ Object.keys(helpers).forEach(function (key) {
18
18
  if (key in exports && exports[key] === helpers[key]) return;
19
19
  exports[key] = helpers[key];
20
20
  });
21
+
22
+ var _isElement = _interopRequireDefault(require("./isElement"));
23
+
21
24
  var DOMHelper = (0, _extends2.default)({}, helpers, {
22
- isElement: function isElement(node) {
23
- return (node === null || node === void 0 ? void 0 : node.nodeType) && typeof (node === null || node === void 0 ? void 0 : node.nodeName) === 'string';
24
- }
25
+ isElement: _isElement.default
25
26
  });
26
27
  var _default = DOMHelper;
27
28
  exports.default = _default;
@@ -0,0 +1,2 @@
1
+ declare const isElement: (node: HTMLElement) => boolean;
2
+ export default isElement;
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports.default = void 0;
5
+
6
+ var isElement = function isElement(node) {
7
+ return (node === null || node === void 0 ? void 0 : node.nodeType) === 1 && typeof (node === null || node === void 0 ? void 0 : node.nodeName) === 'string';
8
+ };
9
+
10
+ var _default = isElement;
11
+ exports.default = _default;
@@ -41,19 +41,19 @@ export interface DatePickerProps extends PickerBaseProps<DatePickerLocale>, Form
41
41
  /** Hidden seconds */
42
42
  hideSeconds?: (second: number, date: Date) => boolean;
43
43
  /** Called when the calendar panel date changes */
44
- onChangeCalendarDate?: (date: Date, event?: React.SyntheticEvent<HTMLElement>) => void;
44
+ onChangeCalendarDate?: (date: Date, event?: React.SyntheticEvent) => void;
45
45
  /** Called when opening the month view */
46
46
  onToggleMonthDropdown?: (toggle: boolean) => void;
47
47
  /** Called when opening the time view */
48
48
  onToggleTimeDropdown?: (toggle: boolean) => void;
49
49
  /** Called when the option is selected */
50
- onSelect?: (date: Date, event?: React.SyntheticEvent<HTMLElement>) => void;
50
+ onSelect?: (date: Date, event?: React.SyntheticEvent) => void;
51
51
  /** Called after the prev month */
52
52
  onPrevMonth?: (date: Date) => void;
53
53
  /** Called after the next month */
54
54
  onNextMonth?: (date: Date) => void;
55
55
  /** Called after clicking the OK button */
56
- onOk?: (date: Date, event: React.SyntheticEvent<HTMLElement>) => void;
56
+ onOk?: (date: Date, event: React.SyntheticEvent) => void;
57
57
  /** Called when clean */
58
58
  onClean?: (event: React.MouseEvent) => void;
59
59
  /** Custom render value */
@@ -328,7 +328,7 @@ var DatePicker = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
328
328
  * The callback after the enter key is triggered on the input
329
329
  */
330
330
 
331
- var handleInputBlur = (0, _react.useCallback)(function (event) {
331
+ var handleInputPressEnd = (0, _react.useCallback)(function (event) {
332
332
  if (inputState === 'Typing') {
333
333
  updateValue(event, calendarDate);
334
334
  }
@@ -417,7 +417,9 @@ var DatePicker = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
417
417
  var _usePickerClassName = (0, _Picker.usePickerClassName)((0, _extends2.default)({}, props, {
418
418
  classPrefix: classPrefix,
419
419
  name: 'date',
420
- hasValue: hasValue
420
+ appearance: appearance,
421
+ hasValue: hasValue,
422
+ cleanable: cleanable
421
423
  })),
422
424
  classes = _usePickerClassName[0],
423
425
  usedClassNamePropKeys = _usePickerClassName[1];
@@ -458,7 +460,8 @@ var DatePicker = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
458
460
  inputPlaceholder: typeof placeholder === 'string' && placeholder ? placeholder : formatStr,
459
461
  inputMask: _utils.DateUtils.getDateMask(formatStr),
460
462
  onInputChange: handleInputChange,
461
- onInputBlur: handleInputBlur,
463
+ onInputBlur: handleInputPressEnd,
464
+ onInputPressEnter: handleInputPressEnd,
462
465
  onKeyDown: onPickerKeyDown,
463
466
  onClean: (0, _utils.createChainedFunction)(handleClean, onClean),
464
467
  cleanable: cleanable && !disabled,
@@ -16,7 +16,7 @@ export interface CalendarProps extends WithAsProps, Omit<CalendarCoreProps, Omit
16
16
  onChangeCalendarDate?: (index: number, date: Date) => void;
17
17
  onChangeCalendarTime?: (index: number, date: Date) => void;
18
18
  onMouseMove?: (date: Date) => void;
19
- onSelect?: (date: Date, event?: React.SyntheticEvent<any>) => void;
19
+ onSelect?: (date: Date, event?: React.SyntheticEvent) => void;
20
20
  showOneCalendar?: boolean;
21
21
  showWeekNumbers?: boolean;
22
22
  value?: ValueType;
@@ -26,9 +26,9 @@ export interface DateRangePickerProps extends PickerBaseProps, FormControlBasePr
26
26
  /** Disabled date */
27
27
  disabledDate?: DisabledDateFunction;
28
28
  /** Called when the option is selected */
29
- onSelect?: (date: Date, event?: React.SyntheticEvent<HTMLElement>) => void;
29
+ onSelect?: (date: Date, event?: React.SyntheticEvent) => void;
30
30
  /** Called after clicking the OK button */
31
- onOk?: (date: ValueType, event: React.SyntheticEvent<HTMLElement>) => void;
31
+ onOk?: (date: ValueType, event: React.SyntheticEvent) => void;
32
32
  /** Called when clean */
33
33
  onClean?: (event: React.MouseEvent) => void;
34
34
  /** Custom render value */
@@ -98,7 +98,8 @@ var DateRangePicker = /*#__PURE__*/_react.default.forwardRef(function (props, re
98
98
 
99
99
  var _useCustom = (0, _utils.useCustom)('DateRangePicker', overrideLocale),
100
100
  locale = _useCustom.locale,
101
- formatDate = _useCustom.formatDate;
101
+ formatDate = _useCustom.formatDate,
102
+ parseDate = _useCustom.parseDate;
102
103
 
103
104
  var rangeFormatStr = "" + formatStr + character + formatStr;
104
105
 
@@ -393,13 +394,17 @@ var DateRangePicker = /*#__PURE__*/_react.default.forwardRef(function (props, re
393
394
  var rangeValue = value.split(character); // isMatch('01/11/2020', 'MM/dd/yyyy') ==> true
394
395
  // isMatch('2020-11-01', 'MM/dd/yyyy') ==> false
395
396
 
396
- if (!_utils.DateUtils.isMatch(rangeValue[0], formatStr) || !_utils.DateUtils.isMatch(rangeValue[1], formatStr)) {
397
+ if (!_utils.DateUtils.isMatch(rangeValue[0], formatStr, {
398
+ locale: locale.dateLocale
399
+ }) || !_utils.DateUtils.isMatch(rangeValue[1], formatStr, {
400
+ locale: locale.dateLocale
401
+ })) {
397
402
  setInputState('Error');
398
403
  return;
399
404
  }
400
405
 
401
- var startDate = new Date(rangeValue[0]);
402
- var endDate = new Date(rangeValue[1]);
406
+ var startDate = parseDate(rangeValue[0], formatStr);
407
+ var endDate = parseDate(rangeValue[1], formatStr);
403
408
  var selectValue = [startDate, endDate];
404
409
 
405
410
  if (!_utils.DateUtils.isValid(startDate) || !_utils.DateUtils.isValid(endDate)) {
@@ -421,7 +426,7 @@ var DateRangePicker = /*#__PURE__*/_react.default.forwardRef(function (props, re
421
426
  * The callback after the enter key is triggered on the input
422
427
  */
423
428
 
424
- var handleInputBlur = (0, _react.useCallback)(function (event) {
429
+ var handleInputPressEnd = (0, _react.useCallback)(function (event) {
425
430
  if (inputState === 'Typing') {
426
431
  handleValueUpdate(event, selectValue);
427
432
  }
@@ -569,7 +574,9 @@ var DateRangePicker = /*#__PURE__*/_react.default.forwardRef(function (props, re
569
574
  var _usePickerClassName = (0, _Picker.usePickerClassName)((0, _extends2.default)({}, props, {
570
575
  classPrefix: classPrefix,
571
576
  name: 'daterange',
572
- hasValue: hasValue
577
+ appearance: appearance,
578
+ hasValue: hasValue,
579
+ cleanable: cleanable
573
580
  })),
574
581
  classes = _usePickerClassName[0],
575
582
  usedClassNamePropKeys = _usePickerClassName[1];
@@ -595,7 +602,8 @@ var DateRangePicker = /*#__PURE__*/_react.default.forwardRef(function (props, re
595
602
  inputValue: value ? getDisplayString(value, true) : '',
596
603
  inputPlaceholder: typeof placeholder === 'string' && placeholder ? placeholder : rangeFormatStr,
597
604
  onInputChange: handleInputChange,
598
- onInputBlur: handleInputBlur,
605
+ onInputBlur: handleInputPressEnd,
606
+ onInputPressEnter: handleInputPressEnd,
599
607
  onKeyDown: onPickerKeyDown,
600
608
  onClean: (0, _utils.createChainedFunction)(handleClean, onClean),
601
609
  cleanable: cleanable && !disabled,
@@ -12,7 +12,7 @@ export interface DisclosureProps {
12
12
  defaultOpen?: boolean;
13
13
  hideOnClickOutside?: boolean;
14
14
  /** Callback when disclosure button is being activated to update the open state */
15
- onToggle?: (open: boolean, event: React.SyntheticEvent<HTMLElement>) => void;
15
+ onToggle?: (open: boolean, event: React.SyntheticEvent) => void;
16
16
  }
17
17
  declare function Disclosure(props: DisclosureProps): JSX.Element;
18
18
  declare namespace Disclosure {
@@ -13,7 +13,7 @@ export declare type DisclosureContextProps = [
13
13
  DisclosureState,
14
14
  Dispatch<DisclosureAction>,
15
15
  {
16
- onToggle: (open: boolean, event?: React.SyntheticEvent<HTMLElement>) => void;
16
+ onToggle: (open: boolean, event?: React.SyntheticEvent) => void;
17
17
  }
18
18
  ];
19
19
  declare const DisclosureContext: React.Context<DisclosureContextProps>;
@@ -32,7 +32,7 @@ export interface DropdownMenuItemProps<T = any> extends WithAsProps, Omit<React.
32
32
  */
33
33
  open?: boolean;
34
34
  /** Select the callback function for the current option */
35
- onSelect?: (eventKey: T, event: React.SyntheticEvent<HTMLElement>) => void;
35
+ onSelect?: (eventKey: T, event: React.SyntheticEvent) => void;
36
36
  }
37
37
  /**
38
38
  * The <Dropdown.Item> API
@@ -54,7 +54,13 @@ var DropdownItem = /*#__PURE__*/_react.default.forwardRef(function (props, ref)
54
54
  eventKey = props.eventKey,
55
55
  onSelect = props.onSelect,
56
56
  icon = props.icon,
57
- rest = (0, _objectWithoutPropertiesLoose2.default)(props, ["classPrefix", "className", "active", "eventKey", "onSelect", "icon"]);
57
+ _props$as = props.as,
58
+ Component = _props$as === void 0 ? 'li' : _props$as,
59
+ divider = props.divider,
60
+ panel = props.panel,
61
+ children = props.children,
62
+ disabled = props.disabled,
63
+ restProps = (0, _objectWithoutPropertiesLoose2.default)(props, ["classPrefix", "className", "active", "eventKey", "onSelect", "icon", "as", "divider", "panel", "children", "disabled"]);
58
64
  var internalId = (0, _useInternalId.default)('DropdownItem');
59
65
  var nav = (0, _react.useContext)(_NavContext.default);
60
66
  var dropdown = (0, _react.useContext)(_DropdownContext.default);
@@ -106,6 +112,15 @@ var DropdownItem = /*#__PURE__*/_react.default.forwardRef(function (props, ref)
106
112
  };
107
113
  }
108
114
  }, [internalId, selected, dispatch]);
115
+ var renderDropdownItem = (0, _react.useCallback)(function (ui) {
116
+ if (Component === 'li') {
117
+ return ui;
118
+ }
119
+
120
+ return /*#__PURE__*/_react.default.createElement("li", {
121
+ role: "none presentation"
122
+ }, ui);
123
+ }, [Component]);
109
124
 
110
125
  if (sidenav !== null && sidenav !== void 0 && sidenav.expanded) {
111
126
  return /*#__PURE__*/_react.default.createElement(_SidenavDropdownItem.default, (0, _extends2.default)({
@@ -113,28 +128,19 @@ var DropdownItem = /*#__PURE__*/_react.default.forwardRef(function (props, ref)
113
128
  }, props));
114
129
  }
115
130
 
116
- var _rest$as = rest.as,
117
- Component = _rest$as === void 0 ? 'li' : _rest$as,
118
- divider = rest.divider,
119
- panel = rest.panel,
120
- children = rest.children,
121
- disabled = rest.disabled,
122
- restProps = (0, _objectWithoutPropertiesLoose2.default)(rest, ["as", "divider", "panel", "children", "disabled"]);
123
-
124
131
  if (divider) {
125
- return /*#__PURE__*/_react.default.createElement(Component, (0, _extends2.default)({
132
+ return renderDropdownItem( /*#__PURE__*/_react.default.createElement(Component, (0, _extends2.default)({
126
133
  ref: ref,
127
134
  role: "separator",
128
135
  className: merge(prefix('divider'), className)
129
- }, restProps));
136
+ }, restProps)));
130
137
  }
131
138
 
132
139
  if (panel) {
133
- return /*#__PURE__*/_react.default.createElement(Component, (0, _extends2.default)({
140
+ return renderDropdownItem( /*#__PURE__*/_react.default.createElement(Component, (0, _extends2.default)({
134
141
  ref: ref,
135
- role: "none presentation",
136
142
  className: merge(prefix('panel'), className)
137
- }, restProps), children);
143
+ }, restProps), children));
138
144
  }
139
145
 
140
146
  if (navbar) {
@@ -158,6 +164,7 @@ var DropdownItem = /*#__PURE__*/_react.default.forwardRef(function (props, ref)
158
164
  className: classes,
159
165
  "aria-current": selected || undefined
160
166
  }, dataAttributes, restProps, {
167
+ as: Component,
161
168
  onClick: (0, _utils.createChainedFunction)(handleClickNavbarDropdownItem, restProps.onClick)
162
169
  }), icon && /*#__PURE__*/_react.default.cloneElement(icon, {
163
170
  className: prefix('menu-icon')
@@ -188,12 +195,12 @@ var DropdownItem = /*#__PURE__*/_react.default.forwardRef(function (props, ref)
188
195
  dataAttributes['data-event-key-type'] = typeof eventKey;
189
196
  }
190
197
 
191
- return /*#__PURE__*/_react.default.createElement(Component, (0, _extends2.default)({
198
+ return renderDropdownItem( /*#__PURE__*/_react.default.createElement(Component, (0, _extends2.default)({
192
199
  ref: (0, _utils.mergeRefs)(ref, menuitemRef),
193
200
  className: classes
194
201
  }, menuitem, dataAttributes, restProps), icon && /*#__PURE__*/_react.default.cloneElement(icon, {
195
202
  className: prefix('menu-icon')
196
- }), children);
203
+ }), children));
197
204
  });
198
205
  });
199
206
 
@@ -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<Element>) => void;
23
- onToggle?: (eventKey: T, event: React.SyntheticEvent<Element>) => void;
22
+ onSelect?: (eventKey: T, event: React.SyntheticEvent) => void;
23
+ onToggle?: (eventKey: T, event: React.SyntheticEvent) => void;
24
24
  }
25
25
  /**
26
26
  * The <Dropdown.Menu> API
@@ -33,7 +33,7 @@ export interface FormProps<T = Record<string, any>, errorMsgType = any, E = {
33
33
  /** The error message comes from context */
34
34
  errorFromContext?: boolean;
35
35
  /** Callback fired when data changing */
36
- onChange?: (formValue: T, event: React.SyntheticEvent<HTMLElement>) => void;
36
+ onChange?: (formValue: T, event: React.SyntheticEvent) => void;
37
37
  /** Callback fired when error checking */
38
38
  onError?: (formError: E) => void;
39
39
  /** Callback fired when data cheking */
@@ -1,5 +1,6 @@
1
1
  import React from 'react';
2
- import { TypeAttributes, FormControlBaseProps, WithAsProps, RsRefForwardingComponent } from '../@types/common';
2
+ import Input from '../Input';
3
+ import { TypeAttributes, FormControlBaseProps, WithAsProps } from '../@types/common';
3
4
  /**
4
5
  * Props that FormControl passes to its accepter
5
6
  */
@@ -12,7 +13,7 @@ export interface FormControlProps<P = any, ValueType = any> extends WithAsProps,
12
13
  /** Value */
13
14
  value?: ValueType;
14
15
  /** Callback fired when data changing */
15
- onChange?(value: ValueType, event: React.SyntheticEvent<HTMLElement>): void;
16
+ onChange?(value: ValueType, event: React.SyntheticEvent): void;
16
17
  /** The data validation trigger type, and it wiill overrides the setting on <Form> */
17
18
  checkTrigger?: TypeAttributes.CheckTrigger;
18
19
  /** Show error messages */
@@ -28,5 +29,10 @@ export interface FormControlProps<P = any, ValueType = any> extends WithAsProps,
28
29
  /** Asynchronous check value */
29
30
  checkAsync?: boolean;
30
31
  }
31
- declare const FormControl: RsRefForwardingComponent<'div', FormControlProps>;
32
+ interface FormControlComponent extends React.FC<FormControlProps> {
33
+ <Accepter extends React.ElementType = typeof Input>(props: FormControlProps & {
34
+ accepter?: Accepter;
35
+ } & React.ComponentPropsWithRef<Accepter>): React.ReactElement;
36
+ }
37
+ declare const FormControl: FormControlComponent;
32
38
  export default FormControl;
@@ -138,14 +138,18 @@ var FormControl = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
138
138
  }
139
139
  }
140
140
 
141
- var ariaDescribedby = controlId ? controlId + "-" + (messageNode ? 'error-message' : 'help-text') : null;
141
+ var ariaDescribedby = controlId ? controlId + "-help-text" : null;
142
+ var fieldHasError = Boolean(messageNode);
143
+ var ariaErrormessage = fieldHasError && controlId ? controlId + "-error-message" : undefined;
142
144
  return /*#__PURE__*/_react.default.createElement(Component, {
143
145
  className: classes,
144
146
  ref: ref
145
147
  }, /*#__PURE__*/_react.default.createElement(AccepterComponent, (0, _extends3.default)({
146
148
  id: controlId,
147
149
  "aria-labelledby": controlId ? controlId + "-control-label" : null,
148
- "aria-describedby": ariaDescribedby
150
+ "aria-describedby": ariaDescribedby,
151
+ "aria-invalid": fieldHasError || undefined,
152
+ "aria-errormessage": ariaErrormessage
149
153
  }, rest, {
150
154
  readOnly: readOnly,
151
155
  plaintext: plaintext,
@@ -3,7 +3,7 @@ import { WithAsProps, RsRefForwardingComponent, TypeAttributes, FormControlBaseP
3
3
  export interface LocaleType {
4
4
  unfilled: string;
5
5
  }
6
- export interface InputProps extends WithAsProps, Omit<React.InputHTMLAttributes<HTMLInputElement>, 'onChange' | 'size'>, FormControlBaseProps<string | number | ReadonlyArray<string>> {
6
+ export interface InputProps extends WithAsProps, Omit<React.InputHTMLAttributes<HTMLInputElement>, 'onChange' | 'size'>, FormControlBaseProps {
7
7
  /** The HTML input type */
8
8
  type?: string;
9
9
  /** The HTML input id */
@@ -12,6 +12,7 @@ export interface InputProps extends WithAsProps, Omit<React.InputHTMLAttributes<
12
12
  size?: TypeAttributes.Size;
13
13
  /** Ref of input element */
14
14
  inputRef?: React.Ref<any>;
15
+ onChange?: (value: string, event: React.ChangeEvent<HTMLInputElement>) => void;
15
16
  /** Called on press enter */
16
17
  onPressEnter?: React.KeyboardEventHandler<HTMLInputElement>;
17
18
  }
@@ -21,7 +21,7 @@ var _AngleUp = _interopRequireDefault(require("@rsuite/icons/legacy/AngleUp"));
21
21
 
22
22
  var _AngleDown = _interopRequireDefault(require("@rsuite/icons/legacy/AngleDown"));
23
23
 
24
- var _DOMHelper = _interopRequireDefault(require("../DOMHelper"));
24
+ var _on = _interopRequireDefault(require("dom-lib/on"));
25
25
 
26
26
  var _InputGroup = _interopRequireDefault(require("../InputGroup/InputGroup"));
27
27
 
@@ -216,7 +216,7 @@ var InputNumber = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
216
216
  var wheelListener;
217
217
 
218
218
  if (inputRef.current && scrollable) {
219
- wheelListener = _DOMHelper.default.on(inputRef.current, 'wheel', handleWheel, {
219
+ wheelListener = (0, _on.default)(inputRef.current, 'wheel', handleWheel, {
220
220
  passive: false
221
221
  });
222
222
  }
@@ -33,7 +33,7 @@ var _omit = _interopRequireDefault(require("lodash/omit"));
33
33
 
34
34
  var _pick = _interopRequireDefault(require("lodash/pick"));
35
35
 
36
- var _domLib = require("dom-lib");
36
+ var _getWidth = _interopRequireDefault(require("dom-lib/getWidth"));
37
37
 
38
38
  var _shallowEqual = _interopRequireDefault(require("../utils/shallowEqual"));
39
39
 
@@ -232,7 +232,7 @@ var InputPicker = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
232
232
 
233
233
  // In multiple selection, you need to set a maximum width for the input.
234
234
  if ((_triggerRef$current2 = triggerRef.current) !== null && _triggerRef$current2 !== void 0 && _triggerRef$current2.root) {
235
- setMaxWidth((0, _domLib.getWidth)(triggerRef.current.root));
235
+ setMaxWidth((0, _getWidth.default)(triggerRef.current.root));
236
236
  }
237
237
  }, []); // Update the position of the menu when the search keyword and value change
238
238
 
@@ -674,7 +674,8 @@ var InputPicker = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
674
674
  classPrefix: classPrefix,
675
675
  appearance: appearance,
676
676
  hasValue: hasValue,
677
- name: 'input'
677
+ name: 'input',
678
+ cleanable: cleanable
678
679
  })),
679
680
  pickerClasses = _usePickerClassName[0],
680
681
  usedClassNamePropKeys = _usePickerClassName[1];