Files
twenty/packages/twenty-front/src/hooks/useCombinedRefs.ts
2023-12-10 18:10:54 +01:00

15 lines
418 B
TypeScript

import React, { Ref, RefCallback } from 'react';
import { isFunction } from '@sniptt/guards';
export const useCombinedRefs =
<T>(...refs: (Ref<T> | undefined)[]): RefCallback<T> =>
(node: T) => {
for (const ref of refs) {
if (isFunction(ref)) {
ref(node);
} else if (ref !== null && ref !== undefined) {
(ref as React.MutableRefObject<T | null>).current = node;
}
}
};