From 53988e2581d5983dcaff8ffbe0fa7837d3da8e0c Mon Sep 17 00:00:00 2001 From: Chewbacca Date: Fri, 2 Jun 2023 10:28:10 -0400 Subject: [PATCH] Prevent lookup if not enabled --- app/soapbox/api/hooks/groups/useGroupLookup.ts | 2 +- app/soapbox/entity-store/hooks/useEntityLookup.ts | 5 ++++- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/app/soapbox/api/hooks/groups/useGroupLookup.ts b/app/soapbox/api/hooks/groups/useGroupLookup.ts index 6e41975e5..a9cb2b369 100644 --- a/app/soapbox/api/hooks/groups/useGroupLookup.ts +++ b/app/soapbox/api/hooks/groups/useGroupLookup.ts @@ -12,7 +12,7 @@ function useGroupLookup(slug: string) { Entities.GROUPS, (group) => group.slug === slug, () => api.get(`/api/v1/groups/lookup?name=${slug}`), - { schema: groupSchema }, + { schema: groupSchema, enabled: !!slug }, ); const { entity: relationship } = useGroupRelationship(group?.id); diff --git a/app/soapbox/entity-store/hooks/useEntityLookup.ts b/app/soapbox/entity-store/hooks/useEntityLookup.ts index a49a659a4..73b2ef938 100644 --- a/app/soapbox/entity-store/hooks/useEntityLookup.ts +++ b/app/soapbox/entity-store/hooks/useEntityLookup.ts @@ -25,6 +25,7 @@ function useEntityLookup( const [isFetching, setPromise] = useLoading(true); const entity = useAppSelector(state => findEntity(state, entityType, lookupFn)); + const isEnabled = opts.enabled ?? true; const isLoading = isFetching && !entity; const fetchEntity = async () => { @@ -38,10 +39,12 @@ function useEntityLookup( }; useEffect(() => { + if (!isEnabled) return; + if (!entity || opts.refetch) { fetchEntity(); } - }, []); + }, [isEnabled]); return { entity,