/*------------------------------*/
/*	FUNCOES DE PROPOSITO GERAL	*/
/*------------------------------*/

// BLOCO DE FUNCOES PARENTES
function mascara(o,f){
	v_obj=o
	v_fun=f
	setTimeout("execmascara()",1)
}

function execmascara(){
	v_obj.value=v_fun(v_obj.value)
}

function soNumeros(v){
	return v.replace(/\D/g,"")
}

function telefone(v){
	v = soNumeros(v);
	v=v.replace(/^(\d\d)(\d)/g,"($1) $2") //Coloca parênteses em volta dos dois primeiros dígitos
	v=v.replace(/(\d{4})(\d)/,"$1-$2")    //Coloca hífen entre o quarto e o quinto dígitos
	return v
}

function data(v){
	v = soNumeros(v);
	v=v.replace(/(\d{2})(\d)/,"$1/$2")       //Coloca um ponto entre o terceiro e o quarto dígitos
	v=v.replace(/(\d{2})(\d)/,"$1/$2")       //Coloca um ponto entre o terceiro e o quarto dígitos
	return v
}

function cpf(v){
	v = soNumeros(v);
	v=v.replace(/(\d{3})(\d)/,"$1.$2")       //Coloca um ponto entre o terceiro e o quarto dígitos
	v=v.replace(/(\d{3})(\d)/,"$1.$2")       //Coloca um ponto entre o terceiro e o quarto dígitos
											 //de novo (para o segundo bloco de números)
	v=v.replace(/(\d{3})(\d{1,2})$/,"$1-$2") //Coloca um hífen entre o terceiro e o quarto dígitos
	return v
}

function cep(v){
	v = soNumeros(v);
	//v=v.replace(/D/g,"")                //Remove tudo o que não é dígito
	v=v.replace(/^(\d{5})(\d)/,"$1-$2") //Esse é tão fácil que não merece explicações
	return v
}

function cnpj(v){
	v = soNumeros(v);
	v=v.replace(/^(\d{2})(\d)/,"$1.$2")             //Coloca ponto entre o segundo e o terceiro dígitos
	v=v.replace(/^(\d{2})\.(\d{3})(\d)/,"$1.$2.$3") //Coloca ponto entre o quinto e o sexto dígitos
	v=v.replace(/\.(\d{3})(\d)/,".$1/$2")           //Coloca uma barra entre o oitavo e o nono dígitos
	v=v.replace(/(\d{4})(\d)/,"$1-$2")              //Coloca um hífen depois do bloco de quatro dígitos
	return v
}

function romanos(v){
	v=v.toUpperCase()             //Maiúsculas
	v=v.replace(/[^IVXLCDM]/g,"") //Remove tudo o que não for I, V, X, L, C, D ou M
	//Essa é complicada! Copiei daqui: http://www.diveintopython.org/refactoring/refactoring.html
	while(v.replace(/^M{0,4}(CM|CD|D?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})$/,"")!="")
		v=v.replace(/.$/,"")
	return v
}

function site(v){
	//Esse sem comentarios para que você entenda sozinho ;-)
	v=v.replace(/^http:\/\/?/,"")
	dominio=v
	caminho=""
	if(v.indexOf("/")>-1)
		dominio=v.split("/")[0]
		caminho=v.replace(/[^\/]*/,"")
	dominio=dominio.replace(/[^\w\.\+-:@]/g,"")
	caminho=caminho.replace(/[^\w\d\+-@:\?&=%\(\)\.]/g,"")
	caminho=caminho.replace(/([\?&])=/,"$1")
	if(caminho!="")dominio=dominio.replace(/\.+$/,"")
	v="http://"+dominio+caminho
	return v
}


function MM_preloadImages() { //v3.0
  var d=document; if(d.images){ if(!d.MM_p) d.MM_p=new Array();
	var i,j=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++)
	if (a[i].indexOf("#")!=0){ d.MM_p[j]=new Image; d.MM_p[j++].src=a[i];}}
}
function MM_swapImgRestore() { //v3.0
  var i,x,a=document.MM_sr; for(i=0;a&&i<a.length&&(x=a[i])&&x.oSrc;i++) x.src=x.oSrc;
}
function MM_findObj(n, d) { //v4.01
  var p,i,x;  if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
	d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
  if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
  for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
  if(!x && d.getElementById) x=d.getElementById(n); return x;
}

function MM_swapImage() { //v3.0
  var i,j=0,x,a=MM_swapImage.arguments; document.MM_sr=new Array; for(i=0;i<(a.length-2);i+=3)
   if ((x=MM_findObj(a[i]))!=null){document.MM_sr[j++]=x; if(!x.oSrc) x.oSrc=x.src; x.src=a[i+2];}
}

function enviaEmail() {
	objForm = document.cadastroemail;
	strEmail = objForm.strEmail.value;
	
	Shadowbox.open({
		content:    'newsletter.php',
		player:     "iframe",
		height:     386,
		width:      420
	});
}
/*------------------------------*/
/*	FUNCOES DE PROPOSITO GERAL	*/
/*------------------------------*/

