var formOk = false;
function CheckFormulier(formId, aVerplicht)
{
var f = document.forms[formId];
var k = document.getElementById("submitKnop");
ok = true;
var error = "";
for(i = 0; i < aVerplicht.length; i++){
if(!f.elements[aVerplicht[i]].value){
ok = false;
error += "U heeft nog niet alle verplichte velden ingevuld!
\n";
break;
}
}
if(typeof(document.getElementById("email")) != "undefined" && document.getElementById("email") != null)
{
filter = /^([a-zA-Z0-9_\.\-\+\~])+\@(([a-zA-Z0-9\-\~])+\.)+([a-zA-Z0-9]{2,4})+([\ ]{0,})+$/; // filter for email check
if(!filter.test(document.getElementById("email").value)) {
ok = false;
document.getElementById("email").style.backgroundColor = "#cc0000";
document.getElementById("email").style.color = "#FFFFFF";
if (document.getElementById("email").value) error += "Er zit een fout in uw e-mailadres!
\n";
}
else {
document.getElementById("email").style.backgroundColor = "#FFFFFF";
document.getElementById("email").style.color = "#000000";
}
}
if(typeof(document.getElementById("btwnummer")) != "undefined" && typeof(document.getElementById("vestigingsland")) != "undefined")
{
if (document.getElementById("btwnummer")) {
landcode = document.getElementById("vestigingsland").value;
pattern = btwcontrole[document.getElementById("vestigingsland").value];
if(pattern)
{
pattern = new RegExp("^("+pattern+")$","i");
if(!pattern.test(document.getElementById("btwnummer").value)) {
ok = false;
document.getElementById("btwnummer").style.color = "#cc0000";
error += "Er zit een fout in uw btw-nummer!
\n";
}
else {
document.getElementById("btwnummer").style.color = "#000000";
}
}
else
{
ok = false;
error += "Het patroon van het opgegeven btw-nummer wijkt af van het standaardpatroon!
\n";
document.getElementById("btwnummer").style.color = "#cc0000";
}
}
}
// Als de array telcontrole bestaat, moeten de opgegeven telefoonnummers worden gecontroleerd
if (typeof(telcontrole) != "undefined") {
// De array aTelVeld bevat de mogelijke velden waar telefoonnummers worden ingevuld
var aTelVeld = new Array ("telefoon", "vestigingstelefoon");
for (i = 0; i < aTelVeld.length; i++) {
var telVeld = aTelVeld[i];
// Als het veld bestaat, dan controleren...
if(typeof(f.elements[telVeld]) != "undefined")
{
// ...tenminste als er iets is ingevuld
if (f.elements[telVeld].value) {
// Even bepalen in welk land de persoon/het bedrijf is gevestigd
if (typeof(f.elements["vestigingsland"]) != "undefined") landcode = f.elements["vestigingsland"].value;
else if (typeof(f.elements["postland"]) != "undefined") landcode = f.elements["postland"].value;
minLengte = telcontrole[landcode]["min"];
maxLengte = telcontrole[landcode]["max"];
if(minLengte && maxLengte)
{
var telnummer = f.elements[telVeld].value;
// Alle non-numerieke tekens verwijderen
telnummer = telnummer.replace(/[^0-9]/g, '');
// Lengte controleren
if(telnummer.length < minLengte || telnummer.length > maxLengte) {
ok = false;
f.elements[telVeld].style.color = "#cc0000";
error += "Er zit een fout in uw telefoonnummer!
\n";
}
else {
f.elements[telVeld].style.color = "#000000";
}
}
else
{
ok = false;
error += "De lengte van het opgegeven telefoonnummer wijkt af van de standaardlengte!
\n";
f.elements[telVeld].style.color = "#cc0000";
}
}
}
}
}
if(typeof(f.elements["akkoord"]) != "undefined")
{
if (f.elements["akkoord"].checked == false) {
ok = false;
error += "U moet nog aangeven dat u akkoord bent!
\n";
}
}
// er is getypt, dus als er een hidden field is ter controle van spam, waarde aanpassen
if(typeof(f.elements["isSpam"]) != "undefined")
{
f.elements["isSpam"].value = "allclear";
}
if(ok) {
k.className = "submitButton";
k.disabled = false;
formOk = true;
if (document.getElementById(formId+'_error')) {
document.getElementById(formId+'_error').style.display = 'none';
document.getElementById(formId+'_error').innerHTML = "";
}
}
else {
k.className = "submitButton disabled";
k.disabled = true;
formOk = false;
if (document.getElementById(formId+'_error')) {
document.getElementById(formId+'_error').style.display = '';
document.getElementById(formId+'_error').innerHTML = error;
}
}
}
// ====================================================================
// URLEncode and URLDecode functions
//
// Copyright Albion Research Ltd. 2002
// http://www.albionresearch.com/
//
// You may copy these functions providing that
// (a) you leave this copyright notice intact, and
// (b) if you use these functions on a publicly accessible
// web site you include a credit somewhere on the web site
// with a link back to http://www.albionresarch.com/
//
// If you find or fix any bugs, please let us know at albionresearch.com
//
// SpecialThanks to Neelesh Thakur for being the first to
// report a bug in URLDecode() - now fixed 2003-02-19.
// ====================================================================
function URLEncode(plaintext)
{
// The Javascript escape and unescape functions do not correspond
// with what browsers actually do...
var SAFECHARS = "0123456789" + // Numeric
"ABCDEFGHIJKLMNOPQRSTUVWXYZ" + // Alphabetic
"abcdefghijklmnopqrstuvwxyz" +
"-_.!~*'()"; // RFC2396 Mark characters
var HEX = "0123456789ABCDEF";
var encoded = "";
for (var i = 0; i < plaintext.length; i++ ) {
var ch = plaintext.charAt(i);
if (ch == " ") {
encoded += "+"; // x-www-urlencoded, rather than %20
} else if (SAFECHARS.indexOf(ch) != -1) {
encoded += ch;
} else {
var charCode = ch.charCodeAt(0);
if (charCode > 255) {
alert( "Het speciale teken '"
+ ch
+ "' kon niet worden omgezet naar een normaal teken.\n" +
"(URL encoding ondersteund alleen 8-bit characters.)\n" +
"Het teken zal worden vervangen door een spatie." );
encoded += "+";
} else {
encoded += "%";
encoded += HEX.charAt((charCode >> 4) & 0xF);
encoded += HEX.charAt(charCode & 0xF);
}
}
} // for
return encoded;
};
function URLDecode(encoded)
{
// Replace + with ' '
// Replace %xx with equivalent character
// Put [ERROR] in output if %xx is invalid.
var HEXCHARS = "0123456789ABCDEFabcdef";
var plaintext = "";
var i = 0;
while (i < encoded.length) {
var ch = encoded.charAt(i);
if (ch == "+") {
plaintext += " ";
i++;
} else if (ch == "%") {
if (i < (encoded.length-2)
&& HEXCHARS.indexOf(encoded.charAt(i+1)) != -1
&& HEXCHARS.indexOf(encoded.charAt(i+2)) != -1 ) {
plaintext += unescape( encoded.substr(i,3) );
i += 3;
} else {
alert( 'Bad escape combination near ...' + encoded.substr(i) );
plaintext += "%[ERROR]";
i++;
}
} else {
plaintext += ch;
i++;
}
} // while
return plaintext;
};