var iCalWidth = 180
var iCalHeight = 135
var	fixedX = -1 // x position (-1 if to appear below control)
var	fixedY = -1 // y position (-1 if to appear below control)
var startAt = 0 // 0 - sunday ; 1 - monday
var showWeekNumber = 0	// 0 - don't show; 1 - show
var showToday = 1		// 0 - don't show; 1 - show
var imgDir = "../Images/Calendar/"	// directory for images ... e.g. var imgDir="/img/"
var bShowFullDayName = false //whether to display T or Tue on day headings

//UI vars for control messages
var gotoString = "Go To Current Month"
var todayString = "Today is"
var weekString = "Wk"
var scrollLeftMessage = "Click to scroll to previous month. Hold mouse button to scroll automatically."
var scrollRightMessage = "Click to scroll to next month. Hold mouse button to scroll automatically."
var selectMonthMessage = "Click to select a month."
var selectYearMessage = "Click to select a year."
var selectDateMessage = "Select [date] as date." // do not replace [date], it will be replaced by date.

//vars related to whether data was selected and what each data point selected was
var crossobj, crossMonthObj, crossYearObj;
var monthSelected, yearSelected, dateSelected, omonthSelected, oyearSelected, odateSelected;
var monthConstructed, yearConstructed, intervalID1, intervalID2, timeoutID1, timeoutID2;
var ctlNow, dateFormat, nStartingYear;

//form elements to place selected date(s) into
var ctlToPlaceValue, ctlToPlaceEndDateValue;

var bPageLoaded=false
var ie=document.all //check to see browser type
var dom=document.getElementById 

var ns4=document.layers

var today =	new	Date();
	

var dateNow	 = today.getDate()
	
var monthNow = today.getMonth()

var yearNow	 = today.getYear()

if(navigator.appName == "Opera"){ yearNow = today.getFullYear();}


var imgsrc = new Array("drop1.gif","drop2.gif","left1.gif","left2.gif","right1.gif","right2.gif")
var img	= new Array()

var bShow = false;
var objName;
var noOfYears;
/* 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 !=null){
          if(( overDiv.offsetLeft + overDiv.offsetWidth ) <= objLeft );
          else if(( overDiv.offsetTop + overDiv.offsetHeight ) <= objTop );
          else if( overDiv.offsetTop >= ( objTop + objHeight ));
          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 = "";
//        }
//      }
//    var selColl = document.all.tags("SELECT");
//    //Rerives collection for all the Select tags in the document
//	if (selColl!=null)
//	{
//		for (i=0; i<selColl.length; i++) 
//			selColl[i].style.visibility = "visible";
//	}
}

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 )
}

//write div containing calendar and place holders for cal header and calendar content
if (dom)
{
	for	(i=0;i<imgsrc.length;i++)
	{
		img[i] = new Image
		img[i].src= img + imgsrc[i]
	}
	document.write ("<div onclick='bShow=true' id='calendar' class='div-style'><table width="+ iCalWidth + " cellpadding=1 cellspacing=0 class='table-style' height=" + iCalHeight + "><tr class='title-background-style'><td height=13><table cellpadding=0 cellspacing=0 width=100%><tr><td class='title-style' height=13 valign=top><span id='caption'></span></td><td align=right width=15><a href='javascript:hideCalendar()'><img src='"+imgDir+"close.gif' width='15' height='13' border='0' alt='Close the Calendar'></a></td></tr></table></td></tr><tr><td class='body-style' valign=top><span id='content'></span></td></tr>")
		
	if (showToday==1)
	{
		document.write ("<tr class='today-style'><td><span id='lblToday' class='body-style'></span></td></tr>")
	}
		
	document.write ("</table></div><div id='selectMonth' class='div-style' style=\"width:58px\"></div><div id='selectYear' class='div-style'></div>");
}

var	monthName =	new	Array("January","February","March","April","May","June","July","August","September","October","November","December")
if (startAt==0)
{
	if (bShowFullDayName == false){
		dayName = new Array	("S","M","T","W","T","F","S")
	}else{
		dayName = new Array	("Sun","Mon","Tue","Wed","Thu","Fri","Sat")
	} 
}
else
{	
	if (bShowFullDayName == false){
		dayName = new Array	("M","T","W","T","F","S","S")
	}else{
		dayName = new Array	("Mon","Tue","Wed","Thu","Fri","Sat","Sun")
	}
}

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)
		{
			if (bShowFullDayName == false) {
				var sToday = monthName[monthNow].substring(0,3) + " " +  dateNow +  " " + yearNow
			}else{ 
				var sToday = dayName[(today.getDay()-startAt==-1)?6:(today.getDay()-startAt)]+", " + dateNow + " " + monthName[monthNow].substring(0,3) + "	" +	yearNow
			}				
			document.getElementById("lblToday").innerHTML =	todayString + " <a class='today-style' onmousemove='window.status=\""+gotoString+"\"' onmouseout='window.status=\"\"' title='"+gotoString+"' href='javascript:monthSelected=monthNow;yearSelected=yearNow;constructCalendar();'>" +	sToday + "</a>"
		}

		///*make calendar header fixed width so that header does not "flop" around			
		sHTMLCalHead = "<table cellpadding=0 cellspacing=0><tr>"			
		sHTMLCalHead+="<td id='spanLeft' height=13 width=10 valign=top class='title-control-normal-style' onmouseover='swapImage(\"changeLeft\",\"left2.gif\");this.className=\"title-control-select-style\";window.status=\""+scrollLeftMessage+"\"' title=\""+scrollLeftMessage+"\" onclick='javascript:decMonth()' onmouseout='clearInterval(intervalID1);swapImage(\"changeLeft\",\"left1.gif\");this.className=\"title-control-normal-style\";window.status=\"\"' onmousedown='clearTimeout(timeoutID1);timeoutID1=setTimeout(\"StartDecMonth()\",500)' onmouseup='clearTimeout(timeoutID1);clearInterval(intervalID1)'><img id='changeLeft' src='"+imgDir+"left1.gif' width=10 height=11 border=0></td>"
		sHTMLCalHead+="<td id='spanRight' height=13 width=10 valign=top class='title-control-normal-style' onmouseover='swapImage(\"changeRight\",\"right2.gif\");this.className=\"title-control-select-style\";window.status=\""+scrollRightMessage+"\"' title=\""+scrollRightMessage+"\" onmouseout='clearInterval(intervalID1);swapImage(\"changeRight\",\"right1.gif\");this.className=\"title-control-normal-style\";window.status=\"\"' onclick='incMonth()' onmousedown='clearTimeout(timeoutID1);timeoutID1=setTimeout(\"StartIncMonth()\",500)' onmouseup='clearTimeout(timeoutID1);clearInterval(intervalID1)'><img id='changeRight' src='"+imgDir+"right1.gif' width=10 height=11 border=0></td>"
		sHTMLCalHead+="<td id='spanMonth' height=13 width=90 valign=top class='title-control-normal-style' onmouseover='swapImage(\"changeMonth\",\"drop2.gif\");this.className=\"title-control-select-style\";window.status=\""+selectMonthMessage+"\"' title=\""+selectMonthMessage+"\" onmouseout='swapImage(\"changeMonth\",\"drop1.gif\");this.className=\"title-control-normal-style\";window.status=\"\"' onclick='popUpMonth()'></td>"
		sHTMLCalHead+="<td id='spanYear' height=13 valign=top class='title-control-normal-style' onmouseover='swapImage(\"changeYear\",\"drop2.gif\");this.className=\"title-control-select-style\";window.status=\""+selectYearMessage+"\"' title=\""+selectYearMessage+"\" onmouseout='swapImage(\"changeYear\",\"drop1.gif\");this.className=\"title-control-normal-style\";window.status=\"\"'	onclick='popUpYear()'></td>"
		sHTMLCalHead+= "</tr></table>"
		//*/
		document.getElementById("caption").innerHTML  =	sHTMLCalHead

		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 ;
}

//controls formatting of date
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 (" ","/") //comment this out to remove /
	sTmp = sTmp.replace	("mmm","<o>")
	sTmp = sTmp.replace	("mm","<n>")
	sTmp = sTmp.replace	("m","<m>")
	sTmp = sTmp.replace	("<m>",m+1)		
	sTmp = sTmp.replace	("<n>",padZero(m+1))
	sTmp = sTmp.replace	("<o>",monthName[m])
	sTmp = sTmp.replace ("yyyy",y)
	//return sTmp.replace ("yyyy",y) //original code
	return sTmp.replace (" ","/") //comment this out to remove /
}

//handles setting of actual dat value in form field
function closeCalendar() {
	try{		
		var	sTmp;
		hideCalendar();
		ctlToPlaceValue.value =	constructDate(dateSelected,monthSelected,yearSelected)
		ctlToPlaceValue.focus();
		if(ctlToPlaceEndDateValue!=null){ //place value in end date if end date control passed/present
				ctlToPlaceEndDateValue.value =	ctlToPlaceValue.value;
				setExpDate(objName);
		}			
	}catch(er){
			alert(er);
	}  		
}

/*** Start 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[i];
			if (i==monthSelected){
				sName =	"<B>" +	sName +	"</B>"
			}
			sHTML += "<tr><td id='m" + i + "' onmouseover='this.className=\"dropdown-select-style\"' onmouseout='this.className=\"dropdown-normal-style\"' onclick='monthConstructed=false;monthSelected=" + i + ";constructCalendar();popDownMonth();event.cancelBubble=true'>&nbsp;" + sName + "&nbsp;</td></tr>"
		}

		document.getElementById("selectMonth").innerHTML = "<table class='dropdown-style' cellspacing=0 cellpadding=1 onmouseover='clearTimeout(timeoutID1)' onmouseout='clearTimeout(timeoutID1);timeoutID1=setTimeout(\"popDownMonth()\",100);event.cancelBubble=true'>" + sHTML + "</table>"

		monthConstructed=true
	}
}

function popUpMonth() {
	constructMonth()
	crossMonthObj.visibility = (dom||ie)? "visible"	: "show"
	crossMonthObj.left = parseInt(crossobj.left) + 20  + "px"// x offset of month selector
	crossMonthObj.top =	parseInt(crossobj.top) + 16  + "px"// y offset of month selector
}

function popDownMonth()	{
	crossMonthObj.visibility= "hidden"
}

/*** END Month Pulldown ***/
/*** Start Year Pulldown ***/

function incYear() {
	for	(i=0; i<7; i++){
		newYear	= (i+nStartingYear)+1
		if (newYear==yearSelected)
		{ txtYear =	"&nbsp;<B>"	+ newYear +	"</B>&nbsp;" }
		else
		{ txtYear =	"&nbsp;" + newYear + "&nbsp;" }
		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 =	"&nbsp;<B>"	+ newYear +	"</B>&nbsp;" }
		else
		{ txtYear =	"&nbsp;" + newYear + "&nbsp;" }
		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.className=\"dropdown-select-style\"' onmouseout='clearInterval(intervalID1);this.className=\"dropdown-normal-style\"' onmousedown='clearInterval(intervalID1);intervalID1=setInterval(\"decYear()\",30)' onmouseup='clearInterval(intervalID1)'>-</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.className=\"dropdown-select-style\"' onmouseout='this.className=\"dropdown-normal-style\"' onclick='selectYear("+j+");event.cancelBubble=true'>&nbsp;" + sName + "&nbsp;</td></tr>"
			j ++;
		}

		sHTML += "<tr><td align='center' onmouseover='this.className=\"dropdown-select-style\"' onmouseout='clearInterval(intervalID2);this.className=\"dropdown-normal-style\"' onmousedown='clearInterval(intervalID2);intervalID2=setInterval(\"incYear()\",30)'	onmouseup='clearInterval(intervalID2)'>+</td></tr>"

		document.getElementById("selectYear").innerHTML	= "<table width=44 class='dropdown-style' onmouseover='clearTimeout(timeoutID2)' onmouseout='clearTimeout(timeoutID2);timeoutID2=setTimeout(\"popDownYear()\",100)' cellspacing=0>"	+ sHTML	+ "</table>"

		yearConstructed	= true
	}
}

function popDownYear() {
	clearInterval(intervalID1)
	clearTimeout(timeoutID1)
	clearInterval(intervalID2)
	clearTimeout(timeoutID2)
	crossYearObj.visibility= "hidden"
}

function popUpYear() {
	var	leftOffset

	constructYear()
	crossYearObj.visibility	= (dom||ie)? "visible" : "show"
	leftOffset = parseInt(crossobj.left) + document.getElementById("spanYear").offsetLeft;
	if (ie)
	{
		leftOffset += 1 // x offset of year selector
	}
	crossYearObj.left =	leftOffset + "px";
	crossYearObj.top = parseInt(crossobj.top) +	16  + "px"// y offset of year selector
}

/*** END Year Pulldown ***/

/*** Start actual calendar code which builds string of calendar content***/

function WeekNbr(today)
{
	Year = takeYear(today);
	Month = today.getMonth();
	Day = today.getDate();
	now = Date.UTC(Year,Month,Day+1,0,0,0);
	var Firstday = new Date();
	Firstday.setYear(Year);
	Firstday.setMonth(0);
	Firstday.setDate(1);
	then = Date.UTC(Year,0,1,0,0,0);
	var Compensation = Firstday.getDay();
	if (Compensation > 3) Compensation -= 4;
	else Compensation += 3;
	NumberOfWeek =  Math.round((((now-then)/86400000)+Compensation)/7);
	return NumberOfWeek;
}

function takeYear(theDate)
{
	x = theDate.getYear();
	var y = x % 100;
	y += (y < 38) ? 2000 : 1900;
	return y;
}

//builds string containing HTML table that is calender
function constructCalendar () {
	var iDateCelWidth = (iCalWidth/7) - 4
	var dateMessage
	var	startDate =	new	Date (yearSelected,monthSelected,1)
	var	endDate	= new Date (yearSelected,monthSelected+1,1);
	endDate	= new Date (endDate	- (24*60*60*1000));
	numDaysInMonth = endDate.getDate()
	
	datePointer	= 0
	dayPointer = startDate.getDay() - startAt
	
	if (dayPointer<0)
	{
		dayPointer = 6
	}

	sHTML =	"<table	border=0 cellspacing=0 cellpadding=1 width=100%><tr>"

	if (showWeekNumber==1)
	{
		sHTML += "<td width=" + iDateCelWidth + ">" + weekString + "</td><td width=1 rowspan=7 class='weeknumber-div-style'><img src='"+imgDir+"divider.gif' width=1></td>"
	}

	for	(i=0; i<7; i++)	{
		sHTML += "<td align='right' class='dayheader-style' width=" + iDateCelWidth + ">"+ dayName[i]+"</td>"
	}
	sHTML +="</tr><tr>"
	
	if (showWeekNumber==1)
	{
		sHTML += "<td align=right width=" + iDateCelWidth + ">" + WeekNbr(startDate) + "</td>"
	}

	for	( var i=1; i<=dayPointer;i++ )
	{
		sHTML += "<td width=" + iDateCelWidth + ">&nbsp;</td>"
	}
	//Start writing cells with dates in them
	for	( datePointer=1; datePointer<=numDaysInMonth; datePointer++ )
	{
		dayPointer++;
		sHTML += "<td align=right width=" + iDateCelWidth + ">"

		var sStyle="normal-day-style"; //regular day

		if ((datePointer==dateNow)&&(monthSelected==monthNow)&&(yearSelected==yearNow)) //today
		{ sStyle = "current-day-style"; } 
		else if	(dayPointer % 7 == (startAt * -1) +1) //end-of-the-week day
		{ sStyle = "end-of-weekday-style"; }

		//selected day
		if ((datePointer==odateSelected) &&	(monthSelected==omonthSelected)	&& (yearSelected==oyearSelected))
		{ sStyle += " selected-day-style"; }

		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 += " holiday-style";
					sHint+=sHint==""?Holidays[k].desc:"\n"+Holidays[k].desc
				}
			}
		}

		var regexp= /\"/g
		sHint=sHint.replace(regexp,"&quot;")

		dateMessage = "onmousemove='window.status=\""+selectDateMessage.replace("[date]",constructDate(datePointer,monthSelected,yearSelected))+"\"' onmouseout='window.status=\"\"' "
		sHint = selectDateMessage.replace("[date]",constructDate(datePointer,monthSelected,yearSelected));
		sHTML += "<a class='"+sStyle+"' "+dateMessage+" title=\"" + sHint + "\" href='javascript:dateSelected="+datePointer+";closeCalendar();'>" + datePointer + "</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))) + "</td>"
			}
		}
	}
				
	//write string to calendar content placeholder
	document.getElementById("content").innerHTML  = sHTML

	document.getElementById("spanMonth").innerHTML = "&nbsp;" +	monthName[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 getDays(GivenYear)
{
	if((GivenYear % 4 == 0 && GivenYear % 100 !=0 ) || (GivenYear % 100 == 0 && GivenYear % 400 ==0 ))
		return 29;
	else
		return 28;
}	
	
//handles building calendar - this is the function that is called by page controls to do calendar functionality
function popUpCalendar(ctl, ctl2, ctlEndDate, format, givenYears) {
	
var	leftpos=0; // (x) location on page of element calling this function - used to hide selects near calendar
var	toppos=0; // (y) location on page of element calling this function - used to hide selects near calendar
objName = ctl2.name;
try{

	if (bPageLoaded)
	{
		if ( crossobj.visibility ==	"hidden" ) {
			ctlToPlaceValue = ctl2;
			if(ctlEndDate!=null){
				ctlToPlaceEndDateValue = ctlEndDate;
			}
			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)
						{
							// invalid date	format
							formatChar=""
						}
					}
				}
			}

			tokensChanged =	0
			if ( formatChar	!= "" )
			{					
				//CODE CHANGE - specify delimiter on date value so can split val properly
				formatChar = "/"
				
				// use user's date
				x = ctl2.value ;
				ctl2.value = "";
				aData =	ctl2.value.split(formatChar)
				ctl2.value = x;
				for	(i=0;i<3;i++)
				{
					if ((aFormat[i]=="d") || (aFormat[i]=="dd"))
					{
						dateSelected = parseInt(aData[i], 10)
						tokensChanged ++
					}
					else if	((aFormat[i]=="m") || (aFormat[i]=="mm"))
					{							
						monthSelected =	parseInt(aData[i], 10) - 1 	
						tokensChanged ++
					}
					else if	(aFormat[i]=="yyyy")
					{
						yearSelected = parseInt(aData[i], 10);
						tokensChanged ++
					}
					else if	(aFormat[i]=="mmm")
					{
						for	(j=0; j<12;	j++)
						{
							if (aData[i]==monthName[j])
							{
								monthSelected=j
								tokensChanged ++
							}
						}
					}
				}
							//setExpDate(ctl2);	
				
			}

			if ((tokensChanged!=3)||isNaN(dateSelected)||isNaN(monthSelected)||isNaN(yearSelected))
			{
				dateSelected = dateNow;
				monthSelected = monthNow;	
				yearSelected = yearNow;
			}				

			odateSelected=dateSelected;
			omonthSelected=monthSelected;
			oyearSelected=yearSelected;

			var aTag = ctl
			do {
				aTag = aTag.offsetParent;
				leftpos	+= aTag.offsetLeft;
				toppos += aTag.offsetTop;
			} while(aTag.tagName!="BODY");

			crossobj.left =	ctl.offsetLeft	+ leftpos + "px";
			crossobj.top = ctl.offsetTop +	toppos + ctl.offsetHeight + "px";
			
			
			constructCalendar (1, monthSelected, yearSelected);
			crossobj.visibility=(dom||ie)? "visible" : "show"
			
			//make call to hide selects
			hideElement('SELECT', document.getElementById("calendar"));
			hideElement('APPLET', document.getElementById("calendar"));	
				
			bShow = true;
		}
	}
	else
	{
		init();
		popUpCalendar(ctl,	ctl2, format);
	}
}catch(er){
		alert(er);
}  	

}

