import { Button } from "@/components/ui/button"; import { Dialog, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, DialogTrigger, } from "@/components/ui/dialog"; import { Form, FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, } from "@/components/ui/form"; import { Input } from "@/components/ui/input"; import { api } from "@/utils/api"; import { AlertBlock } from "@/components/shared/alert-block"; import { zodResolver } from "@hookform/resolvers/zod"; import { useEffect } from "react"; import { useForm } from "react-hook-form"; import { toast } from "sonner"; import { z } from "zod"; const addUser = z.object({ email: z .string() .min(1, "Email is required") .email({ message: "Invalid email" }), }); type AddUser = z.infer; export const AddUser = () => { const utils = api.useUtils(); const { mutateAsync, isError, error, isLoading } = api.admin.createUserInvitation.useMutation(); const form = useForm({ defaultValues: { email: "", }, resolver: zodResolver(addUser), }); useEffect(() => { form.reset(); }, [form, form.formState.isSubmitSuccessful, form.reset]); const onSubmit = async (data: AddUser) => { await mutateAsync({ email: data.email, }) .then(async () => { toast.success("Invitation created"); await utils.user.all.invalidate(); }) .catch(() => { toast.error("Error to create the invitation"); }); }; return ( Add User Invite a new user {isError && {error?.message}}
{ return ( Email This will be the email of the new user ); }} />
); };