function checkrequired(which) {
  var pass=true;
  if (document.images) {
    for (i=0;i<which.length;i++) {
      var tempobj=which.elements[i];
      if (tempobj.name.substring(0,8)=="required") {
        if (((tempobj.type=="text" || tempobj.type=="textarea") && tempobj.value=='') || (tempobj.type.toString().charAt(0)=="s" && tempobj.selectedIndex==0)) {
          pass=false;
          break;
        }



      }
    }
  }

/*
	if ((which.c2.checked==true) && (which.Email.value=='') || (which.c4.checked==true) && (which.Phone.value=='')) {
	  pass=false;
	}
*/

  if (!pass) {
    shortFieldName=tempobj.name.substring(8,30).toUpperCase();
    alert("Please make sure the "+shortFieldName+" field is properly completed.");
    tempobj.focus();
    return false;
  } else {
	return true;
	}
}



function checkemailfields(which) {
  if (document.images) {
    for (i=0;i<which.length;i++) {
      var tempobj=which.elements[i];
      if (tempobj.name.indexOf("Email")!=-1) {
      	if (tempobj.value != '') {
			if (!emailCheck(tempobj.value)) return false;
		}

      }
    }
  }
	return true;
}




function checkbad(which) {
  var good=true;
	var bad = new Array(25);
	bad[0]="qwerty";
	bad[1]="pussy";
	bad[2]="orgasm";
	bad[3]="penis";
	bad[4]="throat";
	bad[5]="doggie";
	bad[6]="doggy";
	bad[7]="hoodia";
	bad[8]="viagra";
	bad[9]="ytrewq";
	bad[10]="orgy";
	bad[11]="lesbian";
	bad[12]="jerking";
	bad[13]="sluts";
	bad[14]="boobs";
	bad[15]="ourworld";
	bad[16]="160characters";
	bad[17]="tits";
	bad[18]="telenet";
	bad[19]="lastminute";
	bad[20]="@mail.com";
	bad[21]="pussy";
	bad[22]="skorohod";
	bad[23]="enzyte";
	bad[24]="gimail";



  if (document.images) {
    for (i=0;i<which.length;i++) {
      var tempobj=which.elements[i];
      
	    for (j=0;j<bad.length;j++) {
		  if (tempobj.value.indexOf(bad[j])!=-1) {
			  good=false;
			  break;
		  }
		}

    }
  }
  if (!good) {
    alert("Please check your comments.");
    return false;
  } else {
	return true;
	}
}





function checkcontact(which) {
	var subvalue = "";

	if (!checkbad(which)) return false;
	
	for (i = 0; i < 3; i++){
		if (document.contactform.subscription[i].checked == true){
			subvalue = document.contactform.subscription[i].value; 
		}
	}

	if (parent.document.URL != "http://www.sales-lead-experts.com/about/signup.cfm") {
	  if ( (  ((which.consultingservices.checked == true) || (which.speakingservices.checked == true))         && (which.c1.checked == false && which.c2.checked == false && which.c4.checked == false) ) ) {
	    alert("Please check at least one contact method.");
	    return false;
	  }
	}
	
	if (parent.document.URL != "http://www.sales-lead-experts.com/test.html") {
	  if ( (  ((which.consultingservices.checked == true) || (which.speakingservices.checked == true))         && (which.c1.checked == false && which.c2.checked == false && which.c4.checked == false) ) ) {
	    alert("Please check at least one contact method.");
	    return false;
	  }
	}
	
	if ((which.c1.checked == false && which.c2.checked == false && which.c4.checked == false) && ((checksubs(which)==false) || (subvalue == "No")) ) {
		alert("Please check how you prefer to be contacted, or if you want to sign up for the Email or Print Edition of Sales Lead Report.");
		return false;
	}

	if (which.c4.checked == true && which.Telephone.value == '' ) {
		alert("Please add your phone number.");
		which.Telephone.focus();
		return false;
	}

	
	if (((subvalue == "Email Edition") || (which.c2.checked == true)) && (which.Email.value =='')) {
		alert("Please enter your email address.");
		which.Email.focus();
		return false;
	} else if (((subvalue == "Print Edition")) && (which.Address.value =='')) {
		alert("Please enter your mailing address.");
		which.Address.focus();
		return false;
	} else if (((subvalue == "Print Edition")) && (which.City.value =='')) {
		alert("Please enter your city.");
		which.City.focus();
		return false;
	} else if (((subvalue == "Print Edition")) && (which.State.value =='')) {
		alert("Please enter your state or province.");
		which.State.focus();
		return false;
	} else if (((subvalue == "Print Edition")) && (which.PostalCode.value =='')) {
		alert("Please enter your postal code.");
		which.PostalCode.focus();
		return false;
	} else if (((subvalue == "Print Edition")) && (which.Name.value =='')) {
		alert("Please enter your name.");
		which.Name.focus();
		return false;
	} else {
		
	if (!checkemailfields(which)) return false;
	if (!checkrequired(which)) return false;
	


var uword = hex_md5(document.getElementById(jfldid).value);

if (uword==cword[anum-1]) {
}

else {
alert("ERROR: Enter the code as it is shown.");
document.getElementById(jfldid).focus();
return false;
}








	
	  return true;
	}
	
	

//	if (which.requiredEmail.value) {
//		if (!emailCheck(which.requiredEmail.value)) return false;
//		}
//	if (which.Email.value) {
//		if (!emailCheck(which.Email.value)) return false;
//		}

/*
 for testing
	alert(subvalue);
	alert(".");
	return false;
*/

}

