import React, { useState } from 'react'; import { Eye, EyeOff, Mail, Lock, ArrowRight, BookOpen, Phone } from 'lucide-react'; import { useAppConfig } from '../contexts/AppConfigContext'; import CopyrightNotice from './CopyrightNotice'; import '../styles/Login.css'; const Login = ({ onNavigateToSignup, onNavigateToHome }) => { const { config } = useAppConfig(); const [showPassword, setShowPassword] = useState(false); const [formData, setFormData] = useState({ email: '', password: '' }); const [isLoading, setIsLoading] = useState(false); const [errors, setErrors] = useState({}); const handleInputChange = (e) => { const { name, value } = e.target; setFormData(prev => ({ ...prev, [name]: value })); // Clear error when user starts typing if (errors[name]) { setErrors(prev => ({ ...prev, [name]: '' })); } }; const validateForm = () => { const newErrors = {}; if (!formData.email) { newErrors.email = 'Email is required'; } else if (!/\S+@\S+\.\S+/.test(formData.email)) { newErrors.email = 'Please enter a valid email address'; } if (!formData.password) { newErrors.password = 'Password is required'; } else if (formData.password.length < 6) { newErrors.password = 'Password must be at least 6 characters'; } setErrors(newErrors); return Object.keys(newErrors).length === 0; }; const handleSubmit = async (e) => { e.preventDefault(); if (!validateForm()) return; setIsLoading(true); try { const response = await fetch(`${process.env.REACT_APP_API_URL}/auth/login`, { method: 'POST', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify({ email: formData.email, password: formData.password }), }); const data = await response.json(); if (response.ok) { // Store the token and user info localStorage.setItem('authToken', data.access_token); localStorage.setItem('user', JSON.stringify(data.user)); onNavigateToHome?.(data.user, data.access_token); } else { setErrors({ submit: data.detail || 'Login failed. Please try again.' }); } } catch (error) { console.error('Login error:', error); setErrors({ submit: 'Login failed. Please try again.' }); } finally { setIsLoading(false); } }; const handleGoogleSignIn = () => { console.log('Google Sign In clicked'); // Future Google Auth integration will go here }; const handlePhoneSignIn = () => { console.log('Phone Sign In clicked'); // Future Phone Auth integration will go here }; return (
{/* Header */}

Welcome Back

{config?.login?.subtitle || 'Sign in to continue'}

{/* Main Login Form */}
{/* Email Field */}
{errors.email && ( {errors.email} )}
{/* Password Field */}
{errors.password && ( {errors.password} )}
{/* Forgot Password */}
{/* Submit Error */} {errors.submit && (
{errors.submit}
)} {/* Submit Button */}
{/* Divider */}
or continue with
{/* Social Login Options */}
{/* Footer */}

Don't have an account?{' '}

Powered by Neon.ai
); }; export default Login;