UNPKG

1.14 kBJavaScriptView Raw
1import { useRef } from 'react';
2
3function isEqual(a, b) {
4 if (a.length !== b.length) return false;
5
6 for (var i = 0; i < a.length; i++) {
7 if (a[i] !== b[i]) {
8 return false;
9 }
10 }
11
12 return true;
13}
14
15/**
16 * Identical to `useMemo` _except_ that it provides a semantic guarantee that
17 * values will not be invalidated unless the dependencies change. This is unlike
18 * the built in `useMemo` which may discard memoized values for performance reasons.
19 *
20 * @param factory A function that returns a value to be memoized
21 * @param deps A dependency array
22 */
23export default function useStableMemo(factory, deps) {
24 var isValid = true;
25 var valueRef = useRef(); // initial hook call
26
27 if (!valueRef.current) {
28 valueRef.current = {
29 deps: deps,
30 result: factory()
31 }; // subsequent calls
32 } else {
33 isValid = !!(deps && valueRef.current.deps && isEqual(deps, valueRef.current.deps));
34 }
35
36 var cache = isValid ? valueRef.current : {
37 deps: deps,
38 result: factory()
39 }; // must update immediately so any sync renders here don't cause an infinite loop
40
41 valueRef.current = cache;
42 return cache.result;
43}
\No newline at end of file