This commit is contained in:
2025-12-21 20:40:32 +01:00
commit c7f669fc11
54 changed files with 7575 additions and 0 deletions

View File

@@ -0,0 +1,128 @@
import React, { useState, useEffect } from 'react';
import { useNavigate } from 'react-router-dom';
import { supabase, isSupabaseConfigured } from '../../lib/supabaseClient';
import { Button } from '../../components/Button';
import { Lock, AlertCircle, CheckCircle, RefreshCw, Save } from 'lucide-react';
export const ResetPassword: React.FC = () => {
const navigate = useNavigate();
const [password, setPassword] = useState('');
const [confirmPassword, setConfirmPassword] = useState('');
const [loading, setLoading] = useState(false);
const [error, setError] = useState<string | null>(null);
const [success, setSuccess] = useState(false);
useEffect(() => {
// Supabase sets the session automatically when clicking the recovery link
const checkSession = async () => {
if (isSupabaseConfigured) {
const { data } = await supabase.auth.getSession();
if (!data.session) {
setError("A link lejárt vagy érvénytelen. Kérjük, igényeljen újat!");
}
}
};
checkSession();
}, []);
const handleSubmit = async (e: React.FormEvent) => {
e.preventDefault();
setLoading(true);
setError(null);
if (password.length < 6) {
setError('A jelszónak legalább 6 karakternek kell lennie.');
setLoading(false);
return;
}
if (password !== confirmPassword) {
setError('A jelszavak nem egyeznek.');
setLoading(false);
return;
}
try {
if (!isSupabaseConfigured) {
await new Promise(resolve => setTimeout(resolve, 1000));
setSuccess(true);
return;
}
const { error } = await supabase.auth.updateUser({
password: password
});
if (error) {
setError(error.message);
} else {
setSuccess(true);
}
} catch (err: any) {
setError('Váratlan hiba történt.');
} finally {
setLoading(false);
}
};
return (
<div className="min-h-screen pt-20 pb-12 bg-gray-50 flex flex-col items-center justify-center px-4 sm:px-6 lg:px-8">
<div className="w-full max-w-md">
<div className="text-center mb-8">
<h2 className="text-3xl font-extrabold text-gray-900 tracking-tight">Új jelszó megadása</h2>
<p className="mt-2 text-sm text-gray-600 font-medium">Kérjük, adja meg az új biztonságos jelszavát.</p>
</div>
<div className="bg-white py-10 px-6 md:px-10 shadow-xl rounded-[32px] border border-gray-100">
{success ? (
<div className="text-center animate-fade-in">
<div className="w-16 h-16 bg-green-100 rounded-full flex items-center justify-center mx-auto mb-6">
<CheckCircle className="w-8 h-8 text-green-600" />
</div>
<h3 className="text-xl font-bold text-gray-900 mb-2">Jelszó sikeresen módosítva!</h3>
<p className="text-gray-600 mb-8 text-sm leading-relaxed">Most már bejelentkezhet az új jelszavával.</p>
<Button fullWidth onClick={() => navigate('/auth/login')}>Bejelentkezés</Button>
</div>
) : (
<form className="space-y-6" onSubmit={handleSubmit}>
{error && (
<div className="rounded-xl bg-red-50 p-4 border border-red-100 flex items-start animate-fade-in">
<AlertCircle className="h-5 w-5 text-red-400 shrink-0 mt-0.5" />
<p className="ml-3 text-sm font-medium text-red-800">{error}</p>
</div>
)}
<div className="space-y-4">
<div>
<label className="block text-xs font-black text-gray-400 uppercase tracking-widest mb-2">Új jelszó</label>
<div className="relative">
<Lock className="absolute left-3 top-3.5 w-5 h-5 text-gray-300" />
<input type="password" required value={password} onChange={(e) => setPassword(e.target.value)} className="appearance-none block w-full pl-10 pr-4 py-3 border border-gray-200 rounded-xl shadow-sm focus:outline-none focus:ring-4 focus:ring-primary/10 focus:border-primary sm:text-sm bg-white text-gray-900 font-medium" />
</div>
</div>
<div>
<label className="block text-xs font-black text-gray-400 uppercase tracking-widest mb-2">Megerősítés</label>
<div className="relative">
<Lock className="absolute left-3 top-3.5 w-5 h-5 text-gray-300" />
<input type="password" required value={confirmPassword} onChange={(e) => setConfirmPassword(e.target.value)} className="appearance-none block w-full pl-10 pr-4 py-3 border border-gray-200 rounded-xl shadow-sm focus:outline-none focus:ring-4 focus:ring-primary/10 focus:border-primary sm:text-sm bg-white text-gray-900 font-medium" />
</div>
</div>
</div>
<div>
<Button type="submit" fullWidth disabled={loading} size="lg" className="shadow-lg shadow-primary/20">
{loading ? (
<RefreshCw className="w-5 h-5 animate-spin" />
) : (
<>Jelszó mentése <Save className="ml-2 w-4 h-4" /></>
)}
</Button>
</div>
</form>
)}
</div>
</div>
</div>
);
};