A set of helpful react.js hooks
npm install react-helpful-hooks --save
yarn add react-helpful-hooks
This hook is meant to simplify async operations inside components.
In this example:
onClickis the callback function that triggers the async operation.asyncFunctionis the original async function.depsis the dependency array to updateasyncFunction.isLoadingwill be true afteronClickwas executed but before the promise completes.erroris the data from the rejected promise.responseis the data from the resolved promise.This hook also handle cases where component unmounts before the promise is resolved/rejected
const [onClick, isLoading, error, response] = useAsyncCallback<Error, Response>(asyncFunction, deps);
<button
onClick={onClick}
disabled={isLoading}
>
click me
</button>
{response && <p>response: {response}</p>}
{error && <p>error: {error}</p>}This hook is to be used as a timer, but also works as a timeout or interval if combined with a useEffect
In this example:
timeris the time elapsed from initialization or the last reset (starting at 0).playis a callback to start the timer.pauseis a callback to pause the timer.resetsets the timer at 0. If the timer is running, it will keep running. If the timer is paused, it will remain paused.intervalis the time interval in milliseconds that will elapse between each tick.isRunningis a boolean that represent the current timer state. Defaults totruestartsRunningis the initial state forisRunningNote: the number given back as
timerrepresents the elapsed time plus the spent execution time. This means that an interval of 1000ms will most likely have an elapsed time of more than 1000ms (normally by a few milliseconds)
const { timer, play, pause, reset, isRunning } = useTimer(interval, startsRunning);This hook uses the same interface as
useState, but adds the possibility to access the change historyIn this example:
stateis the current state, not different as the one fromuseState.setStateis the state setter, not different as the one fromuseState.historyis the list of state values that was set. It starts from the latest one.'initial value'is the optional initial state value, not different as the one fromuseState.limitis the optional history limit. If you set 2, then you will have a max history array of 2 items. When the limit is rached, the oldest value is discarded. Defaults to Infinity.
const [state, setState, history] = useStateHistory<string>('initial state', limit);- useQueryParamState
- useStorageState
- useSafeState
check for unmounts