静默启动

This commit is contained in:
刘嘉伟 2024-10-14 11:24:54 +08:00
parent 2ccddbe4b6
commit 4d9c5bf003
4 changed files with 226 additions and 168 deletions

View File

@ -143,7 +143,8 @@ export const initConfigApi = win => {
user: sourceConfig?.user || "", user: sourceConfig?.user || "",
metaToken: sourceConfig?.metadatas?.token || "", metaToken: sourceConfig?.metadatas?.token || "",
systemSelfStart: false, systemSelfStart: false,
systemStartupConnect: false systemStartupConnect: false,
systemSilentStartup: false
}; };
let frpcProxys = []; let frpcProxys = [];
// 解析proxy // 解析proxy

View File

@ -1,16 +1,29 @@
import {app, BrowserWindow, ipcMain, Menu, MenuItem, MenuItemConstructorOptions, shell, Tray} from "electron"; import {
import {release} from "node:os"; app,
import node_path, {join} from "node:path"; BrowserWindow,
import {initGitHubApi} from "../api/github"; ipcMain,
import {initConfigApi} from "../api/config"; Menu,
import {initProxyApi} from "../api/proxy"; MenuItem,
import {initFrpcApi, startFrpWorkerProcess, stopFrpcProcess} from "../api/frpc"; MenuItemConstructorOptions,
import {initLoggerApi} from "../api/logger"; shell,
import {initFileApi} from "../api/file"; Tray
import {getConfig} from "../storage/config"; } from "electron";
import { release } from "node:os";
import node_path, { join } from "node:path";
import { initGitHubApi } from "../api/github";
import { initConfigApi } from "../api/config";
import { initProxyApi } from "../api/proxy";
import {
initFrpcApi,
startFrpWorkerProcess,
stopFrpcProcess
} from "../api/frpc";
import { initLoggerApi } from "../api/logger";
import { initFileApi } from "../api/file";
import { getConfig } from "../storage/config";
import log from "electron-log"; import log from "electron-log";
import {initCommonApi} from "../api/common"; import { initCommonApi } from "../api/common";
import {initLocalApi} from "../api/local"; import { initLocalApi } from "../api/local";
// The built directory structure // The built directory structure
// //
// ├─┬ dist-electron // ├─┬ dist-electron
@ -50,10 +63,16 @@ const preload = join(__dirname, "../preload/index.js");
const url = process.env.VITE_DEV_SERVER_URL; const url = process.env.VITE_DEV_SERVER_URL;
const indexHtml = join(process.env.DIST, "index.html"); const indexHtml = join(process.env.DIST, "index.html");
let isQuiting; let isQuiting;
log.transports.file.level = 'debug'; log.transports.file.level = "debug";
log.transports.console.level = "debug"; log.transports.console.level = "debug";
async function createWindow() { async function createWindow(config: FrpConfig) {
console.log("config", config);
let show = true;
if (config) {
show = !config.systemSilentStartup;
}
console.log("界面", show);
win = new BrowserWindow({ win = new BrowserWindow({
title: "Frpc Desktop", title: "Frpc Desktop",
icon: join(process.env.VITE_PUBLIC, "logo/only/16x16.png"), icon: join(process.env.VITE_PUBLIC, "logo/only/16x16.png"),
@ -70,7 +89,8 @@ async function createWindow() {
// Read more on https://www.electronjs.org/docs/latest/tutorial/context-isolation // Read more on https://www.electronjs.org/docs/latest/tutorial/context-isolation
nodeIntegration: true, nodeIntegration: true,
contextIsolation: false contextIsolation: false
} },
show: show
}); });
if (process.env.VITE_DEV_SERVER_URL) { if (process.env.VITE_DEV_SERVER_URL) {
// electron-vite-vue#298 // electron-vite-vue#298
@ -87,25 +107,25 @@ async function createWindow() {
}); });
// Make all links open with the browser, not with the application // Make all links open with the browser, not with the application
win.webContents.setWindowOpenHandler(({url}) => { win.webContents.setWindowOpenHandler(({ url }) => {
if (url.startsWith("https:")) shell.openExternal(url); if (url.startsWith("https:")) shell.openExternal(url);
return {action: "deny"}; return { action: "deny" };
}); });
// 隐藏菜单栏 // 隐藏菜单栏
const {Menu} = require("electron"); const { Menu } = require("electron");
Menu.setApplicationMenu(null); Menu.setApplicationMenu(null);
// hide menu for Mac // hide menu for Mac
// if (process.platform !== "darwin") { // if (process.platform !== "darwin") {
// app.dock.hide(); // app.dock.hide();
// } // }
win.on('minimize', function (event) { win.on("minimize", function (event) {
event.preventDefault(); event.preventDefault();
win.hide(); win.hide();
}); });
win.on('close', function (event) { win.on("close", function (event) {
if (!isQuiting) { if (!isQuiting) {
event.preventDefault(); event.preventDefault();
win.hide(); win.hide();
@ -115,14 +135,18 @@ async function createWindow() {
} }
return false; return false;
}); });
} }
export const createTray = () => { export const createTray = (config: FrpConfig) => {
log.info(`当前环境 platform${process.platform} arch${process.arch} appData${app.getPath("userData")} version:${app.getVersion()}`) log.info(
let menu: Array<(MenuItemConstructorOptions) | (MenuItem)> = [ `当前环境 platform${process.platform} arch${
process.arch
} appData${app.getPath("userData")} version:${app.getVersion()}`
);
let menu: Array<MenuItemConstructorOptions | MenuItem> = [
{ {
label: '显示主窗口', click: function () { label: "显示主窗口",
click: function () {
win.show(); win.show();
if (process.platform === "darwin") { if (process.platform === "darwin") {
app.dock.show(); app.dock.show();
@ -130,40 +154,39 @@ export const createTray = () => {
} }
}, },
{ {
label: '退出', label: "退出",
click: () => { click: () => {
isQuiting = true; isQuiting = true;
stopFrpcProcess(() => { stopFrpcProcess(() => {
app.quit(); app.quit();
}) });
} }
} }
]; ];
tray = new Tray(node_path.join(process.env.VITE_PUBLIC, "logo/only/16x16.png")) tray = new Tray(
tray.setToolTip('Frpc Desktop') node_path.join(process.env.VITE_PUBLIC, "logo/only/16x16.png")
const contextMenu = Menu.buildFromTemplate(menu) );
tray.setContextMenu(contextMenu) tray.setToolTip("Frpc Desktop");
const contextMenu = Menu.buildFromTemplate(menu);
tray.setContextMenu(contextMenu);
// 托盘双击打开 // 托盘双击打开
tray.on('double-click', () => { tray.on("double-click", () => {
win.show(); win.show();
}) });
getConfig((err, config) => {
if (!err) {
if (config) { if (config) {
if (config.systemStartupConnect) { if (config.systemStartupConnect) {
log.info(`已开启自动连接 正在自动连接服务器`) log.info(`已开启自动连接 正在自动连接服务器`);
startFrpWorkerProcess(config) startFrpWorkerProcess(config);
} }
} }
} };
})
}
app.whenReady().then(() => { app.whenReady().then(() => {
createWindow().then(r => { getConfig((err, config) => {
createTray() createWindow(config).then(r => {
createTray(config);
// 初始化各个API // 初始化各个API
initGitHubApi(); initGitHubApi();
initConfigApi(win); initConfigApi(win);
@ -174,7 +197,8 @@ app.whenReady().then(() => {
initCommonApi(); initCommonApi();
initLocalApi(); initLocalApi();
// initUpdaterApi(win); // initUpdaterApi(win);
}) });
});
}); });
app.on("window-all-closed", () => { app.on("window-all-closed", () => {
@ -182,7 +206,7 @@ app.on("window-all-closed", () => {
if (process.platform !== "darwin") { if (process.platform !== "darwin") {
stopFrpcProcess(() => { stopFrpcProcess(() => {
app.quit(); app.quit();
}) });
} }
}); });
@ -199,14 +223,16 @@ app.on("activate", () => {
if (allWindows.length) { if (allWindows.length) {
allWindows[0].focus(); allWindows[0].focus();
} else { } else {
createWindow(); getConfig((err, config) => {
createWindow(config).then(r => {});
});
} }
}); });
app.on('before-quit', () => { app.on("before-quit", () => {
log.info("before-quit") log.info("before-quit");
isQuiting = true; isQuiting = true;
}) });
// New window example arg: new windows url // New window example arg: new windows url
ipcMain.handle("open-win", (_, arg) => { ipcMain.handle("open-win", (_, arg) => {
@ -221,6 +247,6 @@ ipcMain.handle("open-win", (_, arg) => {
if (process.env.VITE_DEV_SERVER_URL) { if (process.env.VITE_DEV_SERVER_URL) {
childWindow.loadURL(`${url}#${arg}`); childWindow.loadURL(`${url}#${arg}`);
} else { } else {
childWindow.loadFile(indexHtml, {hash: arg}); childWindow.loadFile(indexHtml, { hash: arg });
} }
}); });

View File

@ -41,6 +41,7 @@ const defaultFormData = ref<FrpConfig>({
proxyConfigProxyUrl: "", proxyConfigProxyUrl: "",
systemSelfStart: false, systemSelfStart: false,
systemStartupConnect: false, systemStartupConnect: false,
systemSilentStartup: false,
user: "", user: "",
metaToken: "", metaToken: "",
transportHeartbeatInterval: 30, transportHeartbeatInterval: 30,
@ -933,7 +934,7 @@ onUnmounted(() => {
<el-col :span="24"> <el-col :span="24">
<div class="h2">系统配置</div> <div class="h2">系统配置</div>
</el-col> </el-col>
<el-col :span="12"> <el-col :span="8">
<el-form-item label="开机自启:" prop="systemSelfStart"> <el-form-item label="开机自启:" prop="systemSelfStart">
<template #label> <template #label>
<div class="h-full flex items-center mr-1"> <div class="h-full flex items-center mr-1">
@ -963,7 +964,36 @@ onUnmounted(() => {
/> />
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="12"> <el-col :span="8">
<el-form-item label="静默启动:" prop="systemSilentStartup">
<template #label>
<div class="h-full flex items-center mr-1">
<el-popover placement="top" trigger="hover">
<template #default>
开启后启动时<span class="font-black text-[#5A3DAA]"
>不打开界面</span
>
</template>
<template #reference>
<IconifyIconOffline
class="text-base"
color="#5A3DAA"
icon="info"
/>
</template>
</el-popover>
</div>
静默启动
</template>
<el-switch
active-text="开"
inline-prompt
inactive-text="关"
v-model="formData.systemSilentStartup"
/>
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="自动连接:" prop="systemStartupConnect"> <el-form-item label="自动连接:" prop="systemStartupConnect">
<template #label> <template #label>
<div class="h-full flex items-center mr-1"> <div class="h-full flex items-center mr-1">

1
types/global.d.ts vendored
View File

@ -76,6 +76,7 @@ declare global {
proxyConfigProxyUrl: string; proxyConfigProxyUrl: string;
systemSelfStart: boolean; systemSelfStart: boolean;
systemStartupConnect: boolean; systemStartupConnect: boolean;
systemSilentStartup: boolean;
user: string; user: string;
metaToken: string; metaToken: string;
transportHeartbeatInterval: number; transportHeartbeatInterval: number;