You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
memos/web/src/store/v1/memo.ts

88 lines
2.2 KiB
TypeScript

import { create } from "zustand";
import { combine } from "zustand/middleware";
import { memoServiceClient } from "@/grpcweb";
import { CreateMemoRequest, ListMemosRequest, Memo } from "@/types/proto/api/v2/memo_service";
export const useMemoV1Store = create(
combine({ memoById: new Map<number, Memo>() }, (set, get) => ({
getState: () => get(),
fetchMemos: async (request: Partial<ListMemosRequest>) => {
const { memos } = await memoServiceClient.listMemos(request);
return memos;
},
getOrFetchMemoById: async (id: number) => {
const memo = get().memoById.get(id);
if (memo) {
return memo;
}
const res = await memoServiceClient.getMemo({
id,
});
if (!res.memo) {
throw new Error("Memo not found");
}
set((state) => {
state.memoById.set(id, res.memo as Memo);
return state;
});
return res.memo;
},
getMemoById: (id: number) => {
return get().memoById.get(id);
},
createMemo: async (request: CreateMemoRequest) => {
const { memo } = await memoServiceClient.createMemo(request);
if (!memo) {
throw new Error("Memo not found");
}
set((state) => {
state.memoById.set(memo.id, memo);
return state;
});
return memo;
},
updateMemo: async (update: Partial<Memo>, updateMask: string[]) => {
const { memo } = await memoServiceClient.updateMemo({
id: update.id!,
memo: update,
updateMask,
});
if (!memo) {
throw new Error("Memo not found");
}
set((state) => {
state.memoById.set(memo.id, memo);
return state;
});
return memo;
},
deleteMemo: async (id: number) => {
await memoServiceClient.deleteMemo({
id: id,
});
set((state) => {
state.memoById.delete(id);
return state;
});
},
fetchMemoResources: async (id: number) => {
const { resources } = await memoServiceClient.listMemoResources({
id,
});
return resources;
},
fetchMemoRelations: async (id: number) => {
const { relations } = await memoServiceClient.listMemoRelations({
id,
});
return relations;
},
}))
);