Package Exports
- little-state-machine
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (little-state-machine) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
♆ Little State Machine
State management made super simple
- Follow flux application architecture
- Tiny with 0 dependency and simple (less 1kb)
- Persist your state by default (
sessionStorage) - Build with React Hooks
Install
$ npm install little-state-machineDemo
Check out the Demo.
API
🔗 StateMachineProvider
This is a Provider Component to wrapper around your entire app in order to create context.
🔗 createStore
Function to initial the global store, call at app root where StateMachineProvider is.
🔗 useStateMachine(Action | Actions, Options?) =>
This hook function will return action/actions and state of the app.
// individual action
Action: (store: Object, payload: any) => void;
// multiple actions
Actions: { [key: string] : Action }
// options to name action in debug, and weather trigger global state update to re-render entire app
Options: {
debugName: string, // unique debug name can really help you :)
shouldReRenderApp: boolean,
}React DevTools
Built-in DevTool component to track your state change and action.
<StateMachineProvider>
{process.env.NODE_ENV !== 'production' && <DevTool />}
</StateMachineProvider>
Window Object
🔗 window.STATE_MACHINE_DEBUG
This will toggle the console output in dev tool.
window.STATE_MACHINE_DEBUG(true) to turn debug on in console
window.STATE_MACHINE_DEBUG(false) to turn off debug on in console
🔗 window.STATE_MACHINE_RESET
This will reset the entire store.
window.STATE_MACHINE_RESET() to reset the localStorage or sessionStorage
🔗 window.STATE_MACHINE_GET_STORE
This will return the entire store.
window.STATE_MACHINE_GET_STORE()
🔗 window.STATE_MACHINE_SAVE_TO
Save into another session/local storage
window.STATE_MACHINE_GET_STORE(name: string)
🔗 window.STATE_MACHINE_LOAD
Load saved state into your app, you can either supply a name of your session/local storage, or supply a string of data.
window.STATE_MACHINE_GET_STORE({ storeName?: string, data?: Object })
storeName: external session/local storage name
data: string of data
Example
📋 app.js
import React from 'react'
import yourDetail from './yourDetail'
import YourComponent from './yourComponent'
import { StateMachineProvider, createStore } from 'little-state-machine'
// create your store
createStore({
yourDetail,
});
export default () => {
return (
<StateMachineProvider>
<YourComponent />
</StateMachineProvider>
)
}📋 yourComponent.js
import React from 'react'
import { updateName } from './action.js'
import { useStateMachine } from 'little-state-machine'
export default function YourComponent() {
const {
action,
state: { yourDetail: { name } },
} = useStateMachine(updateName);
return <div onClick={() => action('bill')}>{name}</div>
}📋 yourDetail.js
export default {
name: 'test',
}📋 action.js
export function updateName(state, payload) {
return {
...state,
yourDetail: {
name: payload
},
}
}