/************************************************************************************************************
JS Calendar
Copyright (C) September 2006  DTHMLGoodies.com, Alf Magne Kalleland

This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.

This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA

Dhtmlgoodies.com., hereby disclaims all copyright interest in this script
written by Alf Magne Kalleland.

Alf Magne Kalleland, 2006
Owner of DHTMLgoodies.com
	
************************************************************************************************************/	

/* Update log:
(C) www.dhtmlgoodies.com, September 2005

Version 1.2, November 8th - 2005 - Added <iframe> background in IE
Version 1.3, November 12th - 2005 - Fixed top bar position in Opera 7
Version 1.4, December 28th - 2005 - Support for Spanish and Portuguese
Version 1.5, January  18th - 2006 - Fixed problem with next-previous buttons after a month has been selected from dropdown
Version 1.6, February 22nd - 2006 - Added variable which holds the path to images.
									Format todays date at the bottom by use of the todayStringFormat variable
									Pick todays date by clicking on todays date at the bottom of the calendar
Version 2.0	 May, 25th - 2006	  - Added support for time(hour and minutes) and changing year and hour when holding mouse over + and - options. (i.e. instead of click)
Version 2.1	 July, 2nd - 2006	  - Added support for more date formats(example: d.m.yyyy, i.e. one letter day and month).

*/
var languageCode = 'en';	// Possible values: 	en,ge,no,nl,es,pt-br,fr	
							// en = english, ge = german, no = norwegian,nl = dutch, es = spanish, pt-br = portuguese, fr = french, da = danish, hu = hungarian(Use UTF-8 doctype for hungarian)

								
// Format of current day at the bottom of the calendar
// [todayString] = the value of todayString
// [dayString] = day of week (examle: mon, tue, wed...)
// [UCFdayString] = day of week (examle: Mon, Tue, Wed...) ( First letter in uppercase)
// [day] = Day of month, 1..31
// [monthString] = Name of current month
// [year] = Current year							
var todayStringFormat = '[todayString] [UCFdayString]. [day]. [monthString] [year]';						
var pathToImages = '/posarelli/posarellivillas/templates/img/calendar/';	// Relative to your HTML file

var speedOfSelectBoxSliding = 200;	// Milliseconds between changing year and hour when holding mouse over "-" and "+" - lower value = faster

var calendar_offsetTop = 0;		// Offset - calendar placement - You probably have to modify this value if you're not using a strict doctype
var calendar_offsetLeft = 0;	// Offset - calendar placement - You probably have to modify this value if you're not using a strict doctype
var calendarDiv = false;

var MSIE = false;
var Opera = false;
var safari = false;
if(navigator.userAgent.indexOf('MSIE')>=0 && navigator.userAgent.indexOf('Opera')<0)MSIE=true;
if(navigator.userAgent.indexOf('Opera')>=0)Opera=true;
if(navigator.userAgent.indexOf('Safari')>=0)safari=true;
var monthArray;
var monthArrayShort;
var dayArray;
var weekString;
var todayString;

function language(languageCode)
{
	switch(languageCode){
		case "en":	/* English */
			monthArray = ['January','February','March','April','May','June','July','August','September','October','November','December'];
			monthArrayShort = ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'];
			dayArray = ['M','T','W','T','F','S','S'];
			weekString = 'Week';
			todayString = '';
			break;
		case "de":	/* German */
			monthArray = ['Januar','Februar','M&#228;rz','April','Mai','Juni','Juli','August','September','Oktober','November','Dezember'];
			monthArrayShort = ['Jan','Feb','Mar','Apr','Mai','Jun','Jul','Aug','Sep','Okt','Nov','Dez'];
			dayArray = ['M','D','M','D','F','S','S'];	
			weekString = 'Woche';
			todayString = 'Heute';		
			break;
		case "fr":      /* French */
			monthArray = ['Janvier','F&#233;vrier','Mars','Avril','Mai','Juin','Juillet','Ao&#251;t','Septembre','Octobre','Novembre','D&#233;cembre'];		
			monthArrayShort = ['Jan','Fev','Mar','Avr','Mai','Jun','Jul','Aou','Sep','Oct','Nov','Dec'];
			dayArray = ['L','M','M','J','V','S','D'];
			weekString = 'Sem';
			todayString = "Aujourd'hui";
			break; 	
		case "it":	/* Italian*/
			monthArray = ['Gennaio','Febbraio','Marzo','Aprile','Maggio','Giugno','Luglio','Agosto','Settembre','Ottobre','Novembre','Dicembre'];
			monthArrayShort = ['Gen','Feb','Mar','Apr','Mag','Giu','Lugl','Ago','Set','Ott','Nov','Dic'];
			dayArray = ['L','M','M','G','V','S','D'];
			weekString = 'Settimana';
			todayString = 'Oggi &egrave; il';
			break;
		default:	/* English */
			monthArray = ['January','February','March','April','May','June','July','August','September','October','November','December'];
			monthArrayShort = ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'];
			dayArray = ['M','T','W','T','F','S','S'];
			weekString = 'Week';
			todayString = '';
			break;	
	}
}

