1 {% extends
"base.html" %}
8 <link rel=
"stylesheet" href=
"/static/node_modules/datatables.net-bs/css/dataTables.bootstrap.min.css">
11 {% block title_header_big %}
14 {% block left_sidebar %}
16 {% include 'osm/osm_project_left_sidebar.html' %}
21 {% block breadcrumb_body %}
23 {% if user.is_admin %}
24 <li><a href=
"{% url 'projects:projects_list' %}">Projects
</a></li>
26 <li><a href=
"#">Projects
</a></li>
30 {% block content_body %}
34 <div class=
"col-md-12">
36 <div class=
"box-header with-border">
37 <h3 class=
"box-title">Projects
</h3>
38 <div class=
"box-tools">
39 <button type=
"button" class=
"btn btn-default" data-container=
"body"
40 data-toggle=
"tooltip" data-placement=
"top" title=
"New Project"
41 onclick=
"javascript:showModalNewProject()">
42 <i class=
"fa fa-plus"></i> New Project
</button>
45 <div class=
"box-body">
46 <table id=
"projects_table" class=
"table table-bordered table-striped">
50 <th>Modification Date
</th>
51 <th>Creation Date
</th>
64 {% include
"modal/project_new.html" %}
65 {% include
"modal/project_edit.html" %}
68 {% block resource_block %}
70 <script src=
"/static/node_modules/datatables.net/js/jquery.dataTables.min.js"></script>
71 <script src=
"/static/node_modules/datatables.net-bs/js/dataTables.bootstrap.min.js"></script>
75 $(document).ready( function () {
76 table = $('#projects_table').DataTable({
79 "url":
"/projects/list",
80 "dataSrc": function (json) {
81 return json['projects'];
85 console.log(
"no auth");
86 moveToLogin(window.location.pathname);
89 "error": function (hxr, error, thrown) {
98 "render": function (data, type, row) {
99 return '
<a href=
"/projects/'+row['name']+'/switch/" >'+row['name']+'
</a>'
104 "render": function (data, type, row) {
105 return moment.unix(row[
"_admin"]['modified']).format('YYYY-MM-DD hh:mm:ss a');
110 "render": function (data, type, row) {
111 return moment.unix(row[
"_admin"]['created']).format('YYYY-MM-DD hh:mm:ss a');
116 "render": function (data, type, row) {
117 return '
<div class=
"btn-group">\n' +
118 '
<button type=
"button" class=
"btn btn-default dropdown-toggle"\n' +
119 '
data-toggle=
"dropdown" aria-expanded=
"false">Actions\n' +
120 '
<span class=
"fa fa-caret-down"></span></button>\n' +
121 '
<ul class=
"dropdown-menu">\n' +
122 '
<li><a href=
"#"\n' +
123 '
onclick=
"javascript:editProject(\''+ row['name']+'\')">\n' +
124 '
<i class=
"fa fa-edit"></i> Rename
</a></li>\n' +
126 '
<a href=
"#" onclick=
"javascript:deleteProject(\''+ row['name']+'\')" style=
"color:red">\n' +
127 '
<i class=
"fa fa-trash" ></i> Delete
</a>\n' +
138 setInterval(function () {
144 function showModalNewProject(){
145 $('#modal_new_project').modal('show');
148 function editProject(project_id){
149 var url =
"/projects/" + project_id+
"/edit";
150 $(
"#formEditProject").attr(
"action", url);
151 $('#modal_edit_project').modal('show');
154 function deleteProject(project_id) {
155 var url =
"/projects/" + project_id+
"/delete";
156 bootbox.confirm(
"Are you sure want to delete?", function (result) {
162 "Accept": 'application/json'
166 }).done(function (response,textStatus, jqXHR) {
169 message:
"Project deleted.",
170 callback: function () {
174 }).fail(function(result){
175 var data = result.responseJSON;
176 var title =
"Error " + (data.code ? data.code: 'unknown');
177 var message = data.detail ? data.detail: 'No detail available.';
187 $(document).ready(function () {
188 $(
"#formNewProject").submit(function (event) {
189 event.preventDefault(); //prevent default action
190 var post_url = $(this).attr(
"action"); //get form action url
191 var request_method = $(this).attr(
"method"); //get form GET/POST method
192 var form_data = new FormData(this); //Encode form elements for submission
193 console.log(post_url);
196 type: request_method,
199 "Accept": 'application/json'
203 }).done(function (response,textStatus, jqXHR) {
206 message:
"Project created.",
207 callback: function () {
209 $('#modal_new_project').modal('hide');
212 }).fail(function(result){
213 var data = result.responseJSON;
214 var title =
"Error " + (data.code ? data.code: 'unknown');
215 var message = data.detail ? data.detail: 'No detail available.';
223 $(
"#formEditProject").submit(function(event){
224 event.preventDefault(); //prevent default action
225 var post_url = $(this).attr(
"action"); //get form action url
226 var request_method = $(this).attr(
"method"); //get form GET/POST method
227 var form_data = new FormData(this); //Encode form elements for submission
228 console.log(post_url);
231 type: request_method,
234 "Accept": 'application/json'
238 }).done(function (response,textStatus, jqXHR) {
241 message:
"Project updated.",
242 callback: function () {
244 $('#modal_edit_project').modal('hide');
247 }).fail(function(result){
248 var data = result.responseJSON;
249 var title =
"Error " + (data.code ? data.code: 'unknown');
250 var message = data.detail ? data.detail: 'No detail available.';