rsuite 5.20.0 → 5.22.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 (139) hide show
  1. package/CHANGELOG.md +25 -973
  2. package/CheckTreePicker/styles/index.less +0 -25
  3. package/DatePicker/styles/index.less +11 -0
  4. package/Picker/styles/index.less +0 -10
  5. package/Picker/styles/mixin.less +0 -5
  6. package/README.md +4 -2
  7. package/Table/styles/index.less +12 -7
  8. package/TreePicker/styles/index.less +0 -19
  9. package/Windowing/package.json +7 -0
  10. package/cjs/Calendar/MonthDropdown.d.ts +1 -0
  11. package/cjs/Calendar/MonthDropdown.js +27 -40
  12. package/cjs/Cascader/Cascader.d.ts +2 -2
  13. package/cjs/Cascader/DropdownMenu.js +5 -2
  14. package/cjs/CheckPicker/CheckPicker.d.ts +2 -2
  15. package/cjs/CheckPicker/CheckPicker.js +4 -1
  16. package/cjs/CheckTreePicker/CheckTreePicker.js +37 -39
  17. package/cjs/CustomProvider/CustomProvider.d.ts +1 -108
  18. package/cjs/CustomProvider/CustomProvider.js +2 -5
  19. package/cjs/CustomProvider/index.d.ts +2 -2
  20. package/cjs/CustomProvider/index.js +0 -1
  21. package/cjs/DatePicker/DatePicker.js +25 -3
  22. package/cjs/DatePicker/types.d.ts +1 -0
  23. package/cjs/DateRangePicker/DateRangePicker.js +39 -20
  24. package/cjs/Disclosure/Disclosure.d.ts +2 -2
  25. package/cjs/Disclosure/Disclosure.js +6 -6
  26. package/cjs/InputPicker/InputPicker.js +4 -1
  27. package/cjs/Modal/ModalBody.js +18 -17
  28. package/cjs/MultiCascader/DropdownMenu.js +5 -2
  29. package/cjs/Navbar/NavbarDropdownMenu.js +16 -10
  30. package/cjs/Overlay/OverlayTrigger.d.ts +2 -2
  31. package/cjs/Picker/DropdownMenu.d.ts +2 -1
  32. package/cjs/Picker/DropdownMenu.js +38 -34
  33. package/cjs/Picker/PickerOverlay.d.ts +2 -2
  34. package/cjs/Picker/PickerToggle.js +4 -1
  35. package/cjs/Picker/PickerToggleTrigger.d.ts +2 -2
  36. package/cjs/Picker/PickerToggleTrigger.js +11 -10
  37. package/cjs/Picker/index.d.ts +3 -3
  38. package/cjs/Picker/types.d.ts +7 -5
  39. package/cjs/Picker/utils.d.ts +11 -12
  40. package/cjs/Picker/utils.js +4 -0
  41. package/cjs/SelectPicker/SelectPicker.d.ts +4 -5
  42. package/cjs/SelectPicker/SelectPicker.js +4 -1
  43. package/cjs/Tree/Tree.d.ts +2 -5
  44. package/cjs/TreePicker/TreePicker.js +35 -37
  45. package/cjs/TreePicker/test/TreePicker.test.js +14 -0
  46. package/cjs/Whisper/Whisper.d.ts +3 -3
  47. package/cjs/Whisper/Whisper.js +11 -10
  48. package/cjs/Windowing/AutoSizer.d.ts +25 -0
  49. package/cjs/Windowing/AutoSizer.js +103 -0
  50. package/cjs/Windowing/List.d.ts +45 -0
  51. package/cjs/Windowing/List.js +72 -0
  52. package/cjs/Windowing/index.d.ts +5 -0
  53. package/cjs/Windowing/index.js +19 -0
  54. package/cjs/index.d.ts +1 -0
  55. package/cjs/toaster/ToastContainer.d.ts +2 -1
  56. package/cjs/toaster/ToastContainer.js +27 -26
  57. package/cjs/toaster/toaster.d.ts +1 -1
  58. package/cjs/toaster/toaster.js +43 -13
  59. package/cjs/toaster/useToaster.d.ts +1 -1
  60. package/cjs/utils/index.d.ts +1 -0
  61. package/cjs/utils/index.js +6 -1
  62. package/cjs/utils/render.d.ts +3 -0
  63. package/cjs/utils/render.js +49 -0
  64. package/cjs/utils/treeUtils.d.ts +2 -2
  65. package/cjs/utils/useUniqueId.js +10 -2
  66. package/dist/rsuite-rtl.css +20 -73
  67. package/dist/rsuite-rtl.min.css +1 -1
  68. package/dist/rsuite-rtl.min.css.map +1 -1
  69. package/dist/rsuite.css +20 -73
  70. package/dist/rsuite.js +118 -377
  71. package/dist/rsuite.js.map +1 -1
  72. package/dist/rsuite.min.css +1 -1
  73. package/dist/rsuite.min.css.map +1 -1
  74. package/dist/rsuite.min.js +1 -1
  75. package/dist/rsuite.min.js.LICENSE.txt +2 -0
  76. package/dist/rsuite.min.js.map +1 -1
  77. package/esm/Calendar/MonthDropdown.d.ts +1 -0
  78. package/esm/Calendar/MonthDropdown.js +26 -41
  79. package/esm/Cascader/Cascader.d.ts +2 -2
  80. package/esm/Cascader/DropdownMenu.js +5 -2
  81. package/esm/CheckPicker/CheckPicker.d.ts +2 -2
  82. package/esm/CheckPicker/CheckPicker.js +4 -1
  83. package/esm/CheckTreePicker/CheckTreePicker.js +37 -38
  84. package/esm/CustomProvider/CustomProvider.d.ts +1 -108
  85. package/esm/CustomProvider/CustomProvider.js +2 -4
  86. package/esm/CustomProvider/index.d.ts +2 -2
  87. package/esm/CustomProvider/index.js +2 -2
  88. package/esm/DatePicker/DatePicker.js +22 -3
  89. package/esm/DatePicker/types.d.ts +1 -0
  90. package/esm/DateRangePicker/DateRangePicker.js +39 -20
  91. package/esm/Disclosure/Disclosure.d.ts +2 -2
  92. package/esm/Disclosure/Disclosure.js +6 -6
  93. package/esm/InputPicker/InputPicker.js +4 -1
  94. package/esm/Modal/ModalBody.js +16 -17
  95. package/esm/MultiCascader/DropdownMenu.js +5 -2
  96. package/esm/Navbar/NavbarDropdownMenu.js +14 -8
  97. package/esm/Overlay/OverlayTrigger.d.ts +2 -2
  98. package/esm/Picker/DropdownMenu.d.ts +2 -1
  99. package/esm/Picker/DropdownMenu.js +38 -36
  100. package/esm/Picker/PickerOverlay.d.ts +2 -2
  101. package/esm/Picker/PickerToggle.js +4 -1
  102. package/esm/Picker/PickerToggleTrigger.d.ts +2 -2
  103. package/esm/Picker/PickerToggleTrigger.js +10 -11
  104. package/esm/Picker/index.d.ts +3 -3
  105. package/esm/Picker/types.d.ts +7 -5
  106. package/esm/Picker/utils.d.ts +11 -12
  107. package/esm/Picker/utils.js +4 -0
  108. package/esm/SelectPicker/SelectPicker.d.ts +4 -5
  109. package/esm/SelectPicker/SelectPicker.js +4 -1
  110. package/esm/Tree/Tree.d.ts +2 -5
  111. package/esm/TreePicker/TreePicker.js +34 -35
  112. package/esm/TreePicker/test/TreePicker.test.js +14 -0
  113. package/esm/Whisper/Whisper.d.ts +3 -3
  114. package/esm/Whisper/Whisper.js +10 -11
  115. package/esm/Windowing/AutoSizer.d.ts +25 -0
  116. package/esm/Windowing/AutoSizer.js +88 -0
  117. package/esm/Windowing/List.d.ts +45 -0
  118. package/esm/Windowing/List.js +58 -0
  119. package/esm/Windowing/index.d.ts +5 -0
  120. package/esm/Windowing/index.js +3 -0
  121. package/esm/index.d.ts +1 -0
  122. package/esm/toaster/ToastContainer.d.ts +2 -1
  123. package/esm/toaster/ToastContainer.js +28 -26
  124. package/esm/toaster/toaster.d.ts +1 -1
  125. package/esm/toaster/toaster.js +41 -13
  126. package/esm/toaster/useToaster.d.ts +1 -1
  127. package/esm/utils/index.d.ts +1 -0
  128. package/esm/utils/index.js +1 -0
  129. package/esm/utils/render.d.ts +3 -0
  130. package/esm/utils/render.js +37 -0
  131. package/esm/utils/treeUtils.d.ts +2 -2
  132. package/esm/utils/useUniqueId.js +7 -2
  133. package/package.json +5 -5
  134. package/styles/mixins/listbox.less +0 -5
  135. package/styles/variables.less +1 -0
  136. package/cjs/Picker/VirtualizedList.d.ts +0 -37
  137. package/cjs/Picker/VirtualizedList.js +0 -15
  138. package/esm/Picker/VirtualizedList.d.ts +0 -37
  139. package/esm/Picker/VirtualizedList.js +0 -4
@@ -1,5 +1,7 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
+
3
5
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
6
 
5
7
  exports.__esModule = true;
@@ -9,7 +11,7 @@ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")
9
11
 
10
12
  var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
11
13
 
12
- var _react = _interopRequireDefault(require("react"));
14
+ var _react = _interopRequireWildcard(require("react"));
13
15
 
14
16
  var _pick = _interopRequireDefault(require("lodash/pick"));
15
17
 
@@ -32,15 +34,14 @@ var PickerToggleTrigger = /*#__PURE__*/_react.default.forwardRef(function (props
32
34
  trigger = _props$trigger === void 0 ? 'click' : _props$trigger,
33
35
  rest = (0, _objectWithoutPropertiesLoose2.default)(props, ["pickerProps", "speaker", "placement", "trigger"]);
34
36
  var pickerTriggerProps = (0, _pick.default)(pickerProps, pickTriggerPropKeys);
35
- return /*#__PURE__*/_react.default.createElement(_CustomProvider.CustomConsumer, null, function (context) {
36
- return /*#__PURE__*/_react.default.createElement(_OverlayTrigger.default, (0, _extends2.default)({}, rest, pickerTriggerProps, {
37
- disabled: pickerTriggerProps.disabled || pickerTriggerProps.loading,
38
- ref: ref,
39
- trigger: trigger,
40
- placement: (0, _utils.placementPolyfill)(placement, context === null || context === void 0 ? void 0 : context.rtl),
41
- speaker: speaker
42
- }));
43
- });
37
+ var context = (0, _react.useContext)(_CustomProvider.CustomContext);
38
+ return /*#__PURE__*/_react.default.createElement(_OverlayTrigger.default, (0, _extends2.default)({}, rest, pickerTriggerProps, {
39
+ disabled: pickerTriggerProps.disabled || pickerTriggerProps.loading,
40
+ ref: ref,
41
+ trigger: trigger,
42
+ placement: (0, _utils.placementPolyfill)(placement, context === null || context === void 0 ? void 0 : context.rtl),
43
+ speaker: speaker
44
+ }));
44
45
  });
