/**
* Filename.......: calendar.js
* Project........: Popup Calendar
* Last Modified..: $Date: 2002/07/22 18:17:05 $
* CVS Revision...: $Revision: 1.2 $
* Copyright......: 2001, 2002 Richard Heyes
*/

/**
* Global variables
*/
	dynCalendar_layers          = new Array();
	dynCalendar_mouseoverStatus = false;
	dynCalendar_mouseX          = 0;
	dynCalendar_mouseY          = 0;
	
	

/**
* The calendar constructor
*
* @access public
* @param string objName      Name of the object that you create
* @param string callbackFunc Name of the callback function
* @param string OPTIONAL     Optional layer name
* @param string OPTIONAL     Optional images path
*/
	function dynCalendar(objName, callbackFunc, callBackFunc2 , writeDates , minDate, maxDate )
	{
		writeDate=writeDates;
		writeDate=writeDate.split(";");
		/**
        * Properties
        */
		// Todays date
		this.today          = new Date();
		this.date           = this.today.getDate();
		this.month          = this.today.getMonth();
		//this.month        = arguments[3] ? arguments[3] : this.today.getMonth();
		this.year           = this.today.getFullYear();

		this.objName        = objName;
		this.callbackFunc   = callbackFunc;
		this.callBackFunc2  = callBackFunc2;

		this.minDate		= minDate;
		this.maxDate		= maxDate;
		if(this.minDate == null)
		{
			this.minDate = 		new Date();
			this.minDate.setFullYear(this.today.getFullYear() - 1)
		}
		if(this.maxDate == null)
		{
			this.maxDate = 		new Date();
			this.maxDate.setFullYear(this.today.getFullYear() + 1)	
		}

		if(this.objName=='Calendar0'){
			this.month = this.today.getMonth()-1;
		}else if(this.objName=='Calendar1'){
			this.month = this.today.getMonth();
				if(this.month > 11){
				this.month = this.month-12;
				this.year++;
			}
		}else if(this.objName=='Calendar2'){
			this.month = this.today.getMonth()+1;
			if(this.month > 11){
				this.month = this.month-12;
				this.year++;
			}
		}else{
			
			this.month          = this.today.getMonth();
		}
		
		this.imagesPath     = '/_images/';
		//this.imagesPath     = arguments[2] ? arguments[2] : 'images/';
		this.layerID        = arguments[3] ? arguments[3] : 'dynCalendar_layer_' + dynCalendar_layers.length;

		this.offsetX        = 5;
		this.offsetY        = 5;

		this.useMonthCombo  = true;
		this.useYearCombo   = true;
		this.yearComboRange = 5;

		this.currentMonth   = this.month;
		this.currentYear    = this.year;

		/**
        * Public Methods
        */
		this.show              = dynCalendar_show;
		this.writeHTML         = dynCalendar_writeHTML;
		this.setEventDates     = dynCalendar_setEventDates;
		this.showEventDates    = dynCalendar_showEventDates;		

		// Accessor methods
		this.setOffset         = dynCalendar_setOffset;
		this.setOffsetX        = dynCalendar_setOffsetX;
		this.setOffsetY        = dynCalendar_setOffsetY;
		this.setImagesPath     = dynCalendar_setImagesPath;
		this.setMonthCombo     = dynCalendar_setMonthCombo;
		this.setYearCombo      = dynCalendar_setYearCombo;
		this.setCurrentMonth   = dynCalendar_setCurrentMonth;
		this.setCurrentYear    = dynCalendar_setCurrentYear;
		this.setYearComboRange = dynCalendar_setYearComboRange;

		/**
        * Private methods
        */
		// Layer manipulation
		this._getLayer         = dynCalendar_getLayer;
		this._hideLayer        = dynCalendar_hideLayer;
		this._showLayer        = dynCalendar_showLayer;
		this._setLayerPosition = dynCalendar_setLayerPosition;
		this._setHTML          = dynCalendar_setHTML;

		// Miscellaneous
		this._getDaysInMonth   = dynCalendar_getDaysInMonth;
		this._mouseover        = dynCalendar_mouseover;

		/**
        * Constructor type code
        */
		dynCalendar_layers[dynCalendar_layers.length] = this;
		this.writeHTML();
	}

	function dynCalendar_setEventDates(dateAry)
	{
		writeDate=dateAry;
	}

	function dynCalendar_showEventDates(dateAry, month, year)
	{
		this.setEventDates(dateAry);
		this.show(month, year);
	}

