From 4aff11421f1cccaf34a7c983fd8dc9a841042947 Mon Sep 17 00:00:00 2001
From: Xinto <48173186+X1nto@users.noreply.github.com>
Date: Sun, 19 Mar 2023 13:21:26 +0400
Subject: [PATCH] Replace update notices with notifications (#558)
---
src/Vencord.ts | 34 ++++++++++------------
src/api/settings.ts | 2 ++
src/components/VencordSettings/Updater.tsx | 12 ++++++--
3 files changed, 28 insertions(+), 20 deletions(-)
diff --git a/src/Vencord.ts b/src/Vencord.ts
index ba7d01fe6..98bc83a61 100644
--- a/src/Vencord.ts
+++ b/src/Vencord.ts
@@ -27,7 +27,7 @@ export { PlainSettings, Settings };
import "./utils/quickCss";
import "./webpack/patchWebpack";
-import { popNotice, showNotice } from "./api/Notices";
+import { showNotification } from "./api/Notifications";
import { PlainSettings, Settings } from "./api/settings";
import { patches, PMLogger, startAllPlugins } from "./plugins";
import { checkForUpdates, rebuild, update, UpdateLogger } from "./utils/updater";
@@ -49,32 +49,30 @@ async function init() {
if (Settings.autoUpdate) {
await update();
const needsFullRestart = await rebuild();
- setTimeout(() => {
- showNotice(
- "Vencord has been updated!",
- "Restart",
- () => {
+ if (Settings.autoUpdateNotification)
+ showNotification({
+ title: "Vencord has been updated!",
+ body: "Click here to restart",
+ permanent: true,
+ onClick() {
if (needsFullRestart)
window.DiscordNative.app.relaunch();
else
location.reload();
}
- );
- }, 10_000);
+ });
return;
}
if (Settings.notifyAboutUpdates)
- setTimeout(() => {
- showNotice(
- "A Vencord update is available!",
- "View Update",
- () => {
- popNotice();
- SettingsRouter.open("VencordUpdater");
- }
- );
- }, 10_000);
+ showNotification({
+ title: "A Vencord update is available!",
+ body: "Click here to view the update",
+ permanent: true,
+ onClick() {
+ SettingsRouter.open("VencordUpdater");
+ }
+ });
} catch (err) {
UpdateLogger.error("Failed to check for updates", err);
}
diff --git a/src/api/settings.ts b/src/api/settings.ts
index 1ca26116b..0ebfe1d3f 100644
--- a/src/api/settings.ts
+++ b/src/api/settings.ts
@@ -28,6 +28,7 @@ const logger = new Logger("Settings");
export interface Settings {
notifyAboutUpdates: boolean;
autoUpdate: boolean;
+ autoUpdateNotification: boolean,
useQuickCss: boolean;
enableReactDevtools: boolean;
themeLinks: string[];
@@ -52,6 +53,7 @@ export interface Settings {
const DefaultSettings: Settings = {
notifyAboutUpdates: true,
autoUpdate: false,
+ autoUpdateNotification: true,
useQuickCss: true,
themeLinks: [],
enableReactDevtools: false,
diff --git a/src/components/VencordSettings/Updater.tsx b/src/components/VencordSettings/Updater.tsx
index caed4f7ef..3c3eb91b3 100644
--- a/src/components/VencordSettings/Updater.tsx
+++ b/src/components/VencordSettings/Updater.tsx
@@ -185,7 +185,7 @@ function Newer(props: CommonProps) {
}
function Updater() {
- const settings = useSettings(["notifyAboutUpdates", "autoUpdate"]);
+ const settings = useSettings(["notifyAboutUpdates", "autoUpdate", "autoUpdateNotification"]);
const [repo, err, repoPending] = useAwaiter(getRepo, { fallbackValue: "Loading..." });
@@ -205,7 +205,7 @@ function Updater() {
settings.notifyAboutUpdates = v}
- note="Shows a toast on startup"
+ note="Shows a notification on startup"
disabled={settings.autoUpdate}
>
Get notified about new updates
@@ -217,6 +217,14 @@ function Updater() {
>
Automatically update
+ settings.autoUpdateNotification = v}
+ note="Shows a notification when Vencord automatically updates"
+ disabled={!settings.autoUpdate}
+ >
+ Get notified when an automatic update completes
+
Repo