//-------------------------------------------------------
function RR_TrackCount(fieldObj, maxChars){
  //var formObj =  RR_findObj(formName);
  //var countField = eval("fieldObj.form."+countFieldName);
  eval('var countField = "formObj.myCount;"');
  var diff = maxChars - fieldObj.value.length;

  // Need to check & enforce limit here also in case user pastes data
  if (diff < 0){
    fieldObj.value = fieldObj.value.substring(0,maxChars);
    diff = maxChars - fieldObj.value.length;
  }
  countField.value = diff;
}

function RR_LimitText(fieldObj,maxChars){
  var result = true;
  if (fieldObj.value.length >= maxChars){
    result = false;
  }
  if (window.event){
    window.event.returnValue = result;
  }
  return result;
}
function RR_findObj(n, d) { //v4.01
  var p,i,x;  if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
    d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
  if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
  for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=RR_findObj(n,d.layers[i].document);
  if(!x && d.getElementById) x=d.getElementById(n); return x;
}

function isDatexx (strDate) {
   var parsedDate = strDate.split ("/");
   var year = 0;
   if (parsedDate.length != 3) return false;
   var day, month, year;
  
   month= parsedDate[0];
   day = parsedDate[1];
   year = parseInt(parsedDate[2]);
   year = 2000 + year;
   
   var xStrDate = month + '-' +day + '-'+ year;  
   //alert('In:' + xStrDate); 
   
   //var objDate = new Date (xStrDate);
   var objDate = new Date (year, month-1, day);
   //xStrDate = (objDate.getMonth()+1) + '-' +objDate.getDate() + '-'+ objDate.getFullYear(); 
   //alert('Out:' +xStrDate);
   msg = '';  
   var xday=0, xmonth=0, xyear=0;
   xmonth= (objDate.getMonth()+1);
   xday =  objDate.getDate()+0;
   xyear = objDate.getFullYear()+0;
   syear = objDate.getYear()+0;
   
   msg += 'month=' + month + '\n';
   msg += 'day=' + day + '\n'; 
   msg += 'year=' + year + '\n';
   
   msg += 'xmonth=' + xmonth + '\n';
   msg += 'xday=' + xday + '\n';
   msg += 'xyear=' + xyear + '\n';
   
   alert(msg);	
   if (month != objDate.getMonth()+1) return false;
   if (day != objDate.getDate()) return false;
   if (year != objDate.getFullYear() && year != objDate.getYear()) return false;
 
   return true;
   // return xStrDate;
} 

function toOracleDate (strDate) {
   var valid = true;
   var parsedDate = strDate.split ("/");
   var year = 0;
   if (parsedDate.length != 3) return "";
   var  day, month, year;
   //var zyear = new int();
   month= parsedDate[0];
   day = parsedDate[1];
   year ='20' + parsedDate[2];
   zyear = parseInt(year);
   //year = 2000 + zyear;
   
   var xStrDate = month + '-' +day + '-'+ year; 
   //alert('In:' + xStrDate);
   
    var objDate = new Date (year, month-1, day);
   //xStrDate = (objDate.getMonth()+1) + '-' +objDate.getDate() + '-'+ objDate.getFullYear(); 
   //alert('Out:' +xStrDate);
	
   if (month != objDate.getMonth()+1) return "";
   if (day != objDate.getDate()) return "";
   if (year != objDate.getFullYear())return "";
   
   var oracleDate = year +'/' + month +'/' +day ;
   //alert(oracleDate);
   return oracleDate ;
} 
function toDateTimeOld (fieldDate,fieldHour,fieldMin,fieldAM) {
//------------------------------------------------------------------------------
// Date and Time
//------------------------------------------------------------------------------
	var parsedDate;
	
	var x_min=0; 
	var x_hour=0;
	var x_am=""; 
	var x_date="";
	
	var date="";
	var year=0;
	var day=0; 
	var month=0;
	
	x_min = RR_findObj(fieldMin).value; 
	x_hour = RR_findObj(fieldHour).value; 
	x_am = RR_findObj(fieldAM).value; 
	
	if(x_am == "PM" && parseInt(x_hour)<12){	 
		x_hour = parseInt(x_hour) + 12;
	}
	
    x_date = RR_findObj(fieldDate).value;
	parsedDate = x_date.split("/"); 
	month= parsedDate[0];
	day = parsedDate[1];
	year = parseInt(parsedDate[2]);
	year = 2000 + year;
	
	date = year + '-' + month + '-'+ day + ' ' + x_hour + ':' + x_min ;
	//'2003-06-13 15:18:22' 
	return date;
}
function padout(number) { 
	return (number < 10) ? '0' + number : number; 
}

