1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-03-21 14:50:08 +03:00

feature #3748: Add template scheduled actions panel

This commit is contained in:
Daniel Molina 2015-06-09 18:45:59 +02:00
parent 7d393820a6
commit b2ee8711ef
4 changed files with 228 additions and 7 deletions

View File

@ -23,6 +23,7 @@ define(function(require) {
require('./vms-tab/panels/network'),
require('./vms-tab/panels/snapshots'),
require('./vms-tab/panels/placement'),
require('./vms-tab/panels/actions'),
// require('./vms-tab/panels/template')
];

View File

@ -44,7 +44,6 @@ define(function(require) {
"VM.chmod": _commonActions.singleAction('chmod'),
"VM.rename": _commonActions.singleAction('rename'),
"VM.update_template": _commonActions.singleAction('update'),
"VM.update_actions": _commonActions.singleAction('update'),
"VM.deploy_action": _commonActions.singleAction('deploy'),
"VM.migrate_action": _commonActions.singleAction('migrate'),
"VM.migrate_live_action": _commonActions.singleAction('livemigrate'),
@ -98,12 +97,6 @@ define(function(require) {
},
error: onError
},
"VM.deploy" : {
type: "custom",
call: function() {
popUpDeployVMDialog();
}
},
"VM.silent_deploy_action" : {

View File

@ -0,0 +1,224 @@
define(function(require) {
/*
DEPENDENCIES
*/
var Locale = require('utils/locale');
var Sunstone = require('sunstone');
var Humanize = require('utils/humanize');
var TemplateUtils = require('utils/template-utils');
/*
CONSTANTS
*/
var TAB_ID = require('../tabId');
var PANEL_ID = require('./actions/panelId');
var RESOURCE = "VM";
var XML_ROOT = "VM";
/*
CONSTRUCTOR
*/
function Panel(info) {
this.panelId = PANEL_ID;
this.title = Locale.tr("Actions");
this.icon = "fa-calendar";
this.element = info[XML_ROOT];
return this;
};
Panel.PANEL_ID = PANEL_ID;
Panel.prototype.html = _html;
Panel.prototype.setup = _setup;
return Panel;
/*
FUNCTION DEFINITIONS
*/
function _html() {
var that = this;
var html = '<div class="row">\
<div class="large-12 columns">\
<table id="scheduling_actions_table" class="info_table dataTable extended_table">\
<thead>\
<tr>\
<th>' + Locale.tr("ID") + '</th>\
<th>' + Locale.tr("ACTION") + '</th>\
<th>' + Locale.tr("TIME") + '</th>\
<th>' + Locale.tr("DONE") + '</th>\
<th>' + Locale.tr("MESSAGE") + '</th>\
<th colspan="">' + Locale.tr("Actions") + '</th>\
<th><button id="add_scheduling_action" class="button tiny success right radius" >' + Locale.tr("Add action") + '</button></th>\
</tr>\
</thead>' +
fromJSONtoActionsTable(that.element.USER_TEMPLATE.SCHED_ACTION) +
'</table>\
</div>\
</div>';
return html;
}
function _setup(context) {
var that = this;
context.off('click', '#add_scheduling_action');
context.on('click', '#add_scheduling_action', function() {
$("#add_scheduling_action", context).attr("disabled", "disabled");
$("#scheduling_actions_table").append('<tr>\
<td></td>\
<td class="columns">\
<select id="select_new_action" class="select_new_action" name="select_action">\
<option value="shutdown">' + Locale.tr("shutdown") + '</option>\
<option value="shutdown-hard">' + Locale.tr("shutdown-hard") + '</option>\
<option value="hold">' + Locale.tr("hold") + '</option>\
<option value="release">' + Locale.tr("release") + '</option>\
<option value="stop">' + Locale.tr("stop") + '</option>\
<option value="suspend">' + Locale.tr("suspend") + '</option>\
<option value="resume">' + Locale.tr("resume") + '</option>\
<option value="delete">' + Locale.tr("delete") + '</option>\
<option value="delete-recreate">' + Locale.tr("delete-recreate") + '</option>\
<option value="reboot">' + Locale.tr("reboot") + '</option>\
<option value="reboot-hard">' + Locale.tr("reboot-hard") + '</option>\
<option value="poweroff">' + Locale.tr("poweroff") + '</option>\
<option value="poweroff-hard">' + Locale.tr("poweroff-hard") + '</option>\
<option value="undeploy">' + Locale.tr("undeploy") + '</option>\
<option value="undeploy-hard">' + Locale.tr("undeploy-hard") + '</option>\
<option value="snapshot-create">' + Locale.tr("snapshot-create") + '</option>\
</select>\
</td>\
<td>\
<input id="date_input" type="date" placeholder="2013/12/30"/>\
<input id="time_input" type="time" placeholder="12:30"/>\
</td>\
<td>\
<button id="submit_scheduling_action" class="button small secondary radius" >' + Locale.tr("Add") + '</button>\
</td>\
<td colspan=2></td>\
</tr>');
return false;
});
context.off("click", "#submit_scheduling_action");
context.on("click", "#submit_scheduling_action", function() {
var date_input_value = $("#date_input", context).val();
var time_input_value = $("#time_input", context).val();
if (date_input_value == "" || time_input_value == "")
return false;
var time_value = date_input_value + ' ' + time_input_value
// Calculate MAX_ID
var max_id = -1;
if (that.element.USER_TEMPLATE.SCHED_ACTION) {
if (!that.element.USER_TEMPLATE.SCHED_ACTION.length) {
var tmp_element = that.element.USER_TEMPLATE.SCHED_ACTION;
that.element.USER_TEMPLATE.SCHED_ACTION = new Array();
that.element.USER_TEMPLATE.SCHED_ACTION.push(tmp_element);
}
$.each(that.element.USER_TEMPLATE.SCHED_ACTION, function(i, element) {
if (max_id < element.ID)
max_id = element.ID
})
} else {
that.element.USER_TEMPLATE.SCHED_ACTION = new Array();
}
var new_action = {};
new_action.ID = parseInt(max_id) + 1;
new_action.ACTION = $("#select_new_action", context).val();
var epoch_str = new Date(time_value);
new_action.TIME = parseInt(epoch_str.getTime()) / 1000;
that.element.USER_TEMPLATE.SCHED_ACTION.push(new_action);
// Let OpenNebula know
var template_str = TemplateUtils.templateToString(that.element.USER_TEMPLATE);
Sunstone.runAction("VM.update_template", that.element.ID, template_str);
$("#add_scheduling_action", context).removeAttr("disabled");
return false;
});
// Listener for key,value pair remove action
context.off("click", ".remove_action_x");
context.on("click", ".remove_action_x", function() {
var index = this.id.substring(6, this.id.length);
var tmp_tmpl = new Array();
$.each(that.element.USER_TEMPLATE.SCHED_ACTION, function(i, element) {
if (element.ID != index)
tmp_tmpl[i] = element
})
that.element.USER_TEMPLATE.SCHED_ACTION = tmp_tmpl;
var template_str = TemplateUtils.templateToString(that.element.USER_TEMPLATE);
// Let OpenNebula know
Sunstone.runAction("VM.update_template", that.element.ID, template_str);
});
}
// Returns an HTML string with the json keys and values
function fromJSONtoActionsTable(actions_array) {
var str = ""
var empty = '\
<tr id="no_actions_tr">\
<td colspan="6">' + Locale.tr("No actions to show") + '</td>\
</tr>' ;
if (!actions_array) {
return empty;
}
if (!$.isArray(actions_array)) {
var tmp_array = new Array();
tmp_array[0] = actions_array;
actions_array = tmp_array;
}
if (!actions_array.length) {
return empty;
}
$.each(actions_array, function(index, scheduling_action) {
str += fromJSONtoActionRow(scheduling_action);
});
return str;
}
// Helper for fromJSONtoHTMLTable function
function fromJSONtoActionRow(scheduling_action) {
var done_str = scheduling_action.DONE ? (Humanize.prettyTime(scheduling_action.DONE)) : "";
var message_str = scheduling_action.MESSAGE ? scheduling_action.MESSAGE : "";
var time_str = Humanize.prettyTime(scheduling_action.TIME);
var str = "";
str += '<tr class="tr_action_' + scheduling_action.ID + '">\
<td class="id_row">' + scheduling_action.ID + '</td>\
<td class="action_row">' + scheduling_action.ACTION + '</td>\
<td nowrap class="time_row">' + time_str + '</td>\
<td class="done_row">' + done_str + '</td>\
<td class="message_row">' + message_str + '</td>\
<td>\
<div>\
<a id="minus_' + scheduling_action.ID + '" class="remove_action_x" href="#"><i class="fa fa-trash-o"/></a>\
</div>\
</td>\
</tr>';
return str;
}
});

View File

@ -0,0 +1,3 @@
define(function(require){
return 'vm_actions_tab';
});