mirror of
https://git.proxmox.com/git/pve-manager
synced 2025-08-09 19:09:36 +00:00
use ObjectGrid from widget toolkit
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com> Reviewed-by: Dominik Csapak <d.csapak@proxmox.com>
This commit is contained in:
parent
09cacce778
commit
8ea2c8709e
@ -86,7 +86,6 @@ JSSRC= \
|
|||||||
window/Settings.js \
|
window/Settings.js \
|
||||||
window/StartupEdit.js \
|
window/StartupEdit.js \
|
||||||
panel/NotesView.js \
|
panel/NotesView.js \
|
||||||
grid/ObjectGrid.js \
|
|
||||||
grid/PendingObjectGrid.js \
|
grid/PendingObjectGrid.js \
|
||||||
grid/ResourceGrid.js \
|
grid/ResourceGrid.js \
|
||||||
grid/PoolMembers.js \
|
grid/PoolMembers.js \
|
||||||
|
@ -126,7 +126,7 @@ Ext.define('PVE.dc.MacPrefixEdit', {
|
|||||||
});
|
});
|
||||||
|
|
||||||
Ext.define('PVE.dc.OptionView', {
|
Ext.define('PVE.dc.OptionView', {
|
||||||
extend: 'PVE.grid.ObjectGrid',
|
extend: 'Proxmox.grid.ObjectGrid',
|
||||||
alias: ['widget.pveDcOptionView'],
|
alias: ['widget.pveDcOptionView'],
|
||||||
|
|
||||||
onlineHelp: 'datacenter_configuration_file',
|
onlineHelp: 'datacenter_configuration_file',
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
Ext.define('PVE.FirewallOptions', {
|
Ext.define('PVE.FirewallOptions', {
|
||||||
extend: 'PVE.grid.ObjectGrid',
|
extend: 'Proxmox.grid.ObjectGrid',
|
||||||
alias: ['widget.pveFirewallOptions'],
|
alias: ['widget.pveFirewallOptions'],
|
||||||
|
|
||||||
fwtype: undefined, // 'dc', 'node' or 'vm'
|
fwtype: undefined, // 'dc', 'node' or 'vm'
|
||||||
|
@ -1,132 +0,0 @@
|
|||||||
/* Renders a list of key values objets
|
|
||||||
|
|
||||||
mandatory config parameters:
|
|
||||||
rows: an object container where each propery is a key-value object we want to render
|
|
||||||
var rows = {
|
|
||||||
keyboard: {
|
|
||||||
header: gettext('Keyboard Layout'),
|
|
||||||
editor: 'PVE.dc.KeyboardEdit',
|
|
||||||
renderer: PVE.Utils.render_kvm_language,
|
|
||||||
required: true
|
|
||||||
},
|
|
||||||
|
|
||||||
optional:
|
|
||||||
disabled: setting this parameter to true will disable selection and focus on the
|
|
||||||
pveObjectGrid as well as greying out input elements.
|
|
||||||
Useful for a readonly tabular display
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
Ext.define('PVE.grid.ObjectGrid', {
|
|
||||||
extend: 'Ext.grid.GridPanel',
|
|
||||||
alias: ['widget.pveObjectGrid'],
|
|
||||||
disabled: false,
|
|
||||||
hideHeaders: true,
|
|
||||||
|
|
||||||
getObjectValue: function(key, defaultValue) {
|
|
||||||
var me = this;
|
|
||||||
var rec = me.store.getById(key);
|
|
||||||
if (rec) {
|
|
||||||
return rec.data.value;
|
|
||||||
}
|
|
||||||
return defaultValue;
|
|
||||||
},
|
|
||||||
|
|
||||||
renderKey: function(key, metaData, record, rowIndex, colIndex, store) {
|
|
||||||
var me = this;
|
|
||||||
var rows = me.rows;
|
|
||||||
var rowdef = (rows && rows[key]) ? rows[key] : {};
|
|
||||||
return rowdef.header || key;
|
|
||||||
},
|
|
||||||
|
|
||||||
renderValue: function(value, metaData, record, rowIndex, colIndex, store) {
|
|
||||||
var me = this;
|
|
||||||
var rows = me.rows;
|
|
||||||
var key = record.data.key;
|
|
||||||
var rowdef = (rows && rows[key]) ? rows[key] : {};
|
|
||||||
|
|
||||||
var renderer = rowdef.renderer;
|
|
||||||
if (renderer) {
|
|
||||||
return renderer(value, metaData, record, rowIndex, colIndex, store);
|
|
||||||
}
|
|
||||||
|
|
||||||
return value;
|
|
||||||
},
|
|
||||||
|
|
||||||
initComponent : function() {
|
|
||||||
var me = this;
|
|
||||||
|
|
||||||
var rows = me.rows;
|
|
||||||
|
|
||||||
if (!me.rstore) {
|
|
||||||
if (!me.url) {
|
|
||||||
throw "no url specified";
|
|
||||||
}
|
|
||||||
|
|
||||||
me.rstore = Ext.create('PVE.data.ObjectStore', {
|
|
||||||
url: me.url,
|
|
||||||
interval: me.interval,
|
|
||||||
extraParams: me.extraParams,
|
|
||||||
rows: me.rows
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
var rstore = me.rstore;
|
|
||||||
|
|
||||||
var store = Ext.create('PVE.data.DiffStore', { rstore: rstore,
|
|
||||||
sorters: [],
|
|
||||||
filters: []
|
|
||||||
});
|
|
||||||
|
|
||||||
if (rows) {
|
|
||||||
Ext.Object.each(rows, function(key, rowdef) {
|
|
||||||
if (Ext.isDefined(rowdef.defaultValue)) {
|
|
||||||
store.add({ key: key, value: rowdef.defaultValue });
|
|
||||||
} else if (rowdef.required) {
|
|
||||||
store.add({ key: key, value: undefined });
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (me.sorterFn) {
|
|
||||||
store.sorters.add(Ext.create('Ext.util.Sorter', {
|
|
||||||
sorterFn: me.sorterFn
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
store.filters.add(Ext.create('Ext.util.Filter', {
|
|
||||||
filterFn: function(item) {
|
|
||||||
if (rows) {
|
|
||||||
var rowdef = rows[item.data.key];
|
|
||||||
if (!rowdef || (rowdef.visible === false)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}));
|
|
||||||
|
|
||||||
Proxmox.Utils.monStoreErrors(me, rstore);
|
|
||||||
|
|
||||||
Ext.applyIf(me, {
|
|
||||||
store: store,
|
|
||||||
stateful: false,
|
|
||||||
columns: [
|
|
||||||
{
|
|
||||||
header: gettext('Name'),
|
|
||||||
width: me.cwidth1 || 200,
|
|
||||||
dataIndex: 'key',
|
|
||||||
renderer: me.renderKey
|
|
||||||
},
|
|
||||||
{
|
|
||||||
flex: 1,
|
|
||||||
header: gettext('Value'),
|
|
||||||
dataIndex: 'value',
|
|
||||||
renderer: me.renderValue
|
|
||||||
}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
|
|
||||||
me.callParent();
|
|
||||||
}
|
|
||||||
});
|
|
@ -1,5 +1,5 @@
|
|||||||
Ext.define('PVE.grid.PendingObjectGrid', {
|
Ext.define('PVE.grid.PendingObjectGrid', {
|
||||||
extend: 'PVE.grid.ObjectGrid',
|
extend: 'Proxmox.grid.ObjectGrid',
|
||||||
alias: ['widget.pvePendingObjectGrid'],
|
alias: ['widget.pvePendingObjectGrid'],
|
||||||
|
|
||||||
getObjectValue: function(key, defaultValue, pending) {
|
getObjectValue: function(key, defaultValue, pending) {
|
||||||
|
@ -134,7 +134,7 @@ Ext.define('PVE.lxc.DNSEdit', {
|
|||||||
|
|
||||||
/*jslint confusion: true */
|
/*jslint confusion: true */
|
||||||
Ext.define('PVE.lxc.DNS', {
|
Ext.define('PVE.lxc.DNS', {
|
||||||
extend: 'PVE.grid.ObjectGrid',
|
extend: 'Proxmox.grid.ObjectGrid',
|
||||||
alias: ['widget.pveLxcDNS'],
|
alias: ['widget.pveLxcDNS'],
|
||||||
|
|
||||||
onlineHelp: 'pct_container_network',
|
onlineHelp: 'pct_container_network',
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*jslint confusion: true */
|
/*jslint confusion: true */
|
||||||
Ext.define('PVE.lxc.Options', {
|
Ext.define('PVE.lxc.Options', {
|
||||||
extend: 'PVE.grid.ObjectGrid',
|
extend: 'Proxmox.grid.ObjectGrid',
|
||||||
alias: ['widget.pveLxcOptions'],
|
alias: ['widget.pveLxcOptions'],
|
||||||
|
|
||||||
onlineHelp: 'pct_options',
|
onlineHelp: 'pct_options',
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*jslint confusion: true */
|
/*jslint confusion: true */
|
||||||
Ext.define('PVE.lxc.RessourceView', {
|
Ext.define('PVE.lxc.RessourceView', {
|
||||||
extend: 'PVE.grid.ObjectGrid',
|
extend: 'Proxmox.grid.ObjectGrid',
|
||||||
alias: ['widget.pveLxcRessourceView'],
|
alias: ['widget.pveLxcRessourceView'],
|
||||||
|
|
||||||
onlineHelp: 'pct_configuration',
|
onlineHelp: 'pct_configuration',
|
||||||
|
@ -19,7 +19,7 @@ Ext.define('PVE.node.SubscriptionKeyEdit', {
|
|||||||
});
|
});
|
||||||
|
|
||||||
Ext.define('PVE.node.Subscription', {
|
Ext.define('PVE.node.Subscription', {
|
||||||
extend: 'PVE.grid.ObjectGrid',
|
extend: 'Proxmox.grid.ObjectGrid',
|
||||||
|
|
||||||
alias: ['widget.pveNodeSubscription'],
|
alias: ['widget.pveNodeSubscription'],
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
Ext.define('PVE.pool.StatusView', {
|
Ext.define('PVE.pool.StatusView', {
|
||||||
extend: 'PVE.grid.ObjectGrid',
|
extend: 'Proxmox.grid.ObjectGrid',
|
||||||
alias: ['widget.pvePoolStatusView'],
|
alias: ['widget.pvePoolStatusView'],
|
||||||
disabled: true,
|
disabled: true,
|
||||||
|
|
||||||
|
@ -171,7 +171,7 @@ Ext.define('PVE.window.TaskViewer', {
|
|||||||
handler: stop_task
|
handler: stop_task
|
||||||
});
|
});
|
||||||
|
|
||||||
statgrid = Ext.create('PVE.grid.ObjectGrid', {
|
statgrid = Ext.create('Proxmox.grid.ObjectGrid', {
|
||||||
title: gettext('Status'),
|
title: gettext('Status'),
|
||||||
layout: 'fit',
|
layout: 'fit',
|
||||||
tbar: [ stop_btn1 ],
|
tbar: [ stop_btn1 ],
|
||||||
|
Loading…
Reference in New Issue
Block a user