1 | import _typeof from "@babel/runtime/helpers/esm/typeof";
|
2 | import { isValidElement, version } from 'react';
|
3 | import { ForwardRef, isFragment, isMemo } from 'react-is';
|
4 | import useMemo from "./hooks/useMemo";
|
5 | export var fillRef = function fillRef(ref, node) {
|
6 | if (typeof ref === 'function') {
|
7 | ref(node);
|
8 | } else if (_typeof(ref) === 'object' && ref && 'current' in ref) {
|
9 | ref.current = node;
|
10 | }
|
11 | };
|
12 |
|
13 |
|
14 |
|
15 |
|
16 | export var composeRef = function composeRef() {
|
17 | for (var _len = arguments.length, refs = new Array(_len), _key = 0; _key < _len; _key++) {
|
18 | refs[_key] = arguments[_key];
|
19 | }
|
20 | var refList = refs.filter(Boolean);
|
21 | if (refList.length <= 1) {
|
22 | return refList[0];
|
23 | }
|
24 | return function (node) {
|
25 | refs.forEach(function (ref) {
|
26 | fillRef(ref, node);
|
27 | });
|
28 | };
|
29 | };
|
30 | export var useComposeRef = function useComposeRef() {
|
31 | for (var _len2 = arguments.length, refs = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
|
32 | refs[_key2] = arguments[_key2];
|
33 | }
|
34 | return useMemo(function () {
|
35 | return composeRef.apply(void 0, refs);
|
36 | }, refs, function (prev, next) {
|
37 | return prev.length !== next.length || prev.every(function (ref, i) {
|
38 | return ref !== next[i];
|
39 | });
|
40 | });
|
41 | };
|
42 | export var supportRef = function supportRef(nodeOrComponent) {
|
43 | var _type$prototype, _nodeOrComponent$prot;
|
44 | var type = isMemo(nodeOrComponent) ? nodeOrComponent.type.type : nodeOrComponent.type;
|
45 |
|
46 |
|
47 | if (typeof type === 'function' && !((_type$prototype = type.prototype) !== null && _type$prototype !== void 0 && _type$prototype.render) && type.$$typeof !== ForwardRef) {
|
48 | return false;
|
49 | }
|
50 |
|
51 |
|
52 | if (typeof nodeOrComponent === 'function' && !((_nodeOrComponent$prot = nodeOrComponent.prototype) !== null && _nodeOrComponent$prot !== void 0 && _nodeOrComponent$prot.render) && nodeOrComponent.$$typeof !== ForwardRef) {
|
53 | return false;
|
54 | }
|
55 | return true;
|
56 | };
|
57 | function isReactElement(node) {
|
58 | return isValidElement(node) && !isFragment(node);
|
59 | }
|
60 | export var supportNodeRef = function supportNodeRef(node) {
|
61 | return isReactElement(node) && supportRef(node);
|
62 | };
|
63 |
|
64 |
|
65 |
|
66 |
|
67 |
|
68 |
|
69 | export var getNodeRef = Number(version.split('.')[0]) >= 19 ?
|
70 |
|
71 | function (node) {
|
72 | if (isReactElement(node)) {
|
73 | return node.props.ref;
|
74 | }
|
75 | return null;
|
76 | } :
|
77 |
|
78 | function (node) {
|
79 | if (isReactElement(node)) {
|
80 | return node.ref;
|
81 | }
|
82 | return null;
|
83 | }; |
\ | No newline at end of file |