20 lines
512 B
JavaScript
20 lines
512 B
JavaScript
|
'use client';
|
||
|
|
||
|
import * as React from 'react';
|
||
|
import useEnhancedEffect from '../useEnhancedEffect';
|
||
|
|
||
|
/**
|
||
|
* Inspired by https://github.com/facebook/react/issues/14099#issuecomment-440013892
|
||
|
* See RFC in https://github.com/reactjs/rfcs/pull/220
|
||
|
*/
|
||
|
|
||
|
function useEventCallback(fn) {
|
||
|
const ref = React.useRef(fn);
|
||
|
useEnhancedEffect(() => {
|
||
|
ref.current = fn;
|
||
|
});
|
||
|
return React.useRef((...args) =>
|
||
|
// @ts-expect-error hide `this`
|
||
|
(0, ref.current)(...args)).current;
|
||
|
}
|
||
|
export default useEventCallback;
|