mirror of
https://github.com/kremalicious/umami.git
synced 2025-01-03 10:35:07 +01:00
40 lines
919 B
JavaScript
40 lines
919 B
JavaScript
import { useState, useEffect } from 'react';
|
|
import { get } from 'lib/web';
|
|
|
|
export default function useFetch(url, params = {}, options = {}) {
|
|
const [data, setData] = useState();
|
|
const [error, setError] = useState();
|
|
const keys = Object.keys(params)
|
|
.sort()
|
|
.map(key => params[key]);
|
|
const { update = [], onDataLoad = () => {} } = options;
|
|
|
|
async function loadData() {
|
|
try {
|
|
setError(null);
|
|
const data = await get(url, params);
|
|
setData(data);
|
|
onDataLoad(data);
|
|
} catch (e) {
|
|
console.error(e);
|
|
setError(e);
|
|
}
|
|
}
|
|
|
|
useEffect(() => {
|
|
if (url) {
|
|
const { interval, delay = 0 } = options;
|
|
|
|
setTimeout(() => loadData(), delay);
|
|
|
|
const id = interval ? setInterval(() => loadData(), interval) : null;
|
|
|
|
return () => {
|
|
clearInterval(id);
|
|
};
|
|
}
|
|
}, [url, ...keys, ...update]);
|
|
|
|
return { data, error, loadData };
|
|
}
|