function checkcontactstep1(which) {

	if (!checkbad(which)) return false;

	
  if (which.Name.value == '' && which.Email.value == '' &&  which.Telephone.value == '') {
	    alert("Please fill out the form.");
		which.Name.focus();
	    return false;
	} else {
		
	if (!checkemailfields(which)) return false;
	if (!checkrequired(which)) return false;
	  return true;
	}
	

}

function checkplanner (which) {
	if(which.checked) {
		document.getElementById('c1').disabled = false;
		document.getElementById('c2').disabled = false;
		document.getElementById('c4').disabled = false;
	} else {
		document.getElementById('c1').disabled = true;
		document.getElementById('c2').disabled = true;
		document.getElementById('c4').disabled = true;
	}
}

function checkplanner2 () {
	if(document.getElementById('field403').checked) {
		document.getElementById('field404').disabled = false;
		document.getElementById('field405').disabled = false;
	} else {
		document.getElementById('field404').disabled = true;
		document.getElementById('field405').disabled = true;
	}
}

function checkvidcontact(which) {

	if (!checkbad(which)) return false;
	
	if(!which.check_planner.checked && !which.check_call.checked) {
		alert("Please select a choice for how you would like to be contacted.");
		return false;
	}
	
	if(which.check_planner.checked) { //if the check mail
		if (which.c1.checked == false && which.c2.checked == false) {
			alert("Please check how you prefer to be contacted.");
			return false;
		}

		/*if (which.c4.checked == true && which.Telephone.value == '' ) {
			alert("Please add your phone number.");
			which.Telephone.focus();
			return false;
		}*/
		
 if (which.c1.checked && (which.Name.value =='' || which.Email.value =='' || which.Address.value =='' || which.City.value =='' || which.State.value =='' || which.PostalCode.value =='') ) { // if mail is checked
			if(which.Name.value =='') {
				alert("Please enter your name");
				which.Name.focus();
				return false;
			} else if(which.Email.value =='') {
				alert("Please provide an email");
				which.Email.focus();
				return false;
			} else if(which.Address.value =='') {
				alert("Please enter your address");
				which.Address.focus();
				return false;
			} else if(which.City.value =='') {
				alert("Please enter your city");
				which.City.focus();
				return false;
			} else if(which.State.value =='') {
				alert("Please enter your state");
				which.State.focus();
				return false;
			} else if(which.PostalCode.value =='') {
				alert("Please enter your zip/postal code");
				which.PostalCode.focus();
				return false;
			} 
		}
		
		
		if ((which.c2.checked == true) && (which.Email.value == '')) {
			alert("Please enter your email address.");
			which.Email.focus();
			return false;
		}
		
		 
			
			if (!checkemailfields(which)) return false;
			if (!checkrequired(which)) return false;
			  return true;
		
	} else { //if the user does not want Mac's Meeting Planner Kit 
		if (which.Name.value == '' ) {
			alert('Please enter your name');
			which.Name.focus();
			return false;
		}
		
		/*if (which.Email.value == '' ) {
			alert('Please provide an email address');
			return false;
		}*/
		if (which.Telephone.value == '' ) {
			alert('Please add your phone number.');
			which.Telephone.focus();
			return false;
		}
		
		if (!checkemailfields(which)) return false;
		if (!checkrequired(which)) return false;

var uword = hex_md5(document.getElementById(jfldid).value);

if (uword==cword[anum-1]) {
}

else {
alert("ERROR: Enter the code as it is shown.");
document.getElementById(jfldid).focus();
return false;
}

		return true;
	}
}


function checksubs(which) {

//CHECKING RADIO BUTTONS
	var subscriptionOption = -1;
	for (i=0; i<which.subscription.length;i++) {
		if (which.subscription[i].checked) {
			subscriptionOption = i
		}
	}
	if (subscriptionOption == -1) {
		return false;
	} else {
		return true;
	}
}




