28 lines
1004 B
JavaScript
28 lines
1004 B
JavaScript
var $92muK$react = require("react");
|
|
|
|
function $parcel$export(e, n, v, s) {
|
|
Object.defineProperty(e, n, {get: v, set: s, enumerable: true, configurable: true});
|
|
}
|
|
|
|
$parcel$export(module.exports, "useCallbackRef", () => $28e03942f763e819$export$25bec8c6f54ee79a);
|
|
|
|
/**
|
|
* 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 $28e03942f763e819$export$25bec8c6f54ee79a(callback) {
|
|
const callbackRef = $92muK$react.useRef(callback);
|
|
$92muK$react.useEffect(()=>{
|
|
callbackRef.current = callback;
|
|
}); // https://github.com/facebook/react/issues/19240
|
|
return $92muK$react.useMemo(()=>(...args)=>{
|
|
var _callbackRef$current;
|
|
return (_callbackRef$current = callbackRef.current) === null || _callbackRef$current === void 0 ? void 0 : _callbackRef$current.call(callbackRef, ...args);
|
|
}
|
|
, []);
|
|
}
|
|
|
|
|
|
|
|
|
|
//# sourceMappingURL=index.js.map
|