2022-03-04 23:34:02 +00:00
|
|
|
import useSWR, { SWRConfiguration } from 'swr';
|
2022-02-24 21:29:47 +00:00
|
|
|
|
2021-03-15 22:05:51 +00:00
|
|
|
import fetcher from './fetchJSON';
|
|
|
|
|
2022-02-24 21:29:47 +00:00
|
|
|
const periodicFetch = <T>(
|
2021-03-15 23:21:57 +00:00
|
|
|
url: string,
|
2022-08-18 20:34:21 +00:00
|
|
|
{ refreshInterval = 5000, onSuccess }: SWRConfiguration<T> = {},
|
2022-04-04 21:54:31 +00:00
|
|
|
): GetResponses<T> => {
|
2022-02-24 21:29:47 +00:00
|
|
|
// The purpose of react-hooks/rules-of-hooks is to ensure that react hooks
|
|
|
|
// are called in order (i.e., not potentially skipped due to conditionals).
|
|
|
|
// We can safely disable this rule as this function is simply a wrapper.
|
|
|
|
// eslint-disable-next-line react-hooks/rules-of-hooks
|
2022-04-04 21:54:31 +00:00
|
|
|
const { data, error: swrError } = useSWR<T>(url, fetcher, {
|
2021-03-15 22:05:51 +00:00
|
|
|
refreshInterval,
|
2022-03-04 23:34:02 +00:00
|
|
|
onSuccess,
|
2021-03-15 22:05:51 +00:00
|
|
|
});
|
2022-02-24 21:29:47 +00:00
|
|
|
|
2021-03-15 22:05:51 +00:00
|
|
|
return {
|
|
|
|
data,
|
2022-04-04 21:54:31 +00:00
|
|
|
isLoading: !swrError && !data,
|
|
|
|
error: swrError,
|
2021-03-15 22:05:51 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-02-24 21:29:47 +00:00
|
|
|
export default periodicFetch;
|