summaryrefslogtreecommitdiffstats
path: root/app/users/controllers/user-accounts-controller.html
blob: f5bdda0a4674f886aee04c626c661e1edf1f4e57 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
<loader loading="loading"></loader>
<div id="user-accounts">

  <div class="row column acnt-prop-header">
    <h1>User account properties</h1>
  </div>

  <div class="col-sm-12">
    <form class="row column user-manage__form">
      <div class="col-sm-12">
        <label class="col-md-1 control-label" for="lockoutTime"> User Lockout Time (sec) </label>
        <div class="col-md-3 acnt-prop__input-wrapper">
          <input type="number" id="lockoutTime" min="30" max="600" ng-model="properties.AccountLockoutDuration"/>
        </div>
      </div>
      <div class="col-sm-12">
        <label class="col-md-1 control-label" for="lockoutThreshold"> Failed Login Attempts </label>
        <div class="col-md-3 acnt-prop__input-wrapper">
          <input type="number" id="lockoutThreshold" min="3" max="10" ng-model="properties.AccountLockoutThreshold"/>
        </div>
      </div>
      <div class="acnt-prop__submit-wrapper">
          <button type="button" class="btn-primary inline" ng-click="saveAllValues()">Save settings</button>
      </div>
    </form>
  </div>

  <div class="row column">
    <h1>User account information</h1>
  </div>
  <div class="table row column user-list__tbl" ng-show="users.length != 0">
    <div class="table__head">
      <div class="table__row">
        <div class="table__cell"> Username </div>
        <div class="table__cell"> Enabled </div>
        <div class="table__cell"> Role </div>
        <div class="table__cell"> Locked </div>
        <div class="table__cell"> Action </div>
      </div>
    </div>
    <div class="table__body">
      <div class="table__row" ng-repeat="user in users">
        <div class="table__cell"> {{user.UserName}} </div>
        <div class="table__cell"> {{user.Enabled}} </div>
        <div class="table__cell"> {{user.RoleId}} </div>
        <div class="table__cell"> {{user.Locked}} </div>
        <div class="table__cell">
          <button type="button" class="btn-edit inline" ng-disabled="isUserSelected" ng-click="setSelectedUser(user)">Edit</button>
          <button type="button" class="btn-delete inline" ng-disabled="isUserSelected" ng-click="deleteUser(user.UserName)">Delete</button>
        </div>
      </div>
    </div>
  </div>
  <div class="table row column" ng-show="users.length == 0">
    <span>No users exist in system</span>
  </div>

  <form role="form" name="user__form" class="user-manage__form">
    <section class="row column" aria-label="user manage form" ng-class="{'submitted':submitted}">
       <div class="column small-12 page-header">
        <h2 class="inline">User account settings</h2>
       </div>
        <div class='col-sm-12'>
          <label class="col-md-1 control-label" for="user-manage__username">UserName</label>
          <div class="col-md-3">
            <input type="text" name="UserName" id="user-manage__username" ng-model="selectedUser.UserName" has-error="doesUserExist()" required />
            <div ng-messages="user__form.UserName.$error" class="form-error" ng-class="{'visible' : user__form.UserName.$touched || submitted}">
              <p ng-message="required">Field is required</p>
              <p ng-message="hasError">Username exists</p>
            </div>
          </div>
        </div>
        <div class='col-sm-12 inline'>
          <label class="col-md-1 control-label" for="user-manage__passwd">Password</label>
          <div class="col-md-3 user-manage__input-wrapper inline">
            <input type="{{showpassword ? 'text' : 'password'}}" class="user-manage__new-password inline" name="Password" id="user-manage__passwd" ng-model="selectedUser.Password" ng-minlength="properties.MinPasswordLength" ng-maxlength="properties.MaxPasswordLength" required autocomplete="off"/>
            <button ng-model="showpassword" ng-click="togglePassword = !togglePassword; showpassword = !showpassword;" class="password-toggle">
              <span ng-hide="togglePassword">Show</span>
              <span ng-show="togglePassword">Hide</span>
            </button>
            <div ng-messages="user__form.Password.$error" class="form-error" ng-class="{'visible' : user__form.Password.$touched || submitted}">
              <p ng-message="required">Field is required</p>
              <p ng-message="minlength">Must be at least {{properties.MinPasswordLength}} characters</p>
              <p ng-message="maxlength">Must be {{properties.MaxPasswordLength}} characters or less</p>
            </div>
          </div>
        </div>
        <div class='col-sm-12'>
          <label class="col-md-1 control-label" for="user-manage__verifypasswd">Retype Password</label>
          <div class="col-md-3 user-manage__input-wrapper inline">
            <input type="{{showpasswordVerify ? 'text' : 'password'}}" class="user-manage__verify-password inline" name="VerifyPassword" id="user-manage__verifypasswd" ng-model="selectedUser.VerifyPassword" has-error="selectedUser.VerifyPassword != selectedUser.Password" required autocomplete="off">
            <button ng-model="showpasswordVerify" ng-click="toggleVerify = !toggleVerify; showpasswordVerify = !showpasswordVerify;" class="password-toggle">
              <span ng-hide="toggleVerify">Show</span>
              <span ng-show="toggleVerify">Hide</span>
            </button>
            <div ng-messages="user__form.VerifyPassword.$error" class="form-error" ng-class="{'visible' : user__form.VerifyPassword.$touched || submitted}">
              <p ng-message="required">Field is required</p>
              <p ng-message="hasError">Passwords do not match</p>
            </div>
          </div>
        </div>
        <div class='col-sm-12'>
          <label class="col-md-1 control-label" for="role">Role</label>
          <div class="col-md-3 user-manage__input-wrapper inline">
            <select ng-model="selectedUser.RoleId" id="role" name="role" class="inline" required>
              <option ng-repeat="role in roles" class="inline">{{role}}</option>
            </select>
            <div ng-messages="user__form.role.$error" class="form-error" ng-class="{'visible' : user__form.role.$touched || submitted}">
              <p ng-message="required">Field is required</p>
            </div>
          </div>
        </div>
        <div class='col-sm-12'>
          <label class="col-md-1 control-label" for="user-manage__enabled">Enabled</label>
          <div class="col-md-3 user-manage__input-wrapper inline">
            <label class="control-check">
              <input type="checkbox" name="Enabled" id="user-manage__enabled" ng-model="selectedUser.Enabled"/>
                <span class="control__indicator"></span>
            </label>
          </div>
        </div>
        <div class="user-manage__submit-wrapper">
            <button type="button" ng-click="submitted=true; user__form.$valid && createNewUser(); user__form.$setUntouched()" ng-show="!isUserSelected" class="btn-primary inline">Create user</button>
            <button type="button" class="btn-primary inline" ng-click="submitted=true; user__form.$valid && updateUserInfo(); user__form.$setUntouched()" ng-show="isUserSelected">Save</button>
            <button type="button" class="btn-primary inline" ng-if="isUserSelected" ng-click="cancel()">Cancel</button>
        </div>
    </section>
  </form>
</div>
OpenPOWER on IntegriCloud