Last active
          November 12, 2019 18:19 
        
      - 
      
- 
        Save avanslaars/d414f1943eadea3dc22aeb4689bf25ee to your computer and use it in GitHub Desktop. 
    Generated by XState Viz: https://xstate.js.org/viz
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | // Available variables: | |
| // - Machine | |
| // - interpret | |
| // - assign | |
| // - send | |
| // - sendParent | |
| // - spawn | |
| // - raise | |
| // - actions | |
| // - XState (all XState exports) | |
| const myMachine = Machine({ | |
| id: 'slide', | |
| initial: 'ground', | |
| states: { | |
| ground: { | |
| on: { | |
| CLIMB_UP: 'ladder' | |
| } | |
| }, | |
| ladder: { | |
| initial: 'unknown', | |
| states: { | |
| 'unknown': {on: { | |
| '':[ | |
| {target: 'step2', cond: 'isJumping'}, | |
| {target: 'step1'} | |
| ] | |
| }}, | |
| 'step1': { | |
| on: { | |
| CLIMB_DOWN: '#slide.ground', | |
| CLIMB_UP: 'step2' | |
| } | |
| }, | |
| 'step2': { | |
| on: { | |
| CLIMB_DOWN: 'step1', | |
| CLIMB_UP: '#slide.topOfSlide' | |
| } | |
| } | |
| } | |
| }, | |
| topOfSlide: { | |
| on: { | |
| CLIMB_DOWN: 'ladder.step2', | |
| SLIDE: 'ground' | |
| } | |
| }, | |
| } | |
| }, { | |
| guards: { | |
| isJumping: () => false | |
| } | |
| }) | |
| // Add step1 and step2 subStates to ladder | |
| // CLIMB_UP and CLIMB_DOWN should move between those states | |
| // CLIMB_UP from step2 should move to topOfSlide | |
| // CLIMB_DOWN from topOfSlide should move to step2 | |
| // Add an isJumping guard that returns true | |
| // Change CLIMB_UP from ground to trigger multiple transitions | |
| // if isJumping then go to step2 | |
| // otherwise go to step1 | |
| // Refactor so the ground CLIMB_UP transition just goes to ladder | |
| // Add an initial entering state for ladder that has an automatic transition to either step1 or step2 based on the isJumping guard | 
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment