/*#############################################################################
JavaScript Document
Criado por Thiago Costa 
Data: 15/12/2008 22:30

Objetivo: Biblioteca de funções genéricas através de expressão regular

Histórico de alterações/inclusões

Data              Responsável                   Descrição da alteração/inclusão
---------------   --------------------------    ---------------------------------------------------------------------



#############################################################################*/



/*Função Pai de Mascaras*/    
function Mascara(o,f){  
	v_obj=o       
	v_fun=f       
	setTimeout("execmascara()",1)   
}       
/*Função que Executa os objetos*/ 
function execmascara(){ 
	v_obj.value=v_fun(v_obj.value) 
}

/*Função que Determina as expressões regulares dos objetos*/   
function leech(v){      
	v=v.replace(/o/gi,"0")       
	v=v.replace(/i/gi,"1")      
	v=v.replace(/z/gi,"2")     
	v=v.replace(/e/gi,"3")   
	v=v.replace(/a/gi,"4")     
	v=v.replace(/s/gi,"5")     
	v=v.replace(/t/gi,"7")     
	return v   
}

/*Função que padroniza valor monétario*/   
function Valor(v){       
	 v=v.replace(/\D/g,"") //Remove tudo o que não é dígito        
	 v=v.replace(/^([0-9]{3}\.?){3}-[0-9]{2}$/,"$1.$2");    
	 //v=v.replace(/(\d{3})(\d)/g,"$1,$2")       
	 v=v.replace(/(\d)(\d{2})$/,"$1.$2")  //Coloca ponto antes dos 2 últimos digitos        
	 return v  
}

/*Função que padroniza telefone (11) 4184-1241*/    
function Telefone(v){        
	v=v.replace(/\D/g,"")
	v=v.replace(/^(\d\d)(\d)/g,"($1) $2")
	v=v.replace(/(\d{4})(\d)/,"$1-$2")
	return v    
}


/*Função que padroniza telefone 11-41841241*/    
function Telefone1(v){        
	v=v.replace(/\D/g,"")
	v=v.replace(/^(\d\d)(\d)/g,"$1-$2")
	v=v.replace(/(\d{4})(\d)/,"$1$2")
	return v    
}

/*Função que padroniza telefone 11-41841241*/    
function DDDTelefone(v){        
	v=v.replace(/\D/g,"")
	v=v.replace(/^(\d\d)(\d)/g,"$1-$2")
	v=v.replace(/(\d{4})(\d)/,"$1$2")
	return v    
}


/*Função que padroniza telefone 11-41841241*/    
function fFone(v){        
	v=v.replace(/\D/g,"")
	v=v.replace(/^(\d\d)(\d)/g,"$1-$2")
	v=v.replace(/(\d{4})(\d)/,"$1$2")
	return v    
}

/*Função que padroniza CEP*/   
function Cep(v){       
 v=v.replace(/D/g,"")  
 v=v.replace(/^(\d{5})(\d)/,"$1-$2") 
 return v    
}

/*Função que padroniza CPF*/
function Cpf(v){ 
   v=v.replace(/\D/g,"") 
   v=v.replace(/(\d{3})(\d)/,"$1.$2") 
   v=v.replace(/(\d{3})(\d)/,"$1.$2") 
   v=v.replace(/(\d{3})(\d{1,2})$/,"$1-$2") 
   return v   
}

/*Função que padroniza DATA*/    
function Hora(v){        
   v=v.replace(/\D/g,"")         
   v=v.replace(/(\d{2})(\d)/,"$1:$2")          
   return v   
}


/*Função que padroniza Area*/    
function Area(v){       
	v=v.replace(/\D/g,"")        
	v=v.replace(/(\d)(\d{2})$/,"$1.$2")       
	return v           
}

/*Função que padroniza o Site*/   
function Site(v){        
	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    
}

/*Função que permite apenas numeros Romanos*/    
function Romanos(v){       
   v=v.toUpperCase()       
   v=v.replace(/[^IVXLCDM]/g,"")    
   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    
}


/*Função que padroniza CNPJ*/   
function Cnpj(v){       
	v=v.replace(/\D/g,"")          
	v=v.replace(/^(\d{2})(\d)/,"$1.$2")        
	v=v.replace(/^(\d{2})\.(\d{3})(\d)/,"$1.$2.$3")  
	v=v.replace(/\.(\d{3})(\d)/,".$1/$2")             
	v=v.replace(/(\d{4})(\d)/,"$1-$2")               
	return v  
}


