Maya Shavin
Smart & Controllable UI
with
Maya Shavin
State management
MobX
manage state flow of different user interface controls
State management
Set local state
Update local state
Render component
Multiple clicks?
Loading state?
Error state?
Disabled?
Bottom 🆙
Basic actions
New action
New action
Bug fixes
Bug fixes
Bottom 🆙
Difficult to maintain
Difficult to test
🐛
Hard to understand
State Machines
Finite
Deterministic Finite Automata
Deterministic
Finite
Automaton
one initial state
finite number of states
finite number of events
transition map triggered by events
Promises
Async/Await
Callbacks
Observables
UI phases/components are dependent
Transition between phases based on actions
Actions are events triggered
Building user interfaces === building user
diagrams
graphs
trees
flows
State machines & state charts for modern web
Create
Interpret
Execute
State machine/chart
Manage
State machine/chart
Machine
transition
Events
State machine/chart
Actions
States
const fetchMachine = Machine({
id: 'fetch',
initial: 'idle',
context: { retries: 0 },
states: {
idle: {
on: {
FETCH: 'loading'
}
},
loading: {
on: {
RESOLVE: 'success',
REJECT: 'failure'
}
},
success: {
type: 'final'
},
failure: {
on: {
RETRY: {
target: 'loading',
actions: assign({
retries: (context, event) => context.retries + 1
})
}
}
}
}
});
inactive
toggle
active
toggle
import { Machine } from 'xstate';
export const toggleMachine = Machine({
id: 'toggle',
context: {
/* some data */
},
initial: 'inactive',
states: {
inactive: {
on: { toggle: 'active' }
},
active: {
on: { toggle: 'inactive' }
}
}
});
Advantages of XState
Code reusability
Test coverage
Code scalability & maintenance
Better code design & planning
Easy to debug and spot bugs
Visually clear view of the code flow
Resources
State machine/chart
console.log(Maya)
Senior Software Engineer
Core maintainer of StorefrontUI
NuxtJS Ambassador
Everything about Frontend/Web
Media Developer Expert (MDE)
THANK YOU!
Plan. Model. Develop
Smart & Controllable UI with (X)state machine
By Maya Shavin
Smart & Controllable UI with (X)state machine
UI components are built on user flows or state graphs. To manage these states, we usually resolved to boolean variables system like isLoading. But this proves to be buggy and hard to maintain as the codebase grows. There is a better solution. In my talk, we will explore how to fully control our app's states and develop a more adaptive UI system to users' behavior with state machines, statecharts and more.
- 160