45
46
 
46
47
  PickerToggleTrigger.displayName = 'PickerToggleTrigger';
@@ -1,6 +1,6 @@
1
- import { pickTriggerPropKeys, omitTriggerPropKeys, OverlayTriggerInstance, PositionChildProps } from './PickerToggleTrigger';
1
+ import { pickTriggerPropKeys, omitTriggerPropKeys, OverlayTriggerHandle, PositionChildProps } from './PickerToggleTrigger';
2
2
  import { PickerToggleProps } from './PickerToggle';
3
- import { PickerInstance, PickerComponent } from './types';
3
+ import { PickerHandle, PickerComponent } from './types';
4
4
  export { default as DropdownMenu } from './DropdownMenu';
5
5
  export { default as DropdownMenuCheckItem } from './DropdownMenuCheckItem';
6
6
  export { default as DropdownMenuGroup } from './DropdownMenuGroup';
@@ -11,6 +11,6 @@ export { default as PickerToggleTrigger } from './PickerToggleTrigger';
11
11
  export { default as SearchBar } from './SearchBar';
12
12
  export { default as SelectedElement } from './SelectedElement';
13
13
  export { pickTriggerPropKeys, omitTriggerPropKeys };
14
- export type { OverlayTriggerInstance, PositionChildProps, PickerInstance, PickerComponent, PickerToggleProps };
14
+ export type { OverlayTriggerHandle, PositionChildProps, PickerHandle, PickerComponent, PickerToggleProps };
15
15
  export * from './utils';
16
16
  export * from './propTypes';
@@ -1,13 +1,15 @@
1
1
  /// <reference types="react" />
2
2
  import { RsRefForwardingComponent } from '../@types/common';