function ampm(number){ 
	return (number < 12) ? 'am' : 'pm'; 
}
function y2k(number){ 
	return (number < 1000) ? number + 1900 : number; 
}

function nths(day) { 
    if (day == 1 || day == 21 || day == 31) return 'st';
    else if (day == 2 || day == 22) return 'nd';
    else if (day == 3 || day == 23) return 'rd';
    else return 'th';
}

function makeArray0() {
    for (i = 0; i<makeArray0.arguments.length; i++)
        this[i] = makeArray0.arguments[i];
}

var days = new makeArray0("Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday");
var months = new makeArray0('January','February','March','April','May','June','July','August','September','October','November','December');


	
function formatOracleDateTime(dateObject) { 
	//var dateStr = "";
	//var timeStr = "";
	//dateStr = dateObject.getYear() + '-' +padout(dateObject.getMonth()+1) + '-' +padout(dateObject.getDate());
	//timeStr = padout(dateObject.getHours())+ ':' + padout(dateObject.getMinutes()) + ':' +padout(dateObject.getSeconds()); 
    //return dateStr + ' ' + timeStr;
	
	return formatDate(dateObject,"yyyy-MM-dd HH:mm:ss");
	//return formatDate(dateObject,"DD-MMM-YY HH:MI:SS AM");
}

function formatOracleDate(dateObject) {
	//var dateStr = "";
	//var timeStr = "";
	//dateStr = dateObject.getYear() + '-' +padout(dateObject.getMonth()+1) + '-' +padout(dateObject.getDate());
	//timeStr = padout(dateObject.getHours())+ ':' + padout(dateObject.getMinutes()) + ':' +padout(dateObject.getSeconds()); 
    //return dateStr + ' ' + timeStr;		
	return formatDate(dateObject,'YYYY-MM-dd');
}


function toDateObject(year,month,date,hour,minute,second) {
    if (!year) year=0;
    if (!month) month=0;
    if (!date) date=0;
    if (!hour) hour=0;
    if (!minute) minute=0;
    if (!second) second=0;
	
    var dateObject = new Date(year,month,date,hour,minute,second);
	
    return dateObject;		   
}

function fieldtoDateObject (fieldDate,fieldHour,fieldMin,fieldAM) {
//------------------------------------------------------------------------------
// Date and Time
//------------------------------------------------------------------------------
	var parsedDate;
	var x_min=0; 
	var x_hour=0;
	var x_am=""; 
	var x_date="";
	
	var date="";
	var year=0;
	var day=0; 
	var month=0;
	
	
	x_min = RR_findObj(fieldMin).value; 
	x_hour = RR_findObj(fieldHour).value;
	x_am = RR_findObj(fieldAM).value; 
	if( (x_am == "PM") && (parseInt(x_hour) < 12 )){	 
		x_hour = parseInt(x_hour) + 12;
	}
	if( (x_am == "AM") && (parseInt(x_hour) == 12 )){	 
		x_hour = 0;
	}


	//alert('x_am=' + x_am +' x_hour=' + x_hour);
	
	x_date = RR_findObj(fieldDate).value;
	parsedDate = x_date.split("/"); 
	month= parsedDate[0];
	day = parsedDate[1];
	year = parseInt(parsedDate[2]);
	year = 2000 + year;
	
	//date = year + '-' + month + '-'+ day + ' ' + x_hour + ':' + x_min ;
	//'2003-06-13 15:18:22' 
	
	var dateObject = toDateObject(year,month-1,day,x_hour,x_min,0)
	return dateObject;
}

