Initial electron config

This commit is contained in:
uonai 2020-07-01 22:36:29 -05:00
parent e1dbed8967
commit ab1080027a
5 changed files with 80 additions and 1 deletions

19
electron/index.html Normal file
View File

@ -0,0 +1,19 @@
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<!-- https://developer.mozilla.org/en-US/docs/Web/HTTP/CSP -->
<meta http-equiv="Content-Security-Policy" content="default-src 'self'; script-src 'self'">
<meta http-equiv="X-Content-Security-Policy" content="default-src 'self'; script-src 'self'">
<title>Hello World!</title>
</head>
<body>
<h1>Hello World!</h1>
We are using Node.js <span id="node-version"></span>,
Chromium <span id="chrome-version"></span>,
and Electron <span id="electron-version"></span>.
<!-- You can also require other files to run in this process -->
<script src="./renderer.js"></script>
</body>
</html>

46
electron/main.js Normal file
View File

@ -0,0 +1,46 @@
// Modules to control application life and create native browser window
const { app, BrowserWindow } = require("electron");
const path = require("path");
const { fork } = require("child_process");
const ps = fork(path.join(__dirname, "..", "index.js"));
function createWindow() {
// Create the browser window.
const mainWindow = new BrowserWindow({
width: 800,
height: 600,
webPreferences: {
preload: path.join(__dirname, "preload.js"),
},
});
// and load the index.html of the app.
mainWindow.loadFile("electron/index.html");
console.log("window created");
// Open the DevTools.
mainWindow.webContents.openDevTools();
}
// 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.whenReady().then(() => {
createWindow();
app.on("activate", function () {
// On macOS 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();
});
});
// 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", function () {
if (process.platform !== "darwin") app.quit();
});
// 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 require them here.

12
electron/preload.js Normal file
View File

@ -0,0 +1,12 @@
// All of the Node.js APIs are available in the preload process.
// It has the same sandbox as a Chrome extension.
window.addEventListener("DOMContentLoaded", () => {
const replaceText = (selector, text) => {
const element = document.getElementById(selector);
if (element) element.innerText = text;
};
for (const type of ["chrome", "node", "electron"]) {
replaceText(`${type}-version`, process.versions[type]);
}
});

0
electron/renderer.js Normal file
View File

View File

@ -4,11 +4,12 @@
"engines": { "engines": {
"node": ">=11 <12" "node": ">=11 <12"
}, },
"main": "electron/main.js",
"scripts": { "scripts": {
"dev": "node . --unhandled-rejections=strict", "dev": "node . --unhandled-rejections=strict",
"build": "next build", "build": "next build",
"start": "NODE_ENV=production node . --unhandled-rejections=strict", "start": "NODE_ENV=production node . --unhandled-rejections=strict",
"build-system": "rollup -c" "electron": "electron ."
}, },
"dependencies": { "dependencies": {
"@babel/preset-env": "^7.10.4", "@babel/preset-env": "^7.10.4",
@ -26,6 +27,7 @@
"chartkick": "^3.2.0", "chartkick": "^3.2.0",
"compression": "^1.7.4", "compression": "^1.7.4",
"dotenv": "^8.2.0", "dotenv": "^8.2.0",
"electron": "^9.0.5",
"express": "^4.17.1", "express": "^4.17.1",
"formidable": "^1.2.2", "formidable": "^1.2.2",
"fs-extra": "^9.0.1", "fs-extra": "^9.0.1",