// BLOCO DE FUNCOES PARENTES
function mascara(o,f){
	v_obj=o
	v_fun=f
	setTimeout("execmascara()",1)
}

function execmascara(){
	v_obj.value=v_fun(v_obj.value)
}

function soNumeros(v){
	return v.replace(/\D/g,"")
}

function telefone(v){
	v = soNumeros(v);
	v=v.replace(/^(\d\d)(\d)/g,"($1) $2") //Coloca parênteses em volta dos dois primeiros dígitos
	v=v.replace(/(\d{4})(\d)/,"$1-$2")    //Coloca hífen entre o quarto e o quinto dígitos
	return v
}

function data(v){
	v = soNumeros(v);
	v=v.replace(/(\d{2})(\d)/,"$1/$2")       //Coloca um ponto entre o terceiro e o quarto dígitos
	v=v.replace(/(\d{2})(\d)/,"$1/$2")       //Coloca um ponto entre o terceiro e o quarto dígitos
	return v
}

function cpf(v){
	v = soNumeros(v);
	v=v.replace(/(\d{3})(\d)/,"$1.$2")       //Coloca um ponto entre o terceiro e o quarto dígitos
	v=v.replace(/(\d{3})(\d)/,"$1.$2")       //Coloca um ponto entre o terceiro e o quarto dígitos
											 //de novo (para o segundo bloco de números)
	v=v.replace(/(\d{3})(\d{1,2})$/,"$1-$2") //Coloca um hífen entre o terceiro e o quarto dígitos
	return v
}

function cep(v){
	v = soNumeros(v);
	//v=v.replace(/D/g,"")                //Remove tudo o que não é dígito
	v=v.replace(/^(\d{5})(\d)/,"$1-$2") //Esse é tão fácil que não merece explicações
	return v
}

function cnpj(v){
	v = soNumeros(v);
	v=v.replace(/^(\d{2})(\d)/,"$1.$2")             //Coloca ponto entre o segundo e o terceiro dígitos
	v=v.replace(/^(\d{2})\.(\d{3})(\d)/,"$1.$2.$3") //Coloca ponto entre o quinto e o sexto dígitos
	v=v.replace(/\.(\d{3})(\d)/,".$1/$2")           //Coloca uma barra entre o oitavo e o nono dígitos
	v=v.replace(/(\d{4})(\d)/,"$1-$2")              //Coloca um hífen depois do bloco de quatro dígitos
	return v
}

function romanos(v){
	v=v.toUpperCase()             //Maiúsculas
	v=v.replace(/[^IVXLCDM]/g,"") //Remove tudo o que não for I, V, X, L, C, D ou M
	//Essa é complicada! Copiei daqui: http://www.diveintopython.org/refactoring/refactoring.html
	while(v.replace(/^M{0,4}(CM|CD|D?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})$/,"")!="")
		v=v.replace(/.$/,"")
	return v
}

function site(v){
	//Esse sem comentarios para que você entenda sozinho ;-)
	v=v.replace(/^http:\/\/?/,"")
	dominio=v
	caminho=""
	if(v.indexOf("/")>-1)
		dominio=v.split("/")[0]
		caminho=v.replace(/[^\/]*/,"")
	dominio=dominio.replace(/[^\w\.\+-:@]/g,"")
	caminho=caminho.replace(/[^\w\d\+-@:\?&=%\(\)\.]/g,"")
	caminho=caminho.replace(/([\?&])=/,"$1")
	if(caminho!="")dominio=dominio.replace(/\.+$/,"")
	v="http://"+dominio+caminho
	return v
}
// FIM DO BLOCO DE FUNCOES

function pularCampo(obj, sz){
	if (obj.value.length >= sz){
		form = obj.form;
		i = 0;
		while (form.elements[i].name != obj.name && i < form.elements.length) i++;
		i++;
		if (i != form.elements.length) form.elements[i].focus();
	}
	return;
}


function strpos(str, ch) {
	for (var i = 0; i < str.length; i++)
	if (str.substring(i, i+1) == ch) 
		return i;
	return false;
}

// Filtrando o campo com os valores pre-definidos
function filtraCampo(campo){
	var s = "";
	vr = campo.value;
	tam = vr.length;
	for (i = 0; i < tam ; i++) {  
		if (vr.substring(i,i + 1) == "1" || vr.substring(i,i + 1) == "2" || vr.substring(i,i + 1) == "3" || vr.substring(i,i + 1) == "4" || vr.substring(i,i + 1) == "5" || vr.substring(i,i + 1) == "6" || vr.substring(i,i + 1) == "7" || vr.substring(i,i + 1) == "8" || vr.substring(i,i + 1) == "9" || vr.substring(i,i + 1) == "0"){
			s = s + vr.substring(i,i + 1);}
	}
	return s;
}

// Retonrnando somente os numeros
function soNumeros_(campo) {
	campo.value = filtraCampo(campo);
}

