UNPKG

ahooks

Version:
23 lines 989 B
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 (_, 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 (_, idx) { return idx; }) : []; }; var useTrackedEffect = function (effect, deps) { var previousDepsRef = useRef(undefined); useEffect(function () { var changes = diffTwoDeps(previousDepsRef.current, deps); var previousDeps = previousDepsRef.current; previousDepsRef.current = deps; return effect(changes, previousDeps, deps); }, deps); }; export default useTrackedEffect;