﻿// Copyright (c) 2004. Interfax-CNA.  All rights reserved.

var enablePast = 0;		// 0 - disabled ; 1 - enabled
var fixedX = -1;		// x position (-1 if to appear below control)
var fixedY = -1;		// y position (-1 if to appear below control)
var startAt = 1;		// 0 - sunday ; 1 - monday
var showWeekNumber = 0;	// 0 - don't show; 1 - show
var showToday = 1;		// 0 - don't show; 1 - show
var imgDir = '';	// directory for images ... e.g. var imgDir="/Images/"
var AppPath = '';
var dayName = '';

var gotoString = 'Go To Current Month';
var todayString = 'Today is';
var weekString = 'Wk';
var scrollLeftMessage = 'Click to scroll to previous month. Hold mouse button to scroll automatically.';
var scrollRightMessage = 'Click to scroll to next month. Hold mouse button to scroll automatically.';
var selectMonthMessage = 'Click to select a month.';
var selectYearMessage = 'Click to select a year.';
var selectDateMessage = 'Select [date] as date.';		
var	monthName = new Array('January','February','March','April','May','June','July','August','September','October','November','December');
var	monthName2 = new Array('JAN','FEB','MAR','APR','MAY','JUN','JUL','AUG','SEP','OCT','NOV','DEC');
var selectHideElements = null;

var crossobj, crossMonthObj, crossYearObj, monthSelected, yearSelected, dateSelected, omonthSelected, oyearSelected, odateSelected, monthConstructed, yearConstructed, intervalID1, intervalID2, timeoutID1, timeoutID2, ctlToPlaceValue, ctlNow, dateFormat, nStartingYear, selDayAction, isPast;
var imgsrc   = new Array(imgDir + 'drop1.gif', imgDir + 'drop2.gif', imgDir + 'left1.gif', imgDir + 'left2.gif', imgDir + 'right1.gif', imgDir + 'right2.gif');
var img      = new Array();
var visYear  = 0;
var visMonth = 0;
var bPageLoaded = false;
var ie  = document.all;
var dom = document.getElementById;
var ns4 = document.layers;
var today    = new Date();
var dateNow  = today.getDate();
var monthNow = today.getMonth();
var yearNow  = today.getYear();
var bShow    = false;

function InitializeCalendar(appPath)
{
    AppPath = appPath;
}

function prepareCalendar()
{
    if ((AppPath != '') && (imgDir != ''))
    {
        imgDir = AppPath + imgDir;
    }
}

function showPopUpCalendar(textBox, dX, dY)
{
    prepareCalendar();
       
    //selectHideElements = null;

	objParent = textBox.offsetParent;
    objLeft = textBox.offsetLeft;
    objTop = textBox.offsetTop;

	while(objParent.tagName.toUpperCase() != 'BODY')
	{
		objLeft  += objParent.offsetLeft;
		objTop   += objParent.offsetTop;
		objParent = objParent.offsetParent;
	}
	
    if (!IsResSetup())
	{
       	if (curLang == ruLang)
        {
       	    SetResources('Перейти к текущему месяцу', 
	                     'Сегодня', 
	                     'Нд', 
	                     'Предыдущей месяц. Держите кнопку мыши чтобы переходить автоматически.', 
	                     'Следующий месяц. Держите кнопку мыши чтобы переходить автоматически.',
	                     'Выбрать месяц',
	                     'Выбрать год',
	                     'Выбрать [date] дату.',
	                     new Array('Январь','Февраль','Март','Апрель','Май','Июнь','Июль','Август','Сентябрь','Октябрь','Ноябрь','Декабрь'),
	                     new Array('ЯНВ','ФЕВ','МАР','АПР','МАЙ','ИЮН','ИЮЛ','АВГ','СЕН','ОКТ','НОЯ','ДЕК'),
	                     new Array('Пн','Вт','Ср','Чт','Пт','Сб','Вс'),
	                     1 
	                    )
	    }
	    else
	    {
       	    SetResources(gotoString, 
	                     todayString, 
	                     weekString, 
	                     scrollLeftMessage, 
	                     scrollRightMessage,
	                     selectMonthMessage,
	                     selectYearMessage,
	                     selectDateMessage,
	                     monthName,
	                     monthName2,
	                     new Array('Mon','Tue','Wed','Thu','Fri','Sat','Sun'),
	                     1 
	                    )
	    } 
 	}

    showCalendar(textBox, textBox, 'dd.mm.yyyy', 1, objLeft + dX, objTop + dY);
}

function showPopUpCalendarExt(textBox, dX, dY, selectElements)
{
    showPopUpCalendar(textBox, dX, dY);
    setTimeout('hideElements(selectHideElements)', 0);
    selectHideElements = selectElements;
}

if (startAt == 0)
{
    dayName = new Array('Sun','Mon','Tue','Wed','Thu','Fri','Sat');
}
else
{
    dayName = new Array('Mon','Tue','Wed','Thu','Fri','Sat','Sun');
}

var IsResSetupFlag = false;
function IsResSetup() 
{
    return IsResSetupFlag;
}
    
function SetResources(
                  _gotoString, 
                  _todayString, 
                  _weekString, 
                  _scrollLeftMessage, 
                  _scrollRightMessage,
                  _selectMonthMessage,
                  _selectYearMessage,
                  _selectDateMessage,
                  _monthNameArray,
                  _monthNameArray2,
                  _dayNameArray,
                  _startAt 
             ) 
{
    gotoString = _gotoString;
    todayString = _todayString;
    weekString = _weekString;
    scrollLeftMessage = _scrollLeftMessage;
    scrollRightMessage = _scrollRightMessage;
    selectMonthMessage = _selectMonthMessage;
    selectYearMessage = _selectYearMessage;
    selectDateMessage = _selectDateMessage;
    monthName = _monthNameArray;
    monthName2 = _monthNameArray2;
    dayName = _dayNameArray;
    startAt = _startAt;
    IsResSetupFlag = true;
    init();
}

function HolidayRec(d, m, y, desc) 
{
    this.d = d;
    this.m = m;
    this.y = y;
    this.desc = desc;
}

var HolidaysCounter = 0;
var Holidays = new Array();

function addHoliday (d, m, y, desc) 
{
    Holidays[HolidaysCounter++] = new HolidayRec (d, m, y, desc);
}

if (dom) 
{
    for	(i=0;i<imgsrc.length;i++) 
    {
        img[i] = new Image;
        img[i].src = imgDir + imgsrc[i];
    }

    document.write ('<div onclick="bShow=true" id="calendar" style="z-index:+999;position:absolute;visibility:hidden;"><table cellspacing="1" cellpadding="0" style="width:'+((showWeekNumber==1)?250:220)+'" width="'+((showWeekNumber==1)?250:220)+'px" style="font-family:Arial;font-size:11px;border: 1px solid #cfaf7a;" bgcolor="White"><tr bgcolor="#cfaf7a" height="24"><td><table style="width:'+((showWeekNumber==1)?248:218)+'" width="'+((showWeekNumber==1)?248:218)+'px"><tr><td style="padding:2px;font-family:Tahoma;font-size:11px;"><font color="White' + '' /*C9D3E9*/ +'"><b><span id="caption"></span></b></font></td><td align="right"><a href="javascript:hideCalendar()"><img src="'+imgDir+'Images/close.gif" width="17" height="17" border="0" id="closeCalendarImage" /></a></td></tr></table></td></tr><tr><td style="padding:5px" bgcolor="White">'+AppPath+'<span id="content"></span></td></tr>');

    if (showToday == 1) 
    {
        document.write ('<tr bgcolor="#f0f0f0"><td style="padding:5px" align="center"><span id="lblToday"></span></td></tr>');
    }
	
    document.write ('</table></div><div id="selectMonth" style="z-index:+999;position:absolute;visibility:hidden;"></div><div id="selectYear" style="z-index:+999;position:absolute;visibility:hidden;"></div>');
}

var	styleAnchor = 'text-decoration:none;color:black;';
var	styleLightBorder = 'border:1px solid #ffffff;';

function swapImage(srcImg, destImg) 
{
    if (ie)
    {
        document.getElementById(srcImg).setAttribute('src',imgDir + destImg);
    }
}

