// *****************************************
//  FUNCAO PARA VERIFICACAO DE EMAIL VALIDO
// *****************************************
function emailCheck (emailStr) {
	/* The following pattern is used to check if the entered e-mail address
	   fits the user@domain format.  It also is used to separate the username
	   from the domain. */
	var emailPat=/^(.+)@(.+)$/;
	/* The following string represents the pattern for matching all special
	   characters.  We don't want to allow special characters in the address.
	   These characters include ( ) < > @ , ; : \ " . [ ]    */
	var specialChars="\\(\\)<>@,;:\\\\\\\"\\.\\[\\]";
	/* The following string represents the range of characters allowed in a
	   username or domainname.  It really states which chars aren't allowed. */
	var validChars="\[^\\s" + specialChars + "\]";
	/* The following pattern applies if the "user" is a quoted string (in
	   which case, there are no rules about which characters are allowed
	   and which aren't; anything goes).  E.g. "jiminy cricket"@disney.com
	   is a legal e-mail address. */
	var quotedUser="(\"[^\"]*\")";
	/* The following pattern applies for domains that are IP addresses,
	   rather than symbolic names.  E.g. joe@[123.124.233.4] is a legal
	   e-mail address. NOTE: The square brackets are required. */
	var ipDomainPat=/^\[(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})\]$/;
	/* The following string represents an atom (basically a series of
	   non-special characters.) */
	var atom=validChars + '+';
	/* The following string represents one word in the typical username.
	   For example, in john.doe@somewhere.com, john and doe are words.
	   Basically, a word is either an atom or quoted string. */
	var word="(" + atom + "|" + quotedUser + ")";
	// The following pattern describes the structure of the user
	var userPat=new RegExp("^" + word + "(\\." + word + ")*$");
	/* The following pattern describes the structure of a normal symbolic
	   domain, as opposed to ipDomainPat, shown above. */
	var domainPat=new RegExp("^" + atom + "(\\." + atom +")*$");


	/* Finally, let's start trying to figure out if the supplied address is
	   valid. */

	/* Begin with the coarse pattern to simply break up user@domain into
	   different pieces that are easy to analyze. */
	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("Email address seems incorrect (check @ and .'s)");
		alert("O E-mail que colocou está incorrecto (verifique @ e .)");
		return;
	}
	var user=matchArray[1];
	var domain=matchArray[2];

	// See if "user" is valid
	if (user.match(userPat)==null) {
		// user is not valid
		//alert("The username doesn't seem to be valid.");
		alert("O nome do utilizador não parece ser válido.");
		return;
	}

	/* 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("Destination IP address is invalid!");
				alert("O IP de destino é inválido!");
				return;
			}
		}
//		return true;
	}

	// Domain is symbolic name
	var domainArray=domain.match(domainPat);
	if (domainArray==null) {
		//alert("The domain name doesn't seem to be valid.");
		alert("O domínio não parece ser válido.");
		return;
	}

	/* domain name seems valid, but now make sure that it ends in a
	   three-letter word (like com, edu, gov) or a two-letter word,
	   representing country (uk, nl), and that there's a hostname preceding
	   the domain or country. */

	/* Now we need to break up the domain to get a count of how many atoms
	   it consists of. */
	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("The address must end in a three-letter domain, or two letter country.");
	   alert("O E-mail tem de acabar com um domínio de 3 letras ou com as 2 letras do país.");
	   return;
	}

	// Make sure there's a host name preceding the domain.
	if (len<2) {
	   //var errStr="This address is missing a hostname!";
	   var errStr="O E-mail não tem hostname!";
	   alert(errStr);
	   return;
	}
	// If we've gotten this far, everything's valid!
	return true;
}

function Trim(String){
	var i = 0;
	var j = String.length - 1;

	if (String == null)
		return (false);

	for (i = 0; i < String.length; i++)
	{
		if (String.substr(i, 1) != ' ' &&
		    String.substr(i, 1) != '\t')
			break;
	}

	for(j = String.length - 1; j >= 0; j--)
	{
		if (String.substr(j, 1) != ' ' &&
			String.substr(j, 1) != '\t')
		break;
	}

	if (i <= j)
		return (String.substr(i, (j+1)-i));
	else
		return ('');
}



