// ----------------------------------------------------------------------
// Javascript form validation routines.
// Original Author: Stephen Poley
// Adapted and Modified by Roberto Zingales, 2008
//
// Simple routines to quickly pick up obvious typos.
// All validation routines return true if executed by an older browser:
// in this case validation must be left to the server.
//
// Update Jun 2005: discovered that reason IE wasn't setting focus was
// due to an IE timing bug. Added 0.1 sec delay to fix.
//
// Update Oct 2005: minor tidy-up: unused parameter removed
//
// Update Jun 2006: minor improvements to variable names and layout

// ----------------------------------------------------------------------

var nbsp = 160;		// non-breaking space char
var node_text = 3;	// DOM text node-type
var emptyString = /^\s*$/ ;
var global_valfield;	// retain valfield for timer thread

// --------------------------------------------
//                  trim
// Trim leading/trailing whitespace off string
// --------------------------------------------

function trim(str)
{
  return str.replace(/^\s+|\s+$/g, '');
}


// --------------------------------------------
//                  setfocus
// Delayed focus setting to get around IE bug
// --------------------------------------------

function setFocusDelayed()
{
  global_valfield.focus();
}

function setfocus(valfield)
{
  // save valfield in global variable so value retained when routine exits
  global_valfield = valfield;
  setTimeout( 'setFocusDelayed()', 100 );
}


// --------------------------------------------
//                  msg
// Display warn/error message in HTML element.
// commonCheck routine must have previously been called
// --------------------------------------------

function msg(fld,     // id of element to display message in
             msgtype, // class to give element ("warn" or "error")
             message) // string to display
{
  // setting an empty string can give problems if later set to a 
  // non-empty string, so ensure a space present. (For Mozilla and Opera one could 
  // simply use a space, but IE demands something more, like a non-breaking space.)
  var dispmessage;
  if (emptyString.test(message)) 
    dispmessage = String.fromCharCode(nbsp);    
  else  
    dispmessage = message;

  var elem = document.getElementById(fld);
  elem.firstChild.nodeValue = dispmessage;  
  
  elem.className = msgtype;   // set the CSS class to adjust appearance of message
}

// --------------------------------------------
//            commonCheck
// Common code for all validation routines to:
// (a) check for older / less-equipped browsers
// (b) check if empty fields are required
// Returns true (validation passed), 
//         false (validation failed) or 
//         proceed (don't know yet)
// --------------------------------------------

var proceed = 2;  

function commonCheck    (valfield,   // element to be validated
                         infofield,  // id of element to receive info/error msg
                         required)   // true if required
{
  if (!document.getElementById) 
    return true;  // not available on this browser - leave validation to the server
  var elem = document.getElementById(infofield);
  if (!elem.firstChild) return true;  // not available on this browser 
  if (elem.firstChild.nodeType != node_text) return true;  // infofield is wrong type of node  

  if (emptyString.test(valfield.value)) {
    if (required) {
      msg (infofield, "error", "ERRORE: richiesto");  
      setfocus(valfield);
      return false;
    }
    else {
      msg (infofield, "warn", "");   // OK
      return true;  
    }
  }
  return proceed;
}

// --------------------------------------------
//            validatePresent
// Validate if something has been entered
// Returns true if so 
// --------------------------------------------

function validatePresent(valfield,   // element to be validated
                         infofield ) // id of element to receive info/error msg
{
  var stat = commonCheck (valfield, infofield, true);
  if (stat != proceed) return stat;

  msg (infofield, "warn", "");  
  return true;
}

// --------------------------------------------
//               validateEmail
// Validate if e-mail address
// Returns true if so (and also if could not be executed because of old browser)
// --------------------------------------------

function validateEmail  (valfield,   // element to be validated
                         infofield,  // id of element to receive info/error msg
                         required)   // true if required
{
  var stat = commonCheck (valfield, infofield, required);
  if (stat != proceed) return stat;

  var tfld = trim(valfield.value);  // value of field with whitespace trimmed off
  var email = /^[^@]+@[^@.]+\.[^@]*\w\w$/  ;
  if (!email.test(tfld)) {
    msg (infofield, "error", "ERRORE: indirizzo non valido");
    setfocus(valfield);
    return false;
  }

  var email2 = /^[A-Za-z][\w.-]+@\w[\w.-]+\.[\w.-]*[A-Za-z][A-Za-z]$/  ;
  if (!email2.test(tfld)) 
    msg (infofield, "warn", "Indirizzo email inusuale : sei sicuro?");
  else
    msg (infofield, "warn", "");
  return true;
}


