This commit is contained in:
Desmond Sylin 2025-11-15 07:14:05 +08:00 committed by GitHub
commit 0e3fb33bf6
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

17
main.js
View File

@ -36,7 +36,7 @@ const LOG_PREFIX = "obsidian-tray",
OBSIDIAN_BASE64_ICON = ``, OBSIDIAN_BASE64_ICON = ``,
log = (message) => console.log(`${LOG_PREFIX}: ${message}`); log = (message) => console.log(`${LOG_PREFIX}: ${message}`);
let tray, plugin; let tray, plugin, isQuitting = false;
const obsidian = require("obsidian"), const obsidian = require("obsidian"),
{ app, Tray, Menu } = require("electron").remote, { app, Tray, Menu } = require("electron").remote,
{ nativeImage, BrowserWindow } = require("electron").remote, { nativeImage, BrowserWindow } = require("electron").remote,
@ -97,8 +97,14 @@ const vaultWindows = new Set(),
else showWindows(); else showWindows();
}; };
const onWindowClose = (event) => event.preventDefault(), const onWindowClose = (event) => {
// allow window to close during app quit (e.g., system shutdown)
// to prevent blocking macOS shutdown process
if (!isQuitting) event.preventDefault();
},
onWindowUnload = (event) => { onWindowUnload = (event) => {
// allow window to close during app quit
if (isQuitting) return;
log(LOG_WINDOW_CLOSE); log(LOG_WINDOW_CLOSE);
getCurrentWindow().hide(); getCurrentWindow().hide();
event.stopImmediatePropagation(); event.stopImmediatePropagation();
@ -113,6 +119,13 @@ const onWindowClose = (event) => event.preventDefault(),
// from renderer, so won't prevent close by itself, but counteracts // from renderer, so won't prevent close by itself, but counteracts
// the 3-second delayed window force close in obsidian.asar/main.js // the 3-second delayed window force close in obsidian.asar/main.js
getCurrentWindow().on("close", onWindowClose); getCurrentWindow().on("close", onWindowClose);
// listen for app quit events to allow proper shutdown
// especially important for macOS system shutdown
app.on("before-quit", () => {
log("preparing for app quit");
isQuitting = true;
allowWindowClose();
});
}, },
allowWindowClose = () => { allowWindowClose = () => {
getCurrentWindow().removeListener("close", onWindowClose); getCurrentWindow().removeListener("close", onWindowClose);