/* * 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 "./index.css"; import { openNotificationLogModal } from "@api/Notifications/notificationLog"; import { Settings, useSettings } from "@api/Settings"; import ErrorBoundary from "@components/ErrorBoundary"; import { Devs } from "@utils/constants"; import definePlugin from "@utils/types"; import { findExportedComponentLazy } from "@webpack"; import { Menu, Popout, useState } from "@webpack/common"; import type { ReactNode } from "react"; const HeaderBarIcon = findExportedComponentLazy("Icon", "Divider"); function VencordPopout(onClose: () => void) { const { useQuickCss } = useSettings(); const pluginEntries = [] as ReactNode[]; for (const plugin of Object.values(Vencord.Plugins.plugins)) { if (plugin.toolboxActions && Vencord.Plugins.isPluginEnabled(plugin.name)) { pluginEntries.push( {Object.entries(plugin.toolboxActions).map(([text, action]) => { const key = `vc-toolbox-${plugin.name}-${text}`; return ( ); })} ); } } return ( { Settings.useQuickCss = !useQuickCss; }} /> VencordNative.quickCss.openEditor()} /> {...pluginEntries} ); } function VencordPopoutIcon(isShown: boolean) { return ( ); } 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(isShown)} 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, Devs.AutumnVN], patches: [ { find: "toolbar:function", replacement: { match: /(?<=toolbar:function.{0,100}\()\i.Fragment,/, replace: "$self.ToolboxFragmentWrapper," } } ], ToolboxFragmentWrapper: ErrorBoundary.wrap(ToolboxFragmentWrapper, { fallback: () =>

Failed to render :(

}) });