anvil/striker-ui/hooks/useFetch.tsx

47 lines
1011 B
TypeScript
Raw Normal View History

import { useMemo } from 'react';
import useSWR, { BareFetcher, KeyedMutator, SWRConfiguration } from 'swr';
2023-09-19 22:41:38 +00:00
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;
mutate: KeyedMutator<D>;
2023-09-19 22:41:38 +00:00
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, mutate } = useSWR<Data>(
`${baseUrl}${url}`,
fetcher,
config,
);
2023-09-19 22:41:38 +00:00
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, mutate, loading };
2023-09-19 22:41:38 +00:00
};
export default useFetch;