2 Copyright 2019 EveryUP srl
4 Licensed under the Apache License, Version 2.0 (the "License");
5 you may not use this file except in compliance with the License.
6 You may obtain a copy of the License at
8 http://www.apache.org/licenses/LICENSE-2.0
10 Unless required by applicable law or agreed to in writing, software
11 distributed under the License is distributed on an BASIS,
12 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 See the License for the specific language governing permissions and
14 limitations under the License.
17 {% extends
"base.html" %}
20 {% load staticfiles %}
22 {% block head_block %}
24 <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">
28 {% block title_header_big %}
31 {% block left_sidebar %}
33 {% include 'osm/osm_project_left_sidebar.html' %}
38 {% block breadcrumb_body %}
40 {% if user.is_admin %}
41 <li><a href=
"{% url 'projects:projects_list' %}">Projects
</a></li>
43 <li><a href=
"#">Projects
</a></li>
47 {% block content_body %}
51 <div class=
"col-md-12">
53 <div class=
"box-header with-border">
54 <h3 class=
"box-title">Projects
</h3>
55 <div class=
"box-tools">
56 <button type=
"button" class=
"btn btn-default" data-container=
"body"
57 data-toggle=
"tooltip" data-placement=
"top" title=
"New Project"
58 onclick=
"javascript:showModalNewProject({'domains_list_url': '{% url "projects:domains_list
" %}'})">
59 <i class=
"fa fa-plus"></i> New Project
</button>
62 <div class=
"box-body">
63 <table id=
"projects_table" class=
"table table-bordered table-striped">
67 <th>Modification Date
</th>
68 <th>Creation Date
</th>
81 {% include
"modal/project_new.html" %}
82 {% include
"modal/project_edit.html" %}
85 {% block resource_block %}
87 <script src=
"/static/node_modules/datatables.net/js/jquery.dataTables.min.js"></script>
88 <script src=
"/static/node_modules/datatables.net-bs/js/dataTables.bootstrap.min.js"></script>
89 <script src=
"/static/node_modules/select2/dist/js/select2.js"></script>
93 $(document).ready( function () {
94 table = $('#projects_table').DataTable({
97 "url":
"/projects/list",
98 "dataSrc": function (json) {
99 return json['projects'];
103 console.log(
"no auth");
104 moveToLogin(window.location.pathname);
107 "error": function (hxr, error, thrown) {
116 "render": function (data, type, row) {
117 return '
<a href=
"/projects/'+row['name']+'/switch/" >'+row['name']+'
</a>'
122 "render": function (data, type, row) {
123 return moment.unix(row[
"_admin"]['modified']).format('YYYY-MM-DD hh:mm:ss a');
128 "render": function (data, type, row) {
129 return moment.unix(row[
"_admin"]['created']).format('YYYY-MM-DD hh:mm:ss a');
134 "render": function (data, type, row) {
135 return '
<div class=
"btn-group">\n' +
136 '
<button type=
"button" class=
"btn btn-default dropdown-toggle"\n' +
137 '
data-toggle=
"dropdown" aria-expanded=
"false">Actions\n' +
138 '
<span class=
"fa fa-caret-down"></span></button>\n' +
139 '
<ul class=
"dropdown-menu">\n' +
140 '
<li><a href=
"#"\n' +
141 '
onclick=
"javascript:editProject(\''+ row['name']+'\')">\n' +
142 '
<i class=
"fa fa-edit"></i> Rename
</a></li>\n' +
144 '
<a href=
"#" onclick=
"javascript:deleteProject(\''+ row['name']+'\')" style=
"color:red">\n' +
145 '
<i class=
"fa fa-trash" ></i> Delete
</a>\n' +
156 setInterval(function () {
162 function showModalNewProject(args){
163 var dialog = bootbox.dialog({
164 message: '
<div class=
"text-center"><i class=
"fa fa-spin fa-spinner"></i> Loading...
</div>',
168 url: args.domains_list_url,
170 contentType:
"application/json;charset=utf-8",
171 success: function (result_domain) {
173 $('#domain_name').prop('disabled', false).trigger('change');
174 if (result_domain['domains']) {
175 for (d in result_domain['domains']) {
176 var domain = result_domain['domains'][d];
177 if (domain.endsWith(':ro') === false) {
178 domains_list.push({ id: domain, text: domain })
183 if (domains_list.length ==
0) {
184 $('#domainNameGroupDiv').remove();
186 dialog.modal('hide');
188 select2_groups = $('#domain_name').select2({
189 placeholder: 'Select Domain',
192 "noResults": function () {
193 return
"No domains in the platform";
199 $('#modal_new_project').modal('show');
202 error: function (result) {
203 dialog.modal('hide');
204 bootbox.alert(
"An error occurred.");
209 function editProject(project_id){
210 var url =
"/projects/" + project_id+
"/edit";
211 $(
"#formEditProject").attr(
"action", url);
212 $('#modal_edit_project').modal('show');
215 function deleteProject(project_id) {
216 var url =
"/projects/" + project_id+
"/delete";
217 bootbox.confirm(
"Are you sure want to delete?", function (result) {
223 "Accept": 'application/json'
227 }).done(function (response,textStatus, jqXHR) {
230 message:
"Project deleted.",
231 callback: function () {
235 }).fail(function(result){
236 var data = result.responseJSON;
237 var title =
"Error " + (data.code ? data.code: 'unknown');
238 var message = data.detail ? data.detail: 'No detail available.';
248 $(document).ready(function () {
249 $(
"#formNewProject").submit(function (event) {
250 event.preventDefault(); //prevent default action
251 var post_url = $(this).attr(
"action"); //get form action url
252 var request_method = $(this).attr(
"method"); //get form GET/POST method
253 var form_data = new FormData(this); //Encode form elements for submission
254 console.log(post_url);
257 type: request_method,
260 "Accept": 'application/json'
264 }).done(function (response,textStatus, jqXHR) {
267 message:
"Project created.",
268 callback: function () {
270 $('#modal_new_project').modal('hide');
273 }).fail(function(result){
274 var data = result.responseJSON;
275 var title =
"Error " + (data.code ? data.code: 'unknown');
276 var message = data.detail ? data.detail: 'No detail available.';
284 $(
"#formEditProject").submit(function(event){
285 event.preventDefault(); //prevent default action
286 var post_url = $(this).attr(
"action"); //get form action url
287 var request_method = $(this).attr(
"method"); //get form GET/POST method
288 var form_data = new FormData(this); //Encode form elements for submission
289 console.log(post_url);
292 type: request_method,
295 "Accept": 'application/json'
299 }).done(function (response,textStatus, jqXHR) {
302 message:
"Project updated.",
303 callback: function () {
305 $('#modal_edit_project').modal('hide');
308 }).fail(function(result){
309 var data = result.responseJSON;
310 var title =
"Error " + (data.code ? data.code: 'unknown');
311 var message = data.detail ? data.detail: 'No detail available.';