diff --git a/docs/recipes/Zustand.md b/docs/recipes/Zustand.md index fae87272..d5d6fce9 100644 --- a/docs/recipes/Zustand.md +++ b/docs/recipes/Zustand.md @@ -89,7 +89,7 @@ export interface AuthenticationStoreSnapshot extends SnapshotOut -MobX-State-Tree models declare the data type, initial values, derived values, and actions all in one. +MobX-State-Tree models declare the data type, initial values, derived values, and actions all in one. Zustand takes a "barebones" approach and defines a store as a basic state object with data and actions co-located. Create a new file `app/store/AuthenticationStore.ts` and convert the model to Zustand to look like this: @@ -535,7 +535,19 @@ const episodeStore = useEpisodeStore(); ``` ```diff - { + ;(async function load() { + setIsLoading(true) + await episodeStore.fetchEpisodes() + setIsLoading(false) + })() +-- }, [episodeStore]) +++ }, []) + +``` + +```diff + -- episodeStore.setProp("favoritesOnly", !episodeStore.favoritesOnly) @@ -554,7 +566,7 @@ const parsedTitleAndSubtitle = getParsedTitleAndSubtitle(episode); ```diff { +- setTimeout(hideSplashScreen, 500) +-}) --useEffect(() => { -- hideSplashScreen() --}, []) -+const hasHydrated = useStore((state) => state._hasHydrated) ++const rehydrated = useStore((state) => state._hasHydrated) +useEffect(() => { -+ if (hasHydrated) { ++ if (rehydrated) { + setTimeout(hideSplashScreen, 500) + } -+}, [hasHydrated]) - --if (!isNavigationStateRestored || !areFontsLoaded) return null -+if (!hasHydrated || !isNavigationStateRestored || !areFontsLoaded) return null ++}, [rehydrated]) ```