2021-12-20 12:33:46 +01:00
|
|
|
/* eslint-disable no-process-exit */
|
2021-12-19 19:04:34 +01:00
|
|
|
/* eslint-disable @typescript-eslint/no-var-requires */
|
2021-12-22 20:32:36 +01:00
|
|
|
const { app, BrowserWindow, Menu, shell, dialog } = require("electron");
|
2021-12-20 12:33:46 +01:00
|
|
|
const log = require('electron-log');
|
2021-11-27 21:07:25 +01:00
|
|
|
const greenworks = require("./greenworks");
|
2021-09-21 19:29:16 +02:00
|
|
|
|
2021-12-20 12:33:46 +01:00
|
|
|
log.catchErrors();
|
|
|
|
log.info(`Started app: ${JSON.stringify(process.argv)}`);
|
|
|
|
|
|
|
|
process.on('uncaughtException', function () {
|
|
|
|
// The exception will already have been logged by electron-log
|
|
|
|
process.exit(1);
|
|
|
|
});
|
|
|
|
|
2021-11-27 21:07:25 +01:00
|
|
|
if (greenworks.init()) {
|
2021-12-20 12:33:46 +01:00
|
|
|
log.info("Steam API has been initialized.");
|
2021-11-27 21:07:25 +01:00
|
|
|
} else {
|
2021-12-20 12:33:46 +01:00
|
|
|
log.warn("Steam API has failed to initialize.");
|
2021-11-27 21:07:25 +01:00
|
|
|
}
|
|
|
|
|
2021-11-29 05:51:01 +01:00
|
|
|
const debug = false;
|
2021-11-05 05:14:11 +01:00
|
|
|
|
2021-12-21 19:41:11 +01:00
|
|
|
let win = null;
|
|
|
|
|
|
|
|
require("http")
|
|
|
|
.createServer(async function (req, res) {
|
|
|
|
let body = "";
|
|
|
|
req.on("data", (chunk) => {
|
|
|
|
body += chunk.toString(); // convert Buffer to string
|
|
|
|
});
|
|
|
|
req.on("end", () => {
|
|
|
|
const data = JSON.parse(body);
|
|
|
|
win.webContents.executeJavaScript(`document.saveFile("${data.filename}", "${data.code}")`).then((result) => {
|
|
|
|
res.write(result);
|
|
|
|
res.end();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
})
|
2021-12-22 22:15:56 +01:00
|
|
|
.listen(9990, "127.0.0.1");
|
2021-12-21 19:41:11 +01:00
|
|
|
|
2021-12-15 04:34:09 +01:00
|
|
|
function createWindow(killall) {
|
2021-12-21 19:41:11 +01:00
|
|
|
win = new BrowserWindow({
|
2021-09-15 18:22:36 +02:00
|
|
|
show: false,
|
2021-12-16 21:46:26 +01:00
|
|
|
backgroundThrottling: false,
|
2021-12-18 16:43:19 +01:00
|
|
|
backgroundColor: "#000000",
|
2021-09-15 18:22:36 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
win.removeMenu();
|
|
|
|
win.maximize();
|
2021-12-15 04:34:09 +01:00
|
|
|
noScripts = killall ? { query: { noScripts: killall } } : {};
|
|
|
|
win.loadFile("index.html", noScripts);
|
2021-09-15 18:22:36 +02:00
|
|
|
win.show();
|
2021-11-05 05:19:41 +01:00
|
|
|
if (debug) win.webContents.openDevTools();
|
2021-09-21 19:32:06 +02:00
|
|
|
|
|
|
|
win.webContents.on("new-window", function (e, url) {
|
|
|
|
// make sure local urls stay in electron perimeter
|
2021-09-25 07:26:03 +02:00
|
|
|
if (url.substr(0, "file://".length) === "file://") {
|
2021-09-21 19:32:06 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// and open every other protocols on the browser
|
|
|
|
e.preventDefault();
|
|
|
|
shell.openExternal(url);
|
|
|
|
});
|
2021-12-14 04:26:22 +01:00
|
|
|
win.webContents.backgroundThrottling = false;
|
|
|
|
|
|
|
|
// This is backward but the game fills in an array called `document.achievements` and we retrieve it from
|
|
|
|
// here. Hey if it works it works.
|
|
|
|
const achievements = greenworks.getAchievementNames();
|
|
|
|
const intervalID = setInterval(async () => {
|
|
|
|
const achs = await win.webContents.executeJavaScript("document.achievements");
|
|
|
|
for (const ach of achs) {
|
|
|
|
if (!achievements.includes(ach)) continue;
|
|
|
|
greenworks.activateAchievement(ach, () => undefined);
|
|
|
|
}
|
|
|
|
}, 1000);
|
2021-12-17 02:21:25 +01:00
|
|
|
win.achievementsIntervalID = intervalID;
|
2021-11-27 21:07:25 +01:00
|
|
|
|
2021-12-22 20:32:36 +01:00
|
|
|
const reloadAndKill = (killScripts = true) => {
|
2021-12-20 12:33:46 +01:00
|
|
|
log.info('Reloading & Killing all scripts...');
|
2021-12-22 20:32:36 +01:00
|
|
|
setStopProcessHandler(app, win, false);
|
|
|
|
if (intervalID) clearInterval(intervalID);
|
|
|
|
win.webContents.forcefullyCrashRenderer();
|
|
|
|
win.close();
|
|
|
|
createWindow(killScripts);
|
|
|
|
};
|
|
|
|
const promptForReload = () => {
|
|
|
|
win.off('unresponsive', promptForReload);
|
|
|
|
dialog.showMessageBox({
|
|
|
|
type: 'error',
|
|
|
|
title: 'Bitburner > Application Unresponsive',
|
|
|
|
message: 'The application is unresponsive, possibly due to an infinite loop in your scripts.',
|
|
|
|
detail:' Did you forget a ns.sleep(x)?\n\n' +
|
|
|
|
'The application will be restarted for you, do you want to kill all running scripts?',
|
|
|
|
buttons: ['Restart', 'Cancel'],
|
|
|
|
defaultId: 0,
|
|
|
|
checkboxLabel: 'Kill all running scripts',
|
|
|
|
checkboxChecked: true,
|
|
|
|
noLink: true,
|
|
|
|
}).then(({response, checkboxChecked}) => {
|
|
|
|
if (response === 0) {
|
|
|
|
reloadAndKill(checkboxChecked);
|
|
|
|
} else {
|
|
|
|
win.on('unresponsive', promptForReload)
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
win.on('unresponsive', promptForReload);
|
|
|
|
|
2021-12-03 00:42:30 +01:00
|
|
|
// Create the Application's main menu
|
|
|
|
Menu.setApplicationMenu(
|
|
|
|
Menu.buildFromTemplate([
|
|
|
|
{
|
|
|
|
label: "Edit",
|
|
|
|
submenu: [
|
|
|
|
{ label: "Undo", accelerator: "CmdOrCtrl+Z", selector: "undo:" },
|
|
|
|
{ label: "Redo", accelerator: "Shift+CmdOrCtrl+Z", selector: "redo:" },
|
|
|
|
{ type: "separator" },
|
|
|
|
{ label: "Cut", accelerator: "CmdOrCtrl+X", selector: "cut:" },
|
|
|
|
{ label: "Copy", accelerator: "CmdOrCtrl+C", selector: "copy:" },
|
|
|
|
{ label: "Paste", accelerator: "CmdOrCtrl+V", selector: "paste:" },
|
|
|
|
{ label: "Select All", accelerator: "CmdOrCtrl+A", selector: "selectAll:" },
|
|
|
|
],
|
|
|
|
},
|
2021-12-12 18:48:42 +01:00
|
|
|
{
|
|
|
|
label: "reloads",
|
|
|
|
submenu: [
|
|
|
|
{
|
|
|
|
label: "reload",
|
|
|
|
accelerator: "f5",
|
|
|
|
click: () => {
|
|
|
|
win.loadFile("index.html");
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: "reload & kill all scripts",
|
2021-12-22 20:32:36 +01:00
|
|
|
click: reloadAndKill
|
2021-12-12 18:48:42 +01:00
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
2021-12-12 18:58:57 +01:00
|
|
|
{
|
|
|
|
label: "fullscreen",
|
|
|
|
submenu: [
|
|
|
|
{
|
|
|
|
label: "toggle",
|
|
|
|
accelerator: "f9",
|
|
|
|
click: (() => {
|
|
|
|
let full = false;
|
|
|
|
return () => {
|
|
|
|
full = !full;
|
|
|
|
win.setFullScreen(full);
|
|
|
|
};
|
|
|
|
})(),
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
2021-12-12 19:25:28 +01:00
|
|
|
{
|
|
|
|
label: "debug",
|
|
|
|
submenu: [
|
|
|
|
{
|
|
|
|
label: "activate",
|
|
|
|
click: () => win.webContents.openDevTools(),
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
2021-12-03 00:42:30 +01:00
|
|
|
]),
|
|
|
|
);
|
2021-12-17 02:21:25 +01:00
|
|
|
|
|
|
|
return win;
|
2021-09-15 18:22:36 +02:00
|
|
|
}
|
|
|
|
|
2021-12-17 02:21:25 +01:00
|
|
|
function setStopProcessHandler(app, window, enabled) {
|
|
|
|
const clearWindowHandler = () => {
|
|
|
|
if (window.achievementsIntervalID) {
|
|
|
|
clearInterval(window.achievementsIntervalID);
|
|
|
|
}
|
|
|
|
window = null;
|
2021-12-17 17:50:03 +01:00
|
|
|
};
|
2021-12-17 02:21:25 +01:00
|
|
|
|
|
|
|
const stopProcessHandler = () => {
|
2021-12-22 22:16:24 +01:00
|
|
|
log.info('Quitting the app...');
|
2021-12-22 22:15:56 +01:00
|
|
|
app.isQuiting = true;
|
|
|
|
app.quit();
|
|
|
|
// eslint-disable-next-line no-process-exit
|
|
|
|
process.exit(0);
|
2021-12-17 17:50:03 +01:00
|
|
|
};
|
2021-12-17 02:07:34 +01:00
|
|
|
|
2021-12-17 02:21:25 +01:00
|
|
|
if (enabled) {
|
2021-12-17 17:50:03 +01:00
|
|
|
window.on("closed", clearWindowHandler);
|
|
|
|
app.on("window-all-closed", stopProcessHandler);
|
2021-12-17 02:21:25 +01:00
|
|
|
} else {
|
2021-12-17 17:50:03 +01:00
|
|
|
window.removeListener("closed", clearWindowHandler);
|
|
|
|
app.removeListener("window-all-closed", stopProcessHandler);
|
2021-12-17 02:21:25 +01:00
|
|
|
}
|
|
|
|
}
|
2021-12-17 00:26:20 +01:00
|
|
|
|
2021-09-15 18:22:36 +02:00
|
|
|
app.whenReady().then(() => {
|
2021-12-20 12:33:46 +01:00
|
|
|
log.info('Application is ready!');
|
2021-12-18 16:43:19 +01:00
|
|
|
const win = createWindow(process.argv.includes("--no-scripts"));
|
2021-12-17 02:21:25 +01:00
|
|
|
setStopProcessHandler(app, win, true);
|
2021-12-17 07:32:23 +01:00
|
|
|
});
|