function init() 
{
    if (!ns4)
    {
        if (!ie) yearNow += 1900;

        crossobj=(dom)?document.getElementById('calendar').style : ie? document.all.calendar : document.calendar;
        hideCalendar();

        crossMonthObj = (dom) ? document.getElementById('selectMonth').style : ie ? document.all.selectMonth : document.selectMonth;

        crossYearObj = (dom) ? document.getElementById('selectYear').style : ie ? document.all.selectYear : document.selectYear;

        monthConstructed = false;
        yearConstructed = false;

        if (showToday == 1) 
        {
            document.getElementById('lblToday').innerHTML =	'<font color="#000000">' + todayString + ' <a onmousemove="window.status=\''+gotoString+'\'" onmouseout="window.status=\'\'" title="'+gotoString+'" style="'+styleAnchor+'" href="javascript:monthSelected=monthNow;yearSelected=yearNow;constructCalendar();">'+dayName[(today.getDay()-startAt==-1)?6:(today.getDay()-startAt)]+', ' + dateNow + ' ' + monthName[monthNow].substring(0,3) + ' ' + yearNow + '</a></font>';
        }

        sHTML1 = '<span id="spanLeft" style="border:1px solid #cfaf7a;cursor:pointer" onmouseover="swapImage(\'changeLeft\',\'Images/left2.gif\');this.style.borderColor=\'#cfaf7a\';window.status=\''+scrollLeftMessage+'\'" onclick="decMonth()" onmouseout="clearInterval(intervalID1);swapImage(\'changeLeft\',\'Images/left1.gif\');this.style.borderColor=\'#cfaf7a\';window.status=\'\'" onmousedown="clearTimeout(timeoutID1);timeoutID1=setTimeout(\'StartDecMonth()\',500)" onmouseup="clearTimeout(timeoutID1);clearInterval(intervalID1)">&nbsp<img id="changeLeft" src="'+imgDir+'Images/left1.gif" width="10" height="11" border="0">&nbsp</span>&nbsp;';
        sHTML1 += '<span id="spanRight" style="border:1px solid #cfaf7a;cursor:pointer" onmouseover="swapImage(\'changeRight\',\'Images/right2.gif\');this.style.borderColor=\'#cfaf7a\';window.status=\''+scrollRightMessage+'\'" onmouseout="clearInterval(intervalID1);swapImage(\'changeRight\',\'Images/right1.gif\');this.style.borderColor=\'#cfaf7a\';window.status=\'\'" onclick="incMonth()" onmousedown="clearTimeout(timeoutID1);timeoutID1=setTimeout(\'StartIncMonth()\',500)" onmouseup="clearTimeout(timeoutID1);clearInterval(intervalID1)">&nbsp<img id="changeRight" src="';
        sHTML1 += imgDir + 'Images/right1.gif" width="10" height="11" border="0">&nbsp</span>&nbsp;';
        sHTML1 += '<span id="spanMonth" style="border:1px solid #cfaf7a;cursor:pointer" onmouseover="swapImage(\'changeMonth\',\'Images/drop2.gif\');this.style.borderColor=\'#cfaf7a\';window.status=\''+selectMonthMessage+'\'" onmouseout="swapImage(\'changeMonth\',\'Images/drop1.gif\');this.style.borderColor=\'#cfaf7a\';window.status=\'\'" onclick="popUpMonth()"></span>&nbsp;';
        sHTML1 += '<span id="spanYear" style="border:1px solid #cfaf7a;cursor:pointer" onmouseover="swapImage(\'changeYear\',\'Images/drop2.gif\');this.style.borderColor=\'#cfaf7a\';window.status=\''+selectYearMessage+'\'" onmouseout="swapImage(\'changeYear\',\'Images/drop1.gif\');this.style.borderColor=\'#cfaf7a\';window.status=\'\'" onclick="popUpYear()"></span>&nbsp;';

        document.getElementById('caption').innerHTML = sHTML1;

        bPageLoaded=true;
    }
}

function hideCalendar() 
{
    crossobj.visibility = 'hidden';
    if (crossMonthObj != null)
    {
        crossMonthObj.visibility = 'hidden';
    }
    
    if (crossYearObj  != null)
    {
        crossYearObj.visibility = 'hidden';
    }
    
    showElements(selectHideElements);
}

