2024-01-23 00:08:38 +00:00
|
|
|
import { useMemo } from 'react';
|
2024-02-06 23:18:10 +00:00
|
|
|
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;
|
2024-02-06 23:18:10 +00:00
|
|
|
mutate: KeyedMutator<D>;
|
2023-09-19 22:41:38 +00:00
|
|
|
loading: boolean;
|
|
|
|
};
|
|
|
|
|
2024-01-23 00:08:38 +00:00
|
|
|
const useFetch = <Data, Alt = Data>(
|
2023-09-19 22:41:38 +00:00
|
|
|
url: string,
|
|
|
|
options: SWRConfiguration<Data> & {
|
|
|
|
baseUrl?: string;
|
2024-01-23 00:08:38 +00:00
|
|
|
fetcher?: BareFetcher<Data>;
|
|
|
|
mod?: (data: Data) => Alt;
|
2023-09-19 22:41:38 +00:00
|
|
|
} = {},
|
2024-01-23 00:08: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
|
|
|
|
2024-02-06 23:18:10 +00:00
|
|
|
const { data, error, mutate } = useSWR<Data>(
|
|
|
|
`${baseUrl}${url}`,
|
|
|
|
fetcher,
|
|
|
|
config,
|
|
|
|
);
|
2023-09-19 22:41:38 +00:00
|
|
|
|
2024-01-23 00:08: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;
|
|
|
|
|
2024-02-06 23:18:10 +00:00
|
|
|
return { altData, data, error, mutate, loading };
|
2023-09-19 22:41:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
export default useFetch;
|