var xmlHttp = createXmlHttpRequestObject();
var serverAddress = "/vsignup.php";
var showErrors = true;
var fieldErrors = initFieldErrors();
var cache = new Array();
var formOK = false;

function initFieldErrors()
{
	var fieldErrors = new Array();

	fieldErrors["dpUserid"] = 0;
	fieldErrors["dpPassword"] = 0;
	fieldErrors["dpRepassword"] = 0;
	fieldErrors["dpFirstname"] = 0;
	fieldErrors["dpLastname"] = 0;
	fieldErrors["dpEmail"] = 0;
	fieldErrors["dpState"] = 0;
	fieldErrors["dpCountry"] = 0;
	fieldErrors["dpTermsOfUse"] = 0;
	
	return fieldErrors;
}

// creates an XMLHttpRequest instance
function createXmlHttpRequestObject() 
{
  // will store the reference to the XMLHttpRequest object
  var xmlHttp;
  // this should work for all browsers except IE6 and older
  try
  {
    // try to create XMLHttpRequest object
    xmlHttp = new XMLHttpRequest();
  }
  catch(e)
  {
    // assume IE6 or older
    var XmlHttpVersions = new Array("MSXML2.XMLHTTP.6.0",
                                    "MSXML2.XMLHTTP.5.0",
                                    "MSXML2.XMLHTTP.4.0",
                                    "MSXML2.XMLHTTP.3.0",
                                    "MSXML2.XMLHTTP",
                                    "Microsoft.XMLHTTP");
    // try every id until one works
    for (var i=0; i<XmlHttpVersions.length && !xmlHttp; i++) 
    {
      try 
      { 
        // try to create XMLHttpRequest object
        xmlHttp = new ActiveXObject(XmlHttpVersions[i]);
      } 
      catch (e) {} // ignore potential error
    }
  }
  // return the created object or display an error message
  if (!xmlHttp)
    displayError("Error creating the XMLHttpRequest object.");
  else 
    return xmlHttp;
}

// function that displays an error message
function displayError($message)
{
  // ignore errors if showErrors is false
  if (showErrors)
  {
    // turn error displaying Off
    showErrors = false;
    // display error message
 
    alert("Error encountered: \n" + $message);
    // retry validation after 10 seconds
    setTimeout("fieldval();", 10000);
  }
}

// the function handles the validation for any form field
function fieldval(inputValue, fieldID)
{
  // only continue if xmlHttp isn't void
  if (xmlHttp)
  {
    // if we received non-null parameters, we add them to cache in the
    // form of the query string to be sent to the server for validation
    if (fieldID)
    {
  		// encode values for safely adding them to an HTTP request query string
   		inputValue = encodeURIComponent(inputValue);
   		fieldID = encodeURIComponent(fieldID);
   		// add the values to the queue
   		cache.push("inputValue=" + inputValue + "&fieldID=" + fieldID);
    }
    // try to connect to the server
    try
    {
      // continue only if the XMLHttpRequest object isn't busy
      // and the cache is not empty
        // call fieldval() again, in case there are values left in the cache
      if (cache.length > 0)
      {
	      if (xmlHttp.readyState == 4 || xmlHttp.readyState == 0) 
	      {         	
	        // get a new set of parameters from the cache
	        var cacheEntry = cache.shift();        
	        // make a server request to validate the extracted data
	        xmlHttp.open("POST", serverAddress, true);        
	        xmlHttp.setRequestHeader("Content-Type", 
	                                 "application/x-www-form-urlencoded");        
	        xmlHttp.onreadystatechange = handleRequestStateChange;       
	        xmlHttp.send(cacheEntry);       
	      } else
	      { // We should try to process the request once more since currently the XMLHttpRequest object is busy
		  	setTimeout("fieldval();", 500);
	      }
      }
    }
    catch (e)
    {
      // display an error when failing to connect to the server
      displayError(e.toString());
    }
  }
}

