From c4d9ed934a497b232f81ebedb0862ed5882350f2 Mon Sep 17 00:00:00 2001 From: Sam Wray Date: Fri, 2 Aug 2024 12:05:15 +0100 Subject: [PATCH] fix: remove menubar on output windows (#915) updates electron and replaces deprecated new-window event handler with setWindowOpenHandler --- package.json | 2 +- src/background/window-prefs.js | 48 ++++++++++++++++++++++------------ yarn.lock | 8 +++--- 3 files changed, 37 insertions(+), 21 deletions(-) diff --git a/package.json b/package.json index 28d4cd5d..a7a2f085 100644 --- a/package.json +++ b/package.json @@ -80,7 +80,7 @@ "babel-eslint": "^10.0.3", "babel-loader": "^9.1.2", "core-js": "^3.19.1", - "electron": "29.1.5", + "electron": "31.3.1", "electron-builder": "^22.9.1", "electron-notarize": "^1.2.2", "electron-playwright-helpers": "^1.5.3", diff --git a/src/background/window-prefs.js b/src/background/window-prefs.js index e63a545f..022d8309 100644 --- a/src/background/window-prefs.js +++ b/src/background/window-prefs.js @@ -77,6 +77,10 @@ const windowPrefs = { }; }, + /** + * + * @param {BrowserWindow} window + */ async create(window) { require("@electron/remote/main").enable(window.webContents); @@ -87,23 +91,35 @@ const windowPrefs = { window.setTitle("Untitled"); // Configure child windows to open without a menubar (windows/linux) - window.webContents.on( - "new-window", - (event, url, frameName, disposition, options) => { - if (frameName === "modal") { - event.preventDefault(); - event.newGuest = new BrowserWindow({ - ...options, - autoHideMenuBar: true, - closable: false, - enableLargerThanScreen: true, - title: "" - }); - - event.newGuest.removeMenu(); - } + window.webContents.setWindowOpenHandler(({ frameName }) => { + if (frameName === "modal") { + return { + action: "allow", + createWindow: options => { + const window = new BrowserWindow({ + ...options, + autoHideMenuBar: true, + closable: false, + enableLargerThanScreen: true, + title: "" + }); + + window.webContents.on("dom-ready", () => { + // Ugly hack + setTimeout(() => { + window.removeMenu(); + }, 1000); + }); + + return window.webContents; + } + }; } - ); + + return { + action: "deny" + }; + }); const mm = getMediaManager(); diff --git a/yarn.lock b/yarn.lock index 15ba10ef..f74b3c3e 100644 --- a/yarn.lock +++ b/yarn.lock @@ -5143,10 +5143,10 @@ electron-updater@^4.3.1: lodash.isequal "^4.5.0" semver "^7.3.5" -electron@29.1.5: - version "29.1.5" - resolved "https://registry.yarnpkg.com/electron/-/electron-29.1.5.tgz#b745b4d201c1ac9f84d6aa034126288dde34d5a1" - integrity sha512-1uWGRw/ffA62lcrklxGUgVxVtOHojsg/nwsYr+/F9cVjipZJn8iPv/ABGIIexhmUqWcho8BqfTJ4osCBa29gBg== +electron@31.3.1: + version "31.3.1" + resolved "https://registry.yarnpkg.com/electron/-/electron-31.3.1.tgz#de5f21f10db1ba0568e0cdd7ae76ec40a4b800c3" + integrity sha512-9fiuWlRhBfygtcT+auRd/WdBK/f8LZZcrpx0RjpXhH2DPTP/PfnkC4JB1PW55qCbGbh4wAgkYbf4ExIag8oGCA== dependencies: "@electron/get" "^2.0.0" "@types/node" "^20.9.0"