@rc-component/util 1.0.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 (159) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +303 -0
  3. package/es/Children/toArray.d.ts +5 -0
  4. package/es/Children/toArray.js +19 -0
  5. package/es/Dom/canUseDom.d.ts +1 -0
  6. package/es/Dom/canUseDom.js +3 -0
  7. package/es/Dom/contains.d.ts +1 -0
  8. package/es/Dom/contains.js +20 -0
  9. package/es/Dom/dynamicCSS.d.ts +25 -0
  10. package/es/Dom/dynamicCSS.js +153 -0
  11. package/es/Dom/findDOMNode.d.ts +12 -0
  12. package/es/Dom/findDOMNode.js +36 -0
  13. package/es/Dom/focus.d.ts +8 -0
  14. package/es/Dom/focus.js +87 -0
  15. package/es/Dom/isVisible.d.ts +2 -0
  16. package/es/Dom/isVisible.js +27 -0
  17. package/es/Dom/scrollLocker.d.ts +12 -0
  18. package/es/Dom/scrollLocker.js +135 -0
  19. package/es/Dom/shadow.d.ts +8 -0
  20. package/es/Dom/shadow.js +18 -0
  21. package/es/Dom/styleChecker.d.ts +2 -0
  22. package/es/Dom/styleChecker.js +26 -0
  23. package/es/KeyCode.d.ts +436 -0
  24. package/es/KeyCode.js +538 -0
  25. package/es/Portal.d.ts +9 -0
  26. package/es/Portal.js +44 -0
  27. package/es/PortalWrapper.d.ts +51 -0
  28. package/es/PortalWrapper.js +217 -0
  29. package/es/React/isFragment.d.ts +4 -0
  30. package/es/React/isFragment.js +18 -0
  31. package/es/React/render.d.ts +13 -0
  32. package/es/React/render.js +114 -0
  33. package/es/composeProps.d.ts +2 -0
  34. package/es/composeProps.js +24 -0
  35. package/es/getScrollBarSize.d.ts +7 -0
  36. package/es/getScrollBarSize.js +76 -0
  37. package/es/hooks/useEffect.d.ts +2 -0
  38. package/es/hooks/useEffect.js +14 -0
  39. package/es/hooks/useEvent.d.ts +2 -0
  40. package/es/hooks/useEvent.js +16 -0
  41. package/es/hooks/useId.d.ts +4 -0
  42. package/es/hooks/useId.js +69 -0
  43. package/es/hooks/useLayoutEffect.d.ts +4 -0
  44. package/es/hooks/useLayoutEffect.js +30 -0
  45. package/es/hooks/useMemo.d.ts +1 -0
  46. package/es/hooks/useMemo.js +9 -0
  47. package/es/hooks/useMergedState.d.ts +12 -0
  48. package/es/hooks/useMergedState.js +68 -0
  49. package/es/hooks/useMobile.d.ts +6 -0
  50. package/es/hooks/useMobile.js +25 -0
  51. package/es/hooks/useState.d.ts +14 -0
  52. package/es/hooks/useState.js +32 -0
  53. package/es/hooks/useSyncState.d.ts +9 -0
  54. package/es/hooks/useSyncState.js +29 -0
  55. package/es/index.d.ts +6 -0
  56. package/es/index.js +6 -0
  57. package/es/isEqual.d.ts +9 -0
  58. package/es/isEqual.js +55 -0
  59. package/es/isMobile.d.ts +2 -0
  60. package/es/isMobile.js +7 -0
  61. package/es/omit.d.ts +1 -0
  62. package/es/omit.js +9 -0
  63. package/es/pickAttrs.d.ts +11 -0
  64. package/es/pickAttrs.js +51 -0
  65. package/es/proxyObject.d.ts +4 -0
  66. package/es/proxyObject.js +19 -0
  67. package/es/raf.d.ts +6 -0
  68. package/es/raf.js +54 -0
  69. package/es/ref.d.ts +19 -0
  70. package/es/ref.js +89 -0
  71. package/es/setStyle.d.ts +12 -0
  72. package/es/setStyle.js +26 -0
  73. package/es/test/domHook.d.ts +8 -0
  74. package/es/test/domHook.js +64 -0
  75. package/es/utils/get.d.ts +1 -0
  76. package/es/utils/get.js +10 -0
  77. package/es/utils/set.d.ts +6 -0
  78. package/es/utils/set.js +93 -0
  79. package/es/warning.d.ts +32 -0
  80. package/es/warning.js +68 -0
  81. package/lib/Children/toArray.d.ts +5 -0
  82. package/lib/Children/toArray.js +26 -0
  83. package/lib/Dom/canUseDom.d.ts +1 -0
  84. package/lib/Dom/canUseDom.js +9 -0
  85. package/lib/Dom/contains.d.ts +1 -0
  86. package/lib/Dom/contains.js +26 -0
  87. package/lib/Dom/dynamicCSS.d.ts +25 -0
  88. package/lib/Dom/dynamicCSS.js +163 -0
  89. package/lib/Dom/findDOMNode.d.ts +12 -0
  90. package/lib/Dom/findDOMNode.js +45 -0
  91. package/lib/Dom/focus.d.ts +8 -0
  92. package/lib/Dom/focus.js +98 -0
  93. package/lib/Dom/isVisible.d.ts +2 -0
  94. package/lib/Dom/isVisible.js +33 -0
  95. package/lib/Dom/scrollLocker.d.ts +12 -0
  96. package/lib/Dom/scrollLocker.js +141 -0
  97. package/lib/Dom/shadow.d.ts +8 -0
  98. package/lib/Dom/shadow.js +25 -0
  99. package/lib/Dom/styleChecker.d.ts +2 -0
  100. package/lib/Dom/styleChecker.js +33 -0
  101. package/lib/KeyCode.d.ts +436 -0
  102. package/lib/KeyCode.js +544 -0
  103. package/lib/Portal.d.ts +9 -0
  104. package/lib/Portal.js +51 -0
  105. package/lib/PortalWrapper.d.ts +51 -0
  106. package/lib/PortalWrapper.js +226 -0
  107. package/lib/React/isFragment.d.ts +4 -0
  108. package/lib/React/isFragment.js +24 -0
  109. package/lib/React/render.d.ts +13 -0
  110. package/lib/React/render.js +125 -0
  111. package/lib/composeProps.d.ts +2 -0
  112. package/lib/composeProps.js +30 -0
  113. package/lib/getScrollBarSize.d.ts +7 -0
  114. package/lib/getScrollBarSize.js +84 -0
  115. package/lib/hooks/useEffect.d.ts +2 -0
  116. package/lib/hooks/useEffect.js +22 -0
  117. package/lib/hooks/useEvent.d.ts +2 -0
  118. package/lib/hooks/useEvent.js +26 -0
  119. package/lib/hooks/useId.d.ts +4 -0
  120. package/lib/hooks/useId.js +78 -0
  121. package/lib/hooks/useLayoutEffect.d.ts +4 -0
  122. package/lib/hooks/useLayoutEffect.js +39 -0
  123. package/lib/hooks/useMemo.d.ts +1 -0
  124. package/lib/hooks/useMemo.js +18 -0
  125. package/lib/hooks/useMergedState.d.ts +12 -0
  126. package/lib/hooks/useMergedState.js +75 -0
  127. package/lib/hooks/useMobile.d.ts +6 -0
  128. package/lib/hooks/useMobile.js +31 -0
  129. package/lib/hooks/useState.d.ts +14 -0
  130. package/lib/hooks/useState.js +41 -0
  131. package/lib/hooks/useSyncState.d.ts +9 -0
  132. package/lib/hooks/useSyncState.js +39 -0
  133. package/lib/index.d.ts +6 -0
  134. package/lib/index.js +60 -0
  135. package/lib/isEqual.d.ts +9 -0
  136. package/lib/isEqual.js +61 -0
  137. package/lib/isMobile.d.ts +2 -0
  138. package/lib/isMobile.js +13 -0
  139. package/lib/omit.d.ts +1 -0
  140. package/lib/omit.js +15 -0
  141. package/lib/pickAttrs.d.ts +11 -0
  142. package/lib/pickAttrs.js +57 -0
  143. package/lib/proxyObject.d.ts +4 -0
  144. package/lib/proxyObject.js +25 -0
  145. package/lib/raf.d.ts +6 -0
  146. package/lib/raf.js +60 -0
  147. package/lib/ref.d.ts +19 -0
  148. package/lib/ref.js +96 -0
  149. package/lib/setStyle.d.ts +12 -0
  150. package/lib/setStyle.js +32 -0
  151. package/lib/test/domHook.d.ts +8 -0
  152. package/lib/test/domHook.js +71 -0
  153. package/lib/utils/get.d.ts +1 -0
  154. package/lib/utils/get.js +16 -0
  155. package/lib/utils/set.d.ts +6 -0
  156. package/lib/utils/set.js +101 -0
  157. package/lib/warning.d.ts +32 -0
  158. package/lib/warning.js +81 -0
  159. package/package.json +76 -0
