// JavaScript Document
function Check_email()
{
var frm = document.form;
var emailStr = frm.txt_email.value;

// for checking email

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 +")*$")
//********************************

//********** email check *****************

var matchArray=emailStr.match(emailPat)
if (matchArray==null) {
  /* Too many/few @'s or something; basically, this address doesn't
     even fit the general mould of a valid e-mail address. */
        alert("Adresa de email pare incorecta! (verifica numarul de '@' si '.')")
        document.form.txt_email.select()
        document.form.txt_email.focus()
        return false
}
var user=matchArray[1]
var domain=matchArray[2]

// See if "user" is valid
if (user.match(userPat)==null) {
    // user is not valid
    alert("Username-ul adresei nu pare a fi valid")
        document.form.txt_email.select()
        document.form.txt_email.focus()
    return false
}

/* if the e-mail address is at an IP address (as opposed to a symbolic
   host name) make sure the IP address is valid. */
var IPArray=domain.match(ipDomainPat)
if (IPArray!=null) {
    // this is an IP address
          for (var i=1;i<=4;i++) {
            if (IPArray[i]>255) {
                alert("Adresa IP a serverului de email este invalida!")
                document.form.txt_email.select()
                document.form.txt_email.focus()
                return false
            }
    }

    //return true
}

// Domain is symbolic name
/*
var domainArray=domain.match(domainPat)
if (domainArray==null) {
        alert("The domain name doesn't seem to be valid.")
        document.form.txt_email.select()
        document.form.txt_email.focus()
    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) {
   // the address must end in a two letter or three letter word.
   alert("Adresa de email trebuie sa se termine intr-un domeniu din 3 litere sau o tara din 2 litere.")
   document.form.txt_email.select()
   document.form.txt_email.focus()
   return false
}

// Make sure there's a host name preceding the domain.
if (len<2) {
   var errStr="Adresa de email nu are definita serverul de email (hostname)!"
   alert(errStr)
   document.form.txt_email.select()
   document.form.txt_email.focus()
   return false
}


//*************** end email check ***************

return true;
}//end function
