made with esnextbin
  
    
      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
    
  
  
    
  | /* this lacks subscribe behavior or ability to dispatch from outside of component tree but that is generally not neccesary */ | |
| class State extends React.Component { | |
| constructor(props) { | |
| super(props); | |
| this.state = YOUR_INITIAL_STATE; | |
| } | |
| reducer = (action, state, props) => {...newState}; | |
| /* setState takes an object of new state as first arg or a function of props and state that returns new state | |
| * which we will use here | |
| * we pass dispatch around and use it similarly to redux dispatch | 
  
    
      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
    
  
  
    
  | function PromiseComponent(initializeComponent, loadingComponent) { | |
| let cachedComponent; | |
| return class PromiseComponent extends React.Component { | |
| state = { Component: cachedComponent || loadingComponent || () => null }; | |
| componentDidMount() { | |
| if (!cachedComponent) { | |
| initializeComponent.then(component => { | |
| cachedComponent = component.default; | |
| this.setState({ Component: cachedComponent }); | |
| }); | 
  
    
      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
    
  
  
    
  | /* node will be null */ | |
| function Input() { | |
| return <input />; | |
| } | |
| function InputContainer() { | |
| return <div><Input ref={node => console.log(node)} /></div>; | |
| } | |
| /* node will be vnode instance */ | 
made with esnextbin
made with esnextbin
made with esnextbin
  
    
      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
    
  
  
    
  | import React from 'react'; | |
| import { render } from 'react-dom'; | |
| import SyntaxHighlighter from 'react-syntax-highlighter'; | |
| import { docco } from 'react-syntax-highlighter/dist/styles' | |
| import markdown from 'markdown'; | |
| class X extends React.Component { | |
| render() { | |
| return ( | |
| <SyntaxHighlighter language='javascript' style={docco}> | 
  
    
      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
    
  
  
    
  | /* | |
| * In this version without use strict declaration 'SyntaxError: Identifier 'text' has already been declared' is given | |
| */ | |
| const http = require('http'); | |
| const hostname = 'localhost'; | |
| const port = 2001; | |
| http.createServer((req, res) => { | |
| if (req.url === '/favicon.ico') { | 
  
    
      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
    
  
  
    
  | /* | |
| * The reason for this is just a thought exercise | |
| * often people(myself super included) are so confused | |
| * when trying something new, but breaking it down | |
| * to it's simplest existence can be the best way to understand | |
| */ | |
| function createStore(reducer, initState) { | |
| let state = initState; | |
| let subscribers = []; |