Skip to content

Commit

Permalink
Fix issues with stale props
Browse files Browse the repository at this point in the history
Closes reduxjs#86
  • Loading branch information
esamattis committed Sep 8, 2015
1 parent c2f7166 commit c20be4f
Showing 1 changed file with 19 additions and 52 deletions.
71 changes: 19 additions & 52 deletions src/components/createConnect.js
Original file line number Diff line number Diff line change
Expand Up @@ -37,11 +37,10 @@ export default function createConnect(React) {
// Helps track hot reloading.
const version = nextVersion++;

function computeStateProps(store, props) {
const state = store.getState();
function computeStateProps(storeState, props) {
const stateProps = shouldUpdateStateProps ?
finalMapStateToProps(state, props) :
finalMapStateToProps(state);
finalMapStateToProps(storeState, props) :
finalMapStateToProps(storeState);

invariant(
isPlainObject(stateProps),
Expand Down Expand Up @@ -89,7 +88,8 @@ export default function createConnect(React) {
};

shouldComponentUpdate(nextProps, nextState) {
return !pure || !shallowEqual(this.state.props, nextState.props);
return !pure || !shallowEqual(this.props, nextProps) ||
!shallowEqual(this.state, nextState);
}

constructor(props, context) {
Expand All @@ -104,48 +104,17 @@ export default function createConnect(React) {
`or explicitly pass "store" as a prop to "${this.constructor.displayName}".`
);

this.stateProps = computeStateProps(this.store, props);
this.dispatchProps = computeDispatchProps(this.store, props);
this.state = {
props: this.computeNextState()
dispatchProps: computeDispatchProps(this.store, props),
storeState: this.store.getState()
};
}

computeNextState(props = this.props) {
return computeNextState(
this.stateProps,
this.dispatchProps,
props
);
}

updateStateProps(props = this.props) {
const nextStateProps = computeStateProps(this.store, props);
if (shallowEqual(nextStateProps, this.stateProps)) {
return false;
}

this.stateProps = nextStateProps;
return true;
}

updateDispatchProps(props = this.props) {
const nextDispatchProps = computeDispatchProps(this.store, props);
if (shallowEqual(nextDispatchProps, this.dispatchProps)) {
return false;
}

this.dispatchProps = nextDispatchProps;
return true;
}

updateState(props = this.props) {
const nextState = this.computeNextState(props);
if (!shallowEqual(nextState, this.state.props)) {
this.setState({
props: nextState
});
}
this.setState({
dispatchProps: computeDispatchProps(this.store, props)
});
}

isSubscribed() {
Expand All @@ -172,15 +141,10 @@ export default function createConnect(React) {

componentWillReceiveProps(nextProps) {
if (!shallowEqual(nextProps, this.props)) {
if (shouldUpdateStateProps) {
this.updateStateProps(nextProps);
}

if (shouldUpdateDispatchProps) {
this.updateDispatchProps(nextProps);
}

this.updateState(nextProps);
}
}

Expand All @@ -193,19 +157,24 @@ export default function createConnect(React) {
return;
}

if (this.updateStateProps()) {
this.updateState();
}
this.setState({storeState: this.store.getState()});
}

getWrappedInstance() {
return this.refs.wrappedInstance;
}

render() {

const finalProps = computeNextState(
computeStateProps(this.state.storeState, this.props),
this.state.dispatchProps,
this.props
);

return (
<WrappedComponent ref='wrappedInstance'
{...this.state.props} />
{...finalProps} />
);
}
}
Expand All @@ -221,9 +190,7 @@ export default function createConnect(React) {

// Update the state and bindings.
this.trySubscribe();
this.updateStateProps();
this.updateDispatchProps();
this.updateState();
};
}

Expand Down

0 comments on commit c20be4f

Please sign in to comment.