//####################################################################
//#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;
} 


//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);
};

//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)) {
				cmp.style.backgroundColor = "#DBE4E6";
				window.alert('O Campo E-mail deve ser preenchido corretamente!');
				cmp.focus();
				return false;
			} else {
				cmp.style.backgroundColor = "#dde9b5";
			};
			
		} else if(m[0] == 'TIP') {

			if(cmp.value == 'CPF') {

				if(valida_cpf(cmp2.value) == false) {
					cmp2.style.backgroundColor = "#DBE4E6";
					window.alert('O Campo CPF deve ser preenchido corretamente!');
					cmp2.focus();
					return false;
				}

			} else if(cmp.value == 'CNPJ') {

				if(valida_cnpj(cmp2.value) == false) {
					cmp2.style.backgroundColor = "#DBE4E6";
					window.alert('O Campo CNPJ deve ser preenchido corretamente!');
					cmp2.focus();
					return false;
				}

			}

		} else if(m[0] == 'SEN') {
			if(cmp.value.length < 3) {
				cmp.style.backgroundColor = "#DBE4E6";
				window.alert('O Campo '+m[1]+' deve ser preenchido corretamente!');
				cmp.focus();
				return false;
			} else {
				cmp.style.backgroundColor = "#dde9b5";
			};

			if(cmp.value != cmp2.value) {
				cmp2.style.backgroundColor = "#DBE4E6";
				window.alert('Os Campos devem ser iguais!');
				cmp2.focus();
				return false;
			} else {
				cmp.style.backgroundColor = "#dde9b5";
			};

		} else if(m[0] == 'XXX') {
			if(cmp.value.length < 1) {
				cmp.style.backgroundColor = "#DBE4E6";
				window.alert('O Campo '+m[1]+' deve ser preenchido corretamente!');
				cmp.focus();
				return false;
			} else {
				cmp.style.backgroundColor = "#dde9b5";
			};
		}
	};
};

//http://logdaselva.com/mascara-de-cnpj-cpf-data-e-telefone-em-javascript/
function Mascara(tipo, campo, teclaPress) {
	if(window.event)
		var tecla = teclaPress.keyCode;
	else
		tecla = teclaPress.which;

	var s = new String(campo.value);

	s = s.replace(/(\.|\(|\)|\/|\-| )+/g,'');
	tam = s.length + 1;

	if(tecla!=9 && tecla!=8) {
		switch(tipo) {
			case 'CPF':
				if(tam > 3 && tam < 7)
					campo.value = s.substr(0,3) + '.' + s.substr(3, tam);
				if(tam >= 7 && tam < 10)
					campo.value = s.substr(0,3) + '.' + s.substr(3,3) + '.' + s.substr(6,tam-6);
				if(tam >= 10 && tam < 12)
					campo.value = s.substr(0,3) + '.' + s.substr(3,3) + '.' + s.substr(6,3) + '-' + s.substr(9,tam-9);
				break;

			case 'CNPJ':
				if(tam > 2 && tam < 6)
					campo.value = s.substr(0,2) + '.' + s.substr(2, tam);
				if(tam >= 6 && tam < 9)
					campo.value = s.substr(0,2) + '.' + s.substr(2,3) + '.' + s.substr(5,tam-5);
				if(tam >= 9 && tam < 13)
					campo.value = s.substr(0,2) + '.' + s.substr(2,3) + '.' + s.substr(5,3) + '/' + s.substr(8,tam-8);
				if(tam >= 13 && tam < 15)
					campo.value = s.substr(0,2) + '.' + s.substr(2,3) + '.' + s.substr(5,3) + '/' + s.substr(8,4)+ '-' + s.substr(12,tam-12);
				break;

			case 'TEL':
				if(tam > 2 && tam < 4)
					campo.value = '(' + s.substr(0,2) + ') ' + s.substr(2,tam);
				if(tam >= 7 && tam < 11)
					campo.value = '(' + s.substr(0,2) + ') ' + s.substr(2,4) + '-' + s.substr(6,tam-6);
				break;

			case 'DATA':
				if(tam > 2 && tam < 4)
					campo.value = s.substr(0,2) + '/' + s.substr(2, tam);
				if(tam > 4 && tam < 11)
					campo.value = s.substr(0,2) + '/' + s.substr(2,2) + '/' + s.substr(4,tam-4);
				break;
		}
	}
}

function data_formata(campo) {
	separador = '/';
	conjunto1 = 2;
	conjunto2 = 5;
	if(campo.value.length == conjunto1) {
		campo.value = campo.value + separador;
	}
	if(campo.value.length == conjunto2) {
		campo.value = campo.value + separador;
	}
};

function hora_formata(campo) {
	separador = ':';
	conjunto1 = 2;
	if(campo.value.length == conjunto1) {
		campo.value = campo.value + separador;
	}
};

function tel_formata(campo) {
	separador1 = '(';
	separador2 = ')';
	separador3 = '-';
	conjunto1 = 0;
	conjunto2 = 3;
	conjunto3 = 8;
	if (campo.value.length == conjunto1) {
		campo.value = campo.value + separador1;
	}
	if (campo.value.length == conjunto2) {
		campo.value = campo.value + separador2;
	}
	if (campo.value.length == conjunto3) {
		campo.value = campo.value + separador3;
	}
};