// function that handles the HTTP response
function handleRequestStateChange() 
{
  // when readyState is 4, we read the server response
  if (xmlHttp.readyState == 4) 
  {
    // continue only if HTTP status is "OK"
    if (xmlHttp.status == 200) 
    {    	
      try
      {
        // read the response from the server
        readResponse();
      }
      catch(e)
 
      {
        // display error message
        displayError(e.toString());
      }
    }
    else
    {
      // display error message
      displayError(xmlHttp.statusText);
    }
  }
}

// read server's response 
function readResponse()
{ 
  // retrieve the server's response 
  var response = xmlHttp.responseText;
  // server error?
  if (response.indexOf("ERRNO") >= 0 
      || response.indexOf("error:") >= 0
      || response.length == 0)
    throw(response.length == 0 ? "Server error." : response);
 // get response in XML format (assume the response is valid XML)
  responseXml = xmlHttp.responseXML;
  // get the document element
  xmlDoc  = responseXml.documentElement;
  result  = xmlDoc.getElementsByTagName("result")[0].firstChild.data;
  fieldID = xmlDoc.getElementsByTagName ("fieldid")[0].firstChild.data;
  errmsg  = xmlDoc.getElementsByTagName("errmsg")[0].firstChild.data;
  // find the HTML element that displays the error
  message = document.getElementById(fieldID + "Error");
  // show the error or hide the error
  message.className = (result == "0") ? "error" : "hidden";  
  message.innerHTML = errmsg;
  
  fieldErrors[fieldID] = result;
  
  if ((fieldID == "dpPassword") && (result == 1))
  {	if (document.getElementById("dpPassword").value == document.getElementById("dpRepassword").value)
  	{	fieldErrors["dpRepassword"] = 1;
  		document.getElementById("dpRepasswordError").className = "hidden";
	}
  }	
  if ((fieldID == "dpRepassword") && (result == 1))
  {	if (document.getElementById("dpPassword").value == document.getElementById("dpRepassword").value)
  	{	fieldErrors["dpPassword"] = 1;
  		document.getElementById("dpPasswordError").className = "hidden";
	}
  }	
  
  var total = fieldErrors["dpUserid"] + fieldErrors["dpPassword"] +	fieldErrors["dpRepassword"] + fieldErrors["dpFirstname"] + fieldErrors["dpLastname"] + fieldErrors["dpEmail"] + fieldErrors["dpState"] + fieldErrors["dpCountry"] + fieldErrors["dpTermsOfUse"];

  if (total == "111111111")
  {	formOK = true;
  	//document.getElementById("SignupSubmit").disabled=false;
  } else
  {	formOK = false;
    //document.getElementById("SignupSubmit").disabled=true;
  }

  //var aidval = document.getElementById("dpUserid").value;
//  document.getElementById("ErrRes").innerHTML = total;
//document.getElementById("ErrRes").innerHTML = aidval;
//document.getElementById("ErrMsg").innerHTML = document.getElementById("dpUserid").name;
  // call fieldval() again, in case there are values left in the cache
  setTimeout("fieldval();", 500);
}

function beforeSubit()
{
	if (!formOK)
	{
/*		
		if (navigator.userAgent.indexOf("Chrome", 0) > 0)
		{	delete window.alert;
		}
		if (navigator.userAgent.indexOf("Firefox", 0) > 0)
		{	delete window.alert;
		}
*/		
		// If the browser is not IE than execute the following command
		if (navigator.userAgent.indexOf("MSIE", 0) == 0)
		{	delete window.alert;
		}
		alert("All required fields must be filled");
		return false;
	}
} // beforeSubit

// sets focus on the first field of the form
function setFocus()    
{
  document.getElementById("dpUserid").focus();
  //document.getElementById("SignupSubmit").disabled=true;
}

// sets focus on the first field of the form
function disableSubmit()    
{
  //document.getElementById("SignupSubmit").disabled=true;
}

