diff --git a/apps/recovery-utility/renderer/components/Modals/WithdrawModal/SignTransaction/index.tsx b/apps/recovery-utility/renderer/components/Modals/WithdrawModal/SignTransaction/index.tsx index afd3db5a..a9611eda 100644 --- a/apps/recovery-utility/renderer/components/Modals/WithdrawModal/SignTransaction/index.tsx +++ b/apps/recovery-utility/renderer/components/Modals/WithdrawModal/SignTransaction/index.tsx @@ -1,5 +1,17 @@ -import { ReactNode, useEffect } from 'react'; -import { Typography, Box, Grid, List, ListItem, ListItemIcon, ListItemText, SxProps, Theme } from '@mui/material'; +import { ReactNode } from 'react'; +import { + Typography, + Box, + Grid, + List, + ListItem, + ListItemIcon, + ListItemText, + SxProps, + Theme, + Tooltip, + IconButton, +} from '@mui/material'; import { VaultAccount, RelayRxTx, @@ -14,7 +26,7 @@ import { useWrappedState, } from '@fireblocks/recovery-shared'; import { AssetConfig } from '@fireblocks/asset-config'; -import { CallMade, CallReceived, LeakAdd, Toll } from '@mui/icons-material'; +import { CallMade, CallReceived, LeakAdd, Toll, FileCopy } from '@mui/icons-material'; import { useWorkspace } from '../../../../context/Workspace'; import { useSettings } from '../../../../context/Settings'; import { SigningWallet } from '../../../../lib/wallets/SigningWallet'; @@ -40,6 +52,7 @@ const textOverflowStyles: SxProps = { textOverflow: 'ellipsis', whiteSpace: 'nowrap', overflow: 'hidden', + userSelect: 'text', }; type Props = { @@ -123,6 +136,10 @@ export const SignTransaction = ({ txId, account, asset, inboundRelayParams }: Pr ); }; + const handleCopyClick = (textToCopy: string) => { + navigator.clipboard.writeText(textToCopy); + }; + if (inboundRelayParams.accountId !== account.id || unsignedTx.path[2] !== account.id) { return Unexpected account ID from Recovery Relay.; } @@ -134,7 +151,7 @@ export const SignTransaction = ({ txId, account, asset, inboundRelayParams }: Pr if (unsignedTx.id !== txId) { return Unexpected transaction ID from Recovery Relay.; } - + let fromAddressRef; return ( {outboundRelayUrl ? ( @@ -162,6 +179,17 @@ export const SignTransaction = ({ txId, account, asset, inboundRelayParams }: Pr secondaryTypographyProps={{ display: 'flex', alignItems: 'center', sx: textOverflowStyles }} /> + + + + + + @@ -173,9 +201,16 @@ export const SignTransaction = ({ txId, account, asset, inboundRelayParams }: Pr {account.name} - - {unsignedTx.from} - + + handleCopyClick(unsignedTx.from)}> + + + + + + {unsignedTx.from} + + } primaryTypographyProps={{ fontWeight: '600', color: '#000' }} @@ -188,18 +223,20 @@ export const SignTransaction = ({ txId, account, asset, inboundRelayParams }: Pr - - - - - - + + handleCopyClick(unsignedTx.to)}> + + + + + + {unsignedTx.to} + + + + } primaryTypographyProps={{ fontWeight: '600', color: '#000' }} secondaryTypographyProps={{ fontFamily: monospaceFontFamily, sx: textOverflowStyles }} /> diff --git a/apps/recovery-utility/renderer/pages/setup.tsx b/apps/recovery-utility/renderer/pages/setup.tsx index 44f3e0d7..da119590 100644 --- a/apps/recovery-utility/renderer/pages/setup.tsx +++ b/apps/recovery-utility/renderer/pages/setup.tsx @@ -247,7 +247,7 @@ const Setup = () => { primaryTypographyProps={{ variant: 'h2' }} secondary={ - If you already have a privatae-public key pair, you can simply upload the public key here instead of generating a + If you already have a private-public key pair, you can simply upload the public key here instead of generating a public key }