<!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/v1.1.1/angular-bootstrap-validator.js"></script>

    <script src="script.js"></script>
  </head>

  <body ng-app="myapp"  ng-controller="RegisterController as ctrl">
    <h1>Hello Plunker!</h1>
    <form name="ctrl.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"  ng-click="ctrl.register()">Register</button>
      </div>
    </form>
    <pre>{{ ctrl | json }}</pre>
  </body>

</html>
angular.module('myapp', ['ui.bootstrap', 'angular.bootstrap.validator'])
  .controller('RegisterController', function() {
    var vm = this;
    vm.register = function() {
      console.log(vm.myForm.email.$modelValue);
      console.log(vm.myForm.password.$modelValue);
      vm.myForm.$setPristine();
    };
  });
/* Styles go here */

"use strict";!function(){angular.module("angular.bootstrap.validator",[])}(),function(){angular.module("angular.bootstrap.validator").directive("abvDifferent",function(){return{restrict:"A",scope:{targetModel:"=abvDifferent"},require:"ngModel",link:function(t,a,e,n){n.$validators.abvDifferent=function(a){return a!==t.targetModel},t.$watch("targetModel",function(){n.$validate()})}}})}(),function(){angular.module("angular.bootstrap.validator").directive("abvError",["$animate","$log",function(t,a){return{restrict:"A",scope:{validatorName:"@abvError",oldControlName:"@abvModel",controlName:"@abvFor"},require:"^form",terminal:!0,link:function(e,n,r,o){var i;e.oldControlName&&(a.warn("abv-model is deprecated use abv-for"),e.controlName=e.oldControlName),i=e.controlName?e.controlName:n.siblings(".form-control")[0]?n.siblings(".form-control")[0].name:n.parent().find('input[type="checkbox"]')[0].name;var l="$parent."+o.$name,c=l+".$submitted && "+l+"."+i+".$error."+e.validatorName;e.$watch(c,function(a){t[a?"removeClass":"addClass"](n,"ng-hide",{tempClasses:"ng-hide-animate"})})}}}])}(),function(){angular.module("angular.bootstrap.validator").directive("abvForm",["$compile",function(t){function a(t){var a=$(t),e=a.attr("name");return e||(e=a.attr("id"),a.attr("name",e)),a.attr("ng-model")||a.data("ng-model")||a.attr("ng-model",e),e}function e(t,a){return"{'has-success': "+t+".$submitted && "+t+"."+a+".$valid, 'has-error': "+t+".$submitted && "+t+"."+a+".$invalid }"}return{require:"form",restrict:"A",terminal:!0,compile:function(){return function(n,r,o,i){n.resetForm=function(){i.$commitViewValue(),i.$setPristine()};var l=i.$name;r.find('button[type="submit"]').attr("ng-disabled",l+".$submitted && "+l+".$invalid"),r.find('button[type="reset"]').attr("ng-click","resetForm()"),r.attr("novalidate","novalidate"),r.find(".form-group").each(function(t,n){var r=$(n).find(".form-control");r.each(function(t,r){var o=a(r);$(n).hasClass("has-feedback")&&angular.element(r).after('<span class="glyphicon form-control-feedback" ng-class="{\'glyphicon-ok\' : '+l+"."+o+".$valid, 'glyphicon-remove' : "+l+"."+o+'.$invalid }" ng-if="'+l+'.$submitted" aria-hidden="true"></span>'),angular.element(n).attr("ng-class",e(l,o))})}),r.find(".checkbox").each(function(t,n){var r=$(n).find('input[type="checkbox"]');if(1===r.length){var o=a(r[0]);angular.element(n).wrap('<div ng-class="'+e(l,o)+'"></div>')}}),t(r.contents())(n)}}}}])}(),function(){angular.module("angular.bootstrap.validator").directive("abvIdentical",function(){return{restrict:"A",scope:{targetModel:"=abvIdentical"},require:"ngModel",link:function(t,a,e,n){n.$validators.abvIdentical=function(a){return a===t.targetModel},t.$watch("targetModel",function(){n.$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":["angular","module","directive","restrict","scope","targetModel","require","link","element","attributes","ngModel","$validators","abvDifferent","modelValue","$watch","$validate","$animate","$log","validatorName","oldControlName","controlName","terminal","attrs","form","warn","siblings","name","parent","find","formName","$name","watchExpr","value","tempClasses","$compile","addNameNgModelToControlAndGetControlName","controlElement","control","$","attr","data","ngClassAttribute","compile","controller","resetForm","$commitViewValue","$setPristine","each","index","formGroup","controls","hasClass","after","checkbox","length","wrap","contents","abvIdentical"],"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.each((index, 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              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>`)\r\n            }\r\n\r\n            // set the has-error CSS if the form has been submitted\r\n            angular.element(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            angular.element(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/"}