/* * Vencord, a modification for Discord's desktop app * Copyright (c) 2023 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 { openNotificationLogModal } from "@api/Notifications/notificationLog"; import ErrorBoundary from "@components/ErrorBoundary"; import { Devs } from "@utils/constants"; import { LazyComponent } from "@utils/misc"; import definePlugin from "@utils/types"; import { findByCode } from "@webpack"; import { Menu, Popout, useState } from "@webpack/common"; import type { ReactNode } from "react"; const HeaderBarIcon = LazyComponent(() => findByCode(".HEADER_BAR_BADGE,", ".tooltip")); function VencordPopout(onClose: () => void) { const pluginEntries = [] as ReactNode[]; for (const plugin of Object.values(Vencord.Plugins.plugins)) { if (plugin.toolboxActions) { pluginEntries.push( {Object.entries(plugin.toolboxActions).map(([text, action]) => { const key = `vc-toolbox-${plugin.name}-${text}`; return ( ); })} ); } } return ( VencordNative.quickCss.openEditor()} /> {...pluginEntries} ); } function VencordPopoutIcon() { return ( Vencord Toolbox ); } function VencordPopoutButton() { const [show, setShow] = useState(false); return ( setShow(false)} renderPopout={() => VencordPopout(() => setShow(false))} > {(_, { isShown }) => ( setShow(v => !v)} tooltip={isShown ? null : "Vencord Toolbox"} icon={VencordPopoutIcon} selected={isShown} /> )} ); } function ToolboxFragmentWrapper({ children }: { children: ReactNode[]; }) { children.splice( children.length - 1, 0, ); return <>{children}; } export default definePlugin({ name: "VencordToolbox", description: "Adds a button next to the inbox button in the channel header that houses Vencord quick actions", authors: [Devs.Ven], patches: [ { find: ".mobileToolbar", replacement: { match: /(?<=toolbar:function.{0,100}\()\i.Fragment,/, replace: "$self.ToolboxFragmentWrapper," } } ], ToolboxFragmentWrapper: ErrorBoundary.wrap(ToolboxFragmentWrapper, { fallback: () =>

Failed to render :(

}) });