import { AlertBlock } from "@/components/shared/alert-block"; 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 { zodResolver } from "@hookform/resolvers/zod"; import { AlertTriangle, SquarePen } from "lucide-react"; import { useEffect } from "react"; import { useForm } from "react-hook-form"; import { toast } from "sonner"; import { z } from "zod"; const updateMariadbSchema = z.object({ name: z.string().min(1, { message: "Name is required", }), description: z.string().optional(), }); type UpdateMariadb = z.infer; interface Props { mariadbId: string; } export const UpdateMariadb = ({ mariadbId }: Props) => { const utils = api.useUtils(); const { mutateAsync, error, isError, isLoading } = api.mariadb.update.useMutation(); const { data } = api.mariadb.one.useQuery( { mariadbId, }, { enabled: !!mariadbId, }, ); const form = useForm({ defaultValues: { description: data?.description ?? "", name: data?.name ?? "", }, resolver: zodResolver(updateMariadbSchema), }); useEffect(() => { if (data) { form.reset({ description: data.description ?? "", name: data.name, }); } }, [data, form, form.reset]); const onSubmit = async (formData: UpdateMariadb) => { await mutateAsync({ name: formData.name, mariadbId: mariadbId, description: formData.description || "", }) .then(() => { toast.success("MariaDB updated succesfully"); utils.mariadb.one.invalidate({ mariadbId: mariadbId, }); }) .catch(() => { toast.error("Error to update the Mariadb"); }) .finally(() => {}); }; return ( Modify MariaDB Update the MariaDB data {isError && {error?.message}}
( Name )} /> ( Description