mirror of
https://git.proxmox.com/git/pve-manager
synced 2025-08-02 18:51:07 +00:00
copy lxc/Resources.js from manager to manager6
This commit is contained in:
parent
ab2fac2f75
commit
c7ee0c11ac
279
www/manager6/lxc/Resources.js
Normal file
279
www/manager6/lxc/Resources.js
Normal file
@ -0,0 +1,279 @@
|
||||
/*jslint confusion: true */
|
||||
Ext.define('PVE.lxc.RessourceView', {
|
||||
extend: 'PVE.grid.ObjectGrid',
|
||||
alias: ['widget.pveLxcRessourceView'],
|
||||
|
||||
renderKey: function(key, metaData, rec, rowIndex, colIndex, store) {
|
||||
var me = this;
|
||||
var rows = me.rows;
|
||||
var rowdef = rows[key] || {};
|
||||
|
||||
metaData.tdAttr = "valign=middle";
|
||||
|
||||
if (rowdef.tdCls) {
|
||||
metaData.tdCls = rowdef.tdCls;
|
||||
if (rowdef.tdCls == 'pve-itype-icon-storage') {
|
||||
var value = me.getObjectValue(key, '', true);
|
||||
}
|
||||
}
|
||||
return rowdef.header || key;
|
||||
},
|
||||
|
||||
initComponent : function() {
|
||||
var me = this;
|
||||
var i, confid;
|
||||
|
||||
var nodename = me.pveSelNode.data.node;
|
||||
if (!nodename) {
|
||||
throw "no node name specified";
|
||||
}
|
||||
|
||||
var vmid = me.pveSelNode.data.vmid;
|
||||
if (!vmid) {
|
||||
throw "no VM ID specified";
|
||||
}
|
||||
|
||||
var caps = Ext.state.Manager.get('GuiCap');
|
||||
|
||||
var mpeditor = caps.vms['VM.Config.Disk'] ? 'PVE.lxc.MountPointEdit' : undefined;
|
||||
|
||||
var rows = {
|
||||
memory: {
|
||||
header: gettext('Memory'),
|
||||
editor: caps.vms['VM.Config.Memory'] ? 'PVE.lxc.MemoryEdit' : undefined,
|
||||
never_delete: true,
|
||||
defaultValue: 512,
|
||||
tdCls: 'pve-itype-icon-memory',
|
||||
renderer: function(value) {
|
||||
return PVE.Utils.format_size(value*1024*1024);
|
||||
}
|
||||
},
|
||||
swap: {
|
||||
header: gettext('Swap'),
|
||||
editor: caps.vms['VM.Config.Memory'] ? 'PVE.lxc.MemoryEdit' : undefined,
|
||||
never_delete: true,
|
||||
defaultValue: 512,
|
||||
tdCls: 'pve-itype-icon-swap',
|
||||
renderer: function(value) {
|
||||
return PVE.Utils.format_size(value*1024*1024);
|
||||
}
|
||||
},
|
||||
cpulimit: {
|
||||
header: gettext('CPU limit'),
|
||||
never_delete: true,
|
||||
editor: caps.vms['VM.Config.CPU'] ? 'PVE.lxc.CPUEdit' : undefined,
|
||||
defaultValue: 1,
|
||||
tdCls: 'pve-itype-icon-processor',
|
||||
renderer: function(value) {
|
||||
if (value) { return value; }
|
||||
return gettext('unlimited');
|
||||
}
|
||||
},
|
||||
cpuunits: {
|
||||
header: gettext('CPU units'),
|
||||
never_delete: true,
|
||||
editor: caps.vms['VM.Config.CPU'] ? 'PVE.lxc.CPUEdit' : undefined,
|
||||
defaultValue: 1024,
|
||||
tdCls: 'pve-itype-icon-processor'
|
||||
},
|
||||
rootfs: {
|
||||
header: gettext('Root Disk'),
|
||||
defaultValue: PVE.Utils.noneText,
|
||||
editor: mpeditor,
|
||||
tdCls: 'pve-itype-icon-storage'
|
||||
}
|
||||
};
|
||||
|
||||
for (i = 0; i < 10; i++) {
|
||||
confid = "mp" + i;
|
||||
rows[confid] = {
|
||||
group: 1,
|
||||
tdCls: 'pve-itype-icon-storage',
|
||||
editor: mpeditor,
|
||||
header: gettext('Mount Point') + ' (' + confid + ')'
|
||||
};
|
||||
}
|
||||
|
||||
for (i = 0; i < 8; i++) {
|
||||
confid = "unused" + i;
|
||||
rows[confid] = {
|
||||
group: 1,
|
||||
tdCls: 'pve-itype-icon-storage',
|
||||
editor: mpeditor,
|
||||
header: gettext('Unused Disk') + ' ' + i
|
||||
};
|
||||
}
|
||||
|
||||
var reload = function() {
|
||||
me.rstore.load();
|
||||
};
|
||||
|
||||
var baseurl = 'nodes/' + nodename + '/lxc/' + vmid + '/config';
|
||||
|
||||
var sm = Ext.create('Ext.selection.RowModel', {});
|
||||
|
||||
var run_editor = function() {
|
||||
var rec = sm.getSelection()[0];
|
||||
if (!rec) {
|
||||
return;
|
||||
}
|
||||
|
||||
var rowdef = rows[rec.data.key];
|
||||
if (!rowdef.editor) {
|
||||
return;
|
||||
}
|
||||
|
||||
var editor = rowdef.editor;
|
||||
|
||||
var win = Ext.create(editor, {
|
||||
pveSelNode: me.pveSelNode,
|
||||
confid: rec.data.key,
|
||||
url: '/api2/extjs/' + baseurl
|
||||
});
|
||||
|
||||
win.show();
|
||||
win.on('destroy', reload);
|
||||
};
|
||||
|
||||
var run_resize = function() {
|
||||
var rec = sm.getSelection()[0];
|
||||
if (!rec) {
|
||||
return;
|
||||
}
|
||||
|
||||
var win = Ext.create('PVE.window.MPResize', {
|
||||
disk: rec.data.key,
|
||||
nodename: nodename,
|
||||
vmid: vmid
|
||||
});
|
||||
|
||||
win.show();
|
||||
|
||||
win.on('destroy', reload);
|
||||
};
|
||||
|
||||
var run_remove = function(b, e, rec) {
|
||||
PVE.Utils.API2Request({
|
||||
url: '/api2/extjs/' + baseurl,
|
||||
waitMsgTarget: me,
|
||||
method: 'PUT',
|
||||
params: {
|
||||
'delete': rec.data.key
|
||||
},
|
||||
callback: function() {
|
||||
reload();
|
||||
},
|
||||
failure: function (response, opts) {
|
||||
Ext.Msg.alert('Error', response.htmlStatus);
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
var edit_btn = new PVE.button.Button({
|
||||
text: gettext('Edit'),
|
||||
selModel: sm,
|
||||
disabled: true,
|
||||
enableFn: function(rec) {
|
||||
if (!rec) {
|
||||
return false;
|
||||
}
|
||||
var rowdef = rows[rec.data.key];
|
||||
return !!rowdef.editor;
|
||||
},
|
||||
handler: run_editor
|
||||
});
|
||||
|
||||
var resize_btn = new PVE.button.Button({
|
||||
text: gettext('Resize disk'),
|
||||
selModel: sm,
|
||||
disabled: true,
|
||||
handler: run_resize
|
||||
});
|
||||
|
||||
var remove_btn = new PVE.button.Button({
|
||||
text: gettext('Remove'),
|
||||
selModel: sm,
|
||||
disabled: true,
|
||||
dangerous: true,
|
||||
confirmMsg: function(rec) {
|
||||
var msg = Ext.String.format(gettext('Are you sure you want to remove entry {0}'),
|
||||
"'" + me.renderKey(rec.data.key, {}, rec) + "'");
|
||||
if (rec.data.key.match(/^unused\d+$/)) {
|
||||
msg += " " + gettext('This will permanently erase all image data.');
|
||||
}
|
||||
|
||||
return msg;
|
||||
},
|
||||
handler: run_remove
|
||||
});
|
||||
|
||||
var set_button_status = function() {
|
||||
var sm = me.getSelectionModel();
|
||||
var rec = sm.getSelection()[0];
|
||||
|
||||
if (!rec) {
|
||||
edit_btn.disable();
|
||||
remove_btn.disable();
|
||||
resize_btn.disable();
|
||||
return;
|
||||
}
|
||||
var key = rec.data.key;
|
||||
var value = rec.data.value;
|
||||
var rowdef = rows[key];
|
||||
|
||||
var isDisk = (rowdef.tdCls == 'pve-itype-icon-storage');
|
||||
|
||||
var noedit = rec.data['delete'] || !rowdef.editor;
|
||||
if (!noedit && PVE.UserName !== 'root@pam' && key.match(/^mp\d+$/)) {
|
||||
var mp = PVE.Parser.parseLxcMountPoint(value);
|
||||
if (mp.type !== 'volume') {
|
||||
noedit = true;
|
||||
}
|
||||
}
|
||||
edit_btn.setDisabled(noedit);
|
||||
|
||||
remove_btn.setDisabled(!isDisk || rec.data.key === 'rootfs');
|
||||
resize_btn.setDisabled(!isDisk);
|
||||
|
||||
};
|
||||
|
||||
Ext.applyIf(me, {
|
||||
url: '/api2/json/' + baseurl,
|
||||
selModel: sm,
|
||||
cwidth1: 170,
|
||||
tbar: [
|
||||
{
|
||||
text: gettext('Add'),
|
||||
menu: new Ext.menu.Menu({
|
||||
items: [
|
||||
{
|
||||
text: gettext('Mount Point'),
|
||||
iconCls: 'pve-itype-icon-storage',
|
||||
disabled: !caps.vms['VM.Config.Disk'],
|
||||
handler: function() {
|
||||
var win = Ext.create('PVE.lxc.MountPointEdit', {
|
||||
url: '/api2/extjs/' + baseurl,
|
||||
pveSelNode: me.pveSelNode
|
||||
});
|
||||
win.on('destroy', reload);
|
||||
win.show();
|
||||
}
|
||||
}
|
||||
]
|
||||
})
|
||||
},
|
||||
edit_btn,
|
||||
remove_btn,
|
||||
resize_btn
|
||||
],
|
||||
rows: rows,
|
||||
listeners: {
|
||||
show: reload,
|
||||
itemdblclick: run_editor,
|
||||
selectionchange: set_button_status
|
||||
}
|
||||
});
|
||||
|
||||
me.callParent();
|
||||
}
|
||||
});
|
Loading…
Reference in New Issue
Block a user