Files
nice-app-web/src/shared/model/store.ts
2025-09-22 16:33:18 +09:00

48 lines
1.3 KiB
TypeScript

import { persistOptions, withLenses } from '@dhmk/zustand-lens';
import { create } from 'zustand';
import { devtools, persist } from 'zustand/middleware';
import { immer } from 'zustand/middleware/immer';
import { createUserInfoStore, UserInfoState } from '@/entities/user/model/store';
import { createBannerInfoStore, BannerInfoState } from '@/entities/common/model/store';
import { StorageKeys } from '@/shared/constants/local-storage';
export type RootStore = {
UserStore: UserInfoState;
BannerStore: BannerInfoState;
};
export const useStore = create<RootStore>()(
devtools(
persist(
immer(
withLenses(() => ({
UserStore: createUserInfoStore,
BannerStore: createBannerInfoStore,
})),
),
{
name: StorageKeys.RootStore,
version: 1,
...persistOptions,
},
),
),
);
type StoreWithPersist = typeof useStore;
export const withStorageDOMEvents = (store: StoreWithPersist) => {
const storageEventCallback = (e: StorageEvent) => {
if (e.key === store.persist.getOptions().name && e.newValue) {
store.persist.rehydrate();
}
};
window.addEventListener('storage', storageEventCallback);
return () => {
window.removeEventListener('storage', storageEventCallback);
};
};
withStorageDOMEvents(useStore);
window.store = useStore;