mirror of
https://github.com/infiniflow/ragflow.git
synced 2025-12-08 20:42:30 +08:00
### What problem does this PR solve? Feat: Add FileUploadDialog #3221 ### Type of change - [x] New Feature (non-breaking change which adds functionality)
28 lines
724 B
TypeScript
28 lines
724 B
TypeScript
import * as React from 'react';
|
|
|
|
/**
|
|
* @see https://github.com/radix-ui/primitives/blob/main/packages/react/use-callback-ref/src/useCallbackRef.tsx
|
|
*/
|
|
|
|
/**
|
|
* A custom hook that converts a callback to a ref to avoid triggering re-renders when passed as a
|
|
* prop or avoid re-executing effects when passed as a dependency
|
|
*/
|
|
function useCallbackRef<T extends (...args: never[]) => unknown>(
|
|
callback: T | undefined,
|
|
): T {
|
|
const callbackRef = React.useRef(callback);
|
|
|
|
React.useEffect(() => {
|
|
callbackRef.current = callback;
|
|
});
|
|
|
|
// https://github.com/facebook/react/issues/19240
|
|
return React.useMemo(
|
|
() => ((...args) => callbackRef.current?.(...args)) as T,
|
|
[],
|
|
);
|
|
}
|
|
|
|
export { useCallbackRef };
|