]>
git.proxmox.com Git - proxmox-widget-toolkit.git/blob - grid/ObjectGrid.js
1 /* Renders a list of key values objets
3 mandatory config parameters:
4 rows: an object container where each propery is a key-value object we want to render
7 header: gettext('Keyboard Layout'),
8 editor: 'Your.KeyboardEdit',
13 disabled: setting this parameter to true will disable selection and focus on the
14 proxmoxObjectGrid as well as greying out input elements.
15 Useful for a readonly tabular display
19 Ext
.define('Proxmox.grid.ObjectGrid', {
20 extend
: 'Ext.grid.GridPanel',
21 alias
: ['widget.proxmoxObjectGrid'],
25 getObjectValue: function(key
, defaultValue
) {
27 var rec
= me
.store
.getById(key
);
29 return rec
.data
.value
;
34 renderKey: function(key
, metaData
, record
, rowIndex
, colIndex
, store
) {
37 var rowdef
= (rows
&& rows
[key
]) ? rows
[key
] : {};
38 return rowdef
.header
|| key
;
41 renderValue: function(value
, metaData
, record
, rowIndex
, colIndex
, store
) {
44 var key
= record
.data
.key
;
45 var rowdef
= (rows
&& rows
[key
]) ? rows
[key
] : {};
47 var renderer
= rowdef
.renderer
;
49 return renderer(value
, metaData
, record
, rowIndex
, colIndex
, store
);
55 initComponent : function() {
62 throw "no url specified";
65 me
.rstore
= Ext
.create('Proxmox.data.ObjectStore', {
67 interval
: me
.interval
,
68 extraParams
: me
.extraParams
,
73 var rstore
= me
.rstore
;
75 var store
= Ext
.create('Proxmox.data.DiffStore', { rstore
: rstore
,
81 Ext
.Object
.each(rows
, function(key
, rowdef
) {
82 if (Ext
.isDefined(rowdef
.defaultValue
)) {
83 store
.add({ key
: key
, value
: rowdef
.defaultValue
});
84 } else if (rowdef
.required
) {
85 store
.add({ key
: key
, value
: undefined });
91 store
.sorters
.add(Ext
.create('Ext.util.Sorter', {
96 store
.filters
.add(Ext
.create('Ext.util.Filter', {
97 filterFn: function(item
) {
99 var rowdef
= rows
[item
.data
.key
];
100 if (!rowdef
|| (rowdef
.visible
=== false)) {
108 Proxmox
.Utils
.monStoreErrors(me
, rstore
);
115 header
: gettext('Name'),
116 width
: me
.cwidth1
|| 200,
118 renderer
: me
.renderKey
122 header
: gettext('Value'),
124 renderer
: me
.renderValue