-
Notifications
You must be signed in to change notification settings - Fork 105
Expand file tree
/
Copy pathindex.ts
More file actions
26 lines (23 loc) · 842 Bytes
/
index.ts
File metadata and controls
26 lines (23 loc) · 842 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
import type {DependencyList} from 'react';
import {useMemo, useRef} from 'react';
import type {DependenciesComparator} from '../types.js';
/**
* Like useMemo but uses provided comparator function to validate dependency changes.
*
* @param factory useMemo factory function
* @param deps useMemo dependency list
* @param comparator function to validate dependency changes
* @returns useMemo result
*/
export const useCustomCompareMemo = <T, Deps extends DependencyList>(
factory: () => T,
deps: Deps,
comparator: DependenciesComparator<Deps>,
): T => {
const dependencies = useRef<Deps>(undefined);
if (dependencies.current === undefined || !comparator(dependencies.current, deps)) {
dependencies.current = deps;
}
// eslint-disable-next-line react-hooks/exhaustive-deps
return useMemo<T>(factory, dependencies.current);
};