var timeoutDelay = 1000; // milliseconds, change this if you like, set to 0 for the calendar to never auto disappear
var g_startDay = 0// 0=sunday, 1=monday
// preload images
var imgUp = new Image(8,12);
imgUp.src = '/BagicNxt/images/up.gif';
var imgDown = new Image(8,12);
imgDown.src = '/BagicNxt/images/down.gif';
// used by timeout auto hide functions
var timeoutId = false;
// the now standard browser sniffer class
function Browser(){
this.dom = document.getElementById?1:0;
this.ie4 = (document.all && !this.dom)?1:0;
this.ns4 = (document.layers && !this.dom)?1:0;
this.ns6 = (this.dom && !document.all)?1:0;
this.ie5 = (this.dom && document.all)?1:0;
this.ok = this.dom || this.ie4 || this.ns4;
this.platform = navigator.platform;
}
var browser = new Browser();
// dom browsers require this written to the HEAD section
if (browser.dom || browser.ie4){
document.writeln('')
document.write('
');
}
var g_Calendar; // global to hold the calendar reference, set by constructor
function calendarTimeout(){
if (browser.ie4 || browser.ie5){
if (window.event.srcElement && window.event.srcElement.name!='month') timeoutId=setTimeout('g_Calendar.hide();',timeoutDelay);
}
if (browser.ns6 || browser.ns4){
timeoutId=setTimeout('g_Calendar.hide();',timeoutDelay);
}
}
// constructor for calendar class
function Calendar(){
g_Calendar = this;
// some constants needed throughout the program
this.daysOfWeek = new Array("Su","Mo","Tu","We","Th","Fr","Sa");
this.months = new Array("January","February","March","April","May","June","July","August","September","October","November","December");
this.daysInMonth = new Array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
if (browser.ns4){
var tmpLayer = new Layer(127);
if (timeoutDelay){
tmpLayer.captureEvents(Event.MOUSEOVER | Event.MOUSEOUT);
tmpLayer.onmouseover = function(event) { if (timeoutId) clearTimeout(timeoutId); };
tmpLayer.onmouseout = function(event) { timeoutId=setTimeout('g_Calendar.hide()',timeoutDelay);};
}
tmpLayer.x = 100;
tmpLayer.y = 100;
tmpLayer.bgColor = "#ffffff";
}
if (browser.dom || browser.ie4){
var tmpLayer = browser.dom?document.getElementById('container'):document.all.container;
}
this.containerLayer = tmpLayer;
if (browser.ns4 && browser.platform=='Win32') {
this.containerLayer.clip.height=134;
this.containerLayer.clip.width=127;
}
}
Calendar.prototype.getFirstDOM = function() {
var thedate = new Date();
thedate.setDate(1);
thedate.setMonth(this.month);
thedate.setFullYear(this.year);
return thedate.getDay();
}
Calendar.prototype.getDaysInMonth = function (){
if (this.month!=1) {
return this.daysInMonth[this.month]
}
else {
// is it a leap year
if (Date.isLeapYear(this.year)) {
return 29;
}
else {
return 28;
}
}
}
Calendar.prototype.buildString = function(){
var tmpStr = '';
var iCount = 1;
var iFirstDOM = (7+this.getFirstDOM()-g_startDay)%7; // to prevent calling it in a loop
var iDaysInMonth = this.getDaysInMonth(); // to prevent calling it in a loop
tmpStr += '';
tmpStr += '';
for (var i=0;i<7;i++){
tmpStr += '' + this.daysOfWeek[(g_startDay+i)%7] + ' | ';
}
tmpStr += ' ';
var tmpFrom = parseInt('' + this.dateFromYear + this.dateFromMonth + this.dateFromDay,10);
var tmpTo = parseInt('' + this.dateToYear + this.dateToMonth + this.dateToDay,10);
var tmpCompare;
for (var j=1;j<=6;j++){
tmpStr += '';
for (var i=1;i<=7;i++){
tmpStr += '=iFirstDOM+1 && iCount <= iDaysInMonth){
if (iCount==this.day && this.year==this.oYear && this.month==this.oMonth) tmpStr += 'class="calHighlightColor"';
else {
if (i==7-g_startDay || i==((7-g_startDay)%7)+1) tmpStr += 'class="calWeekend"';
else tmpStr += 'class="cal"';
}
tmpStr += '>';
/* could create a date object here and compare that but probably more efficient to convert to a number
and compare number as numbers are primitives */
tmpCompare = parseInt('' + this.year + padZero(this.month) + padZero(iCount),10);
if (tmpCompare >= tmpFrom && tmpCompare <= tmpTo) {
tmpStr += '' + iCount + '';
} else {
tmpStr += '' + iCount + '';
}
iCount++;
} else {
if (i==7-g_startDay || i==((7-g_startDay)%7)+1) tmpStr += 'class="calWeekend"'; else tmpStr +='class="cal"';
tmpStr += '> ';
}
tmpStr += ' | '
}
tmpStr += ' '
}
tmpStr += ' |
'
return tmpStr;
}
Calendar.prototype.selectChange = function(){
this.month = browser.ns6?this.containerLayer.ownerDocument.forms[0].month.selectedIndex:this.containerLayer.document.forms[0].month.selectedIndex;
this.writeString(this.buildString());
}
Calendar.prototype.inputChange = function(){
var tmp = browser.ns6?this.containerLayer.ownerDocument.forms[0].year:this.containerLayer.document.forms[0].year;
if (tmp.value >=1900 || tmp.value <=2100){
this.year = tmp.value;
this.writeString(this.buildString());
} else {
tmp.value = this.year;
}
}
Calendar.prototype.changeYear = function(incr){
(incr==1)?this.year++:this.year--;
this.writeString(this.buildString());
}
Calendar.prototype.changeMonth = function(incr){
if (this.month==11 && incr==1){
this.month = 0;
this.year++;
} else {
if (this.month==0 && incr==-1){
this.month = 11;
this.year--;
} else {
(incr==1)?this.month++:this.month--;
}
}
this.writeString(this.buildString());
}
Calendar.prototype.clickDay = function(day){
// var tmp = eval('document.' + this.target);
if (window.XMLHttpRequest && !(window.ActiveXObject)) // added by khaleel for call: 54333399
{
this.target = this.target.split('.')[1]
var tmp = document.getElementById(this.target);
} else {
var tmp = eval('document.' + this.target);
}
tmp.value = this.formatDateAsString(day,this.month,this.year);
//Added by swaroopa for BMW on 2/9/2007
var val=this.target;
var ind=val.indexOf('.');
var objToFocus=val.substring(ind+1,val.length);
document.getElementById(objToFocus).focus();
//Addition Ends
try {changeDateValue(tmp);}catch(e){} //Added By Gaurang To have the value of the date in the calling page
if (browser.ns4) this.containerLayer.hidden=true;
if (browser.dom || browser.ie4){
this.containerLayer.style.visibility='hidden';
}
}
Calendar.prototype.formatDateAsString = function(day, month, year){
var delim = eval('/\\' + this.dateDelim + '/g');
switch (this.dateFormat.replace(delim,"")){
case 'ddmmmyyyy': return padZero(day) + this.dateDelim + this.months[month].substr(0,3) + this.dateDelim + year;
case 'ddmmyyyy': return padZero(day) + this.dateDelim + padZero(month+1) + this.dateDelim + year;
case 'mmddyyyy': return padZero((month+1)) + this.dateDelim + padZero(day) + this.dateDelim + year;
case 'yyyymmdd': return year + this.dateDelim + padZero(month+1) + this.dateDelim + padZero(day);
default: alert('unsupported date format');
}
}
Calendar.prototype.writeString = function(str){
if (browser.ns4){
this.containerLayer.document.open();
this.containerLayer.document.write(str);
this.containerLayer.document.close();
}
if (browser.dom || browser.ie4){
this.containerLayer.innerHTML = str;
}
}
Calendar.prototype.show = function(event, target, bHasDropDown, dateFormat, dateFrom, dateTo){
// calendar can restrict choices between 2 dates, if however no restrictions
// are made, let them choose any date between 1900 and 3000
this.dateFrom = dateFrom || new Date(1900,0,1);
this.dateFromDay = padZero(this.dateFrom.getDate());
this.dateFromMonth = padZero(this.dateFrom.getMonth());
this.dateFromYear = this.dateFrom.getFullYear();
this.dateTo = dateTo || new Date(3000,0,1);
this.dateToDay = padZero(this.dateTo.getDate());
this.dateToMonth = padZero(this.dateTo.getMonth());
this.dateToYear = this.dateTo.getFullYear();
this.hasDropDown = bHasDropDown;
this.dateFormat = dateFormat || 'dd-mmm-yyyy';
switch (this.dateFormat){
case 'dd-mmm-yyyy':
case 'dd-mm-yyyy':
case 'yyyy-mm-dd':
this.dateDelim = '-';
break;
case 'dd/mm/yyyy':
case 'mm/dd/yyyy':
case 'dd/mmm/yyyy':
this.dateDelim = '/';
break;
}
if (browser.ns4) {
if (!this.containerLayer.hidden) {
this.containerLayer.hidden=true;
return;
}
}
if (browser.dom || browser.ie4){
if (this.containerLayer.style.visibility=='visible') {
this.containerLayer.style.visibility='hidden';
return;
}
}
if (browser.ie5 || browser.ie4){
var event = window.event;
}
if (browser.ns4){
this.containerLayer.x = event.x+10;
this.containerLayer.y = event.y-5;
}
if (browser.ie5 || browser.ie4){
var obj = event.srcElement;
x = 0;
while (obj.offsetParent != null) {
x += obj.offsetLeft;
obj = obj.offsetParent;
}
x += obj.offsetLeft;
y = 0;
var obj = event.srcElement;
while (obj.offsetParent != null) {
y += obj.offsetTop;
obj = obj.offsetParent;
}
y += obj.offsetTop;
this.containerLayer.style.left = x+35;
if (event.y>0)this.containerLayer.style.top = y;
}
if (browser.ns6){
this.containerLayer.style.left = event.pageX+10;
this.containerLayer.style.top = event.pageY-5;
}
this.target = target;
var tmp = eval('document.' + this.target);
if (tmp && tmp.value && tmp.value.split(this.dateDelim).length==3 && tmp.value.indexOf('d')==-1){
var atmp = tmp.value.split(this.dateDelim)
switch (this.dateFormat){
case 'dd-mmm-yyyy':
case 'dd/mmm/yyyy':
for (var i=0;i parseInt(g_Calendar.containerLayer.style.left,10) && e.pageX < (parseInt(g_Calendar.containerLayer.style.left,10)+125) && e.pageY < (parseInt(g_Calendar.containerLayer.style.top,10)+125) && e.pageY > parseInt(g_Calendar.containerLayer.style.top,10));
if (e.target.name!='imgCalendar' && e.target.name!='month' && e.target.name!='year' && e.target.name!='calendar' && !bTest)
{
g_Calendar.hide();
}
}
if (browser.ie4 || browser.ie5){
// extra test to see if user clicked inside the calendar but not on a valid date, we don't want it to disappear in this case
//var bTest = (e.x > parseInt(g_Calendar.containerLayer.style.left,10) && e.x < (parseInt(g_Calendar.containerLayer.style.left,10)+125) && e.y < (parseInt(g_Calendar.containerLayer.style.top,10)+125) && e.y > parseInt(g_Calendar.containerLayer.style.top,10));
// if (e.srcElement.name!='imgCalendar' && e.srcElement.name!='month' && e.srcElement.name!='year' && !bTest & typeof(e.srcElement)!='object'){
// g_Calendar.hide();
//}
}
if (browser.ns4) g_Calendar.hide();
}
// utility function
function padZero(num) {
return ((num <= 9) ? ("0" + num) : num);
}
// Finally licked extending native date object;
Date.isLeapYear = function(year){ if (year%4==0 && ((year%100!=0) || (year%400==0))) return true; else return false; }
Date.daysInYear = function(year){ if (Date.isLeapYear(year)) return 366; else return 365;}
var DAY = 1000*60*60*24;
Date.prototype.addDays = function(num){
return new Date((num*DAY)+this.valueOf());
}
// events capturing, careful you don't override this by setting something in the onload event of
// the body tag
window.onload=function(){
new Calendar(new Date());
if (browser.ns4){
if (typeof document.NSfix == 'undefined'){
document.NSfix = new Object();
document.NSfix.initWidth=window.innerWidth;
document.NSfix.initHeight=window.innerHeight;
}
}
}
if (browser.ns4) window.onresize = function(){
if (document.NSfix.initWidth!=window.innerWidth || document.NSfix.initHeight!=window.innerHeight) window.location.reload(false);
} // ns4 resize bug workaround
window.document.onclick=handleDocumentClick;