// ===================================================================
// Author: Matt Kruse <matt@mattkruse.com>
// WWW: http://www.mattkruse.com/
//
// NOTICE: You may use this code for any purpose, commercial or
// private, without any further permission from the author. You may
// remove this notice from your final code if you wish, however it is
// appreciated by the author if at least my web site address is kept.
//
// You may *NOT* re-distribute this code in any way except through its
// use. That means, you can include it in your product, or your web
// site, or any other form where the code is actually being used. You
// may not put the plain javascript up on your site for download or
// include it in your javascript libraries for download. 
// If you wish to share this code with others, please just point them
// to the URL instead.
// Please DO NOT link directly to my .js files from your site. Copy
// the files to your server and use them there. Thank you.
// ===================================================================

var MONTH_NAMES=new Array('January','February','March','April','May','June','July','August','September','October','November','December','Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec');var DAY_NAMES=new Array('Sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday','Sun','Mon','Tue','Wed','Thu','Fri','Sat');
function LZ(x){return(x<0||x>9?"":"0")+x}
function isDate(val,format){var date=getDateFromFormat(val,format);if(date==0){return false;}return true;}
function compareDates(date1,dateformat1,date2,dateformat2){var d1=getDateFromFormat(date1,dateformat1);var d2=getDateFromFormat(date2,dateformat2);if(d1==0 || d2==0){return -1;}else if(d1 > d2){return 1;}return 0;}
function formatDate(date,format){format=format+"";var result="";var i_format=0;var c="";var token="";var y=date.getYear()+"";var M=date.getMonth()+1;var d=date.getDate();var E=date.getDay();var H=date.getHours();var m=date.getMinutes();var s=date.getSeconds();var yyyy,yy,MMM,MM,dd,hh,h,mm,ss,ampm,HH,H,KK,K,kk,k;var value=new Object();if(y.length < 4){y=""+(y-0+1900);}value["y"]=""+y;value["yyyy"]=y;value["yy"]=y.substring(2,4);value["M"]=M;value["MM"]=LZ(M);value["MMM"]=MONTH_NAMES[M-1];value["NNN"]=MONTH_NAMES[M+11];value["d"]=d;value["dd"]=LZ(d);value["E"]=DAY_NAMES[E+7];value["EE"]=DAY_NAMES[E];value["H"]=H;value["HH"]=LZ(H);if(H==0){value["h"]=12;}else if(H>12){value["h"]=H-12;}else{value["h"]=H;}value["hh"]=LZ(value["h"]);if(H>11){value["K"]=H-12;}else{value["K"]=H;}value["k"]=H+1;value["KK"]=LZ(value["K"]);value["kk"]=LZ(value["k"]);if(H > 11){value["a"]="PM";}else{value["a"]="AM";}value["m"]=m;value["mm"]=LZ(m);value["s"]=s;value["ss"]=LZ(s);while(i_format < format.length){c=format.charAt(i_format);token="";while((format.charAt(i_format)==c) &&(i_format < format.length)){token += format.charAt(i_format++);}if(value[token] != null){result=result + value[token];}else{result=result + token;}}return result;}
function _isInteger(val){var digits="1234567890";for(var i=0;i < val.length;i++){if(digits.indexOf(val.charAt(i))==-1){return false;}}return true;}
function _getInt(str,i,minlength,maxlength){for(var x=maxlength;x>=minlength;x--){var token=str.substring(i,i+x);if(token.length < minlength){return null;}if(_isInteger(token)){return token;}}return null;}
function getDateFromFormat(val,format){val=val+"";format=format+"";var i_val=0;var i_format=0;var c="";var token="";var token2="";var x,y;var now=new Date();var year=now.getYear();var month=now.getMonth()+1;var date=1;var hh=now.getHours();var mm=now.getMinutes();var ss=now.getSeconds();var ampm="";while(i_format < format.length){c=format.charAt(i_format);token="";while((format.charAt(i_format)==c) &&(i_format < format.length)){token += format.charAt(i_format++);}if(token=="yyyy" || token=="yy" || token=="y"){if(token=="yyyy"){x=4;y=4;}if(token=="yy"){x=2;y=2;}if(token=="y"){x=2;y=4;}year=_getInt(val,i_val,x,y);if(year==null){return 0;}i_val += year.length;if(year.length==2){if(year > 70){year=1900+(year-0);}else{year=2000+(year-0);}}}else if(token=="MMM"||token=="NNN"){month=0;for(var i=0;i<MONTH_NAMES.length;i++){var month_name=MONTH_NAMES[i];if(val.substring(i_val,i_val+month_name.length).toLowerCase()==month_name.toLowerCase()){if(token=="MMM"||(token=="NNN"&&i>11)){month=i+1;if(month>12){month -= 12;}i_val += month_name.length;break;}}}if((month < 1)||(month>12)){return 0;}}else if(token=="EE"||token=="E"){for(var i=0;i<DAY_NAMES.length;i++){var day_name=DAY_NAMES[i];if(val.substring(i_val,i_val+day_name.length).toLowerCase()==day_name.toLowerCase()){i_val += day_name.length;break;}}}else if(token=="MM"||token=="M"){month=_getInt(val,i_val,token.length,2);if(month==null||(month<1)||(month>12)){return 0;}i_val+=month.length;}else if(token=="dd"||token=="d"){date=_getInt(val,i_val,token.length,2);if(date==null||(date<1)||(date>31)){return 0;}i_val+=date.length;}else if(token=="hh"||token=="h"){hh=_getInt(val,i_val,token.length,2);if(hh==null||(hh<1)||(hh>12)){return 0;}i_val+=hh.length;}else if(token=="HH"||token=="H"){hh=_getInt(val,i_val,token.length,2);if(hh==null||(hh<0)||(hh>23)){return 0;}i_val+=hh.length;}else if(token=="KK"||token=="K"){hh=_getInt(val,i_val,token.length,2);if(hh==null||(hh<0)||(hh>11)){return 0;}i_val+=hh.length;}else if(token=="kk"||token=="k"){hh=_getInt(val,i_val,token.length,2);if(hh==null||(hh<1)||(hh>24)){return 0;}i_val+=hh.length;hh--;}else if(token=="mm"||token=="m"){mm=_getInt(val,i_val,token.length,2);if(mm==null||(mm<0)||(mm>59)){return 0;}i_val+=mm.length;}else if(token=="ss"||token=="s"){ss=_getInt(val,i_val,token.length,2);if(ss==null||(ss<0)||(ss>59)){return 0;}i_val+=ss.length;}else if(token=="a"){if(val.substring(i_val,i_val+2).toLowerCase()=="am"){ampm="AM";}else if(val.substring(i_val,i_val+2).toLowerCase()=="pm"){ampm="PM";}else{return 0;}i_val+=2;}else{if(val.substring(i_val,i_val+token.length)!=token){return 0;}else{i_val+=token.length;}}}if(i_val != val.length){return 0;}if(month==2){if( ((year%4==0)&&(year%100 != 0) ) ||(year%400==0) ){if(date > 29){return 0;}}else{if(date > 28){return 0;}}}if((month==4)||(month==6)||(month==9)||(month==11)){if(date > 30){return 0;}}if(hh<12 && ampm=="PM"){hh=hh-0+12;}else if(hh>11 && ampm=="AM"){hh-=12;}var newdate=new Date(year,month-1,date,hh,mm,ss);return newdate.getTime();}
function parseDate(val){var preferEuro=(arguments.length==2)?arguments[1]:false;generalFormats=new Array('y-M-d','MMM d, y','MMM d,y','y-MMM-d','d-MMM-y','MMM d');monthFirst=new Array('M/d/y','M-d-y','M.d.y','MMM-d','M/d','M-d');dateFirst =new Array('d/M/y','d-M-y','d.M.y','d-MMM','d/M','d-M');var checkList=new Array('generalFormats',preferEuro?'dateFirst':'monthFirst',preferEuro?'monthFirst':'dateFirst');var d=null;for(var i=0;i<checkList.length;i++){var l=window[checkList[i]];for(var j=0;j<l.length;j++){d=getDateFromFormat(val,l[j]);if(d!=0){return new Date(d);}}}return null;}