// --------------------------------------------
//            validateTelnr
// Validate telephone number
// Returns true if so (and also if could not be executed because of old browser)
// Permits spaces, hyphens, brackets and leading +
// --------------------------------------------

function validateTelnr  (valfield,   // element to be validated
                         infofield,  // id of element to receive info/error msg
                         required)   // true if required
{
  var stat = commonCheck (valfield, infofield, required);
  if (stat != proceed) return stat;

  var tfld = trim(valfield.value);  // value of field with whitespace trimmed off
  var telnr = /^\+?[0-9 ()-]+[0-9]$/  ;
  if (!telnr.test(tfld)) {
    msg (infofield, "error", "ERRORE: numero di telefono non valido. Puoi inserire numeri, lo spazio ()- ed un + iniziale");
    setfocus(valfield);
    return false;
  }

  var numdigits = 0;
  for (var j=0; j<tfld.length; j++)
    if (tfld.charAt(j)>='0' && tfld.charAt(j)<='9') numdigits++;

  if (numdigits<6) {
    msg (infofield, "error", "ERRORE: " + numdigits + " cifre - troppo corto");
    setfocus(valfield);
    return false;
  }

  if (numdigits>14)
    msg (infofield, "warn", numdigits + " cifre - controlla la correttezza");
  else { 
    if (numdigits<10)
      msg (infofield, "warn", "Solo " + numdigits + " cifre - controlla la correttezza");
    else
      msg (infofield, "warn", "");
  }
  return true;
}

// --------------------------------------------
//             validateAge
// Validate person's age
// Returns true if OK 
// --------------------------------------------

function validateAge    (valfield,   // element to be validated
                         infofield,  // id of element to receive info/error msg
                         required)   // true if required
{
  var stat = commonCheck (valfield, infofield, required);
  if (stat != proceed) return stat;

  var tfld = trim(valfield.value);
  var ageRE = /^[0-9]{1,3}$/
  if (!ageRE.test(tfld)) {
    msg (infofield, "error", "ERRORE: valore non valido");
    setfocus(valfield);
    return false;
  }

  if (tfld>=200) {
    msg (infofield, "error", "ERRORE: valore non valido");
    setfocus(valfield);
    return false;
  }

  if (tfld>110) msg (infofield, "warn", "Oltre 110 anni: sei sicuro?");
  else {
    if (tfld<7) msg (infofield, "warn", "Un po troppo giovane, non credi?");
    else        msg (infofield, "warn", "");
  }
  return true;
}



// --------------------------------------------
//             validateNum
// Checks if a number is in the given range 
// Returns true if OK (created by roz modifying validateage)
// restituisce true se il numero è >= valore minimo , e <= valore massimo
// restituisce false se il numero è <val minimo oppure se è > val massimo
// in caso di dubbio restituisce true, per permettere di continuare l'elaborazione del form
// --------------------------------------------

function validateNum    (valfield,   // element to be validated
                         infofield,  // id of element to receive info/error msg
						 valoreminimo, valoremassimo, // valore minimo e massimo accettabile
                         required)   // true if required
{
  var stat = commonCheck (valfield, infofield, required);
  if (stat != proceed) return stat;

  var tfld = trim(valfield.value);
  var ageRE = /^[0-9]{1,3}$/
  if (!ageRE.test(tfld)) {
    msg (infofield, "error", "ERRORE: numero non valido");
    setfocus(valfield);
    return false;
  }
if ((tfld>=valoreminimo) && (tfld<=valoremassimo))  {
    msg (infofield, "error", "ok");
    return true;
  }
 
 if (tfld>valoremassimo) {
    msg (infofield, "error", "ERRORE: numero troppo grande");
    setfocus(valfield);
    return false;
  }
  
  if (tfld<valoreminimo) {
    msg (infofield, "error", "ERRORE: numero troppo piccolo");
    setfocus(valfield);
    return false;
  }

  return true;
}

