/* * Vencord, a Discord client mod * Copyright (c) 2024 Vendicated and contributors * SPDX-License-Identifier: GPL-3.0-or-later */ import { Link } from "@components/Link"; import { Devs, EquicordDevs } from "@utils/constants"; import { localStorage } from "@utils/localStorage"; import { closeAllModals, openModal } from "@utils/modal"; import definePlugin from "@utils/types"; import { findByProps } from "@webpack"; import { Button, FluxDispatcher, Forms, React, showToast, Toasts } from "@webpack/common"; import AppIconModal from "./AppIconModal"; function removeAppIcon() { const current_icon = findByProps("getCurrentDesktopIcon").getCurrentDesktopIcon(); let icons = JSON.parse(localStorage.getItem("vc_app_icons") || "[]"); const index = icons.findIndex(icon => current_icon === icon.id); if (index !== -1) { icons = icons.filter(e => e.id !== current_icon); delete findByProps("UZ", "QA").QA[current_icon]; delete findByProps("UZ", "QA").UZ[findByProps("UZ", "QA").UZ.findIndex((icon => current_icon === icon?.id))]; localStorage.setItem("vc_app_icons", JSON.stringify(icons)); showToast("Icon successfully deleted!", Toasts.Type.SUCCESS); FluxDispatcher.dispatch({ type: "APP_ICON_UPDATED", id: "AppIcon" }); } else { showToast("Cannot delete native App Icons!", Toasts.Type.FAILURE); return; } } export default definePlugin({ name: "CustomAppIcons", description: "Add/upload custom (In-)App Icons.", authors: [Devs.HappyEnderman, EquicordDevs.SerStars], patches: [ { find: /\i\.\i\.APP_ICON_UPSELL/, replacement: [ { match: /\w+\.jsx\)\(\w+,{markAsDismissed:\w+,isCoachmark:\w+}\)/, replace(str) { return str + ",$self.addButtons()"; } } ] } ], start() { const appIcons = JSON.parse(localStorage.getItem("vc_app_icons") ?? "[]"); for (const icon of appIcons) { findByProps("UZ", "QA").UZ.push(icon); findByProps("UZ", "QA").QA[icon.id] = icon; } }, stop() { }, addButtons() { const { editorFooter } = findByProps("editorFooter"); return ( <> ); }, settingsAboutComponent: () => { return ( <> How to use? Go to { e.preventDefault(); closeAllModals(); FluxDispatcher.dispatch({ type: "USER_SETTINGS_MODAL_SET_SECTION", section: "Appearance" }); }}>Appearance Settings tab. Scroll down to "In-app Icons" and click on "Preview App Icon". And upload your own custom icon! You can only use links when you are uploading your Custom Icon. ); } });