function sendSugestao() {
	
	var termo = new String();
	termo = document.frm_sugestoes.txtCartao.value;		
	if (termo.indexOf('\'') >= 0){
		alert('O campo \"Nº Cartão\" não pode conter o caracter \' (plica).');
		document.frm_sugestoes.txtCartao.focus();
		return;
	}

	if (termo.indexOf('%') >= 0){
		alert('O campo \"Nº Cartão\" não pode conter o caracter \'%\'.');
		document.frm_sugestoes.txtCartao.focus();
		return;
	}
	
	if (termo == '') {
		alert('O campo \"Nº Cartão\" é obrigatório.');
		document.frm_sugestoes.txtCartao.focus();
		return;
	}
	if (Trim(termo).length < 3) {
		alert(' Introduza, pelo menos 3 caracteres no campo \"Nº Cartão\"');
		document.frm_sugestoes.txtCartao.focus();
		return;
	}
	
	termo = document.frm_sugestoes.txtNome.value;		
	if (termo.indexOf('\'') >= 0){
		alert('O campo \"Nome\" não pode conter o caracter \' (plica).');
		document.frm_sugestoes.txtNome.focus();
		return;
	}

	if (termo.indexOf('%') >= 0){
		alert('O campo \"Nome\" não pode conter o caracter \'%\'.');
		document.frm_sugestoes.txtNome.focus();
		return;
	}
	
	if (termo.value == '') {
		alert('O campo \"Nome\" é obrigatório.');
		document.frm_sugestoes.txtNome.focus();
		return;
	}
	if (Trim(termo).length < 3) {
		alert(' Introduza, pelo menos 3 caracteres no campo \"Nome\"');
		document.frm_sugestoes.txtNome.focus();
		return;
	}
	
	termo = document.frm_sugestoes.txtEmail.value;		
	if (termo.indexOf('\'') >= 0){
		alert('O campo \"E-mail\" não pode conter o caracter \' (plica).');
		document.frm_sugestoes.txtEmail.focus();
		return;
	}

	if (termo.indexOf('%') >= 0){
		alert('O campo \"E-mail\" não pode conter o caracter \'%\'.');
		document.frm_sugestoes.txtEmail.focus();
		return;
	}
	
	if (termo.value == '') {
		alert('O campo \"E-mail\" é obrigatório.');
		document.frm_sugestoes.txtEmail.focus();
		return;
	}
	if (Trim(termo).length < 3) {
		alert(' Introduza, pelo menos 3 caracteres no campo \"E-mail\"');
		document.frm_sugestoes.txtEmail.focus();
		return;
	}
	if (!emailCheck(termo)){
		return;
	}
	
	termo = document.frm_sugestoes.txtSugestao.value;		
	if (termo.indexOf('\'') >= 0){
		alert('O campo \"Sugestão\" não pode conter o caracter \' (plica).');
		document.frm_sugestoes.txtSugestao.focus();
		return;
	}

	if (termo.indexOf('%') >= 0){
		alert('O campo \"Sugestão\" não pode conter o caracter \'%\'.');
		document.frm_sugestoes.txtSugestao.focus();
		return;
	}
	
	if (termo.value == '') {
		alert('O campo \"Sugestão\" é obrigatório.');
		document.frm_sugestoes.txtSugestao.focus();
		return;
	}
	if (Trim(termo).length < 3) {
		alert(' Introduza, pelo menos 3 caracteres no campo \"Sugestão\"');
		document.frm_sugestoes.txtSugestao.focus();
		return;
	}
		
	document.forms["frm_sugestoes"].submit();
}


function sendPreInsc(){
	var termo = new String();	
	termo = document.frm_preinsc.txtNome.value;		
	if (termo.indexOf('\'') >= 0){
		alert('O campo \"Nome\" não pode conter o caracter \' (plica).');
		document.frm_preinsc.txtNome.focus();
		return;
	}

	if (termo.indexOf('%') >= 0){
		alert('O campo \"Nome\" não pode conter o caracter \'%\'.');
		document.frm_preinsc.txtNome.focus();
		return;
	}
	
	if (termo.value == '') {
		alert('O campo \"Nome\" é obrigatório.');
		document.frm_preinsc.txtNome.focus();
		return;
	}
	if (Trim(termo).length < 3) {
		alert(' Introduza, pelo menos 3 caracteres no campo \"Nome\"');
		document.frm_preinsc.txtNome.focus();
		return;
	}
			
	termo = document.frm_preinsc.txtDtaNasc.value;		
	if (termo.indexOf('\'') >= 0){
		alert('O campo \"Data Nascimento\" não pode conter o caracter \' (plica).');
		document.frm_preinsc.txtDtaNasc.focus();
		return;
	}

	if (termo.indexOf('%') >= 0){
		alert('O campo \"Data Nascimento\" não pode conter o caracter \'%\'.');
		document.frm_preinsc.txtDtaNasc.focus();
		return;
	}
	
	if (termo.value == '') {
		alert('O campo \"Data Nascimento\" é obrigatório.');
		document.frm_preinsc.txtDtaNasc.focus();
		return;
	}
	if (Trim(termo).length < 3) {
		alert(' Introduza, pelo menos 3 caracteres no campo \"Data Nascimento\"');
		document.frm_preinsc.txtDtaNasc.focus();
		return;
	}
	
	termo = document.frm_preinsc.txtBI.value;		
	if (termo.indexOf('\'') >= 0){
		alert('O campo \"BI\" não pode conter o caracter \' (plica).');
		document.frm_preinsc.txtBI.focus();
		return;
	}

	if (termo.indexOf('%') >= 0){
		alert('O campo \"BI\" não pode conter o caracter \'%\'.');
		document.frm_preinsc.txtBI.focus();
		return;
	}
	
	if (termo.value == '') {
		alert('O campo \"BI\" é obrigatório.');
		document.frm_preinsc.txtBI.focus();
		return;
	}
	if (Trim(termo).length < 3) {
		alert(' Introduza, pelo menos 3 caracteres no campo \"BI\"');
		document.frm_preinsc.txtBI.focus();
		return;
	}
	
	termo = document.frm_preinsc.txtNIF.value;		
	if (termo.indexOf('\'') >= 0){
		alert('O campo \"Nº Contribuinte\" não pode conter o caracter \' (plica).');
		document.frm_preinsc.txtNIF.focus();
		return;
	}

	if (termo.indexOf('%') >= 0){
		alert('O campo \"Nº Contribuinte\" não pode conter o caracter \'%\'.');
		document.frm_preinsc.txtNIF.focus();
		return;
	}
	
	if (termo.value == '') {
		alert('O campo \"Nº Contribuinte\" é obrigatório.');
		document.frm_preinsc.txtNIF.focus();
		return;
	}
	if (Trim(termo).length < 3) {
		alert(' Introduza, pelo menos 3 caracteres no campo \"Nº Contribuinte\"');
		document.frm_preinsc.txtNIF.focus();
		return;
	}
	
	termo = document.frm_preinsc.txtEmail.value;		
	if (termo.indexOf('\'') >= 0){
		alert('O campo \"E-mail\" não pode conter o caracter \' (plica).');
		document.frm_preinsc.txtEmail.focus();
		return;
	}

	if (termo.indexOf('%') >= 0){
		alert('O campo \"E-mail\" não pode conter o caracter \'%\'.');
		document.frm_preinsc.txtEmail.focus();
		return;
	}
	
	if (termo.value == '') {
		alert('O campo \"E-mail\" é obrigatório.');
		document.frm_preinsc.txtEmail.focus();
		return;
	}
	if (Trim(termo).length < 3) {
		alert(' Introduza, pelo menos 3 caracteres no campo \"E-mail\"');
		document.frm_preinsc.txtEmail.focus();
		return;
	}
	if (!emailCheck(termo)){
		return;
	}
		
	document.forms["frm_preinsc"].submit();
}

