]> git.proxmox.com Git - pve-manager.git/blobdiff - www/manager6/window/DownloadUrlToStorage.js
ui: restore: allow override of some settings
[pve-manager.git] / www / manager6 / window / DownloadUrlToStorage.js
index cd747c004f953c5b13be59b786d04870dfa39182..48543d28f7251cf856dbc99bb7837f453cf0512f 100644 (file)
@@ -25,20 +25,29 @@ Ext.define('PVE.window.DownloadUrlToStorage', {
        url: '/nodes/{nodename}/storage/{storage}/download-url',
     },
 
-    resetValues: function() {
-       this.setValues({
+
+    viewModel: {
+       data: {
            size: '-',
            mimetype: '-',
-       });
+           enableQuery: true,
+       },
     },
 
     controller: {
        xclass: 'Ext.app.ViewController',
 
        urlChange: function(field) {
-           let view = this.getView();
-           view.down('[name=check]').setDisabled(false);
-           view.resetValues();
+           this.resetMetaInfo();
+           this.setQueryEnabled();
+       },
+       setQueryEnabled: function() {
+           this.getViewModel().set('enableQuery', true);
+       },
+       resetMetaInfo: function() {
+           let vm = this.getViewModel();
+           vm.set('size', '-');
+           vm.set('mimetype', '-');
        },
 
        urlCheck: function(field) {
@@ -47,8 +56,8 @@ Ext.define('PVE.window.DownloadUrlToStorage', {
 
            const queryParam = view.getValues();
 
-           view.down('[name=check]').setDisabled(true);
-           view.resetValues();
+           me.getViewModel().set('enableQuery', false);
+           me.resetMetaInfo();
            let urlField = view.down('[name=url]');
 
            Proxmox.Utils.API2Request({
@@ -63,6 +72,8 @@ Ext.define('PVE.window.DownloadUrlToStorage', {
                    urlField.setValidation(res.result.message);
                    urlField.validate();
                    Ext.MessageBox.alert(gettext('Error'), res.htmlStatus);
+                   // re-enable so one can directly requery, e.g., if it was just a network hiccup
+                   me.setQueryEnabled();
                },
                success: function(res, opt) {
                    urlField.setValidation();
@@ -95,6 +106,12 @@ Ext.define('PVE.window.DownloadUrlToStorage', {
        {
            xtype: 'inputpanel',
            border: false,
+           onGetValues: function(values) {
+               if (typeof values.checksum === 'string') {
+                   values.checksum = values.checksum.trim();
+               }
+               return values;
+           },
            columnT: [
                {
                    xtype: 'fieldcontainer',
@@ -116,6 +133,9 @@ Ext.define('PVE.window.DownloadUrlToStorage', {
                            name: 'check',
                            text: gettext('Query URL'),
                            margin: '0 0 0 5',
+                           bind: {
+                               disabled: '{!enableQuery}',
+                           },
                            listeners: {
                                click: 'urlCheck',
                            },
@@ -135,7 +155,9 @@ Ext.define('PVE.window.DownloadUrlToStorage', {
                    xtype: 'displayfield',
                    name: 'size',
                    fieldLabel: gettext('File size'),
-                   value: '-',
+                   bind: {
+                       value: '{size}',
+                   },
                },
            ],
            column2: [
@@ -143,7 +165,9 @@ Ext.define('PVE.window.DownloadUrlToStorage', {
                    xtype: 'displayfield',
                    name: 'mimetype',
                    fieldLabel: gettext('MIME type'),
-                   value: '-',
+                   bind: {
+                       value: '{mimetype}',
+                   },
                },
            ],
            advancedColumn1: [
@@ -176,7 +200,7 @@ Ext.define('PVE.window.DownloadUrlToStorage', {
                    uncheckedValue: 0,
                    checked: true,
                    listeners: {
-                       change: 'urlChange',
+                       change: 'setQueryEnabled',
                    },
                },
            ],