useMachine
A small finite-state machine helper hook
Installation
$ npm i react-use-machine
Usage
The following example demonstrates how to use the useMachine
hook in an example button component that fetches data on click:
import React from 'react'
import useMachine from 'react-use-machine'
const LoadingButton = () => {
const {state, event, dispatch} = useMachine(
{
IDLE: {
DATA_REQUESTED: 'LOADING',
},
LOADING: {
DATA_SUCCESS: 'SUCCESS',
DATA_ERROR: 'ERROR',
},
SUCCESS: {
DATA_REQUESTED: 'LOADING',
},
ERROR: {
DATA_REQUESTED: 'LOADING',
},
},
'IDLE',
)
useEffect(() => {
switch (event) {
case 'DATA_REQUESTED':
fetch('https://swapi.co/api/people/1')
.then(d => d.json())
.then(d => {
console.log('data: ', d)
dispatch('DATA_SUCCESS')
})
.catch(e => {
console.log('err: ', e)
dispatch('DATA_ERROR')
})
break
default:
break
}
}, [event, dispatch])
return (
<button
onClick={() => dispatch('DATA_REQUESTED')}
disabled={state === 'LOADING'}
>
load
</button>
)
}
Development
To start local development, simply install npm dependencies (npm i
) and run npm run build:watch
to watch ts files in src/
. Built files can be found in dist/
.
Demo
To run the demo, ensure you have run the build script and have a dist
dir in your project root. Then run npm run demo:setup
to copy these to the demo and npm run demo
to start it locally.
Contributing
This project is open to and encourages contributions! Feel free to discuss any bug fixes/features in the issues. If you wish to work on this project:
- Fork this project
- Create a branch (
git checkout -b new-branch
) - Commit your changes (
git commit -am 'add new feature'
) - Push to the branch (
git push origin new-branch
) - Submit a pull request!