From 6ed085e9f6643514536b580370e55bce1aef7a49 Mon Sep 17 00:00:00 2001 From: Alex Hua Date: Sun, 10 Nov 2024 18:24:03 +0800 Subject: [PATCH] feat: Support opening web ui in side panel (beta) --- _locales/en/messages.json | 9 +++++--- _locales/ja/messages.json | 3 +++ _locales/ko/messages.json | 3 +++ _locales/uk/messages.json | 3 +++ _locales/zh_CN/messages.json | 5 ++++- _locales/zh_TW/messages.json | 5 ++++- background.js | 41 +++++++++++++++++++++++++++++++++++- manifest.json | 6 +++++- options.html | 6 ++++++ 9 files changed, 74 insertions(+), 7 deletions(-) diff --git a/_locales/en/messages.json b/_locales/en/messages.json index 0dc49a0..ca343c6 100644 --- a/_locales/en/messages.json +++ b/_locales/en/messages.json @@ -180,10 +180,13 @@ "message":"Popup" }, "WebUIOpenStyle2":{ - "message":"New tab" + "message":"New Tab" }, "WebUIOpenStyle3":{ - "message":"New window" + "message":"New Window" + }, + "WebUIOpenStyle4":{ + "message":"Side Panel" }, "openWebUIStr":{ "message":"Open AriaNG" @@ -255,7 +258,7 @@ "message":"Creating download task over insecure HTTP/WebSocket protocol can potentially expose Secret Key and related website Cookies on the public network." }, "AutoDownloadCookiesTooltipDes":{ - "message": "The related website cookies will not be attached when auto-download or direct export." + "message": "For insecure RPC, the related website cookies will not be attached when auto-download or direct export." }, "ManualDownloadCookiesTooltipDes":{ "message": "You should determine whether to delete the related website cookies when asking download settings." diff --git a/_locales/ja/messages.json b/_locales/ja/messages.json index 2322c29..b679888 100644 --- a/_locales/ja/messages.json +++ b/_locales/ja/messages.json @@ -185,6 +185,9 @@ "WebUIOpenStyle3":{ "message":"新しいウィンドウ" }, + "WebUIOpenStyle4":{ + "message":"サイドパネル" + }, "openWebUIStr":{ "message":"AriaNGを開く" }, diff --git a/_locales/ko/messages.json b/_locales/ko/messages.json index 4848445..4f6e859 100644 --- a/_locales/ko/messages.json +++ b/_locales/ko/messages.json @@ -185,6 +185,9 @@ "WebUIOpenStyle3": { "message": "새 창" }, + "WebUIOpenStyle4":{ + "message":"측면 패널" + }, "openWebUIStr": { "message": "AriaNG 열기" }, diff --git a/_locales/uk/messages.json b/_locales/uk/messages.json index fb2f016..6c94d4d 100644 --- a/_locales/uk/messages.json +++ b/_locales/uk/messages.json @@ -185,6 +185,9 @@ "WebUIOpenStyle3": { "message": "Нове вікно" }, + "WebUIOpenStyle4":{ + "message":"бічна панель" + }, "openWebUIStr": { "message": "Відкрити AriaNG" }, diff --git a/_locales/zh_CN/messages.json b/_locales/zh_CN/messages.json index 5f429f3..47e78f5 100644 --- a/_locales/zh_CN/messages.json +++ b/_locales/zh_CN/messages.json @@ -185,6 +185,9 @@ "WebUIOpenStyle3":{ "message":"新窗口" }, + "WebUIOpenStyle4":{ + "message":"侧边栏" + }, "openWebUIStr":{ "message":"打开AriaNG" }, @@ -255,7 +258,7 @@ "message":"通过不安全的 HTTP/WebSocket 协议创建下载任务可能会导致 Secret Key 和相关网站的 Cookies 信息暴露于公共网络。" }, "AutoDownloadCookiesTooltipDes":{ - "message": "在自动下载和右键导出下载时,将不会附带相关网站的Cookies信息。" + "message": "使用不安全的RPC协议,在自动下载和右键导出下载时,将不会附带相关网站的Cookies信息。" }, "ManualDownloadCookiesTooltipDes":{ "message": "在询问下载设置时,你需要决定是否删除相关网站的Cookies信息。" diff --git a/_locales/zh_TW/messages.json b/_locales/zh_TW/messages.json index b222a4c..fb6511d 100644 --- a/_locales/zh_TW/messages.json +++ b/_locales/zh_TW/messages.json @@ -185,6 +185,9 @@ "WebUIOpenStyle3":{ "message":"新視窗" }, + "WebUIOpenStyle4":{ + "message":"側邊面板" + }, "openWebUIStr":{ "message":"打開AriaNG" }, @@ -255,7 +258,7 @@ "message":"使用不安全的HTTP/WebSocket協定創建下載工作可能會導致Secret Key和相關網站的Cookies資訊暴露於公共網絡。" }, "AutoDownloadCookiesTooltipDes":{ - "message": "在自動下載和右鍵匯出下載時,將不會附帶相關網站的Cookies資訊。" + "message": "使用不安全的RPC協定,在自動下載和右鍵匯出下載時,將不會附帶相關網站的Cookies資訊。" }, "ManualDownloadCookiesTooltipDes":{ "message": "在詢問下載設定時,你需要决定是否删除相關網站的Cookies資訊。" diff --git a/background.js b/background.js index cf9c3f0..b7fcd80 100644 --- a/background.js +++ b/background.js @@ -8,6 +8,7 @@ const NID_TASK_NEW = "NID_TASK_NEW"; const NID_TASK_STOPPED = "NID_TASK_STOPPED"; const NID_CAPTURED_OTHERS = "NID_CAPTURED_OTHERS"; +var CurrentWindowId = 0; var CurrentTabUrl = "about:blank"; var MonitorId = -1; var MonitorInterval = 3000; // Aria2 monitor interval 3000ms @@ -315,6 +316,20 @@ async function launchUI(info) { const index = chrome.runtime.getURL('ui/ariang/index.html'); let webUiUrl = index + '#!'; // launched from notification, option menu or browser toolbar icon + let sidePanelOpened = false; + if (Configs.webUIOpenStyle == "sidePanel") { + try { + if (info && 'id' in info) { + await chrome.sidePanel.open({ tabId: info.id }); + } else { + await chrome.sidePanel.open({ windowId: CurrentWindowId }); + }; + sidePanelOpened = true; + } catch { + sidePanelOpened = false; + } + } + /* assemble the final web ui url */ if (info?.hasOwnProperty("filename") && info.url) { // launched for new task const downloadItem = info; @@ -341,6 +356,15 @@ async function launchUI(info) { webUiUrl = index; } + if (sidePanelOpened) { + if (info && 'id' in info) { + await chrome.sidePanel.setOptions({ tabId: info.id, path: webUiUrl }); + } else { + await chrome.sidePanel.setOptions({ path: webUiUrl }); + } + return; + } + chrome.tabs.query({ "url": index }).then(function (tabs) { if (tabs?.length > 0) { chrome.windows.update(tabs[0].windowId, { @@ -526,7 +550,7 @@ function onMenuClick(info, tab) { let downloadItem = { url, referrer, filename }; if (info.menuItemId == "MENU_OPEN_WEB_UI") { - launchUI(); + launchUI(tab); } else if (info.menuItemId == "MENU_START_ARIA2") { const url = chrome.runtime.getURL('aria2.html'); chrome.tabs.create({ url }); @@ -549,6 +573,7 @@ function onMenuClick(info, tab) { if (Configs.askBeforeExport) { const rpcItem = getRpcServer(downloadItem.url); downloadItem.dir = rpcItem.location; + downloadItem.id = tab.id; launchUI(downloadItem); } else { let id = info.menuItemId.split('-')[1]; @@ -749,6 +774,16 @@ async function monitorAria2() { } } +async function resetSidePanel(tabId) { + if (Configs.webUIOpenStyle == "sidePanel") { + let { path } = await chrome.sidePanel.getOptions(tabId ? { tabId } : undefined); + const defaultPath = 'ui/ariang/index.html'; + if (!path.endsWith(defaultPath)) { + chrome.sidePanel.setOptions(tabId ? { tabId, path: defaultPath } : { path: defaultPath }); + } + } +} + function registerAllListeners() { chrome.action.onClicked.addListener(launchUI); chrome.contextMenus.onClicked.addListener(onMenuClick); @@ -757,6 +792,7 @@ function registerAllListeners() { CurrentTabUrl = tab?.url || "about:blank"; updateOptionMenu(tab); } + resetSidePanel(tabId); }); chrome.tabs.onActivated.addListener(function (activeInfo) { @@ -764,9 +800,11 @@ function registerAllListeners() { CurrentTabUrl = tab?.url || "about:blank"; updateOptionMenu(tab); }); + resetSidePanel(activeInfo.tabId); }); chrome.windows.onFocusChanged.addListener(function (windowId) { + CurrentWindowId = windowId; chrome.tabs.query({ windowId: windowId, active: true }).then(function (tabs) { if (tabs?.length > 0) { CurrentTabUrl = tabs[0].url || "about:blank"; @@ -883,6 +921,7 @@ function init() { Configs.monitorAria2 ? enableMonitor() : disableMonitor(); url = Configs.captureMagnet ? "https://github.com/alexhua/Aria2-Explore/issues/98" : ''; chrome.runtime.setUninstallURL(url); + chrome.sidePanel.setPanelBehavior({ openPanelOnActionClick: Configs.webUIOpenStyle == "sidePanel" }); }); } diff --git a/manifest.json b/manifest.json index 160a136..eed5c0d 100644 --- a/manifest.json +++ b/manifest.json @@ -3,7 +3,7 @@ "short_name": "A2E", "version": "2.5.5", "manifest_version": 3, - "minimum_chrome_version": "100.0.0", + "minimum_chrome_version": "116.0.0", "default_locale": "en", "description": "__MSG_description__", "options_page": "options.html", @@ -16,6 +16,7 @@ "storage", "system.display", "scripting", + "sidePanel", "power" ], "host_permissions": [ @@ -31,6 +32,9 @@ }, "default_title": "__MSG_appName__" }, + "side_panel": { + "default_path": "ui/ariang/index.html" + }, "content_security_policy": { "extension_pages": "script-src 'self';object-src 'self';" }, diff --git a/options.html b/options.html index 2e04518..c457fa6 100644 --- a/options.html +++ b/options.html @@ -141,6 +141,12 @@ __MSG_WebUIOpenStyle3__ +
+ + +