Persisting & rehydrating data
Previous versions of zfy used to rely on a custom persistence solution. Fortunately, zustand added built-in support for this feature in v3.1.4. Therefore: zfy simply employs zustand's persist middleware and tries to offer an easier API to use.
Persistence
Data is persisted on a store to store basis. In order to make a store persist its data
, you need to provide the persist
option to createStore()
3rd argument and specify which storage solution you'd like to use:
This means that you can have stores using different storage solutions depending on your use case (LocalStorage, Cookies, IndexedDB, etc).
You need to make sure that your storage solution provides agetItem()
, asetItem()
and aremoveItem()
(only needed for zustand v4).
If it does not, of course, you can always provide it yourself:
From there you're all set. Just use getState().update()
to update your store as covered in the Creating & using a store guide and your data
will be persisted.
Rehydration
Similarly to the persistence solution, zfy directly uses zustand's rehydration under the hood and simply exposes it via a different (hopefully simpler) API.
Usually, when it comes to rehydration, you might want to hide all (or part) of your app while the necessary stores are rehydrating. zfy provides 2 solutions out of the box to do so: a component - <PersistGate/>
- and a React Hook, useRehydrate()
.
<PersistGate />
<PersistGate />
This component expects an array of stores
and will take care of displaying its children
only when all the stores will have been rehydrated. You can as well provide a loader
if needed:
useRehydrate()
useRehydrate()
If <PersistGate />
doesn't fit your need, you can have finer control over what happens via useRehydrate()
:
Last updated
Was this helpful?