From 195f1a032fc63d4fd35564a9d11f8ed4afbcac4d Mon Sep 17 00:00:00 2001 From: V Date: Wed, 10 May 2023 23:13:47 +0200 Subject: ShowConnections: Add verified & copy/link icons in tooltip (#1092) --- src/plugins/showConnections/VerifiedIcon.tsx | 38 ++++++++++++++++++++++++++++ src/plugins/showConnections/index.tsx | 24 +++++++++++++++--- src/plugins/showConnections/styles.css | 6 +++++ 3 files changed, 64 insertions(+), 4 deletions(-) create mode 100644 src/plugins/showConnections/VerifiedIcon.tsx (limited to 'src/plugins') diff --git a/src/plugins/showConnections/VerifiedIcon.tsx b/src/plugins/showConnections/VerifiedIcon.tsx new file mode 100644 index 0000000..79e27c4 --- /dev/null +++ b/src/plugins/showConnections/VerifiedIcon.tsx @@ -0,0 +1,38 @@ +/* + * 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 { LazyComponent } from "@utils/react"; +import { findByCode, findLazy } from "@webpack"; +import { i18n, useToken } from "@webpack/common"; + +const ColorMap = findLazy(m => m.colors?.INTERACTIVE_MUTED?.css); +const VerifiedIconComponent = LazyComponent(() => findByCode(".CONNECTIONS_ROLE_OFFICIAL_ICON_TOOLTIP")); + +export function VerifiedIcon() { + const color = useToken(ColorMap.colors.INTERACTIVE_MUTED).hex(); + const forcedIconColor = useToken(ColorMap.colors.INTERACTIVE_ACTIVE).hex(); + + return ( + + ); +} diff --git a/src/plugins/showConnections/index.tsx b/src/plugins/showConnections/index.tsx index e2afc5b..50fcfe1 100644 --- a/src/plugins/showConnections/index.tsx +++ b/src/plugins/showConnections/index.tsx @@ -20,6 +20,8 @@ import "./styles.css"; import { definePluginSettings } from "@api/Settings"; import ErrorBoundary from "@components/ErrorBoundary"; +import { Flex } from "@components/Flex"; +import { CopyIcon, LinkIcon } from "@components/Icons"; import { Devs } from "@utils/constants"; import { copyWithToast } from "@utils/misc"; import { LazyComponent } from "@utils/react"; @@ -28,6 +30,8 @@ import { findByCode, findByCodeLazy, findByPropsLazy, findStoreLazy } from "@web import { Text, Tooltip } from "@webpack/common"; import { User } from "discord-types/general"; +import { VerifiedIcon } from "./VerifiedIcon"; + const Section = LazyComponent(() => findByCode("().lastSection")); const UserProfileStore = findStoreLazy("UserProfileStore"); const ThemeStore = findStoreLazy("ThemeStore"); @@ -97,7 +101,13 @@ function ConnectionsComponent({ id, theme }: { id: string, theme: string; }) { > Connections - {connections.map(connection => )} + + {connections.map(connection => )} + ); } @@ -111,17 +121,23 @@ function CompactConnectionComponent({ connection, theme }: { connection: Connect aria-label={connection.name} src={theme === "light" ? platform.icon.lightSVG : platform.icon.darkSVG} style={{ - marginTop: getSpacingPx(settings.store.iconSpacing), - marginRight: getSpacingPx(settings.store.iconSpacing), width: settings.store.iconSize, height: settings.store.iconSize }} /> ); + const TooltipIcon = url ? LinkIcon : CopyIcon; + return ( + {connection.name} + {connection.verified && } + + + } key={connection.id} > {tooltipProps => diff --git a/src/plugins/showConnections/styles.css b/src/plugins/showConnections/styles.css index 71a835b..383593c 100644 --- a/src/plugins/showConnections/styles.css +++ b/src/plugins/showConnections/styles.css @@ -3,3 +3,9 @@ display: inline-block; cursor: pointer; } + +.vc-sc-tooltip { + display: inline-flex; + gap: 0.25em; + align-items: center; +} -- cgit