From db77962a7275792410210cd8bbdaa638faae4192 Mon Sep 17 00:00:00 2001 From: Fredrik Strand Oseberg Date: Wed, 15 Nov 2023 11:09:13 +0100 Subject: [PATCH] fix/usefeaturesearch cache (#5340) Fixes a bug where the closure over the useFeatureSearch hook would not account for projectId and return the wrong total/initial load --- .../useFeatureSearch/useFeatureSearch.ts | 51 ++++++++++++++++--- 1 file changed, 43 insertions(+), 8 deletions(-) diff --git a/frontend/src/hooks/api/getters/useFeatureSearch/useFeatureSearch.ts b/frontend/src/hooks/api/getters/useFeatureSearch/useFeatureSearch.ts index e22a702145..022439126d 100644 --- a/frontend/src/hooks/api/getters/useFeatureSearch/useFeatureSearch.ts +++ b/frontend/src/hooks/api/getters/useFeatureSearch/useFeatureSearch.ts @@ -1,5 +1,5 @@ import useSWR, { SWRConfiguration } from 'swr'; -import { useCallback } from 'react'; +import { useCallback, useEffect } from 'react'; import { IFeatureToggleListItem } from 'interfaces/featureToggle'; import { formatApiPath } from 'utils/formatPath'; import handleErrorResponses from '../httpErrorResponseHandler'; @@ -19,6 +19,14 @@ interface IUseFeatureSearchOutput { refetch: () => void; } +type CacheValue = { + total: number; + initialLoad: boolean; + [key: string]: number | boolean; +}; + +type InternalCache = Record; + const fallbackData: { features: IFeatureToggleListItem[]; total: number; @@ -28,8 +36,28 @@ const fallbackData: { }; const createFeatureSearch = () => { - let total = 0; - let initialLoad = true; + const internalCache: InternalCache = {}; + + const initCache = (projectId: string) => { + internalCache[projectId] = { + total: 0, + initialLoad: true, + }; + }; + + const set = (projectId: string, key: string, value: number | boolean) => { + if (!internalCache[projectId]) { + initCache(projectId); + } + internalCache[projectId][key] = value; + }; + + const get = (projectId: string) => { + if (!internalCache[projectId]) { + initCache(projectId); + } + return internalCache[projectId]; + }; return ( offset: number, @@ -44,6 +72,11 @@ const createFeatureSearch = () => { limit, searchValue, ); + + useEffect(() => { + initCache(projectId); + }, []); + const { data, error, mutate, isLoading } = useSWR(KEY, fetcher, options); @@ -51,12 +84,14 @@ const createFeatureSearch = () => { mutate(); }, [mutate]); + const cacheValues = get(projectId); + if (data?.total) { - total = data.total; + set(projectId, 'total', data.total); } - if (!isLoading && initialLoad) { - initialLoad = false; + if (!isLoading && cacheValues.initialLoad) { + set(projectId, 'initialLoad', false); } const returnData = data || fallbackData; @@ -65,8 +100,8 @@ const createFeatureSearch = () => { loading: isLoading, error, refetch, - total, - initialLoad: isLoading && initialLoad, + total: cacheValues.total, + initialLoad: isLoading && cacheValues.initialLoad, }; }; };