//<script>

/*
Criado por: Guilherme Braccialli (gbraccialli@hotmail.com)
Data de Criação: 2000-08-02
Data da última alteração: 2002-04-13
*/

function valida(form)
{
	x = form.elements.length -1
	for (i = 0; i <= x; i++)
	{
 		tipo = form.elements[i].name
		tipo = tipo.substring(0, 5)
		tipo = tipo.toUpperCase()
		campo = form.elements[i].name
		campo = campo.substring(5)
		switch (tipo)
		{
			case 'V_REQ': //REQUERIDO
				if (!isNotEmpty(form.elements[campo], form.elements[i].value))
					return false;
				break;
			case 'V_INT': //INTEIRO - NÃO REQUERIDO
				if (!isInteger(form.elements[campo], form.elements[i].value))
					return false;
				break;
			case 'V_CEP':
				if (!isCEP(form.elements[campo],form.elements[i].value))
					return false;
				break;
			case 'V_DBL': //DOUBLE (numérico) - NÃO REQUERIDO
				if (!isDouble(form.elements[campo], form.elements[i].value))
					return false;				
				break;			
			case 'V_EMA': //EMAIL - NÃO REQUERIDO
				if (!isEmail(form.elements[campo], form.elements[i].value))
					return false;
				break;			
			case 'V_CPF': //CPF - NÃO REQUERIDO
				if (!isCPF(form.elements[campo], form.elements[i].value))
					return false;
				break;			
			case 'V_CGC': //CGC - NÃO REQUERIDO
				if (!isCGC(form.elements[campo], form.elements[i].value))
					return false;
				break;
			case 'V_DTA': //DATA
				sDia = campo + '_dia'
				sMes = campo + '_mes'
				sAno = campo + '_ano'
				if (!isDate(form.elements[sDia], form.elements[sMes], form.elements[sAno], form.elements[i].value))
					return false;
				break;
		}				
	}
	return true;
}

function isNotEmpty(campo, mensagem)
{
	if (campo.type == 'select-one')
	{
		if (campo.selectedIndex == 0)
		{
			alert(mensagem);
			campo.focus();
			return false;
		}
	}
	else
	{
		if (campo.value == '')
		{
			alert(mensagem);
			campo.focus();	
			return false;
		}
	}
	return true;
}

function isDouble(campo, mensagem)
{
	sValor = campo.value;
	sValor = sValor.toString();
	sValor = sValor.replace(',','.');
	if (isNaN(sValor) && sValor != '')
	{
		alert(mensagem);
		campo.focus();	
		return false;
	}
	return true;
}

function isInteger(campo,mensagem)
{
	sValor = campo.value;
	sValor = sValor.toString();
	xpqp = sValor.length
	for (iputo = 0; iputo < xpqp; iputo++)
	{
		sAux = sValor.charAt(iputo);
		if (sAux < '0' || sAux > '9')
		{
			alert(mensagem);
			campo.focus();
			return false;
		}
	}
	return true;
}

function isEmail(campo,mensagem)
{
	if (campo.value != '')
	{
		var i = 1;
		sValor = campo.value
		sLength = sValor.length;

		while ((i < sLength) && (sValor.charAt(i) != '@'))
			i++
			
		if ((i >= sLength) || (sValor.charAt(i) != '@')) 
		{
			alert(mensagem);
			campo.focus();
			return false;
		}
		else
			i += 2;
		while ((i < sLength) && (sValor.charAt(i) != '.'))
			i++
		if ((i >= sLength - 1) || (sValor.charAt(i) != '.')) 
		{
			alert(mensagem);
			campo.focus();
			return false;
		}
	}
	return true;
}

function isCPF(campo,mensagem)
{
	sValor1 = campo.value;
	sValor1 = sValor1.toString();
	sValor = '';
	xpqp = sValor1.length
	for (iputo = 0; iputo < xpqp; iputo++)
	{
		sAux = sValor1.charAt(iputo);
		if (sAux < '0' || sAux > '9')
		{
			if (sAux != '.' && sAux != '-' && sAux != '/')
			{
				alert(mensagem);
				campo.focus();
				return false;
			}
		}
		else
		{
			sAux = sAux.toString();
			sValor = sValor + '' + sAux;
		}
	}
	if (sValor != '')
	{
		if (isNaN(sValor) || sValor.length != 11)
		{
			alert(mensagem);
			campo.focus();
			return false;
		}
		soma = (sValor.substr(0,1) * 10) + (sValor.substr(1,1) * 9) + (sValor.substr(2,1) * 8) + (sValor.substr(3,1) * 7) + (sValor.substr(4,1) * 6) + (sValor.substr(5,1) * 5) + (sValor.substr(6,1) * 4) + (sValor.substr(7,1) * 3) + (sValor.substr(8,1) * 2);
		dv1 = (soma % 11);
		if (dv1 == 0 || dv1 == 1) 
			dv1 = 0;
		else
			dv1 = 11 - dv1;
		soma = (sValor.substr(0,1) * 11) + (sValor.substr(1,1) * 10) + (sValor.substr(2,1) * 9) + (sValor.substr(3,1) * 8) + (sValor.substr(4,1) * 7) + (sValor.substr(5,1) * 6) + (sValor.substr(6,1) * 5) + (sValor.substr(7,1) * 4) + (sValor.substr(8,1) * 3) + (dv1 * 2);
		dv2 = (soma % 11);
		if (dv2 == 0 || dv2 == 1) 
			dv2 = 0;
		else
			dv2 = 11 - dv2;
		if (sValor.substr(9,1) != dv1 || sValor.substr(10,1) != dv2)
		{
			alert(mensagem);
			campo.focus();
			return false;
		}
	}
	return true;
}

