// JavaScript Document
// ----------------------------------------------------------------------
//           FormCheq.js (c) ChaTo [www.chato.cl] 1998
//           basado en FormChek.js (c) Eric Krock 1997 Netscape Corp.
// ----------------------------------------------------------------------
// Rutinas para verificacion de formularios, basado en FormChek.js
// Parte del curso "TEJEDORES DEL WEB" http://www.TejedoresDelWeb.com/
// ---------------------------------------------------------------------- 

//VARs que ya estaban
var defaultEmptyOK = false;
var checkNiceness = true;
var digits = "0123456789";
var lowercaseLetters = "abcdefghijklmnopqrstuvwxyzáéíóúñüªº.-/,âêîôû"
var uppercaseLetters = "ABCDEFGHIJKLMNOPQRSTUVWXYZÁÉÍÓÚÑÂÊÎÔÛ"
var whitespace = " \t\n\r";
var phoneChars = "()-+ ";
var DNIChars = "abcdefghijklmnopqrstuvwxyzáéíóúñüªº.-/,âêîôûABCDEFGHIJKLMNOPQRSTUVWXYZÁÉÍÓÚÑÂÊÎÔÛ";
var NumTarjChars = "-";

//VARs que he puesto yo
var msg_final = '';
var elprimero = ''; //ElPrimero a efectos del primer campo que falla para que el cursor se ponga ahí para rectificar
var hayqueponerseen = '';
var havalidado = '0';

//FUNCTIONs que ya estaban
function isEmpty(s)
{   return ((s == null) || (s.length == 0))
}

function isWhitespace (s)
{   var i;
    if (isEmpty(s)) return true;
    for (i = 0; i < s.length; i++)
    {   
        var c = s.charAt(i);
        // si el caracter en que estoy no aparece en whitespace,
        // entonces retornar falso
        if (whitespace.indexOf(c) == -1) return false;
    }
    return true;
}


function stripCharsInBag (s, bag)
{   var i;
    var returnString = "";

    // Buscar por el string, si el caracter no esta en "bag", 
    // agregarlo a returnString
    
    for (i = 0; i < s.length; i++)
    {   var c = s.charAt(i);
        if (bag.indexOf(c) == -1) returnString += c;
    }

    return returnString;
}


function stripCharsNotInBag (s, bag)
{   var i;
    var returnString = "";
    for (i = 0; i < s.length; i++)
    {   
        var c = s.charAt(i);
        if (bag.indexOf(c) != -1) returnString += c;
    }

    return returnString;
}


function stripWhitespace (s)
{   return stripCharsInBag (s, whitespace)
}

function charInString (c, s)
{   for (i = 0; i < s.length; i++)
    {   if (s.charAt(i) == c) return true;
    }
    return false
}

function stripInitialWhitespace (s)
{   var i = 0;
    while ((i < s.length) && charInString (s.charAt(i), whitespace))
       i++;
    return s.substring (i, s.length);
}

function isLetter (c)
{
			return true
//		Sin filtros de caracteres en los campos de texto
//    return( ( uppercaseLetters.indexOf( c ) != -1 ) ||
//            ( lowercaseLetters.indexOf( c ) != -1 ) )
}

function isDigit (c)
{   return ((c >= "0") && (c <= "9"))
}

function isLetterOrDigit (c)
{   return (isLetter(c) || isDigit(c))
}

function isInteger (s)
{   var i;
    if (isEmpty(s)) 
       if (isInteger.arguments.length == 1) return defaultEmptyOK;
       else return (isInteger.arguments[1] == true);
    
    for (i = 0; i < s.length; i++)
    {   
        var c = s.charAt(i);
        if( i != 0 ) {
            if (!isDigit(c)) return false;
        } else { 
            if (!isDigit(c) && (c != "-") || (c == "+")) return false;
        }
    }
    return true;
}


