vérification des champs dans le formulaire avant envoi du mail
continuous-integration/drone/push Build is passing Details

master
Hugo PRADIER 11 months ago
parent 92d53f202d
commit ad5691f036

@ -5,6 +5,13 @@ function sendEmail() {
const phone = document.getElementById("phone").value; const phone = document.getElementById("phone").value;
const message = document.getElementById("message").value; const message = document.getElementById("message").value;
// Réinitialiser les messages d'erreur à chaque fois que la fonction est appelée
document.getElementById("firstname-error").textContent = "";
document.getElementById("name-error").textContent = "";
document.getElementById("email-error").textContent = "";
document.getElementById("phone-error").textContent = "";
document.getElementById("message-error").textContent = "";
// Vérifier que tous les champs sont remplis // Vérifier que tous les champs sont remplis
if ( if (
firstName.trim() === "" || firstName.trim() === "" ||
@ -13,21 +20,24 @@ function sendEmail() {
phone.trim() === "" || phone.trim() === "" ||
message.trim() === "" message.trim() === ""
) { ) {
alert("Veuillez remplir tous les champs."); document.getElementById("response").textContent =
"Veuillez remplir tous les champs.";
return; return;
} }
// Vérifier le format de l'e-mail avec une regex // Vérifier le format de l'e-mail avec une regex
const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/; const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
if (!emailRegex.test(email)) { if (!emailRegex.test(email)) {
alert("Veuillez entrer une adresse e-mail valide."); document.getElementById("email-error").textContent =
"Veuillez entrer une adresse e-mail valide.";
return; return;
} }
// Vérifier le format du numéro de téléphone avec une regex // Vérifier le format du numéro de téléphone avec une regex
const phoneRegex = /^\d{10}$/; const phoneRegex = /^\d{10}$/;
if (!phoneRegex.test(phone)) { if (!phoneRegex.test(phone)) {
alert("Veuillez entrer un numéro de téléphone valide (10 chiffres)."); document.getElementById("phone-error").textContent =
"Veuillez entrer un numéro de téléphone valide (10 chiffres).";
return; return;
} }
@ -44,11 +54,15 @@ function sendEmail() {
}) })
.then( .then(
() => { () => {
alert("Votre message a bien été envoyé !"); // alert("Votre message a bien été envoyé !");
document.getElementById("response").textContent =
"Votre message a bien été envoyé !";
document.getElementById("contact-form").reset(); document.getElementById("contact-form").reset();
}, },
(err) => { (err) => {
alert("Désolé, une erreur s'est produite. Veuillez réessayer."); // alert("Désolé, une erreur s'est produite. Veuillez réessayer.");
document.getElementById("response").textContent =
"Désolé, une erreur s'est produite. Veuillez réessayer.";
} }
); );
} }

@ -332,6 +332,7 @@
id="firstname" id="firstname"
placeholder="Ex: John" placeholder="Ex: John"
/> />
<span id="firstname-error" class="text-danger"></span>
</div> </div>
<div class="col-6 my-2"> <div class="col-6 my-2">
<label for="name" class="form-label">Nom</label> <label for="name" class="form-label">Nom</label>
@ -342,6 +343,7 @@
id="name" id="name"
placeholder="Ex: Doe" placeholder="Ex: Doe"
/> />
<span id="name-error" class="text-danger"></span>
</div> </div>
<div class="col-12 my-2"> <div class="col-12 my-2">
<label for="email" class="form-label">Email</label> <label for="email" class="form-label">Email</label>
@ -352,6 +354,7 @@
id="email" id="email"
placeholder="Ex: johndoe@example.com" placeholder="Ex: johndoe@example.com"
/> />
<span id="email-error" class="text-danger"></span>
</div> </div>
<div class="col-12 my-2"> <div class="col-12 my-2">
<label for="phone" class="form-label">Téléphone</label> <label for="phone" class="form-label">Téléphone</label>
@ -362,6 +365,7 @@
id="phone" id="phone"
placeholder="Ex: 1234567890" placeholder="Ex: 1234567890"
/> />
<span id="phone-error" class="text-danger"></span>
</div> </div>
<div class="col-12 my-2"> <div class="col-12 my-2">
<label for="message" class="form-label">Message</label> <label for="message" class="form-label">Message</label>
@ -372,7 +376,9 @@
rows="3" rows="3"
placeholder="Exemple de message" placeholder="Exemple de message"
></textarea> ></textarea>
<span id="message-error" class="text-danger"></span>
</div> </div>
<span id="response" class="text-danger"></span>
<div class="col-12 my-2"> <div class="col-12 my-2">
<button <button
type="button" type="button"

Loading…
Cancel
Save