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 } from "lucide-react"; import { useEffect } from "react"; import { useForm } from "react-hook-form"; import { toast } from "sonner"; import { z } from "zod"; const addCertificate = z.object({ name: z.string().min(1, "Name is required"), certificateData: z.string().min(1, "Certificate data is required"), privateKey: z.string().min(1, "Private key is required"), autoRenew: z.boolean().optional(), }); type AddCertificate = z.infer; export const AddCertificate = () => { const utils = api.useUtils(); const { mutateAsync, isError, error, isLoading } = api.certificates.create.useMutation(); const form = useForm({ defaultValues: { name: "", certificateData: "", privateKey: "", autoRenew: false, }, resolver: zodResolver(addCertificate), }); useEffect(() => { form.reset(); }, [form, form.formState.isSubmitSuccessful, form.reset]); const onSubmit = async (data: AddCertificate) => { await mutateAsync({ name: data.name, certificateData: data.certificateData, privateKey: data.privateKey, autoRenew: data.autoRenew, }) .then(async () => { toast.success("Certificate Created"); await utils.certificates.all.invalidate(); }) .catch(() => { toast.error("Error to create the Certificate"); }); }; return ( Add Certificate Add a new certificate {isError && (
{error?.message}
)}
{ return ( Certificate Name ); }} /> (
Certificate Data