UNPKG

ahooks

Version:
23 lines 983 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 (_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;