[pve-devel] [PATCH manager 3/6] gui: add form/PCISelector
Dominik Csapak
d.csapak at proxmox.com
Fri Nov 16 16:29:53 CET 2018
this adds a form field for selecting a pci device
Signed-off-by: Dominik Csapak <d.csapak at proxmox.com>
---
www/manager6/Makefile | 1 +
www/manager6/form/PCISelector.js | 89 ++++++++++++++++++++++++++++++++++++++++
2 files changed, 90 insertions(+)
create mode 100644 www/manager6/form/PCISelector.js
diff --git a/www/manager6/Makefile b/www/manager6/Makefile
index cc2f7203..ea5b00b2 100644
--- a/www/manager6/Makefile
+++ b/www/manager6/Makefile
@@ -41,6 +41,7 @@ JSSRC= \
form/StorageSelector.js \
form/DiskStorageSelector.js \
form/BridgeSelector.js \
+ form/PCISelector.js \
form/SecurityGroupSelector.js \
form/IPRefSelector.js \
form/IPProtocolSelector.js \
diff --git a/www/manager6/form/PCISelector.js b/www/manager6/form/PCISelector.js
new file mode 100644
index 00000000..b30881fa
--- /dev/null
+++ b/www/manager6/form/PCISelector.js
@@ -0,0 +1,89 @@
+Ext.define('PVE.form.PCISelector', {
+ extend: 'Proxmox.form.ComboGrid',
+ xtype: 'pvePCISelector',
+
+ store: {
+ fields: [ 'id','vendor', 'device', 'vendorid', 'deviceid', 'iommugroup', 'mdev' ],
+ filterOnLoad: true,
+ sorters: [
+ {
+ property : 'id',
+ direction: 'ASC'
+ }
+ ]
+ },
+
+ autoSelect: false,
+ valueField: 'id',
+ displayField: 'id',
+
+ // can contain a load callback for the store
+ // useful to determine the state of the IOMMU
+ onLoadCallBack: undefined,
+
+ listConfig: {
+ width: 800,
+ columns: [
+ {
+ header: 'ID',
+ dataIndex: 'id',
+ width: 80
+ },
+ {
+ header: gettext('IOMMU group'),
+ dataIndex: 'iommugroup',
+ width: 50
+ },
+ {
+ header: gettext('Vendor'),
+ dataIndex: 'vendor',
+ flex: 1
+ },
+ {
+ header: gettext('Device'),
+ dataIndex: 'device',
+ flex: 1.5
+ },
+ {
+ header: gettext('Mediated Devices'),
+ dataIndex: 'mdev',
+ renderer: function(val) {
+ return Proxmox.Utils.format_boolean(!!val);
+ }
+ }
+ ]
+ },
+
+ setNodename: function(nodename) {
+ var me = this;
+
+ if (!nodename || (me.nodename === nodename)) {
+ return;
+ }
+
+ me.nodename = nodename;
+
+ me.store.setProxy({
+ type: 'proxmox',
+ url: '/api2/json/nodes/' + me.nodename + '/scan/pci'
+ });
+
+ me.store.load();
+ },
+
+ initComponent: function() {
+ var me = this;
+
+ var nodename = me.nodename;
+ me.nodename = undefined;
+
+ me.callParent();
+
+ if (me.onLoadCallBack !== undefined) {
+ me.mon(me.getStore(), 'load', me.onLoadCallBack);
+ }
+
+ me.setNodename(nodename);
+ }
+});
+
--
2.11.0
More information about the pve-devel
mailing list