function cdLocalTime(container, servermode, offsetMinutes, targetdate, debugmode) {
	if (!document.getElementById || !document.getElementById(container)) return
	this.container=document.getElementById(container)
	var servertimestring=(servermode=="server-php")? currenttime : (servermode=="server-ssi")? '<!--#config timefmt="%B %d, %Y %H:%M:%S"--><!--#echo var="DATE_LOCAL" -->' : '<%= Now() %>'
	
	this.localtime=this.serverdate=new Date(servertimestring);
	this.targetdate=new Date(targetdate);
	this.debugmode=(typeof debugmode!="undefined")? 1 : 0;
	this.timesup=false;
	this.localtime.setTime(this.serverdate.getTime()+offsetMinutes*60*1000);
	this.updateTime();
}

cdLocalTime.prototype.updateTime=function() {
	var thisobj=this;
	this.localtime.setSeconds(this.localtime.getSeconds()+1);
	this.timeout = setTimeout(function(){thisobj.updateTime()}, 1000);
}

cdLocalTime.prototype.displaycountdown=function(baseunit, functionref) {
	this.baseunit=baseunit;
	this.formatresults=functionref;
	this.showresults();
}

cdLocalTime.prototype.showresults=function() {
	var thisobj=this;
	var debugstring=(this.debugmode)? "<p style=\"background-color: #FCD6D6; color: black; padding: 5px\"><big>Debug Mode on!</big><br /><b>Current Local time:</b> "+this.localtime.toLocaleString()+"<br />Verify this is the correct current local time, in other words, time zone of count down date.<br /><br /><b>Target Time:</b> "+this.targetdate.toLocaleString()+"<br />Verify this is the date/time you wish to count down to (should be a future date).</p>" : ""
	
	var timediff=(this.targetdate-this.localtime)/1000 //difference btw target date and current date, in seconds
	if (timediff<0){ //if time is up
		this.timesup=true;
		this.container.innerHTML=debugstring+this.formatresults();
		return;
	}
	var oneMinute=60;
	var oneHour=60*60;
	var oneDay=60*60*24;
	var dayfield=Math.floor(timediff/oneDay);
	var hourfield=Math.floor((timediff-dayfield*oneDay)/oneHour);
	var minutefield=Math.floor((timediff-dayfield*oneDay-hourfield*oneHour)/oneMinute);
	var secondfield=Math.floor((timediff-dayfield*oneDay-hourfield*oneHour-minutefield*oneMinute));
	
	if (hourfield <= 9) hourfield = "0" + hourfield;
	if (minutefield <= 9) minutefield = "0" + minutefield;
	if (secondfield <= 9) secondfield = "0" + secondfield;
	
	if (this.baseunit=="hours") {
		hourfield=dayfield*24+hourfield
		dayfield="n/a";
	} else if (this.baseunit=="minutes") {
		minutefield=dayfield*24*60+hourfield*60+minutefield
		dayfield=hourfield="n/a";
	} else if (this.baseunit=="seconds") {
		var secondfield=timediff;
		dayfield=hourfield=minutefield="n/a";
	}
	this.container.innerHTML=debugstring+this.formatresults(dayfield, hourfield, minutefield, secondfield)
	setTimeout(function(){thisobj.showresults()}, 1000) //update results every second
}

function formatresults() {
	if (this.timesup==false) {	
		if(arguments[0]==0) {
			if(arguments[1]==0) {
				if(arguments[2]==0) {
					var displaystring="<span class=launching-text>باقي على إعلان النتيجة </span><span class=counter-text><b>"+arguments[3]+"</b> ثانية</span>"			
				} else {
					var displaystring="<span class=launching-text>باقي على إعلان النتيجة </span><span class=counter-text><b>"+arguments[2]+"</b> دقيقة : <b>"+arguments[3]+"</b> ثانية</span>"			
				}
			} else {
				var displaystring="<span class=launching-text>باقي على إعلان النتيجة </span><span class=counter-text><b>"+arguments[1]+"</b> ساعة <b>"+arguments[2]+"</b> دقيقة <b>"+arguments[3]+"</b> ثانية</span>"		
			}
		} else {
			var displaystring="<span class=launching-text>باقي على إعلان النتيجة </span><span class=counter-text><b>"+arguments[0]+"</b> يوم <b>"+arguments[1]+"</b> ساعة <b>"+arguments[2]+"</b> دقيقة <b>"+arguments[3]+"</b> ثانية</span>"
		}
		return displaystring;
	} else {
		clearTimeout(this.timeout);
		
		oF = document.forms[0];
		for(i=0; i<oF.elements.length; i++) {
			oF.elements[i].disabled=false;
		}
		document.getElementById("cdtime").innerHTML="";
		document.getElementById("greetings").style.display="block";
		return "";
	}
}
