import { zodResolver } from '@hookform/resolvers/zod' import { PermissionAction } from '@supabase/shared-types/out/constants' import { useParams } from 'common' import { Lock, Mail } from 'lucide-react' import { SubmitHandler, useForm } from 'react-hook-form' import { toast } from 'sonner' import { Button, Checkbox, Dialog, DialogContent, DialogHeader, DialogSectionSeparator, DialogTitle, Form, FormControl, FormField, FormItem, FormLabel, FormMessage, Input, } from 'ui' import * as z from 'zod' import { useUserCreateMutation } from '@/data/auth/user-create-mutation' import { useAsyncCheckPermissions } from '@/hooks/misc/useCheckPermissions' export type CreateUserModalProps = { visible: boolean setVisible: (visible: boolean) => void } const CreateUserFormSchema = z.object({ email: z.string().min(1, 'Email is required').email('Must be a valid email address'), password: z.string().min(1, 'Password is required'), autoConfirmUser: z.boolean(), }) const CreateUserModal = ({ visible, setVisible }: CreateUserModalProps) => { const { ref: projectRef } = useParams() const { can: canCreateUsers } = useAsyncCheckPermissions( PermissionAction.AUTH_EXECUTE, 'create_user' ) const { mutate: createUser, isPending: isCreatingUser } = useUserCreateMutation({ onSuccess(res) { toast.success(`Successfully created user: ${res.email}`) form.reset({ email: '', password: '', autoConfirmUser: true }) setVisible(false) }, }) const onCreateUser: SubmitHandler> = async (values) => { if (!projectRef) return console.error('Project ref is required') createUser({ projectRef, user: values }) } const form = useForm>({ resolver: zodResolver(CreateUserFormSchema), defaultValues: { email: '', password: '', autoConfirmUser: true }, }) return ( Create a new user
( Email address
)} /> ( User Password
)} /> ( field.onChange(value)} /> Auto confirm user? )} />

A confirmation email will not be sent when creating a user via this form.

) } export default CreateUserModal