Project

General

Profile

1
<h4>Users</h4>
2
<br />
3

    
4
<table class="table table-sm table-hover col-sm-12 col-md-10 col-lg-8">
5
	<thead class="thead-light">
6
		<tr class="d-flex">
7
			<th class="col-4">User</th>
8
			<th class="col-1 text-center">Enabled</th>
9
			<th class="col-1 text-center">Super Admin</th>
10
			<th class="col-1 text-center">National Admin</th>
11
			<th class="col-3">Countries</th>
12
			<th class="col-2"></th>
13
		</tr>
14
	</thead>
15
	<tbody>
16
		<tr ng-repeat="u in users" class="d-flex">
17
			<th class="col-4" ng-class="{'text-secondary': !u.valid}">{{u.email}}</th>
18
			<td class="col-1 text-center text-success">
19
				<i class="fa fa-check-circle" ng-if="u.valid"></i>
20
				<span class="text-warning"    ng-if="u.role == 'PENDING'">not configured</span>
21
				<span class="text-danger"     ng-if="!u.valid && (u.role != 'PENDING')">disabled</span>
22
			</td>
23
			<td class="col-1 text-center">
24
				<i class="fa fa-check-circle" ng-if="u.role == 'ADMIN'"></i>
25
			</td>
26
			<td class="col-1 text-center">
27
				<i class="fa fa-check-circle" ng-if="u.role == 'NATIONAL_ADMIN'"></i>
28
			</td>
29
			<td class="col-3">
30
				<span ng-if="(u.role != 'ADMIN')">
31
					<img ng-src="resources/images/flags/{{c}}.gif" title="{{c}}" class="mr-1" ng-repeat="c in u.countries" />
32
					<span class="text-warning" ng-if="u.countries.length == 0"><i class="fa fa-exclamation-triangle"></i> no countries</span>
33
				</span>
34
				<span class="text-muted" ng-if="u.role == 'ADMIN'">All countries</span>
35
			</td>
36
			<td class="col-2 text-right">
37
				<a href="mailto:{{u.email}}" class="btn btn-sm  btn-outline-info"><i class="fa fa-at"></i></a>
38
				<button type="button" class="btn btn-sm  btn-outline-info" data-toggle="modal" data-target="#editUserModal" ng-click="setCurrentUser(u)"><i class="fa fa-edit"></i></button>
39
				<button type="button" class="btn btn-sm  btn-outline-danger" ng-click="deleteUser(u.email)"><i class="fa fa-trash"></i></button>
40
			</td>
41
		</tr>
42
	</tbody>
43
</table>
44

    
45

    
46
<div class="modal fade" id="editUserModal" tabindex="-1" role="dialog">
47
	<div class="modal-dialog modal-xl" role="document">
48
		<div class="modal-content">
49
			<div class="modal-header">
50
				<h5 class="modal-title">Edit user</h5>
51
				<button type="button" class="close" data-dismiss="modal">&times;</button>
52
			</div>
53
			<div class="modal-body" style="min-height: 300px; max-height: 500px; overflow-y: auto;">
54
				<form>
55
					<div class="form-group row">
56
						<label class="col-sm-2 col-form-label">Email</label>
57
						<div class="col-sm-10"><a href="mailto:{{currentUser.email}}">{{currentUser.email}}</a></div>
58
					</div>
59
					<div class="form-group row">
60
						<label class="col-sm-2 col-form-label">Enabled</label>
61
						<div class="col-sm-10">
62
							<div class="form-check">
63
								<input class="form-check-input" type="checkbox" ng-model="currentUser.valid" />
64
							</div>
65
						</div>
66
					</div>
67
					<div class="form-group row" ng-if="superAdminMode && currentUser.valid">
68
						<label class="col-sm-2 col-form-label">Role</label>
69
						<div class="col-sm-10">
70
							<div class="form-check form-check-inline">
71
								<input class="form-check-input" type="radio" value="USER" ng-model="currentUser.role">
72
								<label class="form-check-label">USER</label>
73
							</div>
74
							<div class="form-check form-check-inline">
75
								<input class="form-check-input" type="radio" value="NATIONAL_ADMIN" ng-model="currentUser.role">
76
								<label class="form-check-label">NATIONAL ADMIN</label>
77
							</div>
78
							<div class="form-check form-check-inline">
79
								<input class="form-check-input" type="radio" value="ADMIN" ng-model="currentUser.role">
80
								<label class="form-check-label">SUPER ADMIN</label>
81
							</div>
82
						</div>
83
					</div>
84
					
85
					<div class="card mb-3"  ng-if="currentUser.valid && ((currentUser.role == 'USER') || (currentUser.role == 'NATIONAL_ADMIN'))">
86
						<div class="card-header bg-primary text-white py-1">Countries</div>
87
						<div class="card-body">
88
							<div class="form-group row">
89
								<div class="col-xs-6 col-sm-3 col-md-2 col-lg-1" ng-repeat="c in vocs.countries">
90
									<div class="form-check form-check-inline">
91
										<input class="form-check-input" type="checkbox" checklist-model="currentUser.countries" checklist-value="c"/>
92
										<label class="form-check-label">{{c}}</label>
93
									</div>
94
								</div>
95
							</div>
96
						</div>
97
					</div>
98
					
99
				</form>
100
			</div>
101
			<div class="modal-footer">
102
				<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
103
				<button type="button" class="btn btn-primary" data-dismiss="modal" ng-click="saveUser(currentUser)">Save changes</button>
104
			</div>
105
		</div>
106
	</div>
107
</div>
108

    
109

    
110

    
111

    
(7-7/8)