[pve-devel] [PATCH manager 08/11] gui: add form/PCISelector

Dominik Csapak d.csapak at proxmox.com
Thu Nov 15 15:30:54 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