function showElements(elements)
{
    if (elements == null)
    {
        return;
    }

	for (itCount = 0; itCount < elements.length; itCount++)
	{
		var ctrlElement = document.getElementById(elements[itCount]);
		if (ctrlElement == null || ctrlElement.style.display == "")
	    {
	        continue;
	    }
		
  		var selectTextBox = ctrlElement.previousSibling;
	    if (selectTextBox != null && selectTextBox.nodeName.toUpperCase() == "INPUT" && selectTextBox.style.display != "none")
	    {
		    selectTextBox.style.display = "none";
            ctrlElement.style.display = "";
	    }
	}
}

function hideElements(elements)
{
    if (elements == null)
    {
        return;
    }

	for (itCount = 0; itCount < elements.length; itCount++)
	{
		var ctrlElement = document.getElementById(elements[itCount]);
		if (ctrlElement == null || ctrlElement.style.display == "none")
	    {
	        alert()
	        continue;
	    }
	    
  		var selectTextBox = ctrlElement.previousSibling;
  		if (selectTextBox != null && selectTextBox.nodeName.toUpperCase() == "INPUT")
    	{
    	    if (selectTextBox.style.display != "")
    	    {
	            ctrlElement.style.display = "none";
	            selectTextBox.style.display = "";
		    }
		    
		    continue;
    	}
    	
    	selectTextBox = document.createElement("INPUT");
		selectTextBox.style.width = ctrlElement.style.width;
		selectTextBox.className = ctrlElement.className;
		ctrlElement.parentElement.insertBefore(selectTextBox, ctrlElement);
        ctrlElement.style.display = "none";
		selectTextBox.style.height = 17;
	}
}

function padZero(num) 
{
    return (num	< 10) ? '0' + num : num;
}

function constructDate(d,m,y) 
{
    sTmp = dateFormat;
    sTmp = sTmp.replace ('dd','<e>');
    sTmp = sTmp.replace ('d','<d>');
    sTmp = sTmp.replace ('<e>',padZero(d));
    sTmp = sTmp.replace ('<d>',d);
    sTmp = sTmp.replace ('mmmm','<p>');
    sTmp = sTmp.replace ('mmm','<o>');
    sTmp = sTmp.replace ('mm','<n>');
    sTmp = sTmp.replace ('m','<m>');
    sTmp = sTmp.replace ('<m>',m+1);
    sTmp = sTmp.replace ('<n>',padZero(m+1));
    sTmp = sTmp.replace ('<o>',monthName[m]);
    sTmp = sTmp.replace ('<p>',monthName2[m]);
    sTmp = sTmp.replace ('yyyy',y);
    return sTmp.replace ('yy',padZero(y%100));
}

function closeCalendar() 
{
    var isChanged = false;
    var tmp; 

    hideCalendar();

    if (constructDate(dateSelected,monthSelected,yearSelected) != ctlToPlaceValue.value)
    {
        isChanged = true;
    }

    ctlToPlaceValue.value = constructDate(dateSelected,monthSelected,yearSelected);
    if (isChanged == true)
    {
        ctlToPlaceValue.fireEvent("onchange");
    }
}

function StartDecMonth() 
{
    intervalID1 = setInterval("decMonth()",80);
}

function StartIncMonth() 
{
    intervalID1 = setInterval("incMonth()",80);
}

function incMonth () 
{
    monthSelected++;
    if (monthSelected > 11) 
    {
        monthSelected = 0;
        yearSelected++;
    }
    
    constructCalendar();
}

function decMonth ()
{
    monthSelected--;
    if (monthSelected < 0) 
    {
        monthSelected = 11;
        yearSelected--;
    }
    
    constructCalendar();
}

function constructMonth() 
{
    popDownYear()
    if (!monthConstructed) 
    {
        sHTML = "";
        for (i=0; i<12; i++) 
        {
            sName = monthName[i];
            if (i == monthSelected)
            {
                sName = '<b>' + sName + '</b>';
            }
            
            sHTML += '<tr><td id="m' + i + '" onmouseover="this.style.backgroundColor=\'#909090\'" onmouseout="this.style.backgroundColor=\'\'" style="cursor:pointer" onclick="monthConstructed=false;monthSelected=' + i + ';constructCalendar();popDownMonth();event.cancelBubble=true"><font color="#000000">&nbsp;' + sName + '&nbsp;</font></td></tr>';
        }

        document.getElementById('selectMonth').innerHTML = '<table style="width:70" width="70px" style="font-family:Tahoma;font-size:11px;border:1px solid #ffffff;" bgcolor="#f0f0f0" cellspacing="0" onmouseover="clearTimeout(timeoutID1)" onmouseout="clearTimeout(timeoutID1);timeoutID1=setTimeout(\'popDownMonth()\',100);event.cancelBubble=true">' + sHTML + '</table>';
        monthConstructed = true;
    }
}

