// ----------------------------------------------------------------------
// Javascript form validation routines.
// Author: Stephen Poley
//
// 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;    //FIXME  changed to line below??
  //elem.innerHTML = 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
		       infomsg,
		       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  FIXME  FIXME

    if (emptyString.test(valfield.value)) {
	if (required) {
	    msg (infofield, "error", infomsg); //"ERROR: required");  
	    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
			 infomsg)     //info msg if field is empty
{
  var stat = commonCheck (valfield, infofield, infomsg, 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
			 infomsg,    //info msg if field is empty
                         required)   // true if required
{
  var stat = commonCheck (valfield, infofield, infomsg, required);
  if (stat != proceed) return stat;

  var tfld = trim(valfield.value);  // value of field with whitespace trimmed off
  if (!isOkEmail(tfld)) {
    msg (infofield, "error", infomsg);
    setfocus(valfield);
    return false;
  }
   msg (infofield, "warn", "");  
//   var email2 = /^[A-Za-z][\w.-]+@\w[\w.-]+\.[\w.-]*[A-Za-z][A-Za-z]$/  ;
//   if (!email2.test(tfld)) 
//     msg (infofield, "warn", "Unusual e-mail address - check if correct");
//   else {
//     msg (infofield, "warn", "");
//   }


  return true;
}

function isOkEmail(email) {
  var emailpat = /^[^@]+@[^@.]+\.[^@]*\w\w$/  ;
  if (!emailpat.test(email)) {
    return false;
  }
  return true;
}

function validatePassword  (valfield,   // element to be validated
			    infofield,  // id of element to receive info/error msg
			    infomsg,    //info msg if field is empty
			    required)   // true if required
{
  var stat = commonCheck (valfield, infofield, infomsg, required);
  if (stat != proceed) return stat;
  var tfld = trim(valfield.value);  // value of field with whitespace trimmed off
  if (tfld.length >= 6) {
      msg(infofield, "warn", "");	
      return true;
  }
  else {
       msg (infofield, "error", infomsg);
       setfocus(valfield);
       return false;
  }
}
      
function validateChecked (valfield,   // element to be validated
                         infofield,  // id of element to receive info/error msg
			  infomsg)
{
    
    if (valfield.checked) {
	msg (infofield, "warn", "");
	return true;
    }
    else {
	msg (infofield, "error", infomsg);
	return false;
    }
}

// --------------------------------------------
//            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 validatePhone  (valfield,   // element to be validated
                         infofield,  // id of element to receive info/error msg
			 infomsg,     //info msg if field is empty
                         required)   // true if required
{
  var stat = commonCheck (valfield, infofield, infomsg, required);
  if (stat != proceed) return stat;

  var tfld = trim(valfield.value);  // value of field with whitespace trimmed off
//  var us_telnr = /^\(?\d{3}\)?(\s|-)\d{3}-\d{4}$/;   //Matches US phone (###-###-#### or (###) ###-####) 
  var us_telnr = /^\d{3}\-\d{3}\-\d{4}$/;   //Matches US phone ###-###-####
  var intl_telnr = /^\d(\d|-){7,20}/;
  //var telnr = /^\+?[0-9 ()-]+[0-9]$/  ;
  if (!us_telnr.test(tfld)) {
    msg (infofield, "error", infomsg);
    //msg (infofield, "error", "ERROR: not a valid telephone number. Characters permitted are digits, space ()- and leading +");
    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", "ERROR: " + numdigits + " digits - too short");
//     setfocus(valfield);
//     return false;
//   }

//   if (numdigits>14) {
//     msg (infofield, "warn", numdigits + " digits - check if correct");
//   }
//   else { 
//     if (numdigits<10)
//       msg (infofield, "warn", "Only " + numdigits + " digits - check if correct");
//     else
//       msg (infofield, "warn", "");
//   }
  msg (infofield, "warn", "");
  return true;
}


//COMMENT OUT WEBSITE VALIDATATION 3/11/08
// function validateURL  (valfield,   // element to be validated
// 		       infofield,  // id of element to receive info/error msg
// 		       infomsg,     //info msg if field is empty
// 		       required)   // true if required
// {
//     var stat = commonCheck (valfield, infofield, infomsg, required);
//    if (stat != proceed) return stat;
// 
//    var tfld = trim(valfield.value);  // value of field with whitespace trimmed off
//     //var urlregex = /^(http:\/\/|)[A-Za-z0-9\.-]{3,}\.[A-Za-z]{3}/;
//    var urlregex = /^(http:\/\/)?([\w-]+\.)+[a-z]{2,6}$/i;
//
//    if (!urlregex.test(tfld)) {
//         msg (infofield, "error", infomsg);
// 	setfocus(valfield);
// 	return false;
//    }
//    msg (infofield, "warn", "");
//    return true;
// }

function validateZipCode  (valfield,   // element to be validated
			   infofield,  // id of element to receive info/error msg
			   infomsg,     //info msg if field is empty
			   required)   // true if required
{
    var stat = commonCheck (valfield, infofield, infomsg, required);
    if (stat != proceed) return stat;

    var tfld = trim(valfield.value);  // value of field with whitespace trimmed off
    var zipregex = /(^\d{5}$)|(^\d{5}-\d{4}$)/;
 
    if (!zipregex.test(tfld)) {
	msg (infofield, "error", infomsg);
	setfocus(valfield);
	return false;
    }
    msg (infofield, "warn", "");
    return true;
}


