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 { api } from "@/utils/api"; import { zodResolver } from "@hookform/resolvers/zod"; import { SquarePen } from "lucide-react"; import { useEffect } from "react"; import { useForm } from "react-hook-form"; import { toast } from "sonner"; import { z } from "zod"; const updateUserSchema = z.object({ email: z .string() .min(1, "Email is required") .email({ message: "Invalid email" }), password: z.string(), }); type UpdateUser = z.infer; interface Props { authId: string; } export const UpdateUser = ({ authId }: Props) => { const utils = api.useUtils(); const { mutateAsync, error, isError, isLoading } = api.auth.updateByAdmin.useMutation(); const { data } = api.auth.one.useQuery( { id: authId, }, { enabled: !!authId, }, ); const form = useForm({ defaultValues: { email: "", password: "", }, resolver: zodResolver(updateUserSchema), }); useEffect(() => { if (data) { form.reset({ email: data.email || "", password: "", }); } }, [data, form, form.reset]); const onSubmit = async (formData: UpdateUser) => { await mutateAsync({ email: formData.email === data?.email ? null : formData.email, password: formData.password, id: authId, }) .then(() => { toast.success("User updated succesfully"); utils.user.all.invalidate(); }) .catch(() => { toast.error("Error to update the user"); }) .finally(() => {}); }; return ( Update User Update the user {isError && {error?.message}}
( Email )} /> ( Password )} />
); };