From 3a54a24c70775c0af17263d30e088950ca551e7c Mon Sep 17 00:00:00 2001 From: AutumnVN Date: Fri, 5 May 2023 09:41:01 -0700 Subject: VencordToolbox: Change img icon to svg (#1059) Co-authored-by: V --- src/plugins/vencordToolbox.tsx | 141 ----------------------------------- src/plugins/vencordToolbox/index.css | 7 ++ src/plugins/vencordToolbox/index.tsx | 141 +++++++++++++++++++++++++++++++++++ 3 files changed, 148 insertions(+), 141 deletions(-) delete mode 100644 src/plugins/vencordToolbox.tsx create mode 100644 src/plugins/vencordToolbox/index.css create mode 100644 src/plugins/vencordToolbox/index.tsx (limited to 'src') diff --git a/src/plugins/vencordToolbox.tsx b/src/plugins/vencordToolbox.tsx deleted file mode 100644 index 939bbd5..0000000 --- a/src/plugins/vencordToolbox.tsx +++ /dev/null @@ -1,141 +0,0 @@ -/* - * 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 :(

- }) -}); diff --git a/src/plugins/vencordToolbox/index.css b/src/plugins/vencordToolbox/index.css new file mode 100644 index 0000000..422e36d --- /dev/null +++ b/src/plugins/vencordToolbox/index.css @@ -0,0 +1,7 @@ +.vc-toolbox-btn svg { + color: var(--interactive-normal); +} + +:is(.vc-toolbox-btn:hover, .vc-toolbox-btn[class*="selected"]) svg { + color: var(--interactive-active); +} diff --git a/src/plugins/vencordToolbox/index.tsx b/src/plugins/vencordToolbox/index.tsx new file mode 100644 index 0000000..c2bfe6c --- /dev/null +++ b/src/plugins/vencordToolbox/index.tsx @@ -0,0 +1,141 @@ +/* + * 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 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 ( + + + + ); +} + +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, Devs.AutumnVN], + + patches: [ + { + find: ".mobileToolbar", + replacement: { + match: /(?<=toolbar:function.{0,100}\()\i.Fragment,/, + replace: "$self.ToolboxFragmentWrapper," + } + } + ], + + ToolboxFragmentWrapper: ErrorBoundary.wrap(ToolboxFragmentWrapper, { + fallback: () =>

Failed to render :(

+ }) +}); -- cgit