function fieldtoDateObject2 (fieldDate,fieldTime) {
//------------------------------------------------------------------------------
// Date and Time
//------------------------------------------------------------------------------
	
   // Parse Time (HH:mm:ss)
   var xtime = RR_findObj(fieldTime).value;
   var parsedTime = xtime.split(":"); 
   var xhour= parseFloat(parsedTime[0]);
   var xminute= parseFloat(parsedTime[1]);
   
	// Parse Date(YY/MM/DD)
	var xdate = RR_findObj(fieldDate).value;
	var parsedDate = xdate.split("/"); 
	var xmonth=  parseFloat(parsedDate[0]);
	var xday =  parseFloat(parsedDate[1]);
	var xyear = parseFloat("20" + parsedDate[2]);
	
	var dateObject = toDateObject(xyear,xmonth-1,xday,xhour,xminute,0);
	return dateObject;
}

function fieldtoDateObject3 (fieldDate,fieldTime) { 
//------------------------------------------------------------------------------
// Date and Time
//------------------------------------------------------------------------------
	
   // Parse Time (HH:mm:ss)
   var xtime = RR_findObj(fieldTime).value;
   var parsedTime = xtime.split(":"); 
   var xhour= parseFloat(parsedTime[0]);
   var xminute= parseFloat(parsedTime[1]);
   
	// Parse Date(MM/DD/YYYY)
	var xdate = RR_findObj(fieldDate).value;
	var parsedDate = xdate.split("/"); 
	var xmonth = parseFloat(parsedDate[0]);
	var xday = parseFloat(parsedDate[1]);
	var xyear = parseFloat(parsedDate[2]);
	
	var dateObject = toDateObject(xyear,xmonth-1,xday,xhour,xminute,0);
	return dateObject;
}
function fieldDateToDateObject3 (fieldDate) { 
//------------------------------------------------------------------------------
// Date and Time
//------------------------------------------------------------------------------

	// Parse Date(YYYY/MM/DD)
	var xdate = RR_findObj(fieldDate).value;
	var parsedDate = xdate.split("/"); 
	var xmonth=  parseFloat(parsedDate[0]);
	var xday =  parseFloat(parsedDate[1]);
	var xyear = parseFloat(parsedDate[2]);
	if (xyear < 99){
		
	}
	
	var dateObject = toDateObject(xyear,xmonth-1,xday,0,0,0);
	return dateObject;
}

function fieldtoTimeObject (fieldHour,fieldMin,fieldAM) {
//------------------------------------------------------------------------------
// Date and Time
//------------------------------------------------------------------------------
	var parsedDate;
	var x_min=0; 
	var x_hour=0;
	var x_am=""; 
	var x_date="";
	
	x_min = RR_findObj(fieldMin).value; 
	x_hour = RR_findObj(fieldHour).value;
	x_am = RR_findObj(fieldAM).value; 
	
	if( (x_am == "PM") && (parseInt(x_hour) < 12 )){	 
		x_hour = parseInt(x_hour) + 12;
	}
	if( (x_am == "AM") && (parseInt(x_hour) == 12 )){	 
		x_hour = 0;
	}
	var dateObject = toDateObject(0,0,0,x_hour,x_min,0)
	return dateObject;
}
//**********************************************************************
// ------------------------------------------------------------------
// These functions use the same 'format' strings as the 
// java.text.SimpleDateFormat class, with minor exceptions.
// The format string consists of the following abbreviations:
// 
// Field        | Full Form          | Short Form
// -------------+--------------------+-----------------------
// Year         | yyyy (4 digits)    | yy (2 digits), y (2 or 4 digits)
// Month        | MMM (name or abbr.)| MM (2 digits), M (1 or 2 digits)
//              | NNN (abbr.)        |
// Day of Month | dd (2 digits)      | d (1 or 2 digits)
// Day of Week  | EE (name)          | E (abbr)
// Hour (1-12)  | hh (2 digits)      | h (1 or 2 digits)
// Hour (0-23)  | HH (2 digits)      | H (1 or 2 digits)
// Hour (0-11)  | KK (2 digits)      | K (1 or 2 digits)
// Hour (1-24)  | kk (2 digits)      | k (1 or 2 digits)
// Minute       | mm (2 digits)      | m (1 or 2 digits)
// Second       | ss (2 digits)      | s (1 or 2 digits)
// AM/PM        | a                  |
//
// NOTE THE DIFFERENCE BETWEEN MM and mm! Month=MM, not mm!
// Examples:
//  "MMM d, y" matches: January 01, 2000
//                      Dec 1, 1900
//                      Nov 20, 00
//  "M/d/yy"   matches: 01/20/00
//                      9/2/00
//  "MMM dd, yyyy hh:mm:ssa" matches: "January 01, 2000 12:30:45AM"
// ------------------------------------------------------------------

