version 1.15, 2024/03/27 23:49:44 |
version 1.70, 2024/03/30 18:04:36 |
Line 15 function validateMsg(msg) { |
|
Line 15 function validateMsg(msg) { |
|
|
|
async function sendData() { |
async function sendData() { |
var er = 0; |
var er = 0; |
em = document.getElementById("yemail").value, |
em = document.getElementById("cfem").value, |
su = document.getElementById("ysub").value, |
su = document.getElementById("cfsu").value, |
ms = document.getElementById("ymsg").value, |
ms = document.getElementById("cfme").value, |
ii = document.getElementById("cfinfo"); |
ii = document.getElementById("cfinfo"); |
|
|
er=validateEmail(em)?er:++er; |
er=validateEmail(em)?er:++er; |
er=validateSubject(su)?er:++er; |
er=validateSubject(su)?er:++er; |
er=validateMsg(ms)?er:++er; |
er=validateMsg(ms)?er:++er; |
Line 27 async function sendData() { |
|
Line 26 async function sendData() { |
|
ii.textContent="One or more fields have an error. Please check and try again."; |
ii.textContent="One or more fields have an error. Please check and try again."; |
} else { |
} else { |
var fc = document.querySelectorAll(".wpcf7-form-control"); |
var fc = document.querySelectorAll(".wpcf7-form-control"); |
ii.textContent="All good."; |
ii.textContent="Checking..."; |
fc.forEach((f) => { |
fc.forEach((f) => { |
f.disabled=true; |
f.disabled=true; |
l=f; |
l=f; |
}); |
}); |
l.style.visibility="hidden"; |
l.style.visibility="hidden"; |
|
turnstile.ready(function() { |
|
turnstile.render('#cfcontainer', { |
|
theme: 'light', |
|
sitekey: '0x4AAAAAAAVpXFEy152AON1L', |
|
'response-field': false, |
|
retry: 'never', |
|
'error-callback': function(e) { |
|
turnstile.remove(); |
|
}, |
|
callback: function(token) { |
|
const dataToSend = JSON.stringify({"add": em, "sub": su, "msg": ms, "tok": token}); |
|
console.log(`JSON: ${dataToSend}`); |
|
ii.textContent="Sending..."; |
|
|
|
|
turnstile.ready(function() { |
|
turnstile.render('#cfcontainer', { |
fetch("/feedbk/", { |
theme: 'light', |
credentials: "same-origin", |
sitekey: '0x4AAAAAAAVpXFEy152AON1L', |
mode: "same-origin", |
'error-callback': function(e) { |
method: "post", |
turnstile.remove(); |
headers: { "Content-Type": "application/json" }, |
}, |
body: dataToSend |
callback: function(token) { |
}) |
ii.textContent="Sent"; |
.then(response => response.json()) |
console.log(`Challenge Success ${token}`); |
// .then(json => console.log(json)) |
}, |
.then(json ==> ii.textContent=json['msg']) |
}); |
|
}); |
|
|
// ii.textContent=json['msg']; |
|
|
|
|
|
|
|
}, |
|
}); |
|
}); |
} |
} |
}; |
}; |
|
|
form.addEventListener("submit", (event) => { |
form.addEventListener("submit", (event) => { |
event.preventDefault(); |
event.preventDefault(); |
sendData(); |
sendData(); |
}); |
}); |
|
|
// 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 |
|
|
|