diff --git a/src/components/VencordSettings/index.tsx b/src/components/VencordSettings/index.tsx index 0171979fe..cd6ce604a 100644 --- a/src/components/VencordSettings/index.tsx +++ b/src/components/VencordSettings/index.tsx @@ -21,8 +21,7 @@ import "./settingsStyles.css"; import { classNameFactory } from "@api/Styles"; import ErrorBoundary from "@components/ErrorBoundary"; import { handleComponentFailed } from "@components/handleComponentFailed"; -import { findByCodeLazy } from "@webpack"; -import { Forms, SettingsRouter, Text } from "@webpack/common"; +import { Forms, SettingsRouter, TabBar, Text } from "@webpack/common"; import BackupRestoreTab from "./BackupRestoreTab"; import PluginsTab from "./PluginsTab"; @@ -32,8 +31,6 @@ import VencordSettings from "./VencordTab"; const cl = classNameFactory("vc-settings-"); -const TabBar = findByCodeLazy('[role="tab"][aria-disabled="false"]'); - interface SettingsProps { tab: string; } diff --git a/src/main/index.ts b/src/main/index.ts index c35635ecd..b04ef6c40 100644 --- a/src/main/index.ts +++ b/src/main/index.ts @@ -34,6 +34,7 @@ if (IS_VENCORD_DESKTOP || !IS_VANILLA) { case "renderer.js.map": case "preload.js.map": case "patcher.js.map": // doubt + case "main.js.map": cb(join(__dirname, url)); break; default: diff --git a/src/plugins/apiMenuItemDeobfuscator.ts b/src/plugins/apiMenuItemDeobfuscator.ts deleted file mode 100644 index 4b8554fae..000000000 --- a/src/plugins/apiMenuItemDeobfuscator.ts +++ /dev/null @@ -1,82 +0,0 @@ -/* - * Vencord, a modification for Discord's desktop app - * Copyright (c) 2022 Vendicated and contributors - * - * 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 { migratePluginSettings } from "@api/settings"; -import { Devs } from "@utils/constants"; -import definePlugin from "@utils/types"; - -// duplicate values have multiple branches with different types. Just include all to be safe -const nameMap = { - radio: "MenuRadioItem", - separator: "MenuSeparator", - checkbox: "MenuCheckboxItem", - groupstart: "MenuGroup", - - control: "MenuControlItem", - compositecontrol: "MenuControlItem", - - item: "MenuItem", - customitem: "MenuItem", -}; - -migratePluginSettings("MenuItemDeobfuscatorAPI", "MenuItemDeobfuscatorApi"); -export default definePlugin({ - name: "MenuItemDeobfuscatorAPI", - description: "Deobfuscates Discord's Menu Item module", - authors: [Devs.Ven], - patches: [ - { - find: '"Menu API', - replacement: { - match: /function.{0,80}type===(\i)\).{0,50}navigable:.+?Menu API/s, - replace: (m, mod) => { - let nicenNames = ""; - const redefines = [] as string[]; - // if (t.type === m.MenuItem) - const typeCheckRe = /\(.{1,3}\.type===(.{1,5})\)/g; - // push({type:"item"}) - const pushTypeRe = /type:"(\w+)"/g; - - let typeMatch: RegExpExecArray | null; - // for each if (t.type === ...) - while ((typeMatch = typeCheckRe.exec(m)) !== null) { - // extract the current menu item - const item = typeMatch[1]; - // Set the starting index of the second regex to that of the first to start - // matching from after the if - pushTypeRe.lastIndex = typeCheckRe.lastIndex; - // extract the first type: "..." - const type = pushTypeRe.exec(m)?.[1]; - if (type && type in nameMap) { - const name = nameMap[type]; - nicenNames += `Object.defineProperty(${item},"name",{value:"${name}"});`; - redefines.push(`${name}:${item}`); - } - } - if (redefines.length < 6) { - console.warn("[ApiMenuItemDeobfuscator] Expected to at least remap 6 items, only remapped", redefines.length); - } - - // Merge all our redefines with the actual module - return `${nicenNames}Object.assign(${mod},{${redefines.join(",")}});${m}`; - }, - }, - }, - ], -}); - diff --git a/src/plugins/betterRoleDot.ts b/src/plugins/betterRoleDot.ts index 62068c782..481077b5c 100644 --- a/src/plugins/betterRoleDot.ts +++ b/src/plugins/betterRoleDot.ts @@ -45,6 +45,13 @@ export default definePlugin({ replace: "true", }, }, + { + find: ".colorPickerFooter", + replacement: { + match: /function (\i).{0,200}\.colorPickerFooter/, + replace: "$self.ColorPicker=$1;$&" + } + } ], options: { diff --git a/src/plugins/emoteCloner.tsx b/src/plugins/emoteCloner.tsx index 3bcc69446..4a018ec51 100644 --- a/src/plugins/emoteCloner.tsx +++ b/src/plugins/emoteCloner.tsx @@ -238,7 +238,7 @@ export default definePlugin({ name: "EmoteCloner", description: "Adds a Clone context menu item to emotes to clone them your own server", authors: [Devs.Ven, Devs.Nuckyz], - dependencies: ["MenuItemDeobfuscatorAPI", "ContextMenuAPI"], + dependencies: ["ContextMenuAPI"], start() { addContextMenuPatch("message", messageContextMenuPatch); diff --git a/src/plugins/messageLogger/index.tsx b/src/plugins/messageLogger/index.tsx index ef9a0ece6..8199271a3 100644 --- a/src/plugins/messageLogger/index.tsx +++ b/src/plugins/messageLogger/index.tsx @@ -76,7 +76,7 @@ export default definePlugin({ name: "MessageLogger", description: "Temporarily logs deleted and edited messages.", authors: [Devs.rushii, Devs.Ven], - dependencies: ["ContextMenuAPI", "MenuItemDeobfuscatorAPI"], + dependencies: ["ContextMenuAPI"], start() { addDeleteStyle(); diff --git a/src/plugins/reverseImageSearch.tsx b/src/plugins/reverseImageSearch.tsx index 7a3d6d986..4e0a3614d 100644 --- a/src/plugins/reverseImageSearch.tsx +++ b/src/plugins/reverseImageSearch.tsx @@ -76,7 +76,7 @@ export default definePlugin({ name: "ReverseImageSearch", description: "Adds ImageSearch to image context menus", authors: [Devs.Ven, Devs.Nuckyz], - dependencies: ["MenuItemDeobfuscatorAPI", "ContextMenuAPI"], + dependencies: ["ContextMenuAPI"], patches: [ { find: ".Messages.MESSAGE_ACTIONS_MENU_LABEL", diff --git a/src/plugins/spotifyControls/index.tsx b/src/plugins/spotifyControls/index.tsx index ce1bf6759..3a5802a1d 100644 --- a/src/plugins/spotifyControls/index.tsx +++ b/src/plugins/spotifyControls/index.tsx @@ -39,7 +39,6 @@ export default definePlugin({ name: "SpotifyControls", description: "Spotify Controls", authors: [Devs.Ven, Devs.afn, Devs.KraXen72], - dependencies: ["MenuItemDeobfuscatorAPI"], options: { hoverControls: { description: "Show controls on hover", diff --git a/src/plugins/viewIcons.tsx b/src/plugins/viewIcons.tsx index 7d56538ce..b60fb759f 100644 --- a/src/plugins/viewIcons.tsx +++ b/src/plugins/viewIcons.tsx @@ -35,8 +35,6 @@ export default definePlugin({ authors: [Devs.Ven], description: "Makes Avatars/Banners in user profiles clickable, and adds Guild Context Menu Entries to View Banner/Icon.", - dependencies: ["MenuItemDeobfuscatorAPI"], - openImage(url: string) { const u = new URL(url); u.searchParams.set("size", "512"); diff --git a/src/webpack/common/components.ts b/src/webpack/common/components.ts index 4993b2255..9554f9527 100644 --- a/src/webpack/common/components.ts +++ b/src/webpack/common/components.ts @@ -17,40 +17,37 @@ */ // eslint-disable-next-line path-alias/no-relative -import { filters, findByPropsLazy } from "../webpack"; +import { filters, findByPropsLazy, waitFor } from "@webpack"; + import { waitForComponent } from "./internal"; import * as t from "./types/components"; -export const Forms = { - FormTitle: waitForComponent("FormTitle", filters.byCode("errorSeparator")), - FormSection: waitForComponent("FormSection", filters.byCode("titleClassName", "sectionTitle")), - FormDivider: waitForComponent("FormDivider", m => { - if (typeof m !== "function") return false; - const s = m.toString(); - return s.length < 200 && s.includes(".divider"); - }), - FormText: waitForComponent("FormText", m => m.Types?.INPUT_PLACEHOLDER), +export let Forms = {} as { + FormTitle: t.FormTitle, + FormSection: t.FormSection, + FormDivider: t.FormDivider, + FormText: t.FormText, }; -export const Card = waitForComponent("Card", m => m.Types?.PRIMARY && m.defaultProps); -export const Button = waitForComponent("Button", ["Hovers", "Looks", "Sizes"]); -export const Switch = waitForComponent("Switch", filters.byCode("tooltipNote", "ringTarget")); -export const Tooltip = waitForComponent("Tooltip", filters.byCode("shouldShowTooltip:!1", "clickableOnMobile||")); +export let Card: t.Card; +export let Button: t.Button; +export let Switch: t.Switch; +export let Tooltip: t.Tooltip; +export let TextInput: t.TextInput; +export let TextArea: t.TextArea; +export let Text: t.Text; +export let Select: t.Select; +export let SearchableSelect: t.SearchableSelect; +export let Slider: t.Slider; +export let ButtonLooks: t.ButtonLooks; +export let TabBar: any; + export const Timestamp = waitForComponent("Timestamp", filters.byCode(".Messages.MESSAGE_EDITED_TIMESTAMP_A11Y_LABEL.format")); -export const TextInput = waitForComponent("TextInput", ["defaultProps", "Sizes", "contextType"]); -export const TextArea = waitForComponent("TextArea", filters.byCode("handleSetRef", "textArea")); -export const Text = waitForComponent("Text", m => { - if (typeof m !== "function") return false; - const s = m.toString(); - return (s.length < 1500 && s.includes("data-text-variant") && s.includes("always-white")); -}); -export const Select = waitForComponent("Select", filters.byCode("optionClassName", "popoutPosition", "autoFocus", "maxVisibleItems")); -const searchableSelectFilter = filters.byCode("autoFocus", ".Messages.SELECT"); -export const SearchableSelect = waitForComponent("SearchableSelect", m => - m.render && searchableSelectFilter(m.render) -); -export const Slider = waitForComponent("Slider", filters.byCode("closestMarkerIndex", "stickToMarkers")); export const Flex = waitForComponent("Flex", ["Justify", "Align", "Wrap"]); export const ButtonWrapperClasses = findByPropsLazy("buttonWrapper", "buttonContent") as Record; -export const ButtonLooks: t.ButtonLooks = findByPropsLazy("BLANK", "FILLED", "INVERTED"); + +waitFor("FormItem", m => { + ({ Card, Button, FormSwitch: Switch, Tooltip, TextInput, TextArea, Text, Select, SearchableSelect, Slider, ButtonLooks, TabBar } = m); + Forms = m; +}); diff --git a/src/webpack/common/menu.ts b/src/webpack/common/menu.ts index 6ecd754ef..97d1d2f58 100644 --- a/src/webpack/common/menu.ts +++ b/src/webpack/common/menu.ts @@ -16,32 +16,14 @@ * along with this program. If not, see . */ -import { proxyLazy } from "@utils/proxyLazy"; // eslint-disable-next-line path-alias/no-relative -import { filters, mapMangledModule, mapMangledModuleLazy } from "../webpack"; +import { filters, mapMangledModuleLazy, waitFor } from "../webpack"; import type * as t from "./types/menu"; -export const Menu: t.Menu = proxyLazy(() => { - const hasDeobfuscator = Vencord.Settings.plugins.MenuItemDeobfuscatorAPI.enabled; - const menuItems = ["MenuSeparator", "MenuGroup", "MenuItem", "MenuCheckboxItem", "MenuRadioItem", "MenuControlItem"]; +export let Menu = {} as t.Menu; - const map = mapMangledModule("♫ ⊂(。◕‿‿◕。⊂) ♪", { - ContextMenu: filters.byCode("getContainerProps"), - ...Object.fromEntries((hasDeobfuscator ? menuItems : []).map(s => [s, (m: any) => m.name === s])) - }) as t.Menu; - - if (!hasDeobfuscator) { - for (const m of menuItems) - Object.defineProperty(map, m, { - get() { - throw new Error("MenuItemDeobfuscator must be enabled to use this."); - } - }); - } - - return map; -}); +waitFor("MenuItem", m => Menu = m); export const ContextMenu: t.ContextMenuApi = mapMangledModuleLazy('type:"CONTEXT_MENU_OPEN"', { open: filters.byCode("stopPropagation"), diff --git a/src/webpack/webpack.ts b/src/webpack/webpack.ts index a37fe6d61..ffa2daadd 100644 --- a/src/webpack/webpack.ts +++ b/src/webpack/webpack.ts @@ -109,6 +109,8 @@ export const find = traceFunction("find", function find(filter: FilterFn, getDef if (!isWaitFor) { const err = new Error("Didn't find module matching this filter"); if (IS_DEV) { + logger.error(err); + logger.error(filter); if (!devToolsOpen) // Strict behaviour in DevBuilds to fail early and make sure the issue is found throw err;