form date using javascript and sql (firefox, safare drops last dig

  • Thread starter Thread starter Guest
  • Start date Start date
G

Guest

Why does firefox and safare drop the last diggit in a required date field in
a form. I have a form that when completed stores the information in sql and I
needed to store the date in YYYY-MM-DD format so I found a javascript that
forces the user to use the correct format. What happens is the user enters
YYYY/MM/DD and when submit or going to another field the date is YYYY/MM/D I
might mention in explore it works fine.

HERE THE SCRIPT I USED.
<SCRIPT LANGUAGE="JavaScript">
<!-- Begin
// Check browser version
var isNav4 = false, isNav5 = false, isIE4 = false
var strSeperator = "/";
// If you are using any Java validation on the back side you will want to
use the / because
// Java date validations do not recognize the dash as a valid date separator.
var vDateType = 3; // Global value for type of date format
// 1 = mm/dd/yyyy
// 2 = yyyy/dd/mm (Unable to do date check at this time)
// 3 = dd/mm/yyyy
var vYearType = 4; //Set to 2 or 4 for number of digits in the year for
Netscape
var vYearLength = 2; // Set to 4 if you want to force the user to enter 4
digits for the year before validating.
var err = 0; // Set the error code to a default of zero
if(navigator.appName == "Netscape") {
if (navigator.appVersion < "5") {
isNav4 = true;
isNav5 = false;
}
else
if (navigator.appVersion > "4") {
isNav4 = false;
isNav5 = true;
}
}
else {
isIE4 = true;
}
function DateFormat(vDateName, vDateValue, e, dateCheck, dateType) {
vDateType = dateType;
// vDateName = object name
// vDateValue = value in the field being checked
// e = event
// dateCheck
// True = Verify that the vDateValue is a valid date
// False = Format values being entered into vDateValue only
// vDateType
// 1 = mm/dd/yyyy
// 2 = yyyy/mm/dd
// 3 = dd/mm/yyyy
//Enter a tilde sign for the first number and you can check the variable
information.
if (vDateValue == "~") {
alert("AppVersion = "+navigator.appVersion+" \nNav. 4 Version = "+isNav4+"
\nNav. 5 Version = "+isNav5+" \nIE Version = "+isIE4+" \nYear Type =
"+vYearType+" \nDate Type = "+vDateType+" \nSeparator = "+strSeperator);
vDateName.value = "";
vDateName.focus();
return true;
}
var whichCode = (window.Event) ? e.which : e.keyCode;
// Check to see if a seperator is already present.
// bypass the date if a seperator is present and the length greater than 8
if (vDateValue.length > 8 && isNav4) {
if ((vDateValue.indexOf("-") >= 1) || (vDateValue.indexOf("/") >= 1))
return true;
}
//Eliminate all the ASCII codes that are not valid
var alphaCheck = " abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ/-";
if (alphaCheck.indexOf(vDateValue) >= 1) {
if (isNav4) {
vDateName.value = "";
vDateName.focus();
vDateName.select();
return false;
}
else {
vDateName.value = vDateName.value.substr(0, (vDateValue.length-1));
return false;
}
}
if (whichCode == 8) //Ignore the Netscape value for backspace. IE has no value
return false;
else {
//Create numeric string values for 0123456789/
//The codes provided include both keyboard and keypad values
var strCheck =
'47,48,49,50,51,52,53,54,55,56,57,58,59,95,96,97,98,99,100,101,102,103,104,105';
if (strCheck.indexOf(whichCode) != -1) {
if (isNav4) {
if (((vDateValue.length < 6 && dateCheck) || (vDateValue.length == 7 &&
dateCheck)) && (vDateValue.length >=1)) {
alert("Invalid Date\nPlease Re-Enter");
vDateName.value = "";
vDateName.focus();
vDateName.select();
return false;
}
if (vDateValue.length == 6 && dateCheck) {
var mDay = vDateName.value.substr(2,2);
var mMonth = vDateName.value.substr(0,2);
var mYear = vDateName.value.substr(4,4)
//Turn a two digit year into a 4 digit year
if (mYear.length == 2 && vYearType == 4) {
var mToday = new Date();
//If the year is greater than 30 years from now use 19, otherwise use 20
var checkYear = mToday.getFullYear() + 30;
var mCheckYear = '20' + mYear;
if (mCheckYear >= checkYear)
mYear = '19' + mYear;
else
mYear = '20' + mYear;
}
var vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
if (!dateValid(vDateValueCheck)) {
alert("Invalid Date\nPlease Re-Enter");
vDateName.value = "";
vDateName.focus();
vDateName.select();
return false;
}
return true;
}
else {
// Reformat the date for validation and set date type to a 1
if (vDateValue.length >= 8 && dateCheck) {
if (vDateType == 1) // mmddyyyy
{
var mDay = vDateName.value.substr(2,2);
var mMonth = vDateName.value.substr(0,2);
var mYear = vDateName.value.substr(4,4)
vDateName.value = mMonth+strSeperator+mDay+strSeperator+mYear;
}
if (vDateType == 2) // yyyymmdd
{
var mYear = vDateName.value.substr(0,4)
var mMonth = vDateName.value.substr(4,2);
var mDay = vDateName.value.substr(6,2);
vDateName.value = mYear+strSeperator+mMonth+strSeperator+mDay;
}
if (vDateType == 3) // ddmmyyyy
{
var mMonth = vDateName.value.substr(2,2);
var mDay = vDateName.value.substr(0,2);
var mYear = vDateName.value.substr(4,4)
vDateName.value = mDay+strSeperator+mMonth+strSeperator+mYear;
}
//Create a temporary variable for storing the DateType and change
//the DateType to a 1 for validation.
var vDateTypeTemp = vDateType;
vDateType = 1;
var vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
if (!dateValid(vDateValueCheck)) {
alert("Invalid Date\nPlease Re-Enter");
vDateType = vDateTypeTemp;
vDateName.value = "";
vDateName.focus();
vDateName.select();
return false;
}
vDateType = vDateTypeTemp;
return true;
}
else {
if (((vDateValue.length < 8 && dateCheck) || (vDateValue.length == 9 &&
dateCheck)) && (vDateValue.length >=1)) {
alert("Invalid Date\nPlease Re-Enter");
vDateName.value = "";
vDateName.focus();
vDateName.select();
return false;
}
}
}
}
else {
// Non isNav Check
if (((vDateValue.length < 8 && dateCheck) || (vDateValue.length == 9 &&
dateCheck)) && (vDateValue.length >=1)) {
alert("Invalid Date\nPlease Re-Enter");
vDateName.value = "";
vDateName.focus();
return true;
}
// Reformat date to format that can be validated. mm/dd/yyyy
if (vDateValue.length >= 8 && dateCheck) {
// Additional date formats can be entered here and parsed out to
// a valid date format that the validation routine will recognize.
if (vDateType == 1) // mm/dd/yyyy
{
var mMonth = vDateName.value.substr(0,2);
var mDay = vDateName.value.substr(3,2);
var mYear = vDateName.value.substr(6,4)
}
if (vDateType == 2) // yyyy/mm/dd
{
var mYear = vDateName.value.substr(0,4)
var mMonth = vDateName.value.substr(5,2);
var mDay = vDateName.value.substr(8,2);
}
if (vDateType == 3) // dd/mm/yyyy
{
var mDay = vDateName.value.substr(0,2);
var mMonth = vDateName.value.substr(3,2);
var mYear = vDateName.value.substr(6,4)
}
if (vYearLength == 4) {
if (mYear.length < 4) {
alert("Invalid Date\nPlease Re-Enter");
vDateName.value = "";
vDateName.focus();
return true;
}
}
// Create temp. variable for storing the current vDateType
var vDateTypeTemp = vDateType;
// Change vDateType to a 1 for standard date format for validation
// Type will be changed back when validation is completed.
vDateType = 1;
// Store reformatted date to new variable for validation.
var vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
if (mYear.length == 2 && vYearType == 4 && dateCheck) {
//Turn a two digit year into a 4 digit year
var mToday = new Date();
//If the year is greater than 30 years from now use 19, otherwise use 20
var checkYear = mToday.getFullYear() + 30;
var mCheckYear = '20' + mYear;
if (mCheckYear >= checkYear)
mYear = '19' + mYear;
else
mYear = '20' + mYear;
vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
// Store the new value back to the field. This function will
// not work with date type of 2 since the year is entered first.
if (vDateTypeTemp == 1) // mm/dd/yyyy
vDateName.value = mMonth+strSeperator+mDay+strSeperator+mYear;
if (vDateTypeTemp == 3) // dd/mm/yyyy
vDateName.value = mDay+strSeperator+mMonth+strSeperator+mYear;
}
if (!dateValid(vDateValueCheck)) {
alert("Invalid Date\nPlease Re-Enter YYYY/MM/DD");
vDateType = vDateTypeTemp;
vDateName.value = "";
vDateName.focus();
return true;
}
vDateType = vDateTypeTemp;
return true;
}
else {
if (vDateType == 1) {
if (vDateValue.length == 2) {
vDateName.value = vDateValue+strSeperator;
}
if (vDateValue.length == 5) {
vDateName.value = vDateValue+strSeperator;
}
}
if (vDateType == 2) {
if (vDateValue.length == 4) {
vDateName.value = vDateValue+strSeperator;
}
if (vDateValue.length == 7) {
vDateName.value = vDateValue+strSeperator;
}
}
if (vDateType == 3) {
if (vDateValue.length == 2) {
vDateName.value = vDateValue+strSeperator;
}
if (vDateValue.length == 5) {
vDateName.value = vDateValue+strSeperator;
}
}
return true;
}
}
if (vDateValue.length == 10&& dateCheck) {
if (!dateValid(vDateName)) {
// Un-comment the next line of code for debugging the dateValid() function
error messages
//alert(err);
alert("Invalid Date\nPlease Re-Enter");
vDateName.focus();
vDateName.select();
}
}
return false;
}
else {
// If the value is not in the string return the string minus the last
// key entered.
if (isNav4) {
vDateName.value = "";
vDateName.focus();
vDateName.select();
return false;
}
else
{
vDateName.value = vDateName.value.substr(0, (vDateValue.length-1));
return false;
}
}
}
}
function dateValid(objName) {
var strDate;
var strDateArray;
var strDay;
var strMonth;
var strYear;
var intday;
var intMonth;
var intYear;
var booFound = false;
var datefield = objName;
var strSeparatorArray = new Array("-"," ","/",".");
var intElementNr;
// var err = 0;
var strMonthArray = new Array(12);
strMonthArray[0] = "Jan";
strMonthArray[1] = "Feb";
strMonthArray[2] = "Mar";
strMonthArray[3] = "Apr";
strMonthArray[4] = "May";
strMonthArray[5] = "Jun";
strMonthArray[6] = "Jul";
strMonthArray[7] = "Aug";
strMonthArray[8] = "Sep";
strMonthArray[9] = "Oct";
strMonthArray[10] = "Nov";
strMonthArray[11] = "Dec";
//strDate = datefield.value;
strDate = objName;
if (strDate.length < 1) {
return true;
}
for (intElementNr = 0; intElementNr < strSeparatorArray.length;
intElementNr++) {
if (strDate.indexOf(strSeparatorArray[intElementNr]) != -1) {
strDateArray = strDate.split(strSeparatorArray[intElementNr]);
if (strDateArray.length != 3) {
err = 1;
return false;
}
else {
strDay = strDateArray[0];
strMonth = strDateArray[1];
strYear = strDateArray[2];
}
booFound = true;
}
}
if (booFound == false) {
if (strDate.length>5) {
strDay = strDate.substr(0, 2);
strMonth = strDate.substr(2, 2);
strYear = strDate.substr(4);
}
}
//Adjustment for short years entered
if (strYear.length == 2) {
strYear = '20' + strYear;
}
strTemp = strDay;
strDay = strMonth;
strMonth = strTemp;
intday = parseInt(strDay, 10);
if (isNaN(intday)) {
err = 2;
return false;
}
intMonth = parseInt(strMonth, 10);
if (isNaN(intMonth)) {
for (i = 0;i<12;i++) {
if (strMonth.toUpperCase() == strMonthArray.toUpperCase()) {
intMonth = i+1;
strMonth = strMonthArray;
i = 12;
}
}
if (isNaN(intMonth)) {
err = 3;
return false;
}
}
intYear = parseInt(strYear, 10);
if (isNaN(intYear)) {
err = 4;
return false;
}
if (intMonth>12 || intMonth<1) {
err = 5;
return false;
}
if ((intMonth == 1 || intMonth == 3 || intMonth == 5 || intMonth == 7 ||
intMonth == 8 || intMonth == 10 || intMonth == 12) && (intday > 31 || intday
< 1)) {
err = 6;
return false;
}
if ((intMonth == 4 || intMonth == 6 || intMonth == 9 || intMonth == 11) &&
(intday > 30 || intday < 1)) {
err = 7;
return false;
}
if (intMonth == 2) {
if (intday < 1) {
err = 8;
return false;
}
if (LeapYear(intYear) == true) {
if (intday > 29) {
err = 9;
return false;
}
}
else {
if (intday > 28) {
err = 10;
return false;
}
}
}
return true;
}
function LeapYear(intYear) {
if (intYear % 100 == 0) {
if (intYear % 400 == 0) { return true; }
}
else {
if ((intYear % 4) == 0) { return true; }
}
return false;
}
// End -->
</script>

HERES THE FORM
<form enctype='multipart/form-data' action='canhelp.php' method='post'
onsubmit="return FrontPage_Form1_Validator(this)" language="JavaScript"
name="FrontPage_Form1">
<table border=1 bordercolor='#000000'>
<table width='87%' border=1 cellspacing="1" bgcolor="#FFFFCC"
bordercolor="#99CCFF">
<tr><td width="30%"> First Name<font color='#ff0000'>*</font></td>
<td width="20%">
<input type=text name='FirstName' class="memorize"></td>
<td width="20%">
<font face='arial' size=2><b>Last Name</td>
<td width="20%">
<font face='arial' size=2><b>
<input type=text name='LastName' class="memorize"></td></tr>
<tr><td width="30%"> Date Can Help<font color='#ff0000'>*</font></td>
<td width="20%">
<input type=text name='DateCanHelp' size="10"
maxlength="10"javascript:vDateType='2'"
onKeyUp="DateFormat(this,this.value,event,false,'2')"
onBlur="DateFormat(this,this.value,event,true,'2')">
</td>
<td width="20%">
<font face='arial' size=2><b>E Mail<font color='#ff0000'>*</font></td>
<td width="20%">
<font face='arial' size=2><b>
<input type=email name='EMail' class="memorize"></td></tr>
<tr><td valign="top" width="30%"> Comments<font color='#ff0000'>*</font></td>
<td colspan="3" width="60%">
<textarea name='Comments' rows=2 cols=55></textarea></td></tr>
</table>
</td></tr></table>
<input type='submit' value='Submit Form'> <input type=reset value='Clear
Form'></form>
 
Without looking at the details
- your script is flawed in that it only supports Netscape and IE as browsers
(so it will not necessarily work on Mozzila or other browsers)

IMHO
Since you are processing the form w/ PHP
- let users enter the date in a different format and reformat the results in your server side code to what you need in the DB
(you should be checking for a valid date there too before using the data entered)
--

_____________________________________________
SBR @ ENJOY (-: [ Microsoft MVP - FrontPage ]
"Warning - Using the F1 Key will not break anything!" (-;
_____________________________________________


| Why does firefox and safare drop the last diggit in a required date field in
| a form. I have a form that when completed stores the information in sql and I
| needed to store the date in YYYY-MM-DD format so I found a javascript that
| forces the user to use the correct format. What happens is the user enters
| YYYY/MM/DD and when submit or going to another field the date is YYYY/MM/D I
| might mention in explore it works fine.
|
| HERE THE SCRIPT I USED.
| <SCRIPT LANGUAGE="JavaScript">
| <!-- Begin
| // Check browser version
| var isNav4 = false, isNav5 = false, isIE4 = false
| var strSeperator = "/";
| // If you are using any Java validation on the back side you will want to
| use the / because
| // Java date validations do not recognize the dash as a valid date separator.
| var vDateType = 3; // Global value for type of date format
| // 1 = mm/dd/yyyy
| // 2 = yyyy/dd/mm (Unable to do date check at this time)
| // 3 = dd/mm/yyyy
| var vYearType = 4; //Set to 2 or 4 for number of digits in the year for
| Netscape
| var vYearLength = 2; // Set to 4 if you want to force the user to enter 4
| digits for the year before validating.
| var err = 0; // Set the error code to a default of zero
| if(navigator.appName == "Netscape") {
| if (navigator.appVersion < "5") {
| isNav4 = true;
| isNav5 = false;
| }
| else
| if (navigator.appVersion > "4") {
| isNav4 = false;
| isNav5 = true;
| }
| }
| else {
| isIE4 = true;
| }
| function DateFormat(vDateName, vDateValue, e, dateCheck, dateType) {
| vDateType = dateType;
| // vDateName = object name
| // vDateValue = value in the field being checked
| // e = event
| // dateCheck
| // True = Verify that the vDateValue is a valid date
| // False = Format values being entered into vDateValue only
| // vDateType
| // 1 = mm/dd/yyyy
| // 2 = yyyy/mm/dd
| // 3 = dd/mm/yyyy
| //Enter a tilde sign for the first number and you can check the variable
| information.
| if (vDateValue == "~") {
| alert("AppVersion = "+navigator.appVersion+" \nNav. 4 Version = "+isNav4+"
| \nNav. 5 Version = "+isNav5+" \nIE Version = "+isIE4+" \nYear Type =
| "+vYearType+" \nDate Type = "+vDateType+" \nSeparator = "+strSeperator);
| vDateName.value = "";
| vDateName.focus();
| return true;
| }
| var whichCode = (window.Event) ? e.which : e.keyCode;
| // Check to see if a seperator is already present.
| // bypass the date if a seperator is present and the length greater than 8
| if (vDateValue.length > 8 && isNav4) {
| if ((vDateValue.indexOf("-") >= 1) || (vDateValue.indexOf("/") >= 1))
| return true;
| }
| //Eliminate all the ASCII codes that are not valid
| var alphaCheck = " abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ/-";
| if (alphaCheck.indexOf(vDateValue) >= 1) {
| if (isNav4) {
| vDateName.value = "";
| vDateName.focus();
| vDateName.select();
| return false;
| }
| else {
| vDateName.value = vDateName.value.substr(0, (vDateValue.length-1));
| return false;
| }
| }
| if (whichCode == 8) //Ignore the Netscape value for backspace. IE has no value
| return false;
| else {
| //Create numeric string values for 0123456789/
| //The codes provided include both keyboard and keypad values
| var strCheck =
| '47,48,49,50,51,52,53,54,55,56,57,58,59,95,96,97,98,99,100,101,102,103,104,105';
| if (strCheck.indexOf(whichCode) != -1) {
| if (isNav4) {
| if (((vDateValue.length < 6 && dateCheck) || (vDateValue.length == 7 &&
| dateCheck)) && (vDateValue.length >=1)) {
| alert("Invalid Date\nPlease Re-Enter");
| vDateName.value = "";
| vDateName.focus();
| vDateName.select();
| return false;
| }
| if (vDateValue.length == 6 && dateCheck) {
| var mDay = vDateName.value.substr(2,2);
| var mMonth = vDateName.value.substr(0,2);
| var mYear = vDateName.value.substr(4,4)
| //Turn a two digit year into a 4 digit year
| if (mYear.length == 2 && vYearType == 4) {
| var mToday = new Date();
| //If the year is greater than 30 years from now use 19, otherwise use 20
| var checkYear = mToday.getFullYear() + 30;
| var mCheckYear = '20' + mYear;
| if (mCheckYear >= checkYear)
| mYear = '19' + mYear;
| else
| mYear = '20' + mYear;
| }
| var vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
| if (!dateValid(vDateValueCheck)) {
| alert("Invalid Date\nPlease Re-Enter");
| vDateName.value = "";
| vDateName.focus();
| vDateName.select();
| return false;
| }
| return true;
| }
| else {
| // Reformat the date for validation and set date type to a 1
| if (vDateValue.length >= 8 && dateCheck) {
| if (vDateType == 1) // mmddyyyy
| {
| var mDay = vDateName.value.substr(2,2);
| var mMonth = vDateName.value.substr(0,2);
| var mYear = vDateName.value.substr(4,4)
| vDateName.value = mMonth+strSeperator+mDay+strSeperator+mYear;
| }
| if (vDateType == 2) // yyyymmdd
| {
| var mYear = vDateName.value.substr(0,4)
| var mMonth = vDateName.value.substr(4,2);
| var mDay = vDateName.value.substr(6,2);
| vDateName.value = mYear+strSeperator+mMonth+strSeperator+mDay;
| }
| if (vDateType == 3) // ddmmyyyy
| {
| var mMonth = vDateName.value.substr(2,2);
| var mDay = vDateName.value.substr(0,2);
| var mYear = vDateName.value.substr(4,4)
| vDateName.value = mDay+strSeperator+mMonth+strSeperator+mYear;
| }
| //Create a temporary variable for storing the DateType and change
| //the DateType to a 1 for validation.
| var vDateTypeTemp = vDateType;
| vDateType = 1;
| var vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
| if (!dateValid(vDateValueCheck)) {
| alert("Invalid Date\nPlease Re-Enter");
| vDateType = vDateTypeTemp;
| vDateName.value = "";
| vDateName.focus();
| vDateName.select();
| return false;
| }
| vDateType = vDateTypeTemp;
| return true;
| }
| else {
| if (((vDateValue.length < 8 && dateCheck) || (vDateValue.length == 9 &&
| dateCheck)) && (vDateValue.length >=1)) {
| alert("Invalid Date\nPlease Re-Enter");
| vDateName.value = "";
| vDateName.focus();
| vDateName.select();
| return false;
| }
| }
| }
| }
| else {
| // Non isNav Check
| if (((vDateValue.length < 8 && dateCheck) || (vDateValue.length == 9 &&
| dateCheck)) && (vDateValue.length >=1)) {
| alert("Invalid Date\nPlease Re-Enter");
| vDateName.value = "";
| vDateName.focus();
| return true;
| }
| // Reformat date to format that can be validated. mm/dd/yyyy
| if (vDateValue.length >= 8 && dateCheck) {
| // Additional date formats can be entered here and parsed out to
| // a valid date format that the validation routine will recognize.
| if (vDateType == 1) // mm/dd/yyyy
| {
| var mMonth = vDateName.value.substr(0,2);
| var mDay = vDateName.value.substr(3,2);
| var mYear = vDateName.value.substr(6,4)
| }
| if (vDateType == 2) // yyyy/mm/dd
| {
| var mYear = vDateName.value.substr(0,4)
| var mMonth = vDateName.value.substr(5,2);
| var mDay = vDateName.value.substr(8,2);
| }
| if (vDateType == 3) // dd/mm/yyyy
| {
| var mDay = vDateName.value.substr(0,2);
| var mMonth = vDateName.value.substr(3,2);
| var mYear = vDateName.value.substr(6,4)
| }
| if (vYearLength == 4) {
| if (mYear.length < 4) {
| alert("Invalid Date\nPlease Re-Enter");
| vDateName.value = "";
| vDateName.focus();
| return true;
| }
| }
| // Create temp. variable for storing the current vDateType
| var vDateTypeTemp = vDateType;
| // Change vDateType to a 1 for standard date format for validation
| // Type will be changed back when validation is completed.
| vDateType = 1;
| // Store reformatted date to new variable for validation.
| var vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
| if (mYear.length == 2 && vYearType == 4 && dateCheck) {
| //Turn a two digit year into a 4 digit year
| var mToday = new Date();
| //If the year is greater than 30 years from now use 19, otherwise use 20
| var checkYear = mToday.getFullYear() + 30;
| var mCheckYear = '20' + mYear;
| if (mCheckYear >= checkYear)
| mYear = '19' + mYear;
| else
| mYear = '20' + mYear;
| vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
| // Store the new value back to the field. This function will
| // not work with date type of 2 since the year is entered first.
| if (vDateTypeTemp == 1) // mm/dd/yyyy
| vDateName.value = mMonth+strSeperator+mDay+strSeperator+mYear;
| if (vDateTypeTemp == 3) // dd/mm/yyyy
| vDateName.value = mDay+strSeperator+mMonth+strSeperator+mYear;
| }
| if (!dateValid(vDateValueCheck)) {
| alert("Invalid Date\nPlease Re-Enter YYYY/MM/DD");
| vDateType = vDateTypeTemp;
| vDateName.value = "";
| vDateName.focus();
| return true;
| }
| vDateType = vDateTypeTemp;
| return true;
| }
| else {
| if (vDateType == 1) {
| if (vDateValue.length == 2) {
| vDateName.value = vDateValue+strSeperator;
| }
| if (vDateValue.length == 5) {
| vDateName.value = vDateValue+strSeperator;
| }
| }
| if (vDateType == 2) {
| if (vDateValue.length == 4) {
| vDateName.value = vDateValue+strSeperator;
| }
| if (vDateValue.length == 7) {
| vDateName.value = vDateValue+strSeperator;
| }
| }
| if (vDateType == 3) {
| if (vDateValue.length == 2) {
| vDateName.value = vDateValue+strSeperator;
| }
| if (vDateValue.length == 5) {
| vDateName.value = vDateValue+strSeperator;
| }
| }
| return true;
| }
| }
| if (vDateValue.length == 10&& dateCheck) {
| if (!dateValid(vDateName)) {
| // Un-comment the next line of code for debugging the dateValid() function
| error messages
| //alert(err);
| alert("Invalid Date\nPlease Re-Enter");
| vDateName.focus();
| vDateName.select();
| }
| }
| return false;
| }
| else {
| // If the value is not in the string return the string minus the last
| // key entered.
| if (isNav4) {
| vDateName.value = "";
| vDateName.focus();
| vDateName.select();
| return false;
| }
| else
| {
| vDateName.value = vDateName.value.substr(0, (vDateValue.length-1));
| return false;
| }
| }
| }
| }
| function dateValid(objName) {
| var strDate;
| var strDateArray;
| var strDay;
| var strMonth;
| var strYear;
| var intday;
| var intMonth;
| var intYear;
| var booFound = false;
| var datefield = objName;
| var strSeparatorArray = new Array("-"," ","/",".");
| var intElementNr;
| // var err = 0;
| var strMonthArray = new Array(12);
| strMonthArray[0] = "Jan";
| strMonthArray[1] = "Feb";
| strMonthArray[2] = "Mar";
| strMonthArray[3] = "Apr";
| strMonthArray[4] = "May";
| strMonthArray[5] = "Jun";
| strMonthArray[6] = "Jul";
| strMonthArray[7] = "Aug";
| strMonthArray[8] = "Sep";
| strMonthArray[9] = "Oct";
| strMonthArray[10] = "Nov";
| strMonthArray[11] = "Dec";
| //strDate = datefield.value;
| strDate = objName;
| if (strDate.length < 1) {
| return true;
| }
| for (intElementNr = 0; intElementNr < strSeparatorArray.length;
| intElementNr++) {
| if (strDate.indexOf(strSeparatorArray[intElementNr]) != -1) {
| strDateArray = strDate.split(strSeparatorArray[intElementNr]);
| if (strDateArray.length != 3) {
| err = 1;
| return false;
| }
| else {
| strDay = strDateArray[0];
| strMonth = strDateArray[1];
| strYear = strDateArray[2];
| }
| booFound = true;
| }
| }
| if (booFound == false) {
| if (strDate.length>5) {
| strDay = strDate.substr(0, 2);
| strMonth = strDate.substr(2, 2);
| strYear = strDate.substr(4);
| }
| }
| //Adjustment for short years entered
| if (strYear.length == 2) {
| strYear = '20' + strYear;
| }
| strTemp = strDay;
| strDay = strMonth;
| strMonth = strTemp;
| intday = parseInt(strDay, 10);
| if (isNaN(intday)) {
| err = 2;
| return false;
| }
| intMonth = parseInt(strMonth, 10);
| if (isNaN(intMonth)) {
| for (i = 0;i<12;i++) {
| if (strMonth.toUpperCase() == strMonthArray.toUpperCase()) {
| intMonth = i+1;
| strMonth = strMonthArray;
| i = 12;
| }
| }
| if (isNaN(intMonth)) {
| err = 3;
| return false;
| }
| }
| intYear = parseInt(strYear, 10);
| if (isNaN(intYear)) {
| err = 4;
| return false;
| }
| if (intMonth>12 || intMonth<1) {
| err = 5;
| return false;
| }
| if ((intMonth == 1 || intMonth == 3 || intMonth == 5 || intMonth == 7 ||
| intMonth == 8 || intMonth == 10 || intMonth == 12) && (intday > 31 || intday
| < 1)) {
| err = 6;
| return false;
| }
| if ((intMonth == 4 || intMonth == 6 || intMonth == 9 || intMonth == 11) &&
| (intday > 30 || intday < 1)) {
| err = 7;
| return false;
| }
| if (intMonth == 2) {
| if (intday < 1) {
| err = 8;
| return false;
| }
| if (LeapYear(intYear) == true) {
| if (intday > 29) {
| err = 9;
| return false;
| }
| }
| else {
| if (intday > 28) {
| err = 10;
| return false;
| }
| }
| }
| return true;
| }
| function LeapYear(intYear) {
| if (intYear % 100 == 0) {
| if (intYear % 400 == 0) { return true; }
| }
| else {
| if ((intYear % 4) == 0) { return true; }
| }
| return false;
| }
| // End -->
| </script>
|
| HERES THE FORM
| <form enctype='multipart/form-data' action='canhelp.php' method='post'
| onsubmit="return FrontPage_Form1_Validator(this)" language="JavaScript"
| name="FrontPage_Form1">
| <table border=1 bordercolor='#000000'>
| <table width='87%' border=1 cellspacing="1" bgcolor="#FFFFCC"
| bordercolor="#99CCFF">
| <tr><td width="30%"> First Name<font color='#ff0000'>*</font></td>
| <td width="20%">
| <input type=text name='FirstName' class="memorize"></td>
| <td width="20%">
| <font face='arial' size=2><b>Last Name</td>
| <td width="20%">
| <font face='arial' size=2><b>
| <input type=text name='LastName' class="memorize"></td></tr>
| <tr><td width="30%"> Date Can Help<font color='#ff0000'>*</font></td>
| <td width="20%">
| <input type=text name='DateCanHelp' size="10"
| maxlength="10"javascript:vDateType='2'"
| onKeyUp="DateFormat(this,this.value,event,false,'2')"
| onBlur="DateFormat(this,this.value,event,true,'2')">
| </td>
| <td width="20%">
| <font face='arial' size=2><b>E Mail<font color='#ff0000'>*</font></td>
| <td width="20%">
| <font face='arial' size=2><b>
| <input type=email name='EMail' class="memorize"></td></tr>
| <tr><td valign="top" width="30%"> Comments<font color='#ff0000'>*</font></td>
| <td colspan="3" width="60%">
| <textarea name='Comments' rows=2 cols=55></textarea></td></tr>
| </table>
| </td></tr></table>
| <input type='submit' value='Submit Form'> <input type=reset value='Clear
| Form'></form>
|
 
Sorry Im new to all this So can you help me do that. heres the php page
<?php
include("global.inc.php");
$errors=0;
$error="The following errors occured while processing your form input.<ul>";
pt_register('POST','FirstName');
pt_register('POST','LastName');
pt_register('POST','DateCanHelp');
pt_register('POST','EMail');
pt_register('POST','Comments');
$Comments=preg_replace("/(\015\012)|(\015)|(\012)/"," <br />",
$Comments);if($FirstName=="" || $DateCanHelp=="" || $EMail=="" ||
$Comments=="" ){
$errors=1;
$error.="<li>You did not enter one or more of the required fields. Please go
back and try again.";
}
if(!eregi("^[a-z0-9]+([_\\.-][a-z0-9]+)*"
.."@"."([a-z0-9]+([\.-][a-z0-9]+)*)+"."\\.[a-z]{2,}"."$",$EMail)){
$error.="<li>Invalid email address entered";
$errors=1;
}
if($errors==1) echo $error;
else
$where_form_is="http".($HTTP_SERVER_VARS["HTTPS"]=="on"?"s":"")."://".$SERVER_NAME.strrev(strstr(strrev($PHP_SELF),"/"));
$message="First Name: ".$FirstName."
Last Name: ".$LastName."
DateCanHelp: ".$DateCanHelp."
EMail: ".$EMail."
Comments: ".$Comments."
";
$message = stripslashes($message);
mail("(e-mail address removed)","I Can Help",$message,"From: $FirstName $LastName");
$link = mysql_connect("localhost","admin","adminwantsin");
mysql_select_db("use_form",$link);
$query="insert into CanHelp
(First_Name,Last_Name,DateCanHelp,EMail,Comments) values
('".$FirstName."','".$LastName."','".$DateCanHelp."','".$EMail."','".$Comments."')";
mysql_query($query);

header("Refresh: 0;url=http://www.myweb.com\use\canhelp/canhelp.html");
?><?php
}
?>

Stefan B Rusynko said:
Without looking at the details
- your script is flawed in that it only supports Netscape and IE as browsers
(so it will not necessarily work on Mozzila or other browsers)

IMHO
Since you are processing the form w/ PHP
- let users enter the date in a different format and reformat the results in your server side code to what you need in the DB
(you should be checking for a valid date there too before using the data entered)
--

_____________________________________________
SBR @ ENJOY (-: [ Microsoft MVP - FrontPage ]
"Warning - Using the F1 Key will not break anything!" (-;
_____________________________________________


| Why does firefox and safare drop the last diggit in a required date field in
| a form. I have a form that when completed stores the information in sql and I
| needed to store the date in YYYY-MM-DD format so I found a javascript that
| forces the user to use the correct format. What happens is the user enters
| YYYY/MM/DD and when submit or going to another field the date is YYYY/MM/D I
| might mention in explore it works fine.
|
| HERE THE SCRIPT I USED.
| <SCRIPT LANGUAGE="JavaScript">
| <!-- Begin
| // Check browser version
| var isNav4 = false, isNav5 = false, isIE4 = false
| var strSeperator = "/";
| // If you are using any Java validation on the back side you will want to
| use the / because
| // Java date validations do not recognize the dash as a valid date separator.
| var vDateType = 3; // Global value for type of date format
| // 1 = mm/dd/yyyy
| // 2 = yyyy/dd/mm (Unable to do date check at this time)
| // 3 = dd/mm/yyyy
| var vYearType = 4; //Set to 2 or 4 for number of digits in the year for
| Netscape
| var vYearLength = 2; // Set to 4 if you want to force the user to enter 4
| digits for the year before validating.
| var err = 0; // Set the error code to a default of zero
| if(navigator.appName == "Netscape") {
| if (navigator.appVersion < "5") {
| isNav4 = true;
| isNav5 = false;
| }
| else
| if (navigator.appVersion > "4") {
| isNav4 = false;
| isNav5 = true;
| }
| }
| else {
| isIE4 = true;
| }
| function DateFormat(vDateName, vDateValue, e, dateCheck, dateType) {
| vDateType = dateType;
| // vDateName = object name
| // vDateValue = value in the field being checked
| // e = event
| // dateCheck
| // True = Verify that the vDateValue is a valid date
| // False = Format values being entered into vDateValue only
| // vDateType
| // 1 = mm/dd/yyyy
| // 2 = yyyy/mm/dd
| // 3 = dd/mm/yyyy
| //Enter a tilde sign for the first number and you can check the variable
| information.
| if (vDateValue == "~") {
| alert("AppVersion = "+navigator.appVersion+" \nNav. 4 Version = "+isNav4+"
| \nNav. 5 Version = "+isNav5+" \nIE Version = "+isIE4+" \nYear Type =
| "+vYearType+" \nDate Type = "+vDateType+" \nSeparator = "+strSeperator);
| vDateName.value = "";
| vDateName.focus();
| return true;
| }
| var whichCode = (window.Event) ? e.which : e.keyCode;
| // Check to see if a seperator is already present.
| // bypass the date if a seperator is present and the length greater than 8
| if (vDateValue.length > 8 && isNav4) {
| if ((vDateValue.indexOf("-") >= 1) || (vDateValue.indexOf("/") >= 1))
| return true;
| }
| //Eliminate all the ASCII codes that are not valid
| var alphaCheck = " abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ/-";
| if (alphaCheck.indexOf(vDateValue) >= 1) {
| if (isNav4) {
| vDateName.value = "";
| vDateName.focus();
| vDateName.select();
| return false;
| }
| else {
| vDateName.value = vDateName.value.substr(0, (vDateValue.length-1));
| return false;
| }
| }
| if (whichCode == 8) //Ignore the Netscape value for backspace. IE has no value
| return false;
| else {
| //Create numeric string values for 0123456789/
| //The codes provided include both keyboard and keypad values
| var strCheck =
| '47,48,49,50,51,52,53,54,55,56,57,58,59,95,96,97,98,99,100,101,102,103,104,105';
| if (strCheck.indexOf(whichCode) != -1) {
| if (isNav4) {
| if (((vDateValue.length < 6 && dateCheck) || (vDateValue.length == 7 &&
| dateCheck)) && (vDateValue.length >=1)) {
| alert("Invalid Date\nPlease Re-Enter");
| vDateName.value = "";
| vDateName.focus();
| vDateName.select();
| return false;
| }
| if (vDateValue.length == 6 && dateCheck) {
| var mDay = vDateName.value.substr(2,2);
| var mMonth = vDateName.value.substr(0,2);
| var mYear = vDateName.value.substr(4,4)
| //Turn a two digit year into a 4 digit year
| if (mYear.length == 2 && vYearType == 4) {
| var mToday = new Date();
| //If the year is greater than 30 years from now use 19, otherwise use 20
| var checkYear = mToday.getFullYear() + 30;
| var mCheckYear = '20' + mYear;
| if (mCheckYear >= checkYear)
| mYear = '19' + mYear;
| else
| mYear = '20' + mYear;
| }
| var vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
| if (!dateValid(vDateValueCheck)) {
| alert("Invalid Date\nPlease Re-Enter");
| vDateName.value = "";
| vDateName.focus();
| vDateName.select();
| return false;
| }
| return true;
| }
| else {
| // Reformat the date for validation and set date type to a 1
| if (vDateValue.length >= 8 && dateCheck) {
| if (vDateType == 1) // mmddyyyy
| {
| var mDay = vDateName.value.substr(2,2);
| var mMonth = vDateName.value.substr(0,2);
| var mYear = vDateName.value.substr(4,4)
| vDateName.value = mMonth+strSeperator+mDay+strSeperator+mYear;
| }
| if (vDateType == 2) // yyyymmdd
| {
| var mYear = vDateName.value.substr(0,4)
| var mMonth = vDateName.value.substr(4,2);
| var mDay = vDateName.value.substr(6,2);
| vDateName.value = mYear+strSeperator+mMonth+strSeperator+mDay;
| }
| if (vDateType == 3) // ddmmyyyy
| {
| var mMonth = vDateName.value.substr(2,2);
| var mDay = vDateName.value.substr(0,2);
| var mYear = vDateName.value.substr(4,4)
| vDateName.value = mDay+strSeperator+mMonth+strSeperator+mYear;
| }
| //Create a temporary variable for storing the DateType and change
| //the DateType to a 1 for validation.
| var vDateTypeTemp = vDateType;
| vDateType = 1;
| var vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
| if (!dateValid(vDateValueCheck)) {
| alert("Invalid Date\nPlease Re-Enter");
| vDateType = vDateTypeTemp;
| vDateName.value = "";
| vDateName.focus();
| vDateName.select();
| return false;
| }
| vDateType = vDateTypeTemp;
| return true;
| }
| else {
| if (((vDateValue.length < 8 && dateCheck) || (vDateValue.length == 9 &&
| dateCheck)) && (vDateValue.length >=1)) {
| alert("Invalid Date\nPlease Re-Enter");
| vDateName.value = "";
| vDateName.focus();
| vDateName.select();
| return false;
| }
| }
| }
| }
| else {
| // Non isNav Check
| if (((vDateValue.length < 8 && dateCheck) || (vDateValue.length == 9 &&
| dateCheck)) && (vDateValue.length >=1)) {
| alert("Invalid Date\nPlease Re-Enter");
| vDateName.value = "";
| vDateName.focus();
| return true;
| }
| // Reformat date to format that can be validated. mm/dd/yyyy
| if (vDateValue.length >= 8 && dateCheck) {
| // Additional date formats can be entered here and parsed out to
| // a valid date format that the validation routine will recognize.
| if (vDateType == 1) // mm/dd/yyyy
| {
| var mMonth = vDateName.value.substr(0,2);
| var mDay = vDateName.value.substr(3,2);
| var mYear = vDateName.value.substr(6,4)
| }
| if (vDateType == 2) // yyyy/mm/dd
| {
| var mYear = vDateName.value.substr(0,4)
| var mMonth = vDateName.value.substr(5,2);
| var mDay = vDateName.value.substr(8,2);
| }
| if (vDateType == 3) // dd/mm/yyyy
| {
| var mDay = vDateName.value.substr(0,2);
| var mMonth = vDateName.value.substr(3,2);
| var mYear = vDateName.value.substr(6,4)
| }
| if (vYearLength == 4) {
| if (mYear.length < 4) {
| alert("Invalid Date\nPlease Re-Enter");
| vDateName.value = "";
| vDateName.focus();
| return true;
| }
| }
| // Create temp. variable for storing the current vDateType
| var vDateTypeTemp = vDateType;
| // Change vDateType to a 1 for standard date format for validation
| // Type will be changed back when validation is completed.
| vDateType = 1;
| // Store reformatted date to new variable for validation.
| var vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
| if (mYear.length == 2 && vYearType == 4 && dateCheck) {
| //Turn a two digit year into a 4 digit year
| var mToday = new Date();
| //If the year is greater than 30 years from now use 19, otherwise use 20
| var checkYear = mToday.getFullYear() + 30;
| var mCheckYear = '20' + mYear;
| if (mCheckYear >= checkYear)
| mYear = '19' + mYear;
| else
| mYear = '20' + mYear;
| vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
| // Store the new value back to the field. This function will
| // not work with date type of 2 since the year is entered first.
| if (vDateTypeTemp == 1) // mm/dd/yyyy
| vDateName.value = mMonth+strSeperator+mDay+strSeperator+mYear;
| if (vDateTypeTemp == 3) // dd/mm/yyyy
| vDateName.value = mDay+strSeperator+mMonth+strSeperator+mYear;
| }
| if (!dateValid(vDateValueCheck)) {
| alert("Invalid Date\nPlease Re-Enter YYYY/MM/DD");
| vDateType = vDateTypeTemp;
| vDateName.value = "";
| vDateName.focus();
| return true;
| }
| vDateType = vDateTypeTemp;
| return true;
| }
| else {
| if (vDateType == 1) {
| if (vDateValue.length == 2) {
| vDateName.value = vDateValue+strSeperator;
| }
| if (vDateValue.length == 5) {
| vDateName.value = vDateValue+strSeperator;
| }
| }
| if (vDateType == 2) {
| if (vDateValue.length == 4) {
| vDateName.value = vDateValue+strSeperator;
| }
| if (vDateValue.length == 7) {
| vDateName.value = vDateValue+strSeperator;
| }
| }
| if (vDateType == 3) {
| if (vDateValue.length == 2) {
| vDateName.value = vDateValue+strSeperator;
| }
| if (vDateValue.length == 5) {
| vDateName.value = vDateValue+strSeperator;
| }
| }
| return true;
| }
| }
| if (vDateValue.length == 10&& dateCheck) {
| if (!dateValid(vDateName)) {
| // Un-comment the next line of code for debugging the dateValid() function
| error messages
| //alert(err);
 
See http://www.w3schools.com/php/default.asp

--

_____________________________________________
SBR @ ENJOY (-: [ Microsoft MVP - FrontPage ]
"Warning - Using the F1 Key will not break anything!" (-;
_____________________________________________


| Sorry Im new to all this So can you help me do that. heres the php page
| <?php
| include("global.inc.php");
| $errors=0;
| $error="The following errors occured while processing your form input.<ul>";
| pt_register('POST','FirstName');
| pt_register('POST','LastName');
| pt_register('POST','DateCanHelp');
| pt_register('POST','EMail');
| pt_register('POST','Comments');
| $Comments=preg_replace("/(\015\012)|(\015)|(\012)/"," <br />",
| $Comments);if($FirstName=="" || $DateCanHelp=="" || $EMail=="" ||
| $Comments=="" ){
| $errors=1;
| $error.="<li>You did not enter one or more of the required fields. Please go
| back and try again.";
| }
| if(!eregi("^[a-z0-9]+([_\\.-][a-z0-9]+)*"
| ."@"."([a-z0-9]+([\.-][a-z0-9]+)*)+"."\\.[a-z]{2,}"."$",$EMail)){
| $error.="<li>Invalid email address entered";
| $errors=1;
| }
| if($errors==1) echo $error;
| else{
| $where_form_is="http".($HTTP_SERVER_VARS["HTTPS"]=="on"?"s":"")."://".$SERVER_NAME.strrev(strstr(strrev($PHP_SELF),"/"));
| $message="First Name: ".$FirstName."
| Last Name: ".$LastName."
| DateCanHelp: ".$DateCanHelp."
| EMail: ".$EMail."
| Comments: ".$Comments."
| ";
| $message = stripslashes($message);
| mail("(e-mail address removed)","I Can Help",$message,"From: $FirstName $LastName");
| $link = mysql_connect("localhost","admin","adminwantsin");
| mysql_select_db("use_form",$link);
| $query="insert into CanHelp
| (First_Name,Last_Name,DateCanHelp,EMail,Comments) values
| ('".$FirstName."','".$LastName."','".$DateCanHelp."','".$EMail."','".$Comments."')";
| mysql_query($query);
|
| header("Refresh: 0;url=http://www.myweb.com\use\canhelp/canhelp.html");
| ?><?php
| }
| ?>
|
| "Stefan B Rusynko" wrote:
|
| > Without looking at the details
| > - your script is flawed in that it only supports Netscape and IE as browsers
| > (so it will not necessarily work on Mozzila or other browsers)
| >
| > IMHO
| > Since you are processing the form w/ PHP
| > - let users enter the date in a different format and reformat the results in your server side code to what you need in the DB
| > (you should be checking for a valid date there too before using the data entered)
| > --
| >
| > _____________________________________________
| > SBR @ ENJOY (-: [ Microsoft MVP - FrontPage ]
| > "Warning - Using the F1 Key will not break anything!" (-;
| > _____________________________________________
| >
| >
| > | Why does firefox and safare drop the last diggit in a required date field in
| > | a form. I have a form that when completed stores the information in sql and I
| > | needed to store the date in YYYY-MM-DD format so I found a javascript that
| > | forces the user to use the correct format. What happens is the user enters
| > | YYYY/MM/DD and when submit or going to another field the date is YYYY/MM/D I
| > | might mention in explore it works fine.
| > |
| > | HERE THE SCRIPT I USED.
| > | <SCRIPT LANGUAGE="JavaScript">
| > | <!-- Begin
| > | // Check browser version
| > | var isNav4 = false, isNav5 = false, isIE4 = false
| > | var strSeperator = "/";
| > | // If you are using any Java validation on the back side you will want to
| > | use the / because
| > | // Java date validations do not recognize the dash as a valid date separator.
| > | var vDateType = 3; // Global value for type of date format
| > | // 1 = mm/dd/yyyy
| > | // 2 = yyyy/dd/mm (Unable to do date check at this time)
| > | // 3 = dd/mm/yyyy
| > | var vYearType = 4; //Set to 2 or 4 for number of digits in the year for
| > | Netscape
| > | var vYearLength = 2; // Set to 4 if you want to force the user to enter 4
| > | digits for the year before validating.
| > | var err = 0; // Set the error code to a default of zero
| > | if(navigator.appName == "Netscape") {
| > | if (navigator.appVersion < "5") {
| > | isNav4 = true;
| > | isNav5 = false;
| > | }
| > | else
| > | if (navigator.appVersion > "4") {
| > | isNav4 = false;
| > | isNav5 = true;
| > | }
| > | }
| > | else {
| > | isIE4 = true;
| > | }
| > | function DateFormat(vDateName, vDateValue, e, dateCheck, dateType) {
| > | vDateType = dateType;
| > | // vDateName = object name
| > | // vDateValue = value in the field being checked
| > | // e = event
| > | // dateCheck
| > | // True = Verify that the vDateValue is a valid date
| > | // False = Format values being entered into vDateValue only
| > | // vDateType
| > | // 1 = mm/dd/yyyy
| > | // 2 = yyyy/mm/dd
| > | // 3 = dd/mm/yyyy
| > | //Enter a tilde sign for the first number and you can check the variable
| > | information.
| > | if (vDateValue == "~") {
| > | alert("AppVersion = "+navigator.appVersion+" \nNav. 4 Version = "+isNav4+"
| > | \nNav. 5 Version = "+isNav5+" \nIE Version = "+isIE4+" \nYear Type =
| > | "+vYearType+" \nDate Type = "+vDateType+" \nSeparator = "+strSeperator);
| > | vDateName.value = "";
| > | vDateName.focus();
| > | return true;
| > | }
| > | var whichCode = (window.Event) ? e.which : e.keyCode;
| > | // Check to see if a seperator is already present.
| > | // bypass the date if a seperator is present and the length greater than 8
| > | if (vDateValue.length > 8 && isNav4) {
| > | if ((vDateValue.indexOf("-") >= 1) || (vDateValue.indexOf("/") >= 1))
| > | return true;
| > | }
| > | //Eliminate all the ASCII codes that are not valid
| > | var alphaCheck = " abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ/-";
| > | if (alphaCheck.indexOf(vDateValue) >= 1) {
| > | if (isNav4) {
| > | vDateName.value = "";
| > | vDateName.focus();
| > | vDateName.select();
| > | return false;
| > | }
| > | else {
| > | vDateName.value = vDateName.value.substr(0, (vDateValue.length-1));
| > | return false;
| > | }
| > | }
| > | if (whichCode == 8) //Ignore the Netscape value for backspace. IE has no value
| > | return false;
| > | else {
| > | //Create numeric string values for 0123456789/
| > | //The codes provided include both keyboard and keypad values
| > | var strCheck =
| > | '47,48,49,50,51,52,53,54,55,56,57,58,59,95,96,97,98,99,100,101,102,103,104,105';
| > | if (strCheck.indexOf(whichCode) != -1) {
| > | if (isNav4) {
| > | if (((vDateValue.length < 6 && dateCheck) || (vDateValue.length == 7 &&
| > | dateCheck)) && (vDateValue.length >=1)) {
| > | alert("Invalid Date\nPlease Re-Enter");
| > | vDateName.value = "";
| > | vDateName.focus();
| > | vDateName.select();
| > | return false;
| > | }
| > | if (vDateValue.length == 6 && dateCheck) {
| > | var mDay = vDateName.value.substr(2,2);
| > | var mMonth = vDateName.value.substr(0,2);
| > | var mYear = vDateName.value.substr(4,4)
| > | //Turn a two digit year into a 4 digit year
| > | if (mYear.length == 2 && vYearType == 4) {
| > | var mToday = new Date();
| > | //If the year is greater than 30 years from now use 19, otherwise use 20
| > | var checkYear = mToday.getFullYear() + 30;
| > | var mCheckYear = '20' + mYear;
| > | if (mCheckYear >= checkYear)
| > | mYear = '19' + mYear;
| > | else
| > | mYear = '20' + mYear;
| > | }
| > | var vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
| > | if (!dateValid(vDateValueCheck)) {
| > | alert("Invalid Date\nPlease Re-Enter");
| > | vDateName.value = "";
| > | vDateName.focus();
| > | vDateName.select();
| > | return false;
| > | }
| > | return true;
| > | }
| > | else {
| > | // Reformat the date for validation and set date type to a 1
| > | if (vDateValue.length >= 8 && dateCheck) {
| > | if (vDateType == 1) // mmddyyyy
| > | {
| > | var mDay = vDateName.value.substr(2,2);
| > | var mMonth = vDateName.value.substr(0,2);
| > | var mYear = vDateName.value.substr(4,4)
| > | vDateName.value = mMonth+strSeperator+mDay+strSeperator+mYear;
| > | }
| > | if (vDateType == 2) // yyyymmdd
| > | {
| > | var mYear = vDateName.value.substr(0,4)
| > | var mMonth = vDateName.value.substr(4,2);
| > | var mDay = vDateName.value.substr(6,2);
| > | vDateName.value = mYear+strSeperator+mMonth+strSeperator+mDay;
| > | }
| > | if (vDateType == 3) // ddmmyyyy
| > | {
| > | var mMonth = vDateName.value.substr(2,2);
| > | var mDay = vDateName.value.substr(0,2);
| > | var mYear = vDateName.value.substr(4,4)
| > | vDateName.value = mDay+strSeperator+mMonth+strSeperator+mYear;
| > | }
| > | //Create a temporary variable for storing the DateType and change
| > | //the DateType to a 1 for validation.
| > | var vDateTypeTemp = vDateType;
| > | vDateType = 1;
| > | var vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
| > | if (!dateValid(vDateValueCheck)) {
| > | alert("Invalid Date\nPlease Re-Enter");
| > | vDateType = vDateTypeTemp;
| > | vDateName.value = "";
| > | vDateName.focus();
| > | vDateName.select();
| > | return false;
| > | }
| > | vDateType = vDateTypeTemp;
| > | return true;
| > | }
| > | else {
| > | if (((vDateValue.length < 8 && dateCheck) || (vDateValue.length == 9 &&
| > | dateCheck)) && (vDateValue.length >=1)) {
| > | alert("Invalid Date\nPlease Re-Enter");
| > | vDateName.value = "";
| > | vDateName.focus();
| > | vDateName.select();
| > | return false;
| > | }
| > | }
| > | }
| > | }
| > | else {
| > | // Non isNav Check
| > | if (((vDateValue.length < 8 && dateCheck) || (vDateValue.length == 9 &&
| > | dateCheck)) && (vDateValue.length >=1)) {
| > | alert("Invalid Date\nPlease Re-Enter");
| > | vDateName.value = "";
| > | vDateName.focus();
| > | return true;
| > | }
| > | // Reformat date to format that can be validated. mm/dd/yyyy
| > | if (vDateValue.length >= 8 && dateCheck) {
| > | // Additional date formats can be entered here and parsed out to
| > | // a valid date format that the validation routine will recognize.
| > | if (vDateType == 1) // mm/dd/yyyy
| > | {
| > | var mMonth = vDateName.value.substr(0,2);
| > | var mDay = vDateName.value.substr(3,2);
| > | var mYear = vDateName.value.substr(6,4)
| > | }
| > | if (vDateType == 2) // yyyy/mm/dd
| > | {
| > | var mYear = vDateName.value.substr(0,4)
| > | var mMonth = vDateName.value.substr(5,2);
| > | var mDay = vDateName.value.substr(8,2);
| > | }
| > | if (vDateType == 3) // dd/mm/yyyy
| > | {
| > | var mDay = vDateName.value.substr(0,2);
| > | var mMonth = vDateName.value.substr(3,2);
| > | var mYear = vDateName.value.substr(6,4)
| > | }
| > | if (vYearLength == 4) {
| > | if (mYear.length < 4) {
| > | alert("Invalid Date\nPlease Re-Enter");
| > | vDateName.value = "";
| > | vDateName.focus();
| > | return true;
| > | }
| > | }
| > | // Create temp. variable for storing the current vDateType
| > | var vDateTypeTemp = vDateType;
| > | // Change vDateType to a 1 for standard date format for validation
| > | // Type will be changed back when validation is completed.
| > | vDateType = 1;
| > | // Store reformatted date to new variable for validation.
| > | var vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
| > | if (mYear.length == 2 && vYearType == 4 && dateCheck) {
| > | //Turn a two digit year into a 4 digit year
| > | var mToday = new Date();
| > | //If the year is greater than 30 years from now use 19, otherwise use 20
| > | var checkYear = mToday.getFullYear() + 30;
| > | var mCheckYear = '20' + mYear;
| > | if (mCheckYear >= checkYear)
| > | mYear = '19' + mYear;
| > | else
| > | mYear = '20' + mYear;
| > | vDateValueCheck = mMonth+strSeperator+mDay+strSeperator+mYear;
| > | // Store the new value back to the field. This function will
| > | // not work with date type of 2 since the year is entered first.
| > | if (vDateTypeTemp == 1) // mm/dd/yyyy
| > | vDateName.value = mMonth+strSeperator+mDay+strSeperator+mYear;
| > | if (vDateTypeTemp == 3) // dd/mm/yyyy
| > | vDateName.value = mDay+strSeperator+mMonth+strSeperator+mYear;
| > | }
| > | if (!dateValid(vDateValueCheck)) {
| > | alert("Invalid Date\nPlease Re-Enter YYYY/MM/DD");
| > | vDateType = vDateTypeTemp;
| > | vDateName.value = "";
| > | vDateName.focus();
| > | return true;
| > | }
| > | vDateType = vDateTypeTemp;
| > | return true;
| > | }
| > | else {
| > | if (vDateType == 1) {
| > | if (vDateValue.length == 2) {
| > | vDateName.value = vDateValue+strSeperator;
| > | }
| > | if (vDateValue.length == 5) {
| > | vDateName.value = vDateValue+strSeperator;
| > | }
| > | }
| > | if (vDateType == 2) {
| > | if (vDateValue.length == 4) {
| > | vDateName.value = vDateValue+strSeperator;
| > | }
| > | if (vDateValue.length == 7) {
| > | vDateName.value = vDateValue+strSeperator;
| > | }
| > | }
| > | if (vDateType == 3) {
| > | if (vDateValue.length == 2) {
| > | vDateName.value = vDateValue+strSeperator;
| > | }
| > | if (vDateValue.length == 5) {
| > | vDateName.value = vDateValue+strSeperator;
| > | }
| > | }
| > | return true;
| > | }
| > | }
| > | if (vDateValue.length == 10&& dateCheck) {
| > | if (!dateValid(vDateName)) {
| > | // Un-comment the next line of code for debugging the dateValid() function
| > | error messages
| > | //alert(err);
 
Back
Top