这绝对是一个经典, 自己可以手工方便设定日历格式,显示内容,等等,只要你熟悉javascript。
这是我在项目中用到的一个例子,其中需要显示的weekno。
<!--
STEP ONE: Copy
this
code into a
new
file, save as date
-
picker.js
-->
<!-- Original: Kedar R. Bhave (softricks@hotmail.com) -->
<!-- Web Site: http: // www.softricks.com -->
<!-- This script and many more are available free online at -->
<!-- The JavaScript Source !! http: // javascript.internet.com -->
< script language = " javascript " >
var cssfile = " ../Css/calendar.css " ;
var weekend = [ 0 , 6 ];
var weekendColor = " #efefe0 " ;
var weekdayColor = " #ccddee " ;
var fontface = " Tahoma " ;
var fontsize = 2 ;
var gNow = new Date();
var ggWinCal;
isNav = (navigator.appName.indexOf( " Netscape " ) != - 1 ) ? true : false ;
isIE = (navigator.appName.indexOf( " Microsoft " ) != - 1 ) ? true : false ;
Calendar.Months = [ " January " , " February " , " March " , " April " , " May " , " June " ,
" July " , " August " , " September " , " October " , " November " , " December " ];
// Non-Leap year Month days..
Calendar.DOMonth = [ 31 , 28 , 31 , 30 , 31 , 30 , 31 , 31 , 30 , 31 , 30 , 31 ];
// Leap year Month days..
Calendar.lDOMonth = [ 31 , 29 , 31 , 30 , 31 , 30 , 31 , 31 , 30 , 31 , 30 , 31 ];
function Calendar(p_item, p_WinCal, p_month, p_year, p_format) ... {
if ((p_month == null) && (p_year == null)) return;
if (p_WinCal == null)
this.gWinCal = ggWinCal;
else
this.gWinCal = p_WinCal;
if (p_month == null) ...{
this.gMonthName = null;
this.gMonth = null;
this.gYearly = true;
} else ...{
this.gMonthName = Calendar.get_month(p_month);
this.gMonth = new Number(p_month);
this.gYearly = false;
}
this.gYear = p_year;
this.gFormat = p_format;
this.gBGColor = "white";
this.gFGColor = "black";
this.gTextColor = "black";
this.gHeaderColor = "black";
//this.gReturnItem = p_item;
this.gReturnItem = p_item;
//alert(p_item);
}
Calendar.get_month = Calendar_get_month;
Calendar.get_daysofmonth = Calendar_get_daysofmonth;
Calendar.calc_month_year = Calendar_calc_month_year;
Calendar.print = Calendar_print;
function Calendar_get_month(monthNo) ... {
return Calendar.Months[monthNo];
}
function Calendar_get_daysofmonth(monthNo, p_year) ... {
/**//*
Check for leap year ...
1.Years evenly divisible by four are normally leap years, except for...
2.Years also evenly divisible by 100 are not leap years, except for...
3.Years also evenly divisible by 400 are leap years.
*/
if ((p_year % 4) == 0) ...{
if ((p_year % 100) == 0 && (p_year % 400) != 0)
return Calendar.DOMonth[monthNo];
return Calendar.lDOMonth[monthNo];
} else
return Calendar.DOMonth[monthNo];
}
function Calendar_calc_month_year(p_Month, p_Year, incr) ... {
/**//*
Will return an 1-D array with 1st element being the calculated month
and second being the calculated year
after applying the month increment/decrement as specified by 'incr' parameter.
'incr' will normally have 1/-1 to navigate thru the months.
*/
var ret_arr = new Array();
if (incr == -1) ...{
// B A C K W A R D
if (p_Month == 0) ...{
ret_arr[0] = 11;
ret_arr[1] = parseInt(p_Year) - 1;
}
else ...{
ret_arr[0] = parseInt(p_Month) - 1;
ret_arr[1] = parseInt(p_Year);
}
} else if (incr == 1) ...{
// F O R W A R D
if (p_Month == 11) ...{
ret_arr[0] = 0;
ret_arr[1] = parseInt(p_Year) + 1;
}
else ...{
ret_arr[0] = parseInt(p_Month) + 1;
ret_arr[1] = parseInt(p_Year);
}
}
return ret_arr;
}
function Calendar_print() ... {
ggWinCal.print();
}
function Calendar_calc_month_year(p_Month, p_Year, incr) ... {
/**//*
Will return an 1-D array with 1st element being the calculated month
and second being the calculated year
after applying the month increment/decrement as specified by 'incr' parameter.
'incr' will normally have 1/-1 to navigate thru the months.
*/
var ret_arr = new Array();
if (incr == -1) ...{
// B A C K W A R D
if (p_Month == 0) ...{
ret_arr[0] = 11;
ret_arr[1] = parseInt(p_Year) - 1;
}
else ...{
ret_arr[0] = parseInt(p_Month) - 1;
ret_arr[1] = parseInt(p_Year);
}
} else if (incr == 1) ...{
// F O R W A R D
if (p_Month == 11) ...{
ret_arr[0] = 0;
ret_arr[1] = parseInt(p_Year) + 1;
}
else ...{
ret_arr[0] = parseInt(p_Month) + 1;
ret_arr[1] = parseInt(p_Year);
}
}
return ret_arr;
}
// This is for compatibility with Navigator 3, we have to create and discard one object before the prototype object exists.
new Calendar();
Calendar.prototype.getMonthlyCalendarCode = function () ... {
var vCode = "";
var vHeader_Code = "";
var vData_Code = "";
// Begin Table Drawing code here..
//modify by bss 20041029 for batch c item 120 : 200 to 220
vCode = vCode + "<TABLE width='220' border=0 cellpadding=0 cellspacing=0 class=calendarbody >";
vHeader_Code = this.cal_header();
vData_Code = this.cal_data();
vCode = vCode + vHeader_Code + vData_Code;
vCode = vCode + "</TABLE>";
return vCode;
}
Calendar.prototype.show = function () ... {
var vCode = "";
this.gWinCal.document.open();
// Setup the page...
this.wwrite("<html>");
this.wwrite("<head><title>Calendar</title>");
this.wwrite("<link rel=StyleSheet href=" + cssfile + " type='text/css' media='screen,print'> <!--");
this.wwrite("</head>");
this.wwrite("<body " + "class=calendar>");
// Show navigation buttons
var prevMMYYYY = Calendar.calc_month_year(this.gMonth, this.gYear, -1);
var prevMM = prevMMYYYY[0];
var prevYYYY = prevMMYYYY[1];
var nextMMYYYY = Calendar.calc_month_year(this.gMonth, this.gYear, 1);
var nextMM = nextMMYYYY[0];
var nextYYYY = nextMMYYYY[1];
//modify by bss 20041029 for batch c item 120 : 200 to 220
this.wwrite("<TABLE WIDTH='220' CELLSPACING=0 CELLPADDING=0 BORDER=0 CLASS=calendar><TR><TD>")
this.wwrite("<TABLE WIDTH='220' border=0 CELLSPACING=0 CELLPADDING=0 CLASS=calendarhead><TR><TD WIDTH='20' HEIGHT='20' ALIGN=center CLASS=calendarhead>");
this.wwrite("<A HREF="" +
"javascript:window.opener.Build(" +
"'" + this.gReturnItem + "', '" + this.gMonth + "', '" + (parseInt(this.gYear)-1) + "', '" + this.gFormat + "'" +
");" +
""><img src="../Image/yl_left_arrow2.gif" border=0></A></TD><TD WIDTH='20' ALIGN=center CLASS=calendarhead>");
this.wwrite("<A HREF="" +
"javascript:window.opener.Build(" +
"'" + this.gReturnItem + "', '" + prevMM + "', '" + prevYYYY + "', '" + this.gFormat + "'" +
");" +
""><img src="../Image/lb_left_arrow.gif" border=0></A></TD><TD WIDTH='120' ALIGN=center CLASS=calendarhead>");
this.wwrite("<A class=calendarhead HREF="" +
"javascript:window.resizeTo(700,540);window.moveTo(40,20);window.opener.Build(" +
"'" + this.gReturnItem + "', null, '" + prevYYYY + "', '" + this.gFormat + "'" +
");" +
"">");
this.wwriteA(this.gMonthName + ", " + this.gYear);
this.wwriteA("</a></TD><TD WIDTH='20' ALIGN=center CLASS=calendarhead>");
// this.wwrite("<A HREF="javascript:window.print();">Print</A></TD><TD ALIGN=center>");
this.wwrite("<A HREF="" +
"javascript:window.opener.Build(" +
"'" + this.gReturnItem + "', '" + nextMM + "', '" + nextYYYY + "', '" + this.gFormat + "'" +
");" +
""><img src="../Image/lb_right_arrow.gif" border=0></A></TD><TD WIDTH='20' ALIGN=center CLASS=calendarhead>");
this.wwrite("<A HREF="" +
"javascript:window.opener.Build(" +
"'" + this.gReturnItem + "', '" + this.gMonth + "', '" + (parseInt(this.gYear)+1) + "', '" + this.gFormat + "'" +
");" +
""><img src="../Image/yl_right_arrow2.gif" border=0></A></TD></TR></TABLE>");
// Get the complete calendar code for the month..
vCode = this.getMonthlyCalendarCode();
this.wwrite(vCode);
this.wwrite("</td></tr></table></body></html>");
this.gWinCal.document.close();
}
Calendar.prototype.showY = function () ... {
var vCode = "";
var i;
var vr, vc, vx, vy; // Row, Column, X-coord, Y-coord
var vxf = 285; // X-Factor
//modify by bss 20041029 for batch c item 120 : 200 to 220
var vyf = 220; // Y-Factor
var vxm = 10; // X-margin
var vym; // Y-margin
if (isIE) vym = 75;
else if (isNav) vym = 25;
this.gWinCal.document.open();
this.wwrite("<html>");
this.wwrite("<head><title>Calendar</title>");
this.wwrite("<link rel=StyleSheet href=" + cssfile + " type='text/css' media='screen,print'> <!--");
for (i=0; i<12; i++) ...{
vc = i % 3;
if (i>=0 && i<= 2) vr = 0;
if (i>=3 && i<= 5) vr = 1;
if (i>=6 && i<= 8) vr = 2;
if (i>=9 && i<= 11) vr = 3;
vx = parseInt(vxf * vc) + vxm;
vy = parseInt(vyf * vr) + vym;
this.wwrite(".lclass" + i + " {position:absolute;top:" + vy + ";left:" + vx + ";}");
}
this.wwrite("--> </style>");
this.wwrite("</head>");
this.wwrite("<body class=calendar>");
// Show navigation buttons
var prevYYYY = parseInt(this.gYear) - 1;
var nextYYYY = parseInt(this.gYear) + 1;
var curYYYY = new String(gNow.getFullYear().toString());
var curMM = new String(gNow.getMonth());
this.wwrite("<TABLE WIDTH='100%' frame=below CELLSPACING=0 CELLPADDING=0 class=calendarbar><TR><TD ALIGN=left>");
this.wwrite("<A HREF="" +
"javascript:window.opener.Build(" +
"'" + this.gReturnItem + "', null, '" + prevYYYY + "', '" + this.gFormat + "'" +
");" +
"" alt='Prev Year'><img src="../Image/yl_left_arrow2.gif" border=0></A>");
this.wwrite("</TD><TD ALIGN=center>");
this.wwrite("<A class=calendarbar HREF="" +
"javascript:window.moveTo(500,230);window.resizeTo(230,153);window.opener.Build(" +
"'" + this.gReturnItem + "','"+ curMM + "', '" + curYYYY + "', '" + this.gFormat + "'" +
");" +
"" alt='Switch Calendar'>");
this.wwrite(this.gYear + "</A>");
this.wwrite("<A HREF="javascript:window.print();"><img src="../Image/printer.gif" border=0></A>");
this.wwrite("</TD><TD ALIGN=right>");
this.wwrite("<A HREF="" +
"javascript:window.opener.Build(" +
"'" + this.gReturnItem + "', null, '" + nextYYYY + "', '" + this.gFormat + "'" +
");" +
""><img src="../Image/yl_right_arrow2.gif" border=0></A>");
this.wwrite("</TD></TABLE>");
// Get the complete calendar code for each month..
var j;
for (i=11; i>=0; i--) ...{
if (isIE)
this.wwrite("<DIV ID="layer" + i + "" CLASS="lclass" + i + "">");
else if (isNav)
this.wwrite("<LAYER ID="layer" + i + "" CLASS="lclass" + i + "">");
this.gMonth = i;
this.gMonthName = Calendar.get_month(this.gMonth);
vCode = this.getMonthlyCalendarCode();
//modify by bss 20041029 for batch c item 120 : 200 to 220
this.wwrite("<TABLE WIDTH='220' CELLSPACING=0 CELLPADDING=0 BORDER=0 CLASS=calendar><TR><TD align=left>")
this.wwrite(this.gMonthName + "</TD></TR><TR>");
this.wwrite(vCode);
this.wwrite("</TR></table>");
if (isIE)
this.wwrite("</DIV>");
else if (isNav)
this.wwrite("</LAYER>");
}
this.wwrite("</body></html>");
this.gWinCal.document.close();
}
Calendar.prototype.wwrite = function (wtext) ... {
this.gWinCal.document.writeln(wtext);
}
Calendar.prototype.wwriteA = function (wtext) ... {
this.gWinCal.document.write(wtext);
}
Calendar.prototype.cal_header = function () ... {
var vCode = "";
vCode = vCode + "<TR>";
//Modified by bss
//vCode = vCode + "<TD WIDTH='14%' CLASS=sunday ALIGN='CENTER'>Sun</TD>";
//modify by bss 20041029 for batch c item 120
vCode = vCode + "<TD WIDTH='12%' CLASS=weekday ALIGN='CENTER'>WKNo.</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=weekday ALIGN='CENTER'>Mon</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=weekday ALIGN='CENTER'>Tue</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=weekday ALIGN='CENTER'>Wed</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=weekday ALIGN='CENTER'>Thu</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=weekday ALIGN='CENTER'>Fri</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=sunday ALIGN='CENTER'>Sat</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=sunday ALIGN='CENTER'>Sun</TD>";
vCode = vCode + "</TR>";
return vCode;
}
Calendar.prototype.getWeekNo = function (iMonth,iDay,iYear) ... {
/**//*
iMonth: 0~~11
Calendar.get_month = Calendar_get_month;
Calendar.get_daysofmonth = Calendar_get_daysofmonth;
Calendar.calc_month_year = Calendar_calc_month_year;
iday : 1~~31
return week number
*/
var nowDate= new Date();
nowDate.setDate(iDay);
nowDate.setMonth(iMonth);
nowDate.setFullYear(iYear);
var beginYear= new Date();
beginYear.setDate(1);
beginYear.setMonth(0);
beginYear.setFullYear(iYear);
var endYear= new Date();
endYear.setDate(31);
endYear.setMonth(11);
endYear.setFullYear(iYear);
if ((iMonth==11 && iDay>=29 ) && (nowDate.getDay()==1 || nowDate.getDay()==2 || nowDate.getDay()==3 || nowDate.getDay()==6))
...{
//return (iYear+1)+'01'
return '01'
}
else if ((iMonth==0 && iDay<=3 ) && ( nowDate.getDay()==0 || nowDate.getDay()==5 || nowDate.getDay()==6))
...{
return this.getWeekNo(11,28,iYear-1)
}
else
...{
var m=0;
var n=0;
var weekno=0;
switch (beginYear.getDay())...{
case 0:
m=3;
//n=-1;
n=0;
break;
case 1:
m=2;
n=0;
break;
case 2:
m=1;
n=0;
break;
case 3:
m=0;
n=0;
break;
case 4:
m=-1;
n=0;
break;
case 5:
m=-2;
n=-1;
break;
case 6:
m=-3;
n=-1;
break;
default:
m=0;
n=0;
}
var i =0;
var iDayCount=0;
for (i=0; i<iMonth; i++) ...{
iDayCount = iDayCount + Calendar_get_daysofmonth(i,iYear);
}
iDayCount=iDayCount+iDay;
weekno = parseInt((iDayCount - m + 1) / 7) + 1 + n;
//return iYear*100+weekno;
if (weekno<10)
...{
return '0'+weekno;
}
else
...{
return weekno;
}
}
}
Calendar.prototype.cal_data = function () ... {
var vDate = new Date();
vDate.setDate(1);
vDate.setMonth(this.gMonth);
vDate.setFullYear(this.gYear);
var vWeek=0;
var vWeekNo; //add by bss 20041029 for batch c item 120
//modify by bss 20041029 for batch c item 120:var vFirstDay=vDate.getDay()-1;
var vFirstDay=vDate.getDay();
if (vFirstDay == '0') ...{
//modify by bss 20041029 for batch c item 120:if (vFirstDay == '-1') {
vFirstDay = 7;//modify by bss 20041029 for batch c item 120:6 -->7
}
var vDay=1;//The month first day
var vLastDay=Calendar.get_daysofmonth(this.gMonth, this.gYear);
var vOnLastDay=0;
var vCode = "";
/**//*
Get day for the 1st of the requested month/year..
Place as many blank cells before the 1st day of the month as necessary.
*/
vCode = vCode + "<TR>";
//modify by bss 20041029 for batch c item 120:add weekno varWeekNo
varWeekNo=this.getWeekNo(vDate.getMonth(),vDate.getDate(),vDate.getFullYear())
/**//*
vCode = vCode + "<TD WIDTH='16%' " + "ALIGN='CENTER'>" +
"<A " + " HREF='#' " +
"onClick="self.opener.document." + this.gReturnItem + ".value='" +
varWeekNo +
"';window.close();">" +
varWeekNo +
"</A>" +
"</TD>";
*/
vCode = vCode + "<TD WIDTH='12%' " + "ALIGN='CENTER'>" + varWeekNo + "</TD>";
for (i=1; i<vFirstDay; i++) ...{
vCode = vCode + "<TD WIDTH='12%' " + this.write_weekend_string(i) + "></TD>";
}
// Write rest of the 1st week
for (j=vFirstDay; j<8; j++) ...{
//modify by bss 20041029 for batch c item 120:for (j=vFirstDay; j<7; j++) {
vClass = this.format_day(vDay);
vCode = vCode + "<TD WIDTH='12%' " + vClass + "ALIGN='CENTER' >" +
"<A " + this.write_weekend_string(j) + " HREF='#' " +
//"onClick="self.opener.document." + this.gReturnItem + ".value='" +
"onClick="self.opener.document.getElementById('"+ this.gReturnItem +"').value='"+
this.format_data(vDay) +
"';window.close();">" +
vDay +
"</A>" +
"</TD>";
vDay=vDay + 1;
}
vCode = vCode + "</TR>";
vWeek = vWeek + 1;
// Write the rest of the weeks
for (k=2; k<7; k++) ...{
//modify by bss 20041029 for batch c item 120:for (k=2; k<8; k++) {
vCode = vCode + "<TR>";
vWeek = vWeek + 1;
var monDay;
if (vDate.getDay()==0)...{monDay=2+7*(k-2)} else ...{monDay=7*(k-1)+2-vDate.getDay()}
//alert (monDay);
//modify by bss 20041029 for batch c item 120:add weekno
varWeekNo=this.getWeekNo(vDate.getMonth(),monDay,vDate.getFullYear())
vCode = vCode + "<TD WIDTH='12%' " + "ALIGN='CENTER'>" + varWeekNo + "</TD>";
/**//*
vCode = vCode + "<TD WIDTH='12%' " + "ALIGN='CENTER'>" +
"<A " + " HREF='#' " +
"onClick="self.opener.document." + this.gReturnItem + ".value='" +
varWeekNo +
"';window.close();">" +
varWeekNo +
"</A>" +
"</TD>";
*/
for (j=0; j<7; j++) ...{
//modify by bss 20041029 for batch c item 120:for (j=0; j<7; j++) {
vClass = this.format_day(vDay);
vCode = vCode + "<TD WIDTH='12%' " + vClass + " ALIGN='CENTER'" + ">" +
"<A " + this.write_weekend_string(j+1) + "HREF='#' " +
//"onClick="self.opener.document." + this.gReturnItem + ".value='" +
"onClick="self.opener.document.getElementById('"+ this.gReturnItem +"').value='"+
this.format_data(vDay) +
"';window.close();">" +
vDay +
"</A>" +
"</TD>";
vDay=vDay + 1;
if (vDay > vLastDay) ...{
vOnLastDay = 1;
break;
}
}
if (j == 7) ...{
//modify by bss 20041029 for batch c item 120:if (j == 6) {
vCode = vCode + "</TR>";
}
if (vOnLastDay == 1)
//modify by bss 20041029 for batch c item 120:if (vOnLastDay == 1)
break;
}
// Fill up the rest of last week with proper blanks, so that we get proper square blocks
for (m=1; m<(7-j); m++) ...{
//modify by bss 20041029 for batch c item 120:for (m=1; m<(7-j); m++) {
if (this.gYearly)
vCode = vCode + "<TD WIDTH='12%' CLASS=afterday ALIGN='CENTER'" + this.write_weekend_string(j+m) +
"></TD>";
else
vCode = vCode + "<TD WIDTH='12%' CLASS=afterday ALIGN='CENTER'" + this.write_weekend_string(j+m) +
">" + m + "</TD>";
}
if (vWeek <= 6) ...{
//modify by bss 20041029 for batch c item 120:if (vWeek <= 5) {
vCode = vCode + "</TR>";
//vCode = vCode + "<TD WIDTH='12%' " + "ALIGN='CENTER'> </TD>";
if (this.gYearly)...{
vCode = vCode + "<TD WIDTH='12%' CLASS=afterday ALIGN='CENTER'> </TD>";
}
else ...{
//alert(varWeekNo);
//alert(vDate.getMonth() + ' ' +vDate.getFullYear())
if (vDate.getMonth()==11)
if (m>=4)
varWeekNo='02';
else
varWeekNo='01';
else
varWeekNo=this.getWeekNo(vDate.getMonth()+1,m+1,vDate.getFullYear())
vCode = vCode + "<TD WIDTH='12%' CLASS=afterday ALIGN='CENTER'>"+ varWeekNo +"</TD>";
}
for (n=m; n<(m+7); n++) ...{
//modify by bss 20041029 for batch c item 120: for (n=m; n<(m+7); n++) {
if (this.gYearly)
vCode = vCode + "<TD WIDTH='12%' CLASS=afterday ALIGN='CENTER'" + this.write_weekend_string(n) +
"></TD>";
else
vCode = vCode + "<TD WIDTH='12%' CLASS=afterday ALIGN='CENTER'" + this.write_weekend_string(n) +
">" + n + "</TD>";
}
}
return vCode;
}
Calendar.prototype.format_day = function (vday) ... {
var vNowDay = gNow.getDate();
var vNowMonth = gNow.getMonth();
var vNowYear = gNow.getFullYear();
if (vday == vNowDay && this.gMonth == vNowMonth && this.gYear == vNowYear)
return (" class=today ");
else
return ("");
}
Calendar.prototype.write_weekend_string = function (vday) ... {
var i;
//modified by bss
//04-04-04
// Return special formatting for the weekend day.
/**//*for (i=0; i<weekend.length; i++) {
if (vday == weekend[i])
return (" class=weekend ");
}
return (" class=weekday ");*/
if (vday>5)...{
//modify by bss 20041029 for batch c item 120: if (vday>=5){
return (" class=weekend ");
}
else...{
return (" class=weekday ");
}
}
Calendar.prototype.format_data = function (p_day) ... {
var vData;
var vMonth = 1 + this.gMonth;
vMonth = (vMonth.toString().length < 2) ? "0" + vMonth : vMonth;
var vMon = Calendar.get_month(this.gMonth).substr(0,1).toUpperCase() + Calendar.get_month(this.gMonth).substr(1,2).toLowerCase();
var vFMon = Calendar.get_month(this.gMonth).toUpperCase();
var vY4 = new String(this.gYear);
var vY2 = new String(this.gYear.substr(2,2));
var vDD = (p_day.toString().length < 2) ? "0" + p_day : p_day;
switch (this.gFormat) ...{
case "MM/DD/YYYY" :
vData = vMonth + "/" + vDD + "/" + vY4;
break;
case "MM/DD/YY" :
vData = vMonth + "/" + vDD + "/" + vY2;
break;
case "MM-DD-YYYY" :
vData = vMonth + "-" + vDD + "-" + vY4;
break;
case "MM-DD-YY" :
vData = vMonth + "-" + vDD + "-" + vY2;
break;
case "DD/MON/YYYY" :
vData = vDD + "/" + vMon + "/" + vY4;
break;
case "DD/MON/YY" :
vData = vDD + "/" + vMon + "/" + vY2;
break;
case "DD-MON-YYYY" :
vData = vDD + "-" + vMon + "-" + vY4;
break;
case "DD-MON-YY" :
vData = vDD + "-" + vMon + "-" + vY2;
break;
case "DD/MONTH/YYYY" :
vData = vDD + "/" + vFMon + "/" + vY4;
break;
case "DD/MONTH/YY" :
vData = vDD + "/" + vFMon + "/" + vY2;
break;
case "DD-MONTH-YYYY" :
vData = vDD + "-" + vFMon + "-" + vY4;
break;
case "DD-MONTH-YY" :
vData = vDD + "-" + vFMon + "-" + vY2;
break;
case "DD/MM/YYYY" :
vData = vDD + "/" + vMonth + "/" + vY4;
break;
case "DD/MM/YY" :
vData = vDD + "/" + vMonth + "/" + vY2;
break;
case "DD-MM-YYYY" :
vData = vDD + "-" + vMonth + "-" + vY4;
break;
case "DD-MM-YY" :
vData = vDD + "-" + vMonth + "-" + vY2;
break;
case "YYYY-MM-DD" :
vData = vY4 + "-" + vMonth + "-" + vDD;
break;
case "yyyy-MM-dd" :
vData = vY4 + "-" + vMonth + "-" + vDD;
break;
//defined by zhang zi 2006/12/12
case "yyyy/MM/dd" :
vData = vY4 + "/" + vMonth + "/" + vDD;
break;
default :
//vData = vMonth + "/" + vDD + "/" + vY4;
vData = vY4 + "-" + vMonth + "-" + vDD;
}
return vData;
}
function Build(p_item, p_month, p_year, p_format) ... {
var p_WinCal;
if (ggWinCal !=null)
p_WinCal = ggWinCal;
else
...{
vWinCal = self.open("", "Calendar",
"width=220,height=123,status=no,resizable=no,top=245,left=500");
vWinCal.opener = self;
ggWinCal = vWinCal;
p_WinCal = ggWinCal;
}
gCal = new Calendar(p_item, p_WinCal, p_month, p_year, p_format);
// Customize your Calendar here..
gCal.gBGColor="white";
gCal.gLinkColor="black";
gCal.gTextColor="black";
gCal.gHeaderColor="darkgreen";
// Choose appropriate show function
if (gCal.gYearly) gCal.showY();
else gCal.show();
}
function show_calendar(p_item, p_month, p_year, p_format) ... {
/**//*
p_month : 0-11 for Jan-Dec; 12 for All Months.
p_year : 4-digit year
p_format: Date format (mm/dd/yyyy, dd/mm/yy, ...)
p_item : Return Item.
*/
p_item = arguments[0];
if (arguments[1] == null)
p_month = new String(gNow.getMonth());
else
p_month = arguments[1];
if (arguments[2] == "" || arguments[2] == null)
p_year = new String(gNow.getFullYear().toString());
else
p_year = arguments[2];
if (arguments[3] == null)
p_format = "MM/DD/YYYY";
else
p_format = arguments[3];
vWinCal = window.open("", "Calendar",
"width=220,height=123,status=no,resizable=no,top=245,left=500");
vWinCal.opener = self;
ggWinCal = vWinCal;
Build(p_item, p_month, p_year, p_format);
}
/**/ /*
Yearly Calendar Code Starts here
*/
function show_yearly_calendar(p_item, p_year, p_format) ... {
// Load the defaults..
if (p_year == null || p_year == "")
p_year = new String(gNow.getFullYear().toString());
if (p_format == null || p_format == "")
p_format = "MM/DD/YYYY";
var vWinCal = window.open("", "Calendar", "width=700,height=520,top=20,left=50,resizable=no");
vWinCal.opener = self;
ggWinCal = vWinCal;
Build(p_item, null, p_year, p_format);
}
</ script >
<!-- Original: Kedar R. Bhave (softricks@hotmail.com) -->
<!-- Web Site: http: // www.softricks.com -->
<!-- This script and many more are available free online at -->
<!-- The JavaScript Source !! http: // javascript.internet.com -->
< script language = " javascript " >
var cssfile = " ../Css/calendar.css " ;
var weekend = [ 0 , 6 ];
var weekendColor = " #efefe0 " ;
var weekdayColor = " #ccddee " ;
var fontface = " Tahoma " ;
var fontsize = 2 ;
var gNow = new Date();
var ggWinCal;
isNav = (navigator.appName.indexOf( " Netscape " ) != - 1 ) ? true : false ;
isIE = (navigator.appName.indexOf( " Microsoft " ) != - 1 ) ? true : false ;
Calendar.Months = [ " January " , " February " , " March " , " April " , " May " , " June " ,
" July " , " August " , " September " , " October " , " November " , " December " ];
// Non-Leap year Month days..
Calendar.DOMonth = [ 31 , 28 , 31 , 30 , 31 , 30 , 31 , 31 , 30 , 31 , 30 , 31 ];
// Leap year Month days..
Calendar.lDOMonth = [ 31 , 29 , 31 , 30 , 31 , 30 , 31 , 31 , 30 , 31 , 30 , 31 ];
function Calendar(p_item, p_WinCal, p_month, p_year, p_format) ... {
if ((p_month == null) && (p_year == null)) return;
if (p_WinCal == null)
this.gWinCal = ggWinCal;
else
this.gWinCal = p_WinCal;
if (p_month == null) ...{
this.gMonthName = null;
this.gMonth = null;
this.gYearly = true;
} else ...{
this.gMonthName = Calendar.get_month(p_month);
this.gMonth = new Number(p_month);
this.gYearly = false;
}
this.gYear = p_year;
this.gFormat = p_format;
this.gBGColor = "white";
this.gFGColor = "black";
this.gTextColor = "black";
this.gHeaderColor = "black";
//this.gReturnItem = p_item;
this.gReturnItem = p_item;
//alert(p_item);
}
Calendar.get_month = Calendar_get_month;
Calendar.get_daysofmonth = Calendar_get_daysofmonth;
Calendar.calc_month_year = Calendar_calc_month_year;
Calendar.print = Calendar_print;
function Calendar_get_month(monthNo) ... {
return Calendar.Months[monthNo];
}
function Calendar_get_daysofmonth(monthNo, p_year) ... {
/**//*
Check for leap year ...
1.Years evenly divisible by four are normally leap years, except for...
2.Years also evenly divisible by 100 are not leap years, except for...
3.Years also evenly divisible by 400 are leap years.
*/
if ((p_year % 4) == 0) ...{
if ((p_year % 100) == 0 && (p_year % 400) != 0)
return Calendar.DOMonth[monthNo];
return Calendar.lDOMonth[monthNo];
} else
return Calendar.DOMonth[monthNo];
}
function Calendar_calc_month_year(p_Month, p_Year, incr) ... {
/**//*
Will return an 1-D array with 1st element being the calculated month
and second being the calculated year
after applying the month increment/decrement as specified by 'incr' parameter.
'incr' will normally have 1/-1 to navigate thru the months.
*/
var ret_arr = new Array();
if (incr == -1) ...{
// B A C K W A R D
if (p_Month == 0) ...{
ret_arr[0] = 11;
ret_arr[1] = parseInt(p_Year) - 1;
}
else ...{
ret_arr[0] = parseInt(p_Month) - 1;
ret_arr[1] = parseInt(p_Year);
}
} else if (incr == 1) ...{
// F O R W A R D
if (p_Month == 11) ...{
ret_arr[0] = 0;
ret_arr[1] = parseInt(p_Year) + 1;
}
else ...{
ret_arr[0] = parseInt(p_Month) + 1;
ret_arr[1] = parseInt(p_Year);
}
}
return ret_arr;
}
function Calendar_print() ... {
ggWinCal.print();
}
function Calendar_calc_month_year(p_Month, p_Year, incr) ... {
/**//*
Will return an 1-D array with 1st element being the calculated month
and second being the calculated year
after applying the month increment/decrement as specified by 'incr' parameter.
'incr' will normally have 1/-1 to navigate thru the months.
*/
var ret_arr = new Array();
if (incr == -1) ...{
// B A C K W A R D
if (p_Month == 0) ...{
ret_arr[0] = 11;
ret_arr[1] = parseInt(p_Year) - 1;
}
else ...{
ret_arr[0] = parseInt(p_Month) - 1;
ret_arr[1] = parseInt(p_Year);
}
} else if (incr == 1) ...{
// F O R W A R D
if (p_Month == 11) ...{
ret_arr[0] = 0;
ret_arr[1] = parseInt(p_Year) + 1;
}
else ...{
ret_arr[0] = parseInt(p_Month) + 1;
ret_arr[1] = parseInt(p_Year);
}
}
return ret_arr;
}
// This is for compatibility with Navigator 3, we have to create and discard one object before the prototype object exists.
new Calendar();
Calendar.prototype.getMonthlyCalendarCode = function () ... {
var vCode = "";
var vHeader_Code = "";
var vData_Code = "";
// Begin Table Drawing code here..
//modify by bss 20041029 for batch c item 120 : 200 to 220
vCode = vCode + "<TABLE width='220' border=0 cellpadding=0 cellspacing=0 class=calendarbody >";
vHeader_Code = this.cal_header();
vData_Code = this.cal_data();
vCode = vCode + vHeader_Code + vData_Code;
vCode = vCode + "</TABLE>";
return vCode;
}
Calendar.prototype.show = function () ... {
var vCode = "";
this.gWinCal.document.open();
// Setup the page...
this.wwrite("<html>");
this.wwrite("<head><title>Calendar</title>");
this.wwrite("<link rel=StyleSheet href=" + cssfile + " type='text/css' media='screen,print'> <!--");
this.wwrite("</head>");
this.wwrite("<body " + "class=calendar>");
// Show navigation buttons
var prevMMYYYY = Calendar.calc_month_year(this.gMonth, this.gYear, -1);
var prevMM = prevMMYYYY[0];
var prevYYYY = prevMMYYYY[1];
var nextMMYYYY = Calendar.calc_month_year(this.gMonth, this.gYear, 1);
var nextMM = nextMMYYYY[0];
var nextYYYY = nextMMYYYY[1];
//modify by bss 20041029 for batch c item 120 : 200 to 220
this.wwrite("<TABLE WIDTH='220' CELLSPACING=0 CELLPADDING=0 BORDER=0 CLASS=calendar><TR><TD>")
this.wwrite("<TABLE WIDTH='220' border=0 CELLSPACING=0 CELLPADDING=0 CLASS=calendarhead><TR><TD WIDTH='20' HEIGHT='20' ALIGN=center CLASS=calendarhead>");
this.wwrite("<A HREF="" +
"javascript:window.opener.Build(" +
"'" + this.gReturnItem + "', '" + this.gMonth + "', '" + (parseInt(this.gYear)-1) + "', '" + this.gFormat + "'" +
");" +
""><img src="../Image/yl_left_arrow2.gif" border=0></A></TD><TD WIDTH='20' ALIGN=center CLASS=calendarhead>");
this.wwrite("<A HREF="" +
"javascript:window.opener.Build(" +
"'" + this.gReturnItem + "', '" + prevMM + "', '" + prevYYYY + "', '" + this.gFormat + "'" +
");" +
""><img src="../Image/lb_left_arrow.gif" border=0></A></TD><TD WIDTH='120' ALIGN=center CLASS=calendarhead>");
this.wwrite("<A class=calendarhead HREF="" +
"javascript:window.resizeTo(700,540);window.moveTo(40,20);window.opener.Build(" +
"'" + this.gReturnItem + "', null, '" + prevYYYY + "', '" + this.gFormat + "'" +
");" +
"">");
this.wwriteA(this.gMonthName + ", " + this.gYear);
this.wwriteA("</a></TD><TD WIDTH='20' ALIGN=center CLASS=calendarhead>");
// this.wwrite("<A HREF="javascript:window.print();">Print</A></TD><TD ALIGN=center>");
this.wwrite("<A HREF="" +
"javascript:window.opener.Build(" +
"'" + this.gReturnItem + "', '" + nextMM + "', '" + nextYYYY + "', '" + this.gFormat + "'" +
");" +
""><img src="../Image/lb_right_arrow.gif" border=0></A></TD><TD WIDTH='20' ALIGN=center CLASS=calendarhead>");
this.wwrite("<A HREF="" +
"javascript:window.opener.Build(" +
"'" + this.gReturnItem + "', '" + this.gMonth + "', '" + (parseInt(this.gYear)+1) + "', '" + this.gFormat + "'" +
");" +
""><img src="../Image/yl_right_arrow2.gif" border=0></A></TD></TR></TABLE>");
// Get the complete calendar code for the month..
vCode = this.getMonthlyCalendarCode();
this.wwrite(vCode);
this.wwrite("</td></tr></table></body></html>");
this.gWinCal.document.close();
}
Calendar.prototype.showY = function () ... {
var vCode = "";
var i;
var vr, vc, vx, vy; // Row, Column, X-coord, Y-coord
var vxf = 285; // X-Factor
//modify by bss 20041029 for batch c item 120 : 200 to 220
var vyf = 220; // Y-Factor
var vxm = 10; // X-margin
var vym; // Y-margin
if (isIE) vym = 75;
else if (isNav) vym = 25;
this.gWinCal.document.open();
this.wwrite("<html>");
this.wwrite("<head><title>Calendar</title>");
this.wwrite("<link rel=StyleSheet href=" + cssfile + " type='text/css' media='screen,print'> <!--");
for (i=0; i<12; i++) ...{
vc = i % 3;
if (i>=0 && i<= 2) vr = 0;
if (i>=3 && i<= 5) vr = 1;
if (i>=6 && i<= 8) vr = 2;
if (i>=9 && i<= 11) vr = 3;
vx = parseInt(vxf * vc) + vxm;
vy = parseInt(vyf * vr) + vym;
this.wwrite(".lclass" + i + " {position:absolute;top:" + vy + ";left:" + vx + ";}");
}
this.wwrite("--> </style>");
this.wwrite("</head>");
this.wwrite("<body class=calendar>");
// Show navigation buttons
var prevYYYY = parseInt(this.gYear) - 1;
var nextYYYY = parseInt(this.gYear) + 1;
var curYYYY = new String(gNow.getFullYear().toString());
var curMM = new String(gNow.getMonth());
this.wwrite("<TABLE WIDTH='100%' frame=below CELLSPACING=0 CELLPADDING=0 class=calendarbar><TR><TD ALIGN=left>");
this.wwrite("<A HREF="" +
"javascript:window.opener.Build(" +
"'" + this.gReturnItem + "', null, '" + prevYYYY + "', '" + this.gFormat + "'" +
");" +
"" alt='Prev Year'><img src="../Image/yl_left_arrow2.gif" border=0></A>");
this.wwrite("</TD><TD ALIGN=center>");
this.wwrite("<A class=calendarbar HREF="" +
"javascript:window.moveTo(500,230);window.resizeTo(230,153);window.opener.Build(" +
"'" + this.gReturnItem + "','"+ curMM + "', '" + curYYYY + "', '" + this.gFormat + "'" +
");" +
"" alt='Switch Calendar'>");
this.wwrite(this.gYear + "</A>");
this.wwrite("<A HREF="javascript:window.print();"><img src="../Image/printer.gif" border=0></A>");
this.wwrite("</TD><TD ALIGN=right>");
this.wwrite("<A HREF="" +
"javascript:window.opener.Build(" +
"'" + this.gReturnItem + "', null, '" + nextYYYY + "', '" + this.gFormat + "'" +
");" +
""><img src="../Image/yl_right_arrow2.gif" border=0></A>");
this.wwrite("</TD></TABLE>");
// Get the complete calendar code for each month..
var j;
for (i=11; i>=0; i--) ...{
if (isIE)
this.wwrite("<DIV ID="layer" + i + "" CLASS="lclass" + i + "">");
else if (isNav)
this.wwrite("<LAYER ID="layer" + i + "" CLASS="lclass" + i + "">");
this.gMonth = i;
this.gMonthName = Calendar.get_month(this.gMonth);
vCode = this.getMonthlyCalendarCode();
//modify by bss 20041029 for batch c item 120 : 200 to 220
this.wwrite("<TABLE WIDTH='220' CELLSPACING=0 CELLPADDING=0 BORDER=0 CLASS=calendar><TR><TD align=left>")
this.wwrite(this.gMonthName + "</TD></TR><TR>");
this.wwrite(vCode);
this.wwrite("</TR></table>");
if (isIE)
this.wwrite("</DIV>");
else if (isNav)
this.wwrite("</LAYER>");
}
this.wwrite("</body></html>");
this.gWinCal.document.close();
}
Calendar.prototype.wwrite = function (wtext) ... {
this.gWinCal.document.writeln(wtext);
}
Calendar.prototype.wwriteA = function (wtext) ... {
this.gWinCal.document.write(wtext);
}
Calendar.prototype.cal_header = function () ... {
var vCode = "";
vCode = vCode + "<TR>";
//Modified by bss
//vCode = vCode + "<TD WIDTH='14%' CLASS=sunday ALIGN='CENTER'>Sun</TD>";
//modify by bss 20041029 for batch c item 120
vCode = vCode + "<TD WIDTH='12%' CLASS=weekday ALIGN='CENTER'>WKNo.</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=weekday ALIGN='CENTER'>Mon</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=weekday ALIGN='CENTER'>Tue</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=weekday ALIGN='CENTER'>Wed</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=weekday ALIGN='CENTER'>Thu</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=weekday ALIGN='CENTER'>Fri</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=sunday ALIGN='CENTER'>Sat</TD>";
vCode = vCode + "<TD WIDTH='12%' CLASS=sunday ALIGN='CENTER'>Sun</TD>";
vCode = vCode + "</TR>";
return vCode;
}
Calendar.prototype.getWeekNo = function (iMonth,iDay,iYear) ... {
/**//*
iMonth: 0~~11
Calendar.get_month = Calendar_get_month;
Calendar.get_daysofmonth = Calendar_get_daysofmonth;
Calendar.calc_month_year = Calendar_calc_month_year;
iday : 1~~31
return week number
*/
var nowDate= new Date();
nowDate.setDate(iDay);
nowDate.setMonth(iMonth);
nowDate.setFullYear(iYear);
var beginYear= new Date();
beginYear.setDate(1);
beginYear.setMonth(0);
beginYear.setFullYear(iYear);
var endYear= new Date();
endYear.setDate(31);
endYear.setMonth(11);
endYear.setFullYear(iYear);
if ((iMonth==11 && iDay>=29 ) && (nowDate.getDay()==1 || nowDate.getDay()==2 || nowDate.getDay()==3 || nowDate.getDay()==6))
...{
//return (iYear+1)+'01'
return '01'
}
else if ((iMonth==0 && iDay<=3 ) && ( nowDate.getDay()==0 || nowDate.getDay()==5 || nowDate.getDay()==6))
...{
return this.getWeekNo(11,28,iYear-1)
}
else
...{
var m=0;
var n=0;
var weekno=0;
switch (beginYear.getDay())...{
case 0:
m=3;
//n=-1;
n=0;
break;
case 1:
m=2;
n=0;
break;
case 2:
m=1;
n=0;
break;
case 3:
m=0;
n=0;
break;
case 4:
m=-1;
n=0;
break;
case 5:
m=-2;
n=-1;
break;
case 6:
m=-3;
n=-1;
break;
default:
m=0;
n=0;
}
var i =0;
var iDayCount=0;
for (i=0; i<iMonth; i++) ...{
iDayCount = iDayCount + Calendar_get_daysofmonth(i,iYear);
}
iDayCount=iDayCount+iDay;
weekno = parseInt((iDayCount - m + 1) / 7) + 1 + n;
//return iYear*100+weekno;
if (weekno<10)
...{
return '0'+weekno;
}
else
...{
return weekno;
}
}
}
Calendar.prototype.cal_data = function () ... {
var vDate = new Date();
vDate.setDate(1);
vDate.setMonth(this.gMonth);
vDate.setFullYear(this.gYear);
var vWeek=0;
var vWeekNo; //add by bss 20041029 for batch c item 120
//modify by bss 20041029 for batch c item 120:var vFirstDay=vDate.getDay()-1;
var vFirstDay=vDate.getDay();
if (vFirstDay == '0') ...{
//modify by bss 20041029 for batch c item 120:if (vFirstDay == '-1') {
vFirstDay = 7;//modify by bss 20041029 for batch c item 120:6 -->7
}
var vDay=1;//The month first day
var vLastDay=Calendar.get_daysofmonth(this.gMonth, this.gYear);
var vOnLastDay=0;
var vCode = "";
/**//*
Get day for the 1st of the requested month/year..
Place as many blank cells before the 1st day of the month as necessary.
*/
vCode = vCode + "<TR>";
//modify by bss 20041029 for batch c item 120:add weekno varWeekNo
varWeekNo=this.getWeekNo(vDate.getMonth(),vDate.getDate(),vDate.getFullYear())
/**//*
vCode = vCode + "<TD WIDTH='16%' " + "ALIGN='CENTER'>" +
"<A " + " HREF='#' " +
"onClick="self.opener.document." + this.gReturnItem + ".value='" +
varWeekNo +
"';window.close();">" +
varWeekNo +
"</A>" +
"</TD>";
*/
vCode = vCode + "<TD WIDTH='12%' " + "ALIGN='CENTER'>" + varWeekNo + "</TD>";
for (i=1; i<vFirstDay; i++) ...{
vCode = vCode + "<TD WIDTH='12%' " + this.write_weekend_string(i) + "></TD>";
}
// Write rest of the 1st week
for (j=vFirstDay; j<8; j++) ...{
//modify by bss 20041029 for batch c item 120:for (j=vFirstDay; j<7; j++) {
vClass = this.format_day(vDay);
vCode = vCode + "<TD WIDTH='12%' " + vClass + "ALIGN='CENTER' >" +
"<A " + this.write_weekend_string(j) + " HREF='#' " +
//"onClick="self.opener.document." + this.gReturnItem + ".value='" +
"onClick="self.opener.document.getElementById('"+ this.gReturnItem +"').value='"+
this.format_data(vDay) +
"';window.close();">" +
vDay +
"</A>" +
"</TD>";
vDay=vDay + 1;
}
vCode = vCode + "</TR>";
vWeek = vWeek + 1;
// Write the rest of the weeks
for (k=2; k<7; k++) ...{
//modify by bss 20041029 for batch c item 120:for (k=2; k<8; k++) {
vCode = vCode + "<TR>";
vWeek = vWeek + 1;
var monDay;
if (vDate.getDay()==0)...{monDay=2+7*(k-2)} else ...{monDay=7*(k-1)+2-vDate.getDay()}
//alert (monDay);
//modify by bss 20041029 for batch c item 120:add weekno
varWeekNo=this.getWeekNo(vDate.getMonth(),monDay,vDate.getFullYear())
vCode = vCode + "<TD WIDTH='12%' " + "ALIGN='CENTER'>" + varWeekNo + "</TD>";
/**//*
vCode = vCode + "<TD WIDTH='12%' " + "ALIGN='CENTER'>" +
"<A " + " HREF='#' " +
"onClick="self.opener.document." + this.gReturnItem + ".value='" +
varWeekNo +
"';window.close();">" +
varWeekNo +
"</A>" +
"</TD>";
*/
for (j=0; j<7; j++) ...{
//modify by bss 20041029 for batch c item 120:for (j=0; j<7; j++) {
vClass = this.format_day(vDay);
vCode = vCode + "<TD WIDTH='12%' " + vClass + " ALIGN='CENTER'" + ">" +
"<A " + this.write_weekend_string(j+1) + "HREF='#' " +
//"onClick="self.opener.document." + this.gReturnItem + ".value='" +
"onClick="self.opener.document.getElementById('"+ this.gReturnItem +"').value='"+
this.format_data(vDay) +
"';window.close();">" +
vDay +
"</A>" +
"</TD>";
vDay=vDay + 1;
if (vDay > vLastDay) ...{
vOnLastDay = 1;
break;
}
}
if (j == 7) ...{
//modify by bss 20041029 for batch c item 120:if (j == 6) {
vCode = vCode + "</TR>";
}
if (vOnLastDay == 1)
//modify by bss 20041029 for batch c item 120:if (vOnLastDay == 1)
break;
}
// Fill up the rest of last week with proper blanks, so that we get proper square blocks
for (m=1; m<(7-j); m++) ...{
//modify by bss 20041029 for batch c item 120:for (m=1; m<(7-j); m++) {
if (this.gYearly)
vCode = vCode + "<TD WIDTH='12%' CLASS=afterday ALIGN='CENTER'" + this.write_weekend_string(j+m) +
"></TD>";
else
vCode = vCode + "<TD WIDTH='12%' CLASS=afterday ALIGN='CENTER'" + this.write_weekend_string(j+m) +
">" + m + "</TD>";
}
if (vWeek <= 6) ...{
//modify by bss 20041029 for batch c item 120:if (vWeek <= 5) {
vCode = vCode + "</TR>";
//vCode = vCode + "<TD WIDTH='12%' " + "ALIGN='CENTER'> </TD>";
if (this.gYearly)...{
vCode = vCode + "<TD WIDTH='12%' CLASS=afterday ALIGN='CENTER'> </TD>";
}
else ...{
//alert(varWeekNo);
//alert(vDate.getMonth() + ' ' +vDate.getFullYear())
if (vDate.getMonth()==11)
if (m>=4)
varWeekNo='02';
else
varWeekNo='01';
else
varWeekNo=this.getWeekNo(vDate.getMonth()+1,m+1,vDate.getFullYear())
vCode = vCode + "<TD WIDTH='12%' CLASS=afterday ALIGN='CENTER'>"+ varWeekNo +"</TD>";
}
for (n=m; n<(m+7); n++) ...{
//modify by bss 20041029 for batch c item 120: for (n=m; n<(m+7); n++) {
if (this.gYearly)
vCode = vCode + "<TD WIDTH='12%' CLASS=afterday ALIGN='CENTER'" + this.write_weekend_string(n) +
"></TD>";
else
vCode = vCode + "<TD WIDTH='12%' CLASS=afterday ALIGN='CENTER'" + this.write_weekend_string(n) +
">" + n + "</TD>";
}
}
return vCode;
}
Calendar.prototype.format_day = function (vday) ... {
var vNowDay = gNow.getDate();
var vNowMonth = gNow.getMonth();
var vNowYear = gNow.getFullYear();
if (vday == vNowDay && this.gMonth == vNowMonth && this.gYear == vNowYear)
return (" class=today ");
else
return ("");
}
Calendar.prototype.write_weekend_string = function (vday) ... {
var i;
//modified by bss
//04-04-04
// Return special formatting for the weekend day.
/**//*for (i=0; i<weekend.length; i++) {
if (vday == weekend[i])
return (" class=weekend ");
}
return (" class=weekday ");*/
if (vday>5)...{
//modify by bss 20041029 for batch c item 120: if (vday>=5){
return (" class=weekend ");
}
else...{
return (" class=weekday ");
}
}
Calendar.prototype.format_data = function (p_day) ... {
var vData;
var vMonth = 1 + this.gMonth;
vMonth = (vMonth.toString().length < 2) ? "0" + vMonth : vMonth;
var vMon = Calendar.get_month(this.gMonth).substr(0,1).toUpperCase() + Calendar.get_month(this.gMonth).substr(1,2).toLowerCase();
var vFMon = Calendar.get_month(this.gMonth).toUpperCase();
var vY4 = new String(this.gYear);
var vY2 = new String(this.gYear.substr(2,2));
var vDD = (p_day.toString().length < 2) ? "0" + p_day : p_day;
switch (this.gFormat) ...{
case "MM/DD/YYYY" :
vData = vMonth + "/" + vDD + "/" + vY4;
break;
case "MM/DD/YY" :
vData = vMonth + "/" + vDD + "/" + vY2;
break;
case "MM-DD-YYYY" :
vData = vMonth + "-" + vDD + "-" + vY4;
break;
case "MM-DD-YY" :
vData = vMonth + "-" + vDD + "-" + vY2;
break;
case "DD/MON/YYYY" :
vData = vDD + "/" + vMon + "/" + vY4;
break;
case "DD/MON/YY" :
vData = vDD + "/" + vMon + "/" + vY2;
break;
case "DD-MON-YYYY" :
vData = vDD + "-" + vMon + "-" + vY4;
break;
case "DD-MON-YY" :
vData = vDD + "-" + vMon + "-" + vY2;
break;
case "DD/MONTH/YYYY" :
vData = vDD + "/" + vFMon + "/" + vY4;
break;
case "DD/MONTH/YY" :
vData = vDD + "/" + vFMon + "/" + vY2;
break;
case "DD-MONTH-YYYY" :
vData = vDD + "-" + vFMon + "-" + vY4;
break;
case "DD-MONTH-YY" :
vData = vDD + "-" + vFMon + "-" + vY2;
break;
case "DD/MM/YYYY" :
vData = vDD + "/" + vMonth + "/" + vY4;
break;
case "DD/MM/YY" :
vData = vDD + "/" + vMonth + "/" + vY2;
break;
case "DD-MM-YYYY" :
vData = vDD + "-" + vMonth + "-" + vY4;
break;
case "DD-MM-YY" :
vData = vDD + "-" + vMonth + "-" + vY2;
break;
case "YYYY-MM-DD" :
vData = vY4 + "-" + vMonth + "-" + vDD;
break;
case "yyyy-MM-dd" :
vData = vY4 + "-" + vMonth + "-" + vDD;
break;
//defined by zhang zi 2006/12/12
case "yyyy/MM/dd" :
vData = vY4 + "/" + vMonth + "/" + vDD;
break;
default :
//vData = vMonth + "/" + vDD + "/" + vY4;
vData = vY4 + "-" + vMonth + "-" + vDD;
}
return vData;
}
function Build(p_item, p_month, p_year, p_format) ... {
var p_WinCal;
if (ggWinCal !=null)
p_WinCal = ggWinCal;
else
...{
vWinCal = self.open("", "Calendar",
"width=220,height=123,status=no,resizable=no,top=245,left=500");
vWinCal.opener = self;
ggWinCal = vWinCal;
p_WinCal = ggWinCal;
}
gCal = new Calendar(p_item, p_WinCal, p_month, p_year, p_format);
// Customize your Calendar here..
gCal.gBGColor="white";
gCal.gLinkColor="black";
gCal.gTextColor="black";
gCal.gHeaderColor="darkgreen";
// Choose appropriate show function
if (gCal.gYearly) gCal.showY();
else gCal.show();
}
function show_calendar(p_item, p_month, p_year, p_format) ... {
/**//*
p_month : 0-11 for Jan-Dec; 12 for All Months.
p_year : 4-digit year
p_format: Date format (mm/dd/yyyy, dd/mm/yy, ...)
p_item : Return Item.
*/
p_item = arguments[0];
if (arguments[1] == null)
p_month = new String(gNow.getMonth());
else
p_month = arguments[1];
if (arguments[2] == "" || arguments[2] == null)
p_year = new String(gNow.getFullYear().toString());
else
p_year = arguments[2];
if (arguments[3] == null)
p_format = "MM/DD/YYYY";
else
p_format = arguments[3];
vWinCal = window.open("", "Calendar",
"width=220,height=123,status=no,resizable=no,top=245,left=500");
vWinCal.opener = self;
ggWinCal = vWinCal;
Build(p_item, p_month, p_year, p_format);
}
/**/ /*
Yearly Calendar Code Starts here
*/
function show_yearly_calendar(p_item, p_year, p_format) ... {
// Load the defaults..
if (p_year == null || p_year == "")
p_year = new String(gNow.getFullYear().toString());
if (p_format == null || p_format == "")
p_format = "MM/DD/YYYY";
var vWinCal = window.open("", "Calendar", "width=700,height=520,top=20,left=50,resizable=no");
vWinCal.opener = self;
ggWinCal = vWinCal;
Build(p_item, null, p_year, p_format);
}
</ script >
css文件:
body.calendar
{...} {
margin-left:0;
margin-top:0;
margin-right:0;
margin-bottom:0;
background-color:#e4f5fb;
}
a:link {...} { text-decoration: none;}
a:visited {...} { text-decoration: none;}
table.calendar
{...} {
background-color:white;
font-size:12;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
border-color:#336699;
font-weight:bold;
color:rgb(20%,20%,20%);
}
table.calendarhead
{...} {
background-color:#000080;
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
font-weight:bold;
color:white;
}
td.calendarhead
{...} {
background-color:#000080;
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
font-weight:bold;
color:white;
}
a.calendarhead
{...} {
background-color:#000080;
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
font-weight:bold;
color:white;
}
table.calendarbody
{...} {
background-color:white;
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:black;
}
td.weekday
{...} {
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:#000080;
}
td.sunday
{...} {
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:red;
}
a.weekend
{...} {
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:red;
}
a.weekday
{...} {
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:black;
}
td.afterday
{...} {
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:rgb(60%,60%,60%);
background-color:white;
}
td.today
{...} {
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:darkblue;
background-attachment: fixed;
background-image: url("../images/today.gif");
background-repeat: no-repeat;
margin-left:-4;
}
div.lclass0 {...} {position:absolute;top:30;left:5;}
div.lclass1 {...} {position:absolute;top:30;left:235;}
div.lclass2 {...} {position:absolute;top:30;left:465;}
div.lclass3 {...} {position:absolute;top:150;left:5;}
div.lclass4 {...} {position:absolute;top:150;left:235;}
div.lclass5 {...} {position:absolute;top:150;left:465;}
div.lclass6 {...} {position:absolute;top:270;left:5;}
div.lclass7 {...} {position:absolute;top:270;left:235;}
div.lclass8 {...} {position:absolute;top:270;left:465;}
div.lclass9 {...} {position:absolute;top:390;left:5;}
div.lclass10 {...} {position:absolute;top:390;left:235;}
div.lclass11 {...} {position:absolute;top:390;left:465;}
p.eachmonth
{...} {
font-size:12;
font-family:verdana, Arial, Helvetica, Geneva,sans-serif;
font-weight:bold;
color:#000080;
}
table.calendarbar
{...} {
background-color:rgb(90%,90%,90%);
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
font-weight:bold;
color:#000080;
}
a.calendarbar
{...} {
font-size:12;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
font-weight:bold;
color:#000008;
}
{...} {
margin-left:0;
margin-top:0;
margin-right:0;
margin-bottom:0;
background-color:#e4f5fb;
}
a:link {...} { text-decoration: none;}
a:visited {...} { text-decoration: none;}
table.calendar
{...} {
background-color:white;
font-size:12;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
border-color:#336699;
font-weight:bold;
color:rgb(20%,20%,20%);
}
table.calendarhead
{...} {
background-color:#000080;
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
font-weight:bold;
color:white;
}
td.calendarhead
{...} {
background-color:#000080;
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
font-weight:bold;
color:white;
}
a.calendarhead
{...} {
background-color:#000080;
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
font-weight:bold;
color:white;
}
table.calendarbody
{...} {
background-color:white;
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:black;
}
td.weekday
{...} {
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:#000080;
}
td.sunday
{...} {
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:red;
}
a.weekend
{...} {
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:red;
}
a.weekday
{...} {
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:black;
}
td.afterday
{...} {
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:rgb(60%,60%,60%);
background-color:white;
}
td.today
{...} {
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
color:darkblue;
background-attachment: fixed;
background-image: url("../images/today.gif");
background-repeat: no-repeat;
margin-left:-4;
}
div.lclass0 {...} {position:absolute;top:30;left:5;}
div.lclass1 {...} {position:absolute;top:30;left:235;}
div.lclass2 {...} {position:absolute;top:30;left:465;}
div.lclass3 {...} {position:absolute;top:150;left:5;}
div.lclass4 {...} {position:absolute;top:150;left:235;}
div.lclass5 {...} {position:absolute;top:150;left:465;}
div.lclass6 {...} {position:absolute;top:270;left:5;}
div.lclass7 {...} {position:absolute;top:270;left:235;}
div.lclass8 {...} {position:absolute;top:270;left:465;}
div.lclass9 {...} {position:absolute;top:390;left:5;}
div.lclass10 {...} {position:absolute;top:390;left:235;}
div.lclass11 {...} {position:absolute;top:390;left:465;}
p.eachmonth
{...} {
font-size:12;
font-family:verdana, Arial, Helvetica, Geneva,sans-serif;
font-weight:bold;
color:#000080;
}
table.calendarbar
{...} {
background-color:rgb(90%,90%,90%);
font-size:11;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
font-weight:bold;
color:#000080;
}
a.calendarbar
{...} {
font-size:12;
font-family:sans-serif, verdana, Arial, Helvetica, Geneva,sans-serif;
font-weight:bold;
color:#000008;
}