From fd8ed0d84f27095c1b81173b810709c1cd8ab17b Mon Sep 17 00:00:00 2001 From: Thomas Lamprecht Date: Tue, 13 Apr 2021 09:01:28 +0200 Subject: [PATCH] file browser: add config and comments for params, uper case URL Signed-off-by: Thomas Lamprecht --- src/window/FileBrowser.js | 26 ++++++++++++++++++++++---- 1 file changed, 22 insertions(+), 4 deletions(-) diff --git a/src/window/FileBrowser.js b/src/window/FileBrowser.js index 7d82b01..e90b717 100644 --- a/src/window/FileBrowser.js +++ b/src/window/FileBrowser.js @@ -56,6 +56,24 @@ Ext.define("Proxmox.window.FileBrowser", { modal: true, + config: { + // the base-URL to get the list of files. required. + listURL: '', + + // the base download URL, e.g., something like '/api2/...' + downloadURL: '', + + // extra parameters set as proxy paramns and for an actual download request + extraParams: {}, + + // the file types for which the download button should be enabled + downloadableFileTypes: { + 'h': true, // hardlinks + 'f': true, // "normal" files + 'd': true, // directories + }, + }, + controller: { xclass: 'Ext.app.ViewController', @@ -86,7 +104,7 @@ Ext.define("Proxmox.window.FileBrowser", { if (data.type === 'd') { atag.download += ".zip"; } - atag.href = me.buildUrl(view.downloadUrl, params); + atag.href = me.buildUrl(view.downloadURL, params); atag.click(); }, @@ -98,7 +116,7 @@ Ext.define("Proxmox.window.FileBrowser", { if (!selection || selection.length < 1) return; let data = selection[0].data; - let canDownload = view.downloadUrl && ['h', 'f', 'd'].indexOf(data.type) !== -1; + let canDownload = view.downloadURL && view.downloadableFileTypes[data.type]; me.lookup('downloadBtn').setDisabled(!canDownload); }, @@ -106,7 +124,7 @@ Ext.define("Proxmox.window.FileBrowser", { let me = this; let tree = me.lookup('tree'); - if (!view.listUrl) { + if (!view.listURL) { throw "no list URL given"; } @@ -114,7 +132,7 @@ Ext.define("Proxmox.window.FileBrowser", { let proxy = store.getProxy(); Proxmox.Utils.monStoreErrors(tree, store, true); - proxy.setUrl(view.listUrl); + proxy.setUrl(view.listURL); proxy.setExtraParams(view.extraParams); store.load(() => { let root = store.getRoot();