Files
cinny/src/app/state/spaceRooms.ts
T

60 lines
1.4 KiB
TypeScript
Raw Normal View History

import { atom } from 'jotai';
import { produce } from 'immer';
import {
atomWithLocalStorage,
getLocalStorageItem,
setLocalStorageItem,
} from './utils/atomWithLocalStorage';
const SPACE_ROOMS = 'spaceRooms';
const baseSpaceRoomsAtom = atomWithLocalStorage<Set<string>>(
SPACE_ROOMS,
(key) => {
const arrayValue = getLocalStorageItem<string[]>(key, []);
return new Set(arrayValue);
},
(key, value) => {
const arrayValue = Array.from(value);
setLocalStorageItem(key, arrayValue);
}
);
type SpaceRoomsAction =
| {
type: 'PUT';
2025-02-22 19:24:33 +11:00
roomIds: string[];
}
| {
type: 'DELETE';
2025-02-22 19:24:33 +11:00
roomIds: string[];
};
export const spaceRoomsAtom = atom<Set<string>, [SpaceRoomsAction], undefined>(
(get) => get(baseSpaceRoomsAtom),
(get, set, action) => {
2025-02-22 19:24:33 +11:00
const current = get(baseSpaceRoomsAtom);
const { type, roomIds } = action;
if (type === 'DELETE' && roomIds.find((roomId) => current.has(roomId))) {
set(
baseSpaceRoomsAtom,
2025-02-22 19:24:33 +11:00
produce(current, (draft) => {
roomIds.forEach((roomId) => draft.delete(roomId));
})
);
return;
}
2025-02-22 19:24:33 +11:00
if (type === 'PUT') {
const newEntries = roomIds.filter((roomId) => !current.has(roomId));
if (newEntries.length > 0)
set(
baseSpaceRoomsAtom,
produce(current, (draft) => {
newEntries.forEach((roomId) => draft.add(roomId));
})
);
}
}
);