function popUpMonth() 
{
    if (visMonth == 1) 
    {
        popDownMonth();
        visMonth--;
    }
    else
    {
        constructMonth();
        crossMonthObj.visibility = (dom||ie) ? 'visible' : 'show';
        crossMonthObj.left = parseInt(crossobj.left) + 50;
        crossMonthObj.top =	parseInt(crossobj.top) + 26;
        visMonth++;
    }
}

function popDownMonth() 
{
    crossMonthObj.visibility = 'hidden';
    visMonth = 0;
}

function incYear() 
{
    for	(i=0; i<7; i++) 
    {
        newYear	= (i + nStartingYear) + 1;
        if (newYear == yearSelected)
            txtYear = '<span style="color:#000000;font-weight:bold;">&nbsp;' + newYear + '&nbsp;</span>';
        else
            txtYear = '<span style="color:#000000;">&nbsp;' + newYear + '&nbsp;</span>';
        document.getElementById('y'+i).innerHTML = txtYear;
    }
    
    nStartingYear++;
    bShow=true;
}

function decYear() 
{
    for	(i=0; i<7; i++) 
    {
        newYear = (i + nStartingYear) - 1;
        if (newYear == yearSelected)
        {
            txtYear = '<span style="color:#000000;font-weight:bold">&nbsp;' + newYear + '&nbsp;</span>';
        }
        else
        {
            txtYear = '<span style="color:#000000;">&nbsp;' + newYear + '&nbsp;</span>';
        }
        
        document.getElementById('y'+i).innerHTML = txtYear;
    }
    
    nStartingYear--;
    bShow=true;
}

function selectYear(nYear) 
{
    yearSelected = parseInt(nYear + nStartingYear);
    yearConstructed = false;
    constructCalendar();
    popDownYear();
}

function constructYear() 
{
    popDownMonth();
    sHTML = '';
    if (!yearConstructed) 
    {
        sHTML = '<tr><td align="center" onmouseover="this.style.backgroundColor=\'#909090\'" onmouseout="clearInterval(intervalID1);this.style.backgroundColor=\'\'" style="cursor:pointer" onmousedown="clearInterval(intervalID1);intervalID1=setInterval(\'decYear()\',30)" onmouseup="clearInterval(intervalID1)"><font color="#000000">-</font></td></tr>';

        j = 0;
        nStartingYear =	yearSelected - 3;
        for ( i = (yearSelected-3); i <= (yearSelected+3); i++ ) 
        {
            sName = i;
            if (i == yearSelected) 
            {
                sName = '<b>' + sName + '</b>';
            }
            
            sHTML += '<tr><td id="y' + j + '" onmouseover="this.style.backgroundColor=\'#909090\'" onmouseout="this.style.backgroundColor=\'\'" style="cursor:pointer" onclick="selectYear('+j+');event.cancelBubble=true"><font color="#000000">&nbsp;' + sName + '&nbsp;</font></td></tr>';
            j++;
        }

        sHTML += '<tr><td align="center" onmouseover="this.style.backgroundColor=\'#909090\'" onmouseout="clearInterval(intervalID2);this.style.backgroundColor=\'\'" style="cursor:pointer" onmousedown="clearInterval(intervalID2);intervalID2=setInterval(\'incYear()\',30)" onmouseup="clearInterval(intervalID2)"><font color="#000000">+</font></td></tr>';
        document.getElementById('selectYear').innerHTML = '<table style="width:44" width="44px" cellspacing="0" bgcolor="#f0f0f0" style="font-family:Tahoma;font-size:11px;border:1px solid #ffffff;" onmouseover="clearTimeout(timeoutID2)" onmouseout="clearTimeout(timeoutID2);timeoutID2=setTimeout(\'popDownYear()\',100)">' + sHTML + '</table>';
        yearConstructed = true;
    }
}

