import { Button } from "@/components/ui/button"; import { Dialog, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, DialogTrigger, } from "@/components/ui/dialog"; import { Form, FormControl, FormField, FormItem, FormLabel, FormMessage, } from "@/components/ui/form"; import { Input } from "@/components/ui/input"; import { Textarea } from "@/components/ui/textarea"; import { api } from "@/utils/api"; import { AlertBlock } from "@/components/shared/alert-block"; import { zodResolver } from "@hookform/resolvers/zod"; import { PlusIcon } from "lucide-react"; import { useRouter } from "next/router"; import { useEffect, useState } from "react"; import { useForm } from "react-hook-form"; import { toast } from "sonner"; import { z } from "zod"; const AddProjectSchema = z.object({ name: z.string().min(1, { message: "Name is required", }), description: z.string().optional(), }); type AddProject = z.infer; export const AddProject = () => { const utils = api.useUtils(); const [isOpen, setIsOpen] = useState(false); const { mutateAsync, error, isError } = api.project.create.useMutation(); const router = useRouter(); const form = useForm({ defaultValues: { description: "", name: "", }, resolver: zodResolver(AddProjectSchema), }); useEffect(() => { form.reset({ description: "", name: "", }); }, [form, form.reset, form.formState.isSubmitSuccessful]); const onSubmit = async (data: AddProject) => { await mutateAsync({ name: data.name, description: data.description, }) .then(async (data) => { await utils.project.all.invalidate(); toast.success("Project Created"); setIsOpen(false); router.push(`/dashboard/project/${data.projectId}`); }) .catch(() => { toast.error("Error to create a project"); }); }; return ( Add a project The home of something big! {isError && {error?.message}}
( Name )} />
( Description