=================================================================== RCS file: /cvs/cvs/draft/form.min.js,v retrieving revision 1.81 retrieving revision 1.87 diff -u -p -r1.81 -r1.87 --- draft/form.min.js 2024/03/31 15:02:32 1.81 +++ draft/form.min.js 2024/03/31 16:13:39 1.87 @@ -1,66 +1,78 @@ const form = document.querySelector("#cform"); -function validateEmail(email) { -/* +function parseString(str) { + return str.replace(/[~`!@#$%^&*(){}\[\];:"'<,.>?\/\\|+=-]/g, '_'); +} + +function parseMail(email) { + return email.toLowerCase().slice(0,96); +} + +function validateMail(email) { const regex = /^[a-z0-9._%+-]+@[a-z0-9.-]+(\.[a-z]{2,})+$/; return regex.test(email); - */ }; -function validateSubject(subject) { -/* +function parseSubj(subject) { + return parseString(subject).slice(0,96); +} + +function validateSubj(subject) { return (subject.length>3); - */ } -function validateMsg(msg) { -/* +function parseMess(msg) { + return parseString(msg).slice(0,3904); +} + +function validateMess(msg) { return (msg.length>3); - */ } async function sendData() { - var error = 0, - info = document.getElementById("cfinfo"); + var erro = 0, + info = document.getElementById("cfinfo"), + mail = parseMail(document.getElementById("cfem").value), + subj = parseSubj(document.getElementById("cfsu").value), + mess = parseMess(document.getElementById("cfme").value); - if(er) { + erro=validateMail(mail)?erro:++erro; + erro=validateSubj(subj)?erro:++erro; + erro=validateMess(mess)?erro:++erro; + + if(erro) { info.textContent="One or more fields have an error. Please check and try again." } else { + var fcon = document.querySelectorAll(".wpcf7-form-control"); + info.textContent="Please wait..." - } -/* - var er = 0; - em = document.getElementById("cfem").value), - su = document.getElementById("cfsu").value), - ms = document.getElementById("cfme").value), - - er=validateEmail(em)?er:++er; - er=validateSubject(su)?er:++er; - er=validateMsg(ms)?er:++er; - if(er){ - } else { - var fc = document.querySelectorAll(".wpcf7-form-control"); - fc.forEach((f) => { + fcon.forEach((f) => { f.disabled=true; l=f; }); l.style.visibility="hidden"; turnstile.ready(function() { turnstile.render('#cfcontainer', { + retry: 'never', theme: 'light', - sitekey: '0x4AAAAAAAVpXFEy152AON1L', 'response-field': false, - retry: 'never', + sitekey: '0x4AAAAAAAVpXFEy152AON1L', 'error-callback': function(e) { - ii.textContent="Cloudflare Turnstile verification error. Try again later." + info.textContent="Cloudflare Turnstile verification error. Try again later." }, callback: function(token) { - const dataToSend = JSON.stringify({"add": em, "sub": su, "msg": ms, "tok": token}); - ii.textContent="Sending..."; - + const data = JSON.stringify({"add": mail, "sub": subj, "msg": mess, "tok": token}); + info.textContent="Sending..."; + } + }); + }); + info.textContent="Fin"; + turnstile.remove(); + }; +} - -fetch("/feedbk/", { +// ============================================================= // +/*fetch("/feedbk/", { credentials: "same-origin", mode: "same-origin", method: "post", @@ -69,17 +81,9 @@ fetch("/feedbk/", { }) .then(response => response.json()) .then(json => ii.textContent=json['msg']) - - - }, - }); - - }); - turnstile.remove(); + turnstile.close(); - } - */ -}; + }*/ form.addEventListener("submit", (event) => { event.preventDefault();