/* this whole js file is used for web user form validation on email fields- I don't know if the function checkUsername() is used anywhere */ 
/* PW: not totally true... this is to be a general formUtils js file now...  */

function emailCheck (emailStr) {

/* The following variable tells the rest of the function whether or not
to verify that the address ends in a two-letter country or well-known
TLD.  1 means check it, 0 means don't. */

var checkTLD=0;

/* The following is the list of known TLDs that an e-mail address must end with. */

var knownDomsPat=/^(com|net|org|edu|int|mil|gov|arpa|biz|aero|name|coop|info|pro|museum)$/;

/* 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)");
return false;
}
var user=matchArray[1];
var domain=matchArray[2];

// Start by checking that only basic ASCII characters are in the strings (0-127).

for (i=0; i<user.length; i++) {
if (user.charCodeAt(i)>127) {
alert("Ths username in the email address contains invalid characters.");
return false;
   }
}
for (i=0; i<domain.length; i++) {
if (domain.charCodeAt(i)>127) {
alert("Ths domain name in the email address contains invalid characters.");
return false;
   }
}

// See if "user" is valid 

if (user.match(userPat)==null) {

// user is not valid

alert("The username in the email address doesn't seem to be valid.");
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("Destination IP address in email is invalid!");
return false;
   }
}
return true;
}

// Domain is symbolic name.  Check if it's valid.
 
var atomPat=new RegExp("^" + atom + "$");
var domArr=domain.split(".");
var len=domArr.length;
for (i=0;i<len;i++) {
if (domArr[i].search(atomPat)==-1) {
alert("The domain name does not seem to be valid in the email address.");
return false;
   }
}

/* domain name seems valid, but now make sure that it ends in a
known top-level domain (like com, edu, gov) or a two-letter word,
representing country (uk, nl), and that there's a hostname preceding 
the domain or country. */

if (checkTLD && domArr[domArr.length-1].length!=2 && 
domArr[domArr.length-1].search(knownDomsPat)==-1) {
alert("The email address must end in a well-known domain or two letter " + "country.");
return false;
}

// Make sure there's a host name preceding the domain.

if (len<2) {
alert("This address is missing a hostname!");
return false;
}

// If we've gotten this far, everything's valid!
return true;
}



function checkUsername(usernameStr)
{
  var specialChars="\\(\\)><,\\'&;:\\\\\\\"\\[\\] ";
  var validChars="\[^\\s" + specialChars + "\]";
  var atom=validChars + '+';
  var usernamePat=new RegExp("^" + atom + "$");
  if (usernameStr.match(usernamePat)==null) {
    alert("The username must not be empty and cannot contain spaces or the following special characters: ()<>,'&:;[]\\\"");
    return false;
  }
  else {
    return true;
  }
}


/* Form Validation (previously in cmscore.js) */

var requiredFields = new Array();
function addRequiredField(field)
{
  requiredFields.push(field);
}
function checkRequiredFields(form)
{
  for (i=0; i<requiredFields.length; i++) {
    if (requiredFields[i]) { //PW: new temp safety check to stop Moz errors
      if (requiredFields[i].getAttribute) field = requiredFields[i];
      else if (!form) field = document.all(requiredFields[i]);
      else field = form.elements[requiredFields[i]];
      
      if (field == null || field.value == "" || checkArray(field)) {
        message = "Missing Required Field: Please supply values for all required fields" + 
                  " (ie those marked with an *)";
        if (field && field.getAttribute) {
          if (field.getAttribute('displayName'))
            message += '\n' + field.getAttribute('displayName');
          else if (field.getAttribute('name')) {
            if (field.getAttribute('name').indexOf('cmf') == 0)
              message += '\n' + field.getAttribute('name').substring(3);
            else
              message += '\n' + field.getAttribute('name');
          }
        }  
        alert(message);
        return false;
      }
    }
  }
  return true;
}

