Made with create-react-library
react-use-appstate provides simple, extensible API's to manage and maintain global app state without extraneous boilerplate and code overhead. A live demo can be found here.
npm install --save react-use-appstate
import { AppStateProvider } from 'react-use-appstate'
export default function App() {
return (
<AppStateProvider initialState={{ useForm: { name: '' } }}>
<App />
</AppStateProvider>
)
}
import { generate } from 'react-use-appstate'
export default generate('useForm', {})
import useForm from '../hooks/useForm'
export default function Form() {
const {
state,
actions: { setState },
} = useForm()
return (
<form>
<input
name="name"
value={state.data.name}
onChange={e => {
setState({
[e.target.name]: e.target.value
})
}}
>
</form>
)
}
import useForm from '../hooks/useForm'
export default function ThankYou() {
const { state } = useForm()
return <div>Thank you for submitting {state.data.name}</div>
}
import { AppStateProvider } from 'react-use-appstate'
- initialState (Object): Sets the initial state of your application
<AppStateProvider initialState={{ useForm: { name: '' } }}>
<App />
</AppStateProvider>
Each hook generated should represent one resource. For example, if you have users and posts create two hooks, one for users and one for posts.
import { generate } from 'react-use-appstate'
- name (String): Defines the name of the hook. This name should correclate to a top level object in your initial state
- options (Object): used to define custom actions or API's
- api (Object)
- action (object)
- state (Object): the state scoped to this specific hook
- data: (any)
- loading: (Boolean)
- error: (null || Error)
- actions (Object): contains default and custom actions
- setState (function): function to set the state of data defined for the hook
- ...customActions (function)
- api: (Object): contains custom api functions defined in the hook
- ...customApis (promise)
export default generate('useForm', {
/**
* Expose a set of API's to fetch, update, create etc.
* These must be created here, the hook will not
* expose any default API's
*/
api: {
post: async (payload, appState, setAppState) => {
const form = await fetch('http://example.com/form', {
method: 'POST',
body: JSON.stringify(payload)
})
}
}
/**
* Create a set of reusable custom actions to manipulate data
*/
actions: {
pushData: (payload, appState, setAppState) => {
setAppState({
useForm: {
data: appState.useForm.data.concat([payload])
}
})
}
}
})
MIT © natemoore3