/**
* Shows the calendar, or updates the layer if
* already visible.
*
* @access public
* @param integer month Optional month number (0-11)
* @param integer year  Optional year (YYYY format)
*/
	function dynCalendar_show()
	{
		// Variable declarations to prevent globalisation
		var month, year, monthnames, numdays, thisMonth, firstOfMonth;
		var ret, row, i, cssClass, linkHTML, previousMonth, previousMonth1, previousMonth2, previousYear, previousYear1, previousYear2;
		var nextMonth, nextMonth1, nextMonth2, nextYear, nextYear1, nextYear2, prevImgHTML, prevLinkHTML, nextImgHTML, nextLinkHTML;
		
		var monthComboOptions, monthCombo, yearComboOptions, yearCombo, html;
		
		this.currentMonth = month = arguments[0] != null ? arguments[0] : this.currentMonth;
		this.currentYear  = year  = arguments[1] != null ? arguments[1] : this.currentYear;

		monthnames = new Array('January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December');
		numdays    = this._getDaysInMonth(month, year);
		thisMonth    = new Date(year, month, 1);

//		firstOfMonth = thisMonth.getDay();		//sunday as start of week
		firstOfMonth = thisMonth.getDay()-1;	//monday as start of week

		var curDateStr   = this.currentYear+"/"+(this.currentMonth+1)+"/01";
		this.currentDate = new Date();
		this.currentDate.setTime(Date.parse(curDateStr));

		// First few blanks up to first day
		ret = new Array(new Array());
		for(i=0; i<firstOfMonth; i++){
			ret[0][ret[0].length] = '<td></td>';
		}
		var today = new Date();
		var today = new Date(today.getFullYear(),today.getMonth(),today.getDate());
		// Main body of calendar
		row = 0;
		i   = 1;
		while(i <= numdays){
			if(ret[row].length == 7){
				ret[++row] = new Array();
			}

			/**
            * Generate this cells' HTML
            */
			/*
			check data day
			*/
			cDate    = new Date(this.currentYear, this.currentMonth, i);
			cssClass = 'dynCalendar_day';
			if(cDate.getTime() == today.getTime()) cssClass = 'dynCalendar_today';
			if(cDate.getTime() <  today.getTime()) cssClass = 'dynCalendar_prevday';
			for(index in writeDate)
			{
				var imonth   =month+1;
				var monthstr =(imonth < 10? "0"+imonth : imonth+"");
				var daystr   =(i      < 10? "0"+i      : i+""); 
				var dataDate=writeDate[index];
				var nowDate=year+''+monthstr+''+daystr;
				if(dataDate==nowDate){
					if(cssClass == 'dynCalendar_prevday')		cssClass ='dynCalendar_eventprev';
					else if(cssClass == 'dynCalendar_today')	cssClass ='dynCalendar_eventtoday';
					else										cssClass ='dynCalendar_event';							
				break;	
				}
			}
			
			if(cssClass =='dynCalendar_event' || cssClass =='dynCalendar_eventtoday' || cssClass =='dynCalendar_eventprev'){
				linkHTML = '<a href="javascript: ' + this.callbackFunc + '(' + year + ',' + (Number(month) + 1) + ',' + i + '); ">' + (i++) + '</a>';
			ret[row][ret[row].length] = '<td align="center" class="' + cssClass + '">' + linkHTML + '</td>';
			}else{
				linkHTML = (i++);
			ret[row][ret[row].length] = '<td align="center" class="' + cssClass + '">' + linkHTML + '</td>';
				
			}
		}

		// Format the HTML
		for(i=0; i<ret.length; i++){
			ret[i] = ret[i].join('\n') + '\n';
		}

if(this.objName=='Calendar0' || this.objName=='Calendar1' || this.objName=='Calendar2'){
	if(this.objName=='Calendar1'){
	
		previousYear  = thisMonth.getFullYear();
		previousMonth = thisMonth.getMonth() - 2;
		if(previousMonth < 0){
			previousMonth = previousMonth+12;
			previousYear--;
		}
		previousYear1  = thisMonth.getFullYear();
		previousMonth1 = thisMonth.getMonth() -1;
		if(previousMonth1 < 0){
			previousMonth1 = previousMonth1+12;
			previousYear1--;
		}
		previousYear2  = thisMonth.getFullYear();
		previousMonth2 = thisMonth.getMonth() +0;
		if(previousMonth2 < 0){
			previousMonth2 = previousMonth2+12;
			previousYear2--;
		}
		if(previousMonth2 == 12 ){
			previousMonth2 = 0;
			previousYear2++;
		}
		
		nextYear  = thisMonth.getFullYear();
		nextMonth = thisMonth.getMonth() + 0;
		if(nextMonth > 11){
			nextMonth = nextMonth-12;
			nextYear++;
		}
		nextYear1  = thisMonth.getFullYear();
		nextMonth1 = thisMonth.getMonth() + 1;
		if(nextMonth1 > 11){
			nextMonth1 = nextMonth1-12;
			nextYear1++;
		}
		nextYear2  = thisMonth.getFullYear();
		nextMonth2 = thisMonth.getMonth() + 2;
		if(nextMonth2 > 11){
			nextMonth2 = nextMonth2-12;
			nextYear2++;
		}

		prevImgHTML  = '';
		prevLinkHTML = '';		
		nextImgHTML  = '';
		nextLinkHTML = '';

		if(this.currentDate.getTime() > this.minDate.getTime())
		{
			prevImgHTML  = '<img src="' + this.imagesPath + '/prev.gif" alt="<<" border="0" />';
			prevLinkHTML = '<a href="javascript: Calendar0.show(' + previousMonth + ', ' + previousYear + ');Calendar1.show(' + previousMonth1 + ', ' + previousYear1 + ');Calendar2.show(' + previousMonth2 + ', ' + previousYear2 + '); '+this.callBackFunc2+'('+ previousYear1 + ', ' + (previousMonth1 +1) + ', -1);">' + prevImgHTML + '</a>';
		}
		
		if(this.currentDate.getTime() < this.maxDate.getTime())
		{
			nextImgHTML  = '<img src="' + this.imagesPath + '/next.gif" alt=">>" border="0" />';
			nextLinkHTML = '<a href="javascript: Calendar0.show(' + nextMonth + ', ' + nextYear + '); Calendar1.show(' + nextMonth1+ ', ' + nextYear1 + '); Calendar2.show(' + nextMonth2 + ', ' + nextYear2 + '); '+this.callBackFunc2+'('+ nextYear1 + ', ' + (nextMonth1 +1) + ', 1);">' + nextImgHTML + '</a>';
		}

	}else{
		prevImgHTML  = '';
		prevLinkHTML = '';
		nextImgHTML  = '';
		nextLinkHTML = '';
	}
}else{
	
	previousYear  = thisMonth.getFullYear();
	previousMonth = thisMonth.getMonth() - 1;
	if(previousMonth < 0){
		previousMonth = 11;
		previousYear--;
	}
		
	nextYear  = thisMonth.getFullYear();
	nextMonth = thisMonth.getMonth() + 1;
	if(nextMonth > 11){
		nextMonth = 0;
		nextYear++;
	}
	
	prevImgHTML  = '';
	prevLinkHTML = '';		
	nextImgHTML  = '';
	nextLinkHTML = '';

	if(this.currentDate.getTime() > this.minDate.getTime())
	{
		prevImgHTML  = '<img src="' + this.imagesPath + '/prev.gif" alt="<<" border="0" />';
		prevLinkHTML = '<a href="javascript: ' + this.objName + '.show(' + previousMonth + ', ' + previousYear + '); '+this.callBackFunc2+'('+ previousYear + ', ' + (previousMonth +1) + ', -1);">' + prevImgHTML + '</a>';		
		
	}
		
	if(this.currentDate.getTime() < this.maxDate.getTime())
	{
		nextImgHTML  = '<img src="' + this.imagesPath + '/next.gif" alt=">>" border="0" />';
		nextLinkHTML = '<a href="javascript: ' + this.objName + '.show(' + nextMonth + ', ' + nextYear + '); '+this.callBackFunc2+'('+ nextYear + ', ' + (nextMonth +1) + ', 1);">' + nextImgHTML + '</a>';				
	}	
}
		/**
        * Build month combo
        */
		if (this.useMonthCombo) {
			monthComboOptions = '';
			for (i=0; i<12; i++) {
				selected = (i == thisMonth.getMonth() ? 'selected="selected"' : '');
				monthComboOptions += '<option value="' + i + '" ' + selected + '>' + monthnames[i] + '</option>';
			}
			monthCombo = '<select name="months" onchange="' + this.objName + '.show(this.options[this.selectedIndex].value, ' + this.objName + '.currentYear)">' + monthComboOptions + '</select>';
		} else {
			monthCombo = monthnames[thisMonth.getMonth()];
		}
		
		/**
        * Build year combo
        */
		
		if (this.useYearCombo) {
			yearComboOptions = '';
			for (i = thisMonth.getFullYear() - this.yearComboRange; i <= (thisMonth.getFullYear() + this.yearComboRange); i++) {
				selected = (i == thisMonth.getFullYear() ? 'selected="selected"' : '');
				yearComboOptions += '<option value="' + i + '" ' + selected + '>' + i + '</option>';
			}
			yearCombo = '<select style="border: 1px groove" name="years" onchange="' + this.objName + '.show(' + this.objName + '.currentMonth, this.options[this.selectedIndex].value)">' + yearComboOptions + '</select>';
		} else {
			yearCombo = thisMonth.getFullYear();
		}

		html = '<table border="0" class="dynCalendar_table">';
		html += '<tr><td colspan="7" align="center" class="dynCalendar_header"><table width=100%><tr><td>' + yearCombo +'</td><td>'+prevLinkHTML +'</td><td width=45% align=center><span class=dynCalendar_month>'+monthCombo +'</span></td><td>'+nextLinkHTML + '</td></tr></table></td></tr>';
		html += '<tr>';
		html += '<td class="dynCalendar_dayname">M</td>';
		html += '<td class="dynCalendar_dayname">T</td>';
		html += '<td class="dynCalendar_dayname">W</td>';
		html += '<td class="dynCalendar_dayname">T</td>';
		html += '<td class="dynCalendar_dayname">F</td>';
		html += '<td class="dynCalendar_dayname">S</td>';
		html += '<td class="dynCalendar_dayname">S</td></tr>';
		html += '<tr>' + ret.join('</tr>\n<tr>') + '</tr>';
		html += '</table>';

		this._setHTML(html);
		if (!arguments[0] && !arguments[1]) {
			this._showLayer();
			this._setLayerPosition();
		}
	}