var daysInMonthArray = [31,28,31,30,31,30,31,31,30,31,30,31];
var currentMonth;
var currentYear;
var currentDay;
var calendarContentDiv;
var returnDateTo;
var returnFormat;
var activeSelectBoxMonth;
var activeSelectBoxYear;

var iframeObj = false;
//// fix for EI frame problem on time dropdowns 09/30/2006
var iframeObj2 =false;
function EIS_FIX_EI1(where2fixit)
{ 
		if(!iframeObj2)return;
		iframeObj2.style.display = 'block';
}

function EIS_Hide_Frame()
{		if(iframeObj2)iframeObj2.style.display = 'none';}
//// fix for EI frame problem on time dropdowns 09/30/2006
var returnDateToYear;
var returnDateToMonth;
var returnDateToDay;

var inputYear;
var inputMonth;
var inputDay;

var selectBoxHighlightColor = '#D60808'; // Highlight color of select boxes
var selectBoxBGColor = '#3E4B63';
var selectBoxRolloverBgColor = '#E2EBED'; // Background color on drop down lists(rollover)

var selectBoxMovementInProgress = false;
var activeSelectBox = false;

function cancelCalendarEvent()
{
	return false;
}
function isLeapYear(inputYear)
{
	if(inputYear%400==0||(inputYear%4==0&&inputYear%100!=0)) return true;
	return false;	
}

var activeSelectBoxMonth = false;
var activeSelectBoxDirection = false;

function highlightMonthYear()
{
	if(activeSelectBoxMonth)activeSelectBoxMonth.className='';
	activeSelectBox = this;
	if(this.className=='monthYearActive'){
		this.className='';	
	}else{
		this.className = 'monthYearActive';
		activeSelectBoxMonth = this;
	}
	if(this.innerHTML.indexOf('-')>=0 || this.innerHTML.indexOf('+')>=0){
		if(this.className=='monthYearActive')
			selectBoxMovementInProgress = true; 
		else 
			selectBoxMovementInProgress = false;	
		if(this.innerHTML.indexOf('-')>=0)activeSelectBoxDirection = -1; else activeSelectBoxDirection = 1;	
	}else selectBoxMovementInProgress = false;
}

function showMonthDropDown()
{
	if(document.getElementById('monthDropDown').style.display=='block'){
		document.getElementById('monthDropDown').style.display='none';	
		//// fix for EI frame problem on time dropdowns 09/30/2006
				EIS_Hide_Frame();
	}else{
		document.getElementById('monthDropDown').style.display='block';		
		document.getElementById('yearDropDown').style.display='none';
			if (MSIE)
		{ EIS_FIX_EI1('monthDropDown')}
		//// fix for EI frame problem on time dropdowns 09/30/2006
	}
}

function showYearDropDown()
{
	if(document.getElementById('yearDropDown').style.display=='block'){
		document.getElementById('yearDropDown').style.display='none';	
		//// fix for EI frame problem on time dropdowns 09/30/2006
				EIS_Hide_Frame();
	}else{
		document.getElementById('yearDropDown').style.display='block';	
		document.getElementById('monthDropDown').style.display='none';	
			if (MSIE)
		{ EIS_FIX_EI1('yearDropDown')}
		//// fix for EI frame problem on time dropdowns 09/30/2006
	}		
}

function selectMonth()
{
	document.getElementById('calendar_month_txt').innerHTML = this.innerHTML
	actualMonth = this.id.replace(/[^\d]/g,'');
	document.getElementById('monthDropDown').style.display='none';
	//// fix for EI frame problem on time dropdowns 09/30/2006
				EIS_Hide_Frame();
	for(var no=0;no<monthArray.length;no++){
		document.getElementById('monthDiv_'+no).style.color='';	
	}
	this.style.color = selectBoxHighlightColor;
	activeSelectBoxMonth = this;
	if(actualMonth != currentMonth)
	{
		if(actualYear < currentYear || (actualMonth < firstMonth && actualYear == firstYear))
		{
			allDay = true;
		}else
		{
			allDay = false;
		}
	}
	writeCalendarContent();
}

function selectYear()
{
	document.getElementById('calendar_year_txt').innerHTML = this.innerHTML
	//currentYear = this.innerHTML.replace(/[^\d]/g,'');
	actualYear = this.innerHTML.replace(/[^\d]/g,'');
	document.getElementById('yearDropDown').style.display='none';
	//// fix for EI frame problem on time dropdowns 09/30/2006
	EIS_Hide_Frame();
	if(activeSelectBoxYear){
		activeSelectBoxYear.style.color='';
	}
	activeSelectBoxYear=this;
	this.style.color = selectBoxHighlightColor;
	if(actualYear < firstYear || (actualMonth < firstMonth && actualYear == firstYear))
	{
		allDay = true;
	}else
	{
		allDay = false;
	}
	writeCalendarContent();
}

var allDay = false;
var actualMonth;
var actualYear;

function switchMonth()
{
	if(this.src.indexOf('left')>=0){
		actualMonth = actualMonth/1;
		switch(actualMonth)
		{
			case 0:
				actualMonth = 11;
				actualYear = actualYear/1 - 1;
				break;
			default:
				actualMonth = actualMonth/1 - 1;
				break;
		}
	}else{
		actualMonth = actualMonth/1;
		switch(actualMonth)
		{
			case 11:
				actualMonth = 0;
				actualYear = actualYear/1 + 1;
				break;
			default:
				actualMonth = actualMonth/1 + 1;
				break;
		}
	}
	if(actualYear < firstYear || (actualMonth < firstMonth && actualYear == firstYear))
	{
		allDay = true;
	}else
	{
		allDay = false;
	}
	writeCalendarContent();	
}

function createMonthDiv(){
	var div = document.createElement('DIV');
	div.className='monthYearPicker';
	div.id = 'monthPicker';
	for(var no=0;no<monthArray.length;no++){
		var subDiv = document.createElement('DIV');
		subDiv.innerHTML = monthArray[no];
		subDiv.onmouseover = highlightMonthYear;
		subDiv.onmouseout = highlightMonthYear;
		subDiv.onclick = selectMonth;
		subDiv.id = 'monthDiv_' + no;
		subDiv.style.width = '56px';
		subDiv.onselectstart = cancelCalendarEvent;		
		div.appendChild(subDiv);
		if(currentMonth && currentMonth==no){
			subDiv.style.color = selectBoxHighlightColor;
			activeSelectBoxMonth = subDiv;
		}				
	}	
	return div;
}

function changeSelectBoxYear(e,inputObj)
{
	if(!inputObj)inputObj =this;
	var yearItems = inputObj.parentNode.getElementsByTagName('DIV');
	if(inputObj.innerHTML.indexOf('-')>=0){
		var startYear = yearItems[1].innerHTML/1 -1;
		if(activeSelectBoxYear){
			activeSelectBoxYear.style.color='';
		}
	}else{
		var startYear = yearItems[1].innerHTML/1 +1;
		if(activeSelectBoxYear){
			activeSelectBoxYear.style.color='';
		}			
	}
	for(var no=1;no<yearItems.length-1;no++){
		yearItems[no].innerHTML = startYear+no/1-1;	
		yearItems[no].id = 'yearDiv' + (startYear/1+no/1-1);		
	}
	if(activeSelectBoxYear){
		activeSelectBoxYear.style.color='';
		if(document.getElementById('yearDiv'+currentYear)){
			activeSelectBoxYear = document.getElementById('yearDiv'+currentYear);
			activeSelectBoxYear.style.color=selectBoxHighlightColor;;
		}
	}
}

function updateYearDiv()
{
	var div = document.getElementById('yearDropDown');
	var yearItems = div.getElementsByTagName('DIV');
	var now = new Date();
	for(var no=1;no<yearItems.length-1;no++){
		yearItems[no].innerHTML = actualYear/1 -6 + no;
		if(currentYear==(actualYear/1 -6 + no)){
			yearItems[no].style.color = selectBoxHighlightColor;
			activeSelectBoxYear = yearItems[no];				
		}else
		{
			yearItems[no].style.color = '';
		}
	}
}

function updateMonthDiv()
{
	for(no=0;no<12;no++){
		document.getElementById('monthDiv_' + no).style.color = '';
	}
	var now = new Date();
	document.getElementById('monthDiv_' + currentMonth).style.color = selectBoxHighlightColor;
	activeSelectBoxMonth = 	document.getElementById('monthDiv_' + currentMonth);
}

function createYearDiv()
{
	if(!document.getElementById('yearDropDown')){
		var div = document.createElement('DIV');
		div.className='monthYearPicker';
	}else{
		var div = document.getElementById('yearDropDown');
		var subDivs = div.getElementsByTagName('DIV');
		for(var no=0;no<subDivs.length;no++){
			subDivs[no].parentNode.removeChild(subDivs[no]);	
		}	
	}	
	var d = new Date();
	if(currentYear){
		d.setFullYear(currentYear);
	}
	var startYear = d.getFullYear()/1 - 5;
	var subDiv = document.createElement('DIV');
	subDiv.innerHTML = '&nbsp;&nbsp;- ';
	subDiv.onclick = changeSelectBoxYear;
	subDiv.onmouseover = highlightMonthYear;
	subDiv.onmouseout = function(){ selectBoxMovementInProgress = false;};	
	subDiv.onselectstart = cancelCalendarEvent;			
	div.appendChild(subDiv);
	for(var no=startYear;no<(startYear+10);no++){
		var subDiv = document.createElement('DIV');
		subDiv.innerHTML = no;
		subDiv.onmouseover = highlightMonthYear;
		subDiv.onmouseout = highlightMonthYear;		
		subDiv.onclick = selectYear;		
		subDiv.id = 'yearDiv' + no;	
		subDiv.onselectstart = cancelCalendarEvent;
		div.appendChild(subDiv);
		if(currentYear && currentYear==no){
			subDiv.style.color = selectBoxHighlightColor;
			activeSelectBoxYear = subDiv;
		}			
	}
	var subDiv = document.createElement('DIV');
	subDiv.innerHTML = '&nbsp;&nbsp;+ ';
	subDiv.onclick = changeSelectBoxYear;
	subDiv.onmouseover = highlightMonthYear;
	subDiv.onmouseout = function(){ selectBoxMovementInProgress = false;};		
	subDiv.onselectstart = cancelCalendarEvent;			
	div.appendChild(subDiv);
	return div;
}

function slideCalendarSelectBox()
{
	if(selectBoxMovementInProgress){
		if(activeSelectBox.parentNode.id=='hourDropDown'){
			changeSelectBoxHour(false,activeSelectBox);			
		}
		if(activeSelectBox.parentNode.id=='yearDropDown'){
			changeSelectBoxYear(false,activeSelectBox);			
		}
	}
	setTimeout('slideCalendarSelectBox()',speedOfSelectBoxSliding);	
}

function highlightSelect()
{
	if(this.className=='selectBox'){
		this.className = 'selectBoxOver';	
		this.getElementsByTagName('IMG')[0].src = pathToImages + 'down_over.gif';
	}else if(this.className=='selectBoxOver'){
		this.className = 'selectBox';	
		this.getElementsByTagName('IMG')[0].src = pathToImages + 'down.gif';			
	}	
}

function highlightArrow()
{
	if(this.src.indexOf('over')>=0){
		if(this.src.indexOf('left')>=0)this.src = pathToImages + 'left.gif';	
		if(this.src.indexOf('right')>=0)this.src = pathToImages + 'right.gif';				
	}else{
		if(this.src.indexOf('left')>=0)this.src = pathToImages + 'left_over.gif';	
		if(this.src.indexOf('right')>=0)this.src = pathToImages + 'right_over.gif';	
	}
}

function highlightClose()
{
	if(this.src.indexOf('over')>=0){
		this.src = pathToImages + 'close.gif';
	}else{
		this.src = pathToImages + 'close_over.gif';	
	}	
}

function closeCalendar(){

	document.getElementById('yearDropDown').style.display='none';
	document.getElementById('monthDropDown').style.display='none';
	calendarDiv.style.display='none';
	if(iframeObj){
		iframeObj.style.display='none';
		 //// //// fix for EI frame problem on time dropdowns 09/30/2006
			EIS_Hide_Frame();}
	if(activeSelectBoxMonth)activeSelectBoxMonth.className='';
	if(activeSelectBoxYear)activeSelectBoxYear.className='';
	if(selectA != undefined && selectB != undefined)
	{
		var IE=(window.navigator.userAgent.indexOf('MSIE')>-1)?1:0;
		if(ffcontrol != undefined && ffcontrol == 1)
		{
			document.getElementById(selectA).style.display = (document.getElementById(selectA).style.display=='none')?((IE)?'block':'table-row'):'none';
			//document.getElementById(selectA).style.display = 'table-row';
			document.getElementById(selectB).style.display = (document.getElementById(selectB).style.display=='none')?((IE)?'block':'table-row'):'none';
			//document.getElementById(selectB).style.display = 'table-row';
		}else
		{
			document.getElementById(selectA).style.display = 'block';
			document.getElementById(selectB).style.display = 'block';
		}
	}else if(selectA != undefined)
	{
		if(ffcontrol != undefined && ffcontrol == 1)
		{
			document.getElementById(selectA).style.display = (document.getElementById(selectA).style.display=='none')?((IE)?'block':'table-row'):'none';
			//document.getElementById(selectA).style.display = 'table-row';
		}else
		{
			document.getElementById(selectA).style.display = 'block';
		}
	}
}

function writeTopBar()
{
	var topBar = document.createElement('DIV');
	topBar.className = 'topBar';
	topBar.id = 'topBar';
	calendarDiv.appendChild(topBar);
	// Left arrow
	var leftDiv = document.createElement('DIV');
	leftDiv.style.marginRight = '1px';
	var img = document.createElement('IMG');
	img.src = pathToImages + 'left.gif';
	img.onmouseover = highlightArrow;
	img.onclick = switchMonth;
	img.onmouseout = highlightArrow;
	leftDiv.appendChild(img);	
	topBar.appendChild(leftDiv);
	if(Opera)leftDiv.style.width = '16px';
	// Right arrow
	var rightDiv = document.createElement('DIV');
	rightDiv.style.marginRight = '1px';
	var img = document.createElement('IMG');
	img.src = pathToImages + 'right.gif';
	img.onclick = switchMonth;
	img.onmouseover = highlightArrow;
	img.onmouseout = highlightArrow;
	rightDiv.appendChild(img);
	if(Opera)rightDiv.style.width = '16px';
	topBar.appendChild(rightDiv);		
	// Month selector
	var monthDiv = document.createElement('DIV');
	monthDiv.id = 'monthSelect';
	monthDiv.onmouseover = highlightSelect;
	monthDiv.onmouseout = highlightSelect;
	monthDiv.onclick = showMonthDropDown;
	var span = document.createElement('SPAN');
	span.innerHTML = monthArray[currentMonth];
	span.id = 'calendar_month_txt';
	monthDiv.appendChild(span);
	var img = document.createElement('IMG');
	img.src = pathToImages + 'down.gif';
	img.style.position = 'absolute';
	img.style.right = '0px';
	monthDiv.appendChild(img);
	monthDiv.className = 'selectBox';
	topBar.appendChild(monthDiv);
	var monthPicker = createMonthDiv();
	monthPicker.style.left = '37px';
	monthPicker.style.top = monthDiv.offsetTop + monthDiv.offsetHeight + 1 + 'px';
	monthPicker.style.width ='60px';
	monthPicker.id = 'monthDropDown';
	calendarDiv.appendChild(monthPicker);
	// Year selector
	var yearDiv = document.createElement('DIV');
	yearDiv.style.paddingTop = '0px';
	if((document.all || safari) && !Opera)
	{
		yearDiv.style.paddingBottom = '0px';
	}
	yearDiv.onmouseover = highlightSelect;
	yearDiv.onmouseout = highlightSelect;
	yearDiv.onclick = showYearDropDown;
	var span = document.createElement('SPAN');
	span.innerHTML = currentYear;
	span.id = 'calendar_year_txt';
	yearDiv.appendChild(span);
	var img = document.createElement('IMG');
	img.src = pathToImages + 'down.gif';
	yearDiv.appendChild(img);
	yearDiv.className = 'selectBox';
	topBar.appendChild(yearDiv);
	var yearPicker = createYearDiv();
	yearPicker.style.left = '113px';
	yearPicker.style.top = monthDiv.offsetTop + monthDiv.offsetHeight + 1 + 'px';
	yearPicker.style.width = '35px';
	yearPicker.id = 'yearDropDown';
	calendarDiv.appendChild(yearPicker);
	var img = document.createElement('IMG');
	img.src = pathToImages + 'close.gif';
	img.style.styleFloat = 'right';
	img.onmouseover = highlightClose;
	img.onmouseout = highlightClose;
	img.onclick = closeCalendar;
	topBar.appendChild(img);
	if(!document.all){
		img.style.position = 'absolute';
		img.style.right = '2px';
	}
}

function writeCalendarContent()
{
	var calendarContentDivExists = true;
	if(!calendarContentDiv){
		calendarContentDiv = document.createElement('DIV');
		calendarDiv.appendChild(calendarContentDiv);
		calendarContentDivExists = false;
	}
	var d = new Date();
	var day = d.getDate();
	d.setFullYear(actualYear);
	d.setDate(1);
	d.setMonth(actualMonth);
	var dayStartOfMonth = d.getDay();
	if(dayStartOfMonth==0)dayStartOfMonth=7;
	dayStartOfMonth--;
	document.getElementById('calendar_year_txt').innerHTML = actualYear;
	document.getElementById('calendar_month_txt').innerHTML = monthArray[actualMonth];
	var existingTable = calendarContentDiv.getElementsByTagName('TABLE');
	if(existingTable.length>0){
		calendarContentDiv.removeChild(existingTable[0]);
	}
	var calTable = document.createElement('TABLE');
	calTable.width = '100%';
	calTable.cellSpacing = '0';
	calendarContentDiv.appendChild(calTable);
	var calTBody = document.createElement('TBODY');
	calTable.appendChild(calTBody);
	var row = calTBody.insertRow(-1);
	for(var no=0;no<dayArray.length;no++){
		var cell = row.insertCell(-1);
		cell.className = 'dayOfWeek';
		cell.innerHTML = dayArray[no];
	}
	var row = calTBody.insertRow(-1);
	for(var no=0;no<dayStartOfMonth;no++){
		var cell = row.insertCell(-1);
		cell.innerHTML = '&nbsp;';
	}
	var colCounter = dayStartOfMonth;
	var daysInMonth = daysInMonthArray[actualMonth];
	if(daysInMonth==28){
		if(isLeapYear(actualYear))daysInMonth=29;
	}
	for(var no=1;no<=daysInMonth;no++){
		d.setDate(no/1-1);
		if(colCounter>0 && colCounter%7==0){
			var row = calTBody.insertRow(-1);
		}
		var cell = row.insertCell(-1);
		if(no < day && actualMonth == firstMonth && actualYear == firstYear)
		{
			cell.className='disactiveDay';
			cell.innerHTML = no;
		}else
		{
			if(allDay)
			{
				cell.className='disactiveDay';
				cell.innerHTML = no;
			}else
			{
				if(actualYear == currentYear && actualMonth == currentMonth && no == currentDay && utente){
					cell.className='activeDay';
				}else
				{
					cell.onmouseover = function() { this.className='overDay';}
					cell.onmouseout = function() { this.className='';}
				}
				cell.innerHTML = no;
				cell.onclick = pickDate;
			}
		}
		colCounter++;
	}
	if(iframeObj){
		if(!calendarContentDivExists)setTimeout('resizeIframe()',350);else setTimeout('resizeIframe()',10);
	}
}

function resizeIframe()
{
	iframeObj.style.width = calendarDiv.offsetWidth + 'px';
	iframeObj.style.height = calendarDiv.offsetHeight + 'px' ;
}

function pickDate(e)
{
	var month = actualMonth/1 +1;
	if(month<10)month = '0' + month;
	var day = this.innerHTML;
	if(day/1<10)day = '0' + day;
		returnFormat = returnFormat.replace('dd',day);
		returnFormat = returnFormat.replace('mm',month);
		returnFormat = returnFormat.replace('yyyy',actualYear);
		returnFormat = returnFormat.replace('d',day/1);
		returnFormat = returnFormat.replace('m',month/1);
		returnDateTo.value = returnFormat;
		try{
			returnDateTo.onchange();
		}catch(e){
		}
	utente = true;
	closeCalendar();
}

function getTopPos(inputObj)
{
  var returnValue = inputObj.offsetTop + inputObj.offsetHeight;
  while((inputObj = inputObj.offsetParent) != null)returnValue += inputObj.offsetTop;
  return returnValue + calendar_offsetTop;
}

function getleftPos(inputObj)
{
  var returnValue = inputObj.offsetLeft;
  while((inputObj = inputObj.offsetParent) != null)returnValue += inputObj.offsetLeft;
  return returnValue + calendar_offsetLeft;
}

function positionCalendar(inputObj)
{
	var left = getleftPos(inputObj);
	var top = getTopPos(inputObj);
	var maxWidth;
	switch (screen.availWidth)
	{
		case 800:
			maxWidth = 900;
			break;
		case 1024:
			maxWidth = 955;
			break;
		case 1280:
			maxWidth = 1082;
			break;
		default:
			maxWidth = 955;
			break;
	}
	if(left + 177 > maxWidth)
	{
		if(Opera)
		{
			left = (maxWidth - 180 - 18);
		}else
		{
			if(document.all && !Opera)
			{
				left = (maxWidth - 184);
			}else
			{
				left = (maxWidth - 182);
			}
		}
		calendarDiv.style.left = left + 'px';
		calendarDiv.style.top = top + 1 + 'px';
	}else
	{
		calendarDiv.style.left = left + 'px';
		calendarDiv.style.top = top + 1 + 'px';
	}
	if(iframeObj){
		iframeObj.style.left = calendarDiv.style.left;
		iframeObj.style.top =  calendarDiv.style.top;
		//// fix for EI frame problem on time dropdowns 09/30/2006
		iframeObj2.style.left = calendarDiv.style.left;
		iframeObj2.style.top =  calendarDiv.style.top;
	}
}
	
function initCalendar()
{
	if(MSIE){
		iframeObj = document.createElement('IFRAME');
		iframeObj.style.filter = 'alpha(opacity=0)';
		iframeObj.style.position = 'absolute';
		iframeObj.border='0px';
		iframeObj.style.border = '0px';
		iframeObj.style.backgroundColor = '#FF0000';
		//// fix for EI frame problem on time dropdowns 09/30/2006
		iframeObj2 = document.createElement('IFRAME');
		iframeObj2.style.position = 'absolute';
		iframeObj2.border='0px';
		iframeObj2.style.border = '0px';
		iframeObj2.style.height = '1px';
		iframeObj2.style.width = '1px';
		document.body.appendChild(iframeObj2);
		document.body.appendChild(iframeObj);
	}
	calendarDiv = document.createElement('DIV');	
	calendarDiv.id = 'calendarDiv';
	calendarDiv.style.zIndex = 1000;
	if(Opera)
	{
		calendarDiv.style.width = 190 + 'px';
	}
	slideCalendarSelectBox();
	document.body.appendChild(calendarDiv);	
	writeTopBar();
	writeCalendarContent();	
}

function calendarSortItems(a,b)
{
	return a/1 - b/1;
}

var utente = true;
var firstMonth;
var firstYear;
var firstDay;
var selectA;
var selectB;
var ffcontrol;

function displayCalendar(inputField,format,buttonObj,lan,select1,select2,ff)
{
	if(select1 != undefined && select2 != undefined)
	{
		selectA = select1;
		selectB = select2;
		document.getElementById(selectA).style.display = 'none';
		document.getElementById(selectB).style.display = 'none';
		if(ff != undefined)
		{
			ffcontrol = ff;
		}
	}else if(select1 != undefined)
	{
		selectA = select1;
		document.getElementById(selectA).style.display = 'none';
		if(ff != undefined)
		{
			ffcontrol = ff;
		}
	}
	language(lan);
	if(inputField.value.length>0){
		if(!format.match(/^[0-9]*?$/gi)){
			var items = inputField.value.split(/[^0-9]/gi);
			var positionArray = new Array();
			positionArray['d'] = format.indexOf('dd');
			if(positionArray['d']==-1)positionArray['d'] = format.indexOf('d');
			positionArray['m'] = format.indexOf('mm');
			if(positionArray['m']==-1)positionArray['m'] = format.indexOf('m');
			positionArray['y'] = format.indexOf('yyyy');
			var positionArrayNumeric = Array();
			positionArrayNumeric[0] = positionArray['d'];
			positionArrayNumeric[1] = positionArray['m'];
			positionArrayNumeric[2] = positionArray['y'];
			positionArrayNumeric = positionArrayNumeric.sort(calendarSortItems);
			var itemIndex = -1;
			for(var no=0;no<positionArrayNumeric.length;no++){
				if(positionArrayNumeric[no]==-1)continue;
				itemIndex++;
				if(positionArrayNumeric[no]==positionArray['d']){
					//tmpDay = items[itemIndex];
					currentDay = items[itemIndex];
					continue;
				}	
				if(positionArrayNumeric[no]==positionArray['m']){
					currentMonth = items[itemIndex]-1;
					continue;
				}
				if(positionArrayNumeric[no]==positionArray['y']){
					currentYear = items[itemIndex];
					continue;
				}	
			}
			currentMonth = currentMonth / 1;
			currentDay = currentDay / 1;
		}else{		
			var dayPos = format.indexOf('dd');
			currentDay = inputField.value.substr(dayPos,2)/1;
			var monthPos = format.indexOf('mm');
			currentMonth = inputField.value.substr(monthPos,2)/1 -1;
			var yearPos = format.indexOf('yyyy');
			currentYear = inputField.value.substr(yearPos,4)/1;
		}
	}
	var d = new Date();
	firstMonth = d.getMonth();
	firstYear = d.getFullYear();
	firstDay = d.getDate();
	if(document.all)
	{
		if(isNaN(currentMonth) || currentMonth == -1)
		{
			currentMonth = firstMonth/1;
			currentYear = firstYear/1;
			currentDay = firstDay/1;
			actualYear = firstYear/1;
			actualMonth = firstMonth/1;
			utente = false;
		}
		if(Opera)
		{
			if(currentMonth == -1)
			{
				currentMonth = firstMonth/1;
				currentYear = firstYear/1;
				currentDay = firstDay/1;
				actualYear = firstYear/1;
				actualMonth = firstMonth/1;
				utente = false;
			}
		}
		if(!isNaN(currentMonth) || currentMonth == -1)
		{
			actualYear = currentYear/1;
			actualMonth = currentMonth/1;
		}
	}else
	{
		if(currentMonth == -1)
		{
			currentMonth = firstMonth/1;
			currentYear = firstYear/1;
			currentDay = firstDay/1;
			actualYear = firstYear/1;
			actualMonth = firstMonth/1;
			utente = false;
		}else
		{
			actualYear = currentYear/1;
			actualMonth = currentMonth/1;
		}
	}
	if(!calendarDiv){
		initCalendar();			
	}else{
		if(calendarDiv.style.display=='block'){
			closeCalendar();
			return false;
		}
		writeCalendarContent();
	}
	returnFormat = format;
	returnDateTo = inputField;
	positionCalendar(buttonObj);
	calendarDiv.style.visibility = 'visible';	
	calendarDiv.style.display = 'block';	
	if(iframeObj){
		iframeObj.style.display = '';
		iframeObj.style.width = '175px';
		iframeObj2.style.display = '';
		iframeObj2.style.width = '175px';
	}
	updateYearDiv();
	updateMonthDiv();
}

function displayCalendarEnd(inputValue,inputField,format,buttonObj,lan,select1,select2,ff)
{
	if(inputValue == 'yyyy-mm-dd' || inputValue == 'aaaa-mm-gg' || inputValue == 'aaaa-mm-jj' || inputValue == 'yyyy-mm-tt')
	{
		displayCalendar(inputField,format,buttonObj,lan,select1,select2);
	}else
	{
		if(select1 != undefined && select2 != undefined)
		{
			selectA = select1;
			selectB = select2
			document.getElementById(selectA).style.display = 'none';
			document.getElementById(selectB).style.display = 'none';
			if(ff != undefined)
			{
				ffcontrol = ff;
			}
		}else if(select1 != undefined)
		{
			selectA = select1;
			document.getElementById(selectA).style.display = 'none';
			if(ff != undefined)
			{
				ffcontrol = ff;
			}
		}
		language(lan);
		
		var dayPos = format.indexOf('dd');
		currentDay = inputValue.substr(dayPos,2)/1 + 1;
		
		var monthPos = format.indexOf('mm');
		currentMonth = inputValue.substr(monthPos,2)/1 -1;
		
		var yearPos = format.indexOf('yyyy');
		currentYear = inputValue.substr(yearPos,4)/1;
		
		if(currentDay > daysInMonthArray[currentMonth])
		{
			if(currentMonth == 1 && currentYear % 4 == 0)
			{
				if(currentDay != 29)
				{
					currentDay = 1;
					currentMonth++;
				}
			}else
			{
				currentDay = 1;
				currentMonth++;
				if(currentMonth == 12)
				{
					currentMonth = 0;
					currentYear++;
				}
			}
		}
		
		var d = new Date();
		firstMonth = d.getMonth();
		firstYear = d.getFullYear();
		firstDay = d.getDate();
		if(document.all)
		{
			if(isNaN(currentMonth) || currentMonth == -1)
			{
				currentMonth = firstMonth/1;
				currentYear = firstYear/1;
				currentDay = firstDay/1;
				actualYear = firstYear/1;
				actualMonth = firstMonth/1;
				utente = false;
			}
			if(Opera)
			{
				if(currentMonth == -1)
				{
					currentMonth = firstMonth/1;
					currentYear = firstYear/1;
					currentDay = firstDay/1;
					actualYear = firstYear/1;
					actualMonth = firstMonth/1;
					utente = false;
				}
			}
			if(!isNaN(currentMonth) || currentMonth == -1)
			{
				actualYear = currentYear/1;
				actualMonth = currentMonth/1;
			}
		}else
		{
			if(currentMonth == -1)
			{
				currentMonth = firstMonth/1;
				currentYear = firstYear/1;
				currentDay = firstDay/1;
				actualYear = firstYear/1;
				actualMonth = firstMonth/1;
				utente = false;
			}else
			{
				actualYear = currentYear/1;
				actualMonth = currentMonth/1;
			}
		}
		if(!calendarDiv){
			initCalendar();			
		}else{
			if(calendarDiv.style.display=='block'){
				closeCalendar();
				return false;
			}
			writeCalendarContent();
		}
		returnFormat = format;
		returnDateTo = inputField;
		positionCalendar(buttonObj);
		calendarDiv.style.visibility = 'visible';	
		calendarDiv.style.display = 'block';	
		if(iframeObj){
			iframeObj.style.display = '';
			iframeObj.style.width = '175px';
			iframeObj2.style.display = '';
			iframeObj2.style.width = '175px';
		}
		updateYearDiv();
		updateMonthDiv();
	}
}
