2020-07-03 22:32:39 +01:00
|
|
|
import usePrevious from './usePrevious';
|
|
|
|
import { useEffect } from 'react';
|
|
|
|
|
2020-11-12 19:13:28 +00:00
|
|
|
export default function useEffectDebugger(effectHook: any, dependencies: any, dependencyNames: any[] = []) {
|
2020-07-03 22:32:39 +01:00
|
|
|
const previousDeps = usePrevious(dependencies, []);
|
|
|
|
|
2020-11-12 19:13:28 +00:00
|
|
|
const changedDeps = dependencies.reduce((accum: any, dependency: any, index: any) => {
|
2020-07-03 22:32:39 +01:00
|
|
|
if (dependency !== previousDeps[index]) {
|
|
|
|
const keyName = dependencyNames[index] || index;
|
|
|
|
return {
|
|
|
|
...accum,
|
|
|
|
[keyName]: {
|
|
|
|
before: previousDeps[index],
|
|
|
|
after: dependency,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
return accum;
|
|
|
|
}, {});
|
|
|
|
|
|
|
|
if (Object.keys(changedDeps).length) {
|
|
|
|
console.log('[use-effet-debugger] ', changedDeps);
|
|
|
|
}
|
|
|
|
|
2022-08-19 12:10:04 +01:00
|
|
|
// eslint-disable-next-line @seiyab/react-hooks/exhaustive-deps -- Old code before rule was applied
|
2020-07-03 22:32:39 +01:00
|
|
|
useEffect(effectHook, dependencies);
|
|
|
|
}
|