function isCGC(campo,mensagem)
{
	sValor1 = campo.value;
	sValor1 = sValor1.toString();
	sValor = '';
	xpqp = sValor1.length
	for (iputo = 0; iputo < xpqp; iputo++)
	{
		sAux = sValor1.charAt(iputo);
		if (sAux < '0' || sAux > '9')
		{
			if (sAux != '.' && sAux != '-' && sAux != '/')
			{
				alert(mensagem);
				campo.focus();
				return false;
			}
		}
		else
			sValor = sValor + sAux
	}
	if (sValor != '')
	{
		if (isNaN(sValor) || sValor.length != 14)
		{
			alert(mensagem);
			campo.focus();
			return false;
		}
		soma = (sValor.substr(0,1) * 5) + (sValor.substr(1,1) * 4) + (sValor.substr(2,1) * 3) + (sValor.substr(3,1) * 2) + (sValor.substr(4,1) * 9) + (sValor.substr(5,1) * 8) + (sValor.substr(6,1) * 7) + (sValor.substr(7,1) * 6) + (sValor.substr(8,1) * 5) + (sValor.substr(9,1) * 4) + (sValor.substr(10,1) * 3) + (sValor.substr(11,1) * 2)
		dv1 = (soma % 11);
		if (dv1 == 0 || dv1 == 1) 
			dv1 = 0;
		else
			dv1 = 11 - dv1;
		soma = (sValor.substr(0,1) * 6) + (sValor.substr(1,1) * 5) + (sValor.substr(2,1) * 4) + (sValor.substr(3,1) * 3) + (sValor.substr(4,1) * 2) + (sValor.substr(5,1) * 9) + (sValor.substr(6,1) * 8) + (sValor.substr(7,1) * 7) + (sValor.substr(8,1) * 6) + (sValor.substr(9,1) * 5) + (sValor.substr(10,1) * 4) + (sValor.substr(11,1) * 3)  + (dv1 * 2)
		dv2 = (soma % 11);
		if (dv2 == 0 || dv2 == 1) 
			dv2 = 0;
		else
			dv2 = 11 - dv2;
		if (sValor.substr(12,1) != dv1 || sValor.substr(13,1) != dv2)
		{
			alert(mensagem);
			campo.focus();
			return false;
		}
	}
	return true;
}

function isDate(objDia, objMes, objAno, mensagem)
{
	if (objDia.type == 'select-one')
		dia = objDia.options[objDia.selectedIndex].value;
	else
		dia = objDia.value;
	
	if (objMes.type == 'select-one')
		mes = objMes.options[objMes.selectedIndex].value;
	else
		mes = objMes.value;

	if (objAno.type == 'select-one')
		ano = objAno.options[objAno.selectedIndex].value;
	else
		ano = objAno.value;
	
	if (isNaN(dia) || isNaN(mes) || isNaN(ano) || dia == '' || mes == '' || ano == '')
	{
		alert(mensagem);
		objDia.focus();
		return false;
	}
	diaAux = 0;
	dia = parseInt(dia,10)
	mes = parseInt(mes,10)
	ano = parseInt(ano,10)
		
	switch (mes)
	{
		case 2 :
			if (((ano % 400) == 0) || ((ano % 4) == 0 && (ano % 100) != 0))
				diaAux = 29;
			else
				diaAux = 28;
			break;
		case 1  :
		case 3  :
		case 5  :
		case 7  :
		case 8  :
		case 10 :
		case 12 :
			diaAux = 31;
			break;
		case 4 :
		case 6 :
		case 9 :
		case 11:
			diaAux = 30;
			break;
		default:
			diaAux = 0;
	} 
	if (dia > diaAux || dia < 1)
	{
		alert(mensagem);
		objDia.focus();
		return false;
	}
	else
		return true;
}

function isCEP(campo, mensagem)
{
		
	if (campo.value != '')
	{
		var CEPPat = /^(\d{5})(\-)?(\d{3})$/;
		var strAux = campo.value;
		strAux = strAux.toString();
			
		if (strAux.match(CEPPat) == null)
		{
			alert(mensagem);
			campo.focus();
			return false;
		}		
	}	
		
	return true;
}
