//      written by Tan Ling     Wee     on 2 Dec 2001
//     last updated 28 Jul 2003
//     email : fuushikaden@yahoo.com
//     website : www.pengz.com
//     TabSize: 4
//
//     modified by ALQUANTO 30 July 2003 - german language included.
//                                                                       - modified languageLogic with the ISO-2letter-strings
//                                                                       - changes in in showCalendar: defaultLanguage is already set...
//                                                                       - js and html corrected... more xhtml-compliant... simplier css
//     email: popcalendar@alquanto.de
//
//     modified by PinoToy 25 July 2003  - new logic for multiple languages (English, Spanish and ready for more).
//                                                                       - changes in popUpMonth & popDownMonth methods for hidding    popup.
//                                                                       - changes in popDownYear & popDownYear methods for hidding    popup.
//                                                                       - new logic for disabling dates in    the past.
//                                                                       - new method showCalendar, dynamic    configuration of language, enabling     past & position.
//                                                                       - changes in the styles.
//     email  : pinotoy@yahoo.com

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

       var gotoString = {
               en : 'Go To Current Month',
               es : 'Ir al Mes Actual',
               de : 'Gehe zu aktuellem Monat',
               tr  : 'Şimdiki Aya Git'
       };
       var todayString = {
               en : 'Today is',
               es : 'Hoy es',
               de : 'Heute ist',
               tr  : 'Bugün'
       };
       var weekString = {
               en : 'Wk',
               es : 'Sem',
               de : 'KW',
               tr  : 'Hafta'
       };
       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.',
               tr  : 'Önceki aya gitmek için tıklayın.'
       };
       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.',
               tr  : 'Sonraki aya gitmek için tıklayın.'
       };
       var selectMonthMessage = {
               en : 'Click to select a month.',
               es : 'Presione para seleccionar un mes',
               de : 'Klicken um Monat auszuwählen',
               tr  : 'Bir ay seçmek için tıklayın'
       };
       var selectYearMessage = {
               en : 'Click to select a year.',
               es : 'Presione para seleccionar un año',
               de : 'Klicken um Jahr auszuwählen',
               tr  : 'Bir yıl seçmek için tıklayın'
       };
       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.',
               tr  : 'Tarihi [date] olarak seçin.'
       };
       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ärz','April','Mai','Juni','Juli','August','September','Oktober','November','Dezember'),
               tr  : new Array('Ocak','Şubat','Mart','Nisan','Mayıs','Haziran','Temmuz','Ağustos','Eylül','Ekim','Kasım','Aralık')
       };
       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'),
               tr  : new Array('OCA','SUB','MAR','NIS','MAY','HAZ','TEM','AĞU','EYL','EKİ','KAS','ARA')
       };

       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'),
                       tr  : new Array('Pztesi','Sal','Çarş','Perş','Cuma','Cmtesi','Pz')
               };
       } 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'),
                       tr  : new Array('Pztesi','Sal','Çarş','Perş','Cuma','Cmtesi','Pz')
               };
       }

       var crossobj, crossMonthObj, crossYearObj, monthSelected, yearSelected, dateSelected, omonthSelected, oyearSelected, odateSelected, monthConstructed, yearConstructed, intervalID1, intervalID2, timeoutID1, timeoutID2, ctlToPlaceValue, 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 #A0A0A0;" bgcolor="#ffffff"><tr bgcolor="#000066"><td><table width="'+((showWeekNumber==1)?248:218)+'"><tr><td style="padding:2px;font-family:Arial;font-size:11px;"><font color="#ffffff' + '' /*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="#ffffff"><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 #a0a0a0;';

       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="#000066">' + 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 #36f;cursor:pointer" onmouseover="swapImage(\'changeLeft\',\'left2.gif\');this.style.borderColor=\'#8af\';window.status=\''+scrollLeftMessage[language]+'\'" onclick="decMonth()" onmouseout="clearInterval(intervalID1);swapImage(\'changeLeft\',\'left1.gif\');this.style.borderColor=\'#36f\';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 #36f;cursor:pointer" onmouseover="swapImage(\'changeRight\',\'right2.gif\');this.style.borderColor=\'#8af\';window.status=\''+scrollRightMessage[language]+'\'" onmouseout="clearInterval(intervalID1);swapImage(\'changeRight\',\'right1.gif\');this.style.borderColor=\'#36f\';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 #36f;cursor:pointer" onmouseover="swapImage(\'changeMonth\',\'drop2.gif\');this.style.borderColor=\'#8af\';window.status=\''+selectMonthMessage[language]+'\'" onmouseout="swapImage(\'changeMonth\',\'drop1.gif\');this.style.borderColor=\'#36f\';window.status=\'\'" onclick="popUpMonth()"></span>&nbsp;';
                       sHTML1 += '<span id="spanYear" style="border:1px solid #36f;cursor:pointer" onmouseover="swapImage(\'changeYear\',\'drop2.gif\');this.style.borderColor=\'#8af\';window.status=\''+selectYearMessage[language]+'\'" onmouseout="swapImage(\'changeYear\',\'drop1.gif\');this.style.borderColor=\'#36f\';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';
               showElement('SELECT');
               showElement('APPLET');
       }

       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);
               ctlToPlaceValue.focus();
       }

       /*** 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=\'#909090\'" onmouseout="this.style.backgroundColor=\'\'" style="cursor:pointer" onclick="monthConstructed=false;monthSelected=' + i + ';constructCalendar();popDownMonth();event.cancelBubble=true"><font color="#000066">&nbsp;' + sName + '&nbsp;</font></td></tr>';
                       }

                       document.getElementById('selectMonth').innerHTML = '<table width="70" style="font-family:Arial;font-size:11px;border:1px solid #a0a0a0;" 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;
                       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:#006;font-weight:bold;">&nbsp;' + newYear + '&nbsp;</span>';
                       else
                               txtYear = '<span style="color:#006;">&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:#006;font-weight:bold">&nbsp;' + newYear + '&nbsp;</span>';
                       else
                               txtYear = '<span style="color:#006;">&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="#000066">-</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="#000066">&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="#000066">+</font></td></tr>';

                       document.getElementById('selectYear').innerHTML = '<table width="44" cellspacing="0" bgcolor="#f0f0f0" style="font-family:Arial;font-size:11px;border:1px solid #a0a0a0;" 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="#d0d0d0" 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="#000066">' + 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:#fdd;';
                                               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=#ff0000>&nbsp;" + datePointer + "</font>&nbsp;</a></b>";
                       } else if (dayPointer % 7 == (startAt * -1)+1) {                                                                        ///// SI ES DOMINGO
                               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=#54A6E2>" + datePointer + "</font>&nbsp;</a>";
                       } else if ((dayPointer % 7 == (startAt * -1)+7 && startAt==1) || (dayPointer % 7 == startAt && startAt==0)) {   ///// SI ES SABADO
                               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=#54A6E2>" + datePointer + "</font>&nbsp;</a>";
                       } else {                                                                                                                                                        ///// CUALQUIER OTRO DIA
                               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=#000066>" + 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="#000066">' + 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, 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 = '';                                        // 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, 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;
       }
