import { app, BrowserWindow, dialog } from "electron"; import * as path from "node:path"; import { registerIpcHandlers } from "./ipc/ipc_host"; import dotenv from "dotenv"; // @ts-ignore import started from "electron-squirrel-startup"; import { updateElectronApp } from "update-electron-app"; import log from "electron-log"; import { readSettings, writeSettings } from "./main/settings"; log.errorHandler.startCatching(); log.eventLogger.startLogging(); log.scope.labelPadding = false; const logger = log.scope("main"); updateElectronApp(); // additional configuration options available // Load environment variables from .env file dotenv.config(); // Register IPC handlers before app is ready registerIpcHandlers(); // Handle creating/removing shortcuts on Windows when installing/uninstalling. if (started) { app.quit(); } export async function onReady() { await onFirstRunMaybe(); } app.whenReady().then(onReady); /** * Is this the first run of Fiddle? If so, perform * tasks that we only want to do in this case. */ export async function onFirstRunMaybe() { const settings = readSettings(); if (!settings.hasRunBefore) { await promptMoveToApplicationsFolder(); writeSettings({ hasRunBefore: true, }); } } /** * Ask the user if the app should be moved to the * applications folder. */ async function promptMoveToApplicationsFolder(): Promise { if (process.platform !== "darwin") return; if (app.isInApplicationsFolder()) return; logger.log("Prompting user to move to applications folder"); const { response } = await dialog.showMessageBox({ type: "question", buttons: ["Move to Applications Folder", "Do Not Move"], defaultId: 0, message: "Move to Applications Folder? (required for auto-update)", }); if (response === 0) { logger.log("User chose to move to applications folder"); app.moveToApplicationsFolder(); } else { logger.log("User chose not to move to applications folder"); } } declare global { const MAIN_WINDOW_VITE_DEV_SERVER_URL: string; } const createWindow = () => { // Create the browser window. const mainWindow = new BrowserWindow({ width: process.env.NODE_ENV === "development" ? 1280 : 960, height: 700, titleBarStyle: "hidden", titleBarOverlay: true, trafficLightPosition: { x: 10, y: 8, }, webPreferences: { nodeIntegration: false, contextIsolation: true, preload: path.join(__dirname, "preload.js"), // transparent: true, }, // backgroundColor: "#00000001", // frame: false, }); // and load the index.html of the app. if (MAIN_WINDOW_VITE_DEV_SERVER_URL) { mainWindow.loadURL(MAIN_WINDOW_VITE_DEV_SERVER_URL); } else { mainWindow.loadFile( path.join(__dirname, "../renderer/main_window/index.html") ); } if (process.env.NODE_ENV === "development") { // 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.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.