login.view.html 1.4 KB

123456789101112131415161718192021
  1. <div class="col-md-6 col-md-offset-3">
  2. <h2>Login</h2>
  3. <div ng-show="vm.error" class="alert alert-danger">{{vm.error}}</div>
  4. <form name="form" ng-submit="vm.login()" role="form">
  5. <div class="form-group" ng-class="{'has-error': form.username.$dirty && form.username.$error.required}">
  6. <label for="username">Username</label>
  7. <input type="text" name="username" id="username" class="form-control" ng-model="vm.username" required />
  8. <span ng-show="form.username.$dirty && form.username.$error.required" class="help-block">Username is required</span>
  9. </div>
  10. <div class="form-group" ng-class="{'has-error': form.password.$dirty && form.password.$error.required}">
  11. <label for="password">Password</label>
  12. <input type="password" name="password" id="password" class="form-control" ng-model="vm.password" required />
  13. <span ng-show="form.password.$dirty && form.password.$error.required" class="help-block">Password is required</span>
  14. </div>
  15. <div class="form-actions">
  16. <button type="submit" ng-disabled="form.$invalid || vm.dataLoading" class="btn btn-primary">Login</button>
  17. <i ng-if="vm.dataLoading" class="fa fa-spinner fa-spin"></i>
  18. <a href="/register" class="btn btn-link">Register</a>
  19. </div>
  20. </form>
  21. </div>