/*
================================================================================
						Validações de CPF e CNPJ
================================================================================
*/

function clsValida_text_CPF_CNPJ(pObjItemForm, pStrNomeCampo)
{
	if (pObjItemForm.value == "") return ""; // só valida o campo se estiver preenchido

	var lStrMsgRetorno = "";
	var lStrCPFCNPJ = pObjItemForm.value;

	if (lStrCPFCNPJ.length != 11 && lStrCPFCNPJ.length < 14) 
		lStrMsgRetorno = "O CPF ou CNPJ digitado no campo \"" + pStrNomeCampo + "\" esta incompleto.";
	else if (lStrCPFCNPJ.length == 11 && !valida_cpf(lStrCPFCNPJ))
		lStrMsgRetorno = "O CPF digitado no campo \"" + pStrNomeCampo + "\" não é válido.";
	else if (lStrCPFCNPJ.length == 14 && !valida_cnpj(lStrCPFCNPJ))
		lStrMsgRetorno = "O CNPJ digitado no campo \"" + pStrNomeCampo + "\" não é válido.";
	
	return lStrMsgRetorno;
}


function clsValida_text_CPF(pObjItemForm, pStrNomeCampo)
{
	if (pObjItemForm.value == "") return ""; // só valida o campo se estiver preenchido

	var lStrMsgRetorno = "";
	var lStrCPF = pObjItemForm.value;

	if (lStrCPF.length != 11) 
		lStrMsgRetorno = "O CPF digitado no campo \"" + pStrNomeCampo + "\" esta incompleto.";
	else if (!valida_cpf(lStrCPF))
		lStrMsgRetorno = "O CPF digitado no campo \"" + pStrNomeCampo + "\" não é válido.";
	
	return lStrMsgRetorno;
}


function clsValida_text_CNPJ(pObjItemForm, pStrNomeCampo)
{
	if (pObjItemForm.value == "") return ""; // só valida o campo se estiver preenchido

	var lStrMsgRetorno = "";
	var lStrCNPJ = pObjItemForm.value;

	if (lStrCNPJ.length != 14) 
		lStrMsgRetorno = "O CNPJ digitado no campo \"" + pStrNomeCampo + "\" esta incompleto.";
	else if (!valida_cnpj(lStrCNPJ))
		lStrMsgRetorno = "O CNPJ digitado no campo \"" + pStrNomeCampo + "\" não é válido.";
	
	return lStrMsgRetorno;
}

/*
==============================================================================
					Funções auxiliares
==============================================================================
*/

function valida_cpf(cpf)
{
	var numeros, digitos, soma, i, resultado, digitos_iguais;
	digitos_iguais = 1;
	
	if (cpf.length < 11)
		return false;
	
	for (i = 0; i < cpf.length - 1; i++)
		if (cpf.charAt(i) != cpf.charAt(i + 1))
		{
			digitos_iguais = 0;
			break;
		}
	
	if (!digitos_iguais)
	{
		numeros = cpf.substring(0,9);
		digitos = cpf.substring(9);
		soma = 0;
	
		for (i = 10; i > 1; i--)
			soma += numeros.charAt(10 - i) * i;
	
		resultado = soma % 11 < 2 ? 0 : 11 - soma % 11;
	
		if (resultado != digitos.charAt(0))
			return false;
	
		numeros = cpf.substring(0,10);
		soma = 0;
	
		for (i = 11; i > 1; i--)
			soma += numeros.charAt(11 - i) * i;
		
		resultado = soma % 11 < 2 ? 0 : 11 - soma % 11;
	
		if (resultado != digitos.charAt(1))
			return false;
	
		return true;
	}
	else
		return false;
} 

function valida_cnpj(cnpj)
{
	var numeros, digitos, soma, i, resultado, pos, tamanho, digitos_iguais;
	digitos_iguais = 1;
	
	if (cnpj.length < 14 && cnpj.length < 15)
		return false;
		
	for (i = 0; i < cnpj.length - 1; i++)
		if (cnpj.charAt(i) != cnpj.charAt(i + 1))
		{
			digitos_iguais = 0;
			break;
		}
	
	if (!digitos_iguais)
	{
		tamanho = cnpj.length - 2
		numeros = cnpj.substring(0,tamanho);
		digitos = cnpj.substring(tamanho);
		soma = 0;
		pos = tamanho - 7;

		for (i = tamanho; i >= 1; i--)
		{
			soma += numeros.charAt(tamanho - i) * pos--;
			if (pos < 2)
				pos = 9;
		}

		resultado = soma % 11 < 2 ? 0 : 11 - soma % 11;
		
		if (resultado != digitos.charAt(0))
			return false;

		tamanho = tamanho + 1;
		numeros = cnpj.substring(0,tamanho);
		soma = 0;
		pos = tamanho - 7;
	
		for (i = tamanho; i >= 1; i--)
		{
			soma += numeros.charAt(tamanho - i) * pos--;
			if (pos < 2)
				pos = 9;
		}
		
		resultado = soma % 11 < 2 ? 0 : 11 - soma % 11;

		if (resultado != digitos.charAt(1))
			return false;

		return true;
	}
	else
		return false;
}
