copy from ZFSEdit.js to ZFSPoolEdit.js

Signed-off-by: Wolfgang Link <w.l...@proxmox.com>
---
 www/manager/storage/ZFSPoolEdit.js |  173 ++++++++++++++++++++++++++++++++++++
 1 file changed, 173 insertions(+)
 create mode 100644 www/manager/storage/ZFSPoolEdit.js

diff --git a/www/manager/storage/ZFSPoolEdit.js 
b/www/manager/storage/ZFSPoolEdit.js
new file mode 100644
index 0000000..f40bf7a
--- /dev/null
+++ b/www/manager/storage/ZFSPoolEdit.js
@@ -0,0 +1,173 @@
+Ext.define('PVE.storage.ZFSInputPanel', {
+    extend: 'PVE.panel.InputPanel',
+
+    onGetValues: function(values) {
+       var me = this;
+
+       if (me.create) {
+           values.type = 'zfs';
+           values.content = 'images';
+       } else {
+           delete values.storage;
+       }
+
+       values.disable = values.enable ? 0 : 1;
+       delete values.enable;
+
+       return values;
+    },
+
+    initComponent : function() {
+       var me = this;
+
+       me.column1 = [
+           {
+               xtype: me.create ? 'textfield' : 'displayfield',
+               name: 'storage',
+               height: 22, // hack: set same height as text fields
+               value: me.storageId || '',
+               fieldLabel: 'ID',
+               vtype: 'StorageId',
+               allowBlank: false
+           },
+           {
+               xtype: me.create ? 'textfield' : 'displayfield',
+               name: 'portal',
+               height: 22, // hack: set same height as text fields
+               value: '',
+               fieldLabel: gettext('Portal'),
+               allowBlank: false
+           },
+           {
+               xtype: me.create ? 'textfield' : 'displayfield',
+               name: 'pool',
+               height: 22, // hack: set same height as text fields
+               value: '',
+               fieldLabel: gettext('Pool'),
+               allowBlank: false
+           },
+           {
+               xtype: me.create ? 'textfield' : 'displayfield',
+               name: 'blocksize',
+               height: 22, // hack: set same height as text fields
+               value: '4k',
+               fieldLabel: gettext('Block Size'),
+               allowBlank: false
+           },
+           {
+               xtype: me.create ? 'textfield' : 'displayfield',
+               name: 'target',
+               height: 22, // hack: set same height as text fields
+               value: '',
+               fieldLabel: gettext('Target'),
+               allowBlank: false
+           },
+           {
+               xtype: me.create ? 'textfield' : 'displayfield',
+               name: 'comstar_tg',
+               height: 22, // hack: set same height as text fields
+               value: '',
+               fieldLabel: gettext('Target group'),
+               allowBlank: true
+           }
+       ];
+
+       me.column2 = [
+           {
+               xtype: 'pvecheckbox',
+               name: 'enable',
+               checked: true,
+               uncheckedValue: 0,
+               fieldLabel: gettext('Enable')
+           },
+           {
+               xtype: me.create ? 'pveiScsiProviderSelector' : 'displayfield',
+               name: 'iscsiprovider',
+               height: 22, // hack: set same height as text fields
+               value: 'comstar',
+               fieldLabel: gettext('iSCSI Provider'),
+               allowBlank: false
+           },
+           {
+               xtype: 'pvecheckbox',
+               name: 'sparse',
+               checked: false,
+               uncheckedValue: 0,
+               fieldLabel: gettext('Thin provision')
+           },
+           {
+               xtype: 'pvecheckbox',
+               name: 'nowritecache',
+               checked: true,
+               uncheckedValue: 0,
+               fieldLabel: gettext('Write cache')
+           },
+           {
+               xtype: me.create ? 'textfield' : 'displayfield',
+               name: 'comstar_hg',
+               height: 22, // hack: set same height as text fields
+               value: '',
+               fieldLabel: gettext('Host group'),
+               allowBlank: true
+           }
+       ];
+
+       if (me.create || me.storageId !== 'local') {
+           me.column2.unshift({
+               xtype: 'PVE.form.NodeSelector',
+               name: 'nodes',
+               fieldLabel: gettext('Nodes'),
+               emptyText: gettext('All') + ' (' +
+                   gettext('No restrictions') +')',
+               multiSelect: true,
+               autoSelect: false
+           });
+       }
+
+       me.callParent();
+    }
+});
+
+Ext.define('PVE.storage.ZFSEdit', {
+    extend: 'PVE.window.Edit',
+    
+    initComponent : function() {
+       var me = this;
+
+       me.create = !me.storageId;
+
+       if (me.create) {
+            me.url = '/api2/extjs/storage';
+            me.method = 'POST';
+        } else {
+            me.url = '/api2/extjs/storage/' + me.storageId;
+            me.method = 'PUT';
+        }
+
+       var ipanel = Ext.create('PVE.storage.ZFSInputPanel', {
+           create: me.create,
+           storageId: me.storageId
+       });
+
+       Ext.apply(me, {
+            subject: 'ZFS Storage',
+           isAdd: true,
+           items: [ ipanel ]
+       });
+
+       me.callParent();
+
+        if (!me.create) {
+            me.load({
+                success:  function(response, options) {
+                    var values = response.result.data;
+                    if (values.nodes) {
+                        values.nodes = values.nodes.split(',');
+                    }
+                    values.enable = values.disable ? 0 : 1;
+                    ipanel.setValues(values);
+                }
+            });
+        }
+    }
+});
-- 
1.7.10.4


_______________________________________________
pve-devel mailing list
pve-devel@pve.proxmox.com
http://pve.proxmox.com/cgi-bin/mailman/listinfo/pve-devel

Reply via email to