version 1.56, 2024/03/29 21:03:44 |
version 1.83, 2024/03/31 15:45:02 |
|
|
const form = document.querySelector("#cform"); |
const form = document.querySelector("#cform"); |
|
|
function validateEmail(email) { |
function parseString(str) { |
const regex = /^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*$/; |
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); |
return regex.test(email); |
}; |
}; |
|
|
function validateSubject(subject) { |
function parseSubj(subject) { |
return (subject.length>5); |
return parseString(subject).slice(0,96); |
} |
} |
|
|
|
function validateSubj(subject) { |
|
return (subject.length>3); |
|
} |
|
|
|
// ============================================================= // |
|
|
function validateMsg(msg) { |
function validateMsg(msg) { |
return (msg.length>5); |
/* |
|
return (msg.length>3); |
|
*/ |
} |
} |
|
|
|
// ============================================================= // |
|
|
async function sendData() { |
async function sendData() { |
var er = 0; |
var erro = 0, |
em = document.getElementById("cfem").value, |
info = document.getElementById("cfinfo"), |
su = document.getElementById("cfsu").value, |
mail = parseMail(document.getElementById("cfem").value), |
ms = document.getElementById("cfme").value, |
subj = parseSubj(document.getElementById("cfsu").value); |
ii = document.getElementById("cfinfo"); |
|
er=validateEmail(em)?er:++er; |
// ============================================================= // |
|
console.log("sendData().validate("+mail+")"); |
|
console.log("sendData().validate("+subj+")"); |
|
// validate() |
|
erro=validateMail(mail)?erro:++erro; |
|
erro=validateSubj(subj)?erro:++erro; |
|
|
|
console.log("sendData().checkErr()") |
|
if(erro) { |
|
info.textContent="One or more fields have an error. Please check and try again." |
|
} else { |
|
info.textContent="Please wait..." |
|
} |
|
/* |
|
var |
|
su = , |
|
ms = document.getElementById("cfme").value), |
er=validateSubject(su)?er:++er; |
er=validateSubject(su)?er:++er; |
er=validateMsg(ms)?er:++er; |
er=validateMsg(ms)?er:++er; |
if(er){ |
if(er){ |
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."; |
|
fc.forEach((f) => { |
fc.forEach((f) => { |
f.disabled=true; |
f.disabled=true; |
l=f; |
l=f; |
Line 39 async function sendData() { |
|
Line 71 async function sendData() { |
|
'response-field': false, |
'response-field': false, |
retry: 'never', |
retry: 'never', |
'error-callback': function(e) { |
'error-callback': function(e) { |
turnstile.remove(); |
ii.textContent="Cloudflare Turnstile verification error. Try again later." |
}, |
}, |
callback: function(token) { |
callback: function(token) { |
ii.textContent="Sent"; |
const dataToSend = JSON.stringify({"add": em, "sub": su, "msg": ms, "tok": token}); |
console.log(`Challenge Success ${token}`); |
ii.textContent="Sending..."; |
/* --------------------- */ |
|
//const ob = {mail: em, sub: su, msg: ms, id: token }; |
|
//var data="", |
|
// status="", |
|
// feed=JSON.stringify(ob); |
|
//$.post("/feedbk/", feed, function(data, status){ |
|
// console.log("Data: " + data + "\nStatus: " + status); |
|
// console.log(data); |
|
// console.log("JSON: " + JSON.parse(data) ); |
|
// |
|
//}); |
|
/* --------------------- */ |
|
//ovar re=""; |
|
const dataToSend = JSON.stringify({"email": "hey@mail.com", "password": "101010"}); |
|
let dataReceived = ""; |
|
fetch("/feedbk/", { |
fetch("/feedbk/", { |
credentials: "same-origin", |
credentials: "same-origin", |
mode: "same-origin", |
mode: "same-origin", |
method: "post", |
method: "post", |
headers: { "Content-Type": "application/json" }, |
headers: { "Content-Type": "application/json" }, |
body: dataToSend |
body: dataToSend |
}) |
}) |
.then(resp => { |
.then(response => response.json()) |
if (resp.status === 200) { |
.then(json => ii.textContent=json['msg']) |
return resp.json() |
|
} else { |
|
console.log("Status: " + resp.status) |
|
return Promise.reject("server") |
|
} |
|
}) |
|
.then(dataJson => { |
|
console.log(dataJson.get("a")); |
|
// dataReceived = JSON.parse(dataJson.getJSON); |
|
}) |
|
.catch(err => { |
|
if (err === "server") return |
|
console.log(err) |
|
}) |
|
console.log(`Received: ${dataReceived}`) |
|
|
|
|
|
|
|
}, |
}, |
}); |
}); |
|
|
}); |
}); |
|
turnstile.remove(); |
|
turnstile.close(); |
} |
} |
|
*/ |
}; |
}; |
|
|
form.addEventListener("submit", (event) => { |
form.addEventListener("submit", (event) => { |