function popDownYear() 
{
    clearInterval(intervalID1);
    clearTimeout(timeoutID1);
    clearInterval(intervalID2);
    clearTimeout(timeoutID2);
    crossYearObj.visibility= 'hidden';
    visYear = 0;
}

function popUpYear() 
{
    var leftOffset
    if (visYear==1) 
    {
        popDownYear();
        visYear--;
    }
    else
    {
        constructYear();
        crossYearObj.visibility	= (dom||ie) ? 'visible' : 'show';
        leftOffset = parseInt(crossobj.left) + document.getElementById('spanYear').offsetLeft;
        if (ie)
        {
            leftOffset += 6;
        }
        
        crossYearObj.left = leftOffset;
        crossYearObj.top = parseInt(crossobj.top) + 26;
        visYear++;
    }
}

function WeekNbr(n) 
{
    year = n.getFullYear();
    month = n.getMonth() + 1;
    if (startAt == 0) 
    {
        day = n.getDate() + 1;
    }
    else 
    {
        day = n.getDate();
    }

    a = Math.floor((14-month) / 12);
    y = year + 4800 - a;
    m = month + 12 * a - 3;
    b = Math.floor(y/4) - Math.floor(y/100) + Math.floor(y/400);
    J = day + Math.floor((153 * m + 2) / 5) + 365 * y + b - 32045;
    d4 = (((J + 31741 - (J % 7)) % 146097) % 36524) % 1461;
    L = Math.floor(d4 / 1460);
    d1 = ((d4 - L) % 365) + L;
    week = Math.floor(d1/7) + 1;
    return week;
}

