Return Completely New State from an Immer Producer

Share this video with your friends

Social Share Links

Send Tweet
Published 5 years ago
Updated 3 years ago

Occasionally, you might want to write a producer that doesn’t change the draft, but rather returns a completely new data set. This can be achieved by using the return keyword.

Instructor: [0:00] Sometimes it might be required to return a completely new set from a producer. For example, in the case where we add a reset button to our application to revert to the original set. Let's add a button and an event handler.

[0:18] Remember, we will get initial set function already so our first bet will be to reuse it. The question is, how can we connect this initial state function to our drafts? The first guess might be to assign the initial set directly to our drafts, but that doesn't work.

[0:34] You have to realize that this only reassigns the arguments to the function, but it doesn't change the drafts. This is quite similar to how you could not implement increments in the following way. This doesn't work.

[0:47] This doesn't increase. Why? Why? Because it just reassigns the local parameters but not the original arguments.

[0:55] Anyway, what is the proper way of achieving this? Well, this is actually quite simple. Immer allows you to return a completely fresh state from a recipe. Instead of updating our draft in this producer, we just return some new data and Immer will use that as the next state to be returned.

egghead
egghead
~ 3 minutes ago

Member comments are a way for members to communicate, interact, and ask questions about a lesson.

The instructor or someone from the community might respond to your question Here are a few basic guidelines to commenting on egghead.io

Be on-Topic

Comments are for discussing a lesson. If you're having a general issue with the website functionality, please contact us at support@egghead.io.

Avoid meta-discussion

  • This was great!
  • This was horrible!
  • I didn't like this because it didn't match my skill level.
  • +1 It will likely be deleted as spam.

Code Problems?

Should be accompanied by code! Codesandbox or Stackblitz provide a way to share code and discuss it in context

Details and Context

Vague question? Vague answer. Any details and context you can provide will lure more interesting answers!

Markdown supported.
Become a member to join the discussionEnroll Today