@@ -0,0 +1,217 @@
1
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
2
+ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
3
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
4
+ function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
5
+ function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
6
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
7
+ function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
8
+ function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
9
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
10
+ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
11
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
12
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
13
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
14
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
15
+ /* eslint-disable no-underscore-dangle,react/require-default-props */
16
+ import * as React from 'react';
17
+ import raf from "./raf";
18
+ import Portal from "./Portal";
19
+ import canUseDom from "./Dom/canUseDom";
20
+ import setStyle from "./setStyle";
21
+ import ScrollLocker from "./Dom/scrollLocker";
22
+ var openCount = 0;
23
+ var supportDom = canUseDom();
24
+
25
+ /** @private Test usage only */
26
+ export function getOpenCount() {
27
+ return process.env.NODE_ENV === 'test' ? openCount : 0;
28
+ }
29
+
30
+ // https://github.com/ant-design/ant-design/issues/19340
31
+ // https://github.com/ant-design/ant-design/issues/19332
32
+ var cacheOverflow = {};
33
+ var getParent = function getParent(getContainer) {
34
+ if (!supportDom) {
35
+ return null;
36
+ }
37
+ if (getContainer) {
38
+ if (typeof getContainer === 'string') {
39
+ return document.querySelectorAll(getContainer)[0];
40
+ }
41
+ if (typeof getContainer === 'function') {
42
+ return getContainer();
43
+ }
44
+ if (_typeof(getContainer) === 'object' && getContainer instanceof window.HTMLElement) {
45
+ return getContainer;
46
+ }
47
+ }
48
+ return document.body;
49
+ };
50
+ var PortalWrapper = /*#__PURE__*/function (_React$Component) {
51
+ _inherits(PortalWrapper, _React$Component);
52
+ var _super = _createSuper(PortalWrapper);
53
+ function PortalWrapper(props) {
54
+ var _this;
55
+ _classCallCheck(this, PortalWrapper);
56
+ _this = _super.call(this, props);
57
+ _defineProperty(_assertThisInitialized(_this), "container", void 0);
58
+ _defineProperty(_assertThisInitialized(_this), "componentRef", /*#__PURE__*/React.createRef());
59
+ _defineProperty(_assertThisInitialized(_this), "rafId", void 0);
60
+ _defineProperty(_assertThisInitialized(_this), "scrollLocker", void 0);
61
+ _defineProperty(_assertThisInitialized(_this), "renderComponent", void 0);
62
+ _defineProperty(_assertThisInitialized(_this), "updateScrollLocker", function (prevProps) {
63
+ var _ref = prevProps || {},
64
+ prevVisible = _ref.visible;
65
+ var _this$props = _this.props,
66
+ getContainer = _this$props.getContainer,
67
+ visible = _this$props.visible;
68
+ if (visible && visible !== prevVisible && supportDom && getParent(getContainer) !== _this.scrollLocker.getContainer()) {
69
+ _this.scrollLocker.reLock({
70
+ container: getParent(getContainer)
71
+ });
72
+ }
73
+ });
74
+ _defineProperty(_assertThisInitialized(_this), "updateOpenCount", function (prevProps) {
75
+ var _ref2 = prevProps || {},
76
+ prevVisible = _ref2.visible,
77
+ prevGetContainer = _ref2.getContainer;
78
+ var _this$props2 = _this.props,
79
+ visible = _this$props2.visible,
80
+ getContainer = _this$props2.getContainer;
81
+
82
+ // Update count
83
+ if (visible !== prevVisible && supportDom && getParent(getContainer) === document.body) {
84
+ if (visible && !prevVisible) {
85
+ openCount += 1;
86
+ } else if (prevProps) {
87
+ openCount -= 1;
88
+ }
89
+ }
90
+
91
+ // Clean up container if needed
92
+ var getContainerIsFunc = typeof getContainer === 'function' && typeof prevGetContainer === 'function';
93
+ if (getContainerIsFunc ? getContainer.toString() !== prevGetContainer.toString() : getContainer !== prevGetContainer) {
94
+ _this.removeCurrentContainer();
95
+ }
96
+ });
97
+ _defineProperty(_assertThisInitialized(_this), "attachToParent", function () {
98
+ var force = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
99
+ if (force || _this.container && !_this.container.parentNode) {
100
+ var parent = getParent(_this.props.getContainer);
101
+ if (parent) {
102
+ parent.appendChild(_this.container);
103
+ return true;
104
+ }
105
+ return false;
106
+ }
107
+ return true;
108
+ });
109
+ _defineProperty(_assertThisInitialized(_this), "getContainer", function () {
110
+ if (!supportDom) {
111
+ return null;
112
+ }
113
+ if (!_this.container) {
114
+ _this.container = document.createElement('div');
115
+ _this.attachToParent(true);
116
+ }
117
+ _this.setWrapperClassName();
118
+ return _this.container;
119
+ });
120
+ _defineProperty(_assertThisInitialized(_this), "setWrapperClassName", function () {
121
+ var wrapperClassName = _this.props.wrapperClassName;
122
+ if (_this.container && wrapperClassName && wrapperClassName !== _this.container.className) {
123
+ _this.container.className = wrapperClassName;
124
+ }
125
+ });
126
+ _defineProperty(_assertThisInitialized(_this), "removeCurrentContainer", function () {
127
+ var _this$container;
128
+ // Portal will remove from `parentNode`.
129
+ // Let's handle this again to avoid refactor issue.
130
+ (_this$container = _this.container) === null || _this$container === void 0 || (_this$container = _this$container.parentNode) === null || _this$container === void 0 || _this$container.removeChild(_this.container);
131
+ });
132
+ /**
133
+ * Enhance ./switchScrollingEffect
134
+ * 1. Simulate document body scroll bar with
135
+ * 2. Record body has overflow style and recover when all of PortalWrapper invisible
136
+ * 3. Disable body scroll when PortalWrapper has open
137
+ *
138
+ * @memberof PortalWrapper
139
+ */
140
+ _defineProperty(_assertThisInitialized(_this), "switchScrollingEffect", function () {
141
+ if (openCount === 1 && !Object.keys(cacheOverflow).length) {
142
+ // Must be set after switchScrollingEffect
143
+ cacheOverflow = setStyle({
144
+ overflow: 'hidden',
145
+ overflowX: 'hidden',
146
+ overflowY: 'hidden'
147
+ });
148
+ } else if (!openCount) {
149
+ setStyle(cacheOverflow);
150
+ cacheOverflow = {};
151
+ }
152
+ });
153
+ _this.scrollLocker = new ScrollLocker({
154
+ container: getParent(props.getContainer)
155
+ });
156
+ return _this;
157
+ }
158
+ _createClass(PortalWrapper, [{
159
+ key: "componentDidMount",
160
+ value: function componentDidMount() {
161
+ var _this2 = this;
162
+ this.updateOpenCount();
163
+ if (!this.attachToParent()) {
164
+ this.rafId = raf(function () {
165
+ _this2.forceUpdate();
166
+ });
167
+ }
168
+ }
169
+ }, {
170
+ key: "componentDidUpdate",
171
+ value: function componentDidUpdate(prevProps) {
172
+ this.updateOpenCount(prevProps);
173
+ this.updateScrollLocker(prevProps);
174
+ this.setWrapperClassName();
175
+ this.attachToParent();
176
+ }
177
+ }, {
178
+ key: "componentWillUnmount",
179
+ value: function componentWillUnmount() {
180
+ var _this$props3 = this.props,
181
+ visible = _this$props3.visible,
182
+ getContainer = _this$props3.getContainer;
183
+ if (supportDom && getParent(getContainer) === document.body) {
184
+ // 离开时不会 render, 导到离开时数值不变,改用 func 。。
185
+ openCount = visible && openCount ? openCount - 1 : openCount;
186
+ }
187
+ this.removeCurrentContainer();
188
+ raf.cancel(this.rafId);
189
+ }
190
+ }, {
191
+ key: "render",
192
+ value: function render() {
193
+ var _this$props4 = this.props,
194
+ children = _this$props4.children,
195
+ forceRender = _this$props4.forceRender,
196
+ visible = _this$props4.visible;
197
+ var portal = null;
198
+ var childProps = {
199
+ getOpenCount: function getOpenCount() {
200
+ return openCount;
201
+ },
202
+ getContainer: this.getContainer,
203
+ switchScrollingEffect: this.switchScrollingEffect,
204
+ scrollLocker: this.scrollLocker
205
+ };
206
+ if (forceRender || visible || this.componentRef.current) {
207
+ portal = /*#__PURE__*/React.createElement(Portal, {
208
+ getContainer: this.getContainer,
209
+ ref: this.componentRef
210
+ }, children(childProps));
211
+ }
212
+ return portal;
213
+ }
214
+ }]);
215
+ return PortalWrapper;
216
+ }(React.Component);
217
+ export default PortalWrapper;
@@ -0,0 +1,4 @@
1
+ /**
2
+ * Compatible with React 18 or 19 to check if node is a Fragment.
3
+ */
4
+ export default function isFragment(object: any): boolean;
@@ -0,0 +1,18 @@
1
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ var REACT_ELEMENT_TYPE_18 = Symbol.for('react.element');
3
+ var REACT_ELEMENT_TYPE_19 = Symbol.for('react.transitional.element');
4
+ var REACT_FRAGMENT_TYPE = Symbol.for('react.fragment');
5
+
6
+ /**
7
+ * Compatible with React 18 or 19 to check if node is a Fragment.
8
+ */
9
+ export default function isFragment(object) {
10
+ return (
11
+ // Base object type
12
+ object && _typeof(object) === 'object' && (
13
+ // React Element type
14
+ object.$$typeof === REACT_ELEMENT_TYPE_18 || object.$$typeof === REACT_ELEMENT_TYPE_19) &&
15
+ // React Fragment type
16
+ object.type === REACT_FRAGMENT_TYPE
17
+ );
18
+ }
@@ -0,0 +1,13 @@
1
+ import type * as React from 'react';
2
+ import type { Root } from 'react-dom/client';
3
+ declare const MARK = "__rc_react_root__";
4
+ type ContainerType = (Element | DocumentFragment) & {
5
+ [MARK]?: Root;
6
+ };
7
+ /** @private Test usage. Not work in prod */
8
+ export declare function _r(node: React.ReactElement, container: ContainerType): void;
9
+ export declare function render(node: React.ReactElement, container: ContainerType): void;
10
+ /** @private Test usage. Not work in prod */
11
+ export declare function _u(container: ContainerType): void;
12
+ export declare function unmount(container: ContainerType): Promise<void>;
13
+ export {};
@@ -0,0 +1,114 @@
1
+ function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, catch: function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
2
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
3
+ function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
4
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
5
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
6
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
7
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
8
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
9
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
10
+ import * as ReactDOM from 'react-dom';
11
+ // Let compiler not to search module usage
12
+ var fullClone = _objectSpread({}, ReactDOM);
13
+ var version = fullClone.version,
14
+ reactRender = fullClone.render,
15
+ unmountComponentAtNode = fullClone.unmountComponentAtNode;
16
+ var createRoot;
17
+ try {
18
+ var mainVersion = Number((version || '').split('.')[0]);
19
+ if (mainVersion >= 18) {
20
+ createRoot = fullClone.createRoot;
21
+ }
22
+ } catch (e) {
23
+ // Do nothing;
24
+ }
25
+ function toggleWarning(skip) {
26
+ var __SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED = fullClone.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;
27
+ if (__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED && _typeof(__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED) === 'object') {
28
+ __SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.usingClientEntryPoint = skip;
29
+ }
30
+ }
31
+ var MARK = '__rc_react_root__';
32
+
33
+ // ========================== Render ==========================
34
+
35
+ function modernRender(node, container) {
36
+ toggleWarning(true);
37
+ var root = container[MARK] || createRoot(container);
38
+ toggleWarning(false);
39
+ root.render(node);
40
+ container[MARK] = root;
41
+ }
42
+ function legacyRender(node, container) {
43
+ reactRender === null || reactRender === void 0 || reactRender(node, container);
44
+ }
45
+
46
+ /** @private Test usage. Not work in prod */
47
+ export function _r(node, container) {
48
+ if (process.env.NODE_ENV !== 'production') {
49
+ return legacyRender(node, container);
50
+ }
51
+ }
52
+ export function render(node, container) {
53
+ if (createRoot) {
54
+ modernRender(node, container);
55
+ return;
56
+ }
57
+ legacyRender(node, container);
58
+ }
59
+
60
+ // ========================= Unmount ==========================
61
+ function modernUnmount(_x) {
62
+ return _modernUnmount.apply(this, arguments);
63
+ }
64
+ function _modernUnmount() {
65
+ _modernUnmount = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(container) {
66
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
67
+ while (1) switch (_context.prev = _context.next) {
68
+ case 0:
69
+ return _context.abrupt("return", Promise.resolve().then(function () {
70
+ var _container$MARK;
71
+ (_container$MARK = container[MARK]) === null || _container$MARK === void 0 || _container$MARK.unmount();
72
+ delete container[MARK];
73
+ }));
74
+ case 1:
75
+ case "end":
76
+ return _context.stop();
77
+ }
78
+ }, _callee);
79
+ }));
80
+ return _modernUnmount.apply(this, arguments);
81
+ }
82
+ function legacyUnmount(container) {
83
+ unmountComponentAtNode(container);
84
+ }
85
+
86
+ /** @private Test usage. Not work in prod */
87
+ export function _u(container) {
88
+ if (process.env.NODE_ENV !== 'production') {
89
+ return legacyUnmount(container);
90
+ }
91
+ }
92
+ export function unmount(_x2) {
93
+ return _unmount.apply(this, arguments);
94
+ }
95
+ function _unmount() {
96
+ _unmount = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(container) {
97
+ return _regeneratorRuntime().wrap(function _callee2$(_context2) {
98
+ while (1) switch (_context2.prev = _context2.next) {
99
+ case 0:
100
+ if (!(createRoot !== undefined)) {
101
+ _context2.next = 2;
102
+ break;
103
+ }
104
+ return _context2.abrupt("return", modernUnmount(container));
105
+ case 2:
106
+ legacyUnmount(container);
107
+ case 3:
108
+ case "end":
109
+ return _context2.stop();
110
+ }
111
+ }, _callee2);
112
+ }));
113
+ return _unmount.apply(this, arguments);
114
+ }
@@ -0,0 +1,2 @@
1
+ declare function composeProps<T extends Record<string, any>>(originProps: T, patchProps: Partial<T>, isAll?: boolean): T;
2
+ export default composeProps;
@@ -0,0 +1,24 @@
1
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
3
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
4
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
5
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
6
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
+ function composeProps(originProps, patchProps, isAll) {
8
+ var composedProps = _objectSpread(_objectSpread({}, originProps), isAll ? patchProps : {});
9
+ Object.keys(patchProps).forEach(function (key) {
10
+ var func = patchProps[key];
11
+ if (typeof func === 'function') {
12
+ composedProps[key] = function () {
13
+ var _originProps$key;
14
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
15
+ args[_key] = arguments[_key];
16
+ }
17
+ func.apply(void 0, args);
18
+ return (_originProps$key = originProps[key]) === null || _originProps$key === void 0 ? void 0 : _originProps$key.call.apply(_originProps$key, [originProps].concat(args));
19
+ };
20
+ }
21
+ });
22
+ return composedProps;
23
+ }
24
+ export default composeProps;
@@ -0,0 +1,7 @@
1
+ type ScrollBarSize = {
2
+ width: number;
3
+ height: number;
4
+ };
5
+ export default function getScrollBarSize(fresh?: boolean): number;
6
+ export declare function getTargetScrollBarSize(target: HTMLElement): ScrollBarSize;
7
+ export {};
@@ -0,0 +1,76 @@
1
+ /* eslint-disable no-param-reassign */
2
+ import { removeCSS, updateCSS } from "./Dom/dynamicCSS";
3
+ var cached;
4
+ function measureScrollbarSize(ele) {
5
+ var randomId = "rc-scrollbar-measure-".concat(Math.random().toString(36).substring(7));
6
+ var measureEle = document.createElement('div');
7
+ measureEle.id = randomId;
8
+
9
+ // Create Style
10
+ var measureStyle = measureEle.style;
11
+ measureStyle.position = 'absolute';
12
+ measureStyle.left = '0';
13
+ measureStyle.top = '0';
14
+ measureStyle.width = '100px';
15
+ measureStyle.height = '100px';
16
+ measureStyle.overflow = 'scroll';
17
+
18
+ // Clone Style if needed
19
+ var fallbackWidth;
20
+ var fallbackHeight;
21
+ if (ele) {
22
+ var targetStyle = getComputedStyle(ele);
23
+ measureStyle.scrollbarColor = targetStyle.scrollbarColor;
24
+ measureStyle.scrollbarWidth = targetStyle.scrollbarWidth;
25
+
26
+ // Set Webkit style
27
+ var webkitScrollbarStyle = getComputedStyle(ele, '::-webkit-scrollbar');
28
+ var width = parseInt(webkitScrollbarStyle.width, 10);
29
+ var height = parseInt(webkitScrollbarStyle.height, 10);
30
+
31
+ // Try wrap to handle CSP case
32
+ try {
33
+ var widthStyle = width ? "width: ".concat(webkitScrollbarStyle.width, ";") : '';
34
+ var heightStyle = height ? "height: ".concat(webkitScrollbarStyle.height, ";") : '';
35
+ updateCSS("\n#".concat(randomId, "::-webkit-scrollbar {\n").concat(widthStyle, "\n").concat(heightStyle, "\n}"), randomId);
36
+ } catch (e) {
37
+ // Can't wrap, just log error
38
+ console.error(e);
39
+
40
+ // Get from style directly
41
+ fallbackWidth = width;
42
+ fallbackHeight = height;
43
+ }
44
+ }
45
+ document.body.appendChild(measureEle);
46
+
47
+ // Measure. Get fallback style if provided
48
+ var scrollWidth = ele && fallbackWidth && !isNaN(fallbackWidth) ? fallbackWidth : measureEle.offsetWidth - measureEle.clientWidth;
49
+ var scrollHeight = ele && fallbackHeight && !isNaN(fallbackHeight) ? fallbackHeight : measureEle.offsetHeight - measureEle.clientHeight;
50
+
51
+ // Clean up
52
+ document.body.removeChild(measureEle);
53
+ removeCSS(randomId);
54
+ return {
55
+ width: scrollWidth,
56
+ height: scrollHeight
57
+ };
58
+ }
59
+ export default function getScrollBarSize(fresh) {
60
+ if (typeof document === 'undefined') {
61
+ return 0;
62
+ }
63
+ if (fresh || cached === undefined) {
64
+ cached = measureScrollbarSize();
65
+ }
66
+ return cached.width;
67
+ }
68
+ export function getTargetScrollBarSize(target) {
69
+ if (typeof document === 'undefined' || !target || !(target instanceof Element)) {
70
+ return {
71
+ width: 0,
72
+ height: 0
73
+ };
74
+ }
75
+ return measureScrollbarSize(target);
76
+ }
@@ -0,0 +1,2 @@
1
+ /** As `React.useEffect` but pass origin value in callback and not need care deps length change. */
2
+ export default function useEffect(callback: (prevDeps: any[]) => void, deps: any[]): void;
@@ -0,0 +1,14 @@
1
+ import * as React from 'react';
2
+
3
+ /** As `React.useEffect` but pass origin value in callback and not need care deps length change. */
4
+ export default function useEffect(callback, deps) {
5
+ var prevRef = React.useRef(deps);
6
+ React.useEffect(function () {
7
+ if (deps.length !== prevRef.current.length || deps.some(function (dep, index) {
8
+ return dep !== prevRef.current[index];
9
+ })) {
10
+ callback(prevRef.current);
11
+ }
12
+ prevRef.current = deps;
13
+ });
14
+ }
@@ -0,0 +1,2 @@
1
+ declare function useEvent<T extends Function>(callback: T): T;
2
+ export default useEvent;
@@ -0,0 +1,16 @@
1
+ /* eslint-disable @typescript-eslint/ban-types */
2
+ /* eslint-disable react-hooks/exhaustive-deps */
3
+ import * as React from 'react';
4
+ function useEvent(callback) {
5
+ var fnRef = React.useRef();
6
+ fnRef.current = callback;
7
+ var memoFn = React.useCallback(function () {
8
+ var _fnRef$current;
9
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
10
+ args[_key] = arguments[_key];
11
+ }
12
+ return (_fnRef$current = fnRef.current) === null || _fnRef$current === void 0 ? void 0 : _fnRef$current.call.apply(_fnRef$current, [fnRef].concat(args));
13
+ }, []);
14
+ return memoFn;
15
+ }
16
+ export default useEvent;
@@ -0,0 +1,4 @@
1
+ /** @private Note only worked in develop env. Not work in production. */
2
+ export declare function resetUuid(): void;
3
+ declare const _default: (id?: string) => string;
4
+ export default _default;
@@ -0,0 +1,69 @@
1
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
3
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
4
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
5
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
6
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
7
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
8
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
9
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
10
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
11
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
12
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
13
+ import * as React from 'react';
14
+ function getUseId() {
15
+ // We need fully clone React function here to avoid webpack warning React 17 do not export `useId`
16
+ var fullClone = _objectSpread({}, React);
17
+ return fullClone.useId;
18
+ }
19
+ var uuid = 0;
20
+
21
+ /** @private Note only worked in develop env. Not work in production. */
22
+ export function resetUuid() {
23
+ if (process.env.NODE_ENV !== 'production') {
24
+ uuid = 0;
25
+ }
26
+ }
27
+ var useOriginId = getUseId();
28
+ export default useOriginId ?
29
+ // Use React `useId`
30
+ function useId(id) {
31
+ var reactId = useOriginId();
32
+
33
+ // Developer passed id is single source of truth
34
+ if (id) {
35
+ return id;
36
+ }
37
+
38
+ // Test env always return mock id
39
+ if (process.env.NODE_ENV === 'test') {
40
+ return 'test-id';
41
+ }
42
+ return reactId;
43
+ } :
44
+ // Use compatible of `useId`
45
+ function useCompatId(id) {
46
+ // Inner id for accessibility usage. Only work in client side
47
+ var _React$useState = React.useState('ssr-id'),
48
+ _React$useState2 = _slicedToArray(_React$useState, 2),
49
+ innerId = _React$useState2[0],
50
+ setInnerId = _React$useState2[1];
51
+ React.useEffect(function () {
52
+ var nextId = uuid;
53
+ uuid += 1;
54
+ setInnerId("rc_unique_".concat(nextId));
55
+ }, []);
56
+
57
+ // Developer passed id is single source of truth
58
+ if (id) {
59
+ return id;
60
+ }
61
+
62
+ // Test env always return mock id
63
+ if (process.env.NODE_ENV === 'test') {
64
+ return 'test-id';
65
+ }
66
+
67
+ // Return react native id or inner id
68
+ return innerId;
69
+ };
@@ -0,0 +1,4 @@
1
+ import * as React from 'react';
2
+ declare const useLayoutEffect: (callback: (mount: boolean) => void | VoidFunction, deps?: React.DependencyList) => void;
3
+ export declare const useLayoutUpdateEffect: typeof React.useEffect;
4
+ export default useLayoutEffect;