String.prototype.trim = function() { return this.replace(/^\s+|\s+$/g,""); } String.prototype.ltrim = function() { return this.replace(/^\s+/,""); } String.prototype.rtrim = function() { return this.replace(/\s+$/,""); } var EventManager = { /** * Attaches an event handler function to the specified DOM element's event specified by eventName. * * @param {Element} element The DOM element whose event will be attached to. * @param {String} eventName The name of the event(ie. 'load') be sure to specify without the 'on' (ie. 'load' not 'onload'). * @param {Function} listener The function that will handle this event. */ Attach: function(element, eventName, listener) { if(window.attachEvent) element.attachEvent('on' + eventName, listener); // IE else element.addEventListener(eventName, listener, false); // W3C }, /** * Attaches the specified listener to the window load event. * * @param {Function} listener */ AttachWindowLoad: function(listener) { this.Attach(window, 'load', listener); }, /** * Detaches an event handler function to the specified DOM element's event specified by eventName. * * @param {Element} element The DOM element whose event will be attached to. * @param {String} eventName The name of the event be sure to specify without the 'on' (ie. 'load' not 'onload'). * @param {Function} listener The function that will handle this event. */ Detach: function(element, eventName, listener) { if(window.attachEvent) element.detachEvent('on' + eventName, listener); // IE else element.removeEventListener(eventName, listener, false); // W3C }, /** * Gets the context(sender) of a DOM Event. */ GetContext: function(_this) { if(_this.event) return _this.event.srcElement; // IE return _this; // W3C }, /** * @constructor */ EventListener: function(method, context) { this.Method = method; this.Context = context; }, /** * Represents an event to which listeners can be attached and detached. * * @constructor */ CustomEvent: function(sender) { this._listeners = new Array(); this._sender = sender; this.Attach = function(listener, context) { this._listeners.push(new EventManager.EventListener(listener, context)); } this.Detach = function(listener) { for(var i = 0; i < this.listeners.length; i++) { var o = this._listeners[0]; if(o.Method == listener) { this._listeners.remove(listener); break; } } } /** * Steps through the listeners for this event and calls them passing sender and any associated event data. * * @param {Object} eventData An object containing data associated with this event. */ this.Fire = function(eventData) { for(var i = 0; i < this._listeners.length; i++) { var listener = this._listeners[0]; listener.Method(this._sender, listener.Context, eventData); } } } } var DateTimeUtil = { /** * Returns the number of days for the specified month and year. * * @param {int} month The month to retrieve the number of days for. * @param {int} year The year in which the month falls. * @type int; */ DaysInMonth: function (month, year) { month = parseInt(month); year = parseInt(year); var dd = new Date(year, month, 0); return dd.getDate(); } } var weekend = [0,6]; var weekendColor = "#F1D50E"; var fontface = "Verdana"; var fontsize = 2; var gNow = new Date(); var ggWinCal; isNav = (navigator.appName.indexOf("Netscape") != -1) ? true : false; isIE = (navigator.appName.indexOf("Microsoft") != -1) ? true : false; 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_WinCal, p_month, p_year, p_format) { if ((p_month == null) && (p_year == null)) return; if (p_WinCal == null) this.gWinCal = ggWinCal; else this.gWinCal = p_WinCal; 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 = vCode + ""; vHeader_Code = this.cal_header(); vData_Code = this.cal_data(); vCode = vCode + vHeader_Code + vData_Code; vCode = vCode + "
"; return vCode; } Calendar.prototype.show = function() { var vCode = ""; this.gWinCal.document.open(); // Setup the page... this.wwrite(""); this.wwrite("Calendar"); this.wwrite(""); this.wwrite(""); this.wwriteA(""); // 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]; this.wwrite("
"); this.wwrite("<<<\/A>"); this.wwrite("<<\/A>"); this.wwrite(" " + this.gMonthName + " 
" + this.gYear + "
"); this.wwrite("><\/A>"); this.wwrite(">><\/A>

"); // Get the complete calendar code for the month.. vCode = this.getMonthlyCalendarCode(); this.wwrite(vCode); this.wwrite("
"); this.gWinCal.document.close(); } Calendar.prototype.showY = function() { var vCode = ""; var i; var vr, vc, vx, vy; // Row, Column, X-coord, Y-coord var vxf = 285; // X-Factor var vyf = 200; // Y-Factor var vxm = 10; // X-margin var vym; // Y-margin if (isIE) vym = 75; else if (isNav) vym = 25; this.gWinCal.document.open(); this.wwrite(""); this.wwrite("Calendar"); this.wwrite(""); this.wwrite(""); this.wwrite(""); this.wwrite(""); this.wwrite("Year : " + this.gYear); this.wwrite("
"); // Show navigation buttons var prevYYYY = parseInt(this.gYear) - 1; var nextYYYY = parseInt(this.gYear) + 1; this.wwrite("
"); this.wwrite("[<<<\/A>]"); this.wwrite("[Print]"); this.wwrite("[>><\/A>]

"); // Get the complete calendar code for each month.. var j; for (i=11; i>=0; i--) { if (isIE) this.wwrite("
"); else if (isNav) this.wwrite(""); this.gMonth = i; this.gMonthName = Calendar.get_month(this.gMonth); vCode = this.getMonthlyCalendarCode(); this.wwrite(this.gMonthName + "/" + this.gYear + "
"); this.wwrite(vCode); if (isIE) this.wwrite("
"); else if (isNav) this.wwrite(""); } this.wwrite("

"); this.gWinCal.document.close(); } Calendar.prototype.wwrite = function(wtext) { this.gWinCal.document.writeln(wtext); } Calendar.prototype.wwriteA = function(wtext) { this.gWinCal.document.write(wtext); } Calendar.prototype.cal_header = function() { var vCode = ""; vCode = vCode + ""; vCode = vCode + "Sun"; vCode = vCode + "Mon"; vCode = vCode + "Tue"; vCode = vCode + "Wed"; vCode = vCode + "Thu"; vCode = vCode + "Fri"; vCode = vCode + "Sat"; vCode = vCode + ""; 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 + ""; for (i=0; i "; } // Write rest of the 1st week for (j=vFirstDay; j<7; j++) { vCode = vCode + "" + "" + this.format_day(vDay) + "" + ""; vDay=vDay + 1; } vCode = vCode + ""; // Write the rest of the weeks for (k=2; k<7; k++) { vCode = vCode + ""; for (j=0; j<7; j++) { vCode = vCode + "" + "" + this.format_day(vDay) + "" + ""; vDay=vDay + 1; if (vDay > vLastDay) { vOnLastDay = 1; break; } } if (j == 6) vCode = vCode + ""; 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 + " "; else vCode = vCode + "" + m + ""; } 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 ("" + vday + ""); else return (vday); } Calendar.prototype.write_weekend_string = function(vday) { var i; // Return special formatting for the weekend day. for (i=0; i -1) { if(value.length > this.MaxLength) this._minLengthValid = false; } if(this.MinLength > -1) { if(value.length < this.MinLength) this._maxLengthValid = false; } } this.validateEmailAddress = function() { var value = this.get_ControlValue(); this._emailAddressValid = true; if(value == null) return; //var regEx = /^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*\.(\w{2}|(com|net|org|edu|int|mil|gov|arpa|biz|aero|name|coop|info|pro|museum))$/; var regEx = /^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w{2,3})+$/; this._emailAddressValid = regEx.test(value); } this.Validate = function() { this._requiredValid = true; this._numberValid = true; this._dateValid = true; this._maxLengthValid = true; this._minLengthValid = true; this._emailAddressValid = true; if(!this.HandlingOnBlur || this.ValidateRequiredOnBlur) { if(this.IsRequired) this.validateRequired(); } if(this.IsFloat) this.validateFloat(); if(this.IsInteger) this.validateInteger(); if(this.IsDate) this.validateDate(); this.validateLength(); if(this.IsEmailAddress) this.validateEmailAddress(); } this.HandleControlEvents = function(validateOnBlur, displayMessageOnBlur, setFocusOnBlurValidationFailure) { this.ValidatorBase_HandleControlEvents(validateOnBlur, displayMessageOnBlur, setFocusOnBlurValidationFailure); } } GenericValidator.prototype = new ValidatorBase(); var ValidationManager = { _validators: new Array(), /** * Registers the specified validator. * * @param {ValidatorBase} validator The validator to register. */ RegisterValidator: function(validator) { this._validators[validator.get_Control().name] = validator; }, /** * @param {DOMNode} control The control that this validator handles. */ GetValidator: function(control) { return this._validators[control.name]; }, RegisterGenericValidator: function(control, label, isRequired, isFloat, isInteger, isDate, isEmail, maxLength, minLength, validateRequiredOnBlur) { validator = new GenericValidator(control, label); validator.IsRequired = isRequired; validator.IsFloat = isFloat; validator.IsInteger = isInteger; validator.IsDate = isDate; validator.IsEmailAddress = isEmail; validator.MaxLength = maxLength; validator.MinLength = minLength; validator.ValidateRequiredOnBlur = validateRequiredOnBlur; this.RegisterValidator(validator); return validator; }, /** * Calls the Validate method on all of the registered validators and returns their messages. * * @param {Boolean} displayMessage Whether or not to display an alert box with the messsages. * @type {String} * @return The validation messages from the validators, if any. */ ValidateAll: function(displayMessage) { msg = ""; for(var control in this._validators) { this._validators[control].Validate(); msg += this._validators[control].get_ValidationMessage(); } if(displayMessage && msg != "") { alert(msg); } return msg; } }