var MONTH_NAMES=new Array('January','February','March','April','May','June','July','August','September','October','November','December','Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec');
var DAY_NAMES=new Array('Sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday','Sun','Mon','Tue','Wed','Thu','Fri','Sat');

function LZ(x) {return(x<0||x>9?"":"0")+x}

// ------------------------------------------------------------------
// isDate ( date_string, format_string )
// Returns true if date string matches format of format string and
// is a valid date. Else returns false.
// It is recommended that you trim whitespace around the value before
// passing it to this function, as whitespace is NOT ignored!
// ------------------------------------------------------------------
function isDate(val,format) {
	var date=getDateFromFormat(val,format);
	if (date==0) { return false; }
	return true;
	}

// -------------------------------------------------------------------
// compareDates(date1,date1format,date2,date2format)
//   Compare two date strings to see which is greater.
//   Returns:
//   1 if date1 is greater than date2
//   0 if date2 is greater than date1 of if they are the same
//  -1 if either of the dates is in an invalid format
// -------------------------------------------------------------------
function compareDates(date1,dateformat1,date2,dateformat2) {
	var d1=getDateFromFormat(date1,dateformat1);
	var d2=getDateFromFormat(date2,dateformat2);
	if (d1==0 || d2==0) {
		return -1;
		}
	else if (d1 > d2) {
		return 1;
		}
	return 0;
	}

// ------------------------------------------------------------------
// formatDate (date_object, format)
// Returns a date in the output format specified.
// The format string uses the same abbreviations as in getDateFromFormat()
// ------------------------------------------------------------------
function formatDate(date,format) {
	format=format+"";
	var result="";
	var i_format=0;
	var c="";
	var token="";
	var y=date.getYear()+"";
	var M=date.getMonth()+1;
	var d=date.getDate();
	var E=date.getDay();
	var H=date.getHours();
	var m=date.getMinutes();
	var s=date.getSeconds();
	var yyyy,yy,MMM,MM,dd,hh,h,mm,ss,ampm,HH,H,KK,K,kk,k;
	// Convert real date parts into formatted versions
	var value=new Object();
	if (y.length < 4) {y=""+(y-0+1900);}
	value["y"]=""+y;
	value["yyyy"]=y;
	value["yy"]=y.substring(2,4);
	value["M"]=M;
	value["MM"]=LZ(M);
	value["MMM"]=MONTH_NAMES[M-1];
	value["NNN"]=MONTH_NAMES[M+11];
	value["d"]=d;
	value["dd"]=LZ(d);
	value["E"]=DAY_NAMES[E+7];
	value["EE"]=DAY_NAMES[E];
	value["H"]=H;
	value["HH"]=LZ(H);
	if (H==0){value["h"]=12;}
	else if (H>12){value["h"]=H-12;}
	else {value["h"]=H;}
	value["hh"]=LZ(value["h"]);
	if (H>11){value["K"]=H-12;} else {value["K"]=H;}
	value["k"]=H+1;
	value["KK"]=LZ(value["K"]);
	value["kk"]=LZ(value["k"]);
	if (H > 11) { value["a"]="PM"; }
	else { value["a"]="AM"; }
	value["m"]=m;
	value["mm"]=LZ(m);
	value["s"]=s;
	value["ss"]=LZ(s);
	while (i_format < format.length) {
		c=format.charAt(i_format);
		token="";
		while ((format.charAt(i_format)==c) && (i_format < format.length)) {
			token += format.charAt(i_format++);
			}
		if (value[token] != null) { result=result + value[token]; }
		else { result=result + token; }
		}
	return result;
	}
	