/**
* Writes HTML to document for layer
*
* @access public
*/
	function dynCalendar_writeHTML()
	{
		if (is_ie5up || is_nav6up || is_gecko) {
			//document.write('<a href="javascript: ' + this.objName + '.show()"><img src="' + this.imagesPath + 'dynCalendar.gif" border="0" width="16" height="16" /></a>');
			document.write('<div class="dynCalendar" id="' + this.layerID + '" onmouseover="' + this.objName + '._mouseover(true)" onmouseout="' + this.objName + '._mouseover(false)"></div>');
		}
	}

/**
* Sets the offset to the mouse position
* that the calendar appears at.
*
* @access public
* @param integer Xoffset Number of pixels for vertical
*                        offset from mouse position
* @param integer Yoffset Number of pixels for horizontal
*                        offset from mouse position
*/
	function dynCalendar_setOffset(Xoffset, Yoffset)
	{
		this.setOffsetX(Xoffset);
		this.setOffsetY(Yoffset);
	}

/**
* Sets the X offset to the mouse position
* that the calendar appears at.
*
* @access public
* @param integer Xoffset Number of pixels for horizontal
*                        offset from mouse position
*/
	function dynCalendar_setOffsetX(Xoffset)
	{
		this.offsetX = Xoffset;
	}

