Skip to content

Instantly share code, notes, and snippets.

@amogower
Created November 19, 2021 11:54
Show Gist options
  • Save amogower/313efdc5a473a23501d1d799d6746b62 to your computer and use it in GitHub Desktop.
Save amogower/313efdc5a473a23501d1d799d6746b62 to your computer and use it in GitHub Desktop.
Generated by XState Viz: https://xstate.js.org/viz
// Available variables:
// - Machine
// - interpret
// - assign
// - send
// - sendParent
// - spawn
// - raise
// - actions
// - XState (all XState exports)
const timelineMachine = Machine({
id: 'timeline',
initial: 'idle',
context: {
retries: 0
},
states: {
idle: {
on: {
CLOCK_START: 'running'
}
},
running: {
invoke: [
{
src: 'ticker',
},
],
on: {
CLOCK_STOP: 'idle',
MATCH_END: 'finish',
},
},
finish: {
type: 'final'
},
}
}, {
services: {
ticker: (context) => (callback) => {
const id = setInterval(() => callback('TICK'), context.TICK_INTERVAL);
return () => clearInterval(id);
},
},
});
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment