2 <div id="select-platform" class="list-group">
5 <ul class="list-group">
6 <li class="list-group-item">Authority:<b> {{user_details.parent_authority}}</b>
7 <!--<select id="auth_list">
8 <option value="ple.upmc">UPMC</option>
9 <option value="ple.inria">INRIA</option>
10 <option value="ple.nitos">NITOS</option>
11 <option value="ple.iminds">iMinds</option>
14 <li class="list-group-item">Filter: slice</li>
15 <li class="list-group-item">...</li>
16 <li class="list-group-item">...</li>
17 <li class="list-group-item">...</li>
21 <div class="col-md-10">
24 <div id="user-tab-loading"><img src="{{ STATIC_URL }}img/loading.gif" alt="Loading Useres" /></div>
25 <div id="user-tab-loaded" style="display:none;">
35 <!-- XXX TODO: for the moment only PIs have access to Update but users that have slice credentials should also have access to that -->
37 {% if 'is_pi' in pi %}
38 <button id="addusers" type="button" class="btn btn-default"><span class="glyphicon glyphicon-ok"></span> Update users</button>
42 $(document).ready(function() {
44 $.post("/rest/user/",{'filters':{'parent_authority': "{{user_details.parent_authority}}"}}, function( data ) {
48 user_gid, user_enabled, slices, pi_authorities, keys, parent_authority, user_first_name,
49 user_urn, user_last_name, user_phone, user_hrn, user_email, user_type
51 $.each( data, function( key, val ) {
52 list_users.push( "<li><a href=\"portal/user/"+val.user_email+"\">" + val.user_email + "</a></li>" );
54 // checking the box for the users that belong to the selected slice
55 var flag_checkbox = 0;
56 for(var data in val.slices) {
57 var element = val.slices[data];
58 if (element == "{{slice}}"){
59 //console.log("the slice is: "+ element);
61 slice_users.push (val.user_hrn)
62 user_row += "<td><input type='checkbox' checked='True' class='user'></td>";
65 if(flag_checkbox != 1){
66 user_row += "<td><input type='checkbox' class='user'></td>";
68 user_row += "<td>"+val.user_email+"</td>";
69 user_row += "<td>"+val.user_hrn+"</td>";
70 user_row += "<td>"+val.user_enabled+"</td>";
72 table_users.push(user_row);
75 console.log("slice users before");
76 console.log(slice_users);
78 $("table#user-tab tr:last").after(table_users.join( "" ));
79 $("div#user-tab-loaded").css("display","block");
80 $("div#user-tab-loading").css("display","none");
81 $("input:checkbox.user").click(function() {
82 console.log("user_hrn");
83 user_hrn = $(this).closest('tr').find('td:eq(2)').html();
84 console.log(user_hrn);
85 console.log(this.checked);
87 var record_id = this.id;
88 slice_users.push (user_hrn);
90 console.log("not checked");
91 slice_users = $.grep(slice_users, function( user, i ) {
92 return user != user_hrn;
95 console.log(slice_users);
99 $('button#addusers').click(function() {
100 $.post("/update/slice/",{'filters':{'slice_hrn':'{{slice}}'},'params':{'users':slice_users}}, function(data) {
103 // TODO: highlight row after success
104 //$('tr[id="'+record_id+'"]').highlight();
105 mysliceAlert('Success: slice updated','success', true);
107 mysliceAlert('Rest Error for: '+data.error,'warning', true);
109 }); // post update slice
111 // TODO: refresh table
112 //window.location="/portal/institution#slices";
114 }); // button#addusers click
116 }); // document ready