diff --git a/src/plugins/_api/badges/index.tsx b/src/plugins/_api/badges/index.tsx
index 0dc09370..97b91752 100644
--- a/src/plugins/_api/badges/index.tsx
+++ b/src/plugins/_api/badges/index.tsx
@@ -77,34 +77,6 @@ export default definePlugin({
authors: [Devs.Megu, Devs.Ven, Devs.TheSun],
required: true,
patches: [
- /* Patch the badge list component on user profiles */
- {
- find: 'id:"premium",',
- replacement: [
- {
- match: /&&(\i)\.push\(\{id:"premium".+?\}\);/,
- replace: "$&$1.unshift(...$self.getBadges(arguments[0]));",
- },
- {
- // alt: "", aria-hidden: false, src: originalSrc
- match: /alt:" ","aria-hidden":!0,src:(?=(\i)\.src)/,
- // ...badge.props, ..., src: badge.image ?? ...
- replace: "...$1.props,$& $1.image??"
- },
- // replace their component with ours if applicable
- {
- match: /(?<=text:(\i)\.description,spacing:12,.{0,50})children:/,
- replace: "children:$1.component ? () => $self.renderBadgeComponent($1) :"
- },
- // conditionally override their onClick with badge.onClick if it exists
- {
- match: /href:(\i)\.link/,
- replace: "...($1.onClick && { onClick: vcE => $1.onClick(vcE, $1) }),$&"
- }
- ]
- },
-
- /* new profiles */
{
find: ".FULL_SIZE]:26",
replacement: {
diff --git a/src/plugins/betterNotes/index.tsx b/src/plugins/betterNotes/index.tsx
index b97076bf..63fcf647 100644
--- a/src/plugins/betterNotes/index.tsx
+++ b/src/plugins/betterNotes/index.tsx
@@ -17,13 +17,9 @@
*/
import { definePluginSettings, Settings } from "@api/Settings";
-import ErrorBoundary from "@components/ErrorBoundary";
import { Devs } from "@utils/constants";
import { canonicalizeMatch } from "@utils/patches";
import definePlugin, { OptionType } from "@utils/types";
-import { findByPropsLazy } from "@webpack";
-
-const UserPopoutSectionCssClasses = findByPropsLazy("section", "lastSection");
const settings = definePluginSettings({
hide: {
@@ -72,23 +68,9 @@ export default definePlugin({
match: /\.NOTE_PLACEHOLDER,/,
replace: "$&spellCheck:!$self.noSpellCheck,"
}
- },
- {
- find: ".popularApplicationCommandIds,",
- replacement: {
- match: /lastSection:(!?\i)}\),/,
- replace: "$&$self.patchPadding({lastSection:$1}),"
- }
}
],
- patchPadding: ErrorBoundary.wrap(({ lastSection }) => {
- if (!lastSection) return null;
- return (
-
- );
- }),
-
get noSpellCheck() {
return settings.store.noSpellCheck;
}
diff --git a/src/plugins/friendsSince/index.tsx b/src/plugins/friendsSince/index.tsx
index b0aed7a3..0399a2f7 100644
--- a/src/plugins/friendsSince/index.tsx
+++ b/src/plugins/friendsSince/index.tsx
@@ -16,8 +16,6 @@ const containerWrapper = findByPropsLazy("memberSinceWrapper");
const container = findByPropsLazy("memberSince");
const getCreatedAtDate = findByCodeLazy('month:"short",day:"numeric"');
const locale = findByPropsLazy("getLocale");
-const lastSection = findByPropsLazy("lastSection");
-
const section = findLazy((m: any) => m.section !== void 0 && m.heading !== void 0 && Object.values(m).length === 2);
export default definePlugin({
@@ -25,31 +23,7 @@ export default definePlugin({
description: "Shows when you became friends with someone in the user popout",
authors: [Devs.Elvyra, Devs.Antti],
patches: [
- // User popup - old layout
- {
- find: ".USER_PROFILE}};return",
- replacement: {
- match: /,{userId:(\i.id).{0,30}}\)/,
- replace: "$&,$self.friendsSinceOld({ userId: $1 })"
- }
- },
- // DM User Sidebar - old layout
- {
- find: ".PROFILE_PANEL,",
- replacement: {
- match: /,{userId:([^,]+?)}\)/,
- replace: "$&,$self.friendsSinceOld({ userId: $1 })"
- }
- },
- // User Profile Modal - old layout
- {
- find: ".userInfoSectionHeader,",
- replacement: {
- match: /(\.Messages\.USER_PROFILE_MEMBER_SINCE.+?userId:(.+?),textClassName:)(\i\.userInfoText)}\)/,
- replace: (_, rest, userId, textClassName) => `${rest}!$self.getFriendSince(${userId}) ? ${textClassName} : void 0 }), $self.friendsSinceOld({ userId: ${userId}, textClassName: ${textClassName} })`
- }
- },
- // DM User Sidebar - new layout
+ // DM User Sidebar
{
find: ".PANEL}),nicknameIcons",
replacement: {
@@ -57,7 +31,7 @@ export default definePlugin({
replace: "$&,$self.friendsSinceNew({userId:$1,isSidebar:true})"
}
},
- // User Profile Modal - new layout
+ // User Profile Modal
{
find: "action:\"PRESS_APP_CONNECTION\"",
replacement: {
@@ -78,39 +52,6 @@ export default definePlugin({
}
},
- friendsSinceOld: ErrorBoundary.wrap(({ userId, textClassName }: { userId: string; textClassName?: string; }) => {
- if (!RelationshipStore.isFriend(userId)) return null;
-
- const friendsSince = RelationshipStore.getSince(userId);
- if (!friendsSince) return null;
-
- return (
-
-
- Friends Since
-
-
-
- {!!getCurrentChannel()?.guild_id && (
-
- )}
-
- {getCreatedAtDate(friendsSince, locale.getLocale())}
-
-
-
- );
- }, { noop: true }),
-
friendsSinceNew: ErrorBoundary.wrap(({ userId, isSidebar }: { userId: string; isSidebar: boolean; }) => {
if (!RelationshipStore.isFriend(userId)) return null;
diff --git a/src/plugins/moreUserTags/index.tsx b/src/plugins/moreUserTags/index.tsx
index 45538fb6..4802f04a 100644
--- a/src/plugins/moreUserTags/index.tsx
+++ b/src/plugins/moreUserTags/index.tsx
@@ -247,9 +247,9 @@ export default definePlugin({
}
},
{
- find: 'copyMetaData:"User Tag"',
+ find: ".Messages.USER_PROFILE_PRONOUNS",
replacement: {
- match: /(?=,botClass:)/,
+ match: /(?=,hideBotTag:!0)/,
replace: ",moreTags_channelId:arguments[0].moreTags_channelId"
}
},
diff --git a/src/plugins/mutualGroupDMs/index.tsx b/src/plugins/mutualGroupDMs/index.tsx
index 7c71e1ed..a1e73cab 100644
--- a/src/plugins/mutualGroupDMs/index.tsx
+++ b/src/plugins/mutualGroupDMs/index.tsx
@@ -58,20 +58,6 @@ export default definePlugin({
authors: [Devs.amia],
patches: [
- {
- find: ".Messages.MUTUAL_GUILDS_WITH_END_COUNT", // Note: the module is lazy-loaded
- replacement: {
- match: /(?<=\.tabBarItem.{0,50}MUTUAL_GUILDS.+?}\),)(?=.+?(\(0,\i\.jsxs?\)\(.{0,100}id:))/,
- replace: '$self.isBotOrSelf(arguments[0].user)?null:$1"MUTUAL_GDMS",children:$self.getMutualGDMCountText(arguments[0].user)}),'
- }
- },
- {
- find: ".USER_INFO_CONNECTIONS:case",
- replacement: {
- match: /(?<={user:(\i),onClose:(\i)}\);)(?=case \i\.\i\.MUTUAL_FRIENDS)/,
- replace: "case \"MUTUAL_GDMS\":return $self.renderMutualGDMs({user: $1, onClose: $2});"
- }
- },
{
find: ".MUTUAL_FRIENDS?(",
replacement: [
@@ -87,9 +73,6 @@ export default definePlugin({
}
],
- isBotOrSelf,
- getMutualGDMCountText,
-
pushSection(sections: any[], user: User) {
if (isBotOrSelf(user) || sections[IS_PATCHED]) return;
diff --git a/src/plugins/noProfileThemes/index.ts b/src/plugins/noProfileThemes/index.ts
index e2b9327e..2cb83cc7 100644
--- a/src/plugins/noProfileThemes/index.ts
+++ b/src/plugins/noProfileThemes/index.ts
@@ -33,15 +33,6 @@ export default definePlugin({
replace: "=(arguments[0]?.bannerSrc||$1?.banner)&&"
}
},
- {
- find: ".avatarPositionPremiumNoBanner,default:",
- replacement: {
- // premiumUserWithoutBanner: foo().avatarPositionPremiumNoBanner, default: foo().avatarPositionNormal
- match: /\.avatarPositionPremiumNoBanner(?=,default:\i\.(\i))/,
- // premiumUserWithoutBanner: foo().avatarPositionNormal...
- replace: ".$1"
- }
- },
{
find: "hasThemeColors(){",
replacement: {
diff --git a/src/plugins/permissionsViewer/index.tsx b/src/plugins/permissionsViewer/index.tsx
index eaf90439..0dd3f717 100644
--- a/src/plugins/permissionsViewer/index.tsx
+++ b/src/plugins/permissionsViewer/index.tsx
@@ -175,13 +175,6 @@ export default definePlugin({
settings,
patches: [
- {
- find: ".popularApplicationCommandIds,",
- replacement: {
- match: /showBorder:(.{0,60})}\),(?<=guild:(\i),guildMember:(\i),.+?)/,
- replace: (m, showBoder, guild, guildMember) => `${m}$self.UserPermissions(${guild},${guildMember},${showBoder}),`
- }
- },
{
find: ".VIEW_ALL_ROLES,",
replacement: [
@@ -199,9 +192,6 @@ export default definePlugin({
}
],
- UserPermissions: (guild: Guild, guildMember: GuildMember | undefined, showBorder: boolean) =>
- !!guildMember && ,
-
ViewPermissionsButton: ErrorBoundary.wrap(({ guild, guildMember }: { guild: Guild; guildMember: GuildMember; }) => (
!settings.store.preferButtonOverDropdown
- },
{
find: ".BITE_SIZE,user:",
replacement: {
@@ -157,31 +140,6 @@ export default definePlugin({
}, 4000);
},
- getReviewsComponent: ErrorBoundary.wrap((user: User) => {
- const [reviewCount, setReviewCount] = useState();
-
- return (
- openReviewsModal(user.id, user.username)}
- moreTooltipText={
- reviewCount && reviewCount > 50
- ? `View all ${reviewCount} reviews`
- : "Open Review Modal"
- }
- onDropDownClick={state => settings.store.reviewsDropdownState = !state}
- defaultState={settings.store.reviewsDropdownState}
- >
- setReviewCount(r.reviewCount)}
- showInput
- />
-
- );
- }, { message: "Failed to render Reviews" }),
-
BiteSizeReviewsButton: ErrorBoundary.wrap(({ user }: { user: User; }) => {
return (
diff --git a/src/plugins/showAllRoles/index.ts b/src/plugins/showAllRoles/index.ts
deleted file mode 100644
index 97f0181f..00000000
--- a/src/plugins/showAllRoles/index.ts
+++ /dev/null
@@ -1,23 +0,0 @@
-/*
- * Vencord, a Discord client mod
- * Copyright (c) 2024 Vendicated and contributors
- * SPDX-License-Identifier: GPL-3.0-or-later
- */
-
-import { Devs } from "@utils/constants";
-import definePlugin from "@utils/types";
-
-export default definePlugin({
- name: "ShowAllRoles",
- description: "Show all roles in new profiles.",
- authors: [Devs.Luna],
- patches: [
- {
- find: ".Messages.VIEW_ALL_ROLES",
- replacement: {
- match: /(\i)\.slice\(0,\i\)/,
- replace: "$1"
- }
- }
- ]
-});
diff --git a/src/plugins/showConnections/index.tsx b/src/plugins/showConnections/index.tsx
index 19f6258a..d712027e 100644
--- a/src/plugins/showConnections/index.tsx
+++ b/src/plugins/showConnections/index.tsx
@@ -20,19 +20,17 @@ import "./styles.css";
import { definePluginSettings } from "@api/Settings";
import ErrorBoundary from "@components/ErrorBoundary";
+import { Flex } from "@components/Flex";
import { CopyIcon, LinkIcon } from "@components/Icons";
import { Devs } from "@utils/constants";
import { copyWithToast } from "@utils/misc";
import definePlugin, { OptionType } from "@utils/types";
-import { findByCodeLazy, findByPropsLazy, findComponentByCodeLazy, findStoreLazy } from "@webpack";
-import { Text, Tooltip, UserProfileStore } from "@webpack/common";
+import { findByCodeLazy, findByPropsLazy } from "@webpack";
+import { Tooltip, UserProfileStore } from "@webpack/common";
import { User } from "discord-types/general";
import { VerifiedIcon } from "./VerifiedIcon";
-const Section = findComponentByCodeLazy(".lastSection", "children:");
-const ThemeStore = findStoreLazy("ThemeStore");
-
const useLegacyPlatformType: (platform: string) => string = findByCodeLazy(".TWITTER_LEGACY:");
const platforms: { get(type: string): ConnectionPlatform; } = findByPropsLazy("isSupported", "getByUrl");
const getProfileThemeProps = findByCodeLazy(".getPreviewThemeColors", "primaryColor:");
@@ -75,7 +73,7 @@ interface ConnectionPlatform {
}
const profilePopoutComponent = ErrorBoundary.wrap(
- (props: { user: User; displayProfile?: any; simplified?: boolean; }) => (
+ (props: { user: User; displayProfile?: any; }) => (
(
-
- ),
- { noop: true }
-);
-
-function ConnectionsComponent({ id, theme, simplified }: { id: string, theme: string, simplified?: boolean; }) {
+function ConnectionsComponent({ id, theme }: { id: string, theme: string; }) {
const profile = UserProfileStore.getUserProfile(id);
if (!profile)
return null;
@@ -104,33 +92,13 @@ function ConnectionsComponent({ id, theme, simplified }: { id: string, theme: st
if (!connections?.length)
return null;
- const connectionsContainer = (
-
-
- Connections
-
{connections.map(connection => )}
-
- );
-
- if (simplified)
- return connectionsContainer;
-
- return (
-
- {connectionsContainer}
-
+
);
}
@@ -196,31 +164,17 @@ export default definePlugin({
name: "ShowConnections",
description: "Show connected accounts in user popouts",
authors: [Devs.TheKodeToad],
+ settings,
+
patches: [
- {
- find: "{isUsingGuildBio:null!==(",
- replacement: {
- match: /,theme:\i\}\)(?=,.{0,150}setNote:)/,
- replace: "$&,$self.profilePopoutComponent({ user: arguments[0].user, displayProfile: arguments[0].displayProfile })"
- }
- },
- {
- find: ".PROFILE_PANEL,",
- replacement: {
- // createElement(Divider, {}), createElement(NoteComponent)
- match: /\(0,\i\.jsx\)\(\i\.\i,\{\}\).{0,100}setNote:(?=.+?channelId:(\i).id)/,
- replace: "$self.profilePanelComponent({ id: $1.recipients[0] }),$&"
- }
- },
{
find: '"BiteSizeProfileBody"',
replacement: {
match: /currentUser:\i,guild:\i}\)(?<=user:(\i),bio:null==(\i)\?.+?)/,
- replace: "$&,$self.profilePopoutComponent({ user: $1, displayProfile: $2, simplified: true })"
+ replace: "$&,$self.profilePopoutComponent({ user: $1, displayProfile: $2 })"
}
}
],
- settings,
+
profilePopoutComponent,
- profilePanelComponent
});
diff --git a/src/plugins/userVoiceShow/components/VoiceChannelSection.tsx b/src/plugins/userVoiceShow/components/VoiceChannelSection.tsx
index c1bcbd65..8ca335bb 100644
--- a/src/plugins/userVoiceShow/components/VoiceChannelSection.tsx
+++ b/src/plugins/userVoiceShow/components/VoiceChannelSection.tsx
@@ -18,12 +18,11 @@
import "./VoiceChannelSection.css";
-import { findByCodeLazy, findByPropsLazy } from "@webpack";
+import { findByPropsLazy } from "@webpack";
import { Button, Forms, PermissionStore, Toasts } from "@webpack/common";
import { Channel } from "discord-types/general";
const ChannelActions = findByPropsLazy("selectChannel", "selectVoiceChannel");
-const UserPopoutSection = findByCodeLazy(".lastSection", "children:");
const CONNECT = 1n << 20n;
@@ -34,7 +33,8 @@ interface VoiceChannelFieldProps {
}
export const VoiceChannelSection = ({ channel, label, showHeader }: VoiceChannelFieldProps) => (
-
+ // @TODO The div is supposed to be a UserPopoutSection
+
{showHeader && In a voice channel}
-
+
);
diff --git a/src/plugins/userVoiceShow/index.tsx b/src/plugins/userVoiceShow/index.tsx
index 7d640171..cad539b4 100644
--- a/src/plugins/userVoiceShow/index.tsx
+++ b/src/plugins/userVoiceShow/index.tsx
@@ -84,7 +84,7 @@ export default definePlugin({
);
},
- patchPopout: ({ user }: UserProps) => {
+ patchProfilePopout: ({ user }: UserProps) => {
const isSelfUser = user.id === UserStore.getCurrentUser().id;
return (
@@ -94,21 +94,7 @@ export default definePlugin({
},
patches: [
- // above message box
- {
- find: ".popularApplicationCommandIds,",
- replacement: {
- match: /(?<=,)(?=!\i&&!\i&&.{0,50}setNote:)/,
- replace: "$self.patchPopout(arguments[0]),",
- }
- },
- // below username
- {
- find: ".Messages.MUTUAL_GUILDS_WITH_END_COUNT", // Lazy Loaded
- replacement: {
- match: /\.body.+?displayProfile:\i}\),/,
- replace: "$&$self.patchModal(arguments[0]),",
- }
- }
+ // @TODO Maybe patch UserVoiceShow in simplified profile popout
+ // @TODO Patch new profile modal
],
});
diff --git a/src/plugins/viewIcons/index.tsx b/src/plugins/viewIcons/index.tsx
index 927a974f..38d77554 100644
--- a/src/plugins/viewIcons/index.tsx
+++ b/src/plugins/viewIcons/index.tsx
@@ -192,14 +192,6 @@ export default definePlugin({
},
all: true
},
- // Old Profiles Modal pfp
- {
- find: ".MODAL,hasProfileEffect",
- replacement: {
- match: /\{src:(\i)(?=,avatarDecoration)/,
- replace: "{src:$1,onClick:()=>$self.openImage($1)"
- }
- },
// Banners
...[".NITRO_BANNER,", "=!1,canUsePremiumCustomization:"].map(find => ({
find,
@@ -211,14 +203,6 @@ export default definePlugin({
'onClick:ev=>$1&&ev.target.style.backgroundImage&&$self.openImage($2),style:{cursor:$1?"pointer":void 0,'
}
})),
- // Old User DMs "User Profile" popup in the right
- {
- find: ".avatarPositionPanel",
- replacement: {
- match: /(avatarWrapperNonUserBot.{0,50})onClick:(\i\|\|\i)\?void 0(?<=,avatarSrc:(\i).+?)/,
- replace: "$1style:($2)?{cursor:\"pointer\"}:{},onClick:$2?()=>{$self.openImage($3)}"
- }
- },
// Group DMs top small & large icon
{
find: /\.recipients\.length>=2(?!