move space logic to zustand

This commit is contained in:
Ren Amamiya
2023-06-02 18:06:19 +07:00
parent dffe300a5f
commit 48e453fe5c
8 changed files with 126 additions and 42 deletions

View File

@@ -1,27 +1,75 @@
import { getActiveAccount, getLastLogin } from "@utils/storage";
import {
addBlockToDB,
getActiveAccount,
getBlocks,
getLastLogin,
removeBlockFromDB,
} from "@utils/storage";
import { create } from "zustand";
import { createJSONStorage, persist } from "zustand/middleware";
import { immer } from "zustand/middleware/immer";
export const useActiveAccount = create(
persist(
(set) => ({
account: null,
lastLogin: 0,
fetch: async () => {
const response = await getActiveAccount();
set({ account: response });
immer(
persist(
(set: any, get: any) => ({
account: null,
blocks: null,
lastLogin: 0,
fetch: async () => {
const response = await getActiveAccount();
set({ account: response });
},
fetchLastLogin: async () => {
const response = await getLastLogin();
set({ lastLogin: parseInt(response) });
},
fetchBlocks: async () => {
const account = get().account;
const response = await getBlocks(account.id);
set({ blocks: response });
},
addBlock: (kind: number, title: string, content: string) => {
const account = get().account;
// add to db
addBlockToDB(account.id, kind, title, content);
// update state
set((state: any) => ({
blocks: [
...state.blocks,
{
id: account.id + kind,
account_id: account.id,
kind,
title,
content,
},
],
}));
},
removeBlock: (id: string) => {
// remove from db
removeBlockFromDB(id);
// update state
set((state: any) => {
const target = state.blocks.findIndex(
(b: { id: string }) => b.id === id,
);
if (target) {
state.blocks.splice(target, 1);
}
});
},
updateFollows: (list: any) => {
set((state: any) => ({
account: { ...state.account, follows: list },
}));
},
}),
{
name: "account",
storage: createJSONStorage(() => sessionStorage),
},
fetchLastLogin: async () => {
const response = await getLastLogin();
set({ lastLogin: parseInt(response) });
},
updateFollows: (list: any) => {
set((state: any) => ({ account: { ...state.account, follows: list } }));
},
}),
{
name: "account",
storage: createJSONStorage(() => sessionStorage),
},
),
),
);

View File

@@ -3,7 +3,7 @@ import { create } from "zustand";
import { immer } from "zustand/middleware/immer";
export const useChats = create(
immer((set: any, get: any) => ({
immer((set: any) => ({
chats: [],
fetch: async (pubkey: string) => {
const response: any = await getChatsByPubkey(pubkey);