/***************************************************************************************************/
/********* VALIDADOR DE FORMULARIOS ****************************************************************/
/********* JOSE IGNACIO MARCOS PEREZ - DIGIVAL.ES  *************************************************/
/***************************************************************************************************/
function init_form(){
	var formu = document.forms;
	for(i=0;i<formu.length;i++){
		formu[i].onsubmit = function(){ 
			if(validaForm(this)){
				return true;
			}else{
				return false;
			}
		}
	}
};
/***************************************************************************************************/
/********* VALIDA FORMS ****************************************************************************/
/***************************************************************************************************/
var falloValida;

function validaForm(f){
	falloValida = 0;
	// COMPRUEBO LOS OBLIGATORIOS ***************************************
	if(getElementsByClass('obligatorio', null, f)){
		var c_ob = getElementsByClass('obligatorio', null, f);
		for(o=0;o<c_ob.length;o++){
			if(!val_vacio(c_ob[o].value)){
				error('Campo obligatorio.', c_ob[o]);
			}else{
				limpiaerror(c_ob[o]);
			}
		}
	}
	// ******************************************************************
	
	// COMPRUEBO EL USUARIO ***************************************
	if(getElementsByClass('ob_user', null, f)){
		var c_ob_user = getElementsByClass('ob_user', null, f);
		for(us=0;us<c_ob_user.length;us++){
			if(!val_vacio(c_ob_user[us].value)){
				error('Campo obligatorio.', c_ob_user[us]);
			}else	if(c_ob_user[us].value.length<4 || c_ob_user[us].value.length>10) {
				error("El campo debe tener entre 4 y 10 caracteres", c_ob_user[us]);
			}else{
				limpiaerror(c_ob_user[us]);
			}
		}
	}
	// ******************************************************************
	
	// COMPRUEBO QUE EL CAMPO SEA NUMERICO ******************************
	if(getElementsByClass('ob_num', null, f)){
		var c_ob_num = getElementsByClass('ob_num', null, f);
		for(n=0;n<c_ob_num.length;n++){
			if(!numerico(c_ob_num[n].value)) {
				error("El campo no es numerico", c_ob_num[n]);
			}else	if(!val_vacio(c_ob_num[n].value)){
				error('Campo obligatorio.', c_ob_num[n]);
			}else{
				limpiaerror(c_ob_num[n]);
			}
		}
	}
	// COMPRUEBO QUE EL CAMPO SEA NUMERICO PARA DECIMALES******************************
	if(getElementsByClass('ob_numdec', null, f)){
		var c_ob_numdec = getElementsByClass('ob_numdec', null, f);
		for(n=0;n<c_ob_numdec.length;n++){
			if(!numericodecimal(c_ob_numdec[n].value)) {
				error("El campo no es numerico", c_ob_numdec[n]);
			}else	if(!val_vacio(c_ob_numdec[n].value)){
				error('Campo obligatorio.', c_ob_numdec[n]);
			}else{
				limpiaerror(c_ob_numdec[n]);
			}
		}
	}
	// ******************************************************************

	// COMPRUEBO SI REPETIR CONTRASEŅA ES IGUAL A LA CONTRASEŅA**********
	if(getElementsByClass('ob_repcon',null,f)!=""){
		var c_ob_repcon = getElementsByClass('ob_repcon',null,f);
		var c_ob_contra = getElementsByClass('password',null,f);
		for(us=0;us<c_ob_repcon.length;us++){
			if(!val_vacio(c_ob_repcon[us].value)){
				error('Campo obligatorio.', c_ob_repcon[us]);
			}else if(c_ob_repcon[us].value.length<4 || c_ob_repcon[us].value.length>10) {
				error("El campo debe tener entre 4 y 10 caracteres ", c_ob_repcon[us]);
			}else if(c_ob_repcon[us].value!=c_ob_contra[us].value) {
				error("El campo contrasena y repetir contrasena no son iguales", c_ob_repcon[us]);
			}else{
				limpiaerror(c_ob_repcon[us]);
			}
		}
	}
	// COMPRUEBO LOS EMAILS *********************************************
	if(getElementsByClass('ob_email', null, f)){
		var c_ob_email = getElementsByClass('ob_email', null, f);
		for(em=0;em<c_ob_email.length;em++){
			if (!validateEmail(c_ob_email[em].value)) {
				error("Se necesita un email v&aacute;lido.", c_ob_email[em]);
			}else if(!val_vacio(c_ob_email[em].value)){
				error('Campo obligatorio.', c_ob_email[em]);
			}else{
				limpiaerror(c_ob_email[em]);
			}
		}
	}
	// ******************************************************************
	
	// COMPRUEBO QUE LA IMAGEN SEA jpg******************************
	if(getElementsByClass('ob_imagen', null, f)){
		var c_ob_imagenOri = getElementsByClass('ob_imagen', null, f);
		for(im=0;im<c_ob_imagenOri.length;im++){
			if(c_ob_imagenOri[im].value==""){
				error('Campo obligatorio.', c_ob_imagenOri[im]);
			}else{
				var ext=c_ob_imagenOri[im].value.substr(c_ob_imagenOri[im].value.length-3,c_ob_imagenOri[im].value.length);
				if((ext == 'jpg')||(ext == 'JPG')) {
					limpiaerror(c_ob_imagenOri[im]);
				}else{
					error("La imagen no es jpg", c_ob_imagenOri[im]);
				}
			}
		}
	}

	// COMPRUEBO LAS URL ************************************************
	if(getElementsByClass('ob_url', null, f)){
		var c_ob_url = getElementsByClass('ob_url', null, f);
		var urlExp = /http:\/\//i;
		for(u=0;u<c_ob_url.length;u++){
    		 if(c_ob_url[u].value.length<4 || c_ob_url[u].value.indexOf(".") < 1){
				error("El dominio no es v&aacute;lido", c_ob_url[u]);
			}else if(!urlExp.test(c_ob_url[u].value)) {
				var texto = c_ob_url[u].value;
				c_ob_url[u].value ='http://'+texto;
				limpiaerror(c_ob_url[u]);
			}else{
				limpiaerror(c_ob_url[u]);
			}
		}
	}
	// ******************************************************************
	
	// COMPRUEBO LOS CHECKBOX O RADIOS - AL MENOS UNO MARCADO ***********
	if(getElementsByClass('ob_radios', null, f)){
		var c_ob_radios = getElementsByClass('ob_radios', null, f);
		for(r=0;r<c_ob_radios.length;r++){
			if(!(c_ob_radios[r].checked)){
				error('Debe aceptar las condiciones.', c_ob_radios[r]);
			}else{
				limpiaerror(c_ob_radios[r]);
			}
		}
	}
	// ******************************************************************
	
	// VALIDACION DE NUMERO DE CUENTA CORRIENTE *************************
	if(getElementsByClass('ob_ccc', null, f)){
		var c_ob_ccc = getElementsByClass('ob_ccc', null, f);
		for(c=0;c<c_ob_ccc.length;c++){
			if(c_ob_ccc[c].value.length!=20){
				error("El numero de cuenta de constar de 20 numeros", c_ob_ccc[c]);
			}else if (!numerico(c_ob_ccc[c].value)){
				error("Por favor, introduzca correctamente los datos, no son numericos", c_ob_ccc[c]);
			}else{
				var banco2= c_ob_ccc[c].value.substring(0,4);
				var sucursal2= c_ob_ccc[c].value.substring(4,8);
				var dc2= c_ob_ccc[c].value.substring(8,10);
				var cuenta2= c_ob_ccc[c].value.substring(10);
				if (!(obtenerDigito("00" + banco2 + sucursal2) == parseInt(dc2.charAt(0))) || 
					 !(obtenerDigito(cuenta2) == parseInt(dc2.charAt(1)))) {
				  error("Los digitos de control no se corresponden con los demas numeros", c_ob_ccc[c]);
				}else{
					limpiaerror(c_ob_ccc[c]);
				} 
			}
		}
	}
	// ******************************************************************
	if(falloValida == 1) return false;
	else return true;
}

