Fix ViewProfileImages
This commit is contained in:
parent
0444233dd9
commit
4759ca536c
1 changed files with 17 additions and 20 deletions
|
@ -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(() => (
|
||||
<ImageModal
|
||||
shouldAnimate={true}
|
||||
original={url}
|
||||
src={url}
|
||||
renderLinkComponent={renderMaskedLink}
|
||||
/>
|
||||
), { 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}])`
|
||||
}
|
||||
]
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue