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; };