management requests table reorganization
[myslice.git] / portal / templates / management-tab-requests.html
1 <script type="text/javascript">
2         $(document).ready(function() {
3                 $("li#nav-request").addClass("active");
4                 $('table.requests').dataTable( {
5             "sDom": "frtiS",
6             "bScrollCollapse": true,
7             "bStateSave": true,
8             "bPaginate": false,
9             "bLengthChange": false,
10             "bFilter": false,
11             "bSort": true,
12             "bInfo": false,
13             "bAutoWidth": true,
14             "bAutoHeight": false,
15         } );
16         });
17         function on_click_event() {
18                 var ids = []; 
19                 $('.portal__validate__checkbox').each(function(i, el) {
20                         if ($(el).prop('checked')) {
21                                 // portal__validate__checkbox__slice__2
22                                 var id_array = $(el).attr('id').split('__');
23                                 // push(slice__2)
24                                 ids.push(id_array[3] + '__' + id_array[4]);
25                         }
26                 });
27                 if (ids.length > 0) {
28                         var id_str = ids.join('/');
29
30                         // XXX spinner
31
32                         $.getJSON('/portal/validate_action/' + id_str,
33                                 function(status) {
34                                         $.each(status, function(request_type__id, request_status) {
35                                                 // request_status: NAME -> dict (status, description)
36                                                 var status_str = '';
37                                                 $.each(request_status, function(name, result) {
38                                                         if (status_str != '')
39                                                                 status_str += ' -- ';
40
41                                                         if (result.status) {
42                                                                 status_str += '<font color="green">OK</font>';
43                                                                 $('#portal__validate__checkbox__' + request_type__id).hide();
44                                                         } else {
45                                                                 status_str += '<font color="red">ERROR: ' + result.description + '</font>';
46                                                         }
47                                                 });
48                                                 $('#portal__status__' + request_type__id).html(status_str);
49
50
51                                         });
52                                 }
53                         );
54                 }
55         }
56         function on_click_reject() {
57                 var ids = []; 
58                 $('.portal__validate__checkbox').each(function(i, el) {
59                         if ($(el).prop('checked')) {
60                                 // portal__validate__checkbox__slice__2
61                                 var id_array = $(el).attr('id').split('__');
62                                 // push(slice__2)
63                                 ids.push(id_array[3] + '__' + id_array[4]);
64                         }
65                 });
66                 if (ids.length > 0) {
67                         var id_str = ids.join('/');
68
69                         // XXX spinner
70
71                         $.getJSON('/portal/reject_action/' + id_str,
72                                 function(status) {
73                                         $.each(status, function(request_type__id, request_status) {
74                                                 // request_status: NAME -> dict (status, description)
75                                                 var status_str = '';
76                                                 $.each(request_status, function(name, result) {
77                                                         if (status_str != '')
78                                                                 status_str += ' -- ';
79
80                                                         if (result.status) {
81                                                                 status_str += '<font color="green">Rejected</font>';
82                                                                 $('#portal__validate__checkbox__' + request_type__id).hide();
83                                                         } else {
84                                                                 status_str += '<font color="red">ERROR: ' + result.description + '</font>';
85                                                         }
86                                                 });
87                                                 $('#portal__status__' + request_type__id).html(status_str);
88
89
90                                         });
91                                 }
92                         );
93                 }
94         }
95 </script>
96
97 <div class="container-fluid">
98 <div class="col-md-12">
99         <h2>From your authorities</h2>
100 </div>
101 {% if my_authorities %}
102         <table class="table-responsive requests">
103         {% for authority, requests in my_authorities.items %}
104         
105         {% for request in requests %}
106         
107         {% if request.type == 'user' %}
108         <tr>
109         {% elif request.type == 'slice' %}
110         <tr class="info">
111         {% else %}
112         <tr class="active">
113         {% endif %}
114             <td><span class="gray small">{{ request.id }}</span></td>
115             <td>
116             {% if request.allowed == 'allowed' %}
117             <input class='portal__validate__checkbox' id='portal__validate__checkbox__{{request.type}}__{{request.id}}' type='checkbox'/>
118             {% else %}
119                 {% if request.allowed == 'expired' %}expired{% else %}denied{% endif %}
120             {% endif %}
121             </td>
122             <td><span class="type">{{ request.type }}</span></td>
123             <td><i>{{authority}}{{request.site_authority}}</i></td>
124                 <td>
125             {% if request.type == 'user' %}
126                 <b>{{request.first_name}} {{request.last_name}}</b> &lt;<a href="mailto:{{request.email}}">{{request.email}}</a>&gt;
127             {% elif request.type == 'slice' %}
128             <b>{{request.slice_name}}</b> -- Number of nodes: {{request.number_of_nodes}} -- Type of nodes: {{request.type_of_nodes}} -- Purpose: {{request.purpose}}
129             {% else %}
130             <b>{{request.site_name}}</b> ({{request.site_authority}}) -- {{request.address_city}}, {{request.address_country}}
131             {% endif %}
132                 </td>
133                 <td>{{ request.timestamp }}</td>
134                 
135                 <td><span id='portal__status__{{request.type}}__{{request.id}}'></span></td>
136     
137         <!--<div class='portal_validate_request {{request.type}} {% if forloop.counter|divisibleby:2 %}even{% else %}odd{% endif %}'> -->
138           </tr>
139     
140         {% endfor %}
141         
142         {% endfor %}
143     </table>
144 {% else %}
145         <div class="col-md-12">
146                 <i>There is no pending request waiting for validation.</i>
147         </div>
148 {% endif %}
149 </div>
150
151
152 <br />
153 <div class="col-md-12">
154         <h2>From your sub-authorities</h2>
155 </div>
156 {% if sub_authorities %}
157         
158         {% for authority, requests in sub_authorities.items %}
159         <div class="col-md-12">
160         <h3>{{authority}}</h3>
161             <table class="table">
162               <th>
163                 <td>Type</td>
164                 <td>Id</td>
165                 <td>Details</td>
166                 <td>Timestamp</td>
167                 <td>Status</td>
168               </th>
169             {% for request in requests %}
170                   <tr>
171                         <td>
172                         {% if request.allowed == 'allowed' %}
173                         <input class='portal__validate__checkbox' id='portal__validate__checkbox__{{request.type}}__{{request.id}}' type='checkbox'/>
174                         {% else %}
175                                 {% if request.allowed == 'expired' %}
176                                         expired
177                                 {% else %} {# denied #}
178                                         denied
179                                 {% endif %}
180                         {% endif %}
181                         </td>
182                         <td>{{ request.type }}</td>
183                         <td>{{ request.id }}</td>
184                         <td>
185                 {% if request.type == 'user' %}
186                 Login: {{request.login}} -- First name: {{request.first_name}} -- Last name: {{request.last_name}} -- Email: {{request.email}}
187                 {% else %}
188                     {% if request.type == 'slice' %}
189                 Slice name: {{request.slice_name}} -- Number of nodes: {{request.number_of_nodes}} -- Type of nodes: {{request.type_of_nodes}} -- Purpose: {{request.purpose}}
190                     {% else %} {# authority #}
191                 Authority name: {{request.site_name}} -- authority_hrn: {{request.site_authority}} -- City: {{request.address_city}} -- Country: {{request.address_country}}
192                     {% endif %}
193                 {% endif %}
194                         </td>
195                         <td>{{ request.timestamp }}</td>
196                         
197                         <td><span id='portal__status__{{request.type}}__{{request.id}}'></span></td>
198         
199             <!--<div class='portal_validate_request {{request.type}} {% if forloop.counter|divisibleby:2 %}even{% else %}odd{% endif %}'> -->
200                   </tr>
201             {% endfor %}
202             </table>
203         </div>
204         {% endfor %}
205 {% else %}
206 <div class="col-md-12">
207         <i>There is no pending request waiting for validation.</i>
208 </div>
209 {% endif %}
210 <br />
211 <div class="col-md-12">
212         <h2>From your authorities with delegation</h2>
213 </div>
214
215 {% if delegation_authorities %}
216         
217         {% for authority, requests in delegation_authorities.items %}
218         <div class="col-md-12">
219                 <h3>{{authority}}</h3>
220                     <table class="table">
221                       <th>
222                         <td>Type</td>
223                         <td>Id</td>
224                         <td>Details</td>
225                         <td>Timestamp</td>
226                         <td>Status</td>
227                       </th>
228                     {% for request in requests %}
229                           <tr>
230                                 <td>
231                                 {% if request.allowed == 'allowed' %}
232                                 <input class='portal__validate__checkbox' id='portal__validate__checkbox__{{request.type}}__{{request.id}}' type='checkbox'/>
233                                 {% else %}
234                                         {% if request.allowed == 'expired' %}
235                                                 expired
236                                         {% else %} {# denied #}
237                                                 denied
238                                         {% endif %}
239                                 {% endif %}
240                                 </td>
241                                 <td>{{ request.type }}</td>
242                                 <td>{{ request.id }}</td>
243                                 <td>
244                         {% if request.type == 'user' %}
245                         Login: {{request.login}} -- First name: {{request.first_name}} -- Last name: {{request.last_name}} -- Email: {{request.email}}
246                         {% else %}
247                             {% if request.type == 'slice' %}
248                         Slice name: {{request.slice_name}} -- Number of nodes: {{request.number_of_nodes}} -- Type of nodes: {{request.type_of_nodes}} -- Purpose: {{request.purpose}}
249                             {% else %} {# authority #}
250                         Authority name: {{request.site_name}} -- authority_hrn: {{request.site_authority}} -- City: {{request.address_city}} -- Country: {{request.address_country}}
251                             {% endif %}
252                        {% endif %}
253                                 </td>
254                                 <td>{{ request.timestamp }}</td>
255                                 
256                                 <td><span id='portal__status__{{request.type}}__{{request.id}}'></span></td>
257                 
258                     <!--<div class='portal_validate_request {{request.type}} {% if forloop.counter|divisibleby:2 %}even{% else %}odd{% endif %}'> -->
259                           </tr>
260                     {% endfor %}
261                     </table>
262                 </div>
263                 {% endfor %}
264 {% else %}
265 <div class="col-md-12">
266         <i>There is no pending request waiting for validation.</i>
267 </div>
268 {% endif %}
269 <br />
270 <div class="col-md-12">
271         <button class="btn btn-onelab" type="button" id="portal__validate" onclick="on_click_event();"><span class="glyphicon glyphicon-ok"></span> Validate</button>
272         <button class="btn btn-danger" type="button" id="portal__reject" onclick="on_click_reject();"><span class="glyphicon glyphicon-remove"></span> Reject</button>
273 </div>