function sendPedirInfo(){
	var termo = new String();
	termo = document.frm_pedirinfo.txtCartao.value;		
	if (termo.indexOf('\'') >= 0){
		alert('O campo \"Nº Cartão\" não pode conter o caracter \' (plica).');
		document.frm_pedirinfo.txtCartao.focus();
		return;
	}

	if (termo.indexOf('%') >= 0){
		alert('O campo \"Nº Cartão\" não pode conter o caracter \'%\'.');
		document.frm_pedirinfo.txtCartao.focus();
		return;
	}
	
	if (termo == '') {
		alert('O campo \"Nº Cartão\" é obrigatório.');
		document.frm_pedirinfo.txtCartao.focus();
		return;
	}
	if (Trim(termo).length < 3) {
		alert(' Introduza, pelo menos 3 caracteres no campo \"Nº Cartão\"');
		document.frm_pedirinfo.txtCartao.focus();
		return;
	}
	
	termo = document.frm_pedirinfo.txtNome.value;		
	if (termo.indexOf('\'') >= 0){
		alert('O campo \"Nome\" não pode conter o caracter \' (plica).');
		document.frm_pedirinfo.txtNome.focus();
		return;
	}

	if (termo.indexOf('%') >= 0){
		alert('O campo \"Nome\" não pode conter o caracter \'%\'.');
		document.frm_pedirinfo.txtNome.focus();
		return;
	}
	
	if (termo.value == '') {
		alert('O campo \"Nome\" é obrigatório.');
		document.frm_pedirinfo.txtNome.focus();
		return;
	}
	if (Trim(termo).length < 3) {
		alert(' Introduza, pelo menos 3 caracteres no campo \"Nome\"');
		document.frm_pedirinfo.txtNome.focus();
		return;
	}
	
	termo = document.frm_pedirinfo.txtEmail.value;		
	if (termo.indexOf('\'') >= 0){
		alert('O campo \"E-mail\" não pode conter o caracter \' (plica).');
		document.frm_pedirinfo.txtEmail.focus();
		return;
	}

	if (termo.indexOf('%') >= 0){
		alert('O campo \"E-mail\" não pode conter o caracter \'%\'.');
		document.frm_pedirinfo.txtEmail.focus();
		return;
	}
	
	if (termo.value == '') {
		alert('O campo \"E-mail\" é obrigatório.');
		document.frm_pedirinfo.txtEmail.focus();
		return;
	}
	if (Trim(termo).length < 3) {
		alert(' Introduza, pelo menos 3 caracteres no campo \"E-mail\"');
		document.frm_pedirinfo.txtEmail.focus();
		return;
	}
	if (!emailCheck(termo)){
		return;
	}
	
	document.forms["frm_pedirinfo"].submit();	
}

function openImg(url) {
	var leftPos = screen.availWidth/2-(640/2);
	var topPos = screen.availHeight/2-(480/2);
	var janela = window.open("imagem.asp?url=" + url,'Imagem',"scrollbars=no, height=480, width=640,location=no, left=" + leftPos + ", top=" + topPos + ",topmargin=0,leftmargin=0");
	return;
}