/*Função que permite apenas numeros*/    
function Integer(v){        
 return v.replace(/\D/g,"")  
}

//========================
/**
* Formata o Campo de acordo com a mascara informada.
* Ex de uso: onkeyup="AplicaMascara('HORA', this);".
* @author Igor Escobar (blog@igorescobar.com)
* @param Mascara String que possui o nome da mascara de formatação do campo.
* @param elemento Campo que será formatado de acordo com a mascara, voce pode informar o id direto ou o próprio elemento usando o this.
* @returns {void}
* @methods
   - DATA: 
   - HORA:
   - CEP:
   - CPF:
   - CNPJ
   - TEL
   - TELDDD
*/
function AplicaMascara(Mascara, elemento)
{
        
    // Seta o elemento
    var elemento = (elemento) ? elemento : document.getElementById(elemento); 
    if(!elemento) return false;
    
    // DEFINE AS REGRAS DE FORMATAÇÃO DOS CAMPOS
    var Regexs = {
        DATA: /(([0-9]){2})(([0-9]){2})(([0-9]){4})/,
        HORA: /(([0-9]{2}))(([0-9]){2})(([0-9]){2})/,
        CEP: /(([0-9]{5}))(([0-9]){3})/,
        CPF: /(([0-9]{3}))(([0-9]){3})(([0-9]){3})(([0-9]{2,5}))/,
        CNPJ: /(([0-9]{2}))(([0-9]){3})(([0-9]){3})(([0-9]){4})(([0-9]){2,6})/,
        TEL: /(([0-9]){4})(([0-9]){4})/,
        TELDDD: /(([0-9]){2})(([0-9]){4})(([0-9]){4})/
    }
        
    MyRegex = eval('Regexs.'+Mascara);
    
    // INSTANCIA A REGRA REGEX PARA FORMATACAO
    getRegexGroups = new RegExp(MyRegex);
    
    // INSTANCIA A REGRA QUE VERIFICA SE O CAMPO POSSUI SOMENTE NÚMEROS
    onlyNumbers = new RegExp(/^([0-9]+)$/);
    
    // ESTE É O CAMPO COM AS IMPURESAS (DIGITADO PELO USUÁRIO FINAL)
    var CampoSujo = elemento.value;
    
    // RETIRA OS EXCESSOS DOS CAMPOS PARA QUE POSSAMOS APLICAR A MASCARA EM UM CAMPO LIMPO
    
    if(Mascara == "CPF" || Mascara == "CNPJ")
        var oValue = RetiraZerosEsquerda(CampoSujo.replace(/([./;:,\-()]+)/g,""));
    else
        var oValue = CampoSujo.replace(/([./;:,\-()]+)/g,"");
        
 
    if(Mascara == "CPF") { oValue = addLeftZeros(""+oValue, 11); }
    if(Mascara == "CNPJ") { oValue = addLeftZeros(""+oValue, 14); }
    
    
    // VERIFICA SE A REGRA QUE ELE SE ESCOLHEU SE APLICA AO TEXTO DIGITADO NO CAMPO 
    if(getRegexGroups.test(oValue) == true){
 
        //APLICA A REGRA NO CAMPO E FORMATA
        switch(Mascara){
            case 'DATA': oNewCampo = oValue.replace(getRegexGroups,"$1/$3/$5"); break;
            case 'HORA': oNewCampo = oValue.replace(getRegexGroups,"$1:$3:$5"); break;
            case 'CEP': oNewCampo = oValue.replace(getRegexGroups,"$1$3-$5"); break;
            case 'CPF': oNewCampo = oValue.replace(getRegexGroups,"$1.$3.$5-$7"); break;
            case 'CNPJ': oNewCampo = oValue.replace(getRegexGroups,"$1.$3.$5/$7-$9"); break;
            case 'TEL': oNewCampo = oValue.replace(getRegexGroups,"$1-$3"); break;
            case 'TELDDD': oNewCampo = oValue.replace(getRegexGroups,"($1)$3-$5"); break;
        }
        // Retorna o valor do elemento com seu novo valor
        if(parseInt(oValue) != 0 && parseInt(oValue) != "") elemento.value = oNewCampo; 
        
    }
} 
