mirror of
https://github.com/streamich/react-use.git
synced 2026-01-18 14:06:52 +00:00
56 lines
918 B
TypeScript
56 lines
918 B
TypeScript
import {useState, useEffect, useCallback} from 'react';
|
|
|
|
export type AsyncState<T> =
|
|
| {
|
|
loading: true;
|
|
error?: undefined;
|
|
value?: undefined;
|
|
}
|
|
| {
|
|
loading: false;
|
|
error: Error;
|
|
value?: undefined;
|
|
}
|
|
| {
|
|
loading: false;
|
|
error?: undefined;
|
|
value: T;
|
|
};
|
|
|
|
const useAsync = <T>(fn: () => Promise<T>, args?) => {
|
|
const [state, set] = useState<AsyncState<T>>({
|
|
loading: true,
|
|
});
|
|
const memoized = useCallback(fn, args);
|
|
|
|
useEffect(() => {
|
|
let mounted = true;
|
|
const promise = memoized();
|
|
|
|
promise
|
|
.then(value => {
|
|
if (mounted) {
|
|
set({
|
|
loading: false,
|
|
value,
|
|
});
|
|
}
|
|
}, error => {
|
|
if (mounted) {
|
|
set({
|
|
loading: false,
|
|
error,
|
|
});
|
|
}
|
|
});
|
|
|
|
return () => {
|
|
mounted = false;
|
|
};
|
|
}, [memoized]);
|
|
|
|
return state;
|
|
};
|
|
|
|
export default useAsync;
|