/*
MODULE NAME: newacct.js
PURPOSE: contains javascript for newacct module
REFERRING MODULE(S): newacct
DESTINATION MODULE(S): none
QUERYSTRING METHODS SUPPORTED: none
AUTHOR: Grant Szabo (grant@quagmire.com) Sterling Creek Software
CREATED: 11/20/2002
LAST MODIFIED: 11/20/2002
*/

// OES module=newacct
function fcnCheckLoginName() {
	var x = document.NewacctForm.loginName.value.indexOf(" ");
	if (x != -1) {
		document.NewacctForm.loginName.value = "";
		document.NewacctForm.loginName.focus();
		alert(" Please enter a login name that does not contain spaces.  ");
	}
}

// OES module=newacct (FUNCTION TO CHECK VALID EMAIL ADDRESSES)
function validate2(accttype) {
	
	var isOK = true;
	
	
	if (accttype == "SR") {
		if (document.NewacctForm.salesrepcd.value == "")  {
			alert("Sales Representative Code is required, \nPlease fill this form completely before submitting.  ");
			document.NewacctForm.salesrepcd.focus();
			return;
			
		}
	}	

	if ((accttype == "CO") || (accttype == "DO")) {
		if (document.NewacctForm.custnum.value == "")  {
			alert("Customer Number is required, \nPlease fill this form completely before submitting.  ");
			document.NewacctForm.custnum.focus();
			return;
			
		}
	}	

	if (accttype == "PL") {
		if (document.NewacctForm.custnum.value == "")  {
			alert("Private Label Code is required, \nPlease fill this form completely before submitting.  ");
			document.NewacctForm.plnum.focus();
			return;
		}
	}	
	
	if (document.NewacctForm.fullname.value == "")  {
		alert("Name Field is required, \nPlease fill this form completely before submitting.  ");
		document.NewacctForm.fullname.focus();
		return;
		
	}	
	
	if (document.NewacctForm.phnum.value == "")  {
		alert("Phone Number is required, \nPlease fill this form completely before submitting.  ");
		document.NewacctForm.phnum.focus();
		return;
		
	}
	if (isNaN(document.NewacctForm.phnum.value)) {
			alert("Please enter only numbers into the Phone Number field.  ");
			document.NewacctForm.phnum.value = "";
			document.NewacctForm.phnum.focus();
			return;
	}	
	
	if (document.NewacctForm.emailaddr.value == "")  {
		alert("EMail address is required, \nPlease fill this form completely before submitting.  ");
		document.NewacctForm.emailaddr.focus();
		return;
	}
	else {
		var retVal = emailCheck(document.NewacctForm.emailaddr.value);
		if (retVal == false) {
			document.NewacctForm.emailaddr.value = "";
			document.NewacctForm.emailaddr.focus();
			return;
		}
	}	

	if (document.NewacctForm.loginName.value == "")  {
		alert("A Login name is required, \nPlease fill this form completely before submitting.  ");
		document.NewacctForm.loginName.focus();
		return;
	}
/*	else {
		var retVal = LoginCheck(document.NewacctForm.loginName.value);
		if (retVal == 0) {
			document.NewacctForm.loginName.value = "";
			document.NewacctForm.loginName.focus();
			return;
		}
		
	}*/
	//alert("OK");
	//document.NewacctForm.action = "processverify.cfm";
	//document.NewacctForm.submit();
	document.NewacctForm.action = "/pages/newacct/newacct.cfm?method=insert";
	document.NewacctForm.submit();
	
	
}

// OES module=newacct (FUNCTION TO CHECK VALID EMAIL ADDRESSES)
function emailCheck (emailStr) {
	var isOK = true;
	/* 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("The email address you entered is incorrect.    \nPlease reenter (checking for @ and .)");
		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;
	   }
	}
	return true;
}