// Formatando o valor
function formataValor(campo) {
	campo.value = filtraCampo(campo);
	vr = campo.value;
	tam = vr.length;

	if (tam > 2)
		campo.value = vr.substr( 0, tam - 2 ) + ',' + vr.substr( tam - 2, tam ); 
}
function check_email(emailStr)
{
	var emailPat = /^(.+)@(.+)$/
	var specialChars = "\\(\\)<>@,;:\\\\\\\"\\.\\[\\]"
	var validChars = "\[^\\s" + specialChars + "\]"
	var quotedUser = "(\"[^\"]*\")"
	var ipDomainPat = /^\[(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})\]$/
	var atom = validChars + '+'
	var word = "(" + atom + "|" + quotedUser + ")"
	var userPat = new RegExp("^" + word + "(\\." + word + ")*$")
	var domainPat = new RegExp("^" + atom + "(\\." + atom +")*$")

	var matchArray = emailStr.match(emailPat)
	if (matchArray == null)
	{
		return false;
	}

	var user = matchArray[1]
	var domain = matchArray[2]

	if (user.match(userPat) == null)
	{
		return false;
	}

	var IPArray = domain.match(ipDomainPat)

	if (IPArray != null)
	{
		for (var i=1;i<=4;i++)
		{
			if (IPArray[i]>255)
			{
			return false;
			}
		}
		return true;
	}

	var domainArray = domain.match(domainPat)

	if (domainArray == null)
	{
		return false;
	}
	
	var atomPat = new RegExp(atom,"g")
	var domArr = domain.match(atomPat)
	var len = domArr.length
	
	var pos_arroba = emailStr.indexOf("@");
	var str_pos_arroba = emailStr.substr(pos_arroba+1);
	var ponto = str_pos_arroba.indexOf(".");
	var str_dominio = emailStr.substr(pos_arroba, ponto);
	
	if((str_dominio.length) <= 1)
	{
		return false;
	}
	
	if (domArr[domArr.length-1].length < 2 || domArr[domArr.length-1].length > 3)
	{
  		return false;
	}

	if (len < 2)
	{
  		return false;
	}
	return true;
}

$(document).ready(function()
	{
		$(".defaultText").focus(function(srcc)
		{
			if ($(this).val() == $(this)[0].title)
			{
				$(this).val("");
			}
		});
		
		$(".defaultText").blur(function()
		{
			if ($(this).val() == "")
			{
				$(this).addClass("");
				$(this).val($(this)[0].title);
			}
		});
		
		$(".defaultText").blur();        
	});

function enviaPaginacao(strLink, pag) {
	if(pag <= 0 || true == isNaN(pag))
		pag = 1;
	window.location.href = '?x='+strLink+','+(pag-1);
	return (false);
}

function validaFormContato() {
	objForm = document.formContato;
	
	if(objForm.strNome.value == ''){
	alert('Digite seu nome.');
	objForm.strNome.focus();
	return false;
	}

	if(objForm.strEmailContato.value == ''){
	alert('Digite seu e-mail.');
	objForm.strEmailContato.focus();
	return false;
	} 

	if(!check_email(objForm.strEmailContato.value)){
	alert('E-mail invalido.');
	objForm.strEmailContato.focus();
	return false;
	}

	if(objForm.strAssunto.value == ''){
	alert('Digite o assunto.');
	objForm.strAssunto.focus();
	return false;
	} 

	if(objForm.strMensagem.value == ''){
	alert('Digite a mensagem.');
	objForm.strMensagem.focus();
	return false;
	} 

	objForm.submit();
}

function validaFormOrcamento() {
	objForm = document.formOrcamento;
	
	if(objForm.strNomeOrcamento.value == ''){
	alert('Digite seu nome.');
	objForm.strNomeOrcamento.focus();
	return false;
	}

	if(objForm.strEmailOrcamento.value == ''){
	alert('Digite seu e-mail.');
	objForm.strEmailOrcamento.focus();
	return false;
	} 

	if(!check_email(objForm.strEmailOrcamento.value)){
	alert('E-mail invalido.');
	objForm.strEmailOrcamento.focus();
	return false;
	}

	if(objForm.numTelefone.value == ''){
	alert('Digite o número do telefone.');
	objForm.numTelefone.focus();
	return false;
	} 
	
	if(objForm.strObra.value == ''){
	alert('Digite o nome referente a obra.');
	objForm.strObra.focus();
	return false;
	} 

	if(objForm.strLocalizacao.value == ''){
	alert('Digite o endereço da obra');
	objForm.strLocalizacao.focus();
	return false;
	} 

	if(objForm.strSolicitacao.value == ''){
	alert('Escreva qual a solicitação');
	objForm.strSolicitacao.focus();
	return false;
	} 

	objForm.submit();
}

// Função para ser fã
 function tornarFa(codItem,codUsuario,quantidade){
	 if (codUsuario == -1){
		alert('Voce deve-se logar para efetuar o procedimento'); 
	 } else {
		$("#divTornarFa").load("guiaFaAction.php?codUsuario="+codUsuario+"&codItem="+codItem);
	 }
 }
 
function mostraDepoimento(id)
{
	if(document.getElementById('depoimento'+id).style.display == '')
		document.getElementById('depoimento'+id).style.display='none';
	else
		document.getElementById('depoimento'+id).style.display='';
}
function escondeDepoimento(id)
{
	document.getElementById('depoimento'+id).style.display='none';

}