// --------------------------------------------
//            checkBoxcommonCheck (by RoZ)
// Common code for all validation routines to:
// (a) check for older / less-equipped browsers
// (b) check if unchecked checkboxes are required
// Returns true (validation passed), 
//         false (validation failed) or 
//         proceed (don't know yet)
// --------------------------------------------


// controlla che il consenso privacy sia attivato prima di permettere la spedizione del messaggio!
// --------------------------------------------
//             validateConsensoPrivacy
// Checks if a number is in the given range 
// Returns true if OK (created by roz modifying validateage)
// --------------------------------------------

function validateConsensoPrivacy   (valfield,   // checkbox-element to be validated
                         infofield,  // id of element to receive info/error msg
                         required)   // true if required
{	var yeahproceed = 2;  
   if (!document.getElementById) 
   return true;  // not available on this browser - leave validation to the server
    var elem = document.getElementById(infofield); // controllo che infofied sia ok per mostrare gli avvertimenti
    if (!elem.firstChild) return true;  // not available on this browser 
	if (elem.firstChild.nodeType != node_text) return true;  // infofield is wrong type of node, pertanto non posso mostrare il messaggio!
 	
	var  checkboxino = valfield.checked; //se tutto e' ok leggo il cvalore della proprieta' checked del checkbox
	 if (!checkboxino) { // se il checkbox non è marcato...
   			 			if (required) { //nel caso sia un campo obbligatorio...
   								  msg (infofield, "error", "ERRORE: richiesto");   // mostro il messaggio nel campo infofield
    			 		   		  setfocus(valfield); // e riporto il focus sul checkbox
   				   			 	  return false; // e restituisco falso, uscendo dalla funzione
  					 				  } 
   							 else { // nel caso che non sia required non mostro nulla e non mi lamento
    							   msg (infofield, "warn", "");   // OK
   								   return true; //esce dalla funzione 
 								   } // fine di "if required"
  					    }  // fine di if not checkboxino
	  // se invece il boxino e' checcakto...
	msg (infofield, "warn", "Adesso potremo risponderti! Grazie!");   // ringrazio l'utente per lautorizzazione}
	 
  return yeahproceed; // ok mpare puoi continuare
}




/* Funzione shoHide
----------------------------------------------------------------*/
// adesso una funzioncina per mostrare o nascondere i dati di prenotazione
// uso: onclick="showHide('esempio'); return(false);"
// uso per il div: <div style="display: none;" id="esempio">
// nota: il nome delle funzioni js e' camelcase sensitive!!!
// usato ad esempio  per mostrare il div dei campi necessari per prenotare, solo se si vuole prenotare.
// nota: se usi onchange su un checkbox IE attiva l'evento solo quando il checkbox perde il focus... puagh!
// suggerimento:per non escludere gli utenti con  browser senza javascript e' bene in html inizializzare il div come visibile, 
// quindi in body onload nasconderlo in javascript (o in altro modo ad esempio tramite il tag noscript attivo sul tag iniziale del div) , ed eventualmente rimostrarlo con javascript se serve.
// se js e' disattivato il div resta comunque visibile.
function showHide(id){
if (document.getElementById){
obj = document.getElementById(id);
if (obj.style.display == "none"){
obj.style.display = "";
} else {
obj.style.display = "none";
}
}
} 


function nascondi(id){
if (document.getElementById){
obj = document.getElementById(id);

obj.style.display = "none";
}
} 


/* ______________ empyvalidation _______________________________________________ 

Controlla se il field è vuoto.
Parametri opzionali sono:
text --testo per la casella di allarme se il contenuto è illegale.

*/
function emptyValidation(entered, alertbox)
{
// Emptyfield Validation by Henrik Petersen / NetKontoret
// Explained at www.echoecho.com/jsforms.htm
// Please do not remove this line and the two lines above.
with (entered)
{
if (value==null || value=="")
{if (alertbox!="") {alert(alertbox);} return false;}
else {return true;}
}
} 




