Local modifications to ClusterLabs/Anvil by Alteeve
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

46 lines
1011 B

import { useMemo } from 'react';
import useSWR, { BareFetcher, KeyedMutator, 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;
mutate: KeyedMutator<D>;
loading: boolean;
};
const useFetch = <Data, Alt = Data>(
url: string,
options: SWRConfiguration<Data> & {
baseUrl?: string;
fetcher?: BareFetcher<Data>;
mod?: (data: Data) => Alt;
} = {},
): FetchHookResponse<Data> & { altData?: Alt } => {
const {
baseUrl = API_BASE_URL,
fetcher = fetchJSON,
mod,
...config
} = options;
const { data, error, mutate } = useSWR<Data>(
`${baseUrl}${url}`,
fetcher,
config,
);
const altData = useMemo<Alt | undefined>(
() => mod && data && mod(data),
[data, mod],
);
const loading = !error && !data;
return { altData, data, error, mutate, loading };
};
export default useFetch;