dia-gov's picture
Upload 569 files
cd6f98e verified
raw
history blame
716 Bytes
import type { StoreApi, UseBoundStore } from "zustand";
/*
Automatically creates selectors for each states in store.
Zustand recommends using selectors for calling state/actions for optimal performance
Reference: https://docs.pmnd.rs/zustand/guides/auto-generating-selectors
*/
type WithSelectors<S> = S extends { getState: () => infer T }
? S & { use: { [K in keyof T]: () => T[K] } }
: never;
export const createSelectors = <S extends UseBoundStore<StoreApi<object>>>(
_store: S
) => {
const store = _store as WithSelectors<typeof _store>;
store.use = {};
for (const k of Object.keys(store.getState())) {
(store.use)[k] = () => store((s) => s[k as keyof typeof s]);
}
return store;
};