mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
109 lines
3.2 KiB
JavaScript
109 lines
3.2 KiB
JavaScript
import React from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import { useSelector } from 'react-redux';
|
|
import Box from '../../../../components/ui/box';
|
|
import SiteIcon from '../../../../components/ui/site-icon';
|
|
import Typography from '../../../../components/ui/typography/typography';
|
|
import {
|
|
TypographyVariant,
|
|
FontWeight,
|
|
Display,
|
|
JustifyContent,
|
|
BlockSize,
|
|
AlignItems,
|
|
TextAlign,
|
|
TextColor,
|
|
} from '../../../../helpers/constants/design-system';
|
|
import {
|
|
CHAIN_ID_TO_NETWORK_IMAGE_URL_MAP,
|
|
NETWORK_TO_NAME_MAP,
|
|
} from '../../../../../shared/constants/network';
|
|
import { getProviderConfig } from '../../../../ducks/metamask/metamask';
|
|
|
|
export default function ConfirmationNetworkSwitch({ newNetwork }) {
|
|
const { chainId, nickname, type } = useSelector(getProviderConfig);
|
|
|
|
return (
|
|
<Box
|
|
className="confirmation-network-switch"
|
|
display={Display.Flex}
|
|
height={BlockSize.Full}
|
|
justifyContent={JustifyContent.center}
|
|
marginTop={8}
|
|
>
|
|
<Box
|
|
className="confirmation-network-switch__icon"
|
|
display={Display.Block}
|
|
>
|
|
{chainId in CHAIN_ID_TO_NETWORK_IMAGE_URL_MAP ? (
|
|
<SiteIcon
|
|
icon={CHAIN_ID_TO_NETWORK_IMAGE_URL_MAP[chainId]}
|
|
name={nickname}
|
|
size={64}
|
|
/>
|
|
) : (
|
|
<div className="confirmation-network-switch__unknown-icon">
|
|
<i className="fa fa-question fa-2x" />
|
|
</div>
|
|
)}
|
|
<Typography
|
|
color={TextColor.textDefault}
|
|
variant={TypographyVariant.H6}
|
|
fontWeight={FontWeight.Normal}
|
|
align={TextAlign.Center}
|
|
boxProps={{
|
|
display: Display.Flex,
|
|
justifyContent: JustifyContent.center,
|
|
}}
|
|
>
|
|
{nickname || NETWORK_TO_NAME_MAP[type]}
|
|
</Typography>
|
|
</Box>
|
|
<Box
|
|
className="confirmation-network-switch__center-icon"
|
|
display={Display.Flex}
|
|
alignItems={AlignItems.center}
|
|
justifyContent={JustifyContent.center}
|
|
>
|
|
<i className="fa fa-angle-right fa-lg confirmation-network-switch__check" />
|
|
<div className="confirmation-network-switch__dashed-line" />
|
|
</Box>
|
|
<Box
|
|
className="confirmation-network-switch__icon"
|
|
display={Display.Block}
|
|
>
|
|
{newNetwork.chainId in CHAIN_ID_TO_NETWORK_IMAGE_URL_MAP ? (
|
|
<SiteIcon
|
|
icon={CHAIN_ID_TO_NETWORK_IMAGE_URL_MAP[newNetwork.chainId]}
|
|
name={newNetwork.nickname}
|
|
size={64}
|
|
/>
|
|
) : (
|
|
<div className="confirmation-network-switch__unknown-icon">
|
|
<i className="fa fa-question fa-2x" />
|
|
</div>
|
|
)}
|
|
<Typography
|
|
color={TextColor.textDefault}
|
|
variant={TypographyVariant.H6}
|
|
fontWeight={FontWeight.Normal}
|
|
align={TextAlign.Center}
|
|
boxProps={{
|
|
display: Display.Flex,
|
|
justifyContent: JustifyContent.center,
|
|
}}
|
|
>
|
|
{newNetwork.nickname}
|
|
</Typography>
|
|
</Box>
|
|
</Box>
|
|
);
|
|
}
|
|
|
|
ConfirmationNetworkSwitch.propTypes = {
|
|
newNetwork: PropTypes.shape({
|
|
chainId: PropTypes.string.isRequired,
|
|
nickname: PropTypes.string.isRequired,
|
|
}),
|
|
};
|