blob: 62282adc3a466dae7bb631ea5c59222071214f1a [file] [log] [blame]
lombardoffb37bca2018-05-03 16:20:04 +02001{% extends "base.html" %}
lombardofr480be482018-06-26 23:44:40 +02002{% load get %}
3{% load date_tag %}
lombardoffb37bca2018-05-03 16:20:04 +02004{% load staticfiles %}
5
6{% block head_block %}
7 {{ block.super }}
lombardofr45e33ee2018-07-18 19:22:37 +02008 <link rel="stylesheet" href="/static/bower_components/datatables.net-bs/css/dataTables.bootstrap.min.css">
lombardoffb37bca2018-05-03 16:20:04 +02009
10{% endblock %}
11{% block title_header_big %}
12 {{ block.super }}
13{% endblock %}
14{% block left_sidebar %}
15
lombardofr835a0b72018-07-18 15:26:16 +020016{% include 'osm/osm_project_left_sidebar.html' %}
lombardoffb37bca2018-05-03 16:20:04 +020017
18{% endblock %}
19
20
21{% block breadcrumb_body %}
22 {{ block.super }}
23 <li><a href="{% url 'projects:projects_list' %}">Projects</a></li>
24{% endblock %}
25
26{% block content_body %}
27 {{ block.super }}
28 {% csrf_token %}
29<div class="row">
30<div class="col-md-12">
lombardoffb37bca2018-05-03 16:20:04 +020031 <div class="box">
32 <div class="box-header with-border">
33 <h3 class="box-title">Projects</h3>
34 <div class="box-tools">
lombardofr480be482018-06-26 23:44:40 +020035 <button type="button" class="btn btn-default" data-container="body"
36 data-toggle="tooltip" data-placement="top" title="New Project"
37 onclick="javascript:showModalNewProject()">
38 <i class="fa fa-plus"></i> New Project</button>
lombardoffb37bca2018-05-03 16:20:04 +020039 </div>
40 </div>
41 <div class="box-body">
42 <table id="projects_table" class="table table-bordered table-striped">
43 <thead>
44 <tr>
lombardoffb37bca2018-05-03 16:20:04 +020045 <th>Name</th>
lombardoffb37bca2018-05-03 16:20:04 +020046 <th>Modification Date</th>
47 <th>Creation Date</th>
lombardofrbced6e62018-07-18 17:02:16 +020048 <th>Actions</th>
lombardoffb37bca2018-05-03 16:20:04 +020049 </tr>
50 </thead>
51 <tbody>
lombardoffb37bca2018-05-03 16:20:04 +020052
lombardoffb37bca2018-05-03 16:20:04 +020053 </tbody>
54 </table>
55 </div>
56 </div>
57</div>
58
59</div>
lombardofrbced6e62018-07-18 17:02:16 +020060{% include "modal/project_new.html" %}
61{% include "modal/project_edit.html" %}
lombardoffb37bca2018-05-03 16:20:04 +020062{% endblock %}
63
64{% block resource_block %}
65 {{ block.super }}
lombardofr45e33ee2018-07-18 19:22:37 +020066 <script src="/static/bower_components/datatables.net/js/jquery.dataTables.min.js"></script>
67 <script src="/static/bower_components/datatables.net-bs/js/dataTables.bootstrap.min.js"></script>
68
69 <script>
lombardofr8da23132019-06-02 17:18:48 +020070 var table;
71 $(document).ready( function () {
72 table = $('#projects_table').DataTable({
lombardofr4908f382018-09-10 11:36:06 +020073 responsive: true,
74 "ajax": {
75 "url": "/projects/list",
76 "dataSrc": function (json) {
77 return json['projects'];
78 },
79 statusCode: {
80 401: function () {
81 console.log("no auth");
82 moveToLogin(window.location.pathname);
83 }
84 },
85 "error": function (hxr, error, thrown) {
86 console.log(hxr)
87 console.log(thrown)
88 console.log(error);
89 }
90
91 },
92 "columns": [
93 {
94 "render": function (data, type, row) {
lombardofr76483c32019-03-12 15:39:06 +010095 return '<a href="/projects/'+row['name']+'/switch/" >'+row['name']+'</a>'
lombardofr4908f382018-09-10 11:36:06 +020096 },
97 "targets": 0
98 },
99 {
100 "render": function (data, type, row) {
101 return moment.unix(row["_admin"]['modified']).format('YYYY-MM-DD hh:mm:ss a');
102 },
103 "targets": 1
104 },
105 {
106 "render": function (data, type, row) {
107 return moment.unix(row["_admin"]['created']).format('YYYY-MM-DD hh:mm:ss a');
108 },
109 "targets": 2
110 },
111 {
112 "render": function (data, type, row) {
113 return '<div class="btn-group">\n' +
114 ' <button type="button" class="btn btn-default dropdown-toggle"\n' +
115 ' data-toggle="dropdown" aria-expanded="false">Actions\n' +
116 ' <span class="fa fa-caret-down"></span></button>\n' +
117 ' <ul class="dropdown-menu">\n' +
118 ' <li><a href="#"\n' +
119 ' onclick="javascript:editProject(\''+ row['name']+'\')">\n' +
120 ' <i class="fa fa-edit"></i> Rename</a></li>\n' +
121 ' <li>\n' +
122 ' <a href="#" onclick="javascript:deleteProject(\''+ row['name']+'\')" style="color:red">\n' +
123 ' <i class="fa fa-trash" ></i> Delete</a>\n' +
124 ' </li>\n' +
125 ' </ul>\n' +
126 ' </div>';
127 },
lombardofr99a3d352019-01-06 19:41:34 +0100128 "targets": 3,
129 "orderable": false
lombardofr4908f382018-09-10 11:36:06 +0200130 }
131 ]
132 });
133
134 setInterval(function () {
135 table.ajax.reload();
136 }, 10000);
137 });
lombardofr45e33ee2018-07-18 19:22:37 +0200138 </script>
lombardofr480be482018-06-26 23:44:40 +0200139 <script>
140 function showModalNewProject(){
141 $('#modal_new_project').modal('show');
142 }
lombardoffb37bca2018-05-03 16:20:04 +0200143
lombardofr4908f382018-09-10 11:36:06 +0200144 function editProject(project_id){
145 var url = "/projects/" + project_id+"/edit";
lombardofrbced6e62018-07-18 17:02:16 +0200146 $("#formEditProject").attr("action", url);
147 $('#modal_edit_project').modal('show');
148 }
149
lombardofr4908f382018-09-10 11:36:06 +0200150 function deleteProject(project_id) {
151 var url = "/projects/" + project_id+"/delete";
lombardofr8532b432019-04-30 17:28:22 +0200152 bootbox.confirm("Are you sure want to delete?", function (result) {
153 if (result) {
154 $.ajax({
155 url: url,
156 type: 'GET',
157 headers: {
158 "Accept": 'application/json'
159 },
160 contentType: false,
161 processData: false
162 }).done(function (response,textStatus, jqXHR) {
163 bootbox.alert({
164 title: "Result",
165 message: "Project deleted.",
166 callback: function () {
lombardofr8da23132019-06-02 17:18:48 +0200167 table.ajax.reload();
lombardofr8532b432019-04-30 17:28:22 +0200168 }
169 });
170 }).fail(function(result){
171 var data = result.responseJSON;
172 var title = "Error " + (data.code ? data.code: 'unknown');
173 var message = data.detail ? data.detail: 'No detail available.';
174 bootbox.alert({
175 title: title,
176 message: message
177 });
lombardofr480be482018-06-26 23:44:40 +0200178 });
lombardofr8532b432019-04-30 17:28:22 +0200179 }
180 })
lombardofr480be482018-06-26 23:44:40 +0200181 }
182
183 $(document).ready(function () {
lombardofr8532b432019-04-30 17:28:22 +0200184 $("#formNewProject").submit(function (event) {
185 event.preventDefault(); //prevent default action
186 var post_url = $(this).attr("action"); //get form action url
187 var request_method = $(this).attr("method"); //get form GET/POST method
188 var form_data = new FormData(this); //Encode form elements for submission
189 console.log(post_url);
190 $.ajax({
191 url: post_url,
192 type: request_method,
193 data: form_data,
194 headers: {
195 "Accept": 'application/json'
196 },
197 contentType: false,
198 processData: false
199 }).done(function (response,textStatus, jqXHR) {
lombardofr480be482018-06-26 23:44:40 +0200200 bootbox.alert({
lombardofr8532b432019-04-30 17:28:22 +0200201 title: "Result",
202 message: "Project created.",
203 callback: function () {
lombardofr8da23132019-06-02 17:18:48 +0200204 table.ajax.reload();
205 $('#modal_new_project').modal('hide');
206 }
207 });
208 }).fail(function(result){
209 var data = result.responseJSON;
210 var title = "Error " + (data.code ? data.code: 'unknown');
211 var message = data.detail ? data.detail: 'No detail available.';
212 bootbox.alert({
213 title: title,
214 message: message
215 });
216 });
217 });
218
219 $("#formEditProject").submit(function(event){
220 event.preventDefault(); //prevent default action
221 var post_url = $(this).attr("action"); //get form action url
222 var request_method = $(this).attr("method"); //get form GET/POST method
223 var form_data = new FormData(this); //Encode form elements for submission
224 console.log(post_url);
225 $.ajax({
226 url: post_url,
227 type: request_method,
228 data: form_data,
229 headers: {
230 "Accept": 'application/json'
231 },
232 contentType: false,
233 processData: false
234 }).done(function (response,textStatus, jqXHR) {
235 bootbox.alert({
236 title: "Result",
237 message: "Project updated.",
238 callback: function () {
239 table.ajax.reload();
240 $('#modal_edit_project').modal('hide');
lombardofr8532b432019-04-30 17:28:22 +0200241 }
242 });
243 }).fail(function(result){
244 var data = result.responseJSON;
245 var title = "Error " + (data.code ? data.code: 'unknown');
246 var message = data.detail ? data.detail: 'No detail available.';
247 bootbox.alert({
248 title: title,
249 message: message
250 });
251 });
lombardofr480be482018-06-26 23:44:40 +0200252 });
253 });
lombardofr480be482018-06-26 23:44:40 +0200254
255
256
257
258 </script>
lombardoffb37bca2018-05-03 16:20:04 +0200259
260
261{% endblock %}