//handles click on Enter Key to hide calendar
//document.onkeypress = function hidecal1 () { 
//if (event.keyCode==27) 
//{
//	hideCalendar()
//}
//}

//handles click on of document to hide calendar
document.onclick = function hidecal2 () { 		
if (!bShow)
{
	hideCalendar()
}
bShow = false
}

//does initiation of calendar vars
init()


function setDateTxt(oImg, txtID, sDateField) 
{
    try
    {
	    popUpCalendar(oImg, document.getElementById(txtID), document.getElementById(sDateField), 'mm dd yyyy');
    	
    }
    catch(er)
    {
	    alert('Error trying to set date into form element. \n\nPlease enter date into field in this format: MM/DD/YYYY');
    }   
}	

// Created By: MUKESH KUMAR DOOT
var t_o_Control, t_o_Maxheight=0, t_o_Maxwidth=0, t_o_Counter=0, t_o_errormessage="";var t_t_o_PxCounterWidth=0, o_PxCounterWidth=0, t_o_Left=0, t_o_Top=0, t_o_MaxLeft=0;var t_o_MaxTop=0, o_ImageBox, o_HideControl;var t_Timer;var ie = document.all;
function NoImage_FProducts(){var blankImage = document.getElementsByTagName("img");for(var i =0; i<blankImage.length; i++){var oObj = (blankImage[i].src).split('/');oObj = oObj[oObj.length-1];
if(oObj=="" && blankImage[i].parentElement.parentElement.parentElement.parentElement.id=="tblBorder"){blankImage[i].src="../Images/NoImage_FProducts.gif";}}}function set_ImageAnimation(_Sender,
_div,_FinalHeight, _FinalWidth, _FinalLeft, _FinalTop, _innerHTML, _InnerObject, _ImageURL){var _PopupDiv = document.getElementById(_div);_PopupDiv.innerHTML ="";document.getElementById(_InnerObject).innerHTML
= (_ImageURL!="")?"<div style='height:"+_FinalHeight+"px;width:"+_FinalWidth+"px;'><table align='center' cellpadding='0' cellspacing='0' border='0' width='96%' style='height:"+(_FinalHeight-20)+"px'><tr><td><img id='imgDOM' src='"+ _ImageURL +"' border='0' /></td></tr></table></div>" : "<div style='height:"+_FinalHeight +"px;width:"+_FinalWidth +"px;text-align:left;'><br/><label><a href='AddNewAccount.aspx'><strong>Registration required</strong></a></label></div>";
Set_ShowAnimationPopup(_Sender, _div,_FinalHeight, _FinalWidth, _FinalLeft, _FinalTop, _innerHTML);
}function Set_ShowAnimationPopup(_Sender, _div,_FinalHeight, _FinalWidth, _FinalLeft, _FinalTop, _innerHTML){var _SenderLeft = _Sender.offsetLeft;var _SenderobjParent = _Sender.offsetParent;var 
objTop = _Sender.offsetTop;var _PopupDiv = document.getElementById(_div);var _PopupInnerHTML = (_innerHTML != "") ? document.getElementById(_innerHTML).innerHTML : "";while( _SenderobjParent.tagName.toUpperCase()
!= "BODY" ){objTop += _SenderobjParent.offsetTop;_SenderLeft+= _SenderobjParent.offsetLeft;_SenderobjParent = _SenderobjParent.offsetParent;}_PopupDiv.style.display="block";var _Left = _SenderLeft;var _Top = objTop;
PopupAnimation(_PopupDiv, _PopupInnerHTML, _FinalHeight+40, _FinalWidth+40, 30, _Left, _Top, _FinalLeft, _FinalTop, 'Image');}function PopupAnimation(p_Control, p_errormessage, p_Maxheight, p_Maxwidth, p_Counter, p_Left,
p_Top, p_MaxLeft, p_MaxTop, p_ImageBox){if(p_Control.style.height!=p_Maxheight-p_Counter){t_o_Control=p_Control;t_o_errormessage = p_errormessage;t_o_Maxheight=p_Maxheight;t_o_Maxwidth=p_Maxwidth;t_o_Counter=p_Counter;
t_t_o_PxCounterWidth=0;o_PxCounterWidth=0;t_o_Left = p_Left;t_o_Top = p_Top;t_o_MaxLeft = p_MaxLeft;t_o_MaxTop = document.documentElement.scrollTop + p_MaxTop - 90;o_ImageBox = p_ImageBox;p_Control.innerHTML="";PopupAnimationHeightWidth();}}function 
PopupAnimationHeightWidth(){if(t_o_Maxheight>t_t_o_PxCounterWidth || t_o_Maxwidth>o_PxCounterWidth){WindowStatus();if(t_o_Maxheight>t_t_o_PxCounterWidth){t_o_Control.style.height=t_t_o_PxCounterWidth + 'px';
t_t_o_PxCounterWidth+=t_o_Counter;}if(t_o_Maxwidth>o_PxCounterWidth){t_o_Control.style.width=o_PxCounterWidth + 'px';o_PxCounterWidth+=t_o_Counter;}var _diffTop=0;var _diffLeft=0;if(t_o_Top < t_o_MaxTop){
t_o_Control.style.top = t_o_Top + "px";_diffTop = t_o_Top + t_o_Counter;if(_diffTop < t_o_MaxTop)t_o_Top = t_o_Top + t_o_Counter;}else{t_o_Control.style.top = t_o_Top + "px";_diffTop = t_o_Top - t_o_Counter;
if(_diffTop > t_o_MaxTop)t_o_Top = t_o_Top - t_o_Counter;}if(t_o_Left < t_o_MaxLeft){t_o_Control.style.left = t_o_Left + "px";_diffLeft = t_o_Left + t_o_Counter;if(_diffLeft < t_o_MaxLeft)t_o_Left = t_o_Left
+ t_o_Counter;}else{t_o_Control.style.left = t_o_Left + "px";_diffLeft = t_o_Left - (t_o_Counter*2);if(_diffLeft > t_o_MaxLeft)t_o_Left = t_o_Left - (t_o_Counter*2);}}else{t_o_Control.style.height=t_o_Maxheight 
+ 'px';t_o_Control.innerHTML= t_o_errormessage;clearTimeout(t_Timer);try{var oSelect = document.all.tags("SELECT");if (oSelect!=null){for (i=0; i<oSelect.length; i++)
if(i>3) oSelect[i].style.visibility = "hidden";}}catch(Error){}if(o_ImageBox!=null){}return false;}t_Timer=setTimeout("PopupAnimationHeightWidth();",5);}function HidePopup(p_Control, p_Maxheight, p_Maxwidth, 
p_Counter, p_HideControl){if(p_Control.style.height!=0){t_o_Control=p_Control;t_o_Maxheight=p_Maxheight;t_o_Maxwidth=p_Maxwidth;t_o_Counter=p_Counter;t_t_o_PxCounterWidth=p_Maxheight;o_PxCounterWidth=p_Maxwidth;o_HideControl 
=p_HideControl;HidePopupHeightWidth();}try{var oSelect = document.all.tags("SELECT");if (oSelect!=null){for (i=0; i<oSelect.length; i++)
oSelect[i].style.visibility = "visible";}}catch(Error){}}function HidePopupHeightWidth(){if(t_t_o_PxCounterWidth>0 || o_PxCounterWidth>0){WindowStatus();t_o_Control.innerHTML="";if(t_t_o_PxCounterWidth>0){t_o_Control.style.height=
t_t_o_PxCounterWidth + "px";t_t_o_PxCounterWidth-=t_o_Counter;}if(o_PxCounterWidth>0){t_o_Control.style.width=o_PxCounterWidth + "px";o_PxCounterWidth-=t_o_Counter;}}else{o_HideControl.style.display = "none";clearTimeout(t_Timer);
return false;}t_Timer=setTimeout("HidePopupHeightWidth();",5);}function WindowStatus(){if(ie)window.status="Done";}
function SelectGrid(CheckId,GDId)
{
    var chkItems = document.getElementById(GDId).getElementsByTagName("input");
    if(document.getElementById(CheckId).checked==true)
    {
        for(var i=0;i<chkItems.length;i++)
        {
            if(chkItems[i].type=="checkbox")
            {
                chkItems[i].checked=true;
            }
        }
    }
    else
    {
        for(var i=0;i<chkItems.length;i++)
        {
            if(chkItems[i].type=="checkbox")
            {
                chkItems[i].checked=false;
            }
        }
    }
}

function UnSelectGrid(CheckId1,CheckId2)
{
    if(document.getElementById(CheckId2).checked==true)
    {
        document.getElementById(CheckId2).checked=false;
    }
}

function CheckSave(id,GDId)
{
    var Bool=false;
    var chkItems = document.getElementById(GDId).getElementsByTagName("input");
    for(var i=0;i<chkItems.length;i++)
    {
        if(chkItems[i].type=="checkbox")
        {
            if(chkItems[i].checked)Bool=true;
        }
    }
    if (Bool==true)
    {
        //confirm("Do you want to save selected part!!!!");
        return true;
    }
    else
    {
        alert("Atleast one row must be selected!!!!!");
        return false;
    }
}

function changeBold()
{
    document.execCommand("bold", false, null);
}
function changeItalic()
{
    document.execCommand("Italic", false, null);
}
function changeUnderline()
{
    document.execCommand("underline", false, null);
}