blob: f756ff5c44e62ce7afe3b2dea907db809d05da05 [file] [log] [blame]
lombardofr5bc5ebb2019-08-19 09:33:56 +02001<!--
2Copyright 2019 EveryUP srl
3
4Licensed under the Apache License, Version 2.0 (the "License");
5you may not use this file except in compliance with the License.
6You may obtain a copy of the License at
7
8 http://www.apache.org/licenses/LICENSE-2.0
9
10Unless required by applicable law or agreed to in writing, software
11distributed under the License is distributed on an BASIS,
12WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13See the License for the specific language governing permissions and
14limitations under the License.
15-->
lombardofr10b52d12018-07-17 23:42:28 +020016{% extends "base.html" %}
17{% load get %}
18{% load date_tag %}
19{% load staticfiles %}
20
21
22{% block head_block %}
23 {{ block.super }}
lombardofre5a130a2019-07-15 09:17:59 +020024 <link rel="stylesheet" href="/static/node_modules/select2/dist/css/select2.min.css">
25 <link rel="stylesheet" href="/static/node_modules/datatables.net-bs/css/dataTables.bootstrap.min.css">
lombardofr10b52d12018-07-17 23:42:28 +020026{% endblock %}
27{% block title_header_big %}
28 {{ block.super }}
29{% endblock %}
30{% block left_sidebar %}
31 {% include 'osm/osm_project_left_sidebar.html' %}
32{% endblock %}
33
34
35{% block breadcrumb_body %}
36 {{ block.super }}
37 <li><a href="#">Users</a></li>
38{% endblock %}
39
40{% block content_body %}
41 {{ block.super }}
42 {% include 'modal/user_details.html' %}
43 {% include 'modal/user_create.html' %}
lombardofr5bc5ebb2019-08-19 09:33:56 +020044 {% include 'modal/user_credentials_edit.html' %}
45 {% include 'modal/user_proj_role_edit.html' %}
46
lombardofr88d09562018-09-11 18:14:39 +020047
lombardofr10b52d12018-07-17 23:42:28 +020048 {% csrf_token %}
49 <div class="row">
50 <div class="col-md-12">
51
52 <div class="box">
53 <div class="box-header with-border">
54 <h3 class="box-title">Users</h3>
55 <div class="box-tools">
56 <button type="button" class="btn btn-default" data-container="body"
lombardofr88d09562018-09-11 18:14:39 +020057 onclick="javascript:openModalCreateUser({'projects_list_url': '{% url "projects:projects_list" %}'})"
58 data-toggle="tooltip" data-placement="top" title="New User">
lombardofr10b52d12018-07-17 23:42:28 +020059
lombardofr88d09562018-09-11 18:14:39 +020060 <i class="fa fa-plus"></i> Create User
61 </button>
lombardofr10b52d12018-07-17 23:42:28 +020062
63 </div>
64 </div>
65 <div class="box-body">
66 <table id="users_table" class="table table-bordered table-striped">
67 <thead>
68 <tr>
69 <th>Name</th>
lombardofr10b52d12018-07-17 23:42:28 +020070 <th>Identifier</th>
71 <th>Modified</th>
lombardofr88d09562018-09-11 18:14:39 +020072 <th>Created</th>
lombardofr10b52d12018-07-17 23:42:28 +020073 <th>Actions</th>
lombardofr10b52d12018-07-17 23:42:28 +020074 </tr>
75 </thead>
76 <tbody>
lombardofr10b52d12018-07-17 23:42:28 +020077 </tbody>
78 </table>
79 </div>
80 </div>
81 </div>
82
83 </div>
84{% endblock %}
85
86{% block resource_block %}
87 {{ block.super }}
lombardofre5a130a2019-07-15 09:17:59 +020088 <script src="/static/node_modules/datatables.net/js/jquery.dataTables.min.js"></script>
89 <script src="/static/node_modules/datatables.net-bs/js/dataTables.bootstrap.min.js"></script>
90 <script src="/static/node_modules/select2/dist/js/select2.js"></script>
lombardofr10b52d12018-07-17 23:42:28 +020091 <script src="/static/src/userhandler/user_list.js"></script>
lombardofr45e33ee2018-07-18 19:22:37 +020092 <script>
lombardofra91d0322019-05-19 13:24:36 +020093 var table;
lombardofr88d09562018-09-11 18:14:39 +020094 $(document).ready(function () {
lombardofra91d0322019-05-19 13:24:36 +020095 table = $('#users_table').DataTable({
lombardofr88d09562018-09-11 18:14:39 +020096 responsive: true,
97 "ajax": {
98 "url": "/admin/users/list",
99 "dataSrc": function (json) {
100 return json['users'];
101 },
102 statusCode: {
103 401: function () {
104 console.log("no auth");
105 moveToLogin(window.location.pathname);
106 }
107 },
108 "error": function (hxr, error, thrown) {
109 console.log(hxr)
110 console.log(thrown)
111 console.log(error);
lombardofr4908f382018-09-10 11:36:06 +0200112 }
lombardofr4908f382018-09-10 11:36:06 +0200113
lombardofr4908f382018-09-10 11:36:06 +0200114 },
lombardofr88d09562018-09-11 18:14:39 +0200115 "columns": [
116 {
117 "render": function (data, type, row) {
118 return row["username"];
119 },
120 "targets": 0
lombardofr4908f382018-09-10 11:36:06 +0200121 },
lombardofr88d09562018-09-11 18:14:39 +0200122 {
123 "render": function (data, type, row) {
lombardofr5bc5ebb2019-08-19 09:33:56 +0200124
125 return row['_id'];
lombardofr88d09562018-09-11 18:14:39 +0200126 },
127 "targets": 1
lombardofr4908f382018-09-10 11:36:06 +0200128 },
lombardofr88d09562018-09-11 18:14:39 +0200129 {
130 "render": function (data, type, row) {
lombardofr5bc5ebb2019-08-19 09:33:56 +0200131 return moment.unix(row["_admin"]['modified']).format('YYYY-MM-DD hh:mm:ss a');
lombardofr88d09562018-09-11 18:14:39 +0200132 },
133 "targets": 2
lombardofr4908f382018-09-10 11:36:06 +0200134 },
lombardofr88d09562018-09-11 18:14:39 +0200135 {
136 "render": function (data, type, row) {
lombardofr88d09562018-09-11 18:14:39 +0200137 return moment.unix(row["_admin"]['created']).format('YYYY-MM-DD hh:mm:ss a');
138 },
lombardofr5bc5ebb2019-08-19 09:33:56 +0200139 "targets": 3
lombardofr4908f382018-09-10 11:36:06 +0200140 },
lombardofr88d09562018-09-11 18:14:39 +0200141 {
142 "render": function (data, type, row) {
143 return '<div class="btn-group">' +
144 '<button type="button" class="btn btn-default dropdown-toggle"' +
145 'data-toggle="dropdown" aria-expanded="false">Actions ' +
146 '<span class="fa fa-caret-down"></span></button> ' +
147 '<ul class="dropdown-menu">' +
lombardofr5bc5ebb2019-08-19 09:33:56 +0200148 '<li> <a href="#" onclick="javascript:openModalEditUserCredentials({user_id:\'' + row['_id'] + '\', usernarme:\'' + row['username'] + '\'})">' +
149 '<i class="fa fa-lock"></i>Edit Credentials</a></li>' +
150 '<li> <a href="#" onclick="javascript:openModalEditUserRoleMap(\''+row['_id']+'\')">' +
151 '<i class="fa fa-user-tag"></i>Projects-Roles</a></li>' +
lombardofr88d09562018-09-11 18:14:39 +0200152 '<li> <a href="#" onclick="javascript:deleteUser(\'' + row['_id'] + '\', \'' + row['username'] + '\')"' +
153 'style="color:red"><i class="fa fa-trash"></i> Delete</a></li> </ul></div>';
154 },
lombardofr5bc5ebb2019-08-19 09:33:56 +0200155 "targets": 4,
lombardofr99a3d352019-01-06 19:41:34 +0100156 "orderable": false
lombardofr88d09562018-09-11 18:14:39 +0200157 }
158 ]
159 });
lombardofr8b12a9b2018-10-03 11:52:15 +0200160
lombardofr8b12a9b2018-10-03 11:52:15 +0200161
lombardofr88d09562018-09-11 18:14:39 +0200162 setInterval(function () {
lombardofr4908f382018-09-10 11:36:06 +0200163 table.ajax.reload();
164 }, 10000);
lombardofr88d09562018-09-11 18:14:39 +0200165
lombardofra91d0322019-05-19 13:24:36 +0200166 $("#formCreateUser").submit(function (event) {
167 event.preventDefault(); //prevent default action
168 var post_url = $(this).attr("action"); //get form action url
169 var request_method = $(this).attr("method");
170 var form_data = new FormData(this); //Encode form elements for submission
171
172 $.ajax({
173 url: post_url,
174 type: request_method,
175 data: form_data,
176 headers: {
177 "Accept": 'application/json'
178 },
179 contentType: false,
180 processData: false
181 }).done(function (response, textStatus, jqXHR) {
182 $('#modal_new_user').modal('hide');
183 table.ajax.reload();
184 bootbox.alert({
185 title: "Result",
186 message: "User successfully created."
187 });
188
189 }).fail(function (result) {
190 var data = result.responseJSON;
191 var title = "Error " + (data.code ? data.code : 'unknown');
192 var message = data.detail ? data.detail : 'No detail available.';
193 bootbox.alert({
194 title: title,
195 message: message
196 });
197 });
198 });
199
lombardofr88d09562018-09-11 18:14:39 +0200200 $("#formEditUser").submit(function (event) {
201 event.preventDefault(); //prevent default action
202 var post_url = $(this).attr("action"); //get form action url
lombardofr8b12a9b2018-10-03 11:52:15 +0200203 var request_method = $(this).attr("method");
lombardofr88d09562018-09-11 18:14:39 +0200204 var form_data = new FormData(this); //Encode form elements for submission
lombardofr8b12a9b2018-10-03 11:52:15 +0200205
lombardofr88d09562018-09-11 18:14:39 +0200206 $.ajax({
207 url: post_url,
208 type: request_method,
209 data: form_data,
210 headers: {
211 "Accept": 'application/json'
212 },
213 contentType: false,
214 processData: false
215 }).done(function (response, textStatus, jqXHR) {
lombardofr5bc5ebb2019-08-19 09:33:56 +0200216 $('#modal_edit_user_credentials').modal('hide');
lombardofr8b12a9b2018-10-03 11:52:15 +0200217 table.ajax.reload();
lombardofr88d09562018-09-11 18:14:39 +0200218 bootbox.alert({
219 title: "Result",
lombardofra91d0322019-05-19 13:24:36 +0200220 message: "User successfully modified."
lombardofr88d09562018-09-11 18:14:39 +0200221 });
lombardofr8b12a9b2018-10-03 11:52:15 +0200222
lombardofr88d09562018-09-11 18:14:39 +0200223 }).fail(function (result) {
224 var data = result.responseJSON;
225 var title = "Error " + (data.code ? data.code : 'unknown');
226 var message = data.detail ? data.detail : 'No detail available.';
227 bootbox.alert({
228 title: title,
229 message: message
230 });
231 });
232 });
lombardofra91d0322019-05-19 13:24:36 +0200233
lombardofr5bc5ebb2019-08-19 09:33:56 +0200234 $("#password2").keyup(validatePswOnCreate);
235 $("#edit_password2").keyup(validatePswOnEdit);
236
237 $(document).on('click', '.proj-role-map-group-head .btn-add', addMapGroup);
238 $(document).on('click', '.proj-role-map-group .btn-remove', removeMapGroup);
lombardofr88d09562018-09-11 18:14:39 +0200239 });
lombardofr45e33ee2018-07-18 19:22:37 +0200240 </script>
lombardofr10b52d12018-07-17 23:42:28 +0200241
242
243{% endblock %}
244
245{% block footer %}
246 {% include "footer.html" %}
247{% endblock %}