This repository has been archived by the owner on Sep 22, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
119 lines (101 loc) · 3.53 KB
/
app.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
// const { app, ipcMain } = require("deskgap");
// const { BrowserWindow } = require("deskgap")
const { app, ipcMain, BrowserWindow, session } = require("electron");
require('@electron/remote/main').initialize()
const ipc = ipcMain;
const path = require("path");
// const { cpuUsage } = require("process");
const version = "1.0.1-Dev";
const full_version = `BL Otto Launcher v${version}`;
let win;
// Handle creating/removing shortcuts on Windows when installing/uninstalling.
if (require("electron-squirrel-startup")) {
// eslint-disable-line global-require
app.quit();
}
const createWindow = () => {
// Print out version to console once launched
console.log(`Starting up...\nWelcome to ${full_version}!`);
// Create the browser window.
const mainWindow = new BrowserWindow({
width: 1200,
height: 750,
minWidth: 1155,
minHeight: 750,
frame: false,
// titleBarStyle: "hiddenInset",
hasShadow: true,
vibrancy: {
theme: "light", // (default) or 'dark' or '#rrggbbaa'
effect: "acrylic", // (default) or 'blur'
disableOnBlur: true, // (default)
},
webPreferences: {
nodeIntegration: true,
contextIsolation: false,
enableRemoteModule: true,
// devTools: true,
// preload: path.join(__dirname, "appFunctions.js"),
},
});
// Disable live-build blocking feature
// const ses = session.defaultSession;
// const urlToBlock =
// /^https:\/\/trail-blaze\.github\.io\/Otto(\/(.*)?(\?.*)?)?$/;
// // Prevent "other" requests
// ses.webRequest.onBeforeRequest((details, callback) => {
// if (!urlToBlock.test(details.url))
// // cancel the request
// callback({ cancel: true });
// // let the request happen
// else callback({});
// });
// and load the index.html of the app.
mainWindow.loadFile(path.join(__dirname, "escrow.html"));
require("@electron/remote/main").enable(mainWindow.webContents)
// Open the DevTools.
// mainWindow.webContents.openDevTools();
mainWindow.setOpacity(0.95);
win = mainWindow;
};
// This method will be called when Electron has finished
// initialization and is ready to create browser windows.
// Some APIs can only be used after this event occurs.
app.on("ready", createWindow);
// Quit when all windows are closed, except on macOS. There, it's common
// for applications and their menu bar to stay active until the user quits
// explicitly with Cmd + Q.
app.on("window-all-closed", () => {
if (process.platform !== "darwin") {
app.quit();
}
});
app.on("activate", () => {
// On OS X it's common to re-create a window in the app when the
// dock icon is clicked and there are no other windows open.
if (BrowserWindow.getAllWindows().length === 0) {
createWindow();
}
});
// In this file you can include the rest of your app's specific main process
// code. You can also put them in separate files and import them here.
ipc.on("reqPageSwitch", (event, data) => {
console.log("Page Switch Requested.");
win.loadFile(path.join(__dirname, data));
});
let currentState;
ipc.on("sendState", (event, data) => {
currentState = data;
console.log(`currentState = ${currentState}\n`);
});
// Send current state (package#)
// If nothing is saved it will send back nothing at all
ipc.on("reqState", (event, data) => {
event.reply("sendState", currentState);
});
// Send out both the version number and full version name if requested
ipc.on("reqVer", () => {
// win.webContents.send("version", version);
win.webContents.send("full_version", full_version);
console.log("App wants version");
});