Merge pull request #365 from makeplane/fix/workspace_settings_logo

fix: upload button on workspace settings page not working
This commit is contained in:
Aaryan Khandelwal 2023-03-03 13:32:25 +05:30 committed by GitHub
commit 76b615d964
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -7,15 +7,13 @@ import useSWR, { mutate } from "swr";
// react-hook-form // react-hook-form
import { Controller, useForm } from "react-hook-form"; import { Controller, useForm } from "react-hook-form";
// react-dropzone
import Dropzone from "react-dropzone";
// icons // icons
import { LinkIcon } from "@heroicons/react/24/outline"; import { LinkIcon } from "@heroicons/react/24/outline";
// lib // lib
import { requiredWorkspaceAdmin } from "lib/auth"; import { requiredWorkspaceAdmin } from "lib/auth";
// services // services
import workspaceService from "services/workspace.service"; import workspaceService from "services/workspace.service";
import fileServices from "services/file.service";
// layouts // layouts
import AppLayout from "layouts/app-layout"; import AppLayout from "layouts/app-layout";
// hooks // hooks
@ -52,7 +50,6 @@ type TWorkspaceSettingsProps = {
const WorkspaceSettings: NextPage<TWorkspaceSettingsProps> = (props) => { const WorkspaceSettings: NextPage<TWorkspaceSettingsProps> = (props) => {
const [isOpen, setIsOpen] = useState(false); const [isOpen, setIsOpen] = useState(false);
const [image, setImage] = useState<File | null>(null);
const [isImageUploading, setIsImageUploading] = useState(false); const [isImageUploading, setIsImageUploading] = useState(false);
const [isImageUploadModalOpen, setIsImageUploadModalOpen] = useState(false); const [isImageUploadModalOpen, setIsImageUploadModalOpen] = useState(false);
@ -122,9 +119,11 @@ const WorkspaceSettings: NextPage<TWorkspaceSettingsProps> = (props) => {
<ImageUploadModal <ImageUploadModal
isOpen={isImageUploadModalOpen} isOpen={isImageUploadModalOpen}
onClose={() => setIsImageUploadModalOpen(false)} onClose={() => setIsImageUploadModalOpen(false)}
onSuccess={() => { onSuccess={(imageUrl) => {
setIsImageUploading(true);
setValue("logo", imageUrl);
setIsImageUploadModalOpen(false); setIsImageUploadModalOpen(false);
handleSubmit(onSubmit)(); handleSubmit(onSubmit)().then(() => setIsImageUploading(false));
}} }}
value={watch("logo")} value={watch("logo")}
/> />
@ -147,62 +146,31 @@ const WorkspaceSettings: NextPage<TWorkspaceSettingsProps> = (props) => {
<div className="col-span lg:col-span-5"> <div className="col-span lg:col-span-5">
<h4 className="text-md mb-1 leading-6 text-gray-900">Logo</h4> <h4 className="text-md mb-1 leading-6 text-gray-900">Logo</h4>
<div className="flex w-full gap-2"> <div className="flex w-full gap-2">
<Dropzone <button type="button" onClick={() => setIsImageUploadModalOpen(true)}>
multiple={false} {watch("logo") && watch("logo") !== null && watch("logo") !== "" ? (
accept={{ <div className="relative mx-auto flex h-12 w-12">
"image/*": [], <Image
}} src={watch("logo")!}
onDrop={(files) => { alt="Workspace Logo"
setImage(files[0]); objectFit="cover"
}} layout="fill"
> className="rounded-md"
{({ getRootProps, getInputProps }) => ( priority
<div> />
<input {...getInputProps()} /> </div>
<div {...getRootProps()}> ) : (
{(watch("logo") && watch("logo") !== null && watch("logo") !== "") || <div className="relative flex h-12 w-12 items-center justify-center rounded bg-gray-700 p-4 uppercase text-white">
(image && image !== null) ? ( {activeWorkspace?.name?.charAt(0) ?? "N"}
<div className="relative mx-auto flex h-12 w-12">
<Image
src={image ? URL.createObjectURL(image) : watch("logo") ?? ""}
alt="Workspace Logo"
objectFit="cover"
layout="fill"
className="rounded-md"
priority
/>
</div>
) : (
<div className="relative flex h-12 w-12 items-center justify-center rounded bg-gray-700 p-4 uppercase text-white">
{activeWorkspace?.name?.charAt(0) ?? "N"}
</div>
)}
</div>
</div> </div>
)} )}
</Dropzone> </button>
<div> <div>
<p className="mb-2 text-sm text-gray-500"> <p className="mb-2 text-sm text-gray-500">
Max file size is 5MB. Supported file types are .jpg and .png. Max file size is 5MB. Supported file types are .jpg and .png.
</p> </p>
<Button <Button
onClick={() => { onClick={() => {
if (image === null) return; setIsImageUploadModalOpen(true);
setIsImageUploading(true);
const formData = new FormData();
formData.append("asset", image);
formData.append("attributes", JSON.stringify({}));
fileServices
.uploadFile(workspaceSlug as string, formData)
.then((response) => {
const imageUrl = response.asset;
setValue("logo", imageUrl);
handleSubmit(onSubmit)();
setIsImageUploading(false);
})
.catch(() => {
setIsImageUploading(false);
});
}} }}
> >
{isImageUploading ? "Uploading..." : "Upload"} {isImageUploading ? "Uploading..." : "Upload"}