// Make a POST to the server 
// and pass on any data from browser
// via the XMLHTTPRequest
var lastPing = 0;
var url = "/specials/specials.xml.php";

function getButtons()
{
	var req = newXMLHttpRequest();
	//register the callback handler function
  	var callbackHandler = getReadyStateHandler(req, loadButtons);
	req.onreadystatechange = callbackHandler;

	req.open("GET", url, true);
  	req.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
	req.send(null);	
} // talkToServer


// This is the callback functions that gets called
// for the response from the server with the XML data
function loadButtons(testXML) {
	var res = testXML.getElementsByTagName("specials")[0];
	var num = res.getAttribute("pages");
	var timestamp = res.getAttribute("timestamp");

	if (timestamp > lastPing) {
		lastPing = timestamp;

		for(var i = 0; i < num; i++)	{
			pages[i + 1] = testXML.getElementsByTagName("content")[i].firstChild.nodeValue;
		}
	} 
}

function loadPage(view) {

	   if(typeof(pages[view]) == "undefined")
	   		return false;

		var box = document.getElementById("specials_main");
		box.innerHTML = pages[view]; 
}

//function preloadImage(image) {
//	preloadImg = new Image();
//	preloadImg.src = 'specials/_img/' + image + '';
//}


//the following two functions are helper infrastructure to 
//craete a XMLHTTPRequest and register a listner callback function

function newXMLHttpRequest() {
	var xmlreq = false;
	if (window.XMLHttpRequest) {
		xmlreq = new XMLHttpRequest();
	} else if (window.ActiveXObject) {
    		// Try ActiveX
		try { 
			xmlreq = new ActiveXObject("Msxml2.XMLHTTP");
		} catch (e1) { 
			// first method failed 
			try {
				xmlreq = new ActiveXObject("Microsoft.XMLHTTP");
			} catch (e2) {
				 // both methods failed 
			} 
		}
 	}
   	return xmlreq;
} 

function getReadyStateHandler(req, responseXmlHandler) {
	return function () {
	if (req.readyState == 4) {
		if (req.status == 200) {
        		responseXmlHandler(req.responseXML);
		} else {
			//alert("ERROR: " + req.status);
      		}
    	}
 	}
}


var pages = new Array();
if (window.addEventListener){
	window.addEventListener('load', getButtons, false); 
} else if (window.attachEvent){
	window.attachEvent("onload", getButtons);
}
