import type { StateCreator, StoreMutatorIdentifier } from '../vanilla'; export interface StateStorage { getItem: (name: string) => string | null | Promise; setItem: (name: string, value: string) => void | Promise; removeItem: (name: string) => void | Promise; } export type StorageValue = { state: S; version?: number; }; export interface PersistStorage { getItem: (name: string) => StorageValue | null | Promise | null>; setItem: (name: string, value: StorageValue) => void | Promise; removeItem: (name: string) => void | Promise; } export declare function createJSONStorage(getStorage: () => StateStorage): PersistStorage | undefined; export interface PersistOptions { /** Name of the storage (must be unique) */ name: string; /** * @deprecated Use `storage` instead. * A function returning a storage. * The storage must fit `window.localStorage`'s api (or an async version of it). * For example the storage could be `AsyncStorage` from React Native. * * @default () => localStorage */ getStorage?: () => StateStorage; /** * @deprecated Use `storage` instead. * Use a custom serializer. * The returned string will be stored in the storage. * * @default JSON.stringify */ serialize?: (state: StorageValue) => string | Promise; /** * @deprecated Use `storage` instead. * Use a custom deserializer. * Must return an object matching StorageValue * * @param str The storage's current value. * @default JSON.parse */ deserialize?: (str: string) => StorageValue | Promise>; /** * Use a custom persist storage. * * Combining `createJSONStorage` helps creating a persist storage * with JSON.parse and JSON.stringify. * * @default createJSONStorage(() => localStorage) */ storage?: PersistStorage | undefined; /** * Filter the persisted value. * * @params state The state's value */ partialize?: (state: S) => PersistedState; /** * A function returning another (optional) function. * The main function will be called before the state rehydration. * The returned function will be called after the state rehydration or when an error occurred. */ onRehydrateStorage?: (state: S) => ((state?: S, error?: unknown) => void) | void; /** * If the stored state's version mismatch the one specified here, the storage will not be used. * This is useful when adding a breaking change to your store. */ version?: number; /** * A function to perform persisted state migration. * This function will be called when persisted state versions mismatch with the one specified here. */ migrate?: (persistedState: unknown, version: number) => S | Promise; /** * A function to perform custom hydration merges when combining the stored state with the current one. * By default, this function does a shallow merge. */ merge?: (persistedState: unknown, currentState: S) => S; } type PersistListener = (state: S) => void; type StorePersist = { persist: { setOptions: (options: Partial>) => void; clearStorage: () => void; rehydrate: () => Promise | void; hasHydrated: () => boolean; onHydrate: (fn: PersistListener) => () => void; onFinishHydration: (fn: PersistListener) => () => void; getOptions: () => Partial>; }; }; type Persist = (initializer: StateCreator, options: PersistOptions) => StateCreator; declare module '../vanilla' { interface StoreMutators { 'zustand/persist': WithPersist; } } type Write = Omit & U; type WithPersist = S extends { getState: () => infer T; } ? Write> : never; export declare const persist: Persist; export {};