function checkArray(list) {
  if (!list.length) return false;
  for (j=0; j < list.length; j++) {
    if (list[j].checked || list[j].selected) return false;
  }
  return true;
}




function getMultiValue(sel, req)
{
  var result = "";
  var sv = (req == 'yes') ? 0 : 1;
  for (var i=sv; i<sel.length; i++) {
    if (sel[i].selected) {
      result += sel[i].value + " | ";
    }
  }
  return result;
}

/* 
function getReport(){
    var url = "http://thetrac.thelevel.com/staging/reporting-result.csv?text_BathroomCountertopsText=&text_BathroomCabinetsText=&text_PlumbingText=&text_BathroomFlooringText=&text_KitchenCountertopsText=&text_KitchenCabinetsText=&text_FaucetSinkText=&text_BacksplashText=&text_KitchenFlooringText=&text_StandardAppliancesText=&text_UpgradeAppliancesText=&text_FridgeText=&text_RangeText=&text_DishwasherText=&text_HoodFanText=&text_MicrowaveText=&text_WasherDryerText=&text_SuiteFinishesFlooringText=&text_ColourSchemeText=&text_ParkingText=&text_ExteriorText=&text_ExteriorConstructionText=&text_InteriorConstructionText=&text_InteriorFeaturesText=&text_PrimaryPurchasers=&text_SecondaryPurchasers=&text_Traffic=&text_Advertising=&text_MinSize=&text_MaxSize=&text_PriceMin=&text_PriceMax=&text_PPSFMin=&text_PPSFMax=&text_AveragePPSF=&text_CurrentSellingPPSF=&text_StrataFeesPSF=&PropertyId=on&text_PropertyId=2137&text_ProjectName=&select_Status=&select_City=&select_PropertyType=&select_ConstructionType=&text_Website=&text_SalesOffice=&text_SalesOfficePhoneNumber=&text_Site=&text_OccupancyFrom=&text_OccupancyTo=&text_SalesStart=&text_Totalhomes=&text_HomesAvailable=&text_HomesYettoBeReleased=&text_HomesSold=&text_MonthlyAbsorptionRate=&text_HomesReleased=&text_Townhomes=&text_SingleFamily=&text_Condominiums=&text_CityHomes=&text_Lofts=&text_Penthouses=&text_Other=";
    
     var req = new Ajax.Request(
    url,
    {
      method: 'post',
      onFailure:  function(req) { alert('Update Task Status Failed.'); return false;},
      onComplete: function(req) {window.location = url;}
    }
  );      
} */



function reportingValidate(){
  message = "Invalid Search Criteria:\n";
  var a=checkDateFields();
  var b=checkNumberFields();
  var c=checkPriceFields();
  var d=checkInvalidTexts();
  if(a && b && c && d){
    return true;
  }
  else{
    alert(message);
    return false;
  }
}


var dateFields = new Array();
function addDateField(field){
  dateFields.push(field);
}

function checkDateFields(){
  var fields = new Array();
  for (i=0; i<dateFields.length; i++) {
    value = $('text_'+dateFields[i]).value;
    if(value != '' && (value.length != 8 || value.search(/^\d+$/) == -1 || parseFloat(value.substring(4,6)) > 12 || parseFloat(value.substring(6,8)) > 31)){
      fields.push(dateFields[i]);
    }
  }
  if(fields.length > 0)
  {
    for (j=0; j<fields.length; j++) {
      message = message + "-" + $('text_'+fields[j]).getAttribute('displayname') + "\n";
    }
    return false;
  }
  else{
    return true;
  }
}

var numberFields = new Array();
function addNumberField(field){
  numberFields.push(field);
}

function checkNumberFields(){
  var fields = new Array();
  for (i=0; i<numberFields.length; i++) {
    value = $('text_'+numberFields[i]).value;
    
    if(value != '' && value.search(/^\d+$/) == -1){
      fields.push(numberFields[i]);
    }
  }
  if(fields.length > 0)
  {
    for (j=0; j<fields.length; j++) {
      message = message + "-" + $('text_'+fields[j]).getAttribute('displayname') + "\n";
    }
    return false;
  }
  else{
    return true;
  } 
}

