diff --git a/src/plugins/viewIcons.tsx b/src/plugins/viewIcons.tsx index 433c1e53..f41ae85a 100644 --- a/src/plugins/viewIcons.tsx +++ b/src/plugins/viewIcons.tsx @@ -1,57 +1,54 @@ -import { Modal, openModal } from "../utils/modal"; +import IpcEvents from "../utils/IpcEvents"; import definePlugin from '../utils/types'; -import { filters, waitFor } from "../webpack"; - -let ImageModal: any; -let renderMaskedLink: any; - -waitFor(filters.byDisplayName("ImageModal"), m => ImageModal = m.default); -waitFor("renderMaskedLinkComponent", m => renderMaskedLink = m.renderMaskedLinkComponent); const OPEN_URL = "Vencord.Plugins.plugins.ViewIcons.openImage("; export default definePlugin({ name: "ViewIcons", author: "Vendicated", - description: "Makes Avatars/Banners in user profiles clickable, and adds Guild Context Menu Entries to View Banner/Icon. Crashes if you don't have Developer Mode enabled, will fix in the future.", + description: "Makes Avatars/Banners in user profiles clickable, and adds Guild Context Menu Entries to View Banner/Icon.", openImage(url: string) { - openModal(() => ( + VencordNative.ipc.invoke(IpcEvents.OPEN_EXTERNAL, url); + // husk + /* openModal(() => ( - ), { size: Modal.ModalSize.DYNAMIC }); + ), { size: Modal.ModalSize.DYNAMIC }); */ }, patches: [ { - find: "UserProfileModalHeader", + find: "onAddFriend:", replacement: { match: /\{src:(.{1,2}),avatarDecoration/, replace: (_, src) => `{src:${src},onClick:()=>${OPEN_URL}${src}.replace(/\\?.+$/, "")+"?size=2048"),avatarDecoration` } }, { - find: "default.popoutNoBannerPremium", + find: "().popoutNoBannerPremium", replacement: { - match: /style:.{1,2}\(\{\},(.{1,2}),/, + match: /style:.{0,10}\{\},(.{1,2})\)/, replace: (m, bannerObj) => `onClick:${bannerObj}.backgroundImage&&(()=>${OPEN_URL}${bannerObj}.backgroundImage.replace("url(", "").replace(/(\\?size=.+)?\\)/, "?size=2048"))),${m}` } }, { - find: "GuildContextMenuWrapper", + find: '"GuildContextMenu:', replacement: [ { match: /\w=(\w)\.id/, replace: (m, guild) => `_guild=${guild},${m}` }, { - match: /,(.{1,2})\((.{1,2})\.MenuGroup,\{\},void 0,(.{1,2})\)(?=\)\}.{1,2}\.displayName)/, - replace: (_, createElement, menu, copyIdElement) => `,${createElement}(${menu}.MenuGroup,{},void 0,[` + - `_guild.icon&&${createElement}(${menu}.MenuItem,` + + match: /(?<=createElement\((.{1,5}),\{id:"leave-guild".{0,100}\,)(.{1,2}\.createElement)\((.{1,5}),null,(.{1,2})\)(?=\)\}function)/, + replace: (_, menu, createElement, menuGroup, copyIdElement) => + `${createElement}(${menuGroup},null,[` + + `_guild.icon&&${createElement}(${menu},` + `{id:"viewicons-copy-icon",label:"View Icon",action:()=>${OPEN_URL}_guild.getIconURL(void 0,true)+"size=2048")}),` + - `_guild.banner&&${createElement}(${menu}.MenuItem,` + - `{id:"viewicons-copy-banner",label:"View Banner",action:()=>${OPEN_URL}Vencord.Webpack.findByProps("getGuildBannerURL").getGuildBannerURL(_guild).replace(/\\?size=.+/, "?size=2048"))}),${copyIdElement}])` + `_guild.banner&&${createElement}(${menu},` + + `{id:"viewicons-copy-banner",label:"View Banner",action:()=>${OPEN_URL}Vencord.Webpack.findByProps("getGuildBannerURL").getGuildBannerURL(_guild).replace(/\\?size=.+/, "?size=2048"))})` + + `,${copyIdElement}])` } ] }