// ------------------------------------------------------------------
// Utility functions for parsing in getDateFromFormat()
// ------------------------------------------------------------------
function _isInteger(val) {
	var digits="1234567890";
	for (var i=0; i < val.length; i++) {
		if (digits.indexOf(val.charAt(i))==-1) { return false; }
		}
	return true;
	}
function _getInt(str,i,minlength,maxlength) {
	for (var x=maxlength; x>=minlength; x--) {
		var token=str.substring(i,i+x);
		if (token.length < minlength) { return null; }
		if (_isInteger(token)) { return token; }
		}
	return null;
	}
	
// ------------------------------------------------------------------
// getDateFromFormat( date_string , format_string )
//
// This function takes a date string and a format string. It matches
// If the date string matches the format string, it returns the 
// getTime() of the date. If it does not match, it returns 0.
// ------------------------------------------------------------------
function getDateFromFormat(val,format) {
	val=val+"";
	format=format+"";
	var i_val=0;
	var i_format=0;
	var c="";
	var token="";
	var token2="";
	var x,y;
	var now=new Date();
	var year=now.getYear();
	var month=now.getMonth()+1;
	var date=1;
	var hh=now.getHours();
	var mm=now.getMinutes();
	var ss=now.getSeconds();
	var ampm="";
	
	while (i_format < format.length) {
		// Get next token from format string
		c=format.charAt(i_format);
		token="";
		while ((format.charAt(i_format)==c) && (i_format < format.length)) {
			token += format.charAt(i_format++);
			}
		// Extract contents of value based on format token
		if (token=="yyyy" || token=="yy" || token=="y") {
			if (token=="yyyy") { x=4;y=4; }
			if (token=="yy")   { x=2;y=2; }
			if (token=="y")    { x=2;y=4; }
			year=_getInt(val,i_val,x,y);
			if (year==null) { return 0; }
			i_val += year.length;
			if (year.length==2) {
				if (year > 70) { year=1900+(year-0); }
				else { year=2000+(year-0); }
				}
			}
		else if (token=="MMM"||token=="NNN"){
			month=0;
			for (var i=0; i<MONTH_NAMES.length; i++) {
				var month_name=MONTH_NAMES[i];
				if (val.substring(i_val,i_val+month_name.length).toLowerCase()==month_name.toLowerCase()) {
					if (token=="MMM"||(token=="NNN"&&i>11)) {
						month=i+1;
						if (month>12) { month -= 12; }
						i_val += month_name.length;
						break;
						}
					}
				}
			if ((month < 1)||(month>12)){return 0;}
			}
		else if (token=="EE"||token=="E"){
			for (var i=0; i<DAY_NAMES.length; i++) {
				var day_name=DAY_NAMES[i];
				if (val.substring(i_val,i_val+day_name.length).toLowerCase()==day_name.toLowerCase()) {
					i_val += day_name.length;
					break;
					}
				}
			}
		else if (token=="MM"||token=="M") {
			month=_getInt(val,i_val,token.length,2);
			if(month==null||(month<1)||(month>12)){return 0;}
			i_val+=month.length;}
		else if (token=="dd"||token=="d") {
			date=_getInt(val,i_val,token.length,2);
			if(date==null||(date<1)||(date>31)){return 0;}
			i_val+=date.length;}
		else if (token=="hh"||token=="h") {
			hh=_getInt(val,i_val,token.length,2);
			if(hh==null||(hh<1)||(hh>12)){return 0;}
			i_val+=hh.length;}
		else if (token=="HH"||token=="H") {
			hh=_getInt(val,i_val,token.length,2);
			if(hh==null||(hh<0)||(hh>23)){return 0;}
			i_val+=hh.length;}
		else if (token=="KK"||token=="K") {
			hh=_getInt(val,i_val,token.length,2);
			if(hh==null||(hh<0)||(hh>11)){return 0;}
			i_val+=hh.length;}
		else if (token=="kk"||token=="k") {
			hh=_getInt(val,i_val,token.length,2);
			if(hh==null||(hh<1)||(hh>24)){return 0;}
			i_val+=hh.length;hh--;}
		else if (token=="mm"||token=="m") {
			mm=_getInt(val,i_val,token.length,2);
			if(mm==null||(mm<0)||(mm>59)){return 0;}
			i_val+=mm.length;}
		else if (token=="ss"||token=="s") {
			ss=_getInt(val,i_val,token.length,2);
			if(ss==null||(ss<0)||(ss>59)){return 0;}
			i_val+=ss.length;}
		else if (token=="a") {
			if (val.substring(i_val,i_val+2).toLowerCase()=="am") {ampm="AM";}
			else if (val.substring(i_val,i_val+2).toLowerCase()=="pm") {ampm="PM";}
			else {return 0;}
			i_val+=2;}
		else {
			if (val.substring(i_val,i_val+token.length)!=token) {return 0;}
			else {i_val+=token.length;}
			}
		}
	// If there are any trailing characters left in the value, it doesn't match
	if (i_val != val.length) { return 0; }
	// Is date valid for month?
	if (month==2) {
		// Check for leap year
		if ( ( (year%4==0)&&(year%100 != 0) ) || (year%400==0) ) { // leap year
			if (date > 29){ return 0; }
			}
		else { if (date > 28) { return 0; } }
		}
	if ((month==4)||(month==6)||(month==9)||(month==11)) {
		if (date > 30) { return 0; }

		}
	// Correct hours value
	if (hh<12 && ampm=="PM") { hh=hh-0+12; }
	else if (hh>11 && ampm=="AM") { hh-=12; }
	var newdate=new Date(year,month-1,date,hh,mm,ss);
	return newdate.getTime();
	}

