219 lines
7.5 KiB
JavaScript
219 lines
7.5 KiB
JavaScript
import React, { useState } from 'react';
|
|
import { Mail, User, Lock } from 'lucide-react';
|
|
import { useNavigate, Link} from 'react-router-dom'; // Importation du hook useNavigate
|
|
import { API_BASE_URL } from "../config.js";
|
|
|
|
function Signup() {
|
|
const [formData, setFormData] = useState({
|
|
name: '',
|
|
surname: '',
|
|
email: '',
|
|
gender: '',
|
|
password: '',
|
|
confirmPassword: ''
|
|
});
|
|
const navigate = useNavigate(); // Initialisation de useNavigate
|
|
|
|
const handleChange = (e) => {
|
|
const { name, value } = e.target;
|
|
setFormData(prev => ({
|
|
...prev,
|
|
[name]: value
|
|
}));
|
|
};
|
|
|
|
const handleSubmit = async (e) => {
|
|
e.preventDefault();
|
|
|
|
if (formData.password !== formData.confirmPassword) {
|
|
alert("Les mots de passe ne correspondent pas !");
|
|
return;
|
|
}
|
|
|
|
try {
|
|
const response = await fetch(`${API_BASE_URL}/signup`, {
|
|
method: "POST",
|
|
headers: {
|
|
"Content-Type": "application/json",
|
|
},
|
|
body: JSON.stringify(formData),
|
|
});
|
|
|
|
const data = await response.json();
|
|
|
|
if (!response.ok) {
|
|
throw new Error(data.error || "Erreur lors de l'inscription");
|
|
}
|
|
|
|
alert("Inscription réussie !");
|
|
|
|
|
|
navigate("/");
|
|
} catch (error) {
|
|
alert(error.message);
|
|
}
|
|
};
|
|
|
|
return (
|
|
<div className="min-h-screen bg-gradient-to-br from-blue-50 to-indigo-50 py-12 px-4 sm:px-6 lg:px-8">
|
|
<div className="w-96 bg-white rounded-lg shadow-md p-6 mx-auto">
|
|
<h2 className="text-2xl font-bold text-gray-800 mb-6 text-center">Inscription</h2>
|
|
<form onSubmit={handleSubmit} className="space-y-4">
|
|
{/* Formulaire (Nom, Prénom, Sexe, Email, Mot de passe) */}
|
|
<div>
|
|
<label className="block text-sm font-medium text-gray-700 mb-1">
|
|
Nom:
|
|
</label>
|
|
<div className="relative">
|
|
<div className="absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none">
|
|
<User className="h-5 w-5 text-gray-400" />
|
|
</div>
|
|
<input
|
|
type="text"
|
|
name="name"
|
|
value={formData.name}
|
|
onChange={handleChange}
|
|
className="pl-10 block w-full rounded-lg border-gray-300 border p-2.5 focus:ring-2 focus:ring-indigo-500 focus:border-indigo-500"
|
|
required
|
|
/>
|
|
</div>
|
|
</div>
|
|
|
|
<div>
|
|
<label className="block text-sm font-medium text-gray-700 mb-1">
|
|
Prénom:
|
|
</label>
|
|
<div className="relative">
|
|
<div className="absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none">
|
|
<User className="h-5 w-5 text-gray-400" />
|
|
</div>
|
|
<input
|
|
type="text"
|
|
name="surname"
|
|
value={formData.surname}
|
|
onChange={handleChange}
|
|
className="pl-10 block w-full rounded-lg border-gray-300 border p-2.5 focus:ring-2 focus:ring-indigo-500 focus:border-indigo-500"
|
|
required
|
|
/>
|
|
</div>
|
|
</div>
|
|
|
|
{/* Sexe */}
|
|
<div>
|
|
<label className="block text-sm font-medium text-gray-700 mb-2">
|
|
Sexe:
|
|
</label>
|
|
<div className="flex gap-6 items-center">
|
|
<label className="inline-flex items-center">
|
|
<input
|
|
type="radio"
|
|
name="gender"
|
|
value="homme"
|
|
checked={formData.gender === 'homme'}
|
|
onChange={handleChange}
|
|
className="form-radio h-4 w-4 text-indigo-600 focus:ring-indigo-500 border-gray-300"
|
|
/>
|
|
<span className="ml-2">Homme</span>
|
|
</label>
|
|
<label className="inline-flex items-center">
|
|
<input
|
|
type="radio"
|
|
name="gender"
|
|
value="femme"
|
|
checked={formData.gender === 'femme'}
|
|
onChange={handleChange}
|
|
className="form-radio h-4 w-4 text-indigo-600 focus:ring-indigo-500 border-gray-300"
|
|
/>
|
|
<span className="ml-2">Femme</span>
|
|
</label>
|
|
</div>
|
|
</div>
|
|
|
|
{/* Email */}
|
|
<div>
|
|
<label className="block text-sm font-medium text-gray-700 mb-2">
|
|
Email:
|
|
</label>
|
|
<div className="relative">
|
|
<div className="absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none">
|
|
<Mail className="h-5 w-5 text-gray-400" />
|
|
</div>
|
|
<input
|
|
type="email"
|
|
name="email"
|
|
value={formData.email}
|
|
onChange={handleChange}
|
|
className="pl-10 block w-full rounded-lg border-gray-300 border p-2.5 focus:ring-2 focus:ring-indigo-500 focus:border-indigo-500"
|
|
required
|
|
/>
|
|
</div>
|
|
</div>
|
|
|
|
{/* Mot de passe */}
|
|
<div>
|
|
<label className="block text-sm font-medium text-gray-700 mb-1">
|
|
Mot de passe:
|
|
</label>
|
|
<div className="relative">
|
|
<div className="absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none">
|
|
<Lock className="h-5 w-5 text-gray-400" />
|
|
</div>
|
|
<input
|
|
type="password"
|
|
name="password"
|
|
value={formData.password}
|
|
onChange={handleChange}
|
|
className="pl-10 block w-full rounded-lg border-gray-300 border p-2.5 focus:ring-2 focus:ring-indigo-500 focus:border-indigo-500"
|
|
required
|
|
minLength="8"
|
|
/>
|
|
</div>
|
|
</div>
|
|
|
|
{/* Confirmer mot de passe */}
|
|
<div>
|
|
<label className="block text-sm font-medium text-gray-700 mb-1">
|
|
Confirmer le mot de passe:
|
|
</label>
|
|
<div className="relative">
|
|
<div className="absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none">
|
|
<Lock className="h-5 w-5 text-gray-400" />
|
|
</div>
|
|
<input
|
|
type="password"
|
|
name="confirmPassword"
|
|
value={formData.confirmPassword}
|
|
onChange={handleChange}
|
|
className="pl-10 block w-full rounded-lg border-gray-300 border p-2.5 focus:ring-2 focus:ring-indigo-500 focus:border-indigo-500"
|
|
required
|
|
minLength="8"
|
|
/>
|
|
</div>
|
|
</div>
|
|
|
|
{/* Bouton d'inscription */}
|
|
<div className="pt-4">
|
|
<button
|
|
type="submit"
|
|
className="w-full flex justify-center py-2.5 px-4 border border-transparent rounded-lg shadow-sm text-sm font-medium text-white bg-indigo-600 hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-indigo-500"
|
|
>
|
|
S'inscrire
|
|
</button>
|
|
</div>
|
|
|
|
{/*Si il a déjà un compte*/}
|
|
<div className="mt-4 text-sm text-center">
|
|
<p>
|
|
Vous avez déjà un compte ?
|
|
<Link to="/login" className="text-indigo-600 hover:text-indigo-700 font-medium"> Connectez-vous ici</Link>
|
|
</p>
|
|
</div>
|
|
</form>
|
|
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
export default Signup;
|