/***************************************************************************************************/
/********* FUNCION DE ERROR ************************************************************************/
/***************************************************************************************************/
function error(err, campo){
	if(campo.parentNode.lastChild.tagName == 'SPAN'){
		campo.parentNode.lastChild.firstChild.nodeValue = err;
	}else{
		var error = document.createElement('span');
		error.className = "errorForm";
		error.innerHTML = err;
		campo.parentNode.appendChild(error);
	}
	falloValida = 1;
}
function limpiaerror(campo){
	if(campo.parentNode.lastChild.tagName == 'SPAN'){
			campo.parentNode.removeChild(campo.parentNode.lastChild);
	}
}
/***************************************************************************************************/
/********* VALIDACION DE CAMPO VACIO ***************************************************************/
/***************************************************************************************************/
function val_vacio(obj){
	if(obj== null || obj.length == 0) return false;
	else return true;
}
/***************************************************************************************************/
/********* VALIDACION DE EMAIL *********************************************************************/
/***************************************************************************************************/
function validateEmail(email) {
	var emailExp = /^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w{2,4})+$/;
	if(emailExp.test(email)) return true;
	else return false;
 }
/***************************************************************************************************/
/********* VALIDACION DE CCC ***********************************************************************/
/***************************************************************************************************/
function obtenerDigito(valor){
	  valores = new Array(1, 2, 4, 8, 5, 10, 9, 7, 3, 6);
	  control = 0;
	  for (i=0; i<=9; i++)
		control += parseInt(valor.charAt(i)) * valores[i];
	  control = 11 - (control % 11);
	  if (control == 11) control = 0;
	  else if (control == 10) control = 1;
	  return control;
}
/***************************************************************************************************/
/********* VALIDACION DE ALFANUMERICO  ***********************************************************/
/***************************************************************************************************/
function alfanumerico(valor){
	  cad = valor.toString();
	  for (var i=0; i<cad.length; i++) {
			var caracter = cad.charAt(i);
			if (!((caracter>"0" && caracter<"9") || (caracter>"a" && caracter<"z") || (caracter>"A" && caracter<"Z"))){
				return false;
			}
		}
	  return true;
}