/**
* Sets the Y offset to the mouse position
* that the calendar appears at.
*
* @access public
* @param integer Yoffset Number of pixels for vertical
*                        offset from mouse position
*/
	function dynCalendar_setOffsetY(Yoffset)
	{
		this.offsetY = Yoffset;
	}
	
/**
* Sets the images path
*
* @access public
* @param string path Path to use for images
*/
	function dynCalendar_setImagesPath(path)
	{
		this.imagesPath = path;
	}

/**
* Turns on/off the month dropdown
*
* @access public
* @param boolean useMonthCombo Whether to use month dropdown or not
*/
	function dynCalendar_setMonthCombo(useMonthCombo)
	{
		this.useMonthCombo = useMonthCombo;
	}

/**
* Turns on/off the year dropdown
*
* @access public
* @param boolean useYearCombo Whether to use year dropdown or not
*/
	function dynCalendar_setYearCombo(useYearCombo)
	{
		this.useYearCombo = useYearCombo;
	}

/**
* Sets the current month being displayed
*
* @access public
* @param boolean month The month to set the current month to
*/
	function dynCalendar_setCurrentMonth(month)
	{
		this.currentMonth = month;
	}

/**
* Sets the current month being displayed
*
* @access public
* @param boolean year The year to set the current year to
*/
	function dynCalendar_setCurrentYear(year)
	{
		this.currentYear = year;
	}

