anvil/striker-ui/hooks/useFetch.tsx

42 lines
937 B
TypeScript
Raw Normal View History

import { useMemo } from 'react';
2023-09-19 22:41:38 +00:00
import useSWR, { BareFetcher, SWRConfiguration } from 'swr';
import API_BASE_URL from '../lib/consts/API_BASE_URL';
import fetchJSON from '../lib/fetchers/fetchJSON';
type FetchHookResponse<D, E extends Error = Error> = {
data?: D;
error?: E;
loading: boolean;
};
const useFetch = <Data, Alt = Data>(
2023-09-19 22:41:38 +00:00
url: string,
options: SWRConfiguration<Data> & {
baseUrl?: string;
fetcher?: BareFetcher<Data>;
mod?: (data: Data) => Alt;
2023-09-19 22:41:38 +00:00
} = {},
): FetchHookResponse<Data> & { altData?: Alt } => {
const {
baseUrl = API_BASE_URL,
fetcher = fetchJSON,
mod,
...config
} = options;
2023-09-19 22:41:38 +00:00
const { data, error } = useSWR<Data>(`${baseUrl}${url}`, fetcher, config);
const altData = useMemo<Alt | undefined>(
() => mod && data && mod(data),
[data, mod],
);
2023-09-19 22:41:38 +00:00
const loading = !error && !data;
return { altData, data, error, loading };
2023-09-19 22:41:38 +00:00
};
export default useFetch;