import * as api from "@/helpers/api"; import { Resource } from "@/types/proto/api/v2/resource_service"; import { useTranslate } from "@/utils/i18n"; import store, { useAppSelector } from "../"; import { deleteResource, patchResource, setResources } from "../reducer/resource"; import { useGlobalStore } from "./global"; export const useResourceStore = () => { const state = useAppSelector((state) => state.resource); const t = useTranslate(); const globalStore = useGlobalStore(); const maxUploadSizeMiB = globalStore.state.systemStatus.maxUploadSizeMiB; return { state, getState: () => { return store.getState().resource; }, async fetchResourceList(): Promise { const { data: resourceList } = await api.getResourceList(); store.dispatch(setResources(resourceList)); return resourceList; }, async createResource(resourceCreate: ResourceCreate): Promise { const { data: resource } = await api.createResource(resourceCreate); const resourceList = state.resources; store.dispatch(setResources([resource, ...resourceList])); return resource; }, async createResourceWithBlob(file: File): Promise { const { name: filename, size } = file; if (size > maxUploadSizeMiB * 1024 * 1024) { return Promise.reject(t("message.maximum-upload-size-is", { size: maxUploadSizeMiB })); } const formData = new FormData(); formData.append("file", file, filename); const { data: resource } = await api.createResourceWithBlob(formData); const resourceList = state.resources; store.dispatch(setResources([resource, ...resourceList])); return resource; }, async patchResource(resourcePatch: ResourcePatch): Promise { const { data: resource } = await api.patchResource(resourcePatch); store.dispatch(patchResource(resource)); return resource; }, async deleteResourceById(id: ResourceId) { await api.deleteResourceById(id); store.dispatch(deleteResource(id)); }, }; };