Skip to content

Instantly share code, notes, and snippets.

@threepointone
Last active January 11, 2017 03:07
Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save threepointone/014954c9270749d0b1d1051c12a705af to your computer and use it in GitHub Desktop.
Save threepointone/014954c9270749d0b1d1051c12a705af to your computer and use it in GitHub Desktop.
// the big idea is to have a generator that runs
// for the existence of the component's life.
// so to answer the question "how many", assume a generator per component.
// this could be 10s, worst case 100s?
// assume I'm using the super redux-saga library + some helpers (run, start, stop),
// but this pattern would hold for js-csp, or any other generator type thing
class Something extends React.Component {
state = { x: 0, y: 0 }
saga = function *(){
while(true){
let e = yield take('click')
this.setState({ x:e.pageX, y: e.pageY })
}
}.bind(this)
componentDidMount(){
run(this.saga) // start listening
}
componentWillUnMount(){
stop(this.saga) //remove
}
render(){
return <div onClick={e => put('click', e)}>
last click was -
x: {this.state.x}
y: {this.state.y}
</div>
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment