var gdCtrl = new Object();
var goSelectTag = new Array();
var gcGray = "#808080";
var gcToggle = "#ffff00";
var gcBG = "#cccccc";
var gdCurDate = new Date();
var giYear = gdCurDate.getFullYear();
var giMonth = gdCurDate.getMonth()+1;
var giDay = gdCurDate.getDate();
var gMonths = new Array("January","February","March","April","May","June","July","August","September","October","November","December");

function fSetDate(iYear, iMonth, iDay)
{
	VicPopCal.style.visibility = "hidden";
	//Here, you could modify the locale as you need !!!!
	gdCtrl.value = iMonth+"/"+iDay+"/"+iYear; 
	for (i in goSelectTag)
	{
		goSelectTag[i].style.visibility = "visible";
	}
	goSelectTag.length = 0;
}

function fSetSelected(aCell)
{
//	alert(aCell.innerText);
	var iOffset = 0;
	var iYear = parseInt(tbSelYear.value);
	var iMonth = parseInt(tbSelMonth.value);
	self.event.cancelBubble = true;
	aCell.bgColor = gcBG;
	with(aCell)
	{
		var iDay = parseInt(innerText);
	}
	fSetDate(iYear, iMonth, iDay);
}

function Point(iX, iY)
{
	this.x = iX;
	this.y = iY;
}

function fBuildCal(iYear, iMonth) 
{
	var aMonth=new Array();
	for(var i=1;i<7;i++)
	{
		aMonth[i]=new Array(i);
	}
	var dCalDate=new Date(iYear, iMonth-1, 1);
	var iDayOfFirst=dCalDate.getDay();
	var iDaysInMonth=new Date(iYear, iMonth, 0).getDate();
	var iOffsetLast=new Date(iYear, iMonth-1, 0).getDate()-iDayOfFirst+1;
	var iDate = 1;
	var iNext = 1;
	for (d = 0; d < 7; d++)
	{
		if(d<iDayOfFirst)
		{
			aMonth[1][d]="";
		}
		else
		{
			aMonth[1][d]=iDate++;
		}
	}
	for (w = 2; w < 7; w++)
	{
		for (d = 0; d < 7; d++)
		{
			if(iDate<=iDaysInMonth)
			{
				aMonth[w][d]=iDate++;
			}
			else
			{
				aMonth[w][d]="";
			}
		}
	}
	return aMonth;
}

function fDrawCal(iYear, iMonth, iCellHeight, iDateTextSize) 
{
	var WeekDay = new Array("Sun","Mon","Tue","Wed","Thu","Fri","Sat");
	with (document) 
	{
		write("<tr>");
		for(i=0; i<7; i++)
		{
			write("<td><div class=cldiv0>"+WeekDay[i]+"</div></td>");
		}
		write("</tr>");
		for (w = 1; w < 7; w++) 
		{
			write("<tr>");
			for (d = 0; d < 7; d++) 
			{
				write("<td class='bld' id='calCell'>");
				write("<div id='cellText'></div>");
				write("</td>")
			}
			write("</tr>");
		}
	}
}

function fUpdateCal(iYear, iMonth, slDate) 
{
	myMonth = fBuildCal(iYear, iMonth);
	var i = 0;
	for (w = 0; w < 6; w++)
	{
		for (d = 0; d < 7; d++)
		{
			with (cellText[(7*w)+d]) 
			{
				Victor = i++;
				cellText[(7*w)+d].innerHTML = "<div></div>";
				if(myMonth[w+1][d]!="")
				{
					//if(d==0 && myMonth[w+1][d]!=giDay)
					if(d==0 && myMonth[w+1][d]!=slDate && myMonth[w+1][d]!=giDay)
					{
						var st = "<div class='cldiv2' onclick='fSetSelected(this)'>"+myMonth[w+1][d]+"</div>";
					}
					else if(myMonth[w+1][d]==giDay)
					{
						var st = "<div class='cldiv3' onclick='fSetSelected(this)'>"+myMonth[w+1][d]+"</div>";
					}
					else if(myMonth[w+1][d]==slDate && slDate!=0)
					{
						var st = "<div class='cldiv4' onclick='fSetSelected(this)'>"+myMonth[w+1][d]+"</div>";
					}
					else
					{
						var st = "<div class='cldiv1' onclick='fSetSelected(this)'>"+myMonth[w+1][d]+"</div>";
					}
					cellText[(7*w)+d].innerHTML = st;
					//cellText[(7*w)+d].innerHTML = st+""+myMonth[w+1][d]+"</div>"
				}
			}
		}
	}
}

function fSetYearMon(iYear, iMon)
{
	tbSelMonth.options[iMon-1].selected = true;
	for (i = 0; i < tbSelYear.length; i++)
	{
		if (tbSelYear.options[i].value == iYear)
		{
			tbSelYear.options[i].selected = true;
		}
	}
  fUpdateCal(iYear, iMon, 0);
}

function fSetYearMonDate(iYear, iMon, slDate)
{
	tbSelMonth.options[iMon-1].selected = true;
	for (k = 0; k < tbSelYear.length; k++)
	{
		if (tbSelYear.options[k].value == iYear)
		{
			tbSelYear.options[k].selected = true;
		}
	}
  fUpdateCal(iYear, iMon, slDate);
}

function fPrevMonth()
{
	var iMon = tbSelMonth.value;
	var iYear = tbSelYear.value;
	if (--iMon<1) 
	{
		iMon = 12;
		iYear--;
	}
	fSetYearMon(iYear, iMon);
}

function fNextMonth()
{
	var iMon = tbSelMonth.value;
	var iYear = tbSelYear.value;
	if (++iMon>12) 
	{
		iMon = 1;
		iYear++;
	}
	fSetYearMon(iYear, iMon);
}

function fToggleTags()
{
	with (document.all.tags("SELECT"))
	{
		for (i=0; i<length; i++)
		{
			if ((item(i).Victor!="Won")&&fTagInBound(item(i)))
			{
				item(i).style.visibility = "hidden";
				goSelectTag[goSelectTag.length] = item(i);
			}
		}
	}
}

function fTagInBound(aTag)
{
	with (VicPopCal.style)
	{
		var l = parseInt(left);
		var t = parseInt(top);
		var r = l+parseInt(width);
		var b = t+parseInt(height);
		var ptLT = fGetXY(aTag);
		return !((ptLT.x>r)||(ptLT.x+aTag.offsetWidth<l)||(ptLT.y>b)||(ptLT.y+aTag.offsetHeight<t));
	}
}

function fGetXY(aTag)
{
	var oTmp = aTag;
	var pt = new Point(0,0);
	do 
	{
		pt.x += oTmp.offsetLeft;
		pt.y += oTmp.offsetTop;
		oTmp = oTmp.offsetParent;
	} 
	while(oTmp.tagName!="BODY");
	return pt;
}

function fPopCalendar(popCtrl)
{
	gdCtrl = popCtrl;
	if(popCtrl.value==null || popCtrl.value=='')
	{
		fSetYearMon(giYear, giMonth);
	}
	else
	{
		var pval = popCtrl.value;
		pv = pval.split("/");
		//alert(pv[0]);
		fSetYearMonDate(pv[2], pv[0], pv[1]);
	}
	var point = fGetXY(popCtrl);
	with (VicPopCal.style) 
	{
		left = point.x;
		top  = point.y+popCtrl.offsetHeight+1;
		width = VicPopCal.offsetWidth;
		height = VicPopCal.offsetHeight;
		fToggleTags(point);
		visibility = 'visible';
	}
	VicPopCal.focus();
}

function fHideCal()
{
	var oE = window.event;
	if ((oE.clientX>0)&&(oE.clientY>0)&&(oE.clientX<document.body.clientWidth)&&(oE.clientY<document.body.clientHeight)) 
	{
		var oTmp = document.elementFromPoint(oE.clientX,oE.clientY);
		while ((oTmp.tagName!="BODY") && (oTmp.id!="VicPopCal"))
		{
			oTmp = oTmp.offsetParent;
		}
		if (oTmp.id=="VicPopCal")
			return;
	}
	VicPopCal.style.visibility = 'hidden';
	for (i in goSelectTag)
	{
		goSelectTag[i].style.visibility = "visible";
	}
	goSelectTag.length = 0;
}

with (document) 
{
	write("<Div id='VicPopCal' onblur='fHideCal()' onclick='focus()' style='POSITION:absolute;visibility:hidden;border:1px solid;background:white'>");
	write("<table border='0' cellpadding=1 cellspacing=1>");
	write("<TR>");
	write("<td>");
	write("<table border='0' cellpadding=2 cellspacing=1>");
	write("<tr><td><SELECT class='clst' name='tbSelYear' onChange='fUpdateCal(tbSelYear.value, tbSelMonth.value, 0)' Victor='Won' onclick='self.event.cancelBubble=true' onblur='fHideCal()'>");
	for(i=1940;i<=giYear;i++)
	{
		write("<OPTION value='"+i+"'>&nbsp;&nbsp;"+i+"&nbsp;&nbsp;</OPTION>");
	}
	write("</SELECT></td><td align=right>");
	write("<select class='clst' name='tbSelMonth' onChange='fUpdateCal(tbSelYear.value, tbSelMonth.value, 0)' Victor='Won' onclick='self.event.cancelBubble=true' onblur='fHideCal()'>");
	for (i=0; i<12; i++)
	{
		write("<option value='"+(i+1)+"'>"+gMonths[i]+"</option>");
	}
	write("</SELECT></td>");
	write("</tr></table>");
	write("</td>");
	write("</TR><TR>");
	write("<td align='center'>");
	write("<DIV><table width='100%' border='0'cellpadding=1 cellspacing=1>");
	fDrawCal(giYear, giMonth, 18, 16);
	write("</table></DIV>");
	write("</td>");
	write("</TR>");
	write("</TD></TR>");
	write("</TABLE></Div>");
}
