improv
This commit is contained in:
parent
fb24f40412
commit
9132566c6c
11 changed files with 174 additions and 37 deletions
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "VencordDesktop",
|
"name": "VencordDesktop",
|
||||||
"version": "0.1.4",
|
"version": "0.1.3",
|
||||||
"private": true,
|
"private": true,
|
||||||
"description": "",
|
"description": "",
|
||||||
"keywords": [],
|
"keywords": [],
|
||||||
|
|
|
@ -42,7 +42,6 @@ if (!app.requestSingleInstanceLock()) {
|
||||||
|
|
||||||
app.whenReady().then(async () => {
|
app.whenReady().then(async () => {
|
||||||
checkUpdates();
|
checkUpdates();
|
||||||
|
|
||||||
if (process.platform === "win32") app.setAppUserModelId("dev.vencord.desktop");
|
if (process.platform === "win32") app.setAppUserModelId("dev.vencord.desktop");
|
||||||
else if (process.platform === "darwin") app.dock.setIcon(ICON_PATH);
|
else if (process.platform === "darwin") app.dock.setIcon(ICON_PATH);
|
||||||
|
|
||||||
|
|
|
@ -52,8 +52,12 @@ ipcMain.handle(IpcEvents.SHOW_ITEM_IN_FOLDER, (_, path) => {
|
||||||
shell.showItemInFolder(path);
|
shell.showItemInFolder(path);
|
||||||
});
|
});
|
||||||
|
|
||||||
ipcMain.handle(IpcEvents.FOCUS, () => {
|
ipcMain.handle(IpcEvents.FOCUS, e => {
|
||||||
mainWin?.focus();
|
e.sender.focus();
|
||||||
|
});
|
||||||
|
|
||||||
|
ipcMain.handle(IpcEvents.CLOSE, e => {
|
||||||
|
e.sender.close();
|
||||||
});
|
});
|
||||||
|
|
||||||
ipcMain.handle(IpcEvents.SELECT_VENCORD_DIR, async () => {
|
ipcMain.handle(IpcEvents.SELECT_VENCORD_DIR, async () => {
|
||||||
|
|
|
@ -6,18 +6,11 @@
|
||||||
|
|
||||||
import { BrowserWindow } from "electron";
|
import { BrowserWindow } from "electron";
|
||||||
import { join } from "path";
|
import { join } from "path";
|
||||||
|
import { SplashProps } from "shared/browserWinProperties";
|
||||||
import { STATIC_DIR } from "shared/paths";
|
import { STATIC_DIR } from "shared/paths";
|
||||||
|
|
||||||
export function createSplashWindow() {
|
export function createSplashWindow() {
|
||||||
const splash = new BrowserWindow({
|
const splash = new BrowserWindow(SplashProps);
|
||||||
transparent: true,
|
|
||||||
frame: false,
|
|
||||||
height: 350,
|
|
||||||
width: 300,
|
|
||||||
center: true,
|
|
||||||
resizable: false,
|
|
||||||
maximizable: false
|
|
||||||
});
|
|
||||||
|
|
||||||
splash.loadFile(join(STATIC_DIR, "splash.html"));
|
splash.loadFile(join(STATIC_DIR, "splash.html"));
|
||||||
|
|
||||||
|
|
|
@ -4,19 +4,11 @@
|
||||||
* Copyright (c) 2023 Vendicated and Vencord contributors
|
* Copyright (c) 2023 Vendicated and Vencord contributors
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { ipcRenderer } from "electron";
|
|
||||||
import type { Settings } from "shared/settings";
|
import type { Settings } from "shared/settings";
|
||||||
import type { LiteralUnion } from "type-fest";
|
import type { LiteralUnion } from "type-fest";
|
||||||
|
|
||||||
import { IpcEvents } from "../shared/IpcEvents";
|
import { IpcEvents } from "../shared/IpcEvents";
|
||||||
|
import { invoke, sendSync } from "./typedIpcs";
|
||||||
function invoke<T = any>(event: IpcEvents, ...args: any[]) {
|
|
||||||
return ipcRenderer.invoke(event, ...args) as Promise<T>;
|
|
||||||
}
|
|
||||||
|
|
||||||
function sendSync<T = any>(event: IpcEvents, ...args: any[]) {
|
|
||||||
return ipcRenderer.sendSync(event, ...args) as T;
|
|
||||||
}
|
|
||||||
|
|
||||||
export const VencordDesktopNative = {
|
export const VencordDesktopNative = {
|
||||||
app: {
|
app: {
|
||||||
|
|
16
src/preload/typedIpcs.ts
Normal file
16
src/preload/typedIpcs.ts
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
/*
|
||||||
|
* SPDX-License-Identifier: GPL-3.0
|
||||||
|
* Vencord Desktop, a desktop app aiming to give you a snappier Discord Experience
|
||||||
|
* Copyright (c) 2023 Vendicated and Vencord contributors
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { ipcRenderer } from "electron";
|
||||||
|
import { IpcEvents } from "shared/IpcEvents";
|
||||||
|
|
||||||
|
export function invoke<T = any>(event: IpcEvents, ...args: any[]) {
|
||||||
|
return ipcRenderer.invoke(event, ...args) as Promise<T>;
|
||||||
|
}
|
||||||
|
|
||||||
|
export function sendSync<T = any>(event: IpcEvents, ...args: any[]) {
|
||||||
|
return ipcRenderer.sendSync(event, ...args) as T;
|
||||||
|
}
|
|
@ -21,5 +21,8 @@ export const enum IpcEvents {
|
||||||
|
|
||||||
SELECT_VENCORD_DIR = "VCD_SELECT_VENCORD_DIR",
|
SELECT_VENCORD_DIR = "VCD_SELECT_VENCORD_DIR",
|
||||||
|
|
||||||
UPDATER_GET_LATEST_VERSION = "VCD_UPDATER_GET_LATEST_VERSION"
|
UPDATER_GET_DATA = "VCD_UPDATER_GET_DATA",
|
||||||
|
UPDATER_DOWNLOAD = "VCD_UPDATER_DOWNLOAD",
|
||||||
|
|
||||||
|
CLOSE = "VCD_CLOSE"
|
||||||
}
|
}
|
||||||
|
|
18
src/shared/browserWinProperties.ts
Normal file
18
src/shared/browserWinProperties.ts
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
/*
|
||||||
|
* SPDX-License-Identifier: GPL-3.0
|
||||||
|
* Vencord Desktop, a desktop app aiming to give you a snappier Discord Experience
|
||||||
|
* Copyright (c) 2023 Vendicated and Vencord contributors
|
||||||
|
*/
|
||||||
|
|
||||||
|
import type { BrowserWindowConstructorOptions } from "electron";
|
||||||
|
|
||||||
|
export const SplashProps: BrowserWindowConstructorOptions = {
|
||||||
|
transparent: true,
|
||||||
|
frame: false,
|
||||||
|
height: 350,
|
||||||
|
width: 300,
|
||||||
|
center: true,
|
||||||
|
resizable: false,
|
||||||
|
maximizable: false,
|
||||||
|
alwaysOnTop: true
|
||||||
|
};
|
|
@ -4,15 +4,39 @@
|
||||||
* Copyright (c) 2023 Vendicated and Vencord contributors
|
* Copyright (c) 2023 Vendicated and Vencord contributors
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { app, BrowserWindow, ipcMain } from "electron";
|
import { app, BrowserWindow, ipcMain, shell } from "electron";
|
||||||
import { githubGet, ReleaseData } from "main/utils/vencordLoader";
|
import { githubGet, ReleaseData } from "main/utils/vencordLoader";
|
||||||
import { join } from "path";
|
import { join } from "path";
|
||||||
|
import { SplashProps } from "shared/browserWinProperties";
|
||||||
import { IpcEvents } from "shared/IpcEvents";
|
import { IpcEvents } from "shared/IpcEvents";
|
||||||
import { STATIC_DIR } from "shared/paths";
|
import { STATIC_DIR } from "shared/paths";
|
||||||
|
|
||||||
let latestVersion: string;
|
export interface UpdateData {
|
||||||
|
currentVersion: string;
|
||||||
|
latestVersion: string;
|
||||||
|
release: ReleaseData;
|
||||||
|
}
|
||||||
|
|
||||||
ipcMain.handle(IpcEvents.UPDATER_GET_LATEST_VERSION, () => latestVersion);
|
let updateData: UpdateData;
|
||||||
|
|
||||||
|
ipcMain.handle(IpcEvents.UPDATER_GET_DATA, () => updateData);
|
||||||
|
ipcMain.handle(IpcEvents.UPDATER_DOWNLOAD, () => {
|
||||||
|
const { assets } = updateData.release;
|
||||||
|
const url = (() => {
|
||||||
|
switch (process.platform) {
|
||||||
|
case "win32":
|
||||||
|
return assets.find(a => a.name.endsWith(".exe"))!.browser_download_url;
|
||||||
|
case "darwin":
|
||||||
|
return assets.find(a => a.name.endsWith(".dmg"))!.browser_download_url;
|
||||||
|
case "linux":
|
||||||
|
return updateData.release.html_url;
|
||||||
|
default:
|
||||||
|
throw new Error(`Unsupported platform: ${process.platform}`);
|
||||||
|
}
|
||||||
|
})();
|
||||||
|
|
||||||
|
shell.openExternal(url);
|
||||||
|
});
|
||||||
|
|
||||||
function isOutdated(oldVersion: string, newVersion: string) {
|
function isOutdated(oldVersion: string, newVersion: string) {
|
||||||
const oldParts = oldVersion.split(".");
|
const oldParts = oldVersion.split(".");
|
||||||
|
@ -36,15 +60,21 @@ function isOutdated(oldVersion: string, newVersion: string) {
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function checkUpdates() {
|
export async function checkUpdates() {
|
||||||
if (IS_DEV) return;
|
// if (IS_DEV) return;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const raw = await githubGet("/repos/Vencord/Desktop/releases/latest");
|
const raw = await githubGet("/repos/Vencord/Desktop/releases/latest");
|
||||||
const { tag_name } = JSON.parse(raw.toString("utf-8")) as ReleaseData;
|
const data = JSON.parse(raw.toString("utf-8")) as ReleaseData;
|
||||||
|
|
||||||
const oldVersion = app.getVersion();
|
const oldVersion = app.getVersion();
|
||||||
const newVersion = (latestVersion = tag_name.replace(/^v/, ""));
|
const newVersion = data.tag_name.replace(/^v/, "");
|
||||||
if (isOutdated(oldVersion, newVersion)) openNewUpdateWindow();
|
if (isOutdated(oldVersion, newVersion)) {
|
||||||
|
updateData = {
|
||||||
|
currentVersion: oldVersion,
|
||||||
|
latestVersion: newVersion,
|
||||||
|
release: data
|
||||||
|
};
|
||||||
|
openNewUpdateWindow();
|
||||||
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.error("AppUpdater: Failed to check for updates\n", e);
|
console.error("AppUpdater: Failed to check for updates\n", e);
|
||||||
}
|
}
|
||||||
|
@ -52,6 +82,7 @@ export async function checkUpdates() {
|
||||||
|
|
||||||
function openNewUpdateWindow() {
|
function openNewUpdateWindow() {
|
||||||
const win = new BrowserWindow({
|
const win = new BrowserWindow({
|
||||||
|
...SplashProps,
|
||||||
webPreferences: {
|
webPreferences: {
|
||||||
preload: join(__dirname, "updaterPreload.js")
|
preload: join(__dirname, "updaterPreload.js")
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,9 +4,17 @@
|
||||||
* Copyright (c) 2023 Vendicated and Vencord contributors
|
* Copyright (c) 2023 Vendicated and Vencord contributors
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { contextBridge, ipcRenderer } from "electron";
|
import { contextBridge } from "electron";
|
||||||
|
import { invoke } from "preload/typedIpcs";
|
||||||
import { IpcEvents } from "shared/IpcEvents";
|
import { IpcEvents } from "shared/IpcEvents";
|
||||||
|
|
||||||
|
import type { UpdateData } from "./main";
|
||||||
|
|
||||||
contextBridge.exposeInMainWorld("Updater", {
|
contextBridge.exposeInMainWorld("Updater", {
|
||||||
getLatestVersion: () => ipcRenderer.invoke(IpcEvents.UPDATER_GET_LATEST_VERSION)
|
getData: () => invoke<UpdateData>(IpcEvents.UPDATER_GET_DATA),
|
||||||
|
download: () => {
|
||||||
|
invoke<void>(IpcEvents.UPDATER_DOWNLOAD);
|
||||||
|
invoke<void>(IpcEvents.CLOSE);
|
||||||
|
},
|
||||||
|
close: () => invoke<void>(IpcEvents.CLOSE)
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,7 +1,80 @@
|
||||||
<div>hi</div>
|
<head>
|
||||||
<p></p>
|
<style>
|
||||||
|
body {
|
||||||
|
font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell,
|
||||||
|
"Open Sans", "Helvetica Neue", sans-serif;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
color: rgb(219, 222, 225);
|
||||||
|
}
|
||||||
|
|
||||||
|
.wrapper {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
justify-content: space-between;
|
||||||
|
box-sizing: border-box;
|
||||||
|
height: 100%;
|
||||||
|
background-color: hsl(223 6.7% 20.6%);
|
||||||
|
border-radius: 8px;
|
||||||
|
border: 1px solid hsl(220 6.5% 18%);
|
||||||
|
padding: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.buttons {
|
||||||
|
display: grid;
|
||||||
|
grid-template-columns: 1fr 1fr;
|
||||||
|
gap: 0.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
button {
|
||||||
|
cursor: pointer;
|
||||||
|
padding: 0.5em;
|
||||||
|
color: white;
|
||||||
|
border: none;
|
||||||
|
border-radius: 3px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
button:hover,
|
||||||
|
button:active {
|
||||||
|
filter: brightness(0.9);
|
||||||
|
}
|
||||||
|
|
||||||
|
.green {
|
||||||
|
background-color: #248046;
|
||||||
|
}
|
||||||
|
|
||||||
|
.red {
|
||||||
|
background-color: #ed4245;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<div class="wrapper">
|
||||||
|
<section>
|
||||||
|
<h1>Update Available</h1>
|
||||||
|
<p>There's a new update for Vencord Desktop! Update now to get new fixes and features</p>
|
||||||
|
<p>
|
||||||
|
Current: <span id="current"></span>
|
||||||
|
<br />
|
||||||
|
Latest: <span id="latest"></span>
|
||||||
|
</p>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<section class="buttons">
|
||||||
|
<button class="green" onclick="Updater.download()">Download Update</button>
|
||||||
|
<button class="red" onclick="Updater.close()">Close</button>
|
||||||
|
</section>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
|
||||||
<script type="module">
|
<script type="module">
|
||||||
const version = await Updater.getLatestVersion();
|
const data = await Updater.getData();
|
||||||
document.querySelector("p").textContent = version;
|
document.getElementById("current").textContent = data.currentVersion;
|
||||||
|
document.getElementById("latest").textContent = data.latestVersion;
|
||||||
</script>
|
</script>
|
||||||
|
|
Reference in a new issue