//####################################################################
//#Esse script foi criado por:                                       #
//#Eric Maicon Silva Sousa                                           #
//#ericmaicon@jovenet.com.br                                         #
//#eric@ericmaicon.com.br                                            #
//#Todos os JS do site                                               #
//####################################################################

//http://www.pcforum.com.br/cgi/yabb/YaBB.cgi?board=cgi;action=display;num=1090001360
function valida_cpf(cpf)
{
	var numeros, digitos, soma, i, resultado, 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=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;
}

//www.ericmaicon.com.br
//formulario = Formulário (this)
function valida(formulario)
{
	var total = formulario.elements.length;
	var x = 0;

	for(i=0;i<=total;i++)
	{
		var m = formulario.elements[i].name.split('_');
		var cmp = formulario.elements[i];
		var cmp2 = formulario.elements[i+1];

		if(m[0] == 'EMA')
		{
			er = /^[A-Za-z0-9_.-]+@([A-Za-z0-9_]+\.)+[A-Za-z]{2,4}$/
			if(!er.test(cmp.value))
			{
				window.alert('O Campo E-mail deve ser preenchido corretamente!');
				cmp.focus();
				return false;
			}
		
		}
		else if(m[0] == 'TIP')
		{

			if(cmp.value == 'CPF')
			{
				if(valida_cpf(cmp2.value) == false)
				{
					window.alert('O Campo CPF deve ser preenchido corretamente!');
					cmp2.focus();
					return false;
				}
			}
			else if(cmp.value == 'CNPJ')
			{
				if(valida_cnpj(cmp2.value) == false)
				{
					window.alert('O Campo CNPJ deve ser preenchido corretamente!');
					cmp2.focus();
					return false;
				}
			}
		}
		else if(m[0] == 'SEN')
		{
			if(cmp.value.length < 3)
			{
				window.alert('O Campo '+m[1]+' deve ser preenchido corretamente!');
				cmp.focus();
				return false;
			}

			if(cmp.value != cmp2.value)
			{
				window.alert('Os Campos devem ser iguais!');
				cmp2.focus();
				return false;
			}
		
		}
		else if(m[0] == 'CHE')
		{
			if(cmp.checked == 0)
			{
				window.alert('O Campo '+m[1]+' deve ser preenchido corretamente!');
				cmp.focus();
				return false;
			}
		}
		else if(m[0] == 'XXX')
		{
			if(cmp.value.length < 1)
			{
				window.alert('O Campo '+m[1]+' deve ser marcado!');
				cmp.focus();
				return false;
			}

		}
		else if(m[0] == 'EDI')
		{
			if(document.all && ! navigator.userAgent.match(/opera/gi))
				cmp.value = document.getElementById("editor").innerHTML
			else
				cmp.value = document.getElementById("editor").contentDocument.body.innerHTML
		}

		if(cmp.type == 'submit' || cmp.type == 'hidden' || cmp.type == 'reset' || cmp.type == 'radio')
			continue;
	};
};

//http://www.pedrocorreia.net/mySnippets/javascript/RestringirCaracteres
function IsNumber(evt)
{
	var charCode = (evt.which) ? evt.which : evt.keyCode;
	return (charCode>=46 && charCode<=57 || charCode<20);
};