import { useState } from 'react'; import CopyToClipboard from 'react-copy-to-clipboard'; import { truncateByChars } from '@vegaprotocol/utils'; import { VegaIcon, VegaIconNames, TradingButton as Button, Intent, TradingDropdown, TradingDropdownTrigger, TradingDropdownContent, TradingDropdownRadioGroup, TradingDropdownSeparator, TradingDropdownItem, TradingDropdownRadioItem, TradingDropdownItemIndicator, } from '@vegaprotocol/ui-toolkit'; import { isBrowserWalletInstalled, type Key } from '@vegaprotocol/wallet'; import { useDialogStore, useVegaWallet } from '@vegaprotocol/wallet-react'; import { useCopyTimeout } from '@vegaprotocol/react-helpers'; import classNames from 'classnames'; import { ViewType, useSidebar } from '../sidebar'; import { useGetCurrentRouteId } from '../../lib/hooks/use-get-current-route-id'; import { useT } from '../../lib/use-t'; export const VegaWalletConnectButton = ({ intent = Intent.None, onClick, }: { intent?: Intent; onClick?: () => void; }) => { const t = useT(); const [dropdownOpen, setDropdownOpen] = useState(false); const openVegaWalletDialog = useDialogStore((store) => store.open); const currentRouteId = useGetCurrentRouteId(); const setViews = useSidebar((store) => store.setViews); const { status, pubKeys, pubKey, selectPubKey, disconnect, refreshKeys, isReadOnly, } = useVegaWallet(); const walletInstalled = isBrowserWalletInstalled(); const activeKey = pubKeys?.find((pk) => pk.publicKey === pubKey); if (status === 'connected') { return ( { refreshKeys(); setDropdownOpen((x) => !x); }} > } > setDropdownOpen(false)} sideOffset={12} side="bottom" align="end" onEscapeKeyDown={() => setDropdownOpen(false)} >
{ selectPubKey(value); }} > {pubKeys.map((pk) => ( ))} {!isReadOnly && ( { setViews({ type: ViewType.Transfer }, currentRouteId); setDropdownOpen(false); }} > {t('Transfer')} )} {t('Disconnect')}
); } return ( ); }; const KeypairItem = ({ pk, active }: { pk: Key; active: boolean }) => { const t = useT(); const [copied, setCopied] = useCopyTimeout(); return (
{pk.name} {' | '} {truncateByChars(pk.publicKey)} setCopied(true)}> {copied && {t('Copied')}}
); };