import { Button } from "@/components/ui/button"; import { Dialog, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, DialogTrigger, } from "@/components/ui/dialog"; import { DropdownMenuItem } from "@/components/ui/dropdown-menu"; import { Form, FormControl, FormField, FormItem, FormLabel, FormMessage, } from "@/components/ui/form"; import { Input } from "@/components/ui/input"; import { AlertBlock } from "@/components/shared/alert-block"; import { api } from "@/utils/api"; import { zodResolver } from "@hookform/resolvers/zod"; import { CircuitBoard, Folder } from "lucide-react"; import { useEffect } from "react"; import { useForm } from "react-hook-form"; import { toast } from "sonner"; import { z } from "zod"; import { Textarea } from "@/components/ui/textarea"; import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue, } from "@/components/ui/select"; const AddComposeSchema = z.object({ composeType: z.enum(["docker-compose", "stack"]).optional(), name: z.string().min(1, { message: "Name is required", }), description: z.string().optional(), }); type AddCompose = z.infer; interface Props { projectId: string; } export const AddCompose = ({ projectId }: Props) => { const utils = api.useUtils(); const { mutateAsync, isLoading, error, isError } = api.compose.create.useMutation(); const form = useForm({ defaultValues: { name: "", description: "", composeType: "docker-compose", }, resolver: zodResolver(AddComposeSchema), }); useEffect(() => { form.reset(); }, [form, form.reset, form.formState.isSubmitSuccessful]); const onSubmit = async (data: AddCompose) => { await mutateAsync({ name: data.name, description: data.description, projectId, composeType: data.composeType, }) .then(async () => { toast.success("Compose Created"); await utils.project.one.invalidate({ projectId, }); }) .catch(() => { toast.error("Error to create the compose"); }); }; return ( e.preventDefault()} > Compose Create Compose Assign a name and description to your compose {isError && {error?.message}}
( Name )} />
( Compose Type )} /> ( Description