| /* NUGET: BEGIN LICENSE TEXT | 
|  * | 
|  * Microsoft grants you the right to use these script files for the sole | 
|  * purpose of either: (i) interacting through your browser with the Microsoft | 
|  * website or online service, subject to the applicable licensing or use | 
|  * terms; or (ii) using the files as included with a Microsoft product subject | 
|  * to that product's license terms. Microsoft reserves all other rights to the | 
|  * files not expressly granted by Microsoft, whether by implication, estoppel | 
|  * or otherwise. Insofar as a script file is dual licensed under GPL, | 
|  * Microsoft neither took the code under GPL nor distributes it thereunder but | 
|  * under the terms set out in this paragraph. All notices and licenses | 
|  * below are for informational purposes only. | 
|  * | 
|  * NUGET: END LICENSE TEXT */ | 
| /* | 
| * This file has been commented to support Visual Studio Intellisense. | 
| * You should not use this file at runtime inside the browser--it is only | 
| * intended to be used only for design-time IntelliSense.  Please use the | 
| * standard jQuery library for all production use. | 
| * | 
| * Comment version: 1.11.1 | 
| */ | 
|   | 
| /* | 
| * Note: While Microsoft is not the author of this file, Microsoft is | 
| * offering you a license subject to the terms of the Microsoft Software | 
| * License Terms for Microsoft ASP.NET Model View Controller 3. | 
| * Microsoft reserves all other rights. The notices below are provided | 
| * for informational purposes only and are not the license terms under | 
| * which Microsoft distributed this file. | 
| * | 
| * jQuery Validation Plugin - v1.11.1 - 2/4/2013 | 
| * https://github.com/jzaefferer/jquery-validation | 
| * Copyright (c) 2013 Jörn Zaefferer; Licensed MIT | 
| * | 
| */ | 
|   | 
| (function($) { | 
|   | 
| $.extend($.fn, { | 
|     // http://docs.jquery.com/Plugins/Validation/validate | 
|     validate: function( options ) { | 
|         /// <summary> | 
|         /// Validates the selected form. This method sets up event handlers for submit, focus, | 
|         /// keyup, blur and click to trigger validation of the entire form or individual | 
|         /// elements. Each one can be disabled, see the onxxx options (onsubmit, onfocusout, | 
|         /// onkeyup, onclick). focusInvalid focuses elements when submitting a invalid form. | 
|         /// </summary> | 
|         /// <param name="options" type="Object"> | 
|         /// A set of key/value pairs that configure the validate. All options are optional. | 
|         /// </param> | 
|   | 
|         // if nothing is selected, return nothing; can't chain anyway | 
|         if (!this.length) { | 
|             options && options.debug && window.console && console.warn( "nothing selected, can't validate, returning nothing" ); | 
|             return; | 
|         } | 
|   | 
|         // check if a validator for this form was already created | 
|         var validator = $.data(this[0], 'validator'); | 
|         if ( validator ) { | 
|             return validator; | 
|         } | 
|          | 
|         validator = new $.validator( options, this[0] ); | 
|         $.data(this[0], 'validator', validator);  | 
|          | 
|         if ( validator.settings.onsubmit ) { | 
|          | 
|             // allow suppresing validation by adding a cancel class to the submit button | 
|             this.find("input, button").filter(".cancel").click(function() { | 
|                 validator.cancelSubmit = true; | 
|             }); | 
|              | 
|             // when a submitHandler is used, capture the submitting button | 
|             if (validator.settings.submitHandler) { | 
|                 this.find("input, button").filter(":submit").click(function() { | 
|                     validator.submitButton = this; | 
|                 }); | 
|             } | 
|          | 
|             // validate the form on submit | 
|             this.submit( function( event ) { | 
|                 if ( validator.settings.debug ) | 
|                     // prevent form submit to be able to see console output | 
|                     event.preventDefault(); | 
|                      | 
|                 function handle() { | 
|                     if ( validator.settings.submitHandler ) { | 
|                         if (validator.submitButton) { | 
|                             // insert a hidden input as a replacement for the missing submit button | 
|                             var hidden = $("<input type='hidden'/>").attr("name", validator.submitButton.name).val(validator.submitButton.value).appendTo(validator.currentForm); | 
|                         } | 
|                         validator.settings.submitHandler.call( validator, validator.currentForm ); | 
|                         if (validator.submitButton) { | 
|                             // and clean up afterwards; thanks to no-block-scope, hidden can be referenced | 
|                             hidden.remove(); | 
|                         } | 
|                         return false; | 
|                     } | 
|                     return true; | 
|                 } | 
|                      | 
|                 // prevent submit for invalid forms or custom submit handlers | 
|                 if ( validator.cancelSubmit ) { | 
|                     validator.cancelSubmit = false; | 
|                     return handle(); | 
|                 } | 
|                 if ( validator.form() ) { | 
|                     if ( validator.pendingRequest ) { | 
|                         validator.formSubmitted = true; | 
|                         return false; | 
|                     } | 
|                     return handle(); | 
|                 } else { | 
|                     validator.focusInvalid(); | 
|                     return false; | 
|                 } | 
|             }); | 
|         } | 
|          | 
|         return validator; | 
|     }, | 
|     // http://docs.jquery.com/Plugins/Validation/valid | 
|     valid: function() { | 
|         /// <summary> | 
|         /// Checks if the selected form is valid or if all selected elements are valid. | 
|         /// validate() needs to be called on the form before checking it using this method. | 
|         /// </summary> | 
|         /// <returns type="Boolean" /> | 
|   | 
|         if ( $(this[0]).is('form')) { | 
|             return this.validate().form(); | 
|         } else { | 
|             var valid = true; | 
|             var validator = $(this[0].form).validate(); | 
|             this.each(function() { | 
|                 valid &= validator.element(this); | 
|             }); | 
|             return valid; | 
|         } | 
|     }, | 
|     // attributes: space seperated list of attributes to retrieve and remove | 
|     removeAttrs: function(attributes) { | 
|         /// <summary> | 
|         /// Remove the specified attributes from the first matched element and return them. | 
|         /// </summary> | 
|         /// <param name="attributes" type="String"> | 
|         /// A space-seperated list of attribute names to remove. | 
|         /// </param> | 
|   | 
|         var result = {}, | 
|             $element = this; | 
|         $.each(attributes.split(/\s/), function(index, value) { | 
|             result[value] = $element.attr(value); | 
|             $element.removeAttr(value); | 
|         }); | 
|         return result; | 
|     }, | 
|     // http://docs.jquery.com/Plugins/Validation/rules | 
|     rules: function(command, argument) { | 
|         /// <summary> | 
|         /// Return the validations rules for the first selected element. | 
|         /// </summary> | 
|         /// <param name="command" type="String"> | 
|         /// Can be either "add" or "remove". | 
|         /// </param> | 
|         /// <param name="argument" type=""> | 
|         /// A list of rules to add or remove. | 
|         /// </param> | 
|   | 
|         var element = this[0]; | 
|          | 
|         if (command) { | 
|             var settings = $.data(element.form, 'validator').settings; | 
|             var staticRules = settings.rules; | 
|             var existingRules = $.validator.staticRules(element); | 
|             switch(command) { | 
|             case "add": | 
|                 $.extend(existingRules, $.validator.normalizeRule(argument)); | 
|                 staticRules[element.name] = existingRules; | 
|                 if (argument.messages) | 
|                     settings.messages[element.name] = $.extend( settings.messages[element.name], argument.messages ); | 
|                 break; | 
|             case "remove": | 
|                 if (!argument) { | 
|                     delete staticRules[element.name]; | 
|                     return existingRules; | 
|                 } | 
|                 var filtered = {}; | 
|                 $.each(argument.split(/\s/), function(index, method) { | 
|                     filtered[method] = existingRules[method]; | 
|                     delete existingRules[method]; | 
|                 }); | 
|                 return filtered; | 
|             } | 
|         } | 
|          | 
|         var data = $.validator.normalizeRules( | 
|         $.extend( | 
|             {}, | 
|             $.validator.metadataRules(element), | 
|             $.validator.classRules(element), | 
|             $.validator.attributeRules(element), | 
|             $.validator.staticRules(element) | 
|         ), element); | 
|          | 
|         // make sure required is at front | 
|         if (data.required) { | 
|             var param = data.required; | 
|             delete data.required; | 
|             data = $.extend({required: param}, data); | 
|         } | 
|          | 
|         return data; | 
|     } | 
| }); | 
|   | 
| // Custom selectors | 
| $.extend($.expr[":"], { | 
|     // http://docs.jquery.com/Plugins/Validation/blank | 
|     blank: function(a) {return !$.trim("" + a.value);}, | 
|     // http://docs.jquery.com/Plugins/Validation/filled | 
|     filled: function(a) {return !!$.trim("" + a.value);}, | 
|     // http://docs.jquery.com/Plugins/Validation/unchecked | 
|     unchecked: function(a) {return !a.checked;} | 
| }); | 
|   | 
| // constructor for validator | 
| $.validator = function( options, form ) { | 
|     this.settings = $.extend( true, {}, $.validator.defaults, options ); | 
|     this.currentForm = form; | 
|     this.init(); | 
| }; | 
|   | 
| $.validator.format = function(source, params) { | 
|     /// <summary> | 
|     /// Replaces {n} placeholders with arguments. | 
|     /// One or more arguments can be passed, in addition to the string template itself, to insert | 
|     /// into the string. | 
|     /// </summary> | 
|     /// <param name="source" type="String"> | 
|     /// The string to format. | 
|     /// </param> | 
|     /// <param name="params" type="String"> | 
|     /// The first argument to insert, or an array of Strings to insert | 
|     /// </param> | 
|     /// <returns type="String" /> | 
|   | 
|     if ( arguments.length == 1 )  | 
|         return function() { | 
|             var args = $.makeArray(arguments); | 
|             args.unshift(source); | 
|             return $.validator.format.apply( this, args ); | 
|         }; | 
|     if ( arguments.length > 2 && params.constructor != Array  ) { | 
|         params = $.makeArray(arguments).slice(1); | 
|     } | 
|     if ( params.constructor != Array ) { | 
|         params = [ params ]; | 
|     } | 
|     $.each(params, function(i, n) { | 
|         source = source.replace(new RegExp("\\{" + i + "\\}", "g"), n); | 
|     }); | 
|     return source; | 
| }; | 
|   | 
| $.extend($.validator, { | 
|      | 
|     defaults: { | 
|         messages: {}, | 
|         groups: {}, | 
|         rules: {}, | 
|         errorClass: "error", | 
|         validClass: "valid", | 
|         errorElement: "label", | 
|         focusInvalid: true, | 
|         errorContainer: $( [] ), | 
|         errorLabelContainer: $( [] ), | 
|         onsubmit: true, | 
|         ignore: [], | 
|         ignoreTitle: false, | 
|         onfocusin: function(element) { | 
|             this.lastActive = element; | 
|                  | 
|             // hide error label and remove error class on focus if enabled | 
|             if ( this.settings.focusCleanup && !this.blockFocusCleanup ) { | 
|                 this.settings.unhighlight && this.settings.unhighlight.call( this, element, this.settings.errorClass, this.settings.validClass ); | 
|                 this.addWrapper(this.errorsFor(element)).hide(); | 
|             } | 
|         }, | 
|         onfocusout: function(element) { | 
|             if ( !this.checkable(element) && (element.name in this.submitted || !this.optional(element)) ) { | 
|                 this.element(element); | 
|             } | 
|         }, | 
|         onkeyup: function(element) { | 
|             if ( element.name in this.submitted || element == this.lastElement ) { | 
|                 this.element(element); | 
|             } | 
|         }, | 
|         onclick: function(element) { | 
|             // click on selects, radiobuttons and checkboxes | 
|             if ( element.name in this.submitted ) | 
|                 this.element(element); | 
|             // or option elements, check parent select in that case | 
|             else if (element.parentNode.name in this.submitted) | 
|                 this.element(element.parentNode); | 
|         }, | 
|         highlight: function( element, errorClass, validClass ) { | 
|             $(element).addClass(errorClass).removeClass(validClass); | 
|         }, | 
|         unhighlight: function( element, errorClass, validClass ) { | 
|             $(element).removeClass(errorClass).addClass(validClass); | 
|         } | 
|     }, | 
|   | 
|     // http://docs.jquery.com/Plugins/Validation/Validator/setDefaults | 
|     setDefaults: function(settings) { | 
|         /// <summary> | 
|         /// Modify default settings for validation. | 
|         /// Accepts everything that Plugins/Validation/validate accepts. | 
|         /// </summary> | 
|         /// <param name="settings" type="Options"> | 
|         /// Options to set as default. | 
|         /// </param> | 
|   | 
|         $.extend( $.validator.defaults, settings ); | 
|     }, | 
|   | 
|     messages: { | 
|         required: "This field is required.", | 
|         remote: "Please fix this field.", | 
|         email: "Please enter a valid email address.", | 
|         url: "Please enter a valid URL.", | 
|         date: "Please enter a valid date.", | 
|         dateISO: "Please enter a valid date (ISO).", | 
|         number: "Please enter a valid number.", | 
|         digits: "Please enter only digits.", | 
|         creditcard: "Please enter a valid credit card number.", | 
|         equalTo: "Please enter the same value again.", | 
|         accept: "Please enter a value with a valid extension.", | 
|         maxlength: $.validator.format("Please enter no more than {0} characters."), | 
|         minlength: $.validator.format("Please enter at least {0} characters."), | 
|         rangelength: $.validator.format("Please enter a value between {0} and {1} characters long."), | 
|         range: $.validator.format("Please enter a value between {0} and {1}."), | 
|         max: $.validator.format("Please enter a value less than or equal to {0}."), | 
|         min: $.validator.format("Please enter a value greater than or equal to {0}.") | 
|     }, | 
|      | 
|     autoCreateRanges: false, | 
|      | 
|     prototype: { | 
|          | 
|         init: function() { | 
|             this.labelContainer = $(this.settings.errorLabelContainer); | 
|             this.errorContext = this.labelContainer.length && this.labelContainer || $(this.currentForm); | 
|             this.containers = $(this.settings.errorContainer).add( this.settings.errorLabelContainer ); | 
|             this.submitted = {}; | 
|             this.valueCache = {}; | 
|             this.pendingRequest = 0; | 
|             this.pending = {}; | 
|             this.invalid = {}; | 
|             this.reset(); | 
|              | 
|             var groups = (this.groups = {}); | 
|             $.each(this.settings.groups, function(key, value) { | 
|                 $.each(value.split(/\s/), function(index, name) { | 
|                     groups[name] = key; | 
|                 }); | 
|             }); | 
|             var rules = this.settings.rules; | 
|             $.each(rules, function(key, value) { | 
|                 rules[key] = $.validator.normalizeRule(value); | 
|             }); | 
|              | 
|             function delegate(event) { | 
|                 var validator = $.data(this[0].form, "validator"), | 
|                     eventType = "on" + event.type.replace(/^validate/, ""); | 
|                 validator.settings[eventType] && validator.settings[eventType].call(validator, this[0] ); | 
|             } | 
|             $(this.currentForm) | 
|                 .validateDelegate(":text, :password, :file, select, textarea", "focusin focusout keyup", delegate) | 
|                 .validateDelegate(":radio, :checkbox, select, option", "click", delegate); | 
|   | 
|             if (this.settings.invalidHandler) | 
|                 $(this.currentForm).bind("invalid-form.validate", this.settings.invalidHandler); | 
|         }, | 
|   | 
|         // http://docs.jquery.com/Plugins/Validation/Validator/form | 
|         form: function() { | 
|             /// <summary> | 
|             /// Validates the form, returns true if it is valid, false otherwise. | 
|             /// This behaves as a normal submit event, but returns the result. | 
|             /// </summary> | 
|             /// <returns type="Boolean" /> | 
|   | 
|             this.checkForm(); | 
|             $.extend(this.submitted, this.errorMap); | 
|             this.invalid = $.extend({}, this.errorMap); | 
|             if (!this.valid()) | 
|                 $(this.currentForm).triggerHandler("invalid-form", [this]); | 
|             this.showErrors(); | 
|             return this.valid(); | 
|         }, | 
|          | 
|         checkForm: function() { | 
|             this.prepareForm(); | 
|             for ( var i = 0, elements = (this.currentElements = this.elements()); elements[i]; i++ ) { | 
|                 this.check( elements[i] ); | 
|             } | 
|             return this.valid();  | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Validator/element | 
|         element: function( element ) { | 
|             /// <summary> | 
|             /// Validates a single element, returns true if it is valid, false otherwise. | 
|             /// This behaves as validation on blur or keyup, but returns the result. | 
|             /// </summary> | 
|             /// <param name="element" type="Selector"> | 
|             /// An element to validate, must be inside the validated form. | 
|             /// </param> | 
|             /// <returns type="Boolean" /> | 
|   | 
|             element = this.clean( element ); | 
|             this.lastElement = element; | 
|             this.prepareElement( element ); | 
|             this.currentElements = $(element); | 
|             var result = this.check( element ); | 
|             if ( result ) { | 
|                 delete this.invalid[element.name]; | 
|             } else { | 
|                 this.invalid[element.name] = true; | 
|             } | 
|             if ( !this.numberOfInvalids() ) { | 
|                 // Hide error containers on last error | 
|                 this.toHide = this.toHide.add( this.containers ); | 
|             } | 
|             this.showErrors(); | 
|             return result; | 
|         }, | 
|   | 
|         // http://docs.jquery.com/Plugins/Validation/Validator/showErrors | 
|         showErrors: function(errors) { | 
|             /// <summary> | 
|             /// Show the specified messages. | 
|             /// Keys have to refer to the names of elements, values are displayed for those elements, using the configured error placement. | 
|             /// </summary> | 
|             /// <param name="errors" type="Object"> | 
|             /// One or more key/value pairs of input names and messages. | 
|             /// </param> | 
|   | 
|             if(errors) { | 
|                 // add items to error list and map | 
|                 $.extend( this.errorMap, errors ); | 
|                 this.errorList = []; | 
|                 for ( var name in errors ) { | 
|                     this.errorList.push({ | 
|                         message: errors[name], | 
|                         element: this.findByName(name)[0] | 
|                     }); | 
|                 } | 
|                 // remove items from success list | 
|                 this.successList = $.grep( this.successList, function(element) { | 
|                     return !(element.name in errors); | 
|                 }); | 
|             } | 
|             this.settings.showErrors | 
|                 ? this.settings.showErrors.call( this, this.errorMap, this.errorList ) | 
|                 : this.defaultShowErrors(); | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Validator/resetForm | 
|         resetForm: function() { | 
|             /// <summary> | 
|             /// Resets the controlled form. | 
|             /// Resets input fields to their original value (requires form plugin), removes classes | 
|             /// indicating invalid elements and hides error messages. | 
|             /// </summary> | 
|   | 
|             if ( $.fn.resetForm ) | 
|                 $( this.currentForm ).resetForm(); | 
|             this.submitted = {}; | 
|             this.prepareForm(); | 
|             this.hideErrors(); | 
|             this.elements().removeClass( this.settings.errorClass ); | 
|         }, | 
|          | 
|         numberOfInvalids: function() { | 
|             /// <summary> | 
|             /// Returns the number of invalid fields. | 
|             /// This depends on the internal validator state. It covers all fields only after | 
|             /// validating the complete form (on submit or via $("form").valid()). After validating | 
|             /// a single element, only that element is counted. Most useful in combination with the | 
|             /// invalidHandler-option. | 
|             /// </summary> | 
|             /// <returns type="Number" /> | 
|   | 
|             return this.objectLength(this.invalid); | 
|         }, | 
|          | 
|         objectLength: function( obj ) { | 
|             var count = 0; | 
|             for ( var i in obj ) | 
|                 count++; | 
|             return count; | 
|         }, | 
|          | 
|         hideErrors: function() { | 
|             this.addWrapper( this.toHide ).hide(); | 
|         }, | 
|          | 
|         valid: function() { | 
|             return this.size() == 0; | 
|         }, | 
|          | 
|         size: function() { | 
|             return this.errorList.length; | 
|         }, | 
|          | 
|         focusInvalid: function() { | 
|             if( this.settings.focusInvalid ) { | 
|                 try { | 
|                     $(this.findLastActive() || this.errorList.length && this.errorList[0].element || []) | 
|                     .filter(":visible") | 
|                     .focus() | 
|                     // manually trigger focusin event; without it, focusin handler isn't called, findLastActive won't have anything to find | 
|                     .trigger("focusin"); | 
|                 } catch(e) { | 
|                     // ignore IE throwing errors when focusing hidden elements | 
|                 } | 
|             } | 
|         }, | 
|          | 
|         findLastActive: function() { | 
|             var lastActive = this.lastActive; | 
|             return lastActive && $.grep(this.errorList, function(n) { | 
|                 return n.element.name == lastActive.name; | 
|             }).length == 1 && lastActive; | 
|         }, | 
|          | 
|         elements: function() { | 
|             var validator = this, | 
|                 rulesCache = {}; | 
|              | 
|             // select all valid inputs inside the form (no submit or reset buttons) | 
|             // workaround $Query([]).add until http://dev.jquery.com/ticket/2114 is solved | 
|             return $([]).add(this.currentForm.elements) | 
|             .filter(":input") | 
|             .not(":submit, :reset, :image, [disabled]") | 
|             .not( this.settings.ignore ) | 
|             .filter(function() { | 
|                 !this.name && validator.settings.debug && window.console && console.error( "%o has no name assigned", this); | 
|              | 
|                 // select only the first element for each name, and only those with rules specified | 
|                 if ( this.name in rulesCache || !validator.objectLength($(this).rules()) ) | 
|                     return false; | 
|                  | 
|                 rulesCache[this.name] = true; | 
|                 return true; | 
|             }); | 
|         }, | 
|          | 
|         clean: function( selector ) { | 
|             return $( selector )[0]; | 
|         }, | 
|          | 
|         errors: function() { | 
|             return $( this.settings.errorElement + "." + this.settings.errorClass, this.errorContext ); | 
|         }, | 
|          | 
|         reset: function() { | 
|             this.successList = []; | 
|             this.errorList = []; | 
|             this.errorMap = {}; | 
|             this.toShow = $([]); | 
|             this.toHide = $([]); | 
|             this.currentElements = $([]); | 
|         }, | 
|          | 
|         prepareForm: function() { | 
|             this.reset(); | 
|             this.toHide = this.errors().add( this.containers ); | 
|         }, | 
|          | 
|         prepareElement: function( element ) { | 
|             this.reset(); | 
|             this.toHide = this.errorsFor(element); | 
|         }, | 
|      | 
|         check: function( element ) { | 
|             element = this.clean( element ); | 
|              | 
|             // if radio/checkbox, validate first element in group instead | 
|             if (this.checkable(element)) { | 
|                 element = this.findByName(element.name).not(this.settings.ignore)[0]; | 
|             } | 
|              | 
|             var rules = $(element).rules(); | 
|             var dependencyMismatch = false; | 
|             for (var method in rules) { | 
|                 var rule = { method: method, parameters: rules[method] }; | 
|                 try { | 
|                     var result = $.validator.methods[method].call( this, element.value.replace(/\r/g, ""), element, rule.parameters ); | 
|                      | 
|                     // if a method indicates that the field is optional and therefore valid, | 
|                     // don't mark it as valid when there are no other rules | 
|                     if ( result == "dependency-mismatch" ) { | 
|                         dependencyMismatch = true; | 
|                         continue; | 
|                     } | 
|                     dependencyMismatch = false; | 
|                      | 
|                     if ( result == "pending" ) { | 
|                         this.toHide = this.toHide.not( this.errorsFor(element) ); | 
|                         return; | 
|                     } | 
|                      | 
|                     if( !result ) { | 
|                         this.formatAndAdd( element, rule ); | 
|                         return false; | 
|                     } | 
|                 } catch(e) { | 
|                     this.settings.debug && window.console && console.log("exception occured when checking element " + element.id | 
|                          + ", check the '" + rule.method + "' method", e); | 
|                     throw e; | 
|                 } | 
|             } | 
|             if (dependencyMismatch) | 
|                 return; | 
|             if ( this.objectLength(rules) ) | 
|                 this.successList.push(element); | 
|             return true; | 
|         }, | 
|          | 
|         // return the custom message for the given element and validation method | 
|         // specified in the element's "messages" metadata | 
|         customMetaMessage: function(element, method) { | 
|             if (!$.metadata) | 
|                 return; | 
|              | 
|             var meta = this.settings.meta | 
|                 ? $(element).metadata()[this.settings.meta] | 
|                 : $(element).metadata(); | 
|              | 
|             return meta && meta.messages && meta.messages[method]; | 
|         }, | 
|          | 
|         // return the custom message for the given element name and validation method | 
|         customMessage: function( name, method ) { | 
|             var m = this.settings.messages[name]; | 
|             return m && (m.constructor == String | 
|                 ? m | 
|                 : m[method]); | 
|         }, | 
|          | 
|         // return the first defined argument, allowing empty strings | 
|         findDefined: function() { | 
|             for(var i = 0; i < arguments.length; i++) { | 
|                 if (arguments[i] !== undefined) | 
|                     return arguments[i]; | 
|             } | 
|             return undefined; | 
|         }, | 
|          | 
|         defaultMessage: function( element, method) { | 
|             return this.findDefined( | 
|                 this.customMessage( element.name, method ), | 
|                 this.customMetaMessage( element, method ), | 
|                 // title is never undefined, so handle empty string as undefined | 
|                 !this.settings.ignoreTitle && element.title || undefined, | 
|                 $.validator.messages[method], | 
|                 "<strong>Warning: No message defined for " + element.name + "</strong>" | 
|             ); | 
|         }, | 
|          | 
|         formatAndAdd: function( element, rule ) { | 
|             var message = this.defaultMessage( element, rule.method ), | 
|                 theregex = /\$?\{(\d+)\}/g; | 
|             if ( typeof message == "function" ) { | 
|                 message = message.call(this, rule.parameters, element); | 
|             } else if (theregex.test(message)) { | 
|                 message = jQuery.format(message.replace(theregex, '{$1}'), rule.parameters); | 
|             }             | 
|             this.errorList.push({ | 
|                 message: message, | 
|                 element: element | 
|             }); | 
|              | 
|             this.errorMap[element.name] = message; | 
|             this.submitted[element.name] = message; | 
|         }, | 
|          | 
|         addWrapper: function(toToggle) { | 
|             if ( this.settings.wrapper ) | 
|                 toToggle = toToggle.add( toToggle.parent( this.settings.wrapper ) ); | 
|             return toToggle; | 
|         }, | 
|          | 
|         defaultShowErrors: function() { | 
|             for ( var i = 0; this.errorList[i]; i++ ) { | 
|                 var error = this.errorList[i]; | 
|                 this.settings.highlight && this.settings.highlight.call( this, error.element, this.settings.errorClass, this.settings.validClass ); | 
|                 this.showLabel( error.element, error.message ); | 
|             } | 
|             if( this.errorList.length ) { | 
|                 this.toShow = this.toShow.add( this.containers ); | 
|             } | 
|             if (this.settings.success) { | 
|                 for ( var i = 0; this.successList[i]; i++ ) { | 
|                     this.showLabel( this.successList[i] ); | 
|                 } | 
|             } | 
|             if (this.settings.unhighlight) { | 
|                 for ( var i = 0, elements = this.validElements(); elements[i]; i++ ) { | 
|                     this.settings.unhighlight.call( this, elements[i], this.settings.errorClass, this.settings.validClass ); | 
|                 } | 
|             } | 
|             this.toHide = this.toHide.not( this.toShow ); | 
|             this.hideErrors(); | 
|             this.addWrapper( this.toShow ).show(); | 
|         }, | 
|          | 
|         validElements: function() { | 
|             return this.currentElements.not(this.invalidElements()); | 
|         }, | 
|          | 
|         invalidElements: function() { | 
|             return $(this.errorList).map(function() { | 
|                 return this.element; | 
|             }); | 
|         }, | 
|          | 
|         showLabel: function(element, message) { | 
|             var label = this.errorsFor( element ); | 
|             if ( label.length ) { | 
|                 // refresh error/success class | 
|                 label.removeClass().addClass( this.settings.errorClass ); | 
|              | 
|                 // check if we have a generated label, replace the message then | 
|                 label.attr("generated") && label.html(message); | 
|             } else { | 
|                 // create label | 
|                 label = $("<" + this.settings.errorElement + "/>") | 
|                     .attr({"for":  this.idOrName(element), generated: true}) | 
|                     .addClass(this.settings.errorClass) | 
|                     .html(message || ""); | 
|                 if ( this.settings.wrapper ) { | 
|                     // make sure the element is visible, even in IE | 
|                     // actually showing the wrapped element is handled elsewhere | 
|                     label = label.hide().show().wrap("<" + this.settings.wrapper + "/>").parent(); | 
|                 } | 
|                 if ( !this.labelContainer.append(label).length ) | 
|                     this.settings.errorPlacement | 
|                         ? this.settings.errorPlacement(label, $(element) ) | 
|                         : label.insertAfter(element); | 
|             } | 
|             if ( !message && this.settings.success ) { | 
|                 label.text(""); | 
|                 typeof this.settings.success == "string" | 
|                     ? label.addClass( this.settings.success ) | 
|                     : this.settings.success( label ); | 
|             } | 
|             this.toShow = this.toShow.add(label); | 
|         }, | 
|          | 
|         errorsFor: function(element) { | 
|             var name = this.idOrName(element); | 
|             return this.errors().filter(function() { | 
|                 return $(this).attr('for') == name; | 
|             }); | 
|         }, | 
|          | 
|         idOrName: function(element) { | 
|             return this.groups[element.name] || (this.checkable(element) ? element.name : element.id || element.name); | 
|         }, | 
|   | 
|         checkable: function( element ) { | 
|             return /radio|checkbox/i.test(element.type); | 
|         }, | 
|          | 
|         findByName: function( name ) { | 
|             // select by name and filter by form for performance over form.find("[name=...]") | 
|             var form = this.currentForm; | 
|             return $(document.getElementsByName(name)).map(function(index, element) { | 
|                 return element.form == form && element.name == name && element  || null; | 
|             }); | 
|         }, | 
|          | 
|         getLength: function(value, element) { | 
|             switch( element.nodeName.toLowerCase() ) { | 
|             case 'select': | 
|                 return $("option:selected", element).length; | 
|             case 'input': | 
|                 if( this.checkable( element) ) | 
|                     return this.findByName(element.name).filter(':checked').length; | 
|             } | 
|             return value.length; | 
|         }, | 
|      | 
|         depend: function(param, element) { | 
|             return this.dependTypes[typeof param] | 
|                 ? this.dependTypes[typeof param](param, element) | 
|                 : true; | 
|         }, | 
|      | 
|         dependTypes: { | 
|             "boolean": function(param, element) { | 
|                 return param; | 
|             }, | 
|             "string": function(param, element) { | 
|                 return !!$(param, element.form).length; | 
|             }, | 
|             "function": function(param, element) { | 
|                 return param(element); | 
|             } | 
|         }, | 
|          | 
|         optional: function(element) { | 
|             return !$.validator.methods.required.call(this, $.trim(element.value), element) && "dependency-mismatch"; | 
|         }, | 
|          | 
|         startRequest: function(element) { | 
|             if (!this.pending[element.name]) { | 
|                 this.pendingRequest++; | 
|                 this.pending[element.name] = true; | 
|             } | 
|         }, | 
|          | 
|         stopRequest: function(element, valid) { | 
|             this.pendingRequest--; | 
|             // sometimes synchronization fails, make sure pendingRequest is never < 0 | 
|             if (this.pendingRequest < 0) | 
|                 this.pendingRequest = 0; | 
|             delete this.pending[element.name]; | 
|             if ( valid && this.pendingRequest == 0 && this.formSubmitted && this.form() ) { | 
|                 $(this.currentForm).submit(); | 
|                 this.formSubmitted = false; | 
|             } else if (!valid && this.pendingRequest == 0 && this.formSubmitted) { | 
|                 $(this.currentForm).triggerHandler("invalid-form", [this]); | 
|                 this.formSubmitted = false; | 
|             } | 
|         }, | 
|          | 
|         previousValue: function(element) { | 
|             return $.data(element, "previousValue") || $.data(element, "previousValue", { | 
|                 old: null, | 
|                 valid: true, | 
|                 message: this.defaultMessage( element, "remote" ) | 
|             }); | 
|         } | 
|          | 
|     }, | 
|      | 
|     classRuleSettings: { | 
|         required: {required: true}, | 
|         email: {email: true}, | 
|         url: {url: true}, | 
|         date: {date: true}, | 
|         dateISO: {dateISO: true}, | 
|         dateDE: {dateDE: true}, | 
|         number: {number: true}, | 
|         numberDE: {numberDE: true}, | 
|         digits: {digits: true}, | 
|         creditcard: {creditcard: true} | 
|     }, | 
|      | 
|     addClassRules: function(className, rules) { | 
|         /// <summary> | 
|         /// Add a compound class method - useful to refactor common combinations of rules into a single | 
|         /// class. | 
|         /// </summary> | 
|         /// <param name="name" type="String"> | 
|         /// The name of the class rule to add | 
|         /// </param> | 
|         /// <param name="rules" type="Options"> | 
|         /// The compound rules | 
|         /// </param> | 
|   | 
|         className.constructor == String ? | 
|             this.classRuleSettings[className] = rules : | 
|             $.extend(this.classRuleSettings, className); | 
|     }, | 
|      | 
|     classRules: function(element) { | 
|         var rules = {}; | 
|         var classes = $(element).attr('class'); | 
|         classes && $.each(classes.split(' '), function() { | 
|             if (this in $.validator.classRuleSettings) { | 
|                 $.extend(rules, $.validator.classRuleSettings[this]); | 
|             } | 
|         }); | 
|         return rules; | 
|     }, | 
|      | 
|     attributeRules: function(element) { | 
|         var rules = {}; | 
|         var $element = $(element); | 
|   | 
|         for (var method in $.validator.methods) { | 
|             var value = $element.attr(method); | 
|             if (value) { | 
|                 rules[method] = value; | 
|             } | 
|         } | 
|          | 
|         // maxlength may be returned as -1, 2147483647 (IE) and 524288 (safari) for text inputs | 
|         if (rules.maxlength && /-1|2147483647|524288/.test(rules.maxlength)) { | 
|             delete rules.maxlength; | 
|         } | 
|          | 
|         return rules; | 
|     }, | 
|      | 
|     metadataRules: function(element) { | 
|         if (!$.metadata) return {}; | 
|          | 
|         var meta = $.data(element.form, 'validator').settings.meta; | 
|         return meta ? | 
|             $(element).metadata()[meta] : | 
|             $(element).metadata(); | 
|     }, | 
|      | 
|     staticRules: function(element) { | 
|         var rules = {}; | 
|         var validator = $.data(element.form, 'validator'); | 
|         if (validator.settings.rules) { | 
|             rules = $.validator.normalizeRule(validator.settings.rules[element.name]) || {}; | 
|         } | 
|         return rules; | 
|     }, | 
|      | 
|     normalizeRules: function(rules, element) { | 
|         // handle dependency check | 
|         $.each(rules, function(prop, val) { | 
|             // ignore rule when param is explicitly false, eg. required:false | 
|             if (val === false) { | 
|                 delete rules[prop]; | 
|                 return; | 
|             } | 
|             if (val.param || val.depends) { | 
|                 var keepRule = true; | 
|                 switch (typeof val.depends) { | 
|                     case "string": | 
|                         keepRule = !!$(val.depends, element.form).length; | 
|                         break; | 
|                     case "function": | 
|                         keepRule = val.depends.call(element, element); | 
|                         break; | 
|                 } | 
|                 if (keepRule) { | 
|                     rules[prop] = val.param !== undefined ? val.param : true; | 
|                 } else { | 
|                     delete rules[prop]; | 
|                 } | 
|             } | 
|         }); | 
|          | 
|         // evaluate parameters | 
|         $.each(rules, function(rule, parameter) { | 
|             rules[rule] = $.isFunction(parameter) ? parameter(element) : parameter; | 
|         }); | 
|          | 
|         // clean number parameters | 
|         $.each(['minlength', 'maxlength', 'min', 'max'], function() { | 
|             if (rules[this]) { | 
|                 rules[this] = Number(rules[this]); | 
|             } | 
|         }); | 
|         $.each(['rangelength', 'range'], function() { | 
|             if (rules[this]) { | 
|                 rules[this] = [Number(rules[this][0]), Number(rules[this][1])]; | 
|             } | 
|         }); | 
|          | 
|         if ($.validator.autoCreateRanges) { | 
|             // auto-create ranges | 
|             if (rules.min && rules.max) { | 
|                 rules.range = [rules.min, rules.max]; | 
|                 delete rules.min; | 
|                 delete rules.max; | 
|             } | 
|             if (rules.minlength && rules.maxlength) { | 
|                 rules.rangelength = [rules.minlength, rules.maxlength]; | 
|                 delete rules.minlength; | 
|                 delete rules.maxlength; | 
|             } | 
|         } | 
|          | 
|         // To support custom messages in metadata ignore rule methods titled "messages" | 
|         if (rules.messages) { | 
|             delete rules.messages; | 
|         } | 
|          | 
|         return rules; | 
|     }, | 
|      | 
|     // Converts a simple string to a {string: true} rule, e.g., "required" to {required:true} | 
|     normalizeRule: function(data) { | 
|         if( typeof data == "string" ) { | 
|             var transformed = {}; | 
|             $.each(data.split(/\s/), function() { | 
|                 transformed[this] = true; | 
|             }); | 
|             data = transformed; | 
|         } | 
|         return data; | 
|     }, | 
|      | 
|     // http://docs.jquery.com/Plugins/Validation/Validator/addMethod | 
|     addMethod: function(name, method, message) { | 
|         /// <summary> | 
|         /// Add a custom validation method. It must consist of a name (must be a legal javascript  | 
|         /// identifier), a javascript based function and a default string message. | 
|         /// </summary> | 
|         /// <param name="name" type="String"> | 
|         /// The name of the method, used to identify and referencing it, must be a valid javascript | 
|         /// identifier | 
|         /// </param> | 
|         /// <param name="method" type="Function"> | 
|         /// The actual method implementation, returning true if an element is valid | 
|         /// </param> | 
|         /// <param name="message" type="String" optional="true"> | 
|         /// (Optional) The default message to display for this method. Can be a function created by  | 
|         /// jQuery.validator.format(value). When undefined, an already existing message is used  | 
|         /// (handy for localization), otherwise the field-specific messages have to be defined. | 
|         /// </param> | 
|   | 
|         $.validator.methods[name] = method; | 
|         $.validator.messages[name] = message != undefined ? message : $.validator.messages[name]; | 
|         if (method.length < 3) { | 
|             $.validator.addClassRules(name, $.validator.normalizeRule(name)); | 
|         } | 
|     }, | 
|   | 
|     methods: { | 
|   | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/required | 
|         required: function(value, element, param) { | 
|             // check if dependency is met | 
|             if ( !this.depend(param, element) ) | 
|                 return "dependency-mismatch"; | 
|             switch( element.nodeName.toLowerCase() ) { | 
|             case 'select': | 
|                 // could be an array for select-multiple or a string, both are fine this way | 
|                 var val = $(element).val(); | 
|                 return val && val.length > 0; | 
|             case 'input': | 
|                 if ( this.checkable(element) ) | 
|                     return this.getLength(value, element) > 0; | 
|             default: | 
|                 return $.trim(value).length > 0; | 
|             } | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/remote | 
|         remote: function(value, element, param) { | 
|             if ( this.optional(element) ) | 
|                 return "dependency-mismatch"; | 
|              | 
|             var previous = this.previousValue(element); | 
|             if (!this.settings.messages[element.name] ) | 
|                 this.settings.messages[element.name] = {}; | 
|             previous.originalMessage = this.settings.messages[element.name].remote; | 
|             this.settings.messages[element.name].remote = previous.message; | 
|              | 
|             param = typeof param == "string" && {url:param} || param;  | 
|              | 
|             if ( this.pending[element.name] ) { | 
|                 return "pending"; | 
|             } | 
|             if ( previous.old === value ) { | 
|                 return previous.valid; | 
|             } | 
|   | 
|             previous.old = value; | 
|             var validator = this; | 
|             this.startRequest(element); | 
|             var data = {}; | 
|             data[element.name] = value; | 
|             $.ajax($.extend(true, { | 
|                 url: param, | 
|                 mode: "abort", | 
|                 port: "validate" + element.name, | 
|                 dataType: "json", | 
|                 data: data, | 
|                 success: function(response) { | 
|                     validator.settings.messages[element.name].remote = previous.originalMessage; | 
|                     var valid = response === true; | 
|                     if ( valid ) { | 
|                         var submitted = validator.formSubmitted; | 
|                         validator.prepareElement(element); | 
|                         validator.formSubmitted = submitted; | 
|                         validator.successList.push(element); | 
|                         validator.showErrors(); | 
|                     } else { | 
|                         var errors = {}; | 
|                         var message = response || validator.defaultMessage(element, "remote"); | 
|                         errors[element.name] = previous.message = $.isFunction(message) ? message(value) : message; | 
|                         validator.showErrors(errors); | 
|                     } | 
|                     previous.valid = valid; | 
|                     validator.stopRequest(element, valid); | 
|                 } | 
|             }, param)); | 
|             return "pending"; | 
|         }, | 
|   | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/minlength | 
|         minlength: function(value, element, param) { | 
|             return this.optional(element) || this.getLength($.trim(value), element) >= param; | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/maxlength | 
|         maxlength: function(value, element, param) { | 
|             return this.optional(element) || this.getLength($.trim(value), element) <= param; | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/rangelength | 
|         rangelength: function(value, element, param) { | 
|             var length = this.getLength($.trim(value), element); | 
|             return this.optional(element) || ( length >= param[0] && length <= param[1] ); | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/min | 
|         min: function( value, element, param ) { | 
|             return this.optional(element) || value >= param; | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/max | 
|         max: function( value, element, param ) { | 
|             return this.optional(element) || value <= param; | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/range | 
|         range: function( value, element, param ) { | 
|             return this.optional(element) || ( value >= param[0] && value <= param[1] ); | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/email | 
|         email: function(value, element) { | 
|             // contributed by Scott Gonzalez: http://projects.scottsplayground.com/email_address_validation/ | 
|             return this.optional(element) || /^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i.test(value); | 
|         }, | 
|      | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/url | 
|         url: function(value, element) { | 
|             // contributed by Scott Gonzalez: http://projects.scottsplayground.com/iri/ | 
|             return this.optional(element) || /^(https?|ftp):\/\/(((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(\#((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$/i.test(value); | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/date | 
|         date: function(value, element) { | 
|             return this.optional(element) || !/Invalid|NaN/.test(new Date(value)); | 
|         }, | 
|      | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/dateISO | 
|         dateISO: function(value, element) { | 
|             return this.optional(element) || /^\d{4}[\/-]\d{1,2}[\/-]\d{1,2}$/.test(value); | 
|         }, | 
|      | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/number | 
|         number: function(value, element) { | 
|             return this.optional(element) || /^-?(?:\d+|\d{1,3}(?:,\d{3})+)(?:\.\d+)?$/.test(value); | 
|         }, | 
|      | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/digits | 
|         digits: function(value, element) { | 
|             return this.optional(element) || /^\d+$/.test(value); | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/creditcard | 
|         // based on http://en.wikipedia.org/wiki/Luhn | 
|         creditcard: function(value, element) { | 
|             if ( this.optional(element) ) | 
|                 return "dependency-mismatch"; | 
|             // accept only digits and dashes | 
|             if (/[^0-9-]+/.test(value)) | 
|                 return false; | 
|             var nCheck = 0, | 
|                 nDigit = 0, | 
|                 bEven = false; | 
|   | 
|             value = value.replace(/\D/g, ""); | 
|   | 
|             for (var n = value.length - 1; n >= 0; n--) { | 
|                 var cDigit = value.charAt(n); | 
|                 var nDigit = parseInt(cDigit, 10); | 
|                 if (bEven) { | 
|                     if ((nDigit *= 2) > 9) | 
|                         nDigit -= 9; | 
|                 } | 
|                 nCheck += nDigit; | 
|                 bEven = !bEven; | 
|             } | 
|   | 
|             return (nCheck % 10) == 0; | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/accept | 
|         accept: function(value, element, param) { | 
|             param = typeof param == "string" ? param.replace(/,/g, '|') : "png|jpe?g|gif"; | 
|             return this.optional(element) || value.match(new RegExp(".(" + param + ")$", "i"));  | 
|         }, | 
|          | 
|         // http://docs.jquery.com/Plugins/Validation/Methods/equalTo | 
|         equalTo: function(value, element, param) { | 
|             // bind to the blur event of the target in order to revalidate whenever the target field is updated | 
|             // TODO find a way to bind the event just once, avoiding the unbind-rebind overhead | 
|             var target = $(param).unbind(".validate-equalTo").bind("blur.validate-equalTo", function() { | 
|                 $(element).valid(); | 
|             }); | 
|             return value == target.val(); | 
|         } | 
|          | 
|     } | 
|      | 
| }); | 
|   | 
| // deprecated, use $.validator.format instead | 
| $.format = $.validator.format; | 
|   | 
| })(jQuery); | 
|   | 
| // ajax mode: abort | 
| // usage: $.ajax({ mode: "abort"[, port: "uniqueport"]}); | 
| // if mode:"abort" is used, the previous request on that port (port can be undefined) is aborted via XMLHttpRequest.abort()  | 
| ;(function($) { | 
|     var pendingRequests = {}; | 
|         // Use a prefilter if available (1.5+) | 
|     if ( $.ajaxPrefilter ) { | 
|         $.ajaxPrefilter(function(settings, _, xhr) { | 
|             var port = settings.port; | 
|             if (settings.mode == "abort") { | 
|                 if ( pendingRequests[port] ) { | 
|                     pendingRequests[port].abort(); | 
|                 }                pendingRequests[port] = xhr; | 
|             } | 
|         }); | 
|     } else { | 
|         // Proxy ajax | 
|         var ajax = $.ajax; | 
|         $.ajax = function(settings) { | 
|             var mode = ( "mode" in settings ? settings : $.ajaxSettings ).mode, | 
|                 port = ( "port" in settings ? settings : $.ajaxSettings ).port; | 
|             if (mode == "abort") { | 
|                 if ( pendingRequests[port] ) { | 
|                     pendingRequests[port].abort(); | 
|                 } | 
|   | 
|                 return (pendingRequests[port] = ajax.apply(this, arguments)); | 
|             } | 
|             return ajax.apply(this, arguments); | 
|         }; | 
|     } | 
| })(jQuery); | 
|   | 
| // provides cross-browser focusin and focusout events | 
| // IE has native support, in other browsers, use event caputuring (neither bubbles) | 
|   | 
| // provides delegate(type: String, delegate: Selector, handler: Callback) plugin for easier event delegation | 
| // handler is only called when $(event.target).is(delegate), in the scope of the jquery-object for event.target  | 
| ;(function($) { | 
|     // only implement if not provided by jQuery core (since 1.4) | 
|     // TODO verify if jQuery 1.4's implementation is compatible with older jQuery special-event APIs | 
|     if (!jQuery.event.special.focusin && !jQuery.event.special.focusout && document.addEventListener) { | 
|         $.each({ | 
|             focus: 'focusin', | 
|             blur: 'focusout'     | 
|         }, function( original, fix ){ | 
|             $.event.special[fix] = { | 
|                 setup:function() { | 
|                     this.addEventListener( original, handler, true ); | 
|                 }, | 
|                 teardown:function() { | 
|                     this.removeEventListener( original, handler, true ); | 
|                 }, | 
|                 handler: function(e) { | 
|                     arguments[0] = $.event.fix(e); | 
|                     arguments[0].type = fix; | 
|                     return $.event.handle.apply(this, arguments); | 
|                 } | 
|             }; | 
|             function handler(e) { | 
|                 e = $.event.fix(e); | 
|                 e.type = fix; | 
|                 return $.event.handle.call(this, e); | 
|             } | 
|         }); | 
|     }; | 
|     $.extend($.fn, { | 
|         validateDelegate: function(delegate, type, handler) { | 
|             return this.bind(type, function(event) { | 
|                 var target = $(event.target); | 
|                 if (target.is(delegate)) { | 
|                     return handler.apply(target, arguments); | 
|                 } | 
|             }); | 
|         } | 
|     }); | 
| })(jQuery); |