From b95d97d07b1f190b0ef9f433c7fba2beaedc6f80 Mon Sep 17 00:00:00 2001 From: Chocobo1 Date: Mon, 10 Oct 2022 19:36:32 +0800 Subject: [PATCH 1/3] WebUI: simplify attribute usage The `multiple` attribute is a boolean value and its presence equals to `true`. --- src/webui/www/private/upload.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/webui/www/private/upload.html b/src/webui/www/private/upload.html index a656d07df..4233ab66a 100644 --- a/src/webui/www/private/upload.html +++ b/src/webui/www/private/upload.html @@ -14,7 +14,7 @@
- +
From af1c97e2ead8a1cfddf048f959c500882abe33ee Mon Sep 17 00:00:00 2001 From: Chocobo1 Date: Mon, 10 Oct 2022 19:43:04 +0800 Subject: [PATCH 2/3] WebUI: filter file selection to bittorrent files Note that the user can still overwrite the selection filter and select other files. --- src/webui/www/private/upload.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/webui/www/private/upload.html b/src/webui/www/private/upload.html index 4233ab66a..0c6f5d498 100644 --- a/src/webui/www/private/upload.html +++ b/src/webui/www/private/upload.html @@ -14,7 +14,7 @@
- +
From 3b9d68f344d71f051fc131d523a5a7c23dbb523c Mon Sep 17 00:00:00 2001 From: Chocobo1 Date: Mon, 10 Oct 2022 20:06:52 +0800 Subject: [PATCH 3/3] WebUI: handle drag and drop events This allows user to drag and drop .torrent files and URL links onto the main window and will open the respective dialog. Dropping folders are not supported due to technical reasons. Closes #6038. --- src/webui/www/private/scripts/client.js | 93 ++++++++++++++++++++++++- 1 file changed, 92 insertions(+), 1 deletion(-) diff --git a/src/webui/www/private/scripts/client.js b/src/webui/www/private/scripts/client.js index 7d8882ba1..d9e4bc2b8 100644 --- a/src/webui/www/private/scripts/client.js +++ b/src/webui/www/private/scripts/client.js @@ -128,7 +128,6 @@ const qbtVersion = function() { }; window.addEvent('load', function() { - const saveColumnSizes = function() { const filters_width = $('Filters').getSize().x; const properties_height_rel = $('propertiesPanel').getSize().y / Window.getSize().y; @@ -1187,6 +1186,98 @@ window.addEvent('load', function() { $('searchTabLink').addEvent('click', showSearchTab); $('rssTabLink').addEvent('click', showRssTab); updateTabDisplay(); + + const registerDragAndDrop = () => { + $('desktop').addEventListener('dragover', (ev) => { + if (ev.preventDefault) + ev.preventDefault(); + }); + + $('desktop').addEventListener('dragenter', (ev) => { + if (ev.preventDefault) + ev.preventDefault(); + }); + + $('desktop').addEventListener("drop", (ev) => { + if (ev.preventDefault) + ev.preventDefault(); + + const droppedFiles = ev.dataTransfer.files; + + if (droppedFiles.length > 0) { + // dropped files or folders + + // can't handle folder due to cannot put the filelist (from dropped folder) + // to `files` field + for (const item of ev.dataTransfer.items) { + if (item.webkitGetAsEntry().isDirectory) + return; + } + + const id = 'uploadPage'; + new MochaUI.Window({ + id: id, + title: "QBT_TR(Upload local torrent)QBT_TR[CONTEXT=HttpServer]", + loadMethod: 'iframe', + contentURL: new URI("upload.html").toString(), + addClass: 'windowFrame', // fixes iframe scrolling on iOS Safari + scrollbars: true, + maximizable: false, + paddingVertical: 0, + paddingHorizontal: 0, + width: loadWindowWidth(id, 500), + height: loadWindowHeight(id, 460), + onResize: () => { + saveWindowSize(id); + }, + onContentLoaded: () => { + const fileInput = $(`${id}_iframe`).contentDocument.getElementById('fileselect'); + fileInput.files = droppedFiles; + } + }); + } + + const droppedText = ev.dataTransfer.getData("text"); + if (droppedText.length > 0) { + // dropped text + + const urls = droppedText.split('\n') + .map((str) => str.trim()) + .filter((str) => { + const lowercaseStr = str.toLowerCase(); + return lowercaseStr.startsWith("http:") + || lowercaseStr.startsWith("https:") + || lowercaseStr.startsWith("magnet:") + || ((str.length === 40) && !(/[^0-9A-Fa-f]/.test(str))) // v1 hex-encoded SHA-1 info-hash + || ((str.length === 32) && !(/[^2-7A-Za-z]/.test(str))); // v1 Base32 encoded SHA-1 info-hash + }); + + if (urls.length <= 0) + return; + + const id = 'downloadPage'; + const contentURI = new URI('download.html').setData("urls", urls.map(encodeURIComponent).join("|")); + new MochaUI.Window({ + id: id, + title: "QBT_TR(Download from URLs)QBT_TR[CONTEXT=downloadFromURL]", + loadMethod: 'iframe', + contentURL: contentURI.toString(), + addClass: 'windowFrame', // fixes iframe scrolling on iOS Safari + scrollbars: true, + maximizable: false, + closable: true, + paddingVertical: 0, + paddingHorizontal: 0, + width: loadWindowWidth(id, 500), + height: loadWindowHeight(id, 600), + onResize: () => { + saveWindowSize(id); + } + }); + } + }); + }; + registerDragAndDrop(); }); function registerMagnetHandler() {