function isNumber (s)
{   var i;
    var dotAppeared;
    dotAppeared = false;
    if (isEmpty(s)) 
       if (isNumber.arguments.length == 1) return defaultEmptyOK;
       else return (isNumber.arguments[1] == true);
    
    for (i = 0; i < s.length; i++)
    {   
        var c = s.charAt(i);
        if( i != 0 ) {
            if ( c == "." ) {
                if( !dotAppeared )
                    dotAppeared = true;
                else
                    return false;
            } else     
                if (!isDigit(c)) return false;
        } else { 
            if ( c == "." ) {
                if( !dotAppeared )
                    dotAppeared = true;
                else
                    return false;
            } else     
                if (!isDigit(c) && (c != "-") || (c == "+")) return false;
        }
    }
    return true;
}

function isAlphabetic (s)
{   var i;

    if (isEmpty(s)) 
       if (isAlphabetic.arguments.length == 1) return defaultEmptyOK;
       else return (isAlphabetic.arguments[1] == true);
    for (i = 0; i < s.length; i++)
    {   
        // Check that current character is letter.
        var c = s.charAt(i);

        if (!isLetter(c))
        return false;
    }
    return true;
}

function isAlphanumeric (s)
{   var i;

    if (isEmpty(s)) 
       if (isAlphanumeric.arguments.length == 1) return defaultEmptyOK;
       else return (isAlphanumeric.arguments[1] == true);

    for (i = 0; i < s.length; i++)
    {   
        var c = s.charAt(i);
        if (! (isLetter(c) || isDigit(c) ) )
        return false;
    }

    return true;
}


function isName (s)
{
    if (isEmpty(s)) 
       if (isName.arguments.length == 1) return defaultEmptyOK;
       else return (isAlphanumeric.arguments[1] == true);
    return( isAlphanumeric( stripCharsInBag( s, whitespace ) ) );
}

function isPhoneNumber (s)
{   var modString;
    if (isEmpty(s)) 
       if (isPhoneNumber.arguments.length == 1) return defaultEmptyOK;
       else return (isPhoneNumber.arguments[1] == true);
    modString = stripCharsInBag( s, phoneChars );
		if (modString.length > 8) {
			return (isInteger(modString));
		} else {
    	return false;
		}
}

function isDNI (s)
{   
		var modString;
    if (isEmpty(s)) 
       if (isDNI.arguments.length == 1) return defaultEmptyOK;
       else return (isDNI.arguments[1] == true);
    modString = stripCharsInBag( s, DNIChars )
    if (modString.length == 8) {
			return (isInteger(modString));
		} else {
    	return false;
		}
}

function isSelected (s)
{
  return true;
}

function isVotado (s)
{
  return true;
}

function isChecked (s)
{
  return true;
}

function isNice(s)
{
        var i = 0;
        var sLength = s.length;
        var b = 1;
        while(i<sLength) {
                if( (s.charAt(i) == "\"") || (s.charAt(i) == "'" )) b = 0;
                i++;
        }
        return b;
}

function warnInvalid (theField, s)
{   
   	if (elprimero == '') {
		  elprimero = 'Ya no';
			hayqueponerseen = theField;
		}
    msg_final += '\n- '+s;
    return false;
}


function checkField (theField, theFunction, emptyOK, s, s_extra)
{   
    var msg;
		var msg_extra;
		
    if (checkField.arguments.length < 3) emptyOK = defaultEmptyOK;
    if (checkField.arguments.length > 3) {
        msg = s;
    }
		
    if ((emptyOK == true) && (isEmpty(theField.value))) return true;
		
		if (theFunction == isVotado) {
			for (i=0;i<theField.length;i++) { 
       if (theField[i].checked) {
          return false; 
    		}
			}
			msg_final += '\n- '+msg;
			return false;
		}

    if ((emptyOK == false) && (isEmpty(theField.value))) {
     	  return warnInvalid(theField, msg);
		}

//		Mira que en una cadena de texto no haya una doble comilla o comilla simple.
//		No lo usamos
//
//    if ( checkNiceness && !isNice(theField.value)) {
//    		msg = 'El campo "'+theField.id+'" no admite comillas.';
//        return warnInvalid(theField, msg);
//		}

    if (theFunction == isChecked) {
			if ((theField.checked) == true) {
			  return true;
			} else {
  			msg_final += '\n- '+msg;
			  return false;
			}
		} else {
			if (theFunction(theField.value) == true) {
					return true;
			} else {
					if (elprimero == '') {
						elprimero = 'Ya no';
						hayqueponerseen = theField;
					}
					msg_extra = s_extra;
					msg = msg_extra;
					msg_final += '\n- '+msg;
					return false;
			}
		}
}