function constructCalendar () 
{
    var aNumDays = Array (31,0,31,30,31,30,31,31,30,31,30,31);
    var dateMessage;
    var startDate = new Date (yearSelected,monthSelected,1);
    var endDate;

    if (monthSelected==1) 
    {
        endDate = new Date (yearSelected,monthSelected+1,1);
        endDate = new Date (endDate - (24*60*60*1000));
        numDaysInMonth = endDate.getDate();
    }
    else
    {
        numDaysInMonth = aNumDays[monthSelected];
    }

    datePointer = 0;
    dayPointer = startDate.getDay() - startAt;

    if (dayPointer<0) 
    {
        dayPointer = 6;
    }

    sHTML = '<table border="0" style="font-family:Tahoma;font-size:10px;"><tr>';

    if (showWeekNumber == 1) 
    {
        sHTML += '<td width="27"><b>' + weekString + '</b></td><td width="1" rowspan="7" bgcolor="#d0d0d0" style="padding:0px"><img src="'+imgDir+'Images/divider.gif" width="1"></td>';
    }

    for (i = 0; i<7; i++) 
    {
        sHTML += '<td width="27" align="right"><b><font color="#000000">' + dayName[i] + '</font></b></td>';
    }

    sHTML += '</tr><tr>';

    if (showWeekNumber == 1) 
    {
        sHTML += '<td align="right">' + WeekNbr(startDate) + '&nbsp;</td>';
    }

    for	( var i=1; i<=dayPointer;i++ ) 
    {
        sHTML += '<td>&nbsp;</td>';
    }

    for	( datePointer=1; datePointer <= numDaysInMonth; datePointer++ ) 
    {
        dayPointer++;
        sHTML += '<td align="right">';
        sStyle=styleAnchor;
        
        if ((datePointer == odateSelected) && (monthSelected == omonthSelected) && (yearSelected == oyearSelected))
        {
            sStyle+=styleLightBorder;
        }

        sHint = '';
        for (k = 0;k < HolidaysCounter; k++) 
        {
            if ((parseInt(Holidays[k].d) == datePointer)&&(parseInt(Holidays[k].m) == (monthSelected+1))) 
            {
                if ((parseInt(Holidays[k].y)==0)||((parseInt(Holidays[k].y)==yearSelected)&&(parseInt(Holidays[k].y)!=0))) 
                {
                    sStyle+= 'background-color:#fdd;';
                    sHint += sHint=="" ? Holidays[k].desc : "\n"+Holidays[k].desc;
                }
            }
        }

        sHint = sHint.replace('/\"/g', '&quot;');

        dateMessage = 'onmousemove="window.status=\''+selectDateMessage.replace('[date]',constructDate(datePointer,monthSelected,yearSelected))+'\'" onmouseout="window.status=\'\'" ';

        if (enablePast == 0 && ((yearSelected < yearNow) || (monthSelected < monthNow) && (yearSelected == yearNow) || (datePointer < dateNow) && (monthSelected == monthNow) && (yearSelected == yearNow))) 
        {
            selDayAction = '';
            isPast = 1;
        }
        else 
        {
            selDayAction = 'href="javascript:dateSelected=' + datePointer + ';closeCalendar();"';
            isPast = 0;
        }

        if ((datePointer == dateNow) && (monthSelected == monthNow) && (yearSelected == yearNow)) 
        {	
            sHTML += "<b><a "+dateMessage+" title=\"" + sHint + "\" style='"+sStyle+"' "+selDayAction+"><font color=#6699cc>&nbsp;" + datePointer + "</font>&nbsp;</a></b>";
        }
        else if (dayPointer % 7 == (startAt * -1)+1) 
        {
            if (isPast==1)
            {
                sHTML += "<a "+dateMessage+" title=\"" + sHint + "\" style='"+sStyle+"' "+selDayAction+">&nbsp;<font color=#909090>" + datePointer + "</font>&nbsp;</a>";
            }
            else
            {
                sHTML += "<a "+dateMessage+" title=\"" + sHint + "\" style='"+sStyle+"' "+selDayAction+">&nbsp;<font color=#cc3333>" + datePointer + "</font>&nbsp;</a>";
            }
            
        }
        else if ((dayPointer % 7 == (startAt * -1)+7 && startAt==1) || (dayPointer % 7 == startAt && startAt==0)) 
        {	
            if (isPast==1)
            {
                sHTML += "<a "+dateMessage+" title=\"" + sHint + "\" style='"+sStyle+"' "+selDayAction+">&nbsp;<font color=#909090>" + datePointer + "</font>&nbsp;</a>";
            }
            else
            {
                sHTML += "<a "+dateMessage+" title=\"" + sHint + "\" style='"+sStyle+"' "+selDayAction+">&nbsp;<font color=#cc3333>" + datePointer + "</font>&nbsp;</a>";
            }
        }
        else
        {
            if (isPast==1)
            {
                sHTML += "<a "+dateMessage+" title=\"" + sHint + "\" style='"+sStyle+"' "+selDayAction+">&nbsp;<font color=#909090>" + datePointer + "</font>&nbsp;</a>";
            }
            else
            {
                sHTML += "<a "+dateMessage+" title=\"" + sHint + "\" style='"+sStyle+"' "+selDayAction+">&nbsp;<font color=#000000>" + datePointer + "</font>&nbsp;</a>";
            }
        }

        sHTML += '';
        if ((dayPointer+startAt) % 7 == startAt) 
        {
            sHTML += '</tr><tr>';
            if ((showWeekNumber == 1) && (datePointer < numDaysInMonth)) 
            {
                sHTML += '<td align="right">' + (WeekNbr(new Date(yearSelected,monthSelected,datePointer+1))) + '&nbsp;</td>';
            }
        }
    }

    document.getElementById('content').innerHTML   = sHTML
    document.getElementById('spanMonth').innerHTML = '&nbsp;' +	monthName[monthSelected] + '&nbsp;<img id="changeMonth" src="'+imgDir+'Images/drop1.gif" width="12" height="10" border="0">'
    document.getElementById('spanYear').innerHTML  = '&nbsp;' + yearSelected	+ '&nbsp;<img id="changeYear" src="'+imgDir+'Images/drop1.gif" width="12" height="10" border="0">';
}