function checkcheckup(which) {
if (which.Email.value =='') {
		alert("Please enter your email address.");
		which.Email.focus();
		return false;
}

if (which.Email.value) {
	if (!emailCheck(which.Email.value)) {return false;}

/*
	emailCheck(which.Email.value);

*/
}


	var subvalue = "";

if (!checkbad(which)) return false;
	

if (parent.document.URL != "http://www.sales-lead-experts.com/about/signup.cfm") {
  if ((which.checkup1.checked == false) && (which.checkup2.checked == false) && (which.checkup3.checked == false) && (which.checkup4.checked == false) && (which.subscription.checked == false) && (which.checkup6.checked == false) ) {
    alert("Please check at least one way to be contacted.");
    return false;
  }
}

if (parent.document.URL != "http://www.sales-lead-experts.com/test.html") {
  if ((which.checkup1.checked == false) && (which.checkup2.checked == false) && (which.checkup3.checked == false) && (which.checkup4.checked == false) && (which.subscription.checked == false) && (which.checkup6.checked == false) ) {
    alert("Please check at least one way to be contacted.");
    return false;
  }
}


if ((which.checkup1.checked == true || which.checkup2.checked == true) && which.Telephone.value == '' ) {
alert("Please add your phone number.");
which.Telephone.focus();
return false;
}
	
if (!checkemailfields(which)) return false;
if (!checkcheckuprequired(which)) return false;

return true;



}

function checkcheckuprequired(which) {
  var pass=true;
  if (document.images) {
    for (i=0;i<which.length;i++) {
      var tempobj=which.elements[i];
      if ( (tempobj.name.substring(0,4)!="Addr") && (tempobj.name.substring(0,4)!="Titl") && (tempobj.name.substring(0,4)!="City") && (tempobj.name.substring(0,4)!="Stat") && (tempobj.name.substring(0,4)!="Post") && (tempobj.name.substring(0,4)!="Coun") && (tempobj.name.substring(0,4)!="WeMa") && (tempobj.name.substring(0,4)!="Comm")) {
        if (((tempobj.type=="text" || tempobj.type=="textarea") && tempobj.value=='') || (tempobj.type.toString().charAt(0)=="s" && tempobj.selectedIndex==0)) {
          pass=false;
          break;
        }



      }
    }
  }

/*
	if ((which.c2.checked==true) && (which.Email.value=='') || (which.c4.checked==true) && (which.Phone.value=='')) {
	  pass=false;
	}
*/

  if (!pass) {
    shortFieldName=tempobj.name.substring(0,30).toUpperCase();
    alert("Please make sure the "+shortFieldName+" field is properly completed.");
    tempobj.focus();
    return false;
  } else {
	return true;
	}
}


function emailCheck (emailStr) {

/*This script and many more are available free online at
  The JavaScript Source!! http://javascript.internet.com

  V1.1.3: Sandeep V. Tamhankar (stamhankar@hotmail.com)
  Original:  Sandeep V. Tamhankar (stamhankar@hotmail.com)
  Changes:

  1.1.4: Fixed a bug where upper ASCII characters (i.e. accented letters
  international characters) were allowed.

  1.1.3: Added the restriction to only accept addresses ending in two
  letters (interpreted to be a country code) or one of the known
  TLDs (com, net, org, edu, int, mil, gov, arpa), including the
  new ones (biz, aero, name, coop, info, pro, museum).  One can
  easily update the list (if ICANN adds even more TLDs in the
  future) by updating the knownDomsPat variable near the
  top of the function.  Also, I added a variable at the top
  of the function that determines whether or not TLDs should be
  checked at all.  This is good if you are using this function
  internally (i.e. intranet site) where hostnames don't have to 
  conform to W3C standards and thus internal organization e-mail
  addresses don't have to either.
  Changed some of the logic so that the function will work properly
  with Netscape 6.

  1.1.2: Fixed a bug where trailing . in e-mail address was passing
  (the bug is actually in the weak regexp engine of the browser; I
  simplified the regexps to make it work).

  1.1.1: Removed restriction that countries must be preceded by a domain,
  so abc@host.uk is now legal.  However, there's still the 
  restriction that an address must end in a two or three letter
  word.

  1.1: Rewrote most of the function to conform more closely to RFC 822.

  1.0: Original  */



  /* 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=1;

  /* 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 contains invalid characters.");
      return false;
    }
  }
  for (i=0; i<domain.length; i++) {
    if (domain.charCodeAt(i)>127) {
      alert("Ths domain name contains invalid characters.");
      return false;
    }
  }

  // See if "user" is valid 

  if (user.match(userPat)==null) {

    // user is not valid

    alert("The username doesn't seem to be valid in your e-mail address, please correct before continuing.");
    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 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 in your e-mail address does not seem to be valid, please correct before continuing.");
      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("Your e-mail 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;

//  End emailCheck
}


