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:
Thomas Lamprecht 2017-12-06 13:49:24 +01:00 committed by Dominik Csapak
parent 09cacce778
commit 8ea2c8709e
11 changed files with 9 additions and 142 deletions

View File

@ -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 \

View File

@ -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',

View 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'

View File

@ -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();
}
});

View File

@ -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) {

View File

@ -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',

View File

@ -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',

View File

@ -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',

View File

@ -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'],

View File

@ -1,5 +1,5 @@
Ext.define('PVE.pool.StatusView', {
extend: 'PVE.grid.ObjectGrid',
extend: 'Proxmox.grid.ObjectGrid',
alias: ['widget.pvePoolStatusView'],
disabled: true,

View File

@ -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 ],