=================================================================== RCS file: /cvs/cvs/draft/form.min.js,v retrieving revision 1.4 retrieving revision 1.24 diff -u -p -r1.4 -r1.24 --- draft/form.min.js 2024/03/27 23:19:24 1.4 +++ draft/form.min.js 2024/03/28 19:17:34 1.24 @@ -1,4 +1,4 @@ -const form = document.querySelector("#cform"); +//const form = document.querySelector("#cform"); function validateEmail(email) { const regex = /^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*$/; @@ -13,79 +13,63 @@ function validateMsg(msg) { return (msg.length>5); } +//async function postData() { +// const formData = new FormData(form); +// try { +// const response = await fetch("/feedbk/", { +// method: "POST", +// body: formData, +// }); +// console.log(await response.json()); +// } catch (e) { +// console.error(e); +// } +//} + async function sendData() { var er = 0; - em = document.getElementById("yemail").value, - su = document.getElementById("ysub").value, - ms = document.getElementById("ymsg").value, + em = document.getElementById("cfem").value, + su = document.getElementById("cfsu").value, + ms = document.getElementById("cfme").value, ii = document.getElementById("cfinfo"); - er=validateEmail(em)?er:++er; er=validateSubject(su)?er:++er; er=validateMsg(ms)?er:++er; if(er){ ii.textContent="One or more fields have an error. Please check and try again."; } else { - var fc = document.querySelectorAll(".wpcf7-form-control"), - bt = document.querySelector(".wpcf7-button"); + var fc = document.querySelectorAll(".wpcf7-form-control"); ii.textContent="All good."; fc.forEach((f) => { f.disabled=true; + l=f; }); - bt.disabled=true; - bt.value="OK"; + l.style.visibility="hidden"; + turnstile.ready(function() { + turnstile.render('#cfcontainer', { + theme: 'light', + sitekey: '0x4AAAAAAAVpXFEy152AON1L', + 'error-callback': function(e) { + turnstile.remove(); + }, + callback: function(token) { + ii.textContent="Sent"; + console.log(`Challenge Success ${token}`); +// postData(); +var data=`${token}|${em}|${su}|${ms}`, + status=""; +$.post("/feedbk/", function(data, status){ + alert("Data: " + data + "\nStatus: " + status); + + + + }, + }); + }); } }; form.addEventListener("submit", (event) => { event.preventDefault(); sendData(); -}); - -// turnstile.ready(function() { -// var e = document.querySelectorAll(".wpcf7-form-control"), -// b = document.getElementById("wpcf7-button"); -// e.forEach((f) => { - // f.disabled=true; -// }); - -// document.getElementById("wp1").disabled=true; - -// document.getElementById("wpcf7-button").disabled=true; -// document.getElementById("wpcf7-button").value="Please wait..." - - // turnstile.render('#cfcontainer', { -// theme: 'light', - // sitekey: '0x4AAAAAAAVpXFEy152AON1L', -// 'error-callback': function(e) { -// turnstile.remove(); -// b.value=e; -// }, - // callback: function(token) { -// b.value="Sending..."; -// console.log(`Challenge Success ${token}`); - -// document.getElementById("wpcf7-button").disabled=true; -// document.getElementById("wpcf7-button").type="hidden"; - - // }, - // }); - -//}); - - // Associate the FormData object with the form element - // const formData = new FormData(form); - - // try { - // const response = await fetch("https://example.org/post", { - // method: "POST", - // Set the FormData instance as the request body -// body: formData, - // }); - // console.log(await response.json()); -// } catch (e) { -// console.error(e); -// } -//} - -// Take over form submission +}); \ No newline at end of file