keyboard commands for spawning window, better colors

This commit is contained in:
metacryst
2025-11-17 18:57:16 -06:00
parent 8a97f92b0a
commit 0f4d8e5eb9
4 changed files with 73 additions and 28 deletions

86
app.js
View File

@@ -6,24 +6,53 @@ import { fileURLToPath } from 'url';
const __filename = fileURLToPath(import.meta.url);
const __dirname = paths.dirname(__filename);
function createWindow() {
const win = new BrowserWindow({
width: 800,
height: 600,
frame: false,
titleBarStyle: "hidden",
webPreferences: {
contextIsolation: true,
nodeIntegration: false,
webviewTag: true,
const WINDOW_SHORTCUTS = [
process.platform === "darwin" ? "Command+R" : "Control+R",
"\\"
];
function createWindow({onTop = false}) {
const win = new BrowserWindow({
width: 1200,
height: 800,
frame: false,
show: false,
titleBarStyle: "customButtonsOnHover",
webPreferences: {
contextIsolation: true,
nodeIntegration: false,
webviewTag: true,
}
});
if(onTop) {
win.setVisibleOnAllWorkspaces(true, { visibleOnFullScreen: true }); // necessary for full screen
win.setAlwaysOnTop(true, 'screen-saver', 1); // necessary so it doesn't bring you back out of full screen when spawned
}
});
win.loadFile('server/index.html');
win.loadFile('server/index.html');
win.webContents.on('did-fail-load', (e, code, desc) => {
console.log('Webview failed:', desc);
});
win.on("focus", () => {
win.setVibrancy("appearance-based"); // full colors
});
win.on("blur", () => {
win.setVibrancy("selection"); // dims colors
});
win.webContents.on('did-finish-load', () => {
win.show();
});
win.webContents.on('did-fail-load', (e, code, desc) => {
console.log('Webview failed:', desc);
});
win.on('closed', () => {
for (const key of WINDOW_SHORTCUTS) {
globalShortcut.unregister(key);
}
});
}
let devToolsOpened = false;
@@ -39,27 +68,38 @@ function toggleDevTools(win) {
app.on("ready", async () => {
// await Forms.init();
createWindow();
createWindow({onTop: false});
globalShortcut.register('CommandOrControl+Shift+Space', () => {
createWindow({onTop: true});
});
// Register global shortcuts
app.on("browser-window-focus", () => {
const reloadShortcut = process.platform === "darwin" ? "Command+R" : "Control+R";
globalShortcut.register(reloadShortcut, () => {
BrowserWindow.getFocusedWindow().reload();
const focused = BrowserWindow.getFocusedWindow();
if (!focused) return;
// Reload
globalShortcut.register(WINDOW_SHORTCUTS[0], () => {
focused.reload();
});
globalShortcut.register("\\", () => {
toggleDevTools(BrowserWindow.getFocusedWindow());
// Devtools
globalShortcut.register(WINDOW_SHORTCUTS[1], () => {
toggleDevTools(focused);
});
});
app.on("browser-window-blur", () => {
globalShortcut.unregisterAll();
for (const key of WINDOW_SHORTCUTS) {
globalShortcut.unregister(key);
}
});
});
app.on("activate", () => {
if (BrowserWindow.getAllWindows().length === 0) {
createWindow();
createWindow({onTop: false});
}
});