// holds an instance of XMLHttpRequest
var xmlHttp2 = createXmlHttpRequestObject();
// when set to true, display detailed error messages
var showErrors = true;

// creates an XMLHttpRequest instance
function createXmlHttpRequestObject() 
{
  // will store the reference to the XMLHttpRequest object
  var xmlHttp2;
  // this should work for all browsers except IE6 and older
  try
  {
    // try to create XMLHttpRequest object
    xmlHttp2 = 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
        xmlHttp2 = new ActiveXObject(XmlHttpVersions[i]);
      } 
      catch (e) {} // ignore potential error
    }
  }
  // return the created object or display an error message
  if (!xmlHttp)
	  alert("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);
  }
}


// ---------------------------------------------------------------
// Retrieve titles from a feed and display them
function getCal(feedLink, feed)
{
  // only continue if xmlHttp2 isn't void
  if (xmlHttp2)
  {
	// try to connect to the server
    try
    {
      if (xmlHttp2.readyState == 4 || xmlHttp2.readyState == 0)
      {
               
        // Call the server page to execute the server-side operation
        params = feed;
        xmlHttp2.open("POST", "/_templates/_events_ajax_calendar.pxp", true);
        xmlHttp2.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
        xmlHttp2.onreadystatechange = handleHttpGetCalFeeds;
        xmlHttp2.send(params);
      }
      else
      {
        // if connection was busy, try again after 1 second
        setTimeout("getCal('" + feedLink + "', '" + feed + "');", 1000);
      }
    }
    // display the error in case of failure
    catch (e)
    {
      displayError(e.toString());
    }
  }
}

// function that retrieves the HTTP response
function handleHttpGetCalFeeds() 
{
 
  // continue if the process is completed
  if (xmlHttp2.readyState == 4) 
  {
   // continue only if HTTP status is "OK"
    if (xmlHttp2.status == 200) 
    {
      try
      {
        displayCal();
      }
      catch(e)
      {
        // display error message
        displayError(e.toString());
      }
    } 
    else 
    {
      displayError(xmlHttp2.statusText);
    }
  }
}

// Processes server's response
function displayCal()
{
  // read server response as text, to check for errors 
  var response = xmlHttp2.responseText;
  // server error?
  if (response.indexOf("ERRNO") >= 0 
      || response.indexOf("error:") >= 0
      || response.length == 0)
    throw(response.length == 0 ? "Void server response." : response);
  
  // append HTML content to existing DOM structure
  var titlesContainer = document.getElementById("calendarContainer");
  titlesContainer.innerHTML = response;
  
  // make the feed container visible
  document.getElementById("calendarContainer").style.display = "block";
  
}
