ahooks
Version:
react hooks library
23 lines • 983 B
JavaScript
import { useEffect, useRef } from 'react';
var diffTwoDeps = function (deps1, deps2) {
//Let's do a reference equality check on 2 dependency list.
//If deps1 is defined, we iterate over deps1 and do comparison on each element with equivalent element from deps2
//As this func is used only in this hook, we assume 2 deps always have same length.
return deps1 ? deps1.map(function (_ele, idx) {
return !Object.is(deps1[idx], deps2 === null || deps2 === void 0 ? void 0 : deps2[idx]) ? idx : -1;
}).filter(function (ele) {
return ele >= 0;
}) : deps2 ? deps2.map(function (_ele, idx) {
return idx;
}) : [];
};
var useTrackedEffect = function (effect, deps) {
var previousDepsRef = useRef();
useEffect(function () {
var changes = diffTwoDeps(previousDepsRef.current, deps);
var previousDeps = previousDepsRef.current;
previousDepsRef.current = deps;
return effect(changes, previousDeps, deps);
}, deps);
};
export default useTrackedEffect;