<!DOCTYPE html>
<html>
<head>
<link href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.css" rel="stylesheet" data-semver="3.3.6" data-require="bootstrap-css@*" />
<link data-require="font-awesome@*" data-semver="4.5.0" rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.5.0/css/font-awesome.css" />
<script data-require="jquery@1.11.3" data-semver="1.11.3" src="//code.jquery.com/jquery-1.11.3.min.js"></script>
<script data-require="angular.js@1.5.0" data-semver="1.5.0" src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js"></script>
<script data-require="ui-bootstrap@*" data-semver="1.1.1" src="//cdn.rawgit.com/angular-ui/bootstrap/gh-pages/ui-bootstrap-1.1.1.js"></script>
<link href="style.css" rel="stylesheet" />
<!--<script src="abv.js"></script>-->
<script src="//rawgit.com/trajano/angular-bootstrap-validator/master/angular-bootstrap-validator.js"></script>
<script src="script.js"></script>
</head>
<body ng-app="myapp">
<h1>Hello Plunker!</h1>
<form name="myForm" abv-form="">
<fieldset class="form-group has-feedback">
<label for="email">E-mail</label>
<input class="form-control " type="email" required="" id="email" />
<div class="help-block with-errors" data-abv-error="required">E-mail is required</div>
<div class="help-block with-errors" data-abv-error="email">E-mail not valid</div>
</fieldset>
<fieldset class="form-group has-feedback">
<label for="password">Password</label>
<input class="form-control" type="password" required="" id="password" />
<div class="help-block with-errors" data-abv-error="required">Password is required</div>
</fieldset>
<fieldset class="form-group has-feedback">
<label for="confirmPassword">Confirm Password</label>
<input class="form-control" type="password" required="" id="confirmPassword" abv-identical="password" ng-model="confirmPassword"/>
<div class="help-block with-errors" data-abv-error="required">Confirmation password is required</div>
<div class="help-block with-errors" data-abv-error="abvIdentical">Confirmation does not match</div>
</fieldset>
<div class="form-group">
<button class="btn btn-primary" type="submit">Register</button>
</div>
</form>
<pre>{{ myForm | json }}</pre>
</body>
</html>
angular.module('myapp', ['ui.bootstrap', 'angular.bootstrap.validator'])
/* Styles go here */
This is an example of doing validation using Angular and Bootstrap.
"use strict";
;(function () {
"use strict";
angular.module('angular.bootstrap.validator', []);
})();
;(function () {
"use strict";
angular.module('angular.bootstrap.validator').directive('abvDifferent', function () {
return {
restrict: 'A',
scope: {
targetModel: '=abvDifferent'
},
require: 'ngModel',
link: function link(scope, element, attributes, ngModel) {
ngModel.$validators.abvDifferent = function (modelValue) {
return modelValue !== scope.targetModel;
};
scope.$watch('targetModel', function () {
ngModel.$validate();
});
}
};
});
})();
;(function () {
"use strict";
angular.module('angular.bootstrap.validator').directive('abvError', function ($animate, $log) {
return {
restrict: 'A',
scope: {
validatorName: '@abvError',
oldControlName: '@abvModel',
controlName: '@abvFor'
},
require: '^form',
terminal: true,
link: function link(scope, element, attrs, form) {
console.log('hello')
var controlName;
if (scope.oldControlName) {
$log.warn('abv-model is deprecated use abv-for');
scope.controlName = scope.oldControlName;
}
if (scope.controlName) {
controlName = scope.controlName;
} else {
if (element.siblings('.form-control')[0]) {
controlName = element.siblings('.form-control')[0].name;
} else {
controlName = element.parent().find('input[type="checkbox"]')[0].name;
}
}
var formName = "$parent." + form.$name;
var watchExpr = formName + ".$submitted && " + formName + "." + controlName + ".$error." + scope.validatorName;
scope.$watch(watchExpr, function (value) {
$animate[value ? 'removeClass' : 'addClass'](element, 'ng-hide', {
tempClasses: 'ng-hide-animate'
});
});
}
};
});
})();
;(function () {
"use strict";
/* globals $ */
angular.module('angular.bootstrap.validator').directive('abvForm', function ($compile) {
function addNameNgModelToControlAndGetControlName(controlElement) {
var control = $(controlElement);
var controlName = control.attr('name');
if (!controlName) {
controlName = control.attr('id');
control.attr('name', controlName);
}
if (!control.attr('ng-model') && !control.data('ng-model')) {
control.attr('ng-model', controlName);
}
return controlName;
}
function ngClassAttribute(formName, controlName) {
return "{'has-success': " + formName + ".$submitted && " + formName + "." + controlName + ".$valid, 'has-error': " + formName + ".$submitted && " + formName + "." + controlName + ".$invalid }";
}
return {
require: 'form',
restrict: 'A',
terminal: true,
compile: function compile() {
return function (scope, element, attr, controller) {
// reset form function
scope.resetForm = function () {
controller.$commitViewValue();
controller.$setPristine();
};
var formName = controller.$name;
// disable submit buttons when the form is invalid after submit
element.find('button[type="submit"]').attr('ng-disabled', formName + ".$submitted && " + formName + ".$invalid");
// associate the reset button with the reset form function
element.find('button[type="reset"]').attr('ng-click', 'resetForm()');
// disable native form validation because the validation is handled by Angular
element.attr('novalidate', 'novalidate');
// for each form-control in a form group
element.find('.form-group').each(function (index, formGroup) {
var controls = $(formGroup).find('.form-control');
// Only input text areas should have feedback, textarea must not have feedback
// only support one control per form-group as per Bootstrap CSS examples
controls.each(function (index,control) {
// set the name. and ng-model appropriately
var controlName = addNameNgModelToControlAndGetControlName(control);
// add feedback icons
if ($(formGroup).hasClass('has-feedback')) {
angular.element(control).after("<span class=\"glyphicon form-control-feedback\" ng-class=\"{'glyphicon-ok' : " + formName + "." + controlName + ".$valid, 'glyphicon-remove' : " + formName + "." + controlName + ".$invalid }\" ng-if=\"" + formName + ".$submitted\" aria-hidden=\"true\"></span>");
}
// set the has-error CSS if the form has been submitted
$(formGroup).attr('ng-class', ngClassAttribute(formName, controlName));
});
});
// for each checkbox, wrap in a container div
element.find('.checkbox').each(function (index, checkbox) {
var controls = $(checkbox).find('input[type="checkbox"]');
if (controls.length === 1) {
// set the name. and ng-model appropriately
var controlName = addNameNgModelToControlAndGetControlName(controls[0]);
$(checkbox).wrap("<div ng-class=\"" + ngClassAttribute(formName, controlName) + "\"></div>");
}
});
$compile(element.contents())(scope);
};
}
};
});
})();
;(function () {
"use strict";
angular.module('angular.bootstrap.validator').directive('abvIdentical', function () {
return {
restrict: 'A',
scope: {
targetModel: '=abvIdentical'
},
require: 'ngModel',
link: function link(scope, element, attributes, ngModel) {
ngModel.$validators.abvIdentical = function (modelValue) {
return modelValue === scope.targetModel;
};
scope.$watch('targetModel', function () {
ngModel.$validate();
});
}
};
});
})();
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["angular-bootstrap-validator.js","directives/abvDifferent.js","directives/abvError.js","directives/abvForm.js","directives/abvIdentical.js"],"names":[],"mappings":"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","file":"angular-bootstrap-validator.js","sourcesContent":["angular.module('angular.bootstrap.validator', [])\r\n","angular.module('angular.bootstrap.validator')\r\n  .directive('abvDifferent', () => ({\r\n    restrict: 'A',\r\n    scope: {\r\n      targetModel: '=abvDifferent'\r\n    },\r\n    require: 'ngModel',\r\n    link: function(scope, element, attributes, ngModel) {\r\n\r\n      ngModel.$validators.abvDifferent = modelValue => modelValue !== scope.targetModel\r\n\r\n      scope.$watch('targetModel', () => {\r\n        ngModel.$validate()\r\n      })\r\n    }\r\n  }))\r\n","angular.module('angular.bootstrap.validator')\r\n  .directive('abvError', ($animate, $log) => ({\r\n    restrict: 'A',\r\n    scope: {\r\n      validatorName: '@abvError',\r\n      oldControlName: '@abvModel',\r\n      controlName: '@abvFor'\r\n    },\r\n    require: '^form',\r\n    terminal: true,\r\n    link: (scope, element, attrs, form) => {\r\n      var controlName\r\n      if (scope.oldControlName) {\r\n        $log.warn('abv-model is deprecated use abv-for')\r\n        scope.controlName = scope.oldControlName\r\n      }\r\n      if (scope.controlName) {\r\n        controlName = scope.controlName\r\n      } else {\r\n        if (element.siblings('.form-control')[0]) {\r\n          controlName = element.siblings('.form-control')[0].name\r\n        } else {\r\n          controlName = element.parent().find('input[type=\"checkbox\"]')[0].name\r\n        }\r\n      }\r\n      var formName = `$parent.${form.$name}`\r\n      var watchExpr = `${formName}.$submitted && ${formName}.${controlName}.$error.${scope.validatorName}`\r\n      scope.$watch(watchExpr, value => {\r\n        $animate[value ? 'removeClass' : 'addClass'](element, 'ng-hide', {\r\n          tempClasses: 'ng-hide-animate'\r\n        })\r\n      })\r\n    }\r\n  }))\r\n","/* globals $ */\r\nangular.module('angular.bootstrap.validator')\r\n  .directive('abvForm', $compile => {\r\n    function addNameNgModelToControlAndGetControlName(controlElement) {\r\n      var control = $(controlElement)\r\n      var controlName = control.attr('name')\r\n      if (!controlName) {\r\n        controlName = control.attr('id')\r\n        control.attr('name', controlName)\r\n      }\r\n      if (!control.attr('ng-model') && !control.data('ng-model')) {\r\n        control.attr('ng-model', controlName)\r\n      }\r\n      return controlName\r\n\r\n    }\r\n\r\n    function ngClassAttribute(formName, controlName) {\r\n      return `{'has-success': ${formName}.$submitted && ${formName}.${controlName}.$valid, 'has-error': ${formName}.$submitted && ${formName}.${controlName}.$invalid }`\r\n    }\r\n\r\n    return {\r\n      require: 'form',\r\n      restrict: 'A',\r\n      terminal: true,\r\n      compile: () => (scope, element, attr, controller) => {\r\n        // reset form function\r\n        scope.resetForm = function() {\r\n          controller.$commitViewValue()\r\n          controller.$setPristine()\r\n        }\r\n\r\n        var formName = controller.$name\r\n\r\n        // disable submit buttons when the form is invalid after submit\r\n        element.find('button[type=\"submit\"]').attr('ng-disabled', `${formName}.$submitted && ${formName}.$invalid`)\r\n\r\n        // associate the reset button with the reset form function\r\n        element.find('button[type=\"reset\"]').attr('ng-click', 'resetForm()')\r\n\r\n        // disable native form validation because the validation is handled by Angular\r\n        element.attr('novalidate', 'novalidate')\r\n\r\n        // for each form-control in a form group\r\n        element.find('.form-group').each((index, formGroup) => {\r\n          var controls = $(formGroup).find('.form-control')\r\n          // Only input text areas should have feedback, textarea must not have feedback\r\n          // only support one control per form-group as per Bootstrap CSS examples\r\n          controls.forEach(control => {\r\n            // set the name. and ng-model appropriately\r\n            var controlName = addNameNgModelToControlAndGetControlName(control)\r\n\r\n            // add feedback icons\r\n            if ($(formGroup).hasClass('has-feedback')) {\r\n              control.after(`<span class=\"glyphicon form-control-feedback\" ng-class=\"{'glyphicon-ok' : ${formName}.${controlName}.$valid, 'glyphicon-remove' : ${formName}.${controlName}.$invalid }\" ng-if=\"${formName}.$submitted\" aria-hidden=\"true\"></span>`)\r\n            }\r\n\r\n            // set the has-error CSS if the form has been submitted\r\n            $(formGroup).attr('ng-class', ngClassAttribute(formName, controlName))\r\n          })\r\n        })\r\n\r\n        // for each checkbox, wrap in a container div\r\n        element.find('.checkbox').each((index, checkbox) => {\r\n          var controls = $(checkbox).find('input[type=\"checkbox\"]')\r\n          if (controls.length === 1) {\r\n            // set the name. and ng-model appropriately\r\n            var controlName = addNameNgModelToControlAndGetControlName(controls[0])\r\n            $(checkbox).wrap(`<div ng-class=\"${ngClassAttribute(formName, controlName)}\"></div>`)\r\n          }\r\n        })\r\n        $compile(element.contents())(scope)\r\n      }\r\n    }\r\n  })\r\n","angular.module('angular.bootstrap.validator')\r\n  .directive('abvIdentical', () => ({\r\n    restrict: 'A',\r\n    scope: {\r\n      targetModel: '=abvIdentical'\r\n    },\r\n    require: 'ngModel',\r\n    link: function(scope, element, attributes, ngModel) {\r\n\r\n      ngModel.$validators.abvIdentical = modelValue => modelValue === scope.targetModel\r\n\r\n      scope.$watch('targetModel', () => {\r\n        ngModel.$validate()\r\n      })\r\n    }\r\n  }))\r\n"],"sourceRoot":"/source/"}