Add viewIcons
This commit is contained in:
parent
68057d49e8
commit
3dd294e2ad
|
@ -26,8 +26,6 @@ export default ErrorBoundary.wrap(function Settings(props) {
|
||||||
return o;
|
return o;
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
console.log(depMap);
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Forms.FormSection tag="h1" title="Vencord">
|
<Forms.FormSection tag="h1" title="Vencord">
|
||||||
<Forms.FormText>SettingsDir: {settingsDir}</Forms.FormText>
|
<Forms.FormText>SettingsDir: {settingsDir}</Forms.FormText>
|
||||||
|
|
41
src/plugins/viewIcons.ts
Normal file
41
src/plugins/viewIcons.ts
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
import { REACT_GLOBAL } from "../utils/constants";
|
||||||
|
import IpcEvents from "../utils/IpcEvents";
|
||||||
|
import definePlugin from '../utils/types';
|
||||||
|
|
||||||
|
const OPEN_URL = `VencordNative.ipc.invoke("${IpcEvents.OPEN_EXTERNAL}",`;
|
||||||
|
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",
|
||||||
|
patches: [
|
||||||
|
{
|
||||||
|
find: "UserProfileModalHeader",
|
||||||
|
replacement: {
|
||||||
|
match: /\{src:(.{1,2}),avatarDecoration/,
|
||||||
|
replace: (_, src) => `{src:${src},onClick:()=>${OPEN_URL}${src}.replace(/\\?.+$/, "")+"?size=2048"),avatarDecoration`
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
find: "default.popoutNoBannerPremium",
|
||||||
|
replacement: {
|
||||||
|
match: /style:.{1,2}\(\{\},(.{1,2}),/,
|
||||||
|
replace: (m, bannerObj) => `onClick:()=>${OPEN_URL}${bannerObj}.backgroundImage.replace("url(", "").replace(/(\\?size=.+)?\\)/, "?size=2048")),${m}`
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
find: "GuildContextMenuWrapper",
|
||||||
|
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: (_, factory, menuGroup, copyIdElement) => `,${factory}(${menuGroup},{},void 0,[` +
|
||||||
|
`_guild.icon&&${REACT_GLOBAL}.cloneElement(${copyIdElement},` +
|
||||||
|
`{key:"viewicons-copy-icon",id:"viewicons-copy-icon",action:()=>${OPEN_URL}_guild.getIconURL(undefined,true)+"size=2048"),label:"View Icon",icon:null}),` +
|
||||||
|
`_guild.banner&&${REACT_GLOBAL}.cloneElement(${copyIdElement},` +
|
||||||
|
`{key:"viewicons-copy-banner",id:"viewicons-copy-banner",action:()=>${OPEN_URL}Vencord.Webpack.findByProps("getGuildBannerURL").getGuildBannerURL(_guild).replace(/\\?size=.+/, "?size=2048")),label:"View Banner",icon:null}),${copyIdElement}])`
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
});
|
|
@ -1 +1,2 @@
|
||||||
export const WEBPACK_CHUNK = "webpackChunkdiscord_app";
|
export const WEBPACK_CHUNK = "webpackChunkdiscord_app";
|
||||||
|
export const REACT_GLOBAL = "Vencord.Webpack.Common.React";
|
Loading…
Reference in a new issue