Date:  06/03/2004 08:11:20 PM Msg ID:  002099
From:  Nemie Thread:  002095
Subject:  Re: Calendar Java script
Thank you.
Sent by FoxWeb Support on 06/03/2004 04:35:54 PM:
The code below makes a reference to the static file overlib:
 
<script language="JavaScript" src="overlib_mini.js">
 
In order to use to static files from FoxWeb scripts you need to place them in your server's Web tree and refer to them using absolute URLs.  This is all described in detail in the Locating and Addressing Scripts topic of the FoxWeb documentation.

FoxWeb Support Team
support@foxweb.com email

Sent by Nemie on 06/03/2004 03:30:35 PM:
This Java Code is not working from foxweb.....its working outside foxweb.....please help.
 
 
 
<html>
<HEAD>
<!-- This script and many more are available free online at -->
<!-- The JavaScript Source!! http://javascript.internet.com -->
<!-- Original:  James O'Connor (joconnor@nordenterprises.com) -->
<!-- Web Site:  http://nordenterprises.com -->
<script language="JavaScript">
<!-- 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 -->
<!-- -->
<!-- modifications and customizations to work with the "overLIB" library: -->
<!-- Author:   James B. O'Connor (joconnor@nordenterprises.com) -->
<!-- Web Site: http://www.nordenterprises.com -->
<!-- developed for use with http://home-owners-assoc.com -->
<!-- Note: while overlib works fine with Netscape 4, this function does not work very well, since portions of the "over" div -->
<!--   end up under other fields on the form and cannot be seen.  If you really want to use this with NS4, -->
<!--   you'll need to change the positioning in the overlib() call to make sure the "over" div gets positioned -->
<!--   away from all other form fields -->
<!-- you can get overLIB from: -->
//\  overLIB 3.50  --  This notice must remain untouched at all times.
//\  Copyright Erik Bosrup 1998-2001. All rights reserved.
//\  By Erik Bosrup (erik@bosrup.com).  Last modified 2001-08-28.
//\  Portions by Dan Steinman (dansteinman.com). Additions by other people are
//\  listed on the overLIB homepage.
//\  Get the latest version at http://www.bosrup.com/web/overlib/
var weekend = [0,6];
var weekendColor = "#e0e0e0";
var fontface = "Verdana";
var fontsize = 8;   // in "pt" units; used with "font-size" style element
var gNow = new Date();
var ggWinContent;
var ggPosX = -1;
var ggPosY = -1;
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_month, p_year, p_format) {
 if ((p_month == null) && (p_year == null)) return;
 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;
}
Calendar.get_month = Calendar_get_month;
Calendar.get_daysofmonth = Calendar_get_daysofmonth;
Calendar.calc_month_year = Calendar_calc_month_year;
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_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..
 vCode += ("<div align=center><TABLE BORDER=1 BGCOLOR=\"" + this.gBGColor + "\" style='font-size:" + fontsize + "pt;'>");
 
 vHeader_Code = this.cal_header();
 vData_Code = this.cal_data();
 vCode += (vHeader_Code + vData_Code);
 
 vCode += "</TABLE></div>";
 
 return vCode;
}
Calendar.prototype.show = function() {
 var vCode = "";
 // build content into global var ggWinContent
 ggWinContent += ("<FONT FACE='" + fontface + "' ><B>");
 ggWinContent += (this.gMonthName + " " + this.gYear);
 ggWinContent += "</B><BR>";
 
 // 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];
 
 ggWinContent += ("<TABLE WIDTH='100%' BORDER=1 CELLSPACING=0 CELLPADDING=0 BGCOLOR='#e0e0e0' style='font-size:" + fontsize + "pt;'><TR><TD ALIGN=center>");
 ggWinContent += ("[<A HREF=\"javascript:void(0);\" " +
  "onMouseOver=\"window.status='Go back one year'; return true;\" " +
  "onMouseOut=\"window.status=''; return true;\" " +
  "onClick=\"Build(" +
  "'" + this.gReturnItem + "', '" + this.gMonth + "', '" + (parseInt(this.gYear)-1) + "', '" + this.gFormat + "'" +
  ");" +
  "\"><<Year<\/A>]</TD><TD ALIGN=center>");
 ggWinContent += ("[<A HREF=\"javascript:void(0);\" " +
  "onMouseOver=\"window.status='Go back one month'; return true;\" " +
  "onMouseOut=\"window.status=''; return true;\" " +
  "onClick=\"Build(" +
  "'" + this.gReturnItem + "', '" + prevMM + "', '" + prevYYYY + "', '" + this.gFormat + "'" +
  ");" +
  "\"><Mon<\/A>]</TD><TD ALIGN=center>");
 ggWinContent += "       </TD><TD ALIGN=center>";
 ggWinContent += ("[<A HREF=\"javascript:void(0);\" " +
  "onMouseOver=\"window.status='Go forward one month'; return true;\" " +
  "onMouseOut=\"window.status=''; return true;\" " +
  "onClick=\"Build(" +
  "'" + this.gReturnItem + "', '" + nextMM + "', '" + nextYYYY + "', '" + this.gFormat + "'" +
  ");" +
  "\">Mon><\/A>]</TD><TD ALIGN=center>");
 ggWinContent += ("[<A HREF=\"javascript:void(0);\" " +
  "onMouseOver=\"window.status='Go forward one year'; return true;\" " +
  "onMouseOut=\"window.status=''; return true;\" " +
  "onClick=\"Build(" +
  "'" + this.gReturnItem + "', '" + this.gMonth + "', '" + (parseInt(this.gYear)+1) + "', '" + this.gFormat + "'" +
  ");" +
  "\">Year>><\/A>]</TD></TR></TABLE><BR>");
 // Get the complete calendar code for the month, and add it to the
 // content var
 vCode = this.getMonthlyCalendarCode();
 ggWinContent += vCode;
}
Calendar.prototype.showY = function() {
 var vCode = "";
 var i;
 ggWinContent += "<FONT FACE='" + fontface + "' ><B>"
 ggWinContent += ("Year : " + this.gYear);
 ggWinContent += "</B><BR>";
 // Show navigation buttons
 var prevYYYY = parseInt(this.gYear) - 1;
 var nextYYYY = parseInt(this.gYear) + 1;
 
 ggWinContent += ("<TABLE WIDTH='100%' BORDER=1 CELLSPACING=0 CELLPADDING=0 BGCOLOR='#e0e0e0' style='font-size:" + fontsize + "pt;'><TR><TD ALIGN=center>");
 ggWinContent += ("[<A HREF=\"javascript:void(0);\" " +
  "onMouseOver=\"window.status='Go back one year'; return true;\" " +
  "onMouseOut=\"window.status=''; return true;\" " +
  "onClick=\"Build(" +
  "'" + this.gReturnItem + "', null, '" + prevYYYY + "', '" + this.gFormat + "'" +
  ");" +
  "\"><<Year<\/A>]</TD><TD ALIGN=center>");
 ggWinContent += "       </TD><TD ALIGN=center>";
 ggWinContent += ("[<A HREF=\"javascript:void(0);\" " +
  "onMouseOver=\"window.status='Go forward one year'; return true;\" " +
  "onMouseOut=\"window.status=''; return true;\" " +
  "onClick=\"Build(" +
  "'" + this.gReturnItem + "', null, '" + nextYYYY + "', '" + this.gFormat + "'" +
  ");" +
  "\">Year>><\/A>]</TD></TR></TABLE><BR>");
 // Get the complete calendar code for each month.
 // start a table and first row in the table
 ggWinContent += ("<TABLE WIDTH='100%' BORDER=0 CELLSPACING=0 CELLPADDING=5 style='font-size:" + fontsize + "pt;'><TR>");
 var j;
 for (i=0; i<12; i++) {
  // start the table cell
  ggWinContent += "<TD ALIGN='center' VALIGN='top'>";
  this.gMonth = i;
  this.gMonthName = Calendar.get_month(this.gMonth);
  vCode = this.getMonthlyCalendarCode();
  ggWinContent += (this.gMonthName + "/" + this.gYear + "<BR>");
  ggWinContent += vCode;
  ggWinContent += "</TD>";
  if (i == 3 || i == 7) {
   ggWinContent += "</TR><TR>";
   }
 }
 ggWinContent += "</TR></TABLE></font><BR>";
}
Calendar.prototype.cal_header = function() {
 var vCode = "";
 
 vCode = vCode + "<TR>";
 vCode = vCode + "<TD WIDTH='14%'><FONT FACE='" + fontface + "' COLOR='" + this.gHeaderColor + "'><B>Sun</B></FONT></TD>";
 vCode = vCode + "<TD WIDTH='14%'><FONT FACE='" + fontface + "' COLOR='" + this.gHeaderColor + "'><B>Mon</B></FONT></TD>";
 vCode = vCode + "<TD WIDTH='14%'><FONT FACE='" + fontface + "' COLOR='" + this.gHeaderColor + "'><B>Tue</B></FONT></TD>";
 vCode = vCode + "<TD WIDTH='14%'><FONT FACE='" + fontface + "' COLOR='" + this.gHeaderColor + "'><B>Wed</B></FONT></TD>";
 vCode = vCode + "<TD WIDTH='14%'><FONT FACE='" + fontface + "' COLOR='" + this.gHeaderColor + "'><B>Thu</B></FONT></TD>";
 vCode = vCode + "<TD WIDTH='14%'><FONT FACE='" + fontface + "' COLOR='" + this.gHeaderColor + "'><B>Fri</B></FONT></TD>";
 vCode = vCode + "<TD WIDTH='16%'><FONT FACE='" + fontface + "' COLOR='" + this.gHeaderColor + "'><B>Sat</B></FONT></TD>";
 vCode = vCode + "</TR>";
 
 return vCode;
}
Calendar.prototype.cal_data = function() {
 var vDate = new Date();
 vDate.setDate(1);
 vDate.setMonth(this.gMonth);
 vDate.setFullYear(this.gYear);
 var vFirstDay=vDate.getDay();
 var vDay=1;
 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>";
 for (i=0; i<vFirstDay; i++) {
  vCode = vCode + "<TD WIDTH='14%'" + this.write_weekend_string(i) + "><FONT FACE='" + fontface + "'> </FONT></TD>";
 }
 // Write rest of the 1st week
 for (j=vFirstDay; j<7; j++) {
  vCode = vCode + "<TD WIDTH='14%'" + this.write_weekend_string(j) + "><FONT FACE='" + fontface + "'>" +
   "<A HREF='javascript:void(0);' " +
    "onMouseOver=\"window.status='set date to " + this.format_data(vDay) + "'; return true;\" " +
    "onMouseOut=\"window.status=' '; return true;\" " +
    "onClick=\"document." + this.gReturnItem + ".value='" +
    this.format_data(vDay) +
    "';ggPosX=-1;ggPosY=-1;nd();nd();\">" +
    this.format_day(vDay) +
   "</A>" +
   "</FONT></TD>";
  vDay=vDay + 1;
 }
 vCode = vCode + "</TR>";
 // Write the rest of the weeks
 for (k=2; k<7; k++) {
  vCode = vCode + "<TR>";
  for (j=0; j<7; j++) {
   vCode = vCode + "<TD WIDTH='14%'" + this.write_weekend_string(j) + "><FONT FACE='" + fontface + "'>" +
    "<A HREF='javascript:void(0);' " +
     "onMouseOver=\"window.status='set date to " + this.format_data(vDay) + "'; return true;\" " +
     "onMouseOut=\"window.status=' '; return true;\" " +
     "onClick=\"document." + this.gReturnItem + ".value='" +
     this.format_data(vDay) +
     "';window.scroll(0,ggPosY);ggPosX=-1;ggPosY=-1;nd();nd();\">" +
    this.format_day(vDay) +
    "</A>" +
    "</FONT></TD>";
   vDay=vDay + 1;
   if (vDay > vLastDay) {
    vOnLastDay = 1;
    break;
   }
  }
  if (j == 6)
   vCode = vCode + "</TR>";
  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++) {
  if (this.gYearly)
   vCode = vCode + "<TD WIDTH='14%'" + this.write_weekend_string(j+m) +
   "><FONT FACE='" + fontface + "' COLOR='gray'> </FONT></TD>";
  else
   vCode = vCode + "<TD WIDTH='14%'" + this.write_weekend_string(j+m) +
   "><FONT FACE='" + fontface + "' COLOR='gray'>" + m + "</FONT></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 ("<FONT COLOR=\"RED\"><B>" + vday + "</B></FONT>");
 else
  return (vday);
}
Calendar.prototype.write_weekend_string = function(vday) {
 var i;
 // Return special formatting for the weekend day.
 for (i=0; i<weekend.length; i++) {
  if (vday == weekend[i])
   return (" BGCOLOR=\"" + weekendColor + "\"");
 }
 
 return "";
}
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,3).toUpperCase();
 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 "YYYY-MM-DD" :
   vData = vY4 + "-" + vMonth + "-" + vDD;
   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;
  default :
   vData = vMonth + "\/" + vDD + "\/" + vY4;
 }
 return vData;
}
function Build(p_item, p_month, p_year, p_format) {
 gCal = new Calendar(p_item, p_month, p_year, p_format);
 // Customize your Calendar here..
 gCal.gBGColor="white";
 gCal.gLinkColor="black";
 gCal.gTextColor="black";
 gCal.gHeaderColor="darkgreen";
 // initialize the content string
 ggWinContent = "";
 // Choose appropriate show function
 if (gCal.gYearly) {
  // and, since the yearly calendar is so large, override the positioning and fontsize
  // warning: in IE6, it appears that "select" fields on the form will still show
  // through the "over" div; Note: you can set these variables as part of the onClick
  // javascript code before you call the show_yearly_calendar function
  if (ggPosX == -1) ggPosX = 10;
  if (ggPosY == -1) ggPosY = 10;
  if (fontsize == 8) fontsize = 6;
  // generate the calendar
  gCal.showY();
  }
 else {
  gCal.show();
  }
 // if this is the first calendar popup, use autopositioning with an offset
 if (ggPosX == -1 && ggPosY == -1) {
  overlib(ggWinContent, AUTOSTATUSCAP, STICKY, CLOSECLICK, CSSSTYLE,
   TEXTSIZEUNIT, "pt", TEXTSIZE, 8, CAPTIONSIZEUNIT, "pt", CAPTIONSIZE, 8, CLOSESIZEUNIT, "pt", CLOSESIZE, 8,
   CAPTION, "Select a date", OFFSETX, 20, OFFSETY, -20);
  // save where the 'over' div ended up; we want to stay in the same place if the user
  // clicks on one of the year or month navigation links
  if ( (ns4) || (ie4) ) {
          ggPosX = parseInt(over.left);
          ggPosY = parseInt(over.top);
   } else if (ns6) {
   ggPosX = parseInt(over.style.left);
   ggPosY = parseInt(over.style.top);
   }
  }
 else {
  // we have a saved X & Y position, so use those with the FIXX and FIXY options
  overlib(ggWinContent, AUTOSTATUSCAP, STICKY, CLOSECLICK, CSSSTYLE,
   TEXTSIZEUNIT, "pt", TEXTSIZE, 8, CAPTIONSIZEUNIT, "pt", CAPTIONSIZE, 8, CLOSESIZEUNIT, "pt", CLOSESIZE, 8,
   CAPTION, "Select a date", FIXX, ggPosX, FIXY, ggPosY);
  }
 window.scroll(ggPosX, ggPosY);
}
function show_calendar() {
 /*
  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 = "YYYY-MM-DD";
 else
  p_format = arguments[3];
 Build(p_item, p_month, p_year, p_format);
}
/*
Yearly Calendar Code Starts here
*/
function show_yearly_calendar() {
 // Load the defaults..
 //if (p_year == null || p_year == "")
 // p_year = new String(gNow.getFullYear().toString());
 //if (p_format == null || p_format == "")
 // p_format = "YYYY-MM-DD";
 p_item = arguments[0];
 if (arguments[1] == "" || arguments[1] == null)
  p_year = new String(gNow.getFullYear().toString());
 else
  p_year = arguments[1];
 if (arguments[2] == null)
  p_format = "YYYY-MM-DD";
 else
  p_format = arguments[2];
 Build(p_item, null, p_year, p_format);
}
</script>
<script language="JavaScript" src="overlib_mini.js"></script>
</HEAD>
<BODY>
<hr>
<small>&copy; 2004  Trade Group. All rights reserved.</small>
<!-- This script and many more are available free online at -->
<!-- The JavaScript Source!! http://javascript.internet.com -->
<!-- Original:  James O'Connor (joconnor@nordenterprises.com) -->
<!-- Web Site:  http://nordenterprises.com -->
<div id="overDiv" style="position:absolute; visibility:hidden; z-index:1000;"></div>
<p>Pop-up calendar sample page:</p>
<form name="sample" method="post" action="popupcalsample.html">
 <p>Beginning date: <input type="text" name="T1" size="20"> 
 <!-- ggPosX and ggPosY not set, so popup will autolocate to the right of the graphic -->
 <a href="javascript:show_calendar('sample.T1');" onMouseOver="window.status='Date Picker'; overlib('Click here to choose a date from a one month pop-up calendar.'); return true;" onMouseOut="window.status=''; nd(); return true;"><img src="http://nordenterprises.com/h-o-a-home/images/show-calendar.gif" width=24 height=22 border=0></a>
 </p>
 <p>Ending date:     <input type="text" name="T2" size="20"> 
 <!-- ggPosX and ggPosY are set, so popup goes where you tell it -->
 <a href="javascript:ggPosX=5;ggPosY=200;show_yearly_calendar('sample.T2');" onMouseOver="window.status='Date Picker'; overlib('Click here to choose a date from a full year pop-up calendar.'); return true;" onMouseOut="window.status=''; nd(); return true;"><img src="http://nordenterprises.com/h-o-a-home/images/show-calendar.gif" width=24 height=22 border=0></a>
 </p>
 <p><input type="submit" value="Submit" name="B1"><input type="reset"
 value="Reset" name="B2"></p>
</form>
<p><center>
<font face="arial, helvetica" size"-2">Free JavaScripts provided<br>
by <a href="http://javascriptsource.com">The JavaScript Source</a></font>
</center><p>
<!-- Script Size:  22.17 KB -->
</body>
</html>