function analisis_data (any,data) {
	alert (data.charAt(0));
}


//FUNCTIONs que he puesto yo
function isDistintoCero (s)
{
  if (s!=0) {
		return true;
	} else {
		return false;
	}
}

function isCP (s)
{   
    if (isEmpty(s)) 
       if (isCP.arguments.length == 1) return defaultEmptyOK;
       else return (isCP.arguments[1] == true);
    if (s.length == 5) {
			return (isInteger(s));
		} else {
    	return false;
		}
}

function isEmail (s)
{
    if (isEmpty(s)) 
       if (isEmail.arguments.length == 1) return defaultEmptyOK;
       else return (isEmail.arguments[1] == true);
    if (isWhitespace(s)) return false;
    var i = 1;
    var sLength = s.length;
    while ((i < sLength) && (s.charAt(i) != "@"))
    { i++
    }

    if ((i >= sLength) || (s.charAt(i) != "@")) return false;
    else i += 2;

    while ((i < sLength) && (s.charAt(i) != "."))
    { i++
    }

    if ((i >= sLength - 1) || (s.charAt(i) != ".")) return false;
    else return true;
}

function es_dia_valid(dia,mes)
{
return (parseInt(dia)>0 && parseInt(dia)<=diesenelmes[mes - 1]) ? 1 : 0 //Si "dia" esta entre 1 y los dias que tiene el mes "Month" devuelve verdadero si no devuelve falso
}

function verificar_data (formulari) {
	
		var dia = formulari.dia.value;
		var mes = formulari.mes.value;
		var any = formulari.ano.value;
		
		if ((dia!=0) && (mes!=0) && (any!=0)) {
		
			var bixest = 1;
			var totcorrecte = 1;
		
			var diesenelmes = new Array()
			diesenelmes[0] = 31; //Els dies de Gener
			diesenelmes[1] = 0; //Els dies de Febrer es calculen més envant per si l'any es bixest
			diesenelmes[2] = 31; //Els dies de Març
			diesenelmes[3] = 30; //Els dies de Abril
			diesenelmes[4] = 31; //Els dies de Maig
			diesenelmes[5] = 30; //Els dies de Juny
			diesenelmes[6] = 31; //Els dies de Juliol
			diesenelmes[7] = 31; //Els dies de Agost
			diesenelmes[8] = 30; //Els dies de Setembre
			diesenelmes[9] = 31; //Els dies de Octubre
			diesenelmes[10] = 30; //Els dies de Novembre
			diesenelmes[11] = 31; //Els dies de Desembre
			
			if ((any % 4 == 0 && any % 100 != 0) || (any % 400 == 0)) { // Si "any" es un any bixest retorna TRUE, en cas contrari, FALSE
				diesenelmes[1] = 29;
			} else {
				diesenelmes[1] = 28;
			}
			
			if ((dia>0) && (dia <= diesenelmes[mes - 1])) {  //Si "dia" està entre 1 i el dies que té el mes "mes" retorna TRUE, en cas contrari, FALSE
				return;
			} else {
				formulari.dia.value=diesenelmes[mes-1];
				return;
			}
		}
}

function isNumTarj (s)
{   
		var modString;
    if (isEmpty(s)) 
       if (isNumTarj.arguments.length == 1) return defaultEmptyOK;
       else return (isNumTarj.arguments[1] == true);
    modString = stripCharsInBag( s, NumTarjChars )
		return ((isInteger(modString)) && (s.charAt(2)=='-') && (s.length=='9') );
}