-
Notifications
You must be signed in to change notification settings - Fork 54
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Make updateState available in constructor instead of componentDidMount #56
Comments
@aweary Same question, is it possible to move componentDidMount code in to constructor? Don't want to use setTimeout(() => { mutate(...) }, 0) |
@aweary Sorry to rush. I need to make a decision quickly to use this library or not. Is it possible to make this happen? |
@kafein I'm not going to be doing anything else with this library until React Conf this month. If you can I'd recommend you wait until then. |
@aweary Thanks for reply. I'll wait. |
Alright, coming back to this I think moving it to |
Hey there. We recently started using react-copy-write in a small application and had a great experience so far, but there is still something that interferes with our application flow, which is the inability to call
mutate
before a provider is fully mounted.https://codesandbox.io/s/oowloz2qk9
In this example the app will crash, because
mutate
is called before the surrounding provider is fully mounted. We want our ApiProvider to be wrapped around the whole app while still being able to use life cycle hooks to do initialization work that could mutate the state this provider gives us.What we did for experimental reasons is to move the
componentDidMount
code fromCopyOnWriteStoreProvider
to a constructor and everything worked fine afterwards. So my question is whether it's possible to do this switch or if there are special reasons for the design decision to makeupdateState
only available aftercomponentDidMount
ofCopyOnWriteStoreProvider
ran? Are there any performance implications or other pitfalls we are overlooking? If not I'd be glad to open a PR for this issue.The text was updated successfully, but these errors were encountered: