From b4f9806516a83bfcb073d80bfbf1a43f08a7ba75 Mon Sep 17 00:00:00 2001 From: Aaron Cook Date: Mon, 14 Oct 2024 08:50:45 +0200 Subject: [PATCH] refactor: simplify RTK Query `endpoints` (#4360) --- src/store/gateway.ts | 48 +++++++++++++++----------------------------- 1 file changed, 16 insertions(+), 32 deletions(-) diff --git a/src/store/gateway.ts b/src/store/gateway.ts index 3b027245b9..acbfa95c8e 100644 --- a/src/store/gateway.ts +++ b/src/store/gateway.ts @@ -1,51 +1,35 @@ -import { createApi } from '@reduxjs/toolkit/query/react' +import { createApi, fakeBaseQuery } from '@reduxjs/toolkit/query/react' import { getTransactionDetails, type TransactionDetails } from '@safe-global/safe-gateway-typescript-sdk' -import type { BaseQueryFn } from '@reduxjs/toolkit/dist/query/baseQueryTypes' -import type { FetchBaseQueryError } from '@reduxjs/toolkit/dist/query/react' +import { asError } from '@/services/exceptions/utils' import { getDelegates } from '@safe-global/safe-gateway-typescript-sdk' import type { DelegateResponse } from '@safe-global/safe-gateway-typescript-sdk/dist/types/delegates' -const noopBaseQuery: BaseQueryFn< - unknown, // QueryArg type - unknown, // ResultType - FetchBaseQueryError, // ErrorType - {}, // DefinitionExtraOptions - {} // Meta -> = async () => ({ data: null }) +async function buildQueryFn(fn: () => Promise) { + try { + return { data: await fn() } + } catch (error) { + return { error: asError(error) } + } +} export const gatewayApi = createApi({ reducerPath: 'gatewayApi', - baseQuery: noopBaseQuery, + baseQuery: fakeBaseQuery(), endpoints: (builder) => ({ getTransactionDetails: builder.query({ - async queryFn({ chainId, txId }) { - try { - const txDetails = await getTransactionDetails(chainId, txId) - return { data: txDetails } - } catch (error) { - return { error: error as FetchBaseQueryError } - } + queryFn({ chainId, txId }) { + return buildQueryFn(() => getTransactionDetails(chainId, txId)) }, }), getMultipleTransactionDetails: builder.query({ - async queryFn({ chainId, txIds }) { - try { - const txDetails = await Promise.all(txIds.map((txId) => getTransactionDetails(chainId, txId))) - return { data: txDetails } - } catch (error) { - return { error: error as FetchBaseQueryError } - } + queryFn({ chainId, txIds }) { + return buildQueryFn(() => Promise.all(txIds.map((txId) => getTransactionDetails(chainId, txId)))) }, }), getDelegates: builder.query({ - async queryFn({ chainId, safeAddress }) { - try { - const delegates = await getDelegates(chainId, { safe: safeAddress }) - return { data: delegates } - } catch (error) { - return { error: error as FetchBaseQueryError } - } + queryFn({ chainId, safeAddress }) { + return buildQueryFn(() => getDelegates(chainId, { safe: safeAddress })) }, }), }),