	
	
	
function ValidateEnrollment()
{
	var apSSN = document.enroll.elements['appSSN'].value;
	var apLName = document.enroll.elements['appLastName'].value;
	var apFName = document.enroll.elements['appFirstName'].value;
	var apMName = document.enroll.elements['appmiddleName'].value;
	var apGender = document.enroll.elements['appGender'].value;
	var apDOB = document.enroll.elements['appdob'].value;
	var addr1 = document.enroll.elements['add1'].value;
	var addr2 = document.enroll.elements['add2'].value;
	var city = document.enroll.elements['city'].value;
	var state = document.enroll.elements['state'].value;
	var zip = document.enroll.elements['zip'].value;
	var enrollType = document.enroll.elements['enrolltype'].value;
	var fee = document.enroll.elements['fees'].value;
	var message = "";
	var focuswho = "";
	if ((apSSN.length) < 9)
	{
		document.enroll.elements['appSSN'].style.backgroundColor = "#FD923C";
		setTimeout("document.enroll.elements['appSSN'].focus()",10);
		message = message + "Applicant SSN is invalid;\r\n";
		if ((focuswho.length) < 1) 
		{
			focuswho = "appsSSN";
		}
	}
	else
	{
		document.enroll.elements['appSSN'].style.backgroundColor = "#FFFFFF"
	}
	if ((apLName.length) < 1)
	{
		document.enroll.elements['appLastName'].style.backgroundColor = "#FD923C";
		setTimeout("document.enroll.elements['appLastName'].focus()",10);
		message = message + "Applicant Last Name is required;\r\n";
		if ((focuswho.length) < 1) 
		{
			focuswho = "appLastName";
		}
	}
	else
	{
		document.enroll.elements['appLastName'].style.backgroundColor = "#FFFFFF";
	}
	if ((apFName.length) < 1)
	{
		document.enroll.elements['appFirstName'].style.backgroundColor = "#FD923C";
		setTimeout("document.enroll.elements['appFirstName'].focus()",10);
		message = message + "Applicant First Name is required;\r\n";
		if ((focuswho.length) <1) 
		{
			focuswho = "appFirstName";
		}
	}
	else
	{
		document.enroll.elements['appFirstName'].style.backgroundColor = "#FFFFFF";
	}
	if ((apGender.length) < 1)
	{
		document.enroll.elements['appGender'].style.backgroundColor = "#FD923C";
		setTimeout("document.enroll.elements['appGender'].focus()",10);
		message = message + "Applicant Gender is required;\r\n";
		if ((focuswho.length) < 1) 
		{
			focuswho = "appGender";
		}
	}
	else
	{
		document.enroll.elements['appGender'].style.backgroundColor = "#FFFFFF";
	}
	if ((apDOB.length) < 1)
	{
		document.enroll.elements['appdob'].style.backgroundColor = "#FD923C";
		setTimeout("document.enroll.elements['appdob'].focus()",10);
		message = message + "Applicant Date of Birth is required;\r\n";
		if ((focuswho.length) <1) 
		{
			focuswho = "appdob";
		}
	}
	else
	{
		document.enroll.elements['appdob'].style.backgroundColor = "#FFFFFF";
	}
	if ((addr1.length) < 1)
	{
		document.enroll.elements['add1'].style.backgroundColor = "#FD923C";
		setTimeout("document.enroll.elements['add2'].focus()",10);
		message = message + "Applicant Address Line 1 is required;\r\n";
		if ((focuswho.length) < 1) 
		{
			focuswho = "add1";
		}
	}
	else
	{
		document.enroll.elements['add1'].style.backgroundColor = "#FFFFFF";
	}
	if ((city.length) < 1)
	{
		document.enroll.elements['city'].style.backgroundColor = "#FD923C";
		setTimeout("document.enroll.elements['city'].focus()",10);
		message = message + "Applicant City is required;\r\n";
		if ((focuswho.length) < 1) 
		{
			focuswho = "city";
		}
	}
	else
	{
		document.enroll.elements['city'].style.backgroundColor = "#FFFFFF";
	}
	if ((state.length) < 1)
	{
		document.enroll.elements['state'].style.backgroundColor = "#FD923C";
		document.enroll.elements['state'].focus();
		message = message + "Applicant State is required;\r\n";
	}
	else
	{
		document.enroll.elements['state'].style.backgroundColor = "#FFFFFF";
	}
	if ((zip.length) < 5)
	{
		document.enroll.elements['zip'].style.backgroundColor = "#FD923C";
		setTimeout("document.enroll.elements['zip'].focus()",10);
		message = message + "Applicant Zip Code is required;\r\n";
		if ((focuswho.length) < 1) 
		{
			focuswho = "zip";
		}
	}
	else
	{
		document.enroll.elements['zip'].style.backgroundColor = "#FFFFFF";
	}
	if ((message.length) > 0)
	{
		alert(message);
		//document.location = '#top';
		setTimeout("document.enroll.elements[focuswho].focus()",10);
		return false;
	}
	else
	{
		return true;
	}
}

