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, Pencil } from "lucide-react"; import { useEffect } from "react"; import { useForm } from "react-hook-form"; import { toast } from "sonner"; import { z } from "zod"; const UpdateSecuritySchema = z.object({ username: z.string().min(1, "Username is required"), password: z.string().min(1, "Password is required"), }); type UpdateSecurity = z.infer; interface Props { securityId: string; } export const UpdateSecurity = ({ securityId }: Props) => { const utils = api.useUtils(); const { data } = api.security.one.useQuery( { securityId, }, { enabled: !!securityId, }, ); const { mutateAsync, isLoading, error, isError } = api.security.update.useMutation(); const form = useForm({ defaultValues: { username: "", password: "", }, resolver: zodResolver(UpdateSecuritySchema), }); useEffect(() => { if (data) { form.reset({ username: data.username || "", password: data.password || "", }); } }, [form, form.reset, data]); const onSubmit = async (data: UpdateSecurity) => { await mutateAsync({ securityId, username: data.username, password: data.password, }) .then(async (response) => { toast.success("Security Updated"); await utils.application.one.invalidate({ applicationId: response?.applicationId, }); }) .catch(() => { toast.error("Error to update the security"); }); }; return ( Update Update the security {isError && (
{error?.message}
)}
( Username )} /> ( Password )} />
); };