From 5d1283bd85471f160d5220c67ad521379804f9d1 Mon Sep 17 00:00:00 2001 From: Vendicated Date: Sat, 11 Mar 2023 14:18:32 +0100 Subject: [PATCH] Add Web/Desktop specific plugin capabilities; misc fixes --- scripts/build/common.mjs | 10 +- src/globals.d.ts | 3 +- src/plugins/{arRPC.tsx => arRPC.web.tsx} | 4 +- src/plugins/consoleShortcuts.ts | 8 +- src/plugins/devCompanion.dev.tsx | 7 +- src/plugins/{noRPC.ts => noRPC.desktop.ts} | 1 - ...ystemBadge.ts => noSystemBadge.desktop.ts} | 1 - ...icherCider.tsx => richerCider.desktop.tsx} | 134 +++++++++--------- ...umeBooster.ts => volumeBooster.desktop.ts} | 0 ...ContextMenus.ts => webContextMenus.web.ts} | 2 +- src/utils/types.ts | 4 - 11 files changed, 89 insertions(+), 85 deletions(-) rename src/plugins/{arRPC.tsx => arRPC.web.tsx} (96%) rename src/plugins/{noRPC.ts => noRPC.desktop.ts} (98%) rename src/plugins/{noSystemBadge.ts => noSystemBadge.desktop.ts} (98%) rename src/plugins/{richerCider.tsx => richerCider.desktop.tsx} (97%) rename src/plugins/{volumeBooster.ts => volumeBooster.desktop.ts} (100%) rename src/plugins/{webContextMenus.ts => webContextMenus.web.ts} (98%) diff --git a/scripts/build/common.mjs b/scripts/build/common.mjs index 16894707..80c9ae1a 100644 --- a/scripts/build/common.mjs +++ b/scripts/build/common.mjs @@ -33,6 +33,8 @@ export const banner = { `.trim() }; +const isWeb = process.argv.slice(0, 2).some(f => f.endsWith("buildWeb.mjs")); + // https://github.com/evanw/esbuild/issues/619#issuecomment-751995294 /** * @type {import("esbuild").Plugin} @@ -70,7 +72,13 @@ export const globPlugins = { for (const file of files) { if (file.startsWith(".")) continue; if (file === "index.ts") continue; - if (!watch && (file.endsWith(".dev.ts") || file.endsWith(".dev.tsx"))) continue; + const fileBits = file.split("."); + if (fileBits.length > 2 && ["ts", "tsx"].includes(fileBits.at(-1))) { + const mod = fileBits.at(-2); + if (mod === "dev" && !watch) continue; + if (mod === "web" && !isWeb) continue; + if (mod === "desktop" && isWeb) continue; + } const mod = `p${i}`; code += `import ${mod} from "./${dir}/${file.replace(/\.tsx?$/, "")}";\n`; diff --git a/src/globals.d.ts b/src/globals.d.ts index 6c5b4376..7c494e28 100644 --- a/src/globals.d.ts +++ b/src/globals.d.ts @@ -51,8 +51,7 @@ declare global { * Only available when running in Electron, undefined on web. * Thus, avoid using this or only use it inside an {@link IS_WEB} guard. * - * If you really must use it, mark your plugin as Desktop App only via - * `target: "DESKTOP"` + * If you really must use it, mark your plugin as Desktop App only by naming it Foo.desktop.ts(x) */ export var DiscordNative: any; diff --git a/src/plugins/arRPC.tsx b/src/plugins/arRPC.web.tsx similarity index 96% rename from src/plugins/arRPC.tsx rename to src/plugins/arRPC.web.tsx index ca94a0ec..9a16c640 100644 --- a/src/plugins/arRPC.tsx +++ b/src/plugins/arRPC.web.tsx @@ -48,7 +48,6 @@ export default definePlugin({ name: "WebRichPresence (arRPC)", description: "Client plugin for arRPC to enable RPC on Discord Web (experimental)", authors: [Devs.Ducko], - target: "WEB", settingsAboutComponent: () => ( <> @@ -60,6 +59,9 @@ export default definePlugin({ ), async start() { + // ArmCord comes with its own arRPC implementation, so this plugin just confuses users + if ("armcord" in window) return; + if (ws) ws.close(); ws = new WebSocket("ws://127.0.0.1:1337"); // try to open WebSocket diff --git a/src/plugins/consoleShortcuts.ts b/src/plugins/consoleShortcuts.ts index 83b52916..70a9875d 100644 --- a/src/plugins/consoleShortcuts.ts +++ b/src/plugins/consoleShortcuts.ts @@ -32,14 +32,14 @@ export default definePlugin({ authors: [Devs.Ven], getShortcuts() { - function newFindWrapper(filterFactory: (props: any) => Webpack.FilterFn) { - const cache = new Map(); + function newFindWrapper(filterFactory: (...props: any[]) => Webpack.FilterFn) { + const cache = new Map(); - return function (filterProps: any) { + return function (...filterProps: unknown[]) { const cacheKey = String(filterProps); if (cache.has(cacheKey)) return cache.get(cacheKey); - const matches = findAll(filterFactory(filterProps)); + const matches = findAll(filterFactory(...filterProps)); const result = (() => { switch (matches.length) { diff --git a/src/plugins/devCompanion.dev.tsx b/src/plugins/devCompanion.dev.tsx index 1dbf4ca6..cea71e03 100644 --- a/src/plugins/devCompanion.dev.tsx +++ b/src/plugins/devCompanion.dev.tsx @@ -112,7 +112,7 @@ function initWs(isManual = false) { }); ws.addEventListener("close", e => { - if (!wasConnected && !hasErrored) return; + if (!wasConnected || hasErrored) return; logger.info("Dev Companion Disconnected:", e.code, e.reason); @@ -204,8 +204,9 @@ function initWs(isManual = false) { return reply("Unknown Find Type " + type); } - if (results.length === 0) throw "No results"; - if (results.length > 1) throw "Found more than one result! Make this filter more specific"; + const uniqueResultsCount = new Set(results).size; + if (uniqueResultsCount === 0) throw "No results"; + if (uniqueResultsCount > 1) throw "Found more than one result! Make this filter more specific"; } catch (err) { return reply("Failed to find: " + err); } diff --git a/src/plugins/noRPC.ts b/src/plugins/noRPC.desktop.ts similarity index 98% rename from src/plugins/noRPC.ts rename to src/plugins/noRPC.desktop.ts index a78cc27e..ebd7b1a3 100644 --- a/src/plugins/noRPC.ts +++ b/src/plugins/noRPC.desktop.ts @@ -25,7 +25,6 @@ export default definePlugin({ name: "NoRPC", description: "Disables Discord's RPC server.", authors: [Devs.Cyn], - target: "DESKTOP", patches: [ { find: '.ensureModule("discord_rpc")', diff --git a/src/plugins/noSystemBadge.ts b/src/plugins/noSystemBadge.desktop.ts similarity index 98% rename from src/plugins/noSystemBadge.ts rename to src/plugins/noSystemBadge.desktop.ts index e487a974..591a0be0 100644 --- a/src/plugins/noSystemBadge.ts +++ b/src/plugins/noSystemBadge.desktop.ts @@ -23,7 +23,6 @@ export default definePlugin({ name: "NoSystemBadge", description: "Disables the taskbar and system tray unread count badge.", authors: [Devs.rushii], - target: "DESKTOP", patches: [ { find: "setSystemTrayApplications:function", diff --git a/src/plugins/richerCider.tsx b/src/plugins/richerCider.desktop.tsx similarity index 97% rename from src/plugins/richerCider.tsx rename to src/plugins/richerCider.desktop.tsx index 08b0096e..8b6fb5eb 100644 --- a/src/plugins/richerCider.tsx +++ b/src/plugins/richerCider.desktop.tsx @@ -1,67 +1,67 @@ -/* - * Vencord, a modification for Discord's desktop app - * Copyright (c) 2022 OpenAsar - * - * This program is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program. If not, see . -*/ - -import { Link } from "@components/Link"; -import definePlugin from "@utils/types"; -import { Forms } from "@webpack/common"; -const appIds = [ - "911790844204437504", - "886578863147192350", - "1020414178047041627", - "1032800329332445255" -]; -export default definePlugin({ - name: "richerCider", - description: "Enhances Cider (More details in info button) by adding the \"Listening to\" type prefix to the user's rich presence when an applicable ID is found.", - authors: [{ - id: 191621342473224192n, - name: "cryptofyre", - }], - patches: [ - { - find: '.displayName="LocalActivityStore"', - replacement: { - match: /LOCAL_ACTIVITY_UPDATE:function\((\i)\)\{/, - replace: "$&$self.patchActivity($1.activity);", - } - } - ], - settingsAboutComponent: () => ( - <> - Install Cider to use this Plugin - - Follow the link to our website to get Cider up and running, and then enable the plugin. - -

- What is Cider? - - Cider is an open-source and community oriented Apple Music client for Windows, macOS, and Linux. - -

- Recommended Optional Plugins - - I'd recommend using TimeBarAllActivities alongside this plugin to give off a much better visual to the eye (Keep in mind this only affects your client and will not show for other users) - - - ), - patchActivity(activity: any) { - if (appIds.includes(activity.application_id)) { - activity.type = 2; /* LISTENING type */ - } - }, -}); +/* + * Vencord, a modification for Discord's desktop app + * Copyright (c) 2022 OpenAsar + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . +*/ + +import { Link } from "@components/Link"; +import definePlugin from "@utils/types"; +import { Forms } from "@webpack/common"; +const appIds = [ + "911790844204437504", + "886578863147192350", + "1020414178047041627", + "1032800329332445255" +]; +export default definePlugin({ + name: "richerCider", + description: "Enhances Cider (More details in info button) by adding the \"Listening to\" type prefix to the user's rich presence when an applicable ID is found.", + authors: [{ + id: 191621342473224192n, + name: "cryptofyre", + }], + patches: [ + { + find: '.displayName="LocalActivityStore"', + replacement: { + match: /LOCAL_ACTIVITY_UPDATE:function\((\i)\)\{/, + replace: "$&$self.patchActivity($1.activity);", + } + } + ], + settingsAboutComponent: () => ( + <> + Install Cider to use this Plugin + + Follow the link to our website to get Cider up and running, and then enable the plugin. + +

+ What is Cider? + + Cider is an open-source and community oriented Apple Music client for Windows, macOS, and Linux. + +

+ Recommended Optional Plugins + + I'd recommend using TimeBarAllActivities alongside this plugin to give off a much better visual to the eye (Keep in mind this only affects your client and will not show for other users) + + + ), + patchActivity(activity: any) { + if (appIds.includes(activity.application_id)) { + activity.type = 2; /* LISTENING type */ + } + }, +}); diff --git a/src/plugins/volumeBooster.ts b/src/plugins/volumeBooster.desktop.ts similarity index 100% rename from src/plugins/volumeBooster.ts rename to src/plugins/volumeBooster.desktop.ts diff --git a/src/plugins/webContextMenus.ts b/src/plugins/webContextMenus.web.ts similarity index 98% rename from src/plugins/webContextMenus.ts rename to src/plugins/webContextMenus.web.ts index 6419cfd9..56990e1b 100644 --- a/src/plugins/webContextMenus.ts +++ b/src/plugins/webContextMenus.web.ts @@ -23,7 +23,7 @@ export default definePlugin({ name: "WebContextMenus", description: "Re-adds some of context menu items missing on the web version of Discord, namely Copy/Open Link", authors: [Devs.Ven], - target: "WEB", + enabledByDefault: true, patches: [{ // There is literally no reason for Discord to make this Desktop only. diff --git a/src/utils/types.ts b/src/utils/types.ts index 96aa4ab6..76a3d740 100644 --- a/src/utils/types.ts +++ b/src/utils/types.ts @@ -79,10 +79,6 @@ export interface PluginDef { * Whether this plugin should be enabled by default, but can be disabled */ enabledByDefault?: boolean; - /** - * Set this if your plugin only works on Browser or Desktop, not both - */ - target?: "WEB" | "DESKTOP" | "BOTH"; /** * Optionally provide settings that the user can configure in the Plugins tab of settings. * @deprecated Use `settings` instead