var PriceFields = new Array();
function addPriceField(field){
  PriceFields.push(field);
}

function checkPriceFields(){
  var fields = new Array();
	var pairedfields = new Array();
  for (i=0; i<PriceFields.length; i++) {
    value_fr = $('numfr_'+PriceFields[i]).value;
    value_to = $('numto_'+PriceFields[i]).value;
    if((value_fr != '' && value_fr.search(/^\d+$/) == -1) || (value_to != '' && value_to.search(/^\d+$/) == -1)){
      fields.push(PriceFields[i]);
    }
		if((value_fr == '' && value_to != '' ) || (value_fr != '' && value_to == '')){
			pairedfields.push(PriceFields[i]);
		}
  }
	
	
  if(pairedfields.length > 0)
  {
    for (j=0; j<pairedfields.length; j++) {
      message = message + "- please enter both the Min and Max values for " + $('numfr_'+pairedfields[j]).getAttribute('displayname') + "\n";
    }
  }
	
  if(fields.length > 0)
  {
    for (j=0; j<fields.length; j++) {
      message = message + "- " + $('numfr_'+fields[j]).getAttribute('displayname') + "\n";
    }
    
  }
	
	if(pairedfields.length > 0 || fields.length > 0) {
		return false;
  }else{
    return true;
  } 
}

var TextFields = new Array();
function addTextField(field){
  TextFields.push(field);
}

function checkInvalidTexts(){
  var fields = new Array();
  for (i=0; i<TextFields.length; i++) {
      /* (value.indexOf('"') != -1 ||
                       value.indexOf("'") != -1 ||
                       value.indexOf("<") != -1 ||
                       value.indexOf(">") != -1 ||
                       value.indexOf("#") != -1 ||
                       value.indexOf("[") != -1 ||
                       value.indexOf("]") != -1 ||
                       value.indexOf("\\") != -1 ||
                       value.indexOf("(") != -1 ||
                       value.indexOf(")") != -1 ||
                       value.indexOf("%") != -1 ||
                       value.indexOf("|") != -1)
      */
     value = $('text_'+TextFields[i]).value;
    
    if(value != '' && (value.indexOf('"') != -1 ||
                       value.indexOf("'") != -1 ||
                       value.indexOf("<") != -1 ||
                       value.indexOf(">") != -1 ||
                       value.indexOf("#") != -1 ||
                       value.indexOf("[") != -1 ||
                       value.indexOf("]") != -1 ||
                       value.indexOf("\\") != -1 ||
                       value.indexOf("(") != -1 ||
                       value.indexOf(")") != -1 ||
                       value.indexOf("%") != -1 ||
                       value.indexOf("|") != -1 ||
                       value.indexOf("^") != -1)){
      fields.push(TextFields[i]);
    }
  }
  if(fields.length > 0)
  {
    for (j=0; j<fields.length; j++) {
      message = message + "-" + $('text_'+fields[j]).getAttribute('displayname') + "\n";
    }
    return false;
  }
  else{
    return true;
  } 
}

function checkUnitsData(selectOpt, UnitTypes, selectUnitType)
{
	if (selectOpt.checked) {
		//alert('checked');
		for (i = 0; i < UnitTypes.length; i++) {
			UnitTypes[i].disabled = false ;
			//alert(UnitTypes[i].value);
			UnitTypes[i].checked = true ;
		}
		selectUnitType.disabled = false; 
	} else {
		//alert('non-checked');
		for (i = 0; i < UnitTypes.length; i++) {
			UnitTypes[i].disabled = true ;
			//alert(unitField[i].id);
			UnitTypes[i].checked = false ;
		}
		selectUnitType.disabled = true;
	}
}
