import * as React from 'react'; import { authService } from '../services/authService'; import { Icon } from './ui/Icon'; import { useTranslation } from '../hooks/useI18n'; interface AuthProps { onAuthSuccess: () => void; } const Auth: React.FC = ({ onAuthSuccess }) => { const { t } = useTranslation(); const [isLogin, setIsLogin] = React.useState(true); const [email, setEmail] = React.useState(''); const [password, setPassword] = React.useState(''); const [error, setError] = React.useState(''); const [isLoading, setIsLoading] = React.useState(false); const handleSubmit = async (e: React.FormEvent) => { e.preventDefault(); setError(''); setIsLoading(true); const action = isLogin ? authService.login : authService.register; const result = action(email, password); if (result.success) { onAuthSuccess(); } else { setError(result.message); } setIsLoading(false); }; return (

GreenPage AI

{isLogin ? t('auth.welcome_back') : t('auth.create_account')}

{isLogin ? t('auth.signin_prompt') : t('auth.signup_prompt')}

setEmail(e.target.value)} required className="mt-1 block w-full px-3 py-2 bg-gray-100 dark:bg-gray-700 border border-gray-300 dark:border-gray-600 rounded-md shadow-sm placeholder-gray-400 focus:outline-none focus:ring-brand-primary focus:border-brand-primary sm:text-sm" />
setPassword(e.target.value)} required className="mt-1 block w-full px-3 py-2 bg-gray-100 dark:bg-gray-700 border border-gray-300 dark:border-gray-600 rounded-md shadow-sm placeholder-gray-400 focus:outline-none focus:ring-brand-primary focus:border-brand-primary sm:text-sm" />
{error &&

{error}

}

{isLogin ? t('auth.no_account') : t('auth.has_account')}

); }; export default Auth;