From dacc5d10e8074742093496830289e7317a7ce931 Mon Sep 17 00:00:00 2001 From: ygowthamr Date: Sun, 27 Oct 2024 20:06:20 +0530 Subject: [PATCH] Added Trusted email validation functionality in feedback form --- give_feedback.html | 45 ++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 44 insertions(+), 1 deletion(-) diff --git a/give_feedback.html b/give_feedback.html index 4a155aff..3e3328cf 100644 --- a/give_feedback.html +++ b/give_feedback.html @@ -553,6 +553,44 @@

Message Sent

const closePopup = document.getElementById('closePopup'); const feedbackResult = document.getElementById('feedback-result'); + const trustedDomains = [ + 'gmail.com', + 'outlook.com', + 'yahoo.com', + 'protonmail.com', + 'icloud.com', + 'tutanota.com', + 'hotmail.com', + 'live.com', + 'mail.com', + 'zoho.com', + 'gmx.com', + 'aol.com', + 'fastmail.com', + 'yandex.com', + '*.edu', + '*.ac.uk', + '*.edu.in', + '*.edu.au', + 'examplecompany.com', + 'mailfence.com', + 'posteo.de', + 'runbox.com' + ]; + + // Email validation function to check format and domain + function validateEmail(email) { + const emailPattern = /^[^\s@]+@[^\s@]+\.[^\s@]+$/; // Basic email format validation + const domain = email.split('@')[1]; + + return ( + emailPattern.test(email) && + trustedDomains.some((trusted) => + trusted.includes('*') ? domain.endsWith(trusted.slice(1)) : domain === trusted + ) + ); + } + submitBtn.addEventListener('click', () => { const name = document.getElementById('Name').value.trim(); const email = document.getElementById('email2').value.trim(); @@ -579,6 +617,11 @@

Message Sent

alert('Please enter a feedback message!'); return; // Stop execution if name is empty } +if (!validateEmail(email)) { + alert('Please enter a valid email address from a trusted provider.'); + return; + } + // Display feedback result in popup feedbackResult.innerHTML = `Thank you, ${name}!
Your feedback: ${message}
Rating: ${rating} stars`; @@ -764,4 +807,4 @@ - + \ No newline at end of file