summaryrefslogtreecommitdiff
path: root/shared/components/src/utils/memoize.ts
blob: a5e07efc2cb9d267eba9c45bf66bdc075467d2fe (plain)
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
// eslint-disable-next-line import/prefer-default-export
export function memoize<T extends unknown[], S>(
    fn: (...args: T) => S,
    hashFn: (...args: unknown[]) => string = JSON.stringify,
    entryLimit = 5,
): (...args: T) => S {
    const cache: Map<string, S> = new Map();

    return (...args: T) => {
        const value = hashFn(args);
        if (cache.has(value)) {
            return cache.get(value);
        }

        const returnedValue: S = fn.apply(this, args);

        if (cache.size >= entryLimit) {
            const iterator = cache.keys();
            const firstValue = iterator.next().value;
            // remove oldest value
            cache.delete(firstValue);
        }
        cache.set(value, returnedValue);
        return returnedValue;
    };
}