Skip to content

Instantly share code, notes, and snippets.

@parties
Created October 28, 2019 16:55
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save parties/60578b1b889d6646bc91c6303f0ff86d to your computer and use it in GitHub Desktop.
Save parties/60578b1b889d6646bc91c6303f0ff86d 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 formMachine = Machine({
id: "form",
initial: "clean",
context: {
retries: 0,
value: "",
canSubmit: false,
},
states: {
clean: {
on: {
INPUT: "dirty"
}
},
dirty: {
on: {
CLEAR: "clean",
SUBMIT: "submitting",
},
entry: (context, event) =>
context.canSubmit = true,
exit: (context, event) =>
context.canSubmit = false,
},
submitting: {
on: {
RESOLVE: "success",
REJECT: "failure",
}
},
success: {
type: "final"
},
failure: {
on: {
RETRY: {
target: "submitting",
actions: assign({
retries: (context, event) =>
context.retries + 1
})
}
}
},
}
})
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment