var QueryUpdater = Plugin.extend({
init: function(options, element) {
- this.classname="queryupdater";
+ this.classname="queryupdater";
this._super(options, element);
var self = this;
+
+ this.initial = Array();
+ this.selected_resources = Array();
+
this.table = this.elmt('table').dataTable({
// the original querytable layout was
// sDom: "<'row'<'col-xs-5'l><'col-xs-1'r><'col-xs-6'f>>t<'row'<'col-xs-5'i><'col-xs-7'p>>",
sDom: "<'row'<'col-xs-5'l><'col-xs-1'r><'col-xs-6'f>>t>",
// so this does not matter anymore now that the pagination area is turned off
// sPaginationType: 'bootstrap',
- bAutoWidth: true,
+ bAutoWidth: true,
// bJQueryUI : true,
// bRetrieve : true,
// sScrollX : '100%', // Horizontal scrolling
});
// XXX This should not be done at init...
- this.elmt('update').click(this, this.do_update);
+ this.elmt('update').click(this, this.do_checksla);
this.elmt('refresh').click(this, this.do_refresh);
this.elmt('reset').click(this, this.do_reset);
this.elmt('clear_annotations').click(this, this.do_clear_annotations);
/***************************** GUI EVENTS *****************************/
+ do_checksla: function(e) {
+ var username = e.data.options.username;
+ var urn = data.value;
+ var arrayselectedresources = data.selected_resources;
+
+ var accepted_sla = Array();
+ var count = 0;
+ // XXX check that the query is not disabled
+
+ console.log("DATA VALUE: " + data.value);
+
+ //<p>SLA description</p>
+ //<p>Testbed guarantees 0.99 Uptime rate for 0.99 rate of the VirtualWall resources during the sliver lifetime</p>
+ //<p>SLA description</p>
+ //<p>Testbed guarantees 0.99 Uptime rate for 0.99 rate of the WiLab2 resources during the sliver lifetime</p>
+ var promt = $('#modal-body');
+
+ // id="myModalLabel"
+ var flagVW = false;
+ var flagWi = false;
+
+ promt.append('<p>SLA description</p>');
+
+ var wilabForm = "";
+ wilabForm += "<ul>";
+ for(var iter = 0; iter < arrayselectedresources.length; iter++){
+ var list = '<li class="wi'+iter+'" name=wi"'+iter+'">'+arrayselectedresources[iter].toLowerCase()+'</li>';
+
+ if (arrayselectedresources[iter].toLowerCase().indexOf("wilab2") >= 0){
+
+ accepted_sla.push({"wilab2":false});
+ wilabForm += list;
+ flagWi = true;
+
+ }
+
+ }
+ wilabForm += "</ul>";
+
+ //var wallmessage = '<p>SLA description</p><p>Testbed guarantees 0.99 Uptime rate for 0.99 rate of the VirtualWall resources during the sliver lifetime</p>';
+
+ var wallForm = "";
+ wallForm += "<ul>";
+ for(var iter = 0; iter < arrayselectedresources.length; iter++){
+ var list = '<li class="wall'+iter+'" name=wall"'+iter+'" >'+arrayselectedresources[iter].toLowerCase()+'</li>';
+
+ if (arrayselectedresources[iter].toLowerCase().indexOf("wall2") >= 0){
+
+ accepted_sla.push({"wall2":false});
+ wallForm += list;
+ flagVW = true;
+
+ }
+
+ }
+ wallForm += "</ul>";
+
+ var flagDouble = false;
+ if(flagWi)
+ {
+ flagDouble = true;
+ promt.append('<p>Testbed guarantees 0.99 Uptime rate for 0.99 rate of the WiLab2 resources during the sliver lifetime</p>');
+ promt.append(wilabForm);
+ promt.append('<br />');
+ }
+ if(flagVW)
+ {
+ //promt.append(wallmessage);
+ flagDouble = true;
+ promt.append('<p>Testbed guarantees 0.99 Uptime rate for 0.99 rate of the VirtualWall resources during the sliver lifetime</p>');
+ promt.append(wallForm);
+ promt.append('<br />');
+ }
+
+
+ // var wimessage = '<p>SLA description</p><p>Testbed guarantees 0.99 Uptime rate for 0.99 rate of the VirtualWall resources during the sliver lifetime</p>'
+
+ $('#sla_dialog').show();
+ $('#slamodal-wilab2').modal('show');
+
+
+ $("#accept_sla_wilab2").click(function(){
+ console.log("SLA ACCEPTED");
+ console.log("With username: " + username);
+
+ // var promt = $('#modal-body');
+ // var notchecked = true;
+ // for (var i=0;i<50;i++)
+ // {
+ // var wielement = $('#wi'+i);
+ // var wallElement = $('#wall'+i);
+ // if(wielement != null && !wielement.checked)
+ // {
+ // notchecked = false;
+ // }
+ // if(wallElement!= null && !wallElement.checked)
+ // {
+ // notchecked = false;
+ // }
+ // }
+
+
+ if(flagDouble)
+ {
+ $.post("/sla/agreements/simplecreate",
+ { "template_id": "iMindsServiceWiLab2",
+ "user": username,
+ "expiration_time": new Date().toISOString()
+ });
+ $.post("/sla/agreements/simplecreate",
+ { "template_id": "iMindsServiceVirtualwall",
+ "user": username,
+ "expiration_time": new Date().toISOString()
+ });
+
+ $('#slamodal-wilab2').modal('hide');
+ accepted_sla["wilab2"] = true;
+
+ this.do_update(e);
+ }
+ });
+
+ $("#dismiss_sla_wilab2").click(function(){
+ console.log("SLA NOT ACCEPTED");
+ $('#slamodal-wilab2').modal('hide');
+ });
+
+ // for(var iter = 0; iter < arrayselectedresources.length; iter++){
+ // var list = '<input type="checkbox" name="'+iter+'" >'+arrayselectedresources[iter].toLowerCase()+'<br>';
+ // promt.append(list);
+ // if (arrayselectedresources[iter].toLowerCase().indexOf("wall2") >= 0){
+
+
+
+ // accepted_sla.push({"wall2":false});
+
+ // $('#sla_dialog').show();
+ // $('#slamodal-virtualwall').modal('show');
+
+
+ // $("#accept_sla_vwall").click(function(){
+ // console.log("SLA ACCEPTED");
+ // console.log("With username: " + username);
+
+ // $.post("/sla/agreements/simplecreate",
+ // { "template_id": "iMindsServiceVirtualwall",
+ // "user": username,
+ // "expiration_time": new Date()
+ // });
+
+ // $('#slamodal-virtualwall').modal('hide');
+ // accepted_sla["wall2"] = true;
+ // });
+
+ // $("#dismiss_sla_vwall").click(function(){
+ // console.log("SLA NOT ACCEPTED");
+ // $('#slamodal-vir').modal('hide');
+ // });
+
+ // }
+
+ // if (arrayselectedresources[iter].toLowerCase().indexOf("wilab2") >= 0){
+
+ // accepted_sla.push({"wilab2":false});
+
+ // $('#sla_dialog').show();
+ // $('#slamodal-wilab2').modal('show');
+
+
+ // $("#accept_sla_wilab2").click(function(){
+ // console.log("SLA ACCEPTED");
+ // console.log("With username: " + username);
+
+ // $.post("/sla/agreements/simplecreate",
+ // { "template_id": "iMindsServiceWiLab2",
+ // "user": username,
+ // "expiration_time": new Date()
+ // });
+
+ // $('#slamodal-wilab2').modal('hide');
+ // accepted_sla["wilab2"] = true;
+ // });
+
+ // $("#dismiss_sla_wilab2").click(function(){
+ // console.log("SLA NOT ACCEPTED");
+ // $('#slamodal-wilab2').modal('hide');
+ // });
+
+
+ // }
+
+ // }
+
+ // for(var sla in accepted_sla){
+ // if(accepted_sla[sla] == true){
+ // count += 1;
+ // }
+ // }
+
+ // if(count == accepted_sla.length){
+ // this.do_update(e);
+ // }
+ },
+
+
do_update: function(e) {
var self = e.data;
+
+ var username = e.data.options.username;
+ var urn = data.value;
+ // XXX check that the query is not disabled
+
+ self.spin();
+ console.log("do_update");
// XXX check that the query is not disabled
- manifold.raise_event(self.options.query_uuid, RUN_UPDATE);
+ //manifold.raise_event(self.options.query_uuid, RUN_UPDATE);
+
+ // how to stop the spinning after the event?
+ // this should be triggered by some on_updatequery_done ?
+
},
// related buttons are also disabled in the html template
set_state: function(data)
{
+ console.log("function set_state");
var action;
var msg;
var button = '';
// make sure the change is visible : toggle on the whole plugin
// this might have to be made an 'auto-toggle' option of this plugin..
// also it might be needed to be a little finer-grained here
- this.toggle_on();
+
+ // XXX we don't want to show automaticaly the pending when a checkbox is checked
+ //this.toggle_on();
switch(data.request) {
case FIELD_REQUEST_ADD_RESET:
row = this.find_row(data.value);
if (row)
this.table.fnDeleteRow(row.nTr);
+ $("#badge-pending").data('number', $("#badge-pending").data('number') - 1 );
+ $("#badge-pending").text($("#badge-pending").data('number'));
return;
case FIELD_REQUEST_CHANGE:
action = 'UPDATE';
var status = msg + status;
+
+
// find line
// if no, create it, else replace it
// XXX it's not just about adding lines, but sometimes removing some
// XXX how do we handle status reset ?
+ data.value = JSON.stringify(data.value);
+ data.selected_resources = this.selected_resources;
row = this.find_row(data.value);
newline = [
action,
// XXX second parameter refresh = false can improve performance. todo in querytable also
this.table.fnAddData(newline);
row = this.find_row(data.value);
+ $("#badge-pending").data('number', $("#badge-pending").data('number') + 1 );
+ $("#badge-pending").text($("#badge-pending").data('number'));
} else {
// Update row text...
this.table.fnUpdate(newline, row.nTr);
on_new_record: function(record)
{
+ console.log("query_updater on_new_record");
+ console.log(record);
+
// if (not and update) {
// initial['resource'], initial['lease'] ?
- this.initial.push(record.urn);
+ this.initial.push(record);
+ //this.set_record_state(record, RECORD_STATE_ATTACHED);
// We simply add to the table
// } else {
// \ this.initial_resources
on_query_in_progress: function()
{
- messages.debug("queryupdater.on_query_in_progress");
+ messages.debug("queryupdater.on_query_in_progress");
this.spin();
},
this.clear();
},
- on_new_record: function(record)
- {
- },
-
on_query_done: function()
{
+ console.log("on_query_done");
this.unspin();
},
// NOTE: record_key could be sufficient
on_added_record: function(record)
{
+ console.log("on_added_record = ",record);
this.set_record_state(record, RECORD_STATE_ADDED);
+ // update pending number
},
on_removed_record: function(record_key)
{
+ console.log("on_removed_record = ",record_key);
this.set_record_state(RECORD_STATE_REMOVED);
},
on_field_state_changed: function(result)
{
+ console.log("on_field_state_changed");
+ console.log(result);
+ if(result.request == FIELD_REQUEST_ADD){
+ this.selected_resources.push(result.value);
+ } else if(result.request == FIELD_REQUEST_REMOVE_RESET){
+ var i = this.selected_resources.indexOf(result.value);
+ if(i != -1){
+ this.selected_resources.splice(i,1);
+ }
+ }
+ console.log("Resources: " + self.selected_resources);
messages.debug(result)
/* this.set_state(result.request, result.key, result.value, result.status); */
this.set_state(result);
if (!change)
return;
// ioi: Refubrished
- var initial = this.initial_resources;
+ var initial = this.initial;
//var r_removed = []; //
/*-----------------------------------------------------------------------
TODO: remove this dirty hack !!!