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 { api } from "@/utils/api"; import { zodResolver } from "@hookform/resolvers/zod"; import { AlertTriangle, Container } 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 AddRegistrySchema = z.object({ registryName: z.string().min(1, { message: "Registry name is required", }), username: z.string().min(1, { message: "Username is required", }), password: z.string().min(1, { message: "Password is required", }), registryUrl: z.string().min(1, { message: "Registry URL is required", }), imagePrefix: z.string(), }); type AddRegistry = z.infer; export const AddRegistry = () => { const utils = api.useUtils(); const [isOpen, setIsOpen] = useState(false); const { mutateAsync, error, isError } = api.registry.create.useMutation(); const { mutateAsync: testRegistry, isLoading } = api.registry.testRegistry.useMutation(); const router = useRouter(); const form = useForm({ defaultValues: { username: "", password: "", registryUrl: "", imagePrefix: "", registryName: "", }, resolver: zodResolver(AddRegistrySchema), }); const password = form.watch("password"); const username = form.watch("username"); const registryUrl = form.watch("registryUrl"); const registryName = form.watch("registryName"); const imagePrefix = form.watch("imagePrefix"); useEffect(() => { form.reset({ username: "", password: "", registryUrl: "", imagePrefix: "", }); }, [form, form.reset, form.formState.isSubmitSuccessful]); const onSubmit = async (data: AddRegistry) => { await mutateAsync({ password: data.password, registryName: data.registryName, username: data.username, registryUrl: data.registryUrl, registryType: "cloud", imagePrefix: data.imagePrefix, }) .then(async (data) => { await utils.registry.all.invalidate(); toast.success("Registry added"); setIsOpen(false); }) .catch(() => { toast.error("Error to add a registry"); }); }; return ( Add a external registry Fill the next fields to add a external registry. {isError && (
{error?.message}
)}
( Registry Name )} />
( Username )} />
( Password )} />
( Image Prefix )} />
( Registry URL )} />
); };