diff --git a/src/components/Icons.tsx b/src/components/Icons.tsx
index 4227fcea..91b01dcb 100644
--- a/src/components/Icons.tsx
+++ b/src/components/Icons.tsx
@@ -146,3 +146,27 @@ export function OwnerCrownIcon(props: IconProps) {
);
}
+
+export function ImageVisible(props: IconProps) {
+ return (
+
+
+
+ );
+}
+
+export function ImageInvisible(props: IconProps) {
+ return (
+
+
+
+ );
+}
diff --git a/src/plugins/UnsuppressEmbeds.tsx b/src/plugins/UnsuppressEmbeds.tsx
new file mode 100644
index 00000000..99735c73
--- /dev/null
+++ b/src/plugins/UnsuppressEmbeds.tsx
@@ -0,0 +1,69 @@
+/*
+ * Vencord, a modification for Discord's desktop app
+ * Copyright (c) 2022 Vendicated and contributors
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see .
+*/
+
+import { addContextMenuPatch, findGroupChildrenByChildId, NavContextMenuPatchCallback, removeContextMenuPatch } from "@api/ContextMenu";
+import { ImageInvisible, ImageVisible } from "@components/Icons";
+import { Devs } from "@utils/constants";
+import definePlugin from "@utils/types";
+import { Menu, PermissionsBits, PermissionStore, RestAPI, UserStore } from "@webpack/common";
+
+const EMBED_SUPPRESSED = 1 << 2;
+
+const messageContextMenuPatch: NavContextMenuPatchCallback = (children, props) => {
+ const { message: { author, embeds, flags } } = props;
+
+ const isEmbedSuppressed = (flags & EMBED_SUPPRESSED) !== 0;
+ const hasEmbedPerms = !!(PermissionStore.getChannelPermissions({ id: props.channel.id }) & PermissionsBits.EMBED_LINKS);
+
+ return () => {
+ if (!isEmbedSuppressed && !embeds.length) return;
+ if (author.id === UserStore.getCurrentUser().id && !hasEmbedPerms) return;
+ const menuGroup = findGroupChildrenByChildId("delete", children);
+ const deleteItem = menuGroup?.findIndex(i => i?.props?.id === "delete");
+ if (!deleteItem || !menuGroup) return;
+ menuGroup.splice(deleteItem - 1, 0, (
+