'use client'; import { Button } from '@/components/ui/button'; import { Input } from '@/components/ui/input'; import { Card, CardContent, CardHeader, CardTitle, CardDescription, } from '@/components/ui/card'; import { LanguageSelector } from '@/components/ui/language-selector'; import { useForm } from 'react-hook-form'; import { zodResolver } from '@hookform/resolvers/zod'; import * as z from 'zod'; import { Form, FormControl, FormField, FormItem, FormLabel, FormMessage, } from '@/components/ui/form'; import { useEffect } from 'react'; import { httpClient } from '@/app/infra/http/HttpClient'; import { useRouter } from 'next/navigation'; import { Mail, Lock } from 'lucide-react'; import langbotIcon from '@/app/assets/langbot-logo.webp'; import { toast } from 'sonner'; import { useTranslation } from 'react-i18next'; import { ThemeToggle } from '@/components/ui/theme-toggle'; const formSchema = (t: (key: string) => string) => z.object({ email: z.string().email(t('common.invalidEmail')), password: z.string().min(1, t('common.emptyPassword')), }); export default function Register() { const router = useRouter(); const { t } = useTranslation(); const form = useForm>>({ resolver: zodResolver(formSchema(t)), defaultValues: { email: '', password: '', }, }); useEffect(() => { getIsInitialized(); }, []); function getIsInitialized() { httpClient .checkIfInited() .then((res) => { if (res.initialized) { router.push('/login'); } }) .catch((err) => { console.log('error at getIsInitialized: ', err); }); } function onSubmit(values: z.infer>) { handleRegister(values.email, values.password); } function handleRegister(username: string, password: string) { httpClient .initUser(username, password) .then((res) => { console.log('init user success: ', res); toast.success(t('register.initSuccess')); router.push('/login'); }) .catch((err) => { console.log('init user error: ', err); toast.error(t('register.initFailed') + err.message); }); } return (
LangBot {t('register.title')} {t('register.description')}
{t('register.adminAccountNote')}
( {t('common.email')}
)} /> ( {t('common.password')}
)} />
); }