react-use/src/useAsync.ts
lvl99 8b7d5ed3ac reverted useAsync and created new hook useAsyncRetry which leverages useAsync
added story and docs for useAsyncRetry
fixed up new code formatting to match project
2019-03-20 15:12:45 +01:00

50 lines
840 B
TypeScript

import { useState, useEffect, useCallback } from 'react';
export interface AsyncState<T> {
loading: boolean;
error?: Error;
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;
set({
loading: 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;