
$(document).ready(function() {
	// SUCCESS AJAX CALL, replace "success: false," by:     success : function() { callSuccessFunction() }, 
	$("[class^=validate]").validationEngine({
		success : function() { callSuccessFunction() },
		failure : function() { callFailFunction() }
	})
});

var activePrompt = "";

jQuery.fn.validationEngine = function(settings) {
	if($.validationEngineLanguage){					// IS THERE A LANGUAGE LOCALISATION ?
		allRules = $.validationEngineLanguage.allRules
	}else{
		allRules = {"required":{    			  // Add your regex rules here, you can take telephone as an example
							"regex":"none",
							"alertText":"* This field is required",
							"alertTextCheckboxMultiple":"* Please select an option",
							"alertTextCheckboxe":"* This checkbox is required"},
						"length":{
							"regex":"none",
							"alertText":"*Between ",
							"alertText2":" and ",
							"alertText3": " characters allowed"},
						"minCheckbox":{
							"regex":"none",
							"alertText":"* Checks allowed Exceeded"},	
						"confirm":{
							"regex":"none",
							"alertText":"* Your field is not matching"},		
						"telephone":{
							"regex":"/^[0-9\-\(\)\ ]+$/",
							"alertText":"* Invalid phone number"},	
						"email":{
							"regex":"/^[a-zA-Z0-9_\.\-]+\@([a-zA-Z0-9\-]+\.)+[a-zA-Z0-9]{2,4}$/",
							"alertText":"* Invalid e-mail address"},	
						"date":{
                             "regex":"/^[0-9]{4}\-\[0-9]{1,2}\-\[0-9]{1,2}$/",
                             "alertText":"* Invalid date, must be in YYYY-MM-DD format"},
						"onlyNumber":{
							"regex":"/^[0-9\ ]+$/",
							"alertText":"* Numbers only"},	
						"noSpecialCaracters":{
							"regex":"/^[0-9a-zA-Z]+$/",
							"alertText":"* No special caracters allowed"},	
						"onlyLetter":{
							"regex":"/^[a-zA-Z\ \']+$/",
							"alertText":"* Letters only"}
					}	
	}

 	settings = jQuery.extend({
		allrules:allRules,
		success : false,
		failure : function() {}
	}, settings);	

	var counter = 0;
	var started = false;

	$("form").bind("submit", function(caller){   // ON FORM SUBMIT, CONTROL AJAX FUNCTION IF SPECIFIED ON DOCUMENT READY
		
		started = true;
		
		if(!submitValidation(this)){
			if (settings.success){
				settings.success && settings.success(); 
				return false;
			}
		}else{
			settings.failure && settings.failure(); 
			return false;
		}
		
	})
	
	
	
	
	
	$(this).bind("click", function(caller){loadValidation(this)});
	$(this).bind("focus", function(caller){loadValidation(this)});
	$(this+"[type=text]").unbind("click", function(caller){loadValidation(this)});
	
	$(this).bind("blur", function(caller){loadValidation(this,"blur")});
	
	/*
	if($(this.type == "text"){
		$(this).bind("blur", function(caller){loadValidation(this)})
	}else{
		if(document.all){
			$(this).not("[type=checkbox]").bind("mouseup", function(caller){loadValidation(this)})
			$(this).not("[type=checkbox]").bind("click", function(caller){loadValidation(this)})
		}
		
		$(this).not("[type=checkbox]").bind("change", function(caller){loadValidation(this)})
		//$(this).not("[type=checkbox]").bind("keyup", function(caller){loadValidation(this)})
	
		$(this).bind("click", function(caller){loadValidation(this)})
	}
	
	$(this).not("[type=checkbox]").bind("click", function(caller){loadValidation(this)})
	$(this).not("[type=checkbox]").bind("click", function(caller){loadValidation(this)})
	*/
	var border = "";
	
	var setRedBorder = function(caller){
		if(document.all) {
			$(caller).not("[type=radio]").parent().css({border:"1px solid red",padding:"0px" });
		}else{
			border = $(caller).css("border");
			$(caller).css("border","1px solid red");
			
			$(caller).parent().css({border:"1px solid red"});
			
			$(caller).not("[type=checkbox]").parent().css({border:"none"});
		}
		
		$(caller).parent().addClass("error")
		if($(caller).attr("type") == "radio") {
			$(document.getElementById("rdbProductModelNumber_0")).parent().addClass("error");
			$(document.getElementById("rdbProductModelNumber_1")).parent().addClass("error");
			$(document.getElementById("rdbProductModelNumber_2")).parent().addClass("error");
		}
		
	}
	
	
	
	var buildPrompt = function(caller,promptText,type) {			// ERROR PROMPT CREATION AND DISPLAY WHEN AN ERROR OCCUR
		
				
		var divFormError = document.createElement('div')
		var formErrorContent = document.createElement('div')
		var arrow = document.createElement('div')
		
		
		setRedBorder(caller);
		
		
		$(divFormError).addClass("formError")
		$(divFormError).addClass($(caller).attr("name"))
		$(formErrorContent).addClass("formErrorContent")
		$(arrow).addClass("formErrorArrow")

		$("body").append(divFormError);
		$(divFormError).append(arrow)
		$(divFormError).append(formErrorContent)
		$(arrow).html('<div class="line10"></div><div class="line9"></div><div class="line8"></div><div class="line7"></div><div class="line6"></div><div class="line5"></div><div class="line4"></div><div class="line3"></div><div class="line2"></div><div class="line1"></div>')
		$(formErrorContent).html(promptText)
		
		
		
		callerTopPosition = $(caller).offset().top;
		callerleftPosition = $(caller).offset().left;
		callerWidth =  $(caller).width()
		callerHeight =  $(caller).height()
		inputHeight = $(divFormError).height()

		callerleftPosition = callerleftPosition + callerWidth -30
		callerTopPosition = callerTopPosition  -inputHeight -10
	
		$(divFormError).css({
			top:callerTopPosition,
			left:callerleftPosition,
			opacity:0
		})
		
		/*if(!counter){
			$(divFormError).fadeTo("fast",0.8);
			$(divFormError).css("display","block");
			counter++;
		}else{*/
			$(divFormError).css("display","none");
		//}
		
		//if(counter) $(divFormError).css("visibility",hidden)
	};
	
	var updatePromptText = function(caller,promptText,type) {	// UPDATE TEXT ERROR IF AN ERROR IS ALREADY DISPLAYED
		
		//hide active prompt
		if(activePrompt!=""){
			if(($("."+activePrompt).size())){
				$("."+activePrompt).css("display","none");
				counter=0;
			}
		}
		
		if(type=="blur") return false;
			
				
		updateThisPrompt =  $(caller).attr("name");
		$("."+updateThisPrompt).find(".formErrorContent").html(promptText)
		
		
		if(!counter && $(caller).attr("type") != "radio") {
			$("."+updateThisPrompt).fadeTo("fast",0.8);
			$("."+updateThisPrompt).css("display","block");
			counter++;
		}
		
		activePrompt = updateThisPrompt;
		
		callerTopPosition  = $(caller).offset().top;
		callerleftPosition = $(caller).offset().left;
		callerWidth =  $(caller).width()
		callerHeight =  $(caller).height()
		
		inputHeight = $("."+updateThisPrompt).height()
		
		callerTopPosition = callerTopPosition  -inputHeight -10;
		callerleftPosition = callerleftPosition + callerWidth -30;
		$("."+updateThisPrompt).css({top:callerTopPosition,left:callerleftPosition});
	}
	var loadValidation = function(caller,type) {		// GET VALIDATIONS TO BE EXECUTED
		
		if(!started) return false;
		
		rulesParsing = $(caller).attr('class');
		rulesRegExp = /\[(.*)\]/;
		getRules = rulesRegExp.exec(rulesParsing);
		str = getRules[1]
		pattern = /\W+/;
		result= str.split(pattern);	
		
		
		var validateCalll = validateCall(caller,result,type)
		return validateCalll
		
	};
	var validateCall = function(caller,rules,type) {	// EXECUTE VALIDATION REQUIRED BY THE USER FOR THIS FILED
		var promptText =""	
		var prompt = $(caller).attr("name");
		var caller = caller;
		
		
		isError = false;
		callerType = $(caller).attr("type");
		
		for (i=0; i<rules.length;i++){
			switch (rules[i]){
			case "optional": 
				if(!$(caller).val()){
					closePrompt(caller)
					return isError
				}
			break;
			case "required": 
				_required(caller,rules);
			break;
			case "custom": 
				 _customRegex(caller,rules,i);
			break;
			case "length": 
				 _length(caller,rules,i);
			break;
			case "minCheckbox": 
				 _minCheckbox(caller,rules,i);
			break;
			case "confirm": 
				 _confirm(caller,rules,i);
			break;
			default :;
			};
		};
		
		if (isError == true){
			
			if($("input[name="+prompt+"]").size()> 1 && callerType == "radio") {		// Hack for radio group button, the validation go the first radio
				caller = $("input[name="+prompt+"]:first")
				
			}
				
				
			
			($("."+prompt).size() ==0) ? buildPrompt(caller,promptText,type)	: updatePromptText(caller,promptText,type);
			
		
		
		
			
		}else{
			
			closePromptBorder(caller);
			closePrompt(caller)
			
		}		
		
		/* VALIDATION FUNCTIONS */
		function _required(caller,rules){   // VALIDATE BLANK FIELD
			callerType = $(caller).attr("type")
			
			if (callerType == "text" || callerType == "password" || callerType == "textarea"){
				
				if(!$(caller).val()){
					isError = true
					promptText += settings.allrules[rules[i]].alertText+"<br />"
				}	
			}
			if (callerType == "radio" || callerType == "checkbox" ){
				callerName = $(caller).attr("name")
		
				if($("input[name="+callerName+"]:checked").size() == 0) {
					isError = true
					if($("input[name="+callerName+"]").size() ==1) {
						promptText += settings.allrules[rules[i]].alertTextCheckboxe+"<br />" 
					}else{
						 promptText += settings.allrules[rules[i]].alertTextCheckboxMultiple+"<br />"
					}	
				}
			}	
			if (callerType == "select-one") { // added by paul@kinetek.net for select boxes, Thank you
					callerName = $(caller).attr("name");
				
				if(!$("select[name="+callerName+"]").val()) {
					isError = true;
					promptText += settings.allrules[rules[i]].alertText+"<br />";
				}
			}
			if (callerType == "select-multiple") { // added by paul@kinetek.net for select boxes, Thank you
					callerName = $(caller).attr("id");
				
				if(!$("#"+callerName).val()) {
					isError = true;
					promptText += settings.allrules[rules[i]].alertText+"<br />";
				}
			}
		}
		function _customRegex(caller,rules,position){		 // VALIDATE REGEX RULES
			customRule = rules[position+1]
			pattern = eval(settings.allrules[customRule].regex)
			
			if(!pattern.test($(caller).attr('value'))){
				isError = true
				promptText += settings.allrules[customRule].alertText+"<br />"
			}
		}
		function _confirm(caller,rules,position){		 // VALIDATE FIELD MATCH
			confirmField = rules[position+1]
			
			if($(caller).attr('value') != $("#"+confirmField).attr('value')){
				isError = true
				promptText += settings.allrules["confirm"].alertText+"<br />"
			}
		}
		function _length(caller,rules,position){    // VALIDATE LENGTH
		
			startLength = eval(rules[position+1])
			endLength = eval(rules[position+2])
			feildLength = $(caller).attr('value').length

			if(feildLength<startLength || feildLength>endLength){
				isError = true
				promptText += settings.allrules["length"].alertText+startLength+settings.allrules["length"].alertText2+endLength+settings.allrules["length"].alertText3+"<br />"
			}
		}
		function _minCheckbox(caller,rules,position){    // VALIDATE CHECKBOX NUMBER
		
			nbCheck = eval(rules[position+1])
			groupname = $(caller).attr("name")
			groupSize = $("input[name="+groupname+"]:checked").size()
			
			if(groupSize > nbCheck){	
				isError = true
				promptText += settings.allrules["minCheckbox"].alertText+"<br />"
			}
		}

		return(isError) ? isError : false;
	};
	var closePrompt = function(caller) {	// CLOSE PROMPT WHEN ERROR CORRECTED
		closingPrompt = $(caller).attr("name")
		
		//if(document.all) $(caller).css("border","1px solid ");
		
		
		
		$("."+closingPrompt).fadeTo("fast",0,function(){
			$("."+closingPrompt).remove()
			counter = 0;
		});
		
	};
	
	var closePromptBorder = function(caller) {	// CLOSE PROMPT WHEN ERROR CORRECTED
		
		
		if(document.all) {
			$(caller).parent().css("border","none");
			//$(caller).not("[type=radio]").parent().css("padding","0px");
			
			//$(caller+"[type=radio]").css("border","none");
		}else{
			$(caller).css("border",border);
			$(caller).parent().css({border:"none"});
			
				
			
		}
		
		if(document.getElementById("rdbProductModelNumber_0").checked || document.getElementById("rdbProductModelNumber_1").checked || document.getElementById("rdbProductModelNumber_2").checked){
			$(document.getElementById("rdbProductModelNumber_0")).parent().removeClass("error");
			$(document.getElementById("rdbProductModelNumber_1")).parent().removeClass("error");
			$(document.getElementById("rdbProductModelNumber_2")).parent().removeClass("error");
		}
		
		$(caller).parent().removeClass("error")
		
	};
	
	
	var submitValidation = function(caller) {	// FORM SUBMIT VALIDATION LOOPING INLINE VALIDATION
		var stopForm = false
		
		
		$(caller).find(".formError").remove();
		
		var toValidateSize = $(caller).find("[class^=validate]").size()
		
		$(caller).find("[class^=validate]").each(function(){
			
			
			
		if(document.getElementById("voucherForm").style.display =="none"){
				
				
				
				switch($(this).attr("id")){
					case "voucherForm1":
					case "voucherForm2":
					case "voucherForm3":
					case "voucherForm4":
						//setRedBorder(this);
						return "";
						break;
						
				}
			}
			
			var validationPass = loadValidation(this)
			return(validationPass) ? stopForm = true : "";	
		});
		
		
		if(stopForm){							// GET IF THERE IS AN ERROR OR NOT FROM THIS VALIDATION FUNCTIONS
			destination = $(".formError:first").offset().top;
			$("html:not(:animated),body:not(:animated)").animate({ scrollTop: destination}, 1100)
			return true;
		}else{
			return false
		}
	};
};