Reputation: 6904
I am currently trying to manage data dependencies in a react app. Usually I would just use waitFor
. That doesnt help here though, since it won't wait for the async data fetching, just for the sync operations.
Depender:
@bind(Actions.showUserForm)
showUserForm(id) {
const user = UserStore.getState()[id];
this.setState({form: someAction(user)});
}
Dependee:
@bind(Actions.getUser, showUserForm.showUser)
getUser(id) {
this.getInstance().getUser(id);
}
@bind(Actions.getUserSucc)
getUserSucc(user) {
this.setState({ [user.id]: user })
}
Dependee Source
export default {
getUser: {
remote: (state, id) => UserAPI.get(id),
success: Actions.getUserSucc
},
};
The Depender needs somehow to wait for the Dependees async response with the user data. I could just listen to the success
action, though this would trigger the Depender everytime a user is fetched from the backend.
Is there an idiomatic solution for those kind of problems?
Upvotes: 1
Views: 177