/***************************/
//@Author: Adrian "yEnS" Mato Gondelle & Ivan Guardado Castro
//@website: www.yensdesign.com
//@email: yensamg@gmail.com
//@license: Feel free to use it, but keep this credits please!					
/***************************/

$(document).ready(function(){
	//global vars
	var form = $("#customForm");
	var firstName = $("#firstName");
	var firstNameInfo = $("#firstNameInfo");
	var lastName = $("#lastName");
	var lastNameInfo = $("#lastNameInfo");
	var email = $("#email");
	var emailInfo = $("#emailInfo");
	var pass1 = $("#pass1");
	var pass1Info = $("#pass1Info");
	var pass2 = $("#pass2");
	var pass2Info = $("#pass2Info");
	var message = $("#message");
	
	//On blur
	firstName.blur(validateFirstName);
	lastName.blur(validateLastName);
	email.blur(validateEmail);
	pass1.blur(validatePass1);
	pass2.blur(validatePass2);
	//On key press
	firstName.keyup(validateFirstName);
	lastName.keyup(validateLastName);
	pass1.keyup(validatePass1);
	pass2.keyup(validatePass2);
	message.keyup(validateMessage);
	//On Submitting
	form.submit(function(){
		if(validateFirstName() & validateLastName() & validateEmail() & validatePass1() & validatePass2() )
			return true
		else
			return false;
	});
	
	//validation functions
	function validateEmail(){
		//testing regular expression
		var a = $("#email").val();
		var filter = /^[a-zA-Z0-9]+[a-zA-Z0-9_.-]+[a-zA-Z0-9_-]+@[a-zA-Z0-9]+[a-zA-Z0-9.-]+[a-zA-Z0-9]+.[a-z]{2,4}$/;
		//if it's valid email
		if(filter.test(a)){
			email.removeClass("error");
			emailInfo.text(text_valid_mail);
			emailInfo.removeClass("error");
			return true;
		}
		//if it's NOT valid
		else{
			email.addClass("error");
			emailInfo.text(text_type_valid_mail);
			emailInfo.addClass("error");
			return false;
		}
	}
	function validateFirstName(){
		//if it's NOT valid
		if(firstName.val().length < 4){
			firstName.addClass("error");
			firstNameInfo.text(text_type_first_name);
			firstNameInfo.addClass("error");
			return false;
		}
		//if it's valid
		else{
			firstName.removeClass("error");
			firstNameInfo.text(text_type_first_name);
			firstNameInfo.removeClass("error");
			return true;
		}
	}
	function validateLastName(){
		//if it's NOT valid
		if(lastName.val().length < 4){
			lastName.addClass("error");
			lastNameInfo.text(text_type_last_name);
			lastNameInfo.addClass("error");
			return false;
		}
		//if it's valid
		else{
			lastName.removeClass("error");
			lastNameInfo.text(text_type_last_name);
			lastNameInfo.removeClass("error");
			return true;
		}
	}
	function validatePass1(){
		var a = $("#password1");
		var b = $("#password2");

		//it's NOT valid
		if(pass1.val().length <5){
			pass1.addClass("error");
			pass1Info.text(text_min_characters);
			pass1Info.addClass("error");
			return false;
		}
		//it's valid
		else{			
			pass1.removeClass("error");
			pass1Info.text(text_min_characters);
			pass1Info.removeClass("error");
			validatePass2();
			return true;
		}
	}
	function validatePass2(){
		var a = $("#password1");
		var b = $("#password2");
		//are NOT valid
		if( pass1.val() != pass2.val() ){
			pass2.addClass("error");
			pass2Info.text(text_pass_not_match);
			pass2Info.addClass("error");
			return false;
		}
		//are valid
		else{
			pass2.removeClass("error");
			pass2Info.text(text_confirm_password);
			pass2Info.removeClass("error");
			return true;
		}
	}
	function validateMessage(){
		//it's NOT valid
		if(message.val().length < 10){
			message.addClass("error");
			return false;
		}
		//it's valid
		else{			
			message.removeClass("error");
			return true;
		}
	}
});
