keyboard commands for spawning window, better colors
This commit is contained in:
86
app.js
86
app.js
@@ -6,24 +6,53 @@ import { fileURLToPath } from 'url';
|
|||||||
const __filename = fileURLToPath(import.meta.url);
|
const __filename = fileURLToPath(import.meta.url);
|
||||||
const __dirname = paths.dirname(__filename);
|
const __dirname = paths.dirname(__filename);
|
||||||
|
|
||||||
function createWindow() {
|
const WINDOW_SHORTCUTS = [
|
||||||
const win = new BrowserWindow({
|
process.platform === "darwin" ? "Command+R" : "Control+R",
|
||||||
width: 800,
|
"\\"
|
||||||
height: 600,
|
];
|
||||||
frame: false,
|
|
||||||
titleBarStyle: "hidden",
|
function createWindow({onTop = false}) {
|
||||||
webPreferences: {
|
const win = new BrowserWindow({
|
||||||
contextIsolation: true,
|
width: 1200,
|
||||||
nodeIntegration: false,
|
height: 800,
|
||||||
webviewTag: true,
|
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) => {
|
win.on("focus", () => {
|
||||||
console.log('Webview failed:', desc);
|
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;
|
let devToolsOpened = false;
|
||||||
@@ -39,27 +68,38 @@ function toggleDevTools(win) {
|
|||||||
|
|
||||||
app.on("ready", async () => {
|
app.on("ready", async () => {
|
||||||
// await Forms.init();
|
// await Forms.init();
|
||||||
createWindow();
|
createWindow({onTop: false});
|
||||||
|
|
||||||
|
globalShortcut.register('CommandOrControl+Shift+Space', () => {
|
||||||
|
createWindow({onTop: true});
|
||||||
|
});
|
||||||
|
|
||||||
// Register global shortcuts
|
// Register global shortcuts
|
||||||
app.on("browser-window-focus", () => {
|
app.on("browser-window-focus", () => {
|
||||||
const reloadShortcut = process.platform === "darwin" ? "Command+R" : "Control+R";
|
const focused = BrowserWindow.getFocusedWindow();
|
||||||
globalShortcut.register(reloadShortcut, () => {
|
if (!focused) return;
|
||||||
BrowserWindow.getFocusedWindow().reload();
|
|
||||||
|
// 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", () => {
|
app.on("browser-window-blur", () => {
|
||||||
globalShortcut.unregisterAll();
|
for (const key of WINDOW_SHORTCUTS) {
|
||||||
|
globalShortcut.unregister(key);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
app.on("activate", () => {
|
app.on("activate", () => {
|
||||||
if (BrowserWindow.getAllWindows().length === 0) {
|
if (BrowserWindow.getAllWindows().length === 0) {
|
||||||
createWindow();
|
createWindow({onTop: false});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -8,11 +8,12 @@
|
|||||||
body {
|
body {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
|
background-color: #6A2C1C;
|
||||||
}
|
}
|
||||||
|
|
||||||
.draggable {
|
.draggable {
|
||||||
-webkit-app-region: drag;
|
-webkit-app-region: drag;
|
||||||
height: 20px;
|
height: 40px;
|
||||||
position: fixed;
|
position: fixed;
|
||||||
top: 0;
|
top: 0;
|
||||||
left: 0;
|
left: 0;
|
||||||
|
|||||||
@@ -17,8 +17,9 @@
|
|||||||
|
|
||||||
@media (prefers-color-scheme: dark) {
|
@media (prefers-color-scheme: dark) {
|
||||||
:root {
|
:root {
|
||||||
--main: #BD410D;
|
--main: #6A2C1C;
|
||||||
--accent: var(--tan);
|
--accent: var(--tan);
|
||||||
--accent2: var(--green);
|
--accent2: var(--green);
|
||||||
|
--accent3: #c74109
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -4,8 +4,8 @@ class Home extends Shadow {
|
|||||||
|
|
||||||
render() {
|
render() {
|
||||||
ZStack(() => {
|
ZStack(() => {
|
||||||
input("", "20vw")
|
input("", "60vw")
|
||||||
.backgroundColor("var(--darkred)")
|
.backgroundColor("var(--accent3)")
|
||||||
.color("var(--accent)")
|
.color("var(--accent)")
|
||||||
.border("none")
|
.border("none")
|
||||||
.borderTop("1px solid var(--accent)")
|
.borderTop("1px solid var(--accent)")
|
||||||
@@ -31,11 +31,14 @@ class Home extends Shadow {
|
|||||||
})
|
})
|
||||||
|
|
||||||
VStack(() => {
|
VStack(() => {
|
||||||
|
|
||||||
let json = this.getJSONData()
|
let json = this.getJSONData()
|
||||||
|
p(json.length + " Entries")
|
||||||
|
.marginBottom(2, em)
|
||||||
|
|
||||||
for(let i=0; i<100; i++) {
|
for(let i=0; i<100; i++) {
|
||||||
p(json[i].name)
|
p(json[i].name)
|
||||||
.marginLeft(0, em)
|
.marginLeft(0, em)
|
||||||
|
.marginBottom(0.1, em)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.paddingLeft(5, em)
|
.paddingLeft(5, em)
|
||||||
|
|||||||
Reference in New Issue
Block a user