Skip to content

Instantly share code, notes, and snippets.

@aurelkurtula
Last active November 17, 2017 03:37
Show Gist options
  • Save aurelkurtula/b30064ba59b3c16d1a6b18260fcd7bcc to your computer and use it in GitHub Desktop.
Save aurelkurtula/b30064ba59b3c16d1a6b18260fcd7bcc to your computer and use it in GitHub Desktop.
This is to illustrate how react and readux work together, it's the full code explained in this tutorial: https://dev.to/aurelkurtula/a-beginners-introduction-to-working-with-redux-in-react-13k
import ReactDOM from 'react-dom';
import React, { Component } from 'react';
import { Provider, connect } from 'react-redux';
import { createStore, compose } from 'redux';
const todos = (state = [], action) => {
switch (action.type) {
case 'CREATE_TODO':
return state.concat([action.text])
default:
return state;
}
};
const store = createStore(
todos,
undefined,
compose(
window.devToolsExtension ? window.devToolsExtension() : f => f
)
)
const createTodo = (text)=>{
return {
type: 'CREATE_TODO',
text
}
}
class App extends Component {
_handleChange = e => {
e.preventDefault()
let item = e.target.querySelector('input').value;
this.props.createTodo(item);
}
render() {
return (
<div>
<form onSubmit={this._handleChange}>
<input type="text" name="listItem" />
<button type="submit">button</button>
</form>
<br />
{this.props.todos.map((text, id) => (
<div key={id}>
{text}
</div>
)) }
</div>
);
}
}
const MyApp = connect( state => ({
todos: state
}), { createTodo })(App);
ReactDOM.render(
<Provider store={store}>
<MyApp />
</Provider>,
document.getElementById('root'));
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment