react-helpful-hooks v1.0.18
React Helpful Hooks
A set of helpful react.js hooks
Install
npm
npm install react-helpful-hooks --saveyarn
yarn add react-helpful-hooksHooks
useAsyncCallback
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
Example
const [onClick, isLoading, error, response] = useAsyncCallback<Error, Response>(asyncFunction, deps);
<button onClick={onClick} disabled={isLoading}
click me {response && response: {response}} {error && error: {error}}
useTimer
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)Example
const { timer, play, pause, reset, isRunning } = useTimer(interval, startsRunning);
useStateHistory
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.Example
const [state, setState, history] = useStateHistory<string>('initial state', limit);
Planned for the future
- useQueryParamState
- useStorageState
- useSafeState
check for unmounts
5 years ago
5 years ago
5 years ago
5 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago