<!-- This script are available free online -->
<!-- Original:  James O'Connor (joconnor@nordenterprises.com) -->
<!-- Web Site:  http://nordenterprises.com -->

<!-- -->

<!-- modifications and customizations to work with the "overLIB" library: -->
<!-- Author:   James B. O'Connor (joconnor@nordenterprises.com) -->
<!-- Web Site: http://www.nordenterprises.com -->
<!-- developed for use with http://home-owners-assoc.com -->
<!-- Note: while overlib works fine with Netscape 4, this function does not work very well, since portions of the "over" div -->
<!--   end up under other fields on the form and cannot be seen.  If you really want to use this with NS4, -->
<!--   you'll need to change the positioning in the overlib() call to make sure the "over" div gets positioned -->
<!--   away from all other form fields -->
<!-- you can get overLIB from: -->

//\  overLIB 3.50  --  This notice must remain untouched at all times.
//\  Copyright Erik Bosrup 1998-2001. All rights reserved.
//\  By Erik Bosrup (erik@bosrup.com).  Last modified 2001-08-28.
//\  Portions by Dan Steinman (dansteinman.com). Additions by other people are
//\  listed on the overLIB homepage.
//\  Get the latest version at http://www.bosrup.com/web/overlib/


var weekend = [6,6];
var weekendColor = "#e0e0e0";
var fontface = "Tahoma";
var fontsize = 8;			// in "pt" units; used with "font-size" style element

var gNow = new Date();
var ggWinContent;
var ggPosX = -1;
var ggPosY = -1;

Calendar.Months = ["Gennaio", "Febbraio", "Marzo", "Aprile", "Maggio", "Giugno", 
					"Luglio", "Agosto", "Settembre", "Ottobre", "Novembre", "Dicembre"];

// Non-Leap year Month days..
Calendar.DOMonth = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
// Leap year Month days..
Calendar.lDOMonth = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];

function Calendar(p_item, p_month, p_year, p_format) 
{
	if ((p_month == null) && (p_year == null))	return;
	if (p_month == null) 
	{
		this.gMonthName = null;
		this.gMonth = null;
		this.gYearly = true;
	} 
	else 
	{
		this.gMonthName = Calendar.get_month(p_month);
		this.gMonth = new Number(p_month);
		this.gYearly = false;
	}

	this.gYear = p_year;
	this.gFormat = p_format;
	this.gBGColor = "#000000";
	this.gFGColor = "#000000";
	this.gTextColor = "#000000";
	this.gHeaderColor = "#000000";
	this.gReturnItem = p_item;

}


Calendar.get_month = Calendar_get_month;
Calendar.get_daysofmonth = Calendar_get_daysofmonth;
Calendar.calc_month_year = Calendar_calc_month_year;

function Calendar_get_month(monthNo) 
{
	return Calendar.Months[monthNo];
}

function Calendar_get_daysofmonth(monthNo, p_year) 
{
	/* 
	Check for leap year ..
	1.Years evenly divisible by four are normally leap years, except for... 
	2.Years also evenly divisible by 100 are not leap years, except for... 
	3.Years also evenly divisible by 400 are leap years. 
	*/
	if ((p_year % 4) == 0) 
	{
		if ((p_year % 100) == 0 && (p_year % 400) != 0)
			return Calendar.DOMonth[monthNo];

		return Calendar.lDOMonth[monthNo];
	} 
	else
	{
		return Calendar.DOMonth[monthNo];
	}
}


function Calendar_calc_month_year(p_Month, p_Year, incr) 
{
	/* 
	Will return an 1-D array with 1st element being the calculated month 
	and second being the calculated year 
	after applying the month increment/decrement as specified by 'incr' parameter.
	'incr' will normally have 1/-1 to navigate thru the months.
	*/
	var ret_arr = new Array();

	if (incr == -1) 
	{
	// B A C K W A R D
		if (p_Month == 0) 
		{
			ret_arr[0] = 11;
			ret_arr[1] = parseInt(p_Year) - 1;
		}
		else 
		{
			ret_arr[0] = parseInt(p_Month) - 1;
			ret_arr[1] = parseInt(p_Year);
		}
	} 
	else if (incr == 1) 
	{
		// F O R W A R D
		if (p_Month == 11) 
		{
			ret_arr[0] = 0;
			ret_arr[1] = parseInt(p_Year) + 1;
		}
		else 
		{
			ret_arr[0] = parseInt(p_Month) + 1;
			ret_arr[1] = parseInt(p_Year);
		}
	}
	return ret_arr;
}



function Calendar_calc_month_year(p_Month, p_Year, incr) 
{
	/* 
	Will return an 1-D array with 1st element being the calculated month 
	and second being the calculated year 
	after applying the month increment/decrement as specified by 'incr' parameter.
	'incr' will normally have 1/-1 to navigate thru the months.
	*/
	var ret_arr = new Array();

	if (incr == -1) 
	{
		// B A C K W A R D
		if (p_Month == 0) 
		{
			ret_arr[0] = 11;
			ret_arr[1] = parseInt(p_Year) - 1;
		}
		else 
		{
			ret_arr[0] = parseInt(p_Month) - 1;
			ret_arr[1] = parseInt(p_Year);
		}
	} else if (incr == 1) {
	// F O R W A R D
		if (p_Month == 11) 
		{
			ret_arr[0] = 0;
			ret_arr[1] = parseInt(p_Year) + 1;
		}
		else 
		{
			ret_arr[0] = parseInt(p_Month) + 1;
			ret_arr[1] = parseInt(p_Year);
		}
	}
	return ret_arr;
}

// This is for compatibility with Navigator 3, we have to create and discard one object before the prototype object exists.
new Calendar();

Calendar.prototype.getMonthlyCalendarCode = function() 
{
	var vCode = "";
	var vHeader_Code = "";
	var vData_Code = "";

	// Begin Table Drawing code here..
	vCode += ("<div align=center><TABLE BORDER=0 CELLSPACING=0 CELLPADDING=0>");
	vHeader_Code = this.cal_header();
	vData_Code = this.cal_data();
	vCode += (vHeader_Code + vData_Code);
	vCode += "</TABLE></div>";
	return vCode;
}

Calendar.prototype.show = function() 
{
	var vCode = "";
	// build content into global var ggWinContent
	ggWinContent += ("<div class='cal_meseanno'>");
	ggWinContent += (this.gMonthName + " " + this.gYear);
	ggWinContent += "</div>";

	// Show navigation buttons
	var prevMMYYYY = Calendar.calc_month_year(this.gMonth, this.gYear, -1);
	var prevMM = prevMMYYYY[0];
	var prevYYYY = prevMMYYYY[1];
	var nextMMYYYY = Calendar.calc_month_year(this.gMonth, this.gYear, 1);
	var nextMM = nextMMYYYY[0];
	var nextYYYY = nextMMYYYY[1];

	ggWinContent += "<div align='center'><TABLE WIDTH='100%' BORDER='0' CELLSPACING='1' CELLPADDING='0'><TR>";
	
	ggWinContent += ("<TD width='22%' class='cal_selector'><A HREF=\"javascript:void(0);\" " +
					"onMouseOver=\"window.status='Indietro di un anno'; return true;\" " +
					"onMouseOut=\"window.status=''; return true;\" " +
					"onClick=\"Build('" + this.gReturnItem + "', '" + this.gMonth + "', '" + (parseInt(this.gYear)-1) + "', '" + this.gFormat + "');\">" +
					"<img src='images/prev_year.gif' width='7' height='7' border='0' alt='Indietro di un anno'>" +
					"Anno<\/A></TD>");
					
	ggWinContent += ("<TD width='22%' class='cal_selector'>" + 
					"<A HREF=\"javascript:void(0);\" " +
					"onMouseOver=\"window.status='Indietro di un mese'; return true;\" " +
					"onMouseOut=\"window.status=''; return true;\" " +
					"onClick=\"Build('" + this.gReturnItem + "', '" + prevMM + "', '" + prevYYYY + "', '" + this.gFormat + "');\">" + 
					"<img src='images/prev_month.gif' width='7' height='7' border='0' alt='Indietro di un mese'>Mese<\/A>" +
					 "</TD>");
					
	ggWinContent += "<TD width='12%'>&nbsp;</TD>";
	
	ggWinContent += ("<TD width='22%' class='cal_selector'>" +
					"<A HREF=\"javascript:void(0);\" " +
					"onMouseOver=\"window.status='Avanti di un mese'; return true;\" " +
					"onMouseOut=\"window.status=''; return true;\" " +
					"onClick=\"Build('" + this.gReturnItem + "', '" + nextMM + "', '" + nextYYYY + "', '" + this.gFormat + "');\">" +
					"Mese" + 
					"<img src='images/next_month.gif' width='7' height='7' border='0' alt='Avanti di un mese'><\/A>" +
					"</TD>");
					
	ggWinContent += ("<TD width='22%' class='cal_selector'>" +
					"<A HREF=\"javascript:void(0);\" " +
					"onMouseOver=\"window.status='Avanti di un anno'; return true;\" " +
					"onMouseOut=\"window.status=''; return true;\" " +
					"onClick=\"Build('" + this.gReturnItem + "', '" + this.gMonth + "', '" + (parseInt(this.gYear)+1) + "', '" + this.gFormat + "');\">" +
					"Anno" + 
					"<img src='images/next_year.gif' width='7' height='7' border='0' alt='Avanti di un anno'><\/A>" + 
					"</TD>");
					
	ggWinContent += "</TR></TABLE></div><BR>";
	// Get the complete calendar code for the month, and add it to the
	//	content var
	vCode = this.getMonthlyCalendarCode();
	ggWinContent += vCode;
}

Calendar.prototype.showY = function() 
{
	var vCode = "";
	var i;

	ggWinContent += "<FONT FACE='" + fontface + "' ><B>"
	ggWinContent += ("Anno : " + this.gYear);
	ggWinContent += "</B><BR>";

	// Show navigation buttons
	var prevYYYY = parseInt(this.gYear) - 1;
	var nextYYYY = parseInt(this.gYear) + 1;

	ggWinContent += ("<TABLE WIDTH='100%' BORDER=1 CELLSPACING=0 CELLPADDING=0 BGCOLOR='#e0e0e0' style='font-size:" + fontsize + "pt;'><TR><TD ALIGN=center>");
	ggWinContent += ("[<A HREF=\"javascript:void(0);\" " +
					"onMouseOver=\"window.status='Indietro di un anno'; return true;\" " +
					"onMouseOut=\"window.status=''; return true;\" " +
					"onClick=\"Build(" + 
					"'" + this.gReturnItem + "', null, '" + prevYYYY + "', '" + this.gFormat + "'" +
					");" +
					"\">&lt;&lt;Anno<\/A>]</TD><TD ALIGN=center>");
	ggWinContent += "&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</TD><TD ALIGN=center>";
	ggWinContent += ("[<A HREF=\"javascript:void(0);\" " +
					"onMouseOver=\"window.status='Avanti di un anno'; return true;\" " +
					"onMouseOut=\"window.status=''; return true;\" " +
					"onClick=\"Build(" + 
					"'" + this.gReturnItem + "', null, '" + nextYYYY + "', '" + this.gFormat + "'" +
					");" +
					"\">Anno&gt;&gt;<\/A>]</TD></TR></TABLE><BR>");

	// Get the complete calendar code for each month.
	// start a table and first row in the table
	ggWinContent += ("<TABLE WIDTH='100%' BORDER=0 CELLSPACING=0 CELLPADDING=5 style='font-size:" + fontsize + "pt;'><TR>");
	var j;
	for (i=0; i<12; i++) 
	{
		// start the table cell
		ggWinContent += "<TD ALIGN='center' VALIGN='top'>";
		this.gMonth = i;
		this.gMonthName = Calendar.get_month(this.gMonth);
		vCode = this.getMonthlyCalendarCode();
		ggWinContent += (this.gMonthName + "/" + this.gYear + "<BR>");
		ggWinContent += vCode;
		ggWinContent += "</TD>";
		if (i == 3 || i == 7) 
		{
			ggWinContent += "</TR><TR>";
		}
	}
	ggWinContent += "</TR></TABLE></font><BR>";
}

Calendar.prototype.cal_header = function() 
{
	var vCode = "";
	vCode = vCode + "<TR>";
	vCode = vCode + "<TD class='cal_day_header' WIDTH='14%'>Lun</TD>";
	vCode = vCode + "<TD class='cal_day_header' WIDTH='14%'>Mar</TD>";
	vCode = vCode + "<TD class='cal_day_header' WIDTH='14%'>Mer</TD>";
	vCode = vCode + "<TD class='cal_day_header' WIDTH='14%'>Gio</TD>";
	vCode = vCode + "<TD class='cal_day_header' WIDTH='14%'>Ven</TD>";
	vCode = vCode + "<TD class='cal_day_header' WIDTH='14%'>Sab</TD>";
	vCode = vCode + "<TD class='cal_day_header' WIDTH='14%'>Dom</TD>";
	vCode = vCode + "</TR>";
	return vCode;
}

Calendar.prototype.cal_data = function() 
{
	var vDate = new Date();
	vDate.setDate(1);
	vDate.setMonth(this.gMonth);
	vDate.setFullYear(this.gYear);

	var vFirstDay=vDate.getDay();
	if (vFirstDay == 0)
		vFirstDay = 6;
	else
		vFirstDay = vFirstDay -1;
	
	var vDay=1;
	var vLastDay=Calendar.get_daysofmonth(this.gMonth, this.gYear);
	var vOnLastDay=0;
	var vCode = "";

	/*
	Get day for the 1st of the requested month/year..
	Place as many blank cells before the 1st day of the month as necessary. 
	*/
	vCode = vCode + "<TR>";
	for (i=0; i<vFirstDay; i++) 
	{
		vCode = vCode + "<TD WIDTH='14%'" + this.write_weekend_string(i) + " class='cal_day'>";
	}

	// Write rest of the 1st week
	for (j=vFirstDay; j<7; j++) 
	{
		vCode = vCode + "<TD onmouseout=\"linkOver('day" + vDay + "',false)\" onmouseover=\"linkOver('day" + vDay + "',true);" +
					"window.status='imposta la data a: " + this.format_data(vDay) + "'; return true;\" " +
					"onMouseOut=\"window.status=' '; return true;\" " +
					"onClick=\"document." + this.gReturnItem + ".value='" + 
					this.format_data(vDay) + 
					"';window.scroll(0,ggPosY);ggPosX=-1;ggPosY=-1;nd();nd();\" id='day" + vDay + "' WIDTH='14%'" + this.write_weekend_string(j) + " class='cal_day' style='cursor: hand'>" + 
					this.format_day(vDay) + 
					"</TD>";
		vDay=vDay + 1;
	}
	vCode = vCode + "</TR>";

	// Write the rest of the weeks
	for (k=2; k<7; k++) 
	{
		vCode = vCode + "<TR>";
		for (j=0; j<7; j++) 
		{
			vCode = vCode + "<TD onmouseout=\"linkOver('day" + vDay + "',false)\" onmouseover=\"linkOver('day" + vDay + "',true);" +
					"window.status='imposta la data a: " + this.format_data(vDay) + "'; return true;\" " +
					"onMouseOut=\"window.status=' '; return true;\" " +
					"onClick=\"document." + this.gReturnItem + ".value='" + 
					this.format_data(vDay) + 
					"';window.scroll(0,ggPosY);ggPosX=-1;ggPosY=-1;nd();nd();\" id='day" + vDay + "' WIDTH='14%'" + this.write_weekend_string(j) + " class='cal_day' style='cursor: hand'>" + 
					this.format_day(vDay) + 
					"</TD>";
			vDay=vDay + 1;

			if (vDay > vLastDay) 
			{
				vOnLastDay = 1;
				break;
			}
		}

		if (j == 6)
		{
			vCode = vCode + "</TR>";
		}
		if (vOnLastDay == 1)
		{
			break;
		}
	}


	// Fill up the rest of last week with proper blanks, so that we get proper square blocks
	for (m=1; m<(7-j); m++) 
	{
		/*if (this.gYearly)
		{*/
			vCode = vCode + "<TD WIDTH='14%' class='cal_day' " + this.write_weekend_string(j+m) + ">&nbsp;</TD>";
		/*}
		else
		{
			vCode = vCode + "<TD WIDTH='14%' class='cal_day'" + this.write_weekend_string(j+m) + ">" + m + "</TD>";
		}*/
	}
	return vCode;
}

Calendar.prototype.format_day = function(vday) 
{
	var vNowDay = gNow.getDate();
	var vNowMonth = gNow.getMonth();
	var vNowYear = gNow.getFullYear();

	if (vday == vNowDay && this.gMonth == vNowMonth && this.gYear == vNowYear)
	{
		return ("<FONT COLOR=\"RED\"><B>" + vday + "</B></FONT>");
	}
	else
	{
		return (vday);
	}
}

Calendar.prototype.write_weekend_string = function(vday) 
{
	var i;
	// Return special formatting for the weekend day.
	for (i=0; i<weekend.length; i++) 
	{
		if (vday == weekend[i])
		{
			return (" BGCOLOR=\"" + weekendColor + "\"");
		}
	}
	return "";
}

Calendar.prototype.format_data = function(p_day) 
{
	var vData;
	var vMonth = 1 + this.gMonth;
	vMonth = (vMonth.toString().length < 2) ? "0" + vMonth : vMonth;
	var vMon = Calendar.get_month(this.gMonth).substr(0,3).toUpperCase();
	var vFMon = Calendar.get_month(this.gMonth).toUpperCase();
	var vY4 = new String(this.gYear);
	var vY2 = new String(this.gYear.substr(2,2));
	var vDD = (p_day.toString().length < 2) ? "0" + p_day : p_day;

	switch (this.gFormat) 
	{
		case "MM\/DD\/YYYY" :
			vData = vMonth + "\/" + vDD + "\/" + vY4;
			break;
		case "MM\/DD\/YY" :
			vData = vMonth + "\/" + vDD + "\/" + vY2;
			break;
		case "MM-DD-YYYY" :
			vData = vMonth + "-" + vDD + "-" + vY4;
			break;
		case "YYYY-MM-DD" :
			vData = vY4 + "-" + vMonth + "-" + vDD;
			break;
		case "MM-DD-YY" :
			vData = vMonth + "-" + vDD + "-" + vY2;
			break;
		case "DD\/MON\/YYYY" :
			vData = vDD + "\/" + vMon + "\/" + vY4;
			break;
		case "DD\/MON\/YY" :
			vData = vDD + "\/" + vMon + "\/" + vY2;
			break;
		case "DD-MON-YYYY" :
			vData = vDD + "-" + vMon + "-" + vY4;
			break;
		case "DD-MON-YY" :
			vData = vDD + "-" + vMon + "-" + vY2;
			break;
		case "DD\/MONTH\/YYYY" :
			vData = vDD + "\/" + vFMon + "\/" + vY4;
			break;
		case "DD\/MONTH\/YY" :
			vData = vDD + "\/" + vFMon + "\/" + vY2;
			break;
		case "DD-MONTH-YYYY" :
			vData = vDD + "-" + vFMon + "-" + vY4;
			break;
		case "DD-MONTH-YY" :
			vData = vDD + "-" + vFMon + "-" + vY2;
			break;
		case "DD\/MM\/YYYY" :
			vData = vDD + "\/" + vMonth + "\/" + vY4;
			break;
		case "DD\/MM\/YY" :
			vData = vDD + "\/" + vMonth + "\/" + vY2;
			break;
		case "DD-MM-YYYY" :
			vData = vDD + "-" + vMonth + "-" + vY4;
			break;
		case "DD-MM-YY" :
			vData = vDD + "-" + vMonth + "-" + vY2;
			break;
		default :
			vData = vMonth + "\/" + vDD + "\/" + vY4;
	}
	return vData;
}



function Build(p_item, p_month, p_year, p_format) 
{
	gCal = new Calendar(p_item, p_month, p_year, p_format);

	// Customize your Calendar here..
	gCal.gBGColor="#ECECEC";
	gCal.gLinkColor="#000000";
	gCal.gTextColor="#000000";
	gCal.gHeaderColor="darkgreen";

	// initialize the content string
	ggWinContent = "";

	// Choose appropriate show function
	if (gCal.gYearly) 
	{
		// and, since the yearly calendar is so large, override the positioning and fontsize
		// warning: in IE6, it appears that "select" fields on the form will still show
		//	through the "over" div; Note: you can set these variables as part of the onClick
		//	javascript code before you call the show_yearly_calendar function
		if (ggPosX == -1) ggPosX = 10;
		if (ggPosY == -1) ggPosY = 10;
		if (fontsize == 8) fontsize = 6;
		// generate the calendar
		gCal.showY();
	}
	else 
	{
		gCal.show();
	}

	// if this is the first calendar popup, use autopositioning with an offset
	if (ggPosX == -1 && ggPosY == -1) 
	{
		overlib(ggWinContent, AUTOSTATUSCAP, STICKY, CLOSECLICK, CSSSTYLE,
				TEXTSIZEUNIT, "pt", TEXTSIZE, 8, CAPTIONSIZEUNIT, "pt", CAPTIONSIZE, 8, CLOSESIZEUNIT, "pt", CLOSESIZE, 8,
				CAPTION, "Seleziona una data", OFFSETX, 20, OFFSETY, -20);
		// save where the 'over' div ended up; we want to stay in the same place if the user
		//	clicks on one of the year or month navigation links
		if ( (ns4) || (ie4) ) 
		{
			ggPosX = parseInt(over.left);
			ggPosY = parseInt(over.top);
		} 
		else if (ns6) 
		{
			ggPosX = parseInt(over.style.left);
			ggPosY = parseInt(over.style.top);
		}
	}
	else 
	{
		// we have a saved X & Y position, so use those with the FIXX and FIXY options
		overlib(ggWinContent, AUTOSTATUSCAP, STICKY, CLOSECLICK, CSSSTYLE,
				TEXTSIZEUNIT, "pt", TEXTSIZE, 8, CAPTIONSIZEUNIT, "pt", CAPTIONSIZE, 8, CLOSESIZEUNIT, "pt", CLOSESIZE, 8,
				CAPTION, "Seleziona una data", FIXX, ggPosX, FIXY, ggPosY);
	}
	window.scroll(ggPosX, ggPosY);
}

function show_calendar() 
{
	/* 
		p_month : 0-11 for Jan-Dec; 12 for All Months.
		p_year	: 4-digit year
		p_format: Date format (yyyy/mm/dd, dd/mm/yy, ...)
		p_item	: Return Item.
	*/

	p_item = arguments[0];
	if (arguments[1] == null)
	{
		p_month = new String(gNow.getMonth());
	}
	else
	{
		p_month = arguments[1];
	}
	if (arguments[2] == "" || arguments[2] == null)
	{
		p_year = new String(gNow.getFullYear().toString());
	}
	else
	{
		p_year = arguments[2];
	}
	if (arguments[3] == null)
	{
		p_format = "DD/MM/YYYY";
	}
	else
	{	
		p_format = arguments[3];
	}

	Build(p_item, p_month, p_year, p_format);
}

/*
Yearly Calendar Code Starts here
*/
function show_yearly_calendar() 
{
	// Load the defaults..
	//if (p_year == null || p_year == "")
	//	p_year = new String(gNow.getFullYear().toString());
	//if (p_format == null || p_format == "")
	//	p_format = "YYYY-MM-DD";
	p_item = arguments[0];
	if (arguments[1] == "" || arguments[1] == null)
	{
		p_year = new String(gNow.getFullYear().toString());
	}
	else
	{
		p_year = arguments[1];
	}
	if (arguments[2] == null)
	{
		p_format = "YYYY-MM-DD";
	}
	else
	{
		p_format = arguments[2];
	}
	Build(p_item, null, p_year, p_format);
}

function linkOver(idElem,isMouseOver)
{
	if (obj = document.getElementById(idElem))
	{
		pStyle = obj.style;
		if (isMouseOver)
		{
			pStyle.background = "#FFFF00"
			pStyle.color = "#000000";
		}
		else
		{
			pStyle.background = "#ECECEC"
			pStyle.color = "#000000";
		}
	}	
}