/***************************************************************************************************/
/********* VALIDACION DE CAMPO NUMERICO  ***********************************************************/
/***************************************************************************************************/
function numerico(valor){
	  cad = valor.toString();
	  for (var i=0; i<cad.length; i++) {
		var caracter = cad.charAt(i);
		if (caracter<"0" || caracter>"9")
		  return false;
	  }
	  return true;
}

function numericodecimal(valor){
	  cad = valor.toString();
	  for (var i=0; i<cad.length; i++) {
		var caracter = cad.charAt(i);
		if (caracter<"0" || caracter>"9"){
			if (caracter!="," && caracter!=".")
				return false;
		}
	  }
	  return true;
}
/***************************************************************************************************/
/********* GET ELEMENTS BY CLASS *******************************************************************/
/***************************************************************************************************/
function getElementsByClass(ClassName,tagName,parentElement){
		 var elements=new Array();
		 var d=parentElement ? parentElement : document;
		 var allElements;
	
		 if(tagName)
		   allElements=d.all && d.all.tags(tagName)
		    || d.getElementsByTagName && d.getElementsByTagName(tagName);
		 else allElements=d.all || d.getElementsByTagName("*");
		 
		 for(var i=0,len=allElements.length; i<len; i++){ 
		  //modificacion para coger el nombre de una clase cuando tiene varias asignadas
			var cad=allElements[i].className.split(' ');
			for(y=0;y<cad.length; y++) {
	         if(cad[y]==ClassName)
		   		elements[elements.length]=allElements[i];
	      }
		 }
		 return elements;
};
/***************************************************************************************************/
/********* EVENT LISTENER BY SCOTT ANDREW (WWW.SCOTTANDREW.COM) ************************************/
/***************************************************************************************************/
function addEvent(obj, evType, fn, useCapture){
  if (obj.addEventListener){
    obj.addEventListener(evType, fn, useCapture);
    return true;
  } else if (obj.attachEvent){
    var r = obj.attachEvent("on"+evType, fn);
    return r;
  } else {
    alert("Handler could not be attached");
  }
};
/***************************************************************************************************/
/********* EVENTO ON LOAD **************************************************************************/
/***************************************************************************************************/
if (document.getElementsByTagName) addEvent(window, 'load', init_form, false);