From 9251f28caee8d9c67c1920708283e9e780cf127e Mon Sep 17 00:00:00 2001 From: kuuuube Date: Tue, 17 Dec 2024 08:39:52 -0500 Subject: [PATCH 1/3] Fix constant error on firefox mobile from chrome.contextMenus --- ext/js/background/backend.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ext/js/background/backend.js b/ext/js/background/backend.js index 93a4330f5..e341ebc9f 100644 --- a/ext/js/background/backend.js +++ b/ext/js/background/backend.js @@ -1331,7 +1331,7 @@ export class Backend { } try { - if (options.general.enableContextMenuScanSelected) { + if (options.general.enableContextMenuScanSelected && chrome.contextMenus) { chrome.contextMenus.create({ id: 'yomitan_lookup', title: 'Lookup in Yomitan', From a5fac512fe71ab2711d55fdc6332aedd7e4998fb Mon Sep 17 00:00:00 2001 From: kuuuube Date: Tue, 17 Dec 2024 08:51:26 -0500 Subject: [PATCH 2/3] Put if check over whole block --- ext/js/background/backend.js | 28 +++++++++++++++------------- 1 file changed, 15 insertions(+), 13 deletions(-) diff --git a/ext/js/background/backend.js b/ext/js/background/backend.js index e341ebc9f..5080cc7fe 100644 --- a/ext/js/background/backend.js +++ b/ext/js/background/backend.js @@ -1331,19 +1331,21 @@ export class Backend { } try { - if (options.general.enableContextMenuScanSelected && chrome.contextMenus) { - chrome.contextMenus.create({ - id: 'yomitan_lookup', - title: 'Lookup in Yomitan', - contexts: ['selection'], - }, () => this._checkLastError(chrome.runtime.lastError)); - chrome.contextMenus.onClicked.addListener((info) => { - if (info.selectionText) { - this._sendMessageAllTabsIgnoreResponse({action: 'frontendScanSelectedText'}); - } - }); - } else { - chrome.contextMenus.remove('yomitan_lookup', () => this._checkLastError(chrome.runtime.lastError)); + if (chrome.contextMenus) { + if (options.general.enableContextMenuScanSelected) { + chrome.contextMenus.create({ + id: 'yomitan_lookup', + title: 'Lookup in Yomitan', + contexts: ['selection'], + }, () => this._checkLastError(chrome.runtime.lastError)); + chrome.contextMenus.onClicked.addListener((info) => { + if (info.selectionText) { + this._sendMessageAllTabsIgnoreResponse({action: 'frontendScanSelectedText'}); + } + }); + } else { + chrome.contextMenus.remove('yomitan_lookup', () => this._checkLastError(chrome.runtime.lastError)); + } } } catch (e) { log.error(e); From 812fd1976d0f336da47be6479e325179c8c6e297 Mon Sep 17 00:00:00 2001 From: kuuuube Date: Tue, 17 Dec 2024 08:57:48 -0500 Subject: [PATCH 3/3] Split out into separate method so it can early return --- ext/js/background/backend.js | 45 +++++++++++++++++++++--------------- 1 file changed, 26 insertions(+), 19 deletions(-) diff --git a/ext/js/background/backend.js b/ext/js/background/backend.js index 5080cc7fe..efb40ed47 100644 --- a/ext/js/background/backend.js +++ b/ext/js/background/backend.js @@ -1330,30 +1330,37 @@ export class Backend { this._clipboardMonitor.stop(); } + this._setupContextMenu(options); + + void this._accessibilityController.update(this._getOptionsFull(false)); + + this._sendMessageAllTabsIgnoreResponse({action: 'applicationOptionsUpdated', params: {source}}); + } + + /** + * @param {import('settings').ProfileOptions} options + */ + _setupContextMenu(options) { try { - if (chrome.contextMenus) { - if (options.general.enableContextMenuScanSelected) { - chrome.contextMenus.create({ - id: 'yomitan_lookup', - title: 'Lookup in Yomitan', - contexts: ['selection'], - }, () => this._checkLastError(chrome.runtime.lastError)); - chrome.contextMenus.onClicked.addListener((info) => { - if (info.selectionText) { - this._sendMessageAllTabsIgnoreResponse({action: 'frontendScanSelectedText'}); - } - }); - } else { - chrome.contextMenus.remove('yomitan_lookup', () => this._checkLastError(chrome.runtime.lastError)); - } + if (!chrome.contextMenus) { return; } + + if (options.general.enableContextMenuScanSelected) { + chrome.contextMenus.create({ + id: 'yomitan_lookup', + title: 'Lookup in Yomitan', + contexts: ['selection'], + }, () => this._checkLastError(chrome.runtime.lastError)); + chrome.contextMenus.onClicked.addListener((info) => { + if (info.selectionText) { + this._sendMessageAllTabsIgnoreResponse({action: 'frontendScanSelectedText'}); + } + }); + } else { + chrome.contextMenus.remove('yomitan_lookup', () => this._checkLastError(chrome.runtime.lastError)); } } catch (e) { log.error(e); } - - void this._accessibilityController.update(this._getOptionsFull(false)); - - this._sendMessageAllTabsIgnoreResponse({action: 'applicationOptionsUpdated', params: {source}}); } /**