From 0514afe236e5a22150a8e227296d27b96160fafe Mon Sep 17 00:00:00 2001 From: nin0dev Date: Sat, 17 Feb 2024 05:43:10 -0500 Subject: [PATCH 1/4] Added settings for WebKeybinds You can now customize the keybinds that are readded by the plugin. --- src/plugins/webKeybinds.web/index.ts | 309 ++++++++++++++++++++++++++- 1 file changed, 308 insertions(+), 1 deletion(-) diff --git a/src/plugins/webKeybinds.web/index.ts b/src/plugins/webKeybinds.web/index.ts index 12d485aac..554f726d5 100644 --- a/src/plugins/webKeybinds.web/index.ts +++ b/src/plugins/webKeybinds.web/index.ts @@ -16,17 +16,324 @@ * along with this program. If not, see . */ +import { definePluginSettings } from "@api/Settings"; import { Devs } from "@utils/constants"; -import definePlugin from "@utils/types"; +import definePlugin, { OptionType } from "@utils/types"; import { findByPropsLazy } from "@webpack"; import { ComponentDispatch, FluxDispatcher, NavigationRouter, SelectedGuildStore, SettingsRouter } from "@webpack/common"; +const settings = definePluginSettings({ + mainModifierKey: { + type: OptionType.SELECT, + description: "Main modifier key", + options: [ + { "label": "Ctrl/Cmd", "value": "ctrl", default: true }, + { "label": "Shift", "value": "shift" }, + { "label": "Alt", "value": "alt" } + ] as const + }, + quickSwitcherKey: { + type: OptionType.SELECT, + description: "Quick Switcher key", + options: [ + { "label": "Disable keybind", "value": "off" }, + { "label": "A", "value": "a" }, + { "label": "B", "value": "b" }, + { "label": "C", "value": "c" }, + { "label": "D", "value": "d" }, + { "label": "E", "value": "e" }, + { "label": "F", "value": "f" }, + { "label": "G", "value": "g" }, + { "label": "H", "value": "h" }, + { "label": "I", "value": "i" }, + { "label": "J", "value": "j" }, + { "label": "K", "value": "k" }, + { "label": "L", "value": "l" }, + { "label": "M", "value": "m" }, + { "label": "N", "value": "n" }, + { "label": "O", "value": "o" }, + { "label": "P", "value": "p" }, + { "label": "Q", "value": "q" }, + { "label": "R", "value": "r" }, + { "label": "S", "value": "s" }, + { "label": "T", "value": "t", default: true }, + { "label": "U", "value": "u" }, + { "label": "V", "value": "v" }, + { "label": "W", "value": "w" }, + { "label": "X", "value": "x" }, + { "label": "Y", "value": "y" }, + { "label": "Z", "value": "z" }, + { "label": "0", "value": "0" }, + { "label": "1", "value": "1" }, + { "label": "2", "value": "2" }, + { "label": "3", "value": "3" }, + { "label": "4", "value": "4" }, + { "label": "5", "value": "5" }, + { "label": "6", "value": "6" }, + { "label": "7", "value": "7" }, + { "label": "8", "value": "8" }, + { "label": "9", "value": "9" }, + { "label": "Tab", "value": "tab" }, + { "label": ",", "value": "comma" } + ] as const + }, + quickSwitcherModifierKey: { + type: OptionType.SELECT, + description: "Quick Switcher modifier key", + options: [ + { "label": "None", "value": "none", default: true }, + { "label": "Ctrl/Cmd", "value": "ctrl" }, + { "label": "Shift", "value": "shift" }, + { "label": "Alt", "value": "alt" } + ] as const + }, + createGroupDMKey: { + type: OptionType.SELECT, + description: "Create group DM key", + options: [ + { "label": "Disable keybind", "value": "off" }, + { "label": "A", "value": "a" }, + { "label": "B", "value": "b" }, + { "label": "C", "value": "c" }, + { "label": "D", "value": "d" }, + { "label": "E", "value": "e" }, + { "label": "F", "value": "f" }, + { "label": "G", "value": "g" }, + { "label": "H", "value": "h" }, + { "label": "I", "value": "i" }, + { "label": "J", "value": "j" }, + { "label": "K", "value": "k" }, + { "label": "L", "value": "l" }, + { "label": "M", "value": "m" }, + { "label": "N", "value": "n" }, + { "label": "O", "value": "o" }, + { "label": "P", "value": "p" }, + { "label": "Q", "value": "q" }, + { "label": "R", "value": "r" }, + { "label": "S", "value": "s" }, + { "label": "T", "value": "t", default: true }, + { "label": "U", "value": "u" }, + { "label": "V", "value": "v" }, + { "label": "W", "value": "w" }, + { "label": "X", "value": "x" }, + { "label": "Y", "value": "y" }, + { "label": "Z", "value": "z" }, + { "label": "0", "value": "0" }, + { "label": "1", "value": "1" }, + { "label": "2", "value": "2" }, + { "label": "3", "value": "3" }, + { "label": "4", "value": "4" }, + { "label": "5", "value": "5" }, + { "label": "6", "value": "6" }, + { "label": "7", "value": "7" }, + { "label": "8", "value": "8" }, + { "label": "9", "value": "9" }, + { "label": "Tab", "value": "tab" }, + { "label": ",", "value": "comma" } + ] as const + }, + createGroupDMModifierKey: { + type: OptionType.SELECT, + description: "Create group DM modifier key", + options: [ + { "label": "None", "value": "none" }, + { "label": "Ctrl/Cmd", "value": "ctrl" }, + { "label": "Shift", "value": "shift", default: true }, + { "label": "Alt", "value": "alt" } + ] as const + }, + switchNextServerKey: { + type: OptionType.SELECT, + description: "Switch to next server key", + options: [ + { "label": "Disable keybind", "value": "off" }, + { "label": "A", "value": "a" }, + { "label": "B", "value": "b" }, + { "label": "C", "value": "c" }, + { "label": "D", "value": "d" }, + { "label": "E", "value": "e" }, + { "label": "F", "value": "f" }, + { "label": "G", "value": "g" }, + { "label": "H", "value": "h" }, + { "label": "I", "value": "i" }, + { "label": "J", "value": "j" }, + { "label": "K", "value": "k" }, + { "label": "L", "value": "l" }, + { "label": "M", "value": "m" }, + { "label": "N", "value": "n" }, + { "label": "O", "value": "o" }, + { "label": "P", "value": "p" }, + { "label": "Q", "value": "q" }, + { "label": "R", "value": "r" }, + { "label": "S", "value": "s" }, + { "label": "T", "value": "t" }, + { "label": "U", "value": "u" }, + { "label": "V", "value": "v" }, + { "label": "W", "value": "w" }, + { "label": "X", "value": "x" }, + { "label": "Y", "value": "y" }, + { "label": "Z", "value": "z" }, + { "label": "0", "value": "0" }, + { "label": "1", "value": "1" }, + { "label": "2", "value": "2" }, + { "label": "3", "value": "3" }, + { "label": "4", "value": "4" }, + { "label": "5", "value": "5" }, + { "label": "6", "value": "6" }, + { "label": "7", "value": "7" }, + { "label": "8", "value": "8" }, + { "label": "9", "value": "9" }, + { "label": "Tab", "value": "tab", default: true }, + { "label": ",", "value": "comma" } + ] as const + }, + switchNextServerModifierKey: { + type: OptionType.SELECT, + description: "Switch to next server modifier key", + options: [ + { "label": "None", "value": "none", default: true }, + { "label": "Ctrl/Cmd", "value": "ctrl" }, + { "label": "Shift", "value": "shift" }, + { "label": "Alt", "value": "alt" } + ] as const + }, + switchPreviousServerKey: { + type: OptionType.SELECT, + description: "Switch to previous server key", + options: [ + { "label": "Disable keybind", "value": "off" }, + { "label": "A", "value": "a" }, + { "label": "B", "value": "b" }, + { "label": "C", "value": "c" }, + { "label": "D", "value": "d" }, + { "label": "E", "value": "e" }, + { "label": "F", "value": "f" }, + { "label": "G", "value": "g" }, + { "label": "H", "value": "h" }, + { "label": "I", "value": "i" }, + { "label": "J", "value": "j" }, + { "label": "K", "value": "k" }, + { "label": "L", "value": "l" }, + { "label": "M", "value": "m" }, + { "label": "N", "value": "n" }, + { "label": "O", "value": "o" }, + { "label": "P", "value": "p" }, + { "label": "Q", "value": "q" }, + { "label": "R", "value": "r" }, + { "label": "S", "value": "s" }, + { "label": "T", "value": "t" }, + { "label": "U", "value": "u" }, + { "label": "V", "value": "v" }, + { "label": "W", "value": "w" }, + { "label": "X", "value": "x" }, + { "label": "Y", "value": "y" }, + { "label": "Z", "value": "z" }, + { "label": "0", "value": "0" }, + { "label": "1", "value": "1" }, + { "label": "2", "value": "2" }, + { "label": "3", "value": "3" }, + { "label": "4", "value": "4" }, + { "label": "5", "value": "5" }, + { "label": "6", "value": "6" }, + { "label": "7", "value": "7" }, + { "label": "8", "value": "8" }, + { "label": "9", "value": "9" }, + { "label": "Tab", "value": "tab", default: true }, + { "label": ",", "value": "comma" } + ] as const + }, + switchPreviousServerModifierKey: { + type: OptionType.SELECT, + description: "Switch to previous server modifier key", + options: [ + { "label": "None", "value": "none" }, + { "label": "Ctrl/Cmd", "value": "ctrl" }, + { "label": "Shift", "value": "shift", default: true }, + { "label": "Alt", "value": "alt" } + ] as const + }, + switchServersFrom1To9Key: { + type: OptionType.SELECT, + description: "Switch from 1st to 9th servers key", + options: [ + { "label": "Disable keybind", "value": "off" }, + { "label": "1 to 9", "value": "1to9", default: true } + ] as const + }, + switchServersFrom1To9MModifierKey: { + type: OptionType.SELECT, + description: "Switch from 1st to 9th servers modifier key", + options: [ + { "label": "None", "value": "none", default: true }, + { "label": "Ctrl/Cmd", "value": "ctrl" }, + { "label": "Shift", "value": "shift" }, + { "label": "Alt", "value": "alt" } + ] as const + }, + openUserProfileKey: { + type: OptionType.SELECT, + description: "Open user profile key", + options: [ + { "label": "Disable keybind", "value": "off" }, + { "label": "A", "value": "a" }, + { "label": "B", "value": "b" }, + { "label": "C", "value": "c" }, + { "label": "D", "value": "d" }, + { "label": "E", "value": "e" }, + { "label": "F", "value": "f" }, + { "label": "G", "value": "g" }, + { "label": "H", "value": "h" }, + { "label": "I", "value": "i" }, + { "label": "J", "value": "j" }, + { "label": "K", "value": "k" }, + { "label": "L", "value": "l" }, + { "label": "M", "value": "m" }, + { "label": "N", "value": "n" }, + { "label": "O", "value": "o" }, + { "label": "P", "value": "p" }, + { "label": "Q", "value": "q" }, + { "label": "R", "value": "r" }, + { "label": "S", "value": "s" }, + { "label": "T", "value": "t" }, + { "label": "U", "value": "u" }, + { "label": "V", "value": "v" }, + { "label": "W", "value": "w" }, + { "label": "X", "value": "x" }, + { "label": "Y", "value": "y" }, + { "label": "Z", "value": "z" }, + { "label": "0", "value": "0" }, + { "label": "1", "value": "1" }, + { "label": "2", "value": "2" }, + { "label": "3", "value": "3" }, + { "label": "4", "value": "4" }, + { "label": "5", "value": "5" }, + { "label": "6", "value": "6" }, + { "label": "7", "value": "7" }, + { "label": "8", "value": "8" }, + { "label": "9", "value": "9" }, + { "label": "Tab", "value": "tab" }, + { "label": ",", "value": "comma", default: true } + ] as const + }, + openUserProfileModifierKey: { + type: OptionType.SELECT, + description: "Open user profile modifier key", + options: [ + { "label": "None", "value": "none", default: true }, + { "label": "Ctrl/Cmd", "value": "ctrl" }, + { "label": "Shift", "value": "shift" }, + { "label": "Alt", "value": "alt" } + ] as const + }, +}); + const KeyBinds = findByPropsLazy("JUMP_TO_GUILD", "SERVER_NEXT"); export default definePlugin({ name: "WebKeybinds", description: "Re-adds keybinds missing in the web version of Discord: ctrl+t, ctrl+shift+t, ctrl+tab, ctrl+shift+tab, ctrl+1-9, ctrl+,. Only works fully on Vesktop/ArmCord, not inside your browser", authors: [Devs.Ven], + settings, enabledByDefault: true, onKey(e: KeyboardEvent) { From 9a634ab999f193f1ccdd1f507e1586b34ee93da9 Mon Sep 17 00:00:00 2001 From: nin0dev Date: Sat, 17 Feb 2024 05:47:07 -0500 Subject: [PATCH 2/4] Added nin0-dev (hey thats me!) to the devs list --- src/utils/constants.ts | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/utils/constants.ts b/src/utils/constants.ts index 55af93605..1cf4ddb95 100644 --- a/src/utils/constants.ts +++ b/src/utils/constants.ts @@ -410,7 +410,12 @@ export const Devs = /* #__PURE__*/ Object.freeze({ coolelectronics: { name: "coolelectronics", id: 696392247205298207n, - } + }, + nin0dev: + { + name: "nin0-dev", + id: 886685857560539176n, + }, } satisfies Record); // iife so #__PURE__ works correctly From 3f3f9677ca5bff347bc5625b7762111102c76d7e Mon Sep 17 00:00:00 2001 From: nin0dev Date: Sat, 17 Feb 2024 05:55:43 -0500 Subject: [PATCH 3/4] Added main modifier key changing --- src/plugins/webKeybinds.web/index.ts | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/src/plugins/webKeybinds.web/index.ts b/src/plugins/webKeybinds.web/index.ts index 554f726d5..ed08aa3aa 100644 --- a/src/plugins/webKeybinds.web/index.ts +++ b/src/plugins/webKeybinds.web/index.ts @@ -337,9 +337,20 @@ export default definePlugin({ enabledByDefault: true, onKey(e: KeyboardEvent) { - const hasCtrl = e.ctrlKey || (e.metaKey && navigator.platform.includes("Mac")); + let hasModifierKey; + switch (settings.store.mainModifierKey) { + case "ctrl": + hasModifierKey = e.ctrlKey || (e.metaKey && navigator.platform.includes("Mac")); + break; + case "shift": + hasModifierKey = e.shiftKey; + break; + case "alt": + hasModifierKey = e.altKey; + break; + } - if (hasCtrl) switch (e.key) { + if (hasModifierKey) switch (e.key) { case "t": case "T": e.preventDefault(); From 265b580f95a0fd18c3af6ca0efbc99e1bc5f92b0 Mon Sep 17 00:00:00 2001 From: nin0dev Date: Sun, 26 May 2024 16:59:00 -0400 Subject: [PATCH 4/4] Update README.md --- README.md | 68 ++----------------------------------------------------- 1 file changed, 2 insertions(+), 66 deletions(-) diff --git a/README.md b/README.md index a43c9f834..d1a4a1e6f 100644 --- a/README.md +++ b/README.md @@ -1,67 +1,3 @@ -# Vencord +# Ninacord -[![Codeberg Mirror](https://img.shields.io/static/v1?style=for-the-badge&label=Codeberg%20Mirror&message=codeberg.org/Vee/cord&color=2185D0&logo=)](https://codeberg.org/Vee/cord) - -The cutest Discord client mod - -| ![image](https://github.com/Vendicated/Vencord/assets/45497981/706722b1-32de-4d99-bee9-93993b504334) | -|:--:| -| A screenshot of vencord showcasing the [vencord-theme](https://github.com/synqat/vencord-theme) | - -## Features - -- Super easy to install (Download Installer, open, click install button, done) -- 100+ plugins built in: [See a list](https://vencord.dev/plugins) - - Some highlights: SpotifyControls, MessageLogger, Experiments, GameActivityToggle, Translate, NoTrack, QuickReply, Free Emotes/Stickers, PermissionsViewer, CustomCommands, ShowHiddenChannels, PronounDB -- Fairly lightweight despite the many inbuilt plugins -- Excellent Browser Support: Run Vencord in your Browser via extension or UserScript -- Works on any Discord branch: Stable, Canary or PTB all work (though for the best experience I recommend stable!) -- Custom CSS and Themes: Inbuilt css editor with support to import any css files (including BetterDiscord themes) -- Privacy friendly, blocks Discord analytics & crash reporting out of the box and has no telemetry -- Maintained very actively, broken plugins are usually fixed within 12 hours -- Settings sync: Keep your plugins and their settings synchronised between devices / apps (optional) - - -## Installing / Uninstalling - -Visit https://vencord.dev/download - -## Join our Support/Community Server - -https://discord.gg/D9uwnFnqmd - -## Sponsors - -| **Thanks a lot to all Vencord [sponsors](https://github.com/sponsors/Vendicated)!!** | -|:--:| -| [![](https://meow.vendicated.dev/sponsors.png)](https://github.com/sponsors/Vendicated) | -| *generated using [github-sponsor-graph](https://github.com/Vendicated/github-sponsor-graph)* | - - -## Star History - - - - - - Star History Chart - - - -## Disclaimer - -Discord is trademark of Discord Inc. and solely mentioned for the sake of descriptivity. -Mention of it does not imply any affiliation with or endorsement by Discord Inc. - -
-Using Vencord violates Discord's terms of service - -Client modifications are against Discord’s Terms of Service. - -However, Discord is pretty indifferent about them and there are no known cases of users getting banned for using client mods! So you should generally be fine as long as you don’t use any plugins that implement abusive behaviour. But no worries, all inbuilt plugins are safe to use! - -Regardless, if your account is very important to you and it getting disabled would be a disaster for you, you should probably not use any client mods (not exclusive to Vencord), just to be safe - -Additionally, make sure not to post screenshots with Vencord in a server where you might get banned for it - -
+This is [Vencord](https://github.com/Vendicated/Vencord) fork I use to make PRs