//  written by Tan Ling Wee on 2 Dec 2001
//  last updated 28 Jul 2003
//  email : fuushikaden@yahoo.com
//  website : www.pengz.com

		//Callback-Funktion, die nach der Datumswahl aufgerufen wird:
		var callback = '';

    // Funktionalle Einstellungen
    var language                    = 'de';                     // Default Language: en - english ; es - spanish; de - german
    var enablePast                  = 1;                        // 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              = 1;                        // 0 - don't show; 1 - show
    var showToday                   = 1;                        // 0 - don't show; 1 - show
    var imgDir                      = 'images/calender/';     // directory for images ... e.g. var imgDir="/img/"
    var dayName                     = '';

    // Farb-Anpassungen:
    var colorBannerTop              = '#F7F7F7';                // Farbe der oberen Leiste
    var colorBannerDown             = '#F7F7F7';                // Farbe der oberen Leiste
    var colorBorderTable            = '#FFFFFF';                // Farbe der oberen Leiste
    var colorSelectYear             = '#000000';                // Farbe der oberen Leiste
    var colorBorderSelectList       = "#000066";                // Farbe der Rahmen um Dropdown-Elemente
    var colorBorderSelectListOver   = "#1200EA";                // Farbe der Rahmen um Dropdown-Elemente bei mouseover
    var colorFirstBorder            = "#A0A0A0";                // Farbe des Aussenrandes
    var colorCalenderBackground     = "#FFFFFF";                // Farbe des Hindegrundes vom Calender
    var colorBorderToday            = "#FF0000";                // Farbe des Rahmens rund um aktuellem Datum
    var colorTextBannerDown         = "#000066";                // Farbe des Textes auf dem unteren Banner
    var colorSelectedItem           = "#909090";                // Markierung des Elementes im Dropdown-Menue
    var colorTextItem               = "#000066";                // Textfarbe der Elemente im Dropdown-Menue
    var colorBorderSelect           = "#A0A0A0";                // Farbe des Rahmens um Dropdown-Menues
    var colorSelectBackground       = "#F7F7F7";                // Farbe des Hintergrundes von Dropdown-Menue
    var colorSelectCurrItem         = "#000066";                // Farbe desaktuelles Monats/Jahres im Dropdown-Menue
    var colorBeforYears             = "#777777";                // Farbe der Jahre vor dem aktuellen im Dropdown-Menue
    var colorYearUpDown             = "#909090";                // Hintergrund-Farbe von +/- in Jahresauswahl-Menue
    var colorSelectPlisMinus        = "#000066";                // Text-Farbe +/- in Jahresauswahl-Menue
    var colorKWDelimiter            = "#A0A0A0";                // Farbe der Trennlinie zwischen KW und Kalender
    var colorDayName                = "#000066";                // Farbe der Wochentagen
    var colorHolydayBackground      = "#FFDDDD";                // Hintergrundfarbe von Feiertagen
    var colorFontSaSo               = "#54A6E2";                // Fontfarbe von Sa. und So
    var colorCurrDay                = "#FF0000";                // Farbe des aktuellen Datums
    var colorFontLastDays           = "#909090";                // Fontfarbe von vergangenen Tagen
    var colorBevorDays              = "#000066";                // Fontfarbe von zukuenftigen Tagen

    var gotoString = {
        en : 'Go To Current Month',
        es : 'Ir al Mes Actual',
        de : 'Gehe zu aktuellem Monat'
    };
    var todayString = {
        en : 'Today is',
        es : 'Hoy es',
        de : 'Heute ist'
    };
    var weekString = {
        en : 'Wk',
        es : 'Sem',
        de : 'KW'
    };
    var scrollLeftMessage = {
        en : 'Click to scroll to previous month. Hold mouse button to scroll automatically.',
        es : 'Presione para pasar al mes anterior. Deje presionado para pasar varios meses.',
        de : 'Klicken um zum vorigen Monat zu gelangen. Gedrückt halten, um automatisch weiter zu scrollen.'
    };
    var scrollRightMessage = {
        en : 'Click to scroll to next month. Hold mouse button to scroll automatically.',
        es : 'Presione para pasar al siguiente mes. Deje presionado para pasar varios meses.',
        de : 'Klicken um zum nächsten Monat zu gelangen. Gedrückt halten, um automatisch weiter zu scrollen.'
    };
    var selectMonthMessage = {
        en : 'Click to select a month.',
        es : 'Presione para seleccionar un mes',
        de : 'Klicken um Monat auszuwählen'
    };
    var selectYearMessage = {
        en : 'Click to select a year.',
        es : 'Presione para seleccionar un año',
        de : 'Klicken um Jahr auszuwählen'
    };
    var selectDateMessage = {       // do not replace [date], it will be replaced by date.
        en : 'Select [date] as date.',
        es : 'Seleccione [date] como fecha',
        de : 'Wähle [date] als Datum.'
    };
    var monthName = {
        en : new Array('January','February','March','April','May','June','July','August','September','October','November','December'),
        es : new Array('Enero','Febrero','Marzo','Abril','Mayo','Junio','Julio','Agosto','Septiembre','Octubre','Noviembre','Diciembre'),
        de : new Array('Januar','Februar','M&auml;rz','April','Mai','Juni','Juli','August','September','Oktober','November','Dezember')
    };
    var monthName2 = {
        en : new Array('JAN','FEB','MAR','APR','MAY','JUN','JUL','AUG','SEP','OCT','NOV','DEC'),
        es : new Array('ENE','FEB','MAR','ABR','MAY','JUN','JUL','AGO','SEP','OCT','NOV','DIC'),
        de : new Array('JAN','FEB','MRZ','APR','MAI','JUN','JUL','AUG','SEP','OKT','NOV','DEZ')
    };

    if (startAt==0) {
        dayName = {
            en : new Array('Sun','Mon','Tue','Wed','Thu','Fri','Sat'),
            es : new Array('Dom','Lun','Mar','Mie','Jue','Vie','Sab'),
            de : new Array('So','Mo','Di','Mi','Do','Fr','Sa')
        };
    } else {
        dayName = {
            en : new Array('Mon','Tue','Wed','Thu','Fri','Sat','Sun'),
            es : new Array('Lun','Mar','Mie','Jue','Vie','Sab','Dom'),
            de : new Array('Mo','Di','Mi','Do','Fr','Sa','So')
        };
    }

    var crossobj, crossMonthObj, crossYearObj, monthSelected, yearSelected, dateSelected, omonthSelected, oyearSelected, odateSelected, monthConstructed, yearConstructed, intervalID1, intervalID2, timeoutID1, timeoutID2, ctlToPlaceValue, ctl2ToPlaceValue, ctlNow, dateFormat, nStartingYear, selDayAction, isPast;
    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 imgsrc   = new Array('drop1.gif','drop2.gif','left1.gif','left2.gif','right1.gif','right2.gif');
    var img      = new Array();
    var bShow    = false;

    /* hides <select> and <applet> objects (for IE only) */
    function hideElement( elmID, overDiv ) {
        if(ie) {
            for(i = 0; i < document.all.tags( elmID ).length; i++) {
                obj = document.all.tags( elmID )[i];
                if(!obj || !obj.offsetParent) continue;

                // Find the element's offsetTop and offsetLeft relative to the BODY tag.
                objLeft   = obj.offsetLeft;
                objTop    = obj.offsetTop;
                objParent = obj.offsetParent;

                while(objParent.tagName.toUpperCase() != 'BODY') {
                    objLeft  += objParent.offsetLeft;
                    objTop   += objParent.offsetTop;
                    objParent = objParent.offsetParent;
                }

                objHeight = obj.offsetHeight;
                objWidth  = obj.offsetWidth;

                if((overDiv.offsetLeft + overDiv.offsetWidth) <= objLeft);
                else if((overDiv.offsetTop + overDiv.offsetHeight) <= objTop);
                /* CHANGE by Charlie Roche for nested TDs*/
                else if(overDiv.offsetTop >= (objTop + objHeight + obj.height));
                /* END CHANGE */
                else if(overDiv.offsetLeft >= (objLeft + objWidth));
                else {
                    obj.style.visibility = 'hidden';
                }
            }
        }
    }

    /*
    * unhides <select> and <applet> objects (for IE only)
    */
    function showElement(elmID) {
        if(ie) {
            for(i = 0; i < document.all.tags( elmID ).length; i++) {
                obj = document.all.tags(elmID)[i];
                if(!obj || !obj.offsetParent) continue;
                obj.style.visibility = '';
            }
        }
    }

    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 width="'+((showWeekNumber==1)?250:220)+'" style="font-family:Arial;font-size:11px;border: 1px solid ' + colorFirstBorder + ';" bgcolor="' + colorBorderTable + '"><tr bgcolor="' + colorBannerTop + '"><td><table width="'+((showWeekNumber==1)?248:218)+'"><tr><td style="padding:2px;font-family:Arial;font-size:11px;"><font color="' + colorSelectYear + '' /*C9D3E9*/ +'"><b><span id="caption"></span></b></font></td><td align="right"><a href="javascript:hideCalendar()"><img src="'+imgDir+'close.gif" width="15" height="13" border="0" /></a></td></tr></table></td></tr><tr><td style="padding:5px" bgcolor="' + colorCalenderBackground + '"><span id="content"></span></td></tr>');

        if (showToday == 1) {
            document.write ('<tr bgcolor="' + colorBannerDown + '"><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 ' + colorBorderToday + ';';

    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="' + colorTextBannerDown + '">' + todayString[language] + ' <a onmousemove="window.status=\''+gotoString[language]+'\'" onmouseout="window.status=\'\'" title="'+gotoString[language]+'" style="'+styleAnchor+'" href="javascript:monthSelected=monthNow;yearSelected=yearNow;constructCalendar();">'+dayName[language][(today.getDay()-startAt==-1)?6:(today.getDay()-startAt)]+', ' + dateNow + ' ' + monthName[language][monthNow].substring(0,3) + ' ' + yearNow + '</a></font>';
            }

            sHTML1 = '<span id="spanLeft" style="border:1px solid ' + colorBorderSelectList + ';cursor:pointer" onmouseover="swapImage(\'changeLeft\',\'left2.gif\');this.style.borderColor=\''+ colorBorderSelectListOver +'\';window.status=\''+scrollLeftMessage[language]+'\'" onclick="decMonth()" onmouseout="clearInterval(intervalID1);swapImage(\'changeLeft\',\'left1.gif\');this.style.borderColor=\''+ colorBorderSelectList +'\';window.status=\'\'" onmousedown="clearTimeout(timeoutID1);timeoutID1=setTimeout(\'StartDecMonth()\',500)" onmouseup="clearTimeout(timeoutID1);clearInterval(intervalID1)">&nbsp<img id="changeLeft" src="'+imgDir+'left1.gif" width="10" height="11" border="0">&nbsp</span>&nbsp;';
            sHTML1 += '<span id="spanRight" style="border:1px solid ' + colorBorderSelectList + ';cursor:pointer" onmouseover="swapImage(\'changeRight\',\'right2.gif\');this.style.borderColor=\''+ colorBorderSelectListOver +'\';window.status=\''+scrollRightMessage[language]+'\'" onmouseout="clearInterval(intervalID1);swapImage(\'changeRight\',\'right1.gif\');this.style.borderColor=\''+ colorBorderSelectList +'\';window.status=\'\'" onclick="incMonth()" onmousedown="clearTimeout(timeoutID1);timeoutID1=setTimeout(\'StartIncMonth()\',500)" onmouseup="clearTimeout(timeoutID1);clearInterval(intervalID1)">&nbsp<img id="changeRight" src="'+imgDir+'right1.gif" width="10" height="11" border="0">&nbsp</span>&nbsp;';
            sHTML1 += '<span id="spanMonth" style="border:1px solid ' + colorBorderSelectList + ';cursor:pointer" onmouseover="swapImage(\'changeMonth\',\'drop2.gif\');this.style.borderColor=\''+ colorBorderSelectListOver +'\';window.status=\''+selectMonthMessage[language]+'\'" onmouseout="swapImage(\'changeMonth\',\'drop1.gif\');this.style.borderColor=\''+ colorBorderSelectList +'\';window.status=\'\'" onclick="popUpMonth()"></span>&nbsp;';
            sHTML1 += '<span id="spanYear" style="border:1px solid ' + colorBorderSelectList + ';cursor:pointer" onmouseover="swapImage(\'changeYear\',\'drop2.gif\');this.style.borderColor=\''+ colorBorderSelectListOver +'\';window.status=\''+selectYearMessage[language]+'\'" onmouseout="swapImage(\'changeYear\',\'drop1.gif\');this.style.borderColor=\''+ colorBorderSelectList +'\';window.status=\'\'" onclick="popUpYear()"></span>&nbsp;';

            document.getElementById('caption').innerHTML = sHTML1;

            bPageLoaded=true;
        }
    }

    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[language][m]);
        sTmp = sTmp.replace ('<p>',monthName2[language][m]);
        sTmp = sTmp.replace ('yyyy',y);
        return sTmp.replace ('yy',padZero(y%100));
    }

    function closeCalendar() {
        hideCalendar();
        ctlToPlaceValue.value  = constructDate(dateSelected,monthSelected,yearSelected);
        ctl2ToPlaceValue.value = constructDate(dateSelected,monthSelected,yearSelected);

        if(this.callback != "")
        {
        	eval(this.callback);
        }
    }

    /*** Month Pulldown ***/
    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[language][i];
                if (i == monthSelected){
                    sName = '<b>' + sName + '</b>';
                }
                sHTML += '<tr><td id="m' + i + '" onmouseover="this.style.backgroundColor=\'' + colorSelectedItem + '\'" onmouseout="this.style.backgroundColor=\'\'" style="cursor:pointer" onclick="monthConstructed=false;monthSelected=' + i + ';constructCalendar();popDownMonth();event.cancelBubble=true"><font color="' + colorTextItem + '">&nbsp;' + sName + '&nbsp;</font></td></tr>';
            }

            document.getElementById('selectMonth').innerHTML = '<table width="70" style="font-family:Arial;font-size:11px;border:1px solid ' + colorBorderSelect + ';" bgcolor="' + colorSelectBackground + '" 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;
            hideElement('SELECT', document.getElementById('selectMonth'));
            hideElement('APPLET', document.getElementById('selectMonth'));
            visMonth++;
        }
    }

    function popDownMonth() {
        crossMonthObj.visibility = 'hidden';
        visMonth = 0;
    }

    /*** Year Pulldown ***/
    function incYear() {
        for (i=0; i<7; i++) {
            newYear = (i + nStartingYear) + 1;
            if (newYear == yearSelected)
                txtYear = '<span style="color:' + colorSelectCurrItem + ';font-weight:bold;">&nbsp;' + newYear + '&nbsp;</span>';
            else
                txtYear = '<span style="color:' + colorSelectCurrItem + ';">&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:' + colorBeforYears + ';font-weight:bold">&nbsp;' + newYear + '&nbsp;</span>';
            else
                txtYear = '<span style="color:' + colorBeforYears + ';">&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=\'' + colorYearUpDown + '\'" onmouseout="clearInterval(intervalID1);this.style.backgroundColor=\'\'" style="cursor:pointer" onmousedown="clearInterval(intervalID1);intervalID1=setInterval(\'decYear()\',30)" onmouseup="clearInterval(intervalID1)"><font color="' + colorSelectPlisMinus + '">-</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=\'' + colorSelectedItem + '\'" onmouseout="this.style.backgroundColor=\'\'" style="cursor:pointer" onclick="selectYear('+j+');event.cancelBubble=true"><font color="' + colorTextItem + '">&nbsp;' + sName + '&nbsp;</font></td></tr>';
                j++;
            }

            sHTML += '<tr><td align="center" onmouseover="this.style.backgroundColor=\'' + colorSelectedItem + '\'" onmouseout="clearInterval(intervalID2);this.style.backgroundColor=\'\'" style="cursor:pointer" onmousedown="clearInterval(intervalID2);intervalID2=setInterval(\'incYear()\',30)" onmouseup="clearInterval(intervalID2)"><font color="' + colorSelectPlisMinus + '">+</font></td></tr>';

            document.getElementById('selectYear').innerHTML = '<table width="44" cellspacing="0" bgcolor="' + colorSelectBackground + '" style="font-family:Arial;font-size:11px;border:1px solid ' + colorBorderSelect + ';" 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++;
        }
    }

    /*** calendar ***/
    function WeekNbr(n) {
        // Algorithm used:
        // From Klaus Tondering's Calendar document (The Authority/Guru)
        // http://www.tondering.dk/claus/calendar.html
        // a = (14-month) / 12
        // y = year + 4800 - a
        // m = month + 12a - 3
        // J = day + (153m + 2) / 5 + 365y + y / 4 - y / 100 + y / 400 - 32045
        // d4 = (J + 31741 - (J mod 7)) mod 146097 mod 36524 mod 1461
        // L = d4 / 1460
        // d1 = ((d4 - L) mod 365) + L
        // WeekNumber = d1 / 7 + 1

        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:verdana;font-size:10px;"><tr>';

        if (showWeekNumber == 1) {
            sHTML += '<td width="27"><b>' + weekString[language] + '</b></td><td width="1" rowspan="7" bgcolor="' + colorKWDelimiter + '" style="padding:0px"><img src="'+imgDir+'divider.gif" width="1"></td>';
        }

        for (i = 0; i<7; i++) {
            sHTML += '<td width="27" align="right"><b><font color="' + colorDayName + '">' + dayName[language][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:' + colorHolydayBackground + ';';
                        sHint += sHint=="" ? Holidays[k].desc : "\n"+Holidays[k].desc;
                    }
                }
            }

            sHint = sHint.replace('/\"/g', '&quot;');

            dateMessage = 'onmousemove="window.status=\''+selectDateMessage[language].replace('[date]',constructDate(datePointer,monthSelected,yearSelected))+'\'" onmouseout="window.status=\'\'" ';


            //////////////////////////////////////////////
            //////////  Modifications PinoToy  //////////
            //////////////////////////////////////////////
            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)) { ///// today
                sHTML += "<b><a "+dateMessage+" title=\"" + sHint + "\" style='"+sStyle+"' "+selDayAction+"><font color=" + colorCurrDay + ">&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=" + colorFontLastDays + ">" + datePointer + "</font>&nbsp;</a>";
                else
                    sHTML += "<a "+dateMessage+" title=\"" + sHint + "\" style='"+sStyle+"' "+selDayAction+">&nbsp;<font color=" + colorFontSaSo + ">" + 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=" + colorFontLastDays + ">" + datePointer + "</font>&nbsp;</a>";
                else
                    sHTML += "<a "+dateMessage+" title=\"" + sHint + "\" style='"+sStyle+"' "+selDayAction+">&nbsp;<font color=" + colorFontSaSo + ">" + datePointer + "</font>&nbsp;</a>";
            } else {
                if (isPast==1)
                    sHTML += "<a "+dateMessage+" title=\"" + sHint + "\" style='"+sStyle+"' "+selDayAction+">&nbsp;<font color=" + colorFontLastDays + ">" + datePointer + "</font>&nbsp;</a>";
                else
                    sHTML += "<a "+dateMessage+" title=\"" + sHint + "\" style='"+sStyle+"' "+selDayAction+">&nbsp;<font color=" + colorBevorDays + ">" + 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[language][monthSelected] + '&nbsp;<img id="changeMonth" src="'+imgDir+'drop1.gif" width="12" height="10" border="0">'
        document.getElementById('spanYear').innerHTML  = '&nbsp;' + yearSelected    + '&nbsp;<img id="changeYear" src="'+imgDir+'drop1.gif" width="12" height="10" border="0">';
    }

    function showCalendar(ctl, ctl2, format, lang, past, fx, fy) {
        if (lang != null && lang != '') language = lang;
        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="' + colorTextBannerDown + '">' + todayString[language] + ' <a onmousemove="window.status=\''+gotoString[language]+'\'" onmouseout="window.status=\'\'" title="'+gotoString[language]+'" style="'+styleAnchor+'" href="javascript:monthSelected=monthNow;yearSelected=yearNow;constructCalendar();">'+dayName[language][(today.getDay()-startAt==-1)?6:(today.getDay()-startAt)]+', ' + dateNow + ' ' + monthName[language][monthNow].substring(0,3) + ' ' + yearNow + '</a></font>';
        }
        popUpCalendar(ctl, ctl2, format);
    }

    function popUpCalendar(ctl, ctl2, ctl3, format, callback)
    {
        var leftpos = 0;
        var toppos  = 0;

        if (bPageLoaded)
        {
            if (crossobj.visibility == 'hidden')
            {
                ctlToPlaceValue = ctl2;
                ctl2ToPlaceValue = ctl3;
                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 = '';                    // invalid date format

                            }
                        }
                    }
                }

                tokensChanged = 0;
                if (formatChar != "")
                {
                    aData = ctl2.value.split(formatChar);           // use user's date

                    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[language][j])
                                {
                                    monthSelected=j;
                                    tokensChanged++;
                                }
                            }
                        }
                        else if (aFormat[i] == "mmmm")
                        {
                            for (j=0; j<12; j++) {
                                if (aData[i] == monthName2[language][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";

                hideElement('SELECT', document.getElementById('calendar'));
                hideElement('APPLET', document.getElementById('calendar'));

                bShow = true;
            } else {
                hideCalendar();
                if (ctlNow!=ctl) popUpCalendar(ctl, ctl2, ctl3, format);
            }
            ctlNow = ctl;
        }

				if(callback)
        	this.callback = callback;
    }

    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;
    }

   function hideCalendar()
    {
        crossobj.visibility = 'hidden';
        if (crossMonthObj != null) crossMonthObj.visibility = 'hidden';
        if (crossYearObj  != null) crossYearObj.visibility = 'hidden';
        showElement('SELECT');
        showElement('APPLET');
    }