function showCalendar(ctl, ctl2, format, past, fx, fy) 
{
    if (past != null)
    {
        enablePast = past;
    }
    else
    {
        enablePast = 0;
    }
    
    if (fx != null)
    {
        fixedX = fx;
    }
    else 
    {
        fixedX = -1;
    }
    
    if (fy != null)
    {
        fixedY = fy;
    }
    else
    {
        fixedY = -1;
    }

    if (showToday == 1) 
    {
        document.getElementById('lblToday').innerHTML = '<font color="#000000">' + todayString + ' <a onmousemove="window.status=\''+gotoString+'\'" onmouseout="window.status=\'\'" title="'+gotoString+'" style="'+styleAnchor+'" href="javascript:monthSelected=monthNow;yearSelected=yearNow;constructCalendar();">'+dayName[(today.getDay()-startAt==-1)?6:(today.getDay()-startAt)]+', ' + dateNow + ' ' + monthName[monthNow].substring(0,3) + ' ' + yearNow + '</a></font>';
    }
    
    popUpCalendar(ctl, ctl2, format);
}

function popUpCalendar(ctl, ctl2, format) 
{
    var leftpos = 0;
    var toppos  = 0;

    if (bPageLoaded) 
    {
        if (crossobj.visibility == 'hidden') 
        {
            ctlToPlaceValue = ctl2;
            dateFormat = format;
            formatChar = ' ';
            aFormat = dateFormat.split(formatChar);
            if (aFormat.length < 3) 
            {
                formatChar = '/';
                aFormat = dateFormat.split(formatChar);
                if (aFormat.length < 3) 
                {
                    formatChar = '.';
                    aFormat = dateFormat.split(formatChar);
                    if (aFormat.length < 3) 
                    {
                        formatChar = '-';
                        aFormat = dateFormat.split(formatChar);
                        if (aFormat.length < 3) 
                        {
	                        formatChar = '';					
                        }
                    }
                }
            }

            tokensChanged = 0;
            if (formatChar != "") 
            {
                aData =	ctl2.value.split(formatChar);			

                for (i=0; i<3; i++) 
                {
                    if ((aFormat[i] == "d") || (aFormat[i] == "dd")) 
                    {
                        dateSelected = parseInt(aData[i], 10);
                        tokensChanged++;
                    }
                    else if ((aFormat[i] == "m") || (aFormat[i] == "mm")) 
                    {
                        monthSelected = parseInt(aData[i], 10) - 1;
                        tokensChanged++;
                    }
                    else if (aFormat[i] == "yyyy") 
                    {
                        yearSelected = parseInt(aData[i], 10);
                        tokensChanged++;
                    }
                    else if (aFormat[i] == "mmm") 
                    {
                        for (j=0; j<12; j++) 
                        {
	                        if (aData[i] == monthName[j]) 
	                        {
		                        monthSelected=j;
		                        tokensChanged++;
	                        }
                        }
                    }
                    else if (aFormat[i] == "mmmm") 
                    {
                        for (j=0; j<12; j++) 
                        {
	                        if (aData[i] == monthName2[j]) 
	                        {
		                        monthSelected = j;
		                        tokensChanged++;
	                        }
                        }
                    }
                }
            }

            if ((tokensChanged != 3) || isNaN(dateSelected) || isNaN(monthSelected) || isNaN(yearSelected)) 
            {
                dateSelected  = dateNow;
                monthSelected = monthNow;
                yearSelected  = yearNow;
            }

            odateSelected  = dateSelected;
            omonthSelected = monthSelected;
            oyearSelected  = yearSelected;

            aTag = ctl;
            do
            {
                aTag     = aTag.offsetParent;
                leftpos += aTag.offsetLeft;
                toppos  += aTag.offsetTop;
            }
            while (aTag.tagName != 'BODY');

            crossobj.left = (fixedX == -1) ? ctl.offsetLeft + leftpos : fixedX;
            crossobj.top = (fixedY == -1) ? ctl.offsetTop + toppos + ctl.offsetHeight + 2 : fixedY;
            constructCalendar (1, monthSelected, yearSelected);
            crossobj.visibility = (dom||ie) ? "visible" : "show";

            bShow = true;
        }
        else 
        {
            hideCalendar();
            if (ctlNow!=ctl)
            {
                popUpCalendar(ctl, ctl2, format);
            }
        }
        
        ctlNow = ctl;
    }
}

document.onkeypress = function hidecal1 () 
{
    if (event.keyCode == 27) hideCalendar();
}

document.onclick = function hidecal2 ()
{
    if (!bShow) hideCalendar();
    bShow = false;
}

if(ie)
{
    init();
}
else
{
    window.onload = init;
}