3
- export interface PickerInstance {
4
- root?: Element;
5
- overlay?: Element;
6
- target?: HTMLElement;
3
+ import type { ListHandle } from '../Windowing';
4
+ export interface PickerHandle {
5
+ root: HTMLElement | null;
6
+ list?: ListHandle;
7
+ overlay?: HTMLElement | null;
8
+ target?: HTMLElement | null;
7
9
  updatePosition?: () => void;
8
10
  open?: () => void;
9
11
  close?: () => void;
10
12
  }
11
13
  export declare type PickerComponent<P> = RsRefForwardingComponent<'div', P & {
12
- ref?: React.Ref<PickerInstance>;
14
+ ref?: React.Ref<PickerHandle>;
13
15
  }>;
@@ -1,14 +1,14 @@
1
1
  import React from 'react';
2
- import { OverlayTriggerInstance } from './PickerToggleTrigger';
2
+ import { OverlayTriggerHandle } from './PickerToggleTrigger';
3
3
  import { TypeAttributes, ItemDataType } from '../@types/common';
4
- import { ListInstance } from './VirtualizedList';
5
- interface NodeKeys {
4
+ import type { ListHandle } from '../Windowing';
5
+ export interface NodeKeys {
6
6
  valueKey: string;
7
7
  childrenKey: string;
8
8
  }
9
9
  export declare function createConcatChildrenFunction<T = any>(node: any, nodeValue?: any, nodeKeys?: NodeKeys): (data: T[], children: T[]) => T[];
10
10
  export declare function shouldDisplay(label: React.ReactNode, searchKeyword: string): boolean;
11
- interface PickerClassNameProps {
11
+ export interface PickerClassNameProps {
12
12
  name?: string;
13
13
  classPrefix: string;
14
14
  className?: string;
@@ -27,7 +27,7 @@ interface PickerClassNameProps {
27
27
  * The className of the assembled Toggle is on the Picker.
28
28
  */
29
29
  export declare function usePickerClassName(props: PickerClassNameProps): [string, string[]];
30
- interface EventsProps {
30
+ export interface EventsProps {
31
31
  down?: React.KeyboardEventHandler;
32
32
  up?: React.KeyboardEventHandler;
33
33
  enter?: React.KeyboardEventHandler;
@@ -42,7 +42,7 @@ interface EventsProps {
42
42
  * @param events Event callback functions
43
43
  */
44
44
  export declare function onMenuKeyDown(event: React.KeyboardEvent, events: EventsProps): void;
45
- interface FocusItemValueProps {
45
+ export interface FocusItemValueProps {
46
46
  target: HTMLElement | null | (() => HTMLElement | null);
47
47
  data?: any[];
48
48
  valueKey?: string;
@@ -65,7 +65,7 @@ export declare const useFocusItemValue: <T>(defaultFocusItemValue: T | null | un
65
65
  setKeys: React.Dispatch<React.SetStateAction<any[]>>;
66
66
  onKeyDown: (event: any) => void;
67
67
  };
68
- interface ToggleKeyDownEventProps {
68
+ export interface ToggleKeyDownEventProps {
69
69
  toggle?: boolean;
70
70
  triggerRef: React.RefObject<any>;
71
71
  targetRef: React.RefObject<any>;
@@ -86,7 +86,7 @@ interface ToggleKeyDownEventProps {
86
86
  * @param props
87
87
  */
88
88
  export declare const useToggleKeyDownEvent: (props: ToggleKeyDownEventProps) => (event: React.KeyboardEvent) => void;
89
- interface SearchProps {
89
+ export interface SearchProps {
90
90
  labelKey: string;
91
91
  data: ItemDataType[];
92
92
  searchBy?: (keyword: any, label: any, item: any) => boolean;
@@ -104,16 +104,15 @@ export declare function useSearch(props: SearchProps): {
104
104
  checkShouldDisplay: (item: ItemDataType, keyword?: string) => boolean;
105
105
  handleSearch: (searchKeyword: string, event: React.SyntheticEvent) => void;
106
106
  };
107
- interface PickerDependentParameters {
108
- triggerRef?: React.RefObject<OverlayTriggerInstance>;
107
+ export interface PickerDependentParameters {
108
+ triggerRef?: React.RefObject<OverlayTriggerHandle>;
109
109
  rootRef?: React.RefObject<HTMLElement>;
110
110
  overlayRef?: React.RefObject<HTMLElement>;
111
111
  targetRef?: React.RefObject<HTMLElement>;
112
- listRef?: React.RefObject<ListInstance>;
112
+ listRef?: React.RefObject<ListHandle>;
113
113
  inline?: boolean;
114
114
  }
115
115
  /**
116
116
  * A hook of the exposed method of Picker
117
117
  */
118
118
  export declare function usePublicMethods(ref: any, parmas: PickerDependentParameters): void;
119
- export {};
@@ -553,6 +553,10 @@ function usePublicMethods(ref, parmas) {
553
553
  get overlay() {
554
554
  var _overlayRef$current;
555
555
 
556
+ if (!(overlayRef !== null && overlayRef !== void 0 && overlayRef.current)) {
557
+ throw new Error('The overlay is not found. Please confirm whether the picker is open.');
558
+ }
559
+
556
560
  return (_overlayRef$current = overlayRef === null || overlayRef === void 0 ? void 0 : overlayRef.current) !== null && _overlayRef$current !== void 0 ? _overlayRef$current : null;
557
561
  },
558
562
 
@@ -1,7 +1,7 @@
1
1
  import React, { Ref } from 'react';
2
2
  import { PickerLocale } from '../locales';
3
- import { PickerInstance, PickerToggleProps } from '../Picker';
4
- import { ListProps } from '../Picker/VirtualizedList';
3
+ import { PickerHandle, PickerToggleProps } from '../Picker';
4
+ import { ListProps } from '../Windowing';
5
5
  import { FormControlPickerProps, ItemDataType } from '../@types/common';
6
6
  export interface SelectProps<T> {
7
7
  /** Set group condition key in data */
@@ -13,8 +13,7 @@ export interface SelectProps<T> {
13
13
  /** Whether using virtualized list */
14
14
  virtualized?: boolean;
15
15
  /**
16
- * List-related properties in `react-virtualized`
17
- * https://github.com/bvaughn/react-virtualized/blob/master/docs/List.md#prop-types
16
+ * Virtualized List Props
18
17
  */
19
18
  listProps?: Partial<ListProps>;
20
19
  /** Custom search rules. */
@@ -52,7 +51,7 @@ export interface SelectPickerProps<T> extends Omit<FormControlPickerProps<T, Pic
52
51
  }
53
52
  export interface SelectPickerComponent {
54
53
  <T>(props: SelectPickerProps<T> & {
55
- ref?: Ref<PickerInstance>;
54
+ ref?: Ref<PickerHandle>;
56
55
  }): JSX.Element | null;
57
56
  displayName?: string;
58
57
  propTypes?: React.WeakValidationMap<SelectPickerProps<any>>;
@@ -94,6 +94,7 @@ var SelectPicker = /*#__PURE__*/_react.default.forwardRef(function (props, ref)
94
94
  var targetRef = (0, _react.useRef)(null);
95
95
  var overlayRef = (0, _react.useRef)(null);
96
96
  var searchInputRef = (0, _react.useRef)(null);
97
+ var listRef = (0, _react.useRef)(null);
97
98
 
98
99
  var _useCustom = (0, _utils.useCustom)('Picker', overrideLocale),
99
100
  locale = _useCustom.locale;
@@ -213,7 +214,8 @@ var SelectPicker = /*#__PURE__*/_react.default.forwardRef(function (props, ref)
213
214
  (0, _Picker.usePublicMethods)(ref, {
214
215
  triggerRef: triggerRef,
215
216
  overlayRef: overlayRef,
216
- targetRef: targetRef
217
+ targetRef: targetRef,
218
+ listRef: listRef
217
219
  }); // Find active `MenuItem` by `value`
218
220
 
219
221
  var activeItem = data.find(function (item) {
@@ -264,6 +266,7 @@ var SelectPicker = /*#__PURE__*/_react.default.forwardRef(function (props, ref)
264
266
  var menu = items.length ? /*#__PURE__*/_react.default.createElement(_Picker.DropdownMenu, {
265
267
  id: id ? id + "-listbox" : undefined,
266
268
  listProps: listProps,
269
+ listRef: listRef,
267
270
  disabledItemValues: disabledItemValues,
268
271
  valueKey: valueKey,
269
272
  labelKey: labelKey,
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  import { StandardProps, ItemDataType, RsRefForwardingComponent } from '../@types/common';
3
- import { ListProps } from '../Picker/VirtualizedList';
3
+ import { ListProps } from '../Windowing';
4
4
  /**
5
5
  * Tree Node Drag Type
6
6
  */
@@ -46,10 +46,7 @@ export interface TreeBaseProps<ValueType = string | number, ItemDataType = Recor
46
46
  showIndentLine?: boolean;
47
47
  /** Whether using virtualized list */
48
48
  virtualized?: boolean;
49
- /**
50
- * List-related properties in `react-virtualized`
51
- * https://github.com/bvaughn/react-virtualized/blob/master/docs/List.md#prop-types
52
- */
49
+ /** Virtualized List props */
53
50
  listProps?: Partial<ListProps>;
54
51
  /** Expand all nodes By default */
55
52
  defaultExpandAll?: boolean;
@@ -25,7 +25,7 @@ var _react = _interopRequireWildcard(require("react"));
25
25
 
26
26
  var _propTypes = _interopRequireDefault(require("prop-types"));
27
27
 
28
- var _VirtualizedList = require("../Picker/VirtualizedList");
28
+ var _Windowing = require("../Windowing");
29
29
 
30
30
  var _TreeNode = _interopRequireDefault(require("./TreeNode"));
31
31
 
@@ -39,6 +39,10 @@ var _TreeContext = _interopRequireDefault(require("../Tree/TreeContext"));
39
39
 
40
40
  var emptyArray = [];
41
41
 
42
+ var itemSize = function itemSize() {
43
+ return 36;
44
+ };
45
+
42
46
  var TreePicker = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
43
47
  var _props$as = props.as,
44
48
  Component = _props$as === void 0 ? 'div' : _props$as,
@@ -599,33 +603,30 @@ var TreePicker = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
599
603
  }, nodeProps));
600
604
  };
601
605
 
602
- var renderVirtualListNode = function renderVirtualListNode(nodes) {
603
- return function (_ref3) {
604
- var key = _ref3.key,
605
- index = _ref3.index,
606
- style = _ref3.style;
607
- var node = nodes[index];
608
- var layer = node.layer,
609
- visible = node.visible;
610
- var expand = (0, _treeUtils.getExpandWhenSearching)(searchKeywordState, expandItemValues.includes(node[valueKey]));
611
-
612
- if (!node.visible) {
613
- return null;
614
- }
606
+ var renderVirtualListNode = function renderVirtualListNode(_ref3) {
607
+ var index = _ref3.index,
608
+ style = _ref3.style,
609
+ data = _ref3.data;
610
+ var node = data[index];
611
+ var layer = node.layer,
612
+ visible = node.visible;
613
+ var expand = (0, _treeUtils.getExpandWhenSearching)(searchKeywordState, expandItemValues.includes(node[valueKey]));
615
614
 
616
- var nodeProps = (0, _extends2.default)({}, getTreeNodeProps((0, _extends2.default)({}, node, {
617
- expand: expand
618
- }), layer), {
619
- style: style,
620
- hasChildren: node.hasChildren
621
- });
622
- return visible && /*#__PURE__*/_react.default.createElement(_TreeNode.default, (0, _extends2.default)({
623
- ref: function ref(_ref4) {
624
- return saveTreeNodeRef(_ref4, node.refKey);
625
- },
626
- key: key
627
- }, nodeProps));
628
- };
615
+ if (!node.visible) {
616
+ return null;
617
+ }
618
+
619
+ var nodeProps = (0, _extends2.default)({}, getTreeNodeProps((0, _extends2.default)({}, node, {
620
+ expand: expand
621
+ }), layer), {
622
+ style: style,
623
+ hasChildren: node.hasChildren
624
+ });
625
+ return visible && /*#__PURE__*/_react.default.createElement(_TreeNode.default, (0, _extends2.default)({
626
+ ref: function ref(_ref4) {
627
+ return saveTreeNodeRef(_ref4, node.refKey);
628
+ }
629
+ }, nodeProps));
629
630
  };
630
631
 
631
632
  var renderTree = function renderTree() {
@@ -645,24 +646,21 @@ var TreePicker = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
645
646
  onKeyDown: inline ? handleTreeKeyDown : undefined
646
647
  }, /*#__PURE__*/_react.default.createElement("div", {
647
648
  className: treePrefix('nodes')
648
- }, virtualized ? /*#__PURE__*/_react.default.createElement(_VirtualizedList.AutoSizer, {
649
+ }, virtualized ? /*#__PURE__*/_react.default.createElement(_Windowing.AutoSizer, {
649
650
  defaultHeight: inline ? height : menuMaxHeight,
650
651
  style: {
651
652
  width: 'auto',
652
653
  height: 'auto'
653
654
  }
654
655
  }, function (_ref5) {
655
- var height = _ref5.height,
656
- width = _ref5.width;
657
- return /*#__PURE__*/_react.default.createElement(_VirtualizedList.List, (0, _extends2.default)({
656
+ var height = _ref5.height;
657
+ return /*#__PURE__*/_react.default.createElement(_Windowing.List, (0, _extends2.default)({
658
658
  ref: listRef,
659
- width: width,
660
659
  height: height,
661
- rowHeight: 36,
662
- rowCount: formattedNodes.length,
663
- rowRenderer: renderVirtualListNode(formattedNodes),
664
- scrollToAlignment: "center"
665
- }, listProps));
660
+ itemSize: itemSize,
661
+ itemCount: formattedNodes.length,
662
+ itemData: formattedNodes
663
+ }, listProps), renderVirtualListNode);
666
664
  }) : formattedNodes));
667
665
  };
668
666
 
@@ -12,4 +12,18 @@ _react.default.createElement(_TreePicker.default, {
12
12
  return /*#__PURE__*/_react.default.createElement("div", null);
13
13
  },
14
14
  data: []
15
+ });
16
+
17
+ /*#__PURE__*/
18
+ _react.default.createElement(_TreePicker.default, {
19
+ data: [],
20
+ listProps: {
21
+ itemSize: 30,
22
+ onItemsRendered: function onItemsRendered() {
23
+ console.log('onItemsRendered');
24
+ },
25
+ onScroll: function onScroll() {
26
+ console.log('onScroll');
27
+ }
28
+ }
15
29
  });
@@ -1,7 +1,7 @@
1
1
  import React from 'react';
2
- import { OverlayTriggerInstance } from '../Overlay/OverlayTrigger';
2
+ import { OverlayTriggerHandle } from '../Overlay/OverlayTrigger';
3
3
  import { OverlayTriggerProps } from '../Overlay/OverlayTrigger';
4
4
  export declare type WhisperProps = OverlayTriggerProps;
5
- export declare type WhisperInstance = OverlayTriggerInstance;
6
- declare const Whisper: React.ForwardRefExoticComponent<OverlayTriggerProps & React.RefAttributes<OverlayTriggerInstance>>;
5
+ export declare type WhisperInstance = OverlayTriggerHandle;
6
+ declare const Whisper: React.ForwardRefExoticComponent<OverlayTriggerProps & React.RefAttributes<OverlayTriggerHandle>>;
7
7
  export default Whisper;
@@ -1,5 +1,7 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
+
3
5
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
6
 
5
7
  exports.__esModule = true;
@@ -9,7 +11,7 @@ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")
9
11
 
10
12
  var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
11
13
 
12
- var _react = _interopRequireDefault(require("react"));
14
+ var _react = _interopRequireWildcard(require("react"));
13
15
 
14
16
  var _propTypes = _interopRequireDefault(require("prop-types"));
15
17
 
@@ -28,15 +30,14 @@ var Whisper = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
28
30
  placement = _props$placement === void 0 ? 'right' : _props$placement,
29
31
  preventOverflow = props.preventOverflow,
30
32
  rest = (0, _objectWithoutPropertiesLoose2.default)(props, ["onOpen", "onClose", "onEntered", "onExited", "placement", "preventOverflow"]);
31
- return /*#__PURE__*/_react.default.createElement(_CustomProvider.CustomConsumer, null, function (context) {
32
- return /*#__PURE__*/_react.default.createElement(_OverlayTrigger.default, (0, _extends2.default)({}, rest, {
33
- ref: ref,
34
- preventOverflow: preventOverflow,
35
- placement: (0, _utils.placementPolyfill)(placement, context === null || context === void 0 ? void 0 : context.rtl),
36
- onEntered: (0, _utils.createChainedFunction)(onOpen, onEntered),
37
- onExited: (0, _utils.createChainedFunction)(onClose, onExited)
38
- }));
39
- });
33
+ var context = (0, _react.useContext)(_CustomProvider.CustomContext);
34
+ return /*#__PURE__*/_react.default.createElement(_OverlayTrigger.default, (0, _extends2.default)({}, rest, {
35
+ ref: ref,
36
+ preventOverflow: preventOverflow,
37
+ placement: (0, _utils.placementPolyfill)(placement, context === null || context === void 0 ? void 0 : context.rtl),
38
+ onEntered: (0, _utils.createChainedFunction)(onOpen, onEntered),
39
+ onExited: (0, _utils.createChainedFunction)(onClose, onExited)
40
+ }));
40
41
  });
41
42
 
42
43
  Whisper.displayName = 'Whisper';
@@ -0,0 +1,25 @@
1
+ import React from 'react';
2
+ export interface Size {
3
+ height: number;
4
+ width: number;
5
+ }
6
+ export interface AutoSizerProps {
7
+ /** Function responsible for rendering children. */
8
+ children: (size: Size) => React.ReactNode;
9
+ /** Optional custom CSS class name to attach to root AutoSizer element. */
10
+ className?: string | undefined;
11
+ /** Default height to use for initial render; useful for SSR */
12
+ defaultHeight?: number | undefined;
13
+ /** Default width to use for initial render; useful for SSR */
14
+ defaultWidth?: number | undefined;
15
+ /** Disable dynamic :height property */
16
+ disableHeight?: boolean | undefined;
17
+ /** Disable dynamic :width property */
18
+ disableWidth?: boolean | undefined;
19
+ /** Optional inline style */
20
+ style?: React.CSSProperties | undefined;
21
+ /** Callback to be invoked on-resize */
22
+ onResize?: ((size: Size) => void) | undefined;
23
+ }
24
+ declare const AutoSizer: React.ForwardRefExoticComponent<AutoSizerProps & React.RefAttributes<HTMLDivElement>>;
25
+ export default AutoSizer;
@@ -0,0 +1,103 @@
1
+ "use strict";
2
+
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
+
5
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
+
7
+ exports.__esModule = true;
8
+ exports.default = void 0;
9
+
10
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
+
12
+ var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
13
+
14
+ var _react = _interopRequireWildcard(require("react"));
15
+
16
+ var _getStyle = _interopRequireDefault(require("dom-lib/getStyle"));
17
+
18
+ var _utils = require("../utils");
19
+
20
+ var AutoSizer = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
21
+ var children = props.children,
22
+ className = props.className,
23
+ disableHeight = props.disableHeight,
24
+ disableWidth = props.disableWidth,
25
+ defaultHeight = props.defaultHeight,
26
+ defaultWidth = props.defaultWidth,
27
+ style = props.style,
28
+ onResize = props.onResize,
29
+ rest = (0, _objectWithoutPropertiesLoose2.default)(props, ["children", "className", "disableHeight", "disableWidth", "defaultHeight", "defaultWidth", "style", "onResize"]);
30
+
31
+ var _useState = (0, _react.useState)(defaultHeight || 0),
32
+ height = _useState[0],
33
+ setHeight = _useState[1];
34
+
35
+ var _useState2 = (0, _react.useState)(defaultWidth || 0),
36
+ width = _useState2[0],
37
+ setWidth = _useState2[1];
38
+
39
+ var rootRef = (0, _react.useRef)(null);
40
+ var getParentNode = (0, _react.useCallback)(function () {
41
+ var _rootRef$current;
42
+
43
+ if ((_rootRef$current = rootRef.current) !== null && _rootRef$current !== void 0 && _rootRef$current.parentNode && rootRef.current.parentNode.ownerDocument && rootRef.current.parentNode.ownerDocument.defaultView && rootRef.current.parentNode instanceof rootRef.current.parentNode.ownerDocument.defaultView.HTMLElement) {
44
+ return rootRef.current.parentNode;
45
+ }
46
+
47
+ return null;
48
+ }, []);
49
+ var handleResize = (0, _react.useCallback)(function () {
50
+ var parentNode = getParentNode();
51
+
52
+ if (parentNode) {
53
+ var offsetHeight = parentNode.offsetHeight || 0;
54
+ var offsetWidth = parentNode.offsetWidth || 0;
55
+
56
+ var _style = (0, _getStyle.default)(parentNode);
57
+
58
+ var paddingLeft = parseInt(_style.paddingLeft, 10) || 0;
59
+ var paddingRight = parseInt(_style.paddingRight, 10) || 0;
60
+ var paddingTop = parseInt(_style.paddingTop, 10) || 0;
61
+ var paddingBottom = parseInt(_style.paddingBottom, 10) || 0;
62
+ var newHeight = offsetHeight - paddingTop - paddingBottom;
63
+ var newWidth = offsetWidth - paddingLeft - paddingRight;
64
+
65
+ if (!disableHeight && height !== newHeight || !disableWidth && width !== newWidth) {
66
+ setHeight(offsetHeight - paddingTop - paddingBottom);
67
+ setWidth(offsetWidth - paddingLeft - paddingRight);
68
+ onResize === null || onResize === void 0 ? void 0 : onResize({
69
+ height: offsetHeight,
70
+ width: offsetWidth
71
+ });
72
+ }
73
+ }
74
+ }, [disableHeight, disableWidth, getParentNode, height, onResize, width]);
75
+ (0, _utils.useMount)(handleResize);
76
+ (0, _utils.useElementResize)(getParentNode(), handleResize);
77
+ var outerStyle = {
78
+ overflow: 'visible'
79
+ };
80
+ var childParams = {
81
+ width: 0,
82
+ height: 0
83
+ };
84
+
85
+ if (!disableHeight) {
86
+ outerStyle.height = 0;
87
+ childParams.height = height;
88
+ }
89
+
90
+ if (!disableWidth) {
91
+ outerStyle.width = 0;
92
+ childParams.width = width;
93
+ }
94
+
95
+ return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({
96
+ className: className,
97
+ ref: (0, _utils.mergeRefs)(rootRef, ref),
98
+ style: (0, _extends2.default)({}, outerStyle, style)
99
+ }, rest), children(childParams));
100
+ });
101
+
102
+ var _default = AutoSizer;
103
+ exports.default = _default;
@@ -0,0 +1,45 @@
1
+ import { VariableSizeList, ListItemKeySelector, ListOnScrollProps, ListOnItemsRenderedProps } from 'react-window';
2
+ import { WithAsProps, RsRefForwardingComponent } from '../@types/common';
3
+ export interface ListProps<T = any> extends WithAsProps {
4
+ /**
5
+ * @deprecated use itemSize instead
6
+ * Either a fixed row height (number) or a function that returns the height of a row given its index: ({ index: number }): number
7
+ */
8
+ rowHeight?: number | (({ index: number }: {
9
+ index: any;
10
+ }) => number);
11
+ /**
12
+ * Size of a item in the direction being windowed.
13
+ */
14
+ itemSize: number | ((index: number) => number);
15
+ /**
16
+ * Scroll offset for initial render.
17
+ */
18
+ initialScrollOffset?: number;
19
+ /**
20
+ * By default, lists will use an item's index as its key. This is okay if:
21
+ *
22
+ * - Your collections of items is never sorted or modified
23
+ * - Your item renderer is not stateful and does not extend PureComponent
24
+ *
25
+ * If your list does not satisfy the above constraints, use the itemKey property to specify your own keys for items
26
+ */
27
+ itemKey?: ListItemKeySelector<T>;
28
+ /**
29
+ * Called when the items rendered by the list change.
30
+ */
31
+ onItemsRendered?: (props: ListOnItemsRenderedProps) => void;
32
+ /**
33
+ * Called when the list scroll positions changes, as a result of user scrolling or scroll-to method calls.
34
+ */
35
+ onScroll?: (props: ListOnScrollProps) => void;
36
+ }
37
+ export interface ListHandle extends Partial<VariableSizeList> {
38
+ /**
39
+ * @deprecated use scrollToItem instead
40
+ * Ensure row is visible. This method can be used to safely scroll back to a cell that a user has scrolled away from even if it was previously scrolled to.
41
+ */
42
+ scrollToRow?: (index: number) => void;
43
+ }
44
+ declare const List: RsRefForwardingComponent<'div', ListProps>;
45
+ export default List;