Add preliminary prisma support

This commit is contained in:
Jeffrey Li
2022-10-06 21:04:36 -07:00
committed by jeffvli
parent 95c52d8a11
commit 06914b3af4
24 changed files with 19120 additions and 98 deletions
+28 -25
View File
@@ -8,21 +8,20 @@
// ├─┬ dist
// │ └── index.html > Electron-Renderer
//
process.env.DIST_ELECTRON = join(__dirname, "..");
process.env.DIST = join(process.env.DIST_ELECTRON, "../dist");
process.env.PUBLIC = app.isPackaged
? process.env.DIST
: join(process.env.DIST_ELECTRON, "../public");
process.env.DIST_ELECTRON = join(__dirname, '..');
process.env.DIST = join(process.env.DIST_ELECTRON, '../dist');
process.env.PUBLIC = app.isPackaged ? process.env.DIST : join(process.env.DIST_ELECTRON, '../public');
import { app, BrowserWindow, shell, ipcMain } from "electron";
import { release } from "os";
import { join } from "path";
import { release } from 'os';
import { join } from 'path';
import { app, BrowserWindow, shell, ipcMain } from 'electron';
import './features';
// Disable GPU Acceleration for Windows 7
if (release().startsWith("6.1")) app.disableHardwareAcceleration();
if (release().startsWith('6.1')) app.disableHardwareAcceleration();
// Set application name for Windows 10+ notifications
if (process.platform === "win32") app.setAppUserModelId(app.getName());
if (process.platform === 'win32') app.setAppUserModelId(app.getName());
if (!app.requestSingleInstanceLock()) {
app.quit();
@@ -31,18 +30,18 @@ if (!app.requestSingleInstanceLock()) {
let win: BrowserWindow | null = null;
// Here, you can also use other preload
const preload = join(__dirname, "../preload/index.js");
const preload = join(__dirname, '../preload/index.js');
const url = process.env.VITE_DEV_SERVER_URL;
const indexHtml = join(process.env.DIST, "index.html");
const indexHtml = join(process.env.DIST, 'index.html');
async function createWindow() {
win = new BrowserWindow({
title: "Main window",
icon: join(process.env.PUBLIC, "favicon.svg"),
icon: join(process.env.PUBLIC, 'favicon.svg'),
title: 'Main window',
webPreferences: {
preload,
nodeIntegration: false,
contextIsolation: true,
nodeIntegration: false,
preload,
},
});
@@ -54,25 +53,25 @@ async function createWindow() {
}
// Test actively push message to the Electron-Renderer
win.webContents.on("did-finish-load", () => {
win?.webContents.send("main-process-message", new Date().toLocaleString());
win.webContents.on('did-finish-load', () => {
win?.webContents.send('main-process-message', new Date().toLocaleString());
});
// Make all links open with the browser, not with the application
win.webContents.setWindowOpenHandler(({ url }) => {
if (url.startsWith("https:")) shell.openExternal(url);
return { action: "deny" };
if (url.startsWith('https:')) shell.openExternal(url);
return { action: 'deny' };
});
}
app.whenReady().then(createWindow);
app.on("window-all-closed", () => {
app.on('window-all-closed', () => {
win = null;
if (process.platform !== "darwin") app.quit();
if (process.platform !== 'darwin') app.quit();
});
app.on("second-instance", () => {
app.on('second-instance', () => {
if (win) {
// Focus on the main window if the user tried to open another
if (win.isMinimized()) win.restore();
@@ -80,7 +79,7 @@ app.on("second-instance", () => {
}
});
app.on("activate", () => {
app.on('activate', () => {
const allWindows = BrowserWindow.getAllWindows();
if (allWindows.length) {
allWindows[0].focus();
@@ -90,7 +89,7 @@ app.on("activate", () => {
});
// new window example arg: new windows url
ipcMain.handle("open-win", (event, arg) => {
ipcMain.handle('open-win', (event, arg) => {
const childWindow = new BrowserWindow({
webPreferences: {
preload,
@@ -104,3 +103,7 @@ ipcMain.handle("open-win", (event, arg) => {
// childWindow.webContents.openDevTools({ mode: "undocked", activate: true })
}
});
export const getWindow = () => {
return win;
};