From c3a761d2911d1290c259810ff74bc7f014c3062d Mon Sep 17 00:00:00 2001 From: Lenz Weber-Tronic Date: Wed, 13 Sep 2023 15:41:47 +0200 Subject: [PATCH] better typing --- src/react/hooks/useSuspenseQuery.ts | 40 +++++++++++++++++------------ 1 file changed, 24 insertions(+), 16 deletions(-) diff --git a/src/react/hooks/useSuspenseQuery.ts b/src/react/hooks/useSuspenseQuery.ts index dadd8bfc901..80c314fd93c 100644 --- a/src/react/hooks/useSuspenseQuery.ts +++ b/src/react/hooks/useSuspenseQuery.ts @@ -26,6 +26,7 @@ import { canonicalStringify } from "../../cache/index.js"; import { skipToken } from "./constants.js"; import type { SkipToken } from "./constants.js"; import type { CacheKey } from "../cache/types.js"; +import { Operation } from "subscriptions-transport-ws"; export interface UseSuspenseQueryResult< TData = unknown, @@ -41,7 +42,10 @@ export interface UseSuspenseQueryResult< } export type FetchMoreFunction = ( - fetchMoreOptions: FetchMoreQueryOptions & { + fetchMoreOptions: Omit< + FetchMoreQueryOptions, + "updateQuery" + > & { updateQuery?: ( previousQueryResult: TData, options: { @@ -178,7 +182,11 @@ export function useSuspenseQuery< ): UseSuspenseQueryResult { const client = useApolloClient(options.client); const suspenseCache = getSuspenseCache(client); - const watchQueryOptions = useWatchQueryOptions({ client, query, options }); + const watchQueryOptions = useWatchQueryOptions({ + client, + query, + options, + }); const { fetchPolicy, variables } = watchQueryOptions; const { queryKey = [] } = options; @@ -189,7 +197,7 @@ export function useSuspenseQuery< ]; const queryRef = suspenseCache.getQueryRef(cacheKey, () => - client.watchQuery(watchQueryOptions as WatchQueryOptions) + client.watchQuery(watchQueryOptions) ); const [promiseCache, setPromiseCache] = React.useState( @@ -236,21 +244,21 @@ export function useSuspenseQuery< const result = fetchPolicy === "standby" ? skipResult : __use(promise); - const fetchMore: FetchMoreFunction = - React.useCallback( - (options) => { - const promise = queryRef.fetchMore( - options as WatchQueryOptions - ); + const fetchMore = React.useCallback( + ((options) => { + const promise = queryRef.fetchMore(options); - setPromiseCache((previousPromiseCache) => - new Map(previousPromiseCache).set(queryRef.key, queryRef.promise) - ); + setPromiseCache((previousPromiseCache) => + new Map(previousPromiseCache).set(queryRef.key, queryRef.promise) + ); - return promise; - }, - [queryRef] - ); + return promise; + }) satisfies FetchMoreFunction< + unknown, + OperationVariables + > as FetchMoreFunction, + [queryRef] + ); const refetch: RefetchFunction = React.useCallback( (variables) => {