From ef43653ed818a6a84b914c8a1f616794ad78c2c7 Mon Sep 17 00:00:00 2001 From: rob chang Date: Wed, 4 Dec 2024 11:50:41 -0500 Subject: [PATCH] feat: address bar tooltip --- .../UserAddressLink.tsx | 53 +++++++++++++------ 1 file changed, 37 insertions(+), 16 deletions(-) diff --git a/examples/ui-demo/src/components/shared/user-connection-avatar/UserAddressLink.tsx b/examples/ui-demo/src/components/shared/user-connection-avatar/UserAddressLink.tsx index ea040257b2..8f7f48db35 100644 --- a/examples/ui-demo/src/components/shared/user-connection-avatar/UserAddressLink.tsx +++ b/examples/ui-demo/src/components/shared/user-connection-avatar/UserAddressLink.tsx @@ -1,25 +1,46 @@ import truncateAddress from "@/utils/truncate-address"; -import { useConnection } from "@account-kit/react"; -import { useMemo } from "react"; +import { + TooltipProvider, + Tooltip, + TooltipTrigger, + TooltipContent, + TooltipArrow, +} from "@radix-ui/react-tooltip"; +import { useState } from "react"; export const UserAddressLink = ({ address }: { address: string | null }) => { - const connection = useConnection(); + const [showCopied, setShowCopied] = useState(false); + const [isOpen, setIsOpen] = useState(false); const truncatedAddress = truncateAddress(address ?? ""); - const addressBlockExplorerUrl = useMemo(() => { - if (!address || !connection.chain.blockExplorers) { - return null; - } - return `${connection.chain.blockExplorers?.default.url}/address/${address}`; - }, [address, connection]); + const handleClick = async () => { + if (!address) return; + await navigator.clipboard.writeText(address); + setShowCopied(true); + setIsOpen(true); + setTimeout(() => setShowCopied(false), 2000); + }; return ( - - {truncatedAddress} - + + + + + + + +

{showCopied ? "Copied!" : address}

+
+
+
); };