//reguliere expressie voor het controleren van datums, emails, 
var regDatum    = /^(((0[1-9]|[12]\d|3[01])\/(0[13578]|1[02])\/((19|[2-9]\d)\d{2}))|((0[1-9]|[12]\d|30)\/(0[13456789]|1[012])\/((19|[2-9]\d)\d{2}))|((0[1-9]|1\d|2[0-8])\/02\/((19|[2-9]\d)\d{2}))|(29\/02\/((1[6-9]|[2-9]\d)(0[48]|[2468][048]|[13579][26])|((16|[2468][048]|[3579][26])00))))$/;
var emailReg    = /^[A-Za-z0-9](([_\.\-]?[a-zA-Z0-9]+)*)@([A-Za-z0-9]+)(([\.\-]?[a-zA-Z0-9]+)*)\.([A-Za-z]{2,})$/;
var postalReg   =/^[1-9][0-9]{3}\s?[a-zA-Z]{2}$/;
var htmlColorReg= /^(#){1}([a-fA-F0-9]){6}$/;
var numberReg   = /^[-+]?[0-9]\d*(\.\d*)?%?$/;

//functie die de html color controleert
function isHTMLColor(pstrColor){
	if(!pstrColor.match(htmlColorReg)){
		return false;
	}
	return true;
}
//functie die controleert of een string numeriek is
function isNumeric(pstrNumber, guiName){
	if(!pstrNumber.match(numberReg)){
		errormsg(2, guiName);
		return false;
	}
	return true;
}
//functie die controleert of een string phone is
function isPhone(field){
	field.value = field.value.replace(/\s/g, '')
}
//functie die controleert of een string postcode is
function isPostal(field, guiName){
	field.value = field.value.replace(/\s/g, '')
	if(!field.value.match(postalReg)){
		errormsg(2, guiName);
		return false;
	}
	return true;
}
//functie die een datum van 01-01-2006 converteerd naar 01/01/2006
function convertDate(pDate){
	var varrTmp = new Array();
	if(pDate.indexOf('-')>0){
		varrTmp = pDate.split('-');
	}else{
		varrTmp = pDate.split('/');
	};

	var vday;
	var vmonth;
	var vyear;

	varrTmp[0] *= 1;
	varrTmp[1] *= 1;
	varrTmp[2] *= 1;
	
	if(varrTmp[0]<10){
		vday='0'+varrTmp[0];
	}else{
		vday=varrTmp[0];
	}
	if(varrTmp[1]<10){
		vmonth='0'+(varrTmp[1]);
	}else{
		vmonth=(varrTmp[1]);
	}

	return vday+'/'+vmonth+'/'+varrTmp[2];
}
//functie die valideerd of een email correct is.
function IsEmail(pstrEmail){
	//controle of email adres goed is ingevuld
	if(!pstrEmail.match(emailReg)){
		return false;
	}
	return true;
}
function checkDate(pdtVan,pdtTot){									
	//controle of de dtPeriodeVan groter is dan dtPeriodeTot
	//alert(compareDates(pdtVan,"dd-mm-yyyy",pdtTot,"dd-mm-yyyy"));
	if(compareDates(pdtVan,"dd/mm/yyyy",pdtTot,"dd/mm/yyyy")==1){
		return 1;
	}
	if(compareDates(pdtVan,"dd/mm/yyyy",pdtTot,"dd/mm/yyyy")==0){
		return 0;
	}
	if(compareDates(pdtVan,"dd/mm/yyyy",pdtTot,"dd/mm/yyyy")==-1){
		return -1;
	}
}
function createDate(){
	var d = new Date();
	var vday;
	var vmonth;

	if(d.getDate()<10){
		vday='0'+d.getDate();
	}else{
		vday=d.getDate();
	}
	if((d.getMonth()+1)<10){
		vmonth='0'+(d.getMonth()+1);
	}else{
		vmonth=(d.getMonth()+1);
	}
	return vday+'-'+vmonth+'-'+d.getYear()
}
function trimAll(psString){
	while (psString.substring(0,1) == ' '){
		psString = psString.substring(1, psString.length);
	}
	while (psString.substring(psString.length-1, psString.length) == ' '){
		psString = psString.substring(0,psString.length-1);
	}
	return psString;
};
//***************************************************************************************
//Omschr	:	Functie die een e-mailadres controle op juistheid
//Datum		:	8-3-2006
//Versie	:	1
//Naam		:	Ronald
//***************************************************************************************
function isFormat(pstrField, guiName, bRequired, bFormat, pstrDateField){
	//email adres wordt gecontroleerd
	if((bFormat!="date" && pstrField.value != "")||(bFormat=="date" && pstrField!="")){
		var vFormat = "";
		switch(bFormat){
			case "email":
				vFormat = emailReg;
				break;
			case "postal":
				vFormat = postalReg;
				break;
			case "number":
				vFormat = numberReg;
				break;
			case "phone":
				vFormat = phoneReg;
				break;
			case "date":
				vFormat = regDatum;
				break;
		};
		if(bFormat=="date"){
			var tmp  = pstrField.replace(/-/g,'/');
			if(!tmp.match(vFormat)){
				errormsg(2,guiName);
				if(pstrDateField.focus) {pstrDateField.focus();}
				return false;
			};
		}else{
			if(!trimAll(pstrField.value).match(vFormat)){
				errormsg(2,guiName);
				if(pstrField.focus) {pstrField.focus();}
				return false;
			};
		}
	}else{
		if(bRequired==true){
			errormsg(1, guiName);	
			if(pstrField.focus) {pstrField.focus();}
			return false;
		};
	};
	return true;
}
//***************************************************************************************
//Omschr		:	Functie die een groep checkbozen controleert of er 1 is aangevinkt
//Date			:	7-6-2006
//Versie		:	1
//Naam			:	Ronald Buijs
//***************************************************************************************
function isChecked(pstrForm,pstrID,guiName,pstrHiddenValueField,bIsRequired){
	var frmElements = pstrForm.elements;
	
	var intCount=0;
	var strWaarde="";

	for(i=0;i<frmElements.length; i++){
		if(frmElements[i].type=="checkbox"&&frmElements[i].id==pstrID){
			if(frmElements[i].checked==true){
				intCount++;
				strWaarde += frmElements[i].value + ',';

			};
		};
	};
	if(intCount==0){
		if(bIsRequired==true){
			errormsg(1,guiName);
			return false;
		};
	}else{
		pstrHiddenValueField.value = strWaarde;	
	};
	return true;
};
//2 functies van Yohan YLab
function isNotNull(field, guiName){
	//validates if a field contains a value
  //field: input element text|hidden
  //guiName: fieldname to communicate with user
	if ( (!field.value) || (field.value == "") )	{
		errormsg(1, guiName);
		if(field.focus) {field.focus();}
		return false;
	}
	return true;
}

function isRadio(field,guiName){
	ch = false;
	for(i=0;i<field.length;i++){
		if(field[i].checked)ch = true
	}
	if(!ch)errormsg(1, guiName);
	return ch;
}
function errormsg(errorcode, guiName, val){
	switch (errorcode){
		case 1: alert('Het veld \'' + guiName + '\' moet ingevuld zijn.'); break;
		case 2: alert('Het veld \''+guiName+'\' is ongeldig.'); break;
		default: alert('Ongedefineerde foutcode: ' + errorcode); break;
  }
}