function openPriceList() 
{
	window.open("priceOpt.php","PriceOptions", "menubar=no,width=650px,height=400px,toolbar=no");
}

function openMoreDeps()
{
	if ((document.enroll.elements['dep3LastName'].value.length) == 0)
	{
		alert("You cannot add dependents at this time");
	}
	else
	{
		window.open("more_deps.php","MoreDependents", "menubar=no,width=950px,height=500px,toolbar=no");
	}
}


function ckAgreement(strAgreeType) 
{
	if (strAgreeType == 'Agree') 
	{
		document.enroll.elements['next'].disabled = false;
		return true;
	}
	else 
	{
		document.enroll.elements['next'].disabled = true;
		return false;
	}
}

function feeSelected(fldFee){
	
		alert(document.enroll.elements[fldFee].value);
}



//function openPriceList() 
//{
//	window.open("priceOpt.php","PriceOptions", "menubar=no,width=650,height=400,toolbar=no");
//}

function checkDateValue(dtField, dtDate) 
{ 
		var regs = dtDate.split("/");
		var allowBlank = true; 
		var minYear = 1902; 
		var maxYear = (new Date()).getFullYear(); 
		var dDay;
		var mMonth;
		var yYear;
		var d = new Date(dtDate);
		var errorMsg = ""; // regular expression to match required date format 
			dDay = regs[1];
			mMonth = regs[0];
			yYear =  regs[2];
			// regular expression to match required date format 
			re = /^(\d{1,2})\/(\d{1,2})\/(\d{4})$/; 
		
		if((dtDate.length) > 0) 
		{ 
			if(re = document.enroll.elements[dtField].value.match(re)) 
			{ 
				if(dDay < 1 || dDay > 31) 
				{ 
					errorMsg = "Invalid value for day: " + dDay; 
				} 
				else if(mMonth < 1 || mMonth > 12) 
				{ 
					errorMsg = "Invalid value for month: " + regs[1]; 
				} 
				else if(yYear < minYear || yYear > maxYear) 
				{ 
					errorMsg = "Invalid value for year: " + regs[2] + " - must be between " + minYear + " and " + maxYear; 
				} 
			} 
			else 
			{ 
				errorMsg = "Invalid date format: " + dtDate; 
			} 
	} 
		else if(!allowBlank) 
		{ 
			errorMsg = "Empty date not allowed!"; 
		} 
	if(errorMsg != "") 
	{ 
		alert(errorMsg); 
		setTimeout("document.enroll.elements['" + dtField + "'].focus()",10); 
		return false; 
	} 
	return true; 
}

function getSubInfo(fName)
{
	alert(fName);
}

function ValidateEmails(flField)
{
	switch(flField)
	{
		
		case 'emailadd':
			if (((document.enrollcc.elements['emailadd'].value) == null) || ((document.enrollcc.elements['emailadd'].length) < 1) || ((document.enrollcc.elements['emailadd'].value) == ''))
			{
				alert("You must enter a vaild email!");
				setTimeout("document.enrollcc.elements['emailadd'].focus()",10);
				return false;
				
			}
			
			else
			{
				/* 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  */
				// -->
				
				<!-- Begin
				/* 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 emailStr = document.enrollcc.elements['emailadd'].value;
				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.");
					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 does not seem to be valid.");
						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 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;
			}
		break;
	
		case 'confemailadd':
			if ((document.enrollcc.elements['emailadd'].value != document.enrollcc.elements['confemailadd'].value))
			{
				alert("Email addresses do not match!");
				document.enrollcc.elements['confemailadd'].value = '';
				document.enrollcc.elements['emailadd'].focus();
			}
		break;
	}
}

//function checkSSN()
//{
//	if ((document.enroll.elements['appSSN'].value.length) < 9) 
//	{
//		alert("Invalid SSN");
//		setTimeout("document.enroll.elements['appSSN'].focus()",10);
//	}
//}

function whereTo()
{
	
	switch (document.pressed)
	{
		case "Back to Enrollment Form":
			document.enrollcc.action = "javascript: history.back(-1)";
			return true;
			break;
		case "Proceed to Verification":
			document.enrollcc.action = "verification.php";
			return true;
			break;
	}
}
