mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-26 12:29:06 +01:00
ab4843f06b
* UX: Multichain: Implement Account Details Popover * Styling account details popover * using ButtonSecondary with variant, removing Text * adding account-details jest test * Close popover when outside area clicked * Move all export functionality into the popover * Improve jest tests * Implement new design for export key screens * Hide warning when popover is closed * Vertically align the copy button * Move AccountDetailsDisplay to its own file * Move authentication to its own file * Move private key to its own component * Fix misalignment of avatar on display screen * Move private key to its own component * Update ui/components/multichain/account-details/account-details-authenticate.js Co-authored-by: Nidhi Kumari <nidhi.kumari@consensys.net> * Update ui/components/multichain/account-details/account-details.test.js Co-authored-by: Nidhi Kumari <nidhi.kumari@consensys.net> * Prevent account name overflow, update text size * Use FormTextField * Add analytics * Move location of accountDetailsAddress * Ensure passsword input is used --------- Co-authored-by: Victor Thomas <10986371+vthomas13@users.noreply.github.com> Co-authored-by: Nidhi Kumari <nidhi.kumari@consensys.net>
182 lines
5.4 KiB
JavaScript
182 lines
5.4 KiB
JavaScript
import React, { useContext } from 'react';
|
|
import { useDispatch, useSelector } from 'react-redux';
|
|
import { useHistory } from 'react-router-dom';
|
|
import PropTypes from 'prop-types';
|
|
import { getAccountLink } from '@metamask/etherscan-link';
|
|
import { MetaMetricsContext } from '../../../contexts/metametrics';
|
|
import { useI18nContext } from '../../../hooks/useI18nContext';
|
|
import {
|
|
getRpcPrefsForCurrentProvider,
|
|
getBlockExplorerLinkText,
|
|
getCurrentChainId,
|
|
getHardwareWalletType,
|
|
getAccountTypeForKeyring,
|
|
} from '../../../selectors';
|
|
import { findKeyringForAddress } from '../../../ducks/metamask/metamask';
|
|
import { NETWORKS_ROUTE } from '../../../helpers/constants/routes';
|
|
import { Menu, MenuItem } from '../../ui/menu';
|
|
import { Text, IconName } from '../../component-library';
|
|
import {
|
|
MetaMetricsEventCategory,
|
|
MetaMetricsEventLinkType,
|
|
MetaMetricsEventName,
|
|
} from '../../../../shared/constants/metametrics';
|
|
import { getURLHostName } from '../../../helpers/utils/util';
|
|
import { setAccountDetailsAddress, showModal } from '../../../store/actions';
|
|
import { TextVariant } from '../../../helpers/constants/design-system';
|
|
import { formatAccountType } from '../../../helpers/utils/metrics';
|
|
|
|
export const AccountListItemMenu = ({
|
|
anchorElement,
|
|
blockExplorerUrlSubTitle,
|
|
onClose,
|
|
closeMenu,
|
|
isRemovable,
|
|
identity,
|
|
}) => {
|
|
const t = useI18nContext();
|
|
const trackEvent = useContext(MetaMetricsContext);
|
|
const dispatch = useDispatch();
|
|
const history = useHistory();
|
|
|
|
const chainId = useSelector(getCurrentChainId);
|
|
const rpcPrefs = useSelector(getRpcPrefsForCurrentProvider);
|
|
const addressLink = getAccountLink(identity.address, chainId, rpcPrefs);
|
|
|
|
const deviceName = useSelector(getHardwareWalletType);
|
|
|
|
const keyring = useSelector((state) =>
|
|
findKeyringForAddress(state, identity.address),
|
|
);
|
|
const accountType = formatAccountType(getAccountTypeForKeyring(keyring));
|
|
|
|
const blockExplorerLinkText = useSelector(getBlockExplorerLinkText);
|
|
const openBlockExplorer = () => {
|
|
trackEvent({
|
|
event: MetaMetricsEventName.ExternalLinkClicked,
|
|
category: MetaMetricsEventCategory.Navigation,
|
|
properties: {
|
|
link_type: MetaMetricsEventLinkType.AccountTracker,
|
|
location: 'Account Options',
|
|
url_domain: getURLHostName(addressLink),
|
|
},
|
|
});
|
|
|
|
global.platform.openTab({
|
|
url: addressLink,
|
|
});
|
|
onClose();
|
|
};
|
|
|
|
const routeToAddBlockExplorerUrl = () => {
|
|
history.push(`${NETWORKS_ROUTE}#blockExplorerUrl`);
|
|
};
|
|
|
|
return (
|
|
<Menu
|
|
anchorElement={anchorElement}
|
|
className="account-list-item-menu"
|
|
onHide={onClose}
|
|
>
|
|
<MenuItem
|
|
onClick={() => {
|
|
blockExplorerLinkText.firstPart === 'addBlockExplorer'
|
|
? routeToAddBlockExplorerUrl()
|
|
: openBlockExplorer();
|
|
|
|
trackEvent({
|
|
event: MetaMetricsEventName.BlockExplorerLinkClicked,
|
|
category: MetaMetricsEventCategory.Accounts,
|
|
properties: {
|
|
location: 'Account Options',
|
|
chain_id: chainId,
|
|
},
|
|
});
|
|
}}
|
|
subtitle={blockExplorerUrlSubTitle || null}
|
|
iconName={IconName.Export}
|
|
data-testid="account-list-menu-open-explorer"
|
|
>
|
|
<Text variant={TextVariant.bodySm}>{t('viewOnExplorer')}</Text>
|
|
</MenuItem>
|
|
<MenuItem
|
|
onClick={() => {
|
|
dispatch(setAccountDetailsAddress(identity.address));
|
|
trackEvent({
|
|
event: MetaMetricsEventName.NavAccountDetailsOpened,
|
|
category: MetaMetricsEventCategory.Navigation,
|
|
properties: {
|
|
location: 'Account Options',
|
|
},
|
|
});
|
|
onClose();
|
|
closeMenu?.();
|
|
}}
|
|
iconName={IconName.ScanBarcode}
|
|
>
|
|
<Text variant={TextVariant.bodySm}>{t('accountDetails')}</Text>
|
|
</MenuItem>
|
|
{isRemovable ? (
|
|
<MenuItem
|
|
data-testid="account-list-menu-remove"
|
|
onClick={() => {
|
|
dispatch(
|
|
showModal({
|
|
name: 'CONFIRM_REMOVE_ACCOUNT',
|
|
identity,
|
|
}),
|
|
);
|
|
trackEvent({
|
|
event: MetaMetricsEventName.AccountRemoved,
|
|
category: MetaMetricsEventCategory.Accounts,
|
|
properties: {
|
|
account_hardware_type: deviceName,
|
|
chain_id: chainId,
|
|
account_type: accountType,
|
|
},
|
|
});
|
|
onClose();
|
|
}}
|
|
iconName={IconName.Trash}
|
|
>
|
|
<Text variant={TextVariant.bodySm}>{t('removeAccount')}</Text>
|
|
</MenuItem>
|
|
) : null}
|
|
</Menu>
|
|
);
|
|
};
|
|
|
|
AccountListItemMenu.propTypes = {
|
|
/**
|
|
* Element that the menu should display next to
|
|
*/
|
|
anchorElement: PropTypes.instanceOf(window.Element),
|
|
/**
|
|
* Function that executes when the menu is closed
|
|
*/
|
|
onClose: PropTypes.func.isRequired,
|
|
/**
|
|
* Function that closes the menu
|
|
*/
|
|
closeMenu: PropTypes.func,
|
|
/**
|
|
* Domain of the block explorer
|
|
*/
|
|
blockExplorerUrlSubTitle: PropTypes.string,
|
|
/**
|
|
* Represents if the account should be removable
|
|
*/
|
|
isRemovable: PropTypes.bool.isRequired,
|
|
/**
|
|
* Identity of the account
|
|
*/
|
|
/**
|
|
* Identity of the account
|
|
*/
|
|
identity: PropTypes.shape({
|
|
name: PropTypes.string.isRequired,
|
|
address: PropTypes.string.isRequired,
|
|
balance: PropTypes.string.isRequired,
|
|
}).isRequired,
|
|
};
|