UNPKG

2.63 kBJavaScriptView Raw
1import _typeof from "@babel/runtime/helpers/esm/typeof";
2import { isValidElement, version } from 'react';
3import { ForwardRef, isFragment, isMemo } from 'react-is';
4import useMemo from "./hooks/useMemo";
5export 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 * Merge refs into one ref function to support ref passing.
15 */
16export 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};
30export 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};
42export var supportRef = function supportRef(nodeOrComponent) {
43 var _type$prototype, _nodeOrComponent$prot;
44 var type = isMemo(nodeOrComponent) ? nodeOrComponent.type.type : nodeOrComponent.type;
45
46 // Function component node
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 // Class component
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};
57function isReactElement(node) {
58 return /*#__PURE__*/isValidElement(node) && !isFragment(node);
59}
60export var supportNodeRef = function supportNodeRef(node) {
61 return isReactElement(node) && supportRef(node);
62};
63
64/**
65 * In React 19. `ref` is not a property from node.
66 * But a property from `props.ref`.
67 * To check if `props.ref` exist or fallback to `ref`.
68 */
69export var getNodeRef = Number(version.split('.')[0]) >= 19 ?
70// >= React 19
71function (node) {
72 if (isReactElement(node)) {
73 return node.props.ref;
74 }
75 return null;
76} :
77// < React 19
78function (node) {
79 if (isReactElement(node)) {
80 return node.ref;
81 }
82 return null;
83};
\No newline at end of file