mirror of
https://github.com/OpenNebula/one.git
synced 2025-01-12 09:17:41 +03:00
Merge branch 'master' of git.opennebula.org:one
This commit is contained in:
commit
85db3f0c21
@ -99,9 +99,8 @@ module OpenNebulaJSON
|
|||||||
super(params['hard'])
|
super(params['hard'])
|
||||||
end
|
end
|
||||||
|
|
||||||
def migrate(params=Hash.new, live=false, enforce=false)
|
def migrate(params=Hash.new, live=false)
|
||||||
# TODO add enforce parameter
|
super(params['host_id'], live, params['enforce'])
|
||||||
super(params['host_id'], live)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def save_as(params=Hash.new)
|
def save_as(params=Hash.new)
|
||||||
|
@ -709,12 +709,12 @@ var OpenNebula = {
|
|||||||
"deploy",action_obj);
|
"deploy",action_obj);
|
||||||
},
|
},
|
||||||
"livemigrate": function(params){
|
"livemigrate": function(params){
|
||||||
var action_obj = {"host_id": params.data.extra_param};
|
var action_obj = params.data.extra_param;
|
||||||
OpenNebula.Action.simple_action(params,OpenNebula.VM.resource,
|
OpenNebula.Action.simple_action(params,OpenNebula.VM.resource,
|
||||||
"livemigrate",action_obj);
|
"livemigrate",action_obj);
|
||||||
},
|
},
|
||||||
"migrate": function(params){
|
"migrate": function(params){
|
||||||
var action_obj = {"host_id": params.data.extra_param};
|
var action_obj = params.data.extra_param;
|
||||||
OpenNebula.Action.simple_action(params,OpenNebula.VM.resource,
|
OpenNebula.Action.simple_action(params,OpenNebula.VM.resource,
|
||||||
"migrate",action_obj);
|
"migrate",action_obj);
|
||||||
},
|
},
|
||||||
|
@ -213,6 +213,17 @@ var settings_update_password = '<div class="panel">\
|
|||||||
<div class=""></div>\
|
<div class=""></div>\
|
||||||
</div>\
|
</div>\
|
||||||
</div>\
|
</div>\
|
||||||
|
<div class="row centered">\
|
||||||
|
<div class="four columns">\
|
||||||
|
<label class="inline right" for="confirm_password">'+tr("Confirm Password")+':</label>\
|
||||||
|
</div>\
|
||||||
|
<div class="seven columns">\
|
||||||
|
<input type="password" name="confirm_password" id="confirm_password" />\
|
||||||
|
</div>\
|
||||||
|
<div class="one columns">\
|
||||||
|
<div class=""></div>\
|
||||||
|
</div>\
|
||||||
|
</div>\
|
||||||
<hr>\
|
<hr>\
|
||||||
<div class="form_buttons">\
|
<div class="form_buttons">\
|
||||||
<button class="button radius right success" id="update_pw_submit" type="submit" value="User.update">'+tr("Change")+'</button>\
|
<button class="button radius right success" id="update_pw_submit" type="submit" value="User.update">'+tr("Change")+'</button>\
|
||||||
@ -256,12 +267,18 @@ function setupUpdatePassword() {
|
|||||||
|
|
||||||
$('#settings_update_password_form',dialog).submit(function(){
|
$('#settings_update_password_form',dialog).submit(function(){
|
||||||
var pw=$('#new_password',this).val();
|
var pw=$('#new_password',this).val();
|
||||||
|
var confirm_password=$('#confirm_password',this).val();
|
||||||
|
|
||||||
if (!pw.length){
|
if (!pw.length){
|
||||||
notifyError(tr("Fill in a new password"));
|
notifyError(tr("Fill in a new password"));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (pw !== confirm_password){
|
||||||
|
notifyError(tr("Password does not match"));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
Sunstone.runAction("UserSettings.passwd",[-1],pw);
|
Sunstone.runAction("UserSettings.passwd",[-1],pw);
|
||||||
$('#settings_update_password',dialogs_context).trigger("reveal:close")
|
$('#settings_update_password',dialogs_context).trigger("reveal:close")
|
||||||
return false;
|
return false;
|
||||||
|
@ -172,6 +172,17 @@ var update_pw_tmpl = '<div class="panel">\
|
|||||||
<div class=""></div>\
|
<div class=""></div>\
|
||||||
</div>\
|
</div>\
|
||||||
</div>\
|
</div>\
|
||||||
|
<div class="row centered">\
|
||||||
|
<div class="four columns">\
|
||||||
|
<label class="inline right" for="confirm_password">'+tr("Confirm Password")+':</label>\
|
||||||
|
</div>\
|
||||||
|
<div class="seven columns">\
|
||||||
|
<input type="password" name="confirm_password" id="confirm_password" />\
|
||||||
|
</div>\
|
||||||
|
<div class="one columns">\
|
||||||
|
<div class=""></div>\
|
||||||
|
</div>\
|
||||||
|
</div>\
|
||||||
<hr>\
|
<hr>\
|
||||||
<div class="form_buttons">\
|
<div class="form_buttons">\
|
||||||
<button class="button radius right success" id="update_pw_submit" type="submit" value="User.update">'+tr("Change")+'</button>\
|
<button class="button radius right success" id="update_pw_submit" type="submit" value="User.update">'+tr("Change")+'</button>\
|
||||||
@ -870,12 +881,18 @@ function setupUpdatePasswordDialog(){
|
|||||||
|
|
||||||
$('#update_user_pw_form',dialog).submit(function(){
|
$('#update_user_pw_form',dialog).submit(function(){
|
||||||
var pw=$('#new_password',this).val();
|
var pw=$('#new_password',this).val();
|
||||||
|
var confirm_password=$('#confirm_password',this).val();
|
||||||
|
|
||||||
if (!pw.length){
|
if (!pw.length){
|
||||||
notifyError(tr("Fill in a new password"));
|
notifyError(tr("Fill in a new password"));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (pw !== confirm_password){
|
||||||
|
notifyError(tr("Password does not match"));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
Sunstone.runAction("User.passwd",getSelectedNodes(dataTable_users),pw);
|
Sunstone.runAction("User.passwd",getSelectedNodes(dataTable_users),pw);
|
||||||
$update_pw_dialog.trigger("reveal:close")
|
$update_pw_dialog.trigger("reveal:close")
|
||||||
return false;
|
return false;
|
||||||
|
@ -389,10 +389,103 @@ var deploy_vm_tmpl ='\
|
|||||||
</form>\
|
</form>\
|
||||||
</div>';
|
</div>';
|
||||||
|
|
||||||
|
var migrate_vm_tmpl ='\
|
||||||
|
<div class="panel">\
|
||||||
|
<h3>\
|
||||||
|
<small id="migrate_vm_header">'+tr("Migrate Virtual Machine")+'</small>\
|
||||||
|
</h3>\
|
||||||
|
</div>\
|
||||||
|
<div class="reveal-body">\
|
||||||
|
<form id="migrate_vm_form" action="">\
|
||||||
|
<div id="current_hosts_of_vms" class="row">\
|
||||||
|
</div>\
|
||||||
|
<br><br>\
|
||||||
|
<div class="row">\
|
||||||
|
<fieldset>\
|
||||||
|
<legend>'+tr("Select a Host")+'</legend>\
|
||||||
|
<div class="row collapse">\
|
||||||
|
<div class="seven columns">\
|
||||||
|
<button id="refresh_migrate_hosts_table_button_class" type="button" class="button small radius secondary"><i class="icon-refresh" /></button>\
|
||||||
|
</div>\
|
||||||
|
<div class="five columns">\
|
||||||
|
<input id="migrate_hosts_table_search" type="text" placeholder="'+tr("Search")+'"/>\
|
||||||
|
</div>\
|
||||||
|
</div>\
|
||||||
|
<table id="migrate_datatable_hosts" class="datatable twelve">\
|
||||||
|
<thead>\
|
||||||
|
<tr>\
|
||||||
|
<th></th>\
|
||||||
|
<th>' + tr("ID") + '</th>\
|
||||||
|
<th>' + tr("Name") + '</th>\
|
||||||
|
<th>' + tr("Cluster") + '</th>\
|
||||||
|
<th>' + tr("RVMs") + '</th>\
|
||||||
|
<th>' + tr("Real CPU") + '</th>\
|
||||||
|
<th>' + tr("Allocated CPU") + '</th>\
|
||||||
|
<th>' + tr("Real MEM") + '</th>\
|
||||||
|
<th>' + tr("Allocated MEM") + '</th>\
|
||||||
|
<th>' + tr("Status") + '</th>\
|
||||||
|
<th>' + tr("IM MAD") + '</th>\
|
||||||
|
<th>' + tr("VM MAD") + '</th>\
|
||||||
|
<th>' + tr("Last monitored on") + '</th>\
|
||||||
|
</tr>\
|
||||||
|
</thead>\
|
||||||
|
<tbody id="tbodyhosts">\
|
||||||
|
</tbody>\
|
||||||
|
</table>\
|
||||||
|
<div class="row hidden">\
|
||||||
|
<div class="four columns">\
|
||||||
|
<label class="right inline" for="HOST_ID">'+tr("HOST_ID")+':</label>\
|
||||||
|
</div>\
|
||||||
|
<div class="six columns">\
|
||||||
|
<input type="text" id="HOST_ID" name="HOST_ID"/>\
|
||||||
|
</div>\
|
||||||
|
<div class="two columns">\
|
||||||
|
<div class="tip">\
|
||||||
|
</div>\
|
||||||
|
</div>\
|
||||||
|
</div>\
|
||||||
|
<br>\
|
||||||
|
<div id="selected_host" class="vm_param kvm_opt xen_opt vmware_opt">\
|
||||||
|
<span id="select_host" class="radius secondary label">'+tr("Please select a Host from the list")+'</span>\
|
||||||
|
<span id="host_selected" class="radius secondary label hidden">'+tr("You selected the following Host:")+'</span>\
|
||||||
|
<span class="radius label" type="text" id="HOST_NAME" name="host"></span>\
|
||||||
|
</div>\
|
||||||
|
</fieldset>\
|
||||||
|
</div>\
|
||||||
|
<br>\
|
||||||
|
<br>\
|
||||||
|
<div class="show_hide" id="advanced_toggle">\
|
||||||
|
<h4><small><i class=" icon-caret-down"/> '+tr("Advanced options")+'<a id="" class="icon_left" href="#"></a></small></h4>\
|
||||||
|
</div>\
|
||||||
|
<div id="advanced_migrate" class="row advanced">\
|
||||||
|
<div class="row">\
|
||||||
|
<div class="three columns">\
|
||||||
|
<label class="inline right" for="vm_id">'+tr("Enforce")+':</label>\
|
||||||
|
</div>\
|
||||||
|
<div class="two columns">\
|
||||||
|
<input type="checkbox" name="enforce" id="enforce"/>\
|
||||||
|
</div>\
|
||||||
|
<div class="one columns pull-seven tip">'
|
||||||
|
+ tr("If it is set to true, the host capacity will be checked. This will only affect oneadmin requests, regular users resize requests will always be enforced") +
|
||||||
|
'</div>\
|
||||||
|
</div>\
|
||||||
|
</div>\
|
||||||
|
<div class="form_buttons reveal-footer">\
|
||||||
|
<hr>\
|
||||||
|
<div class="form_buttons">\
|
||||||
|
<button class="button radius right success" id="migrate_vm_proceed" value="VM.migrate">'+tr("Migrate")+'</button>\
|
||||||
|
<button class="close-reveal-modal button secondary radius" type="button" value="close">' + tr("Close") + '</button>\
|
||||||
|
</div>\
|
||||||
|
</div>\
|
||||||
|
<a class="close-reveal-modal">×</a>\
|
||||||
|
</form>\
|
||||||
|
</div>';
|
||||||
|
|
||||||
var vmachine_list_json = {};
|
var vmachine_list_json = {};
|
||||||
var dataTable_vMachines;
|
var dataTable_vMachines;
|
||||||
var $create_vm_dialog;
|
var $create_vm_dialog;
|
||||||
var $deploy_vm_dialog;
|
var $deploy_vm_dialog;
|
||||||
|
var $migrate_vm_dialog;
|
||||||
var $vnc_dialog;
|
var $vnc_dialog;
|
||||||
var rfb;
|
var rfb;
|
||||||
|
|
||||||
@ -472,19 +565,31 @@ var vm_actions = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
"VM.migrate" : {
|
"VM.migrate" : {
|
||||||
type: "multiple",
|
type: "custom",
|
||||||
|
call: function(){
|
||||||
|
popUpMigrateVMDialog(false);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
"VM.migrate_action" : {
|
||||||
|
type: "single",
|
||||||
call: OpenNebula.VM.migrate,
|
call: OpenNebula.VM.migrate,
|
||||||
callback: vmShow,
|
callback: vmShow,
|
||||||
elements: function() { return getSelectedNodes(dataTable_vMachines); },
|
|
||||||
error: onError,
|
error: onError,
|
||||||
notify: true
|
notify: true
|
||||||
},
|
},
|
||||||
|
|
||||||
"VM.migrate_live" : {
|
"VM.migrate_live" : {
|
||||||
type: "multiple",
|
type: "custom",
|
||||||
|
call: function(){
|
||||||
|
popUpMigrateVMDialog(true);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
"VM.migrate_live_action" : {
|
||||||
|
type: "single",
|
||||||
call: OpenNebula.VM.livemigrate,
|
call: OpenNebula.VM.livemigrate,
|
||||||
callback: vmShow,
|
callback: vmShow,
|
||||||
elements: vmElements,
|
|
||||||
error: onError,
|
error: onError,
|
||||||
notify: true
|
notify: true
|
||||||
},
|
},
|
||||||
@ -953,20 +1058,18 @@ var vm_buttons = {
|
|||||||
condition: mustBeAdmin
|
condition: mustBeAdmin
|
||||||
},
|
},
|
||||||
"VM.migrate" : {
|
"VM.migrate" : {
|
||||||
type: "confirm_with_select",
|
type: "action",
|
||||||
text: tr("Migrate"),
|
text: tr("Migrate"),
|
||||||
tip: tr("This will migrate the selected VMs to the chosen host"),
|
tip: tr("This will migrate the selected VMs to the chosen host"),
|
||||||
layout: "vmsplanification_buttons",
|
layout: "vmsplanification_buttons",
|
||||||
select: hosts_sel,
|
|
||||||
condition: mustBeAdmin
|
condition: mustBeAdmin
|
||||||
|
|
||||||
},
|
},
|
||||||
"VM.migrate_live" : {
|
"VM.migrate_live" : {
|
||||||
type: "confirm_with_select",
|
type: "action",
|
||||||
text: tr("Migrate") + ' <span class="label secondary radius">live</span>',
|
text: tr("Migrate") + ' <span class="label secondary radius">live</span>',
|
||||||
tip: tr("This will live-migrate the selected VMs to the chosen host"),
|
tip: tr("This will live-migrate the selected VMs to the chosen host"),
|
||||||
layout: "vmsplanification_buttons",
|
layout: "vmsplanification_buttons",
|
||||||
select: hosts_sel,
|
|
||||||
condition: mustBeAdmin
|
condition: mustBeAdmin
|
||||||
},
|
},
|
||||||
"VM.hold" : {
|
"VM.hold" : {
|
||||||
@ -3354,6 +3457,107 @@ function setupDeployVMDialog(){
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function setupMigrateVMDialog(live){
|
||||||
|
dialogs_context.append('<div id="migrate_vm_dialog"></div>');
|
||||||
|
//Insert HTML in place
|
||||||
|
$migrate_vm_dialog = $('#migrate_vm_dialog')
|
||||||
|
var dialog = $migrate_vm_dialog;
|
||||||
|
dialog.html(migrate_vm_tmpl);
|
||||||
|
dialog.addClass("reveal-modal large max-height");
|
||||||
|
|
||||||
|
var dataTable_migrate_hosts = $('#migrate_datatable_hosts', dialog).dataTable({
|
||||||
|
"iDisplayLength": 4,
|
||||||
|
"bAutoWidth":false,
|
||||||
|
"sDom" : '<"H">t<"F"p>',
|
||||||
|
"aoColumnDefs": [
|
||||||
|
{ "bSortable": false, "aTargets": ["check",5,6,7,8] },
|
||||||
|
{ "sWidth": "35px", "aTargets": [0] }, //check, ID, RVMS, Status,
|
||||||
|
{ "bVisible": false, "aTargets": [3,5,7,10,11,12]}
|
||||||
|
],
|
||||||
|
"fnDrawCallback": function(oSettings) {
|
||||||
|
var nodes = this.fnGetNodes();
|
||||||
|
$.each(nodes, function(){
|
||||||
|
if ($(this).find("td:eq(0)").html() == $('#HOST_ID', dialog).val()) {
|
||||||
|
$("td", this).addClass('markrow');
|
||||||
|
$('input.check_item', this).attr('checked','checked');
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$('tbody input.check_item:checked',dataTable_vMachines).each(function(){
|
||||||
|
var data = dataTable_vMachines.fnGetData( $(this).closest('tr')[0] );
|
||||||
|
$("#current_hosts_of_vms").append('<span class="radius secondary label">'+tr("VM")+' ['+$(this).val() + '] ' + tr("is currently running on Host") + ' [' + data[8] + ']</span><br>')
|
||||||
|
});
|
||||||
|
|
||||||
|
// Retrieve the images to fill the datatable
|
||||||
|
update_datatable_template_hosts(dataTable_migrate_hosts);
|
||||||
|
|
||||||
|
$('#migrate_hosts_table_search', dialog).keyup(function(){
|
||||||
|
dataTable_migrate_hosts.fnFilter( $(this).val() );
|
||||||
|
})
|
||||||
|
|
||||||
|
$('#migrate_datatable_hosts tbody', dialog).delegate("tr", "click", function(e){
|
||||||
|
var aData = dataTable_migrate_hosts.fnGetData(this);
|
||||||
|
|
||||||
|
$("td.markrow", dataTable_migrate_hosts).removeClass('markrow');
|
||||||
|
$('tbody input.check_item', dataTable_migrate_hosts).removeAttr('checked');
|
||||||
|
|
||||||
|
$('#host_selected', dialog).show();
|
||||||
|
$('#select_host', dialog).hide();
|
||||||
|
$('.alert-box', dialog).hide();
|
||||||
|
|
||||||
|
$("td", this).addClass('markrow');
|
||||||
|
$('input.check_item', this).attr('checked','checked');
|
||||||
|
|
||||||
|
$('#HOST_NAME', dialog).text(aData[2]);
|
||||||
|
$('#HOST_ID', dialog).val(aData[1]);
|
||||||
|
return true;
|
||||||
|
});
|
||||||
|
|
||||||
|
$("#refresh_migrate_hosts_table_button_class").die();
|
||||||
|
$("#refresh_migrate_hosts_table_button_class").live('click', function(){
|
||||||
|
update_datatable_template_hosts($('#migrate_datatable_hosts').dataTable());
|
||||||
|
});
|
||||||
|
|
||||||
|
$('#advanced_migrate', dialog).hide();
|
||||||
|
$('#advanced_toggle',dialog).click(function(){
|
||||||
|
$('#advanced_migrate',dialog).toggle();
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
setupTips(dialog);
|
||||||
|
|
||||||
|
$('#migrate_vm_form',dialog).submit(function(){
|
||||||
|
var extra_info = {};
|
||||||
|
|
||||||
|
if ($('#HOST_ID', dialog).val()) {
|
||||||
|
extra_info['host_id'] = $('#HOST_ID', dialog).val();
|
||||||
|
} else {
|
||||||
|
notifyError(tr("You have not selected a host"));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
extra_info['enforce'] = $("#enforce", this).is(":checked") ? true : false
|
||||||
|
|
||||||
|
//notifySubmit("Template.instantiate",template_id, extra_msg);
|
||||||
|
|
||||||
|
$.each(getSelectedNodes(dataTable_vMachines), function(index, elem) {
|
||||||
|
console.log(elem)
|
||||||
|
if (live) {
|
||||||
|
console.log("live")
|
||||||
|
Sunstone.runAction("VM.migrate_live_action", elem, extra_info);
|
||||||
|
} else {
|
||||||
|
console.log("migrate")
|
||||||
|
Sunstone.runAction("VM.migrate_action", elem, extra_info);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$migrate_vm_dialog.trigger("reveal:close")
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// Open creation dialog
|
// Open creation dialog
|
||||||
function popUpDeployVMDialog(){
|
function popUpDeployVMDialog(){
|
||||||
setupDeployVMDialog();
|
setupDeployVMDialog();
|
||||||
@ -3361,6 +3565,11 @@ function popUpDeployVMDialog(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Open creation dialog
|
||||||
|
function popUpMigrateVMDialog(live){
|
||||||
|
setupMigrateVMDialog(live);
|
||||||
|
$migrate_vm_dialog.reveal();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//Prepares autorefresh
|
//Prepares autorefresh
|
||||||
|
@ -867,70 +867,6 @@ function insertButtonsInTab(tab_name, panel_name, panel_buttons, custom_context)
|
|||||||
//another containing a list of actions that can be folded/unfolded.
|
//another containing a list of actions that can be folded/unfolded.
|
||||||
function initListButtons(){
|
function initListButtons(){
|
||||||
|
|
||||||
// //for each multi_action select
|
|
||||||
// $('.multi_action_slct',main_tabs_context).each(function(){
|
|
||||||
// //prepare replacement buttons
|
|
||||||
// var buttonset = $('<div style="display:inline-block;" class="top_button"></div');
|
|
||||||
// var button1 = $('<button class="last_action_button action_button confirm_button confirm_with_select_button" value="">'+tr("Previous action")+'</button>')//.button();
|
|
||||||
// button1.attr('disabled','disabled');
|
|
||||||
// var button2 = $('<button class="list_button" value="">See more</button>')
|
|
||||||
// //.button({
|
|
||||||
// // text:false,
|
|
||||||
// // icons: { primary: "ui-icon-triangle-1-s" }
|
|
||||||
// //});
|
|
||||||
// // buttonset.append(button1);
|
|
||||||
// // buttonset.append(button2);
|
|
||||||
// // buttonset.buttonset();
|
|
||||||
////
|
|
||||||
// //prepare list
|
|
||||||
// var options = $('option', $(this));
|
|
||||||
// var list = $('<ul class="action_list"></ul>');
|
|
||||||
// $.each(options,function(){
|
|
||||||
// var classes = $(this).attr('class');
|
|
||||||
// var item = $('<li></li>');
|
|
||||||
// var a = $('<a href="#" class="'+classes+'" value="'+$(this).val()+'">'+$(this).text()+'</a>');
|
|
||||||
// a.val($(this).val());
|
|
||||||
// item.html(a);
|
|
||||||
// list.append(item);
|
|
||||||
// });
|
|
||||||
// list.css({
|
|
||||||
// "display":"none"
|
|
||||||
// });
|
|
||||||
//
|
|
||||||
// $(this).before(buttonset);
|
|
||||||
// $(this).parents('.action_blocks').append(list);
|
|
||||||
// $(this).remove();
|
|
||||||
//
|
|
||||||
// });
|
|
||||||
//
|
|
||||||
// //below the listeners for events on these buttons and list
|
|
||||||
//
|
|
||||||
// //enable run the last action button
|
|
||||||
// //$('.action_list li a',main_tabs_context).click(function(){
|
|
||||||
// // //enable run last action button
|
|
||||||
// // var prev_action_button = $('.last_action_button',$(this).parents('.action_blocks'));
|
|
||||||
// // prev_action_button.val($(this).val());
|
|
||||||
// // prev_action_button.removeClass("confirm_with_select_button");
|
|
||||||
// // prev_action_button.removeClass("confirm_button");
|
|
||||||
// // prev_action_button.removeClass("action_button");
|
|
||||||
// // prev_action_button.addClass($(this).attr('class'));
|
|
||||||
// // prev_action_button.button("option","label",$(this).text());
|
|
||||||
// // prev_action_button.button("enable");
|
|
||||||
// // $(this).parents('ul').hide("blind",100);
|
|
||||||
// // //return false;
|
|
||||||
// //});
|
|
||||||
//
|
|
||||||
// //Show the list of actions in place
|
|
||||||
// $('.list_button',main_tabs_context).click(function(){
|
|
||||||
// $('.action_list',$(this).parents('.action_blocks')).css({
|
|
||||||
// "left": $(this).prev().position().left,
|
|
||||||
// "top": $(this).prev().position().top+13,
|
|
||||||
// "width": $(this).parent().outerWidth()-11
|
|
||||||
// });
|
|
||||||
// //100ms animation time
|
|
||||||
// $('.action_list',$(this).parents('.action_blocks')).toggle("blind",100);
|
|
||||||
// return false;
|
|
||||||
// });
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Prepares the standard confirm dialogs
|
//Prepares the standard confirm dialogs
|
||||||
@ -947,6 +883,11 @@ function setupConfirmDialogs(){
|
|||||||
</div>\
|
</div>\
|
||||||
<form action="">\
|
<form action="">\
|
||||||
<div id="confirm_tip">'+tr("You have to confirm this action.")+'</div>\
|
<div id="confirm_tip">'+tr("You have to confirm this action.")+'</div>\
|
||||||
|
<br />\
|
||||||
|
<div class="row">\
|
||||||
|
<span id="confirm_action" class="radius secondary label"></span><br>\
|
||||||
|
<span id="confirm_ids" class="radius secondary label"></span><br><br>\
|
||||||
|
</div>\
|
||||||
<br />\
|
<br />\
|
||||||
<div id="question">'+tr("Do you want to proceed?")+'</div>\
|
<div id="question">'+tr("Do you want to proceed?")+'</div>\
|
||||||
<br />\
|
<br />\
|
||||||
@ -958,27 +899,14 @@ function setupConfirmDialogs(){
|
|||||||
<a class="close-reveal-modal">×</a>\
|
<a class="close-reveal-modal">×</a>\
|
||||||
</form>');
|
</form>');
|
||||||
|
|
||||||
//prepare the jquery dialog
|
|
||||||
//dialog.dialog({
|
|
||||||
// resizable:false,
|
|
||||||
// modal:true,
|
|
||||||
// width:300,
|
|
||||||
// heigth:200,
|
|
||||||
// autoOpen:false
|
|
||||||
//});
|
|
||||||
dialog.addClass("reveal-modal");
|
dialog.addClass("reveal-modal");
|
||||||
|
|
||||||
//enhace the button look
|
|
||||||
//$('button',dialog).button();
|
|
||||||
|
|
||||||
|
|
||||||
dialogs_context.append('<div id="confirm_with_select_dialog" title=\"'+tr("Confirmation of action")+'\"></div>');
|
dialogs_context.append('<div id="confirm_with_select_dialog" title=\"'+tr("Confirmation of action")+'\"></div>');
|
||||||
dialog = $('div#confirm_with_select_dialog',dialogs_context);
|
dialog = $('div#confirm_with_select_dialog',dialogs_context);
|
||||||
|
|
||||||
dialog.html(
|
dialog.html(
|
||||||
'<div class="panel">\
|
'<div class="panel">\
|
||||||
<h3>\
|
<h3>\
|
||||||
<small>'+tr("Confirm")+'</small>\
|
<small>'+tr("Confirm")+'</small><br><br>\
|
||||||
</h3>\
|
</h3>\
|
||||||
</div>\
|
</div>\
|
||||||
<form action="">\
|
<form action="">\
|
||||||
@ -989,6 +917,9 @@ function setupConfirmDialogs(){
|
|||||||
<select style="margin: 10px 0;" id="confirm_select">\
|
<select style="margin: 10px 0;" id="confirm_select">\
|
||||||
</select>\
|
</select>\
|
||||||
</div>\
|
</div>\
|
||||||
|
<div class="row">\
|
||||||
|
<span id="confirm_action" class="radius secondary label"></span><br>\
|
||||||
|
<span id="confirm_ids" class="radius secondary label"></span>\
|
||||||
</div>\
|
</div>\
|
||||||
<hr>\
|
<hr>\
|
||||||
<div class="form_buttons">\
|
<div class="form_buttons">\
|
||||||
@ -998,18 +929,8 @@ function setupConfirmDialogs(){
|
|||||||
<a class="close-reveal-modal">×</a>\
|
<a class="close-reveal-modal">×</a>\
|
||||||
</form>');
|
</form>');
|
||||||
|
|
||||||
//prepare the jquery dialog
|
|
||||||
//dialog.dialog({
|
|
||||||
// resizable:false,
|
|
||||||
// modal:true,
|
|
||||||
// width:300,
|
|
||||||
// heigth:300,
|
|
||||||
// autoOpen:false
|
|
||||||
//});
|
|
||||||
dialog.addClass("reveal-modal")
|
dialog.addClass("reveal-modal")
|
||||||
|
|
||||||
//$('button',dialog).button();
|
|
||||||
|
|
||||||
//when we proceed with a "confirm with select" we need to
|
//when we proceed with a "confirm with select" we need to
|
||||||
//find out if we are running an action with a parametre on a datatable
|
//find out if we are running an action with a parametre on a datatable
|
||||||
//items or if its just an action
|
//items or if its just an action
|
||||||
@ -1063,6 +984,11 @@ function popUpConfirmDialog(target_elem){
|
|||||||
|
|
||||||
$('button#confirm_proceed',dialog).val(value);
|
$('button#confirm_proceed',dialog).val(value);
|
||||||
|
|
||||||
|
var action = SunstoneCfg["actions"][value];
|
||||||
|
if (action.elements()) {
|
||||||
|
$("#confirm_action").html(tr("Action: ") + value)
|
||||||
|
$("#confirm_ids").html(tr("Selected resources: ") + action.elements().join(', '))
|
||||||
|
}
|
||||||
|
|
||||||
$('div#confirm_tip',dialog).text(tip);
|
$('div#confirm_tip',dialog).text(tip);
|
||||||
dialog.reveal();
|
dialog.reveal();
|
||||||
@ -1087,6 +1013,12 @@ function popUpConfirmWithSelectDialog(target_elem){
|
|||||||
$('select#confirm_select',dialog).html(select_var);
|
$('select#confirm_select',dialog).html(select_var);
|
||||||
$('div#confirm_with_select_tip',dialog).text(tip);
|
$('div#confirm_with_select_tip',dialog).text(tip);
|
||||||
|
|
||||||
|
var action = SunstoneCfg["actions"][value];
|
||||||
|
if (action.elements()) {
|
||||||
|
$("#confirm_action").html(tr("Action: ") + value)
|
||||||
|
$("#confirm_ids").html(tr("Selected resources: ") + action.elements().join(', '))
|
||||||
|
}
|
||||||
|
|
||||||
$('button#confirm_with_select_proceed',dialog).val(value);
|
$('button#confirm_with_select_proceed',dialog).val(value);
|
||||||
dialog.reveal();
|
dialog.reveal();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user