/** 
 | 
 * BootstrapValidator (http://bootstrapvalidator.com) 
 | 
 *  
 | 
 * The best jQuery plugin to validate form fields. Designed to use with 
 | 
 * Bootstrap 3 
 | 
 *  
 | 
 * @version v0.4.5 
 | 
 * @author https://twitter.com/nghuuphuoc 
 | 
 * @copyright (c) 2013 - 2014 Nguyen Huu Phuoc 
 | 
 * @license MIT 
 | 
 */ 
 | 
  
 | 
(function($) { 
 | 
    var BootstrapValidator = function(form, options) { 
 | 
        this.$form = $(form); 
 | 
        this.options = $.extend({}, BootstrapValidator.DEFAULT_OPTIONS, options); 
 | 
  
 | 
        this.$invalidField = null; // First invalid field 
 | 
        this.$submitButton = null; // The submit button which is clicked to 
 | 
                                    // submit form 
 | 
  
 | 
        // Validating status 
 | 
        this.STATUS_NOT_VALIDATED = 'NOT_VALIDATED'; 
 | 
        this.STATUS_VALIDATING = 'VALIDATING'; 
 | 
        this.STATUS_INVALID = 'INVALID'; 
 | 
        this.STATUS_VALID = 'VALID'; 
 | 
  
 | 
        // Determine the event that is fired when user change the field value 
 | 
        // Most modern browsers supports input event except IE 7, 8. 
 | 
        // IE 9 supports input event but the event is still not fired if I press 
 | 
        // the backspace key. 
 | 
        // Get IE version 
 | 
        // https://gist.github.com/padolsey/527683/#comment-7595 
 | 
        var ieVersion = (function() { 
 | 
            var v = 3, div = document.createElement('div'), a = div.all || []; 
 | 
            while (div.innerHTML = '<!--[if gt IE ' + (++v) + ']><br><![endif]-->', a[0]) 
 | 
                ; 
 | 
            return v > 4 ? v : !v; 
 | 
        }()); 
 | 
  
 | 
        var el = document.createElement('div'); 
 | 
        this._changeEvent = (ieVersion === 9 || !('oninput' in el)) ? 'keyup' : 'input'; 
 | 
  
 | 
        // The flag to indicate that the form is ready to submit when a 
 | 
        // remote/callback validator returns 
 | 
        this._submitIfValid = null; 
 | 
  
 | 
        this._init(); 
 | 
    }; 
 | 
  
 | 
    // The default options 
 | 
    BootstrapValidator.DEFAULT_OPTIONS = { 
 | 
        // The form CSS class 
 | 
        elementClass : 'bv-form', 
 | 
  
 | 
        // Default invalid message 
 | 
        message : 'This value is not valid', 
 | 
  
 | 
        // The field will not be live validated if its length is less than this 
 | 
        // number of characters 
 | 
        threshold : null, 
 | 
  
 | 
        // Indicate fields which won't be validated 
 | 
        // By default, the plugin will not validate the following kind of 
 | 
        // fields: 
 | 
        // - disabled 
 | 
        // - hidden 
 | 
        // - invisible 
 | 
        // 
 | 
        // The setting consists of jQuery filters. Accept 3 formats: 
 | 
        // - A string. Use a comma to separate filter 
 | 
        // - An array. Each element is a filter 
 | 
        // - An array. Each element can be a callback function 
 | 
        // function($field, validator) { 
 | 
        // $field is jQuery object representing the field element 
 | 
        // validator is the BootstrapValidator instance 
 | 
        // return true or false; 
 | 
        // } 
 | 
        // 
 | 
        // The 3 following settings are equivalent: 
 | 
        // 
 | 
        // 1) ':disabled, :hidden, :not(:visible)' 
 | 
        // 2) [':disabled', ':hidden', ':not(:visible)'] 
 | 
        // 3) [':disabled', ':hidden', function($field) { 
 | 
        // return !$field.is(':visible'); 
 | 
        // }] 
 | 
        excluded : [ ':disabled', ':hidden', ':not(:visible)' ], 
 | 
  
 | 
        // Shows ok/error/loading icons based on the field validity. 
 | 
        // This feature requires Bootstrap v3.1.0 or later 
 | 
        // (http://getbootstrap.com/css/#forms-control-validation). 
 | 
        // Since Bootstrap doesn't provide any methods to know its version, this 
 | 
        // option cannot be on/off automatically. 
 | 
        // In other word, to use this feature you have to upgrade your Bootstrap 
 | 
        // to v3.1.0 or later. 
 | 
        // 
 | 
        // Examples: 
 | 
        // - Use Glyphicons icons: 
 | 
        // feedbackIcons: { 
 | 
        // valid: 'glyphicon glyphicon-ok', 
 | 
        // invalid: 'glyphicon glyphicon-remove', 
 | 
        // validating: 'glyphicon glyphicon-refresh' 
 | 
        // } 
 | 
        // - Use FontAwesome icons: 
 | 
        // feedbackIcons: { 
 | 
        // valid: 'fa fa-check', 
 | 
        // invalid: 'fa fa-times', 
 | 
        // validating: 'fa fa-refresh' 
 | 
        // } 
 | 
        feedbackIcons : { 
 | 
            valid : null, 
 | 
            invalid : null, 
 | 
            validating : null 
 | 
        }, 
 | 
  
 | 
        // The submit buttons selector 
 | 
        // These buttons will be disabled to prevent the valid form from 
 | 
        // multiple submissions 
 | 
        submitButtons : '[type="submit"]', 
 | 
  
 | 
        // The custom submit handler 
 | 
        // It will prevent the form from the default submission 
 | 
        // 
 | 
        // submitHandler: function(validator, form) { 
 | 
        // - validator is the BootstrapValidator instance 
 | 
        // - form is the jQuery object present the current form 
 | 
        // } 
 | 
        submitHandler : null, 
 | 
  
 | 
        // Live validating option 
 | 
        // Can be one of 3 values: 
 | 
        // - enabled: The plugin validates fields as soon as they are changed 
 | 
        // - disabled: Disable the live validating. The error messages are only 
 | 
        // shown after the form is submitted 
 | 
        // - submitted: The live validating is enabled after the form is 
 | 
        // submitted 
 | 
        live : 'enabled', 
 | 
  
 | 
        // Map the field name with validator rules 
 | 
        fields : null 
 | 
    }; 
 | 
  
 | 
    BootstrapValidator.prototype = { 
 | 
        constructor : BootstrapValidator, 
 | 
  
 | 
        /** 
 | 
         * Init form 
 | 
         */ 
 | 
        _init : function() { 
 | 
            var that = this, options = { 
 | 
                excluded : this.$form.attr('data-bv-excluded'), 
 | 
                trigger : this.$form.attr('data-bv-trigger'), 
 | 
                message : this.$form.attr('data-bv-message'), 
 | 
                submitButtons : this.$form.attr('data-bv-submitbuttons'), 
 | 
                threshold : this.$form.attr('data-bv-threshold'), 
 | 
                live : this.$form.attr('data-bv-live'), 
 | 
                fields : {}, 
 | 
                feedbackIcons : { 
 | 
                    valid : this.$form.attr('data-bv-feedbackicons-valid'), 
 | 
                    invalid : this.$form.attr('data-bv-feedbackicons-invalid'), 
 | 
                    validating : this.$form.attr('data-bv-feedbackicons-validating') 
 | 
                } 
 | 
            }, validator, v, // Validator name 
 | 
            enabled, optionName, optionValue, html5AttrName, html5Attrs; 
 | 
  
 | 
            this.$form 
 | 
            // Disable client side validation in HTML 5 
 | 
            .attr('novalidate', 'novalidate').addClass(this.options.elementClass) 
 | 
            // Disable the default submission first 
 | 
            .on('submit.bv', function(e) { 
 | 
                e.preventDefault(); 
 | 
                that.validate(); 
 | 
            }).on('click', this.options.submitButtons, function() { 
 | 
                that.$submitButton = $(this); 
 | 
                // The user just click the submit button 
 | 
                that._submitIfValid = true; 
 | 
            }) 
 | 
            // Find all fields which have either "name" or "data-bv-field" 
 | 
            // attribute 
 | 
            .find('[name], [data-bv-field]').each(function() { 
 | 
                var $field = $(this); 
 | 
                if (that._isExcluded($field)) { 
 | 
                    return; 
 | 
                } 
 | 
  
 | 
                var field = $field.attr('name') || $field.attr('data-bv-field'), validators = {}; 
 | 
                for (v in $.fn.bootstrapValidator.validators) { 
 | 
                    validator = $.fn.bootstrapValidator.validators[v]; 
 | 
                    enabled = $field.attr('data-bv-' + v.toLowerCase()) + ''; 
 | 
                    html5Attrs = ('function' == typeof validator.enableByHtml5) ? validator.enableByHtml5($(this)) : null; 
 | 
  
 | 
                    if ((html5Attrs && enabled != 'false') || (html5Attrs !== true && ('' == enabled || 'true' == enabled))) { 
 | 
                        // Try to parse the options via attributes 
 | 
                        validator.html5Attributes = validator.html5Attributes || { 
 | 
                            message : 'message' 
 | 
                        }; 
 | 
                        validators[v] = $.extend({}, html5Attrs == true ? {} : html5Attrs, validators[v]); 
 | 
  
 | 
                        for (html5AttrName in validator.html5Attributes) { 
 | 
                            optionName = validator.html5Attributes[html5AttrName]; 
 | 
                            optionValue = $field.attr('data-bv-' + v.toLowerCase() + '-' + html5AttrName); 
 | 
                            if (optionValue) { 
 | 
                                if ('true' == optionValue) { 
 | 
                                    optionValue = true; 
 | 
                                } else if ('false' == optionValue) { 
 | 
                                    optionValue = false; 
 | 
                                } 
 | 
                                validators[v][optionName] = optionValue; 
 | 
                            } 
 | 
                        } 
 | 
                    } 
 | 
                } 
 | 
  
 | 
                var opts = { 
 | 
                    trigger : $field.attr('data-bv-trigger'), 
 | 
                    message : $field.attr('data-bv-message'), 
 | 
                    container : $field.attr('data-bv-container'), 
 | 
                    selector : $field.attr('data-bv-selector'), 
 | 
                    threshold : $field.attr('data-bv-threshold'), 
 | 
                    validators : validators 
 | 
                }; 
 | 
  
 | 
                // Check if there is any validators set using HTML attributes 
 | 
                if (!$.isEmptyObject(opts.validators) && !$.isEmptyObject(opts)) { 
 | 
                    $field.attr('data-bv-field', field); 
 | 
                    options.fields[field] = $.extend({}, opts, options.fields[field]); 
 | 
                } 
 | 
            }).end() 
 | 
            // Create hidden inputs to send the submit buttons 
 | 
            .find(this.options.submitButtons).each(function() { 
 | 
                $('<input />').attr('type', 'hidden').attr('name', $(this).attr('name')).val($(this).val()).appendTo(that.$form); 
 | 
            }); 
 | 
  
 | 
            this.options = $.extend(true, this.options, options); 
 | 
            for ( var field in this.options.fields) { 
 | 
                this._initField(field); 
 | 
            } 
 | 
  
 | 
            this.setLiveMode(this.options.live); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Init field 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            field The field name 
 | 
         */ 
 | 
        _initField : function(field) { 
 | 
            if (this.options.fields[field] == null || this.options.fields[field].validators == null) { 
 | 
                return; 
 | 
            } 
 | 
  
 | 
            var fields = this.getFieldElements(field); 
 | 
            // We don't need to validate non-existing fields 
 | 
            if (fields == null) { 
 | 
                delete this.options.fields[field]; 
 | 
                return; 
 | 
            } 
 | 
            for ( var validatorName in this.options.fields[field].validators) { 
 | 
                if (!$.fn.bootstrapValidator.validators[validatorName]) { 
 | 
                    delete this.options.fields[field].validators[validatorName]; 
 | 
                } 
 | 
            } 
 | 
  
 | 
            var that = this, type = fields.attr('type'), event = ('radio' == type || 'checkbox' == type || 'file' == type || 'SELECT' == fields[0].tagName) ? 'change' : that._changeEvent, total = fields.length, updateAll = (total == 1) || ('radio' == type) || ('checkbox' == type); 
 | 
            for (var i = 0; i < total; i++) { 
 | 
                var $field = $(fields[i]), $parent = $field.parents('.form-group'), 
 | 
                // Allow user to indicate where the error messages are shown 
 | 
                $message = this.options.fields[field].container ? $parent.find(this.options.fields[field].container) : this._getMessageContainer($field); 
 | 
  
 | 
                // Set the attribute to indicate the fields which are defined by 
 | 
                // selector 
 | 
                if (!$field.attr('data-bv-field')) { 
 | 
                    $field.attr('data-bv-field', field); 
 | 
                } 
 | 
  
 | 
                // Whenever the user change the field value, mark it as not 
 | 
                // validated yet 
 | 
                $field.on(event + '.update.bv', function() { 
 | 
                    // Reset the flag 
 | 
                    that._submitIfValid = false; 
 | 
                    updateAll ? that.updateStatus(field, that.STATUS_NOT_VALIDATED, null) : that.updateElementStatus($(this), that.STATUS_NOT_VALIDATED, null); 
 | 
                }); 
 | 
  
 | 
                // Create help block elements for showing the error messages 
 | 
                $field.data('bv.messages', $message); 
 | 
                for (validatorName in this.options.fields[field].validators) { 
 | 
                    $field.data('bv.result.' + validatorName, this.STATUS_NOT_VALIDATED); 
 | 
  
 | 
                    if (!updateAll || i == total - 1) { 
 | 
                        $('<small/>').css('display', 'none').attr('data-bv-validator', validatorName).attr('data-bv-validator-for', field).html(this.options.fields[field].validators[validatorName].message || this.options.fields[field].message || this.options.message).addClass('help-block').appendTo($message); 
 | 
                    } 
 | 
                } 
 | 
  
 | 
                // Prepare the feedback icons 
 | 
                // Available from Bootstrap 3.1 
 | 
                // (http://getbootstrap.com/css/#forms-control-validation) 
 | 
                if (this.options.feedbackIcons && this.options.feedbackIcons.validating && this.options.feedbackIcons.invalid && this.options.feedbackIcons.valid && (!updateAll || i == total - 1)) { 
 | 
                    $parent.addClass('has-feedback'); 
 | 
                    var $icon = $('<i/>').css('display', 'none').addClass('form-control-feedback').attr('data-bv-icon-for', field).insertAfter($field); 
 | 
                    // The feedback icon does not render correctly if there is 
 | 
                    // no label 
 | 
                    // https://github.com/twbs/bootstrap/issues/12873 
 | 
                    if ($parent.find('label').length == 0) { 
 | 
                        $icon.css('top', 0); 
 | 
                    } 
 | 
                } 
 | 
            } 
 | 
            if (this.options.fields[field]['enabled'] == null) { 
 | 
                this.options.fields[field]['enabled'] = true; 
 | 
            } 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Get the element to place the error messages 
 | 
         *  
 | 
         * @param {jQuery} 
 | 
         *            $field The field element 
 | 
         * @returns {jQuery} 
 | 
         */ 
 | 
        _getMessageContainer : function($field) { 
 | 
            var $parent = $field.parent(); 
 | 
            if ($parent.hasClass('form-group')) { 
 | 
                return $parent; 
 | 
            } 
 | 
  
 | 
            var cssClasses = $parent.attr('class'); 
 | 
            if (!cssClasses) { 
 | 
                return this._getMessageContainer($parent); 
 | 
            } 
 | 
  
 | 
            cssClasses = cssClasses.split(' '); 
 | 
            var n = cssClasses.length; 
 | 
            for (var i = 0; i < n; i++) { 
 | 
                if (/^col-(xs|sm|md|lg)-\d+$/.test(cssClasses[i]) || /^col-(xs|sm|md|lg)-offset-\d+$/.test(cssClasses[i])) { 
 | 
                    return $parent; 
 | 
                } 
 | 
            } 
 | 
  
 | 
            return this._getMessageContainer($parent); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Called when all validations are completed 
 | 
         */ 
 | 
        _submit : function() { 
 | 
            if (!this.isValid()) { 
 | 
                if ('submitted' == this.options.live) { 
 | 
                    this.setLiveMode('enabled'); 
 | 
                } 
 | 
  
 | 
                // Focus to the first invalid field 
 | 
                if (this.$invalidField) { 
 | 
                    // Activate the tab containing the invalid field if exists 
 | 
                    var $tab = this.$invalidField.parents('.tab-pane'), tabId; 
 | 
                    if ($tab && (tabId = $tab.attr('id'))) { 
 | 
                        $('a[href="#' + tabId + '"][data-toggle="tab"]').trigger('click.bs.tab.data-api'); 
 | 
                    } 
 | 
  
 | 
                    this.$invalidField.focus(); 
 | 
                } 
 | 
  
 | 
                return; 
 | 
            } 
 | 
  
 | 
            // Call the custom submission if enabled 
 | 
            if (this.options.submitHandler && 'function' == typeof this.options.submitHandler) { 
 | 
                // If you want to submit the form inside your submit handler, 
 | 
                // please call defaultSubmit() method 
 | 
                this.options.submitHandler.call(this, this, this.$form, this.$submitButton); 
 | 
            } else { 
 | 
                this.disableSubmitButtons(true).defaultSubmit(); 
 | 
            } 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Check if the field is excluded. Returning true means that the field 
 | 
         * will not be validated 
 | 
         *  
 | 
         * @param {jQuery} 
 | 
         *            $field The field element 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _isExcluded : function($field) { 
 | 
            if (this.options.excluded) { 
 | 
                // Convert to array first 
 | 
                if ('string' == typeof this.options.excluded) { 
 | 
                    this.options.excluded = $.map(this.options.excluded.split(','), function(item) { 
 | 
                        // Trim the spaces 
 | 
                        return $.trim(item); 
 | 
                    }); 
 | 
                } 
 | 
  
 | 
                var length = this.options.excluded.length; 
 | 
                for (var i = 0; i < length; i++) { 
 | 
                    if (('string' == typeof this.options.excluded[i] && $field.is(this.options.excluded[i])) || ('function' == typeof this.options.excluded[i] && this.options.excluded[i].call(this, $field, this) == true)) { 
 | 
                        return true; 
 | 
                    } 
 | 
                } 
 | 
            } 
 | 
  
 | 
            return false; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Check if the number of characters of field value exceed the threshold 
 | 
         * or not 
 | 
         *  
 | 
         * @param {jQuery} 
 | 
         *            $field The field element 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _exceedThreshold : function($field) { 
 | 
            var field = $field.attr('data-bv-field'), threshold = this.options.fields[field].threshold || this.options.threshold; 
 | 
            if (!threshold) { 
 | 
                return true; 
 | 
            } 
 | 
            var type = $field.attr('type'), cannotType = [ 'button', 'checkbox', 'file', 'hidden', 'image', 'radio', 'reset', 'submit' ].indexOf(type) != -1; 
 | 
            return (cannotType || $field.val().length >= threshold); 
 | 
        }, 
 | 
  
 | 
        // --- Public methods --- 
 | 
  
 | 
        /** 
 | 
         * Retrieve the field elements by given name 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            field The field name 
 | 
         * @returns {null|jQuery[]} 
 | 
         */ 
 | 
        getFieldElements : function(field) { 
 | 
            var fields = this.options.fields[field].selector ? $(this.options.fields[field].selector) : this.$form.find('[name="' + field + '"]'); 
 | 
            return (fields.length == 0) ? null : fields; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Set live validating mode 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            mode Live validating mode. Can be 'enabled', 'disabled', 
 | 
         *            'submitted' 
 | 
         * @returns {BootstrapValidator} 
 | 
         */ 
 | 
        setLiveMode : function(mode) { 
 | 
            this.options.live = mode; 
 | 
            if ('submitted' == mode) { 
 | 
                return this; 
 | 
            } 
 | 
  
 | 
            var that = this; 
 | 
            for ( var field in this.options.fields) { 
 | 
                (function(f) { 
 | 
                    var fields = that.getFieldElements(f); 
 | 
                    if (fields) { 
 | 
                        var type = fields.attr('type'), total = fields.length, updateAll = (total == 1) || ('radio' == type) || ('checkbox' == type), trigger = that.options.fields[field].trigger || that.options.trigger || (('radio' == type || 'checkbox' == type || 'file' == type || 'SELECT' == fields[0].tagName) ? 'change' : that._changeEvent), events = $.map(trigger.split(' '), function(item) { 
 | 
                            return item + '.live.bv'; 
 | 
                        }).join(' '); 
 | 
  
 | 
                        for (var i = 0; i < total; i++) { 
 | 
                            ('enabled' == mode) ? $(fields[i]).on(events, function() { 
 | 
                                if (that._exceedThreshold($(this))) { 
 | 
                                    updateAll ? that.validateField(f) : that.validateFieldElement($(this), false); 
 | 
                                } 
 | 
                            }) : $(fields[i]).off(events); 
 | 
                        } 
 | 
                    } 
 | 
                })(field); 
 | 
            } 
 | 
  
 | 
            return this; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Disable/enable submit buttons 
 | 
         *  
 | 
         * @param {Boolean} 
 | 
         *            disabled Can be true or false 
 | 
         * @returns {BootstrapValidator} 
 | 
         */ 
 | 
        disableSubmitButtons : function(disabled) { 
 | 
            if (!disabled) { 
 | 
                this.$form.find(this.options.submitButtons).removeAttr('disabled'); 
 | 
            } else if (this.options.live != 'disabled') { 
 | 
                // Don't disable if the live validating mode is disabled 
 | 
                this.$form.find(this.options.submitButtons).attr('disabled', 'disabled'); 
 | 
            } 
 | 
  
 | 
            return this; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate the form 
 | 
         *  
 | 
         * @returns {BootstrapValidator} 
 | 
         */ 
 | 
        validate : function() { 
 | 
            if (!this.options.fields) { 
 | 
                return this; 
 | 
            } 
 | 
            this.disableSubmitButtons(true); 
 | 
  
 | 
            for ( var field in this.options.fields) { 
 | 
                this.validateField(field); 
 | 
            } 
 | 
  
 | 
            // Check if whether the submit button is clicked 
 | 
            if (this.$submitButton) { 
 | 
                this._submit(); 
 | 
            } 
 | 
  
 | 
            return this; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate given field 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            field The field name 
 | 
         * @returns {BootstrapValidator} 
 | 
         */ 
 | 
        validateField : function(field) { 
 | 
            var fields = this.getFieldElements(field), type = fields.attr('type'), n = (('radio' == type) || ('checkbox' == type)) ? 1 : fields.length; 
 | 
  
 | 
            for (var i = 0; i < n; i++) { 
 | 
                this.validateFieldElement($(fields[i]), (n == 1)); 
 | 
            } 
 | 
  
 | 
            return this; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate field element 
 | 
         *  
 | 
         * @param {jQuery} 
 | 
         *            $field The field element 
 | 
         * @param {Boolean} 
 | 
         *            updateAll If true, update status of all elements which 
 | 
         *            have the same name 
 | 
         * @returns {BootstrapValidator} 
 | 
         */ 
 | 
        validateFieldElement : function($field, updateAll) { 
 | 
            var that = this, field = $field.attr('data-bv-field'), validators = this.options.fields[field].validators, validatorName, validateResult; 
 | 
  
 | 
            if (!this.options.fields[field]['enabled'] || this._isExcluded($field)) { 
 | 
                return this; 
 | 
            } 
 | 
  
 | 
            for (validatorName in validators) { 
 | 
                if ($field.data('bv.dfs.' + validatorName)) { 
 | 
                    $field.data('bv.dfs.' + validatorName).reject(); 
 | 
                } 
 | 
  
 | 
                // Don't validate field if it is already done 
 | 
                var result = $field.data('bv.result.' + validatorName); 
 | 
                if (result == this.STATUS_VALID || result == this.STATUS_INVALID) { 
 | 
                    continue; 
 | 
                } 
 | 
  
 | 
                $field.data('bv.result.' + validatorName, this.STATUS_VALIDATING); 
 | 
                validateResult = $.fn.bootstrapValidator.validators[validatorName].validate(this, $field, validators[validatorName]); 
 | 
  
 | 
                if ('object' == typeof validateResult) { 
 | 
                    updateAll ? this.updateStatus(field, this.STATUS_VALIDATING, validatorName) : this.updateElementStatus($field, this.STATUS_VALIDATING, validatorName); 
 | 
                    $field.data('bv.dfs.' + validatorName, validateResult); 
 | 
  
 | 
                    validateResult.done(function($f, v, isValid) { 
 | 
                        // v is validator name 
 | 
                        $f.removeData('bv.dfs.' + v); 
 | 
                        updateAll ? that.updateStatus($f.attr('data-bv-field'), isValid ? that.STATUS_VALID : that.STATUS_INVALID, v) : that.updateElementStatus($f, isValid ? that.STATUS_VALID : that.STATUS_INVALID, v); 
 | 
  
 | 
                        if (isValid && that._submitIfValid == true) { 
 | 
                            // If a remote validator returns true and the form 
 | 
                            // is ready to submit, then do it 
 | 
                            that._submit(); 
 | 
                        } 
 | 
                    }); 
 | 
                } else if ('boolean' == typeof validateResult) { 
 | 
                    updateAll ? this.updateStatus(field, validateResult ? this.STATUS_VALID : this.STATUS_INVALID, validatorName) : this.updateElementStatus($field, validateResult ? this.STATUS_VALID : this.STATUS_INVALID, validatorName); 
 | 
                } 
 | 
            } 
 | 
  
 | 
            return this; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Update all validating results of elements which have the same field 
 | 
         * name 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            field The field name 
 | 
         * @param {String} 
 | 
         *            status The status. Can be 'NOT_VALIDATED', 'VALIDATING', 
 | 
         *            'INVALID' or 'VALID' 
 | 
         * @param {String} 
 | 
         *            [validatorName] The validator name. If null, the method 
 | 
         *            updates validity result for all validators 
 | 
         * @returns {BootstrapValidator} 
 | 
         */ 
 | 
        updateStatus : function(field, status, validatorName) { 
 | 
            var fields = this.getFieldElements(field), type = fields.attr('type'), n = (('radio' == type) || ('checkbox' == type)) ? 1 : fields.length; 
 | 
  
 | 
            for (var i = 0; i < n; i++) { 
 | 
                this.updateElementStatus($(fields[i]), status, validatorName); 
 | 
            } 
 | 
  
 | 
            return this; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Update validating result of given element 
 | 
         *  
 | 
         * @param {jQuery} 
 | 
         *            $field The field element 
 | 
         * @param {String} 
 | 
         *            status The status. Can be 'NOT_VALIDATED', 'VALIDATING', 
 | 
         *            'INVALID' or 'VALID' 
 | 
         * @param {String} 
 | 
         *            [validatorName] The validator name. If null, the method 
 | 
         *            updates validity result for all validators 
 | 
         * @returns {BootstrapValidator} 
 | 
         */ 
 | 
        updateElementStatus : function($field, status, validatorName) { 
 | 
            var that = this, field = $field.attr('data-bv-field'), $parent = $field.parents('.form-group'), $message = $field.data('bv.messages'), $errors = $message.find('.help-block[data-bv-validator]'), $icon = $parent.find('.form-control-feedback[data-bv-icon-for="' + field + '"]'); 
 | 
  
 | 
            // Update status 
 | 
            if (validatorName) { 
 | 
                $field.data('bv.result.' + validatorName, status); 
 | 
            } else { 
 | 
                for ( var v in this.options.fields[field].validators) { 
 | 
                    $field.data('bv.result.' + v, status); 
 | 
                } 
 | 
            } 
 | 
  
 | 
            // Determine the tab containing the element 
 | 
            var $tabPane = $field.parents('.tab-pane'), tabId, $tab; 
 | 
            if ($tabPane && (tabId = $tabPane.attr('id'))) { 
 | 
                $tab = $('a[href="#' + tabId + '"][data-toggle="tab"]').parent(); 
 | 
            } 
 | 
  
 | 
            // Show/hide error elements and feedback icons 
 | 
            switch (status) { 
 | 
            case this.STATUS_VALIDATING: 
 | 
                this.disableSubmitButtons(true); 
 | 
                $parent.removeClass('has-success').removeClass('has-error'); 
 | 
                // TODO: Show validating message 
 | 
                validatorName ? $errors.filter('.help-block[data-bv-validator="' + validatorName + '"]').hide() : $errors.hide(); 
 | 
                if ($icon) { 
 | 
                    $icon.removeClass(this.options.feedbackIcons.valid).removeClass(this.options.feedbackIcons.invalid).addClass(this.options.feedbackIcons.validating).show(); 
 | 
                } 
 | 
                if ($tab) { 
 | 
                    $tab.removeClass('bv-tab-success').removeClass('bv-tab-error'); 
 | 
                } 
 | 
                break; 
 | 
  
 | 
            case this.STATUS_INVALID: 
 | 
                this.disableSubmitButtons(true); 
 | 
                $parent.removeClass('has-success').addClass('has-error'); 
 | 
                validatorName ? $errors.filter('[data-bv-validator="' + validatorName + '"]').show() : $errors.show(); 
 | 
                if ($icon) { 
 | 
                    $icon.removeClass(this.options.feedbackIcons.valid).removeClass(this.options.feedbackIcons.validating).addClass(this.options.feedbackIcons.invalid).show(); 
 | 
                } 
 | 
                if ($tab) { 
 | 
                    $tab.removeClass('bv-tab-success').addClass('bv-tab-error'); 
 | 
                } 
 | 
                break; 
 | 
  
 | 
            case this.STATUS_VALID: 
 | 
                validatorName ? $errors.filter('[data-bv-validator="' + validatorName + '"]').hide() : $errors.hide(); 
 | 
  
 | 
                // If the field is valid (passes all validators) 
 | 
                var validField = ($errors.filter(function() { 
 | 
                    var display = $(this).css('display'), v = $(this).attr('data-bv-validator'); 
 | 
                    return ('block' == display) || ($field.data('bv.result.' + v) != that.STATUS_VALID); 
 | 
                }).length == 0); 
 | 
                this.disableSubmitButtons(!validField); 
 | 
                if ($icon) { 
 | 
                    $icon.removeClass(this.options.feedbackIcons.invalid).removeClass(this.options.feedbackIcons.validating).removeClass(this.options.feedbackIcons.valid).addClass(validField ? this.options.feedbackIcons.valid : this.options.feedbackIcons.invalid).show(); 
 | 
                } 
 | 
  
 | 
                // Check if all elements in given container are valid 
 | 
                var isValidContainer = function($container) { 
 | 
                    return $container.find('.help-block[data-bv-validator]').filter(function() { 
 | 
                        var display = $(this).css('display'), v = $(this).attr('data-bv-validator'); 
 | 
                        return ('block' == display) || ($field.data('bv.result.' + v) && $field.data('bv.result.' + v) != that.STATUS_VALID); 
 | 
                    }).length == 0; 
 | 
                }; 
 | 
                $parent.removeClass('has-error has-success').addClass(isValidContainer($parent) ? 'has-success' : 'has-error'); 
 | 
                if ($tab) { 
 | 
                    $tab.removeClass('bv-tab-success').removeClass('bv-tab-error').addClass(isValidContainer($tabPane) ? 'bv-tab-success' : 'bv-tab-error'); 
 | 
                } 
 | 
                break; 
 | 
  
 | 
            case this.STATUS_NOT_VALIDATED: 
 | 
            default: 
 | 
                this.disableSubmitButtons(false); 
 | 
                $parent.removeClass('has-success').removeClass('has-error'); 
 | 
                validatorName ? $errors.filter('.help-block[data-bv-validator="' + validatorName + '"]').hide() : $errors.hide(); 
 | 
                if ($icon) { 
 | 
                    $icon.removeClass(this.options.feedbackIcons.valid).removeClass(this.options.feedbackIcons.invalid).removeClass(this.options.feedbackIcons.validating).hide(); 
 | 
                } 
 | 
                if ($tab) { 
 | 
                    $tab.removeClass('bv-tab-success').removeClass('bv-tab-error'); 
 | 
                } 
 | 
                break; 
 | 
            } 
 | 
  
 | 
            return this; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Check the form validity 
 | 
         *  
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        isValid : function() { 
 | 
            var fields, field, $field, type, status, validatorName, n, i; 
 | 
            for (field in this.options.fields) { 
 | 
                if (this.options.fields[field] == null || !this.options.fields[field]['enabled']) { 
 | 
                    continue; 
 | 
                } 
 | 
  
 | 
                fields = this.getFieldElements(field); 
 | 
                type = fields.attr('type'); 
 | 
                n = (('radio' == type) || ('checkbox' == type)) ? 1 : fields.length; 
 | 
  
 | 
                for (i = 0; i < n; i++) { 
 | 
                    $field = $(fields[i]); 
 | 
                    if (this._isExcluded($field)) { 
 | 
                        continue; 
 | 
                    } 
 | 
  
 | 
                    for (validatorName in this.options.fields[field].validators) { 
 | 
                        status = $field.data('bv.result.' + validatorName); 
 | 
                        if (status == this.STATUS_NOT_VALIDATED || status == this.STATUS_VALIDATING) { 
 | 
                            return false; 
 | 
                        } 
 | 
  
 | 
                        if (status == this.STATUS_INVALID) { 
 | 
                            this.$invalidField = $field; 
 | 
                            return false; 
 | 
                        } 
 | 
                    } 
 | 
                } 
 | 
            } 
 | 
  
 | 
            return true; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Submit the form using default submission. It also does not perform 
 | 
         * any validations when submitting the form 
 | 
         *  
 | 
         * It might be used when you want to submit the form right inside the 
 | 
         * submitHandler() 
 | 
         */ 
 | 
        defaultSubmit : function() { 
 | 
            this.$form.off('submit.bv').submit(); 
 | 
        }, 
 | 
  
 | 
        // Useful APIs which aren't used internally 
 | 
  
 | 
        /** 
 | 
         * Reset the form 
 | 
         *  
 | 
         * @param {Boolean} 
 | 
         *            resetFormData Reset current form data 
 | 
         * @returns {BootstrapValidator} 
 | 
         */ 
 | 
        resetForm : function(resetFormData) { 
 | 
            var field, fields, total, type, validator; 
 | 
            for (field in this.options.fields) { 
 | 
                fields = this.getFieldElements(field); 
 | 
                total = fields.length; 
 | 
  
 | 
                for (var i = 0; i < total; i++) { 
 | 
                    for (validator in this.options.fields[field].validators) { 
 | 
                        $(fields[i]).removeData('bv.dfs.' + validator); 
 | 
                    } 
 | 
                } 
 | 
  
 | 
                // Mark field as not validated yet 
 | 
                this.updateStatus(field, this.STATUS_NOT_VALIDATED, null); 
 | 
  
 | 
                if (resetFormData) { 
 | 
                    type = fields.attr('type'); 
 | 
                    ('radio' == type || 'checkbox' == type) ? fields.removeAttr('checked').removeAttr('selected') : fields.val(''); 
 | 
                } 
 | 
            } 
 | 
  
 | 
            this.$invalidField = null; 
 | 
            this.$submitButton = null; 
 | 
  
 | 
            // Enable submit buttons 
 | 
            this.disableSubmitButtons(false); 
 | 
  
 | 
            return this; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Enable/Disable all validators to given field 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            field The field name 
 | 
         * @param {Boolean} 
 | 
         *            enabled Enable/Disable field validators 
 | 
         * @returns {BootstrapValidator} 
 | 
         */ 
 | 
        enableFieldValidators : function(field, enabled) { 
 | 
            this.options.fields[field]['enabled'] = enabled; 
 | 
            this.updateStatus(field, this.STATUS_NOT_VALIDATED, null); 
 | 
  
 | 
            return this; 
 | 
        } 
 | 
    }; 
 | 
  
 | 
    // Plugin definition 
 | 
    $.fn.bootstrapValidator = function(option) { 
 | 
        var params = arguments; 
 | 
        return this.each(function() { 
 | 
            var $this = $(this), data = $this.data('bootstrapValidator'), options = 'object' == typeof option && option; 
 | 
            if (!data) { 
 | 
                data = new BootstrapValidator(this, options); 
 | 
                $this.data('bootstrapValidator', data); 
 | 
            } 
 | 
  
 | 
            // Allow to call plugin method 
 | 
            if ('string' == typeof option) { 
 | 
                data[option].apply(data, Array.prototype.slice.call(params, 1)); 
 | 
            } 
 | 
        }); 
 | 
    }; 
 | 
  
 | 
    // Available validators 
 | 
    $.fn.bootstrapValidator.validators = {}; 
 | 
  
 | 
    $.fn.bootstrapValidator.Constructor = BootstrapValidator; 
 | 
  
 | 
    // Helper methods, which can be used in validator class 
 | 
    $.fn.bootstrapValidator.helpers = { 
 | 
        /** 
 | 
         * Validate a date 
 | 
         *  
 | 
         * @param {Number} 
 | 
         *            year The full year in 4 digits 
 | 
         * @param {Number} 
 | 
         *            month The month number 
 | 
         * @param {Number} 
 | 
         *            day The day number 
 | 
         * @param {Boolean} 
 | 
         *            [notInFuture] If true, the date must not be in the future 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        date : function(year, month, day, notInFuture) { 
 | 
            if (year < 1000 || year > 9999 || month == 0 || month > 12) { 
 | 
                return false; 
 | 
            } 
 | 
            var numDays = [ 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 ]; 
 | 
            // Update the number of days in Feb of leap year 
 | 
            if (year % 400 == 0 || (year % 100 != 0 && year % 4 == 0)) { 
 | 
                numDays[1] = 29; 
 | 
            } 
 | 
  
 | 
            // Check the day 
 | 
            if (day < 0 || day > numDays[month - 1]) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            if (notInFuture === true) { 
 | 
                var currentDate = new Date(), currentYear = currentDate.getFullYear(), currentMonth = currentDate.getMonth(), currentDay = currentDate.getDate(); 
 | 
                return (year < currentYear || (year == currentYear && month - 1 < currentMonth) || (year == currentYear && month - 1 == currentMonth && day < currentDay)); 
 | 
            } 
 | 
  
 | 
            return true; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Implement Luhn validation algorithm 
 | 
         * ((http://en.wikipedia.org/wiki/Luhn)) Credit to 
 | 
         * https://gist.github.com/ShirtlessKirk/2134376 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        luhn : function(value) { 
 | 
            var length = value.length, mul = 0, prodArr = [ [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 ], [ 0, 2, 4, 6, 8, 1, 3, 5, 7, 9 ] ], sum = 0; 
 | 
  
 | 
            while (length--) { 
 | 
                sum += prodArr[mul][parseInt(value.charAt(length), 10)]; 
 | 
                mul ^= 1; 
 | 
            } 
 | 
  
 | 
            return (sum % 10 === 0 && sum > 0); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Implement modulus 11, 10 (ISO 7064) algorithm 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        mod_11_10 : function(value) { 
 | 
            var check = 5, length = value.length; 
 | 
            for (var i = 0; i < length; i++) { 
 | 
                check = (((check || 10) * 2) % 11 + parseInt(value.charAt(i), 10)) % 10; 
 | 
            } 
 | 
            return (check == 1); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Implements Mod 37, 36 (ISO 7064) algorithm Usages: 
 | 
         * mod_37_36('A12425GABC1234002M') mod_37_36('002006673085', 
 | 
         * '0123456789') 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value 
 | 
         * @param {String} 
 | 
         *            alphabet 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        mod_37_36 : function(value, alphabet) { 
 | 
            alphabet = alphabet || '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'; 
 | 
            var modulus = alphabet.length, length = value.length, check = Math.floor(modulus / 2); 
 | 
            for (var i = 0; i < length; i++) { 
 | 
                check = (((check || modulus) * 2) % (modulus + 1) + alphabet.indexOf(value.charAt(i))) % modulus; 
 | 
            } 
 | 
            return (check == 1); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.base64 = { 
 | 
        /** 
 | 
         * Return true if the input value is a base 64 encoded string. 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=|[A-Za-z0-9+/]{4})$/.test(value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.between = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            min : 'min', 
 | 
            max : 'max', 
 | 
            inclusive : 'inclusive' 
 | 
        }, 
 | 
  
 | 
        enableByHtml5 : function($field) { 
 | 
            if ('range' == $field.attr('type')) { 
 | 
                return { 
 | 
                    min : $field.attr('min'), 
 | 
                    max : $field.attr('max') 
 | 
                }; 
 | 
            } 
 | 
  
 | 
            return false; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if the input value is between (strictly or not) two given 
 | 
         * numbers 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - min - max - 
 | 
         *            inclusive [optional]: Can be true or false. Default is 
 | 
         *            true - message: The invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            value = parseFloat(value); 
 | 
            return (options.inclusive === true) ? (value > options.min && value < options.max) : (value >= options.min && value <= options.max); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.callback = { 
 | 
        /** 
 | 
         * Return result from the callback method 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - callback: The 
 | 
         *            callback method that passes 2 parameters: callback: 
 | 
         *            function(fieldValue, validator) { // fieldValue is the 
 | 
         *            value of field // validator is instance of 
 | 
         *            BootstrapValidator } - message: The invalid message 
 | 
         * @returns {Boolean|Deferred} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (options.callback && 'function' == typeof options.callback) { 
 | 
                var dfd = new $.Deferred(); 
 | 
                dfd.resolve($field, 'callback', options.callback.call(this, value, validator)); 
 | 
                return dfd; 
 | 
            } 
 | 
            return true; 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.choice = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            min : 'min', 
 | 
            max : 'max' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Check if the number of checked boxes are less or more than a given 
 | 
         * number 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consists of following keys: - min - max At least 
 | 
         *            one of two keys is required - message: The invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var numChoices = $field.is('select') ? validator.getFieldElements($field.attr('data-bv-field')).find('option').filter(':selected').length : validator.getFieldElements($field.attr('data-bv-field')).filter(':checked').length; 
 | 
            if ((options.min && numChoices < options.min) || (options.max && numChoices > options.max)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            return true; 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.creditCard = { 
 | 
        /** 
 | 
         * Return true if the input value is valid credit card number Based on 
 | 
         * https://gist.github.com/DiegoSalazar/4075533 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following key: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            // Accept only digits, dashes or spaces 
 | 
            if (/[^0-9-\s]+/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.replace(/\D/g, ''); 
 | 
  
 | 
            if (!$.fn.bootstrapValidator.helpers.luhn(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Validate the card number based on prefix (IIN ranges) and length 
 | 
            var cards = { 
 | 
                AMERICAN_EXPRESS : { 
 | 
                    length : [ 15 ], 
 | 
                    prefix : [ '34', '37' ] 
 | 
                }, 
 | 
                DINERS_CLUB : { 
 | 
                    length : [ 14 ], 
 | 
                    prefix : [ '300', '301', '302', '303', '304', '305', '36' ] 
 | 
                }, 
 | 
                DINERS_CLUB_US : { 
 | 
                    length : [ 16 ], 
 | 
                    prefix : [ '54', '55' ] 
 | 
                }, 
 | 
                DISCOVER : { 
 | 
                    length : [ 16 ], 
 | 
                    prefix : [ '6011', '622126', '622127', '622128', '622129', '62213', '62214', '62215', '62216', '62217', '62218', '62219', '6222', '6223', '6224', '6225', '6226', '6227', '6228', '62290', '62291', '622920', '622921', '622922', '622923', '622924', '622925', '644', '645', '646', '647', '648', '649', '65' ] 
 | 
                }, 
 | 
                JCB : { 
 | 
                    length : [ 16 ], 
 | 
                    prefix : [ '3528', '3529', '353', '354', '355', '356', '357', '358' ] 
 | 
                }, 
 | 
                LASER : { 
 | 
                    length : [ 16, 17, 18, 19 ], 
 | 
                    prefix : [ '6304', '6706', '6771', '6709' ] 
 | 
                }, 
 | 
                MAESTRO : { 
 | 
                    length : [ 12, 13, 14, 15, 16, 17, 18, 19 ], 
 | 
                    prefix : [ '5018', '5020', '5038', '6304', '6759', '6761', '6762', '6763', '6764', '6765', '6766' ] 
 | 
                }, 
 | 
                MASTERCARD : { 
 | 
                    length : [ 16 ], 
 | 
                    prefix : [ '51', '52', '53', '54', '55' ] 
 | 
                }, 
 | 
                SOLO : { 
 | 
                    length : [ 16, 18, 19 ], 
 | 
                    prefix : [ '6334', '6767' ] 
 | 
                }, 
 | 
                UNIONPAY : { 
 | 
                    length : [ 16, 17, 18, 19 ], 
 | 
                    prefix : [ '622126', '622127', '622128', '622129', '62213', '62214', '62215', '62216', '62217', '62218', '62219', '6222', '6223', '6224', '6225', '6226', '6227', '6228', '62290', '62291', '622920', '622921', '622922', '622923', '622924', '622925' ] 
 | 
                }, 
 | 
                VISA : { 
 | 
                    length : [ 16 ], 
 | 
                    prefix : [ '4' ] 
 | 
                } 
 | 
            }; 
 | 
  
 | 
            var type, i; 
 | 
            for (type in cards) { 
 | 
                for (i in cards[type]['prefix']) { 
 | 
                    if (value.substr(0, cards[type]['prefix'][i].length) == cards[type]['prefix'][i] // Check 
 | 
                                                                                                        // the 
 | 
                                                                                                        // prefix 
 | 
                            && cards[type]['length'].indexOf(value.length) != -1) // and 
 | 
                                                                                    // length 
 | 
                    { 
 | 
                        return true; 
 | 
                    } 
 | 
                } 
 | 
            } 
 | 
  
 | 
            return false; 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.cusip = { 
 | 
        /** 
 | 
         * Validate a CUSIP Examples: - Valid: 037833100, 931142103, 14149YAR8, 
 | 
         * 126650BG6 - Invalid: 31430F200, 022615AC2 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/CUSIP 
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            value = value.toUpperCase(); 
 | 
            if (!/^[0-9A-Z]{9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            var converted = $.map(value.split(''), function(item) { 
 | 
                var code = item.charCodeAt(0); 
 | 
                return (code >= 'A'.charCodeAt(0) && code <= 'Z'.charCodeAt(0)) 
 | 
                // Replace A, B, C, ..., Z with 10, 11, ..., 35 
 | 
                ? (code - 'A'.charCodeAt(0) + 10) : item; 
 | 
            }), length = converted.length, sum = 0; 
 | 
            for (var i = 0; i < length - 1; i++) { 
 | 
                var num = parseInt(converted[i]); 
 | 
                if (i % 2 != 0) { 
 | 
                    num *= 2; 
 | 
                } 
 | 
                if (num > 9) { 
 | 
                    num -= 9; 
 | 
                } 
 | 
                sum += num; 
 | 
            } 
 | 
  
 | 
            sum = (10 - (sum % 10)) % 10; 
 | 
            return sum == converted[length - 1]; 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.cvv = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            ccfield : 'creditCardField' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if the input value is a valid CVV number. 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - 
 | 
         *            creditCardField: The credit card number field. It can be 
 | 
         *            null - message: The invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            if (!/^[0-9]{3,4}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            if (!options.creditCardField) { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            // Get the credit card number 
 | 
            var creditCard = validator.getFieldElements(options.creditCardField).val(); 
 | 
            if (creditCard == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            creditCard = creditCard.replace(/\D/g, ''); 
 | 
  
 | 
            // Supported credit card types 
 | 
            var cards = { 
 | 
                AMERICAN_EXPRESS : { 
 | 
                    length : [ 15 ], 
 | 
                    prefix : [ '34', '37' ] 
 | 
                }, 
 | 
                DINERS_CLUB : { 
 | 
                    length : [ 14 ], 
 | 
                    prefix : [ '300', '301', '302', '303', '304', '305', '36' ] 
 | 
                }, 
 | 
                DINERS_CLUB_US : { 
 | 
                    length : [ 16 ], 
 | 
                    prefix : [ '54', '55' ] 
 | 
                }, 
 | 
                DISCOVER : { 
 | 
                    length : [ 16 ], 
 | 
                    prefix : [ '6011', '622126', '622127', '622128', '622129', '62213', '62214', '62215', '62216', '62217', '62218', '62219', '6222', '6223', '6224', '6225', '6226', '6227', '6228', '62290', '62291', '622920', '622921', '622922', '622923', '622924', '622925', '644', '645', '646', '647', '648', '649', '65' ] 
 | 
                }, 
 | 
                JCB : { 
 | 
                    length : [ 16 ], 
 | 
                    prefix : [ '3528', '3529', '353', '354', '355', '356', '357', '358' ] 
 | 
                }, 
 | 
                LASER : { 
 | 
                    length : [ 16, 17, 18, 19 ], 
 | 
                    prefix : [ '6304', '6706', '6771', '6709' ] 
 | 
                }, 
 | 
                MAESTRO : { 
 | 
                    length : [ 12, 13, 14, 15, 16, 17, 18, 19 ], 
 | 
                    prefix : [ '5018', '5020', '5038', '6304', '6759', '6761', '6762', '6763', '6764', '6765', '6766' ] 
 | 
                }, 
 | 
                MASTERCARD : { 
 | 
                    length : [ 16 ], 
 | 
                    prefix : [ '51', '52', '53', '54', '55' ] 
 | 
                }, 
 | 
                SOLO : { 
 | 
                    length : [ 16, 18, 19 ], 
 | 
                    prefix : [ '6334', '6767' ] 
 | 
                }, 
 | 
                UNIONPAY : { 
 | 
                    length : [ 16, 17, 18, 19 ], 
 | 
                    prefix : [ '622126', '622127', '622128', '622129', '62213', '62214', '62215', '62216', '62217', '62218', '62219', '6222', '6223', '6224', '6225', '6226', '6227', '6228', '62290', '62291', '622920', '622921', '622922', '622923', '622924', '622925' ] 
 | 
                }, 
 | 
                VISA : { 
 | 
                    length : [ 16 ], 
 | 
                    prefix : [ '4' ] 
 | 
                } 
 | 
            }; 
 | 
            var type, i, creditCardType = null; 
 | 
            for (type in cards) { 
 | 
                for (i in cards[type]['prefix']) { 
 | 
                    if (creditCard.substr(0, cards[type]['prefix'][i].length) == cards[type]['prefix'][i] // Check 
 | 
                                                                                                            // the 
 | 
                                                                                                            // prefix 
 | 
                            && cards[type]['length'].indexOf(creditCard.length) != -1) // and 
 | 
                                                                                        // length 
 | 
                    { 
 | 
                        creditCardType = type; 
 | 
                        break; 
 | 
                    } 
 | 
                } 
 | 
            } 
 | 
  
 | 
            return (creditCardType == null) ? false : (('AMERICAN_EXPRESS' == creditCardType) ? (value.length == 4) : (value.length == 3)); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.date = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            format : 'format' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if the input value is valid date 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message - format: The date format. Default is 
 | 
         *            MM/DD/YYYY The format can be: 
 | 
         *  
 | 
         * i) date: Consist of DD, MM, YYYY parts which are separated by / ii) 
 | 
         * date and time: The time can consist of h, m, s parts which are 
 | 
         * separated by : ii) date, time and A (indicating AM or PM) 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            options.format = options.format || 'MM/DD/YYYY'; 
 | 
  
 | 
            var formats = options.format.split(' '), dateFormat = formats[0], timeFormat = (formats.length > 1) ? formats[1] : null, amOrPm = (formats.length > 2) ? formats[2] : null, sections = value.split(' '), date = sections[0], time = (sections.length > 1) ? sections[1] : null; 
 | 
  
 | 
            if (formats.length != sections.length) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Determine the separator 
 | 
            var separator = (date.indexOf('/') != -1) ? '/' : ((date.indexOf('-') != -1) ? '-' : null); 
 | 
            if (separator == null) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Determine the date 
 | 
            date = date.split(separator); 
 | 
            dateFormat = dateFormat.split(separator); 
 | 
            var year = date[dateFormat.indexOf('YYYY')], month = date[dateFormat.indexOf('MM')], day = date[dateFormat.indexOf('DD')]; 
 | 
  
 | 
            // Determine the time 
 | 
            var minutes = null, hours = null, seconds = null; 
 | 
            if (timeFormat) { 
 | 
                timeFormat = timeFormat.split(':'), time = time.split(':'); 
 | 
  
 | 
                if (timeFormat.length != time.length) { 
 | 
                    return false; 
 | 
                } 
 | 
  
 | 
                hours = time.length > 0 ? time[0] : null; 
 | 
                minutes = time.length > 1 ? time[1] : null; 
 | 
                seconds = time.length > 2 ? time[2] : null; 
 | 
  
 | 
                // Validate seconds 
 | 
                if (seconds) { 
 | 
                    seconds = parseInt(seconds, 10); 
 | 
                    if (seconds < 0 || seconds > 60) { 
 | 
                        return false; 
 | 
                    } 
 | 
                } 
 | 
  
 | 
                // Validate hours 
 | 
                if (hours) { 
 | 
                    hours = parseInt(hours, 10); 
 | 
                    if (hours < 0 || hours >= 24 || (amOrPm && hours > 12)) { 
 | 
                        return false; 
 | 
                    } 
 | 
                } 
 | 
  
 | 
                // Validate minutes 
 | 
                if (minutes) { 
 | 
                    minutes = parseInt(minutes, 10); 
 | 
                    if (minutes < 0 || minutes > 59) { 
 | 
                        return false; 
 | 
                    } 
 | 
                } 
 | 
            } 
 | 
  
 | 
            // Validate day, month, and year 
 | 
            day = parseInt(day, 10); 
 | 
            month = parseInt(month, 10); 
 | 
            year = parseInt(year, 10); 
 | 
  
 | 
            return $.fn.bootstrapValidator.helpers.date(year, month, day); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.different = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            field : 'field' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if the input value is different with given field's value 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consists of the following key: - field: The name 
 | 
         *            of field that will be used to compare with current one - 
 | 
         *            message: The invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            var compareWith = validator.getFieldElements(options.field); 
 | 
            if (compareWith == null) { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            if (value != compareWith.val()) { 
 | 
                validator.updateStatus(options.field, validator.STATUS_VALID, 'different'); 
 | 
                return true; 
 | 
            } else { 
 | 
                return false; 
 | 
            } 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.digits = { 
 | 
        /** 
 | 
         * Return true if the input value contains digits only 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator Validate plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            return /^\d+$/.test(value); 
 | 
        } 
 | 
    } 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.ean = { 
 | 
        /** 
 | 
         * Validate EAN (International Article Number) Examples: - Valid: 
 | 
         * 73513537, 9780471117094, 4006381333931 - Invalid: 73513536 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/European_Article_Number 
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            if (!/^(\d{8}|\d{12}|\d{13})$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            var length = value.length, sum = 0, weight = (length == 8) ? [ 3, 1 ] : [ 1, 3 ]; 
 | 
            for (var i = 0; i < length - 1; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i % 2]; 
 | 
            } 
 | 
            sum = 10 - sum % 10; 
 | 
            return (sum == value.charAt(length - 1)); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.emailAddress = { 
 | 
        enableByHtml5 : function($field) { 
 | 
            return ('email' == $field.attr('type')); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if and only if the input value is a valid email address 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator Validate plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            // Email address regular expression 
 | 
            // http://stackoverflow.com/questions/46155/validate-email-address-in-javascript 
 | 
            var emailRegExp = /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/; 
 | 
            return emailRegExp.test(value); 
 | 
        } 
 | 
    } 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.file = { 
 | 
        html5Attributes : { 
 | 
            extension : 'extension', 
 | 
            maxsize : 'maxSize', 
 | 
            message : 'message', 
 | 
            type : 'type' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate upload file. Use HTML 5 API if the browser supports 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - extension: 
 | 
         *            The allowed extensions, separated by a comma - maxSize: 
 | 
         *            The maximum size in bytes - message: The invalid message - 
 | 
         *            type: The allowed MIME type, separated by a comma 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            var ext, extensions = options.extension ? options.extension.split(',') : null, types = options.type ? options.type.split(',') : null, html5 = (window.File && window.FileList && window.FileReader); 
 | 
  
 | 
            if (html5) { 
 | 
                // Get FileList instance 
 | 
                var files = $field.get(0).files, total = files.length; 
 | 
                for (var i = 0; i < total; i++) { 
 | 
                    // Check file size 
 | 
                    if (options.maxSize && files[i].size > parseInt(options.maxSize)) { 
 | 
                        return false; 
 | 
                    } 
 | 
  
 | 
                    // Check file extension 
 | 
                    ext = files[i].name.substr(files[i].name.lastIndexOf('.') + 1); 
 | 
                    if (extensions && extensions.indexOf(ext) == -1) { 
 | 
                        return false; 
 | 
                    } 
 | 
  
 | 
                    // Check file type 
 | 
                    if (types && types.indexOf(files[i].type) == -1) { 
 | 
                        return false; 
 | 
                    } 
 | 
                } 
 | 
            } else { 
 | 
                // Check file extension 
 | 
                ext = value.substr(value.lastIndexOf('.') + 1); 
 | 
                if (extensions && extensions.indexOf(ext) == -1) { 
 | 
                    return false; 
 | 
                } 
 | 
            } 
 | 
  
 | 
            return true; 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.greaterThan = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            value : 'value', 
 | 
            inclusive : 'inclusive' 
 | 
        }, 
 | 
  
 | 
        enableByHtml5 : function($field) { 
 | 
            var min = $field.attr('min'); 
 | 
            if (min) { 
 | 
                return { 
 | 
                    value : min 
 | 
                }; 
 | 
            } 
 | 
  
 | 
            return false; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if the input value is greater than or equals to given 
 | 
         * number 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator Validate plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - value: The 
 | 
         *            number used to compare to - inclusive [optional]: Can be 
 | 
         *            true or false. Default is true - message: The invalid 
 | 
         *            message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
            value = parseFloat(value); 
 | 
            return (options.inclusive === true) ? (value > options.value) : (value >= options.value); 
 | 
        } 
 | 
    } 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.grid = { 
 | 
        /** 
 | 
         * Validate GRId (Global Release Identifier) Examples: - Valid: 
 | 
         * A12425GABC1234002M, A1-2425G-ABC1234002-M, A1 2425G ABC1234002 M, 
 | 
         * Grid:A1-2425G-ABC1234002-M - Invalid: A1-2425G-ABC1234002-Q 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/Global_Release_Identifier 
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            value = value.toUpperCase(); 
 | 
            if (!/^[GRID:]*([0-9A-Z]{2})[-\s]*([0-9A-Z]{5})[-\s]*([0-9A-Z]{10})[-\s]*([0-9A-Z]{1})$/g.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.replace(/\s/g, '').replace(/-/g, ''); 
 | 
            if ('GRID:' == value.substr(0, 5)) { 
 | 
                value = value.substr(5); 
 | 
            } 
 | 
            return $.fn.bootstrapValidator.helpers.mod_37_36(value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.hex = { 
 | 
        /** 
 | 
         * Return true if and only if the input value is a valid hexadecimal 
 | 
         * number 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consist of key: - message: The invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            return /^[0-9a-fA-F]+$/.test(value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.hexColor = { 
 | 
        enableByHtml5 : function($field) { 
 | 
            return ('color' == $field.attr('type')); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if the input value is a valid hex color 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
            return /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.iban = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            country : 'country' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate an International Bank Account Number (IBAN) To test it, take 
 | 
         * the sample IBAN from 
 | 
         * http://www.nordea.com/Our+services/International+products+and+services/Cash+Management/IBAN+countries/908462.html 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message - country: The ISO 3166-1 country code 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            // See 
 | 
            // http://www.swift.com/dsp/resources/documents/IBAN_Registry.pdf 
 | 
            // http://en.wikipedia.org/wiki/International_Bank_Account_Number#IBAN_formats_by_country 
 | 
            var ibanRegex = { 
 | 
                'AD' : 'AD[0-9]{2}[0-9]{4}[0-9]{4}[A-Z0-9]{12}', // Andorra 
 | 
                'AE' : 'AE[0-9]{2}[0-9]{3}[0-9]{16}', // United Arab Emirates 
 | 
                'AL' : 'AL[0-9]{2}[0-9]{8}[A-Z0-9]{16}', // Albania 
 | 
                'AO' : 'AO[0-9]{2}[0-9]{21}', // Angola 
 | 
                'AT' : 'AT[0-9]{2}[0-9]{5}[0-9]{11}', // Austria 
 | 
                'AZ' : 'AZ[0-9]{2}[A-Z]{4}[A-Z0-9]{20}', // Azerbaijan 
 | 
                'BA' : 'BA[0-9]{2}[0-9]{3}[0-9]{3}[0-9]{8}[0-9]{2}', // Bosnia 
 | 
                                                                        // and 
 | 
                                                                        // Herzegovina 
 | 
                'BE' : 'BE[0-9]{2}[0-9]{3}[0-9]{7}[0-9]{2}', // Belgium 
 | 
                'BF' : 'BF[0-9]{2}[0-9]{23}', // Burkina Faso 
 | 
                'BG' : 'BG[0-9]{2}[A-Z]{4}[0-9]{4}[0-9]{2}[A-Z0-9]{8}', // Bulgaria 
 | 
                'BH' : 'BH[0-9]{2}[A-Z]{4}[A-Z0-9]{14}', // Bahrain 
 | 
                'BI' : 'BI[0-9]{2}[0-9]{12}', // Burundi 
 | 
                'BJ' : 'BJ[0-9]{2}[A-Z]{1}[0-9]{23}', // Benin 
 | 
                'BR' : 'BR[0-9]{2}[0-9]{8}[0-9]{5}[0-9]{10}[A-Z][A-Z0-9]', // Brazil 
 | 
                'CH' : 'CH[0-9]{2}[0-9]{5}[A-Z0-9]{12}', // Switzerland 
 | 
                'CI' : 'CI[0-9]{2}[A-Z]{1}[0-9]{23}', // Ivory Coast 
 | 
                'CM' : 'CM[0-9]{2}[0-9]{23}', // Cameroon 
 | 
                'CR' : 'CR[0-9]{2}[0-9]{3}[0-9]{14}', // Costa Rica 
 | 
                'CV' : 'CV[0-9]{2}[0-9]{21}', // Cape Verde 
 | 
                'CY' : 'CY[0-9]{2}[0-9]{3}[0-9]{5}[A-Z0-9]{16}', // Cyprus 
 | 
                'CZ' : 'CZ[0-9]{2}[0-9]{20}', // Czech Republic 
 | 
                'DE' : 'DE[0-9]{2}[0-9]{8}[0-9]{10}', // Germany 
 | 
                'DK' : 'DK[0-9]{2}[0-9]{14}', // Denmark 
 | 
                'DO' : 'DO[0-9]{2}[A-Z0-9]{4}[0-9]{20}', // Dominican 
 | 
                                                            // Republic 
 | 
                'DZ' : 'DZ[0-9]{2}[0-9]{20}', // Algeria 
 | 
                'EE' : 'EE[0-9]{2}[0-9]{2}[0-9]{2}[0-9]{11}[0-9]{1}', // Estonia 
 | 
                'ES' : 'ES[0-9]{2}[0-9]{4}[0-9]{4}[0-9]{1}[0-9]{1}[0-9]{10}', // Spain 
 | 
                'FI' : 'FI[0-9]{2}[0-9]{6}[0-9]{7}[0-9]{1}', // Finland 
 | 
                'FO' : 'FO[0-9]{2}[0-9]{4}[0-9]{9}[0-9]{1}', // Faroe Islands 
 | 
                'FR' : 'FR[0-9]{2}[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}', // France 
 | 
                'GB' : 'GB[0-9]{2}[A-Z]{4}[0-9]{6}[0-9]{8}', // United 
 | 
                                                                // Kingdom 
 | 
                'GE' : 'GE[0-9]{2}[A-Z]{2}[0-9]{16}', // Georgia 
 | 
                'GI' : 'GI[0-9]{2}[A-Z]{4}[A-Z0-9]{15}', // Gibraltar 
 | 
                'GL' : 'GL[0-9]{2}[0-9]{4}[0-9]{9}[0-9]{1}', // Greenland[ 
 | 
                'GR' : 'GR[0-9]{2}[0-9]{3}[0-9]{4}[A-Z0-9]{16}', // Greece 
 | 
                'GT' : 'GT[0-9]{2}[A-Z0-9]{4}[A-Z0-9]{20}', // Guatemala 
 | 
                'HR' : 'HR[0-9]{2}[0-9]{7}[0-9]{10}', // Croatia 
 | 
                'HU' : 'HU[0-9]{2}[0-9]{3}[0-9]{4}[0-9]{1}[0-9]{15}[0-9]{1}', // Hungary 
 | 
                'IE' : 'IE[0-9]{2}[A-Z]{4}[0-9]{6}[0-9]{8}', // Ireland 
 | 
                'IL' : 'IL[0-9]{2}[0-9]{3}[0-9]{3}[0-9]{13}', // Israel 
 | 
                'IR' : 'IR[0-9]{2}[0-9]{22}', // Iran 
 | 
                'IS' : 'IS[0-9]{2}[0-9]{4}[0-9]{2}[0-9]{6}[0-9]{10}', // Iceland 
 | 
                'IT' : 'IT[0-9]{2}[A-Z]{1}[0-9]{5}[0-9]{5}[A-Z0-9]{12}', // Italy 
 | 
                'JO' : 'JO[0-9]{2}[A-Z]{4}[0-9]{4}[0]{8}[A-Z0-9]{10}', // Jordan 
 | 
                'KW' : 'KW[0-9]{2}[A-Z]{4}[0-9]{22}', // Kuwait 
 | 
                'KZ' : 'KZ[0-9]{2}[0-9]{3}[A-Z0-9]{13}', // Kazakhstan 
 | 
                'LB' : 'LB[0-9]{2}[0-9]{4}[A-Z0-9]{20}', // Lebanon 
 | 
                'LI' : 'LI[0-9]{2}[0-9]{5}[A-Z0-9]{12}', // Liechtenstein 
 | 
                'LT' : 'LT[0-9]{2}[0-9]{5}[0-9]{11}', // Lithuania 
 | 
                'LU' : 'LU[0-9]{2}[0-9]{3}[A-Z0-9]{13}', // Luxembourg 
 | 
                'LV' : 'LV[0-9]{2}[A-Z]{4}[A-Z0-9]{13}', // Latvia 
 | 
                'MC' : 'MC[0-9]{2}[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}', // Monaco 
 | 
                'MD' : 'MD[0-9]{2}[A-Z0-9]{20}', // Moldova 
 | 
                'ME' : 'ME[0-9]{2}[0-9]{3}[0-9]{13}[0-9]{2}', // Montenegro 
 | 
                'MG' : 'MG[0-9]{2}[0-9]{23}', // Madagascar 
 | 
                'MK' : 'MK[0-9]{2}[0-9]{3}[A-Z0-9]{10}[0-9]{2}', // Macedonia 
 | 
                'ML' : 'ML[0-9]{2}[A-Z]{1}[0-9]{23}', // Mali 
 | 
                'MR' : 'MR13[0-9]{5}[0-9]{5}[0-9]{11}[0-9]{2}', // Mauritania 
 | 
                'MT' : 'MT[0-9]{2}[A-Z]{4}[0-9]{5}[A-Z0-9]{18}', // Malta 
 | 
                'MU' : 'MU[0-9]{2}[A-Z]{4}[0-9]{2}[0-9]{2}[0-9]{12}[0-9]{3}[A-Z]{3}',// Mauritius 
 | 
                'MZ' : 'MZ[0-9]{2}[0-9]{21}', // Mozambique 
 | 
                'NL' : 'NL[0-9]{2}[A-Z]{4}[0-9]{10}', // Netherlands 
 | 
                'NO' : 'NO[0-9]{2}[0-9]{4}[0-9]{6}[0-9]{1}', // Norway 
 | 
                'PK' : 'PK[0-9]{2}[A-Z]{4}[A-Z0-9]{16}', // Pakistan 
 | 
                'PL' : 'PL[0-9]{2}[0-9]{8}[0-9]{16}', // Poland 
 | 
                'PS' : 'PS[0-9]{2}[A-Z]{4}[A-Z0-9]{21}', // Palestinian 
 | 
                'PT' : 'PT[0-9]{2}[0-9]{4}[0-9]{4}[0-9]{11}[0-9]{2}', // Portugal 
 | 
                'QA' : 'QA[0-9]{2}[A-Z]{4}[A-Z0-9]{21}', // Qatar 
 | 
                'RO' : 'RO[0-9]{2}[A-Z]{4}[A-Z0-9]{16}', // Romania 
 | 
                'RS' : 'RS[0-9]{2}[0-9]{3}[0-9]{13}[0-9]{2}', // Serbia 
 | 
                'SA' : 'SA[0-9]{2}[0-9]{2}[A-Z0-9]{18}', // Saudi Arabia 
 | 
                'SE' : 'SE[0-9]{2}[0-9]{3}[0-9]{16}[0-9]{1}', // Sweden 
 | 
                'SI' : 'SI[0-9]{2}[0-9]{5}[0-9]{8}[0-9]{2}', // Slovenia 
 | 
                'SK' : 'SK[0-9]{2}[0-9]{4}[0-9]{6}[0-9]{10}', // Slovakia 
 | 
                'SM' : 'SM[0-9]{2}[A-Z]{1}[0-9]{5}[0-9]{5}[A-Z0-9]{12}', // San 
 | 
                                                                            // Marino 
 | 
                'SN' : 'SN[0-9]{2}[A-Z]{1}[0-9]{23}', // Senegal 
 | 
                'TN' : 'TN59[0-9]{2}[0-9]{3}[0-9]{13}[0-9]{2}', // Tunisia 
 | 
                'TR' : 'TR[0-9]{2}[0-9]{5}[A-Z0-9]{1}[A-Z0-9]{16}', // Turkey 
 | 
                'VG' : 'VG[0-9]{2}[A-Z]{4}[0-9]{16}' // Virgin Islands, 
 | 
                                                        // British 
 | 
            }; 
 | 
            value = value.replace(/[^a-zA-Z0-9]/g, '').toUpperCase(); 
 | 
            var country = options.country || value.substr(0, 2); 
 | 
            if (!ibanRegex[country]) { 
 | 
                return false; 
 | 
            } 
 | 
            if (!(new RegExp('^' + ibanRegex[country] + '$')).test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(4) + value.substr(0, 4); 
 | 
            value = $.map(value.split(''), function(n) { 
 | 
                var code = n.charCodeAt(0); 
 | 
                return (code >= 'A'.charCodeAt(0) && code <= 'Z'.charCodeAt(0)) 
 | 
                // Replace A, B, C, ..., Z with 10, 11, ..., 35 
 | 
                ? (code - 'A'.charCodeAt(0) + 10) : n; 
 | 
            }); 
 | 
            value = value.join(''); 
 | 
  
 | 
            var temp = parseInt(value.substr(0, 1), 10), length = value.length; 
 | 
            for (var i = 1; i < length; ++i) { 
 | 
                temp = (temp * 10 + parseInt(value.substr(i, 1), 10)) % 97; 
 | 
            } 
 | 
            return (temp == 1); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.id = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            country : 'country' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate identification number in different countries 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/National_identification_number 
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consist of key: - message: The invalid message - 
 | 
         *            country: The ISO 3166-1 country code 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            var country = options.country || value.substr(0, 2), method = [ '_', country.toLowerCase() ].join(''); 
 | 
            if (this[method] && 'function' == typeof this[method]) { 
 | 
                return this[method](value); 
 | 
            } 
 | 
  
 | 
            return true; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Unique Master Citizen Number which uses in - Bosnia and 
 | 
         * Herzegovina (country code: BA) - Macedonia (MK) - Montenegro (ME) - 
 | 
         * Serbia (RS) - Slovenia (SI) 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/Unique_Master_Citizen_Number 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @param {String} 
 | 
         *            countryCode The ISO country code, can be BA, MK, ME, RS, 
 | 
         *            SI 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _validateJMBG : function(value, countryCode) { 
 | 
            if (!/^\d{13}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            var day = parseInt(value.substr(0, 2), 10), month = parseInt(value.substr(2, 2), 10), year = parseInt(value.substr(4, 3), 10), rr = parseInt(value.substr(7, 2), 10), k = parseInt(value.substr(12, 1), 10); 
 | 
  
 | 
            // Validate date of birth 
 | 
            // FIXME: Validate the year of birth 
 | 
            if (day > 31 || month > 12) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Validate checksum 
 | 
            var sum = 0; 
 | 
            for (var i = 0; i < 6; i++) { 
 | 
                sum += (7 - i) * (parseInt(value.charAt(i)) + parseInt(value.charAt(i + 6))); 
 | 
            } 
 | 
            sum = 11 - sum % 11; 
 | 
            if (sum == 10 || sum == 11) { 
 | 
                sum = 0; 
 | 
            } 
 | 
            if (sum != k) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Validate political region 
 | 
            // rr is the political region of birth, which can be in ranges: 
 | 
            // 10-19: Bosnia and Herzegovina 
 | 
            // 20-29: Montenegro 
 | 
            // 30-39: Croatia (not used anymore) 
 | 
            // 41-49: Macedonia 
 | 
            // 50-59: Slovenia (only 50 is used) 
 | 
            // 70-79: Central Serbia 
 | 
            // 80-89: Serbian province of Vojvodina 
 | 
            // 90-99: Kosovo 
 | 
            switch (countryCode.toUpperCase()) { 
 | 
            case 'BA': 
 | 
                return (10 <= rr && rr <= 19); 
 | 
            case 'MK': 
 | 
                return (41 <= rr && rr <= 49); 
 | 
            case 'ME': 
 | 
                return (20 <= rr && rr <= 29); 
 | 
            case 'RS': 
 | 
                return (70 <= rr && rr <= 99); 
 | 
            case 'SI': 
 | 
                return (50 <= rr && rr <= 59); 
 | 
            default: 
 | 
                return true; 
 | 
            } 
 | 
        }, 
 | 
  
 | 
        _ba : function(value) { 
 | 
            return this._validateJMBG(value, 'BA'); 
 | 
        }, 
 | 
        _mk : function(value) { 
 | 
            return this._validateJMBG(value, 'MK'); 
 | 
        }, 
 | 
        _me : function(value) { 
 | 
            return this._validateJMBG(value, 'ME'); 
 | 
        }, 
 | 
        _rs : function(value) { 
 | 
            return this._validateJMBG(value, 'RS'); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Examples: 0101006500006 
 | 
         */ 
 | 
        _si : function(value) { 
 | 
            return this._validateJMBG(value, 'SI'); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Bulgarian national identification number (EGN) Examples: - 
 | 
         * Valid: 7523169263, 8032056031, 803205 603 1, 8001010008, 7501020018, 
 | 
         * 7552010005, 7542011030 - Invalid: 8019010008 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/Uniform_civil_number 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _bg : function(value) { 
 | 
            if (!/^\d{10}$/.test(value) && !/^\d{6}\s\d{3}\s\d{1}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.replace(/\s/g, ''); 
 | 
            // Check the birth date 
 | 
            var year = parseInt(value.substr(0, 2), 10) + 1900, month = parseInt(value.substr(2, 2), 10), day = parseInt(value.substr(4, 2), 10); 
 | 
            if (month > 40) { 
 | 
                year += 100; 
 | 
                month -= 40; 
 | 
            } else if (month > 20) { 
 | 
                year -= 100; 
 | 
                month -= 20; 
 | 
            } 
 | 
  
 | 
            if (!$.fn.bootstrapValidator.helpers.date(year, month, day)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            var sum = 0, weight = [ 2, 4, 8, 5, 10, 9, 7, 3, 6 ]; 
 | 
            for (var i = 0; i < 9; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
            sum = (sum % 11) % 10; 
 | 
            return (sum == value.substr(9, 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Brazilian national identification number (CPF) Examples: - 
 | 
         * Valid: 39053344705, 390.533.447-05, 111.444.777-35 - Invalid: 
 | 
         * 231.002.999-00 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/Cadastro_de_Pessoas_F%C3%ADsicas 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _br : function(value) { 
 | 
            if (/^1{11}|2{11}|3{11}|4{11}|5{11}|6{11}|7{11}|8{11}|9{11}|0{11}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            if (!/^\d{11}$/.test(value) && !/^\d{3}\.\d{3}\.\d{3}-\d{2}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.replace(/\./g, '').replace(/-/g, ''); 
 | 
  
 | 
            var d1 = 0; 
 | 
            for (var i = 0; i < 9; i++) { 
 | 
                d1 += (10 - i) * parseInt(value.charAt(i)); 
 | 
            } 
 | 
            d1 = 11 - d1 % 11; 
 | 
            if (d1 == 10 || d1 == 11) { 
 | 
                d1 = 0; 
 | 
            } 
 | 
            if (d1 != value.charAt(9)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            var d2 = 0; 
 | 
            for (i = 0; i < 10; i++) { 
 | 
                d2 += (11 - i) * parseInt(value.charAt(i)); 
 | 
            } 
 | 
            d2 = 11 - d2 % 11; 
 | 
            if (d2 == 10 || d2 == 11) { 
 | 
                d2 = 0; 
 | 
            } 
 | 
  
 | 
            return (d2 == value.charAt(10)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Swiss Social Security Number (AHV-Nr/No AVS) Examples: - 
 | 
         * Valid: 756.1234.5678.95, 7561234567895 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/National_identification_number#Switzerland 
 | 
         * @see http://www.bsv.admin.ch/themen/ahv/00011/02185/index.html?lang=de 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _ch : function(value) { 
 | 
            if (!/^756[\.]{0,1}[0-9]{4}[\.]{0,1}[0-9]{4}[\.]{0,1}[0-9]{2}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.replace(/\D/g, '').substr(3); 
 | 
            var length = value.length, sum = 0, weight = (length == 8) ? [ 3, 1 ] : [ 1, 3 ]; 
 | 
            for (var i = 0; i < length - 1; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i % 2]; 
 | 
            } 
 | 
            sum = 10 - sum % 10; 
 | 
            return (sum == value.charAt(length - 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Chilean national identification number (RUN/RUT) Examples: - 
 | 
         * Valid: 76086428-5, 22060449-7, 12531909-2 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/National_identification_number#Chile 
 | 
         * @see https://palena.sii.cl/cvc/dte/ee_empresas_emisoras.html for 
 | 
         *      samples 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _cl : function(value) { 
 | 
            if (!/^\d{7,8}[-]{0,1}[0-9K]$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.replace(/\D/g, ''); 
 | 
            while (value.length < 9) { 
 | 
                value = '0' + value; 
 | 
            } 
 | 
            var sum = 0, weight = [ 3, 2, 7, 6, 5, 4, 3, 2 ]; 
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
            sum = 11 - sum % 11; 
 | 
            if (sum == 11) { 
 | 
                sum = 0; 
 | 
            } else if (sum == 10) { 
 | 
                sum = 'K'; 
 | 
            } 
 | 
            return sum == value.charAt(8); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Czech national identification number (RC) Examples: - Valid: 
 | 
         * 7103192745, 991231123 - Invalid: 1103492745, 590312123 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _cz : function(value) { 
 | 
            if (!/^\d{9,10}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            var year = 1900 + parseInt(value.substr(0, 2)), month = parseInt(value.substr(2, 2)) % 50 % 20, day = parseInt(value.substr(4, 2)); 
 | 
            if (value.length == 9) { 
 | 
                if (year >= 1980) { 
 | 
                    year -= 100; 
 | 
                } 
 | 
                if (year > 1953) { 
 | 
                    return false; 
 | 
                } 
 | 
            } else if (year < 1954) { 
 | 
                year += 100; 
 | 
            } 
 | 
  
 | 
            if (!$.fn.bootstrapValidator.helpers.date(year, month, day)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Check that the birth date is not in the future 
 | 
            if (value.length == 10) { 
 | 
                var check = parseInt(value.substr(0, 9), 10) % 11; 
 | 
                if (year < 1985) { 
 | 
                    check = check % 10; 
 | 
                } 
 | 
                return (check == value.substr(9, 1)); 
 | 
            } 
 | 
  
 | 
            return true; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Danish Personal Identification number (CPR) Examples: - 
 | 
         * Valid: 2110625629, 211062-5629 - Invalid: 511062-5629 
 | 
         *  
 | 
         * @see https://en.wikipedia.org/wiki/Personal_identification_number_(Denmark) 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _dk : function(value) { 
 | 
            if (!/^[0-9]{6}[-]{0,1}[0-9]{4}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.replace(/-/g, ''); 
 | 
            var day = parseInt(value.substr(0, 2), 10), month = parseInt(value.substr(2, 2), 10), year = parseInt(value.substr(4, 2), 10); 
 | 
  
 | 
            switch (true) { 
 | 
            case ('5678'.indexOf(value.charAt(6)) != -1 && year >= 58): 
 | 
                year += 1800; 
 | 
                break; 
 | 
            case ('0123'.indexOf(value.charAt(6)) != -1): 
 | 
            case ('49'.indexOf(value.charAt(6)) != -1 && year >= 37): 
 | 
                year += 1900; 
 | 
                break; 
 | 
            default: 
 | 
                year += 2000; 
 | 
                break; 
 | 
            } 
 | 
  
 | 
            return $.fn.bootstrapValidator.helpers.date(year, month, day); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Estonian Personal Identification Code (isikukood) Examples: - 
 | 
         * Valid: 37605030299 
 | 
         *  
 | 
         * @see http://et.wikipedia.org/wiki/Isikukood 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _ee : function(value) { 
 | 
            // Use the same format as Lithuanian Personal Code 
 | 
            return this._lt(value); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Spanish personal identity code (DNI) Support i) DNI (for 
 | 
         * Spanish citizens) and ii) NIE (for foreign people) 
 | 
         *  
 | 
         * Examples: - Valid: i) 54362315K, 54362315-K; ii) X2482300W, 
 | 
         * X-2482300W, X-2482300-W - Invalid: i) 54362315Z; ii) X-2482300A 
 | 
         *  
 | 
         * @see https://en.wikipedia.org/wiki/National_identification_number#Spain 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _es : function(value) { 
 | 
            if (!/^[0-9A-Z]{8}[-]{0,1}[0-9A-Z]$/.test(value) // DNI 
 | 
                    && !/^[XYZ][-]{0,1}[0-9]{7}[-]{0,1}[0-9A-Z]$/.test(value)) { // NIE 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.replace(/-/g, ''); 
 | 
            var index = 'XYZ'.indexOf(value.charAt(0)); 
 | 
            if (index != -1) { 
 | 
                // It is NIE number 
 | 
                value = index + value.substr(1) + ''; 
 | 
            } 
 | 
  
 | 
            var check = parseInt(value.substr(0, 8), 10); 
 | 
            check = 'TRWAGMYFPDXBNJZSQVHLCKE'[check % 23]; 
 | 
            return (check == value.substr(8, 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Finnish Personal Identity Code (HETU) Examples: - Valid: 
 | 
         * 311280-888Y, 131052-308T - Invalid: 131052-308U, 310252-308Y 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _fi : function(value) { 
 | 
            if (!/^[0-9]{6}[-+A][0-9]{3}[0-9ABCDEFHJKLMNPRSTUVWXY]$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            var day = parseInt(value.substr(0, 2), 10), month = parseInt(value.substr(2, 2), 10), year = parseInt(value.substr(4, 2), 10), centuries = { 
 | 
                '+' : 1800, 
 | 
                '-' : 1900, 
 | 
                'A' : 2000 
 | 
            }; 
 | 
            year = centuries[value.charAt(6)] + year; 
 | 
  
 | 
            if (!$.fn.bootstrapValidator.helpers.date(year, month, day)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            var individual = parseInt(value.substr(7, 3)); 
 | 
            if (individual < 2) { 
 | 
                return false; 
 | 
            } 
 | 
            var n = value.substr(0, 6) + value.substr(7, 3) + ''; 
 | 
            n = parseInt(n); 
 | 
            return '0123456789ABCDEFHJKLMNPRSTUVWXY'.charAt(n % 31) == value.charAt(10); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Croatian personal identification number (OIB) Examples: - 
 | 
         * Valid: 33392005961 - Invalid: 33392005962 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _hr : function(value) { 
 | 
            if (!/^[0-9]{11}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            return $.fn.bootstrapValidator.helpers.mod_11_10(value); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Irish Personal Public Service Number (PPS) Examples: - 
 | 
         * Valid: 6433435F, 6433435FT, 6433435FW, 6433435OA, 6433435IH, 
 | 
         * 1234567TW, 1234567FA - Invalid: 6433435E, 6433435VH 
 | 
         *  
 | 
         * @see https://en.wikipedia.org/wiki/Personal_Public_Service_Number 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _ie : function(value) { 
 | 
            if (!/^\d{7}[A-W][AHWTX]?$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            var getCheckDigit = function(value) { 
 | 
                while (value.length < 7) { 
 | 
                    value = '0' + value; 
 | 
                } 
 | 
                var alphabet = 'WABCDEFGHIJKLMNOPQRSTUV', sum = 0; 
 | 
                for (var i = 0; i < 7; i++) { 
 | 
                    sum += parseInt(value.charAt(i)) * (8 - i); 
 | 
                } 
 | 
                sum += 9 * alphabet.indexOf(value.substr(7)); 
 | 
                return alphabet[sum % 23]; 
 | 
            }; 
 | 
  
 | 
            // 2013 format 
 | 
            if (value.length == 9 && ('A' == value.charAt(8) || 'H' == value.charAt(8))) { 
 | 
                return value.charAt(7) == getCheckDigit(value.substr(0, 7) + value.substr(8) + ''); 
 | 
            } 
 | 
            // The old format 
 | 
            else { 
 | 
                return value.charAt(7) == getCheckDigit(value.substr(0, 7)); 
 | 
            } 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Iceland national identification number (Kennitala) Examples: - 
 | 
         * Valid: 120174-3399, 1201743399, 0902862349 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/Kennitala 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _is : function(value) { 
 | 
            if (!/^[0-9]{6}[-]{0,1}[0-9]{4}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.replace(/-/g, ''); 
 | 
            var day = parseInt(value.substr(0, 2), 10), month = parseInt(value.substr(2, 2), 10), year = parseInt(value.substr(4, 2), 10), century = parseInt(value.charAt(9)); 
 | 
  
 | 
            year = (century == 9) ? (1900 + year) : ((20 + century) * 100 + year); 
 | 
            if (!$.fn.bootstrapValidator.helpers.date(year, month, day, true)) { 
 | 
                return false; 
 | 
            } 
 | 
            // Validate the check digit 
 | 
            var sum = 0, weight = [ 3, 2, 7, 6, 5, 4, 3, 2 ]; 
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
            sum = 11 - sum % 11; 
 | 
            return (sum == value.charAt(8)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Lithuanian Personal Code (Asmens kodas) Examples: - Valid: 
 | 
         * 38703181745 - Invalid: 38703181746, 78703181745, 38703421745 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/National_identification_number#Lithuania 
 | 
         * @see http://www.adomas.org/midi2007/pcode.html 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _lt : function(value) { 
 | 
            if (!/^[0-9]{11}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            var gender = parseInt(value.charAt(0)), year = parseInt(value.substr(1, 2), 10), month = parseInt(value.substr(3, 2), 10), day = parseInt(value.substr(5, 2), 10), century = (gender % 2 == 0) ? (17 + gender / 2) : (17 + (gender + 1) / 2); 
 | 
            year = century * 100 + year; 
 | 
            if (!$.fn.bootstrapValidator.helpers.date(year, month, day, true)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Validate the check digit 
 | 
            var sum = 0, weight = [ 1, 2, 3, 4, 5, 6, 7, 8, 9, 1 ]; 
 | 
            for (var i = 0; i < 10; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
            sum = sum % 11; 
 | 
            if (sum != 10) { 
 | 
                return sum == value.charAt(10); 
 | 
            } 
 | 
  
 | 
            // Re-calculate the check digit 
 | 
            sum = 0; 
 | 
            weight = [ 3, 4, 5, 6, 7, 8, 9, 1, 2, 3 ]; 
 | 
            for (i = 0; i < 10; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
            sum = sum % 11; 
 | 
            if (sum == 10) { 
 | 
                sum = 0; 
 | 
            } 
 | 
            return (sum == value.charAt(10)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Latvian Personal Code (Personas kods) Examples: - Valid: 
 | 
         * 161175-19997, 16117519997 - Invalid: 161375-19997 
 | 
         *  
 | 
         * @see http://laacz.lv/2006/11/25/pk-parbaudes-algoritms/ 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _lv : function(value) { 
 | 
            if (!/^[0-9]{6}[-]{0,1}[0-9]{5}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.replace(/\D/g, ''); 
 | 
            // Check birth date 
 | 
            var day = parseInt(value.substr(0, 2)), month = parseInt(value.substr(2, 2)), year = parseInt(value.substr(4, 2)); 
 | 
            year = year + 1800 + parseInt(value.charAt(6)) * 100; 
 | 
  
 | 
            if (!$.fn.bootstrapValidator.helpers.date(year, month, day, true)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Check personal code 
 | 
            var sum = 0, weight = [ 10, 5, 8, 4, 2, 1, 6, 3, 7, 9 ]; 
 | 
            for (var i = 0; i < 10; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
            sum = (sum + 1) % 11 % 10; 
 | 
            return (sum == value.charAt(10)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Dutch national identification number (BSN) Examples: - 
 | 
         * Valid: 111222333, 941331490, 9413.31.490 - Invalid: 111252333 
 | 
         *  
 | 
         * @see https://nl.wikipedia.org/wiki/Burgerservicenummer 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _nl : function(value) { 
 | 
            while (value.length < 9) { 
 | 
                value = '0' + value; 
 | 
            } 
 | 
            if (!/^[0-9]{4}[.]{0,1}[0-9]{2}[.]{0,1}[0-9]{3}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.replace(/\./g, ''); 
 | 
            if (parseInt(value, 10) == 0) { 
 | 
                return false; 
 | 
            } 
 | 
            var sum = 0, length = value.length; 
 | 
            for (var i = 0; i < length - 1; i++) { 
 | 
                sum += (9 - i) * parseInt(value.charAt(i)); 
 | 
            } 
 | 
            sum = sum % 11; 
 | 
            if (sum == 10) { 
 | 
                sum = 0; 
 | 
            } 
 | 
            return (sum == value.charAt(length - 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Romanian numerical personal code (CNP) Examples: - Valid: 
 | 
         * 1630615123457, 1800101221144 - Invalid: 8800101221144, 1632215123457, 
 | 
         * 1630615123458 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/National_identification_number#Romania 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _ro : function(value) { 
 | 
            if (!/^[0-9]{13}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            var gender = parseInt(value.charAt(0)); 
 | 
            if (gender == 0 || gender == 7 || gender == 8) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Determine the date of birth 
 | 
            var year = parseInt(value.substr(1, 2), 10), month = parseInt(value.substr(3, 2), 10), day = parseInt(value.substr(5, 2), 10), 
 | 
            // The year of date is determined base on the gender 
 | 
            centuries = { 
 | 
                '1' : 1900, // Male born between 1900 and 1999 
 | 
                '2' : 1900, // Female born between 1900 and 1999 
 | 
                '3' : 1800, // Male born between 1800 and 1899 
 | 
                '4' : 1800, // Female born between 1800 and 1899 
 | 
                '5' : 2000, // Male born after 2000 
 | 
                '6' : 2000 
 | 
            // Female born after 2000 
 | 
            }; 
 | 
            if (day > 31 && month > 12) { 
 | 
                return false; 
 | 
            } 
 | 
            if (gender != 9) { 
 | 
                year = centuries[gender + ''] + year; 
 | 
                if (!$.fn.bootstrapValidator.helpers.date(year, month, day)) { 
 | 
                    return false; 
 | 
                } 
 | 
            } 
 | 
  
 | 
            // Validate the check digit 
 | 
            var sum = 0, weight = [ 2, 7, 9, 1, 4, 6, 3, 5, 8, 2, 7, 9 ], length = value.length; 
 | 
            for (var i = 0; i < length - 1; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
            sum = sum % 11; 
 | 
            if (sum == 10) { 
 | 
                sum = 1; 
 | 
            } 
 | 
            return (sum == value.charAt(length - 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Swedish personal identity number (personnummer) Examples: - 
 | 
         * Valid: 8112289874, 811228-9874, 811228+9874 - Invalid: 811228-9873 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/Personal_identity_number_(Sweden) 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _se : function(value) { 
 | 
            if (!/^[0-9]{10}$/.test(value) && !/^[0-9]{6}[-|+][0-9]{4}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.replace(/[^0-9]/g, ''); 
 | 
  
 | 
            var year = parseInt(value.substr(0, 2)) + 1900, month = parseInt(value.substr(2, 2)), day = parseInt(value.substr(4, 2)); 
 | 
            if (!$.fn.bootstrapValidator.helpers.date(year, month, day)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Validate the last check digit 
 | 
            return $.fn.bootstrapValidator.helpers.luhn(value); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Slovak national identifier number (RC) Examples: - Valid: 
 | 
         * 7103192745, 991231123 - Invalid: 7103192746, 1103492745 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _sk : function(value) { 
 | 
            // Slovakia uses the same format as Czech Republic 
 | 
            return this._cz(value); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate San Marino citizen number 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/National_identification_number#San_Marino 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _sm : function(value) { 
 | 
            return /^\d{5}$/.test(value); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate South African ID Example: - Valid: 8001015009087 - Invalid: 
 | 
         * 8001015009287, 8001015009086 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/National_identification_number#South_Africa 
 | 
         * @param {String} 
 | 
         *            value The ID 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _za : function(value) { 
 | 
            if (!/^[0-9]{10}[0|1][8|9][0-9]$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            var year = parseInt(value.substr(0, 2)), currentYear = new Date().getFullYear() % 100, month = parseInt(value.substr(2, 2)), day = parseInt(value.substr(4, 2)); 
 | 
            year = (year >= currentYear) ? (year + 1900) : (year + 2000); 
 | 
  
 | 
            if (!$.fn.bootstrapValidator.helpers.date(year, month, day)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Validate the last check digit 
 | 
            return $.fn.bootstrapValidator.helpers.luhn(value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.identical = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            field : 'field' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Check if input value equals to value of particular one 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consists of the following key: - field: The name 
 | 
         *            of field that will be used to compare with current one 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            var compareWith = validator.getFieldElements(options.field); 
 | 
            if (compareWith == null) { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            if (value == compareWith.val()) { 
 | 
                validator.updateStatus(options.field, validator.STATUS_VALID, 'identical'); 
 | 
                return true; 
 | 
            } else { 
 | 
                return false; 
 | 
            } 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.imei = { 
 | 
        /** 
 | 
         * Validate IMEI (International Mobile Station Equipment Identity) 
 | 
         * Examples: - Valid: 35-209900-176148-1, 35-209900-176148-23, 
 | 
         * 3568680000414120, 490154203237518 - Invalid: 490154203237517 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/International_Mobile_Station_Equipment_Identity 
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            switch (true) { 
 | 
            case /^\d{15}$/.test(value): 
 | 
            case /^\d{2}-\d{6}-\d{6}-\d{1}$/.test(value): 
 | 
            case /^\d{2}\s\d{6}\s\d{6}\s\d{1}$/.test(value): 
 | 
                value = value.replace(/[^0-9]/g, ''); 
 | 
                return $.fn.bootstrapValidator.helpers.luhn(value); 
 | 
                break; 
 | 
  
 | 
            case /^\d{14}$/.test(value): 
 | 
            case /^\d{16}$/.test(value): 
 | 
            case /^\d{2}-\d{6}-\d{6}(|-\d{2})$/.test(value): 
 | 
            case /^\d{2}\s\d{6}\s\d{6}(|\s\d{2})$/.test(value): 
 | 
                return true; 
 | 
  
 | 
            default: 
 | 
                return false; 
 | 
            } 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.integer = { 
 | 
        enableByHtml5 : function($field) { 
 | 
            return ('number' == $field.attr('type')); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if the input value is an integer 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following key: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
            return /^(?:-?(?:0|[1-9][0-9]*))$/.test(value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.ip = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            ipv4 : 'ipv4', 
 | 
            ipv6 : 'ipv6' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if the input value is a IP address. 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - ipv4: Enable 
 | 
         *            IPv4 validator, default to true - ipv6: Enable IPv6 
 | 
         *            validator, default to true - message: The invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
            options = $.extend({}, { 
 | 
                ipv4 : true, 
 | 
                ipv6 : true 
 | 
            }, options); 
 | 
  
 | 
            if (options.ipv4) { 
 | 
                return /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/.test(value); 
 | 
            } else if (options.ipv6) { 
 | 
                return /^\s*((([0-9A-Fa-f]{1,4}:){7}([0-9A-Fa-f]{1,4}|:))|(([0-9A-Fa-f]{1,4}:){6}(:[0-9A-Fa-f]{1,4}|((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){5}(((:[0-9A-Fa-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){4}(((:[0-9A-Fa-f]{1,4}){1,3})|((:[0-9A-Fa-f]{1,4})?:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){3}(((:[0-9A-Fa-f]{1,4}){1,4})|((:[0-9A-Fa-f]{1,4}){0,2}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){2}(((:[0-9A-Fa-f]{1,4}){1,5})|((:[0-9A-Fa-f]{1,4}){0,3}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){1}(((:[0-9A-Fa-f]{1,4}){1,6})|((:[0-9A-Fa-f]{1,4}){0,4}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(:(((:[0-9A-Fa-f]{1,4}){1,7})|((:[0-9A-Fa-f]{1,4}){0,5}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(%.+)?\s*$/.test(str); 
 | 
            } 
 | 
            return false; 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.isbn = { 
 | 
        /** 
 | 
         * Return true if the input value is a valid ISBN 10 or ISBN 13 number 
 | 
         * Examples: - Valid: ISBN 10: 99921-58-10-7, 9971-5-0210-0, 
 | 
         * 960-425-059-0, 80-902734-1-6, 85-359-0277-5, 1-84356-028-3, 
 | 
         * 0-684-84328-5, 0-8044-2957-X, 0-85131-041-9, 0-943396-04-2, 
 | 
         * 0-9752298-0-X ISBN 13: 978-0-306-40615-7 - Invalid: ISBN 10: 
 | 
         * 99921-58-10-6 ISBN 13: 978-0-306-40615-6 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/International_Standard_Book_Number 
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            // http://en.wikipedia.org/wiki/International_Standard_Book_Number#Overview 
 | 
            // Groups are separated by a hyphen or a space 
 | 
            var type; 
 | 
            switch (true) { 
 | 
            case /^\d{9}[\dX]$/.test(value): 
 | 
            case (value.length == 13 && /^(\d+)-(\d+)-(\d+)-([\dX])$/.test(value)): 
 | 
            case (value.length == 13 && /^(\d+)\s(\d+)\s(\d+)\s([\dX])$/.test(value)): 
 | 
                type = 'ISBN10'; 
 | 
                break; 
 | 
            case /^(978|979)\d{9}[\dX]$/.test(value): 
 | 
            case (value.length == 17 && /^(978|979)-(\d+)-(\d+)-(\d+)-([\dX])$/.test(value)): 
 | 
            case (value.length == 17 && /^(978|979)\s(\d+)\s(\d+)\s(\d+)\s([\dX])$/.test(value)): 
 | 
                type = 'ISBN13'; 
 | 
                break; 
 | 
            default: 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Replace all special characters except digits and X 
 | 
            value = value.replace(/[^0-9X]/gi, ''); 
 | 
            var chars = value.split(''), length = chars.length, sum = 0, checksum; 
 | 
  
 | 
            switch (type) { 
 | 
            case 'ISBN10': 
 | 
                sum = 0; 
 | 
                for (var i = 0; i < length - 1; i++) { 
 | 
                    sum += ((10 - i) * parseInt(chars[i])); 
 | 
                } 
 | 
                checksum = 11 - (sum % 11); 
 | 
                if (checksum == 11) { 
 | 
                    checksum = 0; 
 | 
                } else if (checksum == 10) { 
 | 
                    checksum = 'X'; 
 | 
                } 
 | 
                return (checksum + '' == chars[length - 1]); 
 | 
  
 | 
            case 'ISBN13': 
 | 
                sum = 0; 
 | 
                for (var i = 0; i < length - 1; i++) { 
 | 
                    sum += ((i % 2 == 0) ? parseInt(chars[i]) : (parseInt(chars[i]) * 3)); 
 | 
                } 
 | 
                checksum = 10 - (sum % 10); 
 | 
                if (checksum == 10) { 
 | 
                    checksum = '0'; 
 | 
                } 
 | 
                return (checksum + '' == chars[length - 1]); 
 | 
  
 | 
            default: 
 | 
                return false; 
 | 
            } 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.isin = { 
 | 
        // Available country codes 
 | 
        // See http://isin.net/country-codes/ 
 | 
        COUNTRY_CODES : 'AF|AX|AL|DZ|AS|AD|AO|AI|AQ|AG|AR|AM|AW|AU|AT|AZ|BS|BH|BD|BB|BY|BE|BZ|BJ|BM|BT|BO|BQ|BA|BW|BV|BR|IO|BN|BG|BF|BI|KH|CM|CA|CV|KY|CF|TD|CL|CN|CX|CC|CO|KM|CG|CD|CK|CR|CI|HR|CU|CW|CY|CZ|DK|DJ|DM|DO|EC|EG|SV|GQ|ER|EE|ET|FK|FO|FJ|FI|FR|GF|PF|TF|GA|GM|GE|DE|GH|GI|GR|GL|GD|GP|GU|GT|GG|GN|GW|GY|HT|HM|VA|HN|HK|HU|IS|IN|ID|IR|IQ|IE|IM|IL|IT|JM|JP|JE|JO|KZ|KE|KI|KP|KR|KW|KG|LA|LV|LB|LS|LR|LY|LI|LT|LU|MO|MK|MG|MW|MY|MV|ML|MT|MH|MQ|MR|MU|YT|MX|FM|MD|MC|MN|ME|MS|MA|MZ|MM|NA|NR|NP|NL|NC|NZ|NI|NE|NG|NU|NF|MP|NO|OM|PK|PW|PS|PA|PG|PY|PE|PH|PN|PL|PT|PR|QA|RE|RO|RU|RW|BL|SH|KN|LC|MF|PM|VC|WS|SM|ST|SA|SN|RS|SC|SL|SG|SX|SK|SI|SB|SO|ZA|GS|SS|ES|LK|SD|SR|SJ|SZ|SE|CH|SY|TW|TJ|TZ|TH|TL|TG|TK|TO|TT|TN|TR|TM|TC|TV|UG|UA|AE|GB|US|UM|UY|UZ|VU|VE|VN|VG|VI|WF|EH|YE|ZM|ZW', 
 | 
  
 | 
        /** 
 | 
         * Validate an ISIN (International Securities Identification Number) 
 | 
         * Examples: - Valid: US0378331005, AU0000XVGZA3, GB0002634946 - 
 | 
         * Invalid: US0378331004, AA0000XVGZA3 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/International_Securities_Identifying_Number 
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            value = value.toUpperCase(); 
 | 
            var regex = new RegExp('^(' + this.COUNTRY_CODES + ')[0-9A-Z]{10}$'); 
 | 
            if (!regex.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            var converted = '', length = value.length; 
 | 
            // Convert letters to number 
 | 
            for (var i = 0; i < length - 1; i++) { 
 | 
                var c = value.charCodeAt(i); 
 | 
                converted += ((c > 57) ? (c - 55).toString() : value.charAt(i)); 
 | 
            } 
 | 
  
 | 
            var digits = '', n = converted.length, group = (n % 2 != 0) ? 0 : 1; 
 | 
            for (i = 0; i < n; i++) { 
 | 
                digits += (parseInt(converted[i]) * ((i % 2) == group ? 2 : 1) + ''); 
 | 
            } 
 | 
  
 | 
            var sum = 0; 
 | 
            for (i = 0; i < digits.length; i++) { 
 | 
                sum += parseInt(digits.charAt(i)); 
 | 
            } 
 | 
            sum = (10 - (sum % 10)) % 10; 
 | 
            return sum == value.charAt(length - 1); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.ismn = { 
 | 
        /** 
 | 
         * Validate ISMN (International Standard Music Number) Examples: - 
 | 
         * Valid: M230671187, 979-0-0601-1561-5, 979 0 3452 4680 5, 
 | 
         * 9790060115615 - Invalid: 9790060115614 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/International_Standard_Music_Number 
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            // Groups are separated by a hyphen or a space 
 | 
            var type; 
 | 
            switch (true) { 
 | 
            case /^M\d{9}$/.test(value): 
 | 
            case /^M-\d{4}-\d{4}-\d{1}$/.test(value): 
 | 
            case /^M\s\d{4}\s\d{4}\s\d{1}$/.test(value): 
 | 
                type = 'ISMN10'; 
 | 
                break; 
 | 
            case /^9790\d{9}$/.test(value): 
 | 
            case /^979-0-\d{4}-\d{4}-\d{1}$/.test(value): 
 | 
            case /^979\s0\s\d{4}\s\d{4}\s\d{1}$/.test(value): 
 | 
                type = 'ISMN13'; 
 | 
                break; 
 | 
            default: 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            if ('ISMN10' == type) { 
 | 
                value = '9790' + value.substr(1); 
 | 
            } 
 | 
  
 | 
            // Replace all special characters except digits 
 | 
            value = value.replace(/[^0-9]/gi, ''); 
 | 
            var length = value.length, sum = 0, weight = [ 1, 3 ]; 
 | 
            for (var i = 0; i < length - 1; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i % 2]; 
 | 
            } 
 | 
            sum = 10 - sum % 10; 
 | 
            return (sum == value.charAt(length - 1)); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.issn = { 
 | 
        /** 
 | 
         * Validate ISSN (International Standard Serial Number) Examples: - 
 | 
         * Valid: 0378-5955, 0024-9319, 0032-1478 - Invalid: 0032-147X 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/International_Standard_Serial_Number 
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            // Groups are separated by a hyphen or a space 
 | 
            if (!/^\d{4}\-\d{3}[\dX]$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Replace all special characters except digits and X 
 | 
            value = value.replace(/[^0-9X]/gi, ''); 
 | 
            var chars = value.split(''), length = chars.length, sum = 0; 
 | 
  
 | 
            if (chars[7] == 'X') { 
 | 
                chars[7] = 10; 
 | 
            } 
 | 
            for (var i = 0; i < length; i++) { 
 | 
                sum += ((8 - i) * parseInt(chars[i])); 
 | 
            } 
 | 
            return (sum % 11 == 0); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.lessThan = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            value : 'value', 
 | 
            inclusive : 'inclusive' 
 | 
        }, 
 | 
  
 | 
        enableByHtml5 : function($field) { 
 | 
            var max = $field.attr('max'); 
 | 
            if (max) { 
 | 
                return { 
 | 
                    value : max 
 | 
                }; 
 | 
            } 
 | 
  
 | 
            return false; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if the input value is less than or equal to given number 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - value: The 
 | 
         *            number used to compare to - inclusive [optional]: Can be 
 | 
         *            true or false. Default is true - message: The invalid 
 | 
         *            message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
            value = parseFloat(value); 
 | 
            return (options.inclusive === false) ? (value <= options.value) : (value < options.value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.mac = { 
 | 
        /** 
 | 
         * Return true if the input value is a MAC address. 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            return /^([0-9A-F]{2}[:-]){5}([0-9A-F]{2})$/.test(value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.notEmpty = { 
 | 
        enableByHtml5 : function($field) { 
 | 
            var required = $field.attr('required') + ''; 
 | 
            return ('required' == required || 'true' == required); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Check if input value is empty or not 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var type = $field.attr('type'); 
 | 
            if ('radio' == type || 'checkbox' == type) { 
 | 
                return validator.getFieldElements($field.attr('data-bv-field')).filter(':checked').length > 0; 
 | 
            } 
 | 
  
 | 
            return $.trim($field.val()) != ''; 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.numeric = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            separator : 'separator' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate decimal number 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consist of key: - message: The invalid message - 
 | 
         *            separator: The decimal separator. Can be "." (default), 
 | 
         *            "," 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
            var separator = options.separator || '.'; 
 | 
            if (separator != '.') { 
 | 
                value = value.replace(separator, '.'); 
 | 
            } 
 | 
  
 | 
            return !isNaN(parseFloat(value)) && isFinite(value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.phone = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            country : 'country' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if the input value contains a valid US phone number only 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator Validate plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consist of key: - message: The invalid message - 
 | 
         *            country: The ISO 3166 country code Currently it only 
 | 
         *            supports United State (US) country 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            var country = (options.country || 'US').toUpperCase(); 
 | 
            switch (country) { 
 | 
            case 'US': 
 | 
            default: 
 | 
                // Make sure US phone numbers have 10 digits 
 | 
                // May start with 1, +1, or 1-; should discard 
 | 
                // Area code may be delimited with (), & sections may be 
 | 
                // delimited with . or - 
 | 
                // Test: http://regexr.com/38mqi 
 | 
                value = value.replace(/\D/g, ''); 
 | 
                return (/^(?:(1\-?)|(\+1 ?))?\(?(\d{3})[\)\-\.]?(\d{3})[\-\.]?(\d{4})$/).test(value) && (value.length == 10); 
 | 
            } 
 | 
        } 
 | 
    } 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.regexp = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            regexp : 'regexp' 
 | 
        }, 
 | 
  
 | 
        enableByHtml5 : function($field) { 
 | 
            var pattern = $field.attr('pattern'); 
 | 
            if (pattern) { 
 | 
                return { 
 | 
                    regexp : pattern 
 | 
                }; 
 | 
            } 
 | 
  
 | 
            return false; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Check if the element value matches given regular expression 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consists of the following key: - regexp: The 
 | 
         *            regular expression you need to check 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            var regexp = ('string' == typeof options.regexp) ? new RegExp(options.regexp) : options.regexp; 
 | 
            return regexp.test(value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.remote = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            url : 'url', 
 | 
            name : 'name' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Request a remote server to check the input value 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator Plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - url - data 
 | 
         *            [optional]: By default, it will take the value { 
 | 
         *            <fieldName>: <fieldValue> } - name [optional]: Override 
 | 
         *            the field name for the request. - message: The invalid 
 | 
         *            message 
 | 
         * @returns {Boolean|Deferred} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            var name = $field.attr('data-bv-field'), data = options.data; 
 | 
            if (data == null) { 
 | 
                data = {}; 
 | 
            } 
 | 
            // Support dynamic data 
 | 
            if ('function' == typeof data) { 
 | 
                data = data.call(this, validator); 
 | 
            } 
 | 
            data[options.name || name] = value; 
 | 
  
 | 
            var dfd = new $.Deferred(); 
 | 
            var xhr = $.ajax({ 
 | 
                type : 'POST', 
 | 
                url : options.url, 
 | 
                dataType : 'json', 
 | 
                data : data 
 | 
            }); 
 | 
            xhr.then(function(response) { 
 | 
                dfd.resolve($field, 'remote', response.valid === true || response.valid === 'true'); 
 | 
            }); 
 | 
  
 | 
            dfd.fail(function() { 
 | 
                xhr.abort(); 
 | 
            }); 
 | 
  
 | 
            return dfd; 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.rtn = { 
 | 
        /** 
 | 
         * Validate a RTN (Routing transit number) Examples: - Valid: 021200025, 
 | 
         * 789456124 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/Routing_transit_number 
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            if (!/^\d{9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            var sum = 0; 
 | 
            for (var i = 0; i < value.length; i += 3) { 
 | 
                sum += parseInt(value.charAt(i), 10) * 3 + parseInt(value.charAt(i + 1), 10) * 7 + parseInt(value.charAt(i + 2), 10); 
 | 
            } 
 | 
            return (sum != 0 && sum % 10 == 0); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.sedol = { 
 | 
        /** 
 | 
         * Validate a SEDOL (Stock Exchange Daily Official List) Examples: - 
 | 
         * Valid: 0263494, B0WNLY7 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/SEDOL 
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - message: The 
 | 
         *            invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            value = value.toUpperCase(); 
 | 
            if (!/^[0-9A-Z]{7}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            var sum = 0, weight = [ 1, 3, 1, 7, 3, 9, 1 ], length = value.length; 
 | 
            for (var i = 0; i < length - 1; i++) { 
 | 
                sum += weight[i] * parseInt(value.charAt(i), 36); 
 | 
            } 
 | 
            sum = (10 - sum % 10) % 10; 
 | 
            return sum == value.charAt(length - 1); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.siren = { 
 | 
        /** 
 | 
         * Check if a string is a siren number 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consist of key: - message: The invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            if (!/^\d{9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            return $.fn.bootstrapValidator.helpers.luhn(value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.siret = { 
 | 
        /** 
 | 
         * Check if a string is a siret number 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consist of key: - message: The invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            var sum = 0, length = value.length, tmp; 
 | 
            for (var i = 0; i < length; i++) { 
 | 
                tmp = parseInt(value.charAt(i), 10); 
 | 
                if ((i % 2) == 0) { 
 | 
                    tmp = tmp * 2; 
 | 
                    if (tmp > 9) { 
 | 
                        tmp -= 9; 
 | 
                    } 
 | 
                } 
 | 
                sum += tmp; 
 | 
            } 
 | 
            return (sum % 10 == 0); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.step = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            base : 'baseValue', 
 | 
            step : 'step' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if the input value is valid step one 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Can consist of the following keys: - baseValue: 
 | 
         *            The base value - step: The step - message: The invalid 
 | 
         *            message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            options = $.extend({}, { 
 | 
                baseValue : 0, 
 | 
                step : 1 
 | 
            }, options); 
 | 
            value = parseFloat(value); 
 | 
            if (isNaN(value) || !isFinite(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            var round = function(x, precision) { 
 | 
                var m = Math.pow(10, precision); 
 | 
                x = x * m; 
 | 
                var sign = (x > 0) | -(x < 0), isHalf = (x % 1 === 0.5 * sign); 
 | 
                if (isHalf) { 
 | 
                    return (Math.floor(x) + (sign > 0)) / m; 
 | 
                } else { 
 | 
                    return Math.round(x) / m; 
 | 
                } 
 | 
            }, floatMod = function(x, y) { 
 | 
                if (y == 0.0) { 
 | 
                    return 1.0; 
 | 
                } 
 | 
                var dotX = (x + '').split('.'), dotY = (y + '').split('.'), precision = ((dotX.length == 1) ? 0 : dotX[1].length) + ((dotY.length == 1) ? 0 : dotY[1].length); 
 | 
                return round(x - y * Math.floor(x / y), precision); 
 | 
            }; 
 | 
  
 | 
            var mod = floatMod(value - options.baseValue, options.step); 
 | 
            return (mod == 0.0 || mod == options.step); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.stringCase = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            'case' : 'case' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Check if a string is a lower or upper case one 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consist of key: - message: The invalid message - 
 | 
         *            case: Can be 'lower' (default) or 'upper' 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            var stringCase = (options['case'] || 'lower').toLowerCase(); 
 | 
            switch (stringCase) { 
 | 
            case 'upper': 
 | 
                return value === value.toUpperCase(); 
 | 
            case 'lower': 
 | 
            default: 
 | 
                return value === value.toLowerCase(); 
 | 
            } 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.stringLength = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            min : 'min', 
 | 
            max : 'max' 
 | 
        }, 
 | 
  
 | 
        enableByHtml5 : function($field) { 
 | 
            var maxLength = $field.attr('maxlength'); 
 | 
            if (maxLength) { 
 | 
                return { 
 | 
                    max : parseInt(maxLength, 10) 
 | 
                }; 
 | 
            } 
 | 
  
 | 
            return false; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Check if the length of element value is less or more than given 
 | 
         * number 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consists of following keys: - min - max At least 
 | 
         *            one of two keys is required - message: The invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            var length = $.trim(value).length; 
 | 
            if ((options.min && length < options.min) || (options.max && length > options.max)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            return true; 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.uri = { 
 | 
        enableByHtml5 : function($field) { 
 | 
            return ('url' == $field.attr('type')); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if the input value is a valid URL 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            // Credit to https://gist.github.com/dperini/729294 
 | 
            // 
 | 
            // Regular Expression for URL validation 
 | 
            // 
 | 
            // Author: Diego Perini 
 | 
            // Updated: 2010/12/05 
 | 
            // 
 | 
            // the regular expression composed & commented 
 | 
            // could be easily tweaked for RFC compliance, 
 | 
            // it was expressly modified to fit & satisfy 
 | 
            // these test for an URL shortener: 
 | 
            // 
 | 
            // http://mathiasbynens.be/demo/url-regex 
 | 
            // 
 | 
            // Notes on possible differences from a standard/generic validation: 
 | 
            // 
 | 
            // - utf-8 char class take in consideration the full Unicode range 
 | 
            // - TLDs have been made mandatory so single names like "localhost" 
 | 
            // fails 
 | 
            // - protocols have been restricted to ftp, http and https only as 
 | 
            // requested 
 | 
            // 
 | 
            // Changes: 
 | 
            // 
 | 
            // - IP address dotted notation validation, range: 1.0.0.0 - 
 | 
            // 223.255.255.255 
 | 
            // first and last IP address of each class is considered invalid 
 | 
            // (since they are broadcast/network addresses) 
 | 
            // 
 | 
            // - Added exclusion of private, reserved and/or local networks 
 | 
            // ranges 
 | 
            // 
 | 
            // Compressed one-line versions: 
 | 
            // 
 | 
            // Javascript version 
 | 
            // 
 | 
            // /^(?:(?:https?|ftp):\/\/)(?:\S+(?::\S*)?@)?(?:(?!10(?:\.\d{1,3}){3})(?!127(?:\.\d{1,3}){3})(?!169\.254(?:\.\d{1,3}){2})(?!192\.168(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u00a1-\uffff0-9]+-?)*[a-z\u00a1-\uffff0-9]+)(?:\.(?:[a-z\u00a1-\uffff0-9]+-?)*[a-z\u00a1-\uffff0-9]+)*(?:\.(?:[a-z\u00a1-\uffff]{2,})))(?::\d{2,5})?(?:\/[^\s]*)?$/i 
 | 
            // 
 | 
            // PHP version 
 | 
            // 
 | 
            // _^(?:(?:https?|ftp)://)(?:\S+(?::\S*)?@)?(?:(?!10(?:\.\d{1,3}){3})(?!127(?:\.\d{1,3}){3})(?!169\.254(?:\.\d{1,3}){2})(?!192\.168(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\x{00a1}-\x{ffff}0-9]+-?)*[a-z\x{00a1}-\x{ffff}0-9]+)(?:\.(?:[a-z\x{00a1}-\x{ffff}0-9]+-?)*[a-z\x{00a1}-\x{ffff}0-9]+)*(?:\.(?:[a-z\x{00a1}-\x{ffff}]{2,})))(?::\d{2,5})?(?:/[^\s]*)?$_iuS 
 | 
            var urlExp = new RegExp("^" + 
 | 
            // protocol identifier 
 | 
            "(?:(?:https?|ftp)://)" + 
 | 
            // user:pass authentication 
 | 
            "(?:\\S+(?::\\S*)?@)?" + "(?:" + 
 | 
            // IP address exclusion 
 | 
            // private & local networks 
 | 
            "(?!10(?:\\.\\d{1,3}){3})" + "(?!127(?:\\.\\d{1,3}){3})" + "(?!169\\.254(?:\\.\\d{1,3}){2})" + "(?!192\\.168(?:\\.\\d{1,3}){2})" + "(?!172\\.(?:1[6-9]|2\\d|3[0-1])(?:\\.\\d{1,3}){2})" + 
 | 
            // IP address dotted notation octets 
 | 
            // excludes loopback network 0.0.0.0 
 | 
            // excludes reserved space >= 224.0.0.0 
 | 
            // excludes network & broacast addresses 
 | 
            // (first & last IP address of each class) 
 | 
            "(?:[1-9]\\d?|1\\d\\d|2[01]\\d|22[0-3])" + "(?:\\.(?:1?\\d{1,2}|2[0-4]\\d|25[0-5])){2}" + "(?:\\.(?:[1-9]\\d?|1\\d\\d|2[0-4]\\d|25[0-4]))" + "|" + 
 | 
            // host name 
 | 
            "(?:(?:[a-z\\u00a1-\\uffff0-9]+-?)*[a-z\\u00a1-\\uffff0-9]+)" + 
 | 
            // domain name 
 | 
            "(?:\\.(?:[a-z\\u00a1-\\uffff0-9]+-?)*[a-z\\u00a1-\\uffff0-9]+)*" + 
 | 
            // TLD identifier 
 | 
            "(?:\\.(?:[a-z\\u00a1-\\uffff]{2,}))" + ")" + 
 | 
            // port number 
 | 
            "(?::\\d{2,5})?" + 
 | 
            // resource path 
 | 
            "(?:/[^\\s]*)?" + "$", "i"); 
 | 
            return urlExp.test(value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.uuid = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            version : 'version' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if and only if the input value is a valid UUID string 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/Universally_unique_identifier 
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consist of key: - message: The invalid message - 
 | 
         *            version: Can be 3, 4, 5, null 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            // See the format at 
 | 
            // http://en.wikipedia.org/wiki/Universally_unique_identifier#Variants_and_versions 
 | 
            var patterns = { 
 | 
                '3' : /^[0-9A-F]{8}-[0-9A-F]{4}-3[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i, 
 | 
                '4' : /^[0-9A-F]{8}-[0-9A-F]{4}-4[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i, 
 | 
                '5' : /^[0-9A-F]{8}-[0-9A-F]{4}-5[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i, 
 | 
                all : /^[0-9A-F]{8}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{12}$/i 
 | 
            }, version = options.version ? (options.version + '') : 'all'; 
 | 
            return (null == patterns[version]) ? true : patterns[version].test(value); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.vat = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            country : 'country' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate an European VAT number 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consist of key: - message: The invalid message - 
 | 
         *            country: The ISO 3166-1 country code 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            var country = options.country || value.substr(0, 2), method = [ '_', country.toLowerCase() ].join(''); 
 | 
            if (this[method] && 'function' == typeof this[method]) { 
 | 
                return this[method](value); 
 | 
            } 
 | 
  
 | 
            return true; 
 | 
        }, 
 | 
  
 | 
        // VAT validators 
 | 
  
 | 
        /** 
 | 
         * Validate Austrian VAT number Example: - Valid: ATU13585627 - Invalid: 
 | 
         * ATU13585626 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _at : function(value) { 
 | 
            if (!/^ATU[0-9]{8}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(3); 
 | 
            var sum = 0, weight = [ 1, 2, 1, 2, 1, 2, 1 ], temp = 0; 
 | 
  
 | 
            for (var i = 0; i < 7; i++) { 
 | 
                temp = parseInt(value.charAt(i)) * weight[i]; 
 | 
                if (temp > 9) { 
 | 
                    temp = Math.floor(temp / 10) + temp % 10; 
 | 
                } 
 | 
                sum += temp; 
 | 
            } 
 | 
  
 | 
            sum = 10 - (sum + 4) % 10; 
 | 
            if (sum == 10) { 
 | 
                sum = 0; 
 | 
            } 
 | 
  
 | 
            return (sum == value.substr(7, 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Belgian VAT number Example: - Valid: BE0428759497 - Invalid: 
 | 
         * BE431150351 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _be : function(value) { 
 | 
            if (!/^BE[0]{0,1}[0-9]{9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            if (value.length == 9) { 
 | 
                value = '0' + value; 
 | 
            } 
 | 
  
 | 
            if (value.substr(1, 1) == 0) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            var sum = parseInt(value.substr(0, 8), 10) + parseInt(value.substr(8, 2), 10); 
 | 
            return (sum % 97 == 0); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Bulgarian VAT number Example: - Valid: BG175074752, 
 | 
         * BG7523169263, BG8032056031, BG7542011030, BG7111042925 - Invalid: 
 | 
         * BG175074753, BG7552A10004, BG7111042922 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _bg : function(value) { 
 | 
            if (!/^BG[0-9]{9,10}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
  
 | 
            var total = 0, sum = 0, weight = [], i = 0; 
 | 
  
 | 
            // Legal entities 
 | 
            if (value.length == 9) { 
 | 
                for (i = 0; i < 8; i++) { 
 | 
                    sum += parseInt(value.charAt(i)) * (i + 1); 
 | 
                } 
 | 
                sum = sum % 11; 
 | 
                if (sum == 10) { 
 | 
                    sum = 0; 
 | 
                    for (i = 0; i < 8; i++) { 
 | 
                        sum += parseInt(value.charAt(i)) * (i + 3); 
 | 
                    } 
 | 
                } 
 | 
                sum = sum % 10; 
 | 
                return (sum == value.substr(8)); 
 | 
            } 
 | 
            // Physical persons, foreigners and others 
 | 
            else if (value.length == 10) { 
 | 
                // Validate Bulgarian national identification numbers 
 | 
                var egn = function(value) { 
 | 
                    // Check the birth date 
 | 
                    var year = parseInt(value.substr(0, 2), 10) + 1900, month = parseInt(value.substr(2, 2), 10), day = parseInt(value.substr(4, 2), 10); 
 | 
                    if (month > 40) { 
 | 
                        year += 100; 
 | 
                        month -= 40; 
 | 
                    } else if (month > 20) { 
 | 
                        year -= 100; 
 | 
                        month -= 20; 
 | 
                    } 
 | 
  
 | 
                    if (!$.fn.bootstrapValidator.helpers.date(year, month, day)) { 
 | 
                        return false; 
 | 
                    } 
 | 
  
 | 
                    var sum = 0, weight = [ 2, 4, 8, 5, 10, 9, 7, 3, 6 ]; 
 | 
                    for (var i = 0; i < 9; i++) { 
 | 
                        sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
                    } 
 | 
                    sum = (sum % 11) % 10; 
 | 
                    return (sum == value.substr(9, 1)); 
 | 
                }, 
 | 
                // Validate Bulgarian personal number of a foreigner 
 | 
                pnf = function(value) { 
 | 
                    var sum = 0, weight = [ 21, 19, 17, 13, 11, 9, 7, 3, 1 ]; 
 | 
                    for (var i = 0; i < 9; i++) { 
 | 
                        sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
                    } 
 | 
                    sum = sum % 10; 
 | 
                    return (sum == value.substr(9, 1)); 
 | 
                }, 
 | 
                // Finally, consider it as a VAT number 
 | 
                vat = function(value) { 
 | 
                    var sum = 0, weight = [ 4, 3, 2, 7, 6, 5, 4, 3, 2 ]; 
 | 
                    for (var i = 0; i < 9; i++) { 
 | 
                        sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
                    } 
 | 
                    sum = 11 - sum % 11; 
 | 
                    if (sum == 10) { 
 | 
                        return false; 
 | 
                    } 
 | 
                    if (sum == 11) { 
 | 
                        sum = 0; 
 | 
                    } 
 | 
                    return (sum == value.substr(9, 1)); 
 | 
                }; 
 | 
                return (egn(value) || pnf(value) || vat(value)); 
 | 
            } 
 | 
  
 | 
            return false; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Swiss VAT number 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _ch : function(value) { 
 | 
            if (!/^CHE[0-9]{9}(MWST)?$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(3); 
 | 
            var sum = 0, weight = [ 5, 4, 3, 2, 7, 6, 5, 4 ]; 
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                sum += parseInt(value.charAt(i), 10) * weight[i]; 
 | 
            } 
 | 
  
 | 
            sum = 11 - sum % 11; 
 | 
            if (sum == 10) { 
 | 
                return false; 
 | 
            } 
 | 
            if (sum == 11) { 
 | 
                sum = 0; 
 | 
            } 
 | 
  
 | 
            return (sum == value.substr(8, 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Cypriot VAT number Examples: - Valid: CY10259033P - Invalid: 
 | 
         * CY10259033Z 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _cy : function(value) { 
 | 
            if (!/^CY[0-5|9]{1}[0-9]{7}[A-Z]{1}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
  
 | 
            // Do not allow to start with "12" 
 | 
            if (value.substr(0, 2) == '12') { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            // Extract the next digit and multiply by the counter. 
 | 
            var sum = 0, translation = { 
 | 
                '0' : 1, 
 | 
                '1' : 0, 
 | 
                '2' : 5, 
 | 
                '3' : 7, 
 | 
                '4' : 9, 
 | 
                '5' : 13, 
 | 
                '6' : 15, 
 | 
                '7' : 17, 
 | 
                '8' : 19, 
 | 
                '9' : 21 
 | 
            }; 
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                var temp = parseInt(value.charAt(i), 10); 
 | 
                if (i % 2 == 0) { 
 | 
                    temp = translation[temp + '']; 
 | 
                } 
 | 
                sum += temp; 
 | 
            } 
 | 
  
 | 
            sum = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'[sum % 26]; 
 | 
            return (sum == value.substr(8, 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Czech Republic VAT number Can be: i) Legal entities (8 digit 
 | 
         * numbers) ii) Individuals with a RC (the 9 or 10 digit Czech birth 
 | 
         * number) iii) Individuals without a RC (9 digit numbers beginning with 
 | 
         * 6) 
 | 
         *  
 | 
         * Examples: - Valid: i) CZ25123891; ii) CZ7103192745, CZ991231123; iii) 
 | 
         * CZ640903926 - Invalid: i) CZ25123890; ii) CZ1103492745, CZ590312123 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _cz : function(value) { 
 | 
            if (!/^CZ[0-9]{8,10}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
  
 | 
            var sum = 0, i = 0; 
 | 
            if (value.length == 8) { 
 | 
                // Do not allow to start with '9' 
 | 
                if (value.charAt(0) + '' == '9') { 
 | 
                    return false; 
 | 
                } 
 | 
  
 | 
                sum = 0; 
 | 
                for (i = 0; i < 7; i++) { 
 | 
                    sum += parseInt(value.charAt(i), 10) * (8 - i); 
 | 
                } 
 | 
                sum = 11 - sum % 11; 
 | 
                if (sum == 10) { 
 | 
                    sum = 0; 
 | 
                } 
 | 
                if (sum == 11) { 
 | 
                    sum = 1; 
 | 
                } 
 | 
  
 | 
                return (sum == value.substr(7, 1)); 
 | 
            } else if (value.length == 9 && (value.charAt(0) + '' == '6')) { 
 | 
                sum = 0; 
 | 
                // Skip the first (which is 6) 
 | 
                for (i = 0; i < 7; i++) { 
 | 
                    sum += parseInt(value.charAt(i + 1), 10) * (8 - i); 
 | 
                } 
 | 
                sum = 11 - sum % 11; 
 | 
                if (sum == 10) { 
 | 
                    sum = 0; 
 | 
                } 
 | 
                if (sum == 11) { 
 | 
                    sum = 1; 
 | 
                } 
 | 
                sum = [ 8, 7, 6, 5, 4, 3, 2, 1, 0, 9, 10 ][sum - 1]; 
 | 
                return (sum == value.substr(8, 1)); 
 | 
            } else if (value.length == 9 || value.length == 10) { 
 | 
                // Validate Czech birth number (Rodné číslo), which is also 
 | 
                // national identifier 
 | 
                var year = 1900 + parseInt(value.substr(0, 2)), month = parseInt(value.substr(2, 2)) % 50 % 20, day = parseInt(value.substr(4, 2)); 
 | 
                if (value.length == 9) { 
 | 
                    if (year >= 1980) { 
 | 
                        year -= 100; 
 | 
                    } 
 | 
                    if (year > 1953) { 
 | 
                        return false; 
 | 
                    } 
 | 
                } else if (year < 1954) { 
 | 
                    year += 100; 
 | 
                } 
 | 
  
 | 
                if (!$.fn.bootstrapValidator.helpers.date(year, month, day)) { 
 | 
                    return false; 
 | 
                } 
 | 
  
 | 
                // Check that the birth date is not in the future 
 | 
                if (value.length == 10) { 
 | 
                    var check = parseInt(value.substr(0, 9), 10) % 11; 
 | 
                    if (year < 1985) { 
 | 
                        check = check % 10; 
 | 
                    } 
 | 
                    return (check == value.substr(9, 1)); 
 | 
                } 
 | 
  
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            return false; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate German VAT number Examples: - Valid: DE136695976 - Invalid: 
 | 
         * DE136695978 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _de : function(value) { 
 | 
            if (!/^DE[0-9]{9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            return $.fn.bootstrapValidator.helpers.mod_11_10(value); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Danish VAT number Example: - Valid: DK13585628 - Invalid: 
 | 
         * DK13585627 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _dk : function(value) { 
 | 
            if (!/^DK[0-9]{8}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var sum = 0, weight = [ 2, 7, 6, 5, 4, 3, 2, 1 ]; 
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                sum += parseInt(value.charAt(i), 10) * weight[i]; 
 | 
            } 
 | 
  
 | 
            return (sum % 11 == 0); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Estonian VAT number Examples: - Valid: EE100931558, 
 | 
         * EE100594102 - Invalid: EE100594103 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _ee : function(value) { 
 | 
            if (!/^EE[0-9]{9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var sum = 0, weight = [ 3, 7, 1, 3, 7, 1, 3, 7, 1 ]; 
 | 
  
 | 
            for (var i = 0; i < 9; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
  
 | 
            return (sum % 10 == 0); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Spanish VAT number (NIF - Número de Identificación Fiscal) 
 | 
         * Can be: i) DNI (Documento nacional de identidad), for Spaniards ii) 
 | 
         * NIE (Número de Identificación de Extranjeros), for foreigners iii) 
 | 
         * CIF (Certificado de Identificación Fiscal), for legal entities and 
 | 
         * others 
 | 
         *  
 | 
         * Examples: - Valid: i) ES54362315K; ii) ESX2482300W, ESX5253868R; iii) 
 | 
         * ESM1234567L, ESJ99216582, ESB58378431, ESB64717838 - Invalid: i) 
 | 
         * ES54362315Z; ii) ESX2482300A; iii) ESJ99216583 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _es : function(value) { 
 | 
            if (!/^ES[0-9A-Z][0-9]{7}[0-9A-Z]$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var dni = function(value) { 
 | 
                var check = parseInt(value.substr(0, 8), 10); 
 | 
                check = 'TRWAGMYFPDXBNJZSQVHLCKE'[check % 23]; 
 | 
                return (check == value.substr(8, 1)); 
 | 
            }, nie = function(value) { 
 | 
                var check = [ 'XYZ'.indexOf(value.charAt(0)), value.substr(1) ].join(''); 
 | 
                check = parseInt(check, 10); 
 | 
                check = 'TRWAGMYFPDXBNJZSQVHLCKE'[check % 23]; 
 | 
                return (check == value.substr(8, 1)); 
 | 
            }, cif = function(value) { 
 | 
                var first = value.charAt(0), check; 
 | 
                if ('KLM'.indexOf(first) != -1) { 
 | 
                    // K: Spanish younger than 14 year old 
 | 
                    // L: Spanish living outside Spain without DNI 
 | 
                    // M: Granted the tax to foreigners who have no NIE 
 | 
                    check = parseInt(value.substr(1, 8), 10); 
 | 
                    check = 'TRWAGMYFPDXBNJZSQVHLCKE'[check % 23]; 
 | 
                    return (check == value.substr(8, 1)); 
 | 
                } else if ('ABCDEFGHJNPQRSUVW'.indexOf(first) != -1) { 
 | 
                    var sum = 0, weight = [ 2, 1, 2, 1, 2, 1, 2 ], temp = 0; 
 | 
  
 | 
                    for (var i = 0; i < 7; i++) { 
 | 
                        temp = parseInt(value.charAt(i + 1)) * weight[i]; 
 | 
                        if (temp > 9) { 
 | 
                            temp = Math.floor(temp / 10) + temp % 10; 
 | 
                        } 
 | 
                        sum += temp; 
 | 
                    } 
 | 
                    sum = 10 - sum % 10; 
 | 
                    return (sum == value.substr(8, 1) || 'JABCDEFGHI'[sum] == value.substr(8, 1)); 
 | 
                } 
 | 
  
 | 
                return false; 
 | 
            }; 
 | 
  
 | 
            var first = value.charAt(0); 
 | 
            if (/^[0-9]$/.test(first)) { 
 | 
                return dni(value); 
 | 
            } else if (/^[XYZ]$/.test(first)) { 
 | 
                return nie(value); 
 | 
            } else { 
 | 
                return cif(value); 
 | 
            } 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Finnish VAT number Examples: - Valid: FI20774740 - Invalid: 
 | 
         * FI20774741 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _fi : function(value) { 
 | 
            if (!/^FI[0-9]{8}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var sum = 0, weight = [ 7, 9, 10, 5, 8, 4, 2, 1 ]; 
 | 
  
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
  
 | 
            return (sum % 11 == 0); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate French VAT number (TVA - taxe sur la valeur ajoutée) It's 
 | 
         * constructed by a SIREN number, prefixed by two characters. 
 | 
         *  
 | 
         * Examples: - Valid: FR40303265045, FR23334175221, FRK7399859412, 
 | 
         * FR4Z123456782 - Invalid: FR84323140391 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _fr : function(value) { 
 | 
            if (!/^FR[0-9A-Z]{2}[0-9]{9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
  
 | 
            if (!$.fn.bootstrapValidator.helpers.luhn(value.substr(2))) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            if (/^[0-9]{2}$/.test(value.substr(0, 2))) { 
 | 
                // First two characters are digits 
 | 
                return value.substr(0, 2) == (parseInt(value.substr(2) + '12', 10) % 97); 
 | 
            } else { 
 | 
                // The first characters cann't be O and I 
 | 
                var alphabet = '0123456789ABCDEFGHJKLMNPQRSTUVWXYZ', check; 
 | 
                // First one is digit 
 | 
                if (/^[0-9]{1}$/.test(value.charAt(0))) { 
 | 
                    check = alphabet.indexOf(value.charAt(0)) * 24 + alphabet.indexOf(value.charAt(1)) - 10; 
 | 
                } else { 
 | 
                    check = alphabet.indexOf(value.charAt(0)) * 34 + alphabet.indexOf(value.charAt(1)) - 100; 
 | 
                } 
 | 
                return ((parseInt(value.substr(2), 10) + 1 + Math.floor(check / 11)) % 11) == (check % 11); 
 | 
            } 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate United Kingdom VAT number Example: - Valid: GB980780684 - 
 | 
         * Invalid: GB802311781 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _gb : function(value) { 
 | 
            if (!/^GB[0-9]{9}$/.test(value) // Standard 
 | 
                    && !/^GB[0-9]{12}$/.test(value) // Branches 
 | 
                    && !/^GBGD[0-9]{3}$/.test(value) // Government department 
 | 
                    && !/^GBHA[0-9]{3}$/.test(value) // Health authority 
 | 
                    && !/^GB(GD|HA)8888[0-9]{5}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var length = value.length; 
 | 
            if (length == 5) { 
 | 
                var firstTwo = value.substr(0, 2), lastThree = parseInt(value.substr(2)); 
 | 
                return ('GD' == firstTwo && lastThree < 500) || ('HA' == firstTwo && lastThree >= 500); 
 | 
            } else if (length == 11 && ('GD8888' == value.substr(0, 6) || 'HA8888' == value.substr(0, 6))) { 
 | 
                if (('GD' == value.substr(0, 2) && parseInt(value.substr(6, 3)) >= 500) || ('HA' == value.substr(0, 2) && parseInt(value.substr(6, 3)) < 500)) { 
 | 
                    return false; 
 | 
                } 
 | 
                return (parseInt(value.substr(6, 3)) % 97 == parseInt(value.substr(9, 2))); 
 | 
            } else if (length == 9 || length == 12) { 
 | 
                var sum = 0, weight = [ 8, 7, 6, 5, 4, 3, 2, 10, 1 ]; 
 | 
                for (var i = 0; i < 9; i++) { 
 | 
                    sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
                } 
 | 
                sum = sum % 97; 
 | 
  
 | 
                if (parseInt(value.substr(0, 3)) >= 100) { 
 | 
                    return (sum == 0 || sum == 42 || sum == 55); 
 | 
                } else { 
 | 
                    return (sum == 0); 
 | 
                } 
 | 
            } 
 | 
  
 | 
            return true; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Greek VAT number Examples: - Valid: GR023456780, EL094259216 - 
 | 
         * Invalid: EL123456781 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _gr : function(value) { 
 | 
            if (!/^GR[0-9]{9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            if (value.length == 8) { 
 | 
                value = '0' + value; 
 | 
            } 
 | 
  
 | 
            var sum = 0, weight = [ 256, 128, 64, 32, 16, 8, 4, 2 ]; 
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
            sum = (sum % 11) % 10; 
 | 
  
 | 
            return (sum == value.substr(8, 1)); 
 | 
        }, 
 | 
  
 | 
        // EL is traditionally prefix of Greek VAT numbers 
 | 
        _el : function(value) { 
 | 
            if (!/^EL[0-9]{9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = 'GR' + value.substr(2); 
 | 
            return this._gr(value); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Hungarian VAT number Examples: - Valid: HU12892312 - 
 | 
         * Invalid: HU12892313 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _hu : function(value) { 
 | 
            if (!/^HU[0-9]{8}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var sum = 0, weight = [ 9, 7, 3, 1, 9, 7, 3, 1 ]; 
 | 
  
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
  
 | 
            return (sum % 10 == 0); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Croatian VAT number Examples: - Valid: HR33392005961 - 
 | 
         * Invalid: HR33392005962 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _hr : function(value) { 
 | 
            if (!/^HR[0-9]{11}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            return $.fn.bootstrapValidator.helpers.mod_11_10(value); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Irish VAT number Examples: - Valid: IE6433435F, IE6433435OA, 
 | 
         * IE8D79739I - Invalid: IE8D79738J 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _ie : function(value) { 
 | 
            if (!/^IE[0-9]{1}[0-9A-Z\*\+]{1}[0-9]{5}[A-Z]{1,2}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var getCheckDigit = function(value) { 
 | 
                while (value.length < 7) { 
 | 
                    value = '0' + value; 
 | 
                } 
 | 
                var alphabet = 'WABCDEFGHIJKLMNOPQRSTUV', sum = 0; 
 | 
                for (var i = 0; i < 7; i++) { 
 | 
                    sum += parseInt(value.charAt(i)) * (8 - i); 
 | 
                } 
 | 
                sum += 9 * alphabet.indexOf(value.substr(7)); 
 | 
                return alphabet[sum % 23]; 
 | 
            }; 
 | 
  
 | 
            // The first 7 characters are digits 
 | 
            if (/^[0-9]+$/.test(value.substr(0, 7))) { 
 | 
                // New system 
 | 
                return value.charAt(7) == getCheckDigit(value.substr(0, 7) + value.substr(8) + ''); 
 | 
            } else if ('ABCDEFGHIJKLMNOPQRSTUVWXYZ+*'.indexOf(value.charAt(1)) != -1) { 
 | 
                // Old system 
 | 
                return value.charAt(7) == getCheckDigit(value.substr(2, 5) + value.substr(0, 1) + ''); 
 | 
            } 
 | 
  
 | 
            return true; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Italian VAT number, which consists of 11 digits. - First 7 
 | 
         * digits are a company identifier - Next 3 are the province of 
 | 
         * residence - The last one is a check digit 
 | 
         *  
 | 
         * Examples: - Valid: IT00743110157 - Invalid: IT00743110158 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _it : function(value) { 
 | 
            if (!/^IT[0-9]{11}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            if (parseInt(value.substr(0, 7)) == 0) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            var lastThree = parseInt(value.substr(7, 3)); 
 | 
            if ((lastThree < 1) || (lastThree > 201) && lastThree != 999 && lastThree != 888) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            return $.fn.bootstrapValidator.helpers.luhn(value); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Lithuanian VAT number It can be: - 9 digits, for legal 
 | 
         * entities - 12 digits, for temporarily registered taxpayers 
 | 
         *  
 | 
         * Examples: - Valid: LT119511515, LT100001919017, LT100004801610 - 
 | 
         * Invalid: LT100001919018 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _lt : function(value) { 
 | 
            if (!/^LT([0-9]{7}1[0-9]{1}|[0-9]{10}1[0-9]{1})$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var length = value.length, sum = 0; 
 | 
            for (var i = 0; i < length - 1; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * (1 + i % 9); 
 | 
            } 
 | 
            var check = sum % 11; 
 | 
            if (check == 10) { 
 | 
                sum = 0; 
 | 
                for (var i = 0; i < length - 1; i++) { 
 | 
                    sum += parseInt(value.charAt(i)) * (1 + (i + 2) % 9); 
 | 
                } 
 | 
            } 
 | 
            check = check % 11 % 10; 
 | 
            return (check == value.charAt(length - 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Luxembourg VAT number Examples: - Valid: LU15027442 - 
 | 
         * Invalid: LU15027443 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _lu : function(value) { 
 | 
            if (!/^LU[0-9]{8}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            return (value.substr(0, 6) % 89 == value.substr(6, 2)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Latvian VAT number Examples: - Valid: LV40003521600, 
 | 
         * LV16117519997 - Invalid: LV40003521601, LV16137519997 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _lv : function(value) { 
 | 
            if (!/^LV[0-9]{11}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var first = parseInt(value.charAt(0)), sum = 0, weight = [], i = 0, length = value.length; 
 | 
            if (first > 3) { 
 | 
                // Legal entity 
 | 
                sum = 0; 
 | 
                weight = [ 9, 1, 4, 8, 3, 10, 2, 5, 7, 6, 1 ]; 
 | 
                for (i = 0; i < length; i++) { 
 | 
                    sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
                } 
 | 
                sum = sum % 11; 
 | 
                return (sum == 3); 
 | 
            } else { 
 | 
                // Check birth date 
 | 
                var day = parseInt(value.substr(0, 2)), month = parseInt(value.substr(2, 2)), year = parseInt(value.substr(4, 2)); 
 | 
                year = year + 1800 + parseInt(value.charAt(6)) * 100; 
 | 
  
 | 
                if (!$.fn.bootstrapValidator.helpers.date(year, month, day)) { 
 | 
                    return false; 
 | 
                } 
 | 
  
 | 
                // Check personal code 
 | 
                sum = 0; 
 | 
                weight = [ 10, 5, 8, 4, 2, 1, 6, 3, 7, 9 ]; 
 | 
                for (i = 0; i < length - 1; i++) { 
 | 
                    sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
                } 
 | 
                sum = (sum + 1) % 11 % 10; 
 | 
                return (sum == value.charAt(length - 1)); 
 | 
            } 
 | 
  
 | 
            return true; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Maltese VAT number Examples: - Valid: MT11679112 - Invalid: 
 | 
         * MT11679113 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _mt : function(value) { 
 | 
            if (!/^MT[0-9]{8}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var sum = 0, weight = [ 3, 4, 6, 7, 8, 9, 10, 1 ]; 
 | 
  
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
  
 | 
            return (sum % 37 == 0); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Dutch VAT number Examples: - Valid: NL004495445B01 - 
 | 
         * Invalid: NL123456789B90 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _nl : function(value) { 
 | 
            if (!/^NL[0-9]{9}B[0-9]{2}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.substr(2); 
 | 
            var sum = 0, weight = [ 9, 8, 7, 6, 5, 4, 3, 2 ]; 
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
  
 | 
            sum = sum % 11; 
 | 
            if (sum > 9) { 
 | 
                sum = 0; 
 | 
            } 
 | 
            return (sum == value.substr(8, 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Norwegian VAT number 
 | 
         *  
 | 
         * @see http://www.brreg.no/english/coordination/number.html 
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _no : function(value) { 
 | 
            if (!/^NO[0-9]{9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.substr(2); 
 | 
            var sum = 0, weight = [ 3, 2, 7, 6, 5, 4, 3, 2 ]; 
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
  
 | 
            sum = 11 - sum % 11; 
 | 
            if (sum == 11) { 
 | 
                sum = 0; 
 | 
            } 
 | 
            return (sum == value.substr(8, 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Polish VAT number Examples: - Valid: PL8567346215 - Invalid: 
 | 
         * PL8567346216 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _pl : function(value) { 
 | 
            if (!/^PL[0-9]{10}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var sum = 0, weight = [ 6, 5, 7, 2, 3, 4, 5, 6, 7, -1 ]; 
 | 
  
 | 
            for (var i = 0; i < 10; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
  
 | 
            return (sum % 11 == 0); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Portuguese VAT number Examples: - Valid: PT501964843 - 
 | 
         * Invalid: PT501964842 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _pt : function(value) { 
 | 
            if (!/^PT[0-9]{9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var sum = 0, weight = [ 9, 8, 7, 6, 5, 4, 3, 2 ]; 
 | 
  
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
            sum = 11 - sum % 11; 
 | 
            if (sum > 9) { 
 | 
                sum = 0; 
 | 
            } 
 | 
            return (sum == value.substr(8, 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Romanian VAT number Examples: - Valid: RO18547290 - Invalid: 
 | 
         * RO18547291 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _ro : function(value) { 
 | 
            if (!/^RO[1-9][0-9]{1,9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
            value = value.substr(2); 
 | 
  
 | 
            var length = value.length, weight = [ 7, 5, 3, 2, 1, 7, 5, 3, 2 ].slice(10 - length), sum = 0; 
 | 
            for (var i = 0; i < length - 1; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
  
 | 
            sum = (10 * sum) % 11 % 10; 
 | 
            return (sum == value.substr(length - 1, 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Russian VAT number (Taxpayer Identification Number - INN) 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _ru : function(value) { 
 | 
            if (!/^RU([0-9]{9}|[0-9]{12})$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            if (value.length == 10) { 
 | 
                var sum = 0, weight = [ 2, 4, 10, 3, 5, 9, 4, 6, 8, 0 ]; 
 | 
                for (var i = 0; i < 10; i++) { 
 | 
                    sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
                } 
 | 
                sum = sum % 11; 
 | 
                if (sum > 9) { 
 | 
                    sum = sum % 10; 
 | 
                } 
 | 
  
 | 
                return (sum == value.substr(9, 1)); 
 | 
            } else if (value.length == 12) { 
 | 
                var sum1 = 0, weight1 = [ 7, 2, 4, 10, 3, 5, 9, 4, 6, 8, 0 ], sum2 = 0, weight2 = [ 3, 7, 2, 4, 10, 3, 5, 9, 4, 6, 8, 0 ]; 
 | 
  
 | 
                for (var i = 0; i < 11; i++) { 
 | 
                    sum1 += parseInt(value.charAt(i)) * weight1[i]; 
 | 
                    sum2 += parseInt(value.charAt(i)) * weight2[i]; 
 | 
                } 
 | 
                sum1 = sum1 % 11; 
 | 
                if (sum1 > 9) { 
 | 
                    sum1 = sum1 % 10; 
 | 
                } 
 | 
                sum2 = sum2 % 11; 
 | 
                if (sum2 > 9) { 
 | 
                    sum2 = sum2 % 10; 
 | 
                } 
 | 
  
 | 
                return (sum1 == value.substr(10, 1) && sum2 == value.substr(11, 1)); 
 | 
            } 
 | 
  
 | 
            return false; 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Serbian VAT number 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _rs : function(value) { 
 | 
            if (!/^RS[0-9]{9}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var sum = 10, temp = 0; 
 | 
            for (var i = 0; i < 8; i++) { 
 | 
                temp = (parseInt(value.charAt(i)) + sum) % 10; 
 | 
                if (temp == 0) { 
 | 
                    temp = 10; 
 | 
                } 
 | 
                sum = (2 * temp) % 11; 
 | 
            } 
 | 
  
 | 
            return ((sum + parseInt(value.substr(8, 1))) % 10 == 1); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Swedish VAT number Examples: - Valid: SE123456789701 - 
 | 
         * Invalid: SE123456789101 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _se : function(value) { 
 | 
            if (!/^SE[0-9]{10}01$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2, 10); 
 | 
            return $.fn.bootstrapValidator.helpers.luhn(value); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Slovenian VAT number Examples: - Valid: SI50223054 - 
 | 
         * Invalid: SI50223055 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _si : function(value) { 
 | 
            if (!/^SI[0-9]{8}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            var sum = 0, weight = [ 8, 7, 6, 5, 4, 3, 2 ]; 
 | 
  
 | 
            for (var i = 0; i < 7; i++) { 
 | 
                sum += parseInt(value.charAt(i)) * weight[i]; 
 | 
            } 
 | 
            sum = 11 - sum % 11; 
 | 
            if (sum == 10) { 
 | 
                sum = 0; 
 | 
            } 
 | 
            return (sum == value.substr(7, 1)); 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate Slovak VAT number Examples: - Valid: SK2022749619 - Invalid: 
 | 
         * SK2022749618 
 | 
         *  
 | 
         * @param {String} 
 | 
         *            value VAT number 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _sk : function(value) { 
 | 
            if (!/^SK[1-9][0-9][(2-4)|(6-9)][0-9]{7}$/.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.substr(2); 
 | 
            return (value % 11 == 0); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.vin = { 
 | 
        /** 
 | 
         * Validate an US VIN (Vehicle Identification Number) 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consist of key: - message: The invalid message 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '') { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            // Don't accept I, O, Q characters 
 | 
            if (!/^[a-hj-npr-z0-9]{8}[0-9xX][a-hj-npr-z0-9]{8}$/i.test(value)) { 
 | 
                return false; 
 | 
            } 
 | 
  
 | 
            value = value.toUpperCase(); 
 | 
            var chars = { 
 | 
                A : 1, 
 | 
                B : 2, 
 | 
                C : 3, 
 | 
                D : 4, 
 | 
                E : 5, 
 | 
                F : 6, 
 | 
                G : 7, 
 | 
                H : 8, 
 | 
                J : 1, 
 | 
                K : 2, 
 | 
                L : 3, 
 | 
                M : 4, 
 | 
                N : 5, 
 | 
                P : 7, 
 | 
                R : 9, 
 | 
                S : 2, 
 | 
                T : 3, 
 | 
                U : 4, 
 | 
                V : 5, 
 | 
                W : 6, 
 | 
                X : 7, 
 | 
                Y : 8, 
 | 
                Z : 9, 
 | 
                '1' : 1, 
 | 
                '2' : 2, 
 | 
                '3' : 3, 
 | 
                '4' : 4, 
 | 
                '5' : 5, 
 | 
                '6' : 6, 
 | 
                '7' : 7, 
 | 
                '8' : 8, 
 | 
                '9' : 9, 
 | 
                '0' : 0 
 | 
            }, weights = [ 8, 7, 6, 5, 4, 3, 2, 10, 0, 9, 8, 7, 6, 5, 4, 3, 2 ], sum = 0, length = value.length; 
 | 
            for (var i = 0; i < length; i++) { 
 | 
                sum += chars[value.charAt(i) + ''] * weights[i]; 
 | 
            } 
 | 
  
 | 
            var reminder = sum % 11; 
 | 
            if (reminder == 10) { 
 | 
                reminder = 'X'; 
 | 
            } 
 | 
  
 | 
            return reminder == value.charAt(8); 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 | 
; 
 | 
(function($) { 
 | 
    $.fn.bootstrapValidator.validators.zipCode = { 
 | 
        html5Attributes : { 
 | 
            message : 'message', 
 | 
            country : 'country' 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Return true if and only if the input value is a valid country zip 
 | 
         * code 
 | 
         *  
 | 
         * @param {BootstrapValidator} 
 | 
         *            validator The validator plugin instance 
 | 
         * @param {jQuery} 
 | 
         *            $field Field element 
 | 
         * @param {Object} 
 | 
         *            options Consist of key: - message: The invalid message - 
 | 
         *            country: The ISO 3166 country code 
 | 
         *  
 | 
         * Currently it supports the following countries: - US (United State) - 
 | 
         * CA (Canada) - DK (Denmark) - GB (United Kingdom) - IT (Italy) - NL 
 | 
         * (Netherlands) - SE (Sweden) 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        validate : function(validator, $field, options) { 
 | 
            var value = $field.val(); 
 | 
            if (value == '' || !options.country) { 
 | 
                return true; 
 | 
            } 
 | 
  
 | 
            var country = (options.country || 'US').toUpperCase(); 
 | 
            switch (country) { 
 | 
            case 'CA': 
 | 
                return /(?:A|B|C|E|G|J|K|L|M|N|P|R|S|T|V|X|Y){1}[0-9]{1}(?:A|B|C|E|G|J|K|L|M|N|P|R|S|T|V|X|Y){1}\s?[0-9]{1}(?:A|B|C|E|G|J|K|L|M|N|P|R|S|T|V|X|Y){1}[0-9]{1}/i.test(value); 
 | 
            case 'DK': 
 | 
                return /^(DK(-|\s)?)?\d{4}$/i.test(value); 
 | 
            case 'GB': 
 | 
                return this._gb(value); 
 | 
  
 | 
                // http://en.wikipedia.org/wiki/List_of_postal_codes_in_Italy 
 | 
            case 'IT': 
 | 
                return /^(I-|IT-)?\d{5}$/i.test(value); 
 | 
  
 | 
                // http://en.wikipedia.org/wiki/Postal_codes_in_the_Netherlands 
 | 
            case 'NL': 
 | 
                return /^[1-9][0-9]{3} ?(?!sa|sd|ss)[a-z]{2}$/i.test(value); 
 | 
  
 | 
            case 'SE': 
 | 
                return /^(S-)?\d{3}\s?\d{2}$/i.test(value); 
 | 
            case 'US': 
 | 
            default: 
 | 
                return /^\d{4,5}([\-]\d{4})?$/.test(value); 
 | 
            } 
 | 
        }, 
 | 
  
 | 
        /** 
 | 
         * Validate United Kingdom postcode Examples: - Standard: EC1A 1BB, W1A 
 | 
         * 1HQ, M1 1AA, B33 8TH, CR2 6XH, DN55 1PT - Special cases: AI-2640, 
 | 
         * ASCN 1ZZ, GIR 0AA 
 | 
         *  
 | 
         * @see http://en.wikipedia.org/wiki/Postcodes_in_the_United_Kingdom 
 | 
         * @param {String} 
 | 
         *            value The postcode 
 | 
         * @returns {Boolean} 
 | 
         */ 
 | 
        _gb : function(value) { 
 | 
            var firstChar = '[ABCDEFGHIJKLMNOPRSTUWYZ]', // Does not accept 
 | 
                                                            // QVX 
 | 
            secondChar = '[ABCDEFGHKLMNOPQRSTUVWXY]', // Does not accept IJZ 
 | 
            thirdChar = '[ABCDEFGHJKPMNRSTUVWXY]', fourthChar = '[ABEHMNPRVWXY]', fifthChar = '[ABDEFGHJLNPQRSTUWXYZ]', regexps = [ 
 | 
            // AN NAA, ANN NAA, AAN NAA, AANN NAA format 
 | 
            new RegExp('^(' + firstChar + '{1}' + secondChar + '?[0-9]{1,2})(\\s*)([0-9]{1}' + fifthChar + '{2})$', 'i'), 
 | 
            // ANA NAA 
 | 
            new RegExp('^(' + firstChar + '{1}[0-9]{1}' + thirdChar + '{1})(\\s*)([0-9]{1}' + fifthChar + '{2})$', 'i'), 
 | 
            // AANA NAA 
 | 
            new RegExp('^(' + firstChar + '{1}' + secondChar + '{1}?[0-9]{1}' + fourthChar + '{1})(\\s*)([0-9]{1}' + fifthChar + '{2})$', 'i'), 
 | 
  
 | 
            new RegExp('^(BF1)(\\s*)([0-6]{1}[ABDEFGHJLNPQRST]{1}[ABDEFGHJLNPQRSTUWZYZ]{1})$', 'i'), // BFPO 
 | 
                                                                                                        // postcodes 
 | 
            /^(GIR)(\s*)(0AA)$/i, // Special postcode GIR 0AA 
 | 
            /^(BFPO)(\s*)([0-9]{1,4})$/i, // Standard BFPO numbers 
 | 
            /^(BFPO)(\s*)(c\/o\s*[0-9]{1,3})$/i, // c/o BFPO numbers 
 | 
            /^([A-Z]{4})(\s*)(1ZZ)$/i, // Overseas Territories 
 | 
            /^(AI-2640)$/i // Anguilla 
 | 
            ]; 
 | 
            for (var i = 0; i < regexps.length; i++) { 
 | 
                if (regexps[i].test(value)) { 
 | 
                    return true; 
 | 
                } 
 | 
            } 
 | 
  
 | 
            return false; 
 | 
        } 
 | 
    }; 
 | 
}(window.jQuery)); 
 |