Skip to content

nstraub/simple-react-redux

Repository files navigation

react-redux is a great module that allows us to decouple our components from our state, so we can focus only on the view. It does this by providing a connector that maps state and actions to props, effectively allowing us to make all our components dumb again (which is a good thing).

To use it you create a mapStateToProps function and a mapDispatchToProps function, which return state properties and actions respectively. The problem is you have to do this for every component which requires something from the state or performs an action, leading to a lot of repetition and boilerplate code.

simple-react-redux allows you to leverage the power of react-redux declaratively: instead of creating the required functions, you add props to your element to tell it what to get from the state and which actions to use.

Let's say you have a person component, which needs name and age from the state and dispatches the updateName action. With react-redux the code would look something like this:

import {connect} from 'react-redux';
import {updateName} from './actions';

var Person = React.createClass({
    ...
});

function mapStateToProps(state) {
    return {
        name: state.name,
        age: state.age
    };
}

function mapDispatchToProps(dispatch) {
    return {
        updateName: function (newName) {
            return dispatch(updateName(newName));
        }
    }
}

export default connect(mapStateToProps, mapDispatchToProps)(Person);

Using simple-react-redux you can achieve the same functionality with just a few lines of code:

import simpleConnect from 'simple-react-redux';
import {updateName} from './actions';

var Person = React.createClass({
    // ...
});

export default simpleConnect(Person);

And then when you use it:

<Person getFromState={["name", "age"]} getFromActions={{updateName: updateName}} />

And that's it!

About

connect state and actions to props declaratively

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published