import * as api from "@/helpers/api"; import { DEFAULT_MEMO_LIMIT } from "@/helpers/consts"; import store, { useAppSelector } from "../"; import { patchResource, setResources, deleteResource, upsertResources } from "../reducer/resource"; const MAX_FILE_SIZE = 32 << 20; const convertResponseModelResource = (resource: Resource): Resource => { return { ...resource, createdTs: resource.createdTs * 1000, updatedTs: resource.updatedTs * 1000, }; }; export const useResourceStore = () => { const state = useAppSelector((state) => state.resource); return { state, getState: () => { return store.getState().resource; }, async fetchResourceList(): Promise { const { data } = (await api.getResourceList()).data; const resourceList = data.map((m) => convertResponseModelResource(m)); store.dispatch(setResources(resourceList)); return resourceList; }, async fetchResourceListWithLimit(limit = DEFAULT_MEMO_LIMIT, offset?: number): Promise { const resourceFind: ResourceFind = { limit, offset, }; const { data } = (await api.getResourceListWithLimit(resourceFind)).data; const resourceList = data.map((m) => convertResponseModelResource(m)); store.dispatch(upsertResources(resourceList)); return resourceList; }, async createResource(resourceCreate: ResourceCreate): Promise { const { data } = (await api.createResource(resourceCreate)).data; const resource = convertResponseModelResource(data); const resourceList = state.resources; store.dispatch(setResources([resource, ...resourceList])); return resource; }, async createResourceWithBlob(file: File): Promise { const { name: filename, size } = file; if (size > MAX_FILE_SIZE) { return Promise.reject("overload max size: 32MB"); } const formData = new FormData(); formData.append("file", file, filename); const { data } = (await api.createResourceWithBlob(formData)).data; const resource = convertResponseModelResource(data); const resourceList = state.resources; store.dispatch(setResources([resource, ...resourceList])); return resource; }, async createResourcesWithBlob(files: FileList): Promise> { let newResourceList: Array = []; for (const file of files) { const { name: filename, size } = file; if (size > MAX_FILE_SIZE) { return Promise.reject(`${filename} overload max size: 32MB`); } const formData = new FormData(); formData.append("file", file, filename); const { data } = (await api.createResourceWithBlob(formData)).data; const resource = convertResponseModelResource(data); newResourceList = [resource, ...newResourceList]; } const resourceList = state.resources; store.dispatch(setResources([...newResourceList, ...resourceList])); return newResourceList; }, async deleteResourceById(id: ResourceId) { await api.deleteResourceById(id); store.dispatch(deleteResource(id)); }, async patchResource(resourcePatch: ResourcePatch): Promise { const { data } = (await api.patchResource(resourcePatch)).data; const resource = convertResponseModelResource(data); store.dispatch(patchResource(resource)); return resource; }, }; };