// ------------------------------------------------------------------
//  http://www.mattkruse.com/javascript/date/
//
// parseDate( date_string [, prefer_euro_format] )
//
// This function takes a date string and tries to match it to a
// number of possible date formats to get the value. It will try to
// match against the following international formats, in this order:
// y-M-d   MMM d, y   MMM d,y   y-MMM-d   d-MMM-y  MMM d
// M/d/y   M-d-y      M.d.y     MMM-d     M/d      M-d
// d/M/y   d-M-y      d.M.y     d-MMM     d/M      d-M
// A second argument may be passed to instruct the method to search
// for formats like d/M/y (european format) before M/d/y (American).
// Returns a Date object or null if no patterns match.
// ------------------------------------------------------------------
function parseDate(val) {
	var preferEuro=(arguments.length==2)?arguments[1]:false;
	generalFormats=new Array('y-M-d','MMM d, y','MMM d,y','y-MMM-d','d-MMM-y','MMM d');
	monthFirst=new Array('M/d/y','M-d-y','M.d.y','MMM-d','M/d','M-d');
	dateFirst =new Array('d/M/y','d-M-y','d.M.y','d-MMM','d/M','d-M');
	var checkList=new Array('generalFormats',preferEuro?'dateFirst':'monthFirst',preferEuro?'monthFirst':'dateFirst');
	var d=null;
	for (var i=0; i<checkList.length; i++) {
		var l=window[checkList[i]];
		for (var j=0; j<l.length; j++) {
			d=getDateFromFormat(val,l[j]);
			if (d!=0) { return new Date(d); }
			}
		}
	return null;
	}



//***************************************************************************
// Validator Object

var vReg = new Object();
var vError = new Object();
	// REGEX Elements
	// matches zip codes
	vReg.zipCode = /\d{5}(-\d{4})?/; 
	vError.zipCode = 'Zip Code: ##### ';
	// matches $17.23 or $14,281,545.45 or ...
	vReg.Currency = /\$\d{1,3}(,\d{3})*\.\d{2}/;
	vError.Currency= 'Currency: $17.23 or $14,545.45';
	// matches 5:04 or 12:34 but not 75:83
	vReg.Time = /^([1-9]|1[0-2]):[0-5]\d$/; 
	vError.Time  = 'Time: 5:04 or 12:34 but not 75:83';
	//matches email
	vReg.emailAddress = /^.+\@(\[?)[a-zA-Z0-9\-\.]+\.([a-zA-Z]{2,3}|[0-9]{1,3})(\]?)$/;
	vError.emailAddress = 'xxx@xxx.xxx';
	// matches phone ###-###-####
	vReg.phoneNumber = /^\(?\d{3}\)?\s|-\d{3}-\d{4}$/; 
	vError.phoneNumber = 'Phone Number: ###-###-####'; 
	// International Phone Number
	vReg.phoneNumberInternational = /^\d(\d|-){7,20}/;
	vError.phoneNumberInternational = "International Phone Number";
	// IP Address 
	vReg.ipAddress = /^((25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])$/;
	vError.ipAddress = 'ip address: ###\.###\.###\.###';
	// Date xx/xx/xxxx
	vReg.Date = /^\d{1,2}(\-|\/|\.)\d{1,2}\1\d{4}$/; 
	vError.Date = 'Date: mm/dd/yyyy';
	// State Abbreviation
	vReg.State = /^(AK|AL|AR|AZ|CA|CO|CT|DC|DE|FL|GA|HI|IA|ID|IL|IN|KS|KY|LA|MA|MD|ME|MI|MN|MO|MS|MT|NB|NC|ND|NH|NJ|NM|NV|NY|OH|OK|OR|PA|RI|SC|SD|TN|TX|UT|VA|VT|WA|WI|WV|WY)$/i;
	vError.State = 'State Abbreviation';
	// Social Security Number
	vReg.SSN = /^\d{3}\-\d{2}\-\d{4}$/;
    vError.SSN = 'Social Security Number';

//--------------------------------------------------------	
function RR_ValidateRegType(xValue, xType){
	var returnValue = ""; 
	var xReg = "";
	var matches = "";
	if(vReg[xType]){ // regular expression exists   
		xReg  = vReg[xType]; 
		matches = xReg.exec(xValue);
		if(!matches){ // Format Wrong 
			returnValue = vError[xType];
		} 
	}else{  // regular expression does not exists   
	  //returnValue = " Undefined Type: " + xType;
	}
	
	return returnValue;
}
 
//--------------------------------------------------------	
function RR_ValidateType(xValue, xType){
	var returnValue = ""; 
	switch(xType){
	   case "date" :
	       if(!isDate(xValue,"MM/dd/yy")){
		      returnValue += "Date: mm/dd/yy : " + xValue;
		   }
		   break;
		   
		   case "date2" :
	       if(!isDate(xValue,"MM/dd/yyyy")){
		      returnValue += "Date: mm/dd/yyyy : " + xValue;
		   }
		   break;
		   
		case "yes" :
	       if(xValue == ""){
		      returnValue += "Choose Yes or No" ;
		   }
		   break; 
		case "dropdown" :
	       if(xValue <= 0){
		      returnValue += "is Required" ;
		   }
		   break; 
		   
		   case "int" :
	       if( isNaN(xValue) ){
		      returnValue += "is not number" ;
		   }
		   break; 
		   
		   case "number" :
	       if( isNaN(xValue) ){
		      returnValue += "is not number" ;
		   }
		   break; 
		   
		   case "percent" :
		   //alert('Percent=' + xValue);
	       if( isNaN(xValue)){
		      returnValue += "is not number" ;
		   }else if((xValue < 0) || (xValue > 100)) {
				    
			  		returnValue += "is not between 0 and 100" ;
		   }
		   break; 
		   
		default :
		   returnValue += RR_ValidateRegType(xValue, xType);
		   break;
		}
	
	return returnValue;
}

//-------------------------------------------------------
function RR_isEmpty(fieldName){
	var oField=RR_findObj(fieldName);
	var returnValue = true;
	if(oField){
		if(oField.value != ""){
			returnValue = false;
		}
	}
	return returnValue;
	
}
//-------------------------------------------------------
function RR_isYES(fieldName){
	var oField=RR_findObj(fieldName);
	var returnValue = false;
	if(oField){
		var dValue = oDependent[0].checked;
		if(dValue){
			returnValue = true;
		}
	}
	return returnValue;
	
}
//-------------------------------------------------------
function RR_validateField(fieldName, name, xFormat, numberRequired, dependent) { //v4.0
  var error="";
  var oField=RR_findObj(fieldName);
  var oDependent = RR_findObj(dependent);
  var msg = "";
  msg += "RR_validateField(";
  msg += fieldName + ", ";
  msg += name+ ", ";
  msg += xFormat+ ", ";
  msg += numberRequired+ ", ";
  msg += dependent+ ", ";
  msg +=  ')\n';
  var formatError ="";
  //alert(msg);
   var isEnabled = true;
  
  if(oDependent){ 
    isEnabled = false;
	 var dValue = oDependent[0].checked;
	 var dValue1 = oDependent[1].checked;
	 if(dValue){
	    isEnabled = true;
	 }
  }
  
  if(isEnabled){
  
	  if(oField){
		var myName = oField.name;
		var myValue = oField.value;
	    
		
		switch(xFormat){
			case "yes" :
				if(numberRequired > 0){
				    var checkCounter = 0;
					
					for (i = 0;  i < oField.length;  i++){
						if (oField[i].checked){
							checkCounter++;
						}
					} 
					//alert(fieldName + 'checkCounter =' + checkCounter);	
					if(checkCounter < 1){
					  error +=  name +' --  Yes or No  \n';	
					}
				}	 	
		   
				break;
				
			case "radio" :
				if(numberRequired > 0){
				    var checkCounter = 0;
					
					for (i = 0;  i < oField.length;  i++){
						if (oField[i].checked){
							checkCounter++;
						}
					} 
					//alert(fieldName + 'checkCounter =' + checkCounter);	
					if(checkCounter < 1){
					  error +=  name +' --  Select One  \n';	
					}
				}	 	
		   
				break;
				
				case "checkbox": // require check
				if(numberRequired > 0){ 
					var checkCounter = 0;
					
						if (oField.checked){
							checkCounter++;
						}
					
					//alert(fieldName + 'checkCounter =' + checkCounter);	
					if(checkCounter < numberRequired){
					  error +=  name +' --  must check  \n';	
					}
				}	
				break;
				
			case "checklist":
				if(numberRequired > 0){
				 
					var checkCounter = 0;
					for (i = 0;  i < oField.length;  i++){
						if (oField[i].checked){
							checkCounter++;
						}
					} 
					//alert(fieldName + 'checkCounter =' + checkCounter);	
					if(checkCounter < numberRequired){
					  error +=  name +' --  must choose ' + numberRequired +' \n';	
					}
				}	
				break;		 
				
		    case "dropdown":
			    if(oField.type == "select-one"){
					if(numberRequired > 0){ 
						 var xIndex = oField.selectedIndex;
						 myValue= oField.options[xIndex].value; 
						
						 if(myValue <= 0 || trim(myValue) == ""){
							  error +=  name +' --  must choose \n';	
						}
					}
				}
				break;		
				
			default:
				if(oField.value !=""){ // Has Value
				   if(xFormat != ""){ // Format Check
					   formatError = RR_ValidateType(myValue, xFormat);
					   if(formatError != ""){ // format error
							//error += name + '    Not Valid  ' + formatError +'\n';
							 error +=  name  +' -- invalid ['+ formatError +']\n';						
					   }
				   } 
				}else{ // field is null
					if(numberRequired > 0){
						error +=  name +' -- required:     '+'\n';	
					} 
				}
			  
				break;
			}
		}else{ // No field
			if(numberRequired > 0){
				error +=  name +' -- required:     '+'\n';	
			} 	
		}
	}
  return error;
}
//-------------------------------------------------------