/**
* Sets the range of the year combo. Displays this number of
* years either side of the year being displayed.
*
* @access public
* @param integer range The range to set
*/
	function dynCalendar_setYearComboRange(range)
	{
		this.yearComboRange = range;
	}

/**
* Returns the layer object
*
* @access private
*/
	function dynCalendar_getLayer()
	{
		var layerID = this.layerID;

		if (document.getElementById(layerID)) {

			return document.getElementById(layerID);

		} else if (document.all(layerID)) {
			return document.all(layerID);
		}
	}

/**
* Hides the calendar layer
*
* @access private
*/
	function dynCalendar_hideLayer()
	{
		//this._getLayer().style.visibility = 'hidden';
		this._getLayer().style.visibility = 'visible';
		
	}

/**
* Shows the calendar layer
*
* @access private
*/
	function dynCalendar_showLayer()
	{
		this._getLayer().style.visibility = 'visible';
	}

/**
* Sets the layers position
*
* @access private
*/
	function dynCalendar_setLayerPosition()
	{
		this._getLayer().style.top  = (dynCalendar_mouseY + this.offsetY) + 'px';
		this._getLayer().style.left = (dynCalendar_mouseX + this.offsetX) + 'px';
	}

/**
* Sets the innerHTML attribute of the layer
*
* @access private
*/
	function dynCalendar_setHTML(html)
	{
		this._getLayer().innerHTML = html;
	}

/**
* Returns number of days in the supplied month
*
* @access private
* @param integer month The month to get number of days in
* @param integer year  The year of the month in question
*/
	function dynCalendar_getDaysInMonth(month, year)
	{
		monthdays = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
		if (month != 1) {
			return monthdays[month];
		} else {
			return ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0 ? 29 : 28);
		}
	}

/**
* onMouse(Over|Out) event handler
*
* @access private
* @param boolean status Whether the mouse is over the
*                       calendar or not
*/
	function dynCalendar_mouseover(status)
	{
		dynCalendar_mouseoverStatus = status;
		return true;
	}

/**
* onMouseMove event handler
*/
	dynCalendar_oldOnmousemove = document.onmousemove ? document.onmousemove : new Function;

	document.onmousemove = function ()
	{
		if (is_ie5up || is_nav6up || is_gecko) {
			if (arguments[0]) {
				dynCalendar_mouseX = arguments[0].pageX;
				dynCalendar_mouseY = arguments[0].pageY;
			} else {
				dynCalendar_mouseX = event.clientX + document.body.scrollLeft;
				dynCalendar_mouseY = event.clientY + document.body.scrollTop;
				arguments[0] = null;
			}
	
			dynCalendar_oldOnmousemove();
		}
	}

/**
* Callbacks for document.onclick
*/
	dynCalendar_oldOnclick = document.onclick ? document.onclick : new Function;

	document.onclick = function ()
	{
		if (is_ie5up || is_nav6up || is_gecko) {
			
			if(!dynCalendar_mouseoverStatus){
				for(i=0; i<dynCalendar_layers.length; ++i){
					dynCalendar_layers[i]._hideLayer();
				}
			}
	
			dynCalendar_oldOnclick(arguments[0] ? arguments[0] : null);
		}
	}