mirror of
https://git.proxmox.com/git/pve-manager
synced 2025-08-06 12:02:14 +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/StartupEdit.js \
|
||||
panel/NotesView.js \
|
||||
grid/ObjectGrid.js \
|
||||
grid/PendingObjectGrid.js \
|
||||
grid/ResourceGrid.js \
|
||||
grid/PoolMembers.js \
|
||||
|
@ -126,7 +126,7 @@ Ext.define('PVE.dc.MacPrefixEdit', {
|
||||
});
|
||||
|
||||
Ext.define('PVE.dc.OptionView', {
|
||||
extend: 'PVE.grid.ObjectGrid',
|
||||
extend: 'Proxmox.grid.ObjectGrid',
|
||||
alias: ['widget.pveDcOptionView'],
|
||||
|
||||
onlineHelp: 'datacenter_configuration_file',
|
||||
|
@ -1,5 +1,5 @@
|
||||
Ext.define('PVE.FirewallOptions', {
|
||||
extend: 'PVE.grid.ObjectGrid',
|
||||
extend: 'Proxmox.grid.ObjectGrid',
|
||||
alias: ['widget.pveFirewallOptions'],
|
||||
|
||||
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', {
|
||||
extend: 'PVE.grid.ObjectGrid',
|
||||
extend: 'Proxmox.grid.ObjectGrid',
|
||||
alias: ['widget.pvePendingObjectGrid'],
|
||||
|
||||
getObjectValue: function(key, defaultValue, pending) {
|
||||
|
@ -134,7 +134,7 @@ Ext.define('PVE.lxc.DNSEdit', {
|
||||
|
||||
/*jslint confusion: true */
|
||||
Ext.define('PVE.lxc.DNS', {
|
||||
extend: 'PVE.grid.ObjectGrid',
|
||||
extend: 'Proxmox.grid.ObjectGrid',
|
||||
alias: ['widget.pveLxcDNS'],
|
||||
|
||||
onlineHelp: 'pct_container_network',
|
||||
|
@ -1,6 +1,6 @@
|
||||
/*jslint confusion: true */
|
||||
Ext.define('PVE.lxc.Options', {
|
||||
extend: 'PVE.grid.ObjectGrid',
|
||||
extend: 'Proxmox.grid.ObjectGrid',
|
||||
alias: ['widget.pveLxcOptions'],
|
||||
|
||||
onlineHelp: 'pct_options',
|
||||
|
@ -1,6 +1,6 @@
|
||||
/*jslint confusion: true */
|
||||
Ext.define('PVE.lxc.RessourceView', {
|
||||
extend: 'PVE.grid.ObjectGrid',
|
||||
extend: 'Proxmox.grid.ObjectGrid',
|
||||
alias: ['widget.pveLxcRessourceView'],
|
||||
|
||||
onlineHelp: 'pct_configuration',
|
||||
|
@ -19,7 +19,7 @@ Ext.define('PVE.node.SubscriptionKeyEdit', {
|
||||
});
|
||||
|
||||
Ext.define('PVE.node.Subscription', {
|
||||
extend: 'PVE.grid.ObjectGrid',
|
||||
extend: 'Proxmox.grid.ObjectGrid',
|
||||
|
||||
alias: ['widget.pveNodeSubscription'],
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
Ext.define('PVE.pool.StatusView', {
|
||||
extend: 'PVE.grid.ObjectGrid',
|
||||
extend: 'Proxmox.grid.ObjectGrid',
|
||||
alias: ['widget.pvePoolStatusView'],
|
||||
disabled: true,
|
||||
|
||||
|
@ -171,7 +171,7 @@ Ext.define('PVE.window.TaskViewer', {
|
||||
handler: stop_task
|
||||
});
|
||||
|
||||
statgrid = Ext.create('PVE.grid.ObjectGrid', {
|
||||
statgrid = Ext.create('Proxmox.grid.ObjectGrid', {
|
||||
title: gettext('Status'),
|
||||
layout: 'fit',
|
||||
tbar: [ stop_btn1 ],
|
||||
|
Loading…
Reference in New Issue
Block a user