Fix ViewProfileImages
This commit is contained in:
parent
0444233dd9
commit
4759ca536c
|
@ -1,57 +1,54 @@
|
||||||
import { Modal, openModal } from "../utils/modal";
|
import IpcEvents from "../utils/IpcEvents";
|
||||||
import definePlugin from '../utils/types';
|
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(";
|
const OPEN_URL = "Vencord.Plugins.plugins.ViewIcons.openImage(";
|
||||||
export default definePlugin({
|
export default definePlugin({
|
||||||
name: "ViewIcons",
|
name: "ViewIcons",
|
||||||
author: "Vendicated",
|
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) {
|
openImage(url: string) {
|
||||||
openModal(() => (
|
VencordNative.ipc.invoke(IpcEvents.OPEN_EXTERNAL, url);
|
||||||
|
// husk
|
||||||
|
/* openModal(() => (
|
||||||
<ImageModal
|
<ImageModal
|
||||||
shouldAnimate={true}
|
shouldAnimate={true}
|
||||||
original={url}
|
original={url}
|
||||||
src={url}
|
src={url}
|
||||||
renderLinkComponent={renderMaskedLink}
|
renderLinkComponent={renderMaskedLink}
|
||||||
/>
|
/>
|
||||||
), { size: Modal.ModalSize.DYNAMIC });
|
), { size: Modal.ModalSize.DYNAMIC }); */
|
||||||
},
|
},
|
||||||
|
|
||||||
patches: [
|
patches: [
|
||||||
{
|
{
|
||||||
find: "UserProfileModalHeader",
|
find: "onAddFriend:",
|
||||||
replacement: {
|
replacement: {
|
||||||
match: /\{src:(.{1,2}),avatarDecoration/,
|
match: /\{src:(.{1,2}),avatarDecoration/,
|
||||||
replace: (_, src) => `{src:${src},onClick:()=>${OPEN_URL}${src}.replace(/\\?.+$/, "")+"?size=2048"),avatarDecoration`
|
replace: (_, src) => `{src:${src},onClick:()=>${OPEN_URL}${src}.replace(/\\?.+$/, "")+"?size=2048"),avatarDecoration`
|
||||||
}
|
}
|
||||||
}, {
|
}, {
|
||||||
find: "default.popoutNoBannerPremium",
|
find: "().popoutNoBannerPremium",
|
||||||
replacement: {
|
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}`
|
replace: (m, bannerObj) => `onClick:${bannerObj}.backgroundImage&&(()=>${OPEN_URL}${bannerObj}.backgroundImage.replace("url(", "").replace(/(\\?size=.+)?\\)/, "?size=2048"))),${m}`
|
||||||
}
|
}
|
||||||
}, {
|
}, {
|
||||||
find: "GuildContextMenuWrapper",
|
find: '"GuildContextMenu:',
|
||||||
replacement: [
|
replacement: [
|
||||||
{
|
{
|
||||||
match: /\w=(\w)\.id/,
|
match: /\w=(\w)\.id/,
|
||||||
replace: (m, guild) => `_guild=${guild},${m}`
|
replace: (m, guild) => `_guild=${guild},${m}`
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
match: /,(.{1,2})\((.{1,2})\.MenuGroup,\{\},void 0,(.{1,2})\)(?=\)\}.{1,2}\.displayName)/,
|
match: /(?<=createElement\((.{1,5}),\{id:"leave-guild".{0,100}\,)(.{1,2}\.createElement)\((.{1,5}),null,(.{1,2})\)(?=\)\}function)/,
|
||||||
replace: (_, createElement, menu, copyIdElement) => `,${createElement}(${menu}.MenuGroup,{},void 0,[` +
|
replace: (_, menu, createElement, menuGroup, copyIdElement) =>
|
||||||
`_guild.icon&&${createElement}(${menu}.MenuItem,` +
|
`${createElement}(${menuGroup},null,[` +
|
||||||
|
`_guild.icon&&${createElement}(${menu},` +
|
||||||
`{id:"viewicons-copy-icon",label:"View Icon",action:()=>${OPEN_URL}_guild.getIconURL(void 0,true)+"size=2048")}),` +
|
`{id:"viewicons-copy-icon",label:"View Icon",action:()=>${OPEN_URL}_guild.getIconURL(void 0,true)+"size=2048")}),` +
|
||||||
`_guild.banner&&${createElement}(${menu}.MenuItem,` +
|
`_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}])`
|
`{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