This came up in support, and there is no reason to not have it in
the UI, while having it in the API.

Signed-off-by: Hannes Laimer <h.lai...@proxmox.com>
---
v2:
 - use Aaron's improved help text

v3, thanks @Fabian and @Fiona:
 - handle if a path is set correctly
 - move to BaseStorage, so we don't have the same code in two places

 www/manager6/storage/Base.js | 44 ++++++++++++++++++++++++++++++++++++
 1 file changed, 44 insertions(+)

diff --git a/www/manager6/storage/Base.js b/www/manager6/storage/Base.js
index c8c735f3..813f961b 100644
--- a/www/manager6/storage/Base.js
+++ b/www/manager6/storage/Base.js
@@ -4,6 +4,13 @@ Ext.define('PVE.panel.StorageBase', {
 
     type: '',
 
+    viewModel: {
+       data: {
+           isMpReadOnly: false,
+           isMpChecked: false,
+       },
+    },
+
     onGetValues: function(values) {
        let me = this;
 
@@ -19,6 +26,16 @@ Ext.define('PVE.panel.StorageBase', {
        return values;
     },
 
+    setValues: function(values) {
+       let isMp = values.is_mountpoint;
+       let isMpSet = !!isMp && isMp !== '0';
+       let isMpIsPath = isMpSet && isMp !== '1';
+       this.viewModel.set('isMpReadOnly', isMpIsPath);
+       this.viewModel.set('isMpChecked', isMpSet);
+
+       this.callParent([values]);
+    },
+
     initComponent: function() {
        let me = this;
 
@@ -73,6 +90,33 @@ Ext.define('PVE.panel.StorageBase', {
            }
        }
 
+       const hasIsMountpointStorageTypes = ['dir', 'btrfs'];
+
+       if (hasIsMountpointStorageTypes.includes(me.type)) {
+           const isMountpointBox = {
+               xtype: 'proxmoxcheckbox',
+               name: 'is_mountpoint',
+               uncheckedValue: 0,
+               fieldLabel: gettext('Mountpoint'),
+               bind: {
+                   disabled: '{isMpReadOnly}',
+                   value: '{isMpChecked}',
+               },
+               autoEl: {
+                   tag: 'div',
+                   'data-qtip': gettext('Enable if something is mounted at 
this path. Storage is considered offline as long as nothing is mounted.'),
+               },
+           };
+
+           me.advancedColumn1 = me.advancedColumn1 || [];
+           me.advancedColumn2 = me.advancedColumn2 || [];
+           if (me.advancedColumn2.length < me.advancedColumn1.length) {
+               me.advancedColumn2.unshift(isMountpointBox);
+           } else {
+               me.advancedColumn1.unshift(isMountpointBox);
+           }
+       }
+
        me.callParent();
     },
 });
-- 
2.39.5



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

Reply via email to