From 158c2b6e8e41a88233fc819af54f4e0848604d0a Mon Sep 17 00:00:00 2001 From: Joaquim Verges Date: Fri, 25 Oct 2024 11:52:08 +1300 Subject: [PATCH] feat: respect theme accentColor for default connect UI icons (#5163) --- .changeset/few-bears-float.md | 5 ++ .../connect/sign-in/button/RightSection.tsx | 65 ++++++++--------- .../src/react/core/utils/walletIcon.ts | 6 +- .../react/web/ui/ConnectWallet/MenuButton.tsx | 3 - .../web/ui/ConnectWallet/WalletSelector.tsx | 4 +- .../ui/ConnectWallet/WalletTypeRowButton.tsx | 21 ++---- .../web/ui/ConnectWallet/icons/EmailIcon.tsx | 30 ++++++++ .../ConnectWallet/icons/FingerPrintIcon.tsx | 18 ++--- .../web/ui/ConnectWallet/icons/GuestIcon.tsx | 24 +++++++ .../ConnectWallet/icons/OutlineWalletIcon.tsx | 4 +- .../web/ui/ConnectWallet/icons/PhoneIcon.tsx | 32 +++++++++ .../react/web/ui/ConnectWallet/icons/types.ts | 2 +- .../screens/LinkedProfilesScreen.tsx | 11 ++- .../react/web/ui/components/WalletImage.tsx | 69 +++++++++++++------ .../react/web/wallets/in-app/WalletAuth.tsx | 16 ++++- .../shared/ConnectWalletSocialOptions.tsx | 25 ++++--- 16 files changed, 230 insertions(+), 105 deletions(-) create mode 100644 .changeset/few-bears-float.md create mode 100644 packages/thirdweb/src/react/web/ui/ConnectWallet/icons/EmailIcon.tsx create mode 100644 packages/thirdweb/src/react/web/ui/ConnectWallet/icons/GuestIcon.tsx create mode 100644 packages/thirdweb/src/react/web/ui/ConnectWallet/icons/PhoneIcon.tsx diff --git a/.changeset/few-bears-float.md b/.changeset/few-bears-float.md new file mode 100644 index 00000000000..7b3f4bf3808 --- /dev/null +++ b/.changeset/few-bears-float.md @@ -0,0 +1,5 @@ +--- +"thirdweb": patch +--- + +Respect theme accentColor for default icons in connect UI diff --git a/apps/playground-web/src/app/connect/sign-in/button/RightSection.tsx b/apps/playground-web/src/app/connect/sign-in/button/RightSection.tsx index 3e91d0ffb6c..ddf9057cbb9 100644 --- a/apps/playground-web/src/app/connect/sign-in/button/RightSection.tsx +++ b/apps/playground-web/src/app/connect/sign-in/button/RightSection.tsx @@ -82,6 +82,37 @@ export function RightSection(props: { } }, [connectOptions.enableAuth, doLogout]); + const connectButton = ( + + ); + return (
+ // TODO: should show the expanded connected modal here instead + connectButton ) : (
))} - {previewTab === "button" && ( - - )} + {previewTab === "button" && connectButton} {previewTab === "code" && }
diff --git a/packages/thirdweb/src/react/core/utils/walletIcon.ts b/packages/thirdweb/src/react/core/utils/walletIcon.ts index cabb929617f..b7a93f4132e 100644 --- a/packages/thirdweb/src/react/core/utils/walletIcon.ts +++ b/packages/thirdweb/src/react/core/utils/walletIcon.ts @@ -23,9 +23,9 @@ const githubIconUri = ""; const xIcon = ""; -export const emailIcon = +const emailIcon = ""; -export const phoneIcon = +const phoneIcon = ""; export const genericTokenIcon = ""; @@ -33,7 +33,7 @@ const guestIcon = ""; export const genericWalletIcon = ""; -export const passkeyIcon = +const passkeyIcon = ""; export const socialIcons = { diff --git a/packages/thirdweb/src/react/web/ui/ConnectWallet/MenuButton.tsx b/packages/thirdweb/src/react/web/ui/ConnectWallet/MenuButton.tsx index 923ee56c349..131269d05eb 100644 --- a/packages/thirdweb/src/react/web/ui/ConnectWallet/MenuButton.tsx +++ b/packages/thirdweb/src/react/web/ui/ConnectWallet/MenuButton.tsx @@ -34,9 +34,6 @@ export const MenuButton = /* @__PURE__ */ StyledButton((_) => { }, "&[disabled]": { cursor: "not-allowed", - svg: { - display: "none", - }, }, svg: { color: theme.colors.secondaryText, diff --git a/packages/thirdweb/src/react/web/ui/ConnectWallet/WalletSelector.tsx b/packages/thirdweb/src/react/web/ui/ConnectWallet/WalletSelector.tsx index 61d690c5641..743e2412a1c 100644 --- a/packages/thirdweb/src/react/web/ui/ConnectWallet/WalletSelector.tsx +++ b/packages/thirdweb/src/react/web/ui/ConnectWallet/WalletSelector.tsx @@ -16,7 +16,6 @@ import { radius, spacing, } from "../../../core/design-system/index.js"; -import { genericWalletIcon } from "../../../core/utils/walletIcon.js"; import { useSetSelectionData } from "../../providers/wallet-ui-states-provider.js"; import { sortWallets } from "../../utils/sortWallets.js"; import { LoadingScreen } from "../../wallets/shared/LoadingScreen.js"; @@ -42,6 +41,7 @@ import { PoweredByThirdweb } from "./PoweredByTW.js"; import { WalletButtonEl, WalletEntryButton } from "./WalletEntryButton.js"; import { WalletTypeRowButton } from "./WalletTypeRowButton.js"; import { compactModalMaxHeight } from "./constants.js"; +import { OutlineWalletIcon } from "./icons/OutlineWalletIcon.js"; import type { ConnectLocale } from "./locale/types.js"; const InAppWalletSelectionUI = /* @__PURE__ */ lazy( @@ -226,7 +226,7 @@ const WalletSelectorInner: React.FC = (props) => { const connectAWallet = ( { setIsWalletGroupExpanded(true); }} diff --git a/packages/thirdweb/src/react/web/ui/ConnectWallet/WalletTypeRowButton.tsx b/packages/thirdweb/src/react/web/ui/ConnectWallet/WalletTypeRowButton.tsx index 93b95204ced..35bc1225394 100644 --- a/packages/thirdweb/src/react/web/ui/ConnectWallet/WalletTypeRowButton.tsx +++ b/packages/thirdweb/src/react/web/ui/ConnectWallet/WalletTypeRowButton.tsx @@ -1,19 +1,15 @@ import type { ThirdwebClient } from "../../../../client/client.js"; -import { - iconSize, - radius, - spacing, -} from "../../../core/design-system/index.js"; +import { iconSize, spacing } from "../../../core/design-system/index.js"; import { Text } from "../../ui/components/text.js"; -import { Img } from "../components/Img.js"; import { Container } from "../components/basic.js"; import { Button } from "../components/buttons.js"; +import type { IconFC } from "./icons/types.js"; type WalletTypeRowProps = { client: ThirdwebClient; onClick: () => void; title: string; - icon: string; + icon: IconFC; disabled?: boolean; }; @@ -33,16 +29,7 @@ export function WalletTypeRowButton(props: WalletTypeRowProps) { disabled={props.disabled} > - + {props.title} diff --git a/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/EmailIcon.tsx b/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/EmailIcon.tsx new file mode 100644 index 00000000000..04031ebfebc --- /dev/null +++ b/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/EmailIcon.tsx @@ -0,0 +1,30 @@ +import type { IconFC } from "./types.js"; + +/** + * @internal + */ +export const EmailIcon: IconFC = (props) => { + return ( + + + + + ); +}; diff --git a/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/FingerPrintIcon.tsx b/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/FingerPrintIcon.tsx index 8137624a454..cfb28de01fa 100644 --- a/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/FingerPrintIcon.tsx +++ b/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/FingerPrintIcon.tsx @@ -11,63 +11,63 @@ export const FingerPrintIcon: IconFC = (props) => { > { + return ( + + + + + ); +}; diff --git a/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/OutlineWalletIcon.tsx b/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/OutlineWalletIcon.tsx index 927048d2f90..59210957c8a 100644 --- a/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/OutlineWalletIcon.tsx +++ b/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/OutlineWalletIcon.tsx @@ -15,14 +15,14 @@ export const OutlineWalletIcon: IconFC = (props) => { > { + return ( + + + + + + + + + + + ); +}; diff --git a/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/types.ts b/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/types.ts index b32aac26652..83e0d717cb2 100644 --- a/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/types.ts +++ b/packages/thirdweb/src/react/web/ui/ConnectWallet/icons/types.ts @@ -1 +1 @@ -export type IconFC = React.FC<{ size: string }>; +export type IconFC = React.FC<{ size: string; color?: string }>; diff --git a/packages/thirdweb/src/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.tsx b/packages/thirdweb/src/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.tsx index 7ab67e79c15..e8e7327dcad 100644 --- a/packages/thirdweb/src/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.tsx +++ b/packages/thirdweb/src/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.tsx @@ -14,6 +14,9 @@ import { Text } from "../../components/text.js"; import { Blobbie } from "../Blobbie.js"; import { MenuButton } from "../MenuButton.js"; import { AddUserIcon } from "../icons/AddUserIcon.js"; +import { EmailIcon } from "../icons/EmailIcon.js"; +import { FingerPrintIcon } from "../icons/FingerPrintIcon.js"; +import { PhoneIcon } from "../icons/PhoneIcon.js"; import type { ConnectLocale } from "../locale/types.js"; import type { WalletDetailsModalScreen } from "./types.js"; @@ -84,7 +87,7 @@ export function LinkedProfilesScreen(props: { fontSize: fontSize.sm, }} > - + {props.locale.manageWallet.linkProfile} @@ -147,6 +150,12 @@ function LinkedProfile({ > + ) : profile.type === "passkey" ? ( + + ) : profile.type === "email" ? ( + + ) : profile.type === "phone" ? ( + ) : ( (undefined); + const theme = useCustomTheme(); + const [image, setImage] = useState(undefined); const activeWallet = useActiveWallet(); useEffect(() => { async function fetchImage() { @@ -33,7 +43,7 @@ export function WalletImage(props: { // show the admin EOA icon for smart const storage = webLocalStorage; const activeEOAId = props.id; - let image: string | undefined; + let image: WalletImageState | undefined; if ( activeEOAId === "inApp" && @@ -43,17 +53,22 @@ export function WalletImage(props: { // when showing an active wallet icon - check last auth provider and override the IAW icon const lastAuthProvider = await getLastAuthProvider(storage); image = lastAuthProvider - ? getSocialIcon(lastAuthProvider) - : genericWalletIcon; + ? { + uri: getSocialIcon(lastAuthProvider), + authProvider: lastAuthProvider as AuthOption, + } + : { uri: "", authProvider: "wallet" }; } else { const mipdImage = getInstalledWalletProviders().find( (x) => x.info.rdns === activeEOAId, )?.info.icon; if (mipdImage) { - image = mipdImage; + image = { uri: mipdImage }; } else { - image = await getWalletInfo(activeEOAId, true); + image = { + uri: await getWalletInfo(activeEOAId, true), + }; } } @@ -62,10 +77,34 @@ export function WalletImage(props: { fetchImage(); }, [props.id, activeWallet]); - if (image) { + if (image?.authProvider === "email") { + return ; + } + + if (image?.authProvider === "phone") { + return ; + } + + if (image?.authProvider === "passkey") { + return ( + + ); + } + + if (image?.authProvider === "wallet") { + return ( + + ); + } + + if (image?.authProvider === "guest") { + return ; + } + + if (image?.uri) { return ( - ); + return ; } diff --git a/packages/thirdweb/src/react/web/wallets/in-app/WalletAuth.tsx b/packages/thirdweb/src/react/web/wallets/in-app/WalletAuth.tsx index 0328b5a9657..1916a949584 100644 --- a/packages/thirdweb/src/react/web/wallets/in-app/WalletAuth.tsx +++ b/packages/thirdweb/src/react/web/wallets/in-app/WalletAuth.tsx @@ -131,7 +131,12 @@ export function WalletAuth(props: { size={props.size} meta={props.meta || {}} walletConnect={props.walletConnect} - modalHeader={{ title: props.inAppLocale.linkWallet, onBack: back }} + modalHeader={{ + title: props.isLinking + ? props.inAppLocale.linkWallet + : props.inAppLocale.signInWithWallet, + onBack: back, + }} walletIdsToHide={["inApp"]} disableSelectionDataReset={true} /> @@ -141,7 +146,14 @@ export function WalletAuth(props: { return ( - + { setManualInputMode("email"); }} @@ -451,7 +450,7 @@ export const ConnectWalletSocialOptions = ( ) : ( { setManualInputMode("phone"); }} @@ -463,7 +462,7 @@ export const ConnectWalletSocialOptions = ( {passKeyEnabled && ( { handlePassKeyLogin(); }} @@ -476,7 +475,7 @@ export const ConnectWalletSocialOptions = ( {siweEnabled && ( { handleWalletLogin(); }} @@ -488,7 +487,7 @@ export const ConnectWalletSocialOptions = ( {guestEnabled && ( { handleGuestLogin(); }} @@ -500,7 +499,7 @@ export const ConnectWalletSocialOptions = ( {props.isLinking && ( { handleWalletLogin(); }}