function emailCheck (emailStr) {
/* Verificar si el email tiene el formato user@dominio. */
var emailPat=/^(.+)@(.+)$/; 

/* Verificar la existencia de caracteres. ( ) < > @ , ; : \ " . [ ] */
var specialChars="\\(\\)<>@,;:\\\\\\\"\\.\\[\\]"; 

/* Verifica los caracteres que son válidos en una dirección de email */
var validChars="\[^\\s" + specialChars + "\]"; 

var quotedUser="(\"[^\"]*\")"; 

/* Verifica si la dirección de email está representada con una dirección IP Válida */ 


var ipDomainPat=/^\[(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})\]$/;


/* Verificar caracteres inválidos */ 

var atom=validChars + '+';
var word="(" + atom + "|" + quotedUser + ")";
var userPat=new RegExp("^" + word + "(\\." + word + ")*$");
/* domain, as opposed to ipDomainPat, shown above. */
var domainPat=new RegExp("^" + atom + "(\\." + atom +")*$");


var matchArray=emailStr.match(emailPat)
if (matchArray==null) {
/*alert("Email address seems incorrect (check @ and .'s)");*/
return false
}
var user=matchArray[1]
var domain=matchArray[2]

// Si el user "user" es valido 
if (user.match(userPat)==null) {
// Si no
/*alert("El nombre de usuario no es válido.");*/
return false
}

/* Si la dirección IP es válida */
var IPArray=domain.match(ipDomainPat)
if (IPArray!=null) {
for (var i=1;i<=4;i++) {
if (IPArray[i]>255) {
/*alert("IP de destino inválida");*/
return false
}
}
return true
}

var domainArray=domain.match(domainPat)
if (domainArray==null) {
/*alert("El dominio parece no ser válido.");*/
return false
}

var atomPat=new RegExp(atom,"g")
var domArr=domain.match(atomPat)
var len=domArr.length
if (domArr[domArr.length-1].length<2 || domArr[domArr.length-1].length>3) { 

/*alert("La dicrección debe tener 3 letras si es .'com' o 2 si en de algún pais.");*/
return false
}

if (len<2) {
var errStr="La dirección es erronea"
/*alert(errStr);*/
return false
}

// La dirección de email ingresada es Válida
return true;
}
// End -->

function logea(){
if (document.getElementById("usu").value == "")
{ alert("Debe introducir nombre de usuario"); document.getElementById("usu").focus(); return false; }
if (document.getElementById("pass").value == "")
{ alert("Debe introducir su contrase\u00F1a"); document.getElementById("pass").focus(); return false; }
document.getElementById("fentrar").submit();
}


function Validar(){
if (document.getElementById("nombre").value == "")
{ alert("Debe proporcionarnos su Nombre"); document.getElementById("nombre").focus(); return false; }

var mail=emailCheck(document.getElementById("smail").value);
if (mail == false)
{ alert("Debe introducir un e-mail correcto"); document.getElementById("smail").focus(); return false; }

if (document.getElementById("tlf").value == "")
{ alert("Debe proporcionarnos su Telefono"); document.getElementById("tlf").focus(); return false; }

if (document.getElementById("privacidad").checked == false)
{ alert("Debe aceptar la politica de privacidad"); document.getElementById("privacidad").focus(); return false; }

document.getElementById("contactar").submit();
}
