4ed623c84c
* feat: update connect dialog to handle api v2 * feat: better error handling * feat: update to only use strings for pubkey, add json rpc connector * feat: make json connector follow same patterns as rest connector * feat: add ability to change wallet location * feat: add chain id fetch * feat: improve types * feat: adjust send tx types * chore: remove dialog title and chain check temporarily * feat: additional UI and error handling * feat: rename keypair and keypairs to pubKey and pubKeys * feat: make rest and json rpc connectors return consistent data * feat: rename derived ids more clearly * feat: update send_transaction response type * chore: fix tests after context name change * feat: add utils for wallet, add encode tx func * feat: return null if tx is rejected * feat: fix up styles for connect buttons * feat: handle wallet version check * feat: add chain id check * chore: rename select pub key function to match, fix tests * fix: tests for rest connector form * feat: add tests for json rpc flow * feat: connect dialog changes * chore: change status to enum to avoid magic strings * feat: add custom icons and handle provided key name * chore: update global wallet connection e2d tests * chore: change zod validation to only expected required values * chore: ignore new generated code files * chore: fix typos and add translations * chore: set hosted wallet via env var and only show if not mainnet * feat: add functionality for try again button * test: fix failing tests * chore: fix lint and test * chore: remove double import * chore: make console-lite-e2e strict so json connector compiles correctly * chore: make token e2e tsconfig strict * chore: make stats-e2e tsconfig strict * feat: update json rpc request namespace * feat: simplify connector setup, support try again * chore: remove comment * fix: build errors * chore: make chainId check optional based on presence of appChainId, mock request for tests * chore: mock chain id request for all apps on all pages * fix: footer border on small screens * fix: use beforeEach for chainId query mock * chore: remove optional chain check, prevent rendering until fetch is complete * chore: update NX_VEGA_WALLET_URLs as the application now appends the base path, adjust token tests * fix: token e2e test that checks for pubkey name * chore: remove duplicated test, update wallet title assertion * fix: token tests * fix: token e2e assertions * fix: withdraw test * feat: enable json RPC for token * fix: sendTx command now accpets pubkey as separate arg * fix: test to use gui option temporarily Co-authored-by: Dexter <dexter.edwards93@gmail.com>
117 lines
3.3 KiB
TypeScript
117 lines
3.3 KiB
TypeScript
import { t, truncateByChars } from '@vegaprotocol/react-helpers';
|
|
import {
|
|
Button,
|
|
DropdownMenu,
|
|
DropdownMenuContent,
|
|
DropdownMenuItem,
|
|
DropdownMenuItemIndicator,
|
|
DropdownMenuRadioGroup,
|
|
DropdownMenuRadioItem,
|
|
DropdownMenuTrigger,
|
|
Icon,
|
|
} from '@vegaprotocol/ui-toolkit';
|
|
import { useVegaWallet } from '@vegaprotocol/wallet';
|
|
import { useEffect, useMemo, useState } from 'react';
|
|
import CopyToClipboard from 'react-copy-to-clipboard';
|
|
|
|
export interface VegaWalletConnectButtonProps {
|
|
setConnectDialog: (isOpen: boolean) => void;
|
|
}
|
|
|
|
export const VegaWalletConnectButton = ({
|
|
setConnectDialog,
|
|
}: VegaWalletConnectButtonProps) => {
|
|
const [dropdownOpen, setDropdownOpen] = useState(false);
|
|
const { pubKey, pubKeys, selectPubKey, disconnect } = useVegaWallet();
|
|
const isConnected = pubKey !== null;
|
|
|
|
const activeKey = useMemo(() => {
|
|
return pubKeys?.find((pk) => pk.publicKey === pubKey);
|
|
}, [pubKey, pubKeys]);
|
|
|
|
if (isConnected && pubKeys) {
|
|
return (
|
|
<DropdownMenu open={dropdownOpen}>
|
|
<DropdownMenuTrigger
|
|
data-testid="manage-vega-wallet"
|
|
onClick={() => setDropdownOpen((curr) => !curr)}
|
|
>
|
|
{activeKey && <span className="uppercase">{activeKey.name}</span>}
|
|
{': '}
|
|
{truncateByChars(pubKey)}
|
|
</DropdownMenuTrigger>
|
|
<DropdownMenuContent onInteractOutside={() => setDropdownOpen(false)}>
|
|
<div className="min-w-[340px]" data-testid="keypair-list">
|
|
<DropdownMenuRadioGroup
|
|
value={pubKey}
|
|
onValueChange={(value) => {
|
|
selectPubKey(value);
|
|
}}
|
|
>
|
|
{pubKeys.map((k) => (
|
|
<KeypairItem key={k.publicKey} kp={k.publicKey} />
|
|
))}
|
|
</DropdownMenuRadioGroup>
|
|
<DropdownMenuItem data-testid="disconnect" onClick={disconnect}>
|
|
{t('Disconnect')}
|
|
</DropdownMenuItem>
|
|
</div>
|
|
</DropdownMenuContent>
|
|
</DropdownMenu>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<Button
|
|
data-testid="connect-vega-wallet"
|
|
onClick={() => setConnectDialog(true)}
|
|
size="sm"
|
|
>
|
|
<span className="whitespace-nowrap">{t('Connect Vega wallet')}</span>
|
|
</Button>
|
|
);
|
|
};
|
|
|
|
const KeypairItem = ({ kp }: { kp: string }) => {
|
|
const [copied, setCopied] = useState(false);
|
|
useEffect(() => {
|
|
// eslint-disable-next-line
|
|
let timeout: any;
|
|
|
|
if (copied) {
|
|
timeout = setTimeout(() => {
|
|
setCopied(false);
|
|
}, 800);
|
|
}
|
|
|
|
return () => {
|
|
clearTimeout(timeout);
|
|
};
|
|
}, [copied]);
|
|
|
|
return (
|
|
<DropdownMenuRadioItem key={kp} value={kp}>
|
|
<div className="flex-1 mr-2" data-testid={`key-${kp}`}>
|
|
<span className="mr-2">
|
|
<span>{truncateByChars(kp)}</span>
|
|
</span>
|
|
<span>
|
|
<CopyToClipboard text={kp} onCopy={() => setCopied(true)}>
|
|
<button
|
|
data-testid="copy-vega-public-key"
|
|
onClick={(e) => e.stopPropagation()}
|
|
>
|
|
<span className="sr-only">{t('Copy')}</span>
|
|
<Icon name="duplicate" className="mr-2" />
|
|
</button>
|
|
</CopyToClipboard>
|
|
{copied && (
|
|
<span className="text-xs text-neutral-500">{t('Copied')}</span>
|
|
)}
|
|
</span>
|
|
</div>
|
|
<DropdownMenuItemIndicator />
|
|
</DropdownMenuRadioItem>
|
|
);
|
|
};
|