// holds an instance of XMLHttpRequest
var xmlHttp = createXmlHttpRequestObject();
// variables that establish how often to access the server 
var updateInterval = 5; // how many seconds to wait to get new message
var errorRetryInterval = 30; // seconds to wait after server error
// when set to true, display detailed error messages
var debugMode = true;

 
// 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 prog 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) {}
    }
  }
  // return the created object or display an error message
  if (!xmlHttp)
    alert("Error creating the XMLHttpRequest object.");
  else 
    return xmlHttp;
}

// function that displays a new message on the page
function display($message)
{
  // obtain a reference to the <div> element on the page
  myDiv = document.getElementById("ReturnedValues");
  // display message
  myDiv.innerHTML = $message + "<br/>";
}

function clearMessage()
{
  // obtain a reference to the <div> element on the page
  myDiv = document.getElementById("ReturnedValues");
  // display message
  myDiv.innerHTML = "";	
}

// function that displays an error message
function displayError($message)
{
  // display error message, with more technical details if debugMode is true
  display("Error retrieving the search data!" +
          (debugMode ? "<br/>" + $message : ""));
}

// call server asynchronously
function getAllClients()
{
  // only continue if xmlHttp isn't void
  if (xmlHttp)
  {
 
    // try to connect to the server
    try
	{
		// get the last name entered by user
      	var keyword = document.getElementById("keyword").value; 
		var keytype = document.getElementById("keytype").value;
		var stype = document.getElementById("stype").value;
		// create the params string
		var params = "keytype=" + keytype + "&keyword=" + keyword + "&stype=" + stype;
		// remove this line if you don't like the 'Receiving...' message
      	display("Receiving data from server...")
		// initiate the asynchronous HTTP request
		xmlHttp.open("GET", "find.php?" + params, true);
		xmlHttp.onreadystatechange = handleFindUser;
		xmlHttp.send(null);
  	}
    catch(e)
    {
      displayError(e.toString());
    }
  }
}

// call server asynchronously
function getClients()
{
  // only continue if xmlHttp isn't void
  if (xmlHttp)
  {
 
    // try to connect to the server
    try
	{
		// get the last name entered by user
      	var keyword = document.getElementById("keyword").value; 
		var keytype = document.getElementById("keytype").value;
		var stype = document.getElementById("stype").value;
		var agentID = document.getElementById("agentID").value;
		var url = document.getElementById("url").value;
		// create the params string
		var params = "keytype=" + keytype + "&keyword=" + keyword + "&stype=" + stype + "&agentID=" + agentID + "&url=" + url;
		// remove this line if you don't like the 'Receiving...' message
      	display("Receiving data from server...")
		// initiate the asynchronous HTTP request
		xmlHttp.open("GET", "find.php?" + params, true);
		xmlHttp.onreadystatechange = handleFindUser;
		xmlHttp.send(null);
  	}
    catch(e)
    {
      displayError(e.toString());
    }
  }
}

// function called when the state of the HTTP request changes
function handleFindUser() 
{
  // when readyState is 4, we are ready to read the server response
  if (xmlHttp.readyState == 4) 
  {
    // continue only if HTTP status is "OK"
    if (xmlHttp.status == 200) 
    {
      try
      {
        // do something with the response from the server
        handleResponse();
      }
      catch(e)
      {
        // display error message
        displayError(e.toString());
      }
    } 
    else
    {
      // display error message
      displayError(xmlHttp.statusText);   
    }
  }
}

// handles the response received from the server
// Was the getNews method.
function handleResponse() 
{
  // 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);
  // display the message
  display(response);
}
