Вход Регистрация
Файл: CloudBox-main/CloudBox/admin_assets/js/bootstrapvalidator/bootstrapValidator.js
Строк: 4117
<?php
/**
 * 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(formoptions) {
        
this.$form   = $(form);
        
this.options = $.extend({}, BootstrapValidator.DEFAULT_OPTIONSoptions);

        
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 
3div document.createElement('div'), div.all || [];
            while (
div.innerHTML '<!--[if gt IE '+(++v)+']><br><![endif]-->'a[0]);
            return 
: !v;
        }());

        var 
el document.createElement('div');
        
this._changeEvent = (ieVersion === || !('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
        
thresholdnull,

        
// 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,
            
validatingnull
        
},

        
// 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
        //  }
        
submitHandlernull,

        
// 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
        
fieldsnull
    
};

    
BootstrapValidator.prototype = {
        
constructorBootstrapValidator,

        
/**
         * 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'),
                        
validatingthis.$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 ? {} : html5Attrsvalidators[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'),
                            
validatorsvalidators
                        
};

                        
// 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({}, optsoptions.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(truethis.optionsoptions);
            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 
0totali++) {
                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(fieldthat.STATUS_NOT_VALIDATEDnull)
                              : 
that.updateElementStatus($(this), that.STATUS_NOT_VALIDATEDnull);
                });

                
// 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.' validatorNamethis.STATUS_NOT_VALIDATED);

                    if (!
updateAll || == 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 || == 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 
cssClasses.length;
            for (var 
0ni++) {
                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(thisthisthis.$formthis.$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 
0lengthi++) {
                    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$fieldthis) == 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 
0totali++) {
                            (
'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)) ? fields.length;

            for (var 
0ni++) {
                
this.validateFieldElement($(fields[i]), (== 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($fieldupdateAll) {
            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.' validatorNamethis.STATUS_VALIDATING);
                
validateResult = $.fn.bootstrapValidator.validators[validatorName].validate(this$fieldvalidators[validatorName]);

                if (
'object' == typeof validateResult) {
                    
updateAll this.updateStatus(fieldthis.STATUS_VALIDATINGvalidatorName)
                              : 
this.updateElementStatus($fieldthis.STATUS_VALIDATINGvalidatorName);
                    
$field.data('bv.dfs.' validatorNamevalidateResult);

                    
validateResult.done(function($fvisValid) {
                        
// v is validator name
                        
$f.removeData('bv.dfs.' v);
                        
updateAll that.updateStatus($f.attr('data-bv-field'), isValid that.STATUS_VALID that.STATUS_INVALIDv)
                                  : 
that.updateElementStatus($fisValid that.STATUS_VALID that.STATUS_INVALIDv);

                        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(fieldvalidateResult this.STATUS_VALID this.STATUS_INVALIDvalidatorName)
                              : 
this.updateElementStatus($fieldvalidateResult this.STATUS_VALID this.STATUS_INVALIDvalidatorName);
                }
            }

            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(fieldstatusvalidatorName) {
            var 
fields this.getFieldElements(field),
                
type   fields.attr('type'),
                
n      = (('radio' == type) || ('checkbox' == type)) ? fields.length;

            for (var 
0ni++) {
                
this.updateElementStatus($(fields[i]), statusvalidatorName);
            }

            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($fieldstatusvalidatorName) {
            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.' validatorNamestatus);
            } else {
                for (var 
v in this.options.fields[field].validators) {
                    
$field.data('bv.result.' vstatus);
                }
            }

            
// 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'), = $(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'), = $(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 
fieldsfield$field,
                
typestatusvalidatorName,
                
ni;
            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)) ? fields.length;

                for (
0ni++) {
                    
$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 
fieldfieldstotaltypevalidator;
            for (
field in this.options.fields) {
                
fields this.getFieldElements(field);
                
total  fields.length;

                for (var 
0totali++) {
                    for (
validator in this.options.fields[field].validators) {
                        $(
fields[i]).removeData('bv.dfs.' validator);
                    }
                }

                
// Mark field as not validated yet
                
this.updateStatus(fieldthis.STATUS_NOT_VALIDATEDnull);

                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(fieldenabled) {
            
this.options.fields[field]['enabled'] = enabled;
            
this.updateStatus(fieldthis.STATUS_NOT_VALIDATEDnull);

            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(thisoptions);
                
$this.data('bootstrapValidator'data);
            }

            
// Allow to call plugin method
            
if ('string' == typeof option) {
                
data[option].apply(data, Array.prototype.slice.call(params1));
            }
        });
    };

    
// 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(yearmonthdaynotInFuture) {
            if (
year 1000 || year 9999 || month == || month 12) {
                return 
false;
            }
            var 
numDays = [312831303130313130313031];
            
// Update the number of days in Feb of leap year
            
if (year 400 == || (year 100 != && year == 0)) {
                
numDays[1] = 29;
            }

            
// Check the day
            
if (day || 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 currentMonth)
                        || (
year == currentYear && month == 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 = [[0123456789], [0246813579]],
                
sum     0;

            while (
length--) {
                
sum += prodArr[mul][parseInt(value.charAt(length), 10)];
                
mul ^= 1;
            }

            return (
sum 10 === && 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 
0lengthi++) {
                
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(valuealphabet) {
            
alphabet alphabet || '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ';
            var 
modulus alphabet.length,
                
length  value.length,
                
check   Math.floor(modulus 2);
            for (var 
0lengthi++) {
                
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$fieldoptions) {
            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$fieldoptions) {
            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$fieldoptions) {
            var 
value $field.val();
            if (
options.callback && 'function' == typeof options.callback) {
                var 
dfd = new $.Deferred();
                
dfd.resolve($field'callback'options.callback.call(thisvaluevalidator));
                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$fieldoptions) {
            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$fieldoptions) {
            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: [16171819],
                    
prefix: ['6304''6706''6771''6709']
                },
                
MAESTRO: {
                    
length: [1213141516171819],
                    
prefix: ['5018''5020''5038''6304''6759''6761''6762''6763''6764''6765''6766']
                },
                
MASTERCARD: {
                    
length: [16],
                    
prefix: ['51''52''53''54''55']
                },
                
SOLO: {
                    
length: [161819],
                    
prefix: ['6334''6767']
                },
                
UNIONPAY: {
                    
length: [16171819],
                    
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 
typei;
            for (
type in cards) {
                for (
i in cards[type]['prefix']) {
                    if (
value.substr(0cards[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$fieldoptions) {
            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 
0length 1i++) {
                var 
num parseInt(converted[i]);
                if (
!= 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$fieldoptions) {
            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: [16171819],
                    
prefix: ['6304''6706''6771''6709']
                },
                
MAESTRO: {
                    
length: [1213141516171819],
                    
prefix: ['5018''5020''5038''6304''6759''6761''6762''6763''6764''6765''6766']
                },
                
MASTERCARD: {
                    
length: [16],
                    
prefix: ['51''52''53''54''55']
                },
                
SOLO: {
                    
length: [161819],
                    
prefix: ['6334''6767']
                },
                
UNIONPAY: {
                    
length: [16171819],
                    
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 
typeicreditCardType null;
            for (
type in cards) {
                for (
i in cards[type]['prefix']) {
                    if (
creditCard.substr(0cards[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$fieldoptions) {
            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 nullhours nullseconds null;
            if (
timeFormat) {
                
timeFormat timeFormat.split(':'),
                
time       time.split(':');

                if (
timeFormat.length != time.length) {
                    return 
false;
                }

                
hours   time.length time[0] : null;
                
minutes time.length time[1] : null;
                
seconds time.length time[2] : null;

                
// Validate seconds
                
if (seconds) {
                    
seconds parseInt(seconds10);
                    if (
seconds || seconds 60) {
                        return 
false;
                    }
                }

                
// Validate hours
                
if (hours) {
                    
hours parseInt(hours10);
                    if (
hours || hours >= 24 || (amOrPm && hours 12)) {
                        return 
false;
                    }
                }

                
// Validate minutes
                
if (minutes) {
                    
minutes parseInt(minutes10);
                    if (
minutes || minutes 59) {
                        return 
false;
                    }
                }
            }

            
// Validate day, month, and year
            
day   parseInt(day10);
            
month parseInt(month10);
            
year  parseInt(year10);

            return $.
fn.bootstrapValidator.helpers.date(yearmonthday);
        }
    };
}(
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$fieldoptions) {
            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.fieldvalidator.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$fieldoptions) {
            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$fieldoptions) {
            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) ? [31] : [13];
            for (var 
0length 1i++) {
                
sum += parseInt(value.charAt(i)) * weight[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$fieldoptions) {
            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$fieldoptions) {
            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 
0totali++) {
                    
// 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 {
                    
valuemin
                
};
            }

            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$fieldoptions) {
            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$fieldoptions) {
            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(05)) {
                
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$fieldoptions) {
            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$fieldoptions) {
            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$fieldoptions) {
            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(02);
            if (!
ibanRegex[country]) {
                return 
false;
            }
            if (!(new 
RegExp('^' ibanRegex[country] + '$')).test(value)) {
                return 
false;
            }

            
value value.substr(4) + value.substr(04);
            
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(01), 10),
                
length value.length;
            for (var 
1length; ++i) {
                
temp = (temp 10 parseInt(value.substr(i1), 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$fieldoptions) {
            var 
value $field.val();
            if (
value == '') {
                return 
true;
            }

            var 
country options.country || value.substr(02),
                
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(valuecountryCode) {
            if (!/^
d{13}$/.test(value)) {
                return 
false;
            }
            var 
day   parseInt(value.substr(02), 10),
                
month parseInt(value.substr(22), 10),
                
year  parseInt(value.substr(43), 10),
                
rr    parseInt(value.substr(72), 10),
                
k     parseInt(value.substr(121), 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 
06i++) {
                
sum += (i) * (parseInt(value.charAt(i)) + parseInt(value.charAt(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}sd{3}sd{1}$/.test(value)) {
                return 
false;
            }
            
value value.replace(/s/g'');
            
// Check the birth date
            
var year  parseInt(value.substr(02), 10) + 1900,
                
month parseInt(value.substr(22), 10),
                
day   parseInt(value.substr(42), 10);
            if (
month 40) {
                
year += 100;
                
month -= 40;
            } else if (
month 20) {
                
year -= 100;
                
month -= 20;
            }

            if (!$.
fn.bootstrapValidator.helpers.date(yearmonthday)) {
                return 
false;
            }

            var 
sum    0,
                
weight = [2485109736];
            for (var 
09i++) {
                
sum += parseInt(value.charAt(i)) * weight[i];
            }
            
sum = (sum 11) % 10;
            return (
sum == value.substr(91));
        },

        
/**
         * 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 
09i++) {
                
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 (
010i++) {
                
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) ? [31] : [13];
            for (var 
0length 1i++) {
                
sum += parseInt(value.charAt(i)) * weight[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 = [32765432];
            for (var 
08i++) {
                
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(02)),
                
month parseInt(value.substr(22)) % 50 20,
                
day   parseInt(value.substr(42));
            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(yearmonthday)) {
                return 
false;
            }

            
// Check that the birth date is not in the future
            
if (value.length == 10) {
                var 
check parseInt(value.substr(09), 10) % 11;
                if (
year 1985) {
                    
check check 10;
                }
                return (
check == value.substr(91));
            }

            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(02), 10),
                
month parseInt(value.substr(22), 10),
                
year  parseInt(value.substr(42), 10);

            switch (
true) {
                case (
'5678'.indexOf(value.charAt(6)) != -&& year >= 58):
                    
year += 1800;
                    break;
                case (
'0123'.indexOf(value.charAt(6)) != -1):
                case (
'49'.indexOf(value.charAt(6)) != -&& year >= 37):
                    
year += 1900;
                    break;
                default:
                    
year += 2000;
                    break;
            }

            return $.
fn.bootstrapValidator.helpers.date(yearmonthday);
        },

        
/**
         * 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(08), 10);
            
check 'TRWAGMYFPDXBNJZSQVHLCKE'[check 23];
            return (
check == value.substr(81));
        },

        
/**
         * 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(02), 10),
                
month     parseInt(value.substr(22), 10),
                
year      parseInt(value.substr(42), 10),
                
centuries = {
                    
'+'1800,
                    
'-'1900,
                    
'A'2000
                
};
            
year centuries[value.charAt(6)] + year;

            if (!$.
fn.bootstrapValidator.helpers.date(yearmonthday)) {
                return 
false;
            }

            var 
individual parseInt(value.substr(73));
            if (
individual 2) {
                return 
false;
            }
            var 
value.substr(06) + value.substr(73) + '';
            
parseInt(n);
            return 
'0123456789ABCDEFHJKLMNPRSTUVWXY'.charAt(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 
07i++) {
                    
sum += parseInt(value.charAt(i)) * (i);
                }
                
sum += alphabet.indexOf(value.substr(7));
                return 
alphabet[sum 23];
            };

            
// 2013 format
            
if (value.length == && ('A' == value.charAt(8) || 'H' == value.charAt(8))) {
                return 
value.charAt(7) == getCheckDigit(value.substr(07) + value.substr(8) + '');
            }
            
// The old format
            
else {
                return 
value.charAt(7) == getCheckDigit(value.substr(07));
            }
        },

        
/**
         * 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(02), 10),
                
month   parseInt(value.substr(22), 10),
                
year    parseInt(value.substr(42), 10),
                
century parseInt(value.charAt(9));

            
year = (century == 9) ? (1900 year) : ((20 century) * 100 year);
            if (!$.
fn.bootstrapValidator.helpers.date(yearmonthdaytrue)) {
                return 
false;
            }
            
// Validate the check digit
            
var sum    0,
                
weight = [32765432];
            for (var 
08i++) {
                
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(12), 10),
                
month   parseInt(value.substr(32), 10),
                
day     parseInt(value.substr(52), 10),
                
century = (gender == 0) ? (17 gender 2) : (17 + (gender 1) / 2);
            
year century 100 year;
            if (!$.
fn.bootstrapValidator.helpers.date(yearmonthdaytrue)) {
                return 
false;
            }

            
// Validate the check digit
            
var sum    0,
                
weight = [1234567891];
            for (var 
010i++) {
                
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 = [3456789123];
            for (
010i++) {
                
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(02)),
                
month parseInt(value.substr(22)),
                
year  parseInt(value.substr(42));
            
year year 1800 parseInt(value.charAt(6)) * 100;

            if (!$.
fn.bootstrapValidator.helpers.date(yearmonthdaytrue)) {
                return 
false;
            }

            
// Check personal code
            
var sum    0,
                
weight = [10584216379];
            for (var 
010i++) {
                
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(value10) == 0) {
                return 
false;
            }
            var 
sum    0,
                
length value.length;
            for (var 
0length 1i++) {
                
sum += (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 == || gender == || gender == 8) {
                return 
false;
            }

            
// Determine the date of birth
            
var year      parseInt(value.substr(12), 10),
                
month     parseInt(value.substr(32), 10),
                
day       parseInt(value.substr(52), 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(yearmonthday)) {
                    return 
false;
                }
            }

            
// Validate the check digit
            
var sum    0,
                
weight = [279146358279],
                
length value.length;
            for (var 
0length 1i++) {
                
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(02)) + 1900,
                
month parseInt(value.substr(22)),
                
day   parseInt(value.substr(42));
            if (!$.
fn.bootstrapValidator.helpers.date(yearmonthday)) {
                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(02)),
                
currentYear = new Date().getFullYear() % 100,
                
month       parseInt(value.substr(22)),
                
day         parseInt(value.substr(42));
            
year = (year >= currentYear) ? (year 1900) : (year 2000);

            if (!$.
fn.bootstrapValidator.helpers.date(yearmonthday)) {
                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$fieldoptions) {
            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.fieldvalidator.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$fieldoptions) {
            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}sd{6}sd{6}sd{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}sd{6}sd{6}(|sd{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$fieldoptions) {
            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$fieldoptions) {
            var 
value $field.val();
            if (
value == '') {
                return 
true;
            }
            
options = $.extend({}, { ipv4trueipv6true }, 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|1dd|[1-9]?d)(.(25[0-5]|2[0-4]d|1dd|[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|1dd|[1-9]?d)(.(25[0-5]|2[0-4]d|1dd|[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|1dd|[1-9]?d)(.(25[0-5]|2[0-4]d|1dd|[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|1dd|[1-9]?d)(.(25[0-5]|2[0-4]d|1dd|[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|1dd|[1-9]?d)(.(25[0-5]|2[0-4]d|1dd|[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|1dd|[1-9]?d)(.(25[0-5]|2[0-4]d|1dd|[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|1dd|[1-9]?d)(.(25[0-5]|2[0-4]d|1dd|[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$fieldoptions) {
            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 
0length 1i++) {
                        
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 
0length 1i++) {
                        
sum += ((== 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$fieldoptions) {
            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 0length 1i++) {
                var 
value.charCodeAt(i);
                
converted += ((57) ? (55).toString() : value.charAt(i));
            }

            var 
digits '',
                
n      converted.length,
                
group  = (!= 0) ? 1;
            for (
0ni++) {
                
digits += (parseInt(converted[i]) * ((2) == group 1) + '');
            }

            var 
sum 0;
            for (
0digits.lengthi++) {
                
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$fieldoptions) {
            var 
value $field.val();
            if (
value == '') {
                return 
true;
            }

            
// Groups are separated by a hyphen or a space
            
var type;
            switch (
true) {
                case /^
Md{9}$/.test(value):
                case /^
M-d{4}-d{4}-d{1}$/.test(value):
                case /^
Msd{4}sd{4}sd{1}$/.test(value):
                    
type 'ISMN10';
                    break;
                case /^
9790d{9}$/.test(value):
                case /^
979-0-d{4}-d{4}-d{1}$/.test(value):
                case /^
979s0sd{4}sd{4}sd{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 = [13];
            for (var 
0length 1i++) {
                
sum += parseInt(value.charAt(i)) * weight[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$fieldoptions) {
            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 
0lengthi++) {
                
sum += ((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 {
                    
valuemax
                
};
            }

            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$fieldoptions) {
            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$fieldoptions) {
            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$fieldoptions) {
            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$fieldoptions) {
            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$fieldoptions) {
            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-?)|(+?))?(?(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 {
                    
regexppattern
                
};
            }

            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$fieldoptions) {
            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$fieldoptions) {
            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(thisvalidator);
            }
            
data[options.name || name] = value;

            var 
dfd = new $.Deferred();
            var 
xhr = $.ajax({
                
type'POST',
                
urloptions.url,
                
dataType'json',
                
datadata
            
});
            
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$fieldoptions) {
            var 
value $field.val();
            if (
value == '') {
                return 
true;
            }

            if (!/^
d{9}$/.test(value)) {
                return 
false;
            }

            var 
sum 0;
            for (var 
0value.length+= 3) {
                
sum += parseInt(value.charAt(i),     10) * 3
                    
+  parseInt(value.charAt(1), 10) * 7
                    
+  parseInt(value.charAt(2), 10);
            }
            return (
sum != && 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$fieldoptions) {
            var 
value $field.val();
            if (
value == '') {
                return 
true;
            }

            
value value.toUpperCase();
            if (!/^[
0-9A-Z]{7}$/.test(value)) {
                return 
false;
            }

            var 
sum    0,
                
weight = [1317391],
                
length value.length;
            for (var 
0length 1i++) {
                
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$fieldoptions) {
            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$fieldoptions) {
            var 
value $field.val();
            if (
value == '') {
                return 
true;
            }

            var 
sum    0,
                
length value.length,
                
tmp;
            for (var 
0lengthi++) {
                
tmp parseInt(value.charAt(i), 10);
                if ((
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$fieldoptions) {
            var 
value $field.val();
            if (
value == '') {
                return 
true;
            }

            
options = $.extend({}, { baseValue0step}, options);
            
value   parseFloat(value);
            if (
isNaN(value) || !isFinite(value)) {
                return 
false;
            }

            var 
round = function(xprecision) {
                    var 
Math.pow(10precision);
                    
m;
                    var 
sign   = (0) | -(0),
                        
isHalf = (=== 0.5 sign);
                    if (
isHalf) {
                        return (
Math.floor(x) + (sign 0)) / m;
                    } else {
                        return 
Math.round(x) / m;
                    }
                },
                
floatMod = function(xy) {
                    if (
== 0.0) {
                        return 
1.0;
                    }
                    var 
dotX      = ('').split('.'),
                        
dotY      = ('').split('.'),
                        
precision = ((dotX.length == 1) ? dotX[1].length) + ((dotY.length == 1) ? dotY[1].length);
                    return 
round(Math.floor(y), precision);
                };

            var 
mod floatMod(value options.baseValueoptions.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$fieldoptions) {
            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 {
                    
maxparseInt(maxLength10)
                };
            }

            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$fieldoptions) {
            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$fieldoptions) {
            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]|2d|3[0-1])(?:.d{1,3}){2})(?:[1-9]d?|1dd|2[01]d|22[0-3])(?:.(?:1?d{1,2}|2[0-4]d|25[0-5])){2}(?:.(?:[1-9]d?|1dd|2[0-4]d|25[0-4]))|(?:(?:[a-zu00a1-uffff0-9]+-?)*[a-zu00a1-uffff0-9]+)(?:.(?:[a-zu00a1-uffff0-9]+-?)*[a-zu00a1-uffff0-9]+)*(?:.(?:[a-zu00a1-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]|2d|3[0-1])(?:.d{1,3}){2})(?:[1-9]d?|1dd|2[01]d|22[0-3])(?:.(?:1?d{1,2}|2[0-4]d|25[0-5])){2}(?:.(?:[1-9]d?|1dd|2[0-4]d|25[0-4]))|(?:(?:[a-zx{00a1}-x{ffff}0-9]+-?)*[a-zx{00a1}-x{ffff}0-9]+)(?:.(?:[a-zx{00a1}-x{ffff}0-9]+-?)*[a-zx{00a1}-x{ffff}0-9]+)*(?:.(?:[a-zx{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$fieldoptions) {
            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$fieldoptions) {
            var 
value $field.val();
            if (
value == '') {
                return 
true;
            }

            var 
country options.country || value.substr(02),
                
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 = [1212121],
                
temp   0;

            for (var 
07i++) {
                
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(71));
        },

        
/**
         * 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(11) == 0) {
                return 
false;
            }

            var 
sum parseInt(value.substr(08), 10) + parseInt(value.substr(82), 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 0sum 0weight = [], 0;

            
// Legal entities
            
if (value.length == 9) {
                for (
08i++) {
                    
sum += parseInt(value.charAt(i)) * (1);
                }
                
sum sum 11;
                if (
sum == 10) {
                    
sum 0;
                    for (
08i++) {
                        
sum += parseInt(value.charAt(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(02), 10) + 1900,
                            
month parseInt(value.substr(22), 10),
                            
day   parseInt(value.substr(42), 10);
                        if (
month 40) {
                            
year += 100;
                            
month -= 40;
                        } else if (
month 20) {
                            
year -= 100;
                            
month -= 20;
                        }

                        if (!$.
fn.bootstrapValidator.helpers.date(yearmonthday)) {
                            return 
false;
                        }

                        var 
sum    0,
                            
weight = [2485109736];
                        for (var 
09i++) {
                            
sum += parseInt(value.charAt(i)) * weight[i];
                        }
                        
sum = (sum 11) % 10;
                        return (
sum == value.substr(91));
                    },
                    
// Validate Bulgarian personal number of a foreigner
                    
pnf = function(value) {
                        var 
sum    0,
                            
weight = [21191713119731];
                        for (var 
09i++) {
                            
sum += parseInt(value.charAt(i)) * weight[i];
                        }
                        
sum sum 10;
                        return (
sum == value.substr(91));
                    },
                    
// Finally, consider it as a VAT number
                    
vat = function(value) {
                        var 
sum    0,
                            
weight = [432765432];
                        for (var 
09i++) {
                            
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(91));
                    };
                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 = [54327654];
            for (var 
08i++) {
                
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(81));
        },

        
/**
         * 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(02) == '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 
08i++) {
                var 
temp parseInt(value.charAt(i), 10);
                if (
== 0) {
                    
temp translation[temp ''];
                }
                
sum += temp;
            }

            
sum 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'[sum 26];
            return (
sum == value.substr(81));
        },

        
/**
         * 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 (
07i++) {
                    
sum += parseInt(value.charAt(i), 10) * (i);
                }
                
sum 11 sum 11;
                if (
sum == 10) {
                    
sum 0;
                }
                if (
sum == 11) {
                    
sum 1;
                }

                return (
sum == value.substr(71));
            } else if (
value.length == && (value.charAt(0) + '' == '6')) {
                
sum 0;
                
// Skip the first (which is 6)
                
for (07i++) {
                    
sum += parseInt(value.charAt(1), 10) * (i);
                }
                
sum 11 sum 11;
                if (
sum == 10) {
                    
sum 0;
                }
                if (
sum == 11) {
                    
sum 1;
                }
                
sum = [876543210910][sum 1];
                return (
sum == value.substr(81));
            } else if (
value.length == || value.length == 10) {
                
// Validate Czech birth number (Rodné číslo), which is also national identifier
                
var year  1900 parseInt(value.substr(02)),
                    
month parseInt(value.substr(22)) % 50 20,
                    
day   parseInt(value.substr(42));
                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(yearmonthday)) {
                    return 
false;
                }

                
// Check that the birth date is not in the future
                
if (value.length == 10) {
                    var 
check parseInt(value.substr(09), 10) % 11;
                    if (
year 1985) {
                        
check check 10;
                    }
                    return (
check == value.substr(91));
                }

                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 = [27654321];
            for (var 
08i++) {
                
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 = [371371371];

            for (var 
09i++) {
                
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(08), 10);
                    
check 'TRWAGMYFPDXBNJZSQVHLCKE'[check 23];
                    return (
check == value.substr(81));
                },
                
nie = function(value) {
                    var 
check = ['XYZ'.indexOf(value.charAt(0)), value.substr(1)].join('');
                    
check parseInt(check10);
                    
check 'TRWAGMYFPDXBNJZSQVHLCKE'[check 23];
                    return (
check == value.substr(81));
                },
                
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(18), 10);
                        
check 'TRWAGMYFPDXBNJZSQVHLCKE'[check 23];
                        return (
check == value.substr(81));
                    } else if (
'ABCDEFGHJNPQRSUVW'.indexOf(first) != -1) {
                        var 
sum    0,
                            
weight = [2121212],
                            
temp   0;

                        for (var 
07i++) {
                            
temp parseInt(value.charAt(1)) * weight[i];
                            if (
temp 9) {
                                
temp Math.floor(temp 10) + temp 10;
                            }
                            
sum += temp;
                        }
                        
sum 10 sum 10;
                        return (
sum == value.substr(81) || 'JABCDEFGHI'[sum] == value.substr(81));
                    }

                    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 = [791058421];

            for (var 
08i++) {
                
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(02))) {
                
// First two characters are digits
                
return value.substr(02) == (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) + 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(02),
                    
lastThree parseInt(value.substr(2));
                return (
'GD' == firstTwo && lastThree 500) || ('HA' == firstTwo && lastThree >= 500);
            } else if (
length == 11 && ('GD8888' == value.substr(06) || 'HA8888' == value.substr(06))) {
                if ((
'GD' == value.substr(02) && parseInt(value.substr(63)) >= 500)
                    || (
'HA' == value.substr(02) && parseInt(value.substr(63)) < 500))
                {
                    return 
false;
                }
                return (
parseInt(value.substr(63)) % 97 == parseInt(value.substr(92)));
            } else if (
length == || length == 12) {
                var 
sum    0,
                    
weight = [8765432101];
                for (var 
09i++) {
                    
sum += parseInt(value.charAt(i)) * weight[i];
                }
                
sum sum 97;

                if (
parseInt(value.substr(03)) >= 100) {
                    return (
sum == || 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 = [256128643216842];
            for (var 
08i++) {
                
sum += parseInt(value.charAt(i)) * weight[i];
            }
            
sum = (sum 11) % 10;

            return (
sum == value.substr(81));
        },

        
// 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 = [97319731];

            for (var 
08i++) {
                
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 
07i++) {
                    
sum += parseInt(value.charAt(i)) * (i);
                }
                
sum += alphabet.indexOf(value.substr(7));
                return 
alphabet[sum 23];
            };

            
// The first 7 characters are digits
            
if (/^[0-9]+$/.test(value.substr(07))) {
                
// New system
                
return value.charAt(7) == getCheckDigit(value.substr(07) + value.substr(8) + '');
            } else if (
'ABCDEFGHIJKLMNOPQRSTUVWXYZ+*'.indexOf(value.charAt(1)) != -1) {
                
// Old system
                
return value.charAt(7) == getCheckDigit(value.substr(25) + value.substr(01) + '');
            }

            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(07)) == 0) {
                return 
false;
            }

            var 
lastThree parseInt(value.substr(73));
            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 
0length 1i++) {
                
sum += parseInt(value.charAt(i)) * (9);
            }
            var 
check sum 11;
            if (
check == 10) {
                
sum 0;
                for (var 
0length 1i++) {
                    
sum += parseInt(value.charAt(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(06) % 89 == value.substr(62));
        },

        
/**
         * 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 = [914831025761];
                for (
0lengthi++) {
                    
sum += parseInt(value.charAt(i)) * weight[i];
                }
                
sum sum 11;
                return (
sum == 3);
            } else {
                
// Check birth date
                
var day   parseInt(value.substr(02)),
                    
month parseInt(value.substr(22)),
                    
year  parseInt(value.substr(42));
                
year year 1800 parseInt(value.charAt(6)) * 100;

                if (!$.
fn.bootstrapValidator.helpers.date(yearmonthday)) {
                    return 
false;
                }

                
// Check personal code
                
sum    0;
                
weight = [10584216379];
                for (
0length 1i++) {
                    
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 = [346789101];

            for (var 
08i++) {
                
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 = [98765432];
            for (var 
08i++) {
                
sum += parseInt(value.charAt(i)) * weight[i];
            }

            
sum sum 11;
            if (
sum 9) {
                
sum 0;
            }
            return (
sum == value.substr(81));
        },

        
/**
         * 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 = [32765432];
            for (var 
08i++) {
                
sum += parseInt(value.charAt(i)) * weight[i];
            }

            
sum 11 sum 11;
            if (
sum == 11) {
                
sum 0;
            }
            return (
sum == value.substr(81));
        },

        
/**
         * 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 = [657234567, -1];

            for (var 
010i++) {
                
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 = [98765432];

            for (var 
08i++) {
                
sum += parseInt(value.charAt(i)) * weight[i];
            }
            
sum 11 sum 11;
            if (
sum 9) {
                
sum 0;
            }
            return (
sum == value.substr(81));
        },

        
/**
         * 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 = [753217532].slice(10 length),
                
sum    0;
            for (var 
0length 1i++) {
                
sum += parseInt(value.charAt(i)) * weight[i];
            }

            
sum = (10 sum) % 11 10;
            return (
sum == value.substr(length 11));
        },

        
/**
         * 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 = [24103594680];
                for (var 
010i++) {
                    
sum += parseInt(value.charAt(i)) * weight[i];
                }
                
sum sum 11;
                if (
sum 9) {
                    
sum sum 10;
                }

                return (
sum == value.substr(91));
            } else if (
value.length == 12) {
                var 
sum1    0,
                    
weight1 = [724103594680],
                    
sum2    0,
                    
weight2 = [3724103594680];

                for (var 
011i++) {
                    
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(101) && sum2 == value.substr(111));
            }

            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 
08i++) {
                
temp = (parseInt(value.charAt(i)) + sum) % 10;
                if (
temp == 0) {
                    
temp 10;
                }
                
sum = (temp) % 11;
            }

            return ((
sum parseInt(value.substr(81))) % 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(210);
            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 = [8765432];

            for (var 
07i++) {
                
sum += parseInt(value.charAt(i)) * weight[i];
            }
            
sum 11 sum 11;
            if (
sum == 10) {
                
sum 0;
            }
            return (
sum == value.substr(71));
        },

        
/**
         * 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$fieldoptions) {
            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   = {
                    
A1,   B2,   C3,   D4,   E5,   F6,   G7,   H8,
                    
J1,   K2,   L3,   M4,   N5,           P7,           R9,
                            
S2,   T3,   U4,   V5,   W6,   X7,   Y8,   Z9,
                    
'1'1'2'2'3'3'4'4'5'5'6'6'7'7'8'8'9'9'0'0
                
},
                
weights = [876543210098765432],
                
sum     0,
                
length  value.length;
            for (var 
0lengthi++) {
                
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$fieldoptions) {
            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/os*[0-9]{1,3})$/i,        // c/o BFPO numbers
                    
/^([A-Z]{4})(s*)(1ZZ)$/i,                  // Overseas Territories
                    
/^(AI-2640)$/i                              // Anguilla
                
];
            for (var 
0regexps.lengthi++) {
                if (
regexps[i].test(value)) {
                    return 
true;
                }
            }

            return 
false;
        }
    };
}(